: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; flex-wrap: wrap; gap: .5rem; overflow-x: hidden; padding: .5rem; margin-bottom: 1rem; border: 1px solid var(--wc-surface-strong); border-radius: var(--wc-radius-md); background: var(--wc-surface); }
.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%, 360px), 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; }
.group-fixtures { display: grid; gap: .55rem; padding-top: .85rem; margin-top: .85rem; border-top: 1px solid var(--wc-surface-strong); }
.group-fixtures__head { display: flex; justify-content: space-between; gap: .75rem; align-items: center; color: var(--wc-warning); font-size: .76rem; font-weight: 950; letter-spacing: .08em; text-transform: uppercase; }
.group-fixture-list { display: grid; gap: .45rem; padding: 0; margin: 0; list-style: none; }
.group-fixture-row { min-width: 0; }
.group-fixture-row__main { display: grid; gap: .35rem; min-width: 0; padding: .6rem; border-radius: .25rem; color: var(--wc-text); background: color-mix(in srgb, var(--wc-primary) 7%, var(--wc-surface-strong)); text-decoration: none; }
.group-fixture-row__main:hover, .group-fixture-row__main:focus-visible { color: var(--wc-primary); outline: 2px solid color-mix(in srgb, var(--wc-primary) 55%, transparent); outline-offset: 2px; }
.group-fixture-row__meta, .group-fixture-row__venue { min-width: 0; color: var(--wc-muted); font-size: .75rem; line-height: 1.35; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.group-fixture-row__meta { font-weight: 900; }
.group-fixture-row__teams { display: grid; grid-template-columns: minmax(0, 1fr) auto minmax(0, 1fr); gap: .45rem; align-items: center; min-width: 0; }
.fixture-team { display: inline-flex; gap: .38rem; align-items: center; min-width: 0; font-weight: 900; }
.fixture-team img { width: 1.35rem; height: .9rem; object-fit: cover; border-radius: .2rem; box-shadow: 0 0 0 1px var(--wc-surface-strong); flex: 0 0 auto; }
.fixture-team span { min-width: 0; overflow-wrap: break-word; white-space: normal; }
.fixture-team--away { justify-content: flex-end; text-align: right; }
.fixture-score { display: inline-flex; justify-content: center; min-inline-size: 2.75rem; border: 1px solid var(--wc-surface-strong); border-radius: .25rem; padding: .2rem .35rem; color: var(--wc-text); background: var(--wc-surface); font-weight: 950; }
.fixture-score--pending { color: var(--wc-muted); }
.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-team-line, .qualification-status { display: inline-flex; align-items: center; gap: .4rem; min-width: 0; max-width: 100%; vertical-align: middle; }
.standings-team-line { flex-wrap: wrap; }
.qualification-status { flex: 0 0 auto; gap: .25rem; }
.qualification-status .qualification-info { 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 { max-width: 100%; overflow-x: hidden; overflow-y: visible; }
.standings-table tbody tr { content-visibility: auto; contain-intrinsic-size: auto 4rem; }
.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: inline-flex; align-items: center; width: max-content; max-width: 9rem; min-height: 1.35rem; border-radius: .25rem; padding: .2rem .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 > *, .forecast-toolbar form, .forecast-toolbar label { min-width: 0; max-width: 100%; }
.forecast-toolbar > div { overflow-wrap: anywhere; }
.forecast-toolbar-actions { display: flex; gap: .75rem; align-items: flex-end; justify-content: flex-end; flex-wrap: wrap; min-width: 0; }
.forecast-toolbar-actions .button { min-height: 2.4rem; }
.forecast-toolbar .inline-form { justify-content: flex-end; }
.forecast-toolbar label { display: grid; gap: .35rem; }
.forecast-toolbar select { width: min(100%, 18rem); text-overflow: ellipsis; }
.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; }
.knockout-champion-card { display: grid; gap: .25rem; border-color: color-mix(in srgb, var(--wc-warning) 38%, var(--wc-surface-strong)); background: linear-gradient(135deg, color-mix(in srgb, var(--wc-warning) 12%, var(--wc-surface)), var(--wc-surface)); }
.knockout-champion-card span { color: var(--wc-warning); font-size: .76rem; font-weight: 950; letter-spacing: .08em; text-transform: uppercase; }
.knockout-champion-card strong { color: var(--wc-text); font-size: clamp(1.35rem, 3vw, 2.35rem); overflow-wrap: anywhere; }
.knockout-round-stack { display: grid; gap: 1rem; min-width: 0; overflow-x: hidden; }
.knockout-round-panel { display: grid; gap: .85rem; min-width: 0; }
.knockout-round-head { display: flex; justify-content: space-between; gap: 1rem; align-items: start; min-width: 0; }
.knockout-round-head h2, .knockout-round-head p { margin: 0; }
.knockout-round-head h2 { color: var(--wc-text); overflow-wrap: anywhere; }
.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 { max-width: 100%; overflow-x: auto; }
.simulation-participant-table { width: 100%; border-collapse: collapse; min-width: 620px; }
.simulation-participant-table th, .simulation-participant-table td { padding: .6rem; border-bottom: 1px solid var(--wc-surface-strong); text-align: left; vertical-align: top; }
.simulation-participant-table small, .simulation-ranking-list small { display: block; color: var(--wc-muted); font-size: .76rem; line-height: 1.35; }
.simulation-ranking-list { display: grid; gap: .35rem; max-width: 100%; overflow-x: hidden; }
.simulation-ranking-row { display: grid; grid-template-columns: minmax(3rem, .35fr) minmax(0, 1.4fr) minmax(7rem, .8fr) minmax(10rem, 1fr) minmax(6rem, .6fr); gap: .75rem; align-items: center; min-width: 0; padding: .55rem .7rem; border-bottom: 1px solid var(--wc-surface-strong); }
.simulation-ranking-row > * { min-width: 0; overflow-wrap: anywhere; }
.simulation-ranking-row-head { color: var(--wc-warning); font-size: .72rem; font-weight: 950; letter-spacing: .06em; text-transform: uppercase; }
.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-eligible { 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-status-closed { background: var(--wc-surface-strong); color: var(--wc-muted); }
.simulation-ranking-preview { margin-top: .75rem; }
.simulation-ranking-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(min(100%, 680px), 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-team-flag { width: 1.45rem; height: 1rem; flex: 0 0 auto; object-fit: cover; border: 1px solid color-mix(in srgb, var(--wc-muted) 28%, transparent); border-radius: .2rem; background: var(--wc-bg); }
.simulation-team-identity, .simulation-team-pair, .simulation-score-line, .simulation-table-team { display: inline-flex; align-items: center; gap: .38rem; min-width: 0; max-width: 100%; }
.simulation-team-identity span, .simulation-table-team strong, .simulation-bracket-side span { min-width: 0; overflow-wrap: anywhere; }
.simulation-score-line { justify-content: space-between; flex-wrap: wrap; column-gap: .6rem; row-gap: .25rem; }
.simulation-team-pair { flex-wrap: wrap; }
.simulation-team-pair em { color: var(--wc-muted); font-size: .72rem; font-style: normal; font-weight: 950; text-transform: uppercase; }
.simulation-phase-review { grid-column: 1 / -1; }
.simulation-phase-review p { margin: 0; color: var(--wc-muted); }
.simulation-phase-review-form { display: grid; gap: .7rem; min-width: 0; }
.simulation-phase-review-row { display: grid; gap: .65rem; min-width: 0; margin: 0; padding: .75rem; border: 1px solid var(--wc-surface-strong); border-radius: var(--wc-radius-sm); background: var(--wc-bg); }
.simulation-phase-review-row legend { padding: 0 .25rem; color: var(--wc-warning); font-weight: 950; }
.simulation-phase-review-fixtures, .simulation-phase-review-options { display: grid; grid-template-columns: repeat(auto-fit, minmax(min(100%, 14rem), 1fr)); gap: .55rem; min-width: 0; }
.simulation-phase-review-fixtures > span { display: grid; gap: .25rem; min-width: 0; padding: .55rem; border-radius: .55rem; background: var(--wc-surface-strong); }
.simulation-phase-review-options label { display: flex; gap: .4rem; align-items: center; min-width: 0; color: var(--wc-text); font-weight: 900; }
.simulation-phase-review-options span { color: var(--wc-muted); font-size: .78rem; }
.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-ranking-spotlight { display: grid; gap: .85rem; }
.simulation-ranking-spotlight > header { display: flex; justify-content: space-between; gap: 1rem; align-items: start; }
.simulation-ranking-spotlight h2, .simulation-ranking-spotlight p { margin-block: 0 .25rem; }
.simulation-report-action-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(min(100%, 210px), 1fr)); gap: .75rem; }
.simulation-report-action-grid button, .simulation-report-action-grid a { display: grid; gap: .25rem; min-height: 5.5rem; padding: .85rem; border: 1px solid var(--wc-surface-strong); border-radius: var(--wc-radius-md); text-align: left; color: var(--wc-text); background: var(--wc-surface); }
.simulation-report-action-grid button:hover, .simulation-report-action-grid button:focus-visible, .simulation-report-action-grid a:hover, .simulation-report-action-grid a:focus-visible, .simulation-report-action-grid a[aria-current="page"] { outline: 2px solid var(--wc-warning); background: color-mix(in srgb, var(--wc-primary) 8%, var(--wc-surface)); }
.simulation-report-action-grid strong { color: var(--wc-warning); font-size: 1rem; }
.simulation-report-action-grid span { color: var(--wc-muted); font-size: .82rem; line-height: 1.35; }
.simulation-section-dialog { width: min(1180px, calc(100dvw - 1rem)); max-width: none; max-height: min(88dvh, 54rem); 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) 97%, black); box-shadow: var(--wc-shadow); }
.simulation-section-dialog::backdrop { background: rgba(0, 0, 0, .7); backdrop-filter: blur(2px); }
.simulation-section-frame { display: grid; grid-template-rows: auto auto minmax(0, 1fr); gap: .85rem; max-height: min(88dvh, 54rem); overflow: hidden; padding: 1rem; }
.simulation-section-frame > section { min-height: 0; overflow: auto; padding-right: .15rem; }
.simulation-section-frame h3, .simulation-section-frame h4 { margin-top: 0; }
.simulation-report-split { display: grid; grid-template-columns: minmax(0, 1.15fr) minmax(280px, .85fr); gap: 1rem; align-items: start; }
.simulation-report-split > article { min-width: 0; padding: .85rem; border: 1px solid var(--wc-surface-strong); border-radius: var(--wc-radius-md); background: var(--wc-surface-strong); }
.simulation-ranking-summary { display: grid; grid-template-columns: repeat(auto-fit, minmax(min(100%, 150px), 1fr)); gap: .7rem; }
.simulation-ranking-summary article { min-width: 0; padding: .75rem; border: 1px solid var(--wc-surface-strong); border-radius: var(--wc-radius-sm); background: var(--wc-bg); }
.simulation-ranking-summary strong { display: block; color: var(--wc-text); font-size: clamp(1.15rem, 2vw, 1.7rem); overflow-wrap: anywhere; }
.simulation-ranking-summary span { color: var(--wc-muted); font-size: .78rem; font-weight: 900; }
.simulation-ranking-detail-button { min-width: 5rem; }
.simulation-ranking-ledger { display: grid; gap: .85rem; }
.simulation-ledger-list { display: grid; gap: .55rem; }
.simulation-ledger-row { display: grid; grid-template-columns: minmax(5rem, .55fr) minmax(0, 1fr) minmax(0, 1fr) minmax(7rem, .65fr) minmax(10rem, 1fr); gap: .65rem; align-items: start; min-width: 0; padding: .7rem; border: 1px solid var(--wc-surface-strong); border-radius: var(--wc-radius-sm); background: var(--wc-bg); }
.simulation-ledger-row div, .simulation-ledger-row details, .simulation-ledger-row p { min-width: 0; margin: 0; }
.simulation-ledger-row strong, .simulation-ledger-row span { display: block; overflow-wrap: anywhere; }
.simulation-ledger-row span { color: var(--wc-muted); font-size: .75rem; line-height: 1.35; }
.simulation-ledger-row summary { color: var(--wc-warning); cursor: pointer; font-weight: 950; }
.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 { 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-compact-standings strong { display: flex; align-items: center; gap: .38rem; min-width: 0; overflow-wrap: anywhere; }
.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-bracket-head { display: flex; justify-content: space-between; gap: 1rem; align-items: start; min-width: 0; margin-bottom: .75rem; }
.simulation-bracket-head h3, .simulation-bracket-head p { margin-block: 0 .25rem; }
.simulation-bracket-counts { display: flex; flex-wrap: wrap; justify-content: flex-end; gap: .35rem; min-width: 0; }
.simulation-bracket-counts span { display: inline-flex; align-items: center; gap: .28rem; max-width: 100%; padding: .28rem .48rem; border: 1px solid color-mix(in srgb, var(--wc-primary) 36%, var(--wc-surface-strong)); border-radius: 999px; background: color-mix(in srgb, var(--wc-primary) 12%, var(--wc-bg)); color: var(--wc-muted); font-size: .66rem; font-weight: 950; text-transform: uppercase; }
.simulation-bracket-counts strong { color: var(--wc-warning); }
.simulation-champion-path { display: grid; grid-template-columns: minmax(10rem, .42fr) minmax(0, 1fr); gap: .65rem; min-width: 0; margin-bottom: .75rem; }
.simulation-champion-card, .simulation-champion-path li, .simulation-final-card { min-width: 0; border: 1px solid color-mix(in srgb, var(--wc-warning) 34%, var(--wc-surface-strong)); border-radius: var(--wc-radius-sm); background: linear-gradient(180deg, color-mix(in srgb, var(--wc-primary) 12%, var(--wc-surface)), var(--wc-bg)); }
.simulation-champion-card { display: grid; gap: .25rem; padding: .7rem; }
.simulation-champion-card span, .simulation-champion-path li span, .simulation-final-card h4 { color: var(--wc-warning); font-size: .68rem; font-weight: 950; letter-spacing: .06em; text-transform: uppercase; }
.simulation-champion-card strong, .simulation-champion-path li strong { display: flex; align-items: center; gap: .35rem; min-width: 0; color: var(--wc-text); overflow: hidden; text-overflow: clip; white-space: nowrap; }
.simulation-champion-card small, .simulation-champion-path li small { color: var(--wc-muted); font-size: .7rem; }
.simulation-champion-path ol { display: grid; grid-template-columns: repeat(auto-fit, minmax(min(100%, 8.5rem), 1fr)); gap: .45rem; min-width: 0; padding: 0; margin: 0; list-style: none; }
.simulation-champion-path li { display: grid; gap: .16rem; padding: .55rem; }
.simulation-hybrid-bracket { display: grid; grid-template-columns: minmax(0, 1fr) minmax(12.5rem, .52fr) minmax(0, 1fr); gap: .65rem; align-items: center; min-width: 0; overflow-x: hidden; }
.simulation-bracket-wing { display: grid; gap: .5rem; align-items: center; min-width: 0; }
.simulation-bracket-wing-left { grid-template-columns: minmax(0, 1.14fr) minmax(0, .94fr) minmax(0, .82fr) minmax(0, .72fr); }
.simulation-bracket-wing-right { grid-template-columns: minmax(0, .72fr) minmax(0, .82fr) minmax(0, .94fr) minmax(0, 1.14fr); }
.simulation-bracket-round { position: relative; display: grid; gap: .38rem; min-width: 0; padding: .5rem; border: 1px solid color-mix(in srgb, var(--wc-primary) 32%, var(--wc-surface-strong)); border-radius: var(--wc-radius-sm); background: linear-gradient(180deg, color-mix(in srgb, var(--wc-primary) 10%, var(--wc-surface)), var(--wc-surface-strong)); box-shadow: inset 0 0 0 1px color-mix(in srgb, var(--wc-warning) 10%, transparent); }
.simulation-bracket-round::after { content: ""; position: absolute; top: 2.2rem; bottom: 1rem; width: 1px; background: linear-gradient(180deg, transparent, color-mix(in srgb, var(--wc-primary) 58%, transparent), transparent); }
.simulation-bracket-wing-left .simulation-bracket-round::after { right: -.34rem; }
.simulation-bracket-wing-right .simulation-bracket-round::after { left: -.34rem; }
.simulation-bracket-round h4 { display: flex; justify-content: space-between; gap: .35rem; margin: 0; color: var(--wc-warning); font-size: .7rem; letter-spacing: .05em; text-transform: uppercase; }
.simulation-bracket-round h4 span { color: var(--wc-muted); font-size: .62rem; letter-spacing: 0; white-space: nowrap; }
.simulation-bracket-matches { display: grid; gap: .34rem; min-width: 0; }
.simulation-bracket-center { display: grid; gap: .7rem; min-width: 0; align-content: center; }
.simulation-final-card { display: grid; gap: .4rem; padding: .58rem; box-shadow: 0 0 1rem color-mix(in srgb, var(--wc-warning) 12%, transparent); }
.simulation-final-card h4 { margin: 0; }
.simulation-bracket-match { display: grid; gap: .26rem; min-width: 0; padding: .42rem; border: 1px solid color-mix(in srgb, var(--wc-primary) 45%, var(--wc-surface-strong)); border-radius: .45rem; background: color-mix(in srgb, var(--wc-bg) 74%, var(--wc-primary)); box-shadow: 0 0 .75rem color-mix(in srgb, var(--wc-primary) 14%, transparent); }
.simulation-bracket-match-final { border-color: var(--wc-warning); background: color-mix(in srgb, var(--wc-warning) 10%, var(--wc-bg)); }
.simulation-bracket-match-meta { display: flex; justify-content: space-between; gap: .45rem; align-items: center; color: var(--wc-muted); font-size: .6rem; font-weight: 950; text-transform: uppercase; }
.simulation-bracket-side { display: grid; grid-template-columns: auto minmax(0, 1fr) auto; gap: .3rem; align-items: center; min-width: 0; padding: .28rem .34rem; border: 1px solid var(--wc-surface-strong); border-radius: .35rem; background: color-mix(in srgb, var(--wc-surface) 82%, transparent); color: var(--wc-text); }
.simulation-bracket-side.winner { border-color: var(--wc-warning); background: color-mix(in srgb, var(--wc-warning) 18%, var(--wc-surface)); color: var(--wc-warning); }
.simulation-bracket-side strong { color: inherit; font-size: .86rem; }
.simulation-bracket-note { color: var(--wc-muted); font-size: .62rem; line-height: 1.3; overflow-wrap: anywhere; }
.simulation-hybrid-bracket .simulation-bracket-match { gap: .2rem; padding: .34rem; }
.simulation-hybrid-bracket .simulation-bracket-match-meta { font-size: .55rem; }
.simulation-hybrid-bracket .simulation-team-flag { width: 1.05rem; height: .72rem; border-radius: .15rem; }
.simulation-hybrid-bracket .simulation-bracket-side { gap: .22rem; padding: .22rem .28rem; }
.simulation-hybrid-bracket .simulation-bracket-side span { font-size: .68rem; line-height: 1.15; overflow: hidden; text-overflow: clip; white-space: nowrap; }
.simulation-hybrid-bracket .simulation-bracket-side strong { font-size: .76rem; }
.simulation-hybrid-bracket .simulation-bracket-note { display: none; }
.simulation-mobile-knockout { display: none; }
.simulation-mobile-round { min-width: 0; border: 1px solid var(--wc-surface-strong); border-radius: var(--wc-radius-sm); background: var(--wc-bg); overflow: hidden; }
.simulation-mobile-round summary { display: grid; grid-template-columns: minmax(0, 1fr) auto; gap: .2rem .65rem; align-items: center; padding: .72rem; cursor: pointer; color: var(--wc-text); }
.simulation-mobile-round summary span { min-width: 0; color: var(--wc-warning); font-weight: 950; overflow-wrap: anywhere; }
.simulation-mobile-round summary strong { color: var(--wc-text); font-size: .78rem; white-space: nowrap; }
.simulation-mobile-round summary small { grid-column: 1 / -1; color: var(--wc-muted); font-size: .72rem; }
.simulation-mobile-round-matches { display: grid; gap: .5rem; min-width: 0; padding: 0 .72rem .72rem; }
.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-grid > * { display: grid; gap: .25rem; min-width: 0; padding: .75rem; border-radius: var(--wc-radius-sm); background: var(--wc-surface-strong); }
.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-fixture .simulation-table-team { color: var(--wc-text); font-size: inherit; text-transform: none; }
.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; }
.actual-ranking-shell { gap: 1rem; }
.actual-ranking-filter-panel { display: grid; gap: .75rem; }
.actual-ranking-filters { grid-template-columns: minmax(12rem, 1fr) minmax(14rem, 1.2fr) auto; }
.actual-ranking-filters button { align-self: end; min-height: 2.65rem; border-radius: var(--wc-radius-md); background: var(--wc-primary); color: var(--wc-bg); }
.actual-ranking-mode-grid a { text-decoration: none; }
.actual-ranking-list a { color: var(--wc-primary); }
.actual-ranking-list a:hover, .actual-ranking-list a:focus-visible { color: var(--wc-warning); }
.actual-ranking-row small { display: block; color: var(--wc-muted); font-size: .76rem; line-height: 1.35; }
.actual-ranking-spotlight .actual-ranking-list { max-height: 30rem; overflow: hidden; }
.tournament-shell .points-breakdown-dialog { width: min(920px, calc(100dvw - 1rem)); max-height: min(82dvh, 48rem); 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); }
.tournament-shell .points-breakdown-dialog::backdrop { background: rgba(0, 0, 0, .68); backdrop-filter: blur(2px); }
.tournament-shell .points-breakdown-frame { max-height: min(82dvh, 48rem); }
.tournament-shell .points-breakdown-summary article, .tournament-shell .points-breakdown-row { border-color: var(--wc-surface-strong); border-radius: var(--wc-radius-sm); background: var(--wc-bg); }
.tournament-shell .points-breakdown-summary strong { color: var(--wc-text); }
.tournament-shell .points-breakdown-summary span, .tournament-shell .points-breakdown-row span { color: var(--wc-muted); }
.tournament-shell .points-breakdown-row summary { color: var(--wc-warning); }

@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: 980px) {
  .simulation-bracket-head, .simulation-champion-path { grid-template-columns: 1fr; align-items: stretch; flex-direction: column; }
  .simulation-bracket-counts { justify-content: flex-start; }
  .simulation-champion-path ol { grid-template-columns: repeat(auto-fit, minmax(min(100%, 9rem), 1fr)); }
  .simulation-hybrid-bracket { display: none; }
  .simulation-mobile-knockout { display: grid; gap: .65rem; min-width: 0; overflow-x: hidden; }
}

@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; overflow-x: hidden; }
  .forecast-toolbar-actions { align-items: stretch; flex-direction: column; width: 100%; }
  .forecast-toolbar .inline-form { align-items: stretch; flex-direction: column; justify-content: stretch; width: 100%; }
  .forecast-toolbar select, .forecast-toolbar button, .forecast-toolbar-actions .button { width: 100%; }
  .score-line { grid-template-columns: 1fr; text-align: left; }
  .score-team--away { justify-self: start; text-align: left; }
  .score-center { justify-self: center; }
  .group-fixture-row__teams { grid-template-columns: 1fr; gap: .25rem; }
  .fixture-team--away { justify-content: flex-start; text-align: left; }
  .fixture-score { width: max-content; }
  .team-list { grid-template-columns: 1fr; }
  .standings-table { display: block; min-width: 0; width: 100%; font-size: .78rem; }
  .standings-table thead { display: none; }
  .standings-table tbody { display: grid; gap: .55rem; }
  .standings-table tbody tr { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: .2rem .75rem; padding: .65rem; border: 1px solid var(--wc-surface-strong); border-radius: var(--wc-radius-sm); background: var(--wc-surface); content-visibility: visible; contain-intrinsic-size: auto; }
  .standings-table th, .standings-table td { border-bottom: 0; }
  .standings-table td { display: grid; grid-template-columns: 3.5rem minmax(0, 1fr); align-items: center; gap: .4rem; padding: .1rem 0; }
  .standings-table td::before { content: attr(data-label); color: var(--wc-warning); font-size: .68rem; font-weight: 900; letter-spacing: .04em; text-transform: uppercase; }
  .standings-table td[data-label="Team"] { grid-column: 1 / -1; }
  .standings-table td[data-label="Team"] .standings-team-line { justify-content: flex-start; }
  .simulation-wizard-dialog { padding: .85rem; }
  .simulation-wizard-head, .simulation-runner-head, .simulation-report-hero, .simulation-report-progress header, .simulation-agent-prompt-head, .simulation-ranking-spotlight > header, .knockout-round-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, .simulation-report-split { grid-template-columns: 1fr; }
  .actual-ranking-filters { grid-template-columns: 1fr; }
  .simulation-ledger-row { grid-template-columns: 1fr; }
  .simulation-participant-table { min-width: 0; }
  .simulation-participant-table thead { display: none; }
  .simulation-participant-table tr { display: grid; gap: .3rem; padding: .6rem 0; border-bottom: 1px solid var(--wc-surface-strong); }
  .simulation-participant-table td { display: grid; gap: .15rem; padding: .2rem 0; border-bottom: 0; }
  .simulation-ranking-row, .simulation-ranking-row-head { grid-template-columns: 1fr; gap: .25rem; align-items: stretch; padding: .7rem; border: 1px solid var(--wc-surface-strong); border-radius: var(--wc-radius-sm); background: var(--wc-bg); }
  .simulation-ranking-row-head { display: none; }
  .simulation-ranking-row [data-label]::before { content: attr(data-label); display: block; margin-bottom: .1rem; color: var(--wc-warning); font-size: .68rem; font-weight: 950; letter-spacing: .05em; text-transform: uppercase; }
  .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-section-dialog { width: calc(100dvw - .75rem); max-height: 88dvh; }
  .simulation-section-frame { max-height: 88dvh; 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); }
}
