:root{
  --brand:#ad0018; --ink:#111827; --ink-2:#374151; --ink-3:#6b7280; --ink-4:#9ca3af;
  --line:#e5e7eb; --bg:#f3f4f6; --card:#ffffff; --blue:#1d4ed8;
}
*{box-sizing:border-box}
body{margin:0;font-family:'Montserrat',-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,Helvetica,Arial,sans-serif;
  background:var(--bg);color:var(--ink);line-height:1.5}
a{color:var(--brand)}

/* Überschriften & Titel: Oswald */
h1,h2,h3,.brand,.login-title,.kpi-value{
  font-family:'Oswald','Montserrat',sans-serif;letter-spacing:.01em}
.kpi-label,.data-table th{font-family:'Oswald',sans-serif}

/* ── Login ── */
.login-page{display:flex;align-items:center;justify-content:center;min-height:100vh;
  background:linear-gradient(135deg,#ad0018,#7a0011)}
.login-box{background:var(--card);border-radius:18px;padding:36px 34px;width:380px;max-width:92vw;
  box-shadow:0 20px 60px rgba(0,0,0,.35)}
.login-brand{text-align:center;margin-bottom:24px}
.login-logo{font-size:40px}
.login-logo-img{height:54px;width:auto;margin-bottom:10px}
.login-title{font-size:22px;font-weight:800;margin-top:6px}
.login-sub{color:var(--ink-3);font-size:13px}
.login-box form{display:flex;flex-direction:column;gap:14px}
.login-box label{font-size:13px;font-weight:600;color:var(--ink-2);display:flex;flex-direction:column;gap:5px}
.login-box input{padding:11px 13px;border:1px solid var(--line);border-radius:10px;font-size:15px}
.login-box input:focus{outline:none;border-color:var(--brand)}
.btn-primary{background:var(--brand);color:#fff;border:none;padding:12px;border-radius:10px;
  font-size:15px;font-weight:700;cursor:pointer;transition:opacity .15s}
.btn-primary:hover{opacity:.9}
.login-footer{margin-top:20px;text-align:center;font-size:12px;color:var(--ink-3)}
.login-legal{margin-top:12px;display:flex;gap:8px;justify-content:center;align-items:center}
.login-legal a{color:var(--ink-3);text-decoration:none}
.login-legal a:hover{color:var(--brand);text-decoration:underline}
.login-legal span{color:var(--ink-4)}
.alert-error{background:#fee2e2;color:#b91c1c;padding:10px 14px;border-radius:10px;font-size:13px;margin-bottom:16px}

/* ── Topbar ── */
.topbar{background:var(--card);border-bottom:1px solid var(--line)}
.topbar-inner{max-width:1100px;margin:0 auto;padding:14px 22px;display:flex;align-items:center;justify-content:space-between}
.brand{font-weight:700;font-size:18px;display:flex;align-items:center;gap:10px}
.brand-logo{height:32px;width:auto}
.brand-sub{font-weight:500;color:var(--ink-3);font-size:13px;margin-left:6px}
.user{display:flex;align-items:center;gap:14px;font-size:14px}
.logout{color:var(--ink-3);text-decoration:none;font-weight:600}
.logout:hover{color:var(--brand)}

/* ── Layout ── */
.wrap{max-width:1100px;margin:0 auto;padding:28px 22px 60px}
h1{font-size:24px;margin:0 0 4px}
h2{font-size:16px;margin:0}
.muted{color:var(--ink-3)}

.kpi-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:14px;margin:24px 0}
.kpi{background:var(--card);border:1px solid var(--line);border-radius:14px;padding:18px 20px}
.kpi-label{font-size:12px;color:var(--ink-3);font-weight:600;text-transform:uppercase;letter-spacing:.04em}
.kpi-value{font-size:30px;font-weight:800;margin-top:6px;letter-spacing:-.02em}

.card{background:var(--card);border:1px solid var(--line);border-radius:14px;padding:20px 22px;margin-bottom:18px}
.card-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px}
.card-head select{padding:7px 11px;border:1px solid var(--line);border-radius:9px;font-size:13px}

.data-table{width:100%;border-collapse:collapse;font-size:14px;margin-top:10px}
.data-table th{text-align:left;font-size:11px;text-transform:uppercase;letter-spacing:.04em;
  color:var(--ink-3);padding:8px 10px;border-bottom:2px solid var(--line)}
.data-table td{padding:11px 10px;border-bottom:1px solid var(--line)}
.data-table .num{text-align:right;font-variant-numeric:tabular-nums}
.data-table tr:last-child td{border-bottom:none}

.empty{text-align:center;padding:48px;color:var(--ink-3)}
.empty-icon{font-size:40px;margin-bottom:12px}

.footer-note{margin-top:26px;font-size:12px;color:var(--ink-4);text-align:center}

/* ── Anzeigen-Karten (Vorschau + Position) ── */
.ad-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:16px;margin-top:6px}
.ad-card{border:1px solid var(--line);border-radius:13px;overflow:hidden;background:var(--card);
  display:flex;flex-direction:column;transition:box-shadow .15s}
.ad-card:hover{box-shadow:0 6px 24px rgba(0,0,0,.08)}
.ad-preview{background:#0f172a;display:flex;align-items:center;justify-content:center;
  min-height:120px;max-height:180px;overflow:hidden}
.ad-preview img{width:100%;height:auto;max-height:180px;object-fit:contain;display:block}
.ad-noimg{color:#64748b;font-size:13px;text-align:center;padding:30px}
.ad-noimg span{font-size:11px;opacity:.7}
.ad-body{padding:14px 16px}
.ad-title{font-family:'Oswald',sans-serif;font-weight:600;font-size:15px;line-height:1.2;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.ad-pos{display:inline-flex;align-items:center;gap:5px;font-size:12px;font-weight:600;color:#fff;
  background:var(--brand);padding:3px 9px;border-radius:20px;margin-top:8px}
.ad-runtime{font-size:11.5px;color:var(--ink-3);margin-top:8px}
.ad-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin-top:14px;
  padding-top:12px;border-top:1px solid var(--line)}
.ad-stats>div{text-align:center}
.ad-stats .n{display:block;font-family:'Oswald',sans-serif;font-weight:600;font-size:18px;line-height:1}
.ad-stats .l{display:block;font-size:10px;color:var(--ink-3);text-transform:uppercase;letter-spacing:.03em;margin-top:3px}
