:root {
  --canvas: #121212;
  --ink: #f1eee7;
  --muted: #a8a59f;
  --panel: #1a1a1a;
  --line: rgba(241, 238, 231, .22);
  --blue: #ef443a;
  --cyan: #eaff32;
  --gold: #f1eee7;
  --green: #eaff32;
  --red: #ef443a;
  --shadow: 0 24px 58px rgba(0, 0, 0, .42);
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  position: relative; min-width: 320px; margin: 0; color: var(--ink); isolation: isolate;
  background: linear-gradient(121deg, transparent 0 72%, rgba(239,68,58,.12) 72.1% 72.4%, transparent 72.5%), radial-gradient(circle at 84% 8%, rgba(234,255,50,.09), transparent 23rem), repeating-linear-gradient(18deg, rgba(255,255,255,.025) 0 1px, transparent 1px 7px), var(--canvas);
  font-family: Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
}
body::before { content: ""; position: fixed; z-index: 0; inset: 0; pointer-events: none; opacity: .55; background: linear-gradient(94deg, transparent 0 17%, rgba(239,68,58,.17) 17.1% 17.25%, transparent 17.4%), linear-gradient(43deg, transparent 0 87%, rgba(234,255,50,.16) 87.1% 87.24%, transparent 87.4%); mix-blend-mode: screen; }
button { font: inherit; }
button:not(:disabled) { cursor: pointer; }
button:focus-visible, a:focus-visible { outline: 3px solid var(--cyan); outline-offset: 3px; }
.sr-only { position: absolute; width: 1px; height: 1px; padding: 0; overflow: hidden; clip: rect(0, 0, 0, 0); white-space: nowrap; border: 0; }
.role-icon { display: inline-block; flex: 0 0 auto; width: var(--role-icon-size, 24px); aspect-ratio: 1; background: url("role-sprite.webp") no-repeat; background-size: 400% 400%; filter: drop-shadow(0 0 4px rgba(0,0,0,.36)); image-rendering: auto; vertical-align: -.28em; }
.role-icon-small { --role-icon-size: 18px; }
.role-icon-tiny { --role-icon-size: 15px; }
.role-icon-large { --role-icon-size: 30px; }
.role-icon-top { background-position: 66.666% 33.333%; }
.role-icon-jng { background-position: 66.666% 0; }
.role-icon-mid { background-position: 100% 0; }
.role-icon-bot { background-position: 33.333% 0; }
.role-icon-sup { background-position: 33.333% 33.333%; }
.role-label, .champion-role-icons { display: inline-flex; align-items: center; gap: 5px; min-width: 0; }
.role-label > span:last-child, .champion-role-icons > span:last-child { overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }

.site-header { position: relative; z-index: 1; min-height: 76px; display: flex; align-items: center; justify-content: space-between; gap: 20px; padding: 14px clamp(20px, 5vw, 72px); overflow: hidden; border-bottom: 1px solid var(--line); background: rgba(18,18,18,.9); backdrop-filter: blur(14px); }
.site-header::after { content: ""; position: absolute; right: 10%; bottom: -8px; width: 170px; border-top: 3px solid var(--red); transform: rotate(-12deg); }
.brand { display: inline-flex; align-items: center; gap: 11px; color: var(--ink); text-decoration: none; }
.brand-mark { display: grid; place-items: center; width: 42px; height: 42px; color: var(--red); }
.brand-mark svg { display: block; width: 100%; height: 100%; overflow: visible; }
.brand-mark-frame, .brand-mark-route, .brand-mark-core { vector-effect: non-scaling-stroke; }
.brand-mark-frame { fill: rgba(239,68,58,.06); stroke: currentColor; stroke-width: 1.6; }
.brand-mark-route { fill: none; stroke: var(--ink); stroke-width: 1.35; stroke-linecap: square; stroke-linejoin: bevel; }
.brand-mark-core { fill: var(--cyan); stroke: var(--cyan); stroke-width: 1; filter: drop-shadow(0 0 4px rgba(234,255,50,.7)); }
.brand:hover .brand-mark { color: var(--cyan); transform: translateY(-1px) rotate(5deg); }
.brand-mark { transition: color .2s ease, transform .2s ease; }
.brand strong, .brand small { display: block; }
.brand strong { font-family: Impact, "Arial Black", sans-serif; letter-spacing: .1em; font-size: 14px; }
.brand small { margin-top: 2px; color: var(--muted); font-size: 11px; letter-spacing: .08em; text-transform: uppercase; }
.header-data { color: var(--muted); font-size: 12px; }
main { position: relative; z-index: 1; width: min(1170px, calc(100% - 40px)); min-height: calc(100vh - 76px); margin: 0 auto; padding: 48px 0 68px; }
.site-footer { position: relative; z-index: 1; display: flex; align-items: center; justify-content: space-between; gap: 16px; width: min(1170px, calc(100% - 40px)); margin: -28px auto 0; padding: 18px 0 28px; border-top: 1px solid var(--line); color: var(--muted); font-size: 12px; }
.footer-copy { display: grid; gap: 5px; min-width: 0; line-height: 1.45; }
.footer-copy a { color: var(--ink); font-weight: 850; text-decoration: none; }
.footer-copy a:hover { color: var(--cyan); }
.riot-disclaimer { max-width: 800px; color: #7e7b75; font-size: 10px; line-height: 1.45; }
.footer-links { display: flex; flex-wrap: wrap; justify-content: flex-end; gap: 8px; }
.footer-data-link { display: inline-flex; align-items: center; justify-content: center; gap: 8px; min-height: 34px; padding-inline: 13px; font-size: 10px; text-align: center; text-decoration: none; }
.discord-link { display: inline-flex; align-items: center; justify-content: center; gap: 8px; }
.discord-icon { width: 15px; height: 15px; flex: 0 0 auto; }
.site-version { color: var(--cyan); font-size: 10px; font-weight: 850; letter-spacing: .08em; text-transform: uppercase; }
.screen[hidden] { display: none; }
.eyebrow { margin: 0 0 11px; color: var(--red); font-size: 11px; font-weight: 900; letter-spacing: .16em; }
h1, h2, h3, p { margin-top: 0; }
h1, h2, h3 { font-family: Impact, "Arial Black", "Arial Narrow", sans-serif; text-transform: uppercase; }
h1 { margin-bottom: 16px; font-size: clamp(40px, 6vw, 74px); line-height: .91; letter-spacing: -.045em; }
h2 { margin-bottom: 0; font-size: 22px; letter-spacing: -.015em; }

.start-screen { position: relative; display: grid; min-height: calc(100vh - 192px); align-items: center; overflow: hidden; }
.start-screen::before, .start-screen::after { content: ""; position: absolute; z-index: 0; pointer-events: none; }
.start-screen::before { right: -3%; bottom: 7%; width: min(45vw, 560px); height: 35px; background: var(--red); clip-path: polygon(0 42%, 78% 0, 100% 38%, 31% 100%); transform: rotate(-12deg); opacity: .86; }
.start-screen::after { right: 11%; bottom: 17%; width: min(31vw, 370px); height: 15px; background: var(--cyan); clip-path: polygon(0 26%, 100% 0, 81% 100%, 12% 71%); transform: rotate(9deg); opacity: .88; }
.start-copy { position: relative; z-index: 1; max-width: 670px; padding: 24px 0; }
.start-copy > p:not(.eyebrow) { max-width: 550px; margin-bottom: 26px; color: var(--muted); font-size: 18px; line-height: 1.6; }
.start-actions { display: flex; flex-wrap: wrap; gap: 10px; }
.tutorial-button { min-height: 52px; padding-inline: 16px; }
.start-art { --pointer-x: 0px; --pointer-y: 0px; --pointer-tilt: 0deg; position: absolute; right: -7%; top: 50%; width: min(48vw, 610px); aspect-ratio: 1; pointer-events: none; transform: translate3d(var(--pointer-x), calc(-50% + var(--pointer-y)), 0) rotate(var(--pointer-tilt)); transition: transform .35s cubic-bezier(.2,.8,.25,1); }
.start-art::before, .start-art::after { content: ""; position: absolute; inset: 8%; border: 1px solid rgba(239,68,58,.52); clip-path: polygon(50% 0, 100% 50%, 50% 100%, 0 50%); }
.start-art::before { transform: rotate(45deg) translate(calc(var(--pointer-x) * -.18), calc(var(--pointer-y) * -.18)); }
.start-art::after { inset: 23%; border-color: rgba(234,255,50,.74); transform: rotate(-14deg) translate(calc(var(--pointer-x) * .32), calc(var(--pointer-y) * .32)); }
.geo { position: absolute; display: block; transition: transform .35s cubic-bezier(.2,.8,.25,1); }
.geo-orbit { inset: 2%; border: 1px solid rgba(241,238,231,.22); border-radius: 48% 52% 42% 58%; transform: rotate(21deg) translate(calc(var(--pointer-x) * -.22), calc(var(--pointer-y) * -.22)); }
.geo-diamond { top: 16%; left: 15%; width: 43%; aspect-ratio: 1; border: 1px solid rgba(234,255,50,.68); transform: rotate(45deg) translate(calc(var(--pointer-x) * .42), calc(var(--pointer-y) * .42)); }
.geo-core { top: 40%; left: 40%; width: 18%; aspect-ratio: 1; background: var(--ink); clip-path: polygon(50% 0, 100% 38%, 81% 100%, 19% 100%, 0 38%); box-shadow: 0 0 50px rgba(234,255,50,.42); transform: rotate(18deg) translate(calc(var(--pointer-x) * .72), calc(var(--pointer-y) * .72)); }
.geo-square { right: 8%; bottom: 10%; width: 22%; aspect-ratio: 1; border: 2px solid rgba(239,68,58,.72); transform: rotate(26deg) translate(calc(var(--pointer-x) * -.5), calc(var(--pointer-y) * -.5)); }
.geo-line { top: 22%; right: 2%; width: 46%; border-top: 2px solid rgba(234,255,50,.72); transform: rotate(-32deg) translate(calc(var(--pointer-x) * .46), calc(var(--pointer-y) * .46)); transform-origin: right; }
.geo-triangle { left: 12%; bottom: 8%; width: 25%; aspect-ratio: 1; border: 2px solid rgba(239,68,58,.62); clip-path: polygon(50% 0, 100% 100%, 0 100%); transform: rotate(-22deg) translate(calc(var(--pointer-x) * -.36), calc(var(--pointer-y) * -.36)); }
.data-note { display: block; margin-top: 14px; color: #71809c; font-size: 11px; }

.tutorial-modal { position: fixed; z-index: 20; inset: 0; display: grid; place-items: center; padding: 24px; }
.tutorial-modal[hidden] { display: none; }
.tutorial-backdrop { position: absolute; inset: 0; background: rgba(3,7,15,.76); backdrop-filter: blur(7px); }
.tutorial-card { position: relative; width: min(680px, 100%); max-height: min(720px, calc(100vh - 48px)); overflow: auto; padding: 28px; border: 1px solid rgba(89,215,228,.42); border-radius: 14px; background: linear-gradient(135deg, #172540, #0e172a); box-shadow: 0 28px 90px rgba(0,0,0,.55); }
.tutorial-card h2 { margin-bottom: 19px; font-size: 32px; }
.tutorial-close { position: absolute; top: 13px; right: 14px; width: 35px; height: 35px; border: 1px solid var(--line); border-radius: 50%; color: var(--muted); background: transparent; font-size: 22px; line-height: 1; }
.tutorial-close:hover { color: var(--ink); border-color: var(--cyan); }
.tutorial-steps { display: grid; gap: 9px; margin-bottom: 22px; }
.tutorial-steps article { display: grid; grid-template-columns: 38px 1fr; gap: 11px; padding: 11px; border: 1px solid var(--line); border-radius: 8px; background: rgba(255,255,255,.025); }
.tutorial-steps article > span { color: var(--gold); font-size: 12px; font-weight: 900; letter-spacing: .06em; }
.tutorial-steps strong { color: #e5ebf5; font-size: 13px; }
.tutorial-steps p { margin: 4px 0 0; color: var(--muted); font-size: 12px; line-height: 1.45; }
.tutorial-scoring { margin: 4px 0 22px; padding: 17px; border: 1px solid var(--line); border-left: 4px solid var(--cyan); background: rgba(255,255,255,.025); }
.tutorial-scoring h3 { margin-bottom: 12px; font-size: 20px; }
.score-formula { display: flex; align-items: center; flex-wrap: wrap; gap: 7px; margin-bottom: 12px; }
.score-formula span { padding: 5px 7px; color: #17170a; background: var(--cyan); font-size: 9px; font-weight: 900; letter-spacing: .06em; }
.score-formula span:nth-of-type(2) { background: var(--ink); }
.score-formula span:nth-of-type(3) { background: var(--red); }
.score-formula b { color: var(--muted); }
.tutorial-score-grid { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 7px; }
.tutorial-score-grid article { padding: 10px; border: 1px solid var(--line); background: rgba(0,0,0,.16); }
.tutorial-score-grid strong { display: block; color: var(--ink); font-size: 11px; }
.tutorial-score-grid p { margin: 4px 0 0; color: var(--muted); font-size: 10px; line-height: 1.4; }
.tutorial-score-grid b { color: var(--cyan); }
.region-rules { display: grid; gap: 5px; margin-top: 11px; padding-top: 11px; border-top: 1px solid var(--line); }
.region-rules > strong { color: var(--ink); font-size: 10px; letter-spacing: .1em; }
.region-rules span { font-size: 10px; font-weight: 750; }
.region-rules .is-positive { color: var(--cyan); }
.region-rules .is-negative { color: #ffaaa3; }

.primary-button, .secondary-button { min-height: 44px; padding: 0 17px; border-radius: 0; font-size: 13px; font-weight: 900; letter-spacing: .03em; text-transform: uppercase; }
.primary-button { border: 0; color: #170807; background: var(--red); box-shadow: 5px 5px 0 rgba(234,255,50,.72); }
.primary-button span { margin-left: 7px; font-size: 17px; }
.primary-button:hover:not(:disabled) { color: #16170a; background: var(--cyan); box-shadow: 7px 7px 0 rgba(239,68,58,.7); }
.primary-button:disabled { cursor: not-allowed; opacity: .43; }
.secondary-button { border: 1px solid var(--ink); color: var(--ink); background: rgba(18,18,18,.45); }
.secondary-button:hover { border-color: var(--cyan); color: var(--cyan); background: rgba(234,255,50,.08); }
.large-button { min-width: 195px; min-height: 52px; font-size: 15px; }

.screen-heading { max-width: 800px; margin: 18px 0 31px; }
.screen-heading > p:not(.eyebrow), .screen-lead { max-width: 610px; margin-bottom: 0; color: var(--muted); font-size: 16px; line-height: 1.6; }
.team-options { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 14px; }
.team-option { display: grid; justify-items: start; min-height: 338px; padding: 22px; border: 1px solid var(--line); border-radius: 0; color: var(--ink); background: linear-gradient(135deg, rgba(33,33,33,.98), rgba(15,15,15,.98)); text-align: left; transition: transform .16s ease, border-color .16s ease, background .16s ease; }
.team-option:hover { transform: translateY(-3px) rotate(-.4deg); border-color: var(--red); }
.team-option.is-selected { border-color: var(--cyan); box-shadow: inset 6px 0 0 var(--red), 5px 5px 0 rgba(234,255,50,.32), var(--shadow); background: linear-gradient(135deg, #292929, #151515); }
.team-emblem { display: grid; place-items: center; width: 60px; height: 60px; margin-bottom: 19px; border: 1px solid var(--red); border-radius: 0; color: var(--red); background: rgba(239,68,58,.07); font-family: Impact, "Arial Black", sans-serif; font-size: 19px; font-weight: 700; }
.aggressive .team-emblem { border-color: var(--red); color: var(--red); background: rgba(239,68,58,.08); }
.wildcard .team-emblem { border-color: var(--cyan); color: var(--cyan); background: rgba(234,255,50,.08); }
.identity-label { color: var(--cyan); font-size: 10px; font-weight: 850; letter-spacing: .15em; text-transform: uppercase; }
.team-option strong { margin: 5px 0 3px; font-size: 24px; letter-spacing: -.03em; }
.team-source { color: var(--muted); font-size: 12px; }
.team-msi-years { margin-top: 9px; color: #c7d1e2; font-size: 11px; font-weight: 700; }
.team-motto { margin-top: 23px; color: var(--gold); font-size: 13px; font-weight: 800; }
.team-description { margin-top: 8px; color: #c0cadb; font-size: 13px; line-height: 1.48; }
.team-footer { display: flex; align-items: center; justify-content: space-between; width: 100%; margin-top: auto; padding-top: 17px; border-top: 1px solid var(--line); }
.team-footer > span { padding: 5px 8px; border-radius: 0; color: #17170b; background: var(--cyan); font-size: 10px; font-weight: 850; }
.team-footer small { color: var(--muted); font-size: 11px; }
.screen-actions { display: flex; align-items: center; justify-content: space-between; margin-top: 25px; }

.draft-topline { display: flex; align-items: end; justify-content: space-between; gap: 24px; min-height: 108px; margin: 18px 0 6px; }
.draft-topline > div:first-child { display: flex; flex-direction: column; justify-content: end; min-height: 108px; }
.draft-topline h1 { min-height: 1.82em; margin-bottom: 0; }
.round-badge { display: grid; place-items: center; min-height: 34px; padding: 0 11px; border: 1px solid var(--cyan); border-radius: 0; color: #15170c; background: var(--cyan); font-size: 11px; font-weight: 900; letter-spacing: .08em; white-space: nowrap; }
.selection-tools { display: flex; align-items: center; gap: 8px; }
.reroll-button { min-height: 34px; padding: 0 10px; border: 1px solid var(--red); border-radius: 0; color: var(--ink); background: rgba(239,68,58,.11); font-size: 10px; font-weight: 900; letter-spacing: .08em; }
.reroll-button:hover:not(:disabled) { color: #17170b; background: var(--red); box-shadow: 3px 3px 0 var(--cyan); }
.reroll-button:disabled { cursor: not-allowed; opacity: .38; }
.screen-lead { min-height: 52px; margin: 15px 0 25px; }
.draft-candidates { display: grid; grid-template-columns: repeat(5, minmax(0, 1fr)); gap: 10px; }
.player-card { position: relative; display: grid; gap: 8px; min-width: 0; min-height: 287px; padding: 15px; overflow: hidden; border: 1px solid var(--line); border-radius: 0; color: var(--ink); background: linear-gradient(125deg, rgba(37,37,37,.98), rgba(16,16,16,.98)); text-align: left; transition: transform .16s ease, border-color .16s ease; }
.player-card::after { content: ""; position: absolute; top: 0; right: 0; left: 0; height: 4px; border: 0; border-radius: 0; background: var(--red); }
.player-card:hover { transform: translateY(-3px) rotate(-.3deg); border-color: var(--cyan); }
.player-card.is-selected { border-color: var(--cyan); box-shadow: inset 5px 0 0 var(--red), 5px 5px 0 rgba(234,255,50,.18); background: linear-gradient(125deg, rgba(43,47,23,.96), rgba(21,23,12,.98)); }
.card-topline { display: flex; align-items: start; justify-content: space-between; gap: 8px; color: var(--muted); font-size: 10px; font-weight: 800; letter-spacing: .06em; }
.card-topline strong { position: relative; z-index: 1; color: var(--gold); font-size: 22px; letter-spacing: -.04em; }
.card-topline small { color: var(--muted); font-size: 8px; letter-spacing: .03em; }
.player-name { overflow: hidden; font-size: 22px; font-weight: 850; letter-spacing: -.045em; text-overflow: ellipsis; white-space: nowrap; }
.natural-role { color: var(--cyan); font-size: 10px; font-weight: 850; letter-spacing: .08em; }
.player-meta, .champion-pool, .msi-years { overflow: hidden; color: #acb9cf; font-size: 10px; line-height: 1.4; text-overflow: ellipsis; white-space: nowrap; }
.msi-years { color: #d5ddea; font-weight: 700; }
.attribute-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 4px; padding: 8px 0; border-top: 1px solid var(--line); border-bottom: 1px solid var(--line); }
.attribute-grid span { display: grid; gap: 2px; }
.attribute-grid small { color: var(--muted); font-size: 8px; font-weight: 800; }
.attribute-grid b { color: var(--cyan); font-size: 14px; }
.card-cta { align-self: end; margin-top: auto; color: var(--green); font-size: 11px; font-weight: 850; }

.assignment-panel { margin-top: 18px; padding: 20px; border: 1px solid var(--line); border-radius: 12px; background: rgba(18, 26, 45, .84); box-shadow: var(--shadow); }
.assignment-heading { display: flex; align-items: start; justify-content: space-between; gap: 20px; }
.assignment-heading p:not(.eyebrow) { max-width: 350px; margin: 0; color: var(--muted); font-size: 12px; line-height: 1.5; text-align: right; }
.role-placement { display: grid; grid-template-columns: repeat(5, minmax(0, 1fr)); gap: 9px; margin-top: 16px; }
.placement-slot { display: grid; justify-items: start; min-height: 90px; padding: 12px; border: 1px dashed #50617c; border-radius: 8px; color: var(--ink); background: rgba(255,255,255,.018); text-align: left; transition: .15s ease; }
.placement-slot:not(:disabled):hover { border-color: var(--green); background: rgba(94, 211, 154, .08); transform: translateY(-2px); }
.placement-slot.is-offrole:not(:disabled) { border-color: rgba(241, 189, 94, .72); }
.placement-slot.is-filled { border-style: solid; opacity: .52; }
.placement-slot:disabled { cursor: not-allowed; }
.placement-slot > span { color: var(--gold); font-size: 19px; }
.placement-slot strong { margin-top: 4px; font-size: 12px; }
.placement-slot small { margin-top: 4px; color: var(--muted); font-size: 10px; }
.player-bonuses { display: flex; flex-wrap: wrap; gap: 7px; min-height: 30px; margin-top: 14px; }
.player-bonus { display: inline-flex; align-items: center; gap: 5px; padding: 6px 8px; border: 1px solid var(--line); border-radius: 999px; color: #cbd5e5; background: rgba(255,255,255,.035); font-size: 10px; font-weight: 700; }
.player-bonus b { font-size: 12px; }
.player-bonus.cyan b { color: var(--cyan); }
.player-bonus.gold b { color: var(--gold); }
.player-bonus.green b { color: var(--green); }
.player-bonus.blue b { color: var(--blue); }
.player-bonus.red b { color: var(--red); }
.bonus-placeholder { align-self: center; color: var(--muted); font-size: 11px; }
.risk-note { margin-top: 13px; color: #9eadc2; font-size: 12px; line-height: 1.5; }
.risk-note strong { color: var(--gold); }

.review-hero { display: grid; grid-template-columns: 92px minmax(0, 1fr) auto; align-items: center; gap: 21px; margin: 18px 0 28px; }
.review-emblem { display: grid; place-items: center; width: 85px; height: 85px; border: 1px solid var(--cyan); border-radius: 20px 20px 42px 20px; color: var(--cyan); background: rgba(89, 215, 228, .08); font-family: Georgia, serif; font-size: 21px; font-weight: 700; }
.review-emblem.aggressive { border-color: var(--red); color: var(--red); }
.review-emblem.wildcard { border-color: var(--gold); color: var(--gold); }
.review-hero h1 { margin-bottom: 7px; font-size: clamp(36px, 4.5vw, 60px); }
.review-hero p:not(.eyebrow) { margin-bottom: 0; color: var(--muted); font-size: 14px; }
.team-power-summary { display: grid; justify-items: end; }
.team-power-summary span, .team-power-summary small { color: var(--muted); font-size: 10px; font-weight: 850; letter-spacing: .1em; }
.team-power-summary strong { color: var(--green); font-size: 48px; line-height: .9; letter-spacing: -.06em; }
.team-power-summary small { margin-top: 7px; color: var(--green); }
.review-team { display: grid; grid-template-columns: repeat(5, minmax(0, 1fr)); gap: 10px; }
.review-player { width: 100%; min-height: 228px; display: grid; align-content: start; padding: 15px; border: 1px solid rgba(94,211,154,.46); border-radius: 10px; color: var(--ink); background: linear-gradient(135deg, rgba(24, 62, 61, .72), rgba(15, 29, 47, .96)); text-align: left; }
.review-player.is-offrole { border-color: rgba(241,189,94,.72); background: linear-gradient(135deg, rgba(75, 56, 26, .64), rgba(28, 31, 45, .95)); }
.review-player:disabled { cursor: default; }
.review-team.is-swapping .review-player:not(:disabled) { cursor: pointer; }
.review-team.is-swapping .review-player:not(:disabled):hover { transform: translateY(-3px); border-color: var(--cyan); }
.review-player.is-swap-source { border-color: var(--cyan); box-shadow: 0 0 0 2px rgba(89,215,228,.22); }
.review-card-header { display: flex; align-items: center; justify-content: space-between; color: var(--cyan); font-size: 10px; font-weight: 850; letter-spacing: .08em; }
.review-card-header strong { color: var(--gold); font-size: 21px; letter-spacing: -.04em; }
.review-card-header small { color: var(--muted); font-size: 8px; }
.review-player-name { overflow: hidden; margin: 14px 0 4px; font-size: 21px; font-weight: 700; text-overflow: ellipsis; white-space: nowrap; }
.review-player-meta { overflow: hidden; margin-bottom: 14px; color: var(--muted); font-size: 10px; text-overflow: ellipsis; white-space: nowrap; }
.review-champion { overflow: hidden; margin: -7px 0 12px; color: var(--cyan); font-size: 10px; font-weight: 900; letter-spacing: .06em; text-overflow: ellipsis; white-space: nowrap; }
.review-stats { display: grid; grid-template-columns: repeat(3, 1fr); padding: 8px 0; border-top: 1px solid var(--line); border-bottom: 1px solid var(--line); color: var(--muted); font-size: 8px; }
.review-stats b { display: block; margin-top: 2px; color: var(--cyan); font-size: 14px; }
.trait-list { display: flex; flex-wrap: wrap; gap: 5px; margin-top: 11px; }
.trait-list span { padding: 4px 6px; border-radius: 999px; color: #c6d1e3; background: rgba(255,255,255,.08); font-size: 9px; font-weight: 700; }
.is-offrole .trait-list span:first-child { color: var(--gold); background: rgba(241,189,94,.14); }
.review-footer { display: flex; align-items: center; justify-content: space-between; gap: 18px; margin-top: 24px; padding: 20px; border: 1px solid var(--line); border-radius: 10px; background: rgba(18, 26, 45, .84); }
.review-footer p { max-width: 520px; margin: 0; color: var(--muted); font-size: 13px; }
.review-footer > div { display: flex; gap: 8px; }
.swap-note { align-self: center; max-width: 190px; color: var(--cyan); font-size: 11px; line-height: 1.35; }

.tournament-heading { display: flex; align-items: end; justify-content: space-between; gap: 34px; margin: 18px 0 28px; }
.tournament-heading > div:first-child { max-width: 720px; }
.tournament-heading p:not(.eyebrow) { max-width: 650px; margin: 0; color: var(--muted); font-size: 15px; line-height: 1.55; }
.tournament-rules { display: grid; grid-template-columns: auto auto; gap: 4px 14px; min-width: 185px; padding: 14px; border: 1px solid var(--line); border-radius: 9px; background: rgba(18, 26, 45, .82); }
.tournament-rules span { color: var(--cyan); font-size: 10px; font-weight: 850; letter-spacing: .1em; }
.tournament-rules strong { color: #c8d2e3; font-size: 11px; text-align: right; }
.tournament-rules i { grid-column: 1 / -1; justify-self: center; color: var(--gold); font-size: 18px; font-style: normal; line-height: 1; }
.next-series { display: grid; grid-template-columns: minmax(230px, 1fr) minmax(260px, .8fr) auto; align-items: center; gap: 24px; margin-bottom: 22px; padding: 21px; border: 1px solid rgba(89,215,228,.52); border-radius: 12px; background: linear-gradient(120deg, rgba(19, 53, 68, .74), rgba(18, 26, 45, .88)); box-shadow: var(--shadow); }
.next-series h2 { font-size: 21px; }
.next-series p:not(.eyebrow) { margin: 8px 0 0; color: var(--muted); font-size: 12px; line-height: 1.5; }
.next-series-match { display: grid; gap: 5px; }
.next-series-match .bracket-team { padding: 9px 10px; border-radius: 6px; }
.bracket-section { padding: 21px; border: 1px solid var(--line); border-radius: 12px; background: rgba(18, 26, 45, .84); box-shadow: var(--shadow); }
.bracket-section-heading { display: flex; align-items: center; justify-content: space-between; gap: 20px; margin-bottom: 19px; }
.bracket-section-heading h2 { font-size: 21px; }
.bracket-legend { color: var(--muted); font-size: 11px; }
.bracket-legend i, .bracket-legend b { display: inline-block; width: 9px; height: 9px; margin: 0 5px 0 9px; border-radius: 2px; background: var(--cyan); vertical-align: -1px; }
.bracket-legend b { margin-left: 0; background: var(--gold); }
.bracket-board { display: grid; gap: 16px; min-width: 880px; padding: 15px; overflow: auto; border: 1px solid rgba(161,180,216,.12); border-radius: 9px; background: rgba(6, 11, 22, .48); }
.bracket-lane { padding: 13px; border-radius: 8px; }
.upper-lane { border: 1px solid rgba(89,215,228,.21); background: rgba(25, 55, 69, .18); }
.lower-lane { border: 1px solid rgba(241,189,94,.19); background: rgba(69, 48, 23, .15); }
.lane-heading { display: flex; align-items: baseline; gap: 9px; margin-bottom: 12px; }
.lane-heading span, .grand-final > span { color: var(--cyan); font-size: 11px; font-weight: 850; letter-spacing: .11em; }
.lower-lane .lane-heading span { color: var(--gold); }
.lane-heading small { color: var(--muted); font-size: 10px; }
.bracket-rounds { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 15px; }
.bracket-round { display: grid; align-content: space-around; gap: 12px; min-height: 264px; }
.lower-lane .bracket-round { min-height: 150px; }
.bracket-round h3 { margin: 0 0 2px; color: var(--muted); font-size: 9px; letter-spacing: .1em; }
.bracket-match { position: relative; display: grid; gap: 2px; padding: 4px; border: 1px solid var(--line); border-radius: 6px; background: rgba(11, 18, 32, .85); }
.bracket-match.is-next { border-color: var(--gold); box-shadow: 0 0 0 1px rgba(241,189,94,.18); }
.bracket-match.is-path::after { content: ""; position: absolute; top: 50%; right: -15px; width: 14px; border-top: 1px solid rgba(89,215,228,.5); }
.bracket-team, .is-placeholder > div { display: flex; align-items: center; justify-content: space-between; gap: 9px; min-width: 0; padding: 6px 7px; border-radius: 4px; color: #cbd5e5; font-size: 11px; }
.bracket-team span, .is-placeholder span { overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.bracket-team small { flex: 0 0 auto; color: var(--muted); font-size: 9px; }
.bracket-team.is-player { color: #07141c; background: var(--cyan); font-weight: 850; }
.bracket-team.is-player small { color: #153e48; }
.is-placeholder { border-style: dashed; background: rgba(255,255,255,.018); }
.is-placeholder > div { color: #78869e; }
.is-placeholder small { color: #56647b; }
.grand-final { display: grid; grid-template-columns: 140px minmax(250px, 1fr) 150px; align-items: center; gap: 18px; padding: 16px; border: 1px solid rgba(241,189,94,.46); border-radius: 9px; background: linear-gradient(90deg, rgba(87,61,22,.3), rgba(18,26,45,.65)); }
.grand-final > span, .grand-final > strong { color: var(--gold); font-size: 11px; letter-spacing: .09em; }
.grand-final > strong { text-align: right; }
.tournament-outcome { display: grid; place-items: center; min-height: 66px; border-radius: 8px; font-size: 18px; font-weight: 900; letter-spacing: .08em; }
.tournament-outcome.is-champion { color: #171005; background: var(--gold); }
.tournament-outcome.is-eliminated { color: #ffd7dc; background: rgba(233,110,122,.24); }

.match-heading { display: flex; align-items: end; justify-content: space-between; gap: 28px; margin: 18px 0 25px; }
.match-heading > div:first-child { max-width: 700px; }
.match-heading p:not(.eyebrow) { margin: 0; color: var(--muted); font-size: 15px; line-height: 1.55; }
.match-draft-score { display: flex; align-items: center; gap: 10px; padding: 13px; border: 1px solid var(--line); border-radius: 9px; color: #cbd5e5; background: rgba(18,26,45,.82); font-size: 12px; font-weight: 750; text-align: center; }
.match-draft-score span { max-width: 110px; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.match-draft-score b { color: var(--gold); font-size: 10px; }
.draft-status-panel { display: grid; grid-template-columns: 110px minmax(180px, .8fr) minmax(210px, 1fr) minmax(210px, 1fr); gap: 12px; margin-bottom: 18px; padding: 15px; border: 1px solid var(--line); border-radius: 11px; background: rgba(18,26,45,.84); box-shadow: var(--shadow); }
.draft-status-panel > div { display: grid; align-content: start; gap: 5px; min-width: 0; }
.draft-status-panel > div > span, .enemy-draft > span, .your-draft > span { color: var(--muted); font-size: 9px; font-weight: 850; letter-spacing: .1em; }
.draft-status-panel > div > strong { color: var(--cyan); font-size: 13px; line-height: 1.3; }
.draft-status-panel > div:nth-child(2) > strong { color: var(--ink); font-size: 18px; line-height: 1.15; letter-spacing: -.025em; }
.enemy-draft, .your-draft { padding-left: 12px; border-left: 1px solid var(--line); }
.enemy-draft > div, .your-draft > div { display: flex; flex-wrap: wrap; gap: 4px; }
.enemy-draft small, .your-draft small { color: #65738c; font-size: 10px; }
.draft-summary-ban, .draft-summary-pick { padding: 3px 5px; border-radius: 4px; font-size: 9px; font-weight: 750; }
.draft-summary-ban { color: #ffb9c0; background: rgba(233,110,122,.13); }
.draft-summary-pick { color: #a9f0d0; background: rgba(94,211,154,.12); }
.champion-select, .pick-assignment, .simulation-panel { padding: 20px; border: 1px solid var(--line); border-radius: 12px; background: rgba(18,26,45,.84); box-shadow: var(--shadow); }
.section-inline-heading { display: flex; align-items: end; justify-content: space-between; gap: 20px; }
.section-inline-heading h2 { font-size: 21px; }
.section-inline-heading p:not(.eyebrow) { max-width: 390px; margin: 0; color: var(--muted); font-size: 12px; line-height: 1.45; text-align: right; }
.draft-champion-pool { display: grid; grid-template-columns: repeat(5, minmax(0, 1fr)); gap: 8px; margin-top: 16px; }
.champion-card { min-height: 110px; display: grid; align-content: start; gap: 6px; padding: 11px; overflow: hidden; border: 1px solid var(--line); border-radius: 7px; color: var(--ink); background: linear-gradient(145deg, rgba(36,51,82,.82), rgba(15,24,43,.95)); text-align: left; transition: transform .15s ease, border-color .15s ease, opacity .15s ease; }
.champion-card:not(:disabled):hover { transform: translateY(-3px); border-color: var(--cyan); }
.champion-card.is-ban-action:not(:disabled):hover { border-color: var(--red); background: linear-gradient(145deg, rgba(109,40,53,.9), rgba(53,19,31,.96)); box-shadow: 0 0 0 1px rgba(233,110,122,.25); }
.champion-card.is-ban-action:not(:disabled):hover em { color: #ffc0c7; }
.champion-card.is-pick-action:not(:disabled):hover { border-color: var(--green); background: linear-gradient(145deg, rgba(27,83,72,.9), rgba(14,43,44,.96)); box-shadow: 0 0 0 1px rgba(94,211,154,.25); }
.champion-card.is-pick-action:not(:disabled):hover em { color: #bcf7da; }
.champion-card > span { color: var(--cyan); font-size: 8px; font-weight: 850; letter-spacing: .08em; }
.champion-card strong { overflow: hidden; font-size: 17px; letter-spacing: -.035em; text-overflow: ellipsis; white-space: nowrap; }
.champion-ovr { color: var(--gold); font-size: 27px; line-height: .9; letter-spacing: -.06em; }
.champion-ovr small { color: var(--muted); font-size: 8px; letter-spacing: .04em; }
.champion-card em { margin-top: auto; color: var(--green); font-size: 9px; font-style: normal; font-weight: 800; }
.champion-card.is-selected { border-color: var(--gold); box-shadow: inset 0 0 0 1px rgba(241,189,94,.27); }
.champion-card.is-rival-used { opacity: .5; border-color: rgba(233,110,122,.55); background: rgba(70,28,40,.45); }
.champion-card.is-rival-used em { color: #f2a0a9; }
.champion-card.is-player-used { opacity: .58; border-color: rgba(94,211,154,.48); background: rgba(20,57,55,.48); }
.pick-assignment { margin-top: 17px; }
.pick-assignment-slots { display: grid; grid-template-columns: repeat(5, minmax(0, 1fr)); gap: 8px; margin-top: 16px; }
.pick-assignment-slot { min-height: 92px; display: grid; align-content: start; gap: 4px; padding: 11px; border: 1px dashed #50617c; border-radius: 7px; color: var(--ink); background: rgba(255,255,255,.018); text-align: left; transition: .15s ease; }
.pick-assignment-slot:not(:disabled):hover { border-color: var(--green); background: rgba(94,211,154,.08); transform: translateY(-2px); }
.pick-assignment-slot.is-filled { border-style: solid; border-color: rgba(94,211,154,.55); background: rgba(94,211,154,.08); }
.pick-assignment-slot:disabled { cursor: not-allowed; }
.pick-assignment-slot > span { color: var(--muted); font-size: 9px; font-weight: 850; letter-spacing: .08em; }
.pick-assignment-slot strong { overflow: hidden; font-size: 13px; text-overflow: ellipsis; white-space: nowrap; }
.pick-assignment-slot small { color: var(--cyan); font-size: 10px; }
.draft-lineups { display: grid; gap: 11px; margin-top: 17px; }
.draft-lineup { padding: 16px; border: 1px solid rgba(89,215,228,.28); border-radius: 10px; background: rgba(18,41,54,.42); }
.draft-lineup.rival-lineup { border-color: rgba(233,110,122,.27); background: rgba(59,25,37,.34); }
.draft-lineup > div:first-child { display: flex; align-items: end; justify-content: space-between; gap: 16px; margin-bottom: 11px; }
.draft-lineup h2 { font-size: 17px; }
.rival-lineup .eyebrow { color: #f19aa5; }
.lineup-rows { display: grid; grid-template-columns: repeat(5, minmax(0, 1fr)); gap: 7px; }
.lineup-row { display: grid; gap: 3px; min-width: 0; padding: 9px; border: 1px solid rgba(89,215,228,.18); border-radius: 6px; background: rgba(8,13,24,.34); }
.lineup-row.is-rival { border-color: rgba(233,110,122,.18); }
.lineup-row > span { color: var(--muted); font-size: 9px; font-weight: 850; letter-spacing: .08em; }
.lineup-row strong, .lineup-row em { overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.lineup-row strong { color: #e3e9f3; font-size: 12px; }
.lineup-row em { color: var(--cyan); font-size: 10px; font-style: normal; }
.lineup-row.is-rival em { color: #f5a4ae; }
.draft-actions, .simulation-actions { display: flex; align-items: center; justify-content: space-between; gap: 18px; margin-top: 17px; padding: 14px 0 0; }
.draft-actions > span { color: var(--muted); font-size: 12px; }
.simulation-panel { max-width: 980px; margin: 0 auto; }
.simulation-power { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; }
.simulation-power > div { padding: 15px; border: 1px solid var(--line); border-radius: 8px; background: rgba(8,13,24,.48); }
.simulation-power > div:last-child { text-align: right; }
.simulation-power span { display: block; color: var(--muted); font-size: 10px; font-weight: 850; letter-spacing: .1em; }
.simulation-power strong { display: block; margin-top: 5px; color: var(--cyan); font-size: 38px; line-height: 1; letter-spacing: -.06em; }
.simulation-power > div:last-child strong { color: var(--red); }
.simulation-livebar { display: grid; grid-template-columns: 150px minmax(0, 1fr); gap: 10px; margin: 14px 0 0; }
.simulation-livebar > div { min-height: 78px; padding: 13px 15px; border: 1px solid var(--line); background: rgba(8,13,24,.48); }
.simulation-livebar span { display: block; color: var(--muted); font-size: 9px; font-weight: 900; letter-spacing: .12em; }
.simulation-livebar strong { display: block; margin-top: 5px; overflow: hidden; color: var(--ink); font-family: Impact, "Arial Black", sans-serif; font-size: 34px; line-height: .95; letter-spacing: 0; text-overflow: ellipsis; white-space: nowrap; }
.match-phase strong { color: var(--cyan); }
.simulation-result-banner { position: relative; display: grid; grid-template-columns: minmax(0, 1fr) auto; align-items: center; gap: 18px; margin-top: 14px; padding: 16px 18px; overflow: hidden; border: 2px solid var(--cyan); background: linear-gradient(100deg, rgba(234,255,50,.28), rgba(18,18,18,.95) 45%, rgba(239,68,58,.18)); box-shadow: 7px 7px 0 rgba(239,68,58,.62); }
.simulation-result-banner[hidden] { display: none; }
.simulation-result-banner::after { content: ""; position: absolute; inset: auto -10% 12px 42%; height: 6px; background: var(--red); transform: rotate(-5deg); }
.result-copy { position: relative; z-index: 1; display: grid; gap: 1px; min-width: 0; }
.simulation-result-banner .result-copy > span { color: var(--red); font-size: 11px; font-weight: 950; letter-spacing: .18em; }
.simulation-result-banner .result-copy strong { overflow: hidden; color: var(--ink); font-family: Impact, "Arial Black", sans-serif; font-size: clamp(36px, 6vw, 66px); line-height: .88; letter-spacing: 0; text-overflow: ellipsis; text-transform: uppercase; white-space: nowrap; }
.simulation-result-banner .result-copy small { color: var(--muted); font-size: 11px; font-weight: 850; letter-spacing: .08em; text-transform: uppercase; }
.result-continue-button { position: relative; z-index: 1; min-width: 190px; }
.simulation-result-banner.is-defeat { border-color: var(--red); background: linear-gradient(100deg, rgba(239,68,58,.34), rgba(18,18,18,.96) 50%, rgba(241,238,231,.08)); box-shadow: 7px 7px 0 rgba(234,255,50,.45); }
.simulation-result-banner.is-defeat .result-copy > span { color: var(--cyan); }
.advantage-track { position: relative; height: 11px; margin: 20px 0; border-radius: 999px; background: linear-gradient(90deg, rgba(233,110,122,.85), #59677d 50%, rgba(94,211,154,.9)); }
.advantage-track::after { content: ""; position: absolute; left: 50%; top: -4px; height: 19px; border-left: 1px solid rgba(255,255,255,.65); }
.advantage-track span { position: absolute; top: 50%; left: 50%; width: 18px; height: 18px; border: 3px solid var(--canvas); border-radius: 50%; background: var(--gold); box-shadow: 0 1px 10px rgba(0,0,0,.4); transform: translate(-50%, -50%); transition: left .65s cubic-bezier(.2,.8,.25,1); }
.simulation-events { display: grid; align-content: start; gap: 8px; min-height: 120px; }
.simulation-events > p { margin: 0; padding: 31px; color: var(--muted); text-align: center; font-size: 13px; }
.simulation-event { position: relative; display: grid; grid-template-columns: 70px minmax(0, 1fr) 110px; align-items: center; gap: 12px; min-height: 76px; padding: 11px 12px; overflow: hidden; border-left: 4px solid var(--green); border-radius: 4px; background: rgba(94,211,154,.06); }
.simulation-event.is-new::after { content: ""; position: absolute; inset: 0; pointer-events: none; border: 1px solid var(--cyan); opacity: 0; }
.simulation-event.is-rival { border-color: var(--red); background: rgba(233,110,122,.07); }
.simulation-event.is-rival.is-new::after { border-color: var(--red); }
.simulation-event.is-final { border-color: var(--gold); background: rgba(241,189,94,.09); }
.simulation-event-minute, .simulation-event b { color: var(--muted); font-size: 11px; font-weight: 850; }
.simulation-event-minute { font-family: Impact, "Arial Black", sans-serif; color: var(--ink); font-size: 22px; letter-spacing: 0; }
.simulation-event-copy { min-width: 0; text-align: left; }
.simulation-event-copy strong { display: block; overflow-wrap: anywhere; color: var(--cyan); font-size: 14px; font-weight: 950; letter-spacing: .07em; text-transform: uppercase; }
.simulation-event-copy p { margin: 4px 0 0; color: #d4dcea; font-size: 12px; line-height: 1.35; }
.simulation-event-side { display: grid; justify-items: end; gap: 6px; min-width: 0; }
.simulation-event-roles { display: flex; justify-content: flex-end; gap: 4px; max-width: 100%; }
.simulation-event-roles .role-icon { --role-icon-size: 20px; }
.simulation-event b { color: var(--green); text-align: right; }
.simulation-event.is-rival b { color: var(--red); }
.simulation-event.is-final b { color: var(--gold); }
.simulation-actions { justify-content: end; }

.run-summary-hero { display: grid; grid-template-columns: 92px minmax(0, 1fr) auto; align-items: center; gap: 21px; margin: 18px 0 24px; }
.run-summary-hero h1 { margin-bottom: 7px; font-size: clamp(37px, 4.7vw, 64px); }
.run-summary-hero p:not(.eyebrow) { margin: 0; color: var(--muted); font-size: 14px; }
.run-position { display: grid; justify-items: end; }
.run-position span, .run-position small { color: var(--muted); font-size: 10px; font-weight: 850; letter-spacing: .1em; }
.run-position strong { color: var(--gold); font-size: 44px; line-height: .9; letter-spacing: -.06em; }
.run-position small { margin-top: 7px; color: #cbd5e5; }
.run-metrics { display: grid; grid-template-columns: repeat(4, minmax(0, 1fr)); gap: 10px; }
.run-metrics > div { min-height: 86px; padding: 14px; border: 1px solid var(--line); border-radius: 9px; background: rgba(18,26,45,.84); box-shadow: var(--shadow); }
.run-metrics span { display: block; color: var(--muted); font-size: 9px; font-weight: 850; letter-spacing: .1em; }
.run-metrics strong { display: block; overflow: hidden; margin-top: 8px; color: var(--cyan); font-size: 23px; letter-spacing: -.04em; text-overflow: ellipsis; white-space: nowrap; }
.run-roster-section, .run-path-section, .run-bracket-section { margin-top: 18px; padding: 20px; border: 1px solid var(--line); border-radius: 12px; background: rgba(18,26,45,.84); box-shadow: var(--shadow); }
.run-roster { display: grid; grid-template-columns: repeat(5, minmax(0, 1fr)); gap: 9px; margin-top: 16px; }
.run-roster-card { display: grid; gap: 4px; min-height: 125px; padding: 12px; border: 1px solid rgba(94,211,154,.44); border-radius: 8px; background: rgba(23,63,61,.48); }
.run-roster-card.is-offrole { border-color: rgba(241,189,94,.62); background: rgba(70,50,23,.45); }
.run-roster-card > span { color: var(--muted); font-size: 9px; font-weight: 850; letter-spacing: .08em; }
.run-roster-card strong { overflow: hidden; font-size: 16px; text-overflow: ellipsis; white-space: nowrap; }
.run-roster-card em { color: var(--gold); font-size: 11px; font-style: normal; font-weight: 850; }
.run-roster-card p { overflow: hidden; margin: auto 0 0; color: var(--cyan); font-size: 11px; text-overflow: ellipsis; white-space: nowrap; }
.run-roster-card small { color: var(--muted); font-size: 9px; }
.run-history { display: grid; gap: 7px; margin-top: 16px; }
.run-history-row { display: grid; grid-template-columns: 28px minmax(150px, .55fr) minmax(0, 1fr) 28px; align-items: center; gap: 10px; padding: 10px; border-left: 3px solid var(--green); border-radius: 5px; background: rgba(94,211,154,.06); }
.run-history-row.is-loss { border-color: var(--red); background: rgba(233,110,122,.07); }
.run-history-row > span, .run-history-row b { color: var(--muted); font-size: 11px; font-weight: 850; }
.run-history-row strong { color: #d6deec; font-size: 12px; }
.run-history-row p { overflow: hidden; margin: 0; color: var(--muted); font-size: 11px; text-overflow: ellipsis; white-space: nowrap; }
.run-history-row b { color: var(--green); text-align: right; }
.run-history-row.is-loss b { color: var(--red); }
.summary-bracket-scroll { margin-top: 16px; overflow-x: auto; }
.summary-bracket-scroll .bracket-board { margin: 0; }
.run-summary-actions { display: flex; justify-content: end; gap: 9px; margin-top: 20px; }

.data-page { display: grid; gap: 20px; }
.data-hero { display: grid; grid-template-columns: minmax(0, 1fr) auto; align-items: end; gap: 24px; padding-top: 10px; }
.data-hero h1 { margin-bottom: 14px; }
.data-hero p:not(.eyebrow) { max-width: 690px; margin: 0; color: var(--muted); font-size: 15px; line-height: 1.58; }
.data-back-link { position: relative; min-height: 52px; padding-inline: 20px; overflow: visible; border: 2px solid var(--ink); color: #170807; background: var(--red); box-shadow: 7px 7px 0 var(--cyan); text-decoration: none; transform: skewX(-7deg); }
.data-back-link::after { content: ""; position: absolute; left: -10px; bottom: -9px; width: 52px; border-top: 4px solid var(--ink); transform: rotate(-14deg); }
.data-back-link:hover { color: #16170a; border-color: var(--cyan); background: var(--cyan); box-shadow: 8px 8px 0 var(--red); }
.data-back-link:focus-visible { outline-offset: 7px; }
.data-controls { display: grid; grid-template-columns: minmax(240px, 1fr) 170px auto; align-items: end; gap: 10px; }
.data-search, .data-select { display: grid; gap: 6px; }
.data-search label, .data-select label { color: var(--muted); font-size: 10px; font-weight: 900; letter-spacing: .12em; text-transform: uppercase; }
.data-search input, .data-select select { width: 100%; min-height: 42px; border: 1px solid var(--line); border-radius: 0; color: var(--ink); background: #181818; font: inherit; font-size: 13px; }
.data-search input { padding: 0 12px; }
.data-select select { padding: 0 10px; }
.data-search input:focus, .data-select select:focus { outline: 3px solid var(--cyan); outline-offset: 2px; }
.data-view-toggle { display: grid; grid-template-columns: repeat(3, 1fr); min-height: 42px; border: 1px solid var(--line); background: #181818; }
.data-view-toggle button { min-width: 100px; border: 0; border-left: 1px solid var(--line); color: var(--muted); background: transparent; font-size: 10px; font-weight: 900; letter-spacing: .09em; text-transform: uppercase; }
.data-view-toggle button:first-child { border-left: 0; }
.data-view-toggle button.is-active { color: #17170b; background: var(--cyan); }
.data-summary { display: grid; grid-template-columns: repeat(5, minmax(0, 1fr)); gap: 10px; }
.data-summary > div { min-height: 82px; padding: 13px; border: 1px solid var(--line); background: linear-gradient(135deg, rgba(35,35,35,.96), rgba(16,16,16,.98)); }
.data-summary span { display: block; color: var(--muted); font-size: 9px; font-weight: 900; letter-spacing: .1em; text-transform: uppercase; }
.data-summary strong { display: block; margin-top: 8px; color: var(--cyan); font-size: 28px; line-height: 1; letter-spacing: -.045em; }
.rating-method, .data-table-shell, .privacy-panel { position: relative; overflow: hidden; padding: 20px; border: 1px solid var(--line); background: linear-gradient(135deg, rgba(35,35,35,.96), rgba(16,16,16,.98)); }
.rating-method::before, .data-table-shell::before, .privacy-panel::before { content: ""; position: absolute; top: 0; left: 0; width: 100%; height: 3px; background: linear-gradient(90deg, var(--red) 0 34%, var(--cyan) 34% 52%, transparent 52%); }
.rating-method { display: grid; grid-template-columns: 250px minmax(0, 1fr); gap: 18px; align-items: start; }
.rating-method h2 { font-size: 22px; }
.rating-formulas { display: grid; gap: 7px; }
.rating-formulas span { padding: 10px 11px; border-left: 3px solid var(--cyan); color: var(--muted); background: rgba(255,255,255,.025); font-size: 12px; line-height: 1.45; }
.rating-formulas b { color: var(--ink); }
.privacy-panel { display: grid; gap: 16px; max-width: 820px; }
.privacy-panel h2 { margin-bottom: 2px; font-size: 22px; }
.privacy-panel p, .privacy-panel li { color: var(--muted); font-size: 13px; line-height: 1.6; }
.privacy-panel p { margin-bottom: 0; }
.privacy-panel ul { display: grid; gap: 8px; margin: 0; padding-left: 18px; }
.privacy-panel a { color: var(--ink); font-weight: 850; }
.privacy-panel a:hover { color: var(--cyan); }
.data-table-heading { display: flex; align-items: end; justify-content: space-between; gap: 18px; margin-bottom: 15px; }
.data-table-heading h2 { font-size: 24px; }
.data-table-heading > span { color: var(--muted); font-size: 11px; font-weight: 900; letter-spacing: .08em; text-transform: uppercase; }
.data-table-wrap { overflow: auto; border: 1px solid rgba(241,238,231,.16); background: #101010; }
.data-table { width: 100%; min-width: 920px; border-collapse: collapse; }
.data-table th, .data-table td { padding: 10px 11px; border-bottom: 1px solid rgba(241,238,231,.12); color: var(--muted); font-size: 11px; text-align: left; white-space: nowrap; }
.data-table th { position: sticky; top: 0; z-index: 1; color: var(--ink); background: #1d1d1d; font-size: 9px; font-weight: 900; letter-spacing: .1em; text-transform: uppercase; }
.data-table td:nth-child(2), .data-table td:nth-child(11), .data-table td:nth-child(9) { white-space: normal; }
.data-table strong { color: var(--cyan); font-size: 18px; letter-spacing: -.04em; }
.data-load-more-wrap { display: flex; justify-content: center; padding-top: 16px; }
.data-load-more { min-height: 42px; padding: 0 18px; border: 1px solid var(--cyan); color: var(--cyan); background: rgba(234,255,50,.06); font-size: 11px; font-weight: 900; letter-spacing: .09em; text-transform: uppercase; box-shadow: 4px 4px 0 rgba(239,68,58,.5); }
.data-load-more:hover { color: #17170b; background: var(--cyan); box-shadow: 5px 5px 0 var(--red); }
.data-error { margin: 0; padding: 22px; color: var(--red); }

/* MSI poster system: align every game surface with the red, lime and off-white visual language. */
.data-note, .team-msi-years, .team-description, .player-meta, .champion-pool, .msi-years, .risk-note, .review-player-meta, .tournament-rules strong, .bracket-team, .match-draft-score, .run-position small { color: var(--muted); }
.tutorial-card, .tutorial-steps article { border-radius: 0; border-color: rgba(239,68,58,.55); background: linear-gradient(135deg, #202020, #101010); }
.tutorial-card { box-shadow: 9px 9px 0 rgba(234,255,50,.55), 0 28px 90px rgba(0,0,0,.55); }
.tutorial-steps article > span { color: var(--cyan); }
.tutorial-steps strong { color: var(--ink); }
.tutorial-close { border-radius: 0; border-color: var(--line); }

.assignment-panel, .pick-assignment, .champion-select, .draft-status-panel, .draft-lineup, .simulation-panel, .bracket-section, .next-series, .review-footer, .run-roster-section, .run-path-section, .run-bracket-section { position: relative; overflow: hidden; border-radius: 0; border-color: var(--line); background: linear-gradient(135deg, rgba(35,35,35,.96), rgba(16,16,16,.98)); }
.assignment-panel::before, .pick-assignment::before, .champion-select::before, .simulation-panel::before, .review-footer::before, .run-roster-section::before, .run-path-section::before, .run-bracket-section::before { content: ""; position: absolute; top: 0; left: 0; width: 100%; height: 3px; background: linear-gradient(90deg, var(--red) 0 34%, var(--cyan) 34% 52%, transparent 52%); }
.assignment-heading p:not(.eyebrow), .section-inline-heading p:not(.eyebrow), .next-series p:not(.eyebrow), .match-heading p:not(.eyebrow), .tournament-heading p:not(.eyebrow) { color: var(--muted); }

.placement-slot, .pick-assignment-slot { border-color: rgba(241,238,231,.34); border-radius: 0; background: rgba(255,255,255,.018); }
.placement-slot > span { color: var(--red); }
.placement-slot:not(:disabled):hover, .pick-assignment-slot:not(:disabled):hover { border-color: var(--cyan); background: rgba(234,255,50,.08); box-shadow: 4px 4px 0 rgba(239,68,58,.55); }
.placement-slot.is-offrole:not(:disabled) { border-color: var(--red); background: rgba(239,68,58,.08); }
.placement-slot.is-filled, .pick-assignment-slot.is-filled { border-color: var(--cyan); background: rgba(234,255,50,.07); }
.player-bonus { border-radius: 0; color: var(--ink); background: rgba(255,255,255,.035); }
.player-bonus.cyan b, .player-bonus.green b { color: var(--cyan); }
.player-bonus.gold b, .player-bonus.blue b { color: var(--red); }
.risk-note strong { color: var(--red); }

.review-emblem { border-radius: 0; border-color: var(--red); color: var(--red); background: rgba(239,68,58,.08); font-family: Impact, "Arial Black", sans-serif; }
.review-emblem.wildcard { border-color: var(--cyan); color: var(--cyan); background: rgba(234,255,50,.08); }
.review-player { border-radius: 0; border-color: rgba(234,255,50,.55); background: linear-gradient(135deg, rgba(49,52,18,.65), rgba(19,20,11,.98)); }
.review-player.is-offrole { border-color: rgba(239,68,58,.74); background: linear-gradient(135deg, rgba(79,30,28,.7), rgba(29,15,16,.98)); }
.review-player.is-swap-source { border-color: var(--cyan); box-shadow: 5px 5px 0 rgba(239,68,58,.55); }
.review-card-header, .review-stats b { color: var(--cyan); }
.review-card-header strong, .run-roster-card em { color: var(--ink); }
.trait-list span { border-radius: 0; color: var(--ink); background: rgba(241,238,231,.10); }
.is-offrole .trait-list span:first-child { color: #ffb6b0; background: rgba(239,68,58,.18); }

.tournament-rules, .match-draft-score { border-radius: 0; background: rgba(16,16,16,.84); }
.tournament-rules span, .lane-heading span, .grand-final > span { color: var(--red); }
.next-series { border-color: var(--red); border-left-width: 5px; background: linear-gradient(120deg, rgba(68,27,25,.72), rgba(18,18,18,.96)); }
.upper-lane { border-color: rgba(234,255,50,.4); background: rgba(70,76,18,.12); }
.lower-lane { border-color: rgba(239,68,58,.42); background: rgba(79,25,23,.16); }
.lower-lane .lane-heading span { color: var(--red); }
.bracket-board, .bracket-lane, .bracket-match, .grand-final, .tournament-outcome { border-radius: 0; }
.bracket-match.is-next { border-color: var(--red); box-shadow: 4px 4px 0 rgba(234,255,50,.62); }
.bracket-match.is-path::after { border-color: var(--cyan); }
.bracket-team.is-player { color: #13140a; background: var(--cyan); }
.bracket-team.is-player small { color: #353714; }
.grand-final { border-color: var(--cyan); background: linear-gradient(90deg, rgba(85,91,21,.32), rgba(18,18,18,.88)); }
.grand-final > strong { color: var(--cyan); }

.draft-status-panel, .champion-card, .pick-assignment-slot, .draft-lineup, .lineup-row { border-radius: 0; background: linear-gradient(135deg, rgba(35,35,35,.98), rgba(16,16,16,.98)); }
.draft-status-panel > div:nth-child(2) > strong { color: var(--cyan); }
.enemy-draft, .your-draft { border-color: var(--line); }
.draft-summary-ban { color: #ffc2bc; background: rgba(239,68,58,.16); border-radius: 0; }
.draft-summary-pick { color: #1b1d08; background: var(--cyan); border-radius: 0; }
.champion-card { border-color: var(--line); }
.champion-card > span, .champion-card em, .pick-assignment-slot small, .lineup-row em { color: var(--cyan); }
.champion-ovr { color: var(--ink); }
.champion-card.is-ban-action:not(:disabled):hover { background: linear-gradient(145deg, rgba(107,31,28,.96), rgba(45,16,16,.98)); box-shadow: 5px 5px 0 rgba(234,255,50,.48); }
.champion-card.is-pick-action:not(:disabled):hover { background: linear-gradient(145deg, rgba(72,77,19,.96), rgba(28,30,10,.98)); box-shadow: 5px 5px 0 rgba(239,68,58,.55); }
.champion-card.is-player-used { border-color: var(--cyan); background: rgba(70,76,18,.25); }
.champion-card.is-rival-used { border-color: var(--red); background: rgba(79,25,23,.30); }
.draft-lineup { border-color: rgba(234,255,50,.42); background: rgba(60,64,17,.18); }
.draft-lineup.rival-lineup { border-color: rgba(239,68,58,.42); background: rgba(72,25,23,.20); }
.lineup-row { border-color: rgba(234,255,50,.25); }
.lineup-row.is-rival { border-color: rgba(239,68,58,.25); }

.champion-card, .pick-assignment-slot, .review-player, .lineup-row, .run-roster-card { position: relative; overflow: hidden; }
.has-champion-art::before, .has-champion-art::after { content: ""; position: absolute; pointer-events: none; }
.has-champion-art::before { z-index: 0; top: 0; right: -8%; bottom: 0; width: 76%; background: var(--champion-art) 56% center / cover no-repeat; opacity: .43; filter: saturate(1.12) contrast(1.06); transform-origin: center; }
.has-champion-art::after { z-index: 0; inset: 0; background: linear-gradient(90deg, rgba(16,16,16,.98) 0%, rgba(16,16,16,.86) 46%, rgba(16,16,16,.42) 72%, rgba(16,16,16,.14) 100%); }
.has-champion-art > * { position: relative; z-index: 1; }
.champion-card.has-champion-art::before { right: -10%; width: 86%; opacity: .46; }
.champion-card.has-champion-art::after { background: linear-gradient(90deg, rgba(16,16,16,.98) 0%, rgba(16,16,16,.82) 48%, rgba(16,16,16,.3) 100%); }
.champion-card.is-selected.has-champion-art::before { opacity: .68; filter: saturate(1.24) contrast(1.09); }
.pick-assignment-slot.has-champion-art::before, .lineup-row.has-champion-art::before, .run-roster-card.has-champion-art::before { right: -10%; width: 82%; opacity: .38; }
.review-player.has-champion-art::before { right: -2%; width: 96%; background-position: 50% center; opacity: .42; }
.pick-assignment.has-selected-champion-art::before { z-index: 2; }
.pick-assignment.has-selected-champion-art::after { content: ""; position: absolute; z-index: 0; top: 0; right: 0; bottom: 0; width: min(58%, 460px); background: var(--selected-champion-art) center / cover no-repeat; opacity: .34; filter: blur(3px) saturate(1.12) contrast(1.03); transform: scale(1.035); transform-origin: center; pointer-events: none; -webkit-mask-image: linear-gradient(90deg, transparent 0%, rgba(0,0,0,.18) 18%, rgba(0,0,0,.78) 36%, #000 58%); mask-image: linear-gradient(90deg, transparent 0%, rgba(0,0,0,.18) 18%, rgba(0,0,0,.78) 36%, #000 58%); }
.pick-assignment.has-selected-champion-art > * { position: relative; z-index: 1; }

.simulation-power > div, .simulation-livebar > div, .advantage-track, .simulation-event, .run-metrics > div, .run-roster-card, .run-history-row { border-radius: 0; background: rgba(22,22,22,.88); }
.simulation-power strong, .match-phase strong, .simulation-event b, .run-metrics strong { color: var(--cyan); }
.simulation-power > div:last-child strong, .simulation-event.is-rival b, .run-history-row.is-loss b { color: var(--red); }
.advantage-track { background: linear-gradient(90deg, var(--red), #77736b 50%, var(--cyan)); }
.simulation-event { border-color: var(--cyan); background: rgba(234,255,50,.06); }
.simulation-event.is-rival, .run-history-row.is-loss { border-color: var(--red); background: rgba(239,68,58,.07); }
.simulation-event.is-final { border-color: var(--ink); background: rgba(241,238,231,.10); }
.simulation-event.is-rival .simulation-event-copy strong { color: #ffb4ad; }
.simulation-event.is-final .simulation-event-copy strong { color: var(--ink); }
.run-roster-card { border-color: rgba(234,255,50,.5); background: rgba(64,69,17,.22); }
.run-roster-card.is-offrole { border-color: rgba(239,68,58,.64); background: rgba(73,26,24,.28); }
.run-roster-card p { color: var(--cyan); }
.run-history-row { border-color: var(--cyan); }

.natural-role { display: inline-flex; align-items: center; gap: 6px; min-width: 0; }
.natural-role > span:last-child { overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.placement-slot > .role-icon { --role-icon-size: 32px; margin-bottom: 2px; }
.slot-role-label, .review-role, .lineup-role, .run-role, .data-role-label { color: var(--cyan); font-size: 10px; font-weight: 850; letter-spacing: .08em; text-transform: uppercase; }
.pick-assignment-slot > .slot-role-label, .lineup-row > .lineup-role, .run-roster-card > .run-role { color: var(--muted); }
.champion-role-icons { color: var(--cyan); font-size: 8px; font-weight: 850; letter-spacing: .08em; text-transform: uppercase; }
.champion-role-icons.is-flex { display: inline-block; }
.review-card-header > .review-role { color: var(--cyan); }
.review-role .role-icon { --role-icon-size: 20px; }
.lineup-role .role-icon, .run-role .role-icon, .data-role-label .role-icon { --role-icon-size: 16px; }
.data-table .champion-role-icons { font-size: 10px; }
.data-table .data-role-icons .role-icon { --role-icon-size: 16px; }

/* Tournament bracket: a dedicated match-poster treatment instead of the previous data-table look. */
.bracket-section { padding: 0; border: 0; background: transparent; box-shadow: none; overflow: visible; }
.bracket-section-heading { position: relative; margin: 0; padding: 19px 20px; border: 1px solid var(--line); border-bottom: 0; background: #1b1b1b; }
.bracket-section-heading::after { content: ""; position: absolute; right: 0; bottom: 0; width: 31%; height: 4px; background: linear-gradient(90deg, var(--red) 0 63%, var(--cyan) 63%); }
.bracket-section-heading h2 { font-size: 24px; }
.bracket-legend { color: var(--muted); text-transform: uppercase; letter-spacing: .08em; }
.bracket-legend i, .bracket-legend b { border-radius: 0; }
.bracket-legend i { background: var(--cyan); }
.bracket-legend b { background: var(--red); }
.bracket-board { position: relative; gap: 14px; min-width: 930px; padding: 18px; overflow: hidden; border: 1px solid var(--line); border-radius: 0; background: linear-gradient(122deg, transparent 0 83%, rgba(239,68,58,.18) 83.1% 83.35%, transparent 83.5%), repeating-linear-gradient(15deg, rgba(255,255,255,.022) 0 1px, transparent 1px 8px), #101010; }
.bracket-board::before { content: ""; position: absolute; top: 0; left: 23%; width: 41%; border-top: 2px solid rgba(234,255,50,.68); transform: rotate(-5deg); transform-origin: left; }
.bracket-lane { position: relative; padding: 15px; border-radius: 0; }
.upper-lane { border: 1px solid rgba(234,255,50,.48); border-left: 5px solid var(--cyan); background: linear-gradient(90deg, rgba(70,76,18,.24), rgba(16,16,16,.5)); }
.lower-lane { border: 1px solid rgba(239,68,58,.48); border-left: 5px solid var(--red); background: linear-gradient(90deg, rgba(83,27,24,.26), rgba(16,16,16,.5)); }
.lane-heading { position: relative; gap: 12px; padding: 0 0 11px; border-bottom: 1px solid var(--line); }
.lane-heading span { font-family: Impact, "Arial Black", sans-serif; color: var(--cyan); font-size: 15px; letter-spacing: .1em; }
.lower-lane .lane-heading span { color: var(--red); }
.lane-heading small { color: var(--ink); font-size: 10px; font-weight: 750; letter-spacing: .05em; text-transform: uppercase; }
.bracket-rounds { gap: 19px; padding-top: 12px; }
.bracket-round { gap: 15px; }
.bracket-round h3 { color: var(--muted); font-size: 10px; font-weight: 900; letter-spacing: .13em; }
.bracket-match { padding: 3px; border: 1px solid rgba(241,238,231,.30); border-radius: 0; background: #181818; }
.bracket-match::before { content: ""; position: absolute; top: 0; left: 0; width: 3px; height: 100%; background: #4b4b4b; }
.bracket-match.is-next { border-color: var(--red); box-shadow: 5px 5px 0 var(--cyan); background: #271613; }
.bracket-match.is-next::before { background: var(--red); }
.bracket-match.is-path::after { right: -19px; width: 18px; border-top: 2px solid var(--cyan); }
.bracket-team, .is-placeholder > div { min-height: 30px; padding: 7px 8px 7px 11px; border-radius: 0; color: var(--ink); font-size: 11px; }
.bracket-team + .bracket-team, .is-placeholder > div + div { border-top: 1px solid rgba(241,238,231,.12); }
.bracket-team small { color: var(--muted); font-size: 9px; font-weight: 750; letter-spacing: .03em; }
.bracket-team.is-player { color: #16170a; background: var(--cyan); }
.bracket-team.is-player small { color: #3b3d18; }
.bracket-board.has-hover-path .bracket-match:not(.is-hover-path) { opacity: .72; filter: saturate(.78); }
.bracket-match, .bracket-team { transition: opacity .14s ease, filter .14s ease, border-color .14s ease, background .14s ease, box-shadow .14s ease; }
.bracket-match.is-hover-path { border-color: rgba(234,255,50,.52); background: linear-gradient(90deg, rgba(234,255,50,.075), rgba(24,24,24,.98)); box-shadow: inset 0 0 0 1px rgba(234,255,50,.08); }
.bracket-match.is-hover-path::before { background: rgba(234,255,50,.72); }
.bracket-team.is-hover-team { color: var(--ink); background: rgba(234,255,50,.13); font-weight: 850; }
.bracket-team.is-hover-team small { color: #aaa79f; }
.is-placeholder { border-style: dashed; border-color: rgba(241,238,231,.18); background: rgba(255,255,255,.025); }
.is-placeholder > div { color: #918f89; }
.grand-final { grid-template-columns: 150px minmax(250px, 1fr) 160px; padding: 17px; border: 2px solid var(--ink); border-radius: 0; background: linear-gradient(90deg, rgba(239,68,58,.35), rgba(20,20,20,.96) 38%, rgba(234,255,50,.22)); }
.grand-final { order: -1; }
.grand-final > span, .grand-final > strong { font-family: Impact, "Arial Black", sans-serif; color: var(--ink); font-size: 13px; letter-spacing: .12em; }
.grand-final > strong { color: var(--cyan); }

@media (prefers-reduced-motion: no-preference) {
  .screen.is-entering { animation: screen-enter .45s cubic-bezier(.2,.8,.25,1) both; }
  .screen.is-entering .team-option, .screen.is-entering .player-card, .screen.is-entering .placement-slot, .screen.is-entering .review-player, .screen.is-entering .champion-card, .screen.is-entering .pick-assignment-slot, .draft-candidates.is-entering .player-card, .simulation-event.is-new { animation: card-enter .42s cubic-bezier(.2,.8,.25,1) both; animation-delay: var(--delay, 0ms); }
  .screen.is-entering .start-copy { animation: title-enter .55s cubic-bezier(.2,.8,.25,1) both; }
  .start-art { animation: art-glow 5s ease-in-out infinite; }
  .start-art::before { animation: diamond-breathe 7s ease-in-out infinite; }
  .start-art::after { animation: diamond-breathe 5s ease-in-out infinite reverse; }
  .geo-orbit { animation: geometry-fade 6s ease-in-out infinite; }
  .geo-diamond { animation: geometry-fade 4s ease-in-out infinite reverse; }
  .geo-core { animation: core-pulse 3s ease-in-out infinite; }
  .geo-square { animation: geometry-fade 5s ease-in-out infinite .8s; }
  .geo-line { animation: geometry-fade 3.6s ease-in-out infinite .3s; }
  .geo-triangle { animation: geometry-fade 4.4s ease-in-out infinite 1s; }
  .simulation-event.is-new { animation: event-stack-enter .54s cubic-bezier(.16,.92,.24,1.08) both; }
  .simulation-event.is-new::after { animation: event-stack-flash .72s ease-out both; }
  .simulation-result-banner:not([hidden]) { animation: result-slam .72s cubic-bezier(.15,.95,.2,1.12) both; }
  .simulation-result-banner:not([hidden]) .result-copy strong { animation: result-flash 1.15s ease-out .12s both; }
  @keyframes screen-enter { from { opacity: 0; transform: translateY(12px); } to { opacity: 1; transform: translateY(0); } }
  @keyframes card-enter { from { opacity: 0; transform: translateY(18px) scale(.985); } to { opacity: 1; transform: translateY(0) scale(1); } }
  @keyframes title-enter { from { opacity: 0; transform: translateY(18px); } to { opacity: 1; transform: translateY(0); } }
  @keyframes art-glow { 50% { filter: saturate(1.18) brightness(1.14); } }
  @keyframes diamond-breathe { 50% { opacity: .48; scale: 1.045; } }
  @keyframes geometry-fade { 50% { opacity: .48; scale: 1.06; } }
  @keyframes core-pulse { 50% { scale: 1.18; filter: brightness(1.35); box-shadow: 0 0 75px rgba(234,255,50,.78); } }
  @keyframes event-stack-enter {
    0% { opacity: 0; transform: translateY(-18px) scale(.985); filter: saturate(.75) brightness(.9); }
    55% { opacity: 1; transform: translateY(2px) scale(1.01); filter: saturate(1.45) brightness(1.18); }
    100% { opacity: 1; transform: translateY(0) scale(1); filter: saturate(1) brightness(1); }
  }
  @keyframes event-stack-flash {
    0% { opacity: .95; box-shadow: inset 0 0 0 1px currentColor, 0 0 22px rgba(234,255,50,.28); }
    100% { opacity: 0; box-shadow: inset 0 0 0 1px currentColor, 0 0 0 rgba(234,255,50,0); }
  }
  @keyframes result-slam {
    0% { opacity: 0; transform: translateY(18px) scale(.94) skewX(-3deg); filter: saturate(.6); }
    58% { opacity: 1; transform: translateY(-2px) scale(1.025) skewX(-1deg); filter: saturate(1.35); }
    100% { opacity: 1; transform: translateY(0) scale(1) skewX(0); filter: saturate(1); }
  }
  @keyframes result-flash {
    0% { text-shadow: 0 0 0 transparent; }
    35% { text-shadow: 0 0 18px rgba(234,255,50,.72), 5px 5px 0 rgba(239,68,58,.55); }
    100% { text-shadow: 3px 3px 0 rgba(239,68,58,.5); }
  }
}

@media (max-width: 1020px) {
  .draft-candidates { grid-template-columns: repeat(3, minmax(0, 1fr)); }
  .player-card { min-height: 245px; }
  .review-team { grid-template-columns: repeat(3, minmax(0, 1fr)); }
  .next-series { grid-template-columns: 1fr 1fr; }
  .next-series > .primary-button { grid-column: 1 / -1; justify-self: start; }
  .draft-status-panel { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .enemy-draft, .your-draft { padding-left: 0; border-left: 0; border-top: 1px solid var(--line); padding-top: 10px; }
  .draft-champion-pool { grid-template-columns: repeat(3, minmax(0, 1fr)); }
  .lineup-rows { grid-template-columns: repeat(5, minmax(110px, 1fr)); overflow-x: auto; padding-bottom: 4px; }
  .run-roster { grid-template-columns: repeat(3, minmax(0, 1fr)); }
  .simulation-event { grid-template-columns: 64px minmax(0, 1fr) 96px; }
  .simulation-event-roles .role-icon { --role-icon-size: 18px; }
  .data-controls { grid-template-columns: 1fr 150px; }
  .data-view-toggle { grid-column: 1 / -1; }
  .data-summary { grid-template-columns: repeat(3, minmax(0, 1fr)); }
  .rating-method { grid-template-columns: 1fr; }
}
@media (max-width: 760px) {
  main { width: min(100% - 30px, 1170px); padding-top: 30px; }
  .site-footer { width: min(100% - 30px, 1170px); align-items: start; flex-direction: column; margin-top: -22px; }
  .footer-links { justify-content: flex-start; }
  .site-header { align-items: start; flex-direction: column; }
  .team-options { grid-template-columns: 1fr; }
  .team-option { min-height: 260px; }
  .start-art { right: -42%; opacity: .65; }
  .tutorial-card { padding: 23px; }
  .draft-candidates { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .role-placement { grid-template-columns: repeat(5, minmax(115px, 1fr)); overflow-x: auto; padding-bottom: 5px; }
  .review-hero { grid-template-columns: 70px 1fr; }
  .review-emblem { width: 65px; height: 65px; font-size: 16px; }
  .team-power-summary { grid-column: 1 / -1; justify-items: start; }
  .review-team { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .review-footer { align-items: start; flex-direction: column; }
  .tournament-heading { align-items: start; flex-direction: column; }
  .match-heading { align-items: start; flex-direction: column; }
  .simulation-livebar { grid-template-columns: 1fr 1fr; }
  .simulation-event { grid-template-columns: 62px minmax(0, 1fr); }
  .simulation-event-side { grid-column: 2; grid-row: 2; display: flex; align-items: center; justify-content: space-between; width: 100%; }
  .simulation-event-roles { justify-content: flex-start; }
  .run-summary-hero { grid-template-columns: 70px 1fr; }
  .run-summary-hero .review-emblem { width: 65px; height: 65px; font-size: 16px; }
  .run-position { grid-column: 1 / -1; justify-items: start; }
  .run-metrics { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .bracket-section { overflow-x: auto; }
  .pick-assignment-slots { grid-template-columns: repeat(5, minmax(115px, 1fr)); overflow-x: auto; padding-bottom: 5px; }
  .data-hero { grid-template-columns: 1fr; align-items: start; }
  .data-controls { grid-template-columns: 1fr; }
  .data-summary { grid-template-columns: repeat(2, minmax(0, 1fr)); }
}
@media (max-width: 470px) {
  h1 { font-size: 40px; }
  .start-actions { align-items: stretch; flex-direction: column; }
  .start-actions button { width: 100%; }
  .draft-topline, .assignment-heading { align-items: start; flex-direction: column; }
  .assignment-heading p { text-align: left; }
  .draft-candidates, .review-team { grid-template-columns: 1fr; }
  .review-footer > div { width: 100%; flex-direction: column-reverse; }
  .review-footer button { width: 100%; }
  .next-series { grid-template-columns: 1fr; }
  .next-series > .primary-button { width: 100%; }
  .draft-status-panel { grid-template-columns: 1fr; }
  .section-inline-heading { align-items: start; flex-direction: column; }
  .section-inline-heading p:not(.eyebrow) { text-align: left; }
  .draft-champion-pool { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .draft-lineup > div:first-child { align-items: start; flex-direction: column; }
  .draft-actions { align-items: start; flex-direction: column; }
  .draft-actions .primary-button { width: 100%; }
  .simulation-power, .simulation-livebar { grid-template-columns: 1fr; }
  .simulation-power > div:last-child { text-align: left; }
  .simulation-livebar strong { font-size: 30px; }
  .simulation-event { grid-template-columns: 1fr; }
  .simulation-event-side { grid-column: 1; grid-row: auto; }
  .simulation-result-banner { grid-template-columns: 1fr; padding: 17px; }
  .result-continue-button { width: 100%; }
  .run-roster { grid-template-columns: 1fr; }
  .run-history-row { grid-template-columns: 24px 1fr 24px; }
  .run-history-row p { grid-column: 2 / 3; grid-row: 2; }
  .run-summary-actions { flex-direction: column-reverse; }
  .run-summary-actions button { width: 100%; }
  .tutorial-modal { padding: 14px; }
  .tutorial-card { max-height: calc(100vh - 28px); padding: 21px 18px; }
  .tutorial-card h2 { font-size: 27px; }
  .tutorial-score-grid { grid-template-columns: 1fr; }
  .footer-links { width: 100%; flex-direction: column; }
  .footer-data-link, .data-back-link { width: 100%; text-align: center; }
  .data-summary { grid-template-columns: 1fr; }
  .data-view-toggle { grid-template-columns: 1fr; }
  .data-view-toggle button { min-height: 40px; border-left: 0; border-top: 1px solid var(--line); }
  .data-view-toggle button:first-child { border-top: 0; }
}
