: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}

/* ── Immobilien-Portal Erweiterungen ── */
.page-head{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:14px;margin-bottom:20px}
.btn-primary.inline{display:inline-flex;align-items:center;gap:7px;width:auto;padding:10px 18px;text-decoration:none;font-size:14px}
.btn-ghost{display:inline-flex;align-items:center;gap:6px;background:var(--card);border:1px solid var(--line);
  color:var(--ink-2);padding:8px 14px;border-radius:9px;font-size:13px;font-weight:600;cursor:pointer;text-decoration:none}
.btn-ghost:hover{background:var(--bg)}
.btn-danger{color:#dc2626;border-color:#fca5a5}

.immo-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(290px,1fr));gap:16px}
.immo-card{background:var(--card);border:1px solid var(--line);border-radius:14px;overflow:hidden;display:flex;flex-direction:column}
.immo-card-img{height:170px;background:#e5e7eb center/cover no-repeat;position:relative}
.immo-card-img .noimg{display:flex;align-items:center;justify-content:center;height:100%;color:var(--ink-4);font-size:13px}
.immo-badge{position:absolute;top:10px;left:10px;font-size:11px;font-weight:700;padding:3px 10px;border-radius:20px;color:#fff}
.immo-badge.active{background:#16a34a}.immo-badge.pending{background:#d97706}.immo-badge.expired{background:#dc2626}
.immo-card-body{padding:14px 16px;flex:1;display:flex;flex-direction:column}
.immo-card-title{font-family:'Oswald',sans-serif;font-weight:600;font-size:16px;line-height:1.2;margin-bottom:6px}
.immo-card-meta{font-size:12.5px;color:var(--ink-3);margin-bottom:10px}
.immo-card-price{font-family:'Oswald',sans-serif;font-weight:600;font-size:20px;color:var(--brand);margin-top:auto}
.immo-card-actions{display:flex;gap:8px;padding:12px 16px;border-top:1px solid var(--line)}

.form-card{background:var(--card);border:1px solid var(--line);border-radius:14px;padding:24px;max-width:760px}
.form-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:16px;margin-bottom:16px}
.form-field{display:flex;flex-direction:column;gap:5px}
.form-field label{font-size:12.5px;font-weight:600;color:var(--ink-2)}
.form-field input,.form-field select,.form-field textarea{padding:9px 12px;border:1px solid var(--line);
  border-radius:9px;font-size:14px;font-family:inherit;background:#fff;color:var(--ink)}
.form-field input:focus,.form-field select:focus,.form-field textarea:focus{outline:none;border-color:var(--brand)}
.form-field textarea{min-height:120px;resize:vertical}
.form-section{font-family:'Oswald',sans-serif;font-size:15px;font-weight:600;margin:22px 0 4px;color:var(--ink)}
.upload-zone{border:2px dashed var(--line);border-radius:12px;padding:24px;text-align:center;cursor:pointer;color:var(--ink-3)}
.upload-zone:hover{border-color:var(--brand);color:var(--brand)}
.upload-preview{max-height:180px;border-radius:10px;margin-top:10px}
.form-actions{display:flex;gap:10px;margin-top:24px}
.pending-note{background:#fef9c3;border:1px solid #fde68a;color:#854d0e;font-size:13px;padding:10px 14px;border-radius:10px;margin-bottom:18px}
.status-pill{font-size:11px;font-weight:700;padding:2px 9px;border-radius:20px;color:#fff}
.status-pill.active{background:#16a34a}.status-pill.pending{background:#d97706}.status-pill.expired{background:#dc2626}

/* ── Galerie im Formular ── */
.gallery-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(130px,1fr));gap:10px;margin-bottom:12px}
.gallery-item{position:relative;border-radius:10px;overflow:hidden;border:1px solid var(--line);aspect-ratio:4/3;background:#f3f4f6}
.gallery-item img{width:100%;height:100%;object-fit:cover;display:block}
.gallery-item.is-main{border:2px solid var(--brand)}
.gallery-main-badge{position:absolute;top:6px;left:6px;background:var(--brand);color:#fff;font-size:10px;font-weight:700;padding:2px 7px;border-radius:20px}
.gallery-item-actions{position:absolute;bottom:6px;right:6px;display:flex;gap:4px}
.gallery-item-actions button{width:28px;height:28px;border:none;border-radius:7px;background:rgba(255,255,255,.92);cursor:pointer;font-size:13px;display:flex;align-items:center;justify-content:center;box-shadow:0 1px 4px rgba(0,0,0,.2)}
.gallery-item-actions button:hover{background:#fff}
.gallery-item-actions button.del:hover{background:#fee2e2}
