/* ============================================================
   Buhalteris — APP UI
   Reuses design tokens from ../assets/styles.css.
   Dark SaaS app shell: sidebar + topbar + content.
   ============================================================ */

body{overflow-x:hidden}
.app{display:flex;flex-direction:column;min-height:100vh}

/* ---------- APP BAR (horizontal top navigation) ---------- */
.appbar{
  position:sticky;top:0;z-index:40;
  background:rgba(10,11,13,.85);backdrop-filter:blur(16px) saturate(140%);
  box-shadow:0 1px 0 var(--line);
}
.bar-main{
  display:flex;align-items:center;gap:14px;
  max-width:1340px;margin:0 auto;width:100%;padding:14px 26px 13px;
  box-shadow:0 1px 0 var(--line);
}
.appbar .logo{font-size:1.08rem}
.appbar .logo .mark{width:30px;height:30px;font-size:16px}
.bar-main .spacer{flex:1}

.bar-nav{
  display:flex;align-items:center;gap:16px;
  max-width:1340px;margin:0 auto;width:100%;padding:7px 26px;
}
.tabs{display:flex;align-items:center;gap:4px;flex:1;overflow-x:auto;scrollbar-width:none;-ms-overflow-style:none}
.tabs::-webkit-scrollbar{display:none}
.tab{
  display:flex;align-items:center;gap:9px;white-space:nowrap;flex:none;
  padding:9px 15px;border-radius:11px;color:var(--txt-soft);font-size:.92rem;font-weight:500;
  transition:background .18s,color .18s;position:relative;
}
.tab:hover{background:var(--glass);color:var(--txt)}
.tab.on{background:var(--acc);color:var(--acc-ink);font-weight:700;box-shadow:0 8px 22px -10px var(--acc-glow)}
.tab .ti{width:18px;height:18px;flex:none;display:grid;place-items:center}
.tab .ti svg{width:18px;height:18px}
.tab .tb{font-family:var(--f-mono);font-size:11px;padding:1px 7px;border-radius:999px;background:var(--glass-hi);color:var(--txt-soft)}
.tab.on .tb{background:rgba(10,15,0,.22);color:var(--acc-ink)}
.plan-chip{
  display:none;align-items:center;gap:9px;flex:none;white-space:nowrap;
  font-size:.82rem;color:var(--txt-soft);padding:7px 13px;border-radius:11px;
  background:linear-gradient(160deg,rgba(200,255,46,.13),rgba(200,255,46,.02));box-shadow:inset 0 0 0 1px var(--acc-line);
}
.plan-chip b{font-family:var(--f-display);color:var(--txt)}
.plan-chip .pc-bar{width:46px;height:5px;border-radius:5px;background:rgba(255,255,255,.12);overflow:hidden}
.plan-chip .pc-bar i{display:block;height:100%;background:var(--acc);border-radius:5px}

/* search + icon buttons (kept for toolbars and bar) */
.searchbox{display:none;align-items:center;gap:9px;padding:9px 14px;border-radius:11px;background:var(--glass);box-shadow:inset 0 0 0 1px var(--line);color:var(--muted);font-size:.88rem;min-width:210px}
.searchbox input{flex:1;background:none;color:var(--txt);font-family:inherit;font-size:.88rem}
.searchbox input:focus{outline:none}
.searchbox svg{width:18px;height:18px;flex:none}
.icon-btn{width:40px;height:40px;border-radius:11px;flex:none;display:grid;place-items:center;background:var(--glass);box-shadow:inset 0 0 0 1px var(--line);color:var(--txt-soft);transition:.18s;position:relative}
.icon-btn:hover{color:var(--txt);box-shadow:inset 0 0 0 1px var(--line-hi)}
.icon-btn .dotn{position:absolute;top:9px;right:10px;width:7px;height:7px;border-radius:50%;background:var(--acc);box-shadow:0 0 8px var(--acc)}

/* company switcher */
.cswitch{position:relative}
.cswitch-btn{display:flex;align-items:center;gap:11px;padding:8px 12px;border-radius:12px;background:var(--glass);box-shadow:inset 0 0 0 1px var(--line);transition:.18s}
.cswitch-btn:hover{box-shadow:inset 0 0 0 1px var(--line-hi)}
.cav{width:30px;height:30px;border-radius:9px;flex:none;display:grid;place-items:center;font-family:var(--f-display);font-weight:700;font-size:13px;color:#08120a}
.cswitch-btn .cmeta{display:none;flex-direction:column;line-height:1.15;text-align:left}
.cswitch-btn .cmeta .cn{font-weight:700;font-size:.86rem;white-space:nowrap}
.cswitch-btn .cmeta .cc{font-family:var(--f-mono);font-size:10px;color:var(--faint)}
.cswitch-btn .chev{color:var(--muted);transition:transform .2s}
.cswitch.open .chev{transform:rotate(180deg)}
.cmenu{
  position:absolute;right:0;top:calc(100% + 8px);width:280px;padding:8px;border-radius:14px;
  background:rgba(16,19,23,.97);backdrop-filter:blur(16px);
  box-shadow:inset 0 0 0 1px var(--line-hi),0 24px 50px -18px rgba(0,0,0,.85);
  z-index:50;display:none;flex-direction:column;gap:2px;
}
.cswitch.open .cmenu{display:flex}
.cmenu .cml{font-family:var(--f-mono);font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:var(--faint);padding:8px 10px 4px}
.cmenu-item{display:flex;align-items:center;gap:11px;padding:10px;border-radius:10px;text-align:left;transition:background .15s;width:100%}
.cmenu-item:hover{background:var(--glass)}
.cmenu-item.on{background:var(--glass-hi)}
.cmenu-item .cmn{font-weight:600;font-size:.88rem}
.cmenu-item .cmc{font-family:var(--f-mono);font-size:10px;color:var(--faint)}
.cmenu-item .ok{margin-left:auto;color:var(--acc)}

/* ---------- CONTENT ---------- */
.content{padding:28px 26px 60px;max-width:1340px;width:100%;margin:0 auto}
.view{display:none;animation:fade .25s ease}
.view.active{display:block}
@keyframes fade{from{opacity:.4}to{opacity:1}}
.row{display:flex;align-items:center;gap:14px;flex-wrap:wrap}
.between{display:flex;align-items:center;justify-content:space-between;gap:14px;flex-wrap:wrap}
.view-head{margin-bottom:22px}
.view-head h1{font-family:var(--f-display);font-weight:700;font-size:1.7rem;letter-spacing:-.02em}
.view-head p{color:var(--muted);font-size:.92rem;margin-top:5px}

/* period pill */
.period{display:flex;align-items:center;gap:4px;background:var(--glass);border-radius:11px;padding:5px;box-shadow:inset 0 0 0 1px var(--line)}
.period button.nav{width:30px;height:30px;border-radius:8px;display:grid;place-items:center;color:var(--txt-soft)}
.period button.nav:hover{background:var(--glass-hi);color:var(--txt)}
.period .lbl{font-weight:600;font-size:.88rem;min-width:128px;text-align:center}
.period .lbl small{color:var(--faint);font-family:var(--f-mono);font-weight:500}

/* ---------- KPI CARDS ---------- */
.kpis{display:grid;grid-template-columns:repeat(2,1fr);gap:14px;margin-bottom:22px}
.kpi{padding:20px;border-radius:16px;position:relative;overflow:hidden}
.kpi .kt{font-size:.82rem;color:var(--muted);display:flex;align-items:center;gap:8px}
.kpi .kt .ki{width:30px;height:30px;border-radius:9px;display:grid;place-items:center;background:var(--glass);box-shadow:inset 0 0 0 1px var(--line);color:var(--acc)}
.kpi .kv{font-family:var(--f-display);font-weight:700;font-size:1.85rem;letter-spacing:-.02em;margin-top:14px}
.kpi .kd{font-size:.78rem;color:var(--faint);margin-top:6px;display:flex;align-items:center;gap:6px}
.kpi .kd .up{color:var(--acc)}
.kpi.hero-kpi{background:linear-gradient(155deg,rgba(200,255,46,.14),rgba(200,255,46,.02));box-shadow:inset 0 0 0 1px var(--acc-line)}
.kpi.hero-kpi .ki{background:var(--acc);color:var(--acc-ink)}

/* generic card */
.card{border-radius:16px;padding:20px}
.card-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}
.card-head h3{font-family:var(--f-display);font-weight:700;font-size:1.05rem}
.card-head .sub{font-size:.8rem;color:var(--faint)}
.grid-2{display:grid;grid-template-columns:1fr;gap:16px}
.grid-main{display:grid;grid-template-columns:1fr;gap:16px}

/* bar chart */
.chart{display:flex;align-items:flex-end;gap:12px;height:160px;padding-top:10px}
.chart .col{flex:1;display:flex;flex-direction:column;align-items:center;gap:9px;height:100%;justify-content:flex-end}
.chart .bar{width:100%;max-width:44px;border-radius:7px 7px 4px 4px;background:linear-gradient(180deg,rgba(255,255,255,.15),rgba(255,255,255,.05));position:relative;transition:height .6s var(--ease)}
.chart .bar.cur{background:linear-gradient(180deg,var(--acc),var(--acc-deep));box-shadow:0 0 20px -3px var(--acc-glow)}
.chart .bl{font-family:var(--f-mono);font-size:10px;color:var(--faint)}
.chart .bv{font-family:var(--f-mono);font-size:9.5px;color:var(--muted);white-space:nowrap}

/* lists */
.tl-list{display:flex;flex-direction:column}
.tl-item{display:flex;align-items:center;gap:13px;padding:13px 2px;box-shadow:0 1px 0 var(--line)}
.tl-item:last-child{box-shadow:none}
.tl-item .tli{width:36px;height:36px;border-radius:10px;flex:none;display:grid;place-items:center;background:var(--glass);box-shadow:inset 0 0 0 1px var(--line);color:var(--acc)}
.tl-item .tlt{font-size:.9rem;font-weight:500}
.tl-item .tlm{font-size:.76rem;color:var(--faint);margin-top:2px}
.tl-item .tlr{margin-left:auto;text-align:right;font-size:.78rem;color:var(--muted);white-space:nowrap}
.deadline .tli{color:#e0a64f}
.deadline.urgent .tli{color:#e0654f}

/* ---------- TABLES ---------- */
.tbl-wrap{border-radius:16px;overflow:hidden;overflow-x:auto}
table.tbl{width:100%;border-collapse:collapse;min-width:680px}
.tbl thead th{
  text-align:left;font-family:var(--f-mono);font-size:10.5px;letter-spacing:.08em;text-transform:uppercase;
  color:var(--faint);font-weight:500;padding:14px 16px;box-shadow:0 1px 0 var(--line);white-space:nowrap;
}
.tbl thead th.num,.tbl td.num{text-align:right;font-variant-numeric:tabular-nums}
.tbl tbody td{padding:14px 16px;box-shadow:0 1px 0 var(--line);font-size:.9rem;vertical-align:middle}
.tbl tbody tr{transition:background .15s;cursor:pointer}
.tbl tbody tr:hover{background:var(--glass)}
.tbl tbody tr:last-child td{box-shadow:none}
.tbl td.num{font-family:var(--f-mono);font-weight:500}
.tbl .who{display:flex;align-items:center;gap:11px}
.tbl .who .av{width:34px;height:34px;border-radius:9px;flex:none;display:grid;place-items:center;font-family:var(--f-display);font-weight:700;font-size:12px;background:linear-gradient(150deg,var(--acc),var(--acc-deep));color:var(--acc-ink)}
.tbl .who .nm{font-weight:600}
.tbl .who .ps{font-size:.76rem;color:var(--faint)}
.tbl tfoot td{padding:15px 16px;font-family:var(--f-mono);font-weight:700;box-shadow:0 -1px 0 var(--line-hi)}
.tbl tfoot td.num{text-align:right}
.tbl .neto-c{color:var(--acc);font-weight:700}

/* badges */
.tag{display:inline-flex;align-items:center;gap:6px;font-family:var(--f-mono);font-size:11px;font-weight:500;padding:4px 10px;border-radius:999px;white-space:nowrap}
.tag .d{width:6px;height:6px;border-radius:50%}
.tag.ok{background:rgba(200,255,46,.14);color:var(--acc)}
.tag.ok .d{background:var(--acc)}
.tag.wait{background:rgba(224,166,79,.16);color:#e8b66a}
.tag.wait .d{background:#e8b66a}
.tag.muted{background:var(--glass);color:var(--muted)}
.tag.muted .d{background:var(--muted)}
.tag.p2{background:rgba(90,214,192,.14);color:var(--cool)}
.tag.p2 .d{background:var(--cool)}

/* ---------- BUTTONS (app sizes) ---------- */
.btn svg{width:18px;height:18px;flex:none}
.btn.xs svg{width:16px;height:16px}
.btn.sm{padding:9px 16px;font-size:.86rem;border-radius:10px}
.btn.xs{padding:7px 12px;font-size:.8rem;border-radius:9px}
.btn.icon-left svg{margin-right:-2px}
.btn-soft{background:var(--glass);color:var(--txt);box-shadow:inset 0 0 0 1px var(--line-hi)}
.btn-soft:hover{box-shadow:inset 0 0 0 1px var(--acc-line);transform:translateY(-1px)}
.linkish{color:var(--acc);font-size:.85rem;font-weight:600;display:inline-flex;align-items:center;gap:6px}
.linkish:hover{text-decoration:underline;text-underline-offset:3px}

/* ---------- DRAWER (employee detail) ---------- */
.scrim{position:fixed;inset:0;background:rgba(4,5,7,.6);backdrop-filter:blur(3px);z-index:60;opacity:0;pointer-events:none;transition:opacity .25s}
.scrim.show{opacity:1;pointer-events:auto}
.drawer{
  position:fixed;top:0;right:0;height:100vh;width:min(460px,100vw);z-index:70;
  background:linear-gradient(180deg,#101317,#0b0d10);box-shadow:-1px 0 0 var(--line-hi),-30px 0 80px -30px rgba(0,0,0,.9);
  transform:translateX(100%);transition:transform .3s var(--ease);display:flex;flex-direction:column;
}
.drawer.show{transform:none}
.drawer-head{padding:22px 22px 18px;box-shadow:0 1px 0 var(--line);display:flex;align-items:flex-start;gap:14px}
.drawer-head .av{width:52px;height:52px;border-radius:13px;flex:none;display:grid;place-items:center;font-family:var(--f-display);font-weight:700;font-size:18px;background:linear-gradient(150deg,var(--acc),var(--acc-deep));color:var(--acc-ink)}
.drawer-head .dn{font-family:var(--f-display);font-weight:700;font-size:1.2rem}
.drawer-head .dp{color:var(--muted);font-size:.86rem;margin-top:2px}
.drawer-head .x{margin-left:auto;width:34px;height:34px;border-radius:9px;display:grid;place-items:center;background:var(--glass);color:var(--muted);flex:none}
.drawer-head .x:hover{color:var(--txt);background:var(--glass-hi)}
.drawer-body{padding:20px 22px;overflow-y:auto;flex:1;display:flex;flex-direction:column;gap:18px}
.drawer-foot{padding:16px 22px;box-shadow:0 -1px 0 var(--line);display:flex;gap:10px}
.dfield{display:flex;justify-content:space-between;align-items:center;gap:14px;padding:11px 0;box-shadow:0 1px 0 var(--line);font-size:.9rem}
.dfield:last-child{box-shadow:none}
.dfield .dl{color:var(--muted)}
.dfield .dv{font-weight:600;font-family:var(--f-mono)}
.mini-break{background:var(--glass);border-radius:13px;padding:16px;box-shadow:inset 0 0 0 1px var(--line)}
.mini-break .mb-row{display:flex;justify-content:space-between;padding:8px 0;font-size:.86rem;box-shadow:0 1px 0 var(--line)}
.mini-break .mb-row:last-child{box-shadow:none}
.mini-break .mb-row .l{color:var(--txt-soft)}
.mini-break .mb-row .v{font-family:var(--f-mono);font-weight:600}
.mini-break .mb-row.tot{margin-top:4px;padding-top:12px;box-shadow:0 -1px 0 var(--line-hi)}
.mini-break .mb-row.tot .v{color:var(--acc)}

/* ---------- MODAL ---------- */
.modal{
  position:fixed;inset:0;z-index:80;display:none;align-items:center;justify-content:center;padding:20px;
  background:rgba(4,5,7,.66);backdrop-filter:blur(4px);
}
.modal.show{display:flex}
.modal-card{
  width:min(520px,100%);max-height:90vh;overflow-y:auto;border-radius:20px;
  background:linear-gradient(180deg,#11141890,#0b0d10);
  box-shadow:inset 0 0 0 1px var(--line-hi),0 40px 80px -30px rgba(0,0,0,.9);
}
.modal-head{padding:22px 24px 0;display:flex;align-items:flex-start;justify-content:space-between}
.modal-head h3{font-family:var(--f-display);font-weight:700;font-size:1.3rem}
.modal-head p{color:var(--muted);font-size:.86rem;margin-top:4px}
.modal-body{padding:20px 24px}
.modal-foot{padding:0 24px 24px;display:flex;gap:10px;justify-content:flex-end}

/* form fields */
.fg{margin-bottom:16px}
.fg label{display:block;font-size:.84rem;color:var(--txt-soft);margin-bottom:7px}
.fg input,.fg select{
  width:100%;background:rgba(0,0,0,.3);color:var(--txt);font-family:inherit;font-size:.95rem;
  padding:12px 14px;border-radius:11px;box-shadow:inset 0 0 0 1px var(--line-hi);transition:box-shadow .18s;
}
.fg input:focus,.fg select:focus{outline:none;box-shadow:inset 0 0 0 1.5px var(--acc-line)}
.fg .row2{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.fg-check{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:13px 14px;border-radius:11px;background:rgba(0,0,0,.25);box-shadow:inset 0 0 0 1px var(--line)}
.fg-check .t{font-size:.88rem}
.fg-check .t small{display:block;color:var(--faint);font-size:.76rem;margin-top:2px}

/* ---------- PAYSLIP ---------- */
.payslip-toolbar{display:flex;align-items:center;gap:12px;flex-wrap:wrap;margin-bottom:18px}
.payslip{
  max-width:720px;margin:0 auto;border-radius:18px;overflow:hidden;
  background:linear-gradient(180deg,#0f1216,#0c0e11);box-shadow:inset 0 0 0 1px var(--line-hi),0 30px 70px -30px rgba(0,0,0,.8);
}
.ps-head{padding:26px 28px;display:flex;align-items:flex-start;justify-content:space-between;gap:16px;background:linear-gradient(160deg,rgba(200,255,46,.1),transparent);box-shadow:0 1px 0 var(--line)}
.ps-head .co{font-family:var(--f-display);font-weight:700;font-size:1.15rem}
.ps-head .co small{display:block;font-family:var(--f-mono);font-size:11px;color:var(--faint);font-weight:500;margin-top:4px}
.ps-head .ttl{text-align:right}
.ps-head .ttl .lg{display:inline-flex;align-items:center;gap:8px;font-family:var(--f-display);font-weight:700}
.ps-head .ttl .lg .mark{width:26px;height:26px;border-radius:7px;display:grid;place-items:center;background:linear-gradient(150deg,var(--acc),var(--acc-deep));color:var(--acc-ink);font-size:14px}
.ps-head .ttl .pr{font-family:var(--f-mono);font-size:11px;color:var(--muted);margin-top:8px}
.ps-meta{display:grid;grid-template-columns:repeat(2,1fr);gap:1px;background:var(--line)}
.ps-meta .m{background:#0d0f12;padding:16px 28px}
.ps-meta .m .k{font-family:var(--f-mono);font-size:10px;letter-spacing:.06em;text-transform:uppercase;color:var(--faint)}
.ps-meta .m .v{font-weight:600;margin-top:4px;font-size:.95rem}
.ps-lines{padding:8px 28px}
.ps-line{display:flex;justify-content:space-between;align-items:center;padding:13px 0;box-shadow:0 1px 0 var(--line);font-size:.92rem}
.ps-line .l{color:var(--txt-soft)}
.ps-line .l small{color:var(--faint);font-size:.78rem;margin-left:8px}
.ps-line .v{font-family:var(--f-mono);font-weight:600}
.ps-line.minus .v{color:#e89a86}
.ps-line.section{box-shadow:none;padding-bottom:4px;padding-top:18px}
.ps-line.section .l{font-family:var(--f-mono);font-size:10.5px;letter-spacing:.1em;text-transform:uppercase;color:var(--faint)}
.ps-line.sub{padding:7px 0 7px 18px;box-shadow:none}
.ps-line.sub .l{font-size:.84rem;color:var(--muted)}
.ps-line.sub .v{color:var(--muted);font-weight:500;font-size:.86rem}
.ps-total{margin:6px 28px 0;padding:20px 0 0;box-shadow:0 -1px 0 var(--line-hi);display:flex;justify-content:space-between;align-items:flex-end}
.ps-total .l{font-family:var(--f-display);font-weight:700;font-size:1.1rem}
.ps-total .v{font-family:var(--f-display);font-weight:700;font-size:2rem;letter-spacing:-.02em;color:var(--acc)}
.ps-foot{padding:18px 28px 26px;font-size:.76rem;color:var(--faint);line-height:1.5}

/* empty state */
.empty{text-align:center;padding:60px 20px;color:var(--muted)}
.empty .ei{width:60px;height:60px;border-radius:16px;margin:0 auto 16px;display:grid;place-items:center;background:var(--glass);box-shadow:inset 0 0 0 1px var(--line);color:var(--faint)}
.empty h4{font-family:var(--f-display);font-weight:700;font-size:1.1rem;color:var(--txt)}
.empty p{margin-top:6px;font-size:.9rem}

/* toast */
.toast-wrap{position:fixed;bottom:22px;left:50%;transform:translateX(-50%);z-index:90;display:flex;flex-direction:column;gap:10px;align-items:center;pointer-events:none}
.toast{
  display:flex;align-items:center;gap:11px;padding:13px 18px;border-radius:13px;
  background:rgba(18,22,26,.97);box-shadow:inset 0 0 0 1px var(--acc-line),0 16px 40px -16px rgba(0,0,0,.8);
  font-size:.9rem;font-weight:600;animation:toastin .3s var(--ease);
}
.toast .ti{width:24px;height:24px;border-radius:7px;display:grid;place-items:center;background:var(--acc);color:var(--acc-ink);flex:none}
@keyframes toastin{from{opacity:0;transform:translateY(12px)}to{opacity:1;transform:none}}

/* progress segmented */
.runbar{display:flex;align-items:center;gap:0;margin:2px 0 0}
.runstep{display:flex;align-items:center;gap:9px;font-size:.82rem;color:var(--muted)}
.runstep .rn{width:24px;height:24px;border-radius:50%;display:grid;place-items:center;font-family:var(--f-mono);font-size:11px;background:var(--glass);box-shadow:inset 0 0 0 1px var(--line)}
.runstep.done .rn{background:var(--acc);color:var(--acc-ink)}
.runstep.done{color:var(--txt)}
.runline{flex:1;height:2px;background:var(--line);margin:0 12px;min-width:24px}
.runline.done{background:var(--acc-line)}

/* ============================================================
   POLISH PASS — scrollbars, focus, motion, depth
   ============================================================ */
/* dark thin scrollbars (app-wide) */
.content,.drawer-body,.modal-card,.tbl-wrap{scrollbar-width:thin;scrollbar-color:rgba(255,255,255,.16) transparent}
.content::-webkit-scrollbar,.drawer-body::-webkit-scrollbar,.modal-card::-webkit-scrollbar,.tbl-wrap::-webkit-scrollbar{width:9px;height:9px}
.content::-webkit-scrollbar-thumb,.drawer-body::-webkit-scrollbar-thumb,.modal-card::-webkit-scrollbar-thumb,.tbl-wrap::-webkit-scrollbar-thumb{background:rgba(255,255,255,.13);border-radius:8px;border:2px solid transparent;background-clip:padding-box}
.content::-webkit-scrollbar-thumb:hover,.tbl-wrap::-webkit-scrollbar-thumb:hover{background:rgba(255,255,255,.24);background-clip:padding-box}

/* keyboard focus rings */
.btn:focus-visible,.tab:focus-visible,.icon-btn:focus-visible,.cswitch-btn:focus-visible,
.cmenu-item:focus-visible,.period button:focus-visible,.linkish:focus-visible,
.switch:focus-visible,.x:focus-visible,.tbl tbody tr:focus-visible{
  outline:2px solid var(--acc);outline-offset:2px;border-radius:11px;
}
.fg input:focus-visible,.fg select:focus-visible,#brutoInput:focus-visible{outline:none}

/* tactile press states */
.btn:active{transform:translateY(0) scale(.975)}
.tab:active{transform:scale(.97)}
.icon-btn:active,.period button:active,.x:active{transform:scale(.92)}
.cmenu-item:active{transform:scale(.99)}

/* view entrance — starts near-full opacity so it can never trap content hidden or look dim */
#view.vin{animation:viewIn .34s var(--ease)}
@keyframes viewIn{from{opacity:.6;transform:translateY(8px)}to{opacity:1;transform:none}}
@media (prefers-reduced-motion:reduce){#view.vin{animation:none}}

/* kpi: faint top sheen + gentle hover lift */
.kpi{transition:transform .3s var(--ease),box-shadow .3s var(--ease)}
.kpi::after{content:"";position:absolute;inset:0 0 auto 0;height:1px;background:linear-gradient(90deg,transparent,rgba(255,255,255,.14),transparent);pointer-events:none}
.kpi:hover{transform:translateY(-3px)}
.kpi.hero-kpi:hover{box-shadow:inset 0 0 0 1px var(--acc-line),0 18px 40px -22px var(--acc-glow)}

/* clickable table rows get an accent rail on hover */
.tbl tbody tr{position:relative}
.tbl tbody tr td:first-child{box-shadow:0 1px 0 var(--line),inset 3px 0 0 transparent;transition:box-shadow .15s}
.tbl tbody tr:hover td:first-child{box-shadow:0 1px 0 var(--line),inset 3px 0 0 var(--acc)}

/* chart bar hover */
.chart .bar{transition:height .6s var(--ease),filter .2s,transform .2s}
.chart .col:hover .bar{filter:brightness(1.18);transform:scaleY(1.02);transform-origin:bottom}

/* tab badge subtle pulse when pending (reports) */
.tab .tb{transition:background .18s}

/* ---------- COST DONUT ---------- */
.donut-wrap{margin-top:4px}
.donut-row{display:flex;align-items:center;gap:18px}
.donut{width:128px;height:128px;border-radius:50%;flex:none;position:relative}
.donut::after{content:"";position:absolute;inset:19px;border-radius:50%;background:#0f1217;box-shadow:inset 0 0 0 1px var(--line)}
.donut-hole{position:absolute;inset:0;display:grid;place-content:center;justify-items:center;text-align:center;z-index:1}
.donut-hole .dh-v{font-family:var(--f-display);font-weight:700;font-size:1.02rem;letter-spacing:-.02em}
.donut-hole .dh-l{font-family:var(--f-mono);font-size:9.5px;color:var(--faint)}
.dn-legend{flex:1;display:flex;flex-direction:column;gap:9px;min-width:0}
.dn-leg{display:flex;align-items:center;gap:9px;font-size:.82rem}
.dn-leg .sw{width:10px;height:10px;border-radius:3px;flex:none}
.dn-leg .dl{color:var(--txt-soft);flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.dn-leg .dv{font-family:var(--f-mono);font-weight:600;font-size:.8rem}

/* ---------- VACATION BALANCES ---------- */
.bal-list{display:flex;flex-direction:column;gap:15px}
.bal-row{display:flex;align-items:center;gap:12px}
.bal-bar{flex:1;height:7px;border-radius:6px;background:rgba(255,255,255,.1);overflow:hidden;max-width:150px}
.bal-bar i{display:block;height:100%;background:linear-gradient(90deg,var(--acc-deep),var(--acc));border-radius:6px}

/* ---------- DRAWER TABS + PROFILE ---------- */
.dtabs{display:flex;gap:4px;padding:12px 16px;box-shadow:0 1px 0 var(--line);overflow-x:auto;scrollbar-width:none}
.dtabs::-webkit-scrollbar{display:none}
.dtab{padding:8px 13px;border-radius:9px;font-size:.85rem;font-weight:600;color:var(--muted);white-space:nowrap;flex:none;transition:.15s}
.dtab:hover{color:var(--txt);background:var(--glass)}
.dtab.on{background:var(--acc);color:var(--acc-ink)}
.slip-list{display:flex;flex-direction:column;gap:8px}
.slip-item{display:flex;align-items:center;gap:12px;padding:12px 13px;border-radius:12px;background:var(--glass);box-shadow:inset 0 0 0 1px var(--line);cursor:pointer;transition:.15s}
.slip-item:hover{box-shadow:inset 0 0 0 1px var(--acc-line);transform:translateY(-1px)}
.slip-item .tli{width:34px;height:34px;border-radius:9px;display:grid;place-items:center;background:rgba(200,255,46,.12);color:var(--acc);flex:none}
.slip-item .tli svg{width:18px;height:18px}
.slip-item > svg{width:18px;height:18px;color:var(--faint);flex:none}

/* ---------- PRODUCT TOUR ---------- */
.tour-catch{position:fixed;inset:0;z-index:100;display:none}
.tour-catch.show{display:block}
.tour-spot{position:fixed;z-index:101;display:none;border-radius:13px;pointer-events:none;
  box-shadow:0 0 0 9999px rgba(5,6,8,.66),0 0 0 2px var(--acc),0 0 44px -6px var(--acc-glow);
  transition:left .3s var(--ease),top .3s var(--ease),width .3s var(--ease),height .3s var(--ease)}
.tour-pop{position:fixed;z-index:102;display:none;width:300px;max-width:calc(100vw - 32px);padding:18px;border-radius:16px;
  background:linear-gradient(180deg,#14171b,#0d0f12);box-shadow:inset 0 0 0 1px var(--line-hi),0 24px 60px -20px rgba(0,0,0,.9);
  transition:left .3s var(--ease),top .3s var(--ease)}
.tour-pop .tp-step{font-family:var(--f-mono);font-size:11px;color:var(--acc);letter-spacing:.1em}
.tour-pop h4{font-family:var(--f-display);font-weight:700;font-size:1.12rem;margin:8px 0 6px}
.tour-pop p{color:var(--muted);font-size:.88rem;line-height:1.5}
.tour-pop .tp-foot{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-top:16px}
.tour-pop .tp-dots{display:flex;gap:5px}
.tour-pop .tp-dots i{width:6px;height:6px;border-radius:50%;background:rgba(255,255,255,.2);transition:.2s}
.tour-pop .tp-dots i.on{background:var(--acc);width:16px;border-radius:3px}

/* ---------- RESPONSIVE ---------- */
@media(min-width:680px){
  .kpis{grid-template-columns:repeat(4,1fr)}
  .grid-2{grid-template-columns:1.6fr 1fr}
  .cswitch-btn .cmeta{display:flex}
  .searchbox{display:flex}
}
@media(min-width:1460px){
  .plan-chip{display:flex}
}
@media(min-width:1080px){
  .grid-main{grid-template-columns:2fr 1fr}
}
@media(max-width:680px){
  .bar-main{padding:12px 16px 11px}
  .bar-nav{padding:6px 14px}
  .appbar .logo{font-size:.98rem}
  .content{padding:18px 14px 60px}

  /* declutter top-right: settings avatar lives in the tab row already */
  .me-btn{display:none}

  /* scrollable tab row: momentum + snap + fade edges */
  .tabs{-webkit-overflow-scrolling:touch;scroll-snap-type:x proximity;
    -webkit-mask-image:linear-gradient(90deg,transparent,#000 16px,#000 calc(100% - 16px),transparent);
    mask-image:linear-gradient(90deg,transparent,#000 16px,#000 calc(100% - 16px),transparent)}
  .tab{scroll-snap-align:start}

  /* horizontally-scrolling tables: freeze the first (name) column */
  .tbl-wrap{-webkit-overflow-scrolling:touch}
  .tbl thead th:first-child,.tbl tbody td:first-child,.tbl tfoot td:first-child{
    position:sticky;left:0;z-index:2;background:#0c0e11;
  }
  .tbl tbody td:first-child{box-shadow:0 1px 0 var(--line),6px 0 12px -6px rgba(0,0,0,.7)}
  .tbl thead th:first-child{box-shadow:0 1px 0 var(--line),6px 0 12px -6px rgba(0,0,0,.7)}
  .tbl tbody tr:hover td:first-child{box-shadow:0 1px 0 var(--line),inset 3px 0 0 var(--acc),6px 0 12px -6px rgba(0,0,0,.7)}

  /* tighter numbers so KPI values never clip on small cards */
  .kpi{padding:17px}
  .kpi .kv{font-size:1.55rem}
  .view-head h1{font-size:1.45rem}

  /* comfier touch targets */
  .period button.nav{width:36px;height:36px}
  .period .lbl{min-width:112px}
  .between{row-gap:12px}

  /* full-height sheets feel native */
  .drawer{width:100vw}
  .drawer-head{padding:18px 18px 16px}
  .drawer-body{padding:18px}
  .modal{padding:0;align-items:flex-end}
  .modal-card{width:100%;max-height:92vh;border-radius:22px 22px 0 0}
  .modal.show{animation:none}
  .modal-card{animation:sheetUp .3s var(--ease)}
}
@keyframes sheetUp{from{transform:translateY(40px);opacity:.6}to{transform:none;opacity:1}}
