/* ===== AntiSpam Proxy Portal – Theme (Dark default + Light) ===== */
:root{
  --bg:#070A12;--bg2:#0B0F1B;--panel:#101626;--panel-grad:#0a1124;--panel2:#141B2C;
  --line:rgba(255,255,255,.07);--line2:rgba(255,255,255,.14);--th:#0E1B33;--zebra:rgba(255,255,255,.045);
  --txt:#E8EEF9;--muted:#93A1B8;--dim:#6B7488;--inp:rgba(255,255,255,.05);
  /* Markenakzente (konstant in beiden Modi) */
  --blue:#3D86F2;--blue2:#2F6BD8;--bluet:#5AA0FF;--green:#5BD6A0;--red:#E5557A;--amber:#E8B45B;
  --rad:12px;--shadow:0 1px 0 rgba(255,255,255,.03),0 12px 30px -18px rgba(0,0,0,.6);
  
  /* Text-Farben für Badges (dunkler Modus) */
  --badge-txt-blue:#5AA0FF;
  --badge-txt-green:#5BD6A0;
  --badge-txt-red:#E5557A;
  --badge-txt-amber:#E8B45B;
}
html[data-theme="light"], :root[data-theme="light"]{
  --bg:#F4F6FB;--bg2:#EEF2F8;--panel:#FFFFFF;--panel-grad:#FBFCFE;--panel2:#F3F6FB;
  --line:rgba(16,30,60,.12);--line2:rgba(16,30,60,.18);--th:#EEF3FB;--zebra:rgba(16,30,60,.05);
  --txt:#0F1B30;--muted:#4A5870;--dim:#7B879B;--inp:rgba(16,30,60,.04);
  --shadow:0 1px 0 rgba(16,30,60,.02),0 14px 30px -20px rgba(16,30,60,.25);
  
  /* Text-Farben für Badges (heller Modus - bessere Kontraste!) */
  --badge-txt-blue:#1A5FDF;
  --badge-txt-green:#1E7E34;
  --badge-txt-red:#D32F2F;
  --badge-txt-amber:#B78103;
}
*{box-sizing:border-box;margin:0;padding:0}
body{font-family:'Inter',system-ui,Arial,sans-serif;background:var(--bg);color:var(--txt);line-height:1.6;-webkit-font-smoothing:antialiased;min-height:100vh;display:flex;flex-direction:column;transition:background .25s,color .25s}
a{color:var(--blue);text-decoration:none}
h1{font-family:'Space Grotesk','Inter',sans-serif;font-weight:600;font-size:26px;letter-spacing:-.02em;margin-bottom:6px}
h2{font-family:'Space Grotesk',sans-serif;font-weight:600;font-size:16px;margin-bottom:2px}
.muted{color:var(--muted)}.small{font-size:13px}
.wrap{width:100%;max-width:1440px;margin:0 auto;padding:30px 20px;flex:1}
/* brand */
.brand{display:inline-flex;align-items:center;gap:10px}
.brand .wm{font-family:'Space Grotesk',sans-serif;font-weight:700;font-size:19px;color:var(--txt)}
.brand .wm b{color:var(--bluet);font-weight:700}
.brand.big .wm{font-size:26px}
.bars{display:inline-flex;flex-direction:column;gap:3px}
.bars i{display:block;width:26px;height:6px;border-radius:2px}
.bars i:nth-child(1){background:var(--green)}.bars i:nth-child(2){background:var(--muted)}.bars i:nth-child(3){background:var(--red)}
.brand.big .bars i{width:34px;height:7px}
/* topbar */
.topbar{display:flex;align-items:center;justify-content:space-between;gap:14px;padding:13px 22px;background:color-mix(in srgb,var(--bg) 82%,transparent);backdrop-filter:blur(12px);border-bottom:1px solid var(--line);position:sticky;top:0;z-index:10}
.topbar nav{display:flex;align-items:center;gap:20px}
.topbar nav a{color:var(--muted);font-size:14px;font-weight:500}
.topbar nav a:hover,.topbar nav a.active{color:var(--txt)}
.topbar .who{color:var(--dim);font-size:13px}
.topbar .logout{color:var(--blue)}
/* theme toggle */
.tgl{display:inline-flex;align-items:center;gap:0;background:var(--inp);border:1px solid var(--line2);border-radius:20px;padding:3px;cursor:pointer}
.tgl button{border:0;background:transparent;color:var(--muted);font-size:13px;line-height:1;padding:5px 9px;border-radius:16px;cursor:pointer;display:flex;align-items:center}
.tgl button.on{background:var(--blue);color:#fff}
.foot{text-align:center;color:var(--dim);font-size:12.5px;padding:24px;border-top:1px solid var(--line)}
/* cards / generic */
.card{background:linear-gradient(180deg,var(--panel),var(--panel-grad));border:1px solid var(--line2);border-radius:16px;padding:26px;box-shadow:var(--shadow)}
.card.pad{padding:20px}
/* login */
.loginwrap{max-width:380px;margin:8vh auto 0;text-align:center}
.loginwrap .sub{color:var(--muted);font-size:13px;letter-spacing:2px;text-transform:uppercase;margin:14px 0 22px}
.loginwrap label{display:block;font-size:13px;color:var(--muted);margin:14px 0 6px;text-align:left}
.loginwrap input{width:100%;background:var(--inp);border:1px solid var(--line2);border-radius:9px;padding:11px 13px;color:var(--txt);font-size:14px;font-family:inherit}
.loginwrap input:focus{outline:none;border-color:var(--blue)}
.loginwrap button{width:100%;margin-top:20px}
.lhint{margin-top:18px;font-size:13px;color:var(--dim)}
.btn{display:inline-block;background:var(--inp);border:1px solid var(--line2);color:var(--txt);border-radius:9px;padding:9px 16px;font-size:14px;font-weight:500;cursor:pointer;font-family:inherit}
.btn:hover{border-color:var(--blue)}
.btn.primary{background:linear-gradient(135deg,var(--blue),var(--blue2));color:#fff;border:0;font-weight:600}
.alert{background:color-mix(in srgb,var(--red) 14%,transparent);border:1px solid color-mix(in srgb,var(--red) 45%,transparent);color:var(--red);border-radius:9px;padding:11px 14px;font-size:14px;margin-bottom:16px}
.ok{background:color-mix(in srgb,var(--green) 14%,transparent);border:1px solid color-mix(in srgb,var(--green) 45%,transparent);color:var(--green);border-radius:9px;padding:11px 14px;font-size:14px;margin-bottom:16px}
/* KPI row */
.kpis{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:14px;margin:22px 0}
.kpi{background:linear-gradient(180deg,var(--panel),var(--panel-grad));border:1px solid var(--line);border-radius:var(--rad);padding:16px 18px;box-shadow:var(--shadow)}
.kpi .k{font-family:'Space Grotesk',sans-serif;font-size:28px;font-weight:700;letter-spacing:-.02em;display:block}
.kpi .l{color:var(--muted);font-size:12.5px;margin-top:2px;display:flex;align-items:center;gap:6px}
.kpi .dot{width:8px;height:8px;border-radius:50%;display:inline-block}
.kpi.blue .k{color:var(--bluet)}.kpi.red .k{color:var(--red)}.kpi.amber .k{color:var(--amber)}.kpi.green .k{color:var(--green)}
/* chart grid */
.charts{display:grid;grid-template-columns:320px 1fr;gap:16px;margin-bottom:26px}
.chartcard{background:linear-gradient(180deg,var(--panel),var(--panel-grad));border:1px solid var(--line);border-radius:var(--rad);padding:18px 20px;box-shadow:var(--shadow)}
.chartcard h2{margin-bottom:14px}
.chartwrap{position:relative;height:230px}
@media(max-width:760px){.charts{grid-template-columns:1fr}}
/* dashboard domain cards */
.cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:18px;margin-top:8px}
.dcard{background:linear-gradient(180deg,var(--panel),var(--bg2));border:1px solid var(--line);border-radius:var(--rad);padding:22px;box-shadow:var(--shadow)}
.dname{font-family:'Space Grotesk',sans-serif;font-weight:600;font-size:18px}
.dmeta{color:var(--green);font-size:12.5px;margin-top:4px}
.dstatrow{display:flex;gap:24px;margin:18px 0}
.dstat .num{font-family:'Space Grotesk',sans-serif;font-size:26px;font-weight:700;display:block}
.dstat .lbl{color:var(--muted);font-size:12px}
/* toolbar (search) */
.toolbar{display:flex;gap:10px;align-items:center;margin:18px 0 12px;flex-wrap:wrap}
.select-filter{background:var(--inp);border:1px solid var(--line2);border-radius:9px;padding:10px 12px;color:var(--txt);font-size:14px;font-family:inherit;color-scheme:dark}
.select-filter:focus{outline:none;border-color:var(--blue)}
.select-filter option{background:var(--panel);color:var(--txt)}
.search{flex:1;min-width:200px;position:relative}
.search input{width:100%;background:var(--inp);border:1px solid var(--line2);border-radius:9px;padding:10px 12px 10px 36px;color:var(--txt);font-size:14px;font-family:inherit}
.search input:focus{outline:none;border-color:var(--blue)}
.search svg{position:absolute;left:11px;top:50%;transform:translateY(-50%);opacity:.5}
.count{color:var(--dim);font-size:13px;white-space:nowrap}
/* table */
.tablewrap{overflow-x:auto;border:1px solid var(--line);border-radius:var(--rad)}
.qtable{width:100%;border-collapse:collapse;font-size:13px;background:var(--panel);min-width:760px;border-left:1px solid var(--line);border-right:1px solid var(--line)}
.qtable th{background:var(--th);color:var(--muted);text-align:left;padding:11px 12px;font-weight:600;position:sticky;top:0;border-right:1px solid var(--line)}
.qtable td{padding:9px 12px;border-top:1px solid var(--line);border-right:1px solid var(--line)}
.qtable th:last-child, .qtable td:last-child{border-right:0}
.qtable tbody tr.even{background:var(--zebra)}
.qtable tbody tr:hover{background:color-mix(in srgb,var(--blue) 7%,transparent)}
.qtable .nw{white-space:nowrap;color:var(--muted)}
.trunc{max-width:170px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.trunc.wide{max-width:400px}
.sender-cell{max-width:320px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.score{background:color-mix(in srgb,var(--red) 18%,transparent);color:var(--badge-txt-red);font-size:12px;padding:2px 8px;border-radius:10px;white-space:nowrap}
.score.low{background:color-mix(in srgb,var(--amber) 18%,transparent);color:var(--badge-txt-amber)}
/* action badges – einzeilig */
.acts{display:flex;flex-direction:column;gap:5px;width:100%;align-items:stretch}
.inl{display:block;width:100%}
.qb{font-size:12px;border:0;border-radius:7px;padding:6px 12px;cursor:pointer;font-family:inherit;font-weight:500;display:block;width:100%;text-align:center;box-sizing:border-box}
.qb.preview{background:color-mix(in srgb,var(--blue) 12%,transparent);color:var(--badge-txt-blue)}
.qb.deliver{background:color-mix(in srgb,var(--green) 18%,transparent);color:var(--badge-txt-green)}
.qb.whitelist{background:color-mix(in srgb,var(--blue) 18%,transparent);color:var(--badge-txt-blue)}
.qb.blacklist{background:color-mix(in srgb,var(--red) 18%,transparent);color:var(--badge-txt-red)}
.qb.delete{background:var(--inp);color:var(--muted)}
.qb:hover{filter:brightness(1.15)}
/* filter lists */
.fl-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-top:18px}
@media(max-width:680px){.fl-grid{grid-template-columns:1fr}}
.fl-col h2{display:flex;align-items:center;gap:8px;margin-bottom:10px}
.fl-list{list-style:none;display:flex;flex-direction:column;gap:6px}
.fl-list li{display:flex;justify-content:space-between;align-items:center;background:var(--inp);border:1px solid var(--line);border-radius:8px;padding:8px 12px;font-size:13px}
.fl-list .rm{color:var(--red);background:none;border:0;cursor:pointer;font-size:16px;line-height:1}
.fl-add{display:flex;gap:8px;margin-top:10px}
.fl-add input{flex:1;background:var(--inp);border:1px solid var(--line2);border-radius:8px;padding:8px 11px;color:var(--txt);font-size:13px;font-family:inherit}
.pick{display:flex;gap:8px;align-items:center;margin-top:6px;flex-wrap:wrap}
.pick select,.pick input{background:var(--inp);border:1px solid var(--line2);border-radius:8px;padding:9px 11px;color:var(--txt);font-size:14px;font-family:inherit;color-scheme:dark}
.pick select option{background:var(--panel);color:var(--txt)}
@media(max-width:640px){.topbar nav{gap:11px}.who{display:none}}

/* Inline Preview Styles */
.prev-cell {
  background: var(--bg2) !important;
  padding: 16px !important;
  border-top: 0 !important;
}
.prev-container {
  border: 1px solid var(--line2);
  border-radius: 8px;
  overflow: hidden;
  background: #fff;
  display: flex;
  flex-direction: column;
  height: 380px;
  box-shadow: inset 0 2px 8px rgba(0,0,0,0.1);
}
.prev-loading {
  padding: 30px;
  text-align: center;
  color: var(--muted);
  background: var(--panel);
  font-size: 14px;
  font-weight: 500;
  display: flex;
  align-items: center;
  justify-content: center;
  height: 100%;
}
.prev-content {
  display: flex;
  flex-direction: column;
  height: 100%;
}
.prev-meta-info {
  background: var(--panel2);
  border-bottom: 1px solid var(--line2);
  padding: 10px 16px;
  font-size: 12.5px;
  color: var(--muted);
  display: flex;
  flex-wrap: wrap;
  gap: 4px 12px;
}
.prev-meta-info strong {
  color: var(--txt);
}
.prev-iframe {
  flex: 1;
  border: 0;
  width: 100%;
  height: 100%;
  background: #fff;
}

