:root{
  --bg:#0a0e17; --panel:#0e1422; --card:#121a2b; --card2:#0e1626; --raise:#16203400;
  --line:#1f2940; --line2:#192238; --txt:#eef2f8; --mut:#9aa8c2; --dim:#64718c;
  --a1:#5b8cff; --a2:#8a6cff; --ok:#3fd896; --warn:#ffb454; --bad:#ff6b8a;
  --sb:248px; --r:14px; --mw:1240px;
  --sh:0 1px 2px rgba(0,0,0,.3),0 8px 24px -8px rgba(0,0,0,.5);
  color-scheme:dark;
}
*{box-sizing:border-box}
html,body{height:100%}
body{margin:0;font-family:'Inter',system-ui,-apple-system,Segoe UI,Roboto,sans-serif;
     background:var(--bg);color:var(--txt);font-size:14px;line-height:1.5;-webkit-font-smoothing:antialiased}
a{color:var(--a1);text-decoration:none}
.ico{width:18px;height:18px;flex:0 0 auto;vertical-align:-3px}
.ico-sm{width:15px;height:15px;flex:0 0 auto;vertical-align:-2px}

/* ---------- layout ---------- */
.app{display:flex;min-height:100vh}
.sidebar{width:var(--sb);flex:0 0 var(--sb);background:var(--panel);border-right:1px solid var(--line);
         display:flex;flex-direction:column;position:fixed;top:0;bottom:0;left:0;z-index:20}
.sb-brand{display:flex;align-items:center;gap:11px;padding:20px 22px;font-size:16px;font-weight:700;letter-spacing:-.01em}
.sb-brand .mark{width:30px;height:30px;border-radius:9px;display:grid;place-items:center;
       background:linear-gradient(140deg,var(--a1),var(--a2));color:#fff;box-shadow:0 4px 14px -4px var(--a1)}
.sb-nav{padding:10px 12px;display:flex;flex-direction:column;gap:2px;overflow-y:auto;flex:1}
.sb-sec{font-size:10.5px;font-weight:700;color:var(--dim);text-transform:uppercase;letter-spacing:.08em;padding:14px 12px 6px}
.sb-link{display:flex;align-items:center;gap:11px;padding:9px 12px;border-radius:9px;color:var(--mut);
         font-size:13.5px;font-weight:500;transition:.13s;cursor:pointer;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.sb-link:hover{background:#161f33;color:var(--txt)}
.sb-link.active{background:linear-gradient(90deg,rgba(91,140,255,.16),rgba(138,108,255,.06));color:#fff;
         box-shadow:inset 2px 0 0 var(--a1)}
.sb-link .dot{width:7px;height:7px;border-radius:50%;margin-left:auto;flex:0 0 auto}
.sb-foot{border-top:1px solid var(--line);padding:14px 18px;display:flex;align-items:center;gap:10px;font-size:13px;color:var(--mut)}
.sb-foot .av{width:30px;height:30px;border-radius:50%;background:#1c2741;display:grid;place-items:center;font-weight:700;font-size:12px;color:var(--mut)}
.sb-foot a{margin-left:auto;color:var(--dim);display:grid;place-items:center}
.sb-foot a:hover{color:var(--bad)}

.main{flex:1;margin-left:var(--sb);min-width:0}
.topbar{display:flex;align-items:center;gap:14px;border-bottom:1px solid var(--line);
        padding:18px max(32px, calc((100% - var(--mw))/2 + 32px));
        background:rgba(10,14,23,.7);backdrop-filter:blur(8px);position:sticky;top:0;z-index:10}
.topbar h1{font-size:17px;font-weight:650;margin:0;letter-spacing:-.01em}
.topbar .sub{color:var(--dim);font-size:13px}
.topbar .sp{flex:1}
.content{padding:28px 32px 64px;max-width:var(--mw);margin-inline:auto}
.crumb{display:flex;align-items:center;gap:7px;font-size:13px;color:var(--dim);margin-bottom:18px}
.crumb a{color:var(--mut);display:inline-flex;align-items:center;gap:6px}
.crumb a:hover{color:var(--txt)}

/* ---------- cards ---------- */
.card{background:var(--card);border:1px solid var(--line);border-radius:var(--r);margin-bottom:22px;box-shadow:var(--sh)}
.card-b{padding:22px 24px}
.card-h{display:flex;align-items:center;gap:11px;padding:17px 24px;border-bottom:1px solid var(--line2)}
.card-h h2{font-size:14px;font-weight:650;margin:0;letter-spacing:-.01em;display:flex;align-items:center;gap:9px}
.card-h h2 .ico{color:var(--a1)}
.card-h .badge,.card-h .count{margin-left:auto}
.card-h .ctrls{margin-left:auto;display:flex;align-items:center;gap:9px;flex-wrap:wrap}
.count{font-size:11.5px;color:var(--dim);background:var(--card2);border:1px solid var(--line);padding:3px 10px;border-radius:20px;font-variant-numeric:tabular-nums}
details.card>summary{list-style:none;cursor:pointer;display:flex;align-items:center;gap:11px;padding:17px 24px;user-select:none}
details.card>summary::-webkit-details-marker{display:none}
details.card>summary h2{font-size:14px;font-weight:650;margin:0;display:flex;align-items:center;gap:9px}
details.card>summary h2 .ico{color:var(--a1)}
details.card>summary .chev{margin-left:auto;color:var(--dim);transition:.2s}
details.card[open]>summary .chev{transform:rotate(180deg)}
details.card[open]>summary{border-bottom:1px solid var(--line2)}
details.card .card-b{padding-top:20px}

.addbox{display:none;padding:20px 24px;border-bottom:1px solid var(--line2);background:var(--card2)}
.addbox.open{display:block}

/* ---------- tables ---------- */
.tw{overflow-x:auto}
table{width:100%;border-collapse:collapse}
th{text-align:left;padding:11px 24px;color:var(--dim);font-weight:600;font-size:11px;
   text-transform:uppercase;letter-spacing:.05em;border-bottom:1px solid var(--line2);background:var(--card2)}
td{text-align:left;padding:13px 24px;border-bottom:1px solid var(--line2);vertical-align:middle}
tbody tr:last-child td{border-bottom:0}
tbody tr{transition:background .1s} tbody tr:hover{background:#131c30}
td.dom{font-weight:600;white-space:nowrap}
.up,.mono{font-family:ui-monospace,'SF Mono',Menlo,monospace;font-size:12.5px}
.up{color:var(--mut)}
.cnt{color:var(--mut);font-variant-numeric:tabular-nums}
.empty{color:var(--dim);text-align:center;padding:22px}

/* ---------- forms ---------- */
label{display:block;font-size:12px;color:var(--mut);margin-bottom:7px;font-weight:500}
input,select{width:100%;padding:9px 12px;border-radius:9px;border:1px solid #283452;background:var(--card2);
   color:var(--txt);font-size:13.5px;outline:none;transition:.13s;font-family:inherit}
input:focus,select:focus{border-color:var(--a1);box-shadow:0 0 0 3px rgba(91,140,255,.16)}
input::placeholder{color:#4d5b78}
select.inline{width:auto;min-width:118px;padding:7px 30px 7px 11px;cursor:pointer;font-size:13px}
input.evtsearch{width:240px;padding:7px 11px;font-size:13px}
input.evtsearch::-webkit-search-cancel-button{filter:invert(.6);cursor:pointer}
.grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:16px}
.grid .full{grid-column:1/-1}

/* ---------- buttons ---------- */
button,.btn{display:inline-flex;align-items:center;gap:7px;padding:9px 14px;border:0;border-radius:9px;cursor:pointer;
       font-size:13px;font-weight:600;transition:.13s;font-family:inherit;line-height:1}
button:active,.btn:active{transform:translateY(1px)}
.btn-primary{background:linear-gradient(90deg,var(--a1),var(--a2));color:#fff;box-shadow:0 4px 14px -6px var(--a1)}
.btn-primary:hover{filter:brightness(1.08)}
.btn-ghost{background:var(--card2);color:var(--mut);border:1px solid var(--line)}
.btn-ghost:hover{color:var(--txt);border-color:#33436b}
.btn-del{background:transparent;color:var(--bad);border:1px solid #4d2236;padding:8px 13px}
.btn-del:hover{background:rgba(255,107,138,.1)}
button:disabled,.btn:disabled{opacity:.35;pointer-events:none}
.pager{display:flex;align-items:center;gap:10px;padding-top:14px;flex-wrap:wrap}
.pager .btn-ghost{display:inline-flex;align-items:center;gap:5px;padding:7px 13px}
.pgind{font-size:13px;color:var(--mut);min-width:74px;text-align:center;font-variant-numeric:tabular-nums}

/* ---------- badges / toggles ---------- */
.badge{display:inline-flex;align-items:center;gap:5px;padding:3px 10px;border-radius:7px;font-size:11px;font-weight:700;letter-spacing:.01em}
.b-ok{background:rgba(63,216,150,.14);color:var(--ok)}
.m-off{background:#232a3a;color:var(--mut)}.m-js{background:rgba(63,216,150,.14);color:var(--ok)}
.m-pow{background:rgba(91,140,255,.16);color:#7fa6ff}.m-captcha{background:rgba(138,108,255,.16);color:#b39bff}.m-block{background:rgba(255,107,138,.14);color:var(--bad)}
.row-actions{display:flex;gap:9px;align-items:center;justify-content:flex-end;flex-wrap:wrap}
.toolbar{display:flex;gap:10px;align-items:center;flex-wrap:wrap;margin-top:18px}
.note{color:var(--dim);font-size:12.5px;line-height:1.6;margin-top:12px}
.note code{background:var(--card2);border:1px solid var(--line);padding:1px 6px;border-radius:5px;font-size:11.5px;color:var(--mut)}
.err{color:var(--bad);font-size:13px;margin-top:10px;min-height:1px}
.switch{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--mut)}.switch input{width:auto}
.sw{display:inline-flex;align-items:center;gap:8px;cursor:pointer;user-select:none}
.sw .lbl{font-size:11.5px;font-weight:600;color:var(--mut)}
.sw input{display:none}
.sw .track{width:38px;height:21px;border-radius:99px;background:#2a3550;position:relative;transition:.18s;flex:0 0 auto}
.sw .thumb{position:absolute;top:2px;left:2px;width:17px;height:17px;border-radius:50%;background:#8295b5;transition:.18s;box-shadow:0 1px 3px rgba(0,0,0,.4)}
.sw input:checked + .track{background:linear-gradient(90deg,var(--ok),#19b36b)}
.sw input:checked + .track .thumb{left:19px;background:#fff}
.toggles{display:flex;gap:22px;align-items:center;flex-wrap:wrap}

/* ---------- KPI cards (genel bakış) ---------- */
.kpis{display:grid;grid-template-columns:repeat(auto-fit,minmax(168px,1fr));gap:14px;margin-bottom:24px}
.kpi{background:var(--card);border:1px solid var(--line);border-radius:14px;padding:17px 18px;box-shadow:var(--sh);
     display:flex;align-items:flex-start;gap:14px;position:relative;overflow:hidden;transition:.15s}
.kpi:hover{border-color:#2a3650}
.kpi .ic{width:40px;height:40px;border-radius:11px;display:grid;place-items:center;flex:0 0 auto}
.kpi .ic .ico{width:20px;height:20px}
.kpi .v{font-size:25px;font-weight:750;line-height:1;letter-spacing:-.025em;font-variant-numeric:tabular-nums}
.kpi .lab{font-size:11.5px;color:var(--dim);margin-top:7px;font-weight:500}
.kpi.k-blue .ic{background:rgba(91,140,255,.14);color:#7fa6ff}
.kpi.k-purple .ic{background:rgba(138,108,255,.14);color:#b39bff}
.kpi.k-green .ic{background:rgba(63,216,150,.14);color:var(--ok)}
.kpi.k-amber .ic{background:rgba(255,180,84,.14);color:var(--warn)}
.kpi.k-red .ic{background:rgba(255,107,138,.14);color:var(--bad)}
.kpi.k-blue .v{color:#9bbcff}.kpi.k-green .v{color:#6fe3ab}.kpi.k-amber .v{color:#ffc579}.kpi.k-red .v{color:#ff8aa3}

/* ---------- monitoring tiles ---------- */
.tiles{display:grid;grid-template-columns:repeat(auto-fit,minmax(118px,1fr));gap:12px}
.tile{background:var(--card2);border:1px solid var(--line);border-radius:11px;padding:15px 16px;position:relative;overflow:hidden}
.tile .n{font-size:25px;font-weight:750;line-height:1.05;letter-spacing:-.02em;font-variant-numeric:tabular-nums}
.tile .l{font-size:10.5px;color:var(--dim);margin-top:5px;text-transform:uppercase;letter-spacing:.05em;font-weight:600;display:flex;align-items:center;gap:5px}
.tile.t-crps .n{color:#7fa6ff}.tile.t-prps .n{color:var(--warn)}.tile.t-pass .n{color:var(--ok)}
.tile.t-chal .n{color:#7fa6ff}.tile.t-rl .n{color:var(--warn)}.tile.t-block .n{color:var(--bad)}
.cols{display:grid;grid-template-columns:1fr 1fr;gap:22px;margin-top:22px;min-width:0}
.cols>div{min-width:0}
.cols h3{font-size:11.5px;color:var(--mut);margin:0 0 12px;text-transform:uppercase;letter-spacing:.05em;font-weight:600;display:flex;align-items:center;gap:7px}
.cols h3 .ico-sm{color:var(--dim)}
.live{display:inline-flex;align-items:center;gap:6px;font-size:11.5px;color:var(--dim)}
.live .dot{width:7px;height:7px;border-radius:50%;background:var(--ok);animation:pulse 1.6s infinite}
@keyframes pulse{0%{box-shadow:0 0 0 0 rgba(63,216,150,.5)}70%{box-shadow:0 0 0 6px rgba(63,216,150,0)}100%{box-shadow:0 0 0 0 rgba(63,216,150,0)}}
.dlink{color:var(--txt);font-weight:600}.dlink:hover{color:var(--a1)}

/* activity rows (suspect IP/paths) */
.actrow{position:relative;display:flex;align-items:center;gap:10px;padding:9px 12px;border-bottom:1px solid var(--line2);overflow:hidden;border-radius:7px}
.actrow:last-child{border-bottom:0}
.actrow .bar{position:absolute;left:0;top:0;bottom:0;z-index:0;border-radius:7px}
.actrow.ip .bar{background:rgba(255,107,138,.10)}.actrow.path .bar{background:rgba(91,140,255,.09)}
.actrow>*{position:relative;z-index:1}
.actrow .k{font-family:ui-monospace,Menlo,monospace;font-size:12.5px;flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;min-width:0}
.actrow .c{color:var(--mut);font-variant-numeric:tabular-nums;font-size:12.5px;font-weight:600}
.actrow .ban{padding:4px 11px;font-size:11px;font-weight:600;border-radius:7px;background:transparent;color:var(--bad);border:1px solid #4d2236;cursor:pointer}
.actrow .ban:hover{background:rgba(255,107,138,.1)}
.actempty{color:var(--dim);text-align:center;padding:16px;font-size:12.5px}

/* events */
.a-challenge{background:rgba(91,140,255,.16);color:#7fa6ff}.a-ratelimited{background:rgba(255,180,84,.14);color:var(--warn)}
.a-blocked{background:rgba(255,107,138,.14);color:var(--bad)}.a-passed{background:rgba(63,216,150,.14);color:var(--ok)}
.a-error,.a-dropped,.a-other{background:#232a3a;color:var(--mut)}
.evt th,.evt td{padding:9px 14px;font-size:12.5px}
.evt .t{color:var(--dim);font-variant-numeric:tabular-nums;white-space:nowrap}
.evt .ip{font-family:ui-monospace,Menlo,monospace}.evt .m{font-weight:700;font-size:11px;color:var(--mut)}
.evt .p{font-family:ui-monospace,Menlo,monospace;max-width:280px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.evt .st{font-variant-numeric:tabular-nums;font-weight:600}
.evt .cc{white-space:nowrap;color:var(--mut);font-size:12px}
.evt .ua2{font-size:11.5px;color:var(--mut);max-width:210px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.evt .botb{background:rgba(255,107,138,.16);color:var(--bad);padding:1px 6px;border-radius:5px;font-size:9.5px;font-weight:700;letter-spacing:.03em}
.evt .banx{padding:3px 9px;font-size:10.5px;border-radius:6px;background:transparent;color:var(--bad);border:1px solid #4d2236;cursor:pointer}
.evt .banx:hover{background:rgba(255,107,138,.1)}
.ban.done,.banx.done{color:var(--ok);border-color:#1f6b48;pointer-events:none}
/* olay detayı (açılır satır) */
.evt .erow{cursor:pointer}
.evt .erow:hover{background:var(--card2)}
.evt .erow .ecar{display:inline-block;color:var(--dim);font-size:10px;margin-right:7px;transition:transform .15s}
.evt .erow.eopen{background:var(--card2)}
.evt .erow.eopen .ecar{transform:rotate(90deg);color:var(--a1)}
.evt .edrow > td{padding:0;border-bottom:1px solid var(--line)}
.evtd{display:flex;flex-direction:column;gap:7px;padding:14px 18px 16px;background:#0c1322}
.evtd .kv{display:flex;gap:12px;font-size:12.5px;min-width:0;line-height:1.5}
.evtd .dk{color:var(--dim);flex:0 0 92px;text-align:right}
.evtd .dv{color:var(--txt);min-width:0;word-break:break-all}
.evtd .dv code{font-family:ui-monospace,Menlo,monospace;font-size:11.5px;color:var(--mut);background:transparent;padding:0}

/* ---------- özel kurallar (WAF) ---------- */
.rul td,.rul th{padding:9px 10px;vertical-align:middle}
.rul .t{color:var(--dim);font-variant-numeric:tabular-nums;font-weight:600}
.rul .rmatch{font-family:ui-monospace,Menlo,monospace;font-size:12.5px;color:var(--txt)}
.rpill{padding:3px 11px;border-radius:20px;font-size:11px;font-weight:600;cursor:pointer;border:1px solid var(--line);background:var(--card2)}
.rpill.on{color:var(--ok);border-color:#1f6b48;background:rgba(63,216,150,.1)}
.rpill.off{color:var(--dim)}
.rmv{padding:3px 9px;font-size:13px;line-height:1;border-radius:6px;background:var(--card2);color:var(--mut);border:1px solid var(--line);cursor:pointer;margin-right:3px}
.rmv:hover{color:var(--txt);border-color:#33436b}
.rrow{display:flex;gap:8px;flex-wrap:wrap;align-items:center}
.rrow select,.rrow input{height:38px}
.rrow select{background:var(--card2);color:var(--txt);border:1px solid var(--line);border-radius:8px;padding:0 10px}
.rul .rname{font-family:var(--font,inherit);font-size:12px;color:var(--mut);font-weight:600;margin-bottom:3px}
.rul .cand{display:inline-block;color:var(--a1);font-weight:700;font-size:10.5px;padding:0 5px;letter-spacing:.04em}
.rul .cneg{display:inline-block;background:rgba(255,107,138,.16);color:var(--bad);padding:0 6px;border-radius:5px;font-size:10px;font-weight:700;font-family:inherit}
/* koşul oluşturucu */
.rform .rflabel{font-size:12px;font-weight:700;color:var(--mut);letter-spacing:.04em;margin-bottom:8px}
.condrow{display:flex;gap:8px;align-items:center;margin-bottom:8px;flex-wrap:wrap}
.condrow select,.condrow input{height:36px;background:var(--card2);color:var(--txt);border:1px solid var(--line);border-radius:8px;padding:0 10px;font-size:13px}
.condrow .c-field{min-width:140px}.condrow .c-op{min-width:130px}.condrow .c-val{flex:1;min-width:150px}
.condrow .c-neg{display:flex;align-items:center;gap:5px;font-size:11.5px;color:var(--dim);cursor:pointer;user-select:none;white-space:nowrap}
.condrow .c-neg input{width:14px;height:14px;accent-color:var(--bad)}
.condrow .c-rm{width:30px;height:36px;flex:0 0 auto;background:transparent;border:1px solid var(--line);border-radius:8px;color:var(--dim);font-size:18px;line-height:1;cursor:pointer}
.condrow .c-rm:hover{color:var(--bad);border-color:#4d2236}
.addcond{margin:2px 0 12px;display:inline-flex;align-items:center;gap:5px;padding:7px 12px}
.rthen{margin-top:8px;padding-top:12px;border-top:1px solid var(--line2)}

@media(max-width:820px){
  :root{--sb:0px}
  .sidebar{transform:translateX(-100%)}
  .main{margin-left:0}
  .cols{grid-template-columns:1fr}
  .content,.topbar{padding-left:18px;padding-right:18px}
}
