:root{
  --bg:#0b0c10; --card:rgba(255,255,255,.035); --line:rgba(255,255,255,.10);
  --text:#e8e8ea; --muted:rgba(232,232,234,.72); --pill:rgba(255,255,255,.06);
  --btn:rgba(255,255,255,.10); --btn2:transparent;
  --danger:#c33; --ok:#2a7;
}
@media (prefers-color-scheme: light){
  :root{
    --bg:#f6f7fb; --card:#ffffff; --line:#e6e8f0;
    --text:#111217; --muted:#555b70; --pill:#eef0f6;
    --btn:#eef0f6; --btn2:transparent;
    --danger:#b22; --ok:#186;
  }
}
[data-theme="dark"]{
  --bg:#0b0c10; --card:rgba(255,255,255,.035); --line:rgba(255,255,255,.10);
  --text:#e8e8ea; --muted:rgba(232,232,234,.72); --pill:rgba(255,255,255,.06);
  --btn:rgba(255,255,255,.10); --btn2:transparent;
}
[data-theme="light"]{
  --bg:#f6f7fb; --card:#ffffff; --line:#e6e8f0;
  --text:#111217; --muted:#555b70; --pill:#eef0f6;
  --btn:#eef0f6; --btn2:transparent;
}
*{box-sizing:border-box}
body{margin:0;font-family:system-ui,-apple-system,Segoe UI,Roboto,sans-serif;background:var(--bg);color:var(--text)}
a{color:inherit}
code{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,monospace}

.container{max-width:1100px;margin:0 auto;padding:22px}
.topbar{
  display:flex;align-items:center;justify-content:space-between;gap:14px;
  padding:14px 22px;position:sticky;top:0;
  background:color-mix(in srgb, var(--bg) 92%, transparent);
  backdrop-filter: blur(8px);
  border-bottom:1px solid var(--line)
}
.brand{display:flex;align-items:center;gap:10px;text-decoration:none;font-weight:800;letter-spacing:.2px}
.nav{display:flex;gap:12px;align-items:center}
.nav a{text-decoration:none;opacity:.9}
.nav a:hover{opacity:1}
.toggle{cursor:pointer;border:1px solid var(--line);background:var(--btn);border-radius:999px;padding:6px 10px;font-size:12px}

.hero{
  border:1px solid var(--line);background:var(--card);border-radius:18px;padding:18px;
  display:grid;grid-template-columns:1.35fr .65fr;gap:18px
}
.hero h1{margin:0 0 6px;font-size:28px}
.muted{color:var(--muted)}
.badges{display:flex;gap:8px;flex-wrap:wrap;margin-top:10px}
.badge{
  font-size:12px;padding:6px 10px;border-radius:999px;background:var(--pill);
  border:1px solid color-mix(in srgb, var(--line) 80%, transparent)
}
.actions{display:flex;gap:10px;flex-wrap:wrap;margin-top:14px}
.button{padding:10px 14px;border-radius:12px;background:var(--btn);border:1px solid var(--line);text-decoration:none;display:inline-block}
.button.secondary{background:var(--btn2)}
.grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin-top:18px}

.card{border:1px solid var(--line);background:var(--card);border-radius:18px;padding:16px}
.card h3{margin:0 0 6px;font-size:16px}
.card .meta{display:flex;gap:8px;flex-wrap:wrap;margin-top:10px}
.card .meta .badge{padding:5px 9px}

.cardlink{display:block;text-decoration:none}
.cardlink:hover .card{border-color:color-mix(in srgb, var(--line) 140%, transparent)}
.kicker{margin:0 0 8px;color:var(--muted);font-weight:600}
.section{margin-top:18px}

.table{display:grid;gap:6px;margin-top:10px}
.row{
  display:grid;
  grid-template-columns:180px 1fr;
  gap:10px;padding:10px;border-radius:14px;
  border:1px solid color-mix(in srgb, var(--line) 70%, transparent);
  background:color-mix(in srgb, var(--card) 80%, transparent)
}
.row.head{font-weight:800;background:color-mix(in srgb, var(--card) 95%, transparent)}

.media{display:flex;flex-direction:column;gap:10px;align-items:flex-end}
.media .logo{max-width:180px;max-height:90px;object-fit:contain}
.media .heroimg{width:100%;max-height:220px;object-fit:cover;border-radius:16px;border:1px solid var(--line)}
.footer{margin:26px 0 10px;color:var(--muted);font-size:13px}

form label{display:grid;gap:6px;font-weight:600}
input,select,button,textarea{width:100%;padding:10px;border-radius:10px;border:1px solid var(--line);background:transparent;color:var(--text)}
button{background:var(--btn);cursor:pointer;font-weight:700}
textarea{min-height:280px}
hr{border:none;border-top:1px solid var(--line)}

@media (max-width: 920px){
  .hero{grid-template-columns:1fr}
  .grid{grid-template-columns:1fr}
}

/* Status colors */
.status{font-weight:800}
.status-ausschreibung{
  background: color-mix(in srgb, #3b82f6 22%, var(--pill));
  border-color: color-mix(in srgb, #3b82f6 45%, var(--line));
}
.status-meldeschluss{
  background: color-mix(in srgb, #f59e0b 22%, var(--pill));
  border-color: color-mix(in srgb, #f59e0b 45%, var(--line));
}
.status-ergebnisse{
  background: color-mix(in srgb, #10b981 22%, var(--pill));
  border-color: color-mix(in srgb, #10b981 45%, var(--line));
}

/* Footer */
.sitefooter{border-top:1px solid var(--line); margin-top:28px; padding:18px 0; background:color-mix(in srgb, var(--bg) 92%, transparent)}
.footerinner{display:flex;justify-content:space-between;gap:14px;align-items:flex-start}
.footerright{text-align:right}

/* Highlight today (green accent) */
.card.today{
  border-color: color-mix(in srgb, #10b981 60%, var(--line));
  background: color-mix(in srgb, #10b981 12%, var(--card));
}
.bigcard{grid-column:1/-1}
.bigcard .card h3{font-size:20px}
.bigcard .card{padding:18px}


/* Streckenübersicht chips */
.chips{display:flex;flex-wrap:wrap;gap:8px}
.chip{
  border:1px solid var(--line);
  background:var(--pill);
  border-radius:999px;
  padding:7px 10px;
  font-size:12px;
  cursor:default;
  transition: transform .08s ease, border-color .08s ease, background .08s ease;
}
.chip:hover{
  border-color: color-mix(in srgb, #10b981 55%, var(--line));
  background: color-mix(in srgb, #10b981 18%, var(--pill));
  transform: translateY(-1px);
}

/* Ort + Meldeadresse layout */
.twocol{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-top:18px}
@media (max-width: 920px){ .twocol{grid-template-columns:1fr} }
