/* ── Reset ─────────────────────────────────────────────── */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

/* ── Retro Design System ───────────────────────────────── */
:root {
  --paper:     #fef9ec;
  --paper2:    #fff8e1;
  --ink:       #1a1a2e;
  --blue:      #1a237e;
  --blue-mid:  #1565c0;
  --red:       #b71c1c;
  --yellow:    #f9a825;
  --green:     #2e7d32;
  --border:    2px solid #1a237e;
  --shadow:    4px 4px 0 #1a237e;
  --radius:    0px;

  /* Phase colors */
  --ph-groups:  #1565c0;
  --ph-round32: #2e7d32;
  --ph-round16: #e65100;
  --ph-quarters:#6a1b9a;
  --ph-semis:   #b71c1c;
  --ph-third:   #4e342e;
  --ph-final:   #f9a825;
}

body {
  font-family: Arial, Helvetica, sans-serif;
  background: var(--paper);
  color: var(--ink);
  font-size: 14px;
  line-height: 1.4;
}

.hidden { display: none !important; }
a { color: var(--blue); }

/* ── Container ─────────────────────────────────────────── */
.container-inner {
  max-width: 1060px;
  margin: 0 auto;
  padding: 0 1rem;
}

/* ══════════════════════════════════════════════════════════
   ONBOARDING WIZARD
══════════════════════════════════════════════════════════ */
.onboarding {
  position: fixed; inset: 0;
  background: rgba(26, 35, 126, 0.88);
  z-index: 1000;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 1rem;
  overflow-y: auto;
}
.onboarding.hidden { display: none !important; }

.wizard-wrap {
  background: var(--paper);
  border: 4px solid var(--blue);
  box-shadow: 8px 8px 0 var(--red);
  max-width: 680px;
  width: 100%;
  padding: 0;
  position: relative;
  display: flex;
  flex-direction: column;
  max-height: 95vh;
}

.wizard-stars {
  background: var(--blue);
  color: var(--yellow);
  text-align: center;
  font-weight: 900;
  font-size: .75rem;
  letter-spacing: .15em;
  padding: .4rem;
  flex-shrink: 0;
}

/* Progress bar */
.wizard-progress {
  display: flex;
  align-items: center;
  padding: 1rem 2rem;
  background: var(--paper2);
  border-bottom: var(--border);
  gap: 0;
  flex-shrink: 0;
}
.wp-step {
  width: 32px; height: 32px;
  border: 3px solid var(--blue);
  background: white;
  color: var(--blue);
  font-weight: 900;
  font-size: .85rem;
  display: flex; align-items: center; justify-content: center;
  flex-shrink: 0;
  font-family: Impact, Arial Black, sans-serif;
}
.wp-step.active   { background: var(--blue); color: white; }
.wp-step.done     { background: var(--green); border-color: var(--green); color: white; }
.wp-line {
  flex: 1; height: 3px;
  background: var(--blue);
  opacity: .3;
}
.wp-line.done { opacity: 1; background: var(--green); }

/* Wizard body */
.wizard-body {
  padding: 1.5rem 2rem;
  overflow-y: auto;
  flex: 1;
  min-height: 0;
}
.wizard-body h2 {
  font-family: Impact, Arial Black, sans-serif;
  font-size: 1.6rem;
  letter-spacing: .05em;
  color: var(--blue);
  text-transform: uppercase;
  margin-bottom: .25rem;
}
.wizard-body .step-subtitle {
  color: #555;
  font-size: .85rem;
  margin-bottom: 1.25rem;
  border-left: 3px solid var(--yellow);
  padding-left: .6rem;
}

/* Step 1 welcome */
.welcome-trophy {
  font-size: 3rem;
  text-align: center;
  margin-bottom: .75rem;
}
.welcome-features {
  list-style: none;
  display: flex;
  flex-direction: column;
  gap: .5rem;
  margin-top: 1rem;
}
.welcome-features li {
  background: var(--paper2);
  border: 2px solid var(--blue);
  padding: .5rem .75rem;
  font-size: .85rem;
  display: flex;
  align-items: center;
  gap: .5rem;
  font-weight: 600;
}
.welcome-features li span { font-size: 1.1rem; }

/* Bulk action bar */
.bulk-actions {
  display: flex;
  gap: .4rem;
  margin-bottom: .85rem;
  flex-wrap: wrap;
}
.btn-bulk {
  font-family: Impact, Arial Black, sans-serif;
  font-size: .72rem;
  letter-spacing: .05em;
  padding: .35rem .8rem;
  border: 2px solid var(--blue);
  background: white;
  color: var(--blue);
  cursor: pointer;
  transition: all .12s;
  text-transform: uppercase;
}
.btn-bulk:hover { background: var(--blue); color: white; }
.btn-bulk.danger { border-color: #999; color: #666; }
.btn-bulk.danger:hover { background: #666; color: white; border-color: #666; }

/* Team grid */
.group-block { margin-bottom: 1rem; }
.group-label {
  font-family: Impact, Arial Black, sans-serif;
  font-size: .8rem;
  letter-spacing: .1em;
  color: white;
  background: var(--blue);
  padding: .2rem .6rem;
  display: inline-block;
  margin-bottom: .4rem;
}
.team-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: .35rem;
}
.team-btn {
  border: 2px solid #ccc;
  background: white;
  padding: .35rem .4rem;
  cursor: pointer;
  font-size: .78rem;
  font-weight: 700;
  text-align: center;
  transition: all .12s;
  line-height: 1.3;
}
.team-btn:hover { border-color: var(--blue); background: #e8eaf6; }
.team-btn.selected { border-color: var(--blue); background: var(--blue); color: white; }
.team-btn .tf { font-size: 1.1rem; display: block; }

/* Round grid */
.round-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: .6rem;
}
.round-btn {
  border: 3px solid #ccc;
  background: #f2f2f2;
  color: #999;
  padding: .75rem .6rem;
  cursor: pointer;
  font-weight: 900;
  font-family: Impact, Arial Black, sans-serif;
  font-size: .95rem;
  letter-spacing: .05em;
  text-align: center;
  text-transform: uppercase;
  transition: all .15s;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: .2rem;
  position: relative;
}
.round-btn:hover {
  border-color: #aaa;
  background: #e8e8e8;
  color: #666;
}
.round-btn small {
  font-family: Arial;
  font-weight: normal;
  font-size: .7rem;
  text-transform: none;
  opacity: .8;
}
.round-btn .phase-icon { font-size: 1.1rem; }

/* Check badge — hidden by default */
.round-btn::after {
  content: '✓';
  position: absolute;
  top: .3rem;
  right: .4rem;
  font-size: .75rem;
  font-family: Arial;
  font-weight: 900;
  opacity: 0;
  transition: opacity .15s;
}

/* Selected state */
.round-btn.selected { color: white; }
.round-btn.selected::after { opacity: 1; }
.round-btn.selected small { opacity: .85; }

.round-btn[data-phase="final"]   { grid-column: 1/-1; }

.round-btn[data-phase="groups"].selected  { background: var(--ph-groups);  border-color: var(--ph-groups); }
.round-btn[data-phase="round32"].selected { background: var(--ph-round32); border-color: var(--ph-round32); }
.round-btn[data-phase="round16"].selected { background: var(--ph-round16); border-color: var(--ph-round16); }
.round-btn[data-phase="quarters"].selected{ background: var(--ph-quarters);border-color: var(--ph-quarters); }
.round-btn[data-phase="semis"].selected   { background: var(--ph-semis);   border-color: var(--ph-semis); }
.round-btn[data-phase="third"].selected   { background: var(--ph-third);   border-color: var(--ph-third); }
.round-btn[data-phase="final"].selected   { background: var(--ph-final);   border-color: var(--ph-final); color: var(--ink); }
.round-btn[data-phase="final"].selected::after { color: var(--ink); }

/* TV Step */
.tz-detected {
  background: #e8f5e9;
  border: 2px solid var(--green);
  padding: .5rem .75rem;
  margin-bottom: 1rem;
  font-size: .83rem;
  font-weight: 700;
}
.country-select-wrap {
  margin-bottom: 1rem;
}
.country-select-wrap label {
  display: block;
  font-weight: 700;
  font-size: .8rem;
  margin-bottom: .3rem;
  text-transform: uppercase;
  letter-spacing: .05em;
}
.country-select-wrap select {
  width: 100%;
  padding: .45rem .6rem;
  border: 2px solid var(--blue);
  font-size: .9rem;
  background: white;
  font-weight: 700;
  cursor: pointer;
}
.tv-services {
  display: flex;
  flex-wrap: wrap;
  gap: .4rem;
}
.tv-chip {
  border: 2px solid var(--blue);
  background: white;
  padding: .3rem .65rem;
  cursor: pointer;
  font-size: .8rem;
  font-weight: 700;
  transition: all .12s;
}
.tv-chip.selected { background: var(--blue); color: white; }
.tv-chip.streaming { border-color: var(--green); }
.tv-chip.streaming.selected { background: var(--green); }

/* Summary step */
.summary-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: .75rem;
}
.summary-box {
  border: 2px solid var(--blue);
  padding: .75rem;
  background: var(--paper2);
}
.summary-box h4 {
  font-family: Impact, Arial Black, sans-serif;
  letter-spacing: .05em;
  font-size: .85rem;
  color: var(--blue);
  margin-bottom: .4rem;
  text-transform: uppercase;
}
.summary-box p { font-size: .8rem; line-height: 1.6; }
.summary-match-count {
  text-align: center;
  margin-top: 1rem;
  font-family: Impact, Arial Black, sans-serif;
  font-size: 2rem;
  color: var(--red);
  letter-spacing: .05em;
}
.summary-match-count small {
  display: block;
  font-family: Arial;
  font-size: .8rem;
  color: #555;
  font-weight: normal;
}

/* Wizard nav */
.wizard-nav {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 1rem 2rem;
  border-top: var(--border);
  background: var(--paper2);
  flex-shrink: 0;
}

/* ── Buttons ───────────────────────────────────────────── */
.btn-retro {
  font-family: Impact, Arial Black, sans-serif;
  font-size: .95rem;
  letter-spacing: .05em;
  text-transform: uppercase;
  padding: .55rem 1.5rem;
  border: 3px solid;
  cursor: pointer;
  transition: all .12s;
}
.btn-retro:active { transform: translate(2px, 2px); }
.btn-primary {
  background: var(--blue);
  border-color: var(--blue);
  color: white;
  box-shadow: 3px 3px 0 var(--red);
}
.btn-primary:hover { background: #283593; }
.btn-secondary {
  background: white;
  border-color: var(--blue);
  color: var(--blue);
  box-shadow: 3px 3px 0 #aaa;
}
.btn-secondary:hover { background: #e8eaf6; }

/* ══════════════════════════════════════════════════════════
   MAIN APP
══════════════════════════════════════════════════════════ */

/* Header */
.site-header {
  border-bottom: 4px solid var(--blue);
}
.header-stripe {
  background: var(--blue);
  color: var(--yellow);
  text-align: center;
  font-weight: 900;
  font-size: .72rem;
  letter-spacing: .2em;
  padding: .3rem;
  text-transform: uppercase;
}
.bottom-stripe { background: var(--red); }

.header-main {
  background: linear-gradient(135deg, #0d1b6b 0%, #1a237e 40%, #0d47a1 100%);
  padding: 1.25rem 1.5rem;
  display: flex;
  align-items: center;
  gap: 1.25rem;
  position: relative;
}
.header-trophy { font-size: 3rem; flex-shrink: 0; }
.header-titles h1 {
  font-family: Impact, Arial Black, sans-serif;
  font-size: 2.2rem;
  color: var(--yellow);
  letter-spacing: .08em;
  line-height: 1;
  text-shadow: 2px 2px 0 rgba(0,0,0,.5);
}
.header-titles h2 {
  font-family: Impact, Arial Black, sans-serif;
  font-size: 1rem;
  color: #90caf9;
  letter-spacing: .2em;
}
.header-dates {
  font-size: .72rem;
  color: #90caf9;
  letter-spacing: .1em;
  margin-top: .2rem;
}
.btn-config {
  margin-left: auto;
  background: var(--yellow);
  border: 2px solid #f57f17;
  color: var(--ink);
  font-family: Impact, Arial Black, sans-serif;
  font-size: .8rem;
  letter-spacing: .05em;
  padding: .4rem .9rem;
  cursor: pointer;
  flex-shrink: 0;
}
.btn-config:hover { background: #ffd54f; }

/* View toggle bar */
.view-toggle-bar {
  background: var(--paper2);
  border-bottom: 3px solid var(--blue);
  padding: .6rem 0;
}
.view-toggle {
  display: flex;
  gap: .5rem;
  margin-bottom: .4rem;
}
.vt-btn {
  font-family: Impact, Arial Black, sans-serif;
  font-size: .9rem;
  letter-spacing: .05em;
  padding: .45rem 1.25rem;
  border: 3px solid var(--blue);
  background: white;
  color: var(--blue);
  cursor: pointer;
  transition: all .12s;
}
.vt-btn.active { background: var(--blue); color: var(--yellow); }
.vt-btn:hover:not(.active) { background: #e8eaf6; }

.my-cal-info {
  font-size: .78rem;
  color: #555;
}
.my-cal-info strong { color: var(--blue); }

/* All-matches controls */
.all-controls {
  background: #eef0fb;
  border-bottom: 2px solid var(--blue);
  padding: .75rem 0;
}
.search-row { margin-bottom: .6rem; }
.search-row input {
  width: 100%;
  padding: .5rem .75rem;
  border: 2px solid var(--blue);
  font-size: .9rem;
  background: white;
  outline: none;
}
.search-row input:focus { border-color: var(--red); }
.filter-row {
  display: flex;
  flex-wrap: wrap;
  gap: .75rem;
  align-items: flex-start;
}
.filter-group { display: flex; flex-direction: column; gap: .3rem; }
.filter-group label {
  font-family: Impact, Arial Black, sans-serif;
  font-size: .7rem;
  letter-spacing: .12em;
  color: var(--blue);
}
.btn-group { display: flex; flex-wrap: wrap; gap: .3rem; }
.btn-filter {
  font-family: Impact, Arial Black, sans-serif;
  font-size: .72rem;
  letter-spacing: .06em;
  padding: .3rem .6rem;
  border: 2px solid var(--blue);
  background: white;
  color: var(--blue);
  cursor: pointer;
  transition: all .1s;
}
.btn-filter:hover { background: #e8eaf6; }
.btn-filter.active { background: var(--blue); color: white; }

/* Phase legend */
.phase-legend {
  display: flex;
  flex-wrap: wrap;
  gap: .5rem;
  padding: .6rem 1rem;
  font-size: .7rem;
  font-weight: 700;
  letter-spacing: .04em;
}
.legend-item { padding: .15rem .5rem; color: white; }
.legend-item.phase-groups  { background: var(--ph-groups); }
.legend-item.phase-round32 { background: var(--ph-round32); }
.legend-item.phase-round16 { background: var(--ph-round16); }
.legend-item.phase-quarters{ background: var(--ph-quarters); }
.legend-item.phase-semis   { background: var(--ph-semis); }
.legend-item.phase-final   { background: var(--ph-final); color: var(--ink); }

/* Export bar */
.export-bar {
  background: #fff8e1;
  border-bottom: 2px solid var(--yellow);
}
.export-bar-inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: .75rem;
  flex-wrap: wrap;
  padding: .6rem 1rem;
}
.export-left {
  display: flex;
  align-items: center;
  gap: .6rem;
  flex-wrap: wrap;
}
.export-label {
  font-family: Impact, Arial Black, sans-serif;
  font-size: .85rem;
  letter-spacing: .05em;
  color: var(--blue);
}
.export-count {
  font-size: .75rem;
  color: #888;
  font-style: italic;
}
.export-btns {
  display: flex;
  gap: .5rem;
  flex-wrap: wrap;
}
.btn-export {
  font-family: Impact, Arial Black, sans-serif;
  font-size: .85rem;
  letter-spacing: .04em;
  padding: .5rem 1.25rem;
  border: 3px solid;
  cursor: pointer;
  transition: all .12s;
  white-space: nowrap;
}
.btn-export:active { transform: translate(1px,1px); }
.btn-gcal { background: #d93025; border-color: #d93025; color: white; }
.btn-gcal:hover { background: #b71c1c; border-color: #b71c1c; }
.btn-ics  { background: white; border-color: var(--blue); color: var(--blue); }
.btn-ics:hover  { background: var(--blue); color: white; }

/* Post-action instructions */
.export-instructions {
  border-top: 2px solid;
  padding: .6rem 0;
  animation: slideDown .2s ease;
}
.export-instructions.instr-gcal { background: #fce8e6; border-color: #d93025; }
.export-instructions.instr-ics  { background: #e8f5e9; border-color: var(--green); }
.export-instructions .container-inner {
  display: flex;
  align-items: center;
  gap: 1rem;
  flex-wrap: wrap;
}
@keyframes slideDown {
  from { opacity: 0; transform: translateY(-4px); }
  to   { opacity: 1; transform: translateY(0); }
}
.instr-content { flex: 1; font-size: .82rem; line-height: 1.6; }
.instr-content strong { display: block; margin-bottom: .15rem; }
.instr-content ol { padding-left: 1.2rem; margin: 0; }
.instr-content li { margin-bottom: .1rem; }
.instr-content .instr-note {
  margin-top: .35rem;
  font-size: .75rem;
  color: #666;
  font-style: italic;
}
.instr-close {
  background: none;
  border: 1px solid #aaa;
  color: #666;
  font-size: .8rem;
  padding: .25rem .55rem;
  cursor: pointer;
  flex-shrink: 0;
  align-self: flex-start;
}
.instr-close:hover { background: #ddd; }

/* Match count bar */
.match-count-bar {
  font-family: Impact, Arial Black, sans-serif;
  font-size: .8rem;
  letter-spacing: .05em;
  color: #555;
  padding: .6rem 0 .3rem;
  border-bottom: 1px solid #ddd;
  margin-bottom: .75rem;
}
.match-count-bar strong { color: var(--red); }

/* ── Phase Headers ─────────────────────────────────────── */
.phase-banner {
  color: white;
  font-family: Impact, Arial Black, sans-serif;
  letter-spacing: .12em;
  font-size: 1rem;
  padding: .4rem 1rem;
  margin: 1.25rem 0 .6rem;
  display: flex;
  align-items: center;
  gap: .75rem;
}
.phase-banner.ph-groups  { background: var(--ph-groups); }
.phase-banner.ph-round32 { background: var(--ph-round32); }
.phase-banner.ph-round16 { background: var(--ph-round16); }
.phase-banner.ph-quarters{ background: var(--ph-quarters); }
.phase-banner.ph-semis   { background: var(--ph-semis); }
.phase-banner.ph-third   { background: var(--ph-third); }
.phase-banner.ph-final   { background: var(--ph-final); color: var(--ink); }

.phase-banner .ph-matches {
  margin-left: auto;
  font-family: Arial;
  font-weight: normal;
  font-size: .72rem;
  opacity: .85;
  letter-spacing: 0;
}

/* ── Day Block ─────────────────────────────────────────── */
.day-block { margin-bottom: 1rem; }
.day-label {
  font-family: Impact, Arial Black, sans-serif;
  font-size: .78rem;
  letter-spacing: .1em;
  color: #777;
  text-transform: uppercase;
  padding: .3rem 0;
  border-bottom: 1px dashed #ccc;
  margin-bottom: .4rem;
}

/* ── Match Card ────────────────────────────────────────── */
.match-card {
  background: white;
  border: 2px solid #ddd;
  border-left: 6px solid #ddd;
  margin-bottom: .4rem;
  display: grid;
  grid-template-columns: 2rem 1fr auto 1fr auto;
  align-items: center;
  gap: .6rem;
  padding: .6rem .75rem;
  transition: border-color .15s;
  position: relative;
}
.match-card:hover { border-color: var(--blue); border-left-color: inherit; }
.match-card.my-match { background: #fffde7; }

/* Phase border colors */
.match-card.ph-groups  { border-left-color: var(--ph-groups); }
.match-card.ph-round32 { border-left-color: var(--ph-round32); }
.match-card.ph-round16 { border-left-color: var(--ph-round16); }
.match-card.ph-quarters{ border-left-color: var(--ph-quarters); }
.match-card.ph-semis   { border-left-color: var(--ph-semis); }
.match-card.ph-third   { border-left-color: var(--ph-third); }
.match-card.ph-final   {
  border-left-color: var(--ph-final);
  border-color: var(--ph-final);
  background: #fffde7;
  border-width: 3px;
  border-left-width: 8px;
}

.match-num {
  font-family: Impact, Arial Black, sans-serif;
  font-size: .7rem;
  color: #aaa;
  text-align: center;
}
.team { display: flex; flex-direction: column; }
.team-home { text-align: right; }
.team-name { font-weight: 700; font-size: .9rem; }
.team-flag { font-size: 1rem; }

.match-center { text-align: center; min-width: 90px; }
.match-time {
  font-family: Impact, Arial Black, sans-serif;
  font-size: 1.2rem;
  color: var(--red);
  letter-spacing: .03em;
  display: block;
}
.match-time-local { font-size: .65rem; color: #888; display: block; }
.match-vs { font-size: .65rem; color: #999; }
.match-group {
  display: inline-block;
  font-family: Impact, Arial Black, sans-serif;
  font-size: .65rem;
  letter-spacing: .05em;
  padding: .05rem .3rem;
  margin-top: .15rem;
  color: white;
}
.match-group.ph-groups  { background: var(--ph-groups); }
.match-group.ph-round32 { background: var(--ph-round32); }
.match-group.ph-round16 { background: var(--ph-round16); }
.match-group.ph-quarters{ background: var(--ph-quarters); }
.match-group.ph-semis   { background: var(--ph-semis); }
.match-group.ph-third   { background: var(--ph-third); }
.match-group.ph-final   { background: var(--ph-final); color: var(--ink); }

.match-meta { text-align: right; min-width: 140px; }
.match-stadium { font-weight: 700; font-size: .78rem; color: var(--ink); }
.match-city { font-size: .72rem; color: #666; }
.match-tv { font-size: .68rem; color: var(--green); font-weight: 700; margin-top: .15rem; }

.my-star {
  position: absolute;
  top: .3rem; right: .3rem;
  font-size: .65rem;
  color: var(--yellow);
}

/* ── No Results ────────────────────────────────────────── */
.no-results {
  text-align: center;
  padding: 3rem 1rem;
  color: #888;
  font-style: italic;
}


/* ── Footer ────────────────────────────────────────────── */
.site-footer {
  background: var(--blue);
  color: var(--yellow);
  text-align: center;
  padding: 1rem;
  font-size: .72rem;
  letter-spacing: .1em;
  font-weight: 700;
  margin-top: 2rem;
}
.site-footer a { color: #90caf9; }
.site-footer p + p { margin-top: .4rem; }

/* ── Responsive ────────────────────────────────────────── */
@media (max-width: 600px) {
  .match-card {
    grid-template-columns: 1fr;
    text-align: center;
  }
  .team-home, .team-away { text-align: center; }
  .match-meta { text-align: center; min-width: unset; }
  .match-num { display: none; }
  .header-titles h1 { font-size: 1.5rem; }
  .header-trophy { font-size: 2rem; }
  .summary-grid { grid-template-columns: 1fr; }
  .team-grid { grid-template-columns: repeat(2, 1fr); }
  .wizard-body { padding: .85rem 1rem; }
  .wizard-nav { padding: .6rem 1rem; }
  .wizard-progress { padding: .6rem 1rem; }
  .wizard-wrap { max-height: 100vh; border-width: 3px; box-shadow: 4px 4px 0 var(--red); }
}
