:root{font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;color:#171717;background:#f6f3ee;font-synthesis:none;text-rendering:optimizeLegibility}*{box-sizing:border-box}body{margin:0;min-width:320px;background:radial-gradient(circle at 15% 0%,rgba(181,18,34,.12),transparent 260px),linear-gradient(180deg,rgba(8,91,57,.08),transparent 360px),#f6f3ee}button,select{font:inherit}button{border:0}.shell{width:min(1420px,calc(100% - 32px));margin:0 auto;padding:24px 0 40px}.site-header,.game-title,.result-topline{display:flex;align-items:center;justify-content:space-between;gap:16px}.site-header{min-height:58px;margin-bottom:34px}.brand-lockup{display:inline-flex;align-items:center;gap:10px;padding:0;background:transparent;color:#171717;cursor:pointer}.brand-lockup span{display:inline-grid;place-items:center;width:42px;height:42px;border-radius:8px;background:#b51222;color:#fff;font-weight:950}.brand-lockup strong{font-size:18px}.site-nav{display:inline-flex;gap:4px;padding:4px;border:1px solid #d7d0c6;border-radius:8px;background:#fffdf9cc}.site-nav button{min-height:34px;padding:0 12px;border-radius:6px;background:transparent;color:#3b3835;font-weight:850;cursor:pointer}.site-nav button.active{background:#171717;color:#fff}.site-nav button:disabled{cursor:not-allowed;opacity:.45}.home-hero{display:grid;grid-template-columns:minmax(0,1.05fr) minmax(340px,.95fr);gap:36px;align-items:center;min-height:430px}.hero-copy h1,.privacy-page h1,.game-title h1,.result-topline h1{margin:0;letter-spacing:0;line-height:.96;color:#b51222}.hero-copy h1{max-width:780px;font-size:clamp(46px,7vw,96px)}.hero-copy p:not(.eyebrow){max-width:680px;margin:18px 0 0;color:#3b3835;font-size:20px;font-weight:700;line-height:1.45}.hero-actions{display:flex;flex-wrap:wrap;gap:10px;margin-top:24px}.lineup-preview{position:relative;min-height:500px;aspect-ratio:10 / 14;padding:16px;border:1px solid rgba(255,255,255,.82);border-radius:8px;overflow:hidden;background:repeating-linear-gradient(0deg,#ffffff0f 0 48px,#0000000d 48px 96px),linear-gradient(135deg,#17763a,#0f5d34 58%,#0b4e31);box-shadow:inset 0 0 0 3px #ffffff38}.lineup-preview:before,.lineup-preview:after{content:"";position:absolute;z-index:0;left:50%;width:44%;height:13%;transform:translate(-50%);border:2px solid rgba(255,255,255,.48);pointer-events:none}.lineup-preview:before{top:-2px;border-top:0;border-radius:0 0 8px 8px}.lineup-preview:after{bottom:-2px;border-bottom:0;border-radius:8px 8px 0 0}.preview-score,.preview-chip{position:absolute;z-index:1;display:grid;place-items:center;border:1px solid rgba(255,255,255,.58);border-radius:8px;background:#fffdf929;color:#fff;font-weight:950}.preview-score{left:16px;top:16px;width:98px;height:76px;background:#fffdf9eb;color:#171717}.preview-chip{width:76px;height:58px;transform:translate(-50%,-50%);font-size:14px}.preview-score span{color:#6c665f;font-size:12px;text-transform:uppercase}.preview-score strong{font-size:36px;line-height:1}.mode-showcase{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px;margin-top:24px}.mode-card{display:grid;gap:8px;min-height:150px;padding:16px;border:1px solid #d7d0c6;border-radius:8px;background:#fffdf9;color:#171717;text-align:left;cursor:pointer}.mode-card:hover{border-color:#b51222}.mode-card:disabled{cursor:not-allowed;opacity:.62}.mode-card.active{border-color:#b51222;box-shadow:0 0 0 2px #b5122224}.mode-card.static{cursor:default}.mode-card strong{font-size:24px;line-height:1.1}.mode-card small{font-size:14px;line-height:1.4}.steps-band{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px;margin-top:18px}.steps-band div{display:grid;gap:5px;padding:14px 0;border-top:1px solid #d7d0c6}.steps-band b{color:#b51222;font-size:13px}.steps-band strong{font-size:20px}.steps-band span,.home-footer{color:#6c665f;font-weight:750}.home-footer{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-top:20px;padding-top:16px;border-top:1px solid #d7d0c6}.home-footer button{background:transparent;color:#171717;font-weight:850;cursor:pointer}.privacy-page{max-width:1120px}.privacy-page h1,.game-title h1,.result-topline h1{font-size:clamp(40px,5vw,64px)}.privacy-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px;margin-top:22px}.privacy-grid article{min-height:210px;padding:18px;border:1px solid #d7d0c6;border-radius:8px;background:#fffdf9}.privacy-grid svg{color:#b51222}.privacy-grid h2{margin:14px 0 8px}.privacy-grid p{margin:0;color:#3b3835;font-weight:700;line-height:1.5}.game-title,.result-topline{margin-bottom:16px}.topbar{display:flex;align-items:center;justify-content:space-between;gap:16px;min-height:72px}.result-actions{display:flex;flex-wrap:wrap;gap:8px;justify-content:flex-end}.topbar h1,.roll-panel h2,.result-hero h2{margin:0;letter-spacing:0}.topbar h1{font-size:clamp(32px,5vw,56px);line-height:1;color:#b51222}.eyebrow,.label,.muted,small{color:#6c665f}.eyebrow{margin:0 0 6px;font-size:12px;font-weight:800;text-transform:uppercase}.label{display:block;font-size:12px;font-weight:800;text-transform:uppercase}.icon-text{display:inline-flex;align-items:center;justify-content:center;gap:8px;min-height:42px;padding:0 14px;border:1px solid #d7d0c6;border-radius:8px;background:#fffdf9;color:#171717;font-weight:800;cursor:pointer;transition:transform .12s ease,border-color .12s ease,background .12s ease}.icon-text:hover:not(:disabled){transform:translateY(-1px);border-color:#b51222}.icon-text:disabled{cursor:not-allowed;opacity:.45}.icon-text.primary{border-color:#b51222;background:#b51222;color:#fff}.icon-text.ghost{background:#fffdf9b3}.controls-band{display:grid;grid-template-columns:minmax(320px,1.3fr) minmax(260px,1fr) 180px;gap:14px;align-items:end;margin:10px 0}.home-setup{margin-top:22px}.model-disclaimer{max-width:920px;margin:0 0 18px;color:#6c665f;font-size:13px;font-weight:700;line-height:1.4}.strength-strip+.model-disclaimer{margin-top:10px}.home-disclaimer{margin-bottom:4px}.control-group{min-width:0}.segmented{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:6px;min-height:48px;padding:5px;border:1px solid #d7d0c6;border-radius:8px;background:#fffdf9}.segmented button{display:inline-flex;align-items:center;justify-content:center;gap:7px;min-width:0;min-height:36px;padding:0 10px;border-radius:6px;background:transparent;color:#3b3835;font-weight:800;cursor:pointer;white-space:normal}.segmented button.active{background:#171717;color:#fff}.segmented button:disabled,.formation-control select:disabled{cursor:not-allowed;opacity:.62}.formation-control select{width:100%;min-height:48px;padding:0 12px;border:1px solid #d7d0c6;border-radius:8px;background:#fffdf9;color:#171717;font-weight:800}.layout{display:grid;grid-template-columns:minmax(310px,420px) minmax(0,1fr);gap:18px;align-items:start}.left-panel,.pitch-panel,.results{min-width:0}.roll-panel{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:16px;border:1px solid #d7d0c6;border-radius:8px;background:#fffdf9}.roll-panel h2{font-size:22px}.roll-actions{display:flex;flex-wrap:wrap;gap:8px;justify-content:flex-end}.player-list{display:grid;gap:8px;max-height:650px;margin-top:12px;overflow:auto;padding-right:4px}.player-row{display:grid;grid-template-columns:minmax(0,1fr) 48px;gap:10px;align-items:center;width:100%;min-height:62px;padding:10px 12px;border:1px solid #d7d0c6;border-radius:8px;background:#fffdf9;text-align:left;cursor:pointer}.player-row strong,.disc-name,.fixture-row strong,.team-box strong{overflow-wrap:anywhere}.player-row small{display:block;margin-top:3px;font-weight:700}.player-row.selected{border-color:#b51222;box-shadow:0 0 0 2px #b5122229}.rating{display:inline-flex;align-items:center;justify-content:center;width:42px;height:42px;border-radius:8px;background:#171717;color:#fff}.pitch-panel{display:grid;gap:12px}.pitch{position:relative;min-height:520px;aspect-ratio:16 / 10;border:2px solid rgba(255,255,255,.8);border-radius:8px;overflow:hidden;background:repeating-linear-gradient(90deg,#ffffff0d 0 52px,#0000000a 52px 104px),linear-gradient(135deg,#17763a,#0f5d34 52%,#0b4e31);box-shadow:inset 0 0 0 3px #ffffff40}.pitch:before,.pitch:after{content:"";position:absolute;z-index:0;left:50%;transform:translate(-50%);border:2px solid rgba(255,255,255,.5);pointer-events:none}.pitch:before{top:-2px;width:34%;height:15%;border-top:0;border-radius:0 0 8px 8px}.pitch:after{bottom:-2px;width:34%;height:15%;border-bottom:0;border-radius:8px 8px 0 0}.midline{position:absolute;z-index:0;inset:50% 0 auto;height:2px;background:#ffffff73;pointer-events:none}.circle{position:absolute;z-index:0;left:50%;top:50%;width:132px;height:132px;transform:translate(-50%,-50%);border:2px solid rgba(255,255,255,.45);border-radius:50%;pointer-events:none}.disc{position:absolute;z-index:1;display:grid;grid-template-rows:18px minmax(20px,auto) 20px;place-items:center;width:104px;min-height:86px;padding:8px;transform:translate(-50%,-50%);border:2px solid rgba(255,255,255,.7);border-radius:8px;background:#fffdf9eb;color:#171717;cursor:pointer;box-shadow:0 8px 20px #00000029}.disc:not(.filled){background:#fff3;color:#fff}.disc.target{border-color:#f2c94c;box-shadow:0 0 0 4px #f2c94c52,0 8px 20px #00000029}.disc-pos,.disc-rating{font-weight:900}.disc-pos{font-size:12px}.disc-name{display:-webkit-box;width:100%;min-height:20px;overflow:hidden;font-size:13px;font-weight:900;line-height:1.05;text-align:center;-webkit-box-orient:vertical;-webkit-line-clamp:2}.disc-rating{min-width:28px;padding:2px 6px;border-radius:6px;background:#b51222;color:#fff}.team-box{display:grid;grid-template-columns:repeat(auto-fit,minmax(130px,1fr));gap:8px}.team-box>div{min-height:70px;padding:11px;border:1px solid #d7d0c6;border-radius:8px;background:#fffdf9}.team-box strong{display:block;margin-top:6px}.simulate{justify-self:stretch}.results{margin-top:20px}.results-page{margin-top:18px}.strength-strip{grid-template-columns:repeat(auto-fit,minmax(130px,1fr));margin-top:12px}.result-hero{display:flex;align-items:center;gap:14px;padding:16px;border:1px solid #d7d0c6;border-radius:8px;background:#fffdf9}.result-hero svg{flex:0 0 auto;color:#b51222}.result-hero p{margin:6px 0 0}.result-lineup-wrap{margin-top:14px;padding:0 14px 14px;border:1px solid #d7d0c6;border-radius:8px;background:#fffdf9}.result-lineup-wrap h3{margin:0;padding:14px 0 10px}.result-lineup{width:min(100%,900px);min-height:510px;margin:0 auto}.result-lineup .disc{cursor:default}.result-grid{display:grid;grid-template-columns:minmax(360px,1.1fr) minmax(310px,.9fr);gap:18px;margin-top:14px;align-items:start}.table-wrap,.fixture-wrap,.playoff-box{min-width:0;border:1px solid #d7d0c6;border-radius:8px;background:#fffdf9}.table-wrap h3,.fixture-wrap h3,.playoff-box h3{margin:0;padding:14px 14px 10px}.table-wrap{overflow:auto}table{width:100%;min-width:560px;border-collapse:collapse}th,td{padding:9px 12px;border-top:1px solid #ebe5dc;text-align:left;white-space:nowrap}th{color:#6c665f;font-size:12px;text-transform:uppercase}tr.me{background:#b512221a;font-weight:900}.fixture-list{display:grid;max-height:620px;overflow:auto}.fixture-row{display:grid;grid-template-columns:42px minmax(0,1fr);gap:8px;padding:10px 14px;border-top:1px solid #ebe5dc}.fixture-row span{color:#6c665f;font-weight:900}.playoff-box{margin-top:12px;padding-bottom:10px}.playoff-box p{margin:0;padding:8px 14px;border-top:1px solid #ebe5dc;line-height:1.45}@media(max-width:1050px){.controls-band,.layout,.result-grid,.home-hero,.mode-showcase,.privacy-grid{grid-template-columns:1fr}.team-box{grid-template-columns:repeat(3,minmax(0,1fr))}.lineup-preview{width:min(100%,520px);justify-self:center}}@media(max-width:720px){.shell{width:min(100% - 16px,1420px);padding:10px 0 28px}.site-header{min-height:0;margin-bottom:18px}.site-header,.game-title,.result-topline,.topbar,.roll-panel{align-items:stretch;flex-direction:column}.site-nav{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));width:100%}.site-nav button{padding:0 8px}.brand-lockup{justify-content:center}.brand-lockup span{width:38px;height:38px}.home-hero{min-height:0;gap:18px}.hero-copy h1{font-size:44px}.hero-copy p:not(.eyebrow){font-size:17px}.hero-actions .icon-text,.result-topline .icon-text,.game-title .icon-text{width:100%}.steps-band{grid-template-columns:1fr}.home-footer{align-items:flex-start;flex-direction:column}.lineup-preview{width:min(100%,380px);min-height:390px}.result-actions{justify-content:stretch}.privacy-page h1,.game-title h1,.result-topline h1{font-size:38px;line-height:1.02}.topbar h1{font-size:38px}.controls-band{gap:10px;margin:8px 0 10px}.model-disclaimer{margin-bottom:12px;font-size:12px}.segmented{grid-template-columns:1fr;min-height:0}.roll-actions{justify-content:stretch}.roll-actions .icon-text,.topbar .icon-text,.result-actions .icon-text{width:100%}.roll-panel{gap:10px;padding:12px}.roll-panel h2{font-size:20px}.player-list{max-height:330px;margin-top:10px}.player-row{grid-template-columns:minmax(0,1fr) 42px;min-height:56px;padding:8px 10px}.rating{width:38px;height:38px}.pitch{min-height:560px;aspect-ratio:9 / 14}.disc{grid-template-rows:16px minmax(18px,auto) 18px;width:86px;min-height:72px;padding:7px}.disc-name{font-size:11.5px}.team-box{grid-template-columns:repeat(2,minmax(0,1fr))}.team-box>div{min-height:62px;padding:9px}.strength-strip{grid-template-columns:repeat(2,minmax(0,1fr))}.result-hero{align-items:flex-start;padding:14px}.fixture-row{grid-template-columns:34px minmax(0,1fr)}.fixture-list{max-height:520px}}@media(max-width:430px){.shell{width:min(100% - 12px,1420px)}.topbar h1{font-size:34px}.hero-copy h1{font-size:38px}.hero-copy p:not(.eyebrow){font-size:16px}.mode-card{min-height:128px;padding:14px}.lineup-preview{min-height:340px}.preview-chip{width:56px;height:44px;font-size:11px}.preview-score{width:76px;height:58px}.preview-score strong{font-size:30px}.privacy-page h1,.game-title h1,.result-topline h1{font-size:34px}.site-nav button,.segmented button{font-size:13px}.player-list{max-height:280px}.disc{width:76px;min-height:66px;padding:6px}.disc-pos{font-size:11px}.disc-name{font-size:10.5px}.disc-rating{min-width:24px;padding:1px 5px}.pitch{min-height:500px}.team-box{grid-template-columns:1fr}}@media(max-width:360px){.hero-copy h1,.privacy-page h1,.game-title h1,.result-topline h1,.topbar h1{font-size:32px}.site-nav{grid-template-columns:1fr}.pitch{min-height:470px}.disc{width:70px;min-height:62px}}
