*,*:before,*:after{margin:0;padding:0;box-sizing:border-box}:root{--bg: linear-gradient(160deg, #fff7ea 0%, #ffe9c9 55%, #f5ddba 100%);--surface: rgba(255, 255, 255, .85);--text: #2b1d12;--accent: #7c3aed;--shadow: rgba(61, 40, 20, .18);font-family:Nunito,system-ui,-apple-system,sans-serif;line-height:1.5;color:var(--text);font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased}body{min-height:100dvh;background:var(--bg);background-attachment:fixed}button{font:inherit;cursor:pointer;border:none}button:focus-visible{outline:3px solid #f59e0b;outline-offset:2px}#root{min-height:100dvh;display:flex;flex-direction:column}.app-shell{flex:1;padding:clamp(12px,3vw,28px);max-width:980px;margin:0 auto;width:100%}.app-title{font-weight:800;letter-spacing:.02em;text-align:center;margin-bottom:.75rem;font-size:clamp(1.6rem,5vw,2.05rem);color:#4a3728;text-shadow:0 1px 0 rgba(255,255,255,.6)}.home-page{min-height:calc(100dvh - clamp(24px,6vw,56px));display:grid;grid-template-columns:minmax(0,1fr);align-items:center;gap:clamp(18px,5vw,44px);padding:clamp(18px,5vw,46px);border-radius:28px;background:linear-gradient(135deg,#fffffff0,#fffaf1c7),radial-gradient(circle at 18% 22%,rgba(196,30,58,.12),transparent 26%),radial-gradient(circle at 84% 72%,rgba(45,134,52,.13),transparent 28%);box-shadow:0 18px 48px #3d281424,inset 0 1px #fffffff5}.home-copy{text-align:center;max-width:680px;margin:0 auto}.home-kicker{color:#7c4d20;font-weight:900;text-transform:uppercase;letter-spacing:.12em;font-size:.78rem;margin-bottom:10px}.home-title{color:#3e2a1c;font-size:clamp(2.7rem,10vw,5.8rem);line-height:.95;letter-spacing:0;text-shadow:0 2px 0 rgba(255,255,255,.72)}.home-subtitle{max-width:620px;margin:18px auto 0;color:#6e5f52;font-size:clamp(1rem,2.5vw,1.2rem)}.home-actions{display:flex;flex-wrap:wrap;justify-content:center;gap:12px;margin-top:24px}.home-actions .btn{display:inline-flex;align-items:center;justify-content:center;gap:9px;min-width:178px}.home-board{width:min(78vw,430px);aspect-ratio:1;margin:0 auto;border-radius:50%;filter:drop-shadow(0 18px 34px rgba(61,40,20,.22))}.home-board-svg{display:block;width:100%;height:100%;overflow:visible}.ui-card{background:var(--surface);border-radius:20px;padding:clamp(10px,2.2vw,18px);box-shadow:0 8px 32px var(--shadow),inset 0 1px #fffffff2}.btn-row{display:flex;flex-wrap:wrap;gap:10px;justify-content:center;margin-top:14px}.btn{min-height:48px;padding:0 20px;border-radius:14px;font-weight:700;font-size:1rem;box-shadow:0 4px #00000014,0 6px 16px #0000001a}.btn:active{transform:translateY(2px);box-shadow:0 1px #00000014,0 2px 10px #0000001a}.btn-primary{background:linear-gradient(180deg,#8b5cf6,#6d28d9);color:#fefce8}.btn-secondary{background:linear-gradient(180deg,#fff,#f3efe8);color:#3d2f24}.btn-danger{background:linear-gradient(180deg,#f87171,#dc2626);color:#fffbeb}.btn-ghost{background:transparent;box-shadow:none;color:#5c4939}.setup-grid{display:flex;flex-direction:column;gap:14px;margin-top:12px}.setup-seat{display:grid;grid-template-columns:1fr auto;gap:10px;align-items:center;padding:10px;border-radius:14px;background:#f5f0e6cc}.setup-seat input[type=text]{grid-column:1 / -1;padding:12px 14px;border-radius:12px;border:2px solid #e9dcc8;font:inherit;width:100%}.palette{grid-column:1 / -1;display:flex;flex-wrap:wrap;gap:8px}.palette button{width:42px;height:42px;border-radius:50%;border:3px solid transparent;box-shadow:inset 0 -4px #00000026,0 2px 6px #0000001f}.palette button.palette--active{border-color:#1e293b;transform:scale(1.05)}.variant-toggle{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px;max-width:420px;margin:16px auto 0;padding:6px;border-radius:14px;background:#f5f0e6e6;border:2px solid rgba(233,220,200,.9)}.variant-toggle__option{min-height:58px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1px;border-radius:10px;color:#4a3728;background:transparent;font-weight:900}.variant-toggle__option small{color:#786657;font-size:.78rem;font-weight:800}.variant-toggle__option--on{color:#3d1673;background:#ede9fe;box-shadow:0 2px 8px #3d28141f,inset 0 0 0 2px #6d28d9}.variant-toggle__option--on small{color:#5b21b6}.count-row{display:flex;align-items:center;gap:8px;flex-wrap:wrap;justify-content:center}.count-row button.num{min-width:48px;min-height:48px;border-radius:12px;font-weight:800;background:#fff;border:3px solid #e9dcc8}.count-row button.num--on{border-color:#6d28d9;background:#ede9fe}.error-text{color:#dc2626;font-weight:700;text-align:center;margin-top:10px;font-size:.95rem}.game-screen{position:relative;display:flex;flex-direction:column;gap:8px;flex:1}.quit-home-btn{position:absolute;top:10px;left:10px;z-index:5;width:42px;height:42px;display:inline-flex;align-items:center;justify-content:center;flex-shrink:0;border-radius:50%;color:#4a3728;background:#fffffff0;border:2px solid rgba(74,54,37,.12);box-shadow:0 5px 16px #2b1d1229,inset 0 1px #ffffffe6}.quit-home-btn:hover{background:#fff;transform:translateY(-1px)}.quit-home-btn:active{transform:translateY(1px)}.game-sidebar{display:flex;flex-direction:column;gap:10px}.turn-banner{display:flex;align-items:center;justify-content:center;gap:12px;padding:12px 16px;border-radius:16px;font-weight:800;font-size:clamp(1.05rem,3.8vw,1.22rem);background:#ffffffeb;box-shadow:0 4px 14px #00000014,inset 0 0 0 3px #0000000a}.turn-banner .swatch{width:28px;height:28px;border-radius:50%;flex-shrink:0}.turn-history-actions{display:flex;justify-content:center;gap:8px;margin-top:10px}.turn-history-actions button{min-width:82px;min-height:34px;display:inline-flex;align-items:center;justify-content:center;gap:6px;padding:0 10px;border-radius:10px;color:#4a3728;background:linear-gradient(180deg,#fff,#f3efe8);border:2px solid rgba(74,54,37,.08);font-weight:800;font-size:.82rem;box-shadow:0 3px #00000014,0 6px 12px #2b1d1214}.turn-history-actions button:not(:disabled):hover{transform:translateY(-1px)}.turn-history-actions button:not(:disabled):active{transform:translateY(1px);box-shadow:0 1px #00000014,0 3px 8px #2b1d1214}.turn-history-actions button:disabled{cursor:not-allowed;opacity:.42;box-shadow:none}.board-scroll{flex:1;min-height:0;display:flex;align-items:center;justify-content:center}.cc-board-wrap{width:100%;filter:drop-shadow(0 8px 20px rgba(43,29,18,.15));-webkit-tap-highlight-color:transparent;-webkit-touch-callout:none;-webkit-user-select:none;user-select:none}.cc-board-wrap svg{display:block;width:100%;height:auto;max-height:min(82dvh,700px);-webkit-tap-highlight-color:transparent;outline:none}.cc-board-wrap svg *,.cc-board-wrap [role=button]{-webkit-tap-highlight-color:transparent;outline:none}.cc-board-wrap [role=button]:focus,.cc-board-wrap [role=button]:focus-visible,.marble-hit:focus,.marble-hit:focus-visible{outline:none}@media(min-width:600px){.cc-board-wrap svg{max-height:min(84dvh,720px)}}@media(min-width:860px){.app-shell{max-width:1440px;padding:clamp(4px,.8vw,12px)}.home-page{grid-template-columns:minmax(0,1fr) minmax(360px,.82fr);min-height:calc(100dvh - 24px)}.home-copy{text-align:left;margin:0}.home-subtitle{margin-left:0;margin-right:0}.home-actions{justify-content:flex-start}.home-board{width:min(34vw,500px)}.game-screen{flex-direction:row;align-items:flex-start;gap:12px}.board-scroll{flex:1 1 auto;order:1;min-width:0}.game-sidebar{flex:0 0 220px;order:2;position:sticky;top:20px}.cc-board-wrap svg{max-height:min(92dvh,900px)}}.hole-visible{pointer-events:none}.marble-hit{cursor:pointer}.valid-dot{fill:#fcd34d;stroke:#b45309;stroke-width:2px;pointer-events:none;animation:pulseValid 1.1s ease-in-out infinite}.hover-dot{fill:#fbbf2447;stroke:#b4530973;stroke-width:1.5px;pointer-events:none}@keyframes pulseValid{0%,to{opacity:.82;transform:scale(1)}50%{opacity:1;transform:scale(1.04)}}@keyframes pulseWinner{0%,to{transform:scale(1)}50%{transform:scale(1.02)}}.controls-bar{display:flex;flex-wrap:wrap;gap:8px;justify-content:center}.controls-bar .btn{flex:1 1 calc(33% - 8px);min-width:120px;font-size:.95rem}@media(max-width:599px){.app-shell{padding:6px}.game-screen.ui-card{gap:8px;padding:8px;border-radius:18px;background:#ffffffc2}.quit-home-btn{top:14px;left:14px;width:38px;height:38px}.game-sidebar{gap:8px}.turn-banner{min-height:118px;padding:14px 12px 12px 58px;border-radius:18px;font-size:1.05rem;box-shadow:0 5px 18px #2b1d121a,inset 0 0 0 2px #4a36250a}.turn-banner .swatch{width:26px;height:26px}.turn-history-actions{gap:6px;margin-top:8px}.turn-history-actions button{min-width:74px;min-height:32px;padding:0 8px;font-size:.78rem}.game-sidebar>.muted{margin:2px auto 4px;max-width:30ch;font-size:.9rem;line-height:1.35}.controls-bar.ui-card{gap:8px;padding:8px;border-radius:16px;box-shadow:0 8px 20px #3d28141a,inset 0 1px #ffffffeb}.controls-bar .btn{min-width:0;min-height:42px;padding:0 10px;border-radius:14px;font-size:.86rem}.board-scroll{width:calc(100% + 12px);margin-inline:-6px}.cc-board-wrap{width:100%;filter:drop-shadow(0 8px 16px rgba(43,29,18,.12))}.cc-board-wrap svg{max-height:none}}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#1e140a73;display:grid;place-items:center;padding:20px;z-index:50}.modal-card{max-width:420px;width:100%;padding:clamp(18px,4vw,26px);border-radius:20px;background:#fffdf8;max-height:85dvh;overflow-y:auto}.modal-card h3{font-size:1.35rem;margin-bottom:12px;color:#4a3728}.modal-card p+p{margin-top:.65rem}.modal-actions{display:flex;gap:10px;justify-content:flex-end;margin-top:16px;flex-wrap:wrap}.winner-card{text-align:center;animation:pulseWinner 2.4s ease-in-out infinite}.winner-card .swatch{width:56px;height:56px;border-radius:50%;margin:14px auto 8px;box-shadow:inset 0 -10px #0003,0 12px 30px #0003}.muted{color:#6e5f52;font-size:.95rem;text-align:center;margin-top:8px}
