@import "https://fonts.googleapis.com/css2?family=Fraunces:opsz,wght@9..144,600;9..144,700&family=Manrope:wght@400;500;600;700&display=swap";:root{color:#4d3b22;font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;--panel-bg:#fffaf4e6;--panel-border:#76582b24;--surface-alt:#fffcf7e0;--text-strong:#2f2315;--text-muted:#6f5b42;background:radial-gradient(circle at top,#f4c47a38,#0000 34%),linear-gradient(#f8f1e6 0%,#f4ede1 52%,#efe4d3 100%);font-family:Manrope,sans-serif;font-weight:400;line-height:1.5}*{box-sizing:border-box}body{min-width:320px;margin:0}button,textarea{font:inherit}h1,h2,h3{color:var(--text-strong);font-family:Fraunces,serif}#root{width:100%;min-height:100vh}.app-shell{flex-direction:column;gap:1.5rem;min-height:100vh;padding:1.5rem;display:flex}.topbar,.more-panel-header,.panel-header,.chart-header,.detail-meta{flex-wrap:wrap;justify-content:space-between;align-items:flex-start;gap:1rem;display:flex}.topbar h1,.spotlight-card h2,.chart-panel h2,.setup-card h2,.more-panel h2,.panel h3,.table-shell h3{margin:0}.topbar h1{font-size:clamp(2rem,4vw,3.4rem);line-height:.92}.topbar-blurb{color:var(--text-muted);flex-direction:column;gap:.1rem;margin-top:.45rem;font-size:.95rem;display:flex}.topbar-kicker,.section-kicker,.status-label,.metric-card p,.history-card span,.history-card small,.spacebar-hint{text-transform:uppercase;letter-spacing:.14em;margin:0;font-size:.74rem}.topbar-kicker,.section-kicker,.status-label,.metric-card p,.history-card span,.history-card small,.spacebar-hint,.spotlight-note,.field-help,.empty-state,.metric-card span{color:var(--text-muted)}.more-button,.secondary-button,.history-card,.roll-button{cursor:pointer;font:inherit;border:0}.more-button,.secondary-button{color:var(--text-strong);background:#58391e14;border-radius:999px;padding:.8rem 1.15rem;transition:transform .15s,background .15s,box-shadow .15s}.more-button:hover,.secondary-button:hover,.history-card:hover,.roll-button:hover{transform:translateY(-1px)}.more-button:focus-visible,.secondary-button:focus-visible,.history-card:focus-visible,.roll-button:focus-visible{outline-offset:2px;outline:3px solid #ef9b344d}.table-layout,.setup-layout{flex-direction:column;flex:1;gap:1.5rem;display:flex}.spotlight-card,.chart-panel,.setup-card,.panel,.metric-card,.table-shell,.history-card,.start-game-form,.detail-meta{border:1px solid var(--panel-border);background:var(--panel-bg);border-radius:1.75rem;box-shadow:0 20px 45px #31251214}.spotlight-card,.chart-panel,.setup-card,.panel,.table-shell,.detail-meta,.start-game-form{padding:1.4rem}.turn-wheel-panel{justify-content:center;display:flex;position:relative}.turn-wheel-shell{width:100%}.turn-wheel-shell.wheel-width-2{max-width:56rem}.turn-wheel-shell.wheel-width-3{max-width:72rem}.turn-wheel-shell.wheel-width-4{max-width:88rem}.turn-wheel-frame{--wheel-gap:1.1rem;--wheel-peek:clamp(1rem, 3vw, 2.5rem);--card-size:calc((100% - (var(--wheel-peek) * 2) - var(--wheel-gap)) / 2);--card-step:calc(var(--card-size) + var(--wheel-gap));padding:1.2rem var(--wheel-peek);perspective:2200px;background:radial-gradient(140% 120%,#ffffffad 0%,#fff8ee40 42%,#5f3e1f2e 100%),linear-gradient(#87603538,#ffffff8c 20% 80%,#87603538);border:1px solid #76582b29;border-radius:2.1rem;position:relative;overflow:hidden;box-shadow:inset 0 1.2rem 1.8rem #fff6,inset 0 -1rem 1.8rem #6244221f,0 20px 45px #31251214}.turn-wheel-frame:before,.turn-wheel-frame:after{content:"";pointer-events:none;z-index:2;width:clamp(1.25rem,4vw,2.4rem);position:absolute;top:0;bottom:0}.turn-wheel-frame:before{background:linear-gradient(90deg,#3826123d,#38261200);left:0}.turn-wheel-frame:after{background:linear-gradient(-90deg,#3826123d,#38261200);right:0}.turn-wheel-track{grid-auto-flow:column;grid-auto-columns:var(--card-size);gap:var(--wheel-gap);transform:translateX(calc(var(--card-step) * -1));transform-style:preserve-3d;will-change:transform;align-items:stretch;display:grid}.turn-wheel-track.animate{animation:.86s cubic-bezier(.2,.8,.22,1) turn-wheel-spin}.wheel-card{transform-style:preserve-3d;transition:transform .24s,opacity .24s,filter .24s}.wheel-card.slot-edge-left{transform-origin:100%;opacity:.72;filter:saturate(.88);transform:rotateY(58deg)scale(.88)}.wheel-card.slot-front-left{z-index:1;transform:rotateY(18deg)translateZ(2rem)}.wheel-card.slot-front-right{z-index:1;transform:rotateY(-18deg)translateZ(2rem)}.wheel-card.slot-edge-right{transform-origin:0;opacity:.72;filter:saturate(.88);transform:rotateY(-58deg)scale(.88)}.wheel-card.slot-hidden{transform-origin:0;opacity:0;filter:blur(1px);transform:rotateY(-74deg)scale(.78)}.wheel-card .spotlight-card{width:100%;min-height:19rem}.spotlight-card{text-align:center;perspective:1600px;flex-direction:column;justify-content:center;align-items:center;gap:1rem;display:flex;overflow:hidden}.spotlight-card.next{background:radial-gradient(circle at top, #ffcd7052, transparent 55%), var(--panel-bg)}.spotlight-card h2{font-size:clamp(2.1rem,4vw,3.8rem)}.spotlight-stage{width:100%;transform-style:preserve-3d;justify-content:center;display:flex}.spotlight-reel{width:100%;transform-style:preserve-3d;backface-visibility:hidden;flex-direction:column;align-items:center;gap:1rem;display:flex}.spotlight-value{aspect-ratio:1;width:min(18rem,100%);color:var(--text-strong);background:linear-gradient(#fffffff2,#f5ecddf2);border:1px solid #76582b24;border-radius:2rem;place-items:center;font-family:Fraunces,serif;font-size:clamp(4.6rem,10vw,8rem);line-height:1;display:grid}.spotlight-note{font-size:.98rem}@keyframes turn-wheel-spin{0%{transform:translate(0)}64%{transform:translateX(calc(var(--card-step) * -1.08))}78%{transform:translateX(calc(var(--card-step) * -.97))}to{transform:translateX(calc(var(--card-step) * -1))}}.chart-panel{flex-direction:column;gap:1rem;display:flex}.chart-header{grid-template-columns:minmax(0,1fr) auto minmax(0,1fr);align-items:start;gap:1rem;display:grid}.player-legend,.chart-legend{flex-wrap:wrap;gap:1rem;display:flex}.player-legend{justify-content:center;align-self:start}.chart-legend{justify-content:flex-end;align-self:start}.player-legend span,.chart-legend span{color:var(--text-strong);align-items:center;gap:.45rem;font-size:.92rem;display:inline-flex}.legend-swatch{border-radius:999px;width:.8rem;height:.8rem;display:inline-block}.legend-swatch.last-game,.chart-bar.last-game{background:#c07a35}.legend-swatch.current-game,.chart-bar.current-game{background:#d95c2b}.legend-swatch.expected-game,.chart-bar.expected-game{background:#365f7a}.chart-grid{border-top:1px solid #76582b1f;grid-template-columns:repeat(11,minmax(0,1fr));align-items:end;gap:1.15rem;min-height:19rem;padding:1rem .5rem .2rem;display:grid}.chart-group{flex-direction:column;justify-self:center;align-items:center;gap:.7rem;width:min(100%,4.4rem);display:flex}.chart-bars{grid-template-columns:.7fr 1.4fr .7fr;align-items:end;gap:.28rem;width:100%;min-height:16rem;display:grid}.chart-bar{border-radius:.7rem .7rem .2rem .2rem;justify-self:center;width:100%;min-height:0;position:relative;box-shadow:inset 0 -1px #ffffff52}.chart-label{color:var(--text-strong);font-size:1rem;font-weight:700}.chart-bar.last-game,.chart-bar.expected-game{width:68%}.chart-bar.current-game{width:100%}.chart-bar.stacked{background:#fff3;border:1px solid #76582b1a;flex-direction:column-reverse;display:flex;overflow:hidden}.chart-segment{width:100%;box-shadow:inset 0 1px #fff3}.chart-tooltip{color:#fff8ef;opacity:0;pointer-events:none;z-index:5;background:#2f2315f0;border-radius:1rem;min-width:12.5rem;padding:.8rem .9rem;transition:opacity .16s,transform .16s;position:absolute;bottom:calc(100% + .3rem);left:50%;transform:translate(-50%)translateY(.35rem);box-shadow:0 18px 30px #20160c3d}.chart-tooltip:after{content:"";border-top:.55rem solid #2f2315f0;border-left:.45rem solid #0000;border-right:.45rem solid #0000;position:absolute;top:100%;left:50%;transform:translate(-50%)}.chart-tooltip strong{margin-bottom:.45rem;font-size:1rem;display:block}.chart-tooltip p{color:#fff8efd1;margin:0}.chart-tooltip-list{flex-direction:column;gap:.38rem;display:flex}.chart-tooltip-row,.chart-tooltip-player{justify-content:space-between;align-items:center;gap:.6rem;display:flex}.chart-tooltip-player{justify-content:flex-start}.chart-bar.stacked:hover,.chart-bar.stacked:focus-visible{z-index:6;overflow:visible}.chart-bar.stacked:hover .chart-tooltip,.chart-bar.stacked:focus-visible .chart-tooltip{opacity:1;transform:translate(-50%)translateY(0)}.roll-button{color:#fffaf3;background:linear-gradient(135deg,#d65f24,#ef9b34);border-radius:1.6rem;width:100%;min-height:5.75rem;font-family:Fraunces,serif;font-size:clamp(2rem,4vw,3rem);box-shadow:0 18px 30px #d65f2447}.start-button{margin-top:.5rem}.spacebar-hint{text-align:center}.setup-layout{justify-content:center;align-items:center}.setup-card{width:min(100%,46rem)}.setup-card h2{margin-top:.15rem;margin-bottom:1rem;font-size:clamp(2rem,4vw,3rem)}.start-game-form,.content-stack,.history-list,.summary-strip{flex-direction:column;gap:1rem;display:flex}.field-label{color:var(--text-strong);font-weight:700}.players-textarea{resize:vertical;width:100%;min-height:12rem;color:var(--text-strong);font:inherit;background:#fffdf9;border:1px solid #76582b2e;border-radius:1rem;padding:1rem}.form-error{color:#a2331d;margin:0}.drawer-backdrop{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#291d1247;justify-content:flex-end;padding:1rem;display:flex;position:fixed;inset:0}.more-panel{background:#fbf6eef5;border:1px solid #76582b24;border-radius:2rem;flex-direction:column;gap:1rem;width:min(40rem,100%);height:100%;padding:1.25rem;display:flex;overflow-y:auto;box-shadow:0 32px 60px #20160c38}.close-button{align-self:flex-start}.panel,.table-shell,.metric-card,.history-card,.detail-meta{background:var(--surface-alt)}.summary-strip{grid-template-columns:repeat(auto-fit,minmax(9rem,1fr));display:grid}.metric-card{gap:.4rem;padding:1rem}.metric-card strong{color:var(--text-strong);font-size:1.8rem;line-height:1}.history-card{text-align:left;padding:1rem}.history-card.selected{background:linear-gradient(135deg,#ef9b3429,#fffffff5);border-color:#d65f2452}.stats-table{border-collapse:collapse;width:100%;font-size:.96rem}.stats-table th,.stats-table td{text-align:left;border-bottom:1px solid #76582b1f;padding:.7rem .5rem}.stats-table tr:last-child td{border-bottom:0}@media (width<=900px){.app-shell,.drawer-backdrop{padding:1rem}.chart-header{grid-template-columns:1fr}.player-legend,.chart-legend{justify-content:flex-start}.chart-grid{grid-template-columns:1fr}.turn-wheel-shell,.turn-wheel-shell.wheel-width-2,.turn-wheel-shell.wheel-width-3,.turn-wheel-shell.wheel-width-4{max-width:100%}.turn-wheel-frame{--wheel-gap:.85rem;--wheel-peek:.8rem}.chart-group{grid-template-columns:3rem minmax(0,1fr);align-items:end;gap:1rem;display:grid}.chart-bars{min-height:8rem}}@media (width<=640px){.spotlight-value{width:min(14rem,100%)}.wheel-card .spotlight-card{min-height:16rem;padding:1rem}.turn-wheel-frame{--wheel-gap:.65rem;--wheel-peek:.5rem}.wheel-card.slot-edge-left,.wheel-card.slot-edge-right{opacity:.52}.roll-button{min-height:4.8rem;font-size:2rem}.more-panel{border-radius:1.5rem;width:100%}.stats-table{white-space:nowrap;display:block;overflow-x:auto}}
