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

*{box-sizing:border-box;margin:0;padding:0}

/* ──────────── Design Tokens ──────────── */
:root{
  --bg:#f6f5f1;
  --panel:#fbfaf7;
  --card:#ffffff;
  --ink:#1a1a1a;
  --ink-2:#535353;
  --ink-3:#8a8a85;
  --line:#ececea;
  --line-2:#e3e2de;
  --accent:#3d4a2a;
  --accent-2:#5b6b3d;
  --accent-light:#e8efe1;
  --warn:#c2541d;
  --bad:#a83232;
  --good:#3f7a4d;
  --gold:#a8893d;
  --radius-sm:8px;
  --radius-md:10px;
  --radius-lg:14px;
  --radius-xl:16px;
  --radius-pill:99px;
  --shadow-sm:0 1px 2px rgba(0,0,0,.05);
  --shadow-md:0 4px 12px rgba(0,0,0,.08);
  --shadow-lg:0 20px 40px -22px rgba(31,36,25,.5);
}

/* ──────────── Base ──────────── */
body{font-family:'Inter',sans-serif;background:var(--bg);color:var(--ink);font-size:13.5px;line-height:1.5;-webkit-font-smoothing:antialiased}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer;border:none;background:none}
input,textarea,select{font-family:inherit}

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

/* ──────────── Sidebar ──────────── */
.sidebar{width:248px;background:var(--panel);border-right:1px solid var(--line);position:sticky;top:0;height:100vh;display:flex;flex-direction:column;flex-shrink:0;padding:18px 14px;overflow-y:auto}
.brand{display:flex;align-items:center;gap:11px;padding:6px 8px 18px}
.brand-mark{width:32px;height:32px;border-radius:9px;background:var(--accent);color:#f3f1e6;display:flex;align-items:center;justify-content:center;font-family:'Instrument Serif',serif;font-size:20px;line-height:1}
.brand-name{font-family:'Instrument Serif',serif;font-size:21px;letter-spacing:-.01em}
.brand-name em{font-style:italic;color:var(--accent)}
.workspace-pick{margin:6px 4px 16px;padding:10px 12px;border:1px solid var(--line-2);border-radius:var(--radius-md);background:#fff;display:flex;align-items:center;gap:10px}
.ws-dot{width:26px;height:26px;border-radius:7px;background:linear-gradient(135deg,#3d4a2a,#5b6b3d);color:#f3f1e6;display:flex;align-items:center;justify-content:center;font-weight:600;font-size:12px}
.ws-info{flex:1;min-width:0}
.ws-info strong{display:block;font-size:12.5px;font-weight:600}
.ws-info span{font-size:11px;color:var(--ink-3)}
.nav-group{padding:8px 4px}
.nav-label{font-size:10.5px;color:var(--ink-3);text-transform:uppercase;letter-spacing:.08em;padding:8px 8px 6px;font-weight:600}
.nav-item{display:flex;align-items:center;gap:11px;padding:8px 10px;border-radius:var(--radius-sm);color:var(--ink-2);text-decoration:none;font-size:13px;font-weight:500;margin-bottom:1px;cursor:pointer;transition:background .15s}
.nav-item:hover{background:#f0eee8}
.nav-item.active{background:var(--ink);color:#f3f1e6}
.nav-item.active svg{color:#f3f1e6}
.nav-item .icon{color:var(--ink-3)}
.nav-item.active .icon{color:#f3f1e6}
.nav-item .pill{margin-left:auto;font-size:10.5px;font-weight:600;padding:1px 7px;border-radius:var(--radius-sm);background:#fbeed2;color:#7a5e15}
.nav-item.active .pill{background:rgba(243,241,230,.18);color:#f3f1e6}
.side-foot{margin-top:auto;padding:10px 4px;border-top:1px solid var(--line);display:flex;align-items:center;gap:10px}
.avatar{width:30px;height:30px;border-radius:50%;background:#dcd6c2;color:#3d4a2a;display:flex;align-items:center;justify-content:center;font-weight:600;font-size:11.5px;font-family:'Instrument Serif',serif;flex-shrink:0}
.avatar-lg{width:48px;height:48px;font-size:18px}
.side-foot strong{display:block;font-size:12.5px}
.side-foot span{display:block;font-size:11px;color:var(--ink-3)}
.side-foot .logout-btn{margin-left:auto;padding:6px;border-radius:var(--radius-sm);color:var(--ink-3);transition:color .15s,background .15s}
.side-foot .logout-btn:hover{color:var(--bad);background:#f4dada}

/* ──────────── Main Content ──────────── */
.main{flex:1;display:flex;flex-direction:column;min-width:0}
.topbar{height:64px;display:flex;align-items:center;padding:0 32px;gap:18px;border-bottom:1px solid var(--line);background:rgba(246,245,241,.85);backdrop-filter:blur(10px);position:sticky;top:0;z-index:50}
.crumbs{font-size:12.5px;color:var(--ink-3);display:flex;align-items:center;gap:7px}
.crumbs .here{color:var(--ink);font-weight:500}
.crumbs .sep{opacity:.5}
.search{margin-left:auto;width:340px;position:relative}
.search input{width:100%;height:38px;border-radius:var(--radius-md);border:1px solid var(--line-2);background:#fff;padding:0 12px 0 38px;font-family:inherit;font-size:13px;outline:none;transition:border-color .15s}
.search input:focus{border-color:var(--accent)}
.search .icon{position:absolute;left:13px;top:11px;color:var(--ink-3)}
.kbd{position:absolute;right:10px;top:9px;font-size:10.5px;color:var(--ink-3);border:1px solid var(--line-2);padding:1px 6px;border-radius:5px;background:#fafaf6}
.t-actions{display:flex;align-items:center;gap:8px}

/* ──────────── Buttons ──────────── */
.icon-btn{width:38px;height:38px;border-radius:var(--radius-md);border:1px solid var(--line-2);background:#fff;display:flex;align-items:center;justify-content:center;color:var(--ink-2);position:relative;cursor:pointer;transition:background .15s}
.icon-btn:hover{background:#fafaf6}
.icon-btn .dot{position:absolute;top:8px;right:9px;width:8px;height:8px;background:var(--warn);border-radius:50%;border:2px solid #fff}
.btn{height:38px;padding:0 16px;border-radius:var(--radius-md);border:1px solid var(--line-2);background:#fff;font-family:inherit;font-size:13px;font-weight:500;color:var(--ink);display:inline-flex;align-items:center;gap:8px;cursor:pointer;transition:background .15s,border-color .15s}
.btn:hover{background:#fafaf6}
.btn-dark{background:var(--ink);color:#f3f1e6;border-color:var(--ink)}
.btn-dark:hover{background:#000}
.btn-accent{background:var(--accent);color:#f3f1e6;border-color:var(--accent)}
.btn-accent:hover{background:#2e3820}
.btn-sm{height:34px;font-size:12px;padding:0 12px}
.btn-danger{color:var(--bad);border-color:var(--bad)}
.btn-danger:hover{background:#fdf2f2}
.btn-ghost{border:none;background:transparent}
.btn-ghost:hover{background:#f0eee8}

/* ──────────── Hero / Page Head ──────────── */
.page{padding:28px 32px 48px}
.hero{display:grid;grid-template-columns:1.4fr 1fr;gap:22px;margin-bottom:26px}
.eyebrow{display:inline-flex;align-items:center;gap:8px;font-size:11.5px;color:var(--ink-3);text-transform:uppercase;letter-spacing:.1em;font-weight:600;margin-bottom:14px}
.eyebrow .live{width:7px;height:7px;border-radius:50%;background:var(--good);box-shadow:0 0 0 3px rgba(63,122,77,.18);animation:pulse-live 2s ease-in-out infinite}
.h1{font-family:'Instrument Serif',serif;font-size:46px;line-height:1.05;letter-spacing:-.015em;color:var(--ink)}
.h1 em{font-style:italic;color:var(--accent)}
.sub-text{font-size:14px;color:var(--ink-2);margin-top:14px;max-width:560px}
.hero-actions{margin-top:20px;display:flex;gap:10px;flex-wrap:wrap}

/* ──────────── Cutoff Card ──────────── */
.cutoff{background:linear-gradient(160deg,#1f2419 0%,#2b3322 60%,#3d4a2a 100%);color:#f3f1e6;border-radius:18px;padding:22px;position:relative;overflow:hidden;box-shadow:var(--shadow-lg)}
.cutoff::before{content:"";position:absolute;inset:-30% -10% auto auto;width:280px;height:280px;background:radial-gradient(circle,rgba(243,241,230,.10),transparent 60%);border-radius:50%}
.cutoff .cap{font-size:11px;text-transform:uppercase;letter-spacing:.12em;opacity:.7}
.cutoff h2{font-family:'Instrument Serif',serif;font-size:28px;margin-top:6px;line-height:1.15}
.cutoff .timer{display:flex;align-items:baseline;gap:10px;margin-top:18px}
.cutoff .timer .big{font-family:'JetBrains Mono',monospace;font-size:48px;font-weight:500;letter-spacing:-.02em}
.cutoff .timer .lbl{font-size:12px;opacity:.7}
.bar{height:6px;background:rgba(243,241,230,.16);border-radius:var(--radius-pill);margin-top:18px;overflow:hidden}
.bar > div{height:100%;background:linear-gradient(90deg,#dcd6c2,#a8893d);border-radius:var(--radius-pill);transition:width .6s ease}
.cutoff .steps{display:flex;justify-content:space-between;font-size:11.5px;margin-top:10px;opacity:.85}
.cutoff .steps span.done::before{content:"●";color:#cbd6b1;margin-right:5px}
.cutoff .steps span.now::before{content:"○";color:#fff;margin-right:5px}
.cutoff .steps span.pend{opacity:.5}
.cutoff .steps span.pend::before{content:"○";margin-right:5px}

/* ──────────── KPI Cards ──────────── */
.kpi-row{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-bottom:26px}
.kpi{background:var(--card);border:1px solid var(--line);border-radius:var(--radius-lg);padding:18px 18px 16px;position:relative;animation:fade-in-up .4s ease both}
.kpi:nth-child(2){animation-delay:.05s}
.kpi:nth-child(3){animation-delay:.1s}
.kpi:nth-child(4){animation-delay:.15s}
.kpi .lbl{font-size:11.5px;color:var(--ink-3);text-transform:uppercase;letter-spacing:.08em;font-weight:600}
.kpi .val{font-family:'Instrument Serif',serif;font-size:38px;line-height:1.05;margin-top:8px;letter-spacing:-.015em}
.kpi .val small{font-family:'Inter',sans-serif;font-size:14px;color:var(--ink-3);font-weight:500;margin-left:4px}
.kpi .meta{font-size:12px;color:var(--ink-2);margin-top:8px;display:flex;align-items:center;gap:8px}
.delta{display:inline-flex;align-items:center;gap:3px;font-size:11.5px;font-weight:600;padding:2px 7px;border-radius:var(--radius-pill)}
.delta.up{background:#e8efe1;color:var(--good)}
.delta.down{background:#f6e1d6;color:var(--warn)}
.delta.bad{background:#f4dada;color:var(--bad)}

/* ──────────── Feeds Card ──────────── */
.feeds-card{background:var(--card);border:1px solid var(--line);border-radius:var(--radius-lg);padding:14px 18px;margin-bottom:26px;display:flex;align-items:center;gap:24px;animation:fade-in-up .4s ease .2s both}
.feeds-card h4{font-size:11.5px;color:var(--ink-3);text-transform:uppercase;letter-spacing:.08em;font-weight:600;white-space:nowrap}
.feed-list{display:flex;gap:18px;flex:1;flex-wrap:wrap;align-items:center}
.feed-chip{display:flex;align-items:center;gap:9px;padding:7px 12px;border:1px solid var(--line-2);border-radius:var(--radius-md);background:#fbfaf7;transition:border-color .15s}
.feed-chip:hover{border-color:var(--accent-2)}
.feed-chip .ind{width:8px;height:8px;border-radius:50%;flex-shrink:0}
.feed-chip.ok .ind{background:var(--good);box-shadow:0 0 0 3px rgba(63,122,77,.15)}
.feed-chip.warn .ind{background:var(--warn);box-shadow:0 0 0 3px rgba(194,84,29,.15);animation:pulse-warn 2s ease-in-out infinite}
.feed-chip.err .ind{background:var(--bad);box-shadow:0 0 0 3px rgba(168,50,50,.15)}
.feed-chip.processing .ind{background:var(--gold);box-shadow:0 0 0 3px rgba(168,137,61,.15);animation:pulse-warn 1.5s ease-in-out infinite}
.feed-chip strong{font-size:12.5px;font-weight:600}
.feed-chip span{font-size:11px;color:var(--ink-3)}
.upload-cta{padding:9px 14px;border:1px dashed var(--line-2);border-radius:var(--radius-md);font-size:12.5px;color:var(--ink-2);display:flex;align-items:center;gap:8px;cursor:pointer;transition:all .15s}
.upload-cta:hover{background:#fbfaf7;border-color:var(--accent-2);color:var(--accent)}

/* ──────────── Tabs ──────────── */
.tabs{display:flex;align-items:center;gap:4px;background:#efece4;border-radius:11px;padding:4px;width:fit-content;margin-bottom:18px}
.tab{padding:8px 14px;font-size:12.5px;font-weight:500;color:var(--ink-2);border-radius:var(--radius-sm);cursor:pointer;display:flex;align-items:center;gap:6px;transition:all .15s;white-space:nowrap}
.tab:hover{color:var(--ink)}
.tab.active{background:#fff;color:var(--ink);box-shadow:var(--shadow-sm)}
.tab .ct{font-size:11px;background:#e3dfd1;color:var(--ink-2);padding:1px 7px;border-radius:var(--radius-pill);font-weight:600}
.tab.active .ct{background:var(--accent);color:#f3f1e6}

/* ──────────── Panel / Card ──────────── */
.panel{background:var(--card);border:1px solid var(--line);border-radius:var(--radius-xl);overflow:hidden}
.panel-head{padding:18px 20px;display:flex;align-items:flex-start;justify-content:space-between;border-bottom:1px solid var(--line)}
.panel-head h3{font-family:'Instrument Serif',serif;font-size:22px;letter-spacing:-.01em}
.panel-head .desc{font-size:12.5px;color:var(--ink-3);margin-top:3px}

/* ──────────── Tool Row / Filter Chips ──────────── */
.tool-row{display:flex;align-items:center;gap:8px;padding:12px 20px;border-bottom:1px solid var(--line);background:#fbfaf7;flex-wrap:wrap}
.chip-filter{height:30px;padding:0 11px;background:#fff;border:1px solid var(--line-2);border-radius:var(--radius-pill);font-size:12px;color:var(--ink-2);display:inline-flex;align-items:center;gap:6px;cursor:pointer;transition:all .15s;white-space:nowrap}
.chip-filter:hover{border-color:var(--accent-2)}
.chip-filter strong{color:var(--ink);font-weight:600}
.chip-filter.active{background:var(--ink);color:#f3f1e6;border-color:var(--ink)}
.chip-filter.active strong{color:#f3f1e6}
.tool-right{margin-left:auto;display:flex;gap:8px;align-items:center;font-size:12px;color:var(--ink-3)}

/* ──────────── Tables ──────────── */
table{width:100%;border-collapse:collapse;font-size:13px}
thead th{font-weight:500;font-size:11px;text-transform:uppercase;letter-spacing:.08em;color:var(--ink-3);text-align:left;padding:11px 18px;background:#fbfaf7;border-bottom:1px solid var(--line);cursor:pointer;user-select:none;white-space:nowrap;transition:color .15s}
thead th:hover{color:var(--ink)}
thead th.sorted{color:var(--ink);font-weight:600}
thead th .sort-ind{margin-left:4px;font-size:10px}
tbody td{padding:14px 18px;border-bottom:1px solid var(--line);vertical-align:middle}
tbody tr{cursor:pointer;transition:background .12s}
tbody tr:hover{background:#fbfaf7}
tbody tr.selected{background:#f1efe7}
tbody tr.selected td:first-child{box-shadow:inset 3px 0 0 var(--accent)}
.mono{font-family:'JetBrains Mono',monospace;font-size:12px}
.right{text-align:right;font-variant-numeric:tabular-nums}
.bad-num{color:var(--bad);font-weight:600}
.good-num{color:var(--good);font-weight:600}
.dim{color:var(--ink-3)}

/* ──────────── Counterparty Marks ──────────── */
.acct{display:flex;align-items:center;gap:10px}
.cp-mark{width:26px;height:26px;border-radius:7px;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:10.5px;color:#f3f1e6;flex-shrink:0}
.cp-gs{background:#1a2331}
.cp-jpm{background:#5b3a1f}
.cp-ms{background:#2b3a2b}
.cp-ct{background:#5b1f2b}
.cp-ss{background:#3d2b5b}
.cp-bn{background:#2b4a5b}
.acct .nm{font-weight:600;font-size:13px}
.acct .sub-label{font-size:11px;color:var(--ink-3);margin-top:1px}

/* ──────────── Severity / Status ──────────── */
.sev{display:inline-flex;align-items:center;gap:6px;font-size:11.5px;font-weight:600;padding:3px 9px;border-radius:var(--radius-pill)}
.sev-h{background:#f4dada;color:var(--bad)}
.sev-m{background:#f6e7d2;color:#8a5814}
.sev-l{background:#e5e5e1;color:var(--ink-2)}
.status{display:inline-flex;align-items:center;gap:6px;font-size:11.5px;font-weight:500;color:var(--ink-2)}
.status .ind{width:7px;height:7px;border-radius:50%}
.status.s-pending .ind{background:var(--warn);box-shadow:0 0 0 2.5px rgba(194,84,29,.18)}
.status.s-broken .ind{background:#a8a8a3}
.status.s-escalated .ind{background:var(--bad);box-shadow:0 0 0 2.5px rgba(168,50,50,.18)}
.status.s-resolved .ind{background:var(--good);box-shadow:0 0 0 2.5px rgba(63,122,77,.18)}
.status.s-matched .ind{background:var(--good);box-shadow:0 0 0 2.5px rgba(63,122,77,.18)}

/* ──────────── Detail Panel ──────────── */
.body-grid{display:grid;grid-template-columns:1fr 400px;gap:22px}
.detail{background:var(--card);border:1px solid var(--line);border-radius:var(--radius-xl);overflow:hidden;display:flex;flex-direction:column}
.detail-hero{padding:22px;background:linear-gradient(180deg,#fbfaf7,#fff);border-bottom:1px solid var(--line)}
.detail-hero .tag-row{display:flex;gap:6px;flex-wrap:wrap;margin-bottom:12px}
.tag{font-size:11px;font-weight:600;padding:3px 9px;border-radius:var(--radius-pill);background:#efece4;color:var(--ink-2)}
.tag.red{background:#f4dada;color:var(--bad)}
.tag.amber{background:#f6e7d2;color:#8a5814}
.tag.green{background:#e8efe1;color:var(--good)}
.detail-hero h2{font-family:'Instrument Serif',serif;font-size:26px;letter-spacing:-.01em;line-height:1.15}
.detail-hero .meta-text{font-family:'JetBrains Mono',monospace;font-size:11.5px;color:var(--ink-3);margin-top:6px}

.compare{padding:18px 22px;border-bottom:1px solid var(--line)}
.compare h5{font-size:11px;color:var(--ink-3);text-transform:uppercase;letter-spacing:.08em;font-weight:600;margin-bottom:12px}
.compare-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.cmp{padding:12px 14px;border-radius:11px;border:1px solid var(--line-2);background:#fbfaf7}
.cmp .src{font-size:11.5px;color:var(--ink-3);font-weight:500}
.cmp .v{font-family:'Instrument Serif',serif;font-size:24px;margin-top:4px;letter-spacing:-.01em}
.cmp.diff{background:#fdf2eb;border-color:#eecdb8}
.cmp.diff .v{color:var(--bad)}
.delta-row{margin-top:14px;display:flex;align-items:center;justify-content:space-between;padding:10px 12px;background:#1a1a1a;color:#f3f1e6;border-radius:11px}
.delta-row .l{font-size:11.5px;opacity:.7;text-transform:uppercase;letter-spacing:.08em}
.delta-row .r{font-family:'JetBrains Mono',monospace;font-size:15px;color:#f0b393}

/* ──────────── AI Card ──────────── */
.ai-card{margin:18px 22px;padding:16px;border-radius:12px;background:linear-gradient(180deg,#f0eee2,#fbfaf7);border:1px solid #e7e3cf;position:relative}
.ai-card .h{display:flex;align-items:center;gap:8px;font-size:11.5px;color:var(--accent);font-weight:600;text-transform:uppercase;letter-spacing:.08em}
.ai-card .h .icon{color:var(--gold)}
.ai-card h6{font-size:14px;font-weight:600;margin-top:8px}
.ai-card p{font-size:12.5px;color:var(--ink-2);margin-top:6px;line-height:1.55}
.ai-card .conf{margin-top:10px;display:flex;align-items:center;gap:10px;font-size:11.5px;color:var(--ink-3)}
.cbar{height:4px;width:120px;background:#e3dfd1;border-radius:var(--radius-pill);overflow:hidden}
.cbar > div{height:100%;background:var(--accent);border-radius:var(--radius-pill)}

/* ──────────── Timeline ──────────── */
.timeline{padding:6px 22px 18px}
.timeline h5{font-size:11px;color:var(--ink-3);text-transform:uppercase;letter-spacing:.08em;font-weight:600;margin:12px 0}
.tl{position:relative;padding-left:18px}
.tl::before{content:"";position:absolute;left:4px;top:6px;bottom:6px;width:1px;background:var(--line-2)}
.tl-row{position:relative;padding:6px 0}
.tl-row::before{content:"";position:absolute;left:-18px;top:11px;width:9px;height:9px;border-radius:50%;background:#fff;border:2px solid var(--accent-2)}
.tl-row.muted::before{border-color:var(--line-2)}
.tl-row strong{font-size:13px;font-weight:600}
.tl-row span{display:block;font-size:11.5px;color:var(--ink-3);margin-top:2px}

.detail-foot{margin-top:auto;padding:14px 18px;display:flex;gap:8px;border-top:1px solid var(--line);background:#fbfaf7}
.detail-foot .btn{flex:1;justify-content:center}

/* ──────────── Toast ──────────── */
.toast-container{position:fixed;top:80px;right:32px;z-index:9999;display:flex;flex-direction:column;gap:8px}
.toast{background:var(--ink);color:#f3f1e6;padding:12px 20px;border-radius:var(--radius-md);font-size:13px;font-weight:500;display:flex;align-items:center;gap:10px;box-shadow:var(--shadow-md);animation:toast-in .3s ease;max-width:380px}
.toast.toast-out{animation:toast-out .3s ease forwards}
.toast .icon{color:var(--good);flex-shrink:0}
.toast.toast-warn .icon{color:var(--warn)}
.toast.toast-error .icon{color:var(--bad)}

/* ──────────── Modal ──────────── */
.modal-overlay{position:fixed;inset:0;background:rgba(26,26,26,.4);backdrop-filter:blur(4px);z-index:1000;display:flex;align-items:center;justify-content:center;animation:fade-in .2s ease}
.modal{background:var(--card);border-radius:var(--radius-xl);width:480px;max-height:80vh;overflow-y:auto;box-shadow:0 24px 48px rgba(0,0,0,.15);animation:modal-in .25s ease}
.modal-header{padding:20px 24px;border-bottom:1px solid var(--line);display:flex;align-items:center;justify-content:space-between}
.modal-header h3{font-family:'Instrument Serif',serif;font-size:22px}
.modal-body{padding:20px 24px}
.modal-footer{padding:16px 24px;border-top:1px solid var(--line);display:flex;gap:8px;justify-content:flex-end;background:#fbfaf7;border-radius:0 0 var(--radius-xl) var(--radius-xl)}

/* ──────────── Form Elements ──────────── */
.form-group{margin-bottom:16px}
.form-group label{display:block;font-size:12px;font-weight:600;color:var(--ink-2);text-transform:uppercase;letter-spacing:.06em;margin-bottom:6px}
.form-input{width:100%;height:40px;border:1px solid var(--line-2);border-radius:var(--radius-sm);padding:0 12px;font-size:13px;background:#fff;transition:border-color .15s;outline:none}
.form-input:focus{border-color:var(--accent)}
textarea.form-input{height:100px;padding:10px 12px;resize:vertical}
select.form-input{appearance:auto}

/* ──────────── Dropdown ──────────── */
.dropdown{position:relative;display:inline-block}
.dropdown-menu{position:absolute;top:calc(100% + 4px);left:0;background:var(--card);border:1px solid var(--line-2);border-radius:var(--radius-md);box-shadow:var(--shadow-md);min-width:180px;z-index:100;animation:fade-in-up .15s ease;overflow:hidden}
.dropdown-item{padding:9px 14px;font-size:13px;cursor:pointer;display:flex;align-items:center;gap:8px;transition:background .1s}
.dropdown-item:hover{background:#f0eee8}
.dropdown-item.active{background:var(--accent-light);color:var(--accent);font-weight:600}

/* ──────────── Login Screen ──────────── */
.login-container{width:1440px;margin:0 auto;min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--bg)}
.login-card{width:520px}
.login-header{text-align:center;margin-bottom:40px}
.login-header .brand-mark{width:48px;height:48px;border-radius:14px;font-size:28px;margin:0 auto 16px}
.login-header h1{font-family:'Instrument Serif',serif;font-size:36px}
.login-header p{color:var(--ink-2);margin-top:8px;font-size:14px}
.user-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:24px}
.user-card{background:var(--card);border:1px solid var(--line);border-radius:var(--radius-lg);padding:16px;cursor:pointer;transition:all .15s;display:flex;align-items:center;gap:12px}
.user-card:hover{border-color:var(--accent-2);box-shadow:var(--shadow-sm)}
.user-card.selected{border-color:var(--accent);background:var(--accent-light);box-shadow:0 0 0 2px rgba(61,74,42,.2)}
.user-card .card-info h4{font-size:14px;font-weight:600}
.user-card .card-info p{font-size:12px;color:var(--ink-3)}
.login-form{background:var(--card);border:1px solid var(--line);border-radius:var(--radius-lg);padding:24px}
.login-btn{width:100%;height:44px;justify-content:center;font-size:14px;margin-top:8px}

/* ──────────── Connection Cards ──────────── */
.conn-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin-bottom:26px}
.conn-card{background:var(--card);border:1px solid var(--line);border-radius:var(--radius-lg);padding:18px;transition:border-color .15s}
.conn-card:hover{border-color:var(--accent-2)}
.conn-card .conn-top{display:flex;align-items:center;gap:10px;margin-bottom:12px}
.conn-card .conn-name{font-weight:600;font-size:14px}
.conn-card .conn-type{font-size:11px;color:var(--ink-3);margin-top:2px}
.conn-card .conn-stats{display:flex;gap:16px;font-size:12px;color:var(--ink-2)}
.conn-card .conn-stats strong{color:var(--ink);font-family:'JetBrains Mono',monospace;font-size:13px}
.status-pill{display:inline-flex;align-items:center;gap:5px;font-size:11px;font-weight:600;padding:3px 9px;border-radius:var(--radius-pill)}
.status-active{background:#e8efe1;color:var(--good)}
.status-degraded{background:#f6e1d6;color:var(--warn)}
.status-offline{background:#f4dada;color:var(--bad)}
.status-onboarding{background:#fbeed2;color:var(--gold)}

/* ──────────── Expandable Row ──────────── */
.expand-row{display:none;background:#fbfaf7}
.expand-row.open{display:table-row}
.expand-content{padding:16px 18px}
.test-results{display:flex;flex-direction:column;gap:6px}
.test-item{display:flex;align-items:center;gap:10px;font-size:12.5px;padding:6px 0}
.test-item .test-status{font-weight:600;font-size:11px;padding:2px 8px;border-radius:var(--radius-pill)}
.test-item .test-pass{background:#e8efe1;color:var(--good)}
.test-item .test-fail{background:#f4dada;color:var(--bad)}
.test-item .test-pending{background:#fbeed2;color:var(--gold)}

/* ──────────── Pagination ──────────── */
.pagination{display:flex;align-items:center;justify-content:space-between;padding:12px 20px;border-top:1px solid var(--line);background:#fbfaf7;font-size:12.5px;color:var(--ink-3)}
.pagination .page-btns{display:flex;gap:4px}
.page-btn{width:32px;height:32px;border-radius:var(--radius-sm);border:1px solid var(--line-2);background:#fff;display:flex;align-items:center;justify-content:center;font-size:12px;cursor:pointer;transition:all .15s}
.page-btn:hover{background:#f0eee8}
.page-btn.active{background:var(--ink);color:#f3f1e6;border-color:var(--ink)}
.page-btn:disabled{opacity:.4;cursor:not-allowed}

/* ──────────── Empty State ──────────── */
.empty-state{padding:48px;text-align:center;color:var(--ink-3)}
.empty-state .icon{margin:0 auto 16px;color:var(--ink-3);opacity:.5}
.empty-state h4{font-family:'Instrument Serif',serif;font-size:20px;color:var(--ink-2);margin-bottom:6px}
.empty-state p{font-size:13px}

/* ──────────── Animations ──────────── */
@keyframes fade-in{from{opacity:0}to{opacity:1}}
@keyframes fade-in-up{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}
@keyframes toast-in{from{opacity:0;transform:translateX(40px)}to{opacity:1;transform:translateX(0)}}
@keyframes toast-out{to{opacity:0;transform:translateX(40px)}}
@keyframes modal-in{from{opacity:0;transform:scale(.96)}to{opacity:1;transform:scale(1)}}
@keyframes pulse-live{0%,100%{box-shadow:0 0 0 3px rgba(63,122,77,.18)}50%{box-shadow:0 0 0 6px rgba(63,122,77,.10)}}
@keyframes pulse-warn{0%,100%{box-shadow:0 0 0 3px rgba(194,84,29,.15)}50%{box-shadow:0 0 0 6px rgba(194,84,29,.08)}}
@keyframes stagger-row{from{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}

/* Row stagger animation */
tbody tr{animation:stagger-row .3s ease both}
tbody tr:nth-child(1){animation-delay:.03s}
tbody tr:nth-child(2){animation-delay:.06s}
tbody tr:nth-child(3){animation-delay:.09s}
tbody tr:nth-child(4){animation-delay:.12s}
tbody tr:nth-child(5){animation-delay:.15s}
tbody tr:nth-child(6){animation-delay:.18s}
tbody tr:nth-child(7){animation-delay:.21s}
tbody tr:nth-child(8){animation-delay:.24s}

/* ──────────── Utility ──────────── */
.hidden{display:none!important}
.text-center{text-align:center}
.flex{display:flex}
.items-center{align-items:center}
.gap-8{gap:8px}
.gap-16{gap:16px}
.mt-16{margin-top:16px}
.mb-16{margin-bottom:16px}
.mb-26{margin-bottom:26px}
