:root{font-family:Inter,ui-sans-serif,system-ui,-apple-system,sans-serif;color-scheme:dark;--felt-1: #0e6b3a;--felt-2: #095028;--felt-3: #053617;--rail: #2b160a;--rail-light: #5a2f17;--gold: #d4af37;--gold-soft: #e6c869;--chip-red: #c0341d;--bg: #050302;--ink: #f2ece0;--ink-dim: rgba(242, 236, 224, .62);color:var(--ink)}*{box-sizing:border-box}html,body,#root{height:100%}body{margin:0;background-color:#000;background-image:linear-gradient(#050302db,#050302f0),url(/background.jpg);background-size:cover;background-position:center;background-attachment:fixed;background-repeat:no-repeat;overflow:hidden;font-family:Inter,ui-sans-serif,system-ui,sans-serif;-webkit-font-smoothing:antialiased}.scene{position:relative;width:100%;height:100vh;perspective:1400px;perspective-origin:50% 110%;overflow:hidden}.hud-top{position:absolute;top:0;left:0;right:0;display:flex;align-items:center;justify-content:space-between;padding:20px 28px;z-index:30}.brand{font-family:Georgia,serif;font-size:22px;letter-spacing:.45em;color:var(--gold);text-shadow:0 1px 8px rgba(0,0,0,.7)}.brand small{display:block;font-size:9px;letter-spacing:.4em;opacity:.6;margin-top:2px;font-family:Inter,sans-serif}.hud-pills{display:flex;gap:10px;align-items:center}.pill{font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:var(--gold);padding:7px 14px;border:1px solid rgba(212,175,55,.35);border-radius:999px;background:#0a06028c;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px)}.pill.muted{color:var(--ink-dim);border-color:#ffffff14}.felt-wrap{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;padding-top:40px;transform-style:preserve-3d}.felt{--felt-tilt: 15deg;position:relative;width:min(1400px,120vw);height:78vh;border-radius:50%/45%;background:radial-gradient(ellipse at 50% 40%,#1a8a52 0%,var(--felt-1) 35%,var(--felt-2) 70%,var(--felt-3) 100%);transform:rotateX(var(--felt-tilt)) translateY(-4%);transform-origin:50% 90%;box-shadow:inset 0 0 120px #0009,0 0 0 18px var(--rail),0 0 0 20px #d4af3759,0 0 0 36px var(--rail-light),0 80px 120px #000000d9}.felt:before{content:"";position:absolute;top:6%;right:6%;bottom:6%;left:6%;border-radius:50%/45%;border:1px solid rgba(255,255,255,.05);pointer-events:none}.felt:after{content:"";position:absolute;bottom:14%;left:22%;right:22%;height:30%;border-radius:50%;border-top:1px solid rgba(212,175,55,.18);pointer-events:none}.felt-title{position:absolute;top:18%;left:50%;transform:translate(-50%);font-family:Georgia,serif;font-size:14px;letter-spacing:.35em;color:#d4af3773;text-transform:uppercase;text-align:center;pointer-events:none}.board{position:absolute;top:40%;left:50%;transform:translate(-50%) rotateX(calc(-1 * var(--felt-tilt))) translateY(-30px);transform-origin:center bottom;display:flex;gap:10px}.dealer-button{position:absolute;top:62%;left:42%;width:30px;height:30px;border-radius:50%;background:radial-gradient(circle at 30% 30%,#fff,#f0e6b8 55%,#b89a2c);color:#4a3010;font-weight:800;font-size:12px;font-family:Georgia,serif;display:flex;align-items:center;justify-content:center;box-shadow:0 2px 4px #0009,inset 0 0 0 2px #ffffffb3}.chip-stack{position:absolute;width:40px;height:40px}.chip-stack.left{top:60%;left:30%}.chip-stack.right{top:60%;right:30%}.chip-coin{position:absolute;left:0;top:0;width:36px;height:36px;border-radius:50%;background:radial-gradient(circle at 50% 50%,var(--chip-red) 0 38%,transparent 39%),repeating-conic-gradient(var(--chip-red) 0 18deg,#f5ecd9 18deg 27deg);box-shadow:0 2px 3px #00000080,inset 0 0 0 2px #00000026}.chip-coin:after{content:"";position:absolute;top:28%;right:28%;bottom:28%;left:28%;border-radius:50%;background:var(--chip-red);box-shadow:inset 0 0 0 1px #fff6}.chip-coin.blue{background:radial-gradient(circle at 50% 50%,#1d5fa0 0 38%,transparent 39%),repeating-conic-gradient(#1d5fa0 0,#1d5fa0 18deg,#f5ecd9 18deg,#f5ecd9 27deg)}.chip-coin.blue:after{background:#1d5fa0}.chip-coin.black{background:radial-gradient(circle at 50% 50%,#1a1a1a 0 38%,transparent 39%),repeating-conic-gradient(#1a1a1a 0,#1a1a1a 18deg,#f5ecd9 18deg,#f5ecd9 27deg)}.chip-coin.black:after{background:#1a1a1a}.chip-coin.green{background:radial-gradient(circle at 50% 50%,#1e6b3a 0 38%,transparent 39%),repeating-conic-gradient(#1e6b3a 0,#1e6b3a 18deg,#f5ecd9 18deg,#f5ecd9 27deg)}.chip-coin.green:after{background:#1e6b3a}.chip-stack .chip-coin:nth-child(1){transform:translate(0)}.chip-stack .chip-coin:nth-child(2){transform:translate(-6px,-4px)}.chip-stack .chip-coin:nth-child(3){transform:translate(8px,-3px)}.chip-stack .chip-coin:nth-child(4){transform:translate(2px,-10px)}.hero-zone{position:absolute;left:50%;bottom:24px;transform:translate(-50%);z-index:20;display:flex;flex-direction:column;align-items:center;pointer-events:none}.hole-cards{display:flex;gap:0}.hole-cards .card-lg{width:110px;height:154px;border-radius:12px;background:linear-gradient(180deg,#fdfaef,#ece3cf);color:#1a1a1a;display:flex;flex-direction:column;align-items:center;justify-content:space-between;padding:10px 12px;font-family:Georgia,serif;font-weight:700;box-shadow:0 12px 28px #000000b3,inset 0 0 0 1px #00000014;position:relative}.hole-cards .card-lg .corner{display:flex;flex-direction:column;align-items:center;line-height:1}.hole-cards .card-lg .corner.bottom{transform:rotate(180deg)}.hole-cards .card-lg .corner .rank{font-size:28px}.hole-cards .card-lg .corner .suit{font-size:24px;margin-top:2px}.hole-cards .card-lg .pip{position:absolute;font-size:48px;color:inherit;opacity:.18;top:50%;left:50%;transform:translate(-50%,-50%)}.hole-cards .card-lg.red{color:var(--chip-red)}.hole-cards .card-lg:nth-child(1){transform:rotate(-6deg) translate(18px) translateY(8px)}.hole-cards .card-lg:nth-child(2){transform:rotate(6deg) translate(-18px) translateY(8px)}.card{width:64px;height:92px;border-radius:9px;background:linear-gradient(180deg,#fdfaef,#ece3cf);color:#1a1a1a;display:flex;flex-direction:column;align-items:center;justify-content:center;font-weight:700;font-family:Georgia,serif;box-shadow:0 6px 14px #0009,inset 0 0 0 1px #00000014;-webkit-user-select:none;user-select:none}.card .rank{font-size:26px;line-height:1}.card .rank.ten{font-size:22px;letter-spacing:-1px}.hole-cards .card-lg .corner .rank.ten{font-size:24px;letter-spacing:-1px}.card.small .rank.ten{font-size:11px;letter-spacing:-.5px}.card .suit{font-size:24px;line-height:1;margin-top:2px}.card.red{color:var(--chip-red)}.card.placeholder{background:repeating-linear-gradient(45deg,#5a1a1a 0,#5a1a1a 8px,#6b1f1f 8px,#6b1f1f 16px);color:#fff0;border:2px solid rgba(212,175,55,.5)}.card.placeholder .rank,.card.placeholder .suit{visibility:hidden}.card.small{width:32px;height:44px;border-radius:5px;box-shadow:0 2px 4px #00000080}.card.small .rank,.card.small .suit{font-size:13px}.action-panel{position:absolute;top:90px;right:28px;width:420px;max-height:calc(100vh - 120px);display:flex;flex-direction:column;gap:12px;z-index:25;overflow-y:auto;padding:18px;border-radius:18px;background:#08060499;border:1px solid rgba(255,255,255,.07);backdrop-filter:blur(20px) saturate(140%);-webkit-backdrop-filter:blur(20px) saturate(140%);box-shadow:0 24px 60px #0000008c,inset 0 1px #ffffff0f}.action-panel::-webkit-scrollbar{width:6px}.action-panel::-webkit-scrollbar-thumb{background:#ffffff1a;border-radius:999px}.action-title{font-family:Inter,sans-serif;font-size:11px;letter-spacing:.28em;text-transform:uppercase;color:var(--gold);margin:0}.action-prompt{font-size:12px;color:var(--ink-dim);line-height:1.45}.cat-list{display:grid;grid-template-columns:1fr 1fr;gap:6px;align-items:start}.cat{display:flex;flex-direction:column;background:#ffffff06;border:1px solid rgba(255,255,255,.05);border-radius:10px;overflow:hidden;transition:background .15s,border-color .15s}.cat:hover{background:#ffffff0b;border-color:#ffffff1a}.cat-row{display:flex;align-items:center;gap:8px;padding:9px 10px;cursor:pointer;-webkit-user-select:none;user-select:none}.cat-name{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.cat-row input{accent-color:var(--gold);cursor:pointer}.cat-name{font-size:13px;flex:1;letter-spacing:.01em}.cat-badge{font-size:10px;font-weight:600;padding:3px 8px;border-radius:999px;background:#ffffff0f;color:var(--ink);letter-spacing:.05em}.cat.locked .cat-row{cursor:default}.cat.correct{background:#388e5a2e;border-color:#4ea96a66}.cat.correct .cat-badge{background:#4ea96a38;color:#b8eccb}.cat.missed{background:#b4642829;border-color:#d4884a66}.cat.missed .cat-badge{background:#d4884a38;color:#f5c89c}.cat.wrong{background:#aa3c3c2e;border-color:#c2555566}.cat.wrong .cat-badge{background:#c2555538;color:#f0a8a8}.info-btn{width:20px;height:20px;border-radius:50%;background:#d4af371f;border:1px solid rgba(212,175,55,.35);color:var(--gold);font-family:Georgia,serif;font-style:italic;font-weight:700;font-size:11px;display:inline-flex;align-items:center;justify-content:center;cursor:pointer;padding:0;flex-shrink:0}.info-btn:hover{background:#d4af3740}.info-btn.active{background:var(--gold);color:#1a0f08}.combo-reveal{padding:10px 12px;border-top:1px solid rgba(255,255,255,.05);background:#0003}.combo-list{display:flex;flex-direction:column;gap:4px;max-height:180px;overflow-y:auto}.combo-row{display:flex;gap:3px}.combo-more{margin-top:6px;font-size:11px;font-style:italic;color:var(--ink-dim)}.summary{font-size:12px;color:var(--ink-dim);padding:10px 12px;background:#ffffff05;border:1px solid rgba(255,255,255,.05);border-radius:10px}.summary strong{color:var(--gold);font-weight:600}.actions{display:flex;gap:8px}button{font-family:Inter,sans-serif;background:linear-gradient(180deg,var(--gold-soft) 0%,var(--gold) 100%);color:#1a0f08;border:0;border-radius:10px;padding:10px 18px;font-size:12px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;cursor:pointer;flex:1;box-shadow:0 4px 12px #00000080;transition:filter .15s,transform .1s}button:hover:not(:disabled){filter:brightness(1.1)}button:active:not(:disabled){transform:translateY(1px)}button.secondary{background:#ffffff0a;color:var(--ink);border:1px solid rgba(255,255,255,.1);box-shadow:none;flex:0 0 auto;padding:10px 14px}button:disabled{opacity:.4;cursor:not-allowed}.coach-panel{display:flex;flex-direction:column;gap:10px;padding:12px;background:#ffffff08;border:1px solid rgba(212,175,55,.18);border-radius:12px}.coach-header{display:flex;align-items:center;justify-content:space-between;gap:10px}.coach-title{font-family:Georgia,serif;font-size:12px;letter-spacing:.28em;color:var(--gold);text-transform:uppercase}.coach-btn{padding:6px 12px;font-size:10px;flex:0 0 auto}.coach-status{font-size:10px;letter-spacing:.18em;text-transform:uppercase;color:var(--ink-dim);font-style:italic}.coach-loading-text{font-size:11px;color:var(--ink-dim);margin-bottom:6px}.coach-progress{height:5px;background:#0006;border-radius:999px;overflow:hidden}.coach-progress-bar{height:100%;background:linear-gradient(90deg,var(--gold-soft),var(--gold));transition:width .3s}.coach-output{font-size:12.5px;line-height:1.55;color:var(--ink);white-space:pre-wrap;padding:10px 12px;background:#0000004d;border-radius:8px;border-left:2px solid var(--gold);max-height:240px;overflow-y:auto}.coach-output.error{color:#f0a8a8;border-left-color:#c25555}@media (max-width: 819px){body{overflow:auto}.scene.mobile{position:relative;width:100%;height:auto;min-height:100vh;perspective:none;overflow:visible;display:flex;flex-direction:column;padding:12px 12px 24px;gap:12px}.scene.mobile .hud-top{position:static;padding:8px 4px 4px;flex-wrap:wrap;gap:8px}.scene.mobile .brand{font-size:16px;letter-spacing:.35em}.scene.mobile .brand small{font-size:8px;letter-spacing:.3em}.scene.mobile .pill{font-size:10px;padding:5px 10px}.scene.mobile .felt-wrap{position:static;padding:0;transform-style:flat}.scene.mobile .felt{--felt-tilt: 0deg;width:100%;height:auto;aspect-ratio:5 / 3;transform:none;border-radius:50%/35%;box-shadow:inset 0 0 60px #0000008c,0 0 0 8px var(--rail),0 0 0 9px #d4af374d,0 0 0 14px var(--rail-light),0 20px 40px #000000b3;padding:0;display:flex;align-items:center;justify-content:center}.scene.mobile .felt-title,.scene.mobile .dealer-button,.scene.mobile .chip-stack{display:none}.scene.mobile .felt:after{display:none}.scene.mobile .board{position:static;transform:none;display:flex;gap:5px;justify-content:center;flex-wrap:nowrap}.scene.mobile .card{width:42px;height:60px;border-radius:6px}.scene.mobile .card .rank{font-size:18px}.scene.mobile .card .suit,.scene.mobile .card .rank.ten{font-size:16px}.scene.mobile .hero-zone{position:static;transform:none;margin:4px auto 0}.scene.mobile .hole-cards{gap:4px}.scene.mobile .hole-cards .card-lg{width:70px;height:98px;border-radius:8px;padding:6px 8px}.scene.mobile .hole-cards .card-lg .corner .rank{font-size:18px}.scene.mobile .hole-cards .card-lg .corner .suit,.scene.mobile .hole-cards .card-lg .corner .rank.ten{font-size:16px}.scene.mobile .hole-cards .card-lg .pip{font-size:32px}.scene.mobile .hole-cards .card-lg:nth-child(1){transform:rotate(-4deg) translate(8px)}.scene.mobile .hole-cards .card-lg:nth-child(2){transform:rotate(4deg) translate(-8px)}.scene.mobile .action-panel{position:static;width:100%;max-height:none;overflow:visible;padding:14px;border-radius:14px}.scene.mobile .action-prompt{font-size:11px}.scene.mobile .cat-list{gap:5px}.scene.mobile .cat-row{padding:8px 10px;gap:7px}.scene.mobile .cat-name{font-size:12px}.scene.mobile .cat-badge{font-size:9px;padding:2px 6px}.scene.mobile .info-btn{width:18px;height:18px;font-size:10px}.scene.mobile button{padding:12px 14px;font-size:12px}.scene.mobile .combo-list{max-height:140px}.scene.mobile .card.small{width:26px;height:36px}.scene.mobile .card.small .rank,.scene.mobile .card.small .suit{font-size:11px}.scene.mobile .coach-panel{display:none}}
