/* =========================================================
   Aura Filaments ERP — styles
   Brand: deep navy + cyan (from logo)
   ========================================================= */
:root{
  --navy:#0b3b73;
  --navy-deep:#072a52;
  --navy-700:#0e4a8a;
  --cyan:#15b6e4;
  --cyan-deep:#0c93bd;
  --cyan-light:#5fd0ee;

  --ink:#10202f;
  --ink-soft:#54657a;
  --ink-faint:#8a99a8;

  --bg:#eef3f8;
  --surface:#ffffff;
  --surface-2:#f6f9fc;
  --line:#e2e9f1;
  --line-soft:#eef2f7;

  --ok:#1f9d57;
  --ok-bg:#e6f6ee;
  --warn:#c9821a;
  --warn-bg:#fbf1df;
  --danger:#d2453d;
  --danger-bg:#fbe9e8;
  --info:#2a72c9;
  --info-bg:#e7f0fb;

  --radius:14px;
  --radius-sm:10px;
  --shadow-sm:0 1px 2px rgba(16,32,47,.06), 0 1px 3px rgba(16,32,47,.05);
  --shadow:0 6px 20px rgba(11,59,115,.08), 0 2px 6px rgba(11,59,115,.05);
  --topbar-h:62px;
  --side-w:248px;
}

*{box-sizing:border-box;}
html,body{height:100%;}
body{
  margin:0;
  font-family:"Inter",system-ui,-apple-system,sans-serif;
  background:var(--bg);
  color:var(--ink);
  font-size:14px;
  line-height:1.5;
  -webkit-font-smoothing:antialiased;
}
a{color:var(--navy-700);text-decoration:none;}
::selection{background:rgba(21,182,228,.22);}
svg{stroke:currentColor;stroke-width:2;fill:none;stroke-linecap:round;stroke-linejoin:round;}

/* ---------------- Topbar ---------------- */
.topbar{
  position:sticky;top:0;z-index:50;height:var(--topbar-h);
  display:flex;align-items:center;gap:16px;padding:0 18px;
  background:linear-gradient(100deg,var(--navy-deep),var(--navy) 60%,var(--navy-700));
  color:#fff;box-shadow:0 1px 0 rgba(0,0,0,.15), 0 4px 18px rgba(7,42,82,.18);
}
.brand{display:flex;align-items:center;gap:11px;color:#fff;min-width:0;}
.brand-mark{width:38px;height:38px;display:grid;place-items:center;flex:none;
  background:rgba(255,255,255,.08);border-radius:10px;}
.brand-mark svg{width:30px;height:30px;}
.bm-cyan{stroke:var(--cyan-light);stroke-width:3;}
.bm-navy{stroke:#fff;stroke-width:3;}
.brand-words{display:flex;flex-direction:column;line-height:1.05;min-width:0;}
.bw-1{font-weight:800;font-size:17px;letter-spacing:.2px;}
.bw-2{color:var(--cyan-light);font-weight:700;}
.bw-tag{font-size:10px;color:#bcd3ec;letter-spacing:.04em;}

.topbar-search{
  margin-left:8px;flex:1;max-width:520px;display:flex;align-items:center;gap:8px;
  background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.14);
  border-radius:10px;padding:8px 12px;color:#dce8f6;
}
.topbar-search .srch{width:17px;height:17px;color:#bcd3ec;flex:none;}
.topbar-search input{
  flex:1;background:none;border:none;outline:none;color:#fff;font-size:13.5px;font-family:inherit;
}
.topbar-search input::placeholder{color:#a9c2dd;}
.topbar-search kbd{
  font-family:"JetBrains Mono",monospace;font-size:11px;background:rgba(255,255,255,.14);
  border-radius:5px;padding:1px 7px;color:#cfe1f3;
}
.topbar-right{display:flex;align-items:center;gap:8px;margin-left:auto;}
.icon-btn{
  width:38px;height:38px;border-radius:9px;display:grid;place-items:center;cursor:pointer;
  background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.12);color:#eaf2fb;position:relative;
  transition:background .15s;
}
.icon-btn:hover{background:rgba(255,255,255,.2);}
.icon-btn svg{width:19px;height:19px;}
.bell .dot{position:absolute;top:8px;right:9px;width:8px;height:8px;border-radius:50%;
  background:var(--cyan-light);border:2px solid var(--navy);}
.menu-toggle{display:none;}
.user{display:flex;align-items:center;gap:9px;padding-left:6px;}
.avatar{width:36px;height:36px;border-radius:50%;background:linear-gradient(140deg,var(--cyan),var(--cyan-deep));
  display:grid;place-items:center;font-weight:700;font-size:13px;color:#06283f;flex:none;}
.user-meta{display:flex;flex-direction:column;line-height:1.15;}
.un{font-weight:600;font-size:13px;}
.ur{font-size:11px;color:#bcd3ec;}

/* ---------------- Layout ---------------- */
.app{display:flex;min-height:calc(100vh - var(--topbar-h));}
.sidebar{
  width:var(--side-w);flex:none;background:var(--surface);border-right:1px solid var(--line);
  position:sticky;top:var(--topbar-h);height:calc(100vh - var(--topbar-h));
  display:flex;flex-direction:column;overflow-y:auto;z-index:40;
}
.sidebar nav{padding:14px 12px;flex:1;}
.nav-group{margin-bottom:16px;}
.nav-group h4{
  font-size:10.5px;letter-spacing:.13em;text-transform:uppercase;color:var(--ink-faint);
  margin:0 0 6px;padding:0 10px;font-weight:700;
}
.nav-item{
  display:flex;align-items:center;gap:11px;padding:9px 10px;border-radius:9px;
  color:var(--ink-soft);font-weight:500;font-size:13.5px;cursor:pointer;margin-bottom:2px;
  border:1px solid transparent;transition:background .12s,color .12s;
}
.nav-item:hover{background:var(--surface-2);color:var(--ink);}
.nav-item.active{
  background:linear-gradient(90deg,rgba(21,182,228,.14),rgba(11,59,115,.08));
  color:var(--navy);font-weight:600;border-color:rgba(21,182,228,.25);
}
.nav-item.active .ni-ico{color:var(--cyan-deep);}
.ni-ico{width:18px;height:18px;flex:none;color:var(--ink-faint);}
.nav-item.active .ni-ico{color:var(--cyan-deep);}
.ni-badge{margin-left:auto;font-size:10.5px;font-weight:700;background:var(--cyan);color:#062b40;
  border-radius:20px;padding:1px 8px;font-family:"JetBrains Mono",monospace;}
.nav-item.active .ni-badge{background:var(--navy);color:#fff;}
.sidebar-foot{padding:12px 18px;border-top:1px solid var(--line);font-size:11px;color:var(--ink-faint);}
.env-pill{display:flex;align-items:center;gap:7px;font-weight:600;color:var(--ink-soft);margin-bottom:3px;}
.env-pill .led{width:8px;height:8px;border-radius:50%;background:var(--ok);box-shadow:0 0 7px var(--ok);}
.scrim{display:none;}

/* ---------------- View / content ---------------- */
.view{flex:1;min-width:0;padding:24px 28px 60px;}
.page-head{display:flex;align-items:flex-end;justify-content:space-between;gap:18px;flex-wrap:wrap;margin-bottom:22px;}
.page-head .crumbs{font-size:12px;color:var(--ink-faint);font-family:"JetBrains Mono",monospace;margin-bottom:5px;letter-spacing:.03em;}
.page-head h1{font-size:24px;font-weight:800;margin:0;letter-spacing:-.02em;}
.page-head p{margin:5px 0 0;color:var(--ink-soft);max-width:64ch;font-size:13.5px;}
.head-actions{display:flex;gap:9px;flex-wrap:wrap;}

.btn{
  display:inline-flex;align-items:center;gap:7px;font-family:inherit;font-size:13px;font-weight:600;
  padding:9px 15px;border-radius:9px;border:1px solid var(--line);background:var(--surface);color:var(--ink);
  cursor:pointer;transition:all .14s;white-space:nowrap;
}
.btn:hover{border-color:#cdd9e6;background:var(--surface-2);}
.btn svg{width:16px;height:16px;}
.btn.primary{background:linear-gradient(120deg,var(--cyan-deep),var(--cyan));border:none;color:#04293f;box-shadow:var(--shadow-sm);}
.btn.primary:hover{filter:brightness(1.05);}
.btn.navy{background:var(--navy);border:none;color:#fff;}
.btn.navy:hover{background:var(--navy-700);}
.btn.ghost{background:transparent;border-color:transparent;color:var(--ink-soft);}
.btn.sm{padding:6px 11px;font-size:12px;}

/* KPI cards */
.kpi-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:22px;}
.kpi{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:17px 18px;box-shadow:var(--shadow-sm);position:relative;overflow:hidden;}
.kpi .kpi-top{display:flex;align-items:center;justify-content:space-between;}
.kpi .label{font-size:12px;color:var(--ink-soft);font-weight:600;}
.kpi .kpi-ico{width:34px;height:34px;border-radius:9px;display:grid;place-items:center;color:#fff;}
.kpi .kpi-ico svg{width:18px;height:18px;}
.kpi .value{font-size:27px;font-weight:800;margin:9px 0 3px;letter-spacing:-.02em;}
.kpi .sub{font-size:12px;color:var(--ink-faint);display:flex;align-items:center;gap:6px;}
.trend{font-weight:700;display:inline-flex;align-items:center;gap:2px;}
.trend.up{color:var(--ok);}
.trend.down{color:var(--danger);}
.ico-navy{background:linear-gradient(135deg,var(--navy),var(--navy-700));}
.ico-cyan{background:linear-gradient(135deg,var(--cyan-deep),var(--cyan));}
.ico-green{background:linear-gradient(135deg,#1f9d57,#27b365);}
.ico-amber{background:linear-gradient(135deg,#d98a23,#e9a93c);}

/* Cards / panels */
.grid{display:grid;gap:16px;}
.cols-2{grid-template-columns:1.6fr 1fr;}
.cols-2e{grid-template-columns:1fr 1fr;}
.cols-3{grid-template-columns:repeat(3,1fr);}
.card{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow-sm);overflow:hidden;}
.card-head{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:15px 18px;border-bottom:1px solid var(--line-soft);}
.card-head h3{margin:0;font-size:15px;font-weight:700;letter-spacing:-.01em;}
.card-head .sub{font-size:12px;color:var(--ink-faint);}
.card-body{padding:18px;}
.card-body.flush{padding:0;}

/* Tables */
.tbl-wrap{overflow-x:auto;}
table.tbl{width:100%;border-collapse:collapse;font-size:13px;}
table.tbl th{
  text-align:left;font-size:11px;letter-spacing:.05em;text-transform:uppercase;color:var(--ink-faint);
  font-weight:700;padding:11px 18px;background:var(--surface-2);border-bottom:1px solid var(--line);white-space:nowrap;
}
table.tbl td{padding:12px 18px;border-bottom:1px solid var(--line-soft);vertical-align:middle;}
table.tbl tr:last-child td{border-bottom:none;}
table.tbl tbody tr{transition:background .1s;}
table.tbl tbody tr:hover{background:var(--surface-2);}
table.tbl td.num,table.tbl th.num{text-align:right;font-family:"JetBrains Mono",monospace;}
.mono{font-family:"JetBrains Mono",monospace;}
.muted{color:var(--ink-faint);}
.strong{font-weight:700;}
.cell-main{font-weight:600;color:var(--ink);}
.cell-sub{font-size:11.5px;color:var(--ink-faint);}

/* Status pills */
.pill{display:inline-flex;align-items:center;gap:5px;font-size:11.5px;font-weight:700;padding:3px 10px;border-radius:20px;white-space:nowrap;}
.pill::before{content:"";width:6px;height:6px;border-radius:50%;background:currentColor;}
.pill.ok{color:var(--ok);background:var(--ok-bg);}
.pill.warn{color:var(--warn);background:var(--warn-bg);}
.pill.danger{color:var(--danger);background:var(--danger-bg);}
.pill.info{color:var(--info);background:var(--info-bg);}
.pill.neutral{color:var(--ink-soft);background:#eef2f7;}
.tag{display:inline-block;font-size:11px;font-weight:600;padding:2px 8px;border-radius:6px;background:#eef2f7;color:var(--ink-soft);}
.tag.cyan{background:rgba(21,182,228,.14);color:var(--cyan-deep);}
.tag.navy{background:rgba(11,59,115,.1);color:var(--navy);}

/* Charts */
.chart{width:100%;height:auto;display:block;}
.legend{display:flex;gap:16px;flex-wrap:wrap;font-size:12px;color:var(--ink-soft);margin-top:10px;}
.legend span{display:inline-flex;align-items:center;gap:6px;}
.legend i{width:11px;height:11px;border-radius:3px;display:inline-block;}

/* Progress */
.bar{height:8px;border-radius:6px;background:var(--line);overflow:hidden;}
.bar > i{display:block;height:100%;border-radius:6px;background:linear-gradient(90deg,var(--cyan-deep),var(--cyan));}

/* Forms */
.form-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:15px 18px;}
.field{display:flex;flex-direction:column;gap:6px;}
.field.full{grid-column:1/-1;}
.field label{font-size:12px;font-weight:600;color:var(--ink-soft);}
.field input,.field select,.field textarea{
  font-family:inherit;font-size:13.5px;padding:9px 11px;border:1px solid var(--line);border-radius:9px;
  background:var(--surface);color:var(--ink);outline:none;transition:border .14s,box-shadow .14s;width:100%;
}
.field input:focus,.field select:focus,.field textarea:focus{border-color:var(--cyan);box-shadow:0 0 0 3px rgba(21,182,228,.15);}
.field .hint{font-size:11px;color:var(--ink-faint);}
.inline-fields{display:flex;gap:10px;flex-wrap:wrap;align-items:flex-end;}

/* Segmented / tabs */
.tabs{display:flex;gap:4px;background:var(--surface-2);border:1px solid var(--line);border-radius:10px;padding:4px;}
.tabs button{font-family:inherit;font-size:12.5px;font-weight:600;color:var(--ink-soft);background:none;border:none;
  padding:7px 14px;border-radius:7px;cursor:pointer;transition:all .12s;}
.tabs button.active{background:var(--surface);color:var(--navy);box-shadow:var(--shadow-sm);}

/* Two-col detail row */
.dl{display:grid;grid-template-columns:auto 1fr;gap:8px 18px;font-size:13px;}
.dl dt{color:var(--ink-faint);font-weight:600;}
.dl dd{margin:0;font-weight:600;text-align:right;}

/* Virtual factory */
.vf{border-radius:var(--radius);overflow:hidden;border:1px solid var(--navy-deep);
  background:linear-gradient(180deg,#0c1c2c,#102a40);color:#e7eef5;box-shadow:var(--shadow);}
.vf-top{display:flex;justify-content:space-between;align-items:center;gap:16px;flex-wrap:wrap;
  padding:16px 18px;border-bottom:1px solid rgba(255,255,255,.1);}
.vf-title{font-weight:700;font-size:16px;}
.vf-title span{display:block;font-family:"JetBrains Mono",monospace;font-size:10px;letter-spacing:.18em;
  text-transform:uppercase;color:var(--cyan-light);font-weight:500;margin-bottom:3px;}
.vf-stats{display:flex;align-items:center;gap:20px;font-family:"JetBrains Mono",monospace;font-size:11.5px;}
.vf-stats .num{font-size:21px;font-weight:700;display:block;line-height:1;}
.vf-stats .run{color:#4fde92;}
.vf-stats .idle{color:#9fb2c0;}
.vf-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(184px,1fr));gap:12px;padding:18px;}
.machine{background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.1);border-radius:11px;padding:13px;cursor:pointer;transition:border-color .2s,transform .1s;}
.machine:hover{border-color:var(--cyan-light);transform:translateY(-1px);}
.machine .mh{display:flex;justify-content:space-between;align-items:center;font-family:"JetBrains Mono",monospace;font-size:11px;color:#aebfcd;margin-bottom:10px;}
.machine .mstate{display:flex;align-items:center;gap:5px;font-weight:700;}
.machine.on .mstate{color:#4fde92;}
.machine.off .mstate{color:#9fb2c0;}
.machine .led{width:8px;height:8px;border-radius:50%;background:#4fde92;box-shadow:0 0 8px #4fde92;}
.machine.off .led{background:#5d6f7c;box-shadow:none;}
.spindles{display:grid;grid-template-columns:repeat(20,1fr);gap:2px;}
.sp{height:13px;border-radius:2px;background:#3a4d5d;}
.machine.on .sp.live{background:#37c47e;animation:pulse 1.2s ease-in-out infinite;}
.machine .mft{font-family:"JetBrains Mono",monospace;font-size:10px;color:#8aa0b0;margin-top:10px;display:flex;justify-content:space-between;}
@keyframes pulse{0%,100%{opacity:.5;}50%{opacity:1;}}
@media (prefers-reduced-motion:reduce){.machine.on .sp.live{animation:none;opacity:.9;}}

/* misc */
.alert{display:flex;gap:11px;align-items:flex-start;padding:12px 14px;border-radius:10px;font-size:13px;border:1px solid;margin-bottom:10px;}
.alert svg{width:18px;height:18px;flex:none;margin-top:1px;}
.alert.warn{background:var(--warn-bg);border-color:#f0dcb5;color:#7a5410;}
.alert.info{background:var(--info-bg);border-color:#cfe0f6;color:#1c4f8f;}
.spacer{height:16px;}
.row-flex{display:flex;gap:16px;flex-wrap:wrap;}
.flex-1{flex:1;min-width:0;}
.center-empty{padding:48px 20px;text-align:center;color:var(--ink-faint);}
.center-empty svg{width:34px;height:34px;margin-bottom:8px;}
.callout-soft{background:var(--surface-2);border:1px dashed var(--line);border-radius:10px;padding:13px 15px;font-size:13px;color:var(--ink-soft);}
.big-num{font-size:34px;font-weight:800;letter-spacing:-.02em;color:var(--navy);}
.unit{font-size:14px;color:var(--ink-faint);font-weight:600;}

/* Row actions */
.row-acts{display:flex;gap:6px;align-items:center;justify-content:flex-end;}
.icon-act{width:30px;height:30px;border-radius:7px;display:inline-grid;place-items:center;cursor:pointer;
  background:var(--surface-2);border:1px solid var(--line);color:var(--ink-soft);transition:all .12s;}
.icon-act:hover{background:#fff;border-color:#cdd9e6;color:var(--navy);}
.icon-act.danger:hover{color:var(--danger);border-color:#f1c9c6;background:var(--danger-bg);}
.icon-act svg{width:15px;height:15px;}

/* Modal */
.modal-overlay{position:fixed;inset:0;background:rgba(7,42,82,.42);backdrop-filter:blur(2px);
  z-index:200;display:flex;align-items:flex-start;justify-content:center;padding:48px 18px;overflow-y:auto;animation:fade .15s;}
@keyframes fade{from{opacity:0}to{opacity:1}}
.modal{background:var(--surface);width:100%;max-width:620px;border-radius:16px;box-shadow:0 24px 60px rgba(7,42,82,.3);
  overflow:hidden;animation:pop .16s ease;}
@keyframes pop{from{transform:translateY(10px) scale(.98);opacity:0}to{transform:none;opacity:1}}
.modal-head{display:flex;align-items:flex-start;justify-content:space-between;gap:14px;padding:18px 20px;border-bottom:1px solid var(--line-soft);}
.modal-head h3{margin:0;font-size:17px;font-weight:700;letter-spacing:-.01em;}
.modal-body{padding:20px;max-height:62vh;overflow-y:auto;}
.modal-body p{font-size:14px;}
.modal-foot{display:flex;justify-content:flex-end;gap:10px;padding:14px 20px;border-top:1px solid var(--line-soft);background:var(--surface-2);}
.modal-foot .btn.primary.danger-btn,.btn.primary.danger-btn{background:linear-gradient(120deg,#d2453d,#e0635c);color:#fff;}

/* Wide modal + printable documents */
.modal.modal-wide{max-width:780px;}
.print-doc{background:#fff;color:#10202f;font-size:13px;}
.inv{border:1px solid var(--line);border-radius:10px;overflow:hidden;}
.inv-top{display:flex;justify-content:space-between;gap:20px;padding:18px 20px;border-bottom:2px solid var(--navy);}
.inv-seller .nm{font-family:"Inter";font-weight:800;font-size:19px;color:var(--navy);letter-spacing:-.01em;}
.inv-seller .sub{font-size:12px;color:var(--ink-soft);margin-top:3px;line-height:1.5;}
.inv-title{text-align:right;}
.inv-title .t{font-family:"JetBrains Mono",monospace;font-size:13px;letter-spacing:.18em;color:var(--cyan-deep);font-weight:700;text-transform:uppercase;}
.inv-title .no{font-size:18px;font-weight:800;margin-top:4px;}
.inv-title .dt{font-size:12px;color:var(--ink-soft);font-family:"JetBrains Mono",monospace;margin-top:2px;}
.inv-parties{display:grid;grid-template-columns:1fr 1fr;gap:0;border-bottom:1px solid var(--line);}
.inv-parties > div{padding:14px 20px;}
.inv-parties > div:first-child{border-right:1px solid var(--line);}
.inv-parties .lbl{font-size:10.5px;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-faint);font-weight:700;margin-bottom:5px;}
.inv-parties .pn{font-weight:700;font-size:14px;}
.inv-parties .pd{font-size:12px;color:var(--ink-soft);margin-top:2px;}
table.inv-items{width:100%;border-collapse:collapse;}
table.inv-items th{background:var(--surface-2);font-size:10.5px;letter-spacing:.05em;text-transform:uppercase;color:var(--ink-faint);text-align:left;padding:9px 20px;border-bottom:1px solid var(--line);}
table.inv-items td{padding:10px 20px;border-bottom:1px solid var(--line-soft);font-size:13px;}
table.inv-items td.r,table.inv-items th.r{text-align:right;font-family:"JetBrains Mono",monospace;}
.inv-foot{display:grid;grid-template-columns:1.3fr 1fr;gap:0;}
.inv-words{padding:14px 20px;border-right:1px solid var(--line);}
.inv-words .lbl{font-size:10.5px;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-faint);font-weight:700;margin-bottom:5px;}
.inv-words .w{font-weight:600;font-size:13px;}
.inv-totals{padding:8px 20px;}
.inv-totals .row{display:flex;justify-content:space-between;font-size:13px;padding:5px 0;}
.inv-totals .row.grand{border-top:1.5px solid var(--navy);margin-top:5px;padding-top:9px;font-weight:800;font-size:16px;color:var(--navy);}
.inv-totals .row .v{font-family:"JetBrains Mono",monospace;}
.inv-sign{display:flex;justify-content:space-between;align-items:flex-end;padding:18px 20px 14px;border-top:1px solid var(--line);font-size:12px;color:var(--ink-soft);}
.inv-sign .for{text-align:right;font-weight:700;color:var(--ink);}
.inv-stamp{margin-top:36px;font-size:11px;color:var(--ink-faint);}
.doc-note{font-size:11px;color:var(--ink-faint);margin-top:10px;}

@media print {
  body{background:#fff;}
  body * {visibility:hidden;}
  .print-doc, .print-doc *{visibility:visible;}
  .print-doc{position:absolute;left:0;top:0;width:100%;}
  .modal-overlay{position:absolute;inset:0;background:#fff;padding:0;overflow:visible;}
  .modal{box-shadow:none;max-width:100%;border-radius:0;}
  .modal-head,.modal-foot,.topbar,.sidebar,.scrim,.toast{display:none !important;}
  .inv{border:none;}
}

/* Toast */
.toast{position:fixed;bottom:24px;left:50%;transform:translateX(-50%) translateY(20px);
  background:var(--navy-deep);color:#fff;padding:11px 18px;border-radius:10px;font-size:13px;font-weight:600;
  box-shadow:var(--shadow);opacity:0;pointer-events:none;transition:all .25s;z-index:100;display:flex;gap:8px;align-items:center;}
.toast.show{opacity:1;transform:translateX(-50%) translateY(0);}
.toast svg{width:17px;height:17px;color:var(--cyan-light);}

/* Responsive */
@media (max-width:1100px){
  .kpi-grid{grid-template-columns:repeat(2,1fr);}
  .cols-2,.cols-2e,.cols-3{grid-template-columns:1fr;}
}
@media (max-width:860px){
  .menu-toggle{display:grid;}
  .topbar-search{display:none;}
  .sidebar{position:fixed;left:0;top:var(--topbar-h);transform:translateX(-100%);transition:transform .22s;box-shadow:var(--shadow);}
  .sidebar.open{transform:translateX(0);}
  .scrim.show{display:block;position:fixed;inset:var(--topbar-h) 0 0 0;background:rgba(7,42,82,.35);z-index:35;}
  .view{padding:18px 16px 50px;}
  .user-meta{display:none;}
}
@media (max-width:560px){
  .kpi-grid{grid-template-columns:1fr;}
  .form-grid{grid-template-columns:1fr;}
}
