:root{ --bg:#0b1220; --panel:#131c2e; --line:#22304a; --ink:#f1f5f9; --muted:#93a3bb;
  --accent:#38bdf8; --green:#34d399; --amber:#fbbf24; }
*{box-sizing:border-box;}
body{margin:0;background:var(--bg);color:var(--ink);font-family:"Segoe UI",Roboto,Arial,sans-serif;}
.tv-head{display:flex;align-items:baseline;justify-content:space-between;padding:22px 34px;border-bottom:1px solid var(--line);}
.tv-head h1{margin:0;font-size:34px;letter-spacing:.5px;}
.tv-head .t{font-size:22px;color:var(--accent);font-weight:700;}
.tv-head .clock{font-size:20px;color:var(--muted);}
.grid{display:grid;grid-template-columns:repeat(2,1fr);gap:20px;padding:26px 34px;}
@media(max-width:900px){.grid{grid-template-columns:1fr;}}
.card{background:var(--panel);border:1px solid var(--line);border-radius:16px;padding:20px 24px;}
.card .board{font-size:18px;color:var(--muted);margin-bottom:10px;text-transform:uppercase;letter-spacing:1px;}
.match{display:flex;align-items:center;justify-content:space-between;}
.side{flex:1;}
.side .nm{font-size:30px;font-weight:700;}
.side .sub{font-size:16px;color:var(--muted);margin-top:2px;}
.score{font-size:60px;font-weight:800;min-width:140px;text-align:center;}
.vs{font-size:22px;color:var(--muted);padding:0 14px;}
.legs{display:inline-block;background:#1e293b;border-radius:8px;padding:2px 10px;font-size:18px;color:var(--green);margin-left:8px;}
.next-row{display:flex;align-items:center;justify-content:space-between;padding:14px 0;border-bottom:1px solid var(--line);font-size:24px;}
.next-row:last-child{border-bottom:none;}
.next-row .b{color:var(--accent);font-weight:700;font-size:18px;min-width:110px;}
.next-row .w{color:var(--amber);font-size:18px;}
.waiting{padding:20px 34px;color:var(--muted);font-size:20px;}
.waiting span{display:inline-block;background:var(--panel);border:1px solid var(--line);border-radius:10px;padding:6px 14px;margin:4px;color:var(--ink);}
.empty{padding:60px;text-align:center;color:var(--muted);font-size:24px;}

/* ===== TV Aufruf: Status-Bühne & Board-Kästchen ===== */
.stage{display:flex;flex-direction:column;align-items:center;justify-content:center;
  text-align:center;min-height:calc(100vh - 92px);padding:24px;}
.stage-title{font-size:96px;font-weight:800;letter-spacing:2px;}
.stage-sub{font-size:34px;color:var(--muted);margin-top:18px;max-width:80%;}

.boards-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));
  gap:20px;padding:26px 34px;}
.bcard{background:var(--panel);border:1px solid var(--line);border-top:6px solid var(--line);
  border-radius:16px;padding:18px 20px;min-height:180px;}
.bcard.live{border-top-color:var(--green);box-shadow:0 0 0 2px rgba(52,211,153,.25);}
.b-name{font-size:18px;color:var(--accent);font-weight:700;text-transform:uppercase;letter-spacing:1px;}
.b-nogroup,.b-wait{color:var(--muted);font-size:22px;margin-top:24px;}
.b-group{font-size:30px;font-weight:800;margin-top:8px;}
.b-game{font-size:18px;color:var(--muted);margin-top:8px;}
.b-players{font-size:26px;font-weight:700;margin-top:4px;line-height:1.25;}
.b-players .vs{font-size:18px;color:var(--muted);padding:0 8px;}
.b-writer{font-size:18px;color:var(--amber);margin-top:8px;}
.b-live{margin-top:12px;color:var(--green);font-weight:700;font-size:20px;}
.b-call{margin-top:12px;color:var(--accent);font-weight:700;font-size:20px;}

/* ===== TV Aufruf: Gruppenliste (untere Hälfte) ===== */
.groups-title{font-size:22px;color:var(--muted);text-transform:uppercase;letter-spacing:1px;
  padding:8px 34px 0;}
.groups-list{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));
  gap:18px;padding:14px 34px 30px;}
.gcard{background:var(--panel);border:1px solid var(--line);border-radius:14px;padding:14px 18px;}
.g-name{font-size:24px;font-weight:800;color:var(--accent);margin-bottom:8px;}
.g-players{margin:0;padding-left:26px;}
.g-players li{font-size:22px;line-height:1.5;}
.g-empty{color:var(--muted);font-size:18px;}

/* ===== Full-HD Safe-Area (Overscan) ===== */
body.tv{overflow:hidden;}
.tv .tv-safe{box-sizing:border-box;width:100vw;height:100vh;padding:2vh 2.4vw;display:flex;flex-direction:column;}
.tv .tv-head{border-bottom:1px solid var(--line);padding:0 0 12px;margin-bottom:14px;flex:0 0 auto;}
.tv .tv-head h1{font-size:44px;} .tv .tv-head .t{font-size:30px;} .tv .tv-head .clock{font-size:26px;}
.tv .head-right{display:flex;align-items:baseline;gap:24px;}
.tv .page-ind{color:var(--accent);font-size:24px;font-weight:800;}
.tv .head-right{display:flex;align-items:baseline;gap:20px;}
.tv #content{flex:1 1 auto;min-height:0;overflow:hidden;display:flex;flex-direction:column;}

/* Aufruf: Board-Strip oben (gross) */
.call-strip{display:flex;gap:14px;flex-wrap:wrap;margin-bottom:16px;flex:0 0 auto;}
.call{flex:1 1 280px;min-width:0;background:var(--panel);border:1px solid var(--line);border-left:7px solid var(--line);
  border-radius:12px;padding:10px 16px;display:flex;flex-direction:column;gap:3px;}
.call.live{border-left-color:var(--green);}
.call .cb{color:var(--accent);font-weight:800;font-size:18px;text-transform:uppercase;letter-spacing:1px;}
.call .cg{font-size:22px;font-weight:700;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.call .cw{font-size:20px;color:var(--muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}

/* Aufruf: 2 Gruppen nebeneinander, gross */
.g-grid{display:grid;grid-template-columns:1fr 1fr;grid-auto-rows:1fr;gap:18px;flex:1 1 auto;min-height:0;}
.gcard{background:var(--panel);border:1px solid var(--line);border-radius:16px;padding:18px 22px;overflow:hidden;display:flex;flex-direction:column;min-height:0;}
.gcard .g-name{font-size:36px;font-weight:800;color:var(--accent);margin-bottom:4px;}
.gcard .g-board{font-size:22px;color:var(--green);font-weight:700;}
.gcard .g-sub{font-size:16px;color:var(--muted);text-transform:uppercase;letter-spacing:1px;margin:14px 0 4px;}
.g-table,.g-sched{width:100%;border-collapse:collapse;table-layout:fixed;}
.g-table th,.g-sched th{color:var(--muted);font-weight:700;font-size:16px;text-transform:uppercase;text-align:center;padding:5px 8px;border-bottom:2px solid var(--line);}
.g-table td,.g-sched td{text-align:center;padding:6px 8px;border-bottom:1px solid rgba(255,255,255,.06);font-size:24px;}
.g-table .l,.g-sched .l{text-align:left;}
.g-table td.l,.g-sched td.l{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.g-table th:first-child{width:52%;} .g-table th:not(:first-child){width:12%;}
.g-sched th:nth-child(1){width:7%;} .g-sched th:nth-child(2){width:50%;}
.g-sched th:nth-child(3){width:28%;} .g-sched th:nth-child(4){width:15%;}
.g-table .pk{color:var(--green);font-weight:800;}
.g-sched .vs{color:var(--muted);}
.badge{display:inline-block;border-radius:7px;padding:2px 12px;font-size:18px;font-weight:700;}
.badge.offen{background:#1e293b;color:var(--muted);}
.badge.läuft{background:rgba(52,211,153,.18);color:var(--green);}
.badge.fertig{background:rgba(56,189,248,.15);color:var(--accent);}

/* Live: Spieler-Subzeile */
.side .meta{font-size:16px;color:var(--muted);margin-top:4px;}
.side .meta b{color:var(--ink);font-weight:700;}

/* Live: mitwachsende Kacheln, max. 3 nebeneinander; Kopf-an-Kopf (wie Bild) */
.live-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(720px,1fr));gap:18px;align-content:start;}
.live-card{background:var(--panel);border:1px solid var(--line);border-radius:16px;padding:16px 22px;overflow:hidden;}
.live-card .board{font-size:20px;color:var(--muted);text-transform:uppercase;letter-spacing:1px;margin-bottom:8px;}
.live-card .match{display:flex;align-items:center;justify-content:space-between;gap:12px;}
.live-card .side{flex:1;min-width:0;}
.live-card .side.r{text-align:right;}
.live-card .nm{font-size:34px;font-weight:800;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.live-card .meta{font-size:22px;color:var(--muted);margin-top:4px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.live-card .meta b{color:var(--ink);font-weight:800;}
.live-card .sc{flex:0 0 auto;text-align:center;}
.live-card .score{font-size:62px;font-weight:800;line-height:1;}
.live-card .sub{font-size:16px;color:var(--muted);margin-top:4px;}

/* Dauerhafter QR-Code (führt auf die mobile Zuschauerseite) */
.qr-box{position:fixed;right:1.4vw;bottom:1.4vh;background:#fff;border-radius:10px;padding:7px 7px 4px;
  text-align:center;z-index:20;box-shadow:0 4px 18px rgba(0,0,0,.5);text-decoration:none;}
.qr-box img{display:block;width:104px;height:104px;}
.qr-box .cap{color:#0b1220;font-size:11px;font-weight:800;margin-top:3px;letter-spacing:.3px;}

/* ===== TV: KO-Baum ===== */
.cwr{display:block;font-size:18px;color:var(--muted);margin-top:2px;}
.ko-tv-title{font-size:30px;font-weight:800;padding:14px 4px 6px;}
.ko-tv-grid{display:flex;gap:22px;overflow-x:auto;padding-bottom:8px;}
.ko-tv-col{min-width:420px;display:flex;flex-direction:column;gap:18px;justify-content:space-around;}
.ko-tv-h{font-size:22px;font-weight:800;color:var(--accent);text-transform:uppercase;letter-spacing:1px;text-align:center;}
.ko-tv-m{background:var(--panel);border:1px solid var(--line);border-radius:14px;padding:14px 18px;}
.ko-tv-m.running{border-color:var(--green);box-shadow:0 0 0 2px rgba(52,211,153,.25);}
.ko-tv-m.finished{opacity:.75;}
.ko-tv-vs{display:flex;align-items:center;justify-content:space-between;gap:10px;font-size:30px;font-weight:800;}
.ko-tv-vs span{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.ko-tv-vs .vs{font-size:20px;color:var(--muted);font-weight:400;flex:0 0 auto;padding:0 8px;}
.ko-tv-meta{font-size:18px;color:var(--muted);margin-top:8px;}
.ko-tv-badge{display:inline-block;border-radius:6px;padding:1px 8px;font-size:15px;font-weight:700;}
.ko-tv-badge.pending{background:rgba(147,163,187,.2);color:var(--muted);}
.ko-tv-badge.running{background:rgba(52,211,153,.2);color:var(--green);}
.ko-tv-badge.finished{background:rgba(56,189,248,.2);color:var(--accent);}
