
*{margin:0;padding:0;box-sizing:border-box}
/* a11y (audit XCUT contrast): --t3 (3.5:1 on cards) and --t4 (2.2-2.6:1) failed WCAG AA as
   text. --t3 raised #71717A -> #8A8A94 (>=4.9:1 on c2/c3); --t4 raised #52525B -> #71717A
   (3.5-3.8:1, now reserved for dividers/large meta). Bright status fills (gn/gd/bl/rd) are
   unflagged in the dark theme and stay vivid. */
:root,:root[data-theme="harrigan"]{--bg:#08090B;--c1:#0E0F12;--c2:#141518;--c3:#1C1D21;--c4:#0B0C0E;--b1:rgba(255,255,255,.06);--b2:rgba(255,255,255,.10);--b3:rgba(255,255,255,.16);--t1:#F4F4F5;--t2:#A1A1AA;--t3:#8A8A94;--t4:#71717A;--bl:#3B82F6;--cy:#3B82F6;--gn:#22C55E;--gd:#F5B638;--rd:#EF4444;--pp:#8B5CF6;--or:#F5B638;--pk:#3B82F6;--glow-a:transparent;--glow-b:transparent}
/* a11y (audit XCUT contrast): apple light status/data accents failed WCAG AA as TEXT on white
   (gn/gd 2.4:1, bl 3.4:1, rd 3.3:1, t3 3.2:1). Darkened to clear 4.5:1 on white/#F5F5F7 — the
   money/profit values that render in these tokens are now readable for low-vision users. Darker
   accents on a light surface read more polished, not less. Bright fills (dots, progress bars,
   pills) use color-mix/rgba tints that keep their lightness regardless of the base token. */
:root[data-theme="apple"]{--bg:#F5F5F7;--c1:#FFFFFF;--c2:#FFFFFF;--c3:#F0F0F3;--c4:#E8E8EC;--b1:rgba(0,0,0,.06);--b2:rgba(0,0,0,.10);--b3:rgba(0,0,0,.16);--t1:#18181B;--t2:#52525B;--t3:#6B6B70;--t4:#8A8A8F;--bl:#0061D0;--cy:#0061D0;--gn:#147A39;--gd:#9A6207;--rd:#CC0011;--pp:#7C3AED;--or:#9A6207;--pk:#0061D0;--glow-a:transparent;--glow-b:transparent}
:root[data-theme="apple"] body{font-family:-apple-system,BlinkMacSystemFont,'SF Pro Display','SF Pro Text',Inter,sans-serif}
:root[data-theme="apple"] .card,:root[data-theme="apple"] .notif-card,:root[data-theme="apple"] .ex-row,:root[data-theme="apple"] .sub-row,:root[data-theme="apple"] .pl-row,:root[data-theme="apple"] .target-chip{box-shadow:0 1px 2px rgba(0,0,0,.04),0 0 0 1px rgba(60,60,67,.06);border-color:transparent!important}
:root[data-theme="apple"] .card::before{display:none}
:root[data-theme="apple"] .kpi::after{opacity:.6}
:root[data-theme="apple"] .nav{background:rgba(255,255,255,.85)!important}
:root[data-theme="apple"] .notif-pane{box-shadow:0 20px 60px rgba(0,0,0,.18),0 0 0 1px rgba(60,60,67,.08)!important;border-color:transparent!important}
:root[data-theme="apple"] .modal{box-shadow:0 -8px 32px rgba(0,0,0,.12)!important}
:root[data-theme="apple"] .status{background:rgba(52,199,89,.1)!important}
:root[data-theme="apple"] .cl-mrr,:root[data-theme="apple"] .kpi-val,:root[data-theme="apple"] .bal-val,:root[data-theme="apple"] .runway-val,:root[data-theme="apple"] .goal-cur,:root[data-theme="apple"] .goal-pct,:root[data-theme="apple"] .txn-amt,:root[data-theme="apple"] .ex-amt,:root[data-theme="apple"] .sub-row-amt,:root[data-theme="apple"] .pl-row-net,:root[data-theme="apple"] .pl-total .val,:root[data-theme="apple"] .mval,:root[data-theme="apple"] .gauge-pct,:root[data-theme="apple"] .spark-val{font-family:-apple-system,'SF Pro Display',Inter,sans-serif;letter-spacing:-.5px}
:root[data-theme="apple"] .ex-meta .pip{background:rgba(0,122,255,.08);padding:1px 6px;border-radius:4px;color:var(--bl)}
/* apple light-theme contrast fixes: project-detail/win buttons hardcode pale dark-theme tints
   (#8ff0c9 mint, #bcd6ff light blue) that vanish on the light background. Re-point to theme
   accent tokens in apple only — the harrigan dark theme keeps its original tints untouched. */
:root[data-theme="apple"] .pd-ready,:root[data-theme="apple"] .pd-done,:root[data-theme="apple"] .win-claim.is-claimed{color:var(--gn)}
:root[data-theme="apple"] .pd-add-btn,:root[data-theme="apple"] .pd-link{color:var(--bl)}
html,body{height:100%}
body{font-family:Inter,-apple-system,sans-serif;background:var(--bg);color:var(--t1);min-height:100vh;min-height:100dvh;-webkit-font-smoothing:antialiased;overflow-x:hidden;-webkit-tap-highlight-color:transparent}

/* Ambient glow — neutralized to a flat, calm surface (no blurred color blobs).
   Div kept in the DOM (index.html:77); pseudo-elements no longer render. */
.glow{position:fixed;inset:0;pointer-events:none;z-index:0}
.glow::before,.glow::after{display:none}

/* LAYOUT */
.app{max-width:480px;margin:0 auto;padding:0 16px 110px;position:relative;z-index:1}
.shell{position:relative;z-index:1;min-height:100vh;min-height:100dvh}

/* HEADER */
.hdr{padding:env(safe-area-inset-top,20px) 0 14px;border-bottom:1px solid var(--b1);margin-bottom:16px}
.hdr-row{display:flex;justify-content:space-between;align-items:center}
.logo{display:flex;align-items:center;gap:10px}
.logo-mark{width:34px;height:34px;border-radius:10px;background:var(--bl);display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:900;color:#fff}
/* v2.16.17: Harrigan Creative logo — squatter H proportions (was too tall/narrow), tighter band */
.hc-logo{font-size:0;color:transparent;background:#0a0a0a;background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 100 100'><defs><linearGradient id='g' x1='0' y1='0' x2='1' y2='1'><stop offset='0%25' stop-color='%23f1f5f9'/><stop offset='100%25' stop-color='%2394a3b8'/></linearGradient></defs><rect width='100' height='100' rx='14' fill='%23000'/><g fill='url(%23g)'><rect x='18' y='30' width='12' height='40'/><rect x='44' y='30' width='12' height='40'/><rect x='70' y='30' width='12' height='40'/><rect x='18' y='46' width='64' height='8'/></g><rect x='6' y='44' width='88' height='14' fill='%23f8fafc' opacity='.95'/><text x='50' y='54' font-family='-apple-system,BlinkMacSystemFont,Segoe UI,Inter,sans-serif' font-size='9' font-weight='800' text-anchor='middle' fill='%230f172a' letter-spacing='.4'>HARRIGAN</text></svg>");background-size:cover;background-position:center;box-shadow:0 0 22px rgba(0,0,0,.45),inset 0 1px 0 rgba(255,255,255,.06)}
.logo-text{font-size:10px;font-weight:700;letter-spacing:2.5px;text-transform:uppercase;color:var(--t2)}
.status{display:flex;align-items:center;gap:5px;background:rgba(16,185,129,.06);border:1px solid rgba(16,185,129,.15);border-radius:20px;padding:4px 10px 4px 8px;font-size:10px;font-weight:600;color:var(--gn)}
.status.warn{background:rgba(251,191,36,.06);border-color:rgba(251,191,36,.2);color:var(--gd)}
.status.warn .dot{background:var(--gd)}
.status.err{background:rgba(239,68,68,.06);border-color:rgba(239,68,68,.2);color:var(--rd)}
.status.err .dot{background:var(--rd)}
.dot{width:6px;height:6px;background:var(--gn);border-radius:50%;animation:pulse 2s infinite}
@keyframes pulse{0%,100%{box-shadow:0 0 0 0 rgba(16,185,129,.4)}50%{box-shadow:0 0 0 6px rgba(16,185,129,0)}}
.greet{font-size:18px;font-weight:800;margin-top:10px;letter-spacing:-.3px}
.greet em{font-style:normal;color:var(--t1)}
.meta{font-size:11px;color:var(--t3);margin-top:2px;font-weight:500}

/* CARDS */
.card{background:var(--c2);border-radius:12px;padding:14px;border:1px solid var(--b1);margin-bottom:10px;transition:border-color .15s ease,box-shadow .15s ease;position:relative;overflow:hidden}
.card:hover{border-color:var(--b2)}
.card::before{content:'';position:absolute;top:0;left:0;right:0;height:1px;background:var(--b1)}
.card-sm{padding:12px}

/* QUOTE */
.quote{position:relative;padding-left:12px}
.quote::after{content:'';position:absolute;left:0;top:0;bottom:0;width:3px;border-radius:3px;background:var(--bl)}
.quote-text{font-size:11px;font-style:italic;color:var(--t2);line-height:1.5}
.quote-author{font-size:9px;color:var(--t3);margin-top:4px;font-weight:600}

/* WEATHER */
/* v2.16.17: Cash-flow strip — 2x2 on phones, 4-up on desktop */
.cf-strip-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px 16px;align-items:end}
@media(min-width:560px){.cf-strip-grid{grid-template-columns:repeat(4,1fr)}}
.cf-strip-cell{min-width:0}
.cf-strip-lbl{font-size:9px;font-weight:800;color:var(--t4);text-transform:uppercase;letter-spacing:.6px;margin-bottom:3px}
.cf-strip-val{font-family:'JetBrains Mono';font-size:17px;font-weight:800;font-variant-numeric:tabular-nums;line-height:1.05;letter-spacing:-.5px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
@media(min-width:560px){.cf-strip-val{font-size:18px}}
.cf-strip-sub{font-size:9px;color:var(--t4);margin-top:3px;line-height:1.3;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
@keyframes cfStripFadeIn{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}
/* Fade-in on the sub predictor card too */
#subPredictor{animation:cfStripFadeIn .5s ease-out}
.wx{display:flex;align-items:center;gap:12px}
.wx-icon{font-size:30px;line-height:1}
.wx-temp{font-family:'JetBrains Mono';font-size:22px;font-weight:700;letter-spacing:-1px}
.wx-loc{font-size:10px;color:var(--t3);font-weight:500}
.wx-hl{margin-left:auto;font-family:'JetBrains Mono';font-size:10px;color:var(--t2);font-weight:600;text-align:right}
/* v2.16.17: TODAY AT A GLANCE — ADHD-friendly action page */
.td-hero{display:flex;justify-content:space-between;align-items:flex-end;padding:14px 16px;background:var(--c2);border:1px solid var(--b1);border-radius:12px;margin-bottom:14px}
.td-hero-l{flex:1;min-width:0}
.td-hero-day{font-size:11px;color:var(--bl);text-transform:uppercase;letter-spacing:1.2px;font-weight:800;margin-bottom:2px}
.td-hero-greet{font-size:18px;font-weight:800;color:var(--t1);line-height:1.2}
.td-hero-btn{background:rgba(96,165,250,.15);color:var(--bl);border:1px solid rgba(96,165,250,.3);border-radius:50%;width:36px;height:36px;font-size:16px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:transform .3s ease}
.td-hero-btn:hover{transform:rotate(180deg)}
.td-snap{display:grid;grid-template-columns:repeat(4,1fr);gap:8px;margin-bottom:14px}
@media(max-width:480px){.td-snap{grid-template-columns:repeat(2,1fr)}}
.td-snap-tile{background:var(--c2);border:1px solid var(--b1);border-radius:12px;padding:10px 12px;cursor:pointer;transition:transform .15s ease,border-color .15s}
.td-snap-tile:active{transform:scale(.97)}
.td-snap-tile:hover{border-color:var(--bl)}
.td-snap-num{font-family:'JetBrains Mono';font-size:24px;font-weight:800;color:var(--t1);font-variant-numeric:tabular-nums;line-height:1}
.td-snap-lbl{font-size:10px;color:var(--t3);font-weight:600;text-transform:uppercase;letter-spacing:.6px;margin-top:4px}
.td-snap-done .td-snap-num{color:var(--gn)}
.td-focus{background:var(--c2);border:1px solid var(--b1);border-left:3px solid var(--gd);border-radius:12px;padding:14px 16px;margin-bottom:14px;position:relative}
.td-focus-tag{font-size:10px;font-weight:800;color:var(--gd);text-transform:uppercase;letter-spacing:1px;margin-bottom:6px}
.td-focus-text{font-size:14px;font-weight:600;color:var(--t1);line-height:1.45}
.td-focus-skip{position:absolute;top:10px;right:12px;background:transparent;color:var(--t3);border:1px solid var(--b1);border-radius:6px;padding:3px 8px;font-size:10px;font-weight:600;cursor:pointer}
.td-focus-skip:hover{color:var(--t1);border-color:var(--bl)}
.td-loading{padding:14px;color:var(--t3);font-size:12px;font-style:italic;background:var(--c2);border-radius:10px;border:1px dashed var(--b1)}
.td-row{display:flex;align-items:flex-start;gap:10px;background:var(--c2);border:1px solid var(--b1);border-radius:12px;padding:11px 12px;margin-bottom:6px;transition:opacity .25s, transform .25s}
.td-row.td-row-out{opacity:0;transform:translateX(40px)}
.td-row-icon{font-size:18px;flex:0 0 auto;line-height:1.2;padding-top:1px}
.td-row-body{flex:1;min-width:0}
.td-row-title{font-size:13px;font-weight:600;color:var(--t1);line-height:1.35;word-break:break-word}
.td-row-meta{font-size:10px;color:var(--t3);font-weight:500;margin-top:3px;display:flex;gap:8px;flex-wrap:wrap}
.td-row-meta .pill{background:var(--c3);padding:1px 6px;border-radius:4px;color:var(--t2);font-weight:600;letter-spacing:.3px}
.td-row-meta .pill.p1{background:rgba(239,68,68,.15);color:#ef4444}
.td-row-meta .pill.p2{background:rgba(251,146,60,.15);color:#fb923c}
.td-row-meta .pill.p3{background:rgba(96,165,250,.15);color:#60a5fa}
.td-row-actions{display:flex;flex-direction:column;gap:4px;flex:0 0 auto;align-items:flex-end}
.td-btn{border:1px solid var(--b1);background:var(--c1);color:var(--t1);border-radius:8px;padding:5px 10px;font-size:11px;font-weight:700;cursor:pointer;font-family:Inter;white-space:nowrap;transition:all .15s}
.td-btn-yes{border-color:rgba(16,185,129,.35);background:rgba(16,185,129,.1);color:#10b981}
.td-btn-yes:hover{background:rgba(16,185,129,.2)}
.td-btn-no{border-color:rgba(251,146,60,.3);background:rgba(251,146,60,.08);color:#fb923c}
.td-btn-no:hover{background:rgba(251,146,60,.18)}
.td-btn-done{border-color:rgba(34,197,94,.4);background:rgba(34,197,94,.15);color:#22c55e}
.td-btn-skip{border-color:var(--b1);background:transparent;color:var(--t4)}
.td-log-row{display:flex;align-items:center;gap:10px;font-size:11px;color:var(--t2);padding:6px 12px;background:var(--c2);border-left:2px solid var(--bl);margin-bottom:3px;border-radius:0 8px 8px 0}
.td-log-time{font-family:'JetBrains Mono';color:var(--t4);font-size:9px;flex:0 0 auto}
.td-log-text{flex:1}
.td-empty-state{padding:18px;text-align:center;color:var(--t4);font-size:12px;background:var(--c2);border-radius:12px;border:1px dashed var(--b1)}
/* v2.16.17: Animated pro weather widget */
.wx-pro{border-radius:12px;border:1px solid var(--b1);min-height:230px}
.wx-sky{position:absolute;inset:0;overflow:hidden;border-radius:12px}
.wx-sky-grad{position:absolute;inset:0;background:#15171C;transition:background 1.5s ease}
.wx-pro[data-tod="dawn"] .wx-sky-grad{background:#1B1A22}
.wx-pro[data-tod="day"] .wx-sky-grad{background:#191B22}
.wx-pro[data-tod="dusk"] .wx-sky-grad{background:#1B1820}
.wx-pro[data-tod="night"] .wx-sky-grad{background:#0E0F13}
.wx-pro[data-cond="cloudy"] .wx-sky-grad{filter:brightness(.92)}
.wx-pro[data-cond="rain"] .wx-sky-grad{background:#16181C}
.wx-pro[data-cond="storm"] .wx-sky-grad{background:#121317}
.wx-stars{position:absolute;inset:0;background-image:radial-gradient(1px 1px at 20px 30px,rgba(255,255,255,.6),transparent),radial-gradient(1px 1px at 80px 60px,rgba(255,255,255,.4),transparent),radial-gradient(1.5px 1.5px at 140px 20px,rgba(255,255,255,.7),transparent),radial-gradient(1px 1px at 60px 110px,rgba(255,255,255,.5),transparent),radial-gradient(1px 1px at 200px 80px,rgba(255,255,255,.4),transparent),radial-gradient(1.5px 1.5px at 240px 140px,rgba(255,255,255,.6),transparent),radial-gradient(1px 1px at 180px 200px,rgba(255,255,255,.5),transparent);opacity:0;animation:wxStarsTwinkle 4s ease-in-out infinite;transition:opacity 1.5s ease}
.wx-pro[data-tod="night"] .wx-stars,.wx-pro[data-tod="dusk"] .wx-stars{opacity:.85}
@keyframes wxStarsTwinkle{0%,100%{opacity:var(--st-op,.85)}50%{opacity:calc(var(--st-op,.85) * .55)}}
.wx-sun{position:absolute;width:46px;height:46px;background:rgba(245,182,56,.85);border-radius:50%;top:18px;right:18px;opacity:0;transition:opacity 1.5s ease, transform 1.5s ease}
.wx-pro[data-tod="day"] .wx-sun{opacity:.85;transform:translate(0,0)}
.wx-pro[data-tod="dawn"] .wx-sun,.wx-pro[data-tod="dusk"] .wx-sun{opacity:.6;transform:translate(0,16px)}
@keyframes wxSunPulse{0%,100%{opacity:.85}50%{opacity:.85}}
.wx-moon{position:absolute;width:34px;height:34px;background:rgba(228,228,231,.78);border-radius:50%;top:18px;right:18px;opacity:0;transition:opacity 1.5s ease}
.wx-pro[data-tod="night"] .wx-moon{opacity:.95}
.wx-cloud{position:absolute;background:rgba(255,255,255,.18);border-radius:50px;filter:blur(.4px);opacity:0;transition:opacity 1s ease}
.wx-cloud::before,.wx-cloud::after{content:"";position:absolute;background:inherit;border-radius:50%}
.cloud-a{width:64px;height:18px;top:30px;left:-70px;animation:wxCloudDrift 24s linear infinite}
.cloud-a::before{width:24px;height:24px;top:-12px;left:14px}
.cloud-a::after{width:18px;height:18px;top:-8px;left:38px}
.cloud-b{width:48px;height:14px;top:60px;left:-50px;animation:wxCloudDrift 32s linear infinite;animation-delay:-10s;opacity:0}
.cloud-b::before{width:18px;height:18px;top:-9px;left:10px}
.cloud-c{width:80px;height:22px;top:88px;left:-90px;animation:wxCloudDrift 28s linear infinite;animation-delay:-18s;opacity:0}
.cloud-c::before{width:30px;height:30px;top:-14px;left:18px}
.cloud-c::after{width:22px;height:22px;top:-10px;left:48px}
.wx-pro[data-cond="cloudy"] .wx-cloud,.wx-pro[data-cond="partly"] .wx-cloud,.wx-pro[data-cond="rain"] .wx-cloud,.wx-pro[data-cond="storm"] .wx-cloud{opacity:.9}
.wx-pro[data-cond="partly"] .cloud-b,.wx-pro[data-cond="partly"] .cloud-c{opacity:.5}
@keyframes wxCloudDrift{0%{transform:translateX(0)}100%{transform:translateX(420px)}}
.wx-rain{position:absolute;inset:0;opacity:0;background-image:repeating-linear-gradient(100deg,transparent 0,transparent 6px,rgba(255,255,255,.32) 6px,rgba(255,255,255,.32) 7px,transparent 7px,transparent 14px);animation:wxRainFall .8s linear infinite;transition:opacity 1s ease}
.wx-pro[data-cond="rain"] .wx-rain,.wx-pro[data-cond="storm"] .wx-rain{opacity:.5}
@keyframes wxRainFall{0%{background-position:0 0}100%{background-position:14px 30px}}
.wx-pro-icon{font-size:42px;line-height:1;filter:drop-shadow(0 2px 6px rgba(0,0,0,.35));animation:wxIconBob 4s ease-in-out infinite}
@keyframes wxIconBob{0%,100%{transform:translateY(0)}50%{transform:translateY(-3px)}}
.wx-pro-temp{font-family:'JetBrains Mono';font-size:30px;font-weight:800;letter-spacing:-1.5px;color:#fff;text-shadow:0 2px 12px rgba(0,0,0,.4);font-variant-numeric:tabular-nums}
.wx-pro-cond{font-size:11px;color:rgba(255,255,255,.78);font-weight:600;text-transform:capitalize}
.wx-pro-loc{font-size:10px;color:rgba(255,255,255,.65);font-weight:500;margin-top:1px}
.wx-pro-dt{display:flex;justify-content:space-between;align-items:baseline;padding:8px 10px;background:rgba(15,23,42,.45);backdrop-filter:blur(8px);border:1px solid rgba(255,255,255,.12);border-radius:10px;margin-bottom:10px}
.wx-pro-time{font-family:'JetBrains Mono';font-size:18px;font-weight:800;color:#fff;font-variant-numeric:tabular-nums;letter-spacing:-.5px;text-shadow:0 2px 8px rgba(0,0,0,.4)}
.wx-pro-date{font-size:11px;color:rgba(255,255,255,.7);font-weight:600}
.wx-arc-wrap{margin-bottom:10px}
.wx-arc-svg{width:100%;height:46px;display:block}
#wxArcPath{transition:stroke-dashoffset 1s ease}
#wxArcDot{transition:cx .8s ease,cy .8s ease}
.wx-arc-labels{display:flex;justify-content:space-between;font-size:10px;color:rgba(255,255,255,.7);font-weight:600;margin-top:-4px}
.wx-arc-labels b{color:#fff;font-family:'JetBrains Mono';font-weight:700}
.wx-rev-strip{display:flex;justify-content:space-between;align-items:baseline;padding:7px 10px;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.12);border-radius:8px;font-size:11px;backdrop-filter:blur(4px)}
.wx-rev-amt{color:#4ADE80;font-family:'JetBrains Mono';font-weight:800;font-variant-numeric:tabular-nums;font-size:13px}
.wx-rev-meta{color:rgba(255,255,255,.55);font-size:10px}
.wx-pro .wx-rev-strip span:first-child{color:rgba(255,255,255,.75)}

/* MRR GOAL */
.goal-row{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px}
.goal-label{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:1.2px;color:var(--t3)}
.goal-pct{font-family:'JetBrains Mono';font-size:13px;font-weight:700;color:var(--cy)}
.goal-track{height:10px;background:var(--c3);border-radius:10px;overflow:hidden}
.goal-fill{height:100%;border-radius:10px;background:var(--bl);transition:width 1.2s cubic-bezier(.16,1,.3,1);position:relative}
.goal-fill::after{content:'';position:absolute;right:-1px;top:1px;bottom:1px;width:3px;background:#fff;border-radius:3px}
.goal-nums{display:flex;justify-content:space-between;margin-top:6px}
.goal-cur{font-family:'JetBrains Mono';font-size:11px;font-weight:700;color:var(--cy)}
.goal-tgt{font-family:'JetBrains Mono';font-size:11px;font-weight:500;color:var(--t4)}

/* KPI GRID */
.kpi-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:10px}
.kpi{position:relative;overflow:hidden;cursor:default}
.kpi::after{content:'';position:absolute;top:0;left:0;right:0;height:2px;opacity:.85}
.kpi.kpi-bl::after{background:var(--bl)}
.kpi.kpi-gn::after{background:var(--gn)}
.kpi.kpi-rd::after{background:var(--rd)}
.kpi.kpi-gd::after{background:var(--gd)}
.kpi-label{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:1.1px;color:var(--t3);margin-bottom:6px}
/* v2.16.69: center KPI values per user — was left-aligned, looked uneven */
/* v2.19.3: bump to 28px for better readability */
.kpi-val{font-family:'JetBrains Mono';font-size:28px;font-weight:800;line-height:1;text-align:center;width:100%;display:block;letter-spacing:-.5px}
.kpi .kpi-label{text-align:center;justify-content:center}
.kpi .kpi-sub{text-align:center}
.kpi-sub{font-size:11px;color:var(--t2);margin-top:5px;font-weight:500}
.kpi.kpi-bl .kpi-label{color:var(--bl)}
.kpi.kpi-gd .kpi-label{color:var(--gd)}
.kpi.kpi-rd .kpi-label{color:var(--rd)}
.kpi.kpi-gn .kpi-label{color:var(--gn)}
.vg{color:var(--gn)}.vb{color:var(--cy)}.vd{color:var(--gd)}.vr{color:var(--rd)}

/* SPARKLINE */
.spark-row{display:flex;gap:10px;margin-bottom:10px}
.spark-card{flex:1;display:flex;align-items:center;gap:10px}
.spark-info{min-width:0}
.spark-label{font-size:9px;font-weight:700;text-transform:uppercase;letter-spacing:1px;color:var(--t3);margin-bottom:2px}
.spark-val{font-family:'JetBrains Mono';font-size:14px;font-weight:700;color:var(--gn)}
.spark-change{font-family:'JetBrains Mono';font-size:9px;font-weight:700;padding:2px 5px;border-radius:4px;margin-top:3px;display:inline-block}
.spark-change.up{background:rgba(16,185,129,.1);color:var(--gn)}
.spark-change.down{background:rgba(239,68,68,.1);color:var(--rd)}
.spark-chart{flex-shrink:0}
.spark-chart svg{display:block}

/* GAUGE */
.gauge-row{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}
.gauge-title{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:1px;color:var(--t3)}
.gauge-pct{font-family:'JetBrains Mono';font-size:16px;font-weight:700;color:var(--gn)}
.gauge-track{height:6px;background:var(--c3);border-radius:6px;overflow:hidden}
.gauge-fill{height:100%;border-radius:6px;background:var(--gn);transition:width 1.2s cubic-bezier(.16,1,.3,1)}

/* BALANCE ROW */
.bal-grid{display:grid;grid-template-columns:1fr 1fr 1fr;gap:8px;margin-bottom:10px}
.bal{text-align:center}
.bal-label{font-size:8px;font-weight:700;text-transform:uppercase;letter-spacing:.8px;color:var(--t4);margin-bottom:3px}
.bal-val{font-family:'JetBrains Mono';font-size:14px;font-weight:700;color:var(--gn)}
.bal-val.pending{color:var(--gd);cursor:pointer}
.bal-sub{font-size:9px;color:var(--t4);margin-top:3px;font-weight:500;text-align:center}

/* Amex balance + due row */
.amex-bal-row{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-bottom:10px}
.amex-bal-row .card{text-align:center}
.amex-due-card{border:1px solid rgba(239,68,68,.25)!important;background:var(--c2)!important}
.amex-due-card.overdue{border-color:var(--rd)!important}
.amex-due-card.soon{border-color:var(--gd)!important;background:var(--c2)!important}
.amex-due-card.soon .bal-val{color:var(--gd)!important}

/* RUNWAY */
.runway{display:flex;align-items:center;gap:12px}
.runway-icon{font-size:22px}
.runway-val{font-family:'JetBrains Mono';font-size:18px;font-weight:700;color:var(--cy)}
.runway-label{font-size:10px;color:var(--t3)}

/* SECTIONS */
.sec{display:flex;justify-content:space-between;align-items:center;margin:22px 0 10px;padding-bottom:6px;border-bottom:1px solid var(--b1);gap:8px}
.sec h3{font-size:13px;font-weight:700;letter-spacing:-.2px}
.badge{font-family:'JetBrains Mono';font-size:10px;color:var(--t3);background:var(--c3);padding:3px 8px;border-radius:6px;white-space:nowrap}
.sec-actions{display:flex;gap:6px;margin-left:auto}

/* CLIENT CARDS */
.client{cursor:pointer;-webkit-user-select:none;user-select:none;touch-action:manipulation;position:relative}
.client:active{transform:scale(.985);border-color:var(--b2)}
.client *{pointer-events:auto}
.cl-top{display:flex;justify-content:space-between;align-items:flex-start;gap:10px;padding-right:26px}
.cl-top > div:first-child{flex:1;min-width:0}
.cl-name{font-size:13px;font-weight:700}
.cl-mrr{font-family:'JetBrains Mono';font-size:16px;font-weight:700;color:var(--gn)}
.cl-meta{font-size:10px;color:var(--t3);margin-top:1px}
.tags{display:flex;gap:4px;flex-wrap:wrap;margin-top:7px}
.tag{font-size:8px;font-weight:700;padding:2px 7px;border-radius:5px;text-transform:uppercase;letter-spacing:.5px}
.tag-s{background:rgba(59,130,246,.1);color:var(--bl);border:1px solid rgba(59,130,246,.15)}
.tag-a{background:rgba(251,191,36,.08);color:var(--gd);border:1px solid rgba(251,191,36,.12)}
.tag-h{background:rgba(16,185,129,.08);color:var(--gn);border:1px solid rgba(16,185,129,.12)}
.tag-c{background:rgba(168,85,247,.08);color:var(--pp);border:1px solid rgba(168,85,247,.12)}
.tag-m{background:rgba(239,68,68,.08);color:var(--rd);border:1px solid rgba(239,68,68,.12)}

/* Client profit bar */
.cl-profit{display:flex;align-items:center;gap:8px;margin-top:8px}
.cl-profit-label{font-size:9px;color:var(--t4);min-width:32px}
.cl-profit-track{flex:1;height:4px;background:var(--c3);border-radius:4px;overflow:hidden}
.cl-profit-fill{height:100%;border-radius:4px;background:var(--gn);transition:width .8s ease}
.cl-profit-val{font-family:'JetBrains Mono';font-size:10px;font-weight:700;color:var(--gn);min-width:50px;text-align:right}

/* Client detail (expandable) */
.cl-detail{max-height:0;overflow:hidden;transition:max-height .35s cubic-bezier(.4,0,.2,1)}
.client.open .cl-detail{max-height:600px}
.cl-sub{padding-top:8px;margin-top:8px;border-top:1px solid var(--b1)}
.cl-sub-row{display:flex;justify-content:space-between;padding:4px 0;font-size:11px;color:var(--t2);gap:8px}
.cl-sub-row span:last-child{font-family:'JetBrains Mono';font-weight:600;color:var(--t1);white-space:nowrap}
.cl-sub-row.discount{color:var(--gd)}.cl-sub-row.discount span:last-child{color:var(--gd)}
.cl-sub-row.cost{color:var(--rd)}.cl-sub-row.cost span:last-child{color:var(--rd)}
.cl-sub-row.profit{color:var(--gn);font-weight:700}.cl-sub-row.profit span:last-child{color:var(--gn)}
.cl-chev{font-size:10px;color:var(--t4);transition:transform .3s;display:inline-block;margin-left:4px}
.client.open .cl-chev{transform:rotate(180deg)}

/* EXPENSE REVIEW QUEUE */
.tabs-pill{display:flex;gap:4px;background:var(--c1);border:1px solid var(--b1);border-radius:12px;padding:4px;margin-bottom:10px}
.tabs-pill button{flex:1;background:transparent;border:none;color:var(--t3);font-family:Inter;font-size:11px;font-weight:700;padding:8px;border-radius:8px;cursor:pointer;transition:all .2s;text-transform:uppercase;letter-spacing:.5px}
.tabs-pill button.on{background:var(--c3);color:var(--t1);box-shadow:inset 0 1px 0 rgba(255,255,255,.04)}
.tabs-pill .count{display:inline-block;margin-left:4px;background:var(--b2);color:var(--t2);font-family:'JetBrains Mono';font-size:9px;padding:1px 5px;border-radius:4px;font-weight:600}
.tabs-pill button.on .count{background:var(--bl);color:#fff}

.search-row{display:flex;gap:8px;margin-bottom:10px;align-items:center}
.search-input{flex:1;background:var(--c2);border:1px solid var(--b1);border-radius:10px;padding:10px 12px;color:var(--t1);font-family:Inter;font-size:12px;font-weight:500}
.search-input:focus{outline:none;border-color:var(--b3)}
.search-input::placeholder{color:var(--t4)}
.filter-chip{background:var(--c2);border:1px solid var(--b1);border-radius:10px;padding:10px 12px;color:var(--t2);font-family:Inter;font-size:11px;font-weight:600;cursor:pointer;display:flex;align-items:center;gap:4px}
.filter-chip.on{background:var(--bl);color:#fff;border-color:var(--bl)}

/* Expense row */
.ex-row{background:var(--c2);border:1px solid var(--b1);border-radius:12px;padding:12px;margin-bottom:8px;transition:border-color .15s,background .15s;position:relative}
.ex-row.approved{border-left:3px solid var(--gn)}
.ex-row.pending{border-left:3px solid var(--gd)}
.ex-row.assigned{border-left:3px solid var(--bl)}
.ex-row.rejected{opacity:.55;border-left:3px solid var(--rd)}
.ex-head{display:flex;justify-content:space-between;align-items:flex-start;gap:10px;margin-bottom:8px}
.ex-merchant{font-size:13px;font-weight:700;color:var(--t1);line-height:1.3;word-break:break-word}
.ex-meta{font-size:10px;color:var(--t4);margin-top:2px}
.ex-meta .pip{color:var(--t3);font-weight:600}
.ex-amt{font-family:'JetBrains Mono';font-size:15px;font-weight:700;color:var(--rd);white-space:nowrap}
.ex-amt.cr{color:var(--gn)}

.ex-form{display:grid;grid-template-columns:1fr 1fr;gap:6px;margin-top:8px}
.ex-form select,.ex-form input[type="text"]{width:100%;background:var(--c3);border:1px solid var(--b1);border-radius:8px;padding:8px 10px;color:var(--t1);font-family:Inter;font-size:11px;font-weight:500;cursor:pointer}
.ex-form select:focus,.ex-form input:focus{outline:none;border-color:var(--b3)}
.ex-actions{display:flex;gap:6px;margin-top:8px;align-items:center;flex-wrap:wrap}
.ex-btn{background:var(--c3);border:1px solid var(--b1);color:var(--t2);font-family:Inter;font-size:10px;font-weight:700;padding:7px 10px;border-radius:8px;cursor:pointer;transition:all .15s;text-transform:uppercase;letter-spacing:.5px;display:inline-flex;align-items:center;gap:4px}
@media (hover:hover) and (pointer:fine){.ex-btn:hover{border-color:var(--b2);color:var(--t1)}}
.ex-btn.approve{background:rgba(16,185,129,.12);color:var(--gn);border-color:rgba(16,185,129,.25)}
.ex-btn.approve:hover{background:rgba(16,185,129,.2)}
.ex-btn.reject{background:rgba(239,68,68,.08);color:var(--rd);border-color:rgba(239,68,68,.2)}
.ex-btn.primary{background:var(--bl);color:#fff;border-color:var(--bl)}
.ex-chk{display:inline-flex;align-items:center;gap:5px;font-size:10px;font-weight:600;color:var(--t3);cursor:pointer;user-select:none}
.ex-chk input{accent-color:var(--bl)}
.ex-chk.on{color:var(--gd)}
.ex-note{width:100%;margin-top:6px}
.ex-tags-row{display:flex;flex-wrap:wrap;gap:5px;align-items:center;padding:5px 10px 6px;border-top:1px solid var(--b1);background:rgba(99,102,241,.03);border-radius:0 0 8px 8px}
.ex-tag-chip{display:inline-flex;align-items:center;gap:3px;background:rgba(99,102,241,.15);color:#818cf8;border:1px solid rgba(99,102,241,.3);border-radius:12px;padding:2px 8px 2px 10px;font-size:10px;font-weight:700;cursor:default;white-space:nowrap;line-height:16px}
.ex-tag-chip:hover{background:rgba(99,102,241,.25)}
.ex-tag-rm{color:rgba(129,140,248,.7);cursor:pointer;font-size:12px;margin-left:1px;line-height:1}
.ex-tag-rm:hover{color:#818cf8}
.ex-tag-inp{background:transparent;border:1px dashed var(--b2);border-radius:10px;padding:2px 8px;font-size:10px;color:var(--t2);font-family:Inter,sans-serif;width:68px;outline:none;transition:width .15s,border-color .15s}
.ex-tag-inp:focus{border-color:rgba(99,102,241,.5);color:var(--t1);width:100px}
.ex-tag-qa{font-size:9px;font-weight:700;color:var(--t4);padding:2px 7px;border-radius:10px;border:1px solid var(--b1);cursor:pointer;white-space:nowrap;text-transform:uppercase;letter-spacing:.4px;line-height:16px}
.ex-tag-qa:hover{border-color:rgba(99,102,241,.4);color:#818cf8;background:rgba(99,102,241,.08)}
.ex-mem-hint{display:inline-flex;align-items:center;gap:3px;font-size:9px;color:var(--pp);font-weight:600;padding:2px 6px;background:rgba(168,85,247,.08);border-radius:4px;margin-left:auto}

/* Target picker (who does this apply to?) */
.ex-who-label{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:var(--t3);margin:8px 0 6px;display:flex;justify-content:space-between;gap:8px;align-items:center}
.ex-who-sum{font-size:11px;font-weight:600;color:var(--t1);text-transform:none;letter-spacing:0}
.target-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:4px;margin-bottom:8px}
.target-chip{display:flex;align-items:center;gap:6px;padding:7px 10px;background:var(--c3);border:1px solid var(--b1);border-radius:8px;cursor:pointer;font-size:11px;font-weight:500;color:var(--t2);user-select:none;transition:all .15s}
.target-chip:hover{border-color:var(--b2);color:var(--t1)}
.target-chip.on{background:rgba(59,130,246,.12);border-color:var(--bl);color:var(--t1)}
.target-chip input{accent-color:var(--bl);cursor:pointer;flex-shrink:0}
.ex-form-slim{grid-template-columns:1fr 1fr 2fr}
@media (max-width:900px){.ex-form-slim{grid-template-columns:1fr 1fr}.ex-form-slim .ex-note{grid-column:1/-1}}

/* TRANSACTIONS (mercury read-only) */
.txn{display:flex;justify-content:space-between;align-items:center;padding:10px 0;border-bottom:1px solid var(--b1)}
.txn:last-child{border-bottom:none}
.txn-name{font-size:11px;font-weight:600;max-width:210px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.txn-date{font-size:9px;color:var(--t4)}
.txn-amt{font-family:'JetBrains Mono';font-size:12px;font-weight:700}
.txn-amt.db{color:var(--rd)}.txn-amt.cr{color:var(--gn)}

/* AMEX CONNECT */
.connect-btn{background:var(--bl);border:none;border-radius:12px;padding:14px;width:100%;color:#fff;font-family:Inter;font-size:13px;font-weight:700;cursor:pointer;margin-bottom:10px;transition:filter .15s,transform .15s}
.connect-btn:active{transform:scale(.97)}
.connect-btn:hover{filter:brightness(1.06)}
.connect-btn small{display:block;font-size:10px;font-weight:500;opacity:.8;margin-top:3px}
.amex-ok{display:flex;align-items:center;gap:8px;margin-bottom:10px;padding:10px;background:var(--c2);border:1px solid var(--b1);border-radius:10px}
.amex-ok .dot{background:var(--gn)}
.amex-ok span{font-size:11px;font-weight:600;color:var(--gn)}
.amex-warn{padding:12px;background:rgba(251,191,36,.06);border:1px solid rgba(251,191,36,.2);border-radius:12px;margin-bottom:10px;display:flex;gap:10px;align-items:flex-start}
.amex-warn-icon{font-size:20px;flex-shrink:0}
.amex-warn-body{flex:1;min-width:0}
.amex-warn-title{font-size:12px;font-weight:700;color:var(--gd);margin-bottom:2px}
.amex-warn-msg{font-size:11px;color:var(--t2);line-height:1.4;margin-bottom:8px}
.amex-warn button{background:var(--gd);color:#1a1200;border:none;border-radius:8px;padding:7px 12px;font-family:Inter;font-size:11px;font-weight:700;cursor:pointer}

/* REPORTS / P&L */
.pl-controls{display:flex;gap:8px;align-items:center;margin-bottom:10px}
.pl-controls select{flex:1;background:var(--c2);border:1px solid var(--b1);border-radius:10px;padding:10px 12px;color:var(--t1);font-family:Inter;font-size:12px;font-weight:600;cursor:pointer}
.pl-totals{display:grid;grid-template-columns:1fr 1fr 1fr;gap:8px;margin-bottom:12px}
.pl-total{background:var(--c2);border:1px solid var(--b1);border-radius:12px;padding:12px;text-align:center}
.pl-total .lbl{font-size:9px;font-weight:700;text-transform:uppercase;letter-spacing:1px;color:var(--t3);margin-bottom:4px}
.pl-total .val{font-family:'JetBrains Mono';font-size:16px;font-weight:700}
.pl-total.rev .val{color:var(--gn)}
.pl-total.exp .val{color:var(--rd)}
.pl-total.net .val{color:var(--gn)}

.pl-row{background:var(--c2);border:1px solid var(--b1);border-radius:12px;padding:12px;margin-bottom:8px}
.pl-row-top{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}
.pl-row-name{font-size:13px;font-weight:700}
.pl-row-net{font-family:'JetBrains Mono';font-size:14px;font-weight:700}
.pl-row-net.pos{color:var(--gn)}
.pl-row-net.neg{color:var(--rd)}
.pl-row-bar{display:flex;height:6px;border-radius:6px;overflow:hidden;background:var(--c3);margin-bottom:6px}
.pl-row-bar .rev-seg{background:var(--gn)}
.pl-row-bar .exp-seg{background:var(--rd)}
.pl-row-stats{display:flex;justify-content:space-between;font-size:10px;color:var(--t3);font-family:'JetBrains Mono'}
.pl-row-stats span.r{color:var(--gn)}
.pl-row-stats span.x{color:var(--rd)}

/* Subscription list */
.sub-row{display:flex;justify-content:space-between;align-items:center;padding:10px;background:var(--c2);border:1px solid var(--b1);border-radius:10px;margin-bottom:6px}
.sub-row-info{min-width:0;flex:1}
.sub-row-name{font-size:12px;font-weight:700}
.sub-row-meta{font-size:10px;color:var(--t4);margin-top:2px}
.sub-row-amt{font-family:'JetBrains Mono';font-size:13px;font-weight:700;color:var(--rd)}

/* MODAL */
.modal-bg{position:fixed;inset:0;background:rgba(0,0,0,.65);z-index:280;display:none;align-items:flex-end;justify-content:center;backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);padding:20px}
@media(min-width:700px){.modal-bg{align-items:center}.modal-bg .modal{max-width:560px;border-radius:16px}}
.modal-bg.show{display:flex}
.modal{background:var(--c1);border-radius:16px 16px 0 0;width:100%;max-width:480px;max-height:82vh;overflow-y:auto;padding:16px 16px 30px;border:1px solid var(--b1);border-bottom:none;animation:slideUp .3s cubic-bezier(.16,1,.3,1)}
@keyframes slideUp{from{transform:translateY(100%);opacity:.5}to{transform:translateY(0);opacity:1}}
/* v2.16.68: universal card-mount animation. Every card in the Overview tab fades+rises
   in on first render with a small stagger. Uses CSS variables so we don't have to
   inject inline styles per card. */
@keyframes hcCardMount{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}
@keyframes hcChartDraw{from{stroke-dashoffset:var(--hcDash, 1000)}to{stroke-dashoffset:0}}
@keyframes hcBarGrow{from{transform:scaleY(0);transform-origin:bottom}to{transform:scaleY(1);transform-origin:bottom}}
#t-ov .card{animation:hcCardMount .55s cubic-bezier(.2,.8,.2,1) both}
#t-ov .card:nth-child(1){animation-delay:.02s}
#t-ov .card:nth-child(2){animation-delay:.06s}
#t-ov .card:nth-child(3){animation-delay:.10s}
#t-ov .card:nth-child(4){animation-delay:.14s}
#t-ov .card:nth-child(5){animation-delay:.18s}
#t-ov .card:nth-child(6){animation-delay:.22s}
#t-ov .card:nth-child(n+7){animation-delay:.26s}
#t-ov .mini-bar{animation:hcBarGrow .65s cubic-bezier(.2,.8,.2,1) both}
#t-ov .mini-bar:nth-child(1){animation-delay:.32s}
#t-ov .mini-bar:nth-child(2){animation-delay:.36s}
#t-ov .mini-bar:nth-child(3){animation-delay:.40s}
#t-ov .mini-bar:nth-child(4){animation-delay:.44s}
#t-ov .mini-bar:nth-child(5){animation-delay:.48s}
#t-ov .mini-bar:nth-child(6){animation-delay:.52s}
/* SVG path drawing — scoped to overview tab so it doesn't re-fire inside modals */
#t-ov [data-hc-draw]{stroke-dasharray:var(--hcDash, 1000);animation:hcChartDraw 1.2s cubic-bezier(.2,.8,.2,1) both;animation-delay:.3s}
/* v2.16.69: kill any inherited animations inside the True Profit modal —
   the global card/bar/draw rules were re-firing every time the modal opened
   because the modal's inner divs got matched. Modal renders are explicit. */
#trueProfitModal *{animation:none !important;transition:none !important}
@media (prefers-reduced-motion: reduce){
  #t-ov .card,#t-ov .mini-bar,#t-ov [data-hc-draw]{animation:none !important}
}
.modal-bar{width:36px;height:4px;background:var(--c3);border-radius:4px;margin:0 auto 14px}
.modal h2{font-size:16px;font-weight:800;letter-spacing:-.3px}
.modal .msub{font-size:11px;color:var(--t3);margin-top:2px;margin-bottom:14px}
.modal .mrow{display:flex;justify-content:space-between;align-items:center;padding:10px 0;border-bottom:1px solid var(--b1);gap:8px}
.modal .mrow:last-child{border-bottom:none}
.mlabel{font-size:12px;color:var(--t2)}
.mval{font-family:'JetBrains Mono';font-size:13px;font-weight:700}
.mval.green{color:var(--gn)}.mval.gold{color:var(--gd)}.mval.red{color:var(--rd)}
.signal{display:inline-flex;align-items:center;gap:3px;font-family:'JetBrains Mono';font-size:10px;font-weight:700;padding:3px 8px;border-radius:6px}
.signal.up{background:rgba(16,185,129,.08);color:var(--gn);border:1px solid rgba(16,185,129,.12)}
.signal.down{background:rgba(239,68,68,.08);color:var(--rd);border:1px solid rgba(239,68,68,.12)}
.mbtn{background:var(--c3);border:none;color:var(--t1);font-family:Inter;font-size:13px;font-weight:600;padding:12px;width:100%;border-radius:12px;margin-top:14px;cursor:pointer}
.mbtn.primary{background:var(--bl);color:#fff}
.msec{font-size:10px;font-weight:700;color:var(--t4);text-transform:uppercase;letter-spacing:1px;margin:14px 0 6px}

/* TABS */
.tab{display:none}.tab.on{display:block;animation:tabIn .22s cubic-bezier(.2,.8,.4,1) both}
/* v2.23.56 (audit-A): mobile-first — full-bleed (no sidebar exists below 900px, so a
   left:220px offset shoved Settings / Personal Transactions off-screen and clipped them).
   The 220px sidebar clearance is scoped to the desktop breakpoint below. */
#t-set.on,#t-pex.on{position:fixed;inset:0;overflow-x:hidden;overflow-y:auto;z-index:50;background:var(--c1,#070d18)}
@keyframes fadeIn{from{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}
@keyframes tabIn{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}

/* BOTTOM NAV (mobile) */
.nav{position:fixed;bottom:0;left:0;right:0;z-index:100;background:rgba(6,9,15,.88);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-top:1px solid var(--b1);display:flex;justify-content:center;gap:2px;padding:6px 12px env(safe-area-inset-bottom,20px)}
.nav-btn{display:flex;flex-direction:column;align-items:center;gap:2px;padding:6px 14px;border:none;border-radius:12px;font-family:Inter;font-size:9px;font-weight:600;color:var(--t4);background:transparent;cursor:pointer;transition:all .2s;flex:1;max-width:90px}
.nav-btn .icon{font-size:20px;transition:transform .2s;display:inline-flex;align-items:center;justify-content:center}.nav-btn .icon svg{width:20px;height:20px}
.nav-btn.on{color:var(--bl)}
.nav-btn.on .icon{transform:scale(1.15)}

/* SIDEBAR (desktop) */
.sidebar{display:none}

/* SKELETON */
.sk{background:linear-gradient(90deg,var(--c2) 25%,var(--c3) 50%,var(--c2) 75%);background-size:200% 100%;animation:shimmer 1.5s infinite;border-radius:8px;height:22px;width:80px;display:inline-block}
@keyframes shimmer{0%{background-position:200% 0}100%{background-position:-200% 0}}

.empty{text-align:center;padding:32px 16px;color:var(--t3);font-size:12px}
.empty .eicon{font-size:36px;margin-bottom:8px;opacity:.5;display:flex;justify-content:center}.empty .eicon svg{width:36px;height:36px}

/* NOTIFICATIONS */
/* v2.17.35: To-Do card row styles + animated entry / exit. Each row slides in from above
   on insert and slides out + collapses on complete. Mirrors the .sub-row visual language
   so it fits col-side. Checkbox circle uses priority color when filled. */
.todo-row{display:flex;align-items:center;gap:10px;padding:8px 4px;border-bottom:1px solid var(--b1);cursor:pointer;transition:opacity .2s,transform .2s;animation:todoSlideIn .25s cubic-bezier(.16,1,.3,1) both}
.todo-row:last-child{border-bottom:none}
.todo-row:hover{background:rgba(96,165,250,.04)}
.todo-row:active{transform:scale(.99)}
.todo-row.done{opacity:.45;text-decoration:line-through;text-decoration-color:var(--t4)}
.todo-row.removing{animation:todoSlideOut .35s cubic-bezier(.4,0,1,1) forwards}
.todo-check{width:18px;height:18px;min-width:18px;border:1.5px solid var(--t4);border-radius:50%;cursor:pointer;flex-shrink:0;padding:0;background:transparent;transition:border-color .15s,background .15s,transform .15s;display:flex;align-items:center;justify-content:center;color:transparent}
.todo-check:hover{border-color:var(--gn);color:var(--gn);transform:scale(1.08)}
.todo-check.p1{border-color:rgba(239,68,68,.5)}
.todo-check.p2{border-color:rgba(251,191,36,.5)}
.todo-check.p3{border-color:rgba(96,165,250,.5)}
.todo-check.checked{background:var(--gn);border-color:var(--gn);color:#fff;transform:scale(1.08)}
.todo-body{flex:1;min-width:0}
.todo-title{font-size:12px;color:var(--t1);font-weight:600;line-height:1.35;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.todo-meta{font-size:9px;color:var(--t4);margin-top:1px;display:flex;gap:6px;align-items:center;flex-wrap:wrap}
.todo-pri{font-weight:700;letter-spacing:.4px}
.todo-pri.p1{color:var(--rd)}.todo-pri.p2{color:var(--gd)}.todo-pri.p3{color:var(--bl)}
.todo-due{color:var(--t3)}.todo-due.overdue{color:var(--rd);font-weight:700}.todo-due.today{color:var(--gd);font-weight:700}
@keyframes todoSlideIn{from{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}
@keyframes todoSlideOut{
  0%{opacity:1;transform:translateX(0);max-height:60px;padding-top:8px;padding-bottom:8px;margin-bottom:0;border-bottom-width:1px}
  60%{opacity:0;transform:translateX(40px)}
  100%{opacity:0;transform:translateX(40px);max-height:0;padding-top:0;padding-bottom:0;margin-bottom:0;border-bottom-width:0}
}
.notif-bell{position:relative;background:var(--c2);border:1px solid var(--b1);border-radius:50%;width:36px;height:36px;display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:16px;color:var(--t2);transition:all .2s;flex-shrink:0}
.notif-bell:hover{border-color:var(--b2);color:var(--t1)}
/* v2.17.34: shake the bell when there are unread notifications. Plays every 4s while idle,
   pauses when the notif pane is open. Suspends entirely once user has dismissed everything. */
@keyframes notifShake{
  0%,82%,100%{transform:rotate(0)}
  85%{transform:rotate(-14deg)}
  88%{transform:rotate(12deg)}
  91%{transform:rotate(-10deg)}
  94%{transform:rotate(8deg)}
  97%{transform:rotate(-4deg)}
}
.notif-bell.has-unread{color:var(--gd);border-color:rgba(251,191,36,.4);animation:notifShake 4s ease-in-out infinite;transform-origin:50% 4px}
.notif-bell.has-unread:hover,.notif-bell.has-unread.muted{animation-play-state:paused}
.notif-badge{position:absolute;top:-2px;right:-2px;background:var(--rd);color:#fff;font-size:9px;font-weight:700;min-width:16px;height:16px;border-radius:8px;display:inline-flex;align-items:center;justify-content:center;padding:0 4px;box-shadow:0 0 0 2px var(--bg);font-family:'JetBrains Mono'}
.notif-pane{position:fixed;top:60px;right:16px;width:340px;max-height:70vh;background:var(--c1);border:1px solid var(--b2);border-radius:12px;padding:10px;z-index:180;box-shadow:0 12px 40px rgba(0,0,0,.5);display:none;overflow-y:auto}
.notif-pane.open{display:block;animation:fadeIn .2s ease}
.notif-pane-head{display:flex;justify-content:space-between;align-items:center;padding:4px 6px 10px;border-bottom:1px solid var(--b1);margin-bottom:8px}
.notif-pane-head h3{font-size:13px;font-weight:700}
.notif-pane-head button{background:transparent;border:none;color:var(--t3);font-family:Inter;font-size:10px;font-weight:700;cursor:pointer;text-transform:uppercase;letter-spacing:.5px;padding:4px 8px;border-radius:6px}
.notif-pane-head button:hover{background:var(--c3);color:var(--t1)}
.notif-card{display:flex;gap:10px;align-items:flex-start;padding:10px;background:var(--c2);border:1px solid var(--b1);border-radius:10px;margin-bottom:6px;animation:slideInRight .25s cubic-bezier(.16,1,.3,1)}
@keyframes slideInRight{from{transform:translateX(20px);opacity:0}to{transform:translateX(0);opacity:1}}
.notif-body{flex:1;min-width:0}
.notif-title{font-size:12px;font-weight:700;color:var(--t1);margin-bottom:2px}
.notif-msg{font-size:11px;color:var(--t2);line-height:1.3;word-break:break-word}
.notif-meta{font-size:10px;color:var(--t4);font-family:'JetBrains Mono';margin-top:4px;font-weight:600}
.notif-x{background:transparent;border:none;color:var(--t4);font-size:18px;cursor:pointer;padding:0;width:24px;height:24px;display:flex;align-items:center;justify-content:center;border-radius:50%;flex-shrink:0}
.notif-x:hover{background:var(--c3);color:var(--rd)}

@media (min-width:900px){
 .notif-pane{top:70px;right:40px;width:380px}
}

/* Toast */
.toast{position:fixed;top:18px;left:50%;transform:translateX(-50%) translateY(-10px);background:var(--c1);border:1px solid var(--b2);color:var(--t1);padding:10px 16px;border-radius:10px;font-size:12px;font-weight:600;z-index:300;box-shadow:0 8px 30px rgba(0,0,0,.5);opacity:0;pointer-events:none;transition:all .25s;max-width:90vw}
.toast.show{opacity:1;transform:translateX(-50%) translateY(0)}

::-webkit-scrollbar{width:4px;height:4px}
::-webkit-scrollbar-thumb{background:var(--b2);border-radius:3px}

/* */
/* DESKTOP BREAKPOINT (>=900px) */
/* */
@media (min-width:900px){
 body{overflow-y:auto}
 .shell{display:grid;grid-template-columns:220px minmax(0,1fr);min-height:100vh;min-height:100dvh;max-width:1400px;margin:0 auto}
 .app{max-width:none;width:100%;box-sizing:border-box;overflow-x:hidden;padding:28px 40px 40px;grid-column:2;min-width:0}
 /* v2.23.56 (audit-A): the fixed Settings / Personal Transactions tabs clear the 220px
    desktop sidebar here only — on mobile they stay full-bleed (inset:0, see above). */
 #t-set.on,#t-pex.on{left:220px}

 /* Hide bottom nav, show sidebar */
 .nav{display:none}
 .sidebar{display:flex;flex-direction:column;gap:4px;padding:28px 14px;border-right:1px solid var(--b1);grid-column:1;position:sticky;top:0;height:100vh;height:100dvh;-webkit-overflow-scrolling:touch}
 .sidebar .logo{margin-bottom:22px;padding:0 8px}
 .side-btn{display:flex;align-items:center;gap:12px;padding:11px 14px;border-radius:10px;background:transparent;border:none;color:var(--t3);font-family:Inter;font-size:13px;font-weight:600;cursor:pointer;text-align:left;transition:all .2s;width:100%}
 .side-btn .icon{font-size:18px;display:inline-flex;align-items:center}.side-btn .icon svg{width:18px;height:18px}
 .side-btn:hover{background:var(--c2);color:var(--t1)}
 .side-btn.on{background:var(--c3);color:var(--bl);border-left:2px solid var(--bl);padding-left:12px}

 /* Overview: 2-col content with sticky sidebar summary */
 #t-ov{display:none;grid-template-columns:1.4fr 1fr;gap:16px;align-items:start}
 #t-ov.on{display:grid}
 #t-ov .col-main{display:flex;flex-direction:column;min-width:0}
 #t-ov .col-side{display:flex;flex-direction:column;position:sticky;top:20px;min-width:0;max-width:100%}

 /* v2.16.32: Personal Categories tab gets desktop polish — was rendering as cramped mobile column on wide screens */
 #t-pcat{max-width:680px;margin:0 auto}
 #t-pcat .pers-cat-row{padding:10px 12px;background:var(--c2);border:1px solid var(--b1);border-radius:10px;margin-bottom:6px;display:flex;align-items:center;gap:10px;cursor:pointer;transition:all .15s}
 #t-pcat .pers-cat-row:hover{border-color:var(--pp);transform:translateY(-1px)}
 /* v2.16.20: Personal Overview gets a sticky Categories sidebar on desktop.
    grid-row 1/span 999 forces the sidebar to start at row 1 of column 2 even though it's the last DOM child. */
 #t-pov{display:none;grid-template-columns:minmax(0,1fr) 320px;gap:16px;align-items:start}
 #t-pov.on{display:grid}
 #t-pov > *:not(.pcat-side){grid-column:1;min-width:0}
 #t-pov .pcat-side{grid-column:2;grid-row:1/span 999;position:sticky;top:20px;display:flex;flex-direction:column;max-height:calc(100vh - 40px);overflow-y:auto;background:var(--c2);border:1px solid var(--b1);border-radius:12px;padding:16px;align-self:start}
 #t-pov .pcat-side .pcat-side-head{display:flex;justify-content:space-between;align-items:baseline;padding:0 0 10px;border-bottom:1px solid var(--b1);margin-bottom:10px}
 #t-pov .pcat-side .pcat-side-title{font-size:11px;font-weight:800;color:var(--t2);text-transform:uppercase;letter-spacing:.8px}
 #t-pov .pcat-side .pcat-side-month{font-size:10px;color:var(--t3);font-family:'JetBrains Mono';font-variant-numeric:tabular-nums}

 .kpi-grid{grid-template-columns:repeat(4,minmax(0,1fr))}
 #t-ov .kpi-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
 .bal-grid{grid-template-columns:repeat(3,1fr)}

 /* Clients: 2 cols */
 #cL{display:grid;grid-template-columns:1fr 1fr;gap:10px}
 #cL .client{margin-bottom:0}

 /* Expense rows: wider, 4-col form */
 .ex-form{grid-template-columns:1fr 1fr 1fr 1fr}
 .ex-row{padding:14px 16px}

 /* v2.16.54: Expense tab desktop layout — was stuck looking mobile because no #t-ex rule existed.
    Now MRE on the left, One-Times on the right, status banner full-width on top. */
 #t-ex{display:none}
 #t-ex.on{display:grid;grid-template-columns:1fr 1fr;gap:16px;align-items:start}
 #t-ex > #amexArea{grid-column:1/-1}
 #t-ex > #expenseClientFilter{grid-column:1/-1}
 /* v2.16.79: collapse to single column on mobile — was forcing 2-col on small screens. */
 @media (max-width:900px){
   #t-ex.on{grid-template-columns:1fr;gap:12px}
   #t-ex .card{padding:14px 14px}
   #t-ex h3{font-size:14px}
   #t-ex [id$="Total"]{font-size:18px}
 }

 /* Tasks tab: cap width so the filters/list don't sprawl full-1400px */
 #t-tk{max-width:1000px;margin:0 auto}
 /* P&L tab: cap width similarly */
 #t-rp{max-width:1100px;margin:0 auto}
 /* History tab: cap width + sensible reading column */
 #t-hist{max-width:1100px;margin:0 auto}

 /* P&L: 2 cols */
 #plList{display:grid;grid-template-columns:1fr 1fr;gap:10px}
 #plList .pl-row{margin-bottom:0}

 /* Header greet bigger */
 .greet{font-size:22px}
 .hdr{padding-top:0}

 /* Slightly bigger spark */
 .spark-row{gap:16px}

 /* Toast position */
 .toast{top:24px;bottom:auto}
}

/* Very wide screens: cap content width */
@media (min-width:1400px){
 .app{max-width:1200px}
}

/* MOTION / BOOTING UP / MICRO-INTERACTIONS */
@keyframes fadeUp{from{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}
@keyframes bootSlide{0%{opacity:0;transform:translateY(18px);filter:blur(4px)}50%{filter:blur(2px)}100%{opacity:1;transform:translateY(0);filter:blur(0)}}
@keyframes shimmer{0%{background-position:-200px 0}100%{background-position:200px 0}}
/* "Booting up" staggered reveal on initial load */
.tab.on .card{animation:bootSlide .85s cubic-bezier(.2,.9,.3,1) both}
.tab.on .card:nth-child(1){animation-delay:.05s}
.tab.on .card:nth-child(2){animation-delay:.18s}
.tab.on .card:nth-child(3){animation-delay:.32s}
.tab.on .card:nth-child(4){animation-delay:.46s}
.tab.on .card:nth-child(5){animation-delay:.60s}
.tab.on .card:nth-child(6){animation-delay:.74s}
.tab.on .card:nth-child(7){animation-delay:.88s}
.tab.on .card:nth-child(n+8){animation-delay:1s}
.tab.on .goal-card,.tab.on .prospect-card,.tab.on .sub-row,.tab.on .ex-row,.tab.on .pl-row{animation:fadeUp .55s ease-out both}
.tab.on .kpi{animation-duration:1.1s!important}
.tab.on .kpi-grid .kpi:nth-child(1){animation-delay:.18s}
.tab.on .kpi-grid .kpi:nth-child(2){animation-delay:.34s}
.tab.on .kpi-grid .kpi:nth-child(3){animation-delay:.50s}
.tab.on .kpi-grid .kpi:nth-child(4){animation-delay:.66s}
/* MRR goal bar and profit ring draw in — crisp, restrained timing */
.goal-fill{transition:width 1.2s cubic-bezier(.16,1,.3,1)!important}
.gauge-fill,.cl-profit-fill,.exp-cat-fill,.pers-cat-bar-fill{transition:width 1.2s cubic-bezier(.22,1,.36,1)!important}
/* Donut ring progression on boot */
.goal-donut svg circle.slice,.donut-wrap svg circle.slice{transition:stroke-dasharray 1.2s cubic-bezier(.22,1,.36,1), stroke .3s}
/* Cards lift subtly on hover (fast) */
.card:hover{transform:translateY(-1px);transition:transform .15s ease-out, border-color .2s}
.kpi-val{transition:color .4s}
.client{transition:transform .14s ease-out, box-shadow .25s, border-color .25s}
.client:hover{transform:translateY(-2px)}
.client:active{transform:translateY(0) scale(.995)}
.fab{transition:transform .22s cubic-bezier(.34,1.56,.64,1),box-shadow .22s}
.fab:hover{transform:translateY(-3px) scale(1.04)}
.goal-card.done::before{background:var(--gn)}
#aiPulseCard[data-loading="1"]{opacity:.7}
.tab{transition:opacity .3s ease-out}
.tab:not(.on){opacity:0;pointer-events:none}
.tab.on{opacity:1}
/* Greeting slides in first */
.greet,.tagline,.meta{animation:bootSlide .7s cubic-bezier(.2,.9,.3,1) both}
.greet{animation-delay:.08s}
.tagline{animation-delay:.22s}
.meta{animation-delay:.36s}
/* Logo stays static on boot (ambient scan-glow removed) */

/* TASKS TAB (command center) */
.tk-quickadd{display:flex;gap:8px;margin-bottom:14px;align-items:center}
.tk-quickadd input{flex:1;background:var(--c2);border:1px solid var(--b1);border-radius:12px;padding:12px 14px;color:var(--t1);font-family:Inter;font-size:13px;font-weight:500}
.tk-quickadd input:focus{outline:none;border-color:var(--bl)}
.tk-add-btn{background:var(--bl);border:none;border-radius:10px;padding:12px 18px;color:#fff;font-family:Inter;font-size:12px;font-weight:700;cursor:pointer;transition:filter .15s,transform .15s;white-space:nowrap}
.tk-add-btn:hover{filter:brightness(1.06);transform:translateY(-1px)}
.tk-add-btn:active{transform:scale(.97)}

.tk-filters{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:16px;align-items:center}

.tk-group{margin-bottom:18px}
.tk-group-head{display:flex;justify-content:space-between;align-items:center;padding:6px 4px 8px;border-bottom:1px solid var(--b1);margin-bottom:8px}
.tk-group-title{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:1.2px;color:var(--t3);display:flex;align-items:center;gap:8px}
.tk-group-count{font-size:10px;color:var(--t4);font-family:'JetBrains Mono';font-weight:700;background:var(--c3);padding:2px 7px;border-radius:5px;border:1px solid var(--b1)}

.tk-card{background:var(--c2);border:1px solid var(--b1);border-radius:12px;padding:12px 14px;margin-bottom:8px;cursor:pointer;transition:all .15s;position:relative;overflow:hidden;display:flex;gap:12px;align-items:flex-start}
/* v2.17.15: long-press jiggle + drag — iOS-style "wiggle then pick up" for the Tasks tab default view. */
@keyframes tkJiggle{0%{transform:rotate(-.7deg)}50%{transform:rotate(.7deg)}100%{transform:rotate(-.7deg)}}
.tk-card.tk-jiggle{animation:tkJiggle .2s ease-in-out infinite;transform-origin:center;will-change:transform;touch-action:none}
.tk-card.tk-dragging{opacity:.35;pointer-events:none}
.tk-drag-clone{position:fixed;z-index:9999;pointer-events:none;box-shadow:0 14px 40px rgba(0,0,0,.45),0 4px 14px rgba(0,0,0,.25);transform:scale(1.04) rotate(-1.5deg);transition:transform .12s cubic-bezier(.16,1,.3,1);will-change:transform,top,left;background:var(--c1);border-radius:12px;border:1px solid var(--b2)}
.tk-group{transition:background .15s,border-color .15s,box-shadow .15s;border-radius:12px;border:1px solid transparent;padding:2px}
.tk-group.tk-drop-target{background:rgba(96,165,250,.06);border-color:rgba(96,165,250,.45);box-shadow:0 0 0 3px rgba(96,165,250,.12) inset}
.tk-group.tk-drop-target .tk-group-head{color:var(--bl)}
.tk-card:hover{border-color:var(--b2);transform:translateY(-1px);box-shadow:0 4px 14px rgba(0,0,0,.18)}
.tk-card.p1{border-left:3px solid var(--rd)}
.tk-card.p2{border-left:3px solid var(--gd)}
.tk-card.p3{border-left:3px solid var(--bl)}
.tk-card.p4{border-left:3px solid var(--t4)}
.tk-card.overdue{background:var(--c2)}
.tk-card.completed{opacity:.5;text-decoration:line-through}
.tk-check{width:20px;height:20px;border:1.5px solid var(--b2);border-radius:50%;flex-shrink:0;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .15s;margin-top:1px;background:transparent}
.tk-check:hover{border-color:var(--gn);background:rgba(16,185,129,.08)}
.tk-check.p1{border-color:var(--rd)}.tk-check.p2{border-color:var(--gd)}.tk-check.p3{border-color:var(--bl)}
.tk-card-body{flex:1;min-width:0}
.tk-card-title{font-size:13px;font-weight:600;color:var(--t1);line-height:1.4;margin-bottom:4px;word-break:break-word}
.tk-card-desc{font-size:11px;color:var(--t3);margin-bottom:5px;line-height:1.5;overflow:hidden;text-overflow:ellipsis;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical}
.tk-card-meta{display:flex;flex-wrap:wrap;gap:6px;align-items:center;font-size:10px;color:var(--t3);font-family:'JetBrains Mono';font-weight:500}
.tk-pri{font-weight:700;padding:1px 6px;border-radius:4px;font-size:9px;letter-spacing:.5px;text-transform:uppercase}
.tk-pri.p1{background:rgba(239,68,68,.12);color:var(--rd);border:1px solid rgba(239,68,68,.2)}
.tk-pri.p2{background:rgba(251,191,36,.12);color:var(--gd);border:1px solid rgba(251,191,36,.2)}
.tk-pri.p3{background:rgba(59,130,246,.12);color:var(--bl);border:1px solid rgba(59,130,246,.2)}
.tk-due{padding:1px 6px;border-radius:4px;background:var(--c3);border:1px solid var(--b1)}
.tk-due.overdue{background:rgba(239,68,68,.1);color:var(--rd);border-color:rgba(239,68,68,.2)}
.tk-due.today{background:rgba(251,191,36,.1);color:var(--gd);border-color:rgba(251,191,36,.2)}
.tk-proj{color:var(--t4);font-weight:600}
.tk-labels{display:flex;gap:3px;flex-wrap:wrap}
.tk-label{background:rgba(168,85,247,.1);color:var(--pp);padding:1px 6px;border-radius:4px;font-size:9px;font-weight:700;border:1px solid rgba(168,85,247,.18)}
.tk-card-more{color:var(--t4);font-size:10px;display:flex;align-items:center;gap:4px}
.tk-summary-bar{display:flex;gap:10px;margin-bottom:12px;flex-wrap:wrap}
.tk-stat{flex:1;min-width:90px;background:var(--c2);border:1px solid var(--b1);border-radius:10px;padding:10px 12px}
.tk-stat-label{font-size:9px;font-weight:700;text-transform:uppercase;letter-spacing:.8px;color:var(--t3);margin-bottom:3px}
.tk-stat-val{font-family:'JetBrains Mono';font-size:18px;font-weight:700}

/* TASK POPUP (centered, smooth animate) */
@keyframes taskPop{from{opacity:0;transform:scale(.92) translateY(8px)}to{opacity:1;transform:scale(1) translateY(0)}}
.task-overlay{position:fixed;inset:0;background:rgba(0,0,0,.72);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);z-index:310;display:none;align-items:center;justify-content:center;padding:20px}
.task-overlay.show{display:flex;animation:lockFade .2s ease-out}
.task-panel{background:var(--c1);border:1px solid var(--b2);border-radius:16px;padding:22px;max-width:560px;width:100%;box-shadow:0 20px 60px rgba(0,0,0,.5);animation:taskPop .28s cubic-bezier(.34,1.56,.64,1);max-height:92vh;overflow-y:auto}
.task-title{font-size:18px;font-weight:700;color:var(--t1);line-height:1.3;margin-bottom:8px;letter-spacing:-.2px}
.task-title-input{width:100%;font-size:18px;font-weight:700;color:var(--t1);background:transparent;border:none;border-bottom:1px dashed var(--b2);padding:6px 0 8px;margin-bottom:10px;font-family:Inter;outline:none}
.task-title-input:focus{border-color:var(--bl)}
/* ===== PROJECT DETAIL VIEW — scoped styling (v2.19, mobile-first 390px) ===== */
#projectDetail{padding:0;align-items:stretch;justify-content:center}
#projectDetail.show{animation:lockFade .22s ease-out}
/* v2.23.44 (4e): flat redesign — dropped the rise/stagger entrance cascade + the
   heavy shadow. The overlay's lockFade is the only entrance now (it respects
   prefers-reduced-motion site-wide). Flat tokens replace the glassmorphic chrome. */
.pd-modal{position:relative;width:100%;max-width:760px;background:var(--c1);
 border:1px solid var(--b2);border-radius:0;
 padding:max(18px,env(safe-area-inset-top,0px)) 16px calc(28px + env(safe-area-inset-bottom,0px));
 box-shadow:0 -8px 32px rgba(0,0,0,.4);
 max-height:100dvh;height:100dvh;overflow-y:auto;overflow-x:hidden;-webkit-overflow-scrolling:touch;
 box-sizing:border-box;-webkit-tap-highlight-color:transparent}
.pd-modal::before{content:"";position:absolute;inset:0 0 auto;height:1px;background:var(--b1);pointer-events:none}
/* pdRise stays defined — it's a shared sheet-entrance keyframe other panels use
   (.pex-panel, .set-panel). The project-detail modal no longer applies it (4e). */
@keyframes pdRise{from{opacity:0;transform:translateY(22px)}to{opacity:1;transform:translateY(0)}}
/* header */
.pd-head{display:flex;flex-direction:column;gap:10px;margin-bottom:14px}
.pd-head-meta{display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.pd-name{flex:1;min-width:0;width:100%;background:transparent;border:none;border-bottom:1px dashed transparent;color:var(--t1);
 font-family:Inter;font-size:23px;font-weight:800;letter-spacing:-.5px;line-height:1.15;padding:2px 0 4px;outline:none;transition:border-color .15s}
.pd-name:hover{border-bottom-color:var(--b2)}
.pd-name:focus{border-bottom-color:var(--bl)}
.pd-name::placeholder{color:var(--t3)}
.pd-save{font-family:'JetBrains Mono';font-size:10px;font-weight:700;letter-spacing:.3px;padding:3px 9px;border-radius:999px;border:1px solid var(--b2);color:var(--t2);background:rgba(255,255,255,.02);white-space:nowrap;transition:all .2s}
.pd-save[data-state="saving"]{color:var(--gd);border-color:rgba(251,191,36,.35);background:rgba(251,191,36,.08)}
.pd-save[data-state="saved"]{color:var(--gn);border-color:rgba(16,185,129,.3);background:rgba(16,185,129,.07)}
.pd-save[data-state="error"]{color:var(--rd);border-color:rgba(239,68,68,.35);background:rgba(239,68,68,.08)}
.pd-status{font-family:'JetBrains Mono';font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.6px;padding:3px 10px;border-radius:999px;border:1px solid var(--b2);color:var(--t2)}
select.pd-status{appearance:none;-webkit-appearance:none;cursor:pointer;padding:3px 22px 3px 10px;outline:none;
 background-image:linear-gradient(45deg,transparent 50%,currentColor 50%),linear-gradient(135deg,currentColor 50%,transparent 50%);
 background-position:calc(100% - 11px) center,calc(100% - 7px) center;background-size:4px 4px,4px 4px;background-repeat:no-repeat}
select.pd-status option{color:var(--t1);background:var(--c4);text-transform:none;font-weight:600}
.pd-status-idea{color:var(--t2);border-color:var(--b2);background:rgba(148,163,184,.06)}
.pd-status-active{color:var(--bl);border-color:rgba(59,130,246,.4);background:rgba(59,130,246,.1)}
.pd-status-paused{color:var(--gd);border-color:rgba(251,191,36,.35);background:rgba(251,191,36,.08)}
.pd-status-done{color:var(--gn);border-color:rgba(16,185,129,.4);background:rgba(16,185,129,.12)}
.pd-close{margin-left:auto;width:32px;height:32px;flex:0 0 auto;display:grid;place-items:center;border-radius:10px;border:1px solid var(--b2);background:rgba(255,255,255,.02);color:var(--t2);font-size:14px;cursor:pointer;transition:all .15s}
.pd-close:hover{color:var(--t1);border-color:var(--b3);background:rgba(255,255,255,.05)}
/* ready-to-close nudge (Phase 4) — shown when all linked tasks are complete */
.pd-ready{display:block;width:100%;box-sizing:border-box;margin:0 0 16px;padding:11px 16px;text-align:center;
 font-family:Inter;font-weight:800;font-size:13.5px;letter-spacing:.2px;cursor:pointer;border-radius:12px;
 color:var(--gn);border:1px solid rgba(16,185,129,.45);background:rgba(16,185,129,.12);
 transition:background .15s,border-color .15s}
.pd-ready:hover{background:rgba(16,185,129,.2)}
.pd-ready:active{transform:translateY(1px)}
@keyframes pdReadyPulse{0%,100%{opacity:1}50%{opacity:1}}
/* Definition of done — v2.23.44 (4e): the Goal block is now a labeled, editable
   "Definition of done" field with a Hermes-suggest button. Flat tokens. */
.pd-goal{font-size:14px;color:var(--t2);line-height:1.55;margin-bottom:14px;display:flex;flex-direction:column;gap:7px}
.pd-goal-row{display:flex;align-items:center;justify-content:space-between;gap:10px;flex-wrap:wrap}
.pd-goal>.pd-goal-row>b{font-family:'JetBrains Mono';font-size:9px;font-weight:700;text-transform:uppercase;letter-spacing:1.2px;color:var(--t3);flex:0 0 auto}
.pd-dod-suggest{flex:0 0 auto;background:rgba(59,130,246,.1);border:1px solid rgba(59,130,246,.3);color:var(--bl);font-family:Inter;font-size:11px;font-weight:700;letter-spacing:.2px;border-radius:8px;padding:5px 11px;cursor:pointer;min-height:30px;transition:background .15s,border-color .15s}
.pd-dod-suggest:hover{background:rgba(59,130,246,.18)}
.pd-dod-suggest:active{transform:translateY(1px)}
.pd-dod-suggest:focus-visible{outline:2px solid var(--bl);outline-offset:2px}
.pd-dod-suggest:disabled{opacity:.6;cursor:default}
.pd-goal-text{color:var(--t1);font-size:15px;font-weight:500;outline:none;border-radius:8px;padding:8px 10px;background:var(--c2);border:1px solid var(--b1);transition:border-color .15s,background .15s;word-break:break-word;min-height:22px}
.pd-goal-text:hover{border-color:var(--b2)}
.pd-goal-text:focus{border-color:var(--bl);background:var(--c3)}
.pd-goal-text:empty::before{content:"What does done look like?";color:var(--t3)}
/* progress — v2.23.44 (4e): flat track, no inset glass shadow */
.pd-progress{height:8px;border-radius:999px;background:var(--c3);overflow:hidden;margin-bottom:22px}
.pd-bar{height:100%;border-radius:999px;background:var(--bl);transition:width .4s ease}
/* panels — v2.23.44 (4e): flat tokens, no backdrop blur */
.pd-panel{background:var(--c2);border:1px solid var(--b1);border-radius:12px;padding:16px;margin-bottom:14px}
.pd-panel-h{display:flex;align-items:center;gap:8px;font-family:'JetBrains Mono';font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:1.4px;color:var(--t2);margin-bottom:12px}
.pd-count{font-size:9px;color:var(--bl);background:rgba(59,130,246,.12);border:1px solid rgba(59,130,246,.28);border-radius:999px;padding:1px 7px;letter-spacing:.4px}
.pd-empty{font-size:13px;color:var(--t3);padding:10px 2px;font-style:italic}
/* tasks */
.pd-tasks{display:flex;flex-direction:column;gap:6px;margin-bottom:10px}
.pd-task{display:flex;align-items:center;gap:8px;background:rgba(255,255,255,.025);border:1px solid var(--b1);border-radius:10px;padding:9px 11px;font-size:13.5px;color:var(--t1);line-height:1.35}
.pd-task-t{flex:1;min-width:0;cursor:pointer;word-break:break-word;transition:color .12s}
.pd-task-t:hover{color:var(--bl)}
.pd-task-gone{flex:1;color:var(--t3);font-style:italic;font-size:12.5px}
.pd-task-x{flex:0 0 auto;width:22px;height:22px;display:grid;place-items:center;border-radius:7px;border:1px solid transparent;background:transparent;color:var(--t3);font-size:11px;cursor:pointer;transition:all .12s}
.pd-task-x:hover{color:var(--rd);border-color:rgba(239,68,68,.3);background:rgba(239,68,68,.08)}
.pd-task-pick,.pd-input{width:100%;box-sizing:border-box;background:var(--c4);border:1px solid var(--b2);border-radius:10px;color:var(--t1);font-family:Inter;font-size:13.5px;padding:10px 12px;outline:none;transition:border-color .15s}
.pd-task-pick:focus,.pd-input:focus{border-color:var(--bl)}
.pd-task-pick{appearance:none;-webkit-appearance:none;color:var(--t2);cursor:pointer;background-image:linear-gradient(45deg,transparent 50%,var(--t3) 50%),linear-gradient(135deg,var(--t3) 50%,transparent 50%);background-position:calc(100% - 16px) center,calc(100% - 11px) center;background-size:5px 5px,5px 5px;background-repeat:no-repeat}
/* notes */
.pd-note-add{display:flex;gap:8px;margin-bottom:12px}
.pd-note-add .pd-input{flex:1;min-width:0}
.pd-add-btn{flex:0 0 auto;background:rgba(59,130,246,.12);border:1px solid rgba(59,130,246,.4);color:var(--bl);font-weight:700;font-size:13px;border-radius:10px;padding:0 16px;cursor:pointer;transition:background .15s}
.pd-add-btn:hover{background:rgba(59,130,246,.2)}
.pd-add-btn:active{transform:translateY(1px)}
.pd-notes{display:flex;flex-direction:column;gap:7px}
.pd-note{display:flex;flex-direction:column;gap:3px;background:rgba(255,255,255,.022);border-left:2px solid rgba(59,130,246,.4);border-radius:0 10px 10px 0;padding:9px 12px}
.pd-note-ts{font-family:'JetBrains Mono';font-size:9.5px;font-weight:600;letter-spacing:.4px;color:var(--t3);text-transform:uppercase}
.pd-note-t{font-size:13.5px;color:var(--t1);line-height:1.5;word-break:break-word}
/* context panels (Phase 3): client / money / hermes / links */
.pd-stats{display:flex;flex-direction:column;gap:8px}
.pd-stat{display:flex;justify-content:space-between;align-items:baseline;gap:12px}
.pd-stat-k{font-size:11px;font-weight:600;letter-spacing:.3px;text-transform:uppercase;color:var(--t3)}
.pd-stat-v{font-size:13.5px;color:var(--t1);text-align:right;word-break:break-word}
.pd-stat-mono{font-family:'JetBrains Mono';font-weight:800;color:var(--gn)}
.pd-money-list{display:flex;flex-direction:column;gap:6px;margin-top:10px}
.pd-money-row{display:flex;justify-content:space-between;align-items:baseline;font-size:12px;padding:7px 10px;background:var(--c3);border-radius:8px}
.pd-money-d{color:var(--t3);font-family:'JetBrains Mono';font-size:10.5px;letter-spacing:.3px;text-transform:uppercase}
.pd-money-a{color:var(--gn);font-family:'JetBrains Mono';font-weight:800}
/* v2.23.44 (4e): .pd-pills/.pd-pill removed with the Hermes Activity panel. */
.pd-links{display:flex;flex-direction:column;gap:7px;margin-bottom:12px}
.pd-link{display:flex;align-items:center;gap:8px;font-size:13.5px;font-weight:600;color:#bcd6ff;text-decoration:none;background:rgba(59,130,246,.06);border:1px solid rgba(59,130,246,.22);border-radius:10px;padding:9px 12px;word-break:break-word;transition:all .15s}
.pd-link:hover{background:rgba(59,130,246,.14);border-color:rgba(59,130,246,.4)}
.pd-link-i{flex:0 0 auto;font-size:12px;opacity:.8}
.pd-link-add{display:flex;gap:8px;flex-wrap:wrap}
.pd-link-add #pdLinkLabel{flex:0 0 34%;min-width:120px}
.pd-link-add #pdLinkUrl{flex:1;min-width:140px}
/* actions */
.pd-actions{display:flex;gap:10px;margin-top:18px;flex-wrap:wrap}
.pd-done{flex:1;min-width:140px;background:rgba(16,185,129,.14);border:1px solid rgba(16,185,129,.45);color:var(--gn);font-weight:800;font-size:14px;letter-spacing:.2px;border-radius:12px;padding:13px;cursor:pointer;transition:background .15s}
.pd-done:hover{background:rgba(16,185,129,.22)}
.pd-done:active{transform:translateY(1px)}
.pd-del{flex:0 0 auto;background:transparent;border:1px solid var(--b2);color:var(--t3);font-weight:600;font-size:13px;border-radius:12px;padding:13px 18px;cursor:pointer;transition:all .15s}
.pd-del:hover{color:var(--rd);border-color:rgba(239,68,68,.4);background:rgba(239,68,68,.06)}
@media(min-width:760px){
 #projectDetail{padding:24px;align-items:center}
 .pd-modal{height:auto;max-height:92dvh;border-radius:16px;padding:28px 30px;border:1px solid var(--b2)}
 .pd-head{flex-direction:row;align-items:flex-start;gap:14px}
 .pd-head-meta{flex:0 0 auto;align-self:flex-start;padding-top:6px}
}
/* ===== PROJECT MOTIVATION (Phase 5) — Wins log card + active-goals strip =====
   Mounted on the Desk (#activeGoals/#winsCard) and the Projects tab (.mtm-goals/.mtm-wins).
   Cohesive with the dark dashboard: mono uppercase headers, emerald goals + gold wins. */
.mtm-grid{display:grid;grid-template-columns:1fr;gap:12px;margin-bottom:8px}
.mtm-grid-prj{margin:0 0 12px}
@media(min-width:760px){.mtm-grid{grid-template-columns:1fr 1fr}}
.mtm-card{min-width:0}
/* v2.23.44 (4d): the goals card is now a compact STRIP — tighter padding + a
   smaller header gap than the wins card so the condensed list reads dense. */
.card.mtm-goals{padding:12px 14px}
.card.mtm-goals .goal-head{margin-bottom:6px}
.goal-head,.win-head{display:flex;align-items:center;gap:9px;margin-bottom:11px}
.goal-title,.win-title{font-family:'JetBrains Mono';font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:1.4px;color:var(--t2)}
.goal-count,.win-count{font-family:'JetBrains Mono';font-size:9px;font-weight:800;letter-spacing:.4px;border-radius:999px;padding:1px 7px}
.goal-count{color:var(--gn);background:rgba(16,185,129,.12);border:1px solid rgba(16,185,129,.28)}
.win-count{color:var(--gd,#fbbf24);background:rgba(251,191,36,.12);border:1px solid rgba(251,191,36,.28)}
.goal-empty,.win-empty{font-size:12.5px;color:var(--t3);font-style:italic;padding:6px 2px}
/* active goals — v2.23.44 (4d): FLAT hairline list, one dense line per goal.
   No emerald card chrome; rows read like the Desk In-Progress (.dkip) strip. */
.goal-list{display:flex;flex-direction:column}
.goal-row{display:flex;align-items:baseline;gap:8px;width:100%;text-align:left;background:transparent;border:none;border-top:1px solid var(--b1);border-radius:0;padding:9px 2px;cursor:pointer;transition:background .12s;font-family:inherit;line-height:1.35}
.goal-row:first-child{border-top:none}
.goal-row:hover{background:rgba(16,185,129,.05)}
.goal-row:focus-visible{outline:2px solid var(--gn);outline-offset:-2px}
.goal-name{flex:0 0 auto;font-size:12.5px;font-weight:700;color:var(--t1);max-width:50%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.goal-dot{flex:0 0 auto;color:var(--t4)}
.goal-text{flex:1;min-width:0;font-size:12px;color:var(--t3);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.goal-deadline{flex:0 0 auto;font-family:'JetBrains Mono';font-size:9.5px;font-weight:700;letter-spacing:.3px;color:var(--gd,#fbbf24);white-space:nowrap}
.goal-more{display:block;width:100%;text-align:left;background:transparent;border:none;border-top:1px solid var(--b1);color:var(--t3);font-family:Inter;font-size:11px;font-weight:600;padding:9px 2px;cursor:pointer;transition:color .12s}
.goal-more:hover{color:var(--gn)}
.goal-more:focus-visible{outline:2px solid var(--gn);outline-offset:-2px}
/* wins */
.win-list{display:flex;flex-direction:column;gap:7px}
.win-row{display:flex;align-items:flex-start;justify-content:space-between;gap:10px;background:rgba(251,191,36,.045);border:1px solid rgba(251,191,36,.16);border-left:2px solid rgba(251,191,36,.55);border-radius:0 11px 11px 0;padding:10px 12px}
.win-main{flex:1;min-width:0}
.win-name{font-size:13.5px;font-weight:700;color:var(--t1);word-break:break-word}
.win-meta{display:flex;flex-wrap:wrap;gap:7px;align-items:baseline;margin-top:3px}
.win-goal{font-size:12px;color:var(--t3);word-break:break-word}
.win-reward{font-size:11.5px;font-weight:600;color:var(--gd,#fbbf24)}
.win-side{flex:0 0 auto;display:flex;flex-direction:column;align-items:flex-end;gap:6px}
.win-when{font-family:'JetBrains Mono';font-size:9.5px;font-weight:600;letter-spacing:.3px;text-transform:uppercase;color:var(--t3);white-space:nowrap}
.win-claim{background:rgba(251,191,36,.14);border:1px solid rgba(251,191,36,.4);color:var(--gd,#fbbf24);font-family:Inter;font-size:11px;font-weight:700;letter-spacing:.2px;border-radius:8px;padding:5px 11px;cursor:pointer;transition:all .15s;white-space:nowrap}
.win-claim:hover{background:rgba(251,191,36,.24)}
.win-claim:active{transform:translateY(1px)}
.win-claim.is-claimed{background:rgba(16,185,129,.12);border-color:rgba(16,185,129,.4);color:#8ff0c9;box-shadow:none}
.task-meta-row{display:flex;gap:6px;flex-wrap:wrap;margin-bottom:14px;font-size:11px;color:var(--t3);align-items:center}
.task-meta-row .pri-badge{padding:3px 8px;border-radius:5px;font-weight:700;font-size:10px;text-transform:uppercase;letter-spacing:.4px}
.task-section{padding:10px 0;border-top:1px solid var(--b1)}
.task-section:first-of-type{border-top:none;padding-top:4px}
.task-section-label{font-size:9px;font-weight:700;text-transform:uppercase;letter-spacing:1px;color:var(--t3);margin-bottom:6px}
.task-desc{background:var(--c3);border:1px solid var(--b1);border-radius:10px;padding:12px;font-size:12px;line-height:1.6;color:var(--t2);white-space:pre-wrap;margin-bottom:6px}
.task-field{display:flex;gap:8px;align-items:center;font-size:12px;color:var(--t1)}
.task-field input[type="date"],.task-field select{background:var(--c3);border:1px solid var(--b1);border-radius:8px;padding:7px 10px;color:var(--t1);font-family:Inter;font-size:12px;font-weight:600;cursor:pointer}
.task-field input[type="date"]:focus,.task-field select:focus{outline:none;border-color:var(--b3)}
.pri-picker{display:grid;grid-template-columns:repeat(4,1fr);gap:5px;margin-top:4px}
.pri-picker button{background:var(--c3);border:1px solid var(--b1);color:var(--t2);font-family:Inter;font-size:10px;font-weight:700;padding:7px 4px;border-radius:8px;cursor:pointer;text-transform:uppercase;letter-spacing:.4px;transition:all .15s}
.pri-picker button:hover{border-color:var(--b2);color:var(--t1)}
.pri-picker button.on.p1{background:rgba(239,68,68,.15);color:var(--rd);border-color:var(--rd)}
.pri-picker button.on.p2{background:rgba(251,191,36,.15);color:var(--gd);border-color:var(--gd)}
.pri-picker button.on.p3{background:rgba(59,130,246,.15);color:var(--bl);border-color:var(--bl)}
.pri-picker button.on.p4{background:var(--c4);color:var(--t2);border-color:var(--b2)}
.task-labels{display:flex;flex-wrap:wrap;gap:5px}
.task-label-chip{background:rgba(59,130,246,.1);color:var(--bl);padding:3px 9px;border-radius:5px;font-size:10px;font-weight:700}
/* v2.17.48: hide Weekly Pulse + Concentration Risk per user request — clutter. */
#aiPulseCard,#concRisk{display:none!important}
/* v2.17.49: hide separate Mercury Cash Flow card — merged into Money Today/Cash Flow. */
#mercuryCashFlowCard{display:none!important}
/* v2.17.50: hide redundant Commissions MTD card — duplicates One-time/Rev Share card next to expenses. */
#commissionsCard{display:none!important}
/* v2.17.51: retire card-minimize feature per user — clutter > utility. */
.hc-card-min-btn,#hcHiddenBar{display:none!important}
/* v2.17.51: hide uncategorized-expense warning — clicking did nothing useful. */
#rpUncatWarn{display:none!important}
/* v2.17.52: expense MRE rows — clean read-only look by default, full input on focus.
   Boosted selector specificity to override the earlier #t-ex rules at lines ~2022-2031 */
#t-ex .ex-mre-row input[type="text"]{background:transparent!important;border:1px solid transparent!important;border-radius:6px!important;padding:5px 7px!important;color:var(--t1)!important;font-weight:600!important;transition:all .15s}
#t-ex .ex-mre-row input[type="number"]{background:transparent!important;border:1px solid transparent!important;border-radius:6px!important;padding:5px 7px!important;width:88px!important;color:var(--t1)!important;font-family:'JetBrains Mono';text-align:right;font-weight:700;transition:all .15s}
#t-ex .ex-mre-row input[type="text"]:hover,#t-ex .ex-mre-row input[type="number"]:hover{background:rgba(255,255,255,.03)!important;border-color:var(--b1)!important}
#t-ex .ex-mre-row input[type="text"]:focus,#t-ex .ex-mre-row input[type="number"]:focus{background:var(--c3)!important;border-color:var(--bl)!important;outline:none}
#t-ex .ex-mre-row select{background:transparent!important;border:1px solid transparent!important;color:var(--t3)!important;transition:all .15s}
#t-ex .ex-mre-row select:hover,#t-ex .ex-mre-row select:focus{background:var(--c3)!important;border-color:var(--b1)!important;color:var(--t1)!important}
/* v2.17.52: hide Today tab's duplicate to-do section — the Overview #todoCard is the keeper. */
#tdTodoSec,#tdTodoList{display:none!important}
/* v2.17.52: Tasks tab vertical filter sidebar — SaaS-style with checkboxes. */
.tk-layout{display:flex;gap:14px;align-items:flex-start;margin-top:10px}
@media (max-width:899px){.tk-layout{flex-direction:column}}
.tk-sidebar{flex:0 0 230px;background:var(--c2);border:1px solid var(--b1);border-radius:12px;padding:14px;position:sticky;top:14px;max-height:calc(100vh - 40px);overflow-y:auto;scrollbar-width:thin}
@media (max-width:899px){.tk-sidebar{flex:none;width:auto;max-height:none;position:static}}
.tk-sidebar::-webkit-scrollbar{width:4px}
.tk-sidebar::-webkit-scrollbar-thumb{background:var(--b2);border-radius:2px}
.tk-sidebar h4{font-size:9px;color:var(--t3);text-transform:uppercase;letter-spacing:.7px;font-weight:800;margin:14px 0 8px;letter-spacing:.6px}
.tk-sidebar h4:first-child{margin-top:0}
.tk-sb-search{width:100%;background:var(--c3);border:1px solid var(--b1);border-radius:8px;padding:7px 10px;color:var(--t1);font-family:Inter;font-size:12px;outline:none;margin-bottom:8px}

/* v2.18.0: Projects page — view toggles, advanced filters, scroll arrows. */
#t-prj{overflow-x:hidden}
.prj-view-bar{display:inline-flex;gap:3px;background:var(--c2);border:1px solid var(--b1);border-radius:10px;padding:3px}
.prj-view-btn{background:transparent;border:none;border-radius:7px;padding:5px 13px;font-size:11px;font-weight:700;color:var(--t3);cursor:pointer;transition:all .15s;white-space:nowrap}
.prj-view-btn.on{background:var(--c3);color:var(--t1);box-shadow:0 1px 4px rgba(0,0,0,.25)}
.prj-metrics-strip{display:flex;gap:18px;padding:6px 14px;background:var(--c2);border:1px solid var(--b1);border-radius:10px}
.prj-metric-s{text-align:center}.prj-metric-s .lbl{font-size:9px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:var(--t4)}
.prj-metric-s .val{font-size:15px;font-weight:900;color:var(--t1);font-family:'JetBrains Mono';line-height:1.3}
.prj-filter-row{display:flex;align-items:center;gap:5px;flex-wrap:wrap;margin-bottom:10px;padding:6px 10px;background:var(--c2);border:1px solid var(--b1);border-radius:10px}
.prj-flabel{font-size:9px;font-weight:800;text-transform:uppercase;letter-spacing:.5px;color:var(--t4)}
.prj-fdivider{width:1px;height:16px;background:var(--b1);margin:0 4px}
.prj-fchip{background:transparent;border:1px solid var(--b1);border-radius:999px;padding:3px 9px;font-size:10px;font-weight:700;color:var(--t3);cursor:pointer;transition:all .12s;font-family:Inter}
.prj-fchip.on{background:var(--c3);border-color:var(--b2);color:var(--t1)}
.prj-board-wrap{display:block}
/* v2.23.4: horizontal scrollbar lifted to the TOP of the board (synced via _prjSyncTopScroll) */
.prj-topscroll{overflow-x:auto;overflow-y:hidden;height:10px;margin-bottom:3px;display:none}
.prj-topscroll::-webkit-scrollbar{height:8px}
.prj-topscroll::-webkit-scrollbar-thumb{background:var(--b2);border-radius:999px}
.prj-topscroll::-webkit-scrollbar-track{background:transparent}
#prjTopScrollInner{height:1px}
.prj-scroll-btn{flex-shrink:0;width:26px;min-height:140px;border:1px solid var(--b1);background:var(--c2);color:var(--t3);border-radius:10px;cursor:pointer;font-size:18px;font-weight:900;display:flex;align-items:center;justify-content:center;transition:all .15s;align-self:stretch;padding:0}
.prj-scroll-btn:hover{background:var(--c3);color:var(--t1);border-color:var(--b2)}
.prj-hero{display:grid;grid-template-columns:1.2fr .8fr;gap:12px;margin-bottom:12px}
@media (max-width:899px){.prj-hero{grid-template-columns:1fr}}
.prj-panel{background:var(--c2);border:1px solid var(--b1);border-radius:12px;padding:14px 16px;overflow:hidden}
.prj-title{font-size:18px;font-weight:850;letter-spacing:-.45px;color:var(--t1);margin-bottom:5px}
.prj-sub{font-size:12px;color:var(--t3);line-height:1.45;max-width:760px}
.prj-metrics{display:grid;grid-template-columns:repeat(3,1fr);gap:8px}
@media (max-width:520px){.prj-metrics{grid-template-columns:1fr 1fr}}
.prj-metric{background:var(--c2);border:1px solid var(--b1);border-radius:12px;padding:10px 12px;min-height:62px}
.prj-metric .lbl{font-size:9px;color:var(--t4);font-weight:800;text-transform:uppercase;letter-spacing:.7px;margin-bottom:4px}
.prj-metric .val{font-family:'JetBrains Mono';font-size:19px;font-weight:850;color:var(--t1);font-variant-numeric:tabular-nums}
.prj-controls{display:flex;gap:8px;align-items:center;flex-wrap:wrap;margin-bottom:12px}
.prj-controls .search-input{min-width:220px;flex:1 1 260px}
.prj-select{background:var(--c2);border:1px solid var(--b1);border-radius:10px;padding:10px 12px;color:var(--t1);font-family:Inter;font-size:11px;font-weight:650;min-height:38px}
.prj-client-pills{display:flex;gap:8px;overflow-x:auto;scrollbar-width:none;padding:2px 0 10px;margin-bottom:6px}
.prj-client-pills::-webkit-scrollbar{display:none}
.prj-pill{flex-shrink:0;display:inline-flex;align-items:center;gap:7px;border:1px solid var(--b1);background:var(--c2);color:var(--t2);border-radius:999px;padding:8px 11px;font-family:Inter;font-size:11px;font-weight:750;cursor:pointer;white-space:nowrap;min-height:38px}
.prj-pill.on{background:rgba(96,165,250,.18);border-color:rgba(96,165,250,.42);color:var(--bl)}
.prj-pill .ct{font-family:'JetBrains Mono';font-size:10px;background:rgba(255,255,255,.08);color:var(--t3);border-radius:999px;padding:1px 7px}
.prj-board{display:flex;gap:32px;align-items:flex-start;overflow-x:auto;flex:1;min-width:0;padding:2px 4px 10px;-webkit-overflow-scrolling:touch;overscroll-behavior-inline:contain}
.prj-board{scrollbar-width:none}
.prj-board::-webkit-scrollbar{display:none}
.prj-lane{flex:0 0 280px;max-width:280px;min-height:180px;background:var(--c2);border:1px solid var(--b1);border-radius:12px;padding:14px;box-shadow:0 12px 32px rgba(0,0,0,.12)}
@media (max-width:520px){.prj-lane{flex-basis:84vw;max-width:84vw}}
/* v2.23.3: graduated risk accent (left bar) + drag-to-reorder states. Replaces the old
   all-or-nothing red .prj-lane.hot so lanes read calm→green, low→gold, med→orange, high→red. */
.prj-lane{cursor:grab}
.prj-lane:active{cursor:grabbing}
.prj-lane[data-risk="calm"]{box-shadow:inset 4px 0 0 var(--gn),0 12px 32px rgba(0,0,0,.12)}
.prj-lane[data-risk="low"]{box-shadow:inset 4px 0 0 var(--gd),0 12px 32px rgba(0,0,0,.12)}
.prj-lane[data-risk="med"]{box-shadow:inset 4px 0 0 var(--or),0 12px 32px rgba(0,0,0,.12)}
.prj-lane[data-risk="high"]{box-shadow:inset 4px 0 0 var(--rd),0 12px 32px rgba(0,0,0,.12);border-color:rgba(239,68,68,.45);background:var(--c2)}
.prj-lane.prj-dragging{opacity:.4}
.prj-lane.prj-drop-target{outline:2px dashed var(--bl);outline-offset:2px}
.prj-lane-head{display:flex;justify-content:space-between;gap:8px;align-items:flex-start;padding:2px 2px 10px;border-bottom:1px solid var(--b1);margin-bottom:9px}
.prj-lane-avatar{width:34px;height:34px;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:900;color:#fff;flex-shrink:0;letter-spacing:0}
.prj-lane-info{min-width:0;flex:1}
.prj-lane-name{font-size:14px;font-weight:850;color:var(--t1);line-height:1.22;letter-spacing:-.3px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.prj-lane-meta{display:flex;gap:5px;align-items:center;flex-wrap:wrap;margin-top:5px}
.prj-heat-bar{height:3px;border-radius:3px;background:rgba(255,255,255,.06);overflow:hidden;margin-top:7px}
.prj-heat-bar-fill{height:100%;border-radius:3px;transition:width .4s ease}
.prj-chip{display:inline-flex;align-items:center;gap:4px;border-radius:999px;padding:2px 7px;font-size:9px;font-weight:800;text-transform:uppercase;letter-spacing:.35px;border:1px solid var(--b1);background:var(--c3);color:var(--t3);font-family:Inter}
.prj-chip.red{color:var(--rd);border-color:rgba(239,68,68,.38);background:rgba(239,68,68,.12)}
.prj-chip.gold{color:var(--gd);border-color:rgba(251,191,36,.32);background:rgba(251,191,36,.09)}
.prj-chip.blue{color:var(--bl);border-color:rgba(96,165,250,.32);background:rgba(96,165,250,.10)}
.prj-lane-actions{display:flex;gap:5px;flex-shrink:0}.prj-icon-btn{width:32px;height:32px;min-height:32px;border-radius:9px;border:1px solid var(--b1);background:var(--c3);color:var(--t2);cursor:pointer;font-weight:850;font-size:13px;display:flex;align-items:center;justify-content:center}
.prj-icon-btn:hover{border-color:var(--b2);color:var(--t1);background:var(--c4)}
.prj-task{background:var(--c1);border:1px solid var(--b1);border-radius:11px;padding:10px 10px 9px;margin-bottom:7px;cursor:pointer;transition:transform .15s,border-color .15s,box-shadow .15s;display:flex;gap:10px;align-items:flex-start;position:relative;overflow:hidden}
.prj-task:hover{transform:translateY(-1px);border-color:var(--b2);box-shadow:0 6px 20px rgba(0,0,0,.2)}
.prj-task.p1{border-left:3px solid var(--rd)}
.prj-task.p2{border-left:3px solid var(--gd)}
.prj-task.p3{border-left:3px solid var(--bl)}
.prj-task.overdue{background:var(--c1)}
.prj-task.p1.overdue{background:var(--c1)}
.prj-check{width:17px;height:17px;border-radius:50%;border:1.5px solid var(--b2);flex-shrink:0;margin-top:2px;cursor:pointer;transition:border-color .15s,background .15s}.prj-task.p1 .prj-check{border-color:rgba(239,68,68,.6)}.prj-check:hover{border-color:var(--gn);background:rgba(16,185,129,.1)}
.prj-task-body{min-width:0;flex:1}.prj-task-title{font-size:13px;font-weight:700;color:var(--t1);line-height:1.36;margin-bottom:5px;word-break:break-word}
.prj-task-meta{display:flex;gap:5px;flex-wrap:wrap;align-items:center}.prj-empty{padding:20px 10px;text-align:center;color:var(--t4);font-size:12px;line-height:1.5;border:1px dashed var(--b1);border-radius:12px;background:rgba(255,255,255,.02)}
.prj-lane-foot{padding:7px 2px 1px;display:flex;gap:6px;align-items:center;justify-content:space-between;color:var(--t4);font-size:10px}
.tk-sb-search:focus{border-color:var(--bl)}
.tk-sb-opt{display:flex;align-items:center;gap:8px;padding:5px 7px;border-radius:6px;cursor:pointer;font-size:12px;color:var(--t2);transition:background .12s;-webkit-tap-highlight-color:transparent}
.tk-sb-opt:hover{background:rgba(255,255,255,.03)}
.tk-sb-opt input[type="checkbox"]{width:14px;height:14px;cursor:pointer;accent-color:var(--bl);flex-shrink:0}
.tk-sb-opt .lbl{flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.tk-sb-opt .ct{font-family:JetBrains Mono;font-size:10px;color:var(--t4);font-weight:600;flex-shrink:0}
.tk-sb-opt.active .lbl{color:var(--t1);font-weight:700}
.tk-sb-opt.active{background:rgba(96,165,250,.10)}
.tk-sb-pri-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}
.tk-sb-actions{margin-top:14px;padding-top:14px;border-top:1px solid var(--b1);display:flex;gap:6px;align-items:center;flex-wrap:wrap}
.tk-sb-clear{flex:1;background:transparent;border:1px solid var(--b1);color:var(--t3);font-family:Inter;font-size:11px;font-weight:600;padding:6px 10px;border-radius:7px;cursor:pointer;transition:all .15s}
.tk-sb-clear:hover{background:rgba(239,68,68,.10);border-color:rgba(239,68,68,.3);color:var(--rd)}
.tk-sb-count{font-size:10px;color:var(--bl);font-weight:700}
.tk-active-chips{display:flex;gap:6px;flex-wrap:wrap;margin-bottom:10px}
.tk-active-chip{display:inline-flex;align-items:center;gap:5px;background:rgba(96,165,250,.10);border:1px solid rgba(96,165,250,.28);color:var(--bl);font-size:10px;font-weight:700;padding:3px 8px;border-radius:999px}
.tk-active-chip button{background:transparent;border:none;color:var(--bl);cursor:pointer;font-size:14px;line-height:1;padding:0 0 0 3px}
.tk-list-col{flex:1;min-width:0}
/* v2.17.49: month-view calendar cells consistent height — empty days don't shrink */
.cal-mday{min-height:118px!important;max-height:140px;overflow:hidden;display:flex;flex-direction:column}
.cal-mday .cal-mday-evt{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
/* v2.17.48: MRE row clean UI — inputs look like plain text by default, reveal box on focus. */
.ex-mre-row input[type="text"],.ex-mre-row input[type="number"]{background:transparent;border:1px solid transparent;border-radius:6px;padding:5px 7px;color:var(--t1);transition:all .15s}
.ex-mre-row input[type="text"]:hover,.ex-mre-row input[type="number"]:hover{background:rgba(255,255,255,.02);border-color:var(--b1)}
.ex-mre-row input[type="text"]:focus,.ex-mre-row input[type="number"]:focus{background:var(--c3);border-color:var(--bl);outline:none}
.ex-mre-row select{background:transparent!important;border:1px solid transparent!important;color:var(--t3);transition:all .15s}
.ex-mre-row select:hover,.ex-mre-row select:focus{background:var(--c3)!important;border-color:var(--b1)!important;color:var(--t1)}
.ex-mre-row .split-btn{opacity:.4;transition:opacity .15s}
.ex-mre-row:hover .split-btn{opacity:1}
.ex-mre-row .ex-row-x{opacity:.3;transition:opacity .15s}
.ex-mre-row:hover .ex-row-x{opacity:1}
/* v2.17.48: card minimize button — small chip top-right, hover-revealed, click to hide */
.hc-card-min-btn{position:absolute;top:8px;right:8px;width:22px;height:22px;border-radius:50%;background:rgba(255,255,255,.04);border:1px solid var(--b1);color:var(--t4);font-size:14px;line-height:1;cursor:pointer;display:none;align-items:center;justify-content:center;font-weight:700;z-index:5;transition:all .15s;padding:0}
.card[data-card]:hover .hc-card-min-btn{display:inline-flex}
.hc-card-min-btn:hover{background:rgba(239,68,68,.12);border-color:rgba(239,68,68,.3);color:var(--rd)}
.task-actions{display:flex;gap:8px;margin-top:18px;padding-top:14px;border-top:1px solid var(--b1)}
.task-btn{flex:1;padding:11px 14px;border-radius:10px;font-family:Inter;font-size:12px;font-weight:700;cursor:pointer;border:1px solid var(--b1);background:var(--c3);color:var(--t1);transition:all .15s;letter-spacing:.3px}
.task-btn:hover{border-color:var(--b2);transform:translateY(-1px)}
.task-btn.primary{background:rgba(16,185,129,.15);color:var(--gn);border-color:rgba(16,185,129,.3)}
.task-btn.primary:hover{background:rgba(16,185,129,.25)}
.task-btn.ghost{flex:0 0 auto;color:var(--t3);background:transparent;border-color:transparent}

/* VERSION BADGE + CHANGELOG */
.ver-badge{display:none;position:fixed;bottom:20px;left:20px;background:var(--c2);border:1px solid var(--b1);color:var(--t3);font-family:'JetBrains Mono';font-size:10px;font-weight:700;padding:5px 10px;border-radius:20px;cursor:pointer;z-index:50;opacity:.7;transition:all .2s;backdrop-filter:blur(8px)}
@media (min-width:900px){.ver-badge{display:none!important}} /* desktop uses sidebar button instead */
.ver-badge:hover{opacity:1;color:var(--t1);border-color:var(--b2);transform:translateY(-1px)}
.ver-badge .dot-new{display:inline-block;width:6px;height:6px;background:var(--gn);border-radius:50%;margin-right:5px;box-shadow:0 0 8px rgba(16,185,129,.6);animation:pulse 2s infinite}
@media(max-width:700px){.ver-badge{bottom:auto;top:12px;left:12px;font-size:9px;padding:3px 8px}}

.changelog-overlay{position:fixed;inset:0;background:rgba(0,0,0,.75);backdrop-filter:blur(16px);z-index:300;display:none;align-items:flex-start;justify-content:center;padding:40px 20px;overflow-y:auto}
.changelog-overlay.show{display:flex;animation:lockFade .2s ease-out}
.changelog-panel{max-width:620px;width:100%;background:var(--c1);border:1px solid var(--b2);border-radius:16px;padding:28px;box-shadow:0 20px 60px rgba(0,0,0,.5)}
.changelog-head{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:18px;padding-bottom:16px;border-bottom:1px solid var(--b1)}
.changelog-head h2{font-size:22px;font-weight:800;letter-spacing:-.4px;margin-bottom:3px}
.changelog-ver{font-family:'JetBrains Mono';font-size:12px;color:var(--pp);font-weight:700;margin-top:2px}
.cl-release{padding:0;border-bottom:1px solid var(--b1);overflow:hidden}
.cl-release:last-child{border-bottom:none}
.cl-release-head{display:flex;justify-content:space-between;align-items:center;padding:12px 4px;cursor:pointer;user-select:none}
.cl-release-head:hover{color:var(--t1)}
.cl-release-chev{font-size:10px;color:var(--t4);transition:transform .2s;margin-right:6px}
.cl-release.open .cl-release-chev{transform:rotate(90deg)}
.cl-release-body{max-height:0;overflow:hidden;transition:max-height .3s ease-out}
.cl-release.open .cl-release-body{max-height:1200px}
.cl-release-body ul{padding:0 4px 12px}
.cl-release-ver{font-family:'JetBrains Mono';font-size:11px;font-weight:700;color:var(--t1)}
.cl-release-ver .tag{background:rgba(16,185,129,.12);color:var(--gn);padding:1px 7px;border-radius:5px;font-size:9px;margin-left:6px;text-transform:uppercase;letter-spacing:.4px;font-weight:700;border:1px solid rgba(16,185,129,.2)}
.cl-release-date{font-size:10px;color:var(--t4);font-family:'JetBrains Mono'}
.cl-release ul{list-style:none;padding:0;margin:6px 0 0}
.cl-release li{font-size:12px;color:var(--t2);padding:3px 0 3px 16px;line-height:1.55;position:relative}
.cl-release li::before{content:'';position:absolute;left:0;color:var(--bl);font-weight:700}
.cl-release li.fix::before{content:'';font-size:10px}
.cl-release li.add::before{content:'';font-size:11px}
.whats-next{background:var(--c2);border:1px solid var(--b1);border-radius:12px;padding:14px;margin-top:18px}
.whats-next h3{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:1.2px;color:var(--pp);margin-bottom:10px;display:flex;align-items:center;gap:5px}
.whats-next ul{list-style:none;padding:0}
.whats-next li{font-size:11px;color:var(--t2);padding:3px 0 3px 14px;line-height:1.55;position:relative}
.whats-next li::before{content:'';position:absolute;left:0;color:var(--pp);font-size:10px}
.whats-next li.priority::before{content:'';color:var(--pk)}

/* MANUAL CLIENT STYLING */
.client.client-manual{border-style:dashed!important;opacity:.95}
.client.client-manual::before{background:var(--bl)!important;opacity:.6}

/* P&L DESKTOP LAYOUT (full width, matches Overview) */
@media (min-width:900px){
 #t-rp{max-width:none;width:100%}
 #t-rp .pl-totals{grid-template-columns:repeat(3,1fr);gap:14px;margin-bottom:18px}
 #t-rp .pl-total{padding:22px}
 #t-rp .pl-total .val{font-size:24px}
 #t-rp #plList{display:grid;grid-template-columns:repeat(2,1fr);gap:12px}
 #t-rp #plList .pl-row{margin-bottom:0}
 #t-rp .pl-controls{display:flex;gap:10px;align-items:center}
 #t-rp .pl-controls select{max-width:280px}
}
@media (min-width:1200px){
 #t-rp #plList{grid-template-columns:repeat(3,1fr)}
}

/* MOBILE BREATHING ROOM */
@media (max-width:700px){
 .app{padding:0 18px 110px}
 .hdr{padding-top:calc(env(safe-area-inset-top,20px) + 8px);padding-bottom:12px;margin-bottom:16px}
 .greet{font-size:20px;margin-top:10px;line-height:1.2;font-weight:800}
 .tagline{display:none!important}
 .meta{margin-top:4px;font-size:10px;opacity:.7}
 .hdr-row{display:flex;align-items:center;justify-content:space-between;gap:8px}
 .hdr-row .logo{display:flex;align-items:center;gap:8px;min-width:0;flex:1}
 .hdr-row>.logo .logo-text{display:block;font-size:12px;font-weight:800;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
 .hdr-row>div:last-child{flex-shrink:0;display:flex;align-items:center;gap:6px}
 .logo-mark{width:32px;height:32px;font-size:12px;border-radius:8px;flex-shrink:0}
 .hdr-live{display:inline-flex!important;padding:3px 8px 3px 6px!important;font-size:9px!important;flex-shrink:0}
 .hdr-live .dot{width:5px;height:5px}
 .view-toggle-row .view-toggle{width:100%}
 .view-toggle-row .view-toggle button{flex:1;text-align:center;padding:8px;font-size:11px}
 /* v2.17.50: bump mobile tap targets to 44px to meet iOS/Android touch standards */
 .notif-bell{width:44px;height:44px;min-width:44px;min-height:44px}
 .notif-bell svg{width:16px;height:16px}
 .kpi-grid{gap:12px;margin-bottom:14px}
 .kpi{padding:14px}
 .kpi-val{font-size:22px}
 .card{padding:16px;margin-bottom:14px}
 .card-sm{padding:14px}
 .sec{margin:26px 0 12px}
 .bal-grid,.amex-bal-row{gap:10px;margin-bottom:14px}
 .sub-row,.prospect-card{margin-bottom:10px}
 .runway{padding:4px 0}
 /* Don't let header wrap awkwardly */
 .logo{gap:8px;min-width:0;flex:1;overflow:hidden}
 .logo-text{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
}

/* TAGLINE */
.tagline{font-size:10px;color:var(--t3);margin-top:4px;font-weight:600;letter-spacing:.4px;text-transform:uppercase;opacity:.9;display:flex;flex-wrap:wrap;align-items:center;gap:5px}
.tagline b{color:var(--t2);font-weight:700}
.tagline .tsep{display:inline-block;width:3px;height:3px;background:var(--bl);border-radius:50%;opacity:.6}
:root[data-view="personal"] .tagline .tsep{background:var(--pp)}

/* VIEW TOGGLE (Business / Personal) */
.view-toggle{display:flex;background:var(--c1);border:1px solid var(--b1);border-radius:18px;padding:3px;gap:2px;flex-shrink:0}
.view-toggle button{background:transparent;border:none;color:var(--t3);padding:5px 9px;border-radius:14px;cursor:pointer;font-family:Inter;font-size:9px;font-weight:700;letter-spacing:.5px;text-transform:uppercase;transition:all .2s;white-space:nowrap}
.view-toggle button.on{background:var(--bl);color:#fff}
:root[data-view="personal"] .view-toggle button.on{background:var(--pp)}
/* Mobile view toggle row (below greeting) */
.view-toggle-row{display:none}
@media(max-width:700px){.view-toggle-row{display:flex}.hdr-toggle{display:none!important}}

/* Biz / Personal visibility switches */
:root[data-view="personal"] .biz-only{display:none!important}
:root:not([data-view="personal"]) .pers-only{display:none!important}
/* Hard-hide anything a stray biz element might leave on screen in personal */
:root[data-view="personal"] .col-side,:root[data-view="personal"] .notif-pane,:root[data-view="personal"] #amexArea,:root[data-view="personal"] #pendingModal,:root[data-view="personal"] #exTabs,:root[data-view="personal"] #plList{display:none!important}
/* v2.16.22: hide page-header "Updated [time]" on desktop — moved under Biz/Personal toggle in hdr-row */
@media(min-width:900px){#meta{display:none}}
/* mobile: hide the desktop hdrUpdated since the hdr-toggle is hidden on mobile */
@media(max-width:899px){#hdrUpdated{display:none}}
/* v2.16.22: Connection status rows in sidebar */
.cn-row{display:flex;align-items:center;gap:6px;font-size:10px;color:var(--t3);font-weight:600}
.cn-row .cn-dot{width:6px;height:6px;border-radius:50%;background:var(--t4);flex-shrink:0;transition:background .3s}
.cn-row .cn-dot.ok{background:var(--gn);box-shadow:0 0 4px rgba(16,185,129,.5)}
.cn-row .cn-dot.warn{background:var(--gd);box-shadow:0 0 4px rgba(251,191,36,.5)}
.cn-row .cn-dot.err{background:var(--rd);box-shadow:0 0 4px rgba(239,68,68,.5)}
.cn-row .cn-dot.off{background:var(--t4)}
.cn-row .cn-name{flex:1;color:var(--t2)}
.cn-row .cn-meta{font-family:'JetBrains Mono';font-size:9px;color:var(--t4);font-weight:500}

/* v2.16.20: personal mode now mirrors biz layout — keeps desktop sidebar (220px) + content column.
   Was previously collapsed to single-column / max-width 900px which made the page feel cramped and out-of-step with biz.
   Biz/pers nav buttons hide via .biz-only / .pers-only inside the sidebar. */

/* Personal accent skin (reuses structure, just re-tints key elements) */
:root[data-view="personal"] .logo-mark{background:var(--pp)!important;box-shadow:none!important}
:root[data-view="personal"] .greet em{background-image:none;-webkit-text-fill-color:currentColor;color:var(--t1)}
:root[data-view="personal"] .nav-btn.on{color:var(--pp)}
:root[data-view="personal"] .nav-btn.on .icon{filter:none}
:root[data-view="personal"] .kpi.kpi-bl::after{background:var(--pp)!important}
:root[data-view="personal"] .kpi.kpi-bl .kpi-val{color:var(--pp)!important}
:root[data-view="personal"] .kpi.kpi-gd .kpi-val{color:var(--gd)}
:root[data-view="personal"] .status{background:rgba(168,85,247,.08);border-color:rgba(168,85,247,.15);color:var(--pp)}
:root[data-view="personal"] .status .dot{background:var(--pp)}

/* TAX SAVINGS CARD */
.tax-card{background:var(--c2)!important;border:1px solid var(--b1)!important;border-left:3px solid var(--gd)!important;padding:14px}
.tax-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}
.tax-label{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:1.2px;color:var(--gd)}
.tax-val{font-family:'JetBrains Mono';font-size:20px;font-weight:800;color:var(--gd);letter-spacing:-.5px}
.tax-desc{font-size:11px;color:var(--t2);line-height:1.5;font-weight:500}
.tax-desc b{color:var(--t1);font-weight:700}

/* REVENUE DISCREPANCY BANNER */
.discrep-banner{background:var(--c2);border:1px solid var(--b1);border-left:3px solid var(--rd);border-radius:12px;padding:12px;margin-bottom:10px;display:flex;gap:10px;align-items:flex-start}
.discrep-banner .ic{font-size:18px;flex-shrink:0}
.discrep-banner .body{flex:1;min-width:0}
.discrep-banner .title{font-size:12px;font-weight:700;color:var(--rd);margin-bottom:3px}
.discrep-banner .msg{font-size:11px;color:var(--t2);line-height:1.5}

/* LATE PAYER TINT */
.client.client-late{border-left:3px solid var(--or)!important}
.late-chip{background:rgba(249,115,22,.12);color:var(--or);border:1px solid rgba(249,115,22,.22);padding:1px 6px;border-radius:5px;font-size:8px;font-weight:700;text-transform:uppercase;letter-spacing:.4px;margin-left:6px;display:inline-block;vertical-align:1px}

/* KEYBOARD SHORTCUT OVERLAY */
.kbd-overlay{position:fixed;inset:0;background:rgba(0,0,0,.75);backdrop-filter:blur(16px);z-index:300;display:none;align-items:center;justify-content:center;padding:24px;animation:lockFade .15s ease-out}
.kbd-overlay.show{display:flex}
.kbd-panel{background:var(--c2);border:1px solid var(--b2);border-radius:16px;padding:24px;max-width:480px;width:100%;box-shadow:0 20px 60px rgba(0,0,0,.5)}
.kbd-panel h2{font-size:18px;margin-bottom:14px;letter-spacing:-.3px}
.kbd-row{display:flex;justify-content:space-between;align-items:center;padding:7px 0;border-bottom:1px solid var(--b1);font-size:12px}
.kbd-row:last-child{border-bottom:none}
.kbd-row .desc{color:var(--t2)}
.kbd-key{background:var(--c3);border:1px solid var(--b2);border-radius:5px;padding:2px 8px;font-family:'JetBrains Mono';font-size:11px;font-weight:700;color:var(--t1);margin-left:6px}

/* RUNWAY STRESS TEST */
.stress-chip{font-size:9px;color:var(--t3);background:var(--c3);border:1px solid var(--b1);padding:3px 7px;border-radius:5px;cursor:pointer;margin-left:6px;font-weight:600}
.stress-chip:hover{color:var(--or);border-color:rgba(249,115,22,.3)}
.stress-banner{background:var(--c2);border:1px solid var(--b1);border-left:3px solid var(--or);border-radius:8px;padding:10px;margin-top:8px;font-size:11px;color:var(--t2);line-height:1.5;display:none}
.stress-banner.show{display:block}
.stress-banner b{color:var(--or);font-weight:700}

/* CLIENT PAGE (expanded focus view) */
.focus-overlay{position:fixed;inset:0;background:var(--bg);z-index:250;overflow-y:auto;opacity:0;transform:translateY(12px) scale(.99);pointer-events:none;visibility:hidden;transition:opacity .3s ease-out,transform .3s ease-out,visibility 0s linear .3s}
.focus-overlay.show{opacity:1;transform:translateY(0) scale(1);pointer-events:auto;visibility:visible;transition:opacity .3s ease-out,transform .3s ease-out,visibility 0s linear 0s}
.focus-panel{max-width:860px;margin:0 auto;padding:20px 20px 60px}
@media (max-width:700px){.focus-panel{padding:16px 16px 80px}}
.focus-header{display:flex;justify-content:space-between;align-items:flex-start;gap:12px;padding:12px 0 20px;position:sticky;top:0;background:var(--bg);backdrop-filter:blur(8px);z-index:5}
.focus-back{background:var(--c2);border:1px solid var(--b1);border-radius:10px;padding:8px 14px;cursor:pointer;color:var(--t2);font-size:12px;font-weight:600;display:flex;align-items:center;gap:6px}
.focus-back:hover{color:var(--t1);border-color:var(--b2)}
.focus-title-row{flex:1;min-width:0}
.focus-title{font-size:24px;font-weight:800;letter-spacing:-.4px;color:var(--t1);margin-bottom:4px;line-height:1.2}
.focus-subtitle{font-size:12px;color:var(--t3);line-height:1.4}
.focus-actions-top{display:flex;gap:6px;flex-shrink:0}
.focus-icon-btn{background:var(--c2);border:1px solid var(--b1);border-radius:10px;width:38px;height:38px;display:flex;align-items:center;justify-content:center;cursor:pointer;color:var(--t2);font-size:16px}
.focus-icon-btn:hover{color:var(--t1);border-color:var(--b2)}
.focus-hero{background:var(--c2);border:1px solid var(--b1);border-radius:12px;padding:18px;margin-bottom:14px;position:relative;overflow:hidden}
.focus-hero::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:var(--bl)}
.focus-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:10px;margin-bottom:14px}
@media(max-width:700px){.focus-grid{grid-template-columns:1fr 1fr;gap:8px}}
.focus-stat{background:var(--c2);border:1px solid var(--b1);border-radius:12px;padding:14px}
.focus-stat-label{font-size:9px;font-weight:700;text-transform:uppercase;letter-spacing:1px;color:var(--t3);margin-bottom:4px}
.focus-stat-val{font-family:'JetBrains Mono';font-size:18px;font-weight:700;color:var(--t1);letter-spacing:-.3px}
.focus-stat-sub{font-size:9px;color:var(--t4);margin-top:3px;font-weight:500}
.focus-section{margin-top:18px;background:var(--c2);border:1px solid var(--b1);border-radius:12px;padding:14px}
.focus-section h4{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:1.2px;color:var(--t3);margin-bottom:10px;display:flex;justify-content:space-between;align-items:center}
.focus-section h4 .total{color:var(--t2);font-family:'JetBrains Mono';font-size:12px;font-weight:700}

/* Client bar chart (6-mo revenue trend) */
.mini-bars{display:flex;align-items:flex-end;gap:4px;height:50px;margin-bottom:8px}
.mini-bar{flex:1;background:var(--bl);border-radius:3px 3px 0 0;position:relative;min-height:2px;cursor:help}
.mini-bar.current{background:var(--gn)}
.mini-bar-labels{display:flex;gap:4px;font-size:9px;color:var(--t4);font-family:'JetBrains Mono'}
.mini-bar-labels span{flex:1;text-align:center}

/* Expense breakdown by category in focus mode */
.exp-cat-row{display:flex;justify-content:space-between;align-items:center;padding:7px 0;border-bottom:1px solid var(--b1);gap:10px}
.exp-cat-row:last-child{border-bottom:none}
.exp-cat-name{font-size:11px;color:var(--t2);font-weight:600}
.exp-cat-bar{flex:1;height:4px;background:var(--c3);border-radius:2px;overflow:hidden}
.exp-cat-fill{height:100%;background:var(--rd);border-radius:2px}
.exp-cat-amt{font-family:'JetBrains Mono';font-size:11px;font-weight:700;color:var(--rd);white-space:nowrap;min-width:60px;text-align:right}

/* KPI POLISH (icons + MoM arrows) */
.kpi-icon{font-size:13px;margin-right:4px;opacity:.9;vertical-align:-1px}
.kpi-label{display:flex;align-items:center;gap:4px;flex-wrap:wrap}
.kpi-mom{font-family:'JetBrains Mono';font-size:8px;font-weight:700;padding:1px 5px;border-radius:4px;letter-spacing:0;text-transform:none;white-space:nowrap;flex-shrink:0;display:inline-flex;align-items:center;line-height:1}
.kpi-mom.up{background:rgba(16,185,129,.1);color:var(--gn)}
.kpi-mom.down{background:rgba(239,68,68,.1);color:var(--rd)}
.kpi-mom.flat{background:var(--c3);color:var(--t4)}

/* CLIENT HEALTH GRADIENT GLOWS */
.client.client-bleeding{box-shadow:0 0 0 1px rgba(239,68,68,.35), inset 0 0 40px rgba(239,68,68,.04), 0 2px 20px rgba(239,68,68,.15)!important;border-color:rgba(239,68,68,.3)!important}
.client.client-bleeding::before{background:var(--rd)!important;opacity:1!important;height:2px}
.client.client-tight{box-shadow:0 0 0 1px rgba(249,115,22,.22), inset 0 0 30px rgba(249,115,22,.03)!important}
/* v2.23.7: green "excellent" glow removed per request — it was glowing on every healthy-margin
   card (which is most of them), reading as a weird green border. High margin is the default/good
   state, so it gets the plain card look now. Red/orange warning glows below stay (they're rare). */
.client.client-excellent{box-shadow:none}
/* v2.15.0: Client card two-click preview */
.client-expanded{box-shadow:0 0 0 1px var(--bl),0 8px 24px rgba(59,130,246,.12)!important}
:root[data-view="personal"] .client-expanded{box-shadow:0 0 0 1px var(--pp),0 8px 24px rgba(168,85,247,.12)!important}
.client-preview{margin-top:10px;padding-top:10px;border-top:1px solid var(--b1);animation:cpReveal .25s ease-out}
@keyframes cpReveal{from{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:translateY(0)}}
.cp-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:8px;margin-bottom:10px}
.cp-stat{text-align:center}
.cp-label{display:block;font-size:9px;color:var(--t4);text-transform:uppercase;letter-spacing:.5px;font-weight:600}
.cp-val{display:block;font-size:15px;font-weight:800;margin-top:2px}
.cp-actions{display:flex;gap:8px}
.client-preview-btn{flex:1;padding:8px;border-radius:8px;border:1px solid var(--b1);font-family:Inter;font-size:11px;font-weight:700;cursor:pointer;transition:all .15s}
.cp-view{background:var(--bl);color:#fff;border-color:var(--bl)}
.cp-view:hover{filter:brightness(1.1)}
.cp-collapse{background:transparent;color:var(--t3);border-color:var(--b2)}
.cp-collapse:hover{color:var(--t1);border-color:var(--t3)}
@media(max-width:700px){.cp-stats{grid-template-columns:repeat(2,1fr);gap:6px}.cp-val{font-size:14px}}
/* v2.15.0: Expense Insights */
.ins-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:16px}
.ins-card{background:var(--c2);border:1px solid var(--b1);border-radius:10px;padding:12px}
.ins-card-label{font-size:9px;color:var(--t4);text-transform:uppercase;letter-spacing:.5px;font-weight:600}
.ins-card-val{font-size:18px;font-weight:800;margin-top:4px}
.ins-card-sub{font-size:10px;color:var(--t4);margin-top:2px}
.ins-cat-row{display:flex;align-items:center;gap:10px;padding:8px 0;border-bottom:1px solid var(--b0)}
.ins-cat-row:last-child{border-bottom:none}
.ins-cat-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}
.ins-cat-name{flex:1;font-size:12px;font-weight:600;color:var(--t1)}
.ins-cat-bar-wrap{width:100px;height:6px;background:var(--c3);border-radius:3px;overflow:hidden;flex-shrink:0}
.ins-cat-bar-fill{height:100%;border-radius:3px;transition:width .4s ease}
.ins-cat-amt{font-size:12px;font-weight:700;min-width:60px;text-align:right}
.ins-cat-pct{font-size:10px;color:var(--t4);min-width:36px;text-align:right}
.ins-top-vendor{display:flex;justify-content:space-between;align-items:center;padding:6px 0;border-bottom:1px solid var(--b0);font-size:11px}
.ins-top-vendor:last-child{border-bottom:none}
.ins-top-vendor .v-name{font-weight:600;color:var(--t2)}
.ins-top-vendor .v-amt{font-weight:700;color:var(--rd)}
.ins-top-vendor .v-count{color:var(--t4);font-size:10px;margin-left:4px}
.ins-section{margin-bottom:16px}
.ins-section h4{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.6px;color:var(--t3);margin:0 0 8px}
.ins-empty{text-align:center;padding:20px 0;color:var(--t4);font-size:12px}
@media(max-width:700px){.ins-grid{grid-template-columns:1fr 1fr}.ins-card-val{font-size:16px}.ins-cat-bar-wrap{width:60px}}

/* FLOATING ACTION BUTTON */
.fab{position:fixed;right:20px;bottom:90px;width:56px;height:56px;border-radius:50%;background:var(--bl);border:none;color:#fff;font-size:24px;font-weight:300;cursor:pointer;display:flex;align-items:center;justify-content:center;box-shadow:0 6px 20px rgba(0,0,0,.4);z-index:60;transition:transform .15s,box-shadow .15s;line-height:1}
.fab:hover{transform:translateY(-2px) scale(1.03);box-shadow:0 8px 26px rgba(0,0,0,.5)}
.fab:active{transform:scale(.94)}
:root[data-view="personal"] .fab{background:var(--pp);box-shadow:0 6px 20px rgba(0,0,0,.4)}
@media (min-width:900px){.fab{right:40px;bottom:40px}}

/* EMPTY STATE ILLUSTRATIONS */
.empty-ill{display:flex;flex-direction:column;align-items:center;gap:10px;padding:30px 16px;color:var(--t3);text-align:center}
.empty-ill svg{opacity:.6}
.empty-ill-title{font-size:12px;font-weight:700;color:var(--t2);margin-top:4px}
.empty-ill-msg{font-size:11px;color:var(--t4);max-width:280px;line-height:1.5}

/* CLIENT SPARKLINE */
.cl-spark{display:inline-block;margin-left:8px;vertical-align:middle;opacity:.75;flex-shrink:0}
.cl-mrr-wrap{display:flex;align-items:center;gap:8px;justify-content:flex-end;flex-shrink:0;min-width:100px}

/* v2.9.0 UI POLISH */
/* Tabular-nums everywhere money renders digits align vertically across cards/tables */
.cl-mrr,.kpi-val,.bal-val,.runway-val,.goal-cur,.goal-pct,.txn-amt,.ex-amt,.sub-row-amt,.pl-row-net,.pl-total .val,.mval,.gauge-pct,.spark-val,.cl-profit-val,.cl-total-rev b,.pipe-val,#pipeVal,#pipeBreakdown span{font-variant-numeric:tabular-nums;font-feature-settings:"tnum" on,"lnum" on}
/* Sticky revenue column on client cards moved to .cl-top in primary block above to avoid duplicate-rule conflict on iOS */
.cl-top > div:first-child .cl-meta{overflow:hidden;text-overflow:ellipsis}
.cl-top > div:first-child .cl-name{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
/* Compact Total Revenue line (replaces the old block) */
.cl-total-rev{font-size:10px;color:var(--t4);font-weight:500;text-align:right;margin-top:3px;line-height:1.3;font-variant-numeric:tabular-nums}
.cl-total-rev .cl-total-rev-label{color:var(--t4);font-size:9px}
.cl-total-rev b{color:var(--gn);font-family:'JetBrains Mono';font-weight:700;font-size:11px}
.cl-total-rev-ot{font-size:9px;color:var(--t4);display:block}
/* Smaller pay-method pills */
.tag{font-size:8px;padding:2px 6px;border-radius:4px;letter-spacing:.4px}
/* Long subscription names truncate tags row should not overflow */
.tags{display:flex;flex-wrap:wrap;gap:4px;margin-top:6px;max-width:100%;overflow:hidden}
.tags .tag{max-width:160px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.cl-sub-row span:first-child{max-width:62%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;display:inline-block;vertical-align:middle}
/* Divider between active and manual-pending clients */
.client.client-manual:first-of-type{margin-top:18px;position:relative}
.client.client-manual:first-of-type::after{content:'Pending first charge';position:absolute;top:-11px;left:12px;font-size:8px;font-weight:700;color:var(--bl);background:var(--bg);padding:0 8px;text-transform:uppercase;letter-spacing:.8px;border-radius:3px;border:1px solid var(--b2)}
/* ℹ AI summary icon + popover on revenue-list card rows */
.cl-info-btn{position:absolute;top:8px;right:8px;background:rgba(96,165,250,.15);border:1px solid rgba(96,165,250,.35);color:var(--bl);border-radius:6px;width:22px;height:22px;min-height:0;font-size:12px;cursor:pointer;display:flex;align-items:center;justify-content:center;line-height:1;z-index:2;flex-shrink:0;font-family:Inter}
.cl-info-btn:hover{background:rgba(96,165,250,.28);border-color:rgba(96,165,250,.6)}
.cl-info-pop{position:fixed;width:280px;max-width:90vw;background:var(--c2);border:1px solid var(--b1);border-radius:10px;padding:12px 14px;box-shadow:0 8px 24px rgba(0,0,0,.28);z-index:9999;font-family:Inter}
.cl-info-pop-meta{font-size:9px;color:var(--t4);font-weight:600;text-transform:uppercase;letter-spacing:.6px;margin-bottom:6px}
.cl-info-pop-text{font-size:12px;color:var(--t1);line-height:1.55}
/* Mobile tap-state: cards/buttons scale briefly on press */
@media (hover:none){
 .card:active,.client:active,.nav-btn:active,.side-btn:active,.kpi:active,.ex-btn:active,.mbtn:active,.tk-card:active,.filter-chip:active{transform:scale(.985);transition:transform .08s ease-out}
 .fab:active{transform:scale(.94)}
}
/* v2.10.1 REAL PROFIT HERO + MOBILE-FIRST */
.real-profit-hero{background:var(--c2);border:1px solid var(--b1);border-left:3px solid var(--gn);padding:18px 18px 14px;position:relative;overflow:hidden;cursor:default;animation:heroEnter .5s cubic-bezier(.16,1,.3,1) both}
.real-profit-hero::before{content:'';position:absolute;inset:0;background:transparent;pointer-events:none}
@keyframes heroEnter{from{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}
.rph-cols{display:flex;flex-direction:column;gap:0}
.rph-sep{background:rgba(255,255,255,.08);height:1px;width:100%;margin:14px 0}
.rph-col{cursor:pointer;min-width:0;padding:0 2px}
.rph-col:active{opacity:.78;transition:opacity .1s}
.rph-rev-col .rp-label{color:var(--bl)}
@media(max-width:699px){.rph-cols{flex-direction:column}}
.rp-label{font-size:10px;font-weight:800;color:var(--gn);text-transform:uppercase;letter-spacing:1.4px;margin-bottom:6px;position:relative;z-index:1}
.rp-val{font-family:'JetBrains Mono';font-size:36px;font-weight:800;color:var(--t1);line-height:1.1;letter-spacing:-1px;font-variant-numeric:tabular-nums;position:relative;z-index:1}
.rp-val.neg{color:var(--rd)}
.rp-formula{font-size:11px;color:var(--t2);margin-top:4px;font-weight:500;position:relative;z-index:1}
.rp-bar{display:flex;height:6px;border-radius:3px;overflow:hidden;background:var(--c3);margin-top:14px;position:relative;z-index:1}
.rp-bar-rev{background:var(--gn);transition:width .8s cubic-bezier(.16,1,.3,1)}
.rp-bar-exp{background:var(--rd);opacity:.85;transition:width .8s cubic-bezier(.16,1,.3,1)}
.rp-bar-tax{background:var(--gd);opacity:.85;transition:width .8s cubic-bezier(.16,1,.3,1)}
.rp-legend{display:flex;justify-content:space-between;font-size:10px;color:var(--t3);margin-top:8px;font-variant-numeric:tabular-nums;position:relative;z-index:1}
.rp-legend b{color:var(--t1);font-family:'JetBrains Mono';font-weight:700}

/* MOBILE-FIRST defaults these apply by default and get UNDONE on desktop */
.kpi-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px}
.spark-row,.cf-card{padding:14px}
.cf-svg{height:96px}
.kpi-val{font-size:22px}
.kpi-label{font-size:10px}
.card{padding:14px;margin-bottom:10px}
.card-sm{padding:12px}
button,.ex-btn,.mbtn,.nav-btn,.side-btn,.filter-chip{min-height:38px}
.nav-btn{min-height:54px}
.tag,.late-chip{min-height:0}

@media(min-width:700px){
 .kpi-grid{grid-template-columns:repeat(4,minmax(0,1fr));gap:12px}
 #t-ov .kpi-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
 .kpi-val{font-size:28px}
 .card{padding:18px}
 .rp-val{font-size:48px}
 .real-profit-hero{padding:24px}
}

/* v2.10.0 APP FEEL */
/* Mobile bottom nav: shelf treatment so it reads like an iOS app */
@media (max-width:900px){
 .nav{position:fixed;bottom:0;left:0;right:0;background:rgba(13,21,32,.85);backdrop-filter:blur(20px) saturate(140%);-webkit-backdrop-filter:blur(20px) saturate(140%);border-top:1px solid var(--b1);border-radius:18px 18px 0 0;padding:10px 8px calc(10px + env(safe-area-inset-bottom,0px));display:flex;justify-content:space-around;z-index:100;box-shadow:0 -8px 32px rgba(0,0,0,.35)}
 :root[data-theme="apple"] .nav{background:rgba(255,255,255,.85)}
 /* Mobile version pill at very bottom (above the safe area) */
 .ver-mobile{display:flex;align-items:center;justify-content:center;gap:6px;padding:14px 0;font-family:'JetBrains Mono';font-size:10px;color:var(--t4);font-weight:600;opacity:.7}
 .ver-mobile .dot{width:5px;height:5px;background:var(--gn);border-radius:50%;box-shadow:0 0 6px var(--gn)}
 .ver-mobile a{color:var(--t3);text-decoration:none;border-bottom:1px dotted var(--t4)}
}
@media (min-width:901px){.ver-mobile{display:none}}
/* App-feel polish: rounded everything, tighter card shadows, smoother taps */
.card,.client,.prospect-card,.notif-card{border-radius:12px;box-shadow:0 1px 2px rgba(0,0,0,.05),0 0 0 1px var(--b1) inset}
.modal{border-radius:16px 16px 0 0}
@media(min-width:700px){.modal{border-radius:16px}}
/* First-load extended boot animations */
.boot-first .kpi-val{animation:countUp 4s cubic-bezier(.16,1,.3,1) forwards}
.boot-first .donut-fg{animation:donutDraw 3.5s cubic-bezier(.16,1,.3,1) forwards}
.boot-first .cl-profit-fill{animation:fillBar 3s cubic-bezier(.16,1,.3,1) forwards}
.boot-first .card{animation:fadeUpSlow .8s cubic-bezier(.16,1,.3,1) both}
.boot-first .card:nth-child(1){animation-delay:.05s}
.boot-first .card:nth-child(2){animation-delay:.15s}
.boot-first .card:nth-child(3){animation-delay:.25s}
.boot-first .card:nth-child(4){animation-delay:.35s}
.boot-first .card:nth-child(5){animation-delay:.45s}
.boot-first .card:nth-child(6){animation-delay:.55s}
@keyframes fadeUpSlow{from{opacity:0;transform:translateY(14px)}to{opacity:1;transform:translateY(0)}}
@keyframes fillBar{from{width:0}}
/* Daily AI brief banner */
.ai-brief-banner{background:var(--c2);border:1px solid var(--b1);border-left:3px solid var(--pp);border-radius:12px;padding:14px 16px;margin-bottom:14px;position:relative;overflow:hidden}
.ai-brief-banner::before{content:'';position:absolute;inset:0;background:transparent;pointer-events:none}
.ai-brief-head{display:flex;align-items:center;gap:8px;font-size:10px;font-weight:800;color:var(--pp);text-transform:uppercase;letter-spacing:1px;margin-bottom:8px}
.ai-brief-text{font-size:12px;color:var(--t1);line-height:1.6;margin-bottom:10px}
.ai-brief-actions{display:flex;gap:8px;flex-wrap:wrap}
.ai-brief-btn{background:rgba(168,85,247,.12);color:var(--pp);border:1px solid rgba(168,85,247,.22);border-radius:8px;padding:6px 12px;font-family:Inter;font-size:11px;font-weight:700;cursor:pointer;transition:all .15s}
.ai-brief-btn:hover{background:rgba(168,85,247,.2)}
/* 90-day cash flow chart */
.cf-card{padding:16px}
.cf-head{display:flex;justify-content:space-between;align-items:flex-end;margin-bottom:10px}
.cf-title{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:1px;color:var(--t3)}
.cf-end{font-family:'JetBrains Mono';font-size:18px;font-weight:800;color:var(--gn)}
.cf-end.warn{color:var(--gd)}
.cf-end.danger{color:var(--rd)}
.cf-svg{width:100%;height:120px;display:block}
.cf-legend{display:flex;justify-content:space-between;font-size:9px;color:var(--t4);margin-top:6px;font-family:'JetBrains Mono'}
/* Renewal chip on client cards */
.renewal-chip{background:rgba(251,191,36,.12);color:var(--gd);border:1px solid rgba(251,191,36,.25);border-radius:5px;padding:1px 6px;font-size:8px;font-weight:700;letter-spacing:.4px;text-transform:uppercase;margin-left:6px}
.renewal-chip.urgent{background:rgba(239,68,68,.12);color:var(--rd);border-color:rgba(239,68,68,.25)}
/* Onboarding view chooser */
.onboard-overlay{position:fixed;inset:0;background:var(--bg);z-index:9998;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:40px 24px;animation:lockFade .35s ease-out}
.onboard-title{font-size:24px;font-weight:800;margin-bottom:8px;letter-spacing:-.3px;text-align:center}
.onboard-sub{font-size:13px;color:var(--t2);margin-bottom:32px;text-align:center;max-width:340px;line-height:1.5}
.onboard-cards{display:flex;gap:16px;flex-direction:column;max-width:380px;width:100%}
@media (min-width:700px){.onboard-cards{flex-direction:row}}
.onboard-card{flex:1;background:var(--c2);border:1px solid var(--b1);border-radius:18px;padding:20px;cursor:pointer;transition:all .2s;text-align:center}
.onboard-card:hover{border-color:var(--bl);transform:translateY(-2px);box-shadow:0 12px 32px rgba(0,0,0,.28)}
.onboard-card.personal:hover{border-color:var(--pp);box-shadow:0 12px 32px rgba(0,0,0,.28)}
.onboard-icon{font-size:42px;margin-bottom:12px}
.onboard-name{font-size:15px;font-weight:700;margin-bottom:6px}
.onboard-desc{font-size:11px;color:var(--t3);line-height:1.5}
/* Tax ledger */
.tax-ledger-row{display:flex;justify-content:space-between;align-items:center;padding:8px 0;border-bottom:1px solid var(--b1);font-size:11px}
.tax-ledger-row:last-child{border-bottom:none}
.tax-ledger-amt{font-family:'JetBrains Mono';font-weight:700;color:var(--gn);font-variant-numeric:tabular-nums}
/* iOS-specific fixes (v2.9.1) */
button,a,.nav-btn,.side-btn,.client,.card,.tag,.filter-chip,.ex-btn,.mbtn,.fab,.tk-card,.sub-row,.kpi{touch-action:manipulation}
.modal,.notif-pane,.focus-panel,.focus-section,#pexList,#exList,#pcatList{-webkit-overflow-scrolling:touch;overscroll-behavior:contain}
/* Safari sticky-sidebar safety */
@supports (-webkit-touch-callout:none){
 .sidebar{position:-webkit-sticky;position:sticky}
 /* iOS: don't translateZ on .client cards it created a stacking context that swallowed taps in some cases (v2.10.2 fix) */
}
/* Mobile audit: no overflow on any tab */
@media (max-width:520px){
 .tk-filters{flex-wrap:wrap;gap:6px}
 .tk-filters .filter-chip{min-width:0;flex:1 1 auto;font-size:11px;padding:6px 8px}
 .tk-quickadd{flex-direction:column;gap:6px;align-items:stretch}
 .tk-quickadd .tk-add-btn{width:100%}
 .search-row{flex-wrap:wrap;gap:6px}
 .search-row .filter-chip{min-width:0;flex:1 1 auto}
 .search-row .search-input{min-width:100%;flex:1 1 100%}
 .cl-top{gap:8px}
 .cl-mrr-wrap{min-width:90px}
 .cl-mrr{font-size:15px}
 .focus-section{padding:12px 14px}
 .focus-section h4{font-size:11px}
 .modal{max-height:90vh}
 .tags{gap:3px}
 .tags .tag{max-width:110px}
 .pipe-row,#pipeBreakdown > div{gap:4px!important}
 .view-toggle{padding:3px}
 .view-toggle button{font-size:9px;padding:5px 8px}
 /* Nav buttons: prevent label wrap */
 .nav-btn{font-size:9px}
 .nav-btn .icon{font-size:16px}.nav-btn .icon svg{width:16px;height:16px}
}

/* FACE ID / PASSKEY LOCK SCREEN */
.lock-overlay{position:fixed;inset:0;background:var(--bg);z-index:9999;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:40px 24px;text-align:center;animation:lockFade .35s ease-out}
@keyframes lockFade{from{opacity:0;transform:scale(1.02)}to{opacity:1;transform:scale(1)}}
.lock-logo{width:80px;height:80px;border-radius:16px;background:var(--bl);display:flex;align-items:center;justify-content:center;font-size:26px;font-weight:900;color:#fff;margin-bottom:24px}
.lock-title{font-size:22px;font-weight:800;margin-bottom:8px;letter-spacing:-.3px}
.lock-sub{font-size:13px;color:var(--t2);margin-bottom:28px;max-width:320px;line-height:1.5}
.lock-btn{background:var(--bl);border:none;border-radius:12px;padding:14px 28px;color:#fff;font-family:Inter;font-size:14px;font-weight:700;cursor:pointer;letter-spacing:.3px;transition:filter .15s,transform .15s;display:inline-flex;align-items:center;gap:8px;min-width:220px;justify-content:center}
.lock-btn:hover{filter:brightness(1.06);transform:translateY(-1px)}
.lock-btn:active{transform:scale(.97)}
.lock-btn.secondary{background:transparent;color:var(--t3);box-shadow:none;margin-top:10px;font-size:12px}
.lock-btn.secondary:hover{color:var(--t1);transform:none}
.lock-icon{font-size:22px}
.lock-err{color:var(--rd);font-size:12px;margin-top:14px;min-height:18px;font-weight:600}

/* Health dots (inline indicators + tooltips) */
.hd{display:inline-block;width:8px;height:8px;border-radius:50%;vertical-align:middle;margin-right:6px;flex-shrink:0;position:relative;cursor:help}
.hd.excellent{background:var(--gn);box-shadow:0 0 8px rgba(16,185,129,.5)}
.hd.healthy{background:var(--cy);box-shadow:0 0 8px rgba(6,182,212,.4)}
.hd.okay{background:var(--gd)}
.hd.tight{background:var(--or)}
.hd.bleeding{background:var(--rd);box-shadow:0 0 8px rgba(239,68,68,.4);animation:pulse 2s infinite}
.hd.pending{background:var(--bl);box-shadow:0 0 6px rgba(59,130,246,.4);opacity:.85}
.hd.paused{background:var(--gd);box-shadow:0 0 6px rgba(251,191,36,.4);opacity:.85}
/* v2.16.73: grey out non-counted clients in revenue views — explicit visual signal */
.client.client-paused, .client.client-pending, .client.client-churned{opacity:.55;filter:saturate(.65)}
.client.client-paused .cl-rev, .client.client-pending .cl-rev, .client.client-churned .cl-rev{color:var(--t4)!important}
/* v2.16.76: corner status badge removed — was duplicating the inline blue PENDING chip next to the name. Grey-out + the inline chip is enough. */
.hd.churned{background:var(--t4);opacity:.5}
.hd-wrap{position:relative;display:inline-block}
.hd-tip{position:absolute;bottom:calc(100% + 8px);left:0;transform:none;background:var(--c4);border:1px solid var(--b2);color:var(--t1);font-size:10px;padding:6px 10px;border-radius:6px;max-width:280px;white-space:normal;line-height:1.5;opacity:0;pointer-events:none;transition:opacity .15s;z-index:50;font-weight:600;box-shadow:0 4px 14px rgba(0,0,0,.3)}
@media (min-width:700px){.hd-tip{max-width:320px}}
.hd-wrap:hover .hd-tip{opacity:1}

/* PROSPECTS */
.prospect-card{background:var(--c2);border:1px solid var(--b1);border-radius:12px;padding:12px;margin-bottom:8px;transition:border-color .15s;position:relative;overflow:hidden}
.prospect-card::before{content:'';position:absolute;top:0;left:0;right:0;height:2px;background:var(--gd);opacity:.6}
.prospect-card:hover{border-color:var(--b2)}
.prospect-head{display:flex;justify-content:space-between;align-items:flex-start;gap:10px;margin-bottom:6px}
.prospect-name{font-size:13px;font-weight:700;color:var(--t1);line-height:1.3}
.prospect-status{font-size:8px;font-weight:700;padding:2px 7px;border-radius:5px;text-transform:uppercase;letter-spacing:.5px;white-space:nowrap;display:inline-block;margin-top:3px}
.prospect-status.cold{background:rgba(148,163,184,.12);color:var(--t3);border:1px solid rgba(148,163,184,.2)}
.prospect-status.warm{background:rgba(251,191,36,.08);color:var(--gd);border:1px solid rgba(251,191,36,.18)}
.prospect-status.hot{background:rgba(239,68,68,.08);color:var(--rd);border:1px solid rgba(239,68,68,.18)}
.prospect-status.proposal{background:rgba(59,130,246,.1);color:var(--bl);border:1px solid rgba(59,130,246,.18)}
.prospect-status.negotiating{background:rgba(168,85,247,.08);color:var(--pp);border:1px solid rgba(168,85,247,.18)}
.prospect-status.won{background:rgba(16,185,129,.1);color:var(--gn);border:1px solid rgba(16,185,129,.2)}
.prospect-status.lost{background:rgba(100,100,100,.08);color:var(--t4);border:1px solid rgba(100,100,100,.15);opacity:.7}
.prospect-mrr{font-family:'JetBrains Mono';font-size:15px;font-weight:700;color:var(--gd);white-space:nowrap}
.prospect-mrr small{font-size:9px;color:var(--t4);font-weight:500;display:block;text-align:right;margin-top:-1px}
.prospect-body{display:flex;flex-direction:column;gap:3px;font-size:10px;color:var(--t2);margin-top:4px}
.prospect-body .row{display:flex;gap:6px}
.prospect-body .row b{color:var(--t3);font-weight:700;min-width:56px;text-transform:uppercase;font-size:9px;letter-spacing:.4px}
.prospect-actions{display:flex;gap:5px;margin-top:10px;border-top:1px solid var(--b1);padding-top:8px;flex-wrap:wrap}
.prospect-actions button{background:var(--c3);border:1px solid var(--b1);color:var(--t3);font-family:Inter;font-size:9px;font-weight:700;padding:5px 9px;border-radius:6px;cursor:pointer;text-transform:uppercase;letter-spacing:.5px;transition:all .15s}
.prospect-actions button:hover{color:var(--t1);border-color:var(--b2)}
.prospect-actions button.adv{color:var(--gn);border-color:rgba(16,185,129,.25);background:rgba(16,185,129,.08)}
.prospect-actions button.del{color:var(--rd);border-color:rgba(239,68,68,.2)}

/* Prospect add button and form */
.add-prospect-btn{width:100%;background:var(--c2);border:1px dashed var(--b2);color:var(--t3);font-family:Inter;font-size:11px;font-weight:700;padding:11px;border-radius:12px;cursor:pointer;transition:all .15s;text-transform:uppercase;letter-spacing:.5px;margin-bottom:10px}
.add-prospect-btn:hover{border-color:var(--bl);color:var(--bl)}
.prosp-form{display:grid;grid-template-columns:1fr 1fr;gap:8px}
.prosp-form input,.prosp-form select,.prosp-form textarea{background:var(--c3);border:1px solid var(--b1);border-radius:8px;padding:9px 11px;color:var(--t1);font-family:Inter;font-size:12px;font-weight:500;width:100%}
.prosp-form input:focus,.prosp-form select:focus,.prosp-form textarea:focus{outline:none;border-color:var(--b3)}
.prosp-form input::placeholder,.prosp-form textarea::placeholder{color:var(--t4)}
.prosp-form .full{grid-column:1/-1}
.prosp-form textarea{resize:vertical;min-height:60px;font-family:Inter}
.prosp-form label{font-size:9px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:var(--t3);margin-bottom:-2px;display:block}

/* PERSONAL DONUT CHARTS */
.pers-chart-card{padding:14px;margin-bottom:10px}
.pers-chart-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}
.pers-chart-head h4{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:1px;color:var(--t3)}
.pers-chart-head .chart-total{font-family:'JetBrains Mono';font-size:14px;font-weight:700;color:var(--pp)}
.pers-chart-body{display:flex;align-items:center;gap:14px}
.donut-wrap{flex-shrink:0;position:relative;width:130px;height:130px}
.donut-wrap svg{width:100%;height:100%;transform:rotate(-90deg)}
.donut-wrap svg circle.slice{fill:none;stroke-width:18;transition:all .3s;cursor:pointer}
.donut-wrap svg circle.slice:hover{stroke-width:20}
.donut-wrap svg circle.track{fill:none;stroke:var(--c3);stroke-width:18}
.donut-center{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);text-align:center;pointer-events:none;line-height:1}
.donut-center-val{font-family:'JetBrains Mono';font-size:15px;font-weight:700;color:var(--t1);letter-spacing:-.3px}
.donut-center-lbl{font-size:8px;font-weight:700;color:var(--t3);text-transform:uppercase;letter-spacing:.5px;margin-top:3px}
.donut-legend{flex:1;min-width:0;display:flex;flex-direction:column;gap:4px;max-height:136px;overflow-y:auto;padding-right:2px}
.donut-legend::-webkit-scrollbar{width:4px}
.donut-legend::-webkit-scrollbar-thumb{background:var(--b2);border-radius:2px}
.donut-legend-item{display:flex;align-items:center;gap:6px;font-size:10px;cursor:pointer;padding:3px 5px;border-radius:5px;transition:background .15s}
.donut-legend-item:hover{background:var(--c3)}
.donut-legend-item.muted{opacity:.35}
.donut-legend-item .sw{width:9px;height:9px;border-radius:3px;flex-shrink:0}
.donut-legend-item .nm{flex:1;color:var(--t2);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-weight:500}
.donut-legend-item .pc{font-family:'JetBrains Mono';font-size:10px;color:var(--t4);font-weight:600;flex-shrink:0}
.donut-legend-item.active .nm{color:var(--t1);font-weight:700}

/* Profit margin wheel (biz overview) */
.margin-wheel-card{padding:14px;display:flex;align-items:center;gap:14px;margin-bottom:10px}
.margin-donut{width:110px;height:110px;flex-shrink:0}
.margin-info{flex:1;min-width:0}
/* v2.17.63: at narrow mobile widths the 1fr/1fr split squeezes the donut +
   info side-by-side past usable. Stack the two halves vertically and drop
   the inner side-border on stack. Same fix for the KPI label/sub so long
   strings can wrap without overflowing the card box. */
@media (max-width:480px){
 .margin-goal-grid{grid-template-columns:1fr!important}
 .margin-wheel-card{border-right:none!important;border-bottom:1px solid var(--b1)}
 .margin-donut{width:96px;height:96px}
}
.kpi .kpi-label,.kpi .kpi-sub,.kpi .kpi-val{min-width:0;overflow-wrap:anywhere}
.margin-title{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:1px;color:var(--t3);margin-bottom:4px}
.margin-health{font-size:18px;font-weight:800;letter-spacing:-.3px;color:var(--gn);margin-bottom:3px}
.margin-health.excellent{color:var(--gn)}
.margin-health.healthy{color:var(--cy)}
.margin-health.okay{color:var(--gd)}
.margin-health.tight{color:var(--or)}
.margin-health.bleeding{color:var(--rd)}
.margin-desc{font-size:11px;color:var(--t3);line-height:1.45;font-weight:500}

/* v2.16.84: Personal Trend + Goals combo card stacks on mobile (was 2-col, both halves cramped) */
@media (max-width:899px){
 .pers-trend-goals-card > div{grid-template-columns:1fr!important;gap:10px!important}
 .pers-trend-goals-card > div > div:nth-child(2){display:none!important}
 .pers-trend-goals-card #goalsList{max-height:none!important}
}

/* Personal savings goals */
.goals-head{display:flex;justify-content:space-between;align-items:center;margin:16px 0 8px}
.goals-head h3{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:1.2px;color:var(--t3)}
.goals-head .add-btn{background:var(--pp);border:none;border-radius:8px;padding:6px 11px;color:#fff;font-family:Inter;font-size:10px;font-weight:700;cursor:pointer;letter-spacing:.3px;transition:filter .15s}
.goals-head .add-btn:hover{filter:brightness(1.06)}
.goal-card{background:var(--c2);border:1px solid var(--b1);border-radius:12px;padding:14px;display:flex;align-items:center;gap:14px;margin-bottom:8px;position:relative;overflow:hidden}
.goal-card::before{content:'';position:absolute;top:0;left:0;right:0;height:2px;opacity:.8}
.goal-card.done::before{background:var(--gn)}
.goal-card.done{border-color:rgba(16,185,129,.25)}
.goal-donut{flex-shrink:0;width:90px;height:90px;position:relative}
.goal-donut svg{width:100%;height:100%;transform:rotate(-90deg)}
.goal-donut .pct{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-family:'JetBrains Mono';font-size:14px;font-weight:700;color:var(--t1)}
.goal-info{flex:1;min-width:0}
.goal-title{display:flex;align-items:center;gap:6px;font-size:13px;font-weight:700;color:var(--t1);margin-bottom:3px}
.goal-amt{font-family:'JetBrains Mono';font-size:12px;font-weight:600;color:var(--pp)}
.goal-meta{font-size:10px;color:var(--t4);margin-top:3px;font-weight:500}
.goal-actions{display:flex;gap:5px;margin-top:7px;flex-wrap:wrap}
.goal-action{background:var(--c3);border:1px solid var(--b1);border-radius:6px;padding:4px 8px;color:var(--t2);font-family:Inter;font-size:9px;font-weight:700;cursor:pointer;text-transform:uppercase;letter-spacing:.4px;transition:all .15s}
.goal-action:hover{color:var(--t1);border-color:var(--b2)}
.goal-action.prim{background:rgba(168,85,247,.12);color:var(--pp);border-color:rgba(168,85,247,.25)}
.goal-action.del{color:var(--rd);border-color:rgba(239,68,68,.2)}
.goal-done-badge{background:rgba(16,185,129,.12);color:var(--gn);border:1px solid rgba(16,185,129,.25);padding:1px 7px;border-radius:5px;font-size:8px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;margin-left:4px}

/* Personal budget ring (month trend) */
.budget-ring-card{padding:14px;display:flex;align-items:center;gap:14px;margin-bottom:10px}
.budget-ring-card .donut-wrap{width:110px;height:110px}
.budget-info{flex:1;min-width:0}
.budget-title{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:1px;color:var(--t3);margin-bottom:4px}
.budget-val{font-family:'JetBrains Mono';font-size:20px;font-weight:700;color:var(--t1);letter-spacing:-.5px}
.budget-sub{font-size:11px;color:var(--t3);margin-top:3px;font-weight:500}
.budget-edit{background:var(--c3);border:1px solid var(--b1);color:var(--t3);font-size:9px;font-weight:700;padding:4px 8px;border-radius:6px;cursor:pointer;margin-top:6px;text-transform:uppercase;letter-spacing:.5px;display:inline-block}
.budget-edit:hover{color:var(--t1)}

/* Personal category rows */
.pers-cat-row{background:var(--c2);border:1px solid var(--b1);border-radius:12px;padding:11px;margin-bottom:6px;display:flex;align-items:center;gap:10px;transition:all .15s}
.pers-cat-row:hover{border-color:var(--b2)}
.pers-cat-ic{width:34px;height:34px;border-radius:9px;background:var(--c3);display:flex;align-items:center;justify-content:center;font-size:17px;flex-shrink:0}
.pers-cat-info{flex:1;min-width:0}
.pers-cat-name{font-size:12px;font-weight:700;color:var(--t1)}
.pers-cat-meta{font-size:10px;color:var(--t4);margin-top:1px}
.pers-cat-amt{font-family:'JetBrains Mono';font-size:13px;font-weight:700;color:var(--rd);white-space:nowrap}
.pers-cat-bar{height:3px;background:var(--c3);border-radius:3px;overflow:hidden;margin-top:5px}
.pers-cat-bar-fill{height:100%;background:var(--pp);border-radius:3px;transition:width .8s ease}

/* Personal transaction rows */
.pers-txn{background:var(--c2);border:1px solid var(--b1);border-radius:10px;padding:10px 12px;margin-bottom:6px;display:flex;align-items:center;gap:10px}
.pers-txn-ic{width:30px;height:30px;border-radius:8px;background:var(--c3);display:flex;align-items:center;justify-content:center;font-size:14px;flex-shrink:0}
.pers-txn-body{flex:1;min-width:0}
.pers-txn-name{font-size:12px;font-weight:600;color:var(--t1);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.pers-txn-meta{font-size:10px;color:var(--t4);margin-top:2px;display:flex;gap:6px;align-items:center;flex-wrap:wrap}
.pers-txn-cat{background:var(--c3);border:1px solid var(--b1);padding:2px 7px;border-radius:5px;color:var(--t2);font-weight:600;cursor:pointer;font-size:9px;text-transform:uppercase;letter-spacing:.4px}
.pers-txn-cat:hover{color:var(--pp);border-color:rgba(168,85,247,.25)}
.pers-txn-cat.uncategorized{color:var(--gd);border-color:rgba(251,191,36,.25);background:rgba(251,191,36,.05)}
.pers-txn-amt{font-family:'JetBrains Mono';font-size:13px;font-weight:700;color:var(--rd);flex-shrink:0;white-space:nowrap}
.pers-txn-amt.cr{color:var(--gn)}
.pers-empty{padding:30px 20px;text-align:center;color:var(--t3)}

/* Personal connect banner */
.pers-connect-card{background:var(--c2);border:1px solid var(--b1);border-radius:12px;padding:18px;margin-bottom:12px;text-align:center}
.pers-connect-card h3{font-size:15px;font-weight:700;color:var(--t1);margin-bottom:6px}
.pers-connect-card p{font-size:11px;color:var(--t2);margin-bottom:12px;line-height:1.5}
.pers-connect-btn{background:var(--pp);border:none;border-radius:10px;padding:12px 24px;color:#fff;font-family:Inter;font-size:12px;font-weight:700;cursor:pointer;letter-spacing:.3px;transition:filter .15s,transform .15s}
.pers-connect-btn:hover{filter:brightness(1.06);transform:translateY(-1px)}
.pers-connect-btn:active{transform:scale(.97)}

/* Category change modal */
.cat-picker{display:grid;grid-template-columns:1fr 1fr;gap:6px;margin:10px 0}
.cat-picker button{background:var(--c3);border:1px solid var(--b1);border-radius:9px;padding:10px 8px;color:var(--t2);font-family:Inter;font-size:11px;font-weight:600;cursor:pointer;transition:all .15s;display:flex;align-items:center;gap:8px;text-align:left}
.cat-picker button:hover{border-color:var(--b2);color:var(--t1)}
.cat-picker button.on{background:rgba(168,85,247,.1);border-color:var(--pp);color:var(--t1)}
.cat-picker button .emoji{font-size:15px}
.cat-remember{display:flex;align-items:center;gap:8px;padding:10px;background:var(--c3);border:1px solid var(--b1);border-radius:10px;font-size:11px;color:var(--t2);margin:10px 0}
.cat-remember input{accent-color:var(--pp)}

/* v2.10.4 NATIVE-APP FEEL */
/* Pull-to-refresh indicator */
.ptr-indicator{position:fixed;top:-50px;left:50%;transform:translateX(-50%);width:40px;height:40px;background:var(--c1);border:1px solid var(--b2);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:18px;z-index:50;transition:top .25s ease-out,opacity .2s;box-shadow:0 4px 14px rgba(0,0,0,.3)}
.ptr-indicator.active{top:max(env(safe-area-inset-top,12px),16px)}
.ptr-indicator.refreshing{animation:ptrSpin 1s linear infinite}
@keyframes ptrSpin{from{transform:translateX(-50%) rotate(0)}to{transform:translateX(-50%) rotate(360deg)}}

/* Command palette / quick switcher */
.cmdk-overlay{position:fixed;inset:0;background:rgba(0,0,0,.6);backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);z-index:9999;display:none;align-items:flex-start;justify-content:center;padding:80px 16px 16px;animation:fadeIn .15s ease-out}
.cmdk-overlay.show{display:flex}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}
.cmdk-box{width:100%;max-width:560px;background:var(--c1);border:1px solid var(--b2);border-radius:12px;overflow:hidden;box-shadow:0 24px 60px rgba(0,0,0,.5);animation:cmdkIn .2s cubic-bezier(.16,1,.3,1)}
@keyframes cmdkIn{from{opacity:0;transform:scale(.96) translateY(-8px)}to{opacity:1;transform:scale(1) translateY(0)}}
.cmdk-input{width:100%;background:transparent;border:none;color:var(--t1);padding:18px 20px;font-family:Inter;font-size:15px;font-weight:500;border-bottom:1px solid var(--b1)}
.cmdk-input:focus{outline:none}
.cmdk-list{max-height:60vh;overflow-y:auto;padding:6px 0}
.cmdk-item{display:flex;align-items:center;gap:12px;padding:11px 18px;cursor:pointer;color:var(--t2);font-size:13px;transition:background .1s}
.cmdk-item:hover,.cmdk-item.on{background:rgba(59,130,246,.1);color:var(--t1)}
.cmdk-item .cmdk-ic{width:30px;height:30px;border-radius:8px;background:var(--c3);display:flex;align-items:center;justify-content:center;font-size:14px;flex-shrink:0}
.cmdk-item .cmdk-meta{font-size:10px;color:var(--t4);margin-left:auto;font-family:'JetBrains Mono'}
.cmdk-section{padding:8px 18px 4px;font-size:9px;text-transform:uppercase;letter-spacing:1px;color:var(--t4);font-weight:700}
.cmdk-empty{padding:40px 20px;text-align:center;color:var(--t4);font-size:12px}
.cmdk-hint{display:flex;justify-content:space-between;padding:10px 16px;font-size:10px;color:var(--t4);border-top:1px solid var(--b1);background:var(--bg)}
.cmdk-hint kbd{background:var(--c3);border:1px solid var(--b1);border-radius:4px;padding:1px 5px;font-family:'JetBrains Mono';font-size:9px;color:var(--t3)}

/* v2.17.9 → v2.17.30: capture-pair simplified. Was taking ~120px of premium real estate
   for tools used 5x/day max. Now collapsed to a 36px pill at top of Overview that expands
   into the full pair when tapped. Desktop expands inline; mobile expands into a sticky
   sheet so the keyboard doesn't push everything around. */
.capture-pair{align-items:stretch}
.capture-pair > .capture-half{transition:flex .25s ease,opacity .2s,box-shadow .2s;display:flex;flex-direction:column}
.capture-pair > .capture-half.focused{flex:2.4 1 0;box-shadow:0 4px 18px rgba(0,0,0,.18)}
.capture-pair > .capture-half:not(.focused).has-focus-sibling{flex:1 1 0;opacity:.78}
.capture-pair > #overviewTodoistQuickAdd.focused .capture-todo-hint{display:inline}
.capture-collapsed{display:flex;align-items:center;gap:10px;padding:10px 14px;background:var(--c2);border:1px solid var(--b1);border-radius:999px;font-size:11px;font-weight:800;cursor:pointer;transition:border-color .15s,transform .15s;letter-spacing:.5px;text-transform:uppercase;min-height:44px}
.capture-collapsed:hover{border-color:var(--b2);transform:translateY(-1px)}
.capture-collapsed:active{transform:scale(.99)}
.capture-collapsed .ico{font-size:13px;line-height:1}
.capture-collapsed .hint{font-weight:500;color:var(--t4);text-transform:none;letter-spacing:0;font-size:10px;margin-left:auto}
.capture-pair.is-expanded{margin-bottom:10px}
@media (max-width:640px){
  .capture-pair{flex-direction:column;gap:10px!important}
  .capture-pair > .capture-half,
  .capture-pair > .capture-half.focused,
  .capture-pair > .capture-half:not(.focused).has-focus-sibling{flex:1 1 auto;opacity:1;box-shadow:none;padding:14px 16px!important}
  .capture-pair > .capture-half input[type=text]{font-size:14px!important;padding:11px 12px!important;min-height:44px}
  .capture-pair > .capture-half button{min-width:48px;min-height:44px}
  .capture-pair > .capture-half .capture-todo-hint{display:none!important}
  .capture-pair > #captureIdeaCard #captureIdeaList{margin-top:10px!important}
}

/* Toast on mobile — v2.16.99: anchored to BOTTOM (above the bottom nav + safe area). User
   preference; centered-middle was too in-the-face. */
@media (max-width:900px){
 .toast{position:fixed!important;bottom:auto!important;left:50%!important;right:auto!important;top:calc(20px + env(safe-area-inset-top,0px))!important;transform:translateX(-50%) translateY(-10px)!important;max-width:min(86vw,360px)!important;text-align:center;padding:11px 16px!important;font-size:12px!important;box-shadow:0 8px 30px rgba(0,0,0,.5)!important}
 .toast.show{transform:translateX(-50%) translateY(0)!important}
}

/* MRR Goal ETA */
.goal-eta{font-size:10px;color:var(--t3);margin-top:6px;display:flex;align-items:center;gap:6px}
.goal-eta-pace{font-weight:700;font-family:'JetBrains Mono'}
.goal-eta.up .goal-eta-pace{color:var(--gn)}
.goal-eta.down .goal-eta-pace{color:var(--rd)}
.goal-eta.flat .goal-eta-pace{color:var(--t3)}
/* END v2.10.4 */

/* 
 v2.10.3 UI POLISH LAYER runs AFTER all other CSS
 Normalizes spacing/radius/shadow/typography/animation across the app.
 Specificity tuned to override one-off inline styles where needed.
 */

/* v2.13.8: Uniform Net column treatment (was: vertically inconsistent across cards) */
.cl-mrr-wrap > div:last-child{display:flex;flex-direction:column;align-items:flex-end;gap:1px}
.cl-mrr-wrap .cl-mrr{line-height:1.1;margin:0}
.cl-mrr-wrap > div:last-child > div:not(.cl-mrr){font-size:10px;color:var(--t4);font-weight:500;line-height:1.3;font-variant-numeric:tabular-nums}
.cl-total-rev{margin-top:2px!important;line-height:1.3}
.cl-total-rev b{font-size:11px}
.cl-total-rev-ot{display:inline!important;font-size:9px;margin-left:2px}
/* Profit bar value aligned to the right edge consistently */
.cl-profit{display:grid;grid-template-columns:auto 1fr auto;gap:8px;align-items:center;margin-top:10px;padding-top:8px;border-top:1px solid var(--b1)}
.cl-profit-label{font-size:9px;color:var(--t4);text-transform:uppercase;letter-spacing:.6px;font-weight:700}
.cl-profit-track{height:5px;background:var(--c3);border-radius:3px;overflow:hidden}
.cl-profit-fill{height:100%;background:var(--gn);border-radius:3px}
.cl-profit-val{font-family:'JetBrains Mono';font-size:11px;font-weight:700;color:var(--gn);font-variant-numeric:tabular-nums;min-width:70px;text-align:right}

/* v2.13.8 Ask AI floating widget */
.ask-ai-fab{position:fixed;right:20px;bottom:90px;width:56px;height:56px;border-radius:50%;background:var(--bl);border:none;color:#fff;font-size:24px;cursor:pointer;box-shadow:0 6px 20px rgba(0,0,0,.4);z-index:80;transition:transform .15s ease;display:flex;align-items:center;justify-content:center}
.ask-ai-fab:hover{transform:scale(1.05)}
.ask-ai-fab:active{transform:scale(.95)}
@media (min-width:900px){.ask-ai-fab{right:32px;bottom:32px}}
.ask-ai-overlay{position:fixed;inset:0;background:rgba(0,0,0,.55);backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);z-index:9998;display:none;align-items:flex-end;justify-content:center;padding:0}
.ask-ai-overlay.show{display:flex;animation:fadeIn .15s ease-out}
@media (min-width:700px){.ask-ai-overlay{align-items:center;justify-content:flex-end;padding:0 32px 32px 0}}
.ask-ai-panel{background:var(--c1);border:1px solid var(--b2);border-radius:16px 16px 0 0;width:100%;max-width:500px;display:flex;flex-direction:column;max-height:85vh;animation:slideUp .25s cubic-bezier(.16,1,.3,1)}
@media (min-width:700px){.ask-ai-panel{border-radius:16px;max-height:600px;width:440px}}
@keyframes slideUp{from{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}
.ask-ai-head{display:flex;justify-content:space-between;align-items:flex-start;padding:18px 18px 12px;border-bottom:1px solid var(--b1)}
.ask-ai-title{font-size:16px;font-weight:800;color:var(--t1)}
.ask-ai-sub{font-size:11px;color:var(--t3);margin-top:2px}
.ask-ai-close{background:transparent;border:none;color:var(--t3);font-size:24px;cursor:pointer;padding:0 4px;line-height:1}
.ask-ai-history{flex:1;overflow-y:auto;padding:14px 18px;display:flex;flex-direction:column;gap:10px;-webkit-overflow-scrolling:touch}
.ask-ai-msg{padding:10px 12px;border-radius:12px;font-size:13px;line-height:1.5;max-width:85%;white-space:pre-wrap;word-break:break-word}
.ask-ai-msg.user{background:var(--bl);color:#fff;align-self:flex-end;border-bottom-right-radius:4px}
.ask-ai-msg.ai{background:var(--c2);color:var(--t1);border:1px solid var(--b1);align-self:flex-start;border-bottom-left-radius:4px}
.ask-ai-msg.ai.thinking{color:var(--t3);font-style:italic}
.ask-ai-input-row{display:flex;gap:8px;padding:12px 18px calc(12px + env(safe-area-inset-bottom,0px));border-top:1px solid var(--b1);background:var(--bg)}
.ask-ai-input-row textarea{flex:1;background:var(--c2);border:1px solid var(--b1);border-radius:12px;padding:10px 12px;color:var(--t1);font-family:Inter;font-size:13px;resize:none;min-height:40px;max-height:120px;outline:none}
.ask-ai-input-row textarea:focus{border-color:var(--bl)}
.ask-ai-send{background:var(--bl);border:none;border-radius:10px;padding:0 16px;color:#fff;font-family:Inter;font-size:13px;font-weight:700;cursor:pointer;flex-shrink:0}
.ask-ai-send:disabled{opacity:.5;cursor:not-allowed}

/* v2.13.8 Commissions table on client focus page */
.comm-table{width:100%;border-collapse:collapse;font-size:11px;font-variant-numeric:tabular-nums}
.comm-table th{text-align:left;font-size:9px;font-weight:700;color:var(--t3);text-transform:uppercase;letter-spacing:.5px;padding:8px 6px 4px;border-bottom:1px solid var(--b1)}
.comm-table td{padding:6px;border-bottom:1px solid var(--b1);color:var(--t2)}
.comm-table tr:hover td{background:rgba(255,255,255,.02)}
.comm-row.paid td:nth-child(4){color:var(--gn);font-weight:700}
.comm-row.pending td:nth-child(4){color:var(--gd);font-weight:700}
.comm-row.nocharge td:nth-child(4){color:var(--t4)}
.comm-totals{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-bottom:10px}
.comm-totals > div{padding:10px 12px;background:var(--c2);border:1px solid var(--b1);border-radius:10px}
.comm-totals .label{font-size:10px;color:var(--t3);text-transform:uppercase;letter-spacing:.6px;font-weight:700;margin-bottom:4px}
.comm-totals .val{font-size:18px;font-weight:800;font-family:'JetBrains Mono';font-variant-numeric:tabular-nums}
.comm-totals .paid .val{color:var(--gn)}
.comm-totals .pending .val{color:var(--gd)}

/* v2.13.8 Quick Capture (F5) */
.quick-cap-card{background:var(--c2);border:1px solid var(--b1);padding:8px 12px;margin-bottom:10px;transition:border-color .2s}
.quick-cap-card:focus-within{border-color:var(--bl);box-shadow:0 0 0 3px rgba(59,130,246,.1)}
.quick-cap-card input::placeholder{color:var(--t4);font-style:italic}

/* v2.13.8 Risk Radar dot (F4) */
.rr-dot{width:14px;height:14px;border-radius:50%;cursor:pointer;position:relative;transition:transform .15s ease-out}
.rr-dot:hover{transform:scale(1.4)}
.rr-dot.healthy{background:var(--gn);box-shadow:0 0 6px rgba(16,185,129,.5)}
.rr-dot.tight{background:var(--gd);box-shadow:0 0 6px rgba(251,191,36,.4)}
.rr-dot.bleeding{background:var(--rd);box-shadow:0 0 8px rgba(239,68,68,.5)}
.rr-dot.late{background:var(--or);box-shadow:0 0 6px rgba(249,115,22,.4)}
.rr-dot.pending{background:var(--t4);opacity:.6}
.rr-dot::after{content:attr(data-name);position:absolute;bottom:calc(100% + 6px);left:50%;transform:translateX(-50%);background:var(--c4);border:1px solid var(--b2);color:var(--t1);font-size:10px;padding:4px 8px;border-radius:6px;white-space:nowrap;opacity:0;pointer-events:none;transition:opacity .15s;font-family:Inter;font-weight:600;font-variant-numeric:tabular-nums;z-index:9999;box-shadow:0 4px 16px rgba(0,0,0,.4)}
.rr-dot:hover::after{opacity:1}
/* v2.16.22: tooltip was clipped because .card has overflow:hidden — let the radar card breathe */
#riskRadarCard{overflow:visible!important}
#riskRadarCard #riskRadarRow{overflow:visible}

/* v2.13.8 V3 KPI animation timing MoM arrows wait for the number to land then fade in together */
.kpi-mom{opacity:0;transform:translateY(2px);animation:momIn .35s ease-out 2.6s forwards}
@keyframes momIn{to{opacity:1;transform:translateY(0)}}

/* Card elevation system (0/1/2) */
.card,.client,.prospect-card,.notif-card,.cf-card{
 border-radius:12px;
 background:var(--c1);
 border:1px solid var(--b1);
 box-shadow:none;
 transition:box-shadow .25s ease,border-color .25s ease,transform .15s ease-out;
}
/* v2.13.8: hover ONLY on devices that actually have a hover pointer (mouse). iOS triggers ghost-clicks otherwise. */
@media (hover:hover) and (pointer:fine){
 .card:hover,.client:hover,.prospect-card:hover{
 border-color:var(--b2);
 box-shadow:0 4px 14px rgba(0,0,0,.18);
 }
}
.card:active,.client:active,.prospect-card:active{
 transform:scale(.995);
 box-shadow:0 2px 8px rgba(0,0,0,.22);
}

/* Section heading hierarchy */
h2{font-size:18px;font-weight:800;letter-spacing:-.3px;line-height:1.2}
h3{font-size:13px;font-weight:700;letter-spacing:.4px;text-transform:uppercase;color:var(--t2)}
h4{font-size:11px;font-weight:700;letter-spacing:.5px;text-transform:uppercase;color:var(--t2)}

/* Label typography */
.kpi-label,.cl-meta,.cf-title,.rp-label,.tk-group-title{
 font-family:Inter,sans-serif;
 font-weight:700;
}

/* Pill / tag / chip consistency */
.tag,.late-chip,.renewal-chip,.pri-badge,.task-label-chip,.prospect-status{
 font-size:9px;
 font-weight:700;
 padding:2px 7px;
 border-radius:4px;
 letter-spacing:.4px;
 text-transform:uppercase;
 line-height:1.4;
 display:inline-flex;
 align-items:center;
 gap:3px;
}

/* Button surface system */
button{font-family:Inter,sans-serif;cursor:pointer;transition:all .15s ease-out}
.ex-btn{
 background:var(--c2);
 border:1px solid var(--b1);
 border-radius:8px;
 padding:7px 12px;
 color:var(--t2);
 font-size:11px;
 font-weight:600;
 min-height:38px;
}
@media (hover:hover) and (pointer:fine){.ex-btn:hover{border-color:var(--b2);color:var(--t1)}}
.ex-btn:active{transform:scale(.97)}
.mbtn{
 background:var(--bl);
 border:none;
 border-radius:12px;
 padding:12px 18px;
 color:#fff;
 font-size:13px;
 font-weight:700;
 min-height:44px;
 box-shadow:none;
}
.mbtn:hover{filter:brightness(1.06);transform:translateY(-1px)}
.mbtn:active{transform:scale(.97)}

/* Filter chip touch-friendly */
.filter-chip{
 border-radius:10px;
 padding:8px 12px;
 font-size:11px;
 min-height:38px;
 border:1px solid var(--b1);
 background:var(--c2);
 color:var(--t2);
 font-weight:600;
}
.filter-chip:hover{border-color:var(--b2);color:var(--t1)}

/* Search input */
.search-input{
 border-radius:10px;
 padding:10px 12px;
 font-size:12px;
 background:var(--c2);
 border:1px solid var(--b1);
 color:var(--t1);
 min-height:38px;
}
.search-input:focus{outline:none;border-color:var(--bl);box-shadow:0 0 0 3px rgba(59,130,246,.1)}

/* Skeleton loader unified */
.sk{
 display:inline-block;
 background:linear-gradient(90deg,var(--c2),var(--c3),var(--c2));
 background-size:200% 100%;
 animation:skShimmer 1.4s ease-in-out infinite;
 border-radius:6px;
 height:14px;
 width:80px;
 vertical-align:middle;
}
@keyframes skShimmer{0%{background-position:-200% 0}100%{background-position:200% 0}}

/* Empty state illustrations */
.empty,.empty-ill{
 display:flex;
 flex-direction:column;
 align-items:center;
 justify-content:center;
 padding:32px 16px;
 text-align:center;
 gap:8px;
 color:var(--t3);
}
.empty .eicon,.empty-ill svg{
 font-size:36px;
 opacity:.5;
 margin-bottom:4px;
}
.empty > div:not(.eicon){
 font-size:12px;
 color:var(--t3);
 line-height:1.5;
 max-width:280px;
}

/* Toast unified */
.toast{
 border-radius:10px;
 padding:10px 14px;
 font-size:12px;
 font-weight:600;
 box-shadow:0 8px 24px rgba(0,0,0,.3);
 border:1px solid var(--b2);
}

/* Modal polish */
.modal{
 border-radius:16px 16px 0 0;
 padding:20px 18px calc(20px + env(safe-area-inset-bottom,0px));
 box-shadow:0 -16px 48px rgba(0,0,0,.4);
}
@media(min-width:700px){.modal{border-radius:16px;padding:24px}}
.modal h2{margin-bottom:4px}
.msub{font-size:11px;color:var(--t3);margin-bottom:14px}

/* Number alignment everywhere */
.kpi-val,.cl-mrr,.bal-val,.runway-val,.goal-cur,.goal-pct,.txn-amt,.ex-amt,.sub-row-amt,.pl-row-net,.pl-total .val,.mval,.gauge-pct,.spark-val,.cl-profit-val,.rp-val,.cf-end{
 font-family:'JetBrains Mono',monospace;
 font-variant-numeric:tabular-nums;
 font-feature-settings:"tnum" on,"lnum" on;
 letter-spacing:-.3px;
}

/* Sub-row consistency */
.sub-row,.pl-row,.ex-row,.cl-sub-row,.tax-ledger-row{
 padding:10px 12px;
 border-radius:8px;
 transition:background .15s ease;
}
.sub-row:hover,.ex-row:hover{background:rgba(255,255,255,.02)}

/* Tab transitions */
.tab{animation:tabFade .25s ease-out}
@keyframes tabFade{from{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}

/* Header polish */
.hdr{padding-top:max(env(safe-area-inset-top,12px),16px);padding-bottom:14px}
.greet{font-size:18px;font-weight:700;letter-spacing:-.3px;margin-top:6px}
.greet em{font-style:normal;background-image:none;-webkit-text-fill-color:currentColor;color:var(--t1)}

/* Apple theme polish parity */
:root[data-theme="apple"] .card,:root[data-theme="apple"] .client{box-shadow:0 1px 3px rgba(0,0,0,.06),0 0 0 1px rgba(60,60,67,.08) inset!important}
:root[data-theme="apple"] .card:hover{box-shadow:0 8px 22px rgba(0,0,0,.1)!important}

/* Sidebar polish (desktop) */
.side-btn{border-radius:10px;padding:10px 14px;min-height:42px;font-weight:600;letter-spacing:0}
.side-btn.on{background:var(--c3);color:var(--bl);border-left:3px solid var(--bl);padding-left:11px}

/* Bottom nav polish */
.nav-btn{
 display:flex;
 flex-direction:column;
 align-items:center;
 justify-content:center;
 gap:3px;
 padding:6px 4px;
 border-radius:10px;
 background:transparent;
 border:none;
 color:var(--t3);
 font-family:Inter;
 font-size:9px;
 font-weight:700;
 letter-spacing:.3px;
 flex:1;
 min-height:54px;
 transition:color .15s ease,transform .1s ease;
}
.nav-btn .icon{font-size:18px;line-height:1}.nav-btn .icon svg{width:18px;height:18px}
.nav-btn:active{transform:scale(.92)}
.nav-btn.on{color:var(--bl)}
.nav-btn.on .icon{filter:none}

/* Onboarding cards polish */
.onboard-card{border-radius:16px;padding:24px 20px}
.onboard-card:active{transform:scale(.98);transition:transform .1s}

/* KPI card polish */
.kpi{padding:14px}
.kpi-icon{display:inline-block;margin-right:5px;opacity:.85}
.kpi-mom{font-size:9px;font-weight:700;margin-left:6px;padding:1px 5px;border-radius:3px;font-variant-numeric:tabular-nums}
.kpi-mom.up{background:rgba(16,185,129,.14);color:var(--gn)}
.kpi-mom.down{background:rgba(239,68,68,.14);color:var(--rd)}
.kpi-mom.flat{background:var(--c3);color:var(--t3)}
.kpi-sub{font-size:10px;color:var(--t2);margin-top:7px;line-height:1.4;padding-top:5px;border-top:1px solid var(--b1)}

/* Reduce visual weight of decorative elements */
.ai-brief-banner::before,.real-profit-hero::before{opacity:.6}

/* Apply tap haptics on all primary CTAs */
.mbtn,.ex-btn:not(.del),.tk-add-btn,.connect-btn{cursor:pointer;-webkit-tap-highlight-color:transparent}

/* Smooth scrolling */
html{scroll-behavior:smooth}

/* Disable selection on chrome/UI elements (keep on text content) */
.nav,.sidebar,.hdr,.tk-group-head,.cl-name,.kpi-label,.cl-meta{-webkit-user-select:none;user-select:none}
.modal,.task-desc,.notes-textarea,textarea,input{-webkit-user-select:text;user-select:text}

/* END v2.10.3 POLISH */


/* Mobile: tap health dot to show tooltip before navigating */
@media (max-width:900px){
  .hd-tip{pointer-events:none;opacity:0;transition:opacity .2s}
  .hd-wrap.tapped .hd-tip{opacity:1;pointer-events:auto}
}

/* Enhanced mobile app feel — v2.17.12: tighter card spacing, slicker tap feedback,
   smoother transitions, and consistent rounded corners across every Overview card. */
@media (max-width:900px){
  html{scroll-behavior:smooth;-webkit-overflow-scrolling:touch}
  body{overscroll-behavior-y:contain}
  .card{-webkit-tap-highlight-color:transparent;touch-action:manipulation;border-radius:12px}
  .nav-btn{min-height:44px;min-width:44px}
  .app{padding-left:12px;padding-right:12px}
  .card,.kpi,.client{transition:transform .18s cubic-bezier(.2,.8,.3,1),opacity .15s ease,box-shadow .2s ease}
  .card:active{transform:scale(.985);opacity:.92}
  .card[onclick]:active{box-shadow:0 1px 6px rgba(0,0,0,.16)}
  /* Hero cards — punchier on mobile */
  #t-ov .col-main > .card{margin-bottom:8px}
  .real-profit-hero{padding:14px 16px}
  .rp-val{font-size:30px!important;letter-spacing:-1px!important}
  /* KPI grid — tighter 2-col, smoother values */
  .kpi-grid{gap:8px!important}
  .card.kpi{padding:10px 12px;border-radius:12px}
  .kpi-val{font-size:18px;letter-spacing:-.4px}
  .kpi-label{font-size:10px;letter-spacing:.4px}
  .kpi-sub{font-size:9.5px;line-height:1.35}
  /* Money Today / Mercury Cash Flow — pull headers in tight */
  .money-today-hero{padding:12px 14px!important}
  /* Sub headers on overview */
  #t-ov .sec h3{font-size:13px}
  /* Animation respects reduced-motion */
  @media (prefers-reduced-motion:reduce){
    .card,.kpi,.client{transition:none}
    .card:active{transform:none}
  }
}
/* Standalone (added to home screen) enhancements */
@media (display-mode:standalone){
  body{padding-top:env(safe-area-inset-top)}
  .hdr{padding-top:calc(env(safe-area-inset-top,20px) + 8px)}
  .nav{padding-bottom:env(safe-area-inset-bottom,8px)}
}

/* One-time revenue asterisk on profit hero */
.rp-onetime-note{display:inline-block;position:relative;cursor:help}
.rp-onetime-note .rp-ast{color:var(--cy);font-size:22px;font-weight:900;vertical-align:super;margin-left:2px}
.rp-onetime-note .rp-ast-tip{position:absolute;bottom:100%;left:50%;transform:translateX(-50%);background:var(--c2);border:1px solid var(--b1);border-radius:8px;padding:8px 12px;font-size:11px;color:var(--t2);white-space:nowrap;pointer-events:none;opacity:0;transition:opacity .2s;z-index:50;box-shadow:0 4px 12px rgba(0,0,0,.3);font-family:Inter,system-ui}
.rp-onetime-note:hover .rp-ast-tip,.rp-onetime-note.tapped .rp-ast-tip{opacity:1;pointer-events:auto}
.rp-ast-tip b{color:var(--cy);font-family:'JetBrains Mono'}
.rp-ast-tip .rp-ast-recurring{color:var(--gn)}

/* Effective hourly rate per client */
.cl-hourly{display:flex;align-items:center;gap:6px;margin-top:6px;padding:4px 0}
.cl-hourly-rate{font-family:'JetBrains Mono';font-size:12px;font-weight:700;color:var(--cy)}
.cl-hourly-rate.great{color:var(--gn)}
.cl-hourly-rate.low{color:var(--gd)}
.cl-hourly-rate.bad{color:var(--rd)}
.cl-hourly-label{font-size:9px;color:var(--t4)}
.cl-hourly-hrs{font-size:10px;color:var(--t3);cursor:pointer;border-bottom:1px dashed var(--t4);padding:0 2px}
.cl-hourly-hrs:hover{color:var(--cy)}

/* Client LTV */
.cl-ltv{display:flex;align-items:center;gap:6px;margin-top:4px;padding:2px 0}
.cl-ltv-label{font-size:9px;color:var(--t4);text-transform:uppercase;letter-spacing:.5px}
.cl-ltv-val{font-family:'JetBrains Mono';font-size:11px;font-weight:700;color:var(--pp)}
.cl-ltv-months{font-size:9px;color:var(--t4)}
/* Revenue concentration warning */
.conc-warn{display:flex;align-items:center;gap:6px;padding:8px 12px;border-radius:8px;font-size:11px;margin-top:8px}
.conc-warn.high{background:rgba(239,68,68,.08);border:1px solid rgba(239,68,68,.2);color:var(--rd)}
.conc-warn.med{background:rgba(251,191,36,.08);border:1px solid rgba(251,191,36,.2);color:var(--gd)}
.conc-warn.ok{background:rgba(16,185,129,.06);border:1px solid rgba(16,185,129,.15);color:var(--gn)}
/* Goal pace indicator */
.goal-pace{font-size:10px;margin-top:4px;font-weight:600}
.goal-pace.ahead{color:var(--gn)}
.goal-pace.behind{color:var(--rd)}
.goal-pace.ontrack{color:var(--cy)}
/* Expense run rate */
.exp-runrate{font-size:10px;color:var(--t3);margin-top:4px;display:flex;align-items:center;gap:4px}
.exp-runrate b{font-family:'JetBrains Mono';color:var(--rd);font-weight:700}

/* v2.16.60: polished iOS-style calendar modal */
.cal-overlay{position:fixed;inset:0;z-index:300;background:rgba(0,0,0,.65);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);display:flex;align-items:flex-end;justify-content:center;animation:calFade .25s ease-out both}
@media(min-width:700px){.cal-overlay{align-items:center}}
.cal-sheet{background:var(--c1);width:100%;max-width:760px;max-height:92vh;border-radius:16px 16px 0 0;display:flex;flex-direction:column;overflow:hidden;box-shadow:0 -10px 60px rgba(0,0,0,.5);animation:calSlide .35s cubic-bezier(.16,1,.3,1) both}
@media(min-width:700px){.cal-sheet{border-radius:16px;max-height:88vh}}
.cal-head{padding:14px 16px;border-bottom:1px solid var(--b1);display:flex;align-items:center;justify-content:space-between;gap:10px;flex-shrink:0}
.cal-head h2{margin:0;font-size:18px;font-weight:800;letter-spacing:-.4px}
.cal-mode-pills{display:flex;background:var(--c3);border-radius:8px;padding:3px;gap:0}
.cal-mode-pills button{background:transparent;border:none;color:var(--t3);font-family:Inter;font-size:11px;font-weight:700;padding:5px 10px;border-radius:6px;cursor:pointer;letter-spacing:.2px;transition:all .15s}
.cal-mode-pills button.on{background:var(--c1);color:var(--t1);box-shadow:0 1px 2px rgba(0,0,0,.2)}
.cal-nav{display:flex;align-items:center;gap:8px;padding:10px 16px;border-bottom:1px solid var(--b1);flex-shrink:0}
.cal-nav .cal-nav-btn{background:var(--c3);border:1px solid var(--b1);color:var(--t1);width:32px;height:32px;border-radius:8px;cursor:pointer;font-size:14px;font-weight:700;display:inline-flex;align-items:center;justify-content:center}
.cal-nav .cal-nav-title{flex:1;text-align:center;font-size:14px;font-weight:700;color:var(--t1);letter-spacing:-.2px}
.cal-nav .cal-today-btn{background:transparent;border:1px solid var(--b1);color:var(--bl);font-size:11px;font-weight:700;padding:6px 10px;border-radius:8px;cursor:pointer}
.cal-filter{display:flex;gap:6px;padding:8px 16px;border-bottom:1px solid var(--b1);overflow-x:auto;flex-shrink:0}
.cal-filter button{background:var(--c3);border:1px solid var(--b1);color:var(--t3);font-size:10px;font-weight:700;padding:5px 9px;border-radius:6px;cursor:pointer;white-space:nowrap;letter-spacing:.3px}
.cal-filter button.on{background:rgba(96,165,250,.14);color:var(--bl);border-color:rgba(96,165,250,.32)}
.cal-body{flex:1;overflow-y:auto;-webkit-overflow-scrolling:touch}
/* v2.17.13: cal-body inside the inline tab — let the page scroll, drop the modal-style flex/overflow,
   tighten padding so the week/month grids reach edge-to-edge on mobile. */
#t-cal .cal-body{flex:0 1 auto;overflow:visible;padding:0}
#t-cal .cal-mode-pills,
#t-cal .cal-nav,
#t-cal .cal-filter{padding:0;border:none}
#t-cal .cal-nav{display:flex;justify-content:space-between;align-items:center;gap:8px}
#t-cal .cal-filter{flex-wrap:wrap}
/* Month grid */
.cal-mgrid{display:grid;grid-template-columns:repeat(7,1fr);border-top:1px solid var(--b1)}
.cal-mhdr{padding:6px 4px;font-size:9px;font-weight:700;color:var(--t4);text-transform:uppercase;letter-spacing:.6px;text-align:center;border-bottom:1px solid var(--b1);border-right:1px solid var(--b1)}
.cal-mhdr:last-child{border-right:none}
.cal-mday{min-height:72px;padding:5px;border-bottom:1px solid var(--b1);border-right:1px solid var(--b1);position:relative;font-size:11px;display:flex;flex-direction:column;gap:2px;cursor:pointer;transition:background .12s}
.cal-mday:nth-child(7n){border-right:none}
.cal-mday:hover{background:rgba(255,255,255,.02)}
.cal-mday.cal-other-month{opacity:.35}
.cal-mday.cal-today{background:rgba(96,165,250,.06)}
.cal-mday-num{font-weight:700;color:var(--t2);font-size:11px;font-family:'JetBrains Mono';font-variant-numeric:tabular-nums}
.cal-mday.cal-today .cal-mday-num{background:var(--bl);color:#fff;width:20px;height:20px;border-radius:50%;display:inline-flex;align-items:center;justify-content:center;font-size:10px}
.cal-mday-evt{font-size:9px;background:var(--c3);color:var(--t1);border-radius:3px;padding:1px 4px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;border-left:2px solid var(--bl)}
.cal-mday-evt.cal-task{border-left-color:var(--pp);background:rgba(168,85,247,.08)}
.cal-mday-evt.cal-task.cal-overdue{border-left-color:var(--rd);background:rgba(239,68,68,.10)}
.cal-mday-evt.cal-task.cal-p1{border-left-color:var(--rd)}
.cal-mday-more{font-size:9px;color:var(--t4);font-weight:600;font-style:italic}
/* Week view */
/* v2.17.47: week view cleanup — equal column heights via grid-auto-rows + scrollable
   per-column body so a busy Monday doesn't stretch the whole week down 16 rows. */
.cal-week{display:grid;grid-template-columns:repeat(7,minmax(0,1fr));gap:1px;background:var(--b1);border-top:1px solid var(--b1);border-radius:10px;overflow:hidden}
.cal-wcol{background:var(--c1);min-height:420px;max-height:560px;display:flex;flex-direction:column;overflow:hidden}
.cal-wcol.is-today{background:rgba(96,165,250,.04)}
.cal-whdr{padding:9px 6px 7px;font-size:9px;color:var(--t3);font-weight:700;text-align:center;border-bottom:1px solid var(--b1);text-transform:uppercase;letter-spacing:.7px;flex-shrink:0}
.cal-whdr.is-today{color:var(--bl)}
.cal-whdr-day{font-family:'JetBrains Mono';font-size:17px;color:var(--t1);font-weight:800;display:block;margin-top:3px;font-variant-numeric:tabular-nums}
.cal-whdr.is-today .cal-whdr-day{background:var(--bl);color:#fff;width:28px;height:28px;border-radius:50%;display:inline-flex;align-items:center;justify-content:center;font-size:13px;margin:3px auto 0}
.cal-wbody{padding:6px 5px;display:flex;flex-direction:column;gap:4px;overflow-y:auto;flex:1;-webkit-overflow-scrolling:touch;scrollbar-width:thin}
.cal-wbody::-webkit-scrollbar{width:4px}
.cal-wbody::-webkit-scrollbar-thumb{background:var(--b2);border-radius:2px}
.cal-wempty{color:var(--t4);font-size:13px;padding:14px 4px;text-align:center;font-weight:400;opacity:.5}
.cal-wmore{font-size:10px;color:var(--bl);font-weight:700;padding:5px 6px;text-align:center;cursor:pointer;background:rgba(96,165,250,.06);border:1px dashed rgba(96,165,250,.25);border-radius:4px;margin-top:auto;flex-shrink:0;transition:background .15s}
.cal-wmore:hover{background:rgba(96,165,250,.14)}
.cal-wevt{background:var(--c3);border-left:3px solid var(--bl);border-radius:4px;padding:5px 6px;font-size:10px;line-height:1.3;cursor:pointer}
.cal-wevt.cal-task{border-left-color:var(--pp);background:rgba(168,85,247,.08)}
.cal-wevt.cal-task.cal-overdue{border-left-color:var(--rd)}
.cal-wevt.cal-task.cal-p1{border-left-color:var(--rd);font-weight:700}
.cal-wevt-time{color:var(--t3);font-family:'JetBrains Mono';font-size:9px;font-weight:600}
.cal-wevt-title{color:var(--t1);font-weight:600;margin-top:1px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
/* Agenda day-list view */
.cal-agenda{padding:10px}
.cal-agenda-day{margin-bottom:14px}
.cal-agenda-dhdr{font-size:11px;font-weight:800;color:var(--t2);text-transform:uppercase;letter-spacing:.8px;padding:6px 0 4px;border-bottom:1px solid var(--b1);margin-bottom:6px;display:flex;justify-content:space-between}
.cal-agenda-dhdr.is-today{color:var(--bl)}
/* v2.16.82: agenda rows are now compact + tap-to-expand on every viewport.
   Title truncates to a single line; tap toggles .open which reveals time/meta/desc. */
.cal-agenda-row{display:flex;gap:10px;align-items:flex-start;padding:8px 4px;border-radius:8px;cursor:pointer;transition:background .12s}
.cal-agenda-row:hover{background:rgba(255,255,255,.02)}
.cal-agenda-row.open{background:rgba(96,165,250,.06)}
.cal-agenda-time{font-family:'JetBrains Mono';font-size:10px;color:var(--t3);width:48px;font-variant-numeric:tabular-nums;flex-shrink:0;font-weight:600}
.cal-agenda-bar{width:3px;border-radius:2px;background:var(--bl);align-self:stretch;flex-shrink:0;min-height:18px}
.cal-agenda-bar.cal-task{background:var(--pp)}
.cal-agenda-bar.cal-overdue{background:var(--rd)}
.cal-agenda-bar.cal-p1{background:var(--rd)}
.cal-agenda-content{flex:1;min-width:0}
.cal-agenda-title{font-size:13px;font-weight:600;color:var(--t1);line-height:1.4;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.cal-agenda-row.open .cal-agenda-title{white-space:normal;overflow:visible;text-overflow:clip}
.cal-agenda-meta{font-size:10px;color:var(--t3);margin-top:2px;display:flex;gap:6px;align-items:center;flex-wrap:wrap}
.cal-agenda-row .cal-agenda-detail{display:none;margin-top:6px;padding:8px 10px;background:var(--c2);border:1px solid var(--b1);border-radius:8px;font-size:11px;line-height:1.5;color:var(--t2);white-space:pre-wrap;word-break:break-word}
.cal-agenda-row.open .cal-agenda-detail{display:block}
.cal-agenda-chev{color:var(--t4);font-size:10px;flex-shrink:0;margin-left:4px;transition:transform .15s}
.cal-agenda-row.open .cal-agenda-chev{transform:rotate(90deg)}
.cal-empty{padding:32px 16px;text-align:center;color:var(--t4);font-size:12px}
@keyframes calFade{from{opacity:0}to{opacity:1}}
@keyframes calSlide{from{transform:translateY(20%);opacity:0}to{transform:translateY(0);opacity:1}}

/* v2.16.63: Expenses tab visual polish — cleaner rows, better hierarchy */
#t-ex .card { padding: 16px 18px }
#t-ex h3 { font-size:13px; font-weight:800; letter-spacing:-.2px }
#t-ex .ex-mre-row, #t-ex .ex-stmt-row {
  display:flex; align-items:center; gap:10px; padding:10px 12px;
  background:var(--c2); border:1px solid var(--b1); border-radius:10px;
  margin-bottom:6px; transition: border-color .15s, background .15s;
}
#t-ex .ex-mre-row:hover, #t-ex .ex-stmt-row:hover { border-color: var(--b2) }
#t-ex .ex-mre-row input[type="checkbox"], #t-ex .ex-stmt-row input[type="checkbox"] { width:16px; height:16px; cursor:pointer; accent-color:var(--bl) }
#t-ex .ex-mre-row input[type="text"], #t-ex .ex-stmt-row input[type="text"] {
  flex:1; min-width:120px; background:transparent; border:none; color:var(--t1);
  font-family:Inter; font-size:13px; font-weight:600; padding:2px 0; outline:none;
}
#t-ex .ex-mre-row input[type="number"], #t-ex .ex-stmt-row input[type="number"] {
  width:88px; background:var(--c3); border:1px solid var(--b1); border-radius:7px;
  padding:5px 9px; color:var(--t1); font-family:'JetBrains Mono'; font-size:12px;
  text-align:right; font-weight:700; outline:none; transition: border-color .15s;
}
#t-ex .ex-mre-row input[type="number"]:focus, #t-ex .ex-stmt-row input[type="number"]:focus { border-color: var(--bl) }
#t-ex .ex-mre-row select, #t-ex .ex-stmt-row select {
  background:var(--c3); border:1px solid var(--b1); border-radius:7px;
  padding:5px 8px; color:var(--t1); font-size:11px; font-weight:600; cursor:pointer;
}
#t-ex .ex-row-x {
  background:transparent; border:none; color:var(--t4); font-size:16px;
  cursor:pointer; padding:4px 6px; border-radius:6px; transition: all .15s;
}
#t-ex .ex-row-x:hover { color:var(--rd); background:rgba(239,68,68,.08) }
#t-ex .split-btn {
  background: rgba(96,165,250,.10); color: var(--bl); border:1px solid rgba(96,165,250,.25);
  border-radius:6px; padding:4px 9px; font-size:10px; font-weight:700; cursor:pointer;
  transition: all .15s;
}
#t-ex .split-btn:hover { background: rgba(96,165,250,.18); border-color:rgba(96,165,250,.4) }
#t-ex .ex-recurring-chip {
  display:inline-flex; align-items:center; gap:4px; font-size:9px; color:var(--pp);
  font-weight:700; text-transform:uppercase; letter-spacing:.4px;
}

/* v2.16.59 refinement #6: overview card reorder mode */
#t-ov.reorder-mode .col-main > [data-card]{position:relative;cursor:grab;border-color:rgba(96,165,250,.4)!important;box-shadow:0 0 0 1px rgba(96,165,250,.4),0 4px 14px rgba(0,0,0,.18)!important;transition:transform .15s}
#t-ov.reorder-mode .col-main > [data-card]:active{cursor:grabbing;transform:scale(.99)}
#t-ov.reorder-mode .col-main > [data-card]::before{content:'⋮⋮';position:absolute;top:8px;right:10px;color:var(--bl);font-size:14px;font-weight:800;letter-spacing:-2px;opacity:.7;z-index:10;pointer-events:none}
#t-ov.reorder-mode .col-main > [data-card].dragging{opacity:.4}
#t-ov.reorder-mode .col-main > [data-card].drop-target{border-color:var(--gn)!important;box-shadow:0 0 0 2px var(--gn)!important}
.reorder-toolbar{position:fixed;bottom:20px;left:50%;transform:translateX(-50%);background:var(--c1);border:1px solid var(--b2);border-radius:12px;padding:10px 14px;display:flex;gap:8px;align-items:center;z-index:120;box-shadow:0 10px 40px rgba(0,0,0,.4);font-size:11px;color:var(--t2);font-weight:600}

/* v2.16.59 refinement #7: month-rollover celebration */
.month-closed-overlay{position:fixed;inset:0;display:flex;align-items:center;justify-content:center;z-index:300;background:rgba(0,0,0,.78);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);animation:mcoFadeIn .3s ease-out both}
.month-closed-overlay .mco-card{background:var(--c2);border:1px solid rgba(16,185,129,.34);border-radius:16px;padding:42px 44px;max-width:380px;width:90%;text-align:center;box-shadow:0 30px 80px rgba(0,0,0,.5);animation:mcoPop .55s cubic-bezier(.34,1.56,.64,1) both;position:relative;overflow:hidden}
.month-closed-overlay .mco-card::before{content:'';position:absolute;inset:-50%;background:transparent;pointer-events:none}
.mco-tag{font-size:10px;font-weight:800;color:var(--gn);text-transform:uppercase;letter-spacing:1.4px;margin-bottom:8px;position:relative;z-index:1}
.mco-month{font-size:14px;color:var(--t2);font-weight:600;margin-bottom:14px;position:relative;z-index:1}
.mco-num{font-family:'JetBrains Mono';font-size:42px;font-weight:900;color:var(--gn);line-height:1;letter-spacing:-1.5px;font-variant-numeric:tabular-nums;position:relative;z-index:1;animation:mcoCount .9s ease-out both}
.mco-sub{font-size:11px;color:var(--t3);margin-top:10px;line-height:1.5;position:relative;z-index:1}
.mco-actions{display:flex;gap:8px;margin-top:22px;position:relative;z-index:1}
.mco-confetti{position:absolute;width:10px;height:10px;border-radius:2px;animation:mcoConf 2.4s ease-in-out forwards;z-index:0}
@keyframes mcoFadeIn{from{opacity:0}to{opacity:1}}
@keyframes mcoPop{from{transform:scale(.7);opacity:0}to{transform:scale(1);opacity:1}}
@keyframes mcoCount{from{transform:scale(.4);opacity:0}to{transform:scale(1);opacity:1}}
@keyframes mcoConf{from{transform:translate(0,0) rotate(0deg);opacity:1}to{transform:translate(var(--dx),var(--dy)) rotate(720deg);opacity:0}}

/* v2.16.59 (refinement #1): sticky mini-bar — visible after Real Profit hero scrolls out of view */
.sticky-bar{position:fixed;top:0;left:0;right:0;background:color-mix(in srgb,var(--c1) 92%,transparent);backdrop-filter:saturate(180%) blur(14px);-webkit-backdrop-filter:saturate(180%) blur(14px);border-bottom:1px solid var(--b1);padding:8px 16px;display:flex;align-items:center;gap:14px;z-index:90;transform:translateY(-100%);transition:transform .25s ease-out;font-size:11px;font-variant-numeric:tabular-nums}
:root[data-theme="apple"] .sticky-bar{background:rgba(255,255,255,.92);border-bottom-color:rgba(60,60,67,.12)}
.sticky-bar.show{transform:translateY(0)}
.sticky-bar .sb-item{display:flex;flex-direction:column;line-height:1.1}
.sticky-bar .sb-lbl{font-size:8px;color:var(--t4);font-weight:700;text-transform:uppercase;letter-spacing:.6px}
.sticky-bar .sb-val{font-family:'JetBrains Mono';font-size:14px;font-weight:800;color:var(--t1)}
.sticky-bar .sb-val.green{color:var(--gn)}
.sticky-bar .sb-val.red{color:var(--rd)}
.sticky-bar .sb-val.muted{color:var(--t3)}
.sticky-bar .sb-sep{width:1px;height:24px;background:var(--b1)}
.sticky-bar .sb-up{margin-left:auto;background:transparent;border:none;color:var(--bl);cursor:pointer;font-size:11px;font-weight:700;display:flex;align-items:center;gap:4px}
@media(max-width:560px){.sticky-bar{padding:6px 10px;gap:8px}.sticky-bar .sb-val{font-size:12px}.sticky-bar .sb-lbl{font-size:7px}}

/* v2.16.59: Smart Focus — gamified task UI animations */
.sf-group{background:var(--c2);border:1px solid var(--b1);border-radius:12px;overflow:hidden;animation:sfSlideIn .35s ease-out both}
.sf-group-head{display:flex;align-items:center;gap:8px;padding:9px 12px;background:rgba(255,255,255,.02);border-bottom:1px solid var(--b1);cursor:pointer;user-select:none}
.sf-group-head .sf-logo{width:22px;height:22px;border-radius:6px;background:var(--bl);display:flex;align-items:center;justify-content:center;color:#fff;font-weight:800;font-size:10px;flex-shrink:0}
.sf-group-name{font-size:12px;font-weight:700;color:var(--t1);flex:1}
.sf-group-count{font-size:10px;color:var(--t3);font-family:JetBrains Mono;background:var(--c3);padding:2px 6px;border-radius:5px}
.sf-task{display:flex;align-items:flex-start;gap:10px;padding:10px 12px;border-bottom:1px solid var(--b1);cursor:pointer;transition:all .25s ease;position:relative}
.sf-task:last-child{border-bottom:none}
.sf-task:hover{background:rgba(255,255,255,.02)}
.sf-task .sf-check{width:20px;height:20px;border:2px solid var(--t4);border-radius:50%;flex-shrink:0;margin-top:1px;display:flex;align-items:center;justify-content:center;transition:all .2s;background:transparent;cursor:pointer}
.sf-task .sf-check svg{width:12px;height:12px;stroke-dasharray:30;stroke-dashoffset:30;transition:stroke-dashoffset .35s ease}
.sf-task .sf-content{flex:1;min-width:0}
.sf-task .sf-text{font-size:12px;font-weight:600;color:var(--t1);line-height:1.4;transition:color .25s,text-decoration-color .25s}
.sf-task .sf-meta{font-size:9px;color:var(--t4);margin-top:3px;display:flex;gap:6px;flex-wrap:wrap;align-items:center}
.sf-pri{font-weight:800;font-size:9px;padding:1px 5px;border-radius:4px;letter-spacing:.3px}
.sf-pri-5{background:rgba(239,68,68,.18);color:var(--rd)}
.sf-pri-4{background:rgba(249,115,22,.18);color:var(--or)}
.sf-pri-3{background:rgba(251,191,36,.16);color:var(--gd)}
.sf-pri-2{background:rgba(96,165,250,.14);color:var(--bl)}
.sf-pri-1{background:rgba(255,255,255,.05);color:var(--t3)}
.sf-task.done{opacity:.5;animation:sfDone .55s ease both}
.sf-task.done .sf-text{color:var(--t3);text-decoration:line-through;text-decoration-color:var(--t3)}
.sf-task.done .sf-check{border-color:var(--gn);background:var(--gn)}
.sf-task.done .sf-check svg{stroke:#fff;stroke-dashoffset:0}
.sf-task.done::after{content:'✓ done';position:absolute;right:14px;top:50%;transform:translateY(-50%);font-size:10px;color:var(--gn);font-weight:800;animation:sfBadge .55s ease both;letter-spacing:.5px}
@keyframes sfSlideIn{from{transform:translateY(8px);opacity:0}to{transform:translateY(0);opacity:1}}
@keyframes sfDone{0%{transform:scale(1)}30%{transform:scale(.985)}100%{transform:scale(1)}}
@keyframes sfBadge{0%{transform:translateY(-50%) scale(.5);opacity:0}50%{transform:translateY(-50%) scale(1.2);opacity:1}100%{transform:translateY(-50%) scale(1);opacity:1}}
.sf-burst{position:absolute;pointer-events:none;width:60px;height:60px;left:0;top:0;animation:sfBurst .6s ease-out both}
.sf-burst::before,.sf-burst::after{content:'';position:absolute;width:6px;height:6px;border-radius:50%;background:var(--gn);left:8px;top:8px}
.sf-burst::before{animation:sfBurstA .55s ease-out both}
.sf-burst::after{animation:sfBurstB .55s ease-out both}
@keyframes sfBurst{from{opacity:1}to{opacity:0}}
@keyframes sfBurstA{from{transform:translate(0,0)}to{transform:translate(20px,-12px)}}
@keyframes sfBurstB{from{transform:translate(0,0)}to{transform:translate(-18px,16px)}}

/* v2.17.9 → v2.19.5: DESKTOP col-side reorder — Weather → Calendar → Dream Big → Balances → Runway → rest. */
@media (min-width:900px){
 #t-ov .col-side > #wxPro      {order:1}
 #t-ov .col-side > #gcalCard   {order:2}
 #t-ov .col-side > #commCard   {order:3}
 #t-ov .col-side > #balGrid    {order:4}
 #t-ov .col-side > #runwayCard {order:5}
 #t-ov .col-side > *           {order:6}
}

/* v2.17.3: DESKTOP reorder for col-main only (right column / col-side untouched).
   Revenue MTD hero FIRST → Capture Idea → Todoist Quick-Add → KPIs (Clients, One-Time) → Money Today → rest.
   v2.22 layout order: realProfitHero first, then kpi-grid (Clients first, One-Time second). */
@media (min-width:900px){
 #t-ov .col-main > #syncReminderWrap            {order:0}
 #t-ov .col-main > .real-profit-hero             {order:1}
 #t-ov .col-main > #quoteCard                   {order:2}
 #t-ov .col-main > #captureCollapsedRow         {order:3}
 #t-ov .col-main > #capturePair                 {order:3}
 #t-ov .col-main > #captureIdeaCard             {order:3}
 #t-ov .col-main > #overviewTodoistQuickAdd     {order:4}
 #t-ov .col-main > .kpi-grid                    {order:5}
 #t-ov .col-main > #moneyTodayHero              {order:6}
 #t-ov .col-main > #mercuryCashFlowCard         {order:7}
 #t-ov .col-main > .profit-margin-goal-card     {order:8}
 #t-ov .col-main > #aiPulseCard                 {order:9}
 #t-ov .col-main > .quick-cap-card              {order:10}
 #t-ov .col-main > #concRisk                    {order:11}
 #t-ov .col-main > .card                         {order:90}
 /* v2.17.49: goals + alerts at the very bottom (under 90-day cash projection too) */
 #t-ov .col-main > #cashFlowCard                {order:99}
 #t-ov .col-main > #goalsTracker                {order:100}
 #t-ov .col-main > #alertsContainer             {order:101}
}

/* v2.16.58: mobile-only reorder of Overview cards.
   v2.22: Revenue MTD hero first, then Capture Idea > Weather > KPIs > Profit Margin > Money Today > Balances > Cash Radar > rest. */
@media (max-width:899px){
 #t-ov .col-main{display:flex;flex-direction:column}
 #t-ov .col-main > #syncReminderWrap            {order:0}
 #t-ov .col-main > .real-profit-hero             {order:1}
 #t-ov .col-main > #captureCollapsedRow         {order:2}
 #t-ov .col-main > #capturePair                 {order:2}
 #t-ov .col-main > #captureIdeaCard             {order:2}
 #t-ov .col-main > #wxPro                       {order:3}
 #t-ov .col-main > .kpi-grid                    {order:4}
 #t-ov .col-main > .profit-margin-goal-card     {order:5}
 #t-ov .col-main > #moneyTodayHero              {order:6}
 #t-ov .col-main > .bal-grid                    {order:7}
 #t-ov .col-main > #cashRadarCard               {order:8}
 #t-ov .col-main > #mercuryCashFlowCard         {order:9}
 #t-ov .col-main > #cashFlowCard                {order:10}
 #t-ov .col-main > #aiPulseCard                 {order:11}
 #t-ov .col-main > .quick-cap-card              {order:12}
 #t-ov .col-main > #concRisk                    {order:13}
 /* Quote (no class) and any remaining cards default to order:14 */
 #t-ov .col-main > .card                         {order:14}
 /* v2.17.49: goals + alerts at the very bottom on mobile too */
 #t-ov .col-main > #goalsTracker                {order:50}
 #t-ov .col-main > #alertsContainer             {order:51}
 #t-ov .col-main > #captureIdeaCard,
 #t-ov .col-main > #wxPro,
 #t-ov .col-main > .real-profit-hero,
 #t-ov .col-main > .kpi-grid,
 #t-ov .col-main > .profit-margin-goal-card,
 #t-ov .col-main > #moneyTodayHero,
 #t-ov .col-main > .bal-grid,
 #t-ov .col-main > #cashRadarCard,
 #t-ov .col-main > #mercuryCashFlowCard,
 #t-ov .col-main > #cashFlowCard,
 #t-ov .col-main > #aiPulseCard,
 #t-ov .col-main > .quick-cap-card{flex:0 0 auto}
}

/* v2.16.57 (UI uniformity): canonical button + utility kit. Use these instead of inline styles. */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;font-family:Inter;font-size:11px;font-weight:700;letter-spacing:.2px;padding:8px 14px;border-radius:8px;cursor:pointer;border:1px solid transparent;transition:all .15s;white-space:nowrap;line-height:1}
.btn:active{transform:scale(.97)}
.btn-sm{font-size:10px;padding:6px 10px;border-radius:6px}
.btn-xs{font-size:9px;padding:4px 8px;border-radius:6px}
.btn-pri{background:var(--bl);color:#fff;border-color:transparent;box-shadow:0 1px 2px rgba(0,0,0,.06)}
.btn-pri:hover{filter:brightness(1.05)}
.btn-sec{background:var(--c3);color:var(--t1);border-color:var(--b1)}
.btn-sec:hover{border-color:var(--b2);background:var(--c2)}
.btn-gh{background:transparent;color:var(--t2);border-color:var(--b1)}
.btn-gh:hover{color:var(--t1);border-color:var(--b2);background:var(--c2)}
.btn-success{background:rgba(16,185,129,.10);color:var(--gn);border-color:rgba(16,185,129,.28)}
.btn-success:hover{background:rgba(16,185,129,.18)}
.btn-warn{background:rgba(251,191,36,.10);color:var(--gd);border-color:rgba(251,191,36,.28)}
.btn-warn:hover{background:rgba(251,191,36,.18)}
.btn-danger{background:rgba(239,68,68,.10);color:var(--rd);border-color:rgba(239,68,68,.28)}
.btn-danger:hover{background:rgba(239,68,68,.18)}
.btn-info{background:rgba(6,182,212,.10);color:var(--cy);border-color:rgba(6,182,212,.28)}
.btn-info:hover{background:rgba(6,182,212,.18)}

/* Utility classes — use instead of inline flex/spacing */
.row{display:flex;align-items:center;gap:8px}
.row-between{display:flex;align-items:center;justify-content:space-between;gap:8px}
.row-end{display:flex;align-items:center;justify-content:flex-end;gap:8px}
.stack{display:flex;flex-direction:column;gap:8px}
.stack-tight{display:flex;flex-direction:column;gap:4px}
.muted{color:var(--t3)}
.dim{color:var(--t4)}
.mono{font-family:'JetBrains Mono';font-variant-numeric:tabular-nums}
.label{font-size:10px;font-weight:700;color:var(--t3);text-transform:uppercase;letter-spacing:.6px}

/* Standardize section badges/chips */
.chip{display:inline-flex;align-items:center;gap:4px;font-size:10px;font-weight:700;padding:3px 8px;border-radius:5px;border:1px solid var(--b1);background:var(--c3);color:var(--t2)}
.chip-success{background:rgba(16,185,129,.10);color:var(--gn);border-color:rgba(16,185,129,.25)}
.chip-warn{background:rgba(251,191,36,.10);color:var(--gd);border-color:rgba(251,191,36,.25)}
.chip-danger{background:rgba(239,68,68,.10);color:var(--rd);border-color:rgba(239,68,68,.25)}
.chip-info{background:rgba(6,182,212,.10);color:var(--cy);border-color:rgba(6,182,212,.25)}
/* ch = client health score */
.ch-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px}
@media(min-width:420px){.ch-grid{grid-template-columns:repeat(auto-fill,minmax(190px,1fr))}}
.ch-card{display:flex;align-items:flex-start;gap:10px;padding:10px 12px;border:1px solid var(--b1);border-radius:12px;background:var(--c4);transition:border-color .2s}
.ch-card:hover{border-color:var(--b2)}
.ch-dot{width:9px;height:9px;border-radius:50%;flex-shrink:0;margin-top:3px}
.ch-dot.green{background:var(--gn);box-shadow:0 0 8px rgba(16,185,129,.35)}
.ch-dot.yellow{background:var(--gd);box-shadow:0 0 7px rgba(251,191,36,.4)}
.ch-dot.red{background:var(--rd);animation:chPulse 2s infinite}
@keyframes chPulse{0%,100%{box-shadow:0 0 0 0 rgba(239,68,68,.5)}50%{box-shadow:0 0 0 5px rgba(239,68,68,0)}}
.ch-name{font-size:11px;font-weight:700;color:var(--t1);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;margin-bottom:3px}
.ch-mrr{font-family:'JetBrains Mono';font-size:13px;font-weight:700;color:var(--t1);letter-spacing:-.4px}
.ch-sub{font-size:10px;color:var(--t3);margin-top:2px}

/* ================================================================
   v2.24.0 — Accessibility & notification improvements
   ================================================================ */

/* 1. Global focus-visible ring for keyboard/screen-reader users */
:focus-visible{outline:2px solid var(--bl);outline-offset:2px;border-radius:4px}
button:focus-visible,.filter-chip:focus-visible,.nav-btn:focus-visible,.notif-bell:focus-visible,.side-btn:focus-visible{outline:2px solid var(--bl);outline-offset:2px}

/* 2. Inactive chip / filter contrast boost — was too faint */
.filter-chip{color:var(--t1);border-color:var(--b2)}
.prj-fchip{color:var(--t2)}
.target-chip{color:var(--t1)}

/* 3. prefers-reduced-motion: kill ALL animations/transitions site-wide */
@media(prefers-reduced-motion:reduce){
 *,*::before,*::after{animation-duration:0.01ms!important;animation-iteration-count:1!important;transition-duration:0.01ms!important;scroll-behavior:auto!important}
 .notif-bell.has-unread{animation:none!important}
 .notif-card{animation:none!important}
 .notif-pane.open{animation:none!important}
 .boot-first .card,.boot-first .kpi-val,.boot-first .donut-fg,.boot-first .cl-profit-fill{animation:none!important}
 .tab.on{animation:none!important}
 .hd.bleeding{animation:none!important}
 .mco-confetti{animation:none!important}
 .sf-group{animation:none!important}
}

/* 4. Notification filter tabs */
.notif-filter-row{display:flex;gap:4px;margin-bottom:8px;padding:0 2px}
.notif-filter{background:color-mix(in srgb,var(--c3) 88%,#fff 12%);border:1px solid var(--b2);border-radius:8px;padding:5px 10px;font-family:Inter;font-size:10px;font-weight:800;color:var(--t2);cursor:pointer;transition:all .15s;min-height:32px}
.notif-filter:hover{color:var(--t1);border-color:var(--b2)}
.notif-filter.on{background:var(--bl);color:#fff;border-color:var(--bl)}

/* 5. Notification review button */
.notif-review-btn{background:transparent;border:1px solid var(--b1);border-radius:6px;padding:4px 8px;font-family:Inter;font-size:9px;font-weight:700;color:var(--bl);cursor:pointer;margin-top:4px;transition:all .15s;min-height:28px}
.notif-review-btn:hover{background:rgba(59,130,246,.08);border-color:var(--bl)}

/* 6. Notification type label (visible text, not color-only) */
.notif-type-label{font-size:9px;font-weight:700;text-transform:uppercase;letter-spacing:.4px;padding:1px 5px;border-radius:4px;display:inline-block;margin-bottom:2px}
.notif-type-label.money{background:rgba(251,191,36,.12);color:var(--gd)}
.notif-type-label.task{background:rgba(59,130,246,.10);color:var(--bl)}

/* 7. Agent status text (not dot-color-only) */
.dk-agent-status{font-size:9px;font-weight:700;text-transform:uppercase;letter-spacing:.4px;padding:1px 6px;border-radius:4px;display:inline-flex;align-items:center;gap:4px}
.dk-agent-status.active{background:rgba(16,185,129,.10);color:var(--gn)}
.dk-agent-status.down{background:rgba(239,68,68,.10);color:var(--rd)}
.dk-agent-status.waiting{background:rgba(251,191,36,.10);color:var(--gd)}
.dk-agent-status.quiet{background:var(--c3);color:var(--t3)}

/* 8. Recent activity action buttons */
.dk-disp-actions{display:flex;gap:6px;margin-top:6px}
.dk-disp-actions button{background:transparent;border:1px solid var(--b1);color:var(--t2);font-family:Inter;font-size:10px;font-weight:700;padding:5px 10px;border-radius:7px;cursor:pointer;min-height:32px;transition:all .15s}
.dk-disp-actions button:hover{border-color:var(--b2);color:var(--t1)}
.dk-disp-actions button.dk-complete-btn{color:var(--gn);border-color:rgba(16,185,129,.3)}
.dk-disp-actions button.dk-complete-btn:hover{border-color:rgba(16,185,129,.6);background:rgba(16,185,129,.06)}

/* 9. Mobile tap targets: ensure 44px min on action controls */
@media(max-width:899px){
 .dk-disp-actions button{min-height:44px;padding:9px 14px;font-size:11px}
 .notif-x{width:44px;height:44px;min-width:44px;min-height:44px;font-size:20px}
 .notif-review-btn{min-height:44px;padding:9px 12px;font-size:11px}
 .notif-filter{min-height:44px;padding:9px 12px;font-size:11px;flex:1;text-align:center}
 .notif-filter-row{gap:8px}
 .dk-act button{min-height:44px}
 .view-toggle button,.filter-chip,.target-chip,.prj-pill,.prj-fchip,.tk-sb-clear,.tk-active-chip button,.tk-star-btn,.prj-icon-btn,.hc-card-min-btn{min-height:44px;min-width:44px}
 .tk-check{width:44px;height:44px;min-width:44px;min-height:44px}
}

/* ═══════════════════════════════════════════════════════════════════════
   v2.24.1: Mobile UX overhaul
   ═══════════════════════════════════════════════════════════════════════ */

/* ── Req 2: Mobile Tasks — collapsed client pills + filter sidebar toggle ── */
@media(max-width:899px){
 /* Client pills: collapsed by default, centered, tap to expand */
 #tkClientPills{flex-wrap:nowrap;overflow:hidden;max-height:42px;justify-content:center;position:relative;transition:max-height .25s ease}
 #tkClientPills.expanded{max-height:500px;flex-wrap:wrap;overflow:visible}
 /* Filter sidebar: hidden by default on mobile, toggle via button */
 .tk-sidebar{display:none}
 .tk-sidebar.mob-open{display:block}
}

/* ── Req 3: Projects mobile — fix header/actions wrapping ── */
@media(max-width:560px){
 #t-prj>.sec{flex-wrap:wrap;gap:6px}
 #t-prj>.sec h3{flex:0 0 auto;font-size:16px}
 #t-prj>.sec .badge{flex:0 0 auto}
 #t-prj>.sec .filter-chip{flex:1 1 auto;min-width:0;font-size:10px;padding:6px 8px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
 .prj-controls{gap:6px}
 .prj-controls .search-input{min-width:0;flex:1 1 100%}
 .prj-filter-row{padding:6px 8px;gap:4px;overflow-x:auto;flex-wrap:nowrap;scrollbar-width:none}
 .prj-filter-row::-webkit-scrollbar{display:none}
 .prj-filter-row .prj-flabel{font-size:8px;flex-shrink:0}
 .prj-filter-row .prj-fchip{font-size:10px;padding:6px 8px;flex-shrink:0;white-space:nowrap}
}

/* ── Req 4: Smooth horizontal Projects board scroll, no doc overflow ── */
.prj-board-wrap{overflow:hidden}
.prj-board{scroll-snap-type:x proximity;scroll-behavior:smooth}
.prj-lane{scroll-snap-align:start}
@media(max-width:520px){
 .prj-board{gap:14px;padding-left:2px;padding-right:2px}
}

/* ── Req 5: Remove Calendar from mobile bottom nav only ── */
@media(max-width:899px){
 .nav .nav-btn[data-t="cal"]{display:none}
}

/* ================================================================
   v2.23.60 (AUDIT STAGE E) — Accessibility: dialog semantics, skip
   link, focus management, keyboard affordances. Additive only — no
   layout/behavior change. Most semantics are injected at runtime by
   a11y-enhancements.js; these are the styles that pair with them.
   ================================================================ */

/* Native scrollbars/inputs follow the active theme (fixes Windows dark-mode
   form controls + scrollbar color). Mirrors the data-theme switch. */
:root,:root[data-theme="harrigan"]{color-scheme:dark}
:root[data-theme="apple"]{color-scheme:light}

/* Skip-to-content link — visually hidden until focused, then pinned top-left.
   Injected as the first focusable node so keyboard users can jump past the nav. */
.skip-link{position:fixed;top:-100px;left:8px;z-index:9999;background:var(--c1);color:var(--t1);border:1px solid var(--b2);border-radius:8px;padding:10px 16px;font-family:Inter;font-size:13px;font-weight:700;text-decoration:none;box-shadow:0 8px 30px rgba(0,0,0,.5);transition:top .15s ease}
.skip-link:focus,.skip-link:focus-visible{top:calc(8px + env(safe-area-inset-top,0px));outline:2px solid var(--bl);outline-offset:2px}

/* Visually-hidden utility — exposes text to screen readers only (e.g. an
   accessible name on an icon-only control that already has a visual glyph). */
.sr-only{position:absolute!important;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}

/* Keyboard-reachable rows that became focusable (role=button + tabindex=0):
   guarantee the global :focus-visible ring is honored even inside scroll lists. */
[role="button"][tabindex="0"]:focus-visible{outline:2px solid var(--bl);outline-offset:-2px;border-radius:6px}
