/* ===========================================================
   NOC.org portal — design system (shared)
   Type: Space Grotesk (display) · Inter (UI) · JetBrains Mono (data)
   =========================================================== */
:root{
  --bg:#eef2f6; --surface:#fff; --surface-2:#f7f9fb; --rail:#0c1a26; --rail-2:#13283a;
  --ink:#0f2230; --ink-2:#41566a; --muted:#6f879b; --hair:#e4eaf0; --hair-2:#eef2f6;
  --teal:#06b6c7; --teal-d:#069aa8; --teal-l:#22d3de; --teal-bg:#e2f7fa;
  --green:#15a34a; --green-bg:#e6f6ec; --red:#e0464b; --red-bg:#fdeaea;
  --amber:#e8930c; --amber-bg:#fdf1dd; --violet:#6d5ce0; --violet-bg:#eee9fb;
  --shadow:0 1px 2px rgba(16,34,48,.04),0 6px 20px -8px rgba(16,34,48,.10);
  --shadow-lg:0 18px 50px -14px rgba(16,34,48,.28);
  --r:14px; --r-sm:10px;
  --sans:'Inter',-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;
  --disp:'Space Grotesk','Inter',sans-serif;
  --mono:'JetBrains Mono',ui-monospace,'SF Mono',Menlo,monospace;
}
*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{background:var(--bg);color:var(--ink);font-family:var(--sans);font-size:14px;line-height:1.5;-webkit-font-smoothing:antialiased}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer;border:0;background:none;color:inherit}
input,select,textarea{font-family:inherit}
::selection{background:var(--teal);color:#fff}
:focus-visible{outline:2px solid var(--teal);outline-offset:2px;border-radius:6px}
h1,h2,h3,h4{font-family:var(--disp);letter-spacing:-.01em}
.mono{font-family:var(--mono)}

/* ---------- App shell ---------- */
.app{min-height:100vh}
.rail{background:var(--rail);color:#cdd9e3;display:flex;flex-direction:column;position:sticky;top:0;height:100vh}
.rail-top{padding:20px 18px 8px;display:flex;align-items:center;gap:10px}
.logo{width:30px;height:30px;border-radius:9px;background:linear-gradient(135deg,var(--teal),var(--teal-l));display:grid;place-items:center;flex:none;box-shadow:0 0 0 1px rgba(255,255,255,.06),0 6px 16px -6px var(--teal)}
.logo svg{width:17px;height:17px}
.logo-txt{font-family:var(--disp);font-weight:700;font-size:18px;color:#fff;letter-spacing:-.01em}
.logo-txt b{color:var(--teal-l)}
.nav-group{padding:10px 12px}
.nav-label{font-size:10.5px;letter-spacing:.13em;text-transform:uppercase;color:#65809a;padding:8px 10px 6px;font-weight:600}
.nav-item{display:flex;align-items:center;gap:11px;padding:9px 11px;border-radius:10px;color:#aebfcd;font-weight:500;font-size:13.5px;margin:1px 0;position:relative;transition:background .15s,color .15s;width:100%;text-align:left}
.nav-item svg{width:18px;height:18px;flex:none;opacity:.85}
.nav-item .badge{margin-left:auto;font-family:var(--mono);font-size:10.5px;font-weight:600;padding:1px 7px;border-radius:20px;background:rgba(255,255,255,.07);color:#9fb2c2}
.nav-item:hover{background:rgba(255,255,255,.05);color:#e7eef3}
.nav-item.active{background:linear-gradient(90deg,rgba(6,182,199,.18),rgba(6,182,199,.04));color:#fff}
.nav-item.active svg{opacity:1;color:var(--teal-l)}
.nav-item.active::before{content:"";position:absolute;left:-12px;top:8px;bottom:8px;width:3px;border-radius:0 3px 3px 0;background:var(--teal-l)}
.nav-item.alert .badge{background:var(--red);color:#fff}
.rail-sep{height:1px;background:rgba(255,255,255,.07);margin:6px 18px}
.rail-foot{margin-top:auto;padding:12px}
.rail-acct{display:flex;align-items:center;gap:10px;padding:9px 10px;border-radius:11px;background:rgba(255,255,255,.04)}
.rail-acct img{width:30px;height:30px;border-radius:8px}
.rail-acct .m{font-size:11px;color:#8ea3b4;font-family:var(--mono)}
.rail-acct .n{font-size:13px;color:#e7eef3;font-weight:600}
.rail-acct .lo{margin-left:auto;color:#7d96a8}
.rail-acct .lo svg{width:16px;height:16px}

/* ---------- Main ---------- */
.main{min-width:0;display:flex;flex-direction:column}
.brand{display:flex;align-items:center;gap:9px;flex:none;margin-right:4px}
.brand .logo{width:30px;height:30px;border-radius:8px;background:linear-gradient(135deg,#0ad,#06B6C7);display:grid;place-items:center}
.brand .logo svg{width:18px;height:18px}
.brand .logo-txt{font-family:var(--disp);font-weight:700;font-size:18px;color:var(--ink)}
.brand .logo-txt b{color:var(--teal-d)}
.brand-img{height:30px;width:auto;display:block}
.acct{flex:none}
.acct img{width:34px;height:34px;border-radius:10px;border:1px solid var(--hair);display:block}
.topbar{position:sticky;top:0;z-index:30;background:rgba(238,242,246,.82);backdrop-filter:blur(12px);border-bottom:1px solid var(--hair);padding:12px 26px;display:flex;align-items:center;gap:16px}
.mbar{display:none}
.site-sel{display:flex;align-items:center;gap:10px;background:var(--surface);border:1px solid var(--hair);padding:7px 12px;border-radius:11px;box-shadow:var(--shadow);min-width:0;flex-shrink:1;position:relative}
.site-sel .glb{width:30px;height:30px;border-radius:8px;background:var(--teal-bg);display:grid;place-items:center;flex:none}
.site-sel .glb svg{width:16px;height:16px;color:var(--teal-d)}
.site-sel .lbl{font-size:10.5px;color:var(--muted);font-weight:600;text-transform:uppercase;letter-spacing:.06em}
.site-sel .val{font-family:var(--disp);font-weight:600;font-size:14px;color:var(--ink);display:flex;align-items:center;gap:7px;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.site-sel .chev{color:var(--muted);font-size:11px}
.site-menu{position:absolute;top:calc(100% + 8px);left:0;min-width:260px;background:var(--surface);border:1px solid var(--hair);border-radius:13px;box-shadow:var(--shadow-lg);padding:6px;z-index:60;display:none}
.site-menu.open{display:block}
.site-menu button{display:flex;align-items:center;gap:10px;width:100%;padding:9px 11px;border-radius:9px;font-size:13.5px;color:var(--ink-2);font-weight:500;text-align:left}
.site-menu button:hover{background:var(--surface-2)}
.site-menu button.on{background:var(--teal-bg);color:var(--teal-d);font-weight:600}
.site-menu button .mono{font-family:var(--mono);font-size:12.5px}
.site-menu .hd{font-size:10.5px;text-transform:uppercase;letter-spacing:.08em;color:var(--muted);padding:8px 11px 4px;font-weight:600}
.site-menu .dot{width:8px;height:8px;border-radius:50%;background:var(--teal);flex:none}
.spacer{flex:1}
.chips{display:flex;gap:9px}
.chip{display:flex;align-items:center;gap:8px;background:var(--surface);border:1px solid var(--hair);padding:7px 12px;border-radius:11px;box-shadow:var(--shadow);white-space:nowrap}
.chip .k{font-size:11px;color:var(--muted);font-weight:500}
.chip .v{font-family:var(--disp);font-weight:700;font-size:14px}
.chip .dot{width:7px;height:7px;border-radius:50%}
.chip.ok .dot{background:var(--green);box-shadow:0 0 0 3px var(--green-bg)}
.chip.warn .v{color:var(--red)}
.chip.warn .dot{background:var(--red);box-shadow:0 0 0 3px var(--red-bg)}
.tbtn{width:38px;height:38px;border-radius:11px;background:var(--surface);border:1px solid var(--hair);display:grid;place-items:center;box-shadow:var(--shadow);color:var(--ink-2);flex:none}
.tbtn svg{width:18px;height:18px}

.content{padding:22px 26px 104px;max-width:1180px;width:100%;margin:0 auto}
.page-head{display:flex;align-items:flex-end;justify-content:space-between;gap:16px;margin:4px 0 18px;flex-wrap:wrap}
.page-head h1{font-size:23px;font-weight:600;letter-spacing:-.02em;margin:0;display:flex;align-items:center;gap:11px}
.page-head h1 .pill{font-size:11px;font-weight:600;font-family:var(--sans);color:var(--teal-d);background:var(--teal-bg);padding:3px 9px;border-radius:20px;letter-spacing:0}
.page-head p{margin:5px 0 0;color:var(--muted);font-size:13px}

/* tabs */
.tabs{display:flex;gap:3px;background:var(--surface);border:1px solid var(--hair);border-radius:13px;padding:4px;box-shadow:var(--shadow);overflow:auto;scrollbar-width:none}
.tabs::-webkit-scrollbar{display:none}
.tab{padding:8px 15px;border-radius:9px;font-weight:550;font-size:13.5px;color:var(--ink-2);white-space:nowrap;display:flex;align-items:center;gap:7px;transition:background .15s,color .15s}
.tab svg{width:16px;height:16px}
.tab .n{font-family:var(--mono);font-size:11px;background:var(--hair-2);color:var(--muted);padding:0 6px;border-radius:20px;font-weight:600}
.tab:hover{background:var(--surface-2)}
.tab.active{background:var(--rail);color:#fff}
.tab.tab-back{color:var(--muted);font-size:12px;font-weight:500;padding:8px 12px 8px 7px;border-right:1px solid var(--hair);border-radius:9px 0 0 9px;margin-right:6px;gap:4px}
.tab.tab-back svg{width:14px;height:14px}
.tab.tab-back:hover{color:var(--teal-d);background:transparent}
.tab.active .n{background:rgba(255,255,255,.14);color:#cfe9ec}
.tab.flag .n{background:var(--teal);color:#fff}

.panel{display:none;animation:fade .25s ease}
.panel.show{display:block}
@keyframes fade{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:none}}

/* cards + grid */
.grid{display:grid;gap:16px;margin-top:16px}
.two{grid-template-columns:1fr 1fr}.split{grid-template-columns:1.5fr 1fr}
.card{background:var(--surface);border:1px solid var(--hair);border-radius:var(--r);box-shadow:var(--shadow)}
.card-h{padding:16px 18px 0;display:flex;align-items:flex-start;justify-content:space-between;gap:12px}
.card-h h3{font-size:15px;font-weight:600;margin:0}
.card-h .sub{color:var(--muted);font-size:12px;margin-top:2px}
.card-b{padding:16px 18px}

/* KPIs */
.kpis{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
.kpi{background:var(--surface);border:1px solid var(--hair);border-radius:var(--r);padding:16px 17px;box-shadow:var(--shadow);position:relative;overflow:hidden}
.kpi .top{display:flex;align-items:center;gap:9px;color:var(--muted);font-size:12px;font-weight:550}
.kpi .ic{width:28px;height:28px;border-radius:8px;display:grid;place-items:center;flex:none}
.kpi .ic svg{width:15px;height:15px}
.kpi .num{font-family:var(--disp);font-weight:700;font-size:30px;letter-spacing:-.02em;margin:9px 0 2px;line-height:1}
.kpi .num small{font-size:16px;font-weight:600;color:var(--ink-2);margin-left:2px}
.kpi .delta{font-size:12px;font-weight:600;display:flex;align-items:center;gap:4px}
.kpi .delta.up{color:var(--green)}.kpi .delta.down{color:var(--red)}.kpi .delta.flat{color:var(--muted)}
.kpi .spark{position:absolute;right:0;bottom:0;left:0;height:34px;opacity:.5}
.kpi.hero{background:linear-gradient(135deg,#0c1a26,#16384a);color:#fff;border-color:#0c1a26}
.kpi.hero .top{color:#9fc7cf}.kpi.hero .num{color:#fff}.kpi.hero .num small{color:#bfe3e7}
.ic.teal{background:var(--teal-bg);color:var(--teal-d)}.ic.green{background:var(--green-bg);color:var(--green)}
.ic.red{background:var(--red-bg);color:var(--red)}.ic.violet{background:var(--violet-bg);color:var(--violet)}
.ic.amber{background:var(--amber-bg);color:#9a5d05}.ic.glow{background:rgba(255,255,255,.1);color:var(--teal-l)}
.ic.slate{background:#eef2f6;color:var(--ink-2)}

/* chart */
.chartwrap{display:grid;grid-template-columns:1fr 250px;gap:0}
.chart{padding:6px 4px 0}.chart svg{width:100%;height:230px;display:block}
.xlabels{display:flex;justify-content:space-between;font-family:var(--mono);font-size:10px;color:var(--muted);padding:6px 2px 0}
.legend{border-left:1px solid var(--hair);padding:6px 4px 6px 18px;display:flex;flex-direction:column;gap:2px}
.legend .lh{font-size:11px;color:var(--muted);font-weight:600;text-transform:uppercase;letter-spacing:.05em;margin-bottom:6px}
.lrow{display:flex;align-items:center;gap:9px;padding:6px 7px;border-radius:8px}
.lrow:hover{background:var(--surface-2)}
.lrow .sw{width:9px;height:9px;border-radius:3px;flex:none}
.lrow .nm{font-family:var(--mono);font-size:12px;color:var(--ink-2);font-weight:500}
.lrow .vl{margin-left:auto;font-family:var(--disp);font-weight:600;font-size:13px}
.lrow.tot{background:var(--teal-bg)}.lrow.tot .nm{color:var(--teal-d);font-weight:700;font-family:var(--sans)}.lrow.tot .vl{color:var(--teal-d)}
.seg{display:flex;gap:3px;background:var(--surface-2);padding:3px;border-radius:9px;border:1px solid var(--hair)}
.seg button{padding:5px 11px;border-radius:6px;font-size:12px;font-weight:550;color:var(--muted)}
.seg button.on{background:var(--surface);color:var(--ink);box-shadow:var(--shadow)}

/* threats */
.atk{display:flex;align-items:center;gap:11px;padding:9px 0}
.atk+.atk{border-top:1px solid var(--hair-2)}
.atk .tag{font-family:var(--mono);font-size:11.5px;font-weight:600;padding:3px 8px;border-radius:7px;background:var(--red-bg);color:#b23034;white-space:nowrap}
.atk .tag.amber{background:var(--amber-bg);color:#9a5d05}.atk .tag.violet{background:var(--violet-bg);color:#5847c2}
.atk .tag.slate{background:var(--hair-2);color:var(--ink-2)}
.atk .desc{font-size:12.5px;color:var(--ink-2)}
.atk .bar{margin-left:auto;width:120px;height:6px;border-radius:6px;background:var(--hair-2);overflow:hidden;flex:none}
.atk .bar i{display:block;height:100%;border-radius:6px;background:var(--red)}
.atk .ct{font-family:var(--mono);font-weight:600;font-size:12.5px;width:38px;text-align:right;flex:none}

/* tables */
.tbl{width:100%;border-collapse:collapse}
.tbl th{text-align:left;font-size:11px;letter-spacing:.05em;text-transform:uppercase;color:var(--muted);font-weight:600;padding:0 10px 9px;border-bottom:1px solid var(--hair)}
.tbl td{padding:11px 10px;border-bottom:1px solid var(--hair-2);font-size:13px;vertical-align:middle}
.tbl tr:last-child td{border-bottom:0}
.tbl tbody tr:hover{background:var(--surface-2)}
.site-cell{display:flex;align-items:center;gap:9px;font-family:var(--mono);font-size:12.5px;color:var(--ink);font-weight:500}
.site-cell .d{width:8px;height:8px;border-radius:50%;background:var(--teal);flex:none}
.num-c{font-family:var(--mono);font-weight:500;color:var(--ink-2)}
.hit{display:flex;align-items:center;gap:8px}
.hit .track{width:70px;height:6px;border-radius:6px;background:var(--hair-2);overflow:hidden}
.hit .track i{display:block;height:100%;background:var(--teal);border-radius:6px}
.hit .pct{font-family:var(--mono);font-size:12px;font-weight:600;color:var(--teal-d);width:34px}

/* COMPACT logs (single dense line per event) */
.logbar{display:flex;align-items:center;gap:10px;flex-wrap:wrap;margin-bottom:10px}
.search{flex:1;min-width:200px;display:flex;align-items:center;gap:8px;background:var(--surface-2);border:1px solid var(--hair);border-radius:10px;padding:8px 12px}
.search svg{width:16px;height:16px;color:var(--muted)}
.search input{border:0;background:none;outline:none;flex:1;font-family:var(--mono);font-size:13px;color:var(--ink)}
.fbtn{display:flex;align-items:center;gap:7px;padding:8px 13px;border:1px solid var(--hair);border-radius:10px;background:var(--surface);font-weight:550;font-size:13px;color:var(--ink-2);white-space:nowrap}
.fbtn svg{width:15px;height:15px}.fbtn.on{border-color:var(--teal);background:var(--teal-bg);color:var(--teal-d)}
.logtable{width:100%;border-collapse:collapse;font-size:12.5px}
.logtable th{position:sticky;top:0;background:var(--surface);text-align:left;font-size:10.5px;letter-spacing:.05em;text-transform:uppercase;color:var(--muted);font-weight:600;padding:7px 10px;border-bottom:1px solid var(--hair);z-index:1}
.logtable td{padding:8px 10px;border-bottom:1px solid var(--hair-2);white-space:nowrap}
.logtable tr:hover td{background:var(--surface-2)}
.logtable .t{font-family:var(--mono);color:var(--muted);font-size:11.5px}
.logtable .geo{font-family:var(--mono);color:var(--ink-2);font-size:12px}
.logtable .ip{font-family:var(--mono);color:var(--ink);font-weight:500;font-size:12.5px}
.logtable .req{font-family:var(--mono);color:var(--ink);font-size:12px;max-width:380px;overflow:hidden;text-overflow:ellipsis}
.logtable .req .ua{color:var(--muted)}
.verdict{display:inline-flex;align-items:center;gap:5px;font-weight:600;font-size:11.5px;padding:2px 8px;border-radius:7px}
.verdict.ok{background:var(--green-bg);color:#0f7a37}.verdict.block{background:var(--red-bg);color:#b23034}
.verdict svg{width:11px;height:11px}
.vtag{font-family:var(--mono);font-size:10.5px;color:var(--muted);margin-left:6px}
.cache-tag{font-family:var(--mono);font-size:10px;font-weight:600;padding:1px 6px;border-radius:5px;background:var(--teal-bg);color:var(--teal-d)}
.cache-tag.bypass{background:var(--hair-2);color:var(--muted)}

/* custom rules */
.rule{border:1px solid var(--hair);border-radius:12px;padding:14px 16px;margin-bottom:11px;background:var(--surface);transition:border-color .15s,box-shadow .15s}
.rule:hover{border-color:var(--teal);box-shadow:var(--shadow)}
.rule .rh{display:flex;align-items:center;gap:11px;margin-bottom:9px}
.rule .rname{font-family:var(--disp);font-weight:600;font-size:14.5px}
.rule .when{font-family:var(--mono);font-size:12px;color:var(--ink-2);background:var(--surface-2);border:1px solid var(--hair);border-radius:9px;padding:9px 12px;line-height:1.6}
.rule .when .kw{color:var(--violet);font-weight:600}.rule .when .op{color:var(--teal-d);font-weight:600}.rule .when .val{color:var(--ink);font-weight:600}
.rule .meta{display:flex;gap:16px;margin-top:9px;font-size:11.5px;color:var(--muted);font-family:var(--mono);flex-wrap:wrap}
.act-tag{font-size:11px;font-weight:600;padding:3px 9px;border-radius:7px;font-family:var(--sans)}
.act-tag.block{background:var(--red-bg);color:#b23034}.act-tag.allow{background:var(--green-bg);color:#0f7a37}
.act-tag.challenge{background:var(--amber-bg);color:#9a5d05}.act-tag.rl{background:var(--violet-bg);color:#5847c2}
.addrule{border:1.5px dashed var(--hair);border-radius:12px;padding:15px;display:flex;align-items:center;justify-content:center;gap:9px;color:var(--teal-d);font-weight:600;font-size:13.5px;width:100%}
.addrule:hover{border-color:var(--teal);background:var(--teal-bg)}

/* toggle */
.toggle{width:40px;height:23px;border-radius:20px;background:var(--teal);position:relative;flex:none;transition:background .18s}
.toggle::after{content:"";position:absolute;width:18px;height:18px;border-radius:50%;background:#fff;top:2.5px;right:2.5px;box-shadow:0 1px 3px rgba(0,0,0,.2);transition:right .18s,left .18s}
.toggle.off{background:var(--hair)}.toggle.off::after{right:auto;left:2.5px}
.toggle.ml{margin-left:auto}

/* forms */
.field{margin-bottom:16px}
.field label{display:block;font-size:12.5px;font-weight:600;color:var(--ink);margin-bottom:6px}
.field .help{font-size:11.5px;color:var(--muted);margin-top:5px;line-height:1.45}
.inp,.sel,textarea.inp{width:100%;border:1px solid var(--hair);background:var(--surface);border-radius:10px;padding:10px 13px;font-size:13.5px;color:var(--ink);transition:border-color .15s,box-shadow .15s}
.inp::placeholder{color:#9fb0bf}
.inp:focus,.sel:focus,textarea.inp:focus{outline:0;border-color:var(--teal);box-shadow:0 0 0 3px var(--teal-bg)}
.inp.mono{font-family:var(--mono);font-size:13px}
textarea.inp{resize:vertical;min-height:78px;line-height:1.55}
.sel{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%236f879b' stroke-width='2'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 11px center;background-size:16px;padding-right:36px}
.inp.err{border-color:var(--red);box-shadow:0 0 0 3px var(--red-bg)}
.err-msg{color:var(--red);font-size:12px;margin-top:5px;display:none}
.err-msg.show{display:block}
.row2{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.setrow{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:13px 0;border-bottom:1px solid var(--hair-2)}
.setrow:last-child{border-bottom:0}
.setrow .lab b{font-size:13.5px;font-weight:600;display:block}
.setrow .lab span{font-size:12px;color:var(--muted)}
.setrow .ctl{flex:none}

/* buttons */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:10px 18px;border-radius:11px;font-weight:600;font-size:13.5px;transition:transform .1s,background .15s,box-shadow .15s}
.btn:active{transform:translateY(1px)}
.btn svg{width:16px;height:16px}
.btn-primary{background:var(--teal);color:#fff;box-shadow:0 1px 2px rgba(8,148,163,.25)}
.btn-primary:hover{background:var(--teal-d)}
.btn-ghost{background:var(--surface);border:1px solid var(--hair);color:var(--ink-2)}
.btn-ghost:hover{border-color:var(--teal);color:var(--teal-d)}
.btn-dark{background:var(--rail);color:#fff}.btn-dark:hover{background:var(--rail-2)}
.btn-danger{background:var(--red-bg);color:#b23034}.btn-danger:hover{background:#fbdada}
.btn-block{width:100%}
.btn-lg{padding:13px 20px;font-size:15px;border-radius:12px}

/* setting category cards */
.set-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:13px}
.set-card{border:1px solid var(--hair);border-radius:12px;padding:15px 16px;display:flex;gap:13px;align-items:flex-start;transition:border-color .15s,transform .12s;width:100%;text-align:left;background:var(--surface)}
.set-card:hover{border-color:var(--teal);transform:translateY(-2px);box-shadow:var(--shadow)}
.set-card .ic{width:38px;height:38px;border-radius:10px;display:grid;place-items:center;flex:none}
.set-card .ic svg{width:19px;height:19px}
.set-card h4{margin:0 0 3px;font-size:14.5px;font-weight:600}
.set-card p{margin:0;font-size:12px;color:var(--muted);line-height:1.45}
.set-card .keys{margin-top:7px;display:flex;flex-wrap:wrap;gap:5px}
.set-card .keys span{font-family:var(--mono);font-size:10.5px;background:var(--surface-2);border:1px solid var(--hair);color:var(--ink-2);padding:1px 7px;border-radius:6px}

/* site-gate (per-site notice) */
.gate{text-align:center;padding:48px 20px;max-width:520px;margin:10px auto}
.gate .ic{width:56px;height:56px;border-radius:16px;background:var(--teal-bg);color:var(--teal-d);display:grid;place-items:center;margin:0 auto 14px}
.gate .ic svg{width:26px;height:26px}
.gate h3{font-size:18px;margin:0 0 6px}
.gate p{color:var(--muted);font-size:13.5px;margin:0 0 18px}
.gate .picker{display:flex;flex-direction:column;gap:7px;text-align:left}
.gate .picker button{display:flex;align-items:center;gap:11px;border:1px solid var(--hair);background:var(--surface);border-radius:11px;padding:12px 14px;font-family:var(--mono);font-size:13.5px;font-weight:500;color:var(--ink);transition:border-color .15s,transform .1s}
.gate .picker button:hover{border-color:var(--teal);transform:translateX(2px)}
.gate .picker button .d{width:8px;height:8px;border-radius:50%;background:var(--teal)}
.gate .picker button .ar{margin-left:auto;color:var(--muted)}

/* note */
.note{display:flex;gap:11px;align-items:flex-start;background:linear-gradient(120deg,var(--teal-bg),#eef9fa);border:1px solid #bfeaef;border-radius:12px;padding:13px 15px}
.note svg{width:18px;height:18px;color:var(--teal-d);flex:none;margin-top:1px}
.note p{margin:0;font-size:12.5px;color:#0d5e66;line-height:1.5}
.note b{font-weight:600}

/* save bar */
.savebar{position:sticky;bottom:14px;margin-top:18px;display:flex;align-items:center;gap:12px;background:var(--rail);color:#fff;border-radius:14px;padding:12px 16px;box-shadow:var(--shadow-lg);z-index:20}
.savebar .txt{font-size:13px;color:#cdd9e3}.savebar .txt b{color:#fff}
.savebar .sp{flex:1}

/* toast */
.toast-wrap{position:fixed;bottom:20px;right:20px;z-index:200;display:flex;flex-direction:column;gap:8px}
.toast{display:flex;align-items:center;gap:10px;background:var(--rail);color:#fff;padding:12px 16px;border-radius:12px;box-shadow:var(--shadow-lg);font-size:13.5px;font-weight:500;animation:tin .25s ease}
.toast .i{width:22px;height:22px;border-radius:50%;display:grid;place-items:center;flex:none;background:var(--teal)}
.toast .i svg{width:13px;height:13px;color:#fff}
@keyframes tin{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:none}}

/* bottom nav (mobile) */
.botnav{display:flex;position:fixed;bottom:18px;left:50%;transform:translateX(-50%);z-index:40;background:var(--rail);border:1px solid rgba(255,255,255,.09);border-radius:18px;padding:7px 8px;gap:3px;box-shadow:0 10px 34px rgba(12,26,38,.34)}
.botnav a{display:flex;align-items:center;gap:8px;color:#aebfcd;font-size:13px;font-weight:550;padding:9px 15px;border-radius:12px}
.botnav a svg{width:19px;height:19px;opacity:.9}
.botnav a:hover{background:rgba(255,255,255,.06);color:#fff}

/* top section nav — lives inline inside the sticky topbar (body.nav-top) */
.topnav{display:flex;align-items:center;gap:2px;min-width:0}
.topnav a{display:flex;align-items:center;gap:7px;color:var(--muted);font-size:13px;font-weight:600;padding:7px 12px;border-radius:9px;text-decoration:none;white-space:nowrap}
.topnav a svg{width:17px;height:17px;opacity:.8}
.topnav a:hover{background:var(--surface-2);color:var(--ink)}
.topnav a.active{background:rgba(6,182,199,.12);color:var(--teal-d)}
.topnav a.active svg{opacity:1;color:var(--teal-d)}
/* dark variant — matches the bottom bar's color */
.nav-dark .topnav{background:var(--rail);border:1px solid rgba(255,255,255,.09);border-radius:13px;padding:4px 5px}
.nav-dark .topnav a{color:#aebfcd}
.nav-dark .topnav a svg{opacity:.9}
.nav-dark .topnav a:hover{background:rgba(255,255,255,.06);color:#fff}
.nav-dark .topnav a.active{background:rgba(6,182,199,.20);color:#fff}
.nav-dark .topnav a.active svg{color:var(--teal-l);opacity:1}
/* full dark header (navtop=3) — recolor the entire topbar, logo area included */
.nav-fullhead .topbar{background:var(--rail);border-bottom-color:rgba(255,255,255,.08);backdrop-filter:none}
.nav-fullhead .site-sel{background:rgba(255,255,255,.06);border-color:rgba(255,255,255,.12);box-shadow:none}
.nav-fullhead .site-sel .lbl{color:#8fa3b3}
.nav-fullhead .site-sel .val{color:#fff}
.nav-fullhead .site-sel .chev{color:#9fb2c2}
.nav-fullhead .chip{background:rgba(255,255,255,.06);border-color:rgba(255,255,255,.12);box-shadow:none}
.nav-fullhead .chip .k{color:#8fa3b3}
.nav-fullhead .chip .v{color:#e7eef3}
.nav-fullhead .tbtn{background:rgba(255,255,255,.06);border-color:rgba(255,255,255,.12);box-shadow:none;color:#cdd9e3}
.nav-fullhead .tbtn:hover{background:rgba(255,255,255,.10);color:#fff}
.nav-fullhead .acct img{border-color:rgba(255,255,255,.14)}
.nav-fullhead .topnav a{color:#aebfcd}
.nav-fullhead .topnav a svg{opacity:.9}
.nav-fullhead .topnav a:hover{background:rgba(255,255,255,.07);color:#fff}
.nav-fullhead .topnav a.active{background:rgba(6,182,199,.20);color:#fff}
.nav-fullhead .topnav a.active svg{color:var(--teal-l);opacity:1}
/* top nav on: hide the bottom pill + drop the content's bottom reserve on desktop;
   on phones the top nav won't fit the bar, so hide it and bring the bottom pill back */
.nav-top .botnav{display:none}
.nav-top .content{padding-bottom:40px}
@media(max-width:900px){
  .nav-top .topnav{display:none}
  .nav-top .botnav{display:flex}
  .nav-top .content{padding-bottom:92px}
}
.botnav a.active{background:linear-gradient(90deg,rgba(6,182,199,.24),rgba(6,182,199,.06));color:#fff}
.botnav a.active svg{color:var(--teal-l);opacity:1}

/* ---------- AUTH ---------- */
.auth{display:grid;grid-template-columns:1.05fr 1fr;min-height:100vh}
.auth-brand{background:radial-gradient(120% 120% at 0% 0%,#16384a 0%,#0c1a26 55%);color:#fff;padding:48px 56px;display:flex;flex-direction:column;position:relative;overflow:hidden}
.auth-brand::before{content:"";position:absolute;inset:0;background-image:radial-gradient(circle at 1px 1px,rgba(255,255,255,.06) 1px,transparent 0);background-size:26px 26px;opacity:.5}
.auth-brand .b-logo{display:flex;align-items:center;gap:11px;position:relative}
.auth-brand .b-logo .logo{width:34px;height:34px}
.auth-brand .b-logo .logo-txt{font-size:20px}
.auth-brand .b-mid{margin:auto 0;position:relative}
.auth-brand .b-tag{font-size:11px;font-weight:600;letter-spacing:.14em;text-transform:uppercase;color:var(--teal-l);margin-bottom:14px}
.auth-brand h2{font-family:var(--disp);font-size:34px;font-weight:600;letter-spacing:-.025em;line-height:1.12;margin:0 0 16px;max-width:15ch}
.auth-brand p.lead{color:#a9c2cf;font-size:14.5px;line-height:1.6;max-width:42ch;margin:0}
.auth-stats{display:flex;gap:30px;margin-top:34px;position:relative}
.auth-stats .s .n{font-family:var(--disp);font-weight:700;font-size:24px;color:#fff}
.auth-stats .s .n .u{color:var(--teal-l);font-size:16px}
.auth-stats .s .l{font-size:11.5px;color:#8ea8b6;margin-top:2px}
.auth-brand .b-foot{position:relative;color:#7d96a8;font-size:11.5px;display:flex;gap:16px}
.auth-brand .b-foot a:hover{color:#cdd9e3}
.auth-form-wrap{display:flex;align-items:center;justify-content:center;padding:40px 24px;background:var(--surface)}
.auth-card{width:100%;max-width:384px}
.auth-card .ac-h{margin-bottom:24px}
.auth-card .ac-h .eyebrow{font-size:12px;color:var(--teal-d);font-weight:600;margin-bottom:5px}
.auth-card h1{font-size:25px;margin:0 0 6px;letter-spacing:-.02em}
.auth-card .ac-h p{color:var(--muted);font-size:13.5px;margin:0}
.auth-extra{display:flex;align-items:center;justify-content:space-between;margin:-2px 0 18px;font-size:13px}
.check{display:flex;align-items:center;gap:8px;color:var(--ink-2);cursor:pointer;user-select:none}
.check input{display:none}
.check .box{width:18px;height:18px;border-radius:5px;border:1.5px solid var(--hair);display:grid;place-items:center;color:transparent;transition:.15s}
.check input:checked+.box{background:var(--teal);border-color:var(--teal);color:#fff}
.check .box svg{width:12px;height:12px}
.link{color:var(--teal-d);font-weight:600}
.auth-alt{text-align:center;margin-top:22px;color:var(--muted);font-size:13.5px}
.pw-wrap{position:relative}
.pw-wrap .eye{position:absolute;right:11px;top:50%;transform:translateY(-50%);color:var(--muted);width:20px;height:20px}
.strength{height:5px;border-radius:5px;background:var(--hair-2);margin-top:9px;overflow:hidden}
.strength i{display:block;height:100%;width:0;border-radius:5px;transition:width .25s,background .25s}
.strength-l{font-size:11.5px;color:var(--muted);margin-top:5px}
.divider{display:flex;align-items:center;gap:12px;color:var(--muted);font-size:12px;margin:18px 0}
.divider::before,.divider::after{content:"";height:1px;background:var(--hair);flex:1}
.logout-screen{min-height:100vh;display:grid;place-items:center;padding:24px;background:radial-gradient(120% 120% at 50% 0%,#16384a,#0c1a26)}
.logout-box{background:var(--surface);border-radius:18px;padding:40px 36px;max-width:380px;width:100%;text-align:center;box-shadow:var(--shadow-lg)}
.logout-box .lo-ic{width:60px;height:60px;border-radius:18px;background:var(--teal-bg);color:var(--teal-d);display:grid;place-items:center;margin:0 auto 18px}
.logout-box .lo-ic svg{width:28px;height:28px}
.logout-box h1{font-size:22px;margin:0 0 7px}
.logout-box p{color:var(--muted);font-size:13.5px;margin:0 0 22px}

/* ---------- responsive ---------- */
@media(max-width:1080px){
  .chartwrap{grid-template-columns:1fr}
  .legend{border-left:0;border-top:1px solid var(--hair);padding:14px 4px 4px;display:grid;grid-template-columns:repeat(2,1fr);gap:2px}
  .legend .lh{grid-column:1/-1}
}
@media(max-width:960px){
  .kpis{grid-template-columns:1fr 1fr}
  .two,.split,.set-grid,.row2{grid-template-columns:1fr}
  .topbar{padding:10px 14px;gap:10px}
  .brand .logo-txt{display:none}
  .brand-img{height:26px}
  .chips{display:none}
  .tbtn-opt{display:none}
  .botnav{bottom:0;left:0;right:0;transform:none;border-radius:0;border-left:0;border-right:0;border-bottom:0;padding:7px 6px calc(7px + env(safe-area-inset-bottom));gap:0;justify-content:space-around;box-shadow:0 -2px 16px rgba(12,26,38,.18)}
  .botnav a{flex-direction:column;gap:3px;font-size:10px;padding:4px 10px;border-radius:10px}
  .botnav a svg{width:21px;height:21px}
  .botnav a.active{background:none;color:var(--teal-l)}
  .content{padding:18px 15px 92px}
  .auth{grid-template-columns:1fr}
  .auth-brand{padding:30px 26px;min-height:auto}
  .auth-brand .b-mid{margin:18px 0}
  .auth-brand h2{font-size:25px}.auth-stats{display:none}.auth-brand .b-foot{display:none}
  .logtable-wrap{overflow-x:auto}
}
@media(max-width:560px){
  .kpis{grid-template-columns:1fr 1fr}
  .site-sel .lbl{display:none}
  .page-head h1{font-size:20px}
  .resp-tbl thead{display:none}
  .resp-tbl tr{display:grid;grid-template-columns:1fr auto;gap:4px 10px;padding:10px 4px;border-bottom:1px solid var(--hair-2)}
  .resp-tbl td{border:0;padding:2px 4px}
  .resp-tbl td[data-l]::before{content:attr(data-l);display:block;font-size:10px;text-transform:uppercase;letter-spacing:.05em;color:var(--muted);font-weight:600}
  .savebar{flex-wrap:wrap}
}
@media(prefers-reduced-motion:reduce){*{animation:none!important;transition:none!important}}

/* ===== scale UI (Your Sites at 1 → 2,100 sites) ===== */
.toolbar{display:flex;align-items:center;gap:10px;flex-wrap:wrap;margin-bottom:14px}
.sitesearch{flex:1;min-width:220px;display:flex;align-items:center;gap:9px;background:var(--surface);border:1px solid var(--hair);border-radius:11px;padding:9px 13px;box-shadow:var(--shadow)}
.sitesearch svg{width:17px;height:17px;color:var(--muted);flex:none}
.sitesearch input{border:0;background:none;outline:none;flex:1;font-family:var(--mono);font-size:13.5px;color:var(--ink)}
.count-pill{font-family:var(--mono);font-size:12px;color:var(--muted);background:var(--surface-2);border:1px solid var(--hair);padding:6px 11px;border-radius:9px;white-space:nowrap}
.pager{display:flex;align-items:center;gap:4px;flex-wrap:wrap}
.pager a,.pager span{min-width:34px;height:34px;padding:0 9px;display:inline-flex;align-items:center;justify-content:center;border:1px solid var(--hair);border-radius:9px;background:var(--surface);font-size:13px;font-weight:550;color:var(--ink-2);font-family:var(--mono)}
.pager a:hover{border-color:var(--teal);color:var(--teal-d)}
.pager .on{background:var(--rail);color:#fff;border-color:var(--rail)}
.pager .gap{border:0;background:none;color:var(--muted)}
.pager .nav-a svg{width:15px;height:15px}
.empty{text-align:center;padding:46px 20px;color:var(--muted)}
.empty .ic{width:48px;height:48px;border-radius:13px;background:var(--surface-2);display:grid;place-items:center;margin:0 auto 12px;color:var(--muted)}
.empty .ic svg{width:24px;height:24px}
.site-menu .search-in{display:flex;align-items:center;gap:8px;padding:8px 10px;border-bottom:1px solid var(--hair);margin-bottom:4px}
.site-menu .search-in svg{width:15px;height:15px;color:var(--muted)}
.site-menu .search-in input{border:0;outline:none;background:none;flex:1;font-family:var(--mono);font-size:13px}
.site-menu .results{max-height:300px;overflow:auto}
.site-menu .more{font-size:11.5px;color:var(--muted);text-align:center;padding:8px;font-family:var(--mono)}
.row-act{display:flex;gap:7px;justify-content:flex-end}
.row-act .btn{padding:5px 11px;font-size:12px;border-radius:8px}
.dot-on{width:8px;height:8px;border-radius:50%;background:var(--teal);flex:none}
.dot-off{width:8px;height:8px;border-radius:50%;background:var(--hair);flex:none}

/* ===== Overview (cdn-dashboard) ===== */
.kpi-ic{width:36px;height:36px;border-radius:10px;display:grid;place-items:center;margin-bottom:11px}
.kpi-ic svg{width:18px;height:18px}
.kpi-ic.teal{background:#d3f1f5;color:var(--teal-d)}
.kpi-ic.red{background:#fde6e6;color:var(--red)}
.kpi-ic.amber{background:#fbe6cc;color:var(--amber)}
.kpi-ic.soft{background:var(--surface-2);color:var(--muted)}
.kpi-v{font-family:var(--disp);font-weight:700;font-size:29px;letter-spacing:-.02em;line-height:1;color:var(--ink)}
.kpi-v.mono{font-family:var(--mono);font-size:24px}
.kpi-l{font-size:12.5px;color:var(--muted);margin-top:6px;font-weight:500}
.seg a{padding:6px 11px;border-radius:7px;font-size:12px;font-weight:550;color:var(--muted);white-space:nowrap}
.seg a.on{background:var(--surface);color:var(--ink);box-shadow:var(--shadow)}
.seg a:hover{color:var(--ink)}
.chart-wrap{padding:6px 2px 2px}
.ranklegend{display:grid;grid-template-columns:repeat(2,1fr);gap:2px 16px;margin-top:16px;border-top:1px solid var(--hair);padding-top:14px}
.leg-row{display:flex;align-items:center;gap:10px;padding:6px 8px;border-radius:8px}
.leg-row:hover{background:var(--surface-2)}
.leg-rank{width:19px;height:19px;border-radius:5px;background:var(--surface-2);border:1px solid var(--hair);font-size:11px;font-weight:600;display:grid;place-items:center;color:var(--muted);flex:none}
.leg-dom{flex:1;font-size:12.5px;color:var(--ink-2);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.leg-val{font-size:12px;color:var(--muted)}
.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.threat-grid{display:grid;grid-template-columns:215px 1fr;gap:28px;align-items:center}
.threat-hero{display:block;text-align:center;padding:6px 16px 6px 4px;border-right:1px solid var(--hair)}
.threat-num{font-family:var(--disp);font-weight:700;font-size:32px;color:var(--red);line-height:1.05;white-space:nowrap}
.threat-cap{font-size:12px;color:var(--muted);margin-top:8px}
.threat-bars{display:flex;flex-direction:column;gap:10px;min-width:0}
.bar-row{display:grid;grid-template-columns:44px 116px 1fr 64px;align-items:center;gap:10px;font-size:12.5px}
.bar-code{font-weight:600;color:var(--ink-2)}
.bar-code.bad{color:var(--red)}
.bar-name{color:var(--muted);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.bar-track{height:7px;background:var(--surface-2);border-radius:5px;overflow:hidden}
.bar-track.sm{display:inline-block;width:74px;vertical-align:middle;margin-right:7px}
.bar-fill{display:block;height:100%;background:var(--teal);border-radius:5px}
.bar-fill.bad{background:var(--red)}
.bar-val{text-align:right;color:var(--ink-2);font-weight:550}
.rbar{display:flex;flex-direction:column;gap:11px;min-width:0}
.rbar-row{display:grid;grid-template-columns:minmax(120px,40%) 1fr 70px;align-items:center;gap:12px;font-size:12.5px}
.rbar-name{color:var(--ink-2);font-weight:550;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.rbar-name .sub{color:var(--muted);font-weight:400;font-size:11px;font-family:var(--mono)}
.rbar-track{height:7px;background:var(--surface-2);border-radius:5px;overflow:hidden}
.rbar-fill{display:block;height:100%;border-radius:5px;background:var(--teal)}
.rbar-fill.bad{background:var(--red)}
.rbar-val{text-align:right;color:var(--ink-2);font-weight:600;font-family:var(--mono)}
@media(max-width:560px){.rbar-row{grid-template-columns:1fr 64px}.rbar-track{display:none}}
.errlegend{display:flex;gap:14px;align-items:center}
.errkey{display:flex;align-items:center;gap:6px;font-size:12px;color:var(--muted);font-family:var(--mono)}
.ek{width:10px;height:10px;border-radius:3px;display:inline-block}
.ek.e4{background:var(--amber)}
.ek.e5{background:var(--red)}
.t-waf{font-size:11.5px;color:var(--amber);font-weight:600;font-family:var(--mono)}
.t-waf.block{color:var(--red)}
.t-waf-none{color:var(--muted)}
.tbl .tot td{border-top:2px solid var(--hair)}
.pct{color:var(--muted);font-size:11.5px}
@media(max-width:920px){
  .grid-2{grid-template-columns:1fr}
  .threat-grid{grid-template-columns:1fr;gap:16px}
  .threat-hero{border-right:0;border-bottom:1px solid var(--hair);padding-bottom:14px}
  .ranklegend{grid-template-columns:1fr}
  .bar-row{grid-template-columns:40px 1fr 56px;gap:8px}
  .bar-name{display:none}
  .seg{overflow-x:auto;max-width:100%}
}

/* ===== Legacy form reskin (cdn-settings + other Bootstrap-era pages) ===== */
.card-body{padding:20px 22px}
.card-title{font-family:var(--disp);font-weight:600;font-size:18px;color:var(--ink);margin:0 0 3px}
.card-subtitle{font-size:13px;color:var(--muted);margin:0 0 18px;line-height:1.5}
/* mini grid (replaces bootstrap cols since bootstrap is dropped) */
.row{display:flex;flex-wrap:wrap;margin:0 -12px}
.row > [class*="col-"]{padding:0 12px;min-width:0}
.col-12{flex:0 0 100%;max-width:100%}
.col-8{flex:0 0 66.6667%;max-width:66.6667%}
.col-6{flex:0 0 50%;max-width:50%}
.col-lg-3{flex:0 0 25%;max-width:25%}
.col-lg-9{flex:0 0 75%;max-width:75%}
.col-md-2{flex:0 0 18%;max-width:18%}
.col-md-3{flex:0 0 25%;max-width:25%}
.col-md-9{flex:0 0 75%;max-width:75%}
.col-md-12{flex:0 0 100%;max-width:100%}
.hidden-md{display:none}
@media(min-width:992px){.hidden-md{display:block}}
@media(max-width:900px){ .row > [class*="col-"]{flex:0 0 100%;max-width:100%} }
/* field rows */
.form-group{margin-bottom:18px}
.form-group.row{align-items:flex-start}
.col-form-label{font-size:13.5px;font-weight:550;color:var(--ink-2);padding-top:9px}
/* inputs */
.form-control{width:100%;font-family:var(--ui);font-size:14px;color:var(--ink);background:var(--surface);border:1px solid var(--hair);border-radius:10px;padding:9px 12px;outline:none;transition:border-color .12s,box-shadow .12s}
.form-control:focus{border-color:var(--teal);box-shadow:0 0 0 3px rgba(6,182,199,.14)}
textarea.form-control{min-height:84px;resize:vertical;font-family:var(--mono);font-size:13px}
select.form-control{appearance:none;-webkit-appearance:none;padding-right:36px;cursor:pointer;background-image:url("data:image/svg+xml;charset=utf8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='14' fill='none' stroke='%238a99a6' stroke-width='2'%3E%3Cpath d='M3 5l4 4 4-4'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center}
.input-sm{font-size:13px;padding:7px 11px}
/* checkbox rendered as a switch (keeps the real checkbox so it still POSTs) */
input.form-check-input[type=checkbox]{appearance:none;-webkit-appearance:none;width:42px;height:24px;border-radius:13px;background:var(--hair);position:relative;cursor:pointer;vertical-align:middle;transition:background .15s;flex:none;border:0;margin:0 10px 0 0}
input.form-check-input[type=checkbox]::after{content:"";position:absolute;top:3px;left:3px;width:18px;height:18px;border-radius:50%;background:#fff;transition:left .15s;box-shadow:0 1px 2px rgba(0,0,0,.25)}
input.form-check-input[type=checkbox]:checked{background:var(--teal)}
input.form-check-input[type=checkbox]:checked::after{left:21px}
.form-check-label{font-size:13.5px;color:var(--ink-2);vertical-align:middle}
.form-text,.text-muted{font-size:12px;color:var(--muted)}
.form-text{display:block;margin-top:5px;line-height:1.5}
.text-primary{color:var(--teal-d)}
/* buttons (extends new .btn) */
.btn-danger{background:var(--red);color:#fff;border-color:var(--red)}
.btn-danger:hover{filter:brightness(.94)}
.btn-secondary{background:var(--surface-2);color:var(--ink-2);border:1px solid var(--hair)}
.btn-light{background:var(--surface-2);color:var(--ink-2);border:1px solid var(--hair)}
.btn-sm{padding:6px 12px;font-size:12.5px}
.btn-block{display:flex;width:100%}
/* left settings sub-nav */
.setnav{display:flex;align-items:center;gap:10px;width:100%;justify-content:flex-start;text-align:left;padding:10px 13px;margin-bottom:6px;border:1px solid transparent;border-radius:10px;background:transparent;color:var(--ink-2);font-weight:550;font-size:13.5px}
.setnav:hover{background:var(--surface-2)}
.setnav .mdi{font-size:17px;color:var(--muted)}
.setnav-on{background:rgba(6,182,199,.10);color:var(--teal-d);border-color:rgba(6,182,199,.25)}
.setnav-on .mdi{color:var(--teal-d)}
/* alerts */
.alert{padding:12px 15px;border-radius:11px;font-size:13.5px;margin-bottom:16px;border:1px solid transparent}
.alert-danger{background:#fdeaea;border-color:#f6cccc;color:#a02525}
.alert-success{background:#e8f7ef;border-color:#bfe7cf;color:#1d7a44}
/* legacy table (picker) */
.table-responsive{overflow-x:auto}
.table{width:100%;border-collapse:collapse;font-size:13.5px}
.table th{text-align:left;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.04em;color:var(--muted);padding:0 14px 10px;border-bottom:1px solid var(--hair)}
.table td{padding:13px 14px;border-bottom:1px solid var(--hair);color:var(--ink-2);vertical-align:middle}
.table tr:last-child td{border-bottom:0}
.fa-circle::before{content:"●";font-style:normal}
/* spacing utilities still referenced in legacy markup */
.p-b-20{padding-bottom:20px}.m-t-20{margin-top:20px}.m-r-5{margin-right:5px}.m-r-10{margin-right:10px}.m-b-0{margin-bottom:0}

/* ===== Settings: horizontal sub-nav + fixes ===== */
.setsubnav{display:flex;gap:4px;background:var(--surface);border:1px solid var(--hair);border-radius:14px;padding:6px;box-shadow:var(--shadow);overflow-x:auto;margin-bottom:16px;-webkit-overflow-scrolling:touch}
.setsubnav::-webkit-scrollbar{height:0}
.subtab{display:inline-flex;align-items:center;gap:8px;white-space:nowrap;padding:9px 15px;border-radius:9px;font-weight:600;font-size:13.5px;color:var(--ink-2);flex:none}
.subtab .mdi{font-size:17px;color:var(--muted)}
.subtab:hover{background:var(--surface-2)}
.subtab-on{background:var(--rail);color:#fff}
.subtab-on .mdi{color:#bfe3e7}
/* field label width: fixed, comfortable, no awkward wrap in narrow cols */
.form-group.row > label.col-form-label{flex:0 0 200px;max-width:200px;line-height:1.35;padding-top:8px}
.form-group.row > div[class*="col-"]{flex:1 1 auto;max-width:none}
@media(max-width:900px){
  .form-group.row > label.col-form-label{flex:0 0 100%;max-width:100%;padding-top:0;margin-bottom:7px}
}
/* danger zone card */
.danger-card{border-color:#f3cccc;background:linear-gradient(0deg,#fffafa,var(--surface))}
.danger-card .card-title{color:#a02525}

/* ===== Settings redesign: unified card + side-nav + setting rows ===== */
.setcard{display:grid;grid-template-columns:236px 1fr;background:var(--surface);border:1px solid var(--hair);border-radius:16px;box-shadow:var(--shadow);overflow:hidden;min-height:520px;margin-top:4px}
.setside{border-right:1px solid var(--hair);padding:16px 12px;background:linear-gradient(180deg,#fbfdfe,var(--surface))}
.setside-h{font-size:11px;text-transform:uppercase;letter-spacing:.07em;color:var(--muted);font-weight:600;padding:6px 10px 10px}
.side-item{display:flex;align-items:center;gap:11px;padding:10px 11px;border-radius:10px;color:var(--ink-2);font-weight:550;font-size:13.5px;margin-bottom:2px;position:relative}
.side-item .mdi{font-size:18px;color:var(--muted);flex:none;width:20px;text-align:center}
.side-item:hover{background:var(--surface-2)}
.side-item.on{background:rgba(6,182,199,.10);color:var(--teal-d)}
.side-item.on .mdi{color:var(--teal-d)}
.side-item.on::before{content:"";position:absolute;left:0;top:8px;bottom:8px;width:3px;border-radius:3px;background:var(--teal)}
.setpane{padding:26px 30px;display:flex;flex-direction:column;min-width:0}
.pane-head h2{font-family:var(--disp);font-size:20px;font-weight:600}
.pane-head p{color:var(--muted);font-size:13.5px;margin-top:4px;line-height:1.5}
.pane-body{flex:1;margin-top:6px}
.srow{display:flex;align-items:flex-start;justify-content:space-between;gap:28px;padding:19px 0;border-bottom:1px solid var(--hair)}
.srow:last-child{border-bottom:0}
.srow-info{max-width:560px;min-width:0}
.srow-title{font-weight:600;font-size:14.5px;display:flex;align-items:center;gap:8px}
.srow-desc{font-size:13px;color:var(--muted);margin-top:4px;line-height:1.55}
.srow-control{flex:none;padding-top:2px}
.srow.stack{flex-direction:column;align-items:stretch;gap:11px}
.srow.stack .srow-control{width:100%;padding-top:0}
.tagbeta{font-size:10px;font-weight:700;letter-spacing:.04em;color:#8a5b00;background:#ffedcc;padding:2px 7px;border-radius:20px}
/* switch wrapping a real checkbox (posts normally) */
.switch{position:relative;display:inline-block;width:46px;height:27px;flex:none}
.switch input{opacity:0;width:0;height:0;position:absolute}
.switch .slider{position:absolute;inset:0;background:#d4dbe1;border-radius:14px;transition:.18s;cursor:pointer}
.switch .slider::before{content:"";position:absolute;height:21px;width:21px;left:3px;top:3px;background:#fff;border-radius:50%;transition:.18s;box-shadow:0 1px 3px rgba(0,0,0,.28)}
.switch input:checked + .slider{background:var(--teal)}
.switch input:checked + .slider::before{transform:translateX(19px)}
/* setting inputs */
.srow .inp,.srow textarea{width:100%;font-family:var(--mono);font-size:13px;color:var(--ink);background:var(--surface);border:1px solid var(--hair);border-radius:10px;padding:10px 13px;outline:none;transition:border-color .12s,box-shadow .12s}
.srow .inp:focus,.srow textarea:focus{border-color:var(--teal);box-shadow:0 0 0 3px rgba(6,182,199,.14)}
.srow textarea{min-height:74px;resize:vertical}
.srow select.inp{appearance:none;-webkit-appearance:none;cursor:pointer;min-width:240px;background-image:url("data:image/svg+xml;charset=utf8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='14' fill='none' stroke='%237d8d99' stroke-width='2'%3E%3Cpath d='M3 5l4 4 4-4'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;padding-right:36px}
.srow .kv{font-family:var(--mono);font-size:13px;color:var(--ink-2)}
.pane-foot{display:flex;align-items:center;justify-content:space-between;gap:14px;border-top:1px solid var(--hair);margin-top:6px;padding-top:20px;flex-wrap:wrap}
.foot-note{font-size:12.5px;color:var(--muted)}
.setpane .danger{margin-top:18px;border:1px solid #f1cccc;background:linear-gradient(0deg,#fff9f9,var(--surface));border-radius:14px;padding:18px 20px;display:flex;align-items:center;justify-content:space-between;gap:20px;flex-wrap:wrap}
.setpane .danger h4{color:#b02a2a;font-size:15px}.setpane .danger p{color:var(--muted);font-size:13px;margin-top:3px}
/* settings mobile: side-nav becomes scroll strip */
.side-mobile{display:none}
@media(max-width:860px){
  .setcard{grid-template-columns:1fr;border:0;box-shadow:none;background:none}
  .setside{display:none}
  .setpane{padding:0}
  .setpane .pane-head,.setpane .pane-body,.setpane .pane-foot{background:var(--surface);border:1px solid var(--hair);padding-left:18px;padding-right:18px}
  .setpane .pane-head{border-radius:14px 14px 0 0;padding-top:18px}
  .setpane .pane-body{border-top:0;border-bottom:0;padding-top:2px}
  .setpane .pane-foot{border-radius:0 0 14px 14px;padding-bottom:18px}
  .side-mobile{display:flex;gap:6px;overflow-x:auto;padding:6px;background:var(--surface);border:1px solid var(--hair);border-radius:12px;box-shadow:var(--shadow);margin-bottom:14px}
  .side-mobile::-webkit-scrollbar{height:0}
  .side-mobile a{white-space:nowrap;padding:9px 14px;border-radius:9px;font-weight:600;font-size:13px;color:var(--ink-2);flex:none}
  .side-mobile a.on{background:var(--rail);color:#fff}
  .srow{flex-direction:column;align-items:stretch;gap:12px}
  .srow select.inp{width:100%}
}

/* ===== Logs page ===== */
.logbar{display:flex;gap:12px;flex-wrap:wrap;align-items:flex-end;margin-bottom:16px}
.logbar-seg{display:flex;flex-direction:column;gap:5px}
.logbar-l{font-size:11px;text-transform:uppercase;letter-spacing:.05em;color:var(--muted);font-weight:600}
.logbar .inp{font-family:var(--ui);font-size:13.5px;color:var(--ink);background:var(--surface);border:1px solid var(--hair);border-radius:10px;padding:9px 12px;outline:none}
.logbar select.inp{appearance:none;-webkit-appearance:none;cursor:pointer;padding-right:34px;background-image:url("data:image/svg+xml;charset=utf8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='14' fill='none' stroke='%237d8d99' stroke-width='2'%3E%3Cpath d='M3 5l4 4 4-4'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center}
.logbar .inp:focus{border-color:var(--teal);box-shadow:0 0 0 3px rgba(6,182,199,.14)}
.logbar-search{margin-left:auto;display:flex;align-items:flex-end;gap:8px}
.logbar-search .inp{min-width:240px}
.logsum{display:grid;grid-template-columns:1.7fr 1fr;gap:16px;margin-bottom:16px}
.logsum-head{display:flex;align-items:baseline;justify-content:space-between;gap:12px;margin-bottom:8px}
.logsum-head .card-title{margin:0}
.logchart{width:100%;height:150px;display:block}
.reglist{display:flex;flex-direction:column;gap:11px;margin-top:6px}
.regrow{display:flex;align-items:center;gap:10px;font-size:13px}
.regrank{font-family:var(--mono);font-size:11px;color:var(--muted);width:22px}
.regname{font-weight:550;min-width:64px}
.regbar{flex:1 1 0;min-width:0;height:7px;border-radius:4px;background:var(--surface-2);overflow:hidden}
.regbar span{display:block;height:100%;background:var(--teal);border-radius:4px}
.regname.uname{min-width:90px;max-width:300px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;cursor:pointer}
.regname.uname:hover{color:var(--teal-d)}
.regname.uname.is-open{overflow:visible;white-space:normal;word-break:break-all;text-overflow:clip}
.regpct{display:block;color:var(--muted);font-size:11px;font-weight:400}
.region-charts{display:grid;grid-template-columns:repeat(2,1fr);gap:20px}
.region-chart-h{font-size:12.5px;font-weight:600;color:var(--ink-2);margin-bottom:6px}
@media(max-width:680px){.region-charts{grid-template-columns:1fr}}
.mc-wrap{position:relative}
.mc-svg{width:100%;height:300px;display:block}
.mc-tip{position:absolute;top:8px;right:8px;background:var(--surface);border:1px solid var(--hair);border-radius:9px;box-shadow:var(--shadow);padding:8px 10px;font-size:11.5px;pointer-events:none;display:none;min-width:130px;z-index:5}
.mc-tip-t{font-family:var(--mono);color:var(--muted);font-size:10.5px;margin-bottom:5px}
.mc-tip-r{display:flex;align-items:center;gap:6px;color:var(--ink-2);white-space:nowrap;line-height:1.7}
.mc-tip-r b{margin-left:auto;font-family:var(--mono);color:var(--ink);padding-left:10px}
.mc-dot{width:8px;height:8px;border-radius:50%;flex:none;display:inline-block}
.mc-legend{display:flex;flex-wrap:wrap;gap:9px 16px;margin-top:13px;padding-top:13px;border-top:1px solid var(--hair)}
.mc-leg{display:flex;align-items:center;gap:6px;font-size:12px;color:var(--ink-2)}
.mc-leg .mc-dot{width:9px;height:9px;border-radius:2px}
.mon-strip{padding:11px 0;border-bottom:1px solid var(--hair)}
.mon-strip:first-child{padding-top:2px}
.mon-strip:last-child{border-bottom:0;padding-bottom:2px}
.mon-strip-h{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:7px}
.mon-strip-h .mon-name{display:flex;align-items:center;gap:8px;min-width:0;color:var(--ink);font-weight:600;text-decoration:none}
.mon-strip-h .mon-name b{font-size:13.5px;font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.mon-strip-h .mon-name:hover b{color:var(--teal-d)}
.mon-strip-h .sdot{width:9px;height:9px;border-radius:50%;flex:none;background:var(--muted)}
.mon-strip-h .sdot.up{background:var(--green)} .mon-strip-h .sdot.warn{background:var(--amber)} .mon-strip-h .sdot.down{background:var(--red)}
.mon-strip-pct{font-family:var(--mono);font-size:12.5px;font-weight:600;flex:none}
.mon-strip-pct.ok{color:var(--green)} .mon-strip-pct.warn{color:var(--amber)} .mon-strip-pct.bad{color:var(--red)} .mon-strip-pct.na{color:var(--muted)}
.upbars{display:flex;gap:2px;align-items:stretch;height:18px}
.upbars .u{flex:1 1 0;min-width:0;border-radius:2px;background:var(--hair);transition:opacity .1s}
.upbars .u:hover{opacity:.6}
.upbars .u.ok{background:var(--green)} .upbars .u.warn{background:var(--amber)} .upbars .u.bad{background:var(--red)} .upbars .u.na{background:var(--hair)}
.noc-tip{position:fixed;z-index:9999;background:var(--rail);color:#fff;font-size:11.5px;font-family:var(--mono);padding:5px 9px;border-radius:7px;pointer-events:none;display:none;white-space:nowrap;box-shadow:0 6px 22px rgba(0,0,0,.22)}
.attn{background:var(--surface);border:1px solid var(--hair);border-left:3px solid var(--red);border-radius:13px;padding:14px 16px 12px;margin-bottom:16px;box-shadow:var(--shadow)}
.attn-h{font-weight:600;font-size:14px;color:var(--red);display:flex;align-items:center;gap:8px}
.attn-h svg{width:18px;height:18px;flex:none}
.attn-row{display:flex;align-items:center;gap:11px;padding:10px 12px;border-radius:9px;background:var(--surface-2);text-decoration:none;color:var(--ink);margin-top:9px}
.attn-row:hover{background:var(--hair)}
.attn-dot{width:9px;height:9px;border-radius:50%;flex:none}
.attn-dot.down{background:var(--red)} .attn-dot.warn{background:var(--amber)}
.attn-name{font-weight:600;font-size:13.5px;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.attn-badge{font-size:10px;text-transform:uppercase;letter-spacing:.04em;font-weight:700;padding:2px 8px;border-radius:20px;flex:none;color:#fff}
.attn-badge.down{background:var(--red)} .attn-badge.warn{background:var(--amber)}
.attn-meta{margin-left:auto;font-family:var(--mono);font-size:12px;color:var(--muted);flex:none}
.attn-row .chev{width:16px;height:16px;color:var(--muted);flex:none}
@media(max-width:560px){.attn-meta{display:none}}
.logstatus{border:1px solid var(--hair);border-radius:13px;padding:14px 16px 12px;margin-bottom:16px;box-shadow:var(--shadow);background:var(--surface)}
.logstatus.bad{border-left:3px solid var(--red)} .logstatus.warn{border-left:3px solid var(--amber)} .logstatus.ok{border-left:3px solid var(--green)}
.logstatus-h{font-weight:600;font-size:14px;display:flex;align-items:center;gap:8px}
.logstatus.bad .logstatus-h{color:var(--red)} .logstatus.warn .logstatus-h{color:var(--amber)} .logstatus.ok .logstatus-h{color:var(--green)}
.logstatus-h svg{width:18px;height:18px;flex:none}
.logstatus-row{display:flex;align-items:center;gap:10px;padding:8px 11px;border-radius:9px;background:var(--surface-2);text-decoration:none;color:var(--ink);margin-top:8px}
.logstatus-row:hover{background:var(--hair)}
.ls-dot{width:9px;height:9px;border-radius:50%;flex:none}
.ls-dot.down{background:var(--red)} .ls-dot.warn{background:var(--amber)}
.ls-name{font-weight:600;font-size:13.5px;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.ls-tag{margin-left:auto;font-size:11px;font-weight:600;flex:none}
.ls-tag.down{color:var(--red)} .ls-tag.warn{color:var(--amber)}
.inc-card{border:1px solid var(--hair);border-radius:12px;padding:13px 15px;margin-top:11px}
.inc-card:first-of-type{margin-top:4px}
.inc-top{display:flex;align-items:center;gap:10px;margin-bottom:7px}
.inc-badge{font-size:10px;text-transform:uppercase;letter-spacing:.04em;font-weight:700;padding:2px 8px;border-radius:20px;flex:none;color:#fff}
.inc-badge.down{background:var(--red)} .inc-badge.warn{background:var(--amber)}
.inc-name{font-weight:600;font-size:13.5px;color:var(--ink);text-decoration:none;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.inc-name:hover{color:var(--teal-d)}
.inc-when{margin-left:auto;font-family:var(--mono);font-size:11.5px;color:var(--muted);flex:none}
.inc-summary{font-size:13px;color:var(--ink-2);margin-bottom:8px}
.inc-checks{display:flex;flex-wrap:wrap;gap:6px}
.inc-chk{font-size:11.5px;color:var(--muted);background:var(--surface-2);border-radius:6px;padding:3px 8px}
.inc-more{font-size:11.5px;color:var(--muted);padding:3px 4px;font-style:italic}
.regval{flex:none;white-space:nowrap;font-family:var(--mono);font-size:12px;color:var(--ink-2);text-align:right;padding-left:8px}
.regrow.is-extra{display:none}
.reglist.show-extra .regrow.is-extra{display:flex}
.reg-more{align-self:flex-start;margin-top:2px;background:transparent;border:0;color:var(--teal-d);font:600 12px/1 var(--ui);cursor:pointer;padding:6px 2px}
.reg-more:hover{text-decoration:underline}
.logtbl-card .card-body{padding:0}
.logtbl-head{display:flex;align-items:center;justify-content:space-between;gap:14px;padding:18px 22px;border-bottom:1px solid var(--hair)}
.logtbl-head .card-title{margin:0}.logtbl-head .card-subtitle{margin:2px 0 0}
.logtable-wrap{overflow-x:auto}
.logtbl{width:100%;border-collapse:collapse;font-size:13px}
.logtbl thead th{text-align:left;font-size:10.5px;text-transform:uppercase;letter-spacing:.04em;color:var(--muted);font-weight:600;padding:11px 14px;border-bottom:1px solid var(--hair);background:var(--surface-2);position:sticky;top:0}
.logtbl td{padding:11px 14px;border-bottom:1px solid var(--hair);vertical-align:top;color:var(--ink-2)}
.logtbl tr:hover td{background:#fafcfd}
.logtbl .t-time{font-family:var(--mono);font-size:12px;white-space:nowrap}
.logtbl .t-time span{display:block;color:var(--muted)}
.logtbl .t-ip{font-family:var(--mono);font-size:12px;white-space:nowrap}
.logtbl .t-code{font-family:var(--mono);font-size:11px;color:var(--muted)}
.logtbl .t-cache{font-family:var(--mono);font-size:11px;color:var(--ink-2);background:var(--surface-2);padding:2px 7px;border-radius:6px}
.logtbl .t-req{font-family:var(--mono);font-size:12px;word-break:break-all;max-width:430px}
.logtbl .t-meth{font-weight:700;color:var(--ink)}
.logtbl .t-ua{display:block;color:var(--muted);font-size:11px;margin-top:2px;font-family:var(--ui)}
.badge-ok{display:inline-block;font-size:11px;font-weight:600;color:var(--green);background:var(--green-bg);padding:2px 9px;border-radius:20px;white-space:nowrap}
.badge-block{display:inline-block;font-size:11px;font-weight:600;color:#b23034;background:var(--red-bg);padding:2px 9px;border-radius:20px;white-space:nowrap}
.pager{display:flex;align-items:center;gap:10px}
.pgbtn{font-size:12.5px;font-weight:600;color:var(--ink-2);border:1px solid var(--hair);border-radius:9px;padding:6px 13px}
.pgbtn:hover{border-color:var(--teal);color:var(--teal-d)}
.pgbtn.disabled{color:var(--muted);opacity:.5;pointer-events:none}
.pgnow{font-family:var(--mono);font-size:12.5px;color:var(--muted)}
@media(max-width:860px){.logsum{grid-template-columns:1fr}.logbar-search{margin-left:0;width:100%}.logbar-search .inp{flex:1;min-width:0}}

/* ===== Custom Rules page ===== */
.rule-type{display:inline-block;font-size:11px;font-weight:600;color:var(--teal-d);background:rgba(6,182,199,.10);padding:2px 10px;border-radius:20px;white-space:nowrap}
.rulesform{margin-top:8px}
.rulesform .srow code{font-family:var(--mono);font-size:11.5px;background:var(--surface-2);padding:1px 5px;border-radius:5px;color:var(--ink-2)}

/* ===== API docs page ===== */
.apiwrap{display:grid;grid-template-columns:250px minmax(0,1fr);gap:22px;align-items:start}
.apinav{position:sticky;top:14px}
.apimain{min-width:0}
.apinav-card{background:var(--surface);border:1px solid var(--hair);border-radius:16px;padding:12px 10px;max-height:calc(100vh - 30px);overflow:auto}
.apinav-title{font-family:var(--display);font-weight:600;font-size:14px;color:var(--ink);padding:6px 8px 10px}
.apinav-h{display:flex;align-items:center;gap:7px;font-size:10.5px;text-transform:uppercase;letter-spacing:.05em;color:var(--muted);font-weight:600;padding:14px 8px 5px}
.apinav-h .mdi{font-size:14px;color:var(--teal-d)}
.apinav-item{display:block;font-family:var(--mono);font-size:12px;color:var(--ink-2);padding:5px 8px 5px 18px;border-radius:7px;text-decoration:none;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.apinav-item:hover{background:var(--surface-2);color:var(--teal-d)}
.apinav-help{font-size:11.5px;color:var(--muted);padding:14px 8px 4px;border-top:1px solid var(--hair);margin-top:10px}
.apinav-help a{color:var(--teal-d)}
.apikey-card{background:var(--surface);border:1px solid var(--hair);border-radius:16px;padding:22px;margin-bottom:18px}
.apikey-intro h2{font-family:var(--display);font-weight:600;font-size:18px;color:var(--ink);margin:0 0 6px}
.apikey-intro p{font-size:13.5px;color:var(--muted);margin:0 0 16px;max-width:680px}
.apikey-intro code{font-family:var(--mono);font-size:12px;background:var(--surface-2);padding:1px 6px;border-radius:5px;color:var(--ink-2)}
.apikey-box{background:var(--surface-2);border:1px solid var(--hair);border-radius:12px;padding:14px 16px}
.apikey-label{display:block;font-size:11px;text-transform:uppercase;letter-spacing:.05em;color:var(--muted);font-weight:600;margin-bottom:7px}
.apikey-row{display:flex;align-items:center;gap:12px}
.apikey-row code{flex:1;font-family:var(--mono);font-size:14px;color:var(--ink);letter-spacing:.02em;word-break:break-all}
.apikey-none{font-size:13px;color:var(--muted)}
.apidoc{background:var(--surface);border:1px solid var(--hair);border-radius:16px;padding:6px 26px 26px}
.apidoc>p{margin:0}
.apidoc h4{font-family:var(--mono);font-weight:600;font-size:15px;color:var(--ink);margin:0 0 6px;padding-top:22px;scroll-margin-top:14px}
.apidoc h4::before{content:"";display:block;border-top:1px solid var(--hair);margin:0 -26px 22px}
.apidoc>p:first-child h4,.apidoc p:first-of-type h4{}
.apidoc h4+p{font-size:13.5px;color:var(--ink-2);margin:0 0 10px;max-width:760px}
.apidoc small{font-size:12.5px;color:var(--muted);line-height:1.9}
.apidoc small b{color:var(--ink-2);font-weight:600}
.apidoc blockquote{position:relative;font-family:var(--mono);font-size:12px;color:#cfe9ec;background:var(--rail);border:0;border-radius:10px;padding:13px 70px 13px 15px;margin:9px 0 4px;word-break:break-all;line-height:1.7;overflow-wrap:anywhere}
.apidoc hr{display:none}
.api-copy{position:absolute;top:9px;right:9px;font-family:var(--ui);font-size:11px;font-weight:600;color:#bfeef2;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.16);border-radius:7px;padding:3px 10px;cursor:pointer}
.api-copy:hover{background:rgba(255,255,255,.16)}
@media(max-width:900px){.apiwrap{grid-template-columns:1fr}.apinav{position:static}.apinav-card{max-height:none}}

/* ===== DNS section ===== */
.head-cta{display:inline-flex;align-items:center;gap:6px;font-family:var(--ui);font-size:13px;font-weight:600;color:#fff;background:var(--teal);border-radius:10px;padding:9px 16px;text-decoration:none;white-space:nowrap}
.head-cta:hover{background:var(--teal-d);color:#fff}
.head-cta .mdi{font-size:16px}
.dns-addsel{max-width:200px;cursor:pointer;appearance:none;-webkit-appearance:none;padding-right:34px;background-image:url("data:image/svg+xml;charset=utf8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='14' fill='none' stroke='%237d8d99' stroke-width='2'%3E%3Cpath d='M3 5l4 4 4-4'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center}
.dns-table{table-layout:fixed}
.dns-table td{vertical-align:middle;word-break:break-word}
.dns-table td a{color:var(--ink)}
.dns-table td a:hover{color:var(--teal-d)}
.dns-table td b{font-family:var(--mono);font-weight:600;font-size:12.5px;color:var(--ink)}
.dns-table small a{color:var(--muted)}
.dns-type{display:inline-block;font-family:var(--mono);font-size:11px;font-weight:600;color:var(--teal-d);background:rgba(6,182,199,.10);padding:2px 9px;border-radius:6px}
.dns-table .mdi-clock-fast{color:var(--teal)}

/* DNS records: danger-agree + form refinements */
.danger-agree{display:flex;align-items:center;gap:9px;font-size:13px;color:var(--ink-2);margin-top:12px;cursor:pointer}
.danger-agree input{width:16px;height:16px;accent-color:var(--red)}
.dns-table .dot{display:inline-block;width:8px;height:8px;border-radius:50%;margin-right:7px;vertical-align:middle}
.tbl .dot{display:inline-block;width:8px;height:8px;border-radius:50%;margin-right:7px;vertical-align:middle}
.dot.ok{background:var(--green)}.dot.off{background:var(--muted)}

/* global danger card (DNS + reuse) */
.danger{margin-top:18px;border:1px solid #f1cccc;background:linear-gradient(0deg,#fff9f9,var(--surface));border-radius:14px;padding:18px 20px;display:flex;align-items:center;justify-content:space-between;gap:20px;flex-wrap:wrap}
.danger>div{flex:1;min-width:240px}
.danger h4{color:#b02a2a;font-size:15px;margin:0}
.danger p{color:var(--muted);font-size:13px;margin-top:4px;margin-bottom:0}

/* DNS add/edit record forms: modern label/desc + readonly + footer */
form.p-b-20 .form-group{padding:15px 0;margin:0;border-bottom:1px solid var(--hair)}
form.p-b-20 .form-group:first-of-type{padding-top:4px}
form.p-b-20 .form-group label{display:block;margin-bottom:8px;font-family:var(--ui);font-size:14px;font-weight:600;color:var(--ink);line-height:1.4}
form.p-b-20 .form-group label b{font-weight:600;color:var(--ink)}
form.p-b-20 .form-group label small{display:block;font-weight:400;color:var(--muted);font-size:12.5px;margin-top:3px;line-height:1.5}
.form-control[readonly]{background:var(--surface-2);color:var(--muted);border-style:dashed;cursor:default}
form.p-b-20 .form-check{display:flex;align-items:center;gap:0;padding:15px 0 4px}
form.p-b-20 > .btn,form.p-b-20 .btn-primary,form.p-b-20 .btn-danger{margin-top:18px}
form.p-b-20 .float-right{float:right}

/* ===== record add/edit modal (popover over the list) ===== */
.noc-modal-ov{position:fixed;inset:0;z-index:1000;display:flex;align-items:flex-start;justify-content:center;padding:46px 18px;overflow-y:auto}
.noc-modal-bg{position:fixed;inset:0;background:rgba(15,36,48,.5);backdrop-filter:blur(2px);z-index:0}
.noc-modal{position:relative;z-index:1;background:var(--surface);border-radius:18px;width:100%;max-width:540px;box-shadow:0 30px 70px rgba(15,36,48,.32);margin:auto 0;animation:nocModalIn .16s ease-out}
@keyframes nocModalIn{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}
.noc-modal-h{display:flex;align-items:center;justify-content:space-between;gap:14px;padding:19px 24px;border-bottom:1px solid var(--hair)}
.noc-modal-h h3{font-family:var(--disp);font-weight:600;font-size:17px;color:var(--ink);margin:0;display:flex;align-items:center;gap:10px}
.noc-modal-tag{font-family:var(--mono);font-size:11px;font-weight:600;color:var(--teal-d);background:rgba(6,182,199,.1);padding:2px 9px;border-radius:6px}
.noc-modal-x{font-size:26px;line-height:1;color:var(--muted);text-decoration:none;padding:0 2px}
.noc-modal-x:hover{color:var(--ink)}
.noc-modal-b{padding:4px 24px 24px}
.noc-modal-b form.p-b-20{padding-bottom:0}

/* tidy Active toggle */
form.p-b-20 .dns-toggle{display:flex;align-items:center;gap:13px;padding:16px 0 4px}
form.p-b-20 .dns-toggle .form-check-input{margin:0;flex:none}
form.p-b-20 .dns-toggle label{margin:0;padding:0;border:0;cursor:pointer}
form.p-b-20 .dns-toggle label b{display:block;font-weight:600;color:var(--ink);font-size:14px}
form.p-b-20 .dns-toggle label small{display:block;color:var(--muted);font-size:12.5px;margin-top:2px;line-height:1.45}

/* ===== Add-domain page ===== */
.addwrap{max-width:920px;margin:0 auto}
.addhead{text-align:center;margin:6px 0 26px}
.addhead h1{font-family:var(--disp);font-weight:600;font-size:26px;color:var(--ink);margin:0 0 8px}
.addhead p{color:var(--muted);font-size:14px;max-width:580px;margin:0 auto;line-height:1.6}
.addgrid{align-items:start}
.addcard{position:relative}
.addcard-rec{border-color:var(--teal);box-shadow:0 0 0 1px var(--teal),0 18px 40px rgba(6,182,199,.12)}
.addcard-tag{position:absolute;top:-11px;left:24px;background:var(--teal);color:#fff;font-family:var(--ui);font-size:11px;font-weight:600;letter-spacing:.03em;padding:4px 11px;border-radius:7px;z-index:2}
.addfeat{list-style:none;margin:14px 0 20px;padding:0}
.addfeat li{display:flex;align-items:center;gap:9px;font-size:13.5px;color:var(--ink-2);padding:5px 0}
.addfeat li .mdi{color:var(--teal);font-size:18px}
.addform{margin:0}
.addlabel{display:block;font-size:13px;font-weight:600;color:var(--ink);margin-bottom:7px}
.addrow{display:flex;gap:10px}
.addrow .form-control{flex:1}
.addrow .btn{white-space:nowrap}
.addnote{font-size:12px;color:var(--muted);margin:10px 0 0;line-height:1.5}
.form-control-lg{padding:12px 15px;font-size:15px}
@media(max-width:720px){.addrow{flex-direction:column}}

/* ===== enhanced routing editor ===== */
.noc-modal-wide{max-width:720px}
.noc-modal-b form.p-b-20 > label:not([for]){display:block;font-weight:600;color:var(--ink);font-size:14px;margin:4px 0 8px}
.noc-modal-b form.p-b-20 .card-title{font-family:var(--disp);font-weight:600;font-size:15px;color:var(--ink);margin:18px 0 4px}
.noc-modal-b form.p-b-20 > p{font-size:13px;color:var(--muted);margin:0 0 8px;line-height:1.55}
.noc-modal-b input[type=radio]{accent-color:var(--teal);width:16px;height:16px;margin:0 9px 0 0;vertical-align:-3px;cursor:pointer}
.noc-modal-b input[type=radio]+label{display:inline;font-size:13.5px;color:var(--ink-2);cursor:pointer;line-height:2.4}
.noc-modal-b input[type=radio]+label small{color:var(--muted)}
.enh-tbl{margin:6px 0 4px}
.enh-tbl td{vertical-align:middle}
.enh-tbl select.form-control{margin:0;min-width:150px}
.enh-tbl td .form-control[multiple]{min-height:84px}
.form-check-inline{display:inline-flex;align-items:center;gap:6px;margin-right:18px}
.form-check-inline .form-check-label{font-size:13.5px;color:var(--ink-2);margin:0}

/* ===== DNS activation card ===== */
.dns-activate{background:linear-gradient(180deg,#f0fbfc,var(--surface));border:1px solid var(--teal);border-radius:16px;padding:22px 24px;margin-bottom:18px}
.dns-activate-head{display:flex;align-items:flex-start;gap:14px}
.dns-activate-ic{flex:none;width:42px;height:42px;border-radius:11px;background:var(--teal);color:#fff;display:flex;align-items:center;justify-content:center}
.dns-activate-ic svg{width:22px;height:22px}
.dns-activate-txt{flex:1;min-width:0}
.dns-activate-txt h3{font-family:var(--disp);font-weight:600;font-size:17px;color:var(--ink);margin:0 0 4px}
.dns-activate-txt p{font-size:13.5px;color:var(--ink-2);margin:0;line-height:1.55;max-width:660px}
.dns-activate-badge{flex:none;font-size:11px;font-weight:600;color:#9a6b00;background:#fff3d6;border:1px solid #f0d99a;border-radius:20px;padding:4px 12px}
.dns-steps{list-style:none;margin:20px 0 0;padding:0;display:flex;flex-direction:column;gap:16px}
.dns-step{display:flex;gap:13px;align-items:flex-start}
.dns-step-n{flex:none;width:25px;height:25px;border-radius:50%;background:var(--teal);color:#fff;font-family:var(--disp);font-weight:600;font-size:13px;display:flex;align-items:center;justify-content:center;margin-top:1px}
.dns-step-b{flex:1;min-width:0}
.dns-step-b b{display:block;font-size:14px;color:var(--ink);font-weight:600;margin-bottom:3px}
.dns-step-b p{font-size:13px;color:var(--muted);margin:0;line-height:1.55;word-break:break-word}
.dns-step-b a{color:var(--teal-d);word-break:break-all}
.ns-swap{display:flex;align-items:center;gap:16px;margin-top:11px;flex-wrap:wrap}
.ns-col{display:flex;flex-direction:column;gap:6px}
.ns-cap{font-size:10.5px;text-transform:uppercase;letter-spacing:.05em;color:var(--muted);font-weight:600}
.ns-line{font-family:var(--mono);font-size:12px;padding:5px 11px;border-radius:7px;width:fit-content}
.ns-line.old{background:var(--surface-2);color:var(--muted);text-decoration:line-through;border:1px solid var(--hair)}
.ns-line.new{background:rgba(6,182,199,.1);color:var(--teal-d);border:1px solid rgba(6,182,199,.25)}
.ns-arrow{color:var(--teal);display:flex;align-items:center}
.ns-arrow svg{width:22px;height:22px}
@media(max-width:640px){.ns-swap{flex-direction:column;align-items:flex-start}.ns-arrow{transform:rotate(90deg)}}

.ok-txt{color:var(--green);font-weight:600}
.down-txt{color:var(--red);font-weight:600}

/* monitoring extras */
.dot.warn{background:#f5a623}
.mon-type{display:inline-block;font-family:var(--mono);font-size:10.5px;font-weight:600;color:var(--muted);background:var(--surface-2);border:1px solid var(--hair);padding:1px 7px;border-radius:5px;text-transform:uppercase;vertical-align:middle}
.mon-fast{display:inline-block;font-size:10px;font-weight:600;color:var(--teal-d);background:rgba(6,182,199,.1);padding:1px 7px;border-radius:5px;margin-left:6px;text-transform:uppercase;letter-spacing:.03em}

.avail-tbl .avail-date{font-weight:600;color:var(--ink)}
.avail-tbl td b{color:var(--ink);font-weight:600}

/* modal footer + row actions */
.noc-modal-f{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-top:6px;padding-top:16px;border-top:1px solid var(--hair)}
.noc-modal-f-r{display:inline-flex;gap:9px;align-items:center}
.btn-ghost-danger{background:var(--red-bg);border:1px solid rgba(224,72,77,.28);color:#b23034;font-weight:600}
.btn-ghost-danger:hover{background:#fbdada;border-color:rgba(224,72,77,.45)}
.rowlink{color:var(--teal-d);font-weight:600;font-size:12.5px;white-space:nowrap}
.rowlink:hover{text-decoration:underline}
.rowlink .mdi{font-size:14px}

/* monitor status pill (logs + activity) */
.mon-status{display:inline-flex;align-items:center;gap:6px;font-size:12px;font-weight:600;padding:3px 11px;border-radius:20px;line-height:1.5;text-transform:capitalize;white-space:nowrap}
.mon-status .dot{width:7px;height:7px;border-radius:50%;background:currentColor;flex:none}
.mon-status.ok{color:#0a9b54;background:rgba(16,185,99,.12)}
.mon-status.down{color:var(--red);background:rgba(224,72,77,.10)}
.mon-status.warn{color:#b8770a;background:rgba(245,166,35,.14)}

/* ===== add-monitor / generic form ===== */
.formwrap{max-width:640px;margin:0 auto}
.fld-label{display:block;font-size:13px;font-weight:600;color:var(--ink);margin-bottom:8px}
.optset{display:flex;flex-direction:column;gap:9px;margin:0 0 18px}
.opt{display:flex;align-items:flex-start;gap:11px;border:1px solid var(--hair);border-radius:11px;padding:12px 14px;cursor:pointer;transition:border-color .12s,background .12s}
.opt:hover{border-color:var(--teal)}
.opt input{accent-color:var(--teal);width:16px;height:16px;margin-top:2px;flex:none;cursor:pointer}
.opt span{display:flex;flex-direction:column;gap:2px}
.opt span b{font-size:13.5px;color:var(--ink);font-weight:600}
.opt span small{font-size:12px;color:var(--muted)}
.opt:has(input:checked){border-color:var(--teal);background:rgba(6,182,199,.05);box-shadow:0 0 0 1px var(--teal) inset}

/* ===== external / auth pages ===== */
.auth-wrap{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:32px 18px;background:radial-gradient(1000px 520px at 50% -8%,rgba(6,182,199,.16),transparent),linear-gradient(170deg,#0c1a26,#0a141d)}
.auth-card{width:100%;max-width:410px;background:var(--surface);border:1px solid var(--hair);border-radius:18px;box-shadow:0 30px 72px rgba(0,0,0,.5);padding:34px 32px}
.auth-logo{display:block;height:32px;width:auto;margin:0 auto 8px}
.auth-brand{display:block;margin:0 0 22px}
.auth-brand img{height:34px;width:auto;display:block}
.auth-h{font-family:var(--disp);font-weight:600;font-size:20px;color:var(--ink);text-align:center;margin:18px 0 4px}
.auth-sub{font-size:13.5px;color:var(--muted);text-align:center;margin:0 0 22px;line-height:1.5}
.auth-field{margin-bottom:14px}
.auth-field > label{display:block;font-size:12.5px;font-weight:600;color:var(--ink);margin-bottom:6px}
.auth-field .form-control{width:100%}
.auth-row{display:flex;align-items:center;justify-content:space-between;gap:10px;margin:2px 0 18px;font-size:12.5px}
.auth-remember{display:inline-flex;align-items:center;gap:7px;color:var(--ink-2);cursor:pointer;user-select:none}
.auth-remember input{accent-color:var(--teal);width:15px;height:15px}
.auth-link{color:var(--teal-d);font-weight:600;white-space:nowrap}
.auth-link:hover{text-decoration:underline}
.auth-btn{width:100%;justify-content:center}
.auth-foot{text-align:center;font-size:13px;color:var(--muted);margin-top:20px}
.auth-foot a{color:var(--teal-d);font-weight:600}
.auth-msg{border-radius:10px;padding:11px 14px;font-size:13px;margin-bottom:16px;line-height:1.45}
.auth-msg.err{background:var(--red-bg);color:#b3393d;border:1px solid rgba(224,72,77,.25)}
.auth-msg.ok{background:var(--green-bg);color:#0c7a3f;border:1px solid rgba(21,163,74,.25)}
.auth-msg.info{background:var(--surface-2);color:var(--ink-2);border:1px solid var(--hair)}
.auth-divider{display:flex;align-items:center;gap:12px;color:var(--muted);font-size:12px;margin:18px 0}
.auth-divider::before,.auth-divider::after{content:"";flex:1;height:1px;background:var(--hair)}

/* payment summary */
.pay-check{width:54px;height:54px;border-radius:50%;background:var(--green-bg);color:var(--green);display:flex;align-items:center;justify-content:center;margin:6px auto 2px}
.pay-check svg{width:30px;height:30px}
.pay-summary{background:var(--surface-2);border:1px solid var(--hair);border-radius:12px;padding:13px 16px;margin:8px 0 18px}
.pay-row{display:flex;align-items:center;justify-content:space-between;font-size:14px;padding:4px 0}
.pay-row span{color:var(--muted)}
.pay-row b{color:var(--ink);font-weight:600}
.pay-row.total{border-top:1px solid var(--hair);margin-top:4px;padding-top:10px;font-size:15px}
.pay-freq{color:var(--muted);font-weight:500;font-size:12px}

/* billing */
.bill-kv{display:flex;align-items:center;justify-content:space-between;gap:14px;padding:9px 0;border-bottom:1px solid var(--hair);font-size:14px}
.bill-kv:last-of-type{border-bottom:0}
.bill-kv > span{color:var(--muted)}
.bill-kv > b{color:var(--ink);font-weight:600}
.bill-card{display:inline-flex;align-items:center;gap:8px;font-family:var(--mono);font-size:13px}
.bill-card svg{width:22px;height:22px;color:var(--teal)}
.bill-logs{display:flex;flex-direction:column;gap:0;margin-top:6px}
.bill-log{font-size:13px;color:var(--ink-2);padding:9px 2px;border-bottom:1px solid var(--hair);font-family:var(--mono)}
.bill-log:last-child{border-bottom:0}

/* security page */
.sec-status{display:inline-flex;align-items:center;gap:8px;font-size:13.5px;font-weight:600;color:var(--ink);background:var(--green-bg);border:1px solid rgba(21,163,74,.25);border-radius:20px;padding:5px 13px;margin-bottom:10px}
.sec-steps{list-style:none;counter-reset:s;margin:6px 0 0;padding:0;display:flex;flex-direction:column;gap:16px}
.sec-steps li{counter-increment:s;position:relative;padding-left:34px;font-size:13.5px;color:var(--ink-2);line-height:1.5}
.sec-steps li::before{content:counter(s);position:absolute;left:0;top:-1px;width:24px;height:24px;border-radius:50%;background:var(--teal);color:#fff;font-family:var(--disp);font-weight:600;font-size:12px;display:flex;align-items:center;justify-content:center}
.sec-steps li b{color:var(--ink)}
.sec-qr{display:inline-block;margin-top:10px;padding:10px;background:#fff;border:1px solid var(--hair);border-radius:12px}
.sec-qr img{display:block;border-radius:4px}

/* team / users access badges */
.user-access{display:inline-block;font-size:11px;font-weight:600;padding:2px 10px;border-radius:20px;text-transform:capitalize}
.user-access.owner,.user-access.admin{color:var(--teal-d);background:rgba(6,182,199,.12)}
.user-access.customer{color:#5b53c6;background:rgba(99,91,198,.12)}
.user-access.billing{color:#b8770a;background:rgba(245,166,35,.14)}
.user-access.readonly{color:var(--muted);background:var(--surface-2);border:1px solid var(--hair)}

/* notifications */
.notif-add{display:flex;gap:8px;flex-wrap:wrap}
.notif-type{display:inline-block;font-size:11px;font-weight:600;padding:2px 10px;border-radius:20px;text-transform:capitalize}
.notif-type.email{color:var(--teal-d);background:rgba(6,182,199,.12)}
.notif-type.slack{color:#5b53c6;background:rgba(99,91,198,.12)}
.notif-type.public_page{color:#b8770a;background:rgba(245,166,35,.14)}

/* global sub-text + full-bleed table footer note */
.sub{color:var(--muted);font-size:13px;line-height:1.55;margin:0 0 14px}
.sub a{color:var(--teal-d);font-weight:600}
.logtbl-foot{padding:14px 22px 18px;border-top:1px solid var(--hair);font-size:13px;color:var(--muted);line-height:1.55;margin:0}
.logtbl-foot a{color:var(--teal-d);font-weight:600}
/* ===== OVERVIEW (mockup) ===== */
.ov-period{display:inline-flex;gap:2px;background:var(--surface-2);border:1px solid var(--hair);border-radius:9px;padding:3px}
.ov-period button{border:0;background:transparent;font:600 12px/1 var(--ui);color:var(--muted);padding:6px 11px;border-radius:6px;cursor:pointer}
.ov-period button.on{background:#fff;color:var(--ink);box-shadow:0 1px 2px rgba(15,36,48,.08)}

/* status banner */
.status-banner{display:flex;align-items:flex-start;gap:15px;padding:17px 20px;border-radius:15px;margin-bottom:24px;border:1px solid}
.status-banner.ok{background:linear-gradient(100deg,#eafaf1,#f3fbf6);border-color:rgba(21,163,74,.28)}
.status-banner.warn{background:linear-gradient(100deg,#fff6e9,#fffaf1);border-color:rgba(217,138,11,.30)}
.sb-ic{width:40px;height:40px;border-radius:11px;display:flex;align-items:center;justify-content:center;flex:none}
.status-banner.ok .sb-ic{background:rgba(21,163,74,.14);color:var(--green)}
.status-banner.warn .sb-ic{background:rgba(217,138,11,.16);color:#c4810c}
.sb-ic svg{width:22px;height:22px}
.sb-txt{flex:1;min-width:0}
.sb-txt h2{font:600 16px/1.2 var(--disp);color:var(--ink);margin:2px 0 0}
.sb-issues{display:flex;flex-wrap:wrap;gap:8px;margin-top:11px}
.sb-issue{display:inline-flex;align-items:center;gap:7px;background:#fff;border:1px solid var(--hair);border-radius:8px;padding:6px 11px;font-size:12.5px;color:var(--ink-2);font-weight:500}
.sb-issue .dot{width:7px;height:7px;border-radius:50%}
.sb-issue b{color:var(--ink);font-family:var(--mono);font-size:12px}

/* section label */
.ov-label{font:600 12px/1 var(--ui);letter-spacing:.04em;text-transform:uppercase;color:var(--muted);margin:0 0 13px}

/* product summary cards */
.ov-prods{display:grid;grid-template-columns:repeat(3,1fr);gap:15px;margin-bottom:28px}
.ov-prod{background:var(--surface);border:1px solid var(--hair);border-radius:15px;padding:17px 18px;display:flex;flex-direction:column}
.ov-prod-h{display:flex;align-items:center;gap:11px}
.ov-prod-ic{width:36px;height:36px;border-radius:10px;display:flex;align-items:center;justify-content:center;flex:none}
.ov-prod-ic svg{width:20px;height:20px}
.ov-prod-ic.cdn{background:rgba(91,83,198,.12);color:#5b53c6}
.ov-prod-ic.dns{background:rgba(6,182,199,.13);color:var(--teal-d)}
.ov-prod-ic.mon{background:rgba(21,163,74,.13);color:var(--green)}
.ov-prod-h h3{font:600 14px/1 var(--ui);color:var(--ink);margin:0}
.ov-prod-h .ov-prod-sub{font-size:12px;color:var(--muted)}
.ov-prod-link{margin-left:auto;font-size:12.5px;font-weight:600;color:var(--teal-d);white-space:nowrap}
.ov-prod-kpis{display:flex;gap:22px;margin-top:16px;padding-top:15px;border-top:1px solid var(--hair)}
.ov-prod-kpis>div{display:flex;flex-direction:column;gap:3px}
.ov-prod-kpis b{font:600 19px/1 var(--disp);color:var(--ink)}
.ov-prod-kpis span{font-size:11.5px;color:var(--muted)}

/* site cards */
.site-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:15px}
.site-card{background:var(--surface);border:1px solid var(--hair);border-radius:15px;padding:16px 18px;position:relative;transition:border-color .12s,box-shadow .12s}
.site-card:hover{border-color:#d7dee4;box-shadow:0 6px 20px rgba(15,36,48,.06)}
.site-card.down{border-left:3px solid var(--red)}
.site-card.warn{border-left:3px solid #d98a0b}
.site-card-h{display:flex;align-items:center;justify-content:space-between;gap:10px}
.site-name{display:flex;align-items:center;gap:9px;font:600 14.5px/1 var(--ui);color:var(--ink);font-family:var(--mono)}
.site-name .dot{width:9px;height:9px;border-radius:50%;flex:none}
.site-status{font-size:11.5px;font-weight:600;padding:3px 10px;border-radius:20px}
.site-status.ok{color:var(--green);background:var(--green-bg)}
.site-status.warn{color:#b8770a;background:rgba(245,166,35,.14)}
.site-status.down{color:#c0393d;background:var(--red-bg)}
.site-prods{display:flex;gap:6px;flex-wrap:wrap;margin:13px 0 12px}
.site-prod{display:inline-flex;align-items:center;gap:5px;font-size:11.5px;font-weight:600;padding:3px 10px;border-radius:7px;text-decoration:none;transition:filter .12s}
a.site-prod:not(.off):hover{filter:brightness(.95)}
.site-prod .pd{width:6px;height:6px;border-radius:50%}
.site-prod.dns{color:var(--teal-d);background:rgba(6,182,199,.11)}.site-prod.dns .pd{background:var(--teal)}
.site-prod.cdn{color:#5b53c6;background:rgba(91,83,198,.11)}.site-prod.cdn .pd{background:#5b53c6}
.site-prod.mon{color:#0c7a3f;background:rgba(21,163,74,.11)}.site-prod.mon .pd{background:var(--green)}
.site-prod.off{color:var(--muted);background:transparent;border:1px dashed var(--hair)}
.site-meta{display:flex;align-items:center;gap:7px;font-size:12.5px;color:var(--ink-2);font-family:var(--mono)}
.site-issue{display:flex;align-items:center;gap:8px;font-size:12.5px;font-weight:500;border-radius:9px;padding:8px 11px}
.site-issue svg{width:15px;height:15px;flex:none}
.site-issue.down{background:var(--red-bg);color:#b3393d}
.site-issue.warn{background:rgba(245,166,35,.12);color:#9a6a08}
.site-foot{display:flex;align-items:center;justify-content:space-between;margin-top:13px}
.site-manage{font-size:12.5px;font-weight:600;color:var(--teal-d)}
.site-status.idle{color:var(--muted);background:var(--surface-2)}
.site-prod.off{text-decoration:none}
.site-prod.off:hover{border-color:var(--teal);color:var(--teal-d)}
.site-hint{color:var(--muted);font-style:italic;font-family:var(--ui)}
.ov-empty{max-width:540px;margin:40px auto;text-align:center;background:var(--surface);border:1px solid var(--hair);border-radius:18px;padding:42px 34px}
.ov-empty-ic{width:54px;height:54px;border-radius:14px;background:rgba(6,182,199,.12);color:var(--teal-d);display:flex;align-items:center;justify-content:center;margin:0 auto 16px}
.ov-empty-ic svg{width:28px;height:28px}
.ov-empty h2{font:600 20px/1.2 var(--disp);color:var(--ink);margin:0 0 6px}
.ov-empty p{font-size:14px;color:var(--muted);line-height:1.55;margin:0 0 22px}
.ov-empty-actions{display:flex;gap:10px;justify-content:center;flex-wrap:wrap}

/* overview — responsive (desktop columns preserved above) */
@media(max-width:860px){ .ov-prods{grid-template-columns:1fr} }
@media(max-width:680px){ .site-grid{grid-template-columns:1fr} }
@media(max-width:560px){
  .ov-prod-kpis{gap:18px}
  .status-banner{padding:14px 15px;gap:12px}
  .sb-ic{width:34px;height:34px}
  .ov-prod,.site-card{padding:15px 15px}
}
.addcdn-note{background:var(--surface-2);border:1px solid var(--hair);border-left:3px solid var(--teal);border-radius:10px;padding:12px 15px;font-size:13.5px;color:var(--ink-2);line-height:1.5;margin-bottom:18px}

