/* ============================================================================
   WUMS — Application styles
   Presentation layer for the Water Utility Management System (LGU Lila).
   All colors come from the token layer (styles/tokens.css) — no hardcoded hex.
   ========================================================================== */
@import url("styles/tokens.css");

*{box-sizing:border-box}
html,body{margin:0;height:100%}
body{
  font-family:var(--font-sans);
  color:var(--color-text);
  background:var(--color-canvas);
  font-size:14px;line-height:1.5;
  -webkit-font-smoothing:antialiased;
}
button{font-family:inherit}
a{color:var(--color-primary)}
/* Tabular figures wherever numbers align in columns */
.num,.mono,th,td,.lcd,input,.stat .v,.kpi-split .v{font-variant-numeric:tabular-nums}
.mono{font-family:var(--font-mono)}
.hidden{display:none!important}

#app{display:grid;grid-template-columns:var(--rail) 1fr;min-height:100vh}

/* ---------------------------------------------------------------- sidebar -- */
.rail{
  background:var(--color-sidebar-bg);color:var(--color-sidebar-text);
  position:sticky;top:0;height:100vh;display:flex;flex-direction:column;padding:0;
}
.brand{padding:18px 16px 16px;border-bottom:1px solid rgba(255,255,255,.10)}
.brand .lockup{display:flex;align-items:center;gap:11px}
.brand .lockup img{height:30px;width:auto;flex:0 0 auto}
.brand .drop{display:flex;align-items:center;gap:10px}
.brand .logo{width:34px;height:34px;border-radius:9px;background:linear-gradient(150deg,var(--color-primary),var(--color-accent));display:grid;place-items:center;flex:0 0 auto;box-shadow:inset 0 0 0 1px rgba(255,255,255,.15)}
.brand .logo svg{width:20px;height:20px}
.brand .mark{height:34px;width:auto}
.brand h1{font-size:15px;margin:0;color:#fff;letter-spacing:.4px;font-weight:800}
.brand .sub{font-size:10.5px;color:var(--color-sidebar-text);opacity:.8;margin-top:2px;letter-spacing:.2px;line-height:1.35}

nav{padding:10px 10px 0;flex:1;overflow:auto}
.nav-grp{font-size:10px;text-transform:uppercase;letter-spacing:.14em;color:#7E93B0;margin:14px 10px 6px}
.nav-item{display:flex;align-items:center;gap:10px;padding:9px 11px;border-radius:var(--radius-md);color:var(--color-sidebar-text);cursor:pointer;font-size:13.5px;font-weight:500;border:1px solid transparent;margin-bottom:2px}
.nav-item:hover{background:rgba(255,255,255,.07);color:#fff}
.nav-item.on{background:var(--color-sidebar-active-bg);color:var(--color-sidebar-active-tx);font-weight:650;box-shadow:0 1px 2px rgba(13,110,253,.4)}
.nav-item:focus-visible{outline:none;box-shadow:0 0 0 3px rgba(255,255,255,.35)}
.nav-item .ic{width:17px;height:17px;flex:0 0 auto;opacity:.92}
.nav-item .badge{margin-left:auto;font-size:11px;background:rgba(255,255,255,.14);padding:1px 7px;border-radius:20px;font-variant-numeric:tabular-nums}
.nav-item.on .badge{background:rgba(255,255,255,.22);color:#fff}
.rail-foot{padding:12px 16px;border-top:1px solid rgba(255,255,255,.10);font-size:11.5px;color:var(--color-sidebar-text)}
.rail-foot .who{color:#fff;font-weight:600}
.rail-foot a{color:#9DB2D0;cursor:pointer;text-decoration:underline}
.rail-foot a:hover{color:#fff}

/* ---------------------------------------------------------------- top bar -- */
main{min-width:0}
.topbar{display:flex;align-items:center;gap:14px;padding:14px 28px;background:var(--color-surface);border-bottom:1px solid var(--color-border);position:sticky;top:0;z-index:5}
.crumb{font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--color-text-muted)}
.topbar h2{font-size:24px;margin:1px 0 0;font-weight:600;letter-spacing:-.2px;color:var(--color-text)}
.period-pill{margin-left:auto;display:flex;align-items:center;gap:8px;font-size:12px;color:var(--color-n-600);background:var(--color-n-50);border:1px solid var(--color-border);padding:6px 12px;border-radius:30px}
.period-pill b{color:var(--color-primary)}
.wrap{padding:24px 28px 60px;max-width:1200px}

/* ----------------------------------------------------------------- cards --- */
.grid{display:grid;gap:16px}
.cards-4{grid-template-columns:repeat(4,1fr)}
.cards-3{grid-template-columns:repeat(3,1fr)}
.cards-2{grid-template-columns:repeat(2,1fr)}
.stat{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:16px 18px;box-shadow:var(--shadow-card);position:relative;overflow:hidden}
.stat::before{content:"";position:absolute;inset:0 auto 0 0;width:4px;background:var(--color-primary)}
.stat.s-warning::before{background:var(--color-warning)}
.stat.s-danger::before{background:var(--color-danger)}
.stat.s-success::before{background:var(--color-success)}
.stat .k{font-size:11px;text-transform:uppercase;letter-spacing:.1em;color:var(--color-text-muted);display:flex;align-items:center;gap:7px}
.stat .v{font-size:27px;font-weight:600;margin-top:7px;letter-spacing:-.5px;color:var(--color-text)}
.stat .v small{font-size:14px;font-weight:600;color:var(--color-text-muted)}
.stat .foot{font-size:11.5px;color:var(--color-n-600);margin-top:4px}
.dot{width:8px;height:8px;border-radius:50%;display:inline-block}

/* ---------------------------------------------------------------- panels --- */
.panel{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-card);overflow:hidden}
.panel-h{display:flex;align-items:center;gap:12px;padding:14px 18px;border-bottom:1px solid var(--color-n-100)}
.panel-h h3{margin:0;font-size:16px;font-weight:600;color:var(--color-text)}
.panel-h .hint{font-size:12px;color:var(--color-text-muted)}
.panel-b{padding:18px}

/* ---------------------------------------------------------------- tables --- */
table{width:100%;border-collapse:collapse;font-size:13.5px}
th{text-align:left;font-size:10.5px;text-transform:uppercase;letter-spacing:.08em;color:var(--color-n-600);font-weight:600;padding:10px 14px;border-bottom:1px solid var(--color-border);white-space:nowrap;background:var(--color-n-50);position:sticky;top:0}
td{padding:10px 14px;border-bottom:1px solid var(--color-n-100);vertical-align:middle;color:var(--color-text)}
tr:last-child td{border-bottom:none}
tbody tr:hover{background:var(--color-n-50)}
.r{text-align:right}.c{text-align:center}

/* ----------------------------------------------------- status badges/tags -- */
.tag{display:inline-flex;align-items:center;gap:5px;font-size:11px;font-weight:600;padding:2px 9px;border-radius:30px;white-space:nowrap;line-height:1.5}
.tag svg{width:12px;height:12px;flex:0 0 auto}
/* classification */
.t-res{background:#E7F0FF;color:var(--color-primary-active)}
.t-com{background:var(--color-notice-bg);color:var(--color-notice)}
.t-gov{background:var(--color-info-bg);color:var(--color-info)}
/* status (corrected, contrast-verified tokens) */
.t-paid,.t-active{background:var(--color-success-bg);color:var(--color-success)}
.t-unpaid{background:var(--color-warning-bg);color:var(--color-warning)}
.t-partial{background:var(--color-info-bg);color:var(--color-info)}
.t-cut{background:var(--color-danger-bg);color:var(--color-danger)}
.t-closed{background:var(--color-n-100);color:var(--color-n-600)}
.t-notice{background:var(--color-info-bg);color:var(--color-info)}
.t-senior{background:var(--color-notice-bg);color:var(--color-notice)}

/* --------------------------------------------------------------- buttons --- */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:7px;border:1px solid var(--color-n-300);background:var(--color-surface);color:var(--color-n-800);padding:8px 14px;border-radius:var(--radius-md);font-size:13px;font-weight:560;cursor:pointer;transition:.12s}
.btn:hover{background:var(--color-n-50);border-color:var(--color-n-400)}
.btn:focus-visible{outline:none;box-shadow:var(--focus-ring);border-color:var(--color-primary)}
.btn svg{width:15px;height:15px}
/* Primary (filled blue) — also covers legacy .pri / .aqua */
.btn.pri,.btn.aqua{background:var(--color-primary);color:var(--color-text-invert);border-color:var(--color-primary)}
.btn.pri:hover,.btn.aqua:hover{background:var(--color-primary-hover);border-color:var(--color-primary-hover);color:#fff}
.btn.pri:active,.btn.aqua:active{background:var(--color-primary-active);border-color:var(--color-primary-active)}
/* Success (Confirm) */
.btn.success{background:var(--color-success);color:#fff;border-color:var(--color-success)}
.btn.success:hover{background:#136B34;border-color:#136B34}
/* Danger (Disconnect) */
.btn.danger{background:var(--color-danger);color:#fff;border-color:var(--color-danger)}
.btn.danger:hover{background:#B91C1C;border-color:#B91C1C}
/* Outline */
.btn.outline{background:transparent;color:var(--color-primary);border-color:var(--color-primary)}
.btn.outline:hover{background:#E7F0FF}
/* Ghost / icon-only */
.btn.ghost{border-color:transparent;background:transparent;color:var(--color-primary)}
.btn.ghost:hover{background:#E7F0FF}
.btn.sm{padding:5px 10px;font-size:12px}
.btn:disabled{opacity:.45;cursor:not-allowed}

/* ---------------------------------------------------------------- inputs --- */
input,select{font-family:inherit;font-size:13px;color:var(--color-text);background:var(--color-surface);border:1px solid var(--color-n-300);border-radius:var(--radius-sm);padding:8px 11px;width:100%}
input::placeholder{color:var(--color-n-400)}
input:focus,select:focus{outline:none;border-color:var(--color-primary);box-shadow:var(--focus-ring)}
input.mini{padding:6px 9px}
input.err,select.err{border-color:var(--color-danger)}
label.fld{display:block;font-size:11.5px;color:var(--color-n-600);font-weight:600;margin:0 0 5px}
label.fld .req{color:var(--color-danger);margin-left:2px}
.help.err-text{color:var(--color-danger)}
.row{display:flex;gap:12px;align-items:center;flex-wrap:wrap}
.toolbar{display:flex;gap:10px;align-items:center;margin-bottom:16px;flex-wrap:wrap}
.toolbar .search{position:relative;flex:1;min-width:220px;max-width:360px}
.toolbar .search svg{position:absolute;left:11px;top:50%;transform:translateY(-50%);width:15px;height:15px;color:var(--color-n-400)}
.toolbar .search input{padding-left:34px}

/* ------------------------------------------------------------- LCD readout - */
.lcd{font-family:var(--font-mono);background:#08252c;color:#5ff0d6;padding:5px 9px;border-radius:var(--radius-sm);letter-spacing:1px;font-size:13px;display:inline-block;box-shadow:inset 0 0 0 1px rgba(95,240,214,.18),inset 0 1px 6px rgba(0,0,0,.4);font-variant-numeric:tabular-nums}
.lcd.amber{color:#ffcf6b;box-shadow:inset 0 0 0 1px rgba(255,207,107,.2),inset 0 1px 6px rgba(0,0,0,.4)}

/* ---------------------------------------------------------------- modals --- */
.scrim{position:fixed;inset:0;background:rgba(11,36,71,.45);display:flex;align-items:flex-start;justify-content:center;padding:40px 16px;z-index:50;overflow:auto}
.modal{background:var(--color-surface);border-radius:var(--radius-lg);box-shadow:0 24px 60px rgba(11,36,71,.3);width:100%;max-width:560px;overflow:hidden}
.modal.wide{max-width:820px}
.modal-h{display:flex;align-items:center;padding:16px 20px;border-bottom:1px solid var(--color-border)}
.modal-h h3{margin:0;font-size:16px;font-weight:600}
.modal-h .x{margin-left:auto;cursor:pointer;color:var(--color-n-500);width:28px;height:28px;display:grid;place-items:center;border-radius:7px}
.modal-h .x:hover{background:var(--color-n-100)}
.modal-b{padding:20px;max-height:70vh;overflow:auto}
.modal-f{padding:14px 20px;border-top:1px solid var(--color-border);display:flex;gap:10px;justify-content:flex-end;background:var(--color-n-50)}
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.form-grid .full{grid-column:1/-1}

/* --------------------------------------------------------- misc utilities -- */
.empty{text-align:center;color:var(--color-text-muted);padding:46px 20px}
.empty svg{width:38px;height:38px;opacity:.5;margin-bottom:10px}
.toast{position:fixed;bottom:22px;left:50%;transform:translateX(-50%);background:var(--color-sidebar-bg);color:#fff;padding:11px 18px;border-radius:30px;font-size:13px;box-shadow:0 8px 30px rgba(11,36,71,.35);z-index:80;opacity:0;transition:.25s;display:flex;gap:9px;align-items:center;pointer-events:none}
.toast.show{opacity:1;bottom:30px}
.toast.err{background:var(--color-danger)}

.bar{height:8px;border-radius:6px;background:var(--color-n-100);overflow:hidden}
.bar > i{display:block;height:100%;background:linear-gradient(90deg,var(--color-primary),var(--color-accent))}
.mini-bars{display:flex;align-items:flex-end;gap:6px;height:90px}
.mini-bars .b{flex:1;background:#E7F0FF;border-radius:5px 5px 0 0;position:relative;min-height:4px}
.mini-bars .b > i{position:absolute;inset:auto 0 0;background:linear-gradient(180deg,var(--color-primary),var(--color-primary-active));border-radius:5px 5px 0 0}
.mini-bars .lab{font-size:10px;color:var(--color-text-muted);text-align:center;margin-top:6px}

.note{font-size:12px;color:var(--color-n-700);background:#E7F0FF;border:1px solid #BBD6FF;border-radius:var(--radius-md);padding:11px 14px;display:flex;gap:9px}
.note.amber{background:var(--color-warning-bg);color:var(--color-warning);border-color:#F1D49B}
.note svg{width:16px;height:16px;flex:0 0 auto;margin-top:1px}

.kpi-split{display:flex;gap:0;flex-wrap:wrap}
.kpi-split > div{padding:14px 18px;border-right:1px solid var(--color-n-100);flex:1;min-width:130px}
.kpi-split > div:last-child{border-right:none}
.kpi-split .k{font-size:11px;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.08em}
.kpi-split .v{font-size:20px;font-weight:600;margin-top:3px;color:var(--color-text)}

/* ------------------------------------------------------- invoice / notice - */
.inv-sheet{background:#fff;border:1px solid var(--color-border);border-radius:var(--radius-md);padding:0;font-size:12.5px;color:var(--color-n-900)}
.inv-copy{padding:20px 22px;border-bottom:2px dashed var(--color-border)}
.inv-copy:last-child{border-bottom:none}
.inv-head{display:flex;justify-content:space-between;align-items:flex-start}
.inv-head .org{font-weight:700;font-size:14px;color:var(--color-text)}
.inv-head .org small{display:block;font-weight:500;color:var(--color-n-600);font-size:11px}
.inv-head .meta{text-align:right;font-size:11px;color:var(--color-n-600)}
.inv-no{font-family:var(--font-mono);font-weight:700;color:var(--color-primary);font-size:13px}
.inv-tag{display:inline-block;font-size:9.5px;letter-spacing:.12em;text-transform:uppercase;color:var(--color-text-muted);border:1px solid var(--color-border);padding:1px 7px;border-radius:20px;margin-top:4px}
.inv-row{display:flex;justify-content:space-between;padding:3px 0;border-bottom:1px dotted var(--color-n-200)}
.inv-row.tot{border-top:2px solid var(--color-text);border-bottom:none;margin-top:5px;padding-top:7px;font-weight:700;font-size:14px;color:var(--color-text)}
.inv-2col{display:grid;grid-template-columns:1fr 1fr;gap:18px;margin:12px 0}
.inv-meter{background:var(--color-n-50);border:1px solid var(--color-border);border-radius:var(--radius-sm);padding:9px 12px}
.inv-foot{margin-top:12px;font-size:10.5px;color:var(--color-text-muted);display:flex;justify-content:space-between;gap:14px}
.print-logo{height:34px;width:auto;display:none}

.seg{display:inline-flex;border:1px solid var(--color-border);border-radius:var(--radius-md);overflow:hidden}
.seg button{border:none;background:var(--color-surface);padding:7px 13px;font-size:12.5px;cursor:pointer;color:var(--color-n-600);border-right:1px solid var(--color-border)}
.seg button:last-child{border-right:none}
.seg button.on{background:var(--color-primary);color:#fff;font-weight:600}
.seg button:focus-visible{outline:none;box-shadow:var(--focus-ring)}

/* Tabs */
.tabs{display:flex;gap:4px;border-bottom:1px solid var(--color-border)}
.tab{padding:9px 14px;font-size:13px;font-weight:560;color:var(--color-n-600);cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-1px}
.tab.on{color:var(--color-primary);border-bottom-color:var(--color-primary)}
.tab:hover{color:var(--color-text)}

.ledger-line{display:flex;justify-content:space-between;padding:7px 0;border-bottom:1px dotted var(--color-border);font-size:13px}
.help{font-size:11.5px;color:var(--color-text-muted);margin-top:4px}

/* ----------------------------------------------------------------- login -- */
.login-scrim{position:fixed;inset:0;background:linear-gradient(160deg,var(--color-sidebar-bg),#08152c);display:flex;align-items:center;justify-content:center;z-index:100}
.login-card{background:var(--color-surface);border-radius:18px;box-shadow:0 30px 80px rgba(0,0,0,.4);width:100%;max-width:380px;padding:30px 28px}
.login-card .lockup{display:flex;align-items:center;gap:10px;margin-bottom:6px}
.login-card .lockup img{height:34px;width:auto}
.login-card .logo{width:46px;height:46px;border-radius:12px;background:linear-gradient(150deg,var(--color-primary),var(--color-accent));display:grid;place-items:center;margin-bottom:14px}
.login-card .logo svg{width:26px;height:26px}
.login-card h1{font-size:18px;margin:14px 0 2px;font-weight:700}
.login-card .sub{font-size:12px;color:var(--color-text-muted);margin-bottom:20px}
.login-card label.fld{margin-top:12px}
.login-card .err{color:var(--color-danger);font-size:12.5px;margin-top:10px;min-height:16px}
.login-card .hint-creds{font-size:11px;color:var(--color-text-muted);margin-top:16px;line-height:1.6}

/* ----------------------------------------------------- stat tile polish --- */
.stat-row{display:flex;align-items:center;gap:12px}
.stat-ic{width:40px;height:40px;border-radius:11px;flex:0 0 auto;display:grid;place-items:center;background:#E7F0FF;color:var(--color-primary)}
.stat-ic svg{width:20px;height:20px}
.stat .stat-main{min-width:0}
.stat .stat-main .v{margin-top:1px;font-size:24px}
.stat.s-primary .stat-ic{background:#E7F0FF;color:var(--color-primary)}
.stat.s-success .stat-ic{background:var(--color-success-bg);color:var(--color-success)}
.stat.s-success .stat-main .v{color:var(--color-success)}
.stat.s-warning .stat-ic{background:var(--color-warning-bg);color:var(--color-warning)}
.stat.s-warning .stat-main .v{color:var(--color-warning)}
.stat.s-danger  .stat-ic{background:var(--color-danger-bg);color:var(--color-danger)}
.stat.s-danger  .stat-main .v{color:var(--color-danger)}
.stat .foot{margin-top:10px}
.stat{transition:transform .14s ease, box-shadow .14s ease}
.stat:hover{transform:translateY(-2px);box-shadow:0 6px 18px rgba(16,24,40,.10)}
.panel{transition:box-shadow .16s ease}

/* ----------------------------------------------------------------- charts - */
.chart{width:100%;display:block;overflow:visible}
.ch-grid{stroke:var(--color-n-100);stroke-width:1}
.ch-line{fill:none;stroke:var(--color-primary);stroke-width:2.5;stroke-linecap:round;stroke-linejoin:round;
  stroke-dasharray:2400;stroke-dashoffset:2400;animation:draw 1.1s ease forwards}
.ch-dot{fill:#fff;stroke:var(--color-primary);stroke-width:2}
.ch-dot.peak{fill:var(--color-primary)}
.ch-xlabel{fill:var(--color-text-muted);font-size:11px;text-anchor:middle;font-family:var(--font-sans)}
.ch-peak-bg{fill:var(--color-sidebar-bg)}
.ch-peak-tx{fill:#fff;font-size:11px;font-weight:700;text-anchor:middle;font-variant-numeric:tabular-nums;font-family:var(--font-sans)}
@keyframes draw{to{stroke-dashoffset:0}}

/* donut */
.donut-wrap{display:flex;align-items:center;gap:20px;flex-wrap:wrap}
.donut-svg{position:relative;width:150px;height:150px;flex:0 0 auto}
.donut-svg .chart{width:150px;height:150px}
.donut-svg circle[stroke-dasharray]{animation:donutIn .8s ease both}
@keyframes donutIn{from{opacity:0}to{opacity:1}}
.donut-center{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;pointer-events:none}
.donut-center .dc-top{font-size:26px;font-weight:700;letter-spacing:-.5px;color:var(--color-text)}
.donut-center .dc-sub{font-size:11px;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.08em}
.donut-legend{flex:1;min-width:160px;display:flex;flex-direction:column;gap:8px}
.leg-row{display:flex;align-items:center;gap:9px;font-size:12.5px}
.leg-dot{width:10px;height:10px;border-radius:3px;flex:0 0 auto}
.leg-lab{color:var(--color-n-700);flex:1}
.leg-val{font-weight:600;color:var(--color-text)}
.leg-pct{color:var(--color-text-muted);width:38px;text-align:right}

/* bar chart */
.bar-chart{display:flex;align-items:flex-end;gap:10px;height:160px;padding-top:18px}
.bc-col{flex:1;display:flex;flex-direction:column;align-items:center;height:100%;justify-content:flex-end;min-width:0}
.bc-cap{font-size:11px;font-weight:600;color:var(--color-n-700);margin-bottom:4px}
.bc-track{width:100%;max-width:34px;flex:1;display:flex;align-items:flex-end}
.bc-fill{width:100%;border-radius:6px 6px 0 0;background:linear-gradient(180deg,var(--color-primary),var(--color-primary-active));
  transform-origin:bottom;animation:grow .7s ease both}
.bc-lab{font-size:10.5px;color:var(--color-text-muted);margin-top:7px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%}
@keyframes grow{from{transform:scaleY(0)}to{transform:scaleY(1)}}

/* card reveal on load */
.reveal{animation:reveal .45s ease both}
@keyframes reveal{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}
@media (prefers-reduced-motion:reduce){
  .reveal,.bc-fill,.ch-line,.donut-svg circle[stroke-dasharray]{animation:none!important}
  .ch-line{stroke-dashoffset:0}
}

/* ------------------------------------------------------- topbar user chip - */
.user-chip{display:flex;align-items:center;gap:9px;padding:5px 10px 5px 6px;border:1px solid var(--color-border);border-radius:30px;background:var(--color-surface)}
.avatar{width:30px;height:30px;border-radius:50%;flex:0 0 auto;display:grid;place-items:center;color:#fff;font-size:12px;font-weight:700;background:linear-gradient(150deg,var(--color-primary),var(--color-accent))}
.user-chip .u-name{font-size:12.5px;font-weight:600;color:var(--color-text);line-height:1.1}
.user-chip .u-role{font-size:10.5px;color:var(--color-text-muted);text-transform:capitalize}

/* ------------------------------------------------------------- responsive - */
@media (max-width:1000px){
  :root{--rail:64px}
  .brand h1,.brand .sub,.brand .lockup img,.nav-item span.lbl,.nav-grp,.rail-foot{display:none}
  .brand .mark,.brand .logo{margin:0 auto}
  .nav-item{justify-content:center}
  .cards-4{grid-template-columns:repeat(2,1fr)}
  .cards-3{grid-template-columns:1fr}
}

/* ----------------------------------------------------------------- print --- */
@media print{
  .rail,.topbar,.toolbar,.no-print{display:none!important}
  #app{display:block}
  .wrap{padding:0;max-width:none}
  body{background:#fff;color:#000}
  .inv-sheet,.panel{border:none;box-shadow:none}
  .modal{box-shadow:none;max-width:none}
  .scrim{position:static;background:none;padding:0;display:block}
  .modal-h,.modal-f{display:none!important}
  .print-logo{display:block}
  /* Meaning never by color alone in grayscale — badges keep text, draw a hairline border */
  .tag{border:1px solid #999;color:#000 !important;background:#fff !important}
  .inv-no{color:#000}
  /* BIR dual-copy invoice: keep both copies on one output */
  .inv-copy{page-break-inside:avoid}
}
