:root{
  --green-900:#0F2419; --green-800:#163322; --green-700:#1A3A2A; --green-600:#234a36;
  --gold:#C9A24B; --gold-soft:#e7d3a1;
  --paper:#f4f2ec; --card:#ffffff; --ink:#1c2620; --ink-soft:#5c6b62;
  --line:#e3e0d6; --line-strong:#cfcabc;
  --pos:#1f8a5b; --pos-bg:#e7f4ec; --neg:#c0392b; --neg-bg:#fbeae7;
  --row-hover:#f6f4ed; --section-bg:#eef0e9;
  --shadow:0 1px 2px rgba(15,36,25,.06),0 8px 24px rgba(15,36,25,.06);
}
*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{
  font-family:'Inter',system-ui,-apple-system,Segoe UI,Roboto,sans-serif;
  background:var(--paper); color:var(--ink); font-size:14px;
  -webkit-font-smoothing:antialiased; font-variant-numeric:tabular-nums;
}
.num{font-variant-numeric:tabular-nums;font-feature-settings:"tnum"}

/* ---------- shell + sidebar ---------- */
.app-shell{display:flex;min-height:100vh}
.sidebar{
  width:240px;flex:0 0 240px;background:linear-gradient(160deg,var(--green-700),var(--green-900));
  color:#fff;display:flex;flex-direction:column;padding:18px 14px;gap:8px;position:sticky;top:0;
  height:100vh;overflow-y:auto;box-shadow:6px 0 22px rgba(15,36,25,.18);
}
.side-brand{display:flex;align-items:center;gap:10px;padding:0 4px 14px;border-bottom:1px solid rgba(255,255,255,.1);margin-bottom:6px}
.mark{
  width:44px;height:44px;border-radius:10px;flex:0 0 auto;
  background:radial-gradient(circle at 30% 25%,var(--gold-soft),var(--gold) 60%,#a37f2f);
  display:grid;place-items:center;color:var(--green-900);
  font-family:'Bebas Neue',sans-serif;font-size:24px;line-height:1;
  box-shadow:inset 0 0 0 2px rgba(255,255,255,.25);
}
.side-name{font-family:'Bebas Neue',sans-serif;font-weight:400;letter-spacing:.5px;font-size:24px;line-height:1}
.side-name span{color:var(--gold)}
.side-sub{font-size:10.5px;letter-spacing:.14em;text-transform:uppercase;color:var(--gold-soft);margin-top:3px}
.side-nav{display:flex;flex-direction:column;gap:2px;flex:1;padding-top:6px}
.nav-item{
  text-decoration:none;color:rgba(255,255,255,.78);
  display:flex;align-items:center;gap:10px;padding:9px 12px;border-radius:8px;
  font-size:13.5px;font-weight:600;letter-spacing:.01em;
  position:relative;
}
.nav-item svg{width:18px;height:18px;flex:0 0 auto;stroke-width:1.8}
.nav-item:hover{background:rgba(255,255,255,.06);color:#fff}
.nav-item:hover svg{color:var(--gold-soft)}
.nav-item.active{background:rgba(201,162,75,.18);color:#fff}
.nav-item.active::before{content:"";position:absolute;left:0;top:8px;bottom:8px;width:3px;background:var(--gold);border-radius:0 3px 3px 0}
.nav-item.active svg{color:var(--gold)}
.nav-div{height:1px;background:rgba(255,255,255,.1);margin:8px 4px}
.nav-label{font-size:10.5px;letter-spacing:.14em;text-transform:uppercase;color:rgba(255,255,255,.4);padding:6px 12px 2px}
.side-foot{border-top:1px solid rgba(255,255,255,.1);padding-top:10px;margin-top:6px;display:flex;flex-direction:column;gap:6px}
.user-chip{
  display:flex;align-items:center;gap:10px;background:rgba(255,255,255,.06);
  border-radius:10px;padding:8px 10px;color:#fff;text-decoration:none;
}
.user-chip:hover{background:rgba(255,255,255,.1);color:#fff}
.avatar{
  width:32px;height:32px;border-radius:50%;background:var(--gold);
  color:var(--green-900);font-weight:700;display:grid;place-items:center;font-size:13px;
}
.user-meta{display:flex;flex-direction:column;line-height:1.2;min-width:0}
.user-name{font-weight:600;font-size:13px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.user-role{font-size:11px;color:var(--gold-soft)}
.logout-link{
  font-size:11.5px;color:rgba(255,255,255,.5);text-decoration:none;
  padding:6px 12px;display:flex;align-items:center;gap:8px;border-radius:6px;
}
.logout-link svg{width:14px;height:14px;stroke-width:1.8}
.logout-link:hover{color:#fff;background:rgba(255,255,255,.06)}

.content{flex:1;min-width:0;display:flex;flex-direction:column}

/* ---------- topbar ---------- */
.topbar{
  background:#fff;border-bottom:1px solid var(--line);padding:14px 22px;
  display:flex;align-items:center;justify-content:space-between;gap:14px;flex-wrap:wrap;
  position:sticky;top:0;z-index:30;box-shadow:0 1px 0 rgba(15,36,25,.04);
}
.topbar-title{font-family:'Bebas Neue',sans-serif;font-size:26px;letter-spacing:.04em;color:var(--green-900)}
.topbar-controls{display:flex;align-items:center;gap:12px;flex-wrap:wrap}
.ctl{display:flex;flex-direction:column;gap:3px}
.ctl label{font-size:10px;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-soft)}
.ctl-input{
  background:#fff;color:var(--ink);border:1px solid var(--line-strong);
  border-radius:8px;padding:8px 32px 8px 12px;font-size:13px;font-family:inherit;min-width:120px;
  appearance:none;-webkit-appearance:none;-moz-appearance:none;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16'><path fill='none' stroke='%235c6b62' stroke-width='2' stroke-linecap='round' stroke-linejoin='round' d='M3 6l5 5 5-5'/></svg>");
  background-repeat:no-repeat;background-position:right 10px center;background-size:14px;cursor:pointer;
}
.ctl-input:focus{outline:none;border-color:var(--gold);box-shadow:0 0 0 2px rgba(201,162,75,.18)}
.user-form select{
  appearance:none;-webkit-appearance:none;-moz-appearance:none;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16'><path fill='none' stroke='%235c6b62' stroke-width='2' stroke-linecap='round' stroke-linejoin='round' d='M3 6l5 5 5-5'/></svg>");
  background-repeat:no-repeat;background-position:right 10px center;background-size:14px;padding-right:30px !important;cursor:pointer;
}
.save-pill{
  font-size:11px;color:var(--green-700);border:1px solid var(--line-strong);
  border-radius:999px;padding:5px 11px;white-space:nowrap;background:#fff;
  display:inline-flex;align-items:center;gap:6px;
}
.save-pill::before{
  content:"";width:7px;height:7px;border-radius:50%;background:var(--pos);
  box-shadow:0 0 0 0 rgba(31,138,91,.4);
}
.save-pill.saving{color:var(--gold);border-color:var(--gold)}
.save-pill.saving::before{background:var(--gold);animation:pulse 1.2s infinite}
.save-pill.error{color:var(--neg);border-color:var(--neg)}
.save-pill.error::before{background:var(--neg)}
@keyframes pulse{
  0%{box-shadow:0 0 0 0 rgba(201,162,75,.6)}
  70%{box-shadow:0 0 0 8px rgba(201,162,75,0)}
  100%{box-shadow:0 0 0 0 rgba(201,162,75,0)}
}

main{padding:20px 22px 64px;max-width:1500px;width:100%;margin:0 auto}
.panel{display:none}
.panel.active{display:block}
.module-intro p{background:var(--card);border:1px solid var(--line);border-radius:10px;padding:11px 14px;color:var(--ink-soft);font-size:13px;margin:0 0 12px}

/* ---------- toolbar ---------- */
.toolbar{
  display:flex;align-items:center;gap:16px;flex-wrap:wrap;
  background:var(--card);border:1px solid var(--line);border-radius:12px;
  padding:13px 16px;margin-bottom:16px;box-shadow:var(--shadow);
}
.seg{display:inline-flex;background:var(--section-bg);border-radius:9px;padding:3px;gap:2px}
.seg button{
  border:0;background:transparent;font-family:inherit;font-weight:600;font-size:12.5px;
  color:var(--ink-soft);padding:7px 14px;border-radius:7px;cursor:pointer;
}
.seg button:hover{color:var(--ink)}
.seg button.active{background:var(--green-700);color:#fff;box-shadow:var(--shadow)}
.seg button.active:hover{color:#fff}
.seg.gold button.active{background:var(--gold);color:var(--green-900)}
.seg.gold button.active:hover{color:var(--green-900)}
.toolbar .grp{display:flex;flex-direction:column;gap:5px}
.toolbar .grp > span{font-size:10px;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-soft);font-weight:600}
.branch-select, select.toolbar-select{
  min-width:220px;background:#fff;color:var(--ink);border:1px solid var(--line-strong);
  border-radius:8px;padding:8px 32px 8px 12px;font-size:13px;font-family:inherit;
  appearance:none;-webkit-appearance:none;-moz-appearance:none;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16'><path fill='none' stroke='%235c6b62' stroke-width='2' stroke-linecap='round' stroke-linejoin='round' d='M3 6l5 5 5-5'/></svg>");
  background-repeat:no-repeat;background-position:right 10px center;background-size:14px;cursor:pointer;
}
.branch-select:focus, select.toolbar-select:focus{outline:none;border-color:var(--gold);box-shadow:0 0 0 2px rgba(201,162,75,.18)}
.spacer{flex:1}
.btn{
  border:1px solid var(--line-strong);background:var(--card);color:var(--ink);
  font-family:inherit;font-weight:600;font-size:12.5px;padding:8px 13px;border-radius:8px;cursor:pointer;
  display:inline-flex;align-items:center;gap:7px;text-decoration:none;
}
.btn:hover{border-color:var(--green-600);color:var(--green-700)}
.btn.primary{background:var(--green-700);color:#fff;border-color:var(--green-700)}
.btn.primary:hover{background:var(--green-800);color:#fff}
.btn.ghost{background:transparent}
.btn.danger{color:var(--neg);border-color:var(--neg)}
.btn.danger:hover{background:var(--neg-bg)}
.btn.block{width:100%;justify-content:center;padding:10px 14px}
.editing-note{font-size:12px;color:var(--green-700);background:var(--pos-bg);border:1px solid #cfe6d8;border-radius:8px;padding:7px 11px}
.hint{font-size:12px;color:var(--ink-soft)}

/* ---------- statement tables ---------- */
.table-wrap{
  background:var(--card);border:1px solid var(--line);border-radius:12px;
  overflow:auto;box-shadow:var(--shadow);
}
table.stmt{border-collapse:separate;border-spacing:0;width:100%;min-width:1100px}
table.stmt th,table.stmt td{padding:0;white-space:nowrap}
table.stmt thead th{
  position:sticky;top:0;z-index:6;background:var(--green-800);color:#fff;
  font-weight:600;font-size:11.5px;letter-spacing:.04em;text-align:right;
  padding:14px 16px;border-bottom:2px solid var(--gold);min-width:112px;
}
table.stmt thead th.lab{text-align:left;left:0;z-index:8;min-width:300px;position:sticky;padding-left:18px}
table.stmt thead th.fytot{background:var(--green-900)}
.cell-lab{
  position:sticky;left:0;z-index:5;background:var(--card);
  text-align:left;padding:14px 18px;font-size:13px;border-bottom:1px solid var(--line);
  min-width:300px;max-width:360px;
}
tr.line .cell-lab{padding-left:36px}
tr.subtotal .cell-lab{padding-left:36px}
tr.computed .cell-lab{padding-left:36px}
td.val{
  text-align:right;padding:14px 16px;font-size:13px;border-bottom:1px solid var(--line);
  border-left:1px solid #f1efe8;min-width:112px;
}
td.fytot{background:#faf9f4;font-weight:600;border-left:1px solid var(--line)}
tr.line:hover td{background:var(--row-hover)}
tr.line:hover .cell-lab{background:var(--row-hover)}
tr.grphead td{
  background:var(--section-bg);font-family:'Bebas Neue',sans-serif;letter-spacing:.06em;
  font-size:16px;color:var(--green-900);padding:10px 16px;border-bottom:1px solid var(--line-strong);
  border-top:1px solid var(--line-strong);
}
tr.grphead .cell-lab{background:var(--section-bg);position:sticky;left:0}
.grphead-inner{display:flex;align-items:center;justify-content:space-between;gap:10px}
.add-line{
  font-family:'Inter',sans-serif;font-size:11px;font-weight:600;letter-spacing:0;
  background:transparent;border:1px dashed var(--line-strong);color:var(--green-700);
  border-radius:6px;padding:3px 8px;cursor:pointer;
}
.add-line:hover{border-color:var(--green-600);background:#fff}
tr.subtotal td{font-weight:600;background:#fbfaf5;border-bottom:1px solid var(--line)}
tr.subtotal .cell-lab{background:#fbfaf5;font-weight:600}
tr.computed td{background:#eef2ec;border-top:1px solid var(--line-strong);border-bottom:1px solid var(--line-strong)}
tr.computed .cell-lab{background:#eef2ec;font-weight:700}
tr.computed.e1 td{font-weight:600}
tr.computed.e2 td,tr.computed.e2 .cell-lab{background:var(--green-700);color:#fff;font-weight:700;font-size:14px}
tr.computed.e2 .cell-lab{color:var(--gold-soft)}
tr.opening td,tr.opening .cell-lab{background:#f0ede4;font-weight:600}
tr.linked-row td{color:var(--ink-soft);font-style:italic}
tr.linked-row .cell-lab{color:var(--ink-soft);font-style:italic;padding-left:36px}

/* editable inputs */
input.edit{
  width:100%;min-width:96px;text-align:right;border:1px solid transparent;background:transparent;
  font-family:inherit;font-size:13px;color:var(--ink);padding:7px 9px;border-radius:6px;
  font-variant-numeric:tabular-nums;
}
input.edit:hover{border-color:var(--line-strong);background:#fff}
input.edit:focus{outline:none;border-color:var(--gold);background:#fff;box-shadow:0 0 0 2px rgba(201,162,75,.18)}
input.edit:disabled{color:var(--ink-soft);background:transparent;cursor:default}

/* in-cell selects & inline text inputs (branch picker, type picker, name editor) */
.cell-select, .cell-input{
  font-family:inherit;font-size:13px;color:var(--ink);
  border:1px solid transparent;background:transparent;border-radius:6px;
  padding:6px 8px; padding-right:24px;
  appearance:none;-webkit-appearance:none;-moz-appearance:none;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16'><path fill='none' stroke='%235c6b62' stroke-width='2' stroke-linecap='round' stroke-linejoin='round' d='M3 6l5 5 5-5'/></svg>");
  background-repeat:no-repeat;background-position:right 6px center;background-size:14px;
  cursor:pointer;max-width:100%;
}
.cell-input{padding-right:8px;background-image:none;cursor:text}
.cell-select:hover, .cell-input:hover{border-color:var(--line-strong);background-color:#fff}
.cell-select:hover{background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16'><path fill='none' stroke='%231A3A2A' stroke-width='2' stroke-linecap='round' stroke-linejoin='round' d='M3 6l5 5 5-5'/></svg>");background-color:#fff;background-repeat:no-repeat;background-position:right 6px center;background-size:14px}
.cell-select:focus, .cell-input:focus{outline:none;border-color:var(--gold);background-color:#fff;box-shadow:0 0 0 2px rgba(201,162,75,.18)}
.cell-meta{font-size:11.5px;color:var(--ink-soft);margin-top:3px;display:flex;gap:8px;flex-wrap:wrap;align-items:center}
.cell-meta select.cell-select, .cell-meta input.cell-input{padding:3px 18px 3px 6px;font-size:11.5px;background-position:right 4px center;background-size:12px}

/* Corporate Checkups — compact two-line layout */
.corp-meta{display:flex;flex-direction:column;gap:4px;min-width:0}
.corp-name-row{display:flex;align-items:center;gap:8px;min-width:0}
.corp-name-row > b{font-weight:600;font-size:13px;color:var(--ink);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.corp-name-row input.corp-name{font-size:13px;padding:5px 8px;min-width:0}
.corp-name-row select.corp-branch{font-size:11px;padding:3px 18px 3px 6px;background-position:right 4px center;background-size:12px;min-width:80px;max-width:150px;color:var(--ink-soft)}
.corp-loc-row{font-size:11.5px;color:var(--ink-soft)}
input.corp-loc{font-size:12px;padding:4px 8px;width:100%}
.branch-pill{display:inline-flex;align-items:center;font-size:10.5px;letter-spacing:.02em;color:var(--ink-soft);background:var(--section-bg);border:1px solid var(--line);border-radius:999px;padding:2px 8px;white-space:nowrap}

/* Corporate cell button: shows total + tiny count badge, or "+" for empty */
button.corp-cell{
  background:transparent;border:0;font-family:inherit;font-size:13px;font-variant-numeric:tabular-nums;
  color:var(--ink);padding:6px 8px;border-radius:6px;cursor:pointer;
  display:inline-flex;align-items:center;gap:6px;justify-content:flex-end;width:100%;
}
button.corp-cell:hover{background:#fff;box-shadow:inset 0 0 0 1px var(--line-strong)}
button.corp-cell.empty{
  color:var(--gold);font-size:18px;line-height:1;font-weight:300;
  justify-content:center;opacity:.55;
}
button.corp-cell.empty:hover{opacity:1;background:rgba(201,162,75,.08);box-shadow:inset 0 0 0 1px var(--gold-soft)}
.corp-badge{
  display:inline-grid;place-items:center;min-width:18px;height:18px;padding:0 5px;
  font-size:10.5px;font-weight:700;background:var(--green-700);color:#fff;border-radius:9px;
}
/* match reference: client row stays single-row height (no excessive vertical padding) */
tr.corp-row .cell-lab{padding-top:10px;padding-bottom:10px}
tr.corp-row td.val{padding-top:8px;padding-bottom:8px}

td .val-display{display:inline-block;padding:6px 4px;font-size:13px}
.var-pos{color:var(--pos)}
.var-neg{color:var(--neg)}
.muted{color:var(--ink-soft)}

.del-row{border:0;background:transparent;color:var(--ink-soft);cursor:pointer;font-size:14px;padding:4px 8px}
.del-row:hover{color:var(--neg)}

/* ---------- dashboard ---------- */
.kpi-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(210px,1fr));gap:14px;margin-bottom:18px}
.kpi{
  background:var(--card);border:1px solid var(--line);border-radius:14px;padding:16px 18px;
  box-shadow:var(--shadow);position:relative;overflow:hidden;
}
.kpi::before{content:"";position:absolute;left:0;top:0;bottom:0;width:4px;background:var(--gold)}
.kpi.dark{background:linear-gradient(160deg,var(--green-700),var(--green-900));color:#fff}
.kpi.dark::before{background:var(--gold)}
.kpi .k-label{font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-soft)}
.kpi.dark .k-label{color:var(--gold-soft)}
.kpi .k-val{font-family:'Bebas Neue',sans-serif;font-size:34px;line-height:1;margin:8px 0 4px;letter-spacing:.5px}
.kpi .k-sub{font-size:12px;color:var(--ink-soft)}
.kpi.dark .k-sub{color:rgba(255,255,255,.7)}
.chart-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:14px}
.chart-card{background:var(--card);border:1px solid var(--line);border-radius:14px;padding:16px 18px 18px;box-shadow:var(--shadow)}
.chart-card h3{margin:0 0 2px;font-family:'Bebas Neue',sans-serif;font-weight:400;letter-spacing:.04em;font-size:20px;color:var(--green-900)}
.chart-card .c-sub{font-size:11.5px;color:var(--ink-soft);margin-bottom:10px}
.chart-box{position:relative;height:240px}

/* ---------- modals ---------- */
.bulk-overlay{display:none;position:fixed;inset:0;background:rgba(15,36,25,.5);z-index:100;align-items:center;justify-content:center;padding:20px}
.bulk-overlay.show{display:flex}
.bulk-box{background:#fff;border-radius:14px;padding:22px;width:min(560px,100%);box-shadow:0 20px 60px rgba(15,36,25,.4)}
.bulk-box h3{margin:0 0 6px;font-family:'Bebas Neue',sans-serif;letter-spacing:.04em;font-size:22px;color:var(--green-900)}
.bulk-help{color:var(--ink-soft);font-size:13px;margin:0 0 12px}
.bulk-input{width:100%;font-family:inherit;font-size:13px;border:1px solid var(--line-strong);border-radius:8px;padding:10px}
.bulk-actions{display:flex;gap:8px;justify-content:flex-end;margin-top:14px}

/* ---------- settings ---------- */
.settings-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:16px}
.card{background:#fff;border:1px solid var(--line);border-radius:14px;padding:18px;box-shadow:var(--shadow)}
.card.span2{grid-column:span 2}
.card-head h2{margin:0 0 4px;font-family:'Bebas Neue',sans-serif;letter-spacing:.04em;font-size:22px;color:var(--green-900)}
.card-head p{margin:0 0 14px;color:var(--ink-soft);font-size:12.5px}
.user-form{display:grid;grid-template-columns:repeat(4,1fr);gap:10px;margin-bottom:12px}
.user-form .field{display:flex;flex-direction:column;gap:4px}
.user-form .field.wide{grid-column:span 2}
.user-form label{font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-soft)}
.user-form input,.user-form select{border:1px solid var(--line-strong);border-radius:8px;padding:8px 10px;font-size:13px;font-family:inherit}
.user-form input:focus,.user-form select:focus{outline:none;border-color:var(--gold);box-shadow:0 0 0 2px rgba(201,162,75,.18)}
.add-user-row{grid-column:1/-1;display:flex;justify-content:flex-end}
.form-msg{font-size:12px;color:var(--neg);min-height:1em;margin:0 0 8px}
.form-msg.ok{color:var(--pos)}
.user-table{width:100%;border-collapse:collapse;font-size:13px;margin-top:6px}
.user-table th{text-align:left;font-size:10.5px;letter-spacing:.06em;text-transform:uppercase;color:var(--ink-soft);padding:8px 10px;border-bottom:1px solid var(--line)}
.user-table td{padding:9px 10px;border-bottom:1px solid var(--line)}
.user-table tr:hover td{background:var(--row-hover)}
.chip-list{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:10px}
.chip{display:inline-flex;align-items:center;gap:6px;background:var(--section-bg);border:1px solid var(--line);border-radius:999px;padding:5px 10px;font-size:12px}
.chip .x{cursor:pointer;color:var(--ink-soft);font-weight:700}
.chip .x:hover{color:var(--neg)}
.cat-add{display:flex;gap:6px}
.cat-add input{flex:1;border:1px solid var(--line-strong);border-radius:8px;padding:8px 10px;font-size:13px}
.cat-cols{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.cat-head{font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-soft);margin-bottom:8px}
.role-legend{margin:0;padding:0;list-style:none;display:flex;flex-direction:column;gap:8px}
.role-legend li{display:flex;flex-direction:column;font-size:13px;padding:8px 0;border-bottom:1px dashed var(--line)}
.role-legend li:last-child{border-bottom:0}
.role-legend b{color:var(--green-800)}
.role-legend span{color:var(--ink-soft);font-size:12px}
.stub-card{background:#fff;border:1px solid var(--line);border-radius:14px;padding:32px;text-align:center;box-shadow:var(--shadow)}
.stub-card h2{font-family:'Bebas Neue',sans-serif;letter-spacing:.04em;color:var(--green-900)}

/* ---------- login ---------- */
.login-page{min-height:100vh;display:grid;place-items:center;background:linear-gradient(160deg,var(--green-800),var(--green-900));padding:20px}
.login-card{background:#fff;border-radius:18px;padding:34px;width:min(420px,100%);box-shadow:0 20px 60px rgba(15,36,25,.4)}
.login-brand{display:flex;align-items:center;gap:12px;margin-bottom:18px}
.login-brand .mark{width:48px;height:48px;font-size:24px}
.brand-name{font-family:'Bebas Neue',sans-serif;font-size:26px;color:var(--green-900);line-height:1}
.brand-sub{font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-soft);margin-top:3px}
.login-card h2{margin:0 0 18px;font-family:'Bebas Neue',sans-serif;letter-spacing:.04em;color:var(--green-900)}
.login-card .field{display:flex;flex-direction:column;gap:4px;margin-bottom:14px}
.login-card .field label{font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-soft)}
.login-card .field input{border:1px solid var(--line-strong);border-radius:8px;padding:10px 12px;font-size:13px;font-family:inherit}
.login-card .field input:focus{outline:none;border-color:var(--gold);box-shadow:0 0 0 2px rgba(201,162,75,.18)}
.remember{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--ink-soft);margin-bottom:16px}
.login-foot{font-size:11.5px;color:var(--ink-soft);margin-top:14px;text-align:center}
.login-foot code{background:var(--section-bg);padding:1px 5px;border-radius:4px}
.alert{border-radius:8px;padding:10px 12px;font-size:13px;margin-bottom:12px}
.alert-info{background:var(--pos-bg);color:var(--pos)}
.alert-warning{background:#fff4d6;color:#8a6500}
.alert-danger{background:var(--neg-bg);color:var(--neg)}

/* ---------- responsive ---------- */
@media (max-width:880px){
  .app-shell{flex-direction:column}
  .sidebar{width:auto;flex:none;height:auto;position:sticky;top:0;flex-direction:row;align-items:center;
    padding:10px 12px;gap:10px;overflow-x:auto;overflow-y:hidden}
  .side-brand{border:0;margin:0;padding:0 6px 0 2px;flex:0 0 auto}
  .side-sub{display:none}
  .side-nav{flex-direction:row;flex:1;gap:4px;padding:0}
  .nav-item{padding:9px 10px;white-space:nowrap;font-size:12.5px}
  .nav-item.active::before{display:none}
  .nav-item.active{box-shadow:inset 0 -2px 0 var(--gold)}
  .nav-div,.nav-label{display:none}
  .side-foot{border:0;padding:0;flex-direction:row;flex:0 0 auto}
  .user-meta{display:none}
  .logout-link{display:none}
  .settings-grid{grid-template-columns:1fr}
  .card.span2{grid-column:auto}
  .user-form{grid-template-columns:1fr 1fr}
}
@media (max-width:640px){
  main{padding:14px 12px 56px}
  .topbar-title{font-size:22px}
  .kpi .k-val{font-size:28px}
  .user-form{grid-template-columns:1fr}
}
