:root{
  --mint:#0c8c5e; --ink:#08090a; --black:#000; --paper:#fff;
  --mist:#f2f2f2; --cloud:#dddddd;
  --font:'MiSansLatin',-apple-system,"PingFang HK","PingFang TC","Microsoft JhengHei",ui-sans-serif,system-ui,"Segoe UI",Roboto,sans-serif;
  --r-card:16px; --r-btn:4px;
  --sh:lab(100 0 0 / 0.05) 0px 2px 4px 0px;
  --red:#d62828; --green:#0c8c5e; --amber:#e8a317;
}
*{box-sizing:border-box;margin:0;padding:0;-webkit-tap-highlight-color:transparent}
html{touch-action:manipulation;-webkit-text-size-adjust:100%;text-size-adjust:100%}
html,body{background:var(--paper);color:var(--black);font-family:var(--font);
  font-feature-settings:"ss01" on,"cv11" on;-webkit-font-smoothing:antialiased;
  overscroll-behavior:none;-webkit-user-select:none;user-select:none}
input,select{-webkit-user-select:text;user-select:text}
body{padding-bottom:calc(64px + env(safe-area-inset-bottom))}
.app{max-width:640px;margin:0 auto;padding:24px 16px 16px}

.page{display:none}
.page.active{display:block}
.page-head{margin-bottom:20px}
.eyebrow{display:block;font-size:13px;font-weight:500;color:var(--mint);
  letter-spacing:.65px;text-transform:uppercase;margin-bottom:6px}
h1{font-size:24px;font-weight:600;letter-spacing:-.24px;line-height:1.33}

.cards{display:flex;flex-direction:column;gap:12px}
.card{background:var(--paper);border:1px solid var(--mist);border-radius:var(--r-card);
  padding:20px;box-shadow:var(--sh)}
.card-top{display:flex;justify-content:space-between;align-items:flex-start;gap:8px}
.card-title{font-size:16px;font-weight:600;color:var(--ink);line-height:1.3}
.card-sub{font-size:13px;color:#666;margin-top:2px}
.card-del{background:none;border:none;color:#999;font-size:13px;
  font-weight:500;cursor:pointer;padding:4px}

.eta-row{display:flex;align-items:baseline;gap:8px;margin-top:14px;flex-wrap:wrap}
.eta-big{font-size:40px;font-weight:600;letter-spacing:-.4px;line-height:1;color:var(--ink)}
.eta-unit{font-size:15px;color:#666}
.eta-next{font-size:14px;color:#666;margin-top:8px}
.eta-soon{color:var(--mint)}
.eta-err{font-size:14px;color:#999;margin-top:12px}
.loading{font-size:14px;color:#999;margin-top:12px}

.empty{text-align:center;color:#999;font-size:14px;padding:40px 0}

.btn-add{display:block;width:100%;margin-top:16px;padding:12px;
  background:none;border:1px dashed var(--cloud);border-radius:var(--r-btn);
  color:var(--ink);font-family:var(--font);font-size:15px;font-weight:500;cursor:pointer}
.btn-add:active{background:var(--mist)}

.tabbar{position:fixed;left:0;right:0;bottom:0;display:flex;background:var(--paper);
  border-top:1px solid var(--mist);padding-bottom:env(safe-area-inset-bottom);z-index:10}
.tab{flex:1;border:none;background:none;padding:10px 0 12px;font-family:var(--font);
  font-size:11px;font-weight:500;color:#999;cursor:pointer;display:flex;
  flex-direction:column;align-items:center;gap:3px}
.tab .ti{font-size:22px;filter:grayscale(1);opacity:.6}
.tab.active{color:var(--mint)}
.tab.active .ti{filter:none;opacity:1}

.modal-bg{position:fixed;inset:0;background:rgba(0,0,0,.4);z-index:50;
  display:flex;align-items:flex-end;justify-content:center}
.modal{background:var(--paper);width:100%;max-width:640px;border-radius:24px 24px 0 0;
  padding:24px 16px calc(24px + env(safe-area-inset-bottom));max-height:90vh;overflow:auto}
.modal h2{font-size:20px;font-weight:600;letter-spacing:-.2px;margin-bottom:16px}
.field{margin-bottom:14px}
.field label{display:block;font-size:13px;font-weight:500;color:#444;margin-bottom:6px}
select,input{width:100%;padding:11px 12px;border:1px solid var(--cloud);
  border-radius:var(--r-btn);font-family:var(--font);font-size:16px;background:var(--paper);color:var(--black)}
.btn{width:100%;padding:13px;border:none;border-radius:var(--r-btn);
  background:var(--ink);color:var(--paper);font-family:var(--font);font-size:15px;
  font-weight:500;cursor:pointer;box-shadow:lab(2.4 -.16 -.47/.03) 0 2px 4px 0}
.btn:active{opacity:.85}
.btn-ghost{background:none;color:var(--ink);box-shadow:none;margin-top:8px}
.dir-toggle{display:flex;gap:8px}
.dir-toggle button{flex:1;padding:11px;border:1px solid var(--cloud);border-radius:var(--r-btn);
  background:var(--paper);font-family:var(--font);font-size:14px;font-weight:500;cursor:pointer;color:var(--black)}
.dir-toggle button.on{border-color:var(--mint);color:var(--mint);background:rgba(12,140,94,.06)}

.light-dot{width:14px;height:14px;border-radius:50%;display:inline-block;margin-right:6px}
.light-card .eta-big.red{color:var(--red)}
.light-card .eta-big.green{color:var(--green)}
.light-state{font-size:14px;font-weight:500;margin-top:2px}
.light-state.red{color:var(--red)}
.light-state.green{color:var(--green)}

.rec-steps{display:flex;flex-direction:column;gap:10px;margin:12px 0}
.rec-btn{padding:16px;border:1px solid var(--cloud);border-radius:var(--r-btn);
  background:var(--paper);font-family:var(--font);font-size:15px;font-weight:500;
  cursor:pointer;text-align:left;color:var(--black)}
.rec-btn.done{border-color:var(--mint);background:rgba(12,140,94,.06);color:var(--mint)}
.rec-btn.active{border-color:var(--ink);box-shadow:0 0 0 2px var(--ink) inset}
.rec-btn:disabled{opacity:.4;cursor:not-allowed}
.rec-hint{font-size:13px;color:#666;margin-top:4px}

.install-bar{display:none;position:fixed;left:0;right:0;
  bottom:calc(64px + env(safe-area-inset-bottom));align-items:center;gap:10px;
  background:var(--ink);color:var(--paper);padding:12px 16px;z-index:40;
  max-width:640px;margin:0 auto;border-radius:12px 12px 0 0}
.install-txt{flex:1;font-size:14px}
.install-btn{background:var(--mint);color:var(--paper);border:none;border-radius:var(--r-btn);
  padding:8px 16px;font-family:var(--font);font-size:14px;font-weight:500;cursor:pointer}
.install-x{background:none;border:none;color:#999;font-size:14px;cursor:pointer;padding:4px}
