/* CADENCE app — theme system v2 (A1 port, 2026-07-04).
   THREE MATERIALS: clay (dark, default) · paper (light) · void (AMOLED, flat).
   Monochrome "ink" accent until the A9 accent round. Tokens cover colour + radius
   + SHADOW + WASH so a material swap is pure tokens. Habit colours ride on pips. */

/* ---------- CLAY (dark · default) ---------- */
:root{
  --page:#1B171D; --card:#28222B; --card2:#241F27;
  --ink:#E6DDE2; --sub:#9b93a0; --faint:#6E6272; --line:rgba(255,255,255,.06);
  --track:#1E1A21; --checkline:#3a323e; --navoff:#6E6272;
  --a:#EDE7EC; --on:#221D25; --soft:rgba(237,231,236,.10);
  --danger:#E5484D;
  --wash:linear-gradient(150deg,rgba(157,184,220,.08),transparent 45%,rgba(242,164,143,.06) 85%);
  --sh-card:0 12px 26px rgba(0,0,0,.42), inset 0 1.5px 0 rgba(255,255,255,.07);
  --sh-row:0 8px 16px rgba(0,0,0,.3), inset 0 1px 0 rgba(255,255,255,.05);
  --sh-nav:0 14px 30px rgba(0,0,0,.55), inset 0 1.5px 0 rgba(255,255,255,.06);
  --sh-acc:0 8px 18px rgba(237,231,236,.12), inset 0 1.5px 0 rgba(255,255,255,.5);
  --sh-inset:inset 0 2px 5px rgba(0,0,0,.6);
  --sh-peb:inset 0 2px 2px rgba(255,255,255,.08);
  --sh-pebon:inset 0 2px 2px rgba(255,255,255,.4), 0 4px 10px rgba(222,213,220,.2);
  --pipink:rgba(0,0,0,.6); --pipring:var(--page);
  --swborder:rgba(255,255,255,.15); --swring:#fff;
  --r-xl:10px; --r-lg:6px; --r-md:5px; --r-sm:4px; --r-nav:22px;
}
/* ---------- PAPER (light) ---------- */
[data-theme="paper"]{
  --page:#EFE8D9; --card:#FBF8F1; --card2:#FBF8F1;
  --ink:#3E3A32; --sub:#8A8272; --faint:#A79C87; --line:#E6DCC7;
  --track:#E9E2D2; --checkline:#D9CDB8; --navoff:#B5AB94;
  --a:#2F2B24; --on:#F5F0E4; --soft:rgba(47,43,36,.08);
  --danger:#C6373C;
  --wash:linear-gradient(150deg,rgba(168,195,224,.22),transparent 42%,rgba(242,184,168,.18) 85%);
  --sh-card:-3px -3px 8px rgba(255,255,255,.85), 4px 5px 10px rgba(163,146,116,.3);
  --sh-row:-2px -2px 6px rgba(255,255,255,.75), 3px 3px 7px rgba(163,146,116,.2);
  --sh-nav:0 12px 26px rgba(120,100,70,.35), inset 0 1.5px 0 rgba(255,255,255,.8);
  --sh-acc:2px 3px 8px rgba(60,50,35,.35);
  --sh-inset:inset 2px 2px 5px rgba(150,135,105,.35), inset -1px -1px 3px rgba(255,255,255,.7);
  --sh-peb:inset 0 2px 2px rgba(255,255,255,.7), 0 3px 6px rgba(163,146,116,.3);
  --sh-pebon:inset 0 2px 2px rgba(255,255,255,.25), 0 3px 7px rgba(74,68,59,.35);
  --pipink:rgba(0,0,0,.55); --pipring:var(--card);
  --swborder:rgba(0,0,0,.14); --swring:#3E3A32;
}
/* ---------- VOID (AMOLED · flat: shadows off, hairlines on) ---------- */
[data-theme="void"]{
  --page:#000; --card:#000; --card2:#000;
  --ink:#D9D9DE; --sub:#8F8F96; --faint:#5C5C63; --line:#232328;
  --track:#101013; --checkline:#2A2A30; --navoff:#5C5C63;
  --a:#D9D9DE; --on:#0A0A0C; --soft:rgba(217,217,222,.08);
  --danger:#E5484D;
  --wash:none;
  --sh-card:none; --sh-row:none; --sh-nav:none; --sh-acc:none;
  --sh-inset:none; --sh-peb:none; --sh-pebon:none;
  --pipink:rgba(0,0,0,.6); --pipring:#2A2A30;
  --swborder:rgba(255,255,255,.2); --swring:#D9D9DE;
}
[data-theme="void"] .card,[data-theme="void"] .row,[data-theme="void"] .set,[data-theme="void"] .stat,
[data-theme="void"] .qcard,[data-theme="void"] .hero,[data-theme="void"] .tlwrap{border-color:var(--line)}
[data-theme="void"] .well,[data-theme="void"] .bar,[data-theme="void"] .track{border:1px solid var(--line)}

*{box-sizing:border-box;margin:0;padding:0;-webkit-tap-highlight-color:transparent}
html,body{height:100%}
body{background:var(--page);font-family:Quicksand,system-ui,sans-serif;color:var(--ink);transition:background .25s}
button{font-family:inherit;cursor:pointer;border:none;background:none;color:inherit}
.app{height:100dvh;max-width:480px;margin:0 auto;display:flex;flex-direction:column;background:var(--page);position:relative;overflow:hidden}
.app::before{content:'';position:absolute;inset:0;background:var(--wash);pointer-events:none;z-index:0}
.view{flex:1;overflow-y:auto;padding:24px 20px 108px;position:relative;z-index:1}
.center{display:flex;flex:1;align-items:center;justify-content:center;flex-direction:column;gap:10px;color:var(--faint);text-align:center;padding:40px}
.center svg{width:34px;height:34px}
.h1{font-size:22px;font-weight:700;color:var(--ink)}
.h1 small{display:block;font-size:11px;font-weight:600;color:var(--faint);margin-top:2px;letter-spacing:.04em}
.lbl{font-size:9.5px;font-weight:700;letter-spacing:.14em;color:var(--sub);text-transform:uppercase;margin:20px 0 10px}
.lbl.first{margin-top:0}
.top{display:flex;align-items:center;justify-content:space-between;margin-bottom:18px}
.buddy{width:44px;height:44px;border-radius:50%;background:var(--soft);display:flex;align-items:center;justify-content:center}
.buddy svg{width:22px;height:22px;stroke:var(--a)}
/* cards */
.card{background:var(--card);border:1px solid var(--line);border-radius:var(--r-lg);padding:16px;box-shadow:var(--sh-card)}
/* XP header (round clay badge + inset well) */
.xp{display:flex;align-items:center;gap:13px}
.lvl{width:48px;height:48px;border-radius:50%;background:var(--a);display:flex;flex-direction:column;align-items:center;justify-content:center;box-shadow:var(--sh-acc);flex-shrink:0}
.lvl small{font-size:7px;font-weight:700;color:var(--on);opacity:.7;letter-spacing:.08em}
.lvl b{font-size:17px;font-weight:700;color:var(--on);line-height:1}
.xpi{flex:1;min-width:0}
.xpi .r{display:flex;justify-content:space-between;font-size:10px;font-weight:700;color:var(--sub);margin-bottom:6px}
.xpi .r b{color:var(--a)}
.bar{height:11px;border-radius:5px;background:var(--track);box-shadow:var(--sh-inset);overflow:hidden}
.bar i{display:block;height:100%;border-radius:5px;background:var(--a);transition:width .4s}
/* streak pebbles */
.pebbles{display:flex;gap:7px;margin-top:12px;align-items:center}
.peb{width:24px;height:20px;border-radius:48% 52% 55% 45%/55% 50% 50% 45%;background:var(--track);box-shadow:var(--sh-peb);flex-shrink:0}
.peb.on{background:var(--a);box-shadow:var(--sh-pebon)}
.pl{font-size:9.5px;font-weight:700;color:var(--sub);margin-left:4px}
.freeze{margin-left:auto;font-size:10px;font-weight:700;color:var(--a);border:1px solid var(--a);padding:4px 8px;border-radius:var(--r-sm);opacity:.9;white-space:nowrap;flex-shrink:0}
/* hero focus */
.hero{background:var(--card);border:1px solid var(--line);border-radius:var(--r-lg);padding:18px;margin-bottom:8px;box-shadow:var(--sh-card)}
.hero .tag{font-size:8.5px;font-weight:700;color:var(--a);margin-bottom:5px;letter-spacing:.12em;opacity:.75}
.hero h2{font-size:17px;font-weight:700;color:var(--ink);margin-bottom:3px}
.hero p{font-size:11px;color:var(--sub);font-weight:600;margin-bottom:14px}
.btn{width:100%;height:46px;border-radius:var(--r-lg);background:var(--a);color:var(--on);font-size:13.5px;font-weight:700;display:flex;align-items:center;justify-content:center;gap:8px;box-shadow:var(--sh-acc)}
.btn svg{width:18px;height:18px;stroke:var(--on)}
.btn.ghost{background:transparent;border:1px solid var(--line);color:var(--ink);box-shadow:none}
/* rows (compact, sticker pips; pip bg = the habit's own colour) */
.row{display:flex;align-items:center;gap:11px;background:var(--card);border:1px solid var(--line);border-radius:var(--r-md);padding:10px 13px;margin-bottom:8px;box-shadow:var(--sh-row)}
.row .dot{width:29px;height:29px;border-radius:50%;background:var(--soft);border:2.5px solid var(--pipring);display:flex;align-items:center;justify-content:center;flex-shrink:0;color:var(--pipink)}
.row .dot svg{width:14px;height:14px;stroke:currentColor}
.row .g{flex:1;min-width:0}
.row .nm{font-size:12.5px;font-weight:700;color:var(--ink);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.row .mt{font-size:9px;font-weight:600;color:var(--faint);letter-spacing:.03em}
.row .rw{font-size:10.5px;font-weight:700;color:var(--a);flex-shrink:0;opacity:.8}
.check{width:24px;height:24px;border-radius:var(--r-lg);background:var(--track);box-shadow:var(--sh-inset);flex-shrink:0;display:flex;align-items:center;justify-content:center;color:transparent}
.check svg{width:12px;height:12px}
.check.on{background:var(--a);color:var(--on);box-shadow:none}
.empty{color:var(--faint);font-size:13px;font-weight:600;text-align:center;padding:24px 8px}
/* floating island nav */
.nav{position:absolute;bottom:12px;left:12px;right:12px;height:60px;background:var(--card2);border:1px solid var(--line);border-radius:var(--r-nav);display:flex;align-items:center;justify-content:space-around;box-shadow:var(--sh-nav);z-index:20}
.nav a{display:flex;flex-direction:column;align-items:center;gap:3px;font-size:8.5px;font-weight:700;color:var(--navoff);letter-spacing:.05em}
.nav a.on{color:var(--a)}
.nav a svg{width:20px;height:20px}
.nav .fab{position:relative;width:46px;height:46px;border-radius:var(--r-lg);background:var(--a);border:2px solid var(--a);display:flex;align-items:center;justify-content:center;box-shadow:var(--sh-acc);margin-top:-23px;cursor:pointer;transition:background .22s,box-shadow .22s,transform .12s}
.nav .fab:active{transform:scale(.9)}
.nav .fab svg{width:22px;height:22px;stroke:var(--on);transition:transform .25s cubic-bezier(.34,1.56,.64,1),stroke .22s}
.nav .fab.x{background:transparent;box-shadow:none}
.nav .fab.x svg{transform:rotate(45deg);stroke:var(--a)}
.nav .fab .rip{position:absolute;inset:-2px;border-radius:inherit;border:2px solid var(--a);opacity:0;pointer-events:none}
.nav .fab.x .rip{animation:fabrip .5s ease-out}
@keyframes fabrip{0%{opacity:.9;transform:scale(1)}100%{opacity:0;transform:scale(1.9)}}
/* settings (You) */
.set{display:flex;align-items:center;gap:14px;background:var(--card);border:1px solid var(--line);border-radius:var(--r-lg);padding:14px 16px;margin-bottom:9px;box-shadow:var(--sh-row)}
.set .g{flex:1}.set .nm{font-size:14px;font-weight:700}.set .mt{font-size:10.5px;color:var(--faint);font-weight:600}
.seg{display:flex;background:var(--track);border-radius:var(--r-md);padding:3px;box-shadow:var(--sh-inset)}
.seg button{flex:1;padding:8px 12px;border-radius:var(--r-sm);font-size:12px;font-weight:700;color:var(--sub)}
.seg button.on{background:var(--a);color:var(--on)}
.dotc{width:14px;height:14px;border-radius:50%;flex-shrink:0;border:2px solid var(--pipring)}
.xbtn{width:34px;height:34px;border-radius:var(--r-md);display:flex;align-items:center;justify-content:center;background:var(--track);flex-shrink:0}
.xbtn svg{width:15px;height:15px;stroke:var(--sub)}
.xbtn.xs{width:26px;height:26px}.xbtn.xs svg{width:12px;height:12px}
/* sheets */
.backdrop{position:fixed;inset:0;background:rgba(0,0,0,.55);opacity:0;pointer-events:none;transition:opacity .2s;z-index:40}
.backdrop.open{opacity:1;pointer-events:auto}
/* FAB action menu (A3 · locked spec: H1 compact, deal-in, label left / shadowed square tile right) */
.fabmenu{position:fixed;left:50%;transform:translateX(-50%);bottom:104px;width:190px;display:flex;flex-direction:column-reverse;gap:7px;z-index:45;pointer-events:none}
.fabmenu.open{pointer-events:auto}
.fm-opt{display:flex;align-items:center;justify-content:space-between;background:var(--card);border:1px solid var(--line);border-radius:var(--r-lg);padding:8px 8px 8px 13px;box-shadow:var(--sh-row);cursor:pointer;color:var(--ink);
        opacity:0;transform:translateY(26px) scale(.985);transition:transform .26s cubic-bezier(.3,1.12,.45,1),opacity .18s}
.fabmenu.open .fm-opt{opacity:1;transform:translateY(0) scale(1)}
.fabmenu.open .fm-opt:nth-last-child(1){transition-delay:0s}
.fabmenu.open .fm-opt:nth-last-child(2){transition-delay:.045s}
.fabmenu.open .fm-opt:nth-last-child(3){transition-delay:.09s}
.fabmenu.open .fm-opt:nth-last-child(4){transition-delay:.135s}
.fm-opt .ml{font-size:12px;font-weight:700}
.fm-opt .tile{width:30px;height:30px;border-radius:var(--r-md);background:var(--card2);box-shadow:var(--sh-tile,0 4px 10px rgba(0,0,0,.35));display:flex;align-items:center;justify-content:center;color:var(--a);flex-shrink:0}
.fm-opt .tile svg{width:14px;height:14px}
[data-theme="paper"] .fm-opt .tile{background:var(--track);box-shadow:2px 2px 6px rgba(163,146,116,.3), inset 0 1px 0 rgba(255,255,255,.8)}
[data-theme="void"] .fm-opt .tile{box-shadow:none;border:1px solid var(--checkline)}
.sheet{position:fixed;left:0;right:0;bottom:0;max-width:480px;margin:0 auto;background:var(--page);border-radius:calc(var(--r-xl) + 4px) calc(var(--r-xl) + 4px) 0 0;border-top:1px solid var(--line);padding:20px 20px calc(24px + env(safe-area-inset-bottom));transform:translateY(100%);transition:transform .25s;z-index:50}
.sheet.open{transform:translateY(0)}
.sheet h3{font-size:16px;font-weight:700;margin-bottom:14px;display:flex;align-items:center;justify-content:space-between}
.sheet h3 .x{width:30px;height:30px;border-radius:50%;background:var(--card);border:1px solid var(--line);display:flex;align-items:center;justify-content:center}
.sheet h3 .x svg{width:15px;height:15px;stroke:var(--sub)}
.chips{display:flex;gap:7px;flex-wrap:wrap;margin-bottom:14px}
.chip{display:flex;align-items:center;gap:6px;padding:8px 12px;border-radius:var(--r-md);background:var(--card);border:1px solid var(--line);font-size:12.5px;font-weight:700;color:var(--sub)}
.chip svg{width:15px;height:15px;stroke:currentColor}
.chip.on{border-color:var(--a);color:var(--a);background:var(--soft)}
.durs{display:flex;gap:7px;margin-bottom:16px}
.durs button{flex:1;padding:11px 0;border-radius:var(--r-md);background:var(--card);border:1px solid var(--line);font-size:13px;font-weight:700;color:var(--sub)}
.durs button.on{background:var(--a);color:var(--on);border-color:var(--a)}
.toast{position:fixed;left:50%;bottom:100px;transform:translateX(-50%) translateY(20px);background:var(--a);color:var(--on);font-weight:700;font-size:13.5px;padding:12px 20px;border-radius:var(--r-md);box-shadow:var(--sh-acc);opacity:0;pointer-events:none;transition:.25s;z-index:60}
.toast.on{opacity:1;transform:translateX(-50%) translateY(0)}
/* ---- Plan page ---- */
.daystrip{display:flex;gap:7px;overflow-x:auto;padding:2px 2px 12px;scrollbar-width:none}
.daystrip::-webkit-scrollbar{display:none}
.dayb{flex:0 0 auto;width:48px;padding:8px 0 7px;border-radius:var(--r-md);background:var(--card);border:1px solid var(--line);display:flex;flex-direction:column;align-items:center;gap:1px;box-shadow:var(--sh-row)}
.dayb small{font-size:8.5px;font-weight:700;letter-spacing:.06em;color:var(--faint);text-transform:uppercase}
.dayb b{font-size:15px;font-weight:700;color:var(--ink)}
.dayb .pip{width:4px;height:4px;border-radius:50%;background:var(--a);margin-top:2px;opacity:0}
.dayb.has .pip{opacity:1}
.dayb.today small{color:var(--a)}
.dayb.on{background:var(--a);border-color:var(--a);box-shadow:var(--sh-acc)}
.dayb.on small,.dayb.on b{color:var(--on)}.dayb.on .pip{background:var(--on)}
.nextchip{display:flex;align-items:center;gap:8px;background:var(--soft);border:1px solid var(--line);border-radius:var(--r-md);padding:10px 13px;margin-bottom:12px;font-size:11.5px;font-weight:700;color:var(--ink)}
.nextchip svg{width:15px;height:15px;stroke:var(--a);flex-shrink:0}
.nextchip b{color:var(--a)}
.tlwrap{border:1px solid var(--line);border-radius:var(--r-lg);background:var(--card);overflow:hidden;margin-bottom:12px;box-shadow:var(--sh-card)}
.tlscroll{max-height:46vh;overflow-y:auto;position:relative;scrollbar-width:thin;scrollbar-color:var(--track) transparent}
.tlgrid{position:relative;margin-left:46px;border-left:1px solid var(--line)}
.hlbl{position:absolute;left:-44px;width:38px;text-align:right;font-size:9px;font-weight:600;color:var(--faint);transform:translateY(-50%)}
.hline{position:absolute;left:0;right:0;border-top:1px solid var(--line);opacity:.5}
.blk{position:absolute;left:6px;right:8px;border-radius:var(--r-md);padding:6px 9px;background:var(--soft);border:1px solid var(--a);overflow:hidden;z-index:2}
.blk .n{font-size:11px;font-weight:700;color:var(--ink);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.blk .t{font-size:9px;font-weight:600;color:var(--sub)}
.blk.ghost{background:transparent;border:1.5px dashed var(--a);z-index:1;cursor:pointer;opacity:.8}
.blk.ghost .n{color:var(--a)}
.blk.ghost.done{opacity:.4}
.blk.ghost.done .n{text-decoration:line-through}
.nowline{position:absolute;left:0;right:0;height:2px;background:var(--a);z-index:4;pointer-events:none}
.nowline::before{content:'';position:absolute;left:-5px;top:-3px;width:8px;height:8px;border-radius:50%;background:var(--a)}
.timein{display:flex;align-items:center;gap:10px;margin-bottom:16px}
.timein label{font-size:10px;font-weight:700;color:var(--faint);text-transform:uppercase;letter-spacing:.08em}
.timein input{background:var(--card);border:1px solid var(--line);color:var(--ink);font-family:inherit;font-size:15px;font-weight:700;padding:9px 11px;border-radius:var(--r-md);outline:none;color-scheme:dark}
[data-theme="paper"] .timein input{color-scheme:light}
.timein input:focus{border-color:var(--a)}
.timein .chip{margin-bottom:0}
/* ---- Quests page ---- */
.statrow{display:flex;gap:8px;margin-bottom:8px}
.stat{flex:1;background:var(--card);border:1px solid var(--line);border-radius:var(--r-lg);padding:11px 5px;text-align:center;box-shadow:var(--sh-row)}
.stat b{display:block;font-size:16px;font-weight:700;color:var(--ink)}
.stat span{font-size:8px;font-weight:700;color:var(--faint);text-transform:uppercase;letter-spacing:.06em}
.qcard{background:var(--card);border:1px solid var(--line);border-radius:var(--r-lg);padding:14px 15px;margin-bottom:9px;cursor:pointer;box-shadow:var(--sh-row)}
.qcard .h{display:flex;align-items:center;gap:10px;margin-bottom:9px}
.qcard .nm{flex:1;font-size:14px;font-weight:700;color:var(--ink);min-width:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.due{font-size:10px;font-weight:700;color:var(--a);background:var(--soft);padding:4px 8px;border-radius:var(--r-sm);white-space:nowrap}
.due.late{color:#fff;background:var(--danger)}
.qbar{height:8px;border-radius:4px;background:var(--track);box-shadow:var(--sh-inset);overflow:hidden;margin-bottom:6px}
.qbar i{display:block;height:100%;border-radius:4px;background:var(--a);transition:width .4s}
.qmeta{display:flex;justify-content:space-between;font-size:10px;font-weight:600;color:var(--faint)}
.qmeta b{color:var(--sub)}
.tin{width:100%;background:var(--card);border:1px solid var(--line);color:var(--ink);font-family:inherit;font-size:16px;font-weight:600;padding:12px;border-radius:var(--r-md);outline:none;margin-bottom:13px}
.tin:focus{border-color:var(--a)}
.tin::placeholder{color:var(--faint)}
.stepin{flex:1;background:var(--card);border:1px solid var(--line);color:var(--ink);font-family:inherit;font-size:14px;font-weight:600;padding:9px 11px;border-radius:var(--r-md);outline:none;min-width:0}
.stepin:focus{border-color:var(--a)}
.stepin::placeholder{color:var(--faint);font-size:12px}
.subrow{display:flex;align-items:center;gap:11px;padding:9px 2px;border-bottom:1px solid var(--line)}
.subrow:last-child{border-bottom:none}
.subrow .st{flex:1;font-size:13.5px;font-weight:600;color:var(--ink)}
.subrow.done .st{text-decoration:line-through;color:var(--faint)}
.subrow .chip{flex-shrink:0}
.sheetscroll{max-height:34vh;overflow-y:auto;margin-bottom:13px}
.sheetrow{display:flex;gap:9px}
.sheetrow .btn{flex:1}
.rescue{background:var(--soft);border:1px dashed var(--a);border-radius:var(--r-md);padding:12px 14px;font-size:12px;font-weight:600;color:var(--ink);margin-bottom:13px}
/* burst (quest completion peak) */
.burst{position:fixed;left:50%;top:38%;transform:translate(-50%,-50%);z-index:70;pointer-events:none;text-align:center;opacity:0}
.burst b{display:block;font-size:29px;font-weight:700;color:var(--a);letter-spacing:.02em}
.burst span{font-size:14px;font-weight:700;color:var(--ink)}
.burst.on{animation:burstin 1.6s ease forwards}
@keyframes burstin{0%{opacity:0;transform:translate(-50%,-50%) scale(.5)}14%{opacity:1;transform:translate(-50%,-50%) scale(1.18)}28%{transform:translate(-50%,-50%) scale(1)}72%{opacity:1}100%{opacity:0;transform:translate(-50%,-46%) scale(1)}}
@media (prefers-reduced-motion: reduce){ .burst.on{animation:none;opacity:1} .bar i,.qbar i{transition:none} .sheet{transition:none} .nav .fab.x .rip{animation:none} .nav .fab svg{transition:none} }
