@import url('https://fonts.googleapis.com/css2?family=Instrument+Serif&family=Geist:wght@300;400;500;600;700&display=swap');

/* ─── Tokens ─── */
*{box-sizing:border-box;margin:0;padding:0}
:root{
  --bg:#f6f5f1;--surface:#fdfcf9;--surface-2:#ffffff;
  --ink:#15171a;--ink-2:#3a3d42;--muted:#7d8089;
  --line:#ebe9e3;--line-2:#e0ddd4;
  --accent:#2f5d3a;--accent-2:#e8efe4;
  --warn:#a85a1a;--warn-bg:#fbecd9;
  --danger:#9b2c2c;--danger-bg:#f8e0db;
  --serif:'Instrument Serif',Georgia,serif;
  --ease-out:cubic-bezier(.22,1,.36,1);
  --duration-fast:150ms;--duration-normal:250ms;--duration-slow:400ms;
}
html,body{font-family:'Geist',-apple-system,system-ui,sans-serif;background:var(--bg);color:var(--ink);font-size:14px;line-height:1.5;-webkit-font-smoothing:antialiased}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer;border:none;background:none;color:inherit}
input,select,textarea{font-family:inherit;font-size:13px}

/* ─── Shell ─── */
.shell{width:1440px;margin:0 auto;display:flex;min-height:100vh}

/* ─── Sidebar ─── */
.sidebar{width:248px;background:var(--bg);position:sticky;top:0;height:100vh;padding:22px 16px;display:flex;flex-direction:column;flex-shrink:0;border-right:1px solid var(--line);overflow-y:auto}
.brand{display:flex;align-items:center;gap:11px;padding:4px 8px 22px}
.brand-mark{width:34px;height:34px;border-radius:10px;background:linear-gradient(160deg,#1e3a2b,#2f5d3a 60%,#558c5d);display:grid;place-items:center;color:#f6f5f1;box-shadow:0 4px 14px -4px rgba(47,93,58,.5),inset 0 1px 0 rgba(255,255,255,.15)}
.brand-mark svg{width:17px;height:17px}
.brand-tx{line-height:1.15}
.brand-tx .n{font-family:var(--serif);font-size:21px;letter-spacing:.2px;color:var(--ink)}
.brand-tx .s{font-size:10.5px;color:var(--muted);text-transform:uppercase;letter-spacing:.12em;margin-top:1px}
.nav{flex:1;overflow:auto;padding:6px 0}
.nav-label{font-size:10.5px;font-weight:500;color:var(--muted);text-transform:uppercase;letter-spacing:.14em;padding:14px 10px 8px}
.nav-item{display:flex;align-items:center;gap:11px;padding:9px 10px;border-radius:9px;color:var(--ink-2);font-weight:400;font-size:13.5px;margin-bottom:1px;transition:all var(--duration-fast);cursor:pointer}
.nav-item:hover{background:rgba(0,0,0,.03)}
.nav-item.active{background:var(--surface-2);color:var(--ink);font-weight:500;box-shadow:0 1px 0 rgba(0,0,0,.02),0 4px 14px -8px rgba(0,0,0,.1)}
.nav-item .ico{width:16px;height:16px;flex-shrink:0;color:var(--muted);display:flex;align-items:center}
.nav-item.active .ico{color:var(--accent)}
.nav-item .badge{margin-left:auto;font-size:10.5px;font-weight:500;color:var(--muted);padding:1px 7px;border-radius:999px;background:rgba(0,0,0,.04)}
.nav-item.active .badge{background:var(--accent-2);color:var(--accent)}
.side-bottom{padding:14px 8px 4px;border-top:1px solid var(--line);margin-top:8px}
.cycle-card{background:linear-gradient(180deg,#1e3a2b,#2f5d3a);border-radius:14px;padding:16px;color:#f1ede2;position:relative;overflow:hidden}
.cycle-card::before{content:'';position:absolute;inset:-40% -20% auto auto;width:160px;height:160px;background:radial-gradient(circle,rgba(255,255,255,.12),transparent 60%);pointer-events:none}
.cycle-card .lbl{font-size:10.5px;text-transform:uppercase;letter-spacing:.12em;opacity:.7}
.cycle-card .ttl{font-family:var(--serif);font-size:22px;margin-top:4px;letter-spacing:.2px}
.cycle-card .bar{height:4px;background:rgba(255,255,255,.18);border-radius:999px;margin-top:14px;overflow:hidden}
.cycle-card .bar>div{height:100%;background:#d8efbe;border-radius:999px}
.cycle-card .meta{display:flex;justify-content:space-between;font-size:11.5px;margin-top:8px;opacity:.85}
.logout-link{color:var(--muted)!important;font-size:13px!important}
.logout-link:hover{color:var(--danger)!important;background:var(--danger-bg)!important}

/* ─── Main ─── */
.main{flex:1;min-width:0;background:var(--bg);display:flex;flex-direction:column}
.topbar{height:68px;display:flex;align-items:center;padding:0 32px;gap:18px;background:var(--bg);position:sticky;top:0;z-index:50;border-bottom:1px solid var(--line)}
.search{flex:1;max-width:460px;display:flex;align-items:center;gap:9px;background:var(--surface-2);border:1px solid var(--line);border-radius:11px;padding:9px 14px;transition:all var(--duration-fast)}
.search:focus-within{border-color:var(--line-2);box-shadow:0 1px 0 rgba(0,0,0,.02)}
.search input{flex:1;background:none;border:none;outline:none;font-family:inherit;font-size:13px;color:var(--ink-2)}
.search input::placeholder{color:var(--muted)}
.search .kbd{font-size:10.5px;color:var(--muted);background:var(--bg);padding:2px 6px;border-radius:5px;border:1px solid var(--line)}
.top-actions{margin-left:auto;display:flex;align-items:center;gap:6px;position:relative}
.icon-btn{width:36px;height:36px;border-radius:10px;display:grid;place-items:center;color:var(--ink-2);position:relative;transition:background var(--duration-fast)}
.icon-btn:hover{background:rgba(0,0,0,.04)}
.icon-btn .dot{position:absolute;top:8px;right:9px;width:7px;height:7px;background:#c9412e;border-radius:999px;border:2px solid var(--bg)}
.user{display:flex;align-items:center;gap:11px;padding:5px 12px 5px 5px;border-radius:999px;background:var(--surface-2);border:1px solid var(--line);transition:all var(--duration-fast)}
.user:hover{border-color:var(--line-2)}
.avatar{width:28px;height:28px;border-radius:999px;background:linear-gradient(135deg,#2f5d3a,#1e3a2b);color:#f1ede2;display:grid;place-items:center;font-weight:500;font-size:11.5px;font-family:var(--serif);flex-shrink:0}
.user .nm{font-size:13px;font-weight:500;line-height:1.1}
.user .rl{font-size:11px;color:var(--muted);line-height:1}
.user-dropdown{position:absolute;top:48px;right:0;width:260px;background:var(--surface-2);border:1px solid var(--line);border-radius:14px;box-shadow:0 8px 30px -8px rgba(0,0,0,.15);padding:12px;display:none;z-index:100}
.user-dropdown.udd-open{display:block}
.udd-header{display:flex;align-items:center;gap:10px;padding:8px 4px;margin-bottom:8px}
.udd-role{display:flex;align-items:center;gap:8px;font-size:12px;color:var(--muted);padding:4px 8px}
.udd-divider{height:1px;background:var(--line);margin:8px 0}
.udd-item{display:flex;align-items:center;gap:8px;padding:8px;border-radius:8px;font-size:13px;cursor:pointer;transition:background var(--duration-fast)}
.udd-item:hover{background:var(--bg)}

/* ─── Page ─── */
.page{padding:32px 40px 56px;flex:1}
.page-inner{animation:fadeUp .35s var(--ease-out) both}
@keyframes fadeUp{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}
.page-enter .page-inner{animation:fadeUp .35s var(--ease-out) both}
.crumbs{font-size:12px;color:var(--muted);display:flex;align-items:center;gap:7px;margin-bottom:18px}
.crumbs .sep{opacity:.5}
.crumbs .cur{color:var(--ink-2)}
.crumb-link{cursor:pointer;transition:color var(--duration-fast)}
.crumb-link:hover{color:var(--ink)}
.page-head{display:flex;align-items:flex-end;justify-content:space-between;gap:30px;margin-bottom:8px}
.page-head h1{font-family:var(--serif);font-size:42px;font-weight:400;letter-spacing:-0.5px;line-height:1.05}
.page-head h1 em{font-style:italic;color:var(--accent)}
.page-head .sub{font-size:13.5px;color:var(--muted);margin-top:10px;max-width:560px}
.head-actions{display:flex;gap:8px;flex-shrink:0;align-items:center}

/* ─── Buttons ─── */
.btn{display:inline-flex;align-items:center;gap:8px;padding:9px 16px;border-radius:10px;font-size:13px;font-weight:500;background:var(--surface-2);color:var(--ink);border:1px solid var(--line);transition:all var(--duration-fast);cursor:pointer}
.btn:hover{border-color:var(--line-2);background:#fff}
.btn:active{transform:scale(.97)}
.btn.primary{background:var(--ink);color:#f6f5f1;border-color:var(--ink)}
.btn.primary:hover{background:#000}
.btn.primary:disabled,.btn:disabled{opacity:.5;pointer-events:none}
.btn.danger-btn{background:var(--danger);color:#fff;border-color:var(--danger)}
.btn.danger-btn:hover{background:#7a2222}
.btn .ico{width:14px;height:14px}
.btn-sm{padding:6px 12px;font-size:12px;border-radius:8px}

/* ─── Live indicator ─── */
.live{display:inline-flex;align-items:center;gap:7px;font-size:12px;color:var(--muted);padding:7px 12px;background:var(--surface-2);border-radius:999px;border:1px solid var(--line)}
.live .pulse{width:7px;height:7px;border-radius:999px;background:#3ea15c;box-shadow:0 0 0 0 rgba(62,161,92,.5);animation:p 2s infinite}
@keyframes p{0%{box-shadow:0 0 0 0 rgba(62,161,92,.5)}70%{box-shadow:0 0 0 7px rgba(62,161,92,0)}100%{box-shadow:0 0 0 0 rgba(62,161,92,0)}}

/* ─── Tabs ─── */
.tabs{display:flex;gap:24px;margin:28px 0 24px;border-bottom:1px solid var(--line)}
.tab{padding:0 0 14px;font-size:13.5px;font-weight:400;color:var(--muted);border-bottom:1.5px solid transparent;margin-bottom:-1px;display:flex;align-items:center;gap:7px;cursor:pointer;transition:color var(--duration-fast)}
.tab:hover{color:var(--ink-2)}
.tab.active{color:var(--ink);border-color:var(--ink);font-weight:500}
.tab .ct{font-size:11px;color:var(--muted);font-weight:400}
.tab.active .ct{color:var(--ink-2)}

/* ─── Hero KPI ─── */
.hero{background:var(--surface-2);border:1px solid var(--line);border-radius:20px;padding:0;overflow:hidden;margin-bottom:18px;box-shadow:0 1px 0 rgba(0,0,0,.02),0 30px 60px -40px rgba(20,23,30,.12)}
.hero-top{display:grid;grid-template-columns:1.3fr 1fr 1fr 1fr;gap:0}
.hero-cell{padding:26px 28px;border-right:1px solid var(--line);position:relative}
.hero-cell:last-child{border-right:none}
.hero-cell .lbl{font-size:11px;color:var(--muted);text-transform:uppercase;letter-spacing:.12em;font-weight:500;display:flex;align-items:center;gap:7px}
.hero-cell .val{font-family:var(--serif);font-size:48px;font-weight:400;letter-spacing:-0.5px;margin-top:10px;line-height:1;color:var(--ink)}
.hero-cell .val .unit{font-family:'Geist',sans-serif;font-size:18px;color:var(--muted);font-weight:400;margin-left:2px}
.hero-cell .ds{margin-top:14px;display:flex;align-items:center;gap:8px;font-size:12.5px;color:var(--muted)}
.delta{display:inline-flex;align-items:center;gap:4px;padding:2px 8px;border-radius:6px;font-size:11.5px;font-weight:500}
.delta.up{background:var(--accent-2);color:var(--accent)}
.delta.dn{background:var(--danger-bg);color:var(--danger)}
.delta.nu{background:rgba(0,0,0,.04);color:var(--ink-2)}
.hero-cell.first{background:linear-gradient(135deg,#fbfaf6 0%,#f1efe7 100%)}
.ringwrap{display:flex;align-items:center;gap:22px;margin-top:6px}
.ring{width:108px;height:108px;border-radius:50%;position:relative;flex-shrink:0;box-shadow:inset 0 0 0 1px rgba(0,0,0,.03)}
.ring::after{content:'';position:absolute;inset:11px;border-radius:50%;background:linear-gradient(135deg,#fbfaf6 0%,#f1efe7 100%)}
.ring .ct{position:absolute;inset:0;display:grid;place-items:center;z-index:2;text-align:center}
.ring .ct .n{font-family:var(--serif);font-size:26px;line-height:1}
.ring .ct .l{font-size:10px;color:var(--muted);text-transform:uppercase;letter-spacing:.1em;margin-top:2px}
.ringinfo .ttl{font-size:13px;font-weight:500;margin-bottom:8px}
.ringinfo .row2{display:flex;align-items:center;gap:8px;font-size:12px;color:var(--ink-2);margin-bottom:5px}
.ringinfo .row2 .sw{width:9px;height:9px;border-radius:3px}

/* ─── Two Column ─── */
.row{display:grid;grid-template-columns:1.6fr 1fr;gap:18px;margin-bottom:18px}
.card{background:var(--surface-2);border:1px solid var(--line);border-radius:18px;overflow:hidden;box-shadow:0 1px 0 rgba(0,0,0,.02);transition:transform var(--duration-fast),box-shadow var(--duration-fast)}
.card-head{padding:22px 26px 14px;display:flex;align-items:flex-start;gap:14px}
.card-head h3{font-family:var(--serif);font-size:22px;font-weight:400;letter-spacing:.1px;line-height:1.15}
.card-head .sub{font-size:12.5px;color:var(--muted);margin-top:5px}
.card-head .right{margin-left:auto;display:flex;gap:8px;align-items:center;flex-shrink:0}
.seg{display:inline-flex;background:var(--bg);border:1px solid var(--line);border-radius:9px;padding:2px}
.seg button{padding:5px 11px;font-size:11.5px;font-weight:500;color:var(--muted);border-radius:7px;transition:all var(--duration-fast)}
.seg button.on{background:var(--surface-2);color:var(--ink);box-shadow:0 1px 2px rgba(0,0,0,.06)}
.seg button:hover:not(.on){color:var(--ink-2)}

/* ─── Chart ─── */
.chart-wrap{padding:8px 26px 26px}
.chart{height:240px;position:relative;padding:14px 0 22px 36px}
.yaxis{position:absolute;left:0;top:14px;bottom:22px;display:flex;flex-direction:column;justify-content:space-between;font-size:10.5px;color:var(--muted);text-align:right;width:30px}
.cv{position:absolute;left:36px;right:0;top:14px;bottom:22px}
.cv .gline{position:absolute;left:0;right:0;border-top:1px dashed rgba(0,0,0,.05)}
.area{position:absolute;inset:0}
.area svg{width:100%;height:100%;overflow:visible}
.xaxis{position:absolute;left:36px;right:0;bottom:0;display:flex;justify-content:space-between;font-size:10.5px;color:var(--muted)}
.legend{display:flex;gap:22px;font-size:12px;color:var(--ink-2);padding:0 26px 22px}
.legend .sw{width:10px;height:10px;border-radius:3px;display:inline-block;margin-right:7px;vertical-align:middle}

/* ─── Region List ─── */
.region-list{padding:0 14px 16px}
.region{padding:13px 12px;border-radius:11px;display:flex;align-items:center;gap:12px;transition:background var(--duration-fast)}
.region:hover{background:var(--bg)}
.region+.region{border-top:1px solid var(--line)}
.flag{width:32px;height:32px;border-radius:9px;background:var(--bg);border:1px solid var(--line);display:grid;place-items:center;font-size:14px;flex-shrink:0}
.region .info{flex:1;min-width:0}
.region .nm{font-size:13.5px;font-weight:500}
.region .sb{font-size:11.5px;color:var(--muted);margin-top:1px}
.region .nb{font-family:var(--serif);font-size:22px;letter-spacing:.1px}
.region .pc{font-size:11px;color:var(--muted)}
.region .bar{flex:0 0 90px;height:5px;background:var(--bg);border-radius:999px;overflow:hidden;margin:0 6px}
.region .bar>div{height:100%;border-radius:999px;background:var(--accent)}

/* ─── Attention Cards ─── */
.attn{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-bottom:18px}
.attn-card{background:var(--surface-2);border:1px solid var(--line);border-radius:18px;padding:24px;position:relative;overflow:hidden;box-shadow:0 1px 0 rgba(0,0,0,.02);transition:transform var(--duration-fast)}
.attn-card:hover{transform:translateY(-1px)}
.attn-card::before{content:'';position:absolute;top:-50px;right:-50px;width:160px;height:160px;border-radius:50%;opacity:.4;filter:blur(10px)}
.attn-card.red::before{background:radial-gradient(circle,rgba(155,44,44,.18),transparent 70%)}
.attn-card.amber::before{background:radial-gradient(circle,rgba(168,90,26,.18),transparent 70%)}
.attn-card.green::before{background:radial-gradient(circle,rgba(47,93,58,.18),transparent 70%)}
.attn-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:18px;position:relative}
.attn-ic{width:34px;height:34px;border-radius:11px;display:grid;place-items:center;border:1px solid var(--line)}
.attn-card.red .attn-ic{background:var(--danger-bg);color:var(--danger);border-color:rgba(155,44,44,.15)}
.attn-card.amber .attn-ic{background:var(--warn-bg);color:var(--warn);border-color:rgba(168,90,26,.15)}
.attn-card.green .attn-ic{background:var(--accent-2);color:var(--accent);border-color:rgba(47,93,58,.15)}
.attn-tag{font-size:10.5px;color:var(--muted);text-transform:uppercase;letter-spacing:.12em;font-weight:500}
.attn-val{font-family:var(--serif);font-size:38px;letter-spacing:-.3px;line-height:1;margin-bottom:6px;position:relative}
.attn-val .u{font-family:'Geist',sans-serif;font-size:14px;color:var(--muted);margin-left:3px}
.attn-lbl{font-size:13.5px;font-weight:500;color:var(--ink);margin-bottom:6px;position:relative}
.attn-ds{font-size:12.5px;color:var(--muted);line-height:1.55;margin-bottom:18px;position:relative}
.attn-link{display:inline-flex;align-items:center;gap:6px;font-size:12.5px;color:var(--ink);font-weight:500;border-bottom:1px solid var(--ink-2);padding-bottom:1px;position:relative;cursor:pointer;transition:gap var(--duration-fast)}
.attn-link:hover{gap:10px}

/* ─── Table ─── */
.tbl-card{background:var(--surface-2);border:1px solid var(--line);border-radius:18px;overflow:hidden;box-shadow:0 1px 0 rgba(0,0,0,.02);margin-bottom:18px}
.tbl-head{padding:22px 28px 18px;display:flex;align-items:flex-end;gap:14px}
.tbl-head h3{font-family:var(--serif);font-size:24px;font-weight:400;letter-spacing:.1px}
.tbl-head .sub{font-size:12.5px;color:var(--muted);margin-top:4px}
.tbl-head .right{margin-left:auto;display:flex;gap:8px;align-items:center}
.fchip{display:inline-flex;align-items:center;gap:6px;padding:6px 12px;border:1px solid var(--line);border-radius:999px;font-size:12px;color:var(--ink-2);background:var(--surface-2);transition:all var(--duration-fast);cursor:pointer}
.fchip:hover{border-color:var(--line-2)}
.fchip.on{background:var(--ink);color:#f6f5f1;border-color:var(--ink)}
table{width:100%;border-collapse:collapse}
th{text-align:left;font-size:11px;font-weight:500;color:var(--muted);text-transform:uppercase;letter-spacing:.1em;padding:12px 28px;border-top:1px solid var(--line);border-bottom:1px solid var(--line);background:var(--bg);cursor:pointer;user-select:none;white-space:nowrap}
th:hover{color:var(--ink-2)}
th .sort-ind{display:inline-block;margin-left:4px;opacity:.4;font-size:9px}
th.sorted .sort-ind{opacity:1;color:var(--accent)}
td{padding:16px 28px;font-size:13px;border-bottom:1px solid var(--line);color:var(--ink-2);vertical-align:middle}
tr:last-child td{border-bottom:none}
tr:hover td{background:#faf9f4}
tr.clickable{cursor:pointer}
.wh{display:flex;align-items:center;gap:13px}
.wh-ic{width:38px;height:38px;border-radius:11px;background:linear-gradient(135deg,#f1efe7,#e6e3d9);display:grid;place-items:center;color:var(--ink);font-family:var(--serif);font-size:14px;flex-shrink:0;border:1px solid var(--line)}
.wh-nm{font-weight:500;color:var(--ink);font-size:13.5px}
.wh-sub{font-size:11.5px;color:var(--muted);margin-top:1px}

/* ─── Status Pills ─── */
.status{display:inline-flex;align-items:center;gap:6px;padding:3px 10px;font-size:11.5px;font-weight:500;border-radius:999px;border:1px solid transparent;white-space:nowrap}
.status.ok{background:var(--accent-2);color:var(--accent);border-color:rgba(47,93,58,.12)}
.status.late{background:var(--warn-bg);color:var(--warn);border-color:rgba(168,90,26,.12)}
.status.overdue{background:var(--danger-bg);color:var(--danger);border-color:rgba(155,44,44,.12)}
.status.review{background:#e3eaf3;color:#2b4d7a;border-color:rgba(43,77,122,.12)}
.status.draft{background:rgba(0,0,0,.04);color:var(--ink-2);border-color:rgba(0,0,0,.06)}
.status.posted{background:var(--accent-2);color:var(--accent);border-color:rgba(47,93,58,.12)}
.status.rejected{background:var(--danger-bg);color:var(--danger);border-color:rgba(155,44,44,.12)}
.status .d{width:5px;height:5px;border-radius:999px;background:currentColor}

/* ─── Mini Bar ─── */
.val-cell{font-family:var(--serif);font-size:16px;letter-spacing:.1px;color:var(--ink)}
.mini-bar{width:110px;height:4px;background:var(--bg);border-radius:999px;overflow:hidden;display:inline-block;vertical-align:middle;margin-right:10px}
.mini-bar>div{height:100%;background:var(--accent);border-radius:999px}
.alink{display:inline-flex;align-items:center;gap:6px;color:var(--ink);font-weight:500;font-size:12.5px;cursor:pointer;white-space:nowrap}
.alink svg{width:12px;height:12px;transition:transform var(--duration-fast)}
.alink:hover svg{transform:translateX(2px)}

/* ─── Footer ─── */
.footer{padding:24px 40px;display:flex;justify-content:space-between;font-size:12px;color:var(--muted);border-top:1px solid var(--line)}

/* ─── Login ─── */
.login-page{display:flex;align-items:center;justify-content:center;min-height:100vh;background:var(--bg);padding:40px}
.login-container{width:520px;background:var(--surface-2);border:1px solid var(--line);border-radius:20px;padding:40px;box-shadow:0 20px 60px -20px rgba(0,0,0,.12)}
.login-brand{display:flex;align-items:center;gap:14px;margin-bottom:32px}
.login-title{font-family:var(--serif);font-size:24px;letter-spacing:.2px}
.login-subtitle{font-size:12px;color:var(--muted);margin-top:2px}
.login-heading{font-size:15px;font-weight:500;color:var(--ink-2);margin-bottom:16px}
.login-cards{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:24px}
.login-card{display:flex;align-items:center;gap:10px;padding:12px;border:1px solid var(--line);border-radius:12px;cursor:pointer;transition:all var(--duration-fast)}
.login-card:hover{border-color:var(--line-2);background:var(--bg)}
.login-card.selected{border-color:var(--accent);background:var(--accent-2);box-shadow:0 0 0 2px rgba(47,93,58,.15)}
.login-card:nth-child(5){grid-column:span 2}
.login-avatar{width:36px;height:36px;border-radius:999px;display:grid;place-items:center;color:#fff;font-weight:600;font-size:13px;font-family:var(--serif);flex-shrink:0}
.login-card-name{font-weight:500;font-size:13px}
.login-card-role{font-size:11px;color:var(--muted)}
.login-card-region{font-size:10px;color:var(--muted);text-transform:uppercase;letter-spacing:.08em}
.login-form{display:flex;flex-direction:column;gap:14px}
.login-field{display:flex;flex-direction:column;gap:4px}
.login-field label{font-size:12px;font-weight:500;color:var(--ink-2)}
.login-field input{padding:10px 14px;border:1px solid var(--line);border-radius:10px;background:var(--bg);font-size:13px;color:var(--ink);outline:none}
.login-field input:focus{border-color:var(--accent)}
.login-btn{width:100%;justify-content:center;padding:12px}

/* ─── Toast ─── */
#toast-container{position:fixed;bottom:24px;right:24px;display:flex;flex-direction:column;gap:8px;z-index:9999}
.toast{display:flex;align-items:center;gap:10px;padding:12px 18px;background:var(--surface-2);border:1px solid var(--line);border-radius:12px;box-shadow:0 8px 30px -8px rgba(0,0,0,.18);font-size:13px;min-width:280px;max-width:400px;transform:translateX(0);transition:all .3s var(--ease-out)}
.toast-enter{transform:translateX(110%)}
.toast-exit{transform:translateX(110%);opacity:0}
.toast-icon{width:20px;height:20px;border-radius:6px;display:grid;place-items:center;font-size:12px;font-weight:700;flex-shrink:0}
.toast-success .toast-icon{background:var(--accent-2);color:var(--accent)}
.toast-error .toast-icon{background:var(--danger-bg);color:var(--danger)}
.toast-info .toast-icon{background:#e3eaf3;color:#2b4d7a}
.toast-warning .toast-icon{background:var(--warn-bg);color:var(--warn)}

/* ─── Modal ─── */
.modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,.3);display:flex;align-items:center;justify-content:center;z-index:9000;opacity:0;transition:opacity .2s}
.modal-overlay.modal-visible{opacity:1}
.modal-content{background:var(--surface-2);border:1px solid var(--line);border-radius:18px;width:480px;max-width:90vw;max-height:80vh;overflow:auto;box-shadow:0 20px 60px -20px rgba(0,0,0,.25);transform:scale(.98);transition:transform .2s var(--ease-out)}
.modal-visible .modal-content{transform:scale(1)}
.modal-header{display:flex;align-items:center;justify-content:space-between;padding:20px 24px 0}
.modal-header h3{font-family:var(--serif);font-size:20px;font-weight:400}
.modal-close{font-size:20px;color:var(--muted);cursor:pointer;width:32px;height:32px;border-radius:8px;display:grid;place-items:center;transition:background var(--duration-fast)}
.modal-close:hover{background:var(--bg)}
.modal-body{padding:16px 24px}
.modal-actions{display:flex;justify-content:flex-end;gap:8px;padding:16px 24px 20px}

/* ─── Dropdown Panel ─── */
.dd-panel{position:absolute;top:calc(100% + 4px);left:0;min-width:180px;background:var(--surface-2);border:1px solid var(--line);border-radius:12px;box-shadow:0 8px 30px -8px rgba(0,0,0,.15);padding:6px;display:none;z-index:100}
.dd-panel.dd-open{display:block}
.dd-option{padding:8px 12px;border-radius:8px;font-size:13px;cursor:pointer;transition:background var(--duration-fast)}
.dd-option:hover{background:var(--bg)}
.dd-option.dd-active{background:var(--accent-2);color:var(--accent);font-weight:500}

/* ─── KPI Strip ─── */
.kpi-strip{display:grid;gap:18px;margin-bottom:24px}
.kpi-strip.cols-3{grid-template-columns:repeat(3,1fr)}
.kpi-strip.cols-4{grid-template-columns:repeat(4,1fr)}
.kpi-card{background:var(--surface-2);border:1px solid var(--line);border-radius:14px;padding:20px 24px;box-shadow:0 1px 0 rgba(0,0,0,.02)}
.kpi-card .kpi-label{font-size:11px;color:var(--muted);text-transform:uppercase;letter-spacing:.12em;font-weight:500}
.kpi-card .kpi-value{font-family:var(--serif);font-size:32px;margin-top:6px;line-height:1;color:var(--ink)}
.kpi-card .kpi-value .kpi-unit{font-family:'Geist',sans-serif;font-size:14px;color:var(--muted);margin-left:2px}
.kpi-card .kpi-sub{font-size:12px;color:var(--muted);margin-top:8px}

/* ─── Forms ─── */
.form-group{margin-bottom:18px}
.form-group label{display:block;font-size:12px;font-weight:500;color:var(--ink-2);margin-bottom:6px}
.form-group input,.form-group select,.form-group textarea{width:100%;padding:10px 14px;border:1px solid var(--line);border-radius:10px;background:var(--surface-2);font-size:13px;color:var(--ink);outline:none;transition:border-color var(--duration-fast)}
.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:var(--accent)}
.form-group textarea{min-height:80px;resize:vertical}
.form-group input:disabled,.form-group select:disabled,.form-group textarea:disabled{background:var(--bg);color:var(--muted);cursor:not-allowed}
.form-group input.error{border-color:var(--danger)}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.form-section{margin-bottom:28px}
.form-section h4{font-family:var(--serif);font-size:18px;font-weight:400;margin-bottom:14px;padding-bottom:8px;border-bottom:1px solid var(--line)}

/* ─── Radio ─── */
.radio-group{display:flex;gap:12px}
.radio-item{display:flex;align-items:center;gap:8px;padding:8px 14px;border:1px solid var(--line);border-radius:10px;cursor:pointer;transition:all var(--duration-fast);font-size:13px}
.radio-item:hover{border-color:var(--line-2)}
.radio-item.selected{border-color:var(--accent);background:var(--accent-2)}
.radio-dot{width:16px;height:16px;border-radius:999px;border:2px solid var(--line-2);display:grid;place-items:center}
.radio-item.selected .radio-dot{border-color:var(--accent)}
.radio-item.selected .radio-dot::after{content:'';width:8px;height:8px;border-radius:999px;background:var(--accent)}

/* ─── Banners ─── */
.banner{padding:14px 20px;border-radius:12px;font-size:13px;display:flex;align-items:center;gap:10px;margin-bottom:18px}
.banner-success{background:var(--accent-2);color:var(--accent);border:1px solid rgba(47,93,58,.15)}
.banner-warning{background:var(--warn-bg);color:var(--warn);border:1px solid rgba(168,90,26,.15)}
.banner-error{background:var(--danger-bg);color:var(--danger);border:1px solid rgba(155,44,44,.15)}
.banner-info{background:#e3eaf3;color:#2b4d7a;border:1px solid rgba(43,77,122,.15)}

/* ─── Upload Zone ─── */
.upload-zone{border:2px dashed var(--line-2);border-radius:16px;padding:40px;text-align:center;transition:all var(--duration-fast);cursor:pointer}
.upload-zone:hover{border-color:var(--accent);background:var(--accent-2)}
.upload-zone .uz-icon{margin-bottom:12px;color:var(--muted)}
.upload-zone .uz-title{font-weight:500;font-size:14px;margin-bottom:4px}
.upload-zone .uz-sub{font-size:12px;color:var(--muted)}

/* ─── Progress Bar ─── */
.progress-bar{height:8px;background:var(--bg);border-radius:999px;overflow:hidden}
.progress-bar>div{height:100%;background:var(--accent);border-radius:999px;transition:width .3s var(--ease-out)}

/* ─── Checklist ─── */
.checklist{display:flex;flex-direction:column;gap:12px}
.check-item{display:flex;align-items:center;gap:14px;padding:16px 20px;background:var(--surface-2);border:1px solid var(--line);border-radius:12px}
.check-icon{width:28px;height:28px;border-radius:8px;display:grid;place-items:center;flex-shrink:0}
.check-icon.pass{background:var(--accent-2);color:var(--accent)}
.check-icon.fail{background:var(--danger-bg);color:var(--danger)}
.check-item .check-label{flex:1;font-size:13.5px;font-weight:500}
.check-item .check-status{font-size:12px;font-weight:500}
.check-item .check-status.pass-text{color:var(--accent)}
.check-item .check-status.fail-text{color:var(--danger)}

/* ─── Evidence / Config Cards ─── */
.config-card{background:var(--surface-2);border:1px solid var(--line);border-radius:16px;padding:24px;margin-bottom:18px}
.config-card h4{font-family:var(--serif);font-size:18px;margin-bottom:16px}
.mapping-table{width:100%;margin-top:12px}
.mapping-table td{padding:8px 12px;font-size:12px;border-bottom:1px solid var(--line)}
.mapping-table .arrow{color:var(--muted);text-align:center}

/* ─── Schedule Card ─── */
.schedule-card{background:var(--surface-2);border:1px solid var(--line);border-radius:16px;padding:24px;margin-bottom:18px}
.schedule-card h4{font-family:var(--serif);font-size:18px;margin-bottom:16px}

/* ─── Toggle ─── */
.toggle{width:44px;height:24px;border-radius:12px;background:var(--line-2);cursor:pointer;position:relative;transition:background var(--duration-fast)}
.toggle.active{background:var(--accent)}
.toggle::after{content:'';position:absolute;top:2px;left:2px;width:20px;height:20px;border-radius:10px;background:#fff;transition:transform var(--duration-fast);box-shadow:0 1px 3px rgba(0,0,0,.15)}
.toggle.active::after{transform:translateX(20px)}

/* ─── Document viewer ─── */
.doc-preview{background:var(--bg);border:1px solid var(--line);border-radius:14px;padding:40px;display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:300px;color:var(--muted)}
.doc-preview .doc-icon{margin-bottom:12px}

/* ─── Expand row ─── */
.expand-content{display:none;padding:12px 28px 16px;background:var(--bg);font-size:12px;font-family:monospace;white-space:pre-wrap;word-break:break-all;color:var(--ink-2)}
.expand-content.expanded{display:table-row}
tr.expanded+tr .expand-content{display:block}

/* ─── Loading Spinner ─── */
.spinner-wrap{display:flex;flex-direction:column;align-items:center;gap:12px;padding:40px}
.spinner{width:32px;height:32px;border:3px solid var(--line);border-top-color:var(--accent);border-radius:50%;animation:spin .8s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}
.spinner-msg{font-size:13px;color:var(--muted)}

/* ─── Empty State ─── */
.empty-state{text-align:center;padding:48px 20px;color:var(--muted)}
.empty-state .empty-icon{margin-bottom:12px;opacity:.5}
.empty-state .empty-title{font-size:15px;font-weight:500;color:var(--ink-2);margin-bottom:4px}
.empty-state .empty-sub{font-size:13px}

/* ─── Misc ─── */
.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.grid-3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:18px}
.mt-18{margin-top:18px}
.mb-18{margin-bottom:18px}
.text-right{text-align:right}
.text-muted{color:var(--muted)}
.evidence-chip{display:inline-flex;align-items:center;gap:6px;padding:4px 10px;background:var(--bg);border:1px solid var(--line);border-radius:8px;font-size:11px;margin:2px}
.locked-overlay{opacity:.6;pointer-events:none}
.filter-bar{display:flex;gap:8px;align-items:center;margin-bottom:18px;flex-wrap:wrap}
.dd-trigger{position:relative;display:inline-block}
