/* ============ Kleinanzeigen Tool · Dashboard — Hell & frisch (KA-Grün) ============ */
@font-face{font-family:'Hanken';src:url('/fonts/hanken.woff2') format('woff2');font-weight:350 800;font-display:swap}

:root{
  --bg:#f5f8f4; --surface:#ffffff; --surface2:#f0f4ee; --raise:#e9efe6;
  --line:#e3e9df; --line2:#d4ddce;
  --ink:#1b231d; --muted:#5d6b5f; --faint:#8a978c;
  --green:#16a34a; --green2:#22b85a; --greend:#0f7d38; --soft:#e8f6ec;
  --amber:#e08a16; --red:#dc4332;
  --radius:16px; --shadow:0 6px 20px rgba(22,60,30,.08),0 1px 3px rgba(0,0,0,.04);
  --shadow-lg:0 18px 44px rgba(22,60,30,.16);
}
*{box-sizing:border-box}
html,body{margin:0}
[hidden]{display:none!important} /* sonst überschreibt .gate{display:flex} das hidden-Attribut */
body{color:var(--ink);min-height:100vh;display:flex;flex-direction:column;
  font:15px/1.55 'Hanken',system-ui,-apple-system,sans-serif;background:var(--bg)}
h1{font-weight:800;font-size:28px;margin:0 0 .3em;letter-spacing:-.015em}
h2{font-weight:800;font-size:17px;margin:0}
.muted{color:var(--muted)} .center{text-align:center}
b{color:var(--ink)}

/* Buttons */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;cursor:pointer;border:1px solid transparent;
  font:700 14px 'Hanken';border-radius:11px;padding:11px 18px;transition:.16s;color:var(--ink)}
.btn.solid{background:var(--green);color:#fff;box-shadow:0 6px 16px rgba(22,163,74,.26)}
.btn.solid:hover{background:var(--greend);transform:translateY(-1px)}
.btn.ghost{background:var(--surface);border-color:var(--line2)}
.btn.ghost:hover{background:var(--surface2)}
input{font:inherit;background:var(--surface);border:1px solid var(--line);color:var(--ink);border-radius:11px;padding:11px 14px;width:100%}
input:focus{outline:none;border-color:var(--green);box-shadow:0 0 0 4px rgba(22,163,74,.1)}

/* Header */
.top{display:flex;align-items:center;gap:1.6rem;padding:14px 22px;border-bottom:1px solid var(--line);
  background:var(--surface);position:sticky;top:0;z-index:10}
.brand{display:flex;align-items:center;gap:12px}
.brand .logo{line-height:0;filter:drop-shadow(0 4px 10px rgba(22,163,74,.26))}
.brand .logo img{width:38px;height:38px;border-radius:10px;border:1px solid rgba(15,125,56,.2)}
.brand-txt strong{font-weight:800;font-size:18px;display:block}
.seal{font-size:11.5px;font-weight:700;color:var(--greend);background:var(--soft);border:1px solid #cfebd6;border-radius:999px;padding:2px 9px;display:inline-block;margin-top:2px}
.tabs{display:flex;gap:4px;margin-left:auto;padding:4px;background:var(--surface2);border:1px solid var(--line);border-radius:12px;flex-wrap:wrap}
.tabs button{background:transparent;border:0;color:var(--muted);font:700 13px 'Hanken';padding:8px 15px;border-radius:9px;cursor:pointer;transition:.16s}
.tabs button.active{background:var(--surface);color:var(--ink);box-shadow:var(--shadow)}

main{flex:1;width:100%;max-width:1060px;margin:0 auto;padding:1.6rem 1.2rem}
.foot{text-align:center;padding:1.6rem;color:var(--faint);font-size:13px}
.foot b{color:var(--green)}

.card{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:1.3rem;margin-bottom:1.3rem;box-shadow:var(--shadow)}
.card-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:1rem}
.card-head.row{gap:1rem;flex-wrap:wrap}

/* Gate */
.gate{display:flex;justify-content:center;padding:3rem 1rem}
.gate-card{max-width:480px;width:100%;text-align:center;background:var(--surface);border:1px solid var(--line);border-radius:22px;padding:2.4rem 2rem;box-shadow:var(--shadow-lg)}
.gate-badge{width:56px;height:56px;margin:0 auto 1rem;border-radius:16px;display:grid;place-items:center;font-size:28px;background:var(--soft);border:1px solid #cfebd6}
.field{display:flex;gap:.6rem;margin:1.3rem 0 .6rem}
.msg{min-height:1.2em;font-size:14px}.msg.err{color:var(--red)}.msg.ok{color:var(--green)}

.pill{display:inline-grid;place-items:center;min-width:1.9em;height:1.9em;padding:0 .55em;border-radius:999px;background:var(--green);color:#fff;font-size:.8rem;font-weight:800}

/* KPIs */
.kpis{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem;margin-bottom:1.3rem}
.kpi{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:1.3rem 1rem;text-align:center;box-shadow:var(--shadow)}
.kpi-val{display:block;font-weight:800;font-size:2.1rem;line-height:1;color:var(--green);font-feature-settings:'tnum'}
.kpi-lbl{color:var(--muted);font-size:.85rem;margin-top:.3rem;display:block}

/* Lager grid */
.search{max-width:280px}
.grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:1rem}
.item{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;display:flex;flex-direction:column;box-shadow:var(--shadow);transition:.16s}
.item:hover{transform:translateY(-3px);box-shadow:var(--shadow-lg)}
.item .thumb{aspect-ratio:4/3;background:var(--surface2) center/cover no-repeat;display:grid;place-items:center;color:var(--faint)}
.item .body{padding:.8rem .9rem;display:flex;flex-direction:column;gap:.35rem;flex:1}
.item .t{font-weight:700;line-height:1.25;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.item .price{font-weight:800;color:var(--green)}
.item .row{display:flex;gap:.4rem;margin-top:auto}
.item .row button{flex:1;font-size:.82rem;padding:.5em;background:var(--surface2);border:1px solid var(--line);color:var(--ink);border-radius:9px;cursor:pointer}
.item .row button:hover{background:var(--raise)}

/* Tabelle */
.tbl{width:100%;border-collapse:collapse}
.tbl th,.tbl td{padding:.7rem .7rem;border-bottom:1px solid var(--line);text-align:left}
.tbl th{color:var(--muted);font-weight:700;font-size:.85rem}
.tbl th.num,.tbl td.num{text-align:right;font-variant-numeric:tabular-nums}
.tbl td a{color:var(--greend);text-decoration:none;font-weight:600}.tbl td a:hover{text-decoration:underline}
.tbl tbody tr:hover{background:var(--surface2)}
.badge{padding:.18em .65em;border-radius:999px;font-size:.78rem;font-weight:700}
.badge.active{background:var(--soft);color:var(--greend)}
.badge.paused{background:#fdf0db;color:var(--amber)}
.badge.expired{background:#fdeceA;color:var(--red)}

/* Listen */
.list{list-style:none;margin:0;padding:0}
.list li{display:flex;justify-content:space-between;gap:1rem;padding:.7rem 0;border-bottom:1px solid var(--line)}
.list li:last-child{border-bottom:0}
.kv{display:grid;grid-template-columns:auto 1fr;gap:.6rem 1.6rem;margin:0 0 1.1rem}
.kv dt{color:var(--muted)} .kv dd{margin:0}

@media(max-width:680px){.kpis{grid-template-columns:repeat(2,1fr)}.top{flex-wrap:wrap}.tabs{width:100%;order:3;margin-left:0}}
