/* ==========================================================================
   wm.dev-jml.de – WM 2026
   Farbwelt: Navy-Basis + Trikolore-Akzente der drei Gastgeber
   ========================================================================== */

/* Länderflaggen-Font (lokal, Twemoji): Windows rendert Flaggen-Emojis sonst
   nur als Buchstaben-Kürzel (z. B. "DE"), während Sonderflaggen wie England/
   Schottland als Flagge erscheinen. Der Font greift per unicode-range NUR für
   Flaggen-Codepoints – alle anderen Emojis bleiben unverändert. */
@font-face {
  font-family: "Twemoji Country Flags";
  src: url("vendor/TwemojiCountryFlags.woff2") format("woff2");
  unicode-range: U+1F1E6-1F1FF, U+1F3F4, U+E0062-E0063, U+E0065, U+E0067, U+E006C, U+E006E, U+E0073-E0074, U+E0077, U+E007F;
  font-display: swap;
}

:root {
  --bg: #f2f5fb;
  --card: #ffffff;
  --ink: #16203a;
  --ink-soft: #5b6478;
  --line: #e3e8f2;
  --navy: #0c2349;
  --navy-2: #16386e;
  --red: #d62839;
  --green: #1f9d55;
  --blue: #2563eb;
  --gold: #f0b429;
  --radius: 14px;
  --shadow: 0 1px 3px rgba(22, 32, 58, .08), 0 6px 18px rgba(22, 32, 58, .06);
}

* { box-sizing: border-box; }

body {
  margin: 0;
  font-family: "Twemoji Country Flags", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;
  background: var(--bg);
  color: var(--ink);
  line-height: 1.5;
}

.hidden { display: none !important; }

/* ----------------------------------------------------------------- Hero -- */
.hero {
  position: relative;
  overflow: hidden;
  background: linear-gradient(135deg, var(--navy) 0%, var(--navy-2) 60%, #1d4a8f 100%);
  color: #fff;
  text-align: center;
  padding: 48px 16px 56px;
}

.hero-stripes {
  position: absolute;
  inset: auto 0 0 0;
  height: 6px;
  background: linear-gradient(90deg, var(--red) 0 33.3%, #fff 33.3% 66.6%, var(--green) 66.6% 100%);
}

.hero-badge {
  display: inline-block;
  background: rgba(255, 255, 255, .12);
  border: 1px solid rgba(255, 255, 255, .25);
  border-radius: 999px;
  padding: 6px 16px;
  font-size: .9rem;
  margin-bottom: 14px;
}

.hero h1 {
  margin: 0;
  font-size: clamp(3rem, 8vw, 4.6rem);
  letter-spacing: .04em;
  font-weight: 800;
}

.hero-year {
  background: linear-gradient(90deg, var(--gold), #ffd76e);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
}

.hero-sub { margin: 8px 0 0; font-size: 1.15rem; font-weight: 600; }
.hero-note { margin: 6px 0 0; opacity: .8; font-size: .95rem; }

/* --------------------------------------------------------------- Topbar -- */
.topbar {
  position: sticky;
  top: 0;
  z-index: 20;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  flex-wrap: wrap;
  padding: 10px 16px;
  background: rgba(255, 255, 255, .92);
  backdrop-filter: blur(8px);
  border-bottom: 1px solid var(--line);
}

.tabs { display: flex; gap: 6px; flex-wrap: wrap; }

.tab {
  border: 1px solid var(--line);
  background: var(--card);
  color: var(--ink);
  border-radius: 999px;
  padding: 8px 18px;
  font-size: .95rem;
  font-weight: 600;
  cursor: pointer;
  transition: background .15s, color .15s;
}

.tab:hover { background: #eaf0fb; }
.tab.active { background: var(--navy); border-color: var(--navy); color: #fff; }

.topbar-actions { display: flex; gap: 6px; }

/* ----------------------------------------------------------------- Main -- */
main {
  max-width: 1080px;
  margin: 0 auto;
  padding: 22px 16px 60px;
}

.hint {
  color: var(--ink-soft);
  background: var(--card);
  border: 1px dashed var(--line);
  border-radius: var(--radius);
  padding: 18px;
  text-align: center;
}

.error-box, .error-text { color: var(--red); }
.error-box {
  background: #fdecee;
  border: 1px solid #f5c2c9;
  border-radius: var(--radius);
  padding: 14px 18px;
}

.tv-info {
  background: linear-gradient(135deg, #eef4ff, #f4fbf4);
  border: 1px solid var(--line);
  border-radius: var(--radius);
  padding: 14px 18px;
  margin-bottom: 18px;
  font-size: .95rem;
}

.filter-row { display: flex; gap: 8px; flex-wrap: wrap; margin-bottom: 8px; }

.chip {
  border: 1px solid var(--line);
  background: var(--card);
  border-radius: 999px;
  padding: 6px 14px;
  font-size: .88rem;
  cursor: pointer;
}

.chip.active { background: var(--blue); border-color: var(--blue); color: #fff; }

.date-header {
  margin: 26px 4px 10px;
  font-size: 1.05rem;
  color: var(--navy-2);
  border-bottom: 2px solid var(--line);
  padding-bottom: 6px;
}

/* ------------------------------------------------------------ Match-Card -- */
.match-card {
  background: var(--card);
  border: 1px solid var(--line);
  border-radius: var(--radius);
  box-shadow: var(--shadow);
  padding: 14px 18px;
  margin-bottom: 12px;
}

.match-card.live { border-left: 4px solid var(--red); }
.match-card.finished { border-left: 4px solid var(--green); }
.match-card.scheduled { border-left: 4px solid var(--blue); }

.match-top { display: flex; gap: 8px; flex-wrap: wrap; margin-bottom: 8px; }

.badge {
  display: inline-block;
  border-radius: 999px;
  padding: 2px 10px;
  font-size: .75rem;
  font-weight: 700;
  letter-spacing: .02em;
}

.badge-round { background: #eaf0fb; color: var(--navy-2); }
.badge-live { background: var(--red); color: #fff; animation: pulse 1.4s infinite; }
.badge-tv { background: #fdf3d7; color: #8a6d1a; margin-left: auto; }
.badge-muted { background: #f0f1f5; color: var(--ink-soft); }

@keyframes pulse { 50% { opacity: .55; } }

.match-teams {
  display: grid;
  grid-template-columns: 1fr auto 1fr;
  align-items: center;
  gap: 12px;
  font-size: 1.12rem;
  font-weight: 600;
}

.team-home { text-align: right; }
.team-away { text-align: left; }
.team-open { color: var(--ink-soft); font-weight: 500; font-style: italic; }
.team-pairing { text-align: right; color: var(--ink-soft); font-weight: 500; font-style: italic; font-size: .95rem; }

.score {
  font-size: 1.35rem;
  font-weight: 800;
  font-variant-numeric: tabular-nums;
  background: var(--navy);
  color: #fff;
  border-radius: 10px;
  padding: 4px 14px;
  white-space: nowrap;
}

.score-open { background: #eaf0fb; color: var(--navy-2); font-size: .95rem; font-weight: 700; }

.match-meta { margin-top: 8px; color: var(--ink-soft); font-size: .88rem; }

.match-goals { margin-top: 8px; font-size: .88rem; }
.match-goals summary { cursor: pointer; color: var(--navy-2); font-weight: 600; }
.match-goals p { margin: 6px 0 0; color: var(--ink-soft); }

/* --------------------------------------------------------------- Karten -- */
.card {
  background: var(--card);
  border: 1px solid var(--line);
  border-radius: var(--radius);
  box-shadow: var(--shadow);
  padding: 16px 18px;
}

.card h3 { margin: 0 0 10px; color: var(--navy-2); }

.group-grid, .venue-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(310px, 1fr));
  gap: 14px;
}

.standings { width: 100%; border-collapse: collapse; font-size: .88rem; }
.standings th, .standings td { padding: 5px 6px; text-align: center; border-bottom: 1px solid var(--line); }
.standings .left { text-align: left; }
.standings .pkt { font-weight: 800; }
.standings .diff-neg { color: var(--red); font-weight: 700; }
.standings tr.qualify td:first-child { box-shadow: inset 3px 0 0 var(--green); }
.standings tbody tr:last-child td { border-bottom: none; }

.venue-card p { margin: 4px 0; }
.venue-meta { color: var(--ink-soft); font-size: .88rem; }

/* --------------------------------------------------------------- Footer -- */
.footer {
  display: flex;
  justify-content: center;
  gap: 24px;
  flex-wrap: wrap;
  padding: 22px 16px 30px;
  color: var(--ink-soft);
  font-size: .85rem;
  border-top: 1px solid var(--line);
}

body.with-admin-bar .footer { padding-bottom: 90px; }

/* --------------------------------------------------------------- Buttons -- */
.btn {
  border: 1px solid var(--line);
  border-radius: 10px;
  padding: 8px 16px;
  font-size: .92rem;
  font-weight: 600;
  cursor: pointer;
  background: var(--card);
  color: var(--ink);
  text-decoration: none;
  display: inline-block;
}

.btn:hover { filter: brightness(.97); }
.btn:disabled { opacity: .55; cursor: wait; }
.btn-primary { background: var(--blue); border-color: var(--blue); color: #fff; }
.btn-secondary { background: var(--navy); border-color: var(--navy); color: #fff; }
.btn-success { background: var(--green); border-color: var(--green); color: #fff; }
.btn-ghost { background: transparent; }

/* ------------------------------------------------------------- Admin-Bar -- */
.admin-bar {
  position: fixed;
  bottom: 0;
  left: 0;
  right: 0;
  z-index: 30;
  display: flex;
  align-items: center;
  gap: 12px;
  flex-wrap: wrap;
  padding: 12px 18px;
  background: var(--navy);
  color: #fff;
  box-shadow: 0 -4px 16px rgba(12, 35, 73, .35);
}

.admin-bar .btn-ghost { color: #fff; border-color: rgba(255, 255, 255, .35); margin-left: auto; }
.admin-label { font-weight: 700; }
.refresh-status { font-size: .88rem; opacity: .9; }

/* --------------------------------------------------------------- Dialoge -- */
dialog {
  border: none;
  border-radius: var(--radius);
  box-shadow: 0 20px 60px rgba(12, 35, 73, .35);
  padding: 0;
  max-width: min(560px, 92vw);
}

dialog::backdrop { background: rgba(12, 35, 73, .45); }

.dialog-body { padding: 22px 26px; }
.dialog-body h2 { margin: 0 0 6px; color: var(--navy-2); }
.dialog-note { color: var(--ink-soft); font-size: .9rem; margin: 0 0 14px; }
.dialog-wide { width: min(860px, 92vw); }
#proposal-dialog { max-width: min(900px, 94vw); }

.dialog-body input[type="password"] {
  width: 100%;
  padding: 10px 12px;
  border: 1px solid var(--line);
  border-radius: 10px;
  font-size: 1rem;
}

.dialog-actions {
  display: flex;
  justify-content: flex-end;
  gap: 10px;
  margin-top: 18px;
  flex-wrap: wrap;
}

.proposal-queries { margin-bottom: 12px; font-size: .88rem; color: var(--ink-soft); }
.proposal-queries summary { cursor: pointer; }

.proposal-table-wrap { max-height: 50vh; overflow: auto; border: 1px solid var(--line); border-radius: 10px; }
.proposal-table { width: 100%; border-collapse: collapse; font-size: .85rem; }
.proposal-table th {
  position: sticky;
  top: 0;
  background: var(--navy);
  color: #fff;
  text-align: left;
  padding: 8px 10px;
}
.proposal-table td { padding: 7px 10px; border-bottom: 1px solid var(--line); vertical-align: top; }
.proposal-table td.old { color: var(--ink-soft); }
.proposal-table td.new { color: var(--green); font-weight: 600; }

/* ----------------------------------------------------------------- Toast -- */
.toast {
  position: fixed;
  top: 18px;
  left: 50%;
  transform: translateX(-50%);
  z-index: 50;
  background: var(--navy);
  color: #fff;
  border-radius: 999px;
  padding: 10px 22px;
  font-size: .92rem;
  box-shadow: var(--shadow);
}

.toast-error { background: var(--red); }

/* ----------------------------------------------------------------- Print -- */
@media print {
  .topbar, .admin-bar, .toast, .filter-row, .hero-badge, dialog { display: none !important; }
  body { background: #fff; }
  .hero { background: none; color: var(--ink); padding: 10px 0; }
  .hero-year { color: var(--ink); -webkit-text-fill-color: var(--ink); }
  .view.hidden { display: block !important; }
  .match-card, .card { box-shadow: none; break-inside: avoid; }
}

@media (max-width: 640px) {
  .match-teams { font-size: .98rem; gap: 8px; }
  .score { font-size: 1.1rem; padding: 3px 10px; }
}
