@import url('https://fonts.googleapis.com/css2?family=Anton&family=Barlow:wght@400;600;700&display=swap');

:root{
  /* Vereinsfarben aus dem Logo: Rot #dd1411 · Weiss · Gold #b49d2f (fuer Text leicht aufgehellt) */
  --asphalt:#181112;
  --card:#221a1b;
  --card2:#2a1f20;
  --chalk:#f1ece0;
  --chalk-dim:rgba(241,236,224,.62);
  --line:rgba(241,236,224,.16);
  --ball:#dd1411;
  --ball-soft:rgba(221,20,17,.14);
  --gold:#c9ae35;
  --danger:#ff6b6b;
}
*{box-sizing:border-box;margin:0;padding:0}
body{
  background:
    radial-gradient(120% 60% at 50% -10%, rgba(221,20,17,.08), transparent 60%),
    repeating-linear-gradient(115deg, rgba(255,255,255,.012) 0 2px, transparent 2px 7px),
    var(--asphalt);
  color:var(--chalk);
  font-family:'Barlow', system-ui, sans-serif;
  font-variant-numeric:tabular-nums;
  min-height:100vh;
}
.app{max-width:680px;margin:0 auto;padding-bottom:28px}
a{color:var(--ball)}

/* ---- Kopf ---- */
.head{position:relative;overflow:hidden;padding:18px 16px 14px;border-bottom:2px solid var(--line)}
.head-arc{position:absolute;left:50%;top:-190px;transform:translateX(-50%);width:420px;height:420px;border-radius:50%;border:2px dashed rgba(221,20,17,.4);pointer-events:none}
.head-top{display:flex;justify-content:space-between;align-items:center;position:relative;gap:10px;flex-wrap:wrap}
.tag{font-size:.7rem;letter-spacing:.14em;text-transform:uppercase;color:var(--chalk-dim)}
.title{
  font-family:'Anton','Arial Narrow',Impact,sans-serif;
  font-size:clamp(1.9rem, 8vw, 3rem);
  letter-spacing:.03em;line-height:1.02;margin-top:6px;position:relative;
  text-transform:uppercase;text-shadow:3px 3px 0 rgba(221,20,17,.35);
}
.head-sub{position:relative;margin-top:6px;font-size:.8rem;color:var(--chalk-dim)}

/* ---- Sprungleiste ---- */
.toolbar{
  position:sticky;top:0;z-index:20;display:flex;flex-wrap:wrap;
  background:rgba(22,20,16,.94);backdrop-filter:blur(4px);
  border-bottom:2px solid var(--line);
}
.toolbar a{
  flex:1;min-width:80px;text-align:center;padding:13px 6px;text-decoration:none;
  color:var(--chalk-dim);
  font-family:'Anton','Arial Narrow',Impact,sans-serif;
  font-size:.9rem;letter-spacing:.08em;text-transform:uppercase;
  border-bottom:3px solid transparent;
}
.toolbar a:hover,.toolbar a.on{color:var(--ball);border-bottom-color:var(--ball)}

.content{padding:14px 12px;display:flex;flex-direction:column;gap:12px}
.section-title{
  font-family:'Anton',Impact,sans-serif;font-size:1.2rem;letter-spacing:.08em;
  text-transform:uppercase;margin:10px 2px 0;display:flex;align-items:center;gap:10px;
  scroll-margin-top:70px;
}
.section-title::after{content:"";flex:1;border-top:2px dashed rgba(221,20,17,.4)}

/* ---- Cards ---- */
.card{background:var(--card);border:1.5px solid var(--line);border-radius:6px;padding:14px;display:flex;flex-direction:column;gap:10px}
.card.accent{border-color:rgba(221,20,17,.35)}
.card-title{
  font-family:'Anton','Arial Narrow',Impact,sans-serif;font-size:1.05rem;letter-spacing:.07em;
  text-transform:uppercase;padding-bottom:6px;border-bottom:1.5px dashed var(--line);
}
.hint{font-size:.78rem;color:var(--chalk-dim);line-height:1.45}
.hint.center{text-align:center;padding:0 8px}
.info{font-size:.92rem}
.error{color:var(--danger);font-weight:600;padding:10px 12px;border:1.5px solid var(--danger);border-radius:4px;background:rgba(255,82,82,.08)}
.ok-msg{color:#8fd694;font-weight:600;padding:10px 12px;border:1.5px solid rgba(143,214,148,.5);border-radius:4px;background:rgba(143,214,148,.08)}
.empty{color:var(--chalk-dim);font-size:.9rem}

/* ---- Formulare & Buttons ---- */
input[type=text],input[type=password],input[type=number],input[type=time],select{
  padding:11px 12px;border-radius:4px;background:var(--asphalt);
  border:1.5px solid var(--line);color:var(--chalk);font-size:1rem;font-family:inherit;
}
input:focus,select:focus{outline:2px solid var(--ball);outline-offset:1px;border-color:transparent}
select{appearance:none}
label{font-size:.75rem;letter-spacing:.1em;text-transform:uppercase;color:var(--chalk-dim)}
.field{display:flex;flex-direction:column;gap:6px}
.row{display:flex;gap:8px;flex-wrap:wrap;align-items:center}
.row > input[type=text]{flex:1;min-width:140px}
.grid2{display:grid;grid-template-columns:1fr 1fr;gap:10px}
@media(max-width:480px){.grid2{grid-template-columns:1fr}}

.btn{
  display:inline-block;border:1.5px solid var(--line);background:var(--card2);color:var(--chalk);
  padding:12px 16px;border-radius:4px;cursor:pointer;text-decoration:none;text-align:center;
  font-family:'Anton','Arial Narrow',Impact,sans-serif;font-size:.95rem;letter-spacing:.07em;text-transform:uppercase;
}
.btn:focus-visible{outline:2px solid var(--ball);outline-offset:2px}
.btn.primary{background:var(--ball);border-color:var(--ball);color:#fff}
.btn.primary[disabled]{opacity:.35;cursor:not-allowed}
.btn.ghost{background:transparent}
.btn.danger{background:transparent;border-color:var(--danger);color:var(--danger)}
.btn.wide{width:100%}
.btn.big{padding:16px;font-size:1.1rem}
.btn.small{padding:8px 12px;font-size:.8rem}
.btn.save{padding:0;width:52px;height:52px;font-size:1.2rem;flex:none}

/* ---- Teamliste (Admin) ---- */
.team-list{list-style:none;display:flex;flex-direction:column;gap:6px}
.team-row{display:flex;align-items:center;gap:10px;background:var(--card2);border:1px solid var(--line);border-radius:4px;padding:8px 10px}
.team-row form{display:flex;align-items:center;gap:8px}
.team-name{flex:1;font-weight:600;font-size:1rem;word-break:break-word}
.gsel{width:64px;text-align:center;font-weight:700}
.x-btn{background:none;border:none;color:var(--chalk-dim);font-size:1rem;cursor:pointer;padding:6px 8px}
.x-btn:hover{color:var(--danger)}

/* ---- Chips ---- */
.chips{display:flex;gap:6px;flex-wrap:wrap}
.chip{
  padding:8px 14px;border-radius:999px;font-weight:700;font-size:.82rem;text-decoration:none;
  background:transparent;border:1.5px solid var(--line);color:var(--chalk-dim);
}
.chip.on{border-color:var(--ball);color:var(--ball);background:var(--ball-soft)}

/* ---- Fortschritt ---- */
.progress{position:relative;height:30px;background:var(--card);border:1.5px solid var(--line);border-radius:4px;overflow:hidden}
.progress-bar{position:absolute;top:0;bottom:0;left:0;background:var(--ball-soft);border-right:2px solid var(--ball)}
.progress-label{position:relative;display:flex;align-items:center;justify-content:center;height:100%;font-size:.8rem;font-weight:700;letter-spacing:.05em}

/* ---- Spiel-Karte ---- */
.match{background:var(--card);border:1.5px solid var(--line);border-radius:6px;padding:10px 12px;display:flex;flex-direction:column;gap:8px;scroll-margin-top:70px}
.match.done{border-color:rgba(236,229,211,.3)}
.match.next{border-color:var(--ball);box-shadow:0 0 0 1px var(--ball) inset}
.match-side{display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.slot-no{
  font-family:'Anton',Impact,sans-serif;font-size:1.05rem;color:transparent;
  -webkit-text-stroke:1.2px var(--ball);letter-spacing:.05em;min-width:26px;
}
.badge{font-size:.68rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;padding:2px 7px;border-radius:3px;border:1px solid var(--line);color:var(--chalk-dim)}
.badge.court{border-color:rgba(221,20,17,.5);color:var(--ball)}
.badge.time{border-color:rgba(201,174,53,.5);color:var(--gold)}
.match-main{display:grid;grid-template-columns:1fr auto 1fr;align-items:center;gap:8px}
.m-team{font-weight:700;font-size:1rem;line-height:1.2;word-break:break-word}
.m-team.right{text-align:right}
.m-team .winner{color:var(--ball)}
.m-pending{color:var(--chalk-dim);font-weight:400;font-style:italic;font-size:.85rem}
.m-score{display:flex;align-items:center;gap:5px}
.m-score .res{font-family:'Anton',Impact,sans-serif;font-size:1.35rem;min-width:30px;text-align:center}
.colon{font-family:'Anton',Impact,sans-serif;font-size:1.3rem;color:var(--chalk-dim)}
.score-input{
  width:56px;height:52px;text-align:center;border-radius:4px;
  background:var(--asphalt);border:1.5px solid var(--line);color:var(--chalk);
  font-family:'Anton',Impact,sans-serif;font-size:1.4rem;
  -moz-appearance:textfield;
}
.score-input::-webkit-outer-spin-button,.score-input::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}
.score-input:disabled{opacity:.3}
.tie-warn{font-size:.75rem;color:var(--gold);border-top:1px dashed var(--line);padding-top:6px}

/* ---- Tabellen ---- */
.standings{width:100%;border-collapse:collapse;font-size:.88rem}
.standings th{text-align:center;font-size:.68rem;letter-spacing:.1em;text-transform:uppercase;color:var(--chalk-dim);padding:4px 3px;font-weight:600}
.standings td{text-align:center;padding:9px 3px;border-top:1px solid var(--line)}
.standings .tname{text-align:left;font-weight:700}
.standings .pos{width:26px;color:var(--chalk-dim)}
.standings .w{color:var(--ball);font-weight:700}
.standings tr.qual td{background:rgba(201,174,53,.09)}
.qdot{display:inline-block;width:8px;height:8px;border-radius:50%;background:var(--gold);margin-right:7px;vertical-align:middle}

/* ---- "Dein naechstes Spiel" ---- */
.next-panel{
  border:2px solid var(--ball);border-radius:6px;padding:16px 14px;text-align:center;
  background:radial-gradient(80% 120% at 50% 0%, rgba(221,20,17,.18), transparent 70%), var(--card);
}
.next-label{font-size:.72rem;letter-spacing:.2em;text-transform:uppercase;color:var(--chalk-dim)}
.next-big{font-family:'Anton',Impact,sans-serif;font-size:clamp(1.3rem,6vw,1.9rem);text-transform:uppercase;margin:6px 0;line-height:1.15}
.next-meta{font-size:.9rem;color:var(--chalk-dim);font-weight:600}

/* ---- Setzliste / K.O. ---- */
.seed-list{list-style:none;display:flex;flex-direction:column;gap:5px}
.seed-list li{display:flex;align-items:center;gap:6px;font-weight:600;font-size:.95rem;padding:7px 9px;background:var(--card2);border-radius:4px;border:1px solid var(--line)}
.seed-no{font-family:'Anton',Impact,sans-serif;color:transparent;-webkit-text-stroke:1px var(--ball);min-width:28px;font-size:1rem}
.mini-g{font-size:.7rem;font-weight:700;margin-left:auto;padding:1px 7px;border-radius:3px;border:1px solid var(--line);color:var(--chalk-dim)}

/* ---- Sieger-Banner ---- */
.champ{
  border:2px solid var(--gold);border-radius:6px;padding:20px 14px;text-align:center;
  background:radial-gradient(80% 120% at 50% 0%, rgba(201,174,53,.20), transparent 70%), var(--card);
  outline:2px dashed rgba(201,174,53,.45);outline-offset:5px;margin:6px 4px 10px;
}
.champ-label{font-size:.72rem;letter-spacing:.22em;text-transform:uppercase;color:var(--chalk-dim)}
.champ-name{
  font-family:'Anton',Impact,sans-serif;font-size:clamp(1.9rem,8vw,2.7rem);
  text-transform:uppercase;letter-spacing:.03em;color:var(--gold);margin:6px 0 8px;line-height:1.05;
  text-shadow:3px 3px 0 rgba(0,0,0,.45);
}
.podium{display:flex;justify-content:center;gap:18px;font-size:.9rem;font-weight:700;flex-wrap:wrap}

/* ---- Login ---- */
.login-box{max-width:360px;margin:40px auto;display:flex;flex-direction:column;gap:12px}

.foot{text-align:center;font-size:.72rem;color:var(--chalk-dim);padding:16px;opacity:.75}

/* ---- Vereinslogo im Kopf ---- */
.head-row{position:relative;display:flex;align-items:center;gap:14px;margin-top:8px}
.head-row .title{margin-top:0}
.logo{
  width:74px;height:74px;flex:none;object-fit:contain;
  background:#fff;border-radius:50%;padding:7px;
  border:2px solid var(--line);box-shadow:0 3px 0 rgba(0,0,0,.35);
}

/* ================================================
   Version 2: Board, Jetzt-Block, Stats, Hall of Fame
   ================================================ */

/* ---- Drag&Drop-Gruppenboard (Admin-Setup) ---- */
.board{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:10px}
.bcol{border:1.5px dashed var(--line);border-radius:6px;background:rgba(0,0,0,.15);display:flex;flex-direction:column;min-height:120px}
.bcol.over{border-color:var(--gold);background:rgba(201,174,53,.08)}
.bhead{display:flex;justify-content:space-between;align-items:center;padding:8px 10px;border-bottom:1.5px dashed var(--line);
  font-family:'Anton',Impact,sans-serif;font-size:.85rem;letter-spacing:.08em;text-transform:uppercase}
.bcount{font-family:'Barlow',sans-serif;font-weight:700;font-size:.75rem;color:var(--chalk-dim)}
.bzone{display:flex;flex-direction:column;gap:6px;padding:8px;flex:1}
.tchip{display:flex;align-items:center;gap:7px;background:var(--card2);border:1px solid var(--line);border-radius:4px;padding:6px 8px}
.tchip.dragging{opacity:.35}
.tchip-name{flex:1;font-weight:600;font-size:.92rem;word-break:break-word}
.grip{cursor:grab;touch-action:none;user-select:none;color:var(--chalk-dim);font-size:1rem;padding:4px 5px;line-height:1}
.grip:active{cursor:grabbing}
.tchip .gsel{width:52px;padding:6px 4px;font-size:.85rem}
.drag-ghost{position:fixed;z-index:999;pointer-events:none;opacity:.9;box-shadow:0 6px 18px rgba(0,0,0,.5);transform:rotate(-2deg)}

/* ---- "Jetzt auf dem Platz" ---- */
.now-card{border:2px solid var(--ball);border-radius:6px;padding:12px 14px;background:
  radial-gradient(90% 130% at 50% 0%, rgba(221,20,17,.14), transparent 70%), var(--card)}
.now-label{font-size:.7rem;letter-spacing:.2em;text-transform:uppercase;color:var(--ball);font-weight:700}
.now-row{display:flex;align-items:baseline;gap:8px;flex-wrap:wrap;padding:7px 0;border-bottom:1px dashed var(--line)}
.now-row:last-child{border-bottom:none}
.now-vs{font-family:'Anton',Impact,sans-serif;font-size:1.15rem;letter-spacing:.02em;text-transform:uppercase}
.now-meta{font-size:.75rem;color:var(--chalk-dim);font-weight:600}
.now-sub{font-size:.72rem;letter-spacing:.16em;text-transform:uppercase;color:var(--chalk-dim);margin-top:8px}
.countdown{color:var(--gold);font-weight:700}

/* ---- Team-Bilanz & Schiri ---- */
.badge.ref{border-color:rgba(201,174,53,.55);color:var(--gold)}
.mystats{display:grid;grid-template-columns:repeat(auto-fit,minmax(90px,1fr));gap:8px}
.mystat{background:var(--card2);border:1px solid var(--line);border-radius:4px;padding:8px;text-align:center}
.mystat b{display:block;font-family:'Anton',Impact,sans-serif;font-size:1.25rem;letter-spacing:.02em}
.mystat span{font-size:.66rem;letter-spacing:.1em;text-transform:uppercase;color:var(--chalk-dim)}

/* ---- Zahlen zum Tag ---- */
.funstats{display:flex;flex-direction:column;gap:8px}
.funstat{display:flex;align-items:baseline;gap:10px;border-top:1px dashed var(--line);padding-top:8px}
.funstat:first-child{border-top:none;padding-top:0}
.funstat b{font-family:'Anton',Impact,sans-serif;font-size:1.3rem;color:var(--ball);min-width:56px}
.funstat small{display:block;font-size:.7rem;letter-spacing:.1em;text-transform:uppercase;color:var(--chalk-dim)}

/* ---- Hall of Fame ---- */
.hof{list-style:none;display:flex;flex-direction:column;gap:6px}
.hof li{display:flex;align-items:center;gap:10px;flex-wrap:wrap;background:var(--card2);border:1px solid var(--line);border-radius:4px;padding:9px 10px}
.hof .year{font-family:'Anton',Impact,sans-serif;color:transparent;-webkit-text-stroke:1px var(--gold);font-size:1.05rem;min-width:52px}
.hof .champ-sm{font-weight:700;font-size:1rem}
.hof .rest{font-size:.8rem;color:var(--chalk-dim);font-weight:600;margin-left:auto}

/* ---- Tabellen: eigene Zeile ---- */
.standings tr.me td{box-shadow:inset 3px 0 0 var(--ball)}

/* ---- Werkzeug-Links ---- */
.tools{display:grid;grid-template-columns:repeat(auto-fit,minmax(130px,1fr));gap:8px}

/* ---- Grossanzeige (display.php) ---- */
.display .app{max-width:1500px}
.display{cursor:none}
.dpanel{display:none}
.dpanel.on{display:block;animation:dfade .5s ease}
@keyframes dfade{from{opacity:0}to{opacity:1}}
.display .content{padding:26px 30px;gap:20px}
.display .title{font-size:clamp(2.4rem,5vw,4rem)}
.dhead{font-family:'Anton',Impact,sans-serif;font-size:clamp(1.6rem,3.4vw,2.6rem);letter-spacing:.06em;text-transform:uppercase;
  display:flex;align-items:center;gap:14px;margin-bottom:14px}
.dhead::after{content:"";flex:1;border-top:3px dashed rgba(221,20,17,.45)}
.drow{display:flex;align-items:center;gap:16px;flex-wrap:wrap;padding:14px 4px;border-bottom:1.5px dashed var(--line)}
.drow:last-child{border-bottom:none}
.dvs{font-family:'Anton',Impact,sans-serif;font-size:clamp(1.6rem,4vw,3.2rem);letter-spacing:.02em;text-transform:uppercase;line-height:1.1}
.dvs .res{color:var(--ball)}
.dmeta{font-size:clamp(.9rem,1.6vw,1.3rem);color:var(--chalk-dim);font-weight:700}
.display .standings td{font-size:clamp(1rem,1.9vw,1.5rem);padding:13px 6px}
.display .standings th{font-size:clamp(.7rem,1.1vw,.9rem)}
.display .card-title{font-size:clamp(1.2rem,2.2vw,1.8rem)}
.display .champ-name{font-size:clamp(3rem,8vw,6rem)}
.display .foot,.display .head-top{display:none}
@media (prefers-reduced-motion: reduce){.dpanel.on{animation:none}}
