






  *{box-sizing:border-box;margin:0;padding:0}
  :root{
    --amber:#e8a23a;--coral:#d8442a;
    --r-md:13px;--r-lg:18px;--ease:cubic-bezier(.4,0,.2,1);
  }
  body{font-family:'Instrument Sans',system-ui,sans-serif;background:#07080a;color:var(--ink);min-height:100vh;
    display:flex;flex-direction:column;align-items:center;padding:14px 10px 90px}
  /* ---- top control bar ---- */
  .bar{position:sticky;top:0;z-index:50;display:flex;gap:14px;align-items:center;flex-wrap:wrap;justify-content:center;
    background:rgba(12,13,16,.86);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.1);
    border-radius:999px;padding:9px 18px;margin-bottom:16px;font-size:13px;color:#c9bdb0}
  .bar .seg{display:inline-flex;border:1px solid rgba(255,255,255,.16);border-radius:999px;overflow:hidden}
  .bar .seg button{border:0;background:transparent;color:#c9bdb0;font:inherit;font-size:12.5px;padding:6px 13px;cursor:pointer}
  .bar .seg button.on{background:#f6efe8;color:#16110d}
  .bar input[type=range]{width:140px;accent-color:var(--accent)}
  .bar b{color:#f6efe8}
  /* ---- device frame ---- */
  .device{width:100%;transition:max-width .4s var(--ease);border-radius:30px;overflow:hidden;
    border:1px solid rgba(255,255,255,.14);box-shadow:0 30px 80px rgba(0,0,0,.5);background:#0a0b0d}
  .device[data-d=mobile]{max-width:412px}
  .device[data-d=tablet]{max-width:840px}
  .device[data-d=laptop]{max-width:1180px}
  .app{position:relative;min-height:760px;display:flex;isolation:isolate}
  /* world bg */
  #world{position:absolute;inset:0;z-index:0}
  #sky{position:absolute;inset:0;transition:background 1.1s var(--ease)}
  #sun{position:absolute;left:50%;width:46%;padding-bottom:46%;height:0;border-radius:50%;transform:translateX(-50%);
    transition:bottom 1.1s var(--ease),background 1.1s,opacity 1.1s}
  .hill{position:absolute;left:0;right:0;bottom:0;height:30%}
  .hill path{transition:fill 1.1s var(--ease)}
  #scrim{position:absolute;left:0;right:0;top:8%;height:40%;pointer-events:none;transition:background 1.1s}
  /* ---- sidebar (tablet/laptop) ---- */
  .side{position:relative;z-index:3;width:248px;flex:none;padding:22px 16px;display:flex;flex-direction:column;gap:4px;
    border-right:1px solid var(--line);overflow:hidden;isolation:isolate}
  /* the whole sidebar IS a living world */
  .side-world{position:absolute;inset:0;z-index:0}
  .sw-sky{position:absolute;inset:0;transition:background 1.1s var(--ease)}
  .sw-sun{position:absolute;left:50%;width:160px;height:160px;border-radius:50%;transform:translateX(-50%);transition:bottom 1.1s var(--ease),background 1.1s,opacity 1.1s;animation:wcsun 8s var(--ease) infinite}
  .sw-hill{position:absolute;left:0;right:0;bottom:0;height:34%}.sw-hill path{transition:fill 1.1s var(--ease)}
  .side-scrim{position:absolute;inset:0;z-index:1;background:var(--sidescrim);transition:background 1.1s var(--ease)}
  .side>.brand,.side>.nav,.side>.me,.side>.side-meta{position:relative;z-index:2}
  .side .brand{display:flex;align-items:center;gap:10px;margin-bottom:18px;padding:0 8px}
  .side .brand b{font-family:'Italiana',serif;font-weight:400;font-size:22px;color:var(--ink)}
  .nav{display:flex;align-items:center;gap:11px;padding:10px 12px;border-radius:11px;color:var(--ink2);font-size:14.5px;cursor:pointer;transition:.18s}
  .nav svg{width:19px;height:19px}
  .nav:hover{background:var(--card);color:var(--ink)}
  .nav.on{background:color-mix(in srgb,var(--accent) 22%,transparent);color:var(--ink);box-shadow:inset 2px 0 0 var(--accent);backdrop-filter:blur(4px)}
  .side-meta{margin-top:auto;padding:14px 8px 4px}
  .side-meta .n{font-family:'Italiana',serif;font-size:40px;line-height:.9;color:var(--ink);text-shadow:0 1px 12px rgba(0,0,0,.5)}
  .side-meta .bd{font-size:10px;letter-spacing:.2em;text-transform:uppercase;font-weight:600;margin-top:2px}
  .side .me{display:flex;align-items:center;gap:9px;padding:12px 8px 2px;font-size:12.5px;color:var(--ink2)}
  #hill{display:none}
  /* ---- main ---- */
  .main{position:relative;z-index:3;flex:1;min-width:0;overflow:hidden}
  .scr{display:none;padding:26px clamp(18px,4vw,40px) 26px;animation:fade .5s var(--ease)}
  .scr.on{display:block}
  @keyframes fade{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}
  /* bottom tab (mobile) */
  .tabbar{position:absolute;left:0;right:0;bottom:0;z-index:4;display:none;justify-content:space-around;
    padding:10px 8px 14px;background:var(--sidebg);backdrop-filter:blur(14px);border-top:1px solid var(--line)}
  .tab{display:flex;flex-direction:column;align-items:center;gap:3px;color:var(--ink3);font-size:10px;cursor:pointer}
  .tab svg{width:21px;height:21px}.tab.on{color:var(--accent)}
  /* ---- shared type ---- */
  .kick{font-size:11px;letter-spacing:.3em;text-transform:uppercase;color:var(--ink3)}
  .ptitle{font-family:'Italiana',serif;font-weight:400;font-size:38px;line-height:1;color:var(--ink);margin:4px 0 18px}
  .sec{font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--ink3);margin:20px 0 10px}
  .muted{color:var(--ink2)}
  /* home hero */
  .hero{display:flex;flex-direction:column;align-items:center;text-align:center;padding:14px 0 6px}
  .score{font-family:'Italiana',serif;font-size:clamp(108px,22vw,150px);line-height:.82;color:var(--ink);text-shadow:0 2px 40px rgba(0,0,0,.45);transition:color 1.1s}
  .band{font-size:13px;letter-spacing:.34em;text-transform:uppercase;font-weight:600;margin-top:8px;transition:color 1.1s}
  .say{font-family:'Italiana',serif;font-style:italic;font-size:21px;color:var(--ink2);margin-top:14px;max-width:300px;line-height:1.3}
  .topgreet{display:flex;align-items:center;justify-content:space-between;margin-bottom:4px}
  .topgreet .g{font-size:13px;color:var(--ink2)}
  /* widgets */
  .grid{display:grid;grid-template-columns:1fr 1fr;gap:11px;margin-top:22px}
  .device[data-d=laptop] .home .grid{grid-template-columns:repeat(4,1fr)}
  .w{border-radius:16px;border:1px solid var(--line);background:var(--card);backdrop-filter:blur(12px);padding:15px 16px}
  .w__l{font-size:11px;color:var(--ink3);text-transform:uppercase;letter-spacing:.04em}
  .w__v{font-family:'Italiana',serif;font-size:34px;line-height:1;color:var(--ink);margin-top:8px}
  .w__v small{font-family:'Instrument Sans';font-size:13px;color:var(--ink2)}
  .w__d{font-size:12px;margin-top:5px;color:var(--ink2)}
  .w--wide{grid-column:1/-1;display:flex;align-items:center;justify-content:space-between;gap:14px}
  .device[data-d=laptop] .home .w--wide{grid-column:span 2}
  .spark{flex:1;height:46px;min-width:90px}
  /* rows / lists */
  .prog{height:8px;border-radius:999px;background:var(--track);overflow:hidden;margin:2px 0 18px}
  .prog i{display:block;height:100%;background:var(--accent);transition:width .5s,background 1.1s}
  .row{display:flex;align-items:center;gap:12px;padding:12px 15px;border-radius:var(--r-md);border:1px solid var(--line);background:var(--card);margin-bottom:8px}
  .row.big{box-shadow:inset 3px 0 0 var(--accent)}
  .ck{width:21px;height:21px;border-radius:6px;border:2px solid var(--line2);flex:none;display:grid;place-items:center;color:#fff;font-size:12px}
  .row.done .ck{background:var(--accent);border-color:var(--accent)}.row.done .lb{color:var(--ink3);text-decoration:line-through}
  .lb{flex:1;font-size:14px;color:var(--ink)}.time{font-size:12px;color:var(--ink2)}.dt{width:7px;height:7px;border-radius:50%}
  .add{display:flex;gap:9px;align-items:center;padding:12px 15px;border-radius:var(--r-md);border:1px dashed var(--line2);color:var(--ink3);background:transparent;width:100%;font:inherit;font-size:14px;cursor:pointer}
  /* habit */
  .habit{display:grid;grid-template-columns:38px 1fr auto;align-items:center;gap:13px;padding:13px 15px;border-radius:var(--r-md);border:1px solid var(--line);background:var(--card);margin-bottom:9px}
  .hic{width:38px;height:38px;border-radius:11px;display:grid;place-items:center;background:color-mix(in srgb,var(--accent) 16%,transparent);color:var(--accent)}
  .hic svg{width:18px;height:18px}
  .hn{font-size:14px;color:var(--ink)}.hs{font-size:11px;color:var(--ink3)}
  .streak{display:inline-flex;align-items:center;gap:4px;font-size:12px;color:var(--accent);justify-content:flex-end}
  .week{display:flex;gap:5px;margin-top:6px;justify-content:flex-end}
  .wd{width:11px;height:11px;border-radius:50%;background:var(--track);border:1px solid var(--line)}
  .wd.on{background:var(--accent);border-color:var(--accent)}.wd.today{box-shadow:0 0 0 2px color-mix(in srgb,var(--accent) 45%,transparent)}
  /* mountain */
  .mtn{position:relative;border-radius:var(--r-lg);overflow:hidden;border:1px solid var(--line);min-height:300px;padding:20px;background:var(--card)}
  .mtnsky{position:absolute;inset:-20px;background:linear-gradient(180deg,color-mix(in srgb,var(--accent) 22%,transparent),transparent 70%)}
  .mtnhill{position:absolute;left:-20px;right:-20px;bottom:-20px;width:auto;height:54%}.mtnhill path{fill:color-mix(in srgb,var(--accent) 38%,var(--card));transition:fill 1.1s}
  .alt{position:relative;font-family:'Italiana',serif;font-size:50px;color:var(--ink);line-height:1}
  .alt small{font-family:'Instrument Sans';font-size:13px;color:var(--ink2)}
  .miles{position:relative;margin-top:16px;display:flex;flex-direction:column;gap:11px}
  .mile{display:flex;align-items:center;gap:11px;font-size:13px;color:var(--ink2)}
  .pin{width:20px;height:20px;border-radius:50%;border:2px solid var(--line2);flex:none;display:grid;place-items:center;font-size:11px}
  .mile.reached .pin{background:var(--accent);border-color:var(--accent);color:#fff}.mile.reached span{color:var(--ink)}
  /* wins */
  .wins{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:12px}
  .win{border-radius:var(--r-lg);border:1px solid var(--line);padding:18px;background:var(--card);text-align:center}
  .medal{width:54px;height:54px;margin:0 auto 11px;border-radius:50%;display:grid;place-items:center;color:#fff;background:linear-gradient(95deg,var(--amber),var(--coral))}
  .medal svg{width:24px;height:24px}.win.bandw .medal{background:var(--accent)}.win.locked{opacity:.5}.win.locked .medal{background:var(--track);color:var(--ink3)}
  .wt{font-size:14px;color:var(--ink);font-weight:500}.wdte{font-size:11px;color:var(--ink3);margin-top:3px}
  .wxp{display:inline-block;margin-top:9px;font-size:11px;padding:3px 10px;border-radius:999px;background:color-mix(in srgb,var(--accent) 16%,transparent);color:var(--accent)}
  /* settings */
  .setrow{display:flex;align-items:center;gap:13px;padding:14px 15px;border:1px solid var(--line);background:var(--card)}
  .setrow:first-child{border-radius:var(--r-md) var(--r-md) 0 0}.setrow:last-child{border-radius:0 0 var(--r-md) var(--r-md)}.setrow+.setrow{border-top:0}
  .sic{width:30px;height:30px;border-radius:9px;display:grid;place-items:center;background:color-mix(in srgb,var(--accent) 14%,transparent);color:var(--accent)}.sic svg{width:16px;height:16px}
  .slab{flex:1}.slab b{display:block;font-size:14px;color:var(--ink);font-weight:500}.slab small{font-size:12px;color:var(--ink3)}
  .tog{width:44px;height:26px;border-radius:999px;background:var(--track);border:1px solid var(--line);position:relative;cursor:pointer;flex:none}
  .tog::after{content:"";position:absolute;top:2px;left:2px;width:20px;height:20px;border-radius:50%;background:var(--ink2);transition:.2s}
  .tog.on{background:var(--accent);border-color:var(--accent)}.tog.on::after{transform:translateX(18px);background:#fff}
  /* responsive: mobile shows tabbar, hides sidebar */
  .device[data-d=mobile] .side{display:none}
  .device[data-d=mobile] .tabbar{display:flex}
  .device[data-d=mobile] .main{padding-bottom:74px}
  .device[data-d=mobile] .hero{padding-top:8px}
  .device[data-d=tablet] .grid{grid-template-columns:1fr 1fr}
  #world{background:var(--skybot,#0a0b0d)}
  .device{background:var(--skybot,#0a0b0d);transition:max-width .4s var(--ease),background 1.1s var(--ease)}
  @keyframes wcsun{0%,100%{transform:translateX(-50%) scale(1)}50%{transform:translateX(-50%) scale(1.07)}}
  .wc-mote{position:absolute;width:3px;height:3px;border-radius:50%;opacity:0;animation:wcrise linear infinite}
  @keyframes wcrise{0%{transform:translateY(6px);opacity:0}22%{opacity:.7}100%{transform:translateY(-58px);opacity:0}}
  .brand #coin{animation:coinbreathe 6s var(--ease) infinite;filter:drop-shadow(0 0 10px color-mix(in srgb,var(--accent) 45%,transparent))}
  @keyframes coinbreathe{0%,100%{transform:scale(1)}50%{transform:scale(1.06)}}

/* ============ v0.2 interactions (added) ============ */
.crit{width:16px;height:16px;border-radius:50%;border:1px solid var(--line2);cursor:pointer;flex:none;margin-left:6px}
.crit.on{background:radial-gradient(circle,#e6753a,#b6492a);border-color:#e6753a;box-shadow:0 0 8px rgba(230,117,58,.6)}
.composer{border:1px solid var(--accent);border-radius:var(--r-md);padding:12px 14px;background:var(--card);display:none;margin-bottom:8px}
.composer.on{display:block;animation:fade .3s var(--ease)}
.composer input{width:100%;background:transparent;border:0;outline:0;color:var(--ink);font:inherit;font-size:15px;padding:2px 0 10px}
.composer input::placeholder{color:var(--ink3)}
.cbar{display:flex;align-items:center;gap:8px;border-top:1px solid var(--line);padding-top:10px}
.dots{display:flex;gap:6px}
.pdot{width:15px;height:15px;border-radius:50%;cursor:pointer;opacity:.5;transition:.15s;border:2px solid transparent}
.pdot.on{opacity:1;border-color:rgba(255,255,255,.25)}
.chip{font-size:12px;color:var(--ink2);border:1px solid var(--line);border-radius:999px;padding:4px 11px;cursor:pointer}
.commit{margin-left:auto;background:linear-gradient(95deg,#e8a23a,#d8442a);color:#fff;border:0;border-radius:9px;padding:7px 15px;font:inherit;font-weight:600;font-size:13px;cursor:pointer}
.slot{display:flex;align-items:center;gap:13px;padding:13px 15px;border-radius:var(--r-md);border:1px dashed var(--line2);cursor:pointer;transition:.2s;margin-bottom:8px}
.slot .sn{font-family:'Italiana',serif;font-size:26px;color:var(--ink3);width:24px;line-height:1}
.slot .sph{color:var(--ink3);font-size:13.5px;flex:1}
.slot.filled{border-style:solid;border-color:var(--line);background:var(--card);box-shadow:inset 3px 0 0 var(--accent)}
.slot.filled .sn{color:var(--accent)}.slot.filled .sph{color:var(--ink)}
.slot.filled.done .sph{color:var(--ink3);text-decoration:line-through}
.wd.today{cursor:pointer}
.wd.pop{animation:pop .35s var(--ease)}@keyframes pop{0%{transform:scale(1)}50%{transform:scale(1.5)}100%{transform:scale(1)}}
.coaches{display:grid;grid-template-columns:repeat(auto-fit,minmax(110px,1fr));gap:9px}
.coach{border:1px solid var(--line);border-radius:var(--r-md);padding:13px;cursor:pointer;transition:.18s;background:var(--card)}
.coach .cn{font-size:13.5px}.coach .cv{font-size:11px;color:var(--ink3);margin-top:4px;font-style:italic;font-family:'Italiana',serif}
.coach.on{border-color:var(--accent);box-shadow:0 0 0 1px var(--accent),0 0 22px -8px var(--accent)}
.stk input[type=range]{width:100%;accent-color:#e6753a;margin:8px 0 4px}
.seg{display:inline-flex;border:1px solid var(--line2);border-radius:999px;overflow:hidden;margin-top:6px}
.seg button{border:0;background:transparent;color:var(--ink2);font:inherit;font-size:12.5px;padding:7px 14px;cursor:pointer}
.seg button.on{background:var(--ink);color:#16110d}
.stkline{margin-top:14px;font-family:'Italiana',serif;font-style:italic;font-size:18px;color:var(--ink)}
.stkline b{font-style:normal;color:#e6753a}
.nudge{background:transparent;border:1px solid var(--line2);color:var(--ink2);border-radius:999px;padding:5px 12px;font:inherit;font-size:11.5px;cursor:pointer;margin-left:auto}
.nudge:hover{border-color:var(--accent);color:var(--accent)}
.lockwrap{position:fixed;inset:0;z-index:120;background:linear-gradient(180deg,#371d10,#0a0503);display:none;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:30px}
.lockwrap.on{display:flex;animation:fade .5s var(--ease)}
.lockwrap .li{font-size:40px;color:#e6753a}
.lockwrap h2{font-family:'Italiana',serif;font-weight:400;font-size:34px;margin:14px 0 4px;color:#f6efe8}
.lockwrap p{color:#c9bdb0;font-size:13.5px;margin-bottom:22px;max-width:320px}
.doors{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;max-width:380px}
.door{border:1px solid var(--line2);border-radius:var(--r-md);padding:14px 8px;cursor:pointer;transition:.18s;background:rgba(255,255,255,.04)}
.door:hover{border-color:#e6753a}.door .dt{font-size:12.5px;margin-top:4px;color:#f6efe8}.door .dd{font-size:10.5px;color:#cf8a86;margin-top:2px}

/* ============ v0.3 — deeper gaps wired ============ */
.gbar{height:5px;background:var(--track);border-radius:999px;margin-top:6px;overflow:hidden}
.gbar i{display:block;height:100%;background:var(--accent);transition:width .5s}
.xpbar{height:7px;background:var(--track);border-radius:999px;overflow:hidden;margin:0 0 4px}
.xpbar i{display:block;height:100%;background:var(--accent);transition:width .5s}
.winhdr{display:flex;justify-content:space-between;align-items:flex-end;padding:4px 4px 16px;border-bottom:1px solid var(--line);margin-bottom:16px}
.winhdr .v{font-family:'Italiana',serif;font-size:40px;line-height:1;color:var(--ink)}
.win .wprog{font-size:10.5px;color:var(--ink3);margin-top:5px}
.cjoin{display:flex;gap:8px;margin-top:12px}
.cjoin input{flex:1;background:var(--card);border:1px solid var(--line);border-radius:10px;color:var(--ink);font:inherit;font-size:14px;padding:11px 13px;outline:none}
.cjoin input:focus{border-color:var(--accent)}
.cbtn{background:linear-gradient(95deg,#e8a23a,#d8442a);color:#fff;border:0;border-radius:10px;padding:0 18px;font:inherit;font-weight:600;font-size:13px;cursor:pointer}
.whyrow{position:relative;border-radius:var(--r-lg);overflow:hidden;border:1px solid var(--line);padding:20px;min-height:88px;display:flex;align-items:center;cursor:pointer;background:var(--card)}
.whyrow .wq{font-family:'Italiana',serif;font-style:italic;font-size:20px;color:var(--ink);position:relative;z-index:1}
.whyrow .wglow{position:absolute;inset:0;background:radial-gradient(120% 90% at 20% 30%,color-mix(in srgb,var(--accent) 30%,transparent),transparent 70%)}
.chips{display:flex;flex-wrap:wrap;gap:8px}
.chip2{font-size:12.5px;color:var(--ink2);border:1px solid var(--line2);border-radius:999px;padding:6px 13px;cursor:pointer;transition:.15s}
.chip2.on{background:color-mix(in srgb,var(--accent) 22%,transparent);border-color:var(--accent);color:var(--ink)}

/* sidebar theme switch (always-visible, 1-click) */
.themeswitch{position:relative;z-index:2;display:inline-flex;gap:2px;margin:10px 8px 2px;padding:3px;border-radius:999px;background:var(--card);border:1px solid var(--line);width:-moz-fit-content;width:fit-content}
.themeswitch button{display:grid;place-items:center;width:32px;height:26px;border:0;background:transparent;color:var(--ink2);border-radius:999px;cursor:pointer;transition:.15s}
.themeswitch button svg{width:15px;height:15px}
.themeswitch button.on{background:color-mix(in srgb,var(--accent) 26%,transparent);color:var(--ink)}
.themeswitch button:hover{color:var(--ink)}

/* sidebar: quick-capture, streak flame, slip chip */
.qcap{position:relative;z-index:2;display:flex;align-items:center;gap:8px;width:100%;margin:-6px 0 12px;padding:9px 12px;border-radius:11px;background:var(--card);border:1px solid var(--line);color:var(--ink2);font:inherit;font-size:13.5px;cursor:pointer;transition:.18s}
.qcap svg{width:16px;height:16px}
.qcap:hover{border-color:var(--accent);color:var(--ink)}
.swstreak{font-family:'Italiana',serif;font-size:13px;color:var(--accent);margin-top:4px;letter-spacing:.02em}
.slipchip{position:relative;z-index:2;margin:8px 8px 0;padding:7px 11px;border-radius:10px;font-size:11.5px;font-weight:500;background:rgba(230,117,58,.16);border:1px solid rgba(230,117,58,.42);color:#f0a06a}

/* ============ account menu + top-right avatar/bell ============ */
.topbar{position:fixed;top:14px;right:18px;z-index:95;display:flex;align-items:center;gap:8px}
.tbtn,.avatarbtn{position:relative;border:1px solid var(--line);background:var(--card);border-radius:999px;cursor:pointer;display:grid;place-items:center;color:var(--ink2);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);transition:.15s}
.tbtn{width:38px;height:38px}.tbtn svg{width:18px;height:18px}
.tbtn:hover,.avatarbtn:hover{border-color:var(--accent);color:var(--ink)}
.tbtn .dot{position:absolute;top:8px;right:9px;width:8px;height:8px;border-radius:50%;background:#e6753a;box-shadow:0 0 0 2px var(--skybot,#0a0b0d)}
.avatarbtn{width:38px;height:38px;padding:0;overflow:hidden}
.av2{width:30px;height:30px;border-radius:50%;display:grid;place-items:center;background:linear-gradient(95deg,#e8a23a,#d8442a);color:#fff;font-weight:600;font-size:13px}
.av2.big{width:44px;height:44px;font-size:17px;flex:none}
.acctmenu,.notifpop{position:fixed;z-index:130;display:none;width:270px;background:var(--sidebg);border:1px solid var(--line2);border-radius:16px;padding:8px;box-shadow:0 30px 70px -20px rgba(0,0,0,.6);-webkit-backdrop-filter:blur(24px);backdrop-filter:blur(24px)}
.acctmenu.on,.notifpop.on{display:block;animation:fade .18s var(--ease)}
.acct-id{display:flex;align-items:center;gap:11px;padding:10px 10px 8px}
.acct-name{font-size:14.5px;color:var(--ink);font-weight:500}
.acct-sub{font-size:11.5px;color:var(--ink3);margin-top:2px}.acct-sub .tier{color:var(--accent)}
.acct-why{font-family:'Italiana',serif;font-style:italic;font-size:13px;color:var(--ink2);padding:0 11px 10px;line-height:1.35}
.acct-grp{border-top:1px solid var(--line);padding:5px 0}
.acct-item{display:flex;align-items:center;gap:11px;width:100%;border:0;background:transparent;color:var(--ink);font:inherit;font-size:13.5px;text-align:left;padding:9px 11px;border-radius:9px;cursor:pointer;transition:.12s}
.acct-item svg{width:17px;height:17px;color:var(--ink3);flex:none}
.acct-item:hover{background:var(--card)}
.acct-item.danger{color:#e0795a}.acct-item.danger svg{color:#e0795a}
.chip-pro{margin-left:auto;font-size:10px;font-weight:600;color:#2a1505;background:linear-gradient(95deg,#f1d089,#e8a23a);padding:2px 8px;border-radius:999px}
.np-head{font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--ink3);padding:8px 10px 6px}
.np-item{display:flex;gap:10px;align-items:flex-start;padding:9px 10px;border-radius:9px;cursor:pointer}
.np-item:hover{background:var(--card)}
.np-dot{width:8px;height:8px;border-radius:50%;margin-top:5px;flex:none}
.np-item b{font-size:13px;color:var(--ink);font-weight:500;display:block}
.np-item small{font-size:11.5px;color:var(--ink3)}
.me{cursor:pointer;border-radius:10px;transition:.12s}.me:hover{background:var(--card)}

/* ============ Home variation (data-home="v2") ============ */
#timeLayer{position:absolute;inset:0;opacity:0;transition:background 1.4s var(--ease),opacity 1.4s;pointer-events:none;z-index:0}
[data-home="v2"] #timeLayer{opacity:.62}
#worldMotes{position:absolute;inset:0;pointer-events:none;display:none;transition:transform .6s var(--ease);z-index:2}
[data-home="v2"] #worldMotes{display:block}
[data-home="v2"] #worldMotes .wc-mote{box-shadow:0 0 9px 2px currentColor}
#sun{transition:bottom 1.1s var(--ease),background 1.1s,opacity 1.1s,transform .6s var(--ease)}
[data-home="v2"] #sun{filter:saturate(1.25) brightness(1.18)}
.hill{transition:transform .6s var(--ease)}
.hero{position:relative}
.scorebloom{position:absolute;width:460px;height:460px;left:50%;top:92px;transform:translate(-50%,-50%);border-radius:50%;
  background:radial-gradient(circle,color-mix(in srgb,var(--accent) 55%,transparent) 0%,color-mix(in srgb,var(--accent) 22%,transparent) 38%,transparent 66%);filter:blur(30px);opacity:0;pointer-events:none;z-index:0}
[data-home="v2"] .scorebloom{opacity:1;animation:bloomPulse 5s var(--ease) infinite}
@keyframes bloomPulse{0%,100%{transform:translate(-50%,-50%) scale(1);opacity:.6}50%{transform:translate(-50%,-50%) scale(1.2);opacity:1}}
.coachline{display:none;font-family:'Instrument Sans',sans-serif;font-size:14px;font-weight:500;color:var(--accent);margin-top:14px;max-width:340px;text-align:center;line-height:1.45;transition:color 1.1s}
[data-home="v2"] .coachline{display:block;animation:fade .8s var(--ease) both}
[data-home="v2"] .score{position:relative;z-index:1}
@media (prefers-reduced-motion:reduce){[data-home="v2"] .scorebloom{animation:none;opacity:.85}}

/* ============ Home v1 rich dashboard ============ */
.insight{display:flex;align-items:flex-start;gap:12px;margin-top:20px;padding:14px 16px;border-radius:var(--r-lg);border:1px solid var(--line);background:var(--card);box-shadow:inset 3px 0 0 var(--accent)}
.insight .ic{width:22px;height:22px;flex:none;color:var(--accent);margin-top:1px}
.insight .it{font-size:13.5px;color:var(--ink2);line-height:1.55}
.insight .it b{color:var(--accent);font-weight:500}
.statrow{display:grid;grid-template-columns:repeat(3,1fr);gap:11px;margin-top:14px}
.w--full{margin-top:10px;padding:16px}
#scoreGraph{width:100%}
.gx{display:flex;justify-content:space-between;font-size:10.5px;color:var(--ink3);margin-top:6px}
.rings{display:grid;grid-template-columns:repeat(3,1fr);gap:11px;margin-top:10px}
.ring{border-radius:var(--r-lg);border:1px solid var(--line);background:var(--card);padding:15px;display:flex;flex-direction:column;align-items:center;gap:8px}
.ring .rwrap{position:relative;width:66px;height:66px}
.ring .rpct{position:absolute;inset:0;display:grid;place-items:center;font-family:'Italiana',serif;font-size:19px;color:var(--ink)}
.ring .rl{font-size:11px;color:var(--ink3);text-transform:uppercase;letter-spacing:.05em}
.ring .rd{font-size:11px;color:var(--ink2)}
.heatmap{display:grid;grid-template-rows:repeat(7,15px);grid-auto-flow:column;grid-auto-columns:15px;gap:4px;justify-content:start}
.hc{width:15px;height:15px;border-radius:3px;border:1px solid var(--line)}
@media(max-width:560px){.statrow{grid-template-columns:1fr 1fr}.heatmap{grid-template-rows:repeat(7,12px);grid-auto-columns:12px;gap:3px}.hc{width:12px;height:12px}}

/* ============ Home layout modes (?home=bento|deck|focus) ============ */
.hgrid{display:grid;gap:12px;margin-top:20px;grid-template-columns:1fr;grid-template-areas:"i" "s" "g" "r" "h" "b"}
.hi{grid-area:i;margin-top:0}.hs{grid-area:s}.hg{grid-area:g}.hr{grid-area:r}.hh{grid-area:h}.hb{grid-area:b}
.hr,.hb,.hs{min-width:0}
/* rings + stats tiles: identical structure so the 6 boxes line up & match height */
.hr,.hs{display:flex;flex-direction:column}
.hr .rings,.hs .statrow{flex:1;margin-top:0}
.hr .ring,.hs .statrow .w{height:100%}
.ht-head{display:flex;justify-content:space-between;align-items:center;font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--ink3);margin-bottom:10px}
.rangeseg{display:inline-flex;gap:2px;border:1px solid var(--line);border-radius:999px;padding:2px;letter-spacing:0}
.rangeseg button{border:0;background:transparent;color:var(--ink3);font:inherit;font-size:11px;padding:3px 9px;border-radius:999px;cursor:pointer;text-transform:none}
.rangeseg button.on{background:color-mix(in srgb,var(--accent) 26%,transparent);color:var(--ink)}
.home[data-mode] .w--full,.home[data-mode] .hr{transition:transform .18s var(--ease),box-shadow .18s}
.home[data-mode] [data-go]{cursor:pointer}
.home[data-mode] [data-go]:hover{transform:translateY(-2px);box-shadow:0 14px 34px -20px rgba(0,0,0,.6)}
@media(min-width:820px){
  .home[data-mode=bento] .hgrid{grid-template-columns:repeat(4,1fr);grid-template-areas:"g g g g" "r r h h" "i i s s" "b b b b"}
  .home[data-mode=deck] .hgrid{grid-template-columns:1fr 1fr;grid-template-areas:"i i" "g g" "r s" "h h" "b b"}
  .home[data-mode=deck] .hg #scoreGraph svg{height:230px!important}
  .home[data-mode=focus] .hgrid{max-width:600px;margin-left:auto;margin-right:auto;grid-template-columns:1fr;grid-template-areas:"i" "r" "b"}
  .home[data-mode=focus] .hg,.home[data-mode=focus] .hh,.home[data-mode=focus] .hs{display:none}
  .home[data-mode=focus] .rings{grid-template-columns:repeat(3,1fr)}
}
@media(max-width:819px){.hgrid{grid-template-columns:1fr!important;grid-template-areas:"i" "s" "g" "r" "h" "b"!important}.home[data-mode=focus] .hg,.home[data-mode=focus] .hh{display:none}}

/* ============ layout picker + drag-to-customize ============ */
.layoutbar{display:flex;align-items:center;justify-content:flex-end;gap:10px;margin-top:10px}
.lhint{font-size:12px;color:var(--ink3);font-style:italic;font-family:'Italiana',serif}
.lpick{position:relative}
.lbtn{display:inline-flex;align-items:center;gap:7px;border:1px solid var(--line);background:var(--card);color:var(--ink2);font:inherit;font-size:12.5px;padding:7px 12px;border-radius:999px;cursor:pointer;transition:.15s}
.lbtn svg{width:15px;height:15px}
.lbtn:hover{border-color:var(--accent);color:var(--ink)}
.lmenu{position:absolute;right:0;top:calc(100% + 6px);z-index:60;display:none;min-width:200px;background:var(--sidebg);border:1px solid var(--line2);border-radius:14px;padding:6px;box-shadow:0 24px 60px -20px rgba(0,0,0,.6);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px)}
.lmenu.on{display:block;animation:fade .16s var(--ease)}
.lmenu button{display:block;width:100%;text-align:left;border:0;background:transparent;color:var(--ink);font:inherit;font-size:13px;padding:9px 11px;border-radius:9px;cursor:pointer}
.lmenu button:hover{background:var(--card)}
.lmenu button.on{color:var(--accent)}
.lmenu button.on::after{content:"\2713";float:right;color:var(--accent)}
.home[data-mode=custom] .hgrid{display:flex;flex-direction:column;gap:12px;grid-template-areas:none}
.home[data-mode=custom] .hgrid>*{cursor:grab}
.home[data-mode=custom] .hgrid>*.dragging{opacity:.45;cursor:grabbing;outline:2px dashed var(--accent);outline-offset:3px;border-radius:var(--r-lg)}

/* ============ enriched screens (Today/Habits/Wins/Circle/Settings) ============ */
.rwrap{position:relative}
.rwrap svg{width:100%;height:100%;display:block}
.rwrap .rpct{position:absolute;inset:0;display:grid;place-items:center;font-family:'Italiana',serif;color:var(--ink)}
.dayhead{display:flex;align-items:center;gap:14px;margin:14px 0 8px;padding:14px 16px;border-radius:var(--r-lg);border:1px solid var(--line);background:var(--card)}
.th-count{font-size:15px;color:var(--ink);font-weight:500}
.th-coach{font-size:12.5px;color:var(--ink2);margin-top:3px}
.profhead{display:flex;align-items:center;gap:13px;padding:14px 16px;border-radius:var(--r-lg);border:1px solid var(--line);background:var(--card);margin:12px 0 4px}
.plans{display:grid;grid-template-columns:repeat(3,1fr);gap:10px}
.plan{border:1px solid var(--line);border-radius:var(--r-md);background:var(--card);padding:14px;cursor:pointer;transition:.15s}
.plan:hover{border-color:var(--accent)}
.plan.on{border-color:var(--accent);box-shadow:inset 0 0 0 1px var(--accent)}
.plan .pn{font-size:14px;color:var(--ink);font-weight:500}
.plan .pp{font-family:'Italiana',serif;font-size:24px;color:var(--ink);margin:4px 0}
.plan .pd{font-size:11px;color:var(--ink3);line-height:1.4}
.curtag{font-size:9.5px;letter-spacing:.08em;text-transform:uppercase;color:var(--accent);background:color-mix(in srgb,var(--accent) 18%,transparent);padding:2px 6px;border-radius:999px;vertical-align:middle}
.feedrow{display:flex;align-items:center;gap:10px;padding:9px 4px;border-bottom:1px solid var(--line)}
@media(max-width:560px){.plans{grid-template-columns:1fr}}

/* ============ collapsible sidebar (rail) ============ */
.side{transition:width .25s var(--ease),padding .25s var(--ease)}
.railtog{display:flex;align-items:center;gap:9px;width:100%;border:0;background:transparent;color:var(--ink3);font:inherit;font-size:12px;padding:9px 10px;border-radius:9px;cursor:pointer;position:relative;z-index:2;margin-top:4px}
.railtog:hover{color:var(--ink);background:var(--card)}
.railtog svg{width:16px;height:16px;flex:none;transition:transform .25s var(--ease)}
.app[data-rail] .side{width:70px;padding:22px 11px}
.app[data-rail] .brand{justify-content:center}
.app[data-rail] .brand b{display:none}
.app[data-rail] .nav{justify-content:center;gap:0;font-size:0;padding:11px 0}
.app[data-rail] .nav svg{width:21px;height:21px}
.app[data-rail] .qcap{justify-content:center;font-size:0;gap:0;padding:10px 0}
.app[data-rail] .side-meta,.app[data-rail] .themeswitch,.app[data-rail] #slipChip,.app[data-rail] #swStreak{display:none}
.app[data-rail] .railtog{justify-content:center;font-size:0;padding:10px 0}
.app[data-rail] .railtog svg{transform:rotate(180deg)}
.app[data-rail] .me{justify-content:center}
.app[data-rail] .me span:not(#coin2){display:none}
/* rail: hide the environment bar when collapsed — clean icon-only rail; controls return on expand */
.app[data-rail] .envbar{display:none}

/* ============ new personal screens (onboarding, cmd-k, billing, insights) ============ */
.onboard{position:fixed;inset:0;z-index:140;display:none;align-items:center;justify-content:center;padding:24px;background:radial-gradient(120% 90% at 50% 0%,#163a2b 0%,#0a0b0d 62%,#07080a 100%)}
.onboard.on{display:flex;animation:fade .3s var(--ease)}
.ob-card{width:100%;max-width:400px;text-align:center;color:#f6efe8}
.ob-dots{display:flex;gap:6px;justify-content:center;margin-bottom:22px}
.ob-dot{width:7px;height:7px;border-radius:50%;background:rgba(255,255,255,.2);transition:.25s}
.ob-dot.on{background:#5fba84;width:20px;border-radius:999px}
.ob-t{font-family:'Italiana',serif;font-weight:400;font-size:32px;line-height:1.1;color:#f6efe8}
.ob-s{font-family:'Italiana',serif;font-style:italic;font-size:16px;color:#c9bdb0;margin:10px auto 18px;max-width:320px;line-height:1.4}
.ob-input{width:100%;height:50px;padding:0 16px;border-radius:13px;border:1px solid rgba(255,255,255,.16);background:rgba(255,255,255,.05);color:#f6efe8;font:inherit;font-size:15px;text-align:center;outline:none}
.ob-input::placeholder{color:#8a8073}
.ob-cta{width:100%;height:50px;margin-top:16px;border:0;border-radius:13px;font:inherit;font-weight:600;font-size:15px;color:#06140d;background:linear-gradient(95deg,#5fba84,#3c7a5a);cursor:pointer}
.ob-skip{display:block;width:100%;margin-top:12px;border:0;background:transparent;color:#8a8073;font:inherit;font-size:13px;cursor:pointer}
.onboard .coaches{grid-template-columns:repeat(5,1fr)}.onboard .coach{padding:11px 5px}.onboard .coach .cn{font-size:11.5px}
.cmdk{position:fixed;inset:0;z-index:150;display:none;align-items:flex-start;justify-content:center;padding:90px 20px;background:rgba(6,9,12,.5);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}
.cmdk.on{display:flex;animation:fade .15s var(--ease)}
.cmdk-box{width:100%;max-width:480px;background:var(--sidebg);border:1px solid var(--line2);border-radius:16px;overflow:hidden;box-shadow:0 40px 90px -30px rgba(0,0,0,.7);-webkit-backdrop-filter:blur(24px);backdrop-filter:blur(24px)}
.cmdk-box input{width:100%;height:52px;padding:0 18px;border:0;border-bottom:1px solid var(--line);background:transparent;color:var(--ink);font:inherit;font-size:16px;outline:none}
.cmdk-list{max-height:320px;overflow-y:auto;padding:6px}
.cmdk-item{padding:11px 13px;border-radius:9px;font-size:14px;color:var(--ink);cursor:pointer}
.cmdk-item:hover,.cmdk-item.on{background:color-mix(in srgb,var(--accent) 18%,transparent)}
.cmdk-empty{padding:16px;text-align:center;color:var(--ink3);font-size:13px}
.bplans{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-top:6px}
.bplan{border:1px solid var(--line);border-radius:var(--r-lg);background:var(--card);padding:16px;display:flex;flex-direction:column}
.bplan.on{border-color:var(--accent);box-shadow:inset 0 0 0 1px var(--accent)}
.bp-h{display:flex;align-items:center;gap:8px}.bp-n{font-size:15px;color:var(--ink);font-weight:500}
.bp-p{font-family:'Italiana',serif;font-size:30px;color:var(--ink);margin:6px 0 10px}
.bp-f{list-style:none;margin:0 0 14px;padding:0;flex:1}
.bp-f li{font-size:12.5px;color:var(--ink2);padding:4px 0 4px 18px;position:relative}
.bp-f li::before{content:"\2713";position:absolute;left:0;color:var(--accent)}
.bp-cta{border:0;border-radius:11px;padding:10px;font:inherit;font-weight:600;font-size:13px;color:#06140d;background:linear-gradient(95deg,#e8a23a,#d8442a);cursor:pointer}
.bp-cta.ghost{background:transparent;border:1px solid var(--line2);color:var(--ink2)}
@media(max-width:620px){.bplans{grid-template-columns:1fr}}
.rbars{display:flex;align-items:flex-end;justify-content:space-between;gap:8px;height:132px;padding-top:6px}
.rbar{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:flex-end;gap:5px}
.rbar-fill{width:60%;max-width:34px;border-radius:6px 6px 0 0;transition:height .5s var(--ease)}
.rbar-v{font-size:11px;color:var(--ink2);font-family:'Italiana',serif}.rbar-l{font-size:10px;color:var(--ink3)}
/* mobile: app-like fixed bottom tab bar with safe-area */
.tabbar{padding-bottom:calc(14px + env(safe-area-inset-bottom,0px))}

/* ============ lockdown takeover stage ============ */
.lock-stage{width:100%;max-width:460px}
.lk-seal{text-align:center;color:#f6efe8}
.lk-score{font-family:'Italiana',serif;font-size:66px;line-height:.9;margin:6px 0;color:#f0a06a}
.lk-seal h2{font-family:'Italiana',serif;font-weight:400;font-size:30px;margin:10px 0 6px;color:#f6efe8}
.lk-seal p{font-size:14px;color:#c9bdb0;max-width:380px;margin:0 auto;line-height:1.5}
.lk-seal .row{background:rgba(255,255,255,.04)}
.lockwrap[data-lkstate=unlocked]{background:linear-gradient(180deg,#163a2b 0%,#0a1410 70%)!important;transition:background .8s var(--ease)}

/* ============ North — AI coach ============ */
.north-fab{position:fixed;right:22px;bottom:22px;z-index:95;width:58px;height:58px;border-radius:50%;border:0;cursor:pointer;
  background:radial-gradient(circle at 35% 30%, color-mix(in srgb,var(--accent) 80%,#fff), var(--accent) 72%);
  box-shadow:0 8px 28px rgba(0,0,0,.42), inset 0 0 0 1px rgba(255,255,255,.14);
  display:grid;place-items:center;transition:transform .25s var(--ease)}
.north-fab:hover{transform:scale(1.06)}
.north-orb{position:relative;width:30px;height:30px;display:block}
.north-orb i{position:absolute;inset:0;border-radius:50%;border:2px solid rgba(255,255,255,.85);opacity:0;animation:northPulse 3.2s var(--ease) infinite}
.north-orb i:nth-child(1){animation-delay:0s}
.north-orb i:nth-child(2){animation-delay:.8s}
.north-orb i:nth-child(3){animation-delay:1.6s}
.north-orb i:nth-child(4){border:0;inset:9px;background:radial-gradient(circle at 40% 35%,#fff,rgba(255,255,255,.72));opacity:1;animation:northCore 3.2s ease-in-out infinite}
@keyframes northPulse{0%{transform:scale(.4);opacity:0}22%{opacity:.7}100%{transform:scale(1.55);opacity:0}}
@keyframes northCore{0%,100%{transform:scale(1)}50%{transform:scale(1.16)}}
.north-fab.busy .north-orb i{animation-duration:1.05s}
.north-orb.sm{width:26px;height:26px}
.np-head .north-orb.sm i{border-color:var(--accent)}
.np-head .north-orb.sm i:nth-child(4){inset:7px;background:radial-gradient(circle at 40% 35%,color-mix(in srgb,var(--accent) 55%,#fff),var(--accent))}
.north-panel{position:fixed;right:22px;bottom:90px;z-index:96;width:362px;max-width:calc(100vw - 28px);max-height:min(624px,calc(100vh - 120px));
  display:none;flex-direction:column;border-radius:20px;overflow:hidden;background:var(--sidebg);backdrop-filter:blur(20px);
  border:1px solid var(--line2);box-shadow:0 24px 70px rgba(0,0,0,.5)}
.north-panel.on{display:flex;animation:npRise .3s var(--ease)}
@keyframes npRise{from{opacity:0;transform:translateY(14px)}to{opacity:1;transform:none}}
.np-head{display:flex;align-items:center;gap:11px;padding:14px 16px;border-bottom:1px solid var(--line)}
.np-id{flex:1;line-height:1.15}
.np-id b{font-family:'Italiana',serif;font-weight:400;font-size:18px;color:var(--ink);display:block}
.np-id span{font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--accent)}
.np-x{background:none;border:0;color:var(--ink3);font-size:24px;cursor:pointer;line-height:1;padding:0 4px}
.np-thread{flex:1;overflow-y:auto;padding:16px;display:flex;flex-direction:column;gap:10px;min-height:150px}
.np-msg{max-width:85%;padding:10px 13px;border-radius:14px;font-size:13.5px;line-height:1.5}
.np-msg.bot{align-self:flex-start;background:var(--card);border:1px solid var(--line);color:var(--ink);border-bottom-left-radius:4px}
.np-msg.me{align-self:flex-end;background:var(--accent);color:#10130f;border-bottom-right-radius:4px}
.np-msg.typing{color:var(--ink3);font-style:italic}
.np-chips{display:flex;gap:7px;flex-wrap:wrap;padding:0 14px 12px}
.np-chip{font-size:12px;padding:7px 11px;border-radius:999px;border:1px solid var(--line2);background:transparent;color:var(--ink2);cursor:pointer;white-space:nowrap;font:inherit;font-size:12px}
.np-chip:hover{border-color:var(--accent);color:var(--ink)}
.np-input{display:flex;align-items:center;gap:8px;padding:12px 14px;border-top:1px solid var(--line)}
.np-input input{flex:1;background:var(--card);border:1px solid var(--line2);border-radius:999px;padding:10px 14px;color:var(--ink);font:inherit;font-size:13.5px;outline:none}
.np-input input:focus{border-color:var(--accent)}
.np-mic,.np-send{width:36px;height:36px;flex:none;border-radius:50%;border:1px solid var(--line2);background:var(--card);color:var(--ink2);cursor:pointer;display:grid;place-items:center}
.np-mic svg,.np-send svg{width:17px;height:17px}
.np-send{background:var(--accent);border-color:var(--accent);color:#10130f}
.np-mic:hover{color:var(--ink);border-color:var(--accent)}
.ask-north{display:inline-flex;align-items:center;gap:7px;font:inherit;font-size:12px;padding:6px 12px;border-radius:999px;border:1px solid var(--line2);background:transparent;color:var(--accent);cursor:pointer;margin-top:12px}
.ask-north:hover{border-color:var(--accent);background:color-mix(in srgb,var(--accent) 12%,transparent)}
.ask-north::before{content:"";width:8px;height:8px;border-radius:50%;background:var(--accent);box-shadow:0 0 8px var(--accent);flex:none}
@media(max-width:919px){
  .north-fab{bottom:calc(92px + env(safe-area-inset-bottom,0px));right:16px;width:52px;height:52px}
  .north-panel{right:8px;left:8px;width:auto;bottom:calc(84px + env(safe-area-inset-bottom,0px));max-height:70vh}
}

/* ============ team Circle hub tabs ============ */
.ctabs{display:flex;flex-wrap:wrap;width:100%;gap:2px}
.ctabs button{flex:1;min-width:max-content;font-size:12px;padding:8px 12px;white-space:nowrap}
@media(max-width:919px){.ctabs button{font-size:11px;padding:7px 8px}}

/* ============ workspace switcher (Personal | Team) ============ */
.wsswitch{display:flex;gap:2px;margin:0 4px 12px;padding:3px;border:1px solid var(--line);border-radius:999px;background:var(--card);position:relative;z-index:2}
.wsswitch button{flex:1;border:0;background:transparent;color:var(--ink3);font:inherit;font-size:12.5px;padding:7px 0;border-radius:999px;cursor:pointer;transition:.18s}
.wsswitch button.on{background:color-mix(in srgb,var(--accent) 24%,transparent);color:var(--ink)}
#app[data-rail] .wsswitch{display:none}

/* ============ team board (kanban) ============ */
.tboard{display:flex;gap:10px;overflow-x:auto;padding-bottom:6px}
.tcol{flex:1;min-width:148px;background:var(--card);border:1px solid var(--line);border-radius:14px;padding:10px}
.tcol-h{font-size:10.5px;letter-spacing:.1em;text-transform:uppercase;margin-bottom:9px;font-weight:600}
.tcard{background:color-mix(in srgb,var(--ink) 4%,transparent);border:1px solid var(--line);border-radius:10px;padding:9px 11px;margin-bottom:7px}

/* ============ team timeline (gantt) ============ */
.gantt{border:1px solid var(--line);border-radius:14px;padding:12px;background:var(--card)}
.gantt-row{display:flex;align-items:center;gap:10px;margin-bottom:9px}
.gantt-row:last-child{margin-bottom:0}
.g-lbl{width:104px;flex:none;font-size:12px;color:var(--ink2);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.gantt-head .g-track{background:none;height:14px}
.g-wk{position:absolute;top:0;transform:translateX(-50%);font-size:10px;letter-spacing:.06em;color:var(--ink3);white-space:nowrap}
.g-track{flex:1;position:relative;height:20px;background:var(--track);border-radius:6px}
.g-bar{position:absolute;top:0;height:20px;border-radius:6px;min-width:8px;box-shadow:inset 0 0 0 1px rgba(255,255,255,.15)}
.g-pace{position:absolute;top:-4px;bottom:-4px;width:0;border-left:2px dashed var(--ink2);opacity:.55;z-index:3}
.g-ms{position:absolute;top:50%;transform:translate(-50%,-50%);font-size:12px;line-height:1;z-index:4;text-shadow:0 0 5px rgba(0,0,0,.5);cursor:default}
.g-ms.burn{animation:msburn 1.4s ease-in-out infinite}
@keyframes msburn{0%,100%{opacity:1}50%{opacity:.35}}
@media(max-width:919px){.g-lbl{width:80px;font-size:11px}}

/* ============ context-switching sidebar (Personal | Team mode) ============ */
.tnav-grp{display:none;flex-direction:column;gap:3px;position:relative;z-index:2}
#app[data-mode=team] .tnav-grp{display:flex}
#app[data-mode=team] > .side .nav,
#app[data-mode=team] > .side .qcap{display:none}
.tnav{display:flex;align-items:center;gap:11px;padding:10px 12px;border-radius:11px;color:var(--ink2);font-size:14.5px;cursor:pointer;transition:.18s}
.tnav svg{width:19px;height:19px;flex:none}
.tnav:hover{background:var(--card);color:var(--ink)}
.tnav.on{background:color-mix(in srgb,var(--accent) 22%,transparent);color:var(--ink);box-shadow:inset 2px 0 0 var(--accent);backdrop-filter:blur(4px)}
.wsorg{display:flex;align-items:center;gap:9px;width:100%;padding:9px 12px;margin-bottom:8px;border-radius:11px;border:1px solid var(--line2);background:var(--card);color:var(--ink);font:inherit;font-size:13.5px;cursor:pointer}
.wsorg-dot{width:9px;height:9px;border-radius:50%;background:var(--accent);box-shadow:0 0 8px var(--accent);flex:none}
/* sidebar drives team nav on desktop → hide the in-screen tab strip there */
@media(min-width:920px){#app[data-mode=team] #ctabs{display:none}}
/* rail-collapsed team nav: hide org switcher label like other labels */
#app[data-rail] .wsorg span{display:none}

/* ============ clock-in / out ============ */
.clockbtn{display:inline-flex;align-items:center;gap:7px;height:34px;padding:0 13px;border-radius:999px;border:1px solid var(--line2);background:var(--card);color:var(--ink);font:inherit;font-size:12.5px;cursor:pointer;white-space:nowrap}
.clockbtn .clk-dot{width:8px;height:8px;border-radius:50%;background:var(--ink3);flex:none}
.clockbtn.on{border-color:var(--accent)}
.clockbtn.on .clk-dot{background:var(--accent);box-shadow:0 0 8px var(--accent);animation:northCore 2s ease-in-out infinite}
.dp-in{width:100%;background:var(--card);border:1px solid var(--line2);border-radius:10px;padding:11px 13px;color:var(--ink);font:inherit;font-size:14px;outline:none;margin-bottom:9px}
.dp-in:focus{border-color:var(--accent)}
@media(max-width:919px){.clockbtn{padding:0 9px;font-size:11px}.clockbtn #clkLabel{display:none}.clockbtn.on #clkLabel{display:inline}}

/* clock button — icon-only at rest, pill when clocked in (fixes greeting overlap) */
.clockbtn{width:34px;padding:0;justify-content:center}
.clockbtn .clk-ic{width:18px;height:18px;display:inline-block;flex:none}
.clockbtn .clk-dot,.clockbtn #clkLabel{display:none}
.clockbtn.on{width:auto;padding:0 13px}
.clockbtn.on .clk-ic{display:none}
.clockbtn.on .clk-dot{display:inline-block}
.clockbtn.on #clkLabel{display:inline}
@media(min-width:920px){.home .topgreet{padding-right:176px}}

/* ===== live-time clock pill (overrides earlier icon-only rules) ===== */
.clockbtn{width:auto;height:34px;padding:0 12px;display:inline-flex;align-items:center;gap:7px;border-radius:999px;border:1px solid var(--line2);background:var(--card);color:var(--ink);font:inherit;font-size:12.5px;cursor:pointer;white-space:nowrap}
.clockbtn .clk-dot{display:inline-block;width:8px;height:8px;border-radius:50%;background:var(--ink3);flex:none}
.clockbtn #clkTime{display:inline;font-variant-numeric:tabular-nums}
.clockbtn.on{border-color:var(--accent)}
.clockbtn.on .clk-dot{background:var(--accent);box-shadow:0 0 8px var(--accent)}
.clockbtn.danger{border-color:#e6483a;color:#ffb4ab}
.clockbtn.danger .clk-dot{background:#e6483a;box-shadow:0 0 8px #e6483a;animation:clkBlink 1s steps(1) infinite}
@keyframes clkBlink{0%,49%{opacity:1}50%,100%{opacity:.2}}
/* ===== designed profile button + structured collapse ===== */
.side .me{margin:6px 4px 2px;padding:9px 10px;border-radius:12px;border:1px solid var(--line);background:var(--card);gap:10px;cursor:pointer;transition:.18s}
.side .me:hover{border-color:var(--accent)}
.side .me #coin2{width:28px;height:28px;border-radius:50%;overflow:hidden;flex:none;display:grid;place-items:center}
.side .me #meName{flex:1;font-size:13px;color:var(--ink);font-weight:500}
.side .me::after{content:'⋯';color:var(--ink3);font-size:17px;line-height:1;margin-left:auto}
#app[data-rail] .side .me::after{display:none}
.railtog{display:flex!important;align-items:center;gap:9px;width:auto;margin:8px 4px 2px;padding:9px 12px;border-radius:11px;border:1px solid var(--line);background:transparent;color:var(--ink2);font:inherit;font-size:12.5px;cursor:pointer;transition:.18s}
.railtog:hover{border-color:var(--line2);color:var(--ink);background:var(--card)}
.railtog svg{width:16px;height:16px;flex:none}

/* ===== task detail drawer ===== */
.taskdrawer{position:fixed;top:0;right:0;bottom:0;width:404px;max-width:92vw;z-index:97;background:var(--sidebg);backdrop-filter:blur(20px);border-left:1px solid var(--line2);box-shadow:-24px 0 70px rgba(0,0,0,.5);transform:translateX(100%);transition:transform .3s var(--ease);overflow-y:auto}
.taskdrawer.on{transform:none}
.td-inner{padding:22px 20px;position:relative}
.td-x{position:absolute;top:14px;right:14px;width:30px;height:30px;border-radius:50%;border:1px solid var(--line2);background:var(--card);color:var(--ink2);font-size:18px;line-height:1;cursor:pointer}
.td-x:hover{color:var(--ink);border-color:var(--accent)}

/* ===== project lockdown (team-scale consequence) ===== */
.projseal{text-align:center;border:1px solid #5a2a1c;border-radius:18px;padding:26px 20px 18px;background:linear-gradient(180deg,rgba(214,68,42,.13),rgba(0,0,0,0))}
.projseal .li{font-size:32px;color:#e6753a}
.projseal .ps-score{font-family:'Italiana',serif;font-size:54px;line-height:.9;color:#e6753a;margin:4px 0}
.projseal h2{font-family:'Italiana',serif;font-weight:400;font-size:25px;color:var(--ink);margin:4px 0}
.projseal p{font-size:13.5px;color:var(--ink2);max-width:360px;margin:6px auto 6px;line-height:1.5}
.projseal .row:hover{border-color:#e6753a}

/* ===== mobile team tab bar ===== */
@media(max-width:919px){
  #app:not([data-mode=team]) .tabbar-team{display:none}
  #app[data-mode=team] .tabbar:not(.tabbar-team){display:none}
}
html.fm #app:not([data-mode=team]) .tabbar-team{display:none}
html.fm #app[data-mode=team] .tabbar:not(.tabbar-team){display:none}
/* in the phone-frame preview, keep the in-screen team tab strip reachable (matches real mobile, where the min-width:920 hide rule doesn't apply) */
html.fm #app[data-mode=team] #ctabs{display:flex}

/* ===== view types: member/client cards (boxes) + board swimlane (v1.28.1) ===== */
.mboxes{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:10px}
.mbox{position:relative;border:1px solid var(--line);border-radius:14px;background:var(--card);padding:16px 14px 14px;text-align:center;cursor:pointer;transition:border-color .15s}
.mbox:hover{border-color:var(--accent)}
.mbox-av{width:38px;height:38px;border-radius:50%;display:grid;place-items:center;color:#06140d;font-weight:600;font-size:15px;margin:0 auto 8px}
.mbox-score{font-family:'Italiana',serif;font-size:26px;line-height:1}
.mbox-n{font-size:13.5px;color:var(--ink);margin-top:6px;font-weight:500}
.mbox-in{color:#5fba84;font-size:9px;vertical-align:middle}
.mbox-r{font-size:11px;color:var(--ink3);margin-top:2px}
.swimlane{border:1px solid var(--line);border-radius:14px;background:var(--card);padding:12px 14px;margin-bottom:10px}
.swim-h{font-size:13px;color:var(--ink);font-weight:600;margin-bottom:10px}
.swim-cards{display:flex;gap:8px;flex-wrap:wrap}
.swim-card{flex:1;min-width:160px;border:1px solid var(--line);border-radius:10px;background:var(--card2,rgba(255,255,255,.02));padding:9px 11px}
@media(max-width:560px){.mboxes{grid-template-columns:1fr 1fr}.swim-card{min-width:120px}}
/* report / invoice / okr cards */
.repcard{border:1px solid var(--line);border-radius:14px;background:var(--card);padding:14px 14px 13px}
.repmetrics{display:flex;justify-content:space-between;gap:6px;margin-top:10px;border-top:1px solid var(--line);padding-top:9px}
.repmetrics span{font-size:13px;color:var(--ink);font-family:'Italiana',serif;display:flex;flex-direction:column;line-height:1.2}
.repmetrics small{font-size:9px;letter-spacing:.04em;text-transform:uppercase;color:var(--ink3);font-family:'Instrument Sans',sans-serif;margin-top:2px}
.vpick{flex-wrap:wrap}

/* ===== sidebar containment + team menu grouping (v1.29) ===== */
.side{overflow:hidden}
.sidescroll{position:relative;z-index:2;flex:1 1 auto;min-height:0;overflow-y:auto;overflow-x:hidden;display:flex;flex-direction:column;gap:4px;margin:0 -6px;padding:2px 6px;scrollbar-width:thin}
.sidescroll::-webkit-scrollbar{width:6px}
.sidescroll::-webkit-scrollbar-thumb{background:var(--line2);border-radius:3px}
.sidescroll::-webkit-scrollbar-track{background:transparent}
.side .side-meta{margin-top:8px}
.tnav-sec{font-size:9.5px;letter-spacing:.16em;text-transform:uppercase;color:var(--ink3);padding:13px 12px 3px;font-weight:600}
.tnav-grp .tnav-sec:first-of-type{padding-top:6px}
#app[data-rail] .tnav-sec{display:none}
#app[data-rail] .sidescroll{margin:0;padding:2px 0}

/* ===== designed empty state (v1.28) ===== */
.estate{display:flex;flex-direction:column;align-items:center;text-align:center;padding:34px 22px;border:1px dashed var(--line2);border-radius:16px;background:var(--card)}
.es-ic{width:46px;height:46px;border-radius:14px;display:grid;place-items:center;background:var(--track);color:var(--ink3);margin-bottom:12px}
.es-ic svg{width:24px;height:24px}
.es-t{font-size:15px;color:var(--ink);font-weight:500}
.es-s{font-size:12.5px;color:var(--ink3);margin-top:4px;max-width:300px;line-height:1.5}
.es-cta{margin-top:14px;border:1px solid var(--line);background:transparent;color:var(--accent);border-radius:999px;padding:8px 16px;font:inherit;font-size:12.5px;cursor:pointer}
.es-cta:hover{border-color:var(--accent)}
.srhead{font-size:12.5px;color:var(--ink3);margin:2px 0 10px}

/* ===== client portal ===== */
.portal-top{display:flex;align-items:center;gap:12px;padding:16px;border:1px solid var(--line);border-radius:16px;background:var(--card)}
.portal-logo{width:42px;height:42px;border-radius:12px;display:grid;place-items:center;color:#06140d;font-weight:700;font-family:'Italiana',serif;font-size:20px;flex:none}

/* ===== invoicing ===== */
.invst{font-size:10.5px;letter-spacing:.06em;text-transform:uppercase;min-width:56px;text-align:right;flex:none}

/* ===== personal calendar ===== */
.calnav{display:flex;align-items:center;gap:8px;margin:2px 0 14px}
.calmon{font-family:'Italiana',serif;font-size:21px;color:var(--ink);flex:1;text-align:center}
.calarw{width:34px;height:34px;border-radius:10px;border:1px solid var(--line);background:transparent;color:var(--ink);font-size:18px;line-height:1;cursor:pointer;display:grid;place-items:center}
.calarw:hover{border-color:var(--accent);color:var(--accent)}
.calgrid{display:grid;grid-template-columns:repeat(7,1fr);gap:5px}
.calhead{margin-bottom:5px}
.caldow{text-align:center;font-size:10.5px;letter-spacing:.06em;text-transform:uppercase;color:var(--ink3)}
.calcell{position:relative;aspect-ratio:1;border:1px solid var(--line);border-radius:10px;background:var(--card);padding:5px 6px;min-height:46px;overflow:hidden}
.calcell.empty{border:none;background:transparent}
.calcell.today{border-color:var(--accent);box-shadow:inset 0 0 0 1px var(--accent)}
.caln{font-size:12px;color:var(--ink2)}
.calsc{position:absolute;right:6px;top:4px;font-family:'Italiana',serif;font-size:14px}
.caldots{position:absolute;left:6px;bottom:6px;display:flex;gap:3px}
.cd{width:6px;height:6px;border-radius:50%;display:inline-block}
.callegend{display:flex;gap:16px;flex-wrap:wrap;margin-top:14px;font-size:11.5px;color:var(--ink3)}
.callegend span{display:inline-flex;align-items:center;gap:5px}
@media(max-width:560px){.calcell{min-height:40px;padding:3px 4px}.calsc{font-size:12px}.caln{font-size:11px}.calgrid{gap:3px}}

/* ---- Orb brand mark (ember disc + white core/rings · coin retired; FAB/score orbs stay band-colored on --accent) ---- */
.orb-brand{position:relative;display:inline-grid;place-items:center;border-radius:50%;flex:none;vertical-align:middle;
  background:radial-gradient(circle at 42% 38%,#f4c36c,#e8a23a 45%,#d98b2f 100%);
  box-shadow:0 4px 14px rgba(0,0,0,.35), inset 0 0 0 1px rgba(255,255,255,.14)}
.orb-brand .north-orb{width:18px;height:18px}
.orb-brand .north-orb i:nth-child(4){inset:5px}
.orb-brand.orb-lg .north-orb{width:34px;height:34px}
.orb-brand.orb-lg .north-orb i:nth-child(4){inset:10px}
@media (prefers-reduced-motion:reduce){.orb-brand .north-orb i{animation:none!important}.orb-brand .north-orb i:nth-child(1),.orb-brand .north-orb i:nth-child(2),.orb-brand .north-orb i:nth-child(3){opacity:.5;transform:scale(1.1)}}
.orb-brand.orb-sm .north-orb{width:14px;height:14px}
.orb-brand.orb-sm .north-orb i:nth-child(4){inset:4px}

/* ---- Topbar layout hardening: greeting never under the fixed topbar + device safe areas (notch / Dynamic Island / punch-hole / home indicator) ---- */
.topbar{top:calc(14px + env(safe-area-inset-top,0px));right:calc(18px + env(safe-area-inset-right,0px))}
.topgreet{gap:12px}
.topgreet .g{flex:0 1 auto;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
@media(min-width:920px){
  /* pad the greeting by the MEASURED topbar width (--topbarw set by renderClock), minus the centered-.scr inset */
  .home .topgreet{padding-right:max(176px, calc(var(--topbarw,220px) + 24px - max(0px, (100vw - 1080px)/2)))}
}
.tabbar{padding-left:env(safe-area-inset-left,0px);padding-right:env(safe-area-inset-right,0px)}
.north-fab{right:calc(22px + env(safe-area-inset-right,0px));bottom:calc(22px + env(safe-area-inset-bottom,0px))}
@media(max-width:919px){
  .north-fab{bottom:calc(92px + env(safe-area-inset-bottom,0px));right:calc(16px + env(safe-area-inset-right,0px))}
}

/* ---------- ⋯ kebab + action sheet (simple edit everywhere) ---------- */
.kebab{flex:none;width:26px;height:26px;border:none;border-radius:8px;display:grid;place-items:center;background:transparent;color:var(--ink3);cursor:pointer;font:inherit;padding:0;opacity:.65;transition:opacity .15s,background .15s,color .15s}
.kebab::before{content:'\22EF';font-size:17px;line-height:1}
.kebab:hover{opacity:1;background:var(--card);color:var(--ink)}
.row:hover .kebab,.habit:hover .kebab,.tcard:hover .kebab,.mile:hover .kebab{opacity:1}
.sheet-ov{position:fixed;inset:0;z-index:320;background:rgba(4,5,7,.5);-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);display:flex;align-items:flex-end;justify-content:center;opacity:0;transition:opacity .2s var(--ease)}
.sheet-ov.on{opacity:1}
.sheet{width:100%;max-width:420px;margin:0 12px calc(16px + env(safe-area-inset-bottom,0px));border-radius:20px;border:1px solid var(--line2);background:var(--sidebg);-webkit-backdrop-filter:blur(24px);backdrop-filter:blur(24px);box-shadow:0 30px 80px -20px rgba(0,0,0,.65);padding:15px;transform:translateY(16px);transition:transform .24s var(--ease)}
.sheet-ov.on .sheet{transform:none}
@media(min-width:920px){.sheet-ov{align-items:center}.sheet{margin:0 12px}}
.sheet-t{font-family:'Italiana',serif;font-weight:400;font-size:20px;line-height:1.15;color:var(--ink);padding:2px 4px 12px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.sheet-a{display:flex;align-items:center;justify-content:space-between;gap:10px;width:100%;text-align:left;font:inherit;font-size:14px;color:var(--ink);background:var(--card);border:1px solid var(--line);border-radius:12px;padding:12px 14px;margin-bottom:7px;cursor:pointer;transition:border-color .15s}
.sheet-a:hover{border-color:var(--line2)}
.sheet-a small{color:var(--ink3);font-size:11.5px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:50%}
.sheet-a.danger{color:#e6753a}
.sheet-a.cancel{justify-content:center;color:var(--ink3);background:transparent;border-style:dashed;margin-bottom:0}
.sheet-a.save{justify-content:center;background:color-mix(in srgb,var(--accent) 24%,transparent);border-color:var(--accent);margin-bottom:0}
.sheet-in{width:100%;font:inherit;font-size:14px;color:var(--ink);background:var(--card);border:1px solid var(--line2);border-radius:12px;padding:12px 14px;margin-bottom:10px;outline:none;color-scheme:dark}
.sheet-in:focus{border-color:var(--accent)}
.sheet-btns{display:flex;gap:8px}

/* ---------- blood-red critical clock ---------- */
.clockbtn.danger{border-color:#b6492a}
.clockbtn.danger .clk-dot{background:#e6321e;box-shadow:0 0 10px #e6321e;animation:bloodPulse 1.6s ease-in-out infinite}
.clockbtn.danger{animation:bloodRing 1.8s ease-in-out infinite}
.clockbtn.danger2{animation:bloodRing .85s ease-in-out infinite;border-color:#e6321e}
.clockbtn.danger2 #clkTime{color:#ff5a3c;animation:bloodBlink .85s ease-in-out infinite}
.clockbtn.danger2 .clk-dot{animation:bloodPulse .85s ease-in-out infinite}
@keyframes bloodRing{0%,100%{box-shadow:0 0 0 0 rgba(220,40,20,.55)}50%{box-shadow:0 0 0 8px rgba(220,40,20,0)}}
@keyframes bloodBlink{0%,100%{opacity:1}50%{opacity:.4}}
@keyframes bloodPulse{0%,100%{transform:scale(1)}50%{transform:scale(1.4)}}
.time.burnred{color:#ff5a3c !important;font-weight:600;animation:bloodBlink 1.2s ease-in-out infinite}

/* ---------- mood orbs ---------- */
.moodrow{display:flex;align-items:center;gap:10px;margin-top:10px;padding:12px 15px;border:1px solid var(--line);border-radius:var(--r-md);background:var(--card)}
.moodrow .mq{flex:1;font-size:13px;color:var(--ink2);text-align:left}
.mood{display:inline-flex;align-items:center;gap:7px;border:1px solid var(--line);border-radius:999px;padding:7px 12px;cursor:pointer;background:transparent;font:inherit;font-size:13px;color:var(--ink2);transition:border-color .15s,background .15s,color .15s}
.mood i{width:9px;height:9px;border-radius:50%;background:currentColor;flex:none;display:inline-block}
.mood span{color:var(--ink);white-space:nowrap}
.mood:hover{border-color:currentColor;color:var(--ink)}
.mood.on{border-color:currentColor;background:color-mix(in srgb,currentColor 12%,transparent)}
.mood.on span{color:var(--ink)}
.moodweek{display:flex;gap:10px;align-items:center}
.moodweek .mood{width:30px;height:30px;padding:0;border-radius:50%;justify-content:center;gap:0;cursor:default}
.moodweek .mood i{width:auto;height:auto;position:absolute;inset:4px;border-radius:50%;opacity:.45}
.moodweek .mood span{display:none}
.moodweek .mood{position:relative}
.moodweek .md{font-size:10px;color:var(--ink3);text-align:center}

/* ---------- personal task drawer ---------- */
#dayCard{position:relative}
.pd-title{width:100%;font-family:'Italiana',serif;font-size:24px;line-height:1.15;color:var(--ink);background:transparent;border:0;border-bottom:1px dashed transparent;outline:none;padding:2px 0}
.pd-title:hover{border-bottom-color:var(--line2)}
.pd-title:focus{border-bottom-color:var(--accent)}
.pd-in{background:var(--card);border:1px solid var(--line);border-radius:8px;color:var(--ink);font:inherit;font-size:12.5px;padding:5px 8px;outline:none;color-scheme:dark}
.pd-in:focus{border-color:var(--accent)}

/* inline quick-add chip (section headers) */
.qadd{width:20px;height:20px;border-radius:7px;border:1px solid var(--line2);background:transparent;color:var(--ink3);font:inherit;font-size:14px;line-height:1;display:inline-grid;place-items:center;cursor:pointer;padding:0}
.qadd:hover{color:var(--ink);border-color:var(--accent);background:color-mix(in srgb,var(--accent) 14%,transparent)}

/* ===== Slice B — hierarchy depth (subtasks · deps · projects · areas) ===== */
.subchip{flex:none;font-size:10.5px;letter-spacing:.04em;color:var(--ink3);border:1px solid var(--line2);border-radius:999px;padding:2px 7px;margin-left:8px}
.lockg{flex:none;display:inline-grid;place-items:center;color:var(--ink3);margin-left:8px}
.row.blocked{opacity:.55}
.row.blocked .lb{text-decoration:none}
.bwarn{flex:none;font-size:10px;letter-spacing:.05em;text-transform:uppercase;color:#b6492a;background:rgba(230,117,58,.13);border:1px solid rgba(230,117,58,.35);border-radius:999px;padding:2px 7px;margin-left:8px}
.row.big.blockwarn{box-shadow:inset 3px 0 0 #e6753a}
.adot{display:inline-block;width:7px;height:7px;border-radius:50%;margin-right:7px;vertical-align:1px;flex:none}
.areachips{display:flex;gap:6px;flex-wrap:wrap;margin-top:8px}
.achip{font:inherit;font-size:11.5px;letter-spacing:.03em;color:var(--ink3);background:transparent;border:1px solid var(--line2);border-radius:999px;padding:4px 10px;cursor:pointer}
.achip:hover{color:var(--ink);border-color:var(--ac,var(--accent))}
.achip.on{color:var(--ac,var(--accent));border-color:var(--ac,var(--accent));background:color-mix(in srgb,var(--ac,var(--accent)) 14%,transparent)}
.pd-notes{width:100%;min-height:64px;resize:vertical;font:inherit;font-size:13px;line-height:1.5;color:var(--ink);background:var(--card);border:1px solid var(--line2);border-radius:10px;padding:9px 11px;margin-top:2px}
.pd-notes:focus{border-color:var(--accent);outline:none}
.subrow{padding:7px 0}
.subrow .ck{width:17px;height:17px;font-size:10px}
.subrow .lb{font-size:13px}
.subrow.done .lb{text-decoration:line-through;color:var(--ink3)}
.td-x.subdel{position:static;width:22px;height:22px;font-size:14px;flex:none;margin-left:8px;border:none;background:transparent;color:var(--ink3)}
.td-x.subdel:hover{color:#e6753a}
.blockwrap{display:flex;gap:6px;flex-wrap:wrap;align-items:center;margin-top:6px}
.bchip{font-size:11.5px;color:var(--ink2);border:1px solid var(--line2);border-radius:999px;padding:4px 10px;cursor:pointer;display:inline-flex;align-items:center;gap:4px}
.bchip:hover{color:#e6753a;border-color:#e6753a}
.glink{font-size:11px;color:var(--ink3);margin-top:3px}

/* ===== Projects page (personal containers) ===== */
.pjgrid{display:grid;grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:12px;margin-top:6px}
.pjcard{background:var(--card);border:1px solid var(--line);border-radius:14px;padding:14px 14px 16px;cursor:pointer;transition:border-color .15s,transform .15s}
.pjcard:hover{border-color:var(--accent);transform:translateY(-1px)}
.pj-name{font-size:15px;color:var(--ink);display:flex;align-items:center;gap:8px}
.pj-name .adot{width:8px;height:8px;margin:0;flex:none}
.pj-sub{font-size:11.5px;color:var(--ink3);margin-top:5px}
.pj-bar{margin-top:10px}
.backchip{display:inline-flex;align-items:center;gap:6px;font:inherit;font-size:12px;color:var(--ink3);background:transparent;border:1px solid var(--line2);border-radius:999px;padding:5px 12px;cursor:pointer;margin-bottom:12px}
.backchip:hover{color:var(--ink);border-color:var(--accent)}
.vocabrow{display:flex;gap:22px;flex-wrap:wrap;margin-top:2px}
.vocabrow .vlab{font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:var(--ink3);margin-bottom:6px}

/* ============================================================
   Track A — streamline pass: affordances, North FAB, mobile
   ============================================================ */
/* Kebab: always legible, bigger hit area; always-on for touch */
.kebab{width:30px;height:30px;opacity:.8}
.kebab::before{font-size:18px}
.kebab::after{content:'';position:absolute;inset:-7px}
.kebab{position:relative}
.row:hover .kebab,.habit:hover .kebab,.tcard:hover .kebab,.mile:hover .kebab,.pjcard:hover .kebab{opacity:1}
@media(hover:none){.kebab{opacity:1;background:color-mix(in srgb,var(--card) 55%,transparent)}}
/* Critical dot: keep size, widen tap target */
.crit{position:relative}
.crit::after{content:'';position:absolute;inset:-11px}
/* Section quick-add (+) : bigger + clearer */
.qadd{width:26px;height:26px;font-size:16px}
@media(hover:none){.qadd{width:34px;height:34px}}
/* "+ Add / New" rows read like real buttons */
.add{transition:border-color .15s,color .15s,background .15s}
.add:hover{border-color:color-mix(in srgb,var(--accent) 55%,var(--line2));color:var(--ink);background:color-mix(in srgb,var(--accent) 8%,transparent)}
.add:hover span{color:var(--accent)}

/* North FAB — labeled pill on desktop, auto-hide behind overlays */
@media(min-width:920px){
  .north-fab{width:auto;height:54px;border-radius:28px;padding:0 20px 0 12px;display:inline-flex;align-items:center;gap:11px}
  .north-fab::after{content:'Ask North';font-family:'Instrument Sans',sans-serif;font-size:13px;font-weight:600;color:#0a0b0d;white-space:nowrap;letter-spacing:.01em}
}
body:has(#taskDrawer.on) .north-fab,
body:has(#northPanel.on) .north-fab,
body:has(#sheetOv) .north-fab,
body:has(#cmdk.on) .north-fab,
body:has(.lockwrap.on) .north-fab{opacity:0;transform:scale(.7);pointer-events:none}

/* Mobile polish: even stat tiles, drop redundant greeting, denser tabbar targets */
.statrow .w__l{line-height:1.3;min-height:2.5em;display:flex;align-items:flex-end}
@media(max-width:560px){
  .topgreet .g{display:none}
  .statrow .w__v{font-size:30px}
  .tab{padding:5px 0}
}
/* Mobile "More" tab sheet uses the standard sheet; nothing extra needed */
/* Inline "Ask North" pill inside the insight banner: align with the text, not pushed down */
.insight .ask-north{margin-top:0;align-self:center;margin-left:auto;flex:none}
.insight .it{flex:1 1 auto;min-width:0}

/* ============================================================
   AURORA — selectable WORLD SKIN (Seafoam). Additive over Cine.
   Activated by data-theme="aurora" on <html>. The engine keeps
   --accent / --accent-2 / --aur / --star / --cold in sync with
   the live score. Brand orb stays ember; layouts unchanged.
   ============================================================ */
/* aurora world layers stay hidden unless the aurora skin is active */
.aurora,.stars,.cold-veil{display:none}
[data-theme="aurora"]{--aur:.9;--star:.9;--cold:0;--accent-2:var(--accent)}
html[data-theme="aurora"] body{background:#06121a}
[data-theme="aurora"] .app{background:#06121a}
[data-theme="aurora"] #world{background:linear-gradient(180deg,#04090e,#06121a 52%,#08171f 100%)}
/* turn OFF the cine dawn layers (engine still paints them; we just hide) */
[data-theme="aurora"] #sky,[data-theme="aurora"] #sun,[data-theme="aurora"] #timeLayer,[data-theme="aurora"] #hill,[data-theme="aurora"] #worldMotes{opacity:0!important}
[data-theme="aurora"] #scrim{background:radial-gradient(62% 64% at 50% 38%,rgba(0,0,0,.5) 0%,transparent 76%)!important}
/* aurora ribbons (replace the horizon sun) */
[data-theme="aurora"] .aurora{display:block;position:absolute;left:-12%;right:-12%;z-index:2;filter:blur(22px);opacity:var(--aur);transform-origin:bottom;transition:opacity .5s;pointer-events:none}
[data-theme="aurora"] .aurora.a1{bottom:30%;height:200px;background:radial-gradient(60% 100% at 32% 100%,var(--accent),transparent 70%);animation:aur-drift 15s ease-in-out infinite}
[data-theme="aurora"] .aurora.a2{bottom:26%;height:250px;background:radial-gradient(55% 100% at 70% 100%,var(--accent-2),transparent 72%);animation:aur-drift 19s ease-in-out infinite reverse}
@keyframes aur-drift{0%,100%{transform:translateX(-3%)}50%{transform:translateX(4%)}}
/* star field (replace the motes) */
[data-theme="aurora"] .stars{display:block;position:absolute;inset:0;z-index:1;opacity:var(--star);transition:opacity .5s;pointer-events:none}
[data-theme="aurora"] .stars span{position:absolute;width:2px;height:2px;border-radius:50%;background:#fff;animation:aur-twinkle 4s ease-in-out infinite}
@keyframes aur-twinkle{0%,100%{opacity:.2}50%{opacity:.95}}
/* cold / starless veil for lockdown */
[data-theme="aurora"] .cold-veil{display:block;position:absolute;inset:0;z-index:4;pointer-events:none;background:#050a12;opacity:calc(var(--cold) * .6);transition:opacity .5s}
/* sidebar mini-world → night sky (drop the dawn sun, cool the gradient) */
[data-theme="aurora"] #swSun{opacity:0!important}
[data-theme="aurora"] #swSky{background:linear-gradient(180deg,#05090e,#08171f 90%)!important}
@media (prefers-reduced-motion: reduce){
  [data-theme="aurora"] .aurora,[data-theme="aurora"] .stars span{animation:none}
}

/* sidebar Theme picker (Cine / Aurora / Atelier) — z-index above .side-scrim(1)/.sidescroll(2) so clicks land */
.themedrop{position:relative;z-index:6;margin:2px 0 6px}
.themedrop-btn{width:100%;display:flex;align-items:center;gap:9px;font:inherit;font-size:13px;color:var(--ink2);background:transparent;border:1px solid transparent;border-radius:10px;padding:8px 10px;cursor:pointer;transition:background .15s,color .15s}
.themedrop-btn:hover{color:var(--ink);background:color-mix(in srgb,var(--accent) 10%,transparent)}
.themedrop-btn .ti{display:inline-grid;place-items:center;color:var(--accent);flex:none}
.themedrop-btn .chev{margin-left:auto;color:var(--ink3);transition:transform .18s}
.themedrop.open .themedrop-btn .chev{transform:rotate(180deg)}
.themedrop-menu{display:none;position:absolute;left:0;right:0;bottom:calc(100% + 6px);background:var(--sidebg);backdrop-filter:blur(20px) saturate(1.5);-webkit-backdrop-filter:blur(20px) saturate(1.5);border:1px solid var(--line2);border-radius:12px;padding:6px;z-index:80;box-shadow:0 16px 50px rgba(0,0,0,.55)}
.themedrop.open .themedrop-menu{display:block}
.themedrop-menu button{display:flex;align-items:center;gap:10px;width:100%;text-align:left;font:inherit;font-size:13px;color:var(--ink);background:transparent;border:0;border-radius:8px;padding:9px 10px;cursor:pointer}
.themedrop-menu button:hover{background:color-mix(in srgb,var(--accent) 16%,transparent)}
.themedrop-menu button.on{color:var(--accent)}
.themedrop-menu button .ti{display:inline-grid;place-items:center;color:var(--accent);opacity:.92;flex:none}

/* Theme picker v2 — inline segmented (no popup). Icon + name rows; active highlighted. */
.themeseg{display:flex;flex-direction:column;gap:2px;margin:6px 0 4px;position:relative;z-index:6}
.themeseg button{display:flex;align-items:center;gap:9px;width:100%;text-align:left;font:inherit;font-size:13px;color:var(--ink2);background:transparent;border:1px solid transparent;border-radius:10px;padding:7px 10px;cursor:pointer;transition:background .15s,color .15s,border-color .15s}
.themeseg button:hover{color:var(--ink);background:color-mix(in srgb,var(--accent) 10%,transparent)}
.themeseg button.on{color:var(--ink);background:color-mix(in srgb,var(--accent) 16%,transparent);border-color:color-mix(in srgb,var(--accent) 36%,transparent)}
.themeseg button .ti{display:inline-grid;place-items:center;color:var(--accent);flex:none}

/* Environment bar — theme dropdown (<details>) + separate light/dark toggle, at top of sidebar */
.envbar{position:relative;z-index:6;margin:2px 4px 12px;padding:0 2px}
.env-eyebrow{font-size:9.5px;letter-spacing:.18em;text-transform:uppercase;color:var(--ink3);margin:0 4px 5px}
.env-row{display:flex;align-items:center;gap:6px}
.envdrop{position:relative;flex:1;min-width:0}
.envdrop>summary{list-style:none;display:flex;align-items:center;gap:8px;font:inherit;font-size:13px;color:var(--ink);background:var(--card);border:1px solid var(--line);border-radius:10px;padding:7px 10px;cursor:pointer;transition:border-color .15s,background .15s}
.envdrop>summary::-webkit-details-marker{display:none}
.envdrop>summary:hover{border-color:var(--line2)}
.envdrop>summary .ti{display:inline-grid;place-items:center;color:var(--accent);flex:none}
.envdrop>summary .tn{flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.envdrop>summary .chev{color:var(--ink3);flex:none;transition:transform .18s}
.envdrop[open]>summary{border-color:color-mix(in srgb,var(--accent) 42%,transparent)}
.envdrop[open]>summary .chev{transform:rotate(180deg)}
.envdrop-menu{position:absolute;left:0;right:0;top:calc(100% + 5px);background:var(--sidebg);-webkit-backdrop-filter:blur(20px) saturate(1.4);backdrop-filter:blur(20px) saturate(1.4);border:1px solid var(--line2);border-radius:12px;padding:6px;z-index:80;box-shadow:0 18px 50px rgba(0,0,0,.5)}
.envdrop-menu button{display:flex;align-items:center;gap:10px;width:100%;text-align:left;font:inherit;font-size:13px;color:var(--ink);background:transparent;border:0;border-radius:8px;padding:9px 10px;cursor:pointer}
.envdrop-menu button:hover{background:color-mix(in srgb,var(--accent) 16%,transparent)}
.envdrop-menu button.on{color:var(--accent)}
.envdrop-menu button .ti{display:inline-grid;place-items:center;color:var(--accent);flex:none;opacity:.92}
.modetog{display:flex;gap:2px;background:var(--card);border:1px solid var(--line);border-radius:10px;padding:3px;flex:none}
.modetog button{display:grid;place-items:center;width:30px;height:28px;border:0;border-radius:7px;background:transparent;color:var(--ink3);cursor:pointer;transition:.15s}
.modetog button:hover{color:var(--ink)}
.modetog button.on{background:color-mix(in srgb,var(--accent) 20%,transparent);color:var(--accent)}

/* Red-clock urgent popover (reuses .notifpop chrome) */
#urgentPop .np-item{width:100%;text-align:left;background:transparent;border:0;font:inherit;cursor:pointer}
#urgentPop .np-empty{padding:14px 12px;color:var(--ink3);font-size:13px}
#urgentPop .np-all{display:block;width:100%;text-align:left;margin-top:4px;padding:10px;border:0;border-top:1px solid var(--line);background:transparent;color:var(--accent);font:inherit;font-size:12.5px;font-weight:600;cursor:pointer}
#urgentPop .np-all:hover{background:var(--card)}

/* Habit detail drawer */
.hstat4{grid-template-columns:repeat(4,1fr)}
@media(max-width:560px){.hstat4{grid-template-columns:1fr 1fr}}
.hcgrid{display:flex;flex-direction:column;gap:4px;margin:4px 0 2px}
.hcg-row{display:flex;gap:4px}
.hcgrid .wd{flex:1;width:auto;height:13px;border-radius:4px}
.hcgrid .wd.ghost{opacity:.22;pointer-events:none;background:var(--track);border-color:transparent}
.hlog-today{width:100%;margin-top:10px;padding:11px;border:1px solid var(--line2);border-radius:12px;background:transparent;color:var(--ink);font:inherit;font-weight:600;font-size:14px;cursor:pointer;transition:background .15s,border-color .15s,color .15s}
.hlog-today:hover{background:var(--card)}
.hlog-today.on{background:color-mix(in srgb,var(--accent) 18%,transparent);border-color:color-mix(in srgb,var(--accent) 45%,transparent);color:var(--accent)}
.hlog-feed{margin-top:8px;display:flex;flex-direction:column}
.hlog-item{padding:9px 2px;border-bottom:1px solid var(--line)}
.hlog-b{font-size:13.5px;color:var(--ink);line-height:1.45}
.hlog-t{font-size:11px;color:var(--ink3);margin-top:3px}
.hlog-empty{padding:10px 2px;font-size:13px;color:var(--ink3)}

/* Task attachments */
.fileadd{display:inline-flex;align-items:center;gap:7px;margin-top:2px;padding:8px 12px;border:1px dashed var(--line2);border-radius:10px;background:transparent;color:var(--ink2);font:inherit;font-size:13px;cursor:pointer;transition:background .15s,color .15s,border-color .15s}
.fileadd:hover{color:var(--ink);border-color:var(--accent);background:color-mix(in srgb,var(--accent) 8%,transparent)}
.fileadd svg{color:var(--accent);flex:none}
.filelist{margin-top:8px;display:flex;flex-direction:column}
.filerow{display:flex;align-items:center;gap:9px;padding:8px 2px;border-bottom:1px solid var(--line)}
.filerow .fi-ic{color:var(--ink3);flex:none}
.filerow .fi-name{flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-size:13px;color:var(--ink)}
.filerow .fi-name[data-fileopen]:hover{color:var(--accent);text-decoration:underline}
.filerow .fi-sz{font-size:11px;color:var(--ink3);flex:none}
.filerow .fi-x{flex:none}

/* Goals — Climb view (camps on an ascent) */
.climb{position:relative}
.climb-peak{position:relative;height:96px;margin:2px 0 4px;border-radius:14px;overflow:hidden;display:flex;align-items:flex-end;justify-content:center}
.climb-peak .peak-svg{position:absolute;inset:0;width:100%;height:100%}
.climb-peak .peak-svg path{fill:color-mix(in srgb,var(--accent) 15%,transparent);stroke:color-mix(in srgb,var(--accent) 42%,transparent);stroke-width:1}
.peak-cap{position:relative;text-align:center;padding-bottom:12px}
.peak-lab{font-size:10px;letter-spacing:.22em;text-transform:uppercase;color:var(--ink3)}
.peak-pct{font-family:'Italiana',serif;font-size:34px;line-height:1;color:var(--ink)}
.peak-sub{font-size:11px;color:var(--ink3)}
.climb-trail{position:relative;padding-left:32px;margin-top:6px}
.climb-trail::before{content:"";position:absolute;left:14px;top:10px;bottom:10px;width:2px;background:repeating-linear-gradient(var(--line2) 0 5px,transparent 5px 10px)}
.camp{position:relative;display:flex;align-items:center;gap:10px;width:100%;text-align:left;background:transparent;border:0;border-radius:12px;padding:10px 8px 10px 0;cursor:pointer;font:inherit;transition:background .15s}
.camp:hover{background:var(--card)}
.camp-node{position:absolute;left:-25px;top:50%;transform:translateY(-50%);width:18px;height:18px;border-radius:50%;background:var(--card);border:2px solid var(--line2);display:grid;place-items:center;color:#06140d;transition:.2s}
.camp.reached .camp-node{background:var(--accent);border-color:var(--accent)}
.camp-body{flex:1;min-width:0;display:flex;flex-direction:column;gap:2px}
.camp-lvl{font-size:9.5px;letter-spacing:.16em;text-transform:uppercase;color:var(--ink3)}
.camp-title{font-size:14px;color:var(--ink);font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.camp .gbar{margin-top:3px}
.camp-sub{font-size:11px;color:var(--ink3);margin-top:2px}
.camp-pct{font-family:'Italiana',serif;font-size:18px;color:var(--ink2);flex:none}
.camp.reached .camp-pct{color:var(--accent)}

/* ============================================================
   ATELIER — light editorial PAPER skin. Additive over Cine.
   Activated by data-theme="atelier". Engine sets --accent +
   --paper per band (warm/fade); functional text stays AA
   (pinned in setTheme), only #num/#say fade decoratively.
   ============================================================ */
.paper-grain,.paper-vig,.paper-fox{display:none}
html[data-theme="atelier"] body{background:var(--paper,#f4eddb)}
[data-theme="atelier"] .app{background:var(--paper,#f4eddb)}
[data-theme="atelier"] #world{background:var(--paper,#f4eddb)}
/* atelier's world is the PAGE — hide the dawn landscape layers (by id AND class) */
[data-theme="atelier"] #sky,[data-theme="atelier"] #sun,[data-theme="atelier"] #timeLayer,[data-theme="atelier"] #hill,[data-theme="atelier"] #worldMotes,[data-theme="atelier"] #scrim,[data-theme="atelier"] #swSun,[data-theme="atelier"] .side-world,[data-theme="atelier"] .scorebloom,[data-theme="atelier"] .amb-world,[data-theme="atelier"] .amb-hills,[data-theme="atelier"] .amb-hill,[data-theme="atelier"] .mtnsky{opacity:0!important;display:none!important}
[data-theme="atelier"] #swSky{background:var(--paper,#f4eddb)!important}
/* cards/surfaces → paper: kill glass-blur, deboss + ruled edge */
[data-theme="atelier"] .w,[data-theme="atelier"] .w--full,[data-theme="atelier"] .card,[data-theme="atelier"] .gc,[data-theme="atelier"] .moodrow,[data-theme="atelier"] .taskdrawer,[data-theme="atelier"] .me,[data-theme="atelier"] .ring{backdrop-filter:none!important;-webkit-backdrop-filter:none!important;background:var(--card)!important;border:1px solid var(--line)!important;box-shadow:0 1px 0 rgba(255,250,235,.7) inset,0 6px 16px rgba(90,64,30,.10)!important}
[data-theme="atelier"] .side{background:linear-gradient(180deg,#efe7d0,#e9e0c6)!important;box-shadow:inset -10px 0 22px rgba(120,90,50,.07)}
[data-theme="atelier"] .nav.on{background:color-mix(in srgb,var(--accent) 16%,transparent)!important;box-shadow:inset 2px 0 0 var(--accent)}
/* letterpress on the hero numerals */
[data-theme="atelier"] #num,[data-theme="atelier"] #swNum,[data-theme="atelier"] .peak-pct,[data-theme="atelier"] .ptitle{text-shadow:0 1px 0 rgba(255,250,235,.6),0 -1px 0 rgba(70,50,28,.14)}
[data-theme="atelier"] .ptitle{border-bottom:1px solid var(--line);padding-bottom:8px}
[data-theme="atelier"] .insight{box-shadow:inset 3px 0 0 var(--accent)}
/* parchment material — fiber grain + vignette + foxing (opacity = --age, ages as score drops). Below topbar/modals (z<95) so overlays stay clean. */
html[data-theme="atelier"]::before{content:"";position:fixed;inset:0;z-index:90;pointer-events:none;mix-blend-mode:multiply;opacity:.26;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='240' height='240'%3E%3Cfilter id='f'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='3' stitchTiles='stitch'/%3E%3CfeColorMatrix type='saturate' values='0'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23f)' opacity='0.5'/%3E%3C/svg%3E")}
html[data-theme="atelier"]::after{content:"";position:fixed;inset:0;z-index:91;pointer-events:none;box-shadow:inset 0 0 120px rgba(120,95,55,.12),inset 0 0 40px rgba(120,95,55,.06);background:linear-gradient(180deg,rgba(150,120,70,.06),transparent 14%,transparent 86%,rgba(150,120,70,.08))}
[data-theme="atelier"] .paper-fox{display:block;position:fixed;inset:0;z-index:89;pointer-events:none;mix-blend-mode:multiply;opacity:var(--age,.1);transition:opacity .6s;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='600' height='600'%3E%3Cfilter id='x'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.012' numOctaves='2' seed='7'/%3E%3CfeColorMatrix type='matrix' values='0 0 0 0 0.55 0 0 0 0 0.38 0 0 0 0 0.18 0 0 0 1.1 -0.35'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23x)'/%3E%3C/svg%3E")}
@media (prefers-reduced-motion:reduce){[data-theme="atelier"] .paper-fox{transition:none}}

/* ============================================================
   AURORA — LIGHT (day aurora): pale cool sky, soft ribbons, no stars.
   Engine sets --accent (deep) + --accent-2 (pastel) + --aur per band.
   ============================================================ */
[data-theme="aurora-light"]{--aur:.6;--star:0;--cold:0}
html[data-theme="aurora-light"] body{background:#eef5f4}
[data-theme="aurora-light"] .app{background:#eef5f4}
[data-theme="aurora-light"] #world{background:linear-gradient(180deg,#dceeec,#e8f3f1 56%,#f3f8f7 100%)}
[data-theme="aurora-light"] #sky,[data-theme="aurora-light"] #sun,[data-theme="aurora-light"] #timeLayer,[data-theme="aurora-light"] #hill,[data-theme="aurora-light"] #worldMotes{opacity:0!important}
[data-theme="aurora-light"] #scrim{background:radial-gradient(64% 66% at 50% 36%,rgba(255,255,255,.5) 0%,transparent 78%)!important}
[data-theme="aurora-light"] .aurora{display:block;position:absolute;left:-12%;right:-12%;z-index:2;filter:blur(28px);opacity:calc(var(--aur)*.5);transform-origin:bottom;transition:opacity .5s;pointer-events:none;mix-blend-mode:multiply}
[data-theme="aurora-light"] .aurora.a1{bottom:30%;height:200px;background:radial-gradient(60% 100% at 32% 100%,var(--accent),transparent 70%);animation:aur-drift 15s ease-in-out infinite}
[data-theme="aurora-light"] .aurora.a2{bottom:26%;height:250px;background:radial-gradient(55% 100% at 70% 100%,var(--accent-2),transparent 72%);animation:aur-drift 19s ease-in-out infinite reverse}
[data-theme="aurora-light"] .stars,[data-theme="aurora-light"] .cold-veil{display:none!important}
[data-theme="aurora-light"] #swSun{opacity:0!important}
[data-theme="aurora-light"] #swSky{background:linear-gradient(180deg,#dceeec,#f3f8f7 90%)!important}
@media (prefers-reduced-motion:reduce){[data-theme="aurora-light"] .aurora{animation:none}}

/* ============================================================
   ATELIER — DARK (night edition): charcoal paper, screen-blend grain.
   Engine sets --accent (bright) + --paper(#1a1611) + decorative ink per band.
   ============================================================ */
html[data-theme="atelier-dark"] body{background:#1a1611}
[data-theme="atelier-dark"] .app{background:#1a1611}
[data-theme="atelier-dark"] #world{background:var(--paper,#1a1611)}
[data-theme="atelier-dark"] #sky,[data-theme="atelier-dark"] #sun,[data-theme="atelier-dark"] #timeLayer,[data-theme="atelier-dark"] #hill,[data-theme="atelier-dark"] #worldMotes,[data-theme="atelier-dark"] #scrim{opacity:0!important}
[data-theme="atelier-dark"] #swSun{opacity:0!important}
[data-theme="atelier-dark"] #swSky{background:var(--paper,#1a1611)!important}
[data-theme="atelier-dark"] .aurora,[data-theme="atelier-dark"] .stars,[data-theme="atelier-dark"] .cold-veil{display:none!important}
[data-theme="atelier-dark"] .paper-grain{display:block;position:absolute;inset:0;z-index:1;opacity:.06;mix-blend-mode:screen;pointer-events:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='180' height='180'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E")}
[data-theme="atelier-dark"] .paper-vig{display:block;position:absolute;inset:0;z-index:1;pointer-events:none;box-shadow:inset 0 0 160px rgba(0,0,0,.55)}
[data-theme="atelier-dark"] .ptitle{border-bottom:1px solid var(--line);padding-bottom:8px}
[data-theme="atelier-dark"] .insight{box-shadow:inset 3px 0 0 var(--accent)}

/* ============================================================
   Novelty — intensity governor + Seam collapse joint (opt-in, additive)
   ============================================================ */
:root{--fx:.20}
html[data-theme="aurora"],html[data-theme="aurora-light"]{--fx:.30}
html[data-theme="dark"]{--fx:.18}
/* Seam: a band-tinted node glued to the sidebar/content divider; second collapse control sharing the rail state */
/* round, world-coloured collapse joint, low on the divider — the ONLY collapse control */
.mod-seam .seam{position:absolute;z-index:50;left:var(--seam-x,236px);top:80%;transform:translateY(-50%);width:24px;height:24px;border-radius:50%;cursor:pointer;border:0;padding:0;background:radial-gradient(circle at 40% 35%,color-mix(in srgb,var(--accent) 80%,#fff),var(--accent) 75%);box-shadow:0 2px 10px rgba(0,0,0,.4),0 0 0 4px color-mix(in srgb,var(--accent) calc(var(--fx,.2)*90%),transparent),inset 0 0 0 1px rgba(255,255,255,.25);display:grid;place-items:center;transition:left .25s var(--ease),box-shadow .3s}
.mod-seam .seam::after{content:"";width:7px;height:7px;border-right:2px solid #06140d;border-bottom:2px solid #06140d;transform:rotate(135deg) translate(-1px,-1px)}
.mod-seam[data-rail] .seam::after{transform:rotate(-45deg) translate(-1px,-1px)}
.mod-seam .seam:hover{box-shadow:0 2px 12px rgba(0,0,0,.5),0 0 0 6px color-mix(in srgb,var(--accent) 28%,transparent),inset 0 0 0 1px rgba(255,255,255,.3)}
@media (prefers-reduced-motion:reduce){.mod-seam .seam{transition:none}}
@media (max-width:819px){.mod-seam .seam{display:none}}
/* single control: remove the old bottom "Collapse" rail button */
.railtog{display:none!important}

/* Elaborate add-task composer — optional fields row */
.comp-more{display:flex;flex-wrap:wrap;gap:6px;margin-top:9px}
.comp-in{font:inherit;font-size:12.5px;color:var(--ink);background:var(--card);border:1px solid var(--line);border-radius:9px;padding:6px 9px;outline:none;max-width:170px}
.comp-in:focus{border-color:color-mix(in srgb,var(--accent) 45%,transparent)}
.comp-chip{display:inline-flex;align-items:center;gap:5px;font:inherit;font-size:12.5px;color:var(--ink2);background:transparent;border:1px solid var(--line);border-radius:999px;padding:6px 11px;cursor:pointer;transition:color .15s,border-color .15s,background .15s}
.comp-chip svg{flex:none}
.comp-chip:hover{color:var(--ink);border-color:var(--line2)}
.comp-chip.on{color:var(--accent);border-color:color-mix(in srgb,var(--accent) 48%,transparent);background:color-mix(in srgb,var(--accent) 14%,transparent)}
#taskCrit.on{color:#e6753a;border-color:#e6753a;background:color-mix(in srgb,#e6753a 14%,transparent)}

/* Activity tab — thematic progression */
.actv-seg{display:inline-flex;gap:2px;padding:3px;border:1px solid var(--line);border-radius:999px;margin:4px 0 16px}
.actv-seg button{border:0;border-radius:999px;padding:7px 15px;font:inherit;font-size:13px;background:transparent;color:var(--ink3);cursor:pointer;transition:.15s}
.actv-seg button:hover{color:var(--ink)}
.actv-seg button.on{background:color-mix(in srgb,var(--accent) 18%,transparent);color:var(--ink)}
.actv-hero{display:flex;align-items:flex-end;gap:22px;flex-wrap:wrap;margin-bottom:8px}
.actv-headline{flex:none}
.actv-num{font-family:'Italiana',serif;font-size:58px;line-height:.9;color:var(--ink)}
.actv-band{font-size:11px;letter-spacing:.18em;text-transform:uppercase;margin-top:6px}
.actv-trend{flex:1;min-width:220px}
.actv-delta{font-size:12px;margin-top:4px}
.actv-bars{display:flex;align-items:flex-end;gap:6px;height:108px;padding-top:6px}
.actv-bars.q,.actv-bars.y{gap:5px}
.actv-bars .ab{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:flex-end;gap:5px;height:100%}
.actv-bars .ab-f{width:70%;max-width:30px;border-radius:5px 5px 0 0;transition:height .4s var(--ease)}
.actv-bars .ab-l{font-size:10px;color:var(--ink3)}
.actv-heat{display:grid;grid-template-columns:repeat(15,1fr);gap:4px;margin-top:2px}
.actv-heat .ah-cell{aspect-ratio:1;border-radius:3px;opacity:.92}
.actv-day{display:flex;align-items:center;gap:18px;margin-top:2px}
.actv-hi{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:12px;margin-top:8px}
.actv-card{border:1px solid var(--line);border-radius:var(--r-lg);padding:12px 14px}
.actv-card .ahl{font-size:11px;color:var(--ink3)}
.actv-card .ahv{font-size:16px;color:var(--ink);margin-top:3px;font-family:'Italiana',serif}
@media(max-width:560px){.actv-heat{grid-template-columns:repeat(10,1fr)}}
.actv-peek{display:block;width:100%;margin-top:10px;padding:8px;border:0;border-top:1px solid var(--line);background:transparent;color:var(--accent);font:inherit;font-size:12.5px;text-align:center;cursor:pointer;transition:background .15s}
.actv-peek:hover{background:color-mix(in srgb,var(--accent) 8%,transparent)}

/* Daily Mood check-in (Home) — colours stay INSIDE the card; never tint world/orb */
.moodcard{margin:2px 0 14px}
.mood-prompt{display:flex;align-items:center;gap:6px;background:var(--card);border:1px solid var(--line);border-radius:14px;padding:4px 6px 4px 4px}
.mood-prompt .mc-open{flex:1;display:flex;align-items:center;gap:10px;background:transparent;border:0;font:inherit;font-size:13.5px;color:var(--ink2);padding:9px 10px;cursor:pointer;text-align:left;border-radius:11px}
.mood-prompt .mc-open:hover{color:var(--ink);background:color-mix(in srgb,var(--ink) 5%,transparent)}
.mood-prompt .mc-x{flex:none;width:30px;height:30px;border:0;border-radius:8px;background:transparent;color:var(--ink3);font-size:18px;cursor:pointer}
.mood-prompt .mc-x:hover{color:var(--ink);background:color-mix(in srgb,var(--ink) 6%,transparent)}
.mc-dot{width:9px;height:9px;border-radius:50%;background:var(--ink3);flex:none;display:inline-block}
.mc-dot.dim{opacity:.5}
.mc-dot.lg{width:13px;height:13px}
/* Whitelabel: hide Ambition-only chrome on a verified custom domain (tag nodes .amb-chrome) */
html[data-whitelabel="1"] .amb-chrome{display:none !important;}

/* Evening Big-3 nudge (Home) */
#eveNudge{margin:12px 0 0}
.eve-nudge{background:var(--card);border:1px solid var(--line);border-left:3px solid var(--accent);border-radius:14px;padding:14px 16px}
.eve-nudge .evn-head{display:flex;align-items:center;gap:10px}
.eve-nudge .evn-ic{flex:none;display:inline-flex;color:var(--accent)}
.eve-nudge .evn-t{flex:1;font-size:14px;color:var(--ink);line-height:1.35}
.eve-nudge .evn-x{flex:none;width:26px;height:26px;border:0;border-radius:8px;background:transparent;color:var(--ink3);font-size:17px;line-height:1;cursor:pointer}
.eve-nudge .evn-x:hover{background:color-mix(in srgb,var(--ink) 8%,transparent);color:var(--ink)}
.eve-nudge .evn-sub{font-size:12.5px;color:var(--ink3);margin:6px 0 10px}
.eve-nudge .evn-item{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--ink);padding:3px 0}
.eve-nudge .evn-dot{flex:none;width:6px;height:6px;border-radius:50%;background:var(--accent);opacity:.7}
.eve-nudge .evn-go{margin-top:10px;border:0;border-radius:9px;padding:8px 14px;font-size:13px;font-weight:500;cursor:pointer;background:color-mix(in srgb,var(--accent) 16%,transparent);color:var(--accent)}
.eve-nudge .evn-go:hover{background:color-mix(in srgb,var(--accent) 26%,transparent)}
.mood-choose{background:var(--card);border:1px solid var(--line);border-radius:14px;padding:14px}
.mood-choose .mc-head{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-bottom:10px}
.mood-choose .mc-q{font-size:14px;color:var(--ink)}
.mood-choose .mc-x{flex:none;width:26px;height:26px;border:0;border-radius:8px;background:transparent;color:var(--ink3);font-size:17px;line-height:1;cursor:pointer}
.mood-choose .mc-x:hover{background:color-mix(in srgb,var(--ink) 8%,transparent);color:var(--ink)}
.mchips{display:flex;flex-wrap:wrap;gap:8px}
.mchip{display:inline-flex;align-items:center;gap:8px;border:1px solid var(--line);border-radius:999px;padding:8px 13px;background:transparent;font:inherit;font-size:13px;color:var(--ink2);cursor:pointer;transition:border-color .15s,background .15s,color .15s}
.mchip .mc-dot{background:var(--mc)}
.mchip:hover,.mchip:focus-visible{color:var(--ink);border-color:var(--mc);background:color-mix(in srgb,var(--mc) 13%,transparent);outline:none}
.mc-note{font-size:11.5px;color:var(--ink3);margin-top:10px}
/* 5-point mood — equal tiles (Drained → Thriving), fills the card evenly */
.mood-seg{display:grid;grid-template-columns:repeat(5,1fr);gap:8px;margin:10px 0 2px}
.mchip.seg{display:flex;flex-direction:column;align-items:center;gap:9px;padding:14px 4px;border:1px solid var(--line);border-radius:12px;background:transparent;cursor:pointer;transition:border-color .15s,background .15s}
.mchip.seg .mc-dot{width:12px;height:12px;background:var(--mc)}
.mchip.seg .mc-w{font-size:12.5px;color:var(--ink2);transition:color .15s}
.mchip.seg:hover,.mchip.seg:focus-visible{border-color:var(--mc);background:color-mix(in srgb,var(--mc) 13%,transparent);outline:none}
.mchip.seg:hover .mc-w,.mchip.seg:focus-visible .mc-w{color:var(--ink)}
@media(max-width:560px){.mchip.seg .mc-w,.mchip.seg .mc-w{font-size:11px}.mood-seg{gap:6px}}
.mood-logged{display:flex;align-items:flex-start;gap:11px;background:var(--card);border:1px solid var(--line);border-radius:14px;padding:12px 14px}
.mood-logged .mc-dot.lg{margin-top:3px}
.mood-logged .mc-body{flex:1;min-width:0}
.mood-logged .mc-line{font-size:14px;color:var(--ink)}
.mood-logged .mc-north{font-size:12.5px;color:var(--ink2);margin-top:3px;line-height:1.45}
.mood-logged .mc-follow{margin-top:9px;border:1px solid var(--line2);background:transparent;color:var(--ink);font:inherit;font-size:12px;padding:6px 11px;border-radius:999px;cursor:pointer}
.mood-logged .mc-follow:hover{background:color-mix(in srgb,var(--ink) 6%,transparent)}
.mood-logged .mc-change{flex:none;border:0;background:transparent;color:var(--accent);font:inherit;font-size:12px;cursor:pointer;padding:4px}
.t-ease{font-size:12.5px;color:var(--ink2);background:color-mix(in srgb,var(--ink) 5%,transparent);border:1px solid var(--line);border-radius:10px;padding:8px 11px;margin-bottom:10px}
@media (prefers-reduced-motion:reduce){.mchip,.mood-prompt .mc-open,.mood-logged .mc-follow{transition:none}}
/* Ambient key-light (static, low) — one-light specular on glass surfaces; dark + Aurora only (paper themes skip). Scales restraint via --fx. */
.mod-light{--spec:rgba(255,255,255,.10)}
html[data-theme="aurora"] .mod-light{--spec:rgba(205,232,255,.15)}
:is(html[data-theme="dark"],html[data-theme="aurora"]) .mod-light :is(.w,.w--full,.card,.gc){background-image:radial-gradient(135% 115% at 32% -16%,var(--spec),transparent 54%)}
@media (prefers-reduced-transparency:reduce){:is(html[data-theme="dark"],html[data-theme="aurora"]) .mod-light :is(.w,.w--full,.card,.gc){background-image:none}}

/* ===== G4 growth views: axis chip, tree, list ===== */
.gaxis{display:inline-flex;align-items:baseline;gap:8px;margin:0 0 12px;padding:6px 12px;border:1px solid var(--line);border-radius:999px}
.gaxis-n{font-family:Italiana,serif;font-size:24px;line-height:1;color:var(--ink)}
.gaxis-l{font-size:10px;letter-spacing:.16em;text-transform:uppercase;color:var(--ink3)}
.gtree{display:flex;flex-direction:column;gap:18px;margin-top:14px}
.gtg-h{font-size:11px;letter-spacing:.14em;text-transform:uppercase;font-weight:600;margin:0 0 8px}
.gtn{background:rgba(255,255,255,.02);border:1px solid var(--line);border-radius:14px;padding:12px 14px;margin:0 0 8px}
.gtn-h{display:flex;align-items:center;gap:10px;cursor:pointer}
.gtn-t{font-weight:600;color:var(--ink);flex:1}
.gtn-st{font-size:10px;letter-spacing:.08em;text-transform:uppercase;padding:2px 8px;border-radius:999px;border:1px solid var(--line);color:var(--ink3)}
.gtn-p{font-family:Italiana,serif;font-size:18px}
.gkrs{margin:10px 0 0;display:flex;flex-direction:column;gap:4px}
.gkr{display:flex;align-items:center;gap:10px;padding:6px 10px;border-radius:8px;background:color-mix(in srgb,var(--ink) 4%,transparent);font-size:13px}
.gkr-n{flex:1;color:var(--ink)}
.gkr-lk,.gkr-w{font-size:11px;color:var(--ink3)}
.gkr-p{font-variant-numeric:tabular-nums;color:var(--ink);min-width:38px;text-align:right}
.gkr-empty{color:var(--ink3);font-style:italic;background:none}
.glist{display:flex;flex-direction:column;gap:2px;margin-top:14px}
.glrow{display:flex;align-items:center;gap:12px;padding:10px 12px;border-bottom:1px solid var(--line);cursor:pointer}
.glrow:hover{background:color-mix(in srgb,var(--ink) 4%,transparent)}
.gl-dot{width:8px;height:8px;border-radius:50%;flex:none}
.gl-t{flex:1;font-weight:600;color:var(--ink)}
.gl-seg{font-size:12px;color:var(--ink3);min-width:90px}
.gl-st{font-size:10px;letter-spacing:.08em;text-transform:uppercase;color:var(--ink3);min-width:84px}
.gl-kr{font-size:12px;color:var(--ink3);min-width:48px}
.gl-p{font-variant-numeric:tabular-nums;min-width:42px;text-align:right;color:var(--ink)}
.gst-success{color:#3aa57a;border-color:color-mix(in srgb,#3aa57a 50%,transparent)}
.gst-inprocess{color:#c8923a}

/* ===== AMB_SALES_PACK styles ===== */
.ochip{display:inline-flex;align-items:center;gap:5px;border:1px solid var(--line);background:transparent;color:var(--ink3);font-size:12px;padding:5px 11px;border-radius:999px;cursor:pointer;margin:0 0 12px}
.ochip:hover{color:var(--ink);border-color:color-mix(in srgb,var(--accent) 40%,var(--line))}
.sov{display:flex;flex-direction:column;gap:16px}
.sov-hero{display:flex;flex-direction:column;align-items:flex-start;gap:2px}
.sov-score{font-family:Italiana,serif;font-size:64px;line-height:.9;color:var(--ink)}
.sov-band{font-size:12px;letter-spacing:.18em;text-transform:uppercase;color:var(--accent)}
.sov-sub{font-size:13px;color:var(--ink3);margin-top:4px}
.sov-h{font-size:11px;letter-spacing:.14em;text-transform:uppercase;font-weight:600;color:var(--ink3);margin:6px 0 2px}
.shrow{display:grid;grid-template-columns:repeat(5,1fr);gap:10px}
.shx{border:1px solid var(--line);border-radius:12px;padding:12px 14px;background:rgba(255,255,255,.02)}
.shx-v{font-family:Italiana,serif;font-size:24px;line-height:1;color:var(--ink)}
.shx-k{font-size:11px;color:var(--ink3);margin-top:6px}
.satt{display:flex;align-items:center;gap:10px;padding:9px 12px;border-bottom:1px solid var(--line);cursor:pointer}
.satt:hover{background:color-mix(in srgb,var(--ink) 4%,transparent)}
.satt-dot{width:8px;height:8px;border-radius:50%;flex:none}
.satt-t{flex:1;color:var(--ink);font-size:14px}
.satt-d{font-size:12px;color:var(--ink3);min-width:120px}
.satt-due{font-size:12px;color:#c8923a;min-width:54px;text-align:right}
.scols{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:12px}
.scol{background:rgba(255,255,255,.02);border:1px solid var(--line);border-radius:14px;padding:10px;min-height:120px}
.dcard{border:1px solid var(--line);border-radius:12px;padding:11px 12px;margin:8px 0 0;background:color-mix(in srgb,var(--ink) 3%,transparent);cursor:pointer}
.dcard:hover{border-color:color-mix(in srgb,var(--accent) 40%,var(--line))}
.dcard-top{display:flex;justify-content:space-between;align-items:center}
.dcard-org{font-size:11px;letter-spacing:.06em;text-transform:uppercase;color:var(--ink3)}
.dcard-v{font-family:Italiana,serif;font-size:16px;color:var(--ink)}
.dcard-ti{font-weight:600;color:var(--ink);margin:6px 0 8px}
.dcard-pr{display:flex;align-items:center;gap:8px}
.dcard-pr .gpct{font-size:11px;color:var(--ink3)}
.dcard-foot{display:flex;gap:6px;margin-top:9px}
.dchip{font-size:10px;letter-spacing:.04em;text-transform:uppercase;color:var(--ink3);border:1px solid var(--line);border-radius:999px;padding:2px 7px}
.droom{display:flex;flex-direction:column;gap:14px}
.droom-h{display:flex;justify-content:space-between;align-items:flex-start;gap:14px;flex-wrap:wrap}
.droom-org{font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:var(--ink3)}
.droom-ti{font-family:Italiana,serif;font-size:28px;color:var(--ink);line-height:1.1}
.droom-meta{display:flex;gap:14px;flex-wrap:wrap;font-size:12px;color:var(--ink3)}
.droom-bar{display:flex;align-items:center;gap:12px;flex-wrap:wrap}
.droom-bar .gbar2{flex:1;min-width:140px}
.droom-bar .gpct{font-size:12px;color:var(--ink3)}
.droom-bar .ochip{margin:0}
.droom-cols{margin-top:2px}
.srecov{border:1px solid color-mix(in srgb,#c8923a 45%,var(--line));background:color-mix(in srgb,#c8923a 8%,transparent);border-radius:12px;padding:11px 14px;font-size:13px;color:var(--ink)}
.srecov-list{color:var(--ink3)}
.sstep{display:flex;align-items:center;gap:10px;padding:7px 4px;border-bottom:1px solid color-mix(in srgb,var(--line) 60%,transparent);font-size:13px}
.sstep-box{width:18px;text-align:center;color:var(--ink3)}
.sstep-n{flex:1;color:var(--ink)}
.sstep-due{font-size:11px;color:var(--ink3)}
.sstep-side{font-size:11px;color:var(--ink3);min-width:64px;text-align:right}
.sstep.sdone .sstep-n{color:var(--ink3);text-decoration:line-through}
.sstep.sdone .sstep-box{color:#3aa57a}
.sstep.sover .sstep-due{color:#c8923a}
.sstep.ssoon .sstep-due{color:var(--accent)}
.broom{max-width:620px;margin:0 auto;display:flex;flex-direction:column;gap:14px;border:1px solid var(--line);border-radius:18px;padding:22px 24px;background:rgba(255,255,255,.02)}
.broom-tag{font-size:10px;letter-spacing:.1em;text-transform:uppercase;color:var(--ink3)}
.broom-ti{font-family:Italiana,serif;font-size:26px;color:var(--ink)}
.broom-sub{font-size:13px;color:var(--ink3)}
.broom-steps{display:flex;flex-direction:column}
