/* ============================================================
   Life Dashboard - design system
   Dark #0b0c0b base, lime #b3c46a accent, Outfit type.
   Mobile-first (Samsung S24 Ultra), desktop enhanced at 720px.
   ============================================================ */

:root{
  --bg:#0b0c0b;
  --surface-1:#131613;
  --surface-2:#1b1f1a;
  --surface-3:#232821;
  --line:#2a2f27;
  --line-soft:#20241d;

  --lime:#b3c46a;
  --lime-bright:#c6d77b;
  --lime-dim:rgba(179,196,106,.14);
  --lime-glow:rgba(179,196,106,.30);

  --text:#e9ebe2;
  --text-dim:#9aa18f;
  --text-faint:#6a7162;

  --danger:#d96a5e;
  --warn:#d8b15a;
  --info:#7fb0c4;

  --r-sm:9px;
  --r:14px;
  --r-lg:20px;
  --r-pill:999px;

  --pad:16px;
  --gap:12px;
  --tap:46px;

  --shadow:0 6px 22px rgba(0,0,0,.45);
  --font:'Outfit',-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,sans-serif;
}

*{box-sizing:border-box;margin:0;padding:0}
html{-webkit-text-size-adjust:100%}
body{
  font-family:var(--font);
  background:var(--bg);
  color:var(--text);
  line-height:1.5;
  -webkit-font-smoothing:antialiased;
  min-height:100vh;
  min-height:100dvh;
  overscroll-behavior-y:none;
}
.hidden{display:none !important}
button{font-family:inherit;cursor:pointer;color:inherit;background:none;border:none}
input,select,textarea{font-family:inherit;font-size:16px}/* 16px stops iOS/Android zoom */
svg{width:100%;height:100%;fill:none;stroke:currentColor;stroke-width:1.9;
  stroke-linecap:round;stroke-linejoin:round}
:focus-visible{outline:2px solid var(--lime);outline-offset:2px;border-radius:4px}

/* ---------- AUTH ---------- */
.auth{
  min-height:100dvh;display:flex;flex-direction:column;align-items:center;
  justify-content:center;padding:28px;gap:22px;
  background:radial-gradient(120% 80% at 50% -10%,rgba(179,196,106,.10),transparent 60%),var(--bg);
}
.auth-card{
  width:100%;max-width:380px;background:var(--surface-1);
  border:1px solid var(--line);border-radius:var(--r-lg);
  padding:30px 24px;box-shadow:var(--shadow);
}
.brand{display:flex;align-items:center;gap:11px;margin-bottom:6px}
.brand-mark{width:30px;height:30px;border-radius:9px;
  background:linear-gradient(150deg,var(--lime),#7e8f3f);
  box-shadow:0 0 18px var(--lime-glow);flex:none}
.brand-name{font-size:22px;font-weight:700;letter-spacing:-.02em}
.brand-name span{color:var(--lime);font-weight:500}
.auth-sub{color:var(--text-dim);margin:14px 0 22px;font-size:15px}
.auth-form{display:flex;flex-direction:column;gap:15px}
.auth-error{color:var(--danger);font-size:13.5px;min-height:1.1em;font-weight:500}
.auth-foot{color:var(--text-faint);font-size:12.5px;letter-spacing:.04em}

/* ---------- FIELDS ---------- */
.field{display:flex;flex-direction:column;gap:7px}
.field>span{font-size:12.5px;color:var(--text-dim);font-weight:500;
  text-transform:uppercase;letter-spacing:.06em}
input[type=text],input[type=password],input[type=number],input[type=date],
input[type=time],select,textarea{
  width:100%;background:var(--surface-2);border:1px solid var(--line);
  color:var(--text);padding:12px 14px;border-radius:var(--r-sm);min-height:var(--tap);
  transition:border-color .15s,background .15s}
textarea{min-height:84px;resize:vertical;line-height:1.45}
input:focus,select:focus,textarea:focus{border-color:var(--lime);
  background:var(--surface-3);outline:none}
select{appearance:none;-webkit-appearance:none;
  background-image:linear-gradient(45deg,transparent 50%,var(--text-dim) 50%),
    linear-gradient(135deg,var(--text-dim) 50%,transparent 50%);
  background-position:calc(100% - 18px) 50%,calc(100% - 13px) 50%;
  background-size:5px 5px,5px 5px;background-repeat:no-repeat;padding-right:36px}
::placeholder{color:var(--text-faint)}

/* ---------- BUTTONS ---------- */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;
  min-height:var(--tap);padding:0 18px;border-radius:var(--r-sm);
  font-weight:600;font-size:15px;border:1px solid transparent;
  transition:transform .08s,background .15s,border-color .15s}
.btn:active{transform:scale(.97)}
.btn-block{width:100%}
.btn-primary{background:var(--lime);color:#16190d;box-shadow:0 4px 16px var(--lime-glow)}
.btn-primary:hover{background:var(--lime-bright)}
.btn-ghost{background:var(--surface-2);border-color:var(--line);color:var(--text)}
.btn-ghost:hover{background:var(--surface-3)}
.btn-danger{background:transparent;border-color:transparent;color:var(--danger)}
.btn-sm{min-height:38px;padding:0 13px;font-size:13.5px}
.btn-icon{width:var(--tap);min-height:var(--tap);padding:0;flex:none}
.btn svg{width:18px;height:18px}

/* ---------- APP LAYOUT ---------- */
.app{min-height:100dvh;display:flex;flex-direction:column;padding-bottom:78px}
.topbar{position:sticky;top:0;z-index:30;display:flex;align-items:center;
  justify-content:space-between;padding:14px var(--pad) 12px;
  background:linear-gradient(var(--bg) 72%,transparent);
  backdrop-filter:blur(4px)}
.topbar-left{display:flex;align-items:center;gap:10px}
.topbar h2{font-size:21px;font-weight:700;letter-spacing:-.02em}
.dot{width:9px;height:9px;border-radius:50%;background:var(--lime);
  box-shadow:0 0 8px var(--lime-glow);flex:none;transition:background .3s}
.dot.offline{background:var(--warn);box-shadow:none}
.date-pill{font-size:13px;color:var(--text-dim);background:var(--surface-1);
  border:1px solid var(--line-soft);padding:6px 12px;border-radius:var(--r-pill);
  white-space:nowrap}

.view{flex:1;padding:4px var(--pad) 24px;animation:fade .25s ease}
@keyframes fade{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:none}}

/* ---------- TAB BAR ---------- */
.tabbar{position:fixed;bottom:0;left:0;right:0;z-index:40;display:flex;
  background:var(--surface-1);border-top:1px solid var(--line);
  padding:8px 6px calc(8px + env(safe-area-inset-bottom))}
.tab{flex:1;display:flex;flex-direction:column;align-items:center;gap:3px;
  padding:5px 0;color:var(--text-faint);font-size:10.5px;font-weight:500;
  border-radius:var(--r-sm);transition:color .15s}
.tab svg{width:23px;height:23px}
.tab.is-active{color:var(--lime)}
.tab.is-active svg{filter:drop-shadow(0 0 6px var(--lime-glow))}

/* ---------- CARDS ---------- */
.card{background:var(--surface-1);border:1px solid var(--line-soft);
  border-radius:var(--r);padding:var(--pad);margin-bottom:var(--gap)}
.card-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:13px}
.card-head h3{font-size:15px;font-weight:600;letter-spacing:-.01em}
.card-head .sub{font-size:12px;color:var(--text-faint)}
.section-label{font-size:12px;font-weight:600;text-transform:uppercase;
  letter-spacing:.08em;color:var(--text-faint);margin:22px 2px 10px}
.section-label:first-child{margin-top:6px}

/* ---------- TODAY COCKPIT (signature) ---------- */
.cockpit{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--gap);margin-bottom:6px}
.stat{position:relative;background:var(--surface-1);border:1px solid var(--line-soft);
  border-radius:var(--r);padding:15px;overflow:hidden}
.stat .label{font-size:12px;color:var(--text-dim);font-weight:500;
  display:flex;align-items:center;gap:6px}
.stat .label svg{width:15px;height:15px;color:var(--lime)}
.stat .big{font-size:30px;font-weight:700;letter-spacing:-.03em;margin-top:7px;
  font-variant-numeric:tabular-nums}
.stat .big small{font-size:14px;font-weight:500;color:var(--text-faint)}
.stat .meta{font-size:12px;color:var(--text-faint);margin-top:2px}
.stat.wide{grid-column:1 / -1}

/* progress ring */
.ring{--p:0;width:54px;height:54px;flex:none;border-radius:50%;
  background:conic-gradient(var(--lime) calc(var(--p)*1%),var(--surface-3) 0);
  display:grid;place-items:center;position:absolute;top:13px;right:13px}
.ring::after{content:'';width:42px;height:42px;border-radius:50%;background:var(--surface-1)}
.ring .pct{position:absolute;font-size:12px;font-weight:600;color:var(--lime)}

/* progress bar */
.bar{height:8px;background:var(--surface-3);border-radius:var(--r-pill);overflow:hidden;margin-top:11px}
.bar>i{display:block;height:100%;background:linear-gradient(90deg,#8fa04f,var(--lime));
  border-radius:inherit;transition:width .4s ease}

/* quick log row */
.quick{display:flex;gap:9px;flex-wrap:wrap}
.chip{display:inline-flex;align-items:center;gap:7px;background:var(--surface-2);
  border:1px solid var(--line);border-radius:var(--r-pill);padding:9px 15px;
  font-size:14px;font-weight:500;min-height:42px;transition:transform .08s,border-color .15s,background .15s}
.chip:active{transform:scale(.95)}
.chip.lime{border-color:var(--lime);color:var(--lime);background:var(--lime-dim)}
.chip svg{width:16px;height:16px}

/* mood selector */
.mood-row{display:flex;gap:8px;justify-content:space-between}
.mood{flex:1;aspect-ratio:1;max-width:60px;border-radius:var(--r-sm);
  background:var(--surface-2);border:1px solid var(--line);font-size:23px;
  display:grid;place-items:center;transition:transform .08s,border-color .15s,background .15s}
.mood:active{transform:scale(.92)}
.mood.sel{border-color:var(--lime);background:var(--lime-dim);box-shadow:0 0 0 1px var(--lime) inset}

/* ---------- LISTS / ROWS ---------- */
.row{display:flex;align-items:center;gap:12px;padding:13px 0;border-bottom:1px solid var(--line-soft)}
.row:last-child{border-bottom:none}
.row .grow{flex:1;min-width:0}
.row .title{font-size:15px;font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.row .meta{font-size:12.5px;color:var(--text-faint);margin-top:2px}
.row.done .title{color:var(--text-faint);text-decoration:line-through}

.check{width:26px;height:26px;border-radius:8px;border:1.8px solid var(--line);
  flex:none;display:grid;place-items:center;transition:.15s;background:var(--surface-2)}
.check.on{background:var(--lime);border-color:var(--lime)}
.check svg{width:16px;height:16px;color:#16190d;opacity:0;stroke-width:2.6}
.check.on svg{opacity:1}

.pri{width:4px;align-self:stretch;border-radius:3px;background:var(--line);flex:none}
.pri.p2{background:var(--danger)}.pri.p1{background:var(--warn)}.pri.p0{background:var(--text-faint)}

.tag{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.05em;
  padding:3px 8px;border-radius:var(--r-pill);background:var(--surface-3);color:var(--text-dim)}
.tag.food{background:rgba(179,196,106,.16);color:var(--lime)}
.tag.clothing{background:rgba(127,176,196,.16);color:var(--info)}
.tag.online{background:rgba(216,177,90,.16);color:var(--warn)}

/* ---------- SEGMENTED / FILTER ---------- */
.seg{display:flex;background:var(--surface-2);border:1px solid var(--line);
  border-radius:var(--r-sm);padding:4px;gap:4px;margin-bottom:14px;overflow-x:auto}
.seg button{flex:1;white-space:nowrap;padding:9px 12px;border-radius:8px;font-size:13.5px;
  font-weight:500;color:var(--text-dim);transition:.15s}
.seg button.on{background:var(--lime);color:#16190d;font-weight:600}

/* ---------- HABIT GRID ---------- */
.habit{display:flex;align-items:center;gap:13px;padding:13px 0;border-bottom:1px solid var(--line-soft)}
.habit:last-child{border-bottom:none}
.habit .grow{flex:1;min-width:0}
.streak{display:inline-flex;align-items:center;gap:4px;font-size:13px;color:var(--lime);font-weight:600}
.week{display:flex;gap:4px;margin-top:6px}
.week i{width:13px;height:13px;border-radius:4px;background:var(--surface-3)}
.week i.on{background:var(--lime)}
.habit-toggle{width:30px;height:30px;border-radius:50%;border:2px solid var(--line);
  flex:none;display:grid;place-items:center;background:var(--surface-2);transition:.15s}
.habit-toggle.on{background:var(--lime);border-color:var(--lime)}
.habit-toggle svg{width:16px;height:16px;color:#16190d;opacity:0;stroke-width:2.8}
.habit-toggle.on svg{opacity:1}

/* ---------- MONEY ---------- */
.money-hero{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--gap);margin-bottom:var(--gap)}
.money-hero .stat .big{font-size:20px}
.catbar{display:flex;align-items:center;gap:10px;padding:9px 0}
.catbar .name{font-size:13.5px;width:84px;flex:none;color:var(--text-dim);text-transform:capitalize}
.catbar .track{flex:1;height:9px;background:var(--surface-3);border-radius:var(--r-pill);overflow:hidden}
.catbar .track>i{display:block;height:100%;background:var(--lime);border-radius:inherit}
.catbar .val{font-size:13px;font-variant-numeric:tabular-nums;width:64px;text-align:right;flex:none}
.ratio{font-size:13px;font-weight:600}
.ratio.good{color:var(--lime)}.ratio.warn{color:var(--warn)}.ratio.bad{color:var(--danger)}

/* ---------- MISC ---------- */
.empty{text-align:center;padding:40px 18px;color:var(--text-faint)}
.empty svg{width:34px;height:34px;margin-bottom:10px;opacity:.5}
.empty p{font-size:14px}
.fab{position:fixed;right:16px;bottom:90px;z-index:35;width:54px;height:54px;
  border-radius:50%;background:var(--lime);color:#16190d;display:grid;place-items:center;
  box-shadow:0 6px 20px var(--lime-glow)}
.fab svg{width:26px;height:26px;stroke-width:2.4}
.menu-list .row{cursor:pointer}
.menu-list .row svg{width:20px;height:20px;color:var(--text-dim);flex:none}
.kv{display:flex;justify-content:space-between;padding:11px 0;border-bottom:1px solid var(--line-soft);font-size:14px}
.kv:last-child{border:none}.kv .k{color:var(--text-dim)}

/* insight callout */
.insight{display:flex;gap:11px;padding:13px;background:var(--lime-dim);
  border:1px solid rgba(179,196,106,.25);border-radius:var(--r);margin-bottom:var(--gap)}
.insight svg{width:19px;height:19px;color:var(--lime);flex:none;margin-top:1px}
.insight p{font-size:13.5px;line-height:1.5}
.insight b{color:var(--lime);font-weight:600}

/* ---------- MODAL / SHEET ---------- */
.sheet-bg{position:fixed;inset:0;z-index:50;background:rgba(0,0,0,.6);
  display:flex;align-items:flex-end;justify-content:center;animation:fade .2s}
.sheet{width:100%;max-width:560px;background:var(--surface-1);
  border:1px solid var(--line);border-bottom:none;border-radius:var(--r-lg) var(--r-lg) 0 0;
  padding:20px var(--pad) calc(20px + env(safe-area-inset-bottom));
  max-height:88dvh;overflow-y:auto;animation:rise .28s cubic-bezier(.2,.8,.2,1)}
@keyframes rise{from{transform:translateY(100%)}to{transform:none}}
.sheet h3{font-size:18px;font-weight:700;margin-bottom:16px;letter-spacing:-.01em}
.sheet .field{margin-bottom:13px}
.sheet-actions{display:flex;gap:10px;margin-top:8px}
.sheet-actions .btn{flex:1}
.grab{width:36px;height:4px;border-radius:3px;background:var(--line);margin:0 auto 16px}

/* ---------- TOAST ---------- */
.toast{position:fixed;left:50%;bottom:96px;transform:translateX(-50%) translateY(20px);
  background:var(--surface-3);border:1px solid var(--line);color:var(--text);
  padding:11px 18px;border-radius:var(--r-pill);font-size:14px;font-weight:500;
  z-index:60;opacity:0;pointer-events:none;transition:.25s;box-shadow:var(--shadow);max-width:90vw}
.toast.show{opacity:1;transform:translateX(-50%) translateY(0)}
.toast.err{border-color:var(--danger);color:var(--danger)}

/* ---------- DESKTOP ---------- */
@media(min-width:720px){
  .app{padding-bottom:0;padding-left:0}
  .view{max-width:880px;margin:0 auto;width:100%;padding:10px 24px 60px}
  .topbar{max-width:880px;margin:0 auto;width:100%}
  .tabbar{left:50%;transform:translateX(-50%);max-width:560px;border-radius:var(--r-lg) var(--r-lg) 0 0;
    border:1px solid var(--line)}
  .cockpit{grid-template-columns:repeat(4,1fr)}
  .stat.wide{grid-column:span 2}
  .two-col{display:grid;grid-template-columns:1fr 1fr;gap:var(--gap);align-items:start}
}
@media(min-width:720px) and (max-width:1000px){.two-col{grid-template-columns:1fr}}

@media(prefers-reduced-motion:reduce){*{animation:none !important;transition:none !important}}

/* ============================================================
   v2 ADDITIONS
   ============================================================ */

/* Live MST clock under the greeting */
.clock-row{display:flex;align-items:baseline;gap:10px;margin-top:6px}
.live-clock{font-size:18px;font-weight:600;letter-spacing:-.01em;color:var(--lime,#b3c46a);font-variant-numeric:tabular-nums}
.clock-meta{color:var(--text-dim);font-size:12.5px}

/* Dual weather cards */
.weather-row{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:14px}
.weather-card{background:var(--card);border:1px solid var(--line);border-radius:var(--r-lg);padding:12px 14px;display:flex;flex-direction:column;gap:8px}
.wc-city{font-size:13px;color:var(--text-dim);text-transform:uppercase;letter-spacing:.06em;font-weight:600}
.wc-today{display:flex;align-items:baseline;gap:8px;flex-wrap:wrap}
.wc-temp{font-size:32px;font-weight:700;letter-spacing:-.02em;color:var(--text)}
.wc-desc{font-size:13px;color:var(--text-dim);text-transform:capitalize}
.wc-tom{display:flex;flex-wrap:wrap;align-items:baseline;gap:8px;padding-top:8px;border-top:1px dashed var(--line)}
.wc-tom-label{font-size:11px;color:var(--text-dim);text-transform:uppercase;letter-spacing:.06em;font-weight:600;flex-basis:100%}
.wc-tom-hilo{font-size:14px;font-weight:600;color:var(--text)}
.wc-tom-desc{font-size:12.5px;color:var(--text-dim);text-transform:capitalize}
.wc-tom-pop{font-size:12px;color:var(--text-dim)}

/* Calendar event list */
.cal-list{padding:0 12px 12px}
.cal-row{display:grid;grid-template-columns:80px 1fr;gap:6px 12px;padding:10px 0;border-bottom:1px solid var(--line)}
.cal-row:last-child{border-bottom:none}
.cal-when{display:flex;flex-direction:column;line-height:1.2}
.cal-day{font-size:11.5px;color:var(--text-dim);text-transform:uppercase;letter-spacing:.04em;font-weight:600}
.cal-time{font-size:14px;font-weight:600;color:var(--text);font-variant-numeric:tabular-nums}
.cal-title{font-size:14px;font-weight:500;color:var(--text)}
.cal-loc{grid-column:2;font-size:12px;color:var(--text-dim)}

/* Calendar filter picker */
.cal-pick{display:flex;align-items:center;gap:10px;padding:10px 4px;border-bottom:1px solid var(--line)}
.cal-pick:last-child{border-bottom:none}
.cal-pick input{width:18px;height:18px;margin:0}
.cal-pick .dot{width:12px;height:12px;border-radius:50%;flex:none}

/* Needs attention card */
.alert-card{border-color:var(--warn,#e3a02f)}
.alert-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px;padding:0 14px 14px}
.alert-pill{background:rgba(179,196,106,0.12);border:1px solid var(--line);border-radius:var(--r-pill);padding:8px 12px;font-size:13px;text-align:center;color:var(--text)}
.alert-pill.warn{background:rgba(227,160,47,0.13);border-color:var(--warn,#e3a02f);color:var(--warn,#e3a02f)}
.alert-pill b{font-size:16px;margin-right:4px}

/* 10/30-day rollup list */
.rollup-list{padding:0 12px 12px}
.rl-row{padding:8px 0;border-bottom:1px solid var(--line)}
.rl-row:last-child{border-bottom:none}
.rl-date{font-size:12px;color:var(--text-dim);font-weight:600;text-transform:uppercase;letter-spacing:.05em;margin-bottom:4px}
.rl-cells{display:flex;flex-wrap:wrap;gap:10px;font-size:13px;color:var(--text);font-variant-numeric:tabular-nums}
.rl-cells span{min-width:0}
.rl-cells span:empty{display:none}
.rl-work-row{margin-top:4px;font-size:12px;color:var(--text-dim);display:flex;gap:8px;flex-wrap:wrap}
.rl-work{padding:2px 6px;background:rgba(255,255,255,0.04);border-radius:var(--r-pill);font-size:11.5px}

/* Chip selected state — already exists usually but add fallback */
.chip.sel{background:var(--lime,#b3c46a);color:#0b0c0b;border-color:var(--lime,#b3c46a)}

@media (max-width:380px){
  .weather-row{grid-template-columns:1fr}
  .alert-grid{grid-template-columns:1fr}
  .cal-row{grid-template-columns:64px 1fr}
}
