/* ============ TOKENS ============ */
:root{
  /* ── Backgrounds ── */
  --bg:#F6F7F3; --surface:#FFFFFF; --surface2:#EEF1EA;
  /* ── Text ── */
  --ink:#16201A; --muted:#646F63;
  /* ── Borders ── */
  --line:#E2E6DD; --line2:#CCD3C4;
  /* ── Brand: Eucalyptus ── */
  --euc:#1E6B4C; --euc-soft:#E5F0E7; --euc-ink:#134A33;
  --euc-grad-from:#2B8A63; --euc-grad-to:#15543A;
  /* ── Accent: Gold ── */
  --gold:#A2791E; --gold-soft:#F5EEDA; --gold-badge:#C99B33;
  /* ── Semantic ── */
  --red:#AC4530; --red-soft:#F7E7E1;
  --blue:#2A5FA8; --blue-soft:#E4ECF8;
  --orange:#C9763F; --orange-soft:#F8EADC;
  --purple:#6E5FA8; --purple-soft:#EAE6F5;
  --grey-cell:#A8B0A4;
  /* ── Shadows ── */
  --shadow:0 1px 2px rgba(20,28,20,.04),0 10px 28px -10px rgba(20,28,20,.10);
  --shadow-sm:0 1px 2px rgba(20,28,20,.05);
  --shadow-lg:0 4px 10px rgba(20,28,20,.05),0 24px 48px -16px rgba(20,28,20,.16);
  /* ── Shape & Layout ── */
  --radius-xs:7px; --radius-sm:8px; --radius:13px; --radius-lg:16px; --radius-xl:20px; --radius-pill:999px;
  --ctl-h:36px; --ctl-h-sm:28px; --ctl-h-lg:48px;
  --sidebar-w:240px;
  /* ── Motion ── */
  --ease:cubic-bezier(.2,.7,.2,1);
  --dur-fast:120ms; --dur-base:150ms; --dur-slow:200ms; --dur-enter:180ms;
  /* ── Effects ── */
  --focus-ring:0 0 0 3px color-mix(in srgb,var(--euc) 18%,transparent);
  --blur-modal:blur(2px);
  /* ── Typography scale ── */
  --font-display:'Plus Jakarta Sans','Inter',system-ui,sans-serif;
  --font-body:'Inter',system-ui,-apple-system,sans-serif;
  --text-2xs:.64rem; --text-xs:.70rem; --text-sm:.78rem; --text-base:.88rem;
  --text-md:.92rem; --text-lg:1.00rem; --text-xl:1.08rem;
  --text-2xl:1.32rem; --text-3xl:1.62rem; --text-4xl:1.78rem;
  --fw-regular:400; --fw-medium:500; --fw-semibold:600; --fw-bold:700; --fw-extrabold:800;
  --lh-tight:1.25; --lh-base:1.45; --lh-relaxed:1.70;
  --ls-tight:-0.012em; --ls-snug:-0.006em; --ls-normal:0;
  --ls-caps:0.08em; --ls-wide:0.11em; --ls-widest:0.13em;
  --tnum:'tnum' 1;
  /* ── Spacing scale (4px base) ── */
  --space-1:4px; --space-2:8px; --space-3:12px; --space-4:14px; --space-5:16px;
  --space-6:18px; --space-7:20px; --space-8:24px; --space-9:30px; --space-10:38px;
}
html[data-theme="dark"]{
  --bg:#0D1310; --surface:#151D17; --surface2:#1C261E; --ink:#E8EDE6; --muted:#90A092;
  --line:#263027; --line2:#34402F;
  --euc:#4FCB94; --euc-soft:#172E22; --euc-ink:#7FE0AE;
  --gold:#D7AC54; --gold-soft:#2B2414; --gold-badge:#D7AC54;
  --red:#E08667; --red-soft:#33201A;
  --blue:#79ABEC; --blue-soft:#1A2740;
  --orange:#E2925A; --orange-soft:#352617;
  --purple:#AFA1DE; --purple-soft:#251F38;
  --grey-cell:#414C40;
  --shadow:0 1px 2px rgba(0,0,0,.50),0 12px 28px -10px rgba(0,0,0,.55);
  --shadow-sm:0 1px 2px rgba(0,0,0,.50);
  --shadow-lg:0 4px 10px rgba(0,0,0,.50),0 28px 56px -16px rgba(0,0,0,.60);
}
*{box-sizing:border-box;margin:0;padding:0}
html{font-size:15px}
html,body{overflow-x:hidden}
body{
  font-family:var(--font-body); background:var(--bg); color:var(--ink);
  font-feature-settings:var(--tnum); line-height:var(--lh-base); min-height:100vh;
  -webkit-font-smoothing:antialiased; text-rendering:optimizeLegibility; text-wrap:pretty;
}
h1,.display{font-family:var(--font-display);letter-spacing:-.022em;font-weight:var(--fw-bold)}
h2,h3{letter-spacing:var(--ls-snug)}
button,input,select,textarea{font:inherit;color:inherit}
a{color:var(--euc);text-decoration:none}
a:hover{text-decoration:underline}
::selection{background:var(--euc-soft);color:var(--euc-ink)}
/* Slim, quiet scrollbars — premium chrome rather than the OS default */
::-webkit-scrollbar{width:10px;height:10px}
::-webkit-scrollbar-track{background:transparent}
::-webkit-scrollbar-thumb{background:var(--line2);border-radius:99px;border:2px solid var(--bg)}
::-webkit-scrollbar-thumb:hover{background:var(--muted)}
*{scrollbar-color:var(--line2) transparent;scrollbar-width:thin}

/* ============ LAYOUT ============ */
.app{display:grid;grid-template-columns:240px 1fr;height:100vh;overflow:hidden;border-top:3px solid var(--person-accent,transparent)}
.sidebar{
  background:var(--surface2); border-right:1px solid var(--line); padding:20px 0 14px;
  height:100%; overflow-y:auto; display:flex; flex-direction:column;
}
.brand{padding:0 20px 16px;border-bottom:1px solid var(--line);position:relative}
.brand .t{font-family:var(--font-display);font-weight:var(--fw-semibold);font-size:var(--text-2xl);letter-spacing:-.01em;position:relative;display:inline-block}
.brand .t::after{content:'';position:absolute;left:0;right:-4px;bottom:-7px;height:3px;background:linear-gradient(90deg,var(--euc) 0 60%,var(--gold) 60% 100%);border-radius:2px;opacity:.85}
.nav-toggle{display:none}
.fy-pick{padding:14px 20px;border-bottom:1px solid var(--line)}
.fy-pick label{font-size:.66rem;text-transform:uppercase;letter-spacing:var(--ls-wide);color:var(--muted);display:block;margin-bottom:6px;font-weight:var(--fw-semibold)}
.pchips{display:flex;flex-wrap:wrap;gap:6px}
.pchips button{border:1px solid var(--line);background:var(--surface2);color:var(--ink);border-radius:999px;padding:4px 11px;font:inherit;font-size:var(--text-sm);cursor:pointer;display:flex;align-items:center;gap:6px;transition:border-color .15s var(--ease),background .15s var(--ease),box-shadow .15s var(--ease)}
.pchips button .pd{width:8px;height:8px;border-radius:50%;flex:none}
.pchips button.active{background:var(--euc-soft);border-color:var(--euc);color:var(--euc-ink);font-weight:var(--fw-semibold);box-shadow:0 0 0 1px var(--euc) inset}
.pchips button:hover{border-color:var(--euc)}
.personline{display:inline-flex;align-items:center;gap:6px;font-size:.8rem;color:var(--muted)}
.personline .pd{width:9px;height:9px;border-radius:50%;display:inline-block}
.nav{padding:12px 12px;flex:1}
.nav .grp{font-size:.65rem;text-transform:uppercase;letter-spacing:var(--ls-wide);color:var(--muted);padding:14px 10px 6px;font-weight:var(--fw-bold)}
/* Excel-heritage sheet tabs */
.nav button{
  display:flex;align-items:center;gap:10px;width:100%;text-align:left;background:none;border:0;
  padding:8px 10px;border-radius:var(--radius-sm);cursor:pointer;color:var(--ink);font-weight:var(--fw-medium);font-size:var(--text-md);
  transition:background .14s var(--ease),color .14s var(--ease);
}
.nav button:hover{background:var(--surface2)}
.nav button.active{
  background:var(--person-accent-soft, var(--euc-soft));
  color:var(--person-accent-ink, var(--euc-ink));
  font-weight:var(--fw-semibold);
  box-shadow:inset 3px 0 0 var(--person-accent, var(--euc));
}
.nav .tabchip{width:14px;height:9px;border-radius:2px 2px 0 0;border-bottom:2px solid transparent;flex:none}
.nav button.active .tabchip{border-bottom-color:currentColor}
.sidefoot{padding:14px 20px;border-top:1px solid var(--line);display:flex;gap:8px;align-items:center;flex-wrap:wrap}

.main{padding:30px 38px 70px;max-width:1280px;width:100%;min-width:0}
.pagehead{display:flex;align-items:flex-end;justify-content:space-between;gap:16px;margin-bottom:26px;flex-wrap:wrap;padding-bottom:18px;border-bottom:1px solid var(--line)}
.pagehead h1{font-size:var(--text-4xl);font-weight:var(--fw-semibold)}
.pagehead .sub{color:var(--muted);font-size:.9rem;margin-top:4px;max-width:680px}
.headactions{display:flex;gap:8px;flex-wrap:wrap;align-items:center}

/* ============ COMPONENTS ============ */
.card{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow);margin-bottom:18px;transition:box-shadow .2s var(--ease)}
.card.archived{opacity:.7}
.card.archived .chead{background:repeating-linear-gradient(135deg,transparent,transparent 10px,var(--bg) 10px,var(--bg) 20px)}
.asset-search-dropdown{position:absolute;top:2px;left:0;right:0;background:var(--surface);border:1px solid var(--line);border-radius:var(--radius-sm);box-shadow:var(--shadow-lg);z-index:50;max-height:280px;overflow-y:auto}
.asset-search-item{padding:8px 10px;font-size:.84rem;cursor:pointer;border-bottom:1px solid var(--line2)}
.asset-search-item:last-child{border-bottom:none}
.asset-search-item:hover{background:var(--surface2)}
/* Overflow "more actions" menu — for rows with too many actions to show
   inline at equal weight. Trigger is a normal .btn; panel reuses the same
   surface/shadow language as the asset search dropdown above. */
.actmenu{position:relative;display:inline-block}
.actmenu-panel{position:absolute;top:calc(100% + 4px);right:0;background:var(--surface);border:1px solid var(--line);border-radius:var(--radius-sm);box-shadow:var(--shadow-lg);z-index:50;min-width:200px;padding:4px;display:flex;flex-direction:column}
.actmenu-panel button{display:block;width:100%;text-align:left;background:none;border:none;padding:8px 10px;border-radius:var(--radius-xs);font-size:var(--text-sm);cursor:pointer;color:var(--ink);font:inherit}
.actmenu-panel button:hover{background:var(--surface2)}
.actmenu-panel button.danger{color:var(--red)}
.actmenu-panel hr{border:none;border-top:1px solid var(--line);margin:4px 2px}
.card>.chead{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:13px 17px;border-bottom:1px solid var(--line);flex-wrap:wrap;background:color-mix(in srgb,var(--surface2) 50%,var(--surface))}
.card>.chead h2{font-size:1rem;font-weight:var(--fw-bold);letter-spacing:-.005em}
.card>.chead .hint{font-size:.8rem;color:var(--muted)}
.card>.cbody{padding:17px}
.card>.cbody.tight{padding:0;overflow-x:auto;-webkit-overflow-scrolling:touch}
.chead .actions{display:flex;gap:6px;align-items:center;flex-wrap:wrap}

.grid2{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.grid3{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
.grid4{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}
.dash-8grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-bottom:6px}
.dash-row2{display:grid;grid-template-columns:2fr 1fr;gap:18px}
@media(max-width:1000px){
  .grid2,.grid3,.dash-row2{grid-template-columns:1fr}
  .grid4,.dash-8grid{grid-template-columns:repeat(2,1fr)}
  /* On mobile the app returns to normal document flow — no fixed height,
     no overflow:hidden, standard page scroll */
  .app{grid-template-columns:1fr;height:auto;overflow:visible}
  .sidebar{position:static;height:auto;overflow-y:visible;border-right:none;border-bottom:1px solid var(--line)}
  /* Main content scroll wrapper also returns to normal flow */
  .app > div[style*="overflow-y:auto"]{height:auto;overflow-y:visible !important}
  .brand{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:14px 16px}
  .nav-toggle{
    display:flex;align-items:center;gap:6px;border:1px solid var(--line2);background:var(--surface2);
    border-radius:var(--radius-xs);padding:0 12px;height:34px;font:inherit;font-size:.84rem;font-weight:var(--fw-semibold);color:var(--ink);cursor:pointer;
  }
  .nav-toggle-icon{font-size:.7rem;transition:transform .15s;color:var(--muted)}
  .nav-toggle[aria-expanded="true"] .nav-toggle-icon{transform:rotate(180deg)}
  .nav-collapse{display:none}
  .nav-collapse.open{display:block}
}

.btn{
  border:1px solid var(--line2);background:var(--surface);border-radius:var(--radius-sm);padding:0 14px;height:var(--ctl-h);cursor:pointer;
  font-weight:var(--fw-semibold);font-size:.86rem;display:inline-flex;align-items:center;gap:6px;color:var(--ink);
  transition:background .15s var(--ease),border-color .15s var(--ease),box-shadow .15s var(--ease),transform .1s var(--ease);
}
.btn:hover{background:var(--surface2);border-color:var(--line2)}
.btn:active{transform:translateY(1px)}
.btn.primary{background:var(--euc);border-color:var(--euc);color:#fff;box-shadow:0 1px 2px rgba(20,28,20,.08),0 6px 14px -6px color-mix(in srgb,var(--euc) 55%,transparent)}
html[data-theme="dark"] .btn.primary{color:#06140d}
.btn.primary:hover{filter:brightness(1.07);box-shadow:0 1px 2px rgba(20,28,20,.1),0 8px 18px -6px color-mix(in srgb,var(--euc) 65%,transparent)}
.btn.danger{color:var(--red);border-color:var(--red)}
.btn.danger:hover{background:var(--red-soft)}
.btn.small{height:var(--ctl-h-sm);padding:0 9px;font-size:var(--text-sm);border-radius:var(--radius-xs)}
.btn.ghost{border-color:transparent;background:none;box-shadow:none}
.btn.ghost:hover{background:var(--surface2)}
a.btn{text-decoration:none}

.input,select.input,textarea.input{
  width:100%;border:1px solid var(--line2);background:var(--surface);border-radius:var(--radius-sm);
  height:var(--ctl-h);padding:0 11px;font-size:.9rem;transition:border-color .14s var(--ease),box-shadow .14s var(--ease);
}
textarea.input{height:auto;padding:8px 10px}
select.input{
  appearance:none;-webkit-appearance:none;
  background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6'%3E%3Cpath d='M1 1l4 4 4-4' stroke='%23646F63' stroke-width='1.6' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");
  background-repeat:no-repeat;background-position:right 9px center;padding-right:26px;
}
.input:focus,.input:focus-visible{outline:none;border-color:var(--euc);border-width:2px;box-shadow:var(--focus-ring)}
.input.money{text-align:right;font-variant-numeric:tabular-nums}
label.fld{display:block;font-size:.74rem;font-weight:var(--fw-semibold);color:var(--muted);margin-bottom:5px;text-transform:uppercase;letter-spacing:.05em}
.fldrow{display:flex;gap:12px;flex-wrap:wrap}
.fldrow>div{flex:1;min-width:130px}
.fldrow label.fld{min-height:2.7em}

table.tbl{width:100%;border-collapse:collapse;font-size:var(--text-base)}
table.tbl th{
  text-align:left;font-size:var(--text-2xs);text-transform:uppercase;letter-spacing:var(--ls-caps);color:var(--muted);
  padding:10px 14px;border-bottom:1px solid var(--line);background:var(--surface2);font-weight:var(--fw-bold);white-space:nowrap;
}
table.tbl td{padding:8px 14px;border-bottom:1px solid var(--line);vertical-align:middle;height:44px}
table.tbl tr:last-child td{border-bottom:0}
table.tbl tbody tr:nth-child(even) td{background:color-mix(in srgb,var(--surface2) 40%,transparent)}
table.tbl tbody tr{transition:background .12s var(--ease)}
table.tbl tbody tr:hover td{background:color-mix(in srgb,var(--surface2) 55%,transparent)}
table.tbl tr.total:hover td{background:var(--surface2)}
table.tbl td.num,table.tbl th.num{text-align:right;font-variant-numeric:tabular-nums;white-space:nowrap}
/* Ledger signature: totals close out with a double rule, the way an
   accountant underlines a final balance in a paper ledger book. */
table.tbl tr.total td{font-weight:var(--fw-bold);background:var(--surface2);border-top:3px double var(--line2)}
table.tbl tr.subhead td{font-weight:var(--fw-bold);background:var(--euc-soft);color:var(--euc-ink);font-size:var(--text-sm);text-transform:uppercase;letter-spacing:.06em;height:var(--ctl-h)}
table.tbl td.rowact{text-align:right;white-space:nowrap}
table.tbl td.rowact .btn{vertical-align:middle}
table.tbl input.input,table.tbl select.input{height:31px;font-size:.86rem;min-width:64px;border-radius:var(--radius-xs)}
table.tbl select.input{min-width:96px}
table.tbl .editcell{min-width:120px}

.stat{
  background:var(--surface);
  border:1px solid var(--line);
  border-radius:var(--radius);
  padding:16px 18px 15px;
  box-shadow:var(--shadow);
  position:relative;overflow:hidden;
  cursor:pointer;
  transition:box-shadow .18s var(--ease),transform .15s var(--ease);
}
.stat:hover{box-shadow:0 2px 4px rgba(20,28,20,.06),0 14px 36px -10px rgba(20,28,20,.14);transform:translateY(-1px)}
.stat::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:var(--line2);opacity:.6}
.stat::after{content:'';position:absolute;top:3px;left:0;right:0;height:48px;background:linear-gradient(180deg,color-mix(in srgb,var(--surface2) 35%,transparent) 0%,transparent 100%);pointer-events:none}
.stat .l{font-size:var(--text-2xs);text-transform:uppercase;letter-spacing:var(--ls-caps);color:var(--muted);font-weight:var(--fw-semibold);position:relative;z-index:1}
.stat .v{font-family:var(--font-display);font-size:var(--text-3xl);font-weight:var(--fw-bold);margin-top:6px;font-variant-numeric:tabular-nums;letter-spacing:-.022em;position:relative;z-index:1}
.stat .d{font-size:var(--text-sm);color:var(--muted);margin-top:3px;position:relative;z-index:1}
.stat.good::before{background:var(--euc)}
.stat.bad::before{background:var(--red)}
.stat.gold::before{background:var(--gold-badge)}
.stat.good .v{color:var(--euc)}
.stat.bad .v{color:var(--red)}
.stat.gold .v{color:var(--gold-badge)}

.badge{display:inline-flex;align-items:center;gap:5px;font-size:.7rem;font-weight:var(--fw-bold);padding:2.5px 9px;border-radius:99px;border:1px solid;white-space:nowrap;letter-spacing:.01em}
.badge.euc{color:var(--euc-ink);background:var(--euc-soft);border-color:var(--euc)}
.badge.gold{color:var(--gold-badge);background:var(--gold-soft);border-color:var(--gold-badge)}
.badge.red{color:var(--red);background:var(--red-soft);border-color:var(--red)}
.badge.blue{color:var(--blue);background:var(--blue-soft);border-color:var(--blue)}
.badge.purple{color:var(--purple);background:var(--purple-soft);border-color:var(--purple)}
/* Soft variant — no border, lighter bg, for secondary metadata in table cells */
.badge.soft{border-color:transparent;font-weight:var(--fw-semibold);font-size:.68rem;padding:2px 7px}
.badge.soft.euc{background:color-mix(in srgb,var(--euc-soft) 60%,transparent)}
.badge.soft.gold{background:color-mix(in srgb,var(--gold-soft) 60%,transparent)}
.badge.soft.red{background:color-mix(in srgb,var(--red-soft) 60%,transparent)}
.badge.soft.blue{background:color-mix(in srgb,var(--blue-soft) 60%,transparent)}
.badge.soft.purple{background:color-mix(in srgb,var(--purple-soft) 60%,transparent)}

/* frozen FY stamp — the signature mark */
.stamp{
  display:inline-flex;flex-direction:column;align-items:center;justify-content:center;
  border:2.5px solid var(--gold-badge);color:var(--gold-badge);border-radius:8px;padding:5px 12px;
  font-family:var(--font-display);font-weight:var(--fw-semibold);letter-spacing:var(--ls-widest);text-transform:uppercase;font-size:var(--text-2xs);
  transform:rotate(-4deg);line-height:1.25;opacity:.95;user-select:none;pointer-events:none;
}
.stamp .big{font-size:.86rem;letter-spacing:.18em}

/* WFH calendar */
.cal-month{margin-bottom:10px}
.cal-mname{font-weight:var(--fw-bold);font-size:var(--text-md);margin:10px 0 6px}
.cal-grid{display:grid;grid-template-columns:repeat(7,minmax(34px,46px));gap:3px}
.cal-dow{font-size:.64rem;text-transform:uppercase;color:var(--muted);text-align:center;font-weight:var(--fw-bold);padding:2px 0}
.cal-day{
  aspect-ratio:1.15;border:1px solid var(--line);border-radius:var(--radius-xs);display:flex;align-items:center;justify-content:center;
  font-size:.8rem;cursor:pointer;background:var(--surface);font-variant-numeric:tabular-nums;position:relative;
  transition:outline-color .12s var(--ease),background .12s var(--ease);
}
.cal-day.empty{visibility:hidden}
.cal-day.weekend{background:var(--orange-soft);border-color:var(--orange);color:var(--orange);cursor:default}
.cal-day.holiday{background:var(--grey-cell);border-color:var(--grey-cell);color:var(--surface);cursor:default}
.cal-day.wfh{background:var(--wfh-user,var(--blue));border-color:var(--wfh-user,var(--blue));color:#fff;font-weight:var(--fw-bold)}
.cal-day.range-pending{outline:2px dashed var(--euc);outline-offset:1px;box-shadow:0 0 0 2px var(--euc) inset}
.cal-day.away{background:var(--away-user,var(--purple));border-color:var(--away-user,var(--purple));color:#fff}
.cal-day:not(.weekend):not(.holiday):hover{outline:2px solid var(--blue)}
.cal-legend{display:flex;gap:14px;flex-wrap:wrap;font-size:var(--text-sm);color:var(--muted);margin:8px 0 4px}
.cal-legend .sw{display:inline-block;width:13px;height:13px;border-radius:3px;vertical-align:-2px;margin-right:5px;border:1px solid var(--line)}

/* charts */
.chart svg{width:100%;height:auto;display:block}
.chart .axis{font-size:10px;fill:var(--muted)}
.chart .vlab{font-size:9.5px;fill:var(--muted);font-variant-numeric:tabular-nums}
.mom-up{color:var(--euc);font-weight:var(--fw-bold)}
.mom-down{color:var(--red);font-weight:var(--fw-bold)}

/* expandable result table */
.restbl{width:100%;border-collapse:collapse;font-size:.9rem}
.restbl th{text-align:right;font-size:.69rem;text-transform:uppercase;letter-spacing:var(--ls-caps);color:var(--muted);padding:7px 10px;border-bottom:1px solid var(--line);font-weight:var(--fw-bold)}
.restbl th:first-child{text-align:left}
.restbl td{padding:8px 10px;border-bottom:1px solid var(--line);font-variant-numeric:tabular-nums}
.restbl td.num{text-align:right;white-space:nowrap}
.restbl tr.grp>td{cursor:pointer;font-weight:var(--fw-semibold)}
.restbl tr.grp>td:first-child::before{content:'▸';display:inline-block;width:14px;color:var(--muted);transition:transform .12s}
.restbl tr.grp.open>td:first-child::before{transform:rotate(90deg)}
.restbl tr.sub td{background:var(--surface2);color:var(--muted);font-size:.84rem;border-bottom:1px dashed var(--line)}
.restbl tr.sub td:first-child{padding-left:26px}
.restbl tr.tot td{font-weight:var(--fw-bold);border-top:3px double var(--line2);border-bottom:0}
.restbl tr.plain>td:first-child{padding-left:14px}

/* donut */
.donutwrap{display:flex;gap:22px;align-items:center;flex-wrap:wrap}
.donutleg{font-size:.84rem;display:grid;gap:6px}
.donutleg .sw{display:inline-block;width:12px;height:12px;border-radius:3px;margin-right:7px;vertical-align:-1px}

/* receipts */
.rcpt-file{display:inline-flex;align-items:center;gap:6px;font-size:var(--text-sm);padding:4px 9px;border:1px solid var(--line2);border-radius:var(--radius-xs);cursor:pointer;transition:background .12s var(--ease)}
.rcpt-file:hover{background:var(--surface2)}

/* ═══ Documents page ═══ */
.docs-filter-row{display:flex;gap:10px;align-items:center;flex-wrap:wrap;margin-bottom:18px}
.docs-filter-row .input{max-width:320px;flex:1}
.doc-cat{margin-bottom:14px}
.doc-cat-head{display:flex;align-items:center;gap:10px;cursor:pointer;user-select:none;padding:12px 17px;background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow-sm);transition:background .12s var(--ease)}
.doc-cat-head:hover{background:var(--surface2)}
.doc-cat-head h2{margin:0;font-size:var(--text-md);font-weight:var(--fw-bold);flex:1}
.doc-cat-body{border:1px solid var(--line);border-top:none;border-radius:0 0 var(--radius) var(--radius);background:var(--surface);overflow:hidden}
.doc-row{display:flex;align-items:center;gap:12px;padding:11px 17px;border-bottom:1px solid var(--line);cursor:pointer;transition:background .12s var(--ease)}
.doc-row:last-child{border-bottom:none}
.doc-row:hover{background:var(--surface2)}
.doc-icon{font-size:1.2rem;flex-shrink:0;width:26px;text-align:center}
.doc-name{font-size:var(--text-base);font-weight:var(--fw-semibold);color:var(--ink);flex:1;min-width:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.doc-sub{font-size:.76rem;color:var(--muted);margin-top:1px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.doc-meta{display:flex;flex-direction:column;align-items:flex-end;gap:4px;flex-shrink:0}
.doc-missing-head{display:flex;align-items:center;gap:9px;padding:9px 17px;background:var(--gold-soft);border-top:1px solid var(--line);cursor:pointer;user-select:none;transition:background .12s var(--ease)}
.doc-missing-head:hover{background:var(--gold-soft)}
.doc-missing-row{display:flex;align-items:center;gap:12px;padding:8px 17px 8px 40px;border-top:1px dashed var(--line);background:var(--surface2)}
.doc-missing-row:first-of-type{border-top:1px solid var(--line)}
.doc-missing-row .doc-sub{font-size:.8rem}
.doc-empty{padding:20px 17px;color:var(--muted);font-size:.84rem;font-style:italic}
.doc-cat-badges{display:flex;gap:6px;flex-shrink:0;align-items:center}

/* modal & toast */
.modal-back{position:fixed;inset:0;background:rgba(10,15,12,.52);backdrop-filter:var(--blur-modal);display:flex;align-items:center;justify-content:center;z-index:50;padding:20px;animation:fadeIn .15s var(--ease)}
.modal{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius-lg);max-width:660px;width:100%;max-height:88vh;overflow-y:auto;box-shadow:var(--shadow-lg);animation:modalIn .18s var(--ease)}
@keyframes fadeIn{from{opacity:0}}
@keyframes modalIn{from{opacity:0;transform:translateY(6px) scale(.985)}}
.modal .mhead{padding:15px 19px;border-bottom:1px solid var(--line);display:flex;justify-content:space-between;align-items:center}
.modal .mhead h3{font-size:var(--text-xl);font-family:var(--font-display);font-weight:var(--fw-semibold)}
.modal .mbody{padding:19px}
.modal .mfoot{padding:13px 19px;border-top:1px solid var(--line);display:flex;justify-content:flex-end;gap:8px}
#toast{position:fixed;bottom:22px;left:50%;transform:translateX(-50%);background:var(--ink);color:var(--bg);padding:10px 19px;border-radius:10px;font-weight:var(--fw-semibold);font-size:var(--text-base);opacity:0;transition:opacity .25s,transform .25s;z-index:99;pointer-events:none;box-shadow:var(--shadow-lg)}
#toast.show{opacity:1;transform:translate(-50%,-3px)}

.note{font-size:.8rem;color:var(--muted);background:color-mix(in srgb,var(--surface2) 60%,transparent);border:none;border-left:3px solid var(--line2);border-radius:0 var(--radius-xs) var(--radius-xs) 0;padding:9px 13px 9px 14px;margin-top:10px}
.kv{display:flex;justify-content:space-between;gap:10px;padding:7px 0;border-bottom:1px dashed var(--line);font-size:.9rem;align-items:center}
.kv:last-child{border-bottom:0}
.kv .k{color:var(--muted)}
.kv .v{font-weight:var(--fw-semibold);font-variant-numeric:tabular-nums}
.kv.big .v{font-family:var(--font-display);font-weight:var(--fw-semibold);font-size:1.18rem}
.muted{color:var(--muted)}
.right{text-align:right}
.mt{margin-top:14px}
.searchres{border:1px solid var(--line);border-radius:var(--radius-sm);max-height:230px;overflow-y:auto;margin-top:6px}
.searchres button{display:flex;justify-content:space-between;width:100%;border:0;background:none;padding:8px 12px;cursor:pointer;font-size:.86rem;border-bottom:1px solid var(--line);text-align:left;color:var(--ink)}
.searchres button:hover{background:var(--euc-soft)}
.theme-toggle{margin-left:auto}
/* Dashboard stat grids: collapse to single column on mobile so dex is adjacent to its card */
@media(max-width:768px){
  .dash-stat-grid{grid-template-columns:1fr!important}
  .dash-stat-grid [style*="grid-column:1/-1"]{margin-top:0!important}
  /* Reclaim screen width — desktop padding wastes too much space on phones */
  .main{padding:14px 12px 60px}
  .pagehead{gap:8px}
  .pagehead h1{font-size:1.35rem}
  .pagehead .sub{font-size:.84rem}
  .card>.chead{padding:10px 12px}
  .card>.cbody{padding:12px}
  table.tbl{font-size:.82rem}
  table.tbl th,table.tbl td{padding:6px 8px}
  /* Form rows stack on narrow screens instead of cramming columns */
  .fldrow>div{min-width:0;flex-basis:100%}
  .fldrow.fldrow-2up>div{flex-basis:calc(50% - 6px)}
  .fldrow label.fld{min-height:0}
  /* Settings (and similar) rows often use inline style="width:NNNpx" inputs
     that don't fit a phone's content width — cap them, and let the label
     wrap onto its own line above the control rather than overflowing. */
  .input{max-width:100%}
  .kv{flex-wrap:wrap;row-gap:6px}
  .kv .v,.kv>span:last-child{max-width:100%}
  /* Modals use most of the viewport on small screens */
  .modal-back{padding:8px}
  .modal{max-width:100%;max-height:94vh}
  .modal .mbody{padding:14px}
  .modal .mfoot{padding:10px 14px;flex-wrap:wrap}
  .grid3 .stat{padding:12px}
}
/* Address autocomplete dropdown */
.addr-sugg{display:none;position:absolute;top:100%;left:0;right:0;z-index:60;background:var(--surface);border:1px solid var(--line2);border-radius:var(--radius-sm);margin-top:2px;max-height:220px;overflow-y:auto;box-shadow:var(--shadow-lg)}
.addr-sugg-item{padding:8px 12px;font-size:.84rem;cursor:pointer;border-bottom:1px solid var(--line2);line-height:1.4}
.addr-sugg-item:last-child{border-bottom:none}
.addr-sugg-item:hover{background:var(--surface2)}

/* ===== CUSTOM SELECT ===== */
.csel{position:relative;display:block}
.csel-btn{
  width:100%;height:var(--ctl-h);padding:0 11px;
  border:1px solid var(--line2);background:var(--surface);border-radius:var(--radius-sm);
  cursor:pointer;font:inherit;font-size:.9rem;color:var(--ink);
  display:flex;align-items:center;justify-content:space-between;gap:8px;
  text-align:left;line-height:1.3;transition:border-color .14s var(--ease),box-shadow .14s var(--ease);
}
.csel-btn:hover{background:var(--surface2)}
.csel.open .csel-btn,.csel-btn:focus,.csel-btn:focus-visible{
  outline:none;border-color:var(--euc);background:var(--surface);box-shadow:var(--focus-ring);
}
.csel-cur{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;min-width:0}
.csel-chev{color:var(--muted);flex:none;display:block;transition:transform .15s}
.csel.open .csel-chev{transform:rotate(180deg);color:var(--euc)}
.csel-opts{
  position:absolute;top:calc(100% + 4px);left:0;right:0;min-width:max-content;
  background:var(--surface);border:1px solid var(--line2);
  border-radius:var(--radius);padding:5px 0;
  box-shadow:var(--shadow-lg);z-index:300;
  max-height:260px;overflow-y:auto;display:none;
}
.csel.open .csel-opts{display:block;animation:cselIn .12s var(--ease)}
@keyframes cselIn{from{opacity:0;transform:translateY(-5px)}}
@keyframes spin{to{transform:rotate(360deg)}}
.spinner{display:inline-block;width:13px;height:13px;border:2px solid var(--line2);border-top-color:var(--euc);border-radius:50%;animation:spin .7s linear infinite;vertical-align:middle}
@keyframes skelPulse{0%,100%{opacity:.55}50%{opacity:1}}
.skel-row{height:14px;border-radius:5px;background:var(--surface2);animation:skelPulse 1.2s ease-in-out infinite}
.skel-pulse{animation:skelPulse 1.2s ease-in-out infinite}
.csel-opt{
  padding:8px 13px;cursor:pointer;color:var(--ink);
  font-size:.9rem;display:flex;align-items:center;gap:8px;white-space:nowrap;
}
.csel-opt:hover{background:var(--surface2)}
.csel-opt.sel{background:var(--euc-soft);color:var(--euc-ink);font-weight:var(--fw-semibold)}
/* table-cell selects stay compact */
table .csel-btn{height:31px;font-size:.86rem;padding:0 7px;border-radius:var(--radius-xs)}

/* ===== EXPANDABLE DASHBOARD STAT CARDS ===== */
.stat.xable{cursor:pointer;user-select:none;transition:box-shadow .15s var(--ease),background .15s var(--ease),transform .15s var(--ease)}
.stat.xable:hover{box-shadow:0 0 0 1.5px var(--line2),var(--shadow-lg);transform:translateY(-1px)}
.stat.xopen{box-shadow:0 0 0 2px var(--euc)!important;background:var(--surface)!important}
.stat-toggle{font-size:.62rem;color:var(--muted);text-align:right;margin-top:10px;letter-spacing:.06em;text-transform:uppercase;font-weight:var(--fw-semibold)}
.stat.xopen .stat-toggle{color:var(--euc)}
.dex{
  background:var(--surface);border:1.5px solid var(--euc);border-radius:var(--radius);
  padding:17px 19px;margin-top:-10px;margin-bottom:18px;
  box-shadow:var(--shadow-lg);animation:dexIn .16s var(--ease);
}
@keyframes dexIn{from{opacity:0;transform:translateY(-4px)}}
.dex-row{
  display:flex;justify-content:space-between;align-items:center;
  padding:6px 0;border-bottom:1px dashed var(--line);font-size:.9rem;gap:16px;
}
.dex-row:last-child{border-bottom:0}
.dex-row.sub{padding-left:18px;font-size:.84rem}
.dex-row.sub .n{color:var(--muted)}
.dex-row.tot{
  font-weight:var(--fw-bold);border-bottom:0;border-top:3px double var(--line2);
  padding-top:10px;margin-top:4px;font-size:.95rem;
}
.dex-row .n{color:var(--muted);flex:1}
.dex-row .a{font-weight:var(--fw-semibold);font-variant-numeric:tabular-nums;white-space:nowrap;color:var(--ink)}
.dex-lnk{font-size:var(--text-sm);color:var(--euc);cursor:pointer;text-decoration:none;margin-left:6px;white-space:nowrap}
.dex-lnk:hover{text-decoration:underline}



@media print{
  /* Reset the viewport-height layout so all content prints */
  .app{display:block;height:auto;overflow:visible;grid-template-columns:1fr}
  .app > div[style]{height:auto !important;overflow:visible !important}
  .sidebar,.headactions,.nav-toggle,.nav-collapse,.stat-toggle,button:not(.print-keep){display:none !important}
  .main{padding:10px;max-width:none;overflow:visible;height:auto}
  .mytax-body{display:block !important}
  /* Prevent cards from being cut mid-page */
  .card,.stat,.dex{break-inside:avoid;page-break-inside:avoid}
  .kv{break-inside:avoid}
  /* Show all collapsed mytax sections when printing */
  .mytax-body[style*="display:none"]{display:block !important}
  body{background:#fff;color:#000}
  a{color:#000}
  .badge,.muted{color:#444 !important}
  .modal-back,.modal,#toast{display:none !important}
}
@media (prefers-reduced-motion:reduce){*{transition:none!important;animation:none!important}}
:focus-visible{outline:none;box-shadow:var(--focus-ring);border-radius:6px}
