:root {
  --wc-bg: var(--bg);
  --wc-surface: var(--panel);
  --wc-surface-strong: var(--panel2);
  --wc-text: var(--text);
  --wc-muted: var(--muted);
  --wc-primary: var(--accent);
  --wc-warning: var(--accent2);
  --wc-danger: var(--danger);
  --wc-shadow: 0 1rem 2rem rgba(0,0,0,.22);
  --wc-radius-sm: .25rem;
  --wc-radius-md: .5rem;
  --wc-radius-lg: .5rem;
}

.worldcup-container { width: min(var(--fp-content-max), calc(100% - 2rem)); }
body:has(.worldcup-container) { background: var(--wc-bg); }
.ui-themed .tournament-shell {
  --wc-bg: var(--ui-bg);
  --wc-surface: var(--ui-surface);
  --wc-surface-strong: var(--ui-surface-strong);
  --wc-text: var(--ui-text);
  --wc-muted: var(--ui-muted);
  --wc-primary: var(--ui-primary);
  --wc-warning: var(--ui-accent);
}
.worldcup-container.league-themed { color: var(--wc-text); }
.tournament-shell { position: relative; isolation: isolate; overflow: clip; color: var(--wc-text); padding: 1.5rem; border: 1px solid color-mix(in srgb, var(--wc-primary) 20%, var(--wc-surface-strong)); border-radius: var(--wc-radius-lg); background: linear-gradient(135deg, color-mix(in srgb, var(--wc-primary) 7%, var(--wc-surface)), var(--wc-bg)); box-shadow: var(--wc-shadow); }
.tournament-shell::after { content: ""; position: absolute; inset: 0; z-index: -1; pointer-events: none; background-image: linear-gradient(90deg, color-mix(in srgb, var(--wc-muted) 10%, transparent) 1px, transparent 1px), linear-gradient(180deg, color-mix(in srgb, var(--wc-muted) 7%, transparent) 1px, transparent 1px); background-size: 6rem 6rem; mask-image: linear-gradient(180deg, black, transparent 70%); opacity: .22; }
.tournament-shell::before { content: none; }
.tournament-shell h1::after { content: none; }
.wc-breadcrumb ol { display: flex; gap: .5rem; flex-wrap: wrap; padding: 0; margin: 0 0 .75rem; list-style: none; color: var(--wc-muted); font-weight: 800; }
.wc-breadcrumb li:not(:last-child)::after { content: "/"; margin-left: .5rem; color: var(--wc-muted); }
.wc-breadcrumb a, .wc-segmented-nav a, .round-pager a, .back-link { color: var(--wc-primary); }
.wc-segmented-nav { position: sticky; top: 4.5rem; z-index: var(--z-base); display: flex; gap: .5rem; overflow-x: auto; padding: .5rem; margin-bottom: 1rem; border: 1px solid var(--wc-surface-strong); border-radius: var(--wc-radius-md); background: var(--wc-surface); scrollbar-width: thin; }
.wc-segmented-nav a { flex: 0 0 auto; padding: .5rem .75rem; border: 1px solid var(--wc-surface-strong); border-radius: .25rem; color: var(--wc-muted); font-weight: 950; font-size: .84rem; white-space: nowrap; }
.wc-segmented-nav a[aria-current="page"], .wc-segmented-nav a:hover, .wc-segmented-nav a:focus-visible { background: var(--wc-primary); color: var(--wc-bg); }
#live-view-root { display: grid; gap: 1rem; }
.wc-hero-panel, .final-hero { display: flex; align-items: center; justify-content: space-between; gap: 2rem; min-height: 14rem; padding: 2rem; color: var(--wc-text); border: 1px solid var(--wc-surface-strong); border-radius: var(--wc-radius-lg); background: linear-gradient(135deg, color-mix(in srgb, var(--wc-primary) 12%, var(--wc-surface)), var(--wc-surface)); }
.wc-kicker { margin: 0 0 .5rem; color: var(--wc-warning); text-transform: uppercase; letter-spacing: .18em; font-weight: 950; font-size: clamp(.72rem, 1vw, .95rem); }
.hero-title, .view-head h1, .final-hero h1 { margin: 0; color: var(--wc-text); font-size: var(--fp-text-3xl); line-height: 1.08; letter-spacing: 0; text-transform: uppercase; }
.wc-logo { display: grid; place-items: center; width: clamp(5.5rem, 13vw, 10rem); aspect-ratio: 1; border: 2px solid var(--wc-primary); border-radius: .5rem; background: var(--wc-surface-strong); color: var(--wc-text); text-align: center; }
.wc-logo strong { color: var(--wc-warning); font-size: clamp(2.25rem, 6vw, 5rem); line-height: .9; }
.wc-logo span { color: var(--wc-muted); font-size: .8rem; font-weight: 950; text-transform: uppercase; }
.next-countdown-card { display: flex; justify-content: space-between; gap: 1rem; align-items: center; background: linear-gradient(135deg, color-mix(in srgb, var(--wc-primary) 16%, var(--wc-surface)), var(--wc-surface)); }
.next-countdown-card h2 { display: flex; flex-wrap: wrap; gap: .5rem; align-items: center; margin: 0; color: var(--wc-text); font-size: clamp(1.35rem, 3vw, 2.5rem); }
.next-countdown-card .countdown { color: var(--wc-warning); font-size: clamp(1.75rem, 5vw, 4rem); line-height: 1; white-space: nowrap; }
.matchday-action-panel { display: flex; justify-content: space-between; gap: 1rem; align-items: center; border-color: color-mix(in srgb, var(--wc-warning) 35%, var(--wc-surface-strong)); background: linear-gradient(135deg, color-mix(in srgb, var(--wc-warning) 11%, var(--wc-surface)), color-mix(in srgb, var(--wc-primary) 7%, var(--wc-surface))); }
.matchday-action-panel h2, .matchday-action-panel p { margin: 0; }
.matchday-actions { display: flex; gap: .5rem; flex-wrap: wrap; justify-content: flex-end; }
.matchday-actions .button { min-width: 9rem; }
.status-grid, .nav-card-grid, .discovery-card-grid, .groups-grid, .round-grid, .dashboard-grid, .detail-grid { display: grid; gap: 1rem; }
.status-grid { grid-template-columns: repeat(auto-fit, minmax(180px, 1fr)); }
.tournament-shell :is(.status-grid article, .nav-card, .panel-card, .group-summary-card, .match-card, .champion-card) { color: var(--wc-text); background: var(--wc-surface); border: 1px solid var(--wc-surface-strong); border-radius: var(--wc-radius-md); box-shadow: 0 .75rem 1.5rem rgba(0,0,0,.22); }
.status-grid article { display: grid; gap: .25rem; padding: 1rem; }
.status-grid strong { color: var(--wc-text); font-size: clamp(1.45rem, 3vw, 2.6rem); line-height: 1.1; }
.status-grid span { color: var(--wc-muted); }
.nav-card-grid { grid-template-columns: repeat(auto-fit, minmax(180px, 1fr)); }
.nav-card { display: grid; gap: .5rem; min-height: 8rem; padding: 1rem; transition: transform .16s ease, box-shadow .16s ease; }
.nav-card strong { color: var(--wc-text); font-size: 1.2rem; }
.nav-card span, .empty-state, .view-head p, .match-meta, .advance-hint, .penalty-note, .group-next, .trend-list span { color: var(--wc-muted); }
.discovery-card-grid { grid-template-columns: repeat(3, minmax(0, 1fr)); }
.discovery-card { display: grid; gap: .45rem; min-width: 0; min-height: 7rem; padding: 1rem; border: 1px solid color-mix(in srgb, var(--wc-primary) 24%, var(--wc-surface-strong)); border-radius: var(--wc-radius-md); color: var(--wc-text); background: var(--wc-surface); }
.discovery-card span { color: var(--wc-warning); font-size: .78rem; font-weight: 950; letter-spacing: .08em; text-transform: uppercase; }
.discovery-card strong { color: var(--wc-text); font-size: 1.1rem; line-height: 1.25; }
.discovery-card:hover, .discovery-card:focus-visible { color: var(--wc-primary); background: color-mix(in srgb, var(--wc-primary) 8%, var(--wc-surface)); }
.dashboard-grid, .detail-grid { grid-template-columns: repeat(auto-fit, minmax(min(100%, 320px), 1fr)); }
.panel-card { padding: 1rem; }
.panel-card h2, .view-head h1 { margin-top: 0; }
.match-list { display: grid; gap: .75rem; }
.groups-grid { grid-template-columns: repeat(auto-fit, minmax(min(100%, 270px), 1fr)); }
.group-summary-card { content-visibility: auto; padding: 1rem; }
.group-summary-card header { display: flex; justify-content: space-between; gap: .75rem; align-items: start; }
.group-summary-card h2 { margin: 0; color: var(--wc-text); }
.group-summary-card header a { color: var(--wc-primary); font-weight: 950; }
.team-list { display: grid; grid-template-columns: repeat(auto-fit, minmax(120px, 1fr)); gap: .5rem; margin-block: .75rem; }
.team-list span, .team-identity { display: inline-flex; gap: .5rem; align-items: center; min-width: 0; color: var(--wc-text); }
.team-list img, .team-identity img { width: 1.5rem; height: 1rem; object-fit: cover; border-radius: .25rem; box-shadow: 0 0 0 1px var(--wc-surface-strong); flex: 0 0 auto; }
.next-match-inline { display: flex; flex-wrap: wrap; gap: .5rem; align-items: center; font-size: clamp(1rem, 1.6vw, 1.35rem) !important; }
.next-match-inline img { width: 1.5rem; height: 1rem; object-fit: cover; border-radius: .25rem; }
.team-identity--placeholder img, .champion-card .team-identity img { width: 2.5rem; height: 2.5rem; border-radius: .75rem; }
.standings-summary { display: grid; gap: .5rem; padding: 0; margin: .75rem 0; list-style: none; }
.standings-summary li { display: grid; grid-template-columns: minmax(0, 1fr) auto; gap: .5rem; align-items: center; padding: .5rem; border-radius: .25rem; background: var(--wc-surface-strong); color: var(--wc-text); }
.standings-summary em { grid-column: 1 / -1; color: var(--wc-muted); font-size: .76rem; font-style: normal; }
.standings-summary .qualification-info { grid-column: 1 / -1; margin-left: 0; }
.view-head { padding: 1.5rem; border: 1px solid var(--wc-surface-strong); border-radius: var(--wc-radius-lg); background: var(--wc-surface); }
.view-head p { max-width: 70ch; color: var(--wc-muted); }
.standings-wrap { overflow-x: auto; }
.standings-table { min-width: 590px; color: var(--wc-text); font-size: .88rem; }
.standings-table caption { text-align: left; font-weight: 950; padding: .5rem 0; color: var(--wc-warning); }
.standings-table th, .standings-table td { padding: .5rem; border-bottom: 1px solid var(--wc-surface-strong); }
.qual-badge { display: block; width: max-content; max-width: 9rem; margin-top: .25rem; border-radius: .25rem; padding: .25rem .5rem; background: var(--wc-surface-strong); color: var(--wc-muted); font-size: .68rem; font-weight: 900; white-space: nowrap; }
.qualified .qual-badge { color: var(--wc-primary); }
.third .qual-badge { color: var(--wc-warning); }
.out { color: var(--wc-muted); }
.round-pager { display: flex; justify-content: space-between; flex-wrap: wrap; gap: .75rem; }
.round-grid { grid-template-columns: repeat(auto-fit, minmax(min(100%, 300px), 1fr)); align-items: start; }
.final-grid { grid-template-columns: repeat(auto-fit, minmax(min(100%, 380px), 1fr)); }
.match-card { display: grid; gap: .75rem; padding: 1rem; transition: transform .16s ease, box-shadow .16s ease; }
.match-card__head, .score-line { display: flex; align-items: center; justify-content: space-between; gap: .75rem; }
.match-card__head { color: var(--wc-muted); font-weight: 900; }
.score-line { display: grid; grid-template-columns: minmax(0, 1fr) auto minmax(0, 1fr); }
.score-team { min-width: 0; font-weight: 900; color: var(--wc-text); overflow-wrap: anywhere; }
.score-team--away { justify-self: end; text-align: right; }
.score-center { display: inline-flex; align-items: center; gap: .25rem; color: var(--wc-muted); }
.score-bubble { inline-size: clamp(1.75rem, 2.5vw, 2.25rem); block-size: clamp(1.75rem, 2.5vw, 2.25rem); border-radius: .25rem; border: 1px solid var(--wc-surface-strong); display: grid; place-items: center; font-weight: 900; color: var(--wc-text); background: var(--wc-surface-strong); }
.winner { color: var(--wc-warning); font-weight: 1000; }
.loser { color: var(--wc-muted); }
.tournament-shell .status-pill, .tournament-shell .match-card .status-pill { display: inline-flex; align-items: center; border-radius: .25rem; padding: .25rem .5rem; color: var(--wc-bg); background: var(--wc-primary); font-size: .7rem; font-weight: 950; letter-spacing: .05em; white-space: nowrap; }
.tournament-shell .status-live { background: var(--wc-danger); color: var(--wc-bg); animation: live-pulse 1.6s ease-in-out infinite; }
.tournament-shell .status-finished, .tournament-shell .status-scheduled { background: var(--wc-primary); color: var(--wc-bg); }
.tournament-shell .status-postponed { background: var(--wc-surface-strong); color: var(--wc-text); }
.tournament-shell .status-forecast { background: var(--wc-warning); color: var(--wc-bg); }
.live { box-shadow: 0 0 0 .25rem color-mix(in srgb, var(--wc-danger) 26%, transparent), 0 0 1.5rem color-mix(in srgb, var(--wc-danger) 16%, transparent); }
.match-meta, .penalty-note, .advance-hint { margin: 0; font-size: .84rem; line-height: 1.6; }
.info-callout { padding: 1rem; border-radius: var(--wc-radius-md); color: var(--wc-text); background: var(--wc-surface-strong); font-weight: 900; }
.forecast-toolbar { display: flex; justify-content: space-between; gap: 1rem; align-items: center; margin-bottom: 1rem; }
.forecast-toolbar p, .public-trends p { margin: .25rem 0 0; color: var(--wc-muted); }
.forecast-toolbar select, .forecast-toolbar button, .tournament-shell button, .tournament-shell input, .tournament-shell select { color: var(--wc-text); background: var(--wc-surface-strong); border: 1px solid var(--wc-surface-strong); }
.forecast-toolbar button, .tournament-shell button { color: var(--wc-bg); background: var(--wc-primary); }
.trend-list { display: grid; gap: .5rem; margin: .5rem 0 0; padding-left: 1.5rem; }
.champion-card { padding: 1rem; color: var(--wc-text); font-size: clamp(1.2rem, 2.5vw, 2rem); font-weight: 950; }
.mini-wall-chart { display: grid; gap: .75rem; }
.mini-wall-chart h2 { color: var(--wc-text); margin-bottom: 0; }
.mini-rounds { display: grid; grid-template-columns: repeat(auto-fit, minmax(150px, 1fr)); gap: .75rem; }
.mini-rounds a { display: grid; gap: .25rem; padding: 1rem; border: 1px solid var(--wc-surface-strong); border-radius: var(--wc-radius-md); color: var(--wc-text); background: var(--wc-surface); font-weight: 950; }
.mini-rounds a::before { content: ""; width: 2rem; height: .2rem; border-radius: .2rem; background: var(--wc-warning); }
.mini-rounds a:hover, .mini-rounds a:focus-visible, .nav-card:hover, .nav-card:focus-visible { color: var(--wc-primary); }
.wc-admin-form { display: grid; grid-template-columns: repeat(auto-fit, minmax(5rem, 1fr)); gap: .5rem; margin-top: .5rem; padding-top: .5rem; border-top: 1px dashed var(--wc-surface-strong); }
.wc-admin-form label { display: grid; gap: .25rem; color: var(--wc-muted); font-size: .66rem; font-weight: 900; text-transform: uppercase; }
.wc-admin-form input, .wc-admin-form select { width: 100%; min-width: 0; padding: .5rem; border: 1px solid var(--wc-surface-strong); border-radius: .5rem; color: var(--wc-text); background: var(--wc-surface-strong); }
.wc-admin-form button { align-self: end; min-height: 2.5rem; border: 0; border-radius: .5rem; background: var(--wc-primary); color: var(--wc-bg); font-weight: 950; }
.save-state, .update-announcer { color: var(--wc-primary); font-weight: 900; }
.save-state.error { color: var(--wc-danger); }
.updated-flash { animation: updated-flash 1.5s ease; }
.simulation-wizard-dialog { position: relative; box-sizing: border-box; width: min(1120px, calc(100dvw - 1rem)); height: min(760px, calc(100dvh - 1rem)); max-width: none; max-height: none; overflow: hidden; }
.simulation-wizard-frame { display: grid; grid-template-rows: auto auto minmax(0, 1fr); gap: .75rem; min-height: 0; height: 100%; overflow: hidden; }
.simulation-wizard-dialog .dialog-close { position: absolute; top: 1rem; right: 1rem; float: none; z-index: 2; }
.simulation-wizard-head { clear: none; display: flex; justify-content: space-between; gap: 1rem; align-items: start; min-width: 0; padding-right: 5.5rem; margin: 0; }
.simulation-wizard-head h2 { margin: 0; color: var(--wc-text); }
.simulation-wizard-head p { margin-bottom: 0; }
.simulation-setup-flow, .simulation-runner { min-height: 0; overflow: auto; overflow-x: hidden; padding-right: .25rem; }
.simulation-wizard-steps { display: grid; grid-template-columns: repeat(4, minmax(0, 1fr)); gap: .5rem; padding: 0; margin: 1rem 0; list-style: none; }
.simulation-wizard-steps li { padding: .65rem; border: 1px solid var(--wc-surface-strong); border-radius: var(--wc-radius-sm); color: var(--wc-muted); background: var(--wc-surface-strong); font-size: .82rem; font-weight: 950; text-align: center; }
.simulation-wizard-steps li[aria-current="step"] { color: var(--wc-bg); background: var(--wc-primary); }
.simulation-wizard-panel, .simulation-source-panel { display: grid; gap: .75rem; min-width: 0; padding: 1rem; border: 1px solid var(--wc-surface-strong); border-radius: var(--wc-radius-md); background: var(--wc-surface); }
.simulation-wizard-panel[hidden], .simulation-source-panel[hidden], .simulation-runner[hidden], .simulation-token-warning[hidden], .simulation-setup-flow[hidden] { display: none; }
.simulation-meta-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(150px, 1fr)); gap: .75rem; margin: 0; }
.simulation-meta-grid div { min-width: 0; padding: .75rem; border-radius: var(--wc-radius-sm); background: var(--wc-surface-strong); }
.simulation-meta-grid dt { color: var(--wc-warning); font-size: .72rem; font-weight: 950; text-transform: uppercase; letter-spacing: .08em; }
.simulation-meta-grid dd { margin: .2rem 0 0; color: var(--wc-text); overflow-wrap: anywhere; }
.simulation-wizard-nav, .simulation-run-controls { display: flex; gap: .5rem; align-items: center; flex-wrap: wrap; }
.simulation-runner { display: grid; align-content: start; gap: .75rem; }
.simulation-runner-head { display: flex; justify-content: space-between; gap: 1rem; align-items: start; min-width: 0; }
.simulation-runner-head h3 { margin: 0; color: var(--wc-text); font-size: clamp(1.35rem, 3vw, 2.25rem); }
.simulation-progress-meter { height: .65rem; overflow: hidden; border-radius: 999px; background: var(--wc-surface-strong); }
.simulation-progress-meter span { display: block; width: 0; height: 100%; border-radius: inherit; background: linear-gradient(90deg, var(--wc-primary), var(--wc-warning)); transition: width .2s ease; }
.simulation-control-stats { display: grid; grid-template-columns: repeat(4, minmax(0, 1fr)); gap: .75rem; }
.simulation-control-stats article { min-width: 0; padding: .75rem; border: 1px solid var(--wc-surface-strong); border-radius: var(--wc-radius-sm); background: var(--wc-surface-strong); }
.simulation-control-stats strong { display: block; overflow: hidden; color: var(--wc-text); font-size: clamp(1rem, 2vw, 1.5rem); text-overflow: ellipsis; white-space: nowrap; }
.simulation-control-stats span { color: var(--wc-muted); font-size: .78rem; font-weight: 900; }
.simulation-control-room { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: .75rem; align-items: start; }
.simulation-control-room h4, .simulation-run-log-panel h4 { margin: 0; color: var(--wc-warning); }
.simulation-cohort-actions { display: flex; gap: .5rem; flex-wrap: wrap; }
.simulation-participant-table-wrap, .simulation-ranking-table-wrap { max-width: 100%; overflow-x: auto; }
.simulation-participant-table, .simulation-ranking-table { width: 100%; border-collapse: collapse; min-width: 620px; }
.simulation-participant-table th, .simulation-participant-table td, .simulation-ranking-table th, .simulation-ranking-table td { padding: .6rem; border-bottom: 1px solid var(--wc-surface-strong); text-align: left; vertical-align: top; }
.simulation-participant-table small, .simulation-ranking-table small { display: block; color: var(--wc-muted); font-size: .76rem; line-height: 1.35; }
.simulation-status-badge { display: inline-flex; width: max-content; max-width: 100%; align-items: center; gap: .3rem; padding: .25rem .55rem; border-radius: 999px; border: 1px solid var(--wc-surface-strong); background: var(--wc-surface-strong); color: var(--wc-muted); font-size: .68rem; font-weight: 950; text-transform: uppercase; letter-spacing: .03em; overflow-wrap: anywhere; }
.simulation-status-badge::before { content: ""; width: .45rem; height: .45rem; border-radius: 50%; background: currentColor; flex: 0 0 auto; }
.simulation-status-paid { background: color-mix(in srgb, var(--wc-primary) 22%, var(--wc-surface)); color: var(--wc-primary); }
.simulation-status-due { background: color-mix(in srgb, var(--wc-danger) 22%, var(--wc-surface)); color: var(--wc-danger); }
.simulation-status-points { background: color-mix(in srgb, var(--wc-warning) 24%, var(--wc-surface)); color: var(--wc-warning); }
.simulation-ranking-preview { margin-top: .75rem; }
.simulation-ranking-grid { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: .9rem; }
.simulation-ranking-grid article { min-width: 0; padding: .75rem; border: 1px solid var(--wc-surface-strong); border-radius: var(--wc-radius-sm); background: var(--wc-surface-strong); }
.simulation-ranking-grid h3 { margin-top: 0; color: var(--wc-warning); }
.simulation-match-card, .simulation-score-explanation, .simulation-score-card, .simulation-compact-panel { display: grid; gap: .5rem; min-width: 0; }
.simulation-match-card p, .simulation-score-card p, .simulation-compact-panel p { margin: 0; }
.simulation-phase-summary ul { max-height: 14rem; overflow: auto; padding-left: 1.25rem; }
.simulation-log { display: grid; gap: .35rem; max-height: 16rem; overflow: auto; overflow-x: hidden; padding: .75rem; border: 1px solid var(--wc-surface-strong); border-radius: var(--wc-radius-sm); background: var(--wc-bg); }
.simulation-log p { margin: 0; color: var(--wc-muted); font-family: ui-monospace, SFMono-Regular, Consolas, monospace; font-size: .82rem; }
.simulation-mini-list, .simulation-compact-standings { display: grid; gap: .4rem; padding: 0; margin: 0; list-style: none; }
.simulation-mini-list li, .simulation-compact-standings li { display: grid; gap: .1rem; min-width: 0; padding: .45rem; border-radius: var(--wc-radius-sm); background: var(--wc-surface-strong); }
.simulation-mini-list span, .simulation-compact-standings span { color: var(--wc-muted); font-size: .78rem; }
.simulation-wizard-dialog .standings-wrap { overflow-x: hidden; }
.simulation-wizard-dialog .standings-table { min-width: 0; }
.simulation-delay-field { display: grid; gap: .35rem; max-width: 18rem; }
.simulation-toolbar .primary { background: var(--wc-warning); color: var(--wc-bg); }
.simulation-report-teaser { display: grid; gap: .75rem; }
.simulation-report-shell { display: grid; gap: 1rem; }
.simulation-report-hero { display: flex; justify-content: space-between; gap: 1rem; align-items: start; }
.simulation-report-actions { display: flex; flex-wrap: wrap; gap: .5rem; }
.simulation-report-kpis strong { font-size: clamp(1.25rem, 2.5vw, 2.25rem); }
.simulation-report-progress header { display: flex; justify-content: space-between; gap: 1rem; align-items: start; }
.simulation-phase-track { display: grid; grid-template-columns: repeat(auto-fit, minmax(min(100%, 190px), 1fr)); gap: .75rem; }
.simulation-phase-card { display: grid; gap: .35rem; padding: .9rem; border: 1px solid var(--wc-surface-strong); border-radius: var(--wc-radius-md); background: var(--wc-surface-strong); }
.simulation-phase-card span { color: var(--wc-warning); font-size: .72rem; font-weight: 950; text-transform: uppercase; letter-spacing: .08em; }
.simulation-phase-card strong { color: var(--wc-text); }
.simulation-phase-card p { margin: 0; color: var(--wc-muted); }
.simulation-report-grid { align-items: stretch; }
.simulation-decision-grid, .simulation-report-groups, .simulation-knockout-report { display: grid; grid-template-columns: repeat(auto-fit, minmax(min(100%, 300px), 1fr)); gap: 1rem; }
.simulation-decision-card { min-width: 0; padding: 1rem; border: 1px solid var(--wc-surface-strong); border-radius: var(--wc-radius-md); background: var(--wc-surface-strong); }
.simulation-decision-card h3, .simulation-decision-card h4 { margin-bottom: .35rem; color: var(--wc-text); }
.simulation-decision-card ul { display: grid; gap: .35rem; padding-left: 1.1rem; color: var(--wc-muted); }
.simulation-match-report-list { display: grid; gap: .5rem; }
.simulation-match-report { display: grid; gap: .25rem; min-width: 0; padding: .7rem; border-radius: var(--wc-radius-sm); background: var(--wc-surface-strong); }
.simulation-match-report span, .simulation-match-report small { color: var(--wc-muted); }
.simulation-report-log { max-height: 28rem; }
.simulation-agent-prompt-panel { gap: .75rem; }
.simulation-agent-prompt-head { display: flex; justify-content: space-between; gap: 1rem; align-items: start; min-width: 0; }
.simulation-agent-endpoints { display: flex; flex-wrap: wrap; gap: .5rem; min-width: 0; }
.simulation-agent-endpoints code { min-width: 0; overflow-wrap: anywhere; padding: .35rem .5rem; border-radius: .5rem; background: var(--wc-surface-strong); color: var(--wc-warning); }
.simulation-agent-progress { padding: .7rem; border-radius: var(--wc-radius-sm); background: var(--wc-surface-strong); color: var(--wc-text); font-weight: 900; }
.simulation-agent-prompt { box-sizing: border-box; width: 100%; min-height: 22rem; max-height: 34rem; overflow: auto; resize: vertical; color: var(--wc-text); background: var(--wc-bg); border: 1px solid var(--wc-surface-strong); border-radius: var(--wc-radius-sm); font-family: ui-monospace, SFMono-Regular, Consolas, monospace; font-size: .82rem; line-height: 1.5; }
.simulation-source-mix { display: grid; gap: .75rem; }
.simulation-source-mix-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(min(100%, 160px), 1fr)); gap: .75rem; }
.simulation-source-mix article { display: grid; gap: .25rem; min-width: 0; padding: .75rem; border-radius: var(--wc-radius-sm); background: var(--wc-surface-strong); }
.simulation-source-mix strong { color: var(--wc-text); font-size: clamp(1.3rem, 2.5vw, 2.25rem); }
.simulation-source-mix span { color: var(--wc-muted); overflow-wrap: anywhere; }
.simulation-source-mix meter { width: 100%; }
.simulation-match-explorer { display: grid; gap: 1rem; overflow: hidden; }
.simulation-match-filterbar { display: grid; grid-template-columns: repeat(auto-fit, minmax(min(100%, 150px), 1fr)); gap: .75rem; align-items: end; }
.simulation-match-filterbar label { display: grid; gap: .3rem; min-width: 0; color: var(--wc-muted); font-size: .78rem; font-weight: 900; text-transform: uppercase; }
.simulation-match-filterbar input, .simulation-match-filterbar select { width: 100%; min-width: 0; padding: .6rem; border-radius: .6rem; border: 1px solid var(--wc-surface-strong); background: var(--wc-surface-strong); color: var(--wc-text); }
.simulation-match-table-wrap { overflow: auto; border: 1px solid var(--wc-surface-strong); border-radius: var(--wc-radius-md); background: var(--wc-surface-strong); }
.simulation-match-table { width: 100%; min-width: 1040px; border-collapse: separate; border-spacing: 0; }
.simulation-match-table th, .simulation-match-table td { padding: .7rem .75rem; border-bottom: 1px solid color-mix(in srgb, var(--wc-muted) 16%, transparent); text-align: left; vertical-align: middle; }
.simulation-match-table th { position: sticky; top: 0; z-index: 1; background: color-mix(in srgb, var(--wc-surface) 96%, black); color: var(--wc-warning); font-size: .72rem; font-weight: 950; letter-spacing: .06em; text-transform: uppercase; }
.simulation-match-table tr:last-child td { border-bottom: 0; }
.simulation-match-table tr:hover td { background: color-mix(in srgb, var(--wc-primary) 8%, transparent); }
.simulation-match-table td { color: var(--wc-text); }
.simulation-match-table td small { display: block; margin-top: .18rem; color: var(--wc-muted); font-size: .72rem; }
.simulation-table-fixture { display: grid; gap: .12rem; min-width: 12rem; }
.simulation-table-fixture span { color: var(--wc-muted); font-size: .72rem; font-weight: 900; text-transform: uppercase; }
.simulation-table-prediction { min-width: 13rem; }
.simulation-table-prediction .simulation-table-fixture span { color: var(--wc-warning); }
.simulation-table-score { color: var(--wc-warning); font-weight: 1000; white-space: nowrap; }
.simulation-match-actions { display: flex; flex-wrap: wrap; gap: .4rem; }
.simulation-icon-button { display: inline-grid; place-items: center; min-width: 2.5rem; min-height: 2.5rem; border: 1px solid var(--wc-surface-strong); border-radius: .75rem; color: var(--wc-text); background: var(--wc-bg); font-size: 1.05rem; cursor: pointer; }
.simulation-icon-button:hover, .simulation-icon-button:focus-visible { outline: 2px solid var(--wc-warning); }
.simulation-source-badge { display: inline-flex; width: max-content; max-width: 100%; align-items: center; padding: .25rem .55rem; border-radius: 999px; color: var(--wc-bg); background: var(--wc-primary); font-size: .68rem; font-weight: 950; text-transform: uppercase; letter-spacing: .04em; overflow-wrap: anywhere; }
.simulation-source-agent { background: #7c3aed; color: #fff; }
.simulation-source-generated { background: var(--wc-primary); color: var(--wc-bg); }
.simulation-source-copied { background: var(--wc-warning); color: var(--wc-bg); }
.simulation-source-manual { background: var(--wc-danger); color: var(--wc-bg); }
.simulation-source-pending { background: var(--wc-surface); color: var(--wc-muted); border: 1px solid var(--wc-surface-strong); }
.simulation-detail-dialog { width: min(920px, calc(100dvw - 1rem)); max-width: none; max-height: min(82dvh, 48rem); overflow: hidden; padding: 0; border: 1px solid var(--wc-warning); border-radius: var(--wc-radius-lg); color: var(--wc-text); background: color-mix(in srgb, var(--wc-surface) 96%, black); box-shadow: var(--wc-shadow); }
.simulation-detail-dialog::backdrop { background: rgba(0, 0, 0, .68); backdrop-filter: blur(2px); }
.simulation-detail-dialog-frame { display: grid; gap: .85rem; max-height: min(82dvh, 48rem); overflow: auto; padding: 1rem; }
.simulation-detail-dialog-head { display: flex; justify-content: space-between; gap: 1rem; align-items: start; min-width: 0; }
.simulation-detail-dialog-head h3 { margin: .1rem 0 0; overflow-wrap: anywhere; }
.simulation-detail-tabs { display: flex; flex-wrap: wrap; gap: .4rem; }
.simulation-detail-tabs button { border-radius: 999px; padding: .45rem .7rem; }
.simulation-detail-tabs button[aria-current] { background: var(--wc-warning); color: var(--wc-bg); }
.simulation-calculation-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(min(100%, 150px), minmax(0, 1fr))); gap: .5rem; }
.simulation-calculation-grid p { display: grid; gap: .2rem; min-width: 0; margin: 0; padding: .55rem; border-radius: .55rem; background: var(--wc-bg); }
.simulation-calculation-grid strong { color: var(--wc-warning); font-size: .72rem; text-transform: uppercase; letter-spacing: .06em; }
.simulation-calculation-grid span { color: var(--wc-text); overflow-wrap: anywhere; }
.simulation-match-detail-fallback { display: none; color: var(--wc-muted); }
.simulation-match-detail-content { display: grid; gap: .75rem; }
.simulation-match-detail-content section { min-width: 0; }
.simulation-match-detail-content p, .simulation-match-detail-content li { overflow-wrap: anywhere; }

@keyframes live-pulse { 50% { box-shadow: 0 0 0 .25rem color-mix(in srgb, var(--wc-danger) 18%, transparent); } }
@keyframes updated-flash { 20% { outline: 3px solid var(--wc-warning); } }

@media (hover: hover) {
  .nav-card:hover, .match-card:hover, .group-summary-card:hover { transform: translateY(-2px); box-shadow: 0 1rem 2rem rgba(0,0,0,.3); }
}

@media (max-width: 767px) {
  .worldcup-container { width: min(100% - .5rem, 100%); margin-top: .5rem; }
  .tournament-shell { padding: .75rem; border-radius: 1rem; }
  .wc-segmented-nav { top: 4rem; scroll-snap-type: x proximity; }
  .wc-segmented-nav a { scroll-snap-align: start; }
  .wc-hero-panel, .final-hero { align-items: flex-start; flex-direction: column; min-height: 18rem; padding: 1rem; }
  .hero-title, .view-head h1, .final-hero h1 { font-size: 2rem; }
  .next-countdown-card { align-items: flex-start; flex-direction: column; }
  .matchday-action-panel { align-items: stretch; flex-direction: column; }
  .matchday-actions { justify-content: stretch; }
  .matchday-actions .button { flex: 1 1 100%; }
  .discovery-card-grid { grid-template-columns: 1fr; }
  .forecast-toolbar { align-items: stretch; flex-direction: column; }
  .score-line { grid-template-columns: 1fr; text-align: left; }
  .score-team--away { justify-self: start; text-align: left; }
  .score-center { justify-self: center; }
  .team-list { grid-template-columns: 1fr; }
  .standings-table { font-size: .78rem; }
  .simulation-wizard-dialog { padding: .85rem; }
  .simulation-wizard-head, .simulation-runner-head, .simulation-report-hero, .simulation-report-progress header, .simulation-agent-prompt-head { align-items: stretch; flex-direction: column; }
  .simulation-wizard-head { padding-right: 3.5rem; }
  .simulation-wizard-steps { grid-template-columns: 1fr; }
  .simulation-control-stats, .simulation-control-room, .simulation-ranking-grid { grid-template-columns: 1fr; }
  .simulation-participant-table, .simulation-ranking-table { min-width: 0; }
  .simulation-participant-table thead, .simulation-ranking-table thead { display: none; }
  .simulation-participant-table tr, .simulation-ranking-table tr { display: grid; gap: .3rem; padding: .6rem 0; border-bottom: 1px solid var(--wc-surface-strong); }
  .simulation-participant-table td, .simulation-ranking-table td { display: grid; gap: .15rem; padding: .2rem 0; border-bottom: 0; }
  .simulation-run-controls button, .simulation-wizard-nav button { flex: 1 1 10rem; }
  .simulation-detail-dialog { width: calc(100dvw - .75rem); max-height: 86dvh; }
  .simulation-detail-dialog-frame { max-height: 86dvh; padding: .85rem; }
  .simulation-detail-dialog-head { align-items: stretch; flex-direction: column; }
  .simulation-icon-button { min-width: 2.75rem; min-height: 2.75rem; }
}

@media (max-width: 360px) {
  .hero-title, .view-head h1, .final-hero h1 { font-size: 2rem; }
  .status-grid, .nav-card-grid, .discovery-card-grid, .round-grid { gap: .5rem; }
  .match-card { padding: .75rem; }
}

@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after { animation-duration: .01ms !important; animation-iteration-count: 1 !important; scroll-behavior: auto !important; transition: none !important; }
}

@media print {
  body { background: var(--wc-bg) !important; }
  .site-header, .toast-stack, .time-zone-note, .wc-segmented-nav, .wc-breadcrumb, .wc-admin-form, .update-announcer { display: none !important; }
  .container.worldcup-container { width: 100%; margin: 0; }
  .tournament-shell { box-shadow: none; border-radius: 0; print-color-adjust: exact; -webkit-print-color-adjust: exact; }
  .match-card, .group-summary-card, .panel-card { break-inside: avoid; box-shadow: none; }
  .round-grid, .groups-grid { grid-template-columns: repeat(2, 1fr); }
}
