:root{--font-display: "Inter Tight", "Inter", ui-sans-serif, system-ui, sans-serif;--font-body: "Inter", ui-sans-serif, system-ui, sans-serif;--font-mono: "JetBrains Mono", ui-monospace, "SF Mono", Menlo, monospace;--ink-0: #f6f7f8;--ink-1: #d8dadd;--ink-2: #9aa0a8;--ink-3: #6b7280;--ink-4: #3d4148;--ink-5: #232529;--ink-6: #15171a;--ink-7: #0c0d0f;--ink-8: #08090b;--felt-0: #0d2818;--felt-1: #0f3220;--felt-2: #143b28;--felt-3: #1a3d28;--felt-edge: #061410;--act-hit: oklch(.78 .16 60);--act-stand: oklch(.74 .12 220);--act-double: oklch(.72 .18 145);--act-split: oklch(.72 .16 295);--act-surrender: oklch(.65 .05 280);--act-insurance: oklch(.7 .14 35);--good: oklch(.78 .14 150);--warn: oklch(.8 .15 75);--bad: oklch(.68 .18 25);--info: oklch(.74 .12 220);--chip-1: #c8cdd3;--chip-5: #c43a3a;--chip-25: #1f7a4a;--chip-100: #1a1d22;--chip-500: #6b3aa6;--chip-1000: #b88a2a;--bg: var(--ink-8);--panel: rgba(20, 22, 26, .72);--panel-2: rgba(28, 30, 34, .85);--line: rgba(255, 255, 255, .07);--line-2: rgba(255, 255, 255, .12);--line-3: rgba(255, 255, 255, .2);--r-1: 4px;--r-2: 8px;--r-3: 12px;--r-4: 16px;--r-card: 8px;--ease-out: cubic-bezier(.16, 1, .3, 1);--ease-in-out: cubic-bezier(.65, 0, .35, 1)}:root[data-theme=charcoal]{--felt-0: #1a1a1c;--felt-1: #1f1f22;--felt-2: #25252a;--felt-3: #2b2b30;--felt-edge: #050506}:root[data-theme=oxblood]{--felt-0: #2a0e10;--felt-1: #321214;--felt-2: #3a1518;--felt-3: #421a1d;--felt-edge: #0d0405}:root[data-theme=midnight]{--felt-0: #0a1220;--felt-1: #0d172b;--felt-2: #111d36;--felt-3: #15233f;--felt-edge: #04080f}:root[data-display=serif]{--font-display: "Fraunces", "Newsreader", Georgia, serif}:root[data-display=grotesk]{--font-display: "Space Grotesk", "Inter Tight", sans-serif}:root[data-display=mono]{--font-display: "JetBrains Mono", ui-monospace, monospace}.topbar{position:sticky;top:0;z-index:50;display:flex;align-items:center;justify-content:space-between;padding:14px 22px;background:#08090bd9;-webkit-backdrop-filter:blur(20px) saturate(160%);backdrop-filter:blur(20px) saturate(160%);border-bottom:1px solid var(--line)}.topbar-l,.topbar-r{display:flex;align-items:center;gap:24px}.brand{display:flex;align-items:center;gap:12px}.brand-mark{width:28px;height:28px;border-radius:7px;background:linear-gradient(160deg,var(--ink-0) 0%,var(--ink-2) 100%);color:var(--ink-8);display:flex;align-items:center;justify-content:center;font-family:var(--font-display);font-weight:700;font-size:15px;position:relative}.brand-mark i{position:absolute;bottom:4px;right:4px;width:6px;height:6px;border-radius:50%;background:var(--act-double)}.brand-text{display:flex;flex-direction:column;gap:1px}.brand-name{font-size:14px;line-height:1}.brand-sub{font-size:9.5px;color:var(--ink-3)}.modes{display:flex;align-items:center;gap:2px;padding:3px;background:#ffffff08;border:1px solid var(--line);border-radius:9px}.mode-tab{appearance:none;border:0;background:transparent;color:var(--ink-2);display:inline-flex;align-items:center;gap:8px;padding:6px 12px;border-radius:6px;font-size:12.5px;font-weight:500;cursor:pointer;transition:background .12s,color .12s}.mode-tab:hover{color:var(--ink-1)}.mode-tab-on{background:var(--ink-7);color:var(--ink-0);box-shadow:0 1px #ffffff0a inset}.mode-num{color:var(--ink-3);font-size:10.5px}.mode-tab-on .mode-num{color:var(--ink-2)}.bankroll{display:flex;flex-direction:column;align-items:flex-end;gap:1px;padding-right:8px;border-right:1px solid var(--line)}.bankroll-val{font-size:16px;font-weight:600;line-height:1;letter-spacing:-.02em}.rules-pill{appearance:none;display:inline-flex;align-items:center;gap:8px;padding:7px 12px;background:#ffffff0a;border:1px solid var(--line-2);border-radius:999px;color:var(--ink-1);cursor:pointer;transition:background .12s;font-family:inherit}.rules-pill:hover{background:#ffffff14}.rules-pill-name{font-size:11.5px;color:var(--ink-2);padding-left:6px;border-left:1px solid var(--line-2)}.profile-btn{appearance:none;border:1px solid var(--line-2);background:#ffffff0a;width:32px;height:32px;border-radius:50%;display:inline-flex;align-items:center;justify-content:center;cursor:pointer}.profile-avatar{font-family:var(--font-display);font-size:12px;font-weight:600;color:var(--ink-0)}.modal-bg{position:fixed;inset:0;z-index:200;background:#0009;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;padding:32px;animation:fadeUp .2s var(--ease-out)}.modal{width:100%;max-width:720px;max-height:calc(100vh - 64px);background:#14161a;border:1px solid var(--line-2);border-radius:var(--r-4);display:flex;flex-direction:column;box-shadow:0 30px 80px #0009;overflow:hidden}.modal-hd,.modal-ft{padding:20px 24px;display:flex;align-items:center;justify-content:space-between}.modal-hd{border-bottom:1px solid var(--line)}.modal-ft{border-top:1px solid var(--line);background:#ffffff05}.modal-title{font-size:22px;margin:4px 0 0}.modal-body{padding:6px 24px 12px;overflow-y:auto}.modal-shorthand{color:var(--ink-2)}.rules-section{padding:16px 0;display:flex;flex-direction:column;gap:10px}.rules-section .eyebrow{margin-bottom:4px}.rules-row{display:grid;grid-template-columns:1fr auto;gap:16px;align-items:center;padding:8px 0}.rules-row-label{font-size:13px;font-weight:500;color:var(--ink-1)}.rules-row-hint{font-size:11px;color:var(--ink-3);margin-top:2px}.seg{display:inline-flex;background:#0006;border:1px solid var(--line);border-radius:8px;padding:2px}.seg-opt{appearance:none;border:0;background:transparent;padding:5px 11px;font-size:12px;color:var(--ink-2);border-radius:6px;cursor:pointer;font-family:inherit}.seg-opt:hover{color:var(--ink-1)}.seg-opt-on{background:#ffffff14;color:var(--ink-0)}.presets{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:8px}.preset{appearance:none;text-align:left;padding:10px 12px;background:#ffffff08;border:1px solid var(--line);border-radius:10px;cursor:pointer;display:flex;flex-direction:column;gap:4px;color:var(--ink-1);font-family:inherit}.preset:hover{background:#ffffff12}.preset-on{background:#ffffff17;border-color:var(--line-3)}.preset-name{font-size:13px;font-weight:500}.preset-short{color:var(--ink-3);font-size:10px}.drawer-bg{position:fixed;inset:0;z-index:180;background:#00000073;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.drawer{position:fixed;top:0;bottom:0;width:min(420px,92vw);background:#14161a;border-left:1px solid var(--line-2);display:flex;flex-direction:column;z-index:181;box-shadow:-8px 0 40px #00000080;animation:slideInRight .22s var(--ease-out)}.drawer-right{right:0}.drawer-left{left:0;border-left:0;border-right:1px solid var(--line-2);animation-name:slideInLeft}.drawer-hd{display:flex;justify-content:space-between;align-items:center;padding:18px 22px;border-bottom:1px solid var(--line)}.drawer-body{padding:18px 22px;overflow-y:auto;flex:1}@keyframes slideInRight{0%{transform:translate(100%)}to{transform:translate(0)}}@keyframes slideInLeft{0%{transform:translate(-100%)}to{transform:translate(0)}}.card{border-radius:var(--r-card);position:relative;flex-shrink:0;font-family:var(--font-display);font-weight:600;display:inline-block}.card-face{background:linear-gradient(180deg,#fafbfc,#ecedef);box-shadow:0 1px #ffffff80 inset,0 0 0 .5px #0000002e,0 8px 16px -4px #00000073,0 2px 4px #0000004d;overflow:hidden}.card-face img{display:block;width:100%;height:100%;object-fit:cover;border-radius:inherit;-webkit-user-drag:none;user-select:none}.card-back{background:linear-gradient(135deg,#1a3a5c,#0d2541);box-shadow:0 0 0 .5px #0006,0 8px 16px -4px #00000073,0 2px 4px #0000004d;overflow:hidden}.card-back img{display:block;width:100%;height:100%;object-fit:cover;border-radius:inherit;-webkit-user-drag:none;user-select:none}.chip{appearance:none;border:0;display:inline-flex;align-items:center;justify-content:center;font-family:var(--font-mono);cursor:pointer;box-shadow:0 0 0 .5px #00000080,0 2px 4px #0006,0 6px 12px #00000059;transition:transform .12s var(--ease-out);position:relative}.chip:hover{transform:translateY(-2px)}.chip:active{transform:translateY(0)}.chip-selected{outline:2px solid var(--ink-0);outline-offset:2px}.action-btn{appearance:none;display:inline-flex;align-items:center;gap:10px;background:#0006;color:var(--ink-0);border:1px solid rgba(255,255,255,.1);border-radius:10px;font-weight:500;letter-spacing:-.005em;position:relative;cursor:pointer;transition:background .12s var(--ease-out),transform .12s var(--ease-out),border-color .12s;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);font-family:inherit}.action-btn:hover:not(:disabled){background:#0000008c;border-color:var(--act-color);transform:translateY(-1px)}.action-btn:active:not(:disabled){transform:translateY(0)}.action-btn:disabled{opacity:.32;cursor:not-allowed}.action-glyph{display:inline-flex;align-items:center;justify-content:center;width:22px;height:22px;border-radius:6px;background:var(--act-color);color:#0a0a0a;font-family:var(--font-mono);font-weight:700;font-size:12px}.action-label{font-size:inherit}.action-key{margin-left:auto;padding:2px 6px;border:1px solid var(--line-2);border-radius:4px;font-family:var(--font-mono);font-size:10px;color:var(--ink-2);letter-spacing:.04em}.action-hint{border-color:var(--act-color);box-shadow:0 0 0 1px var(--act-color),0 0 24px -6px var(--act-color)}.action-flag{border-color:var(--bad);animation:pulse 1.2s ease-in-out infinite}.heatmap{display:flex;flex-direction:column;gap:10px}.heatmap-grid{display:grid;grid-template-columns:36px repeat(10,var(--cell));gap:2px;align-items:center}.heatmap-corner{grid-column:1;font-size:9px;color:var(--ink-3);white-space:nowrap}.heatmap-coltop,.heatmap-rowlabel{font-family:var(--font-mono);font-size:10px;color:var(--ink-2);text-align:center;font-feature-settings:"tnum"}.heatmap-rowlabel{text-align:right;padding-right:4px}.heatmap-cell{width:var(--cell);height:var(--cell);border-radius:2px;border:.5px solid rgba(255,255,255,.04);position:relative}.heatmap-cell-hi{outline:1.5px solid var(--ink-0);outline-offset:1px;z-index:1}.heatmap-pulse{position:absolute;inset:-2px;border:1.5px solid var(--ink-0);border-radius:4px;animation:pulse 1.4s ease-in-out infinite}.heatmap-legend{display:flex;gap:14px;flex-wrap:wrap;align-items:center;font-size:9.5px}.heatmap-legend span{display:inline-flex;align-items:center;gap:5px}.heatmap-legend i{display:inline-block;width:10px;height:10px;border-radius:2px;border:.5px solid var(--line)}.strategy-pill{display:inline-flex;align-items:center;justify-content:center;min-width:22px;padding:2px 6px;border-radius:4px;font-family:var(--font-mono);font-size:11px;font-weight:600;color:var(--ink-0);background:#ffffff0f;border:.5px solid var(--line-2)}.strategy-pill[data-action=hit]{background:color-mix(in oklab,var(--act-hit) 30%,transparent)}.strategy-pill[data-action=stand]{background:color-mix(in oklab,var(--act-stand) 30%,transparent)}.strategy-pill[data-action=double]{background:color-mix(in oklab,var(--act-double) 30%,transparent)}.strategy-pill[data-action=split]{background:color-mix(in oklab,var(--act-split) 30%,transparent)}.strategy-pill[data-action=surrender]{background:color-mix(in oklab,var(--act-surrender) 30%,transparent)}.panel{background:var(--panel);border:1px solid var(--line);border-radius:var(--r-3);-webkit-backdrop-filter:blur(20px) saturate(140%);backdrop-filter:blur(20px) saturate(140%)}.panel-2{background:var(--panel-2)}.btn{appearance:none;background:#ffffff0d;color:var(--ink-0);border:1px solid var(--line-2);border-radius:8px;padding:8px 14px;font-size:13px;font-weight:500;cursor:pointer;transition:background .12s;font-family:inherit}.btn:hover{background:#ffffff17}.btn-primary:hover{background:var(--ink-1)}.btn-ghost:hover{background:#ffffff0d}.kbd{display:inline-block;padding:1px 5px;border:1px solid var(--line-2);border-radius:3px;background:#0000004d;font-family:var(--font-mono);font-size:10px;color:var(--ink-2);line-height:1.4}.pill{display:inline-flex;align-items:center;gap:6px;padding:3px 10px;border:1px solid var(--line-2);border-radius:999px;font-size:11px;color:var(--ink-1)}.pill-mono{font-family:var(--font-mono);font-size:10.5px;letter-spacing:.04em}.dot{display:inline-block;width:6px;height:6px;border-radius:50%}.badge{display:inline-flex;align-items:center;gap:4px;padding:2px 8px;border-radius:999px;font-size:10.5px;font-weight:500;font-family:var(--font-mono);background:#ffffff0f;color:var(--ink-1);border:.5px solid var(--line-2);letter-spacing:.04em}.badge-good{background:color-mix(in oklab,var(--good) 20%,transparent);color:var(--good);border-color:var(--good)}.badge-bad{background:color-mix(in oklab,var(--bad) 20%,transparent);color:var(--bad);border-color:var(--bad)}.badge-info{background:color-mix(in oklab,var(--info) 20%,transparent);color:var(--info);border-color:var(--info)}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.play-mode{display:flex;flex-direction:column;height:calc(100vh - 60px)}.play-felt{flex:1;display:grid;grid-template-rows:1fr auto 1fr;padding:32px 48px;position:relative;overflow:hidden}.play-felt:before{content:"";position:absolute;inset:12% -10% -20%;border:2px solid rgba(255,255,255,.04);border-radius:50%;pointer-events:none}.dealer-zone,.player-zone{display:flex;flex-direction:column;align-items:center;gap:14px;position:relative;z-index:2}.player-zone{justify-content:flex-end}.zone-label{color:#ffffff73}.zone-label .num{color:#ffffffd9;font-size:13px;font-weight:600}.cards-row{display:flex;gap:0}.cards-row>*+*{margin-left:-56px}.hands-row{display:flex;gap:32px}.hand-stack{display:flex;flex-direction:column;align-items:center;gap:10px;padding:8px;border-radius:10px;transition:background .2s}.hand-active{background:#ffffff0a;box-shadow:0 0 0 1px var(--good)}.hand-bust{opacity:.45}.hand-meta{display:flex;align-items:center;gap:10px;font-size:12px;color:var(--ink-2)}.hand-total{color:var(--ink-0);font-size:14px;font-weight:600}.hand-bet{color:var(--ink-3)}.play-center{display:flex;align-items:center;justify-content:center;position:relative;z-index:2}.bet-prompt{display:flex;flex-direction:column;align-items:center;gap:16px;padding:28px 40px;background:#00000059;border:1px solid rgba(255,255,255,.08);border-radius:16px;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px)}.bet-amount{font-size:44px;line-height:1;color:var(--ink-0);letter-spacing:-.04em}.action-bar{display:grid;grid-template-columns:1fr auto 1fr;padding:14px 24px;background:var(--ink-8);border-top:1px solid var(--line);align-items:center;gap:20px}.action-bar-l{display:flex;align-items:center;gap:24px}.action-bar-c{display:flex;align-items:center;justify-content:center}.action-bar-r{display:flex;justify-content:flex-end;align-items:center;gap:18px}.action-buttons{display:flex;gap:8px}.drill-mode{display:grid;grid-template-columns:1fr 360px;gap:24px;padding:24px;height:calc(100vh - 60px)}.drill-stage{display:flex;flex-direction:column;background:#ffffff05;border:1px solid var(--line);border-radius:16px;overflow:hidden;position:relative}.drill-felt{flex:1;padding:24px;display:flex;flex-direction:column;gap:18px}.drill-felt-title{display:flex;justify-content:space-between;align-items:center}.drill-actions{padding:18px 24px;border-top:1px solid var(--line);display:flex;gap:8px;justify-content:center;background:#0000004d}.drill-sidebar{display:flex;flex-direction:column;gap:16px;background:#ffffff05;border:1px solid var(--line);border-radius:16px;padding:20px;overflow-y:auto}.count-mode{display:flex;flex-direction:column;height:calc(100vh - 60px);background:var(--ink-8)}.count-stage{flex:1;display:flex;align-items:center;justify-content:center;position:relative;padding:40px}.count-card-area{display:flex;align-items:center;justify-content:center;gap:40px;min-height:220px}.count-controls{padding:18px 32px;border-top:1px solid var(--line);display:flex;align-items:center;justify-content:space-between}.mode-placeholder{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;padding:48px;background:#ffffff05;border:1px dashed var(--line-2);border-radius:14px;color:var(--ink-2);text-align:center;max-width:520px;margin:24px auto}.mode-placeholder h2{margin:0;font-family:var(--font-display);font-size:22px;color:var(--ink-0);letter-spacing:-.01em}.mode-placeholder p{margin:0;font-size:13px;line-height:1.5}@media (max-width: 900px){.drill-mode{grid-template-columns:1fr}.play-felt{padding:20px 16px}.topbar{padding:10px 14px}.topbar-l,.topbar-r{gap:12px}.modes{display:none}}@media (max-width: 600px){.bankroll{display:none}}*,*:before,*:after{box-sizing:border-box}html,body,#root{margin:0;padding:0;min-height:100vh}body{font-family:var(--font-body);font-size:14px;color:var(--ink-0);background:var(--bg);-webkit-font-smoothing:antialiased;font-feature-settings:"ss01","cv11"}button,input,select,textarea{font-family:inherit}.felt{background:radial-gradient(1200px 700px at 50% 30%,var(--felt-3) 0%,var(--felt-1) 55%,var(--felt-0) 78%,var(--felt-edge) 100%),repeating-linear-gradient(45deg,transparent 0 2px,rgba(0,0,0,.06) 2px 3px),repeating-linear-gradient(-45deg,transparent 0 2px,rgba(255,255,255,.015) 2px 3px);position:relative}.felt:after{content:"";position:absolute;inset:0;pointer-events:none;background:radial-gradient(60% 50% at 50% 50%,transparent 60%,rgba(0,0,0,.45) 100%)}.tnum{font-variant-numeric:tabular-nums}.display{font-family:var(--font-display);font-weight:500;letter-spacing:-.02em}.eyebrow{font-family:var(--font-mono);font-size:10.5px;font-weight:500;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-3)}.hr{height:1px;background:var(--line);border:0}:focus-visible{outline:2px solid var(--info);outline-offset:2px;border-radius:4px}*::-webkit-scrollbar{width:8px;height:8px}*::-webkit-scrollbar-thumb{background:#ffffff14;border-radius:4px}*::-webkit-scrollbar-thumb:hover{background:#ffffff29}@keyframes fadeUp{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:none}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}@keyframes dealIn{0%{opacity:0;transform:translate(40px,-40px) rotate(-8deg) scale(.92)}to{opacity:1;transform:none}}@keyframes flip{0%{transform:rotateY(180deg)}to{transform:rotateY(0)}}@media (prefers-reduced-motion: reduce){*,*:before,*:after{animation-duration:.001ms!important;animation-iteration-count:1!important;transition-duration:.001ms!important;scroll-behavior:auto!important}}.streak{display:flex;align-items:center;gap:8px;font-family:var(--font-mono)}.streak-val{font-size:18px;color:var(--ink-0)}.streak-best{font-size:11px;color:var(--ink-3)}.hint-toggles{display:flex;gap:14px}.hint-toggles .toggle{display:inline-flex;align-items:center;gap:6px;font-size:12px;color:var(--ink-2);cursor:pointer;user-select:none}.hint-toggles .toggle input[type=checkbox]{accent-color:var(--info);cursor:pointer}.hand-counter{display:flex;align-items:center;gap:6px;font-family:var(--font-mono);font-size:12px;color:var(--ink-2)}.hand-counter .num{color:var(--ink-0);font-size:14px}.insurance-prompt{display:flex;align-items:center;gap:12px;padding:10px 14px;border-radius:10px;background:#0006;border:1px solid var(--line);color:var(--ink-1);font-size:13px}.insurance-prompt .btn{font-size:12px;padding:6px 12px}.coach-banner{padding:10px 16px;border-radius:10px;font-size:13px;background:#00000080;border:1px solid var(--line);max-width:540px;text-align:center;color:var(--ink-1)}.coach-banner.coach-bad{border-color:#ff646466;color:var(--bad)}.coach-banner.coach-good{border-color:#78c88266;color:var(--good)}.coach-banner.coach-neutral{border-color:var(--line-2);color:var(--ink-1)}.result-banner{display:flex;flex-direction:column;align-items:center;gap:12px;padding:22px 36px;border-radius:14px;background:#00000080;border:1px solid var(--line);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px)}.result-banner.result-good{border-color:#78c88280}.result-banner.result-bad{border-color:#dc646480}.result-text{font-size:28px;letter-spacing:-.02em;color:var(--ink-0)}.kbd{display:inline-block;padding:1px 6px;margin-left:6px;border:1px solid var(--line-2);border-radius:4px;font-family:var(--font-mono);font-size:10px;color:var(--ink-2);background:#ffffff0a}.btn{appearance:none;border:1px solid var(--line-2);background:#ffffff0a;color:var(--ink-0);padding:8px 16px;border-radius:10px;font-family:var(--font-body);font-size:13px;font-weight:500;cursor:pointer;transition:background .16s,border-color .16s}.btn:hover:not(:disabled){background:#ffffff14}.btn:focus-visible{outline:2px solid var(--info);outline-offset:2px}.btn:disabled{opacity:.4;cursor:not-allowed}.btn-primary{background:var(--ink-0);color:var(--ink-8);border-color:var(--ink-0)}.btn-primary:hover:not(:disabled){background:var(--ink-1)}.btn-ghost{background:transparent}.deal-btn{font-size:14px;padding:10px 22px}.chip-tray{display:flex;align-items:center;gap:10px}.chip-clear{font-size:12px}.eyebrow{font-family:var(--font-mono);font-size:10px;letter-spacing:.18em;text-transform:uppercase;color:var(--ink-3)}.display{font-family:var(--font-display);font-weight:600}.num{font-family:var(--font-mono);font-feature-settings:"tnum"}.hand-result{display:inline-block;padding:1px 6px;border-radius:4px;font-family:var(--font-mono);font-size:10px;letter-spacing:.05em;background:#ffffff0f;color:var(--ink-1)}.hand-result-win,.hand-result-blackjack,.hand-result-charlie{background:#28783c40;color:var(--good)}.hand-result-lose{background:#a03c3c40;color:var(--bad)}.hand-result-push{background:#ffffff0f;color:var(--ink-2)}.hand-result-surrender{background:#ffffff0a;color:var(--ink-3)}@media (prefers-reduced-motion: reduce){.btn,.hand-stack,.result-banner{transition:none;animation:none}}.bjt-heatmap{display:flex;flex-direction:column;gap:12px;--bjt-heatmap-cell: 22px}.bjt-heatmap--compact{--bjt-heatmap-cell: 14px;gap:8px}.bjt-heatmap__head,.bjt-heatmap__row{display:grid;grid-template-columns:36px repeat(10,var(--bjt-heatmap-cell));gap:2px;align-items:center}.bjt-heatmap__colhead,.bjt-heatmap__rowhead{font-family:var(--font-mono);font-size:10px;color:var(--ink-2);text-align:center;font-feature-settings:"tnum"}.bjt-heatmap__rowhead{text-align:right;padding-right:4px}.bjt-heatmap__section{display:flex;flex-direction:column;gap:2px;padding-top:6px;border-top:1px solid var(--line)}.bjt-heatmap__section:first-of-type{border-top:0;padding-top:0}.bjt-heatmap__sectiontitle{padding:0 0 4px 40px;color:var(--ink-3)}.bjt-heatmap__row .cell-pill{width:var(--bjt-heatmap-cell);height:var(--bjt-heatmap-cell)}.heatmap-cell-btn{appearance:none;margin:0;padding:0;border:0;background:transparent;cursor:pointer;border-radius:3px;display:inline-flex;align-items:stretch}.heatmap-cell-btn:hover .cell-pill{outline:1px solid var(--line-3);outline-offset:1px}.heatmap-cell-btn:focus-visible{outline:2px solid var(--info);outline-offset:2px}.drill-felt-title{display:flex;justify-content:space-between;align-items:flex-start}.drill-felt-title .eyebrow{color:var(--ink-3)}.drill-felt-title .display{color:var(--ink-0);font-family:var(--font-display);font-size:18px;margin-top:2px}.drill-prompt{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:28px}.drill-dealer,.drill-player{display:flex;flex-direction:column;align-items:center;gap:10px}.drill-vs{font-family:var(--font-mono);font-size:11px;color:var(--ink-3);letter-spacing:.16em}.drill-hand-info{font-size:12px;color:var(--ink-2)}.drill-hand-info .num{color:var(--ink-0);font-weight:600}.drill-explanation{margin-top:12px;padding:12px 16px;border-radius:12px;background:#ff50500f;border:1px solid rgba(255,80,80,.18);color:var(--ink-1);font-size:13px;line-height:1.45;max-width:540px}.drill-explanation__title{font-family:var(--font-mono);font-size:11px;letter-spacing:.1em;color:var(--bad, #d4756c);text-transform:uppercase;margin-bottom:6px}.drill-explanation__hint{margin-top:8px;font-size:11px;color:var(--ink-3)}.drill-correct-banner{display:inline-flex;align-items:center;gap:8px;padding:6px 14px;border-radius:999px;background:#50c8781a;border:1px solid rgba(80,200,120,.28);color:var(--good, #5fc685);font-size:12px;font-family:var(--font-mono);letter-spacing:.06em}.drill-filters{display:grid;grid-template-columns:repeat(2,1fr);gap:6px}.drill-filter{appearance:none;background:#ffffff08;color:var(--ink-1);border:1px solid var(--line);border-radius:8px;padding:8px 10px;font-size:12px;font-family:var(--font-mono);cursor:pointer;transition:background .12s}.drill-filter:hover:not(:disabled){background:#ffffff0f}.drill-filter[aria-pressed=true],.drill-filter-on{background:#50c87824;border-color:#50c8786b;color:var(--ink-0)}.drill-filter:disabled{opacity:.5;cursor:not-allowed}.drill-filter-help{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.drill-distribution{display:inline-flex;border:1px solid var(--line);border-radius:8px;overflow:hidden}.drill-distribution__btn{appearance:none;background:transparent;color:var(--ink-2);border:0;padding:6px 14px;font-size:12px;font-family:var(--font-mono);cursor:pointer}.drill-distribution__btn[aria-pressed=true]{background:#50c87824;color:var(--ink-0)}.drill-streak{background:#ffffff08;border:1px solid var(--line);border-radius:12px;padding:14px 16px;display:flex;flex-direction:column;gap:6px}.drill-streak-val{font-size:28px;font-family:var(--font-display);color:var(--ink-0);line-height:1}.drill-streak.is-tier-1{background:#50c8780d}.drill-streak.is-tier-2{background:#50c8781a;border-color:#50c8784d}.drill-streak.is-tier-3{background:#78dcb424;border-color:#78dcb473}.drill-streak.is-tier-4{background:#b4f0dc2e;border-color:#b4f0dc8c;color:var(--ink-0)}.drill-streak-best{font-family:var(--font-mono);font-size:11px;color:var(--ink-3)}.drill-sb-section{border-top:1px solid var(--line);padding-top:12px;display:flex;flex-direction:column;gap:8px}.drill-sb-section:first-of-type{border-top:0;padding-top:0}.drill-sb-row{display:flex;justify-content:space-between;font-size:12px;color:var(--ink-2)}.drill-sb-row .num{color:var(--ink-0);font-weight:600}.drill-action-flag .action-btn{outline:2px solid var(--good, #5fc685);outline-offset:2px}.drill-action-taken[data-attr=taken] .action-btn{outline:2px dashed var(--bad, #d4756c);outline-offset:2px}@media (prefers-reduced-motion: reduce){.drill-action-flag .action-btn,.drill-action-taken .action-btn{transition:none}}.count-submode-nav{display:flex;gap:8px;padding:14px 24px;border-bottom:1px solid var(--line);overflow-x:auto}.count-submode-tab{appearance:none;background:transparent;border:1px solid var(--line-2);border-radius:10px;padding:10px 14px;color:var(--ink-1);cursor:pointer;display:flex;flex-direction:column;gap:2px;min-width:140px;transition:background .16s,border-color .16s}.count-submode-tab:hover{background:#ffffff0a}.count-submode-tab:focus-visible{outline:2px solid var(--info);outline-offset:2px}.count-submode-tab-on{background:#ffffff0f;border-color:var(--ink-1);color:var(--ink-0)}.count-submode-label{font-size:13px;font-weight:600}.count-submode-description{font-size:11px;color:var(--ink-3)}.count-system-picker,.count-tc-rounding{display:flex;align-items:center;gap:10px}.count-system-picker .seg,.count-tc-rounding .seg{display:inline-flex;border:1px solid var(--line-2);border-radius:10px;overflow:hidden}.count-system-picker .seg-opt,.count-tc-rounding .seg-opt{appearance:none;background:transparent;border:none;border-right:1px solid var(--line-2);padding:6px 10px;font-size:12px;color:var(--ink-2);cursor:pointer}.count-system-picker .seg-opt:last-child,.count-tc-rounding .seg-opt:last-child{border-right:none}.count-system-picker .seg-opt-on,.count-tc-rounding .seg-opt-on{background:#ffffff14;color:var(--ink-0)}.count-system-picker .seg-opt:focus-visible,.count-tc-rounding .seg-opt:focus-visible{outline:2px solid var(--info);outline-offset:2px}.count-drill{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:24px;padding:24px;width:100%;max-width:720px;margin:0 auto}.count-idle{display:flex;flex-direction:column;align-items:center;gap:16px;padding:24px 36px;background:#ffffff08;border:1px solid var(--line);border-radius:16px;text-align:center;max-width:520px}.count-idle-text{margin:0;font-size:14px;color:var(--ink-2);line-height:1.5}.count-pair-area{gap:24px}.count-card-empty{color:var(--ink-3);font-size:28px}.count-input-form{display:flex;flex-direction:column;align-items:center;gap:14px;padding:20px 28px;background:#0006;border:1px solid var(--line);border-radius:14px}.count-input-form-final{flex-direction:row;flex-wrap:wrap;align-items:flex-end}.count-input-label{display:flex;flex-direction:column;align-items:flex-start;gap:6px}.count-input{width:200px;padding:10px 12px;border:1px solid var(--line-2);border-radius:10px;background:#ffffff0a;color:var(--ink-0);font-size:22px;text-align:center}.count-input:focus-visible{outline:2px solid var(--info);outline-offset:2px}.count-feedback{display:flex;flex-direction:column;align-items:center;gap:14px;padding:20px 28px;background:#0006;border:1px solid var(--line);border-radius:14px;max-width:540px}.count-feedback-correct{display:flex;flex-direction:column;align-items:center;gap:4px;color:var(--good)}.count-feedback-wrong{display:flex;flex-direction:column;align-items:center;gap:6px;color:var(--bad)}.count-feedback-value{font-size:36px}.count-feedback-note{margin:0;font-size:12px;color:var(--ink-3);text-align:center}.count-tc-question{display:flex;flex-direction:column;align-items:center;gap:18px}.count-tc-row{display:flex;gap:40px}.count-tc-block{display:flex;flex-direction:column;align-items:center;gap:4px}.count-tc-value{font-size:48px}.count-tc-snap-note{font-size:11px;color:var(--info)}.count-tc-note{font-size:12px;color:var(--ink-3)}.count-shoe-meter{display:flex;align-items:center;gap:12px;font-size:12px;color:var(--ink-2);width:100%;max-width:480px}.count-shoe-bar{flex:1;height:6px;background:#ffffff0f;border-radius:3px;overflow:hidden}.count-shoe-bar-fill{height:100%;background:var(--good);transition:width .16s}.count-pause-row{display:flex;gap:10px}.wrong-count-breakdown{display:flex;flex-direction:column;align-items:center;gap:10px;width:100%}.wrong-count-summary{display:flex;flex-direction:column;align-items:center;gap:4px;color:var(--bad)}.wrong-count-numbers{font-size:18px;color:var(--ink-0)}.wrong-count-eyebrow{margin-top:6px}.wrong-count-list{display:flex;flex-wrap:wrap;gap:8px;list-style:none;margin:0;padding:0;justify-content:center}.wrong-count-item{display:flex;flex-direction:column;align-items:center;gap:2px;padding:4px}.wrong-count-tag{font-size:11px;color:var(--ink-3)}.wrong-count-tag-pos{color:var(--good)}.wrong-count-tag-neg{color:var(--bad)}.wrong-count-tally{font-size:10px;color:var(--ink-2)}.count-controls .count-controls-row{display:flex;align-items:center;gap:18px;flex-wrap:wrap}.count-controls .count-controls-stat{display:flex;flex-direction:column;align-items:flex-end}.visually-hidden{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}@media (prefers-reduced-motion: reduce){.count-shoe-bar-fill,.count-submode-tab{transition:none}}.bjt-summary{position:fixed;inset:0;z-index:60;background:#000000c7;display:flex;align-items:stretch;justify-content:center;overflow-y:auto;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px)}.bjt-summary__panel{width:min(1100px,100%);margin:auto;padding:40px 48px 32px;background:var(--panel);border:1px solid var(--line);border-radius:var(--r-4);display:flex;flex-direction:column;gap:24px;color:var(--ink-0)}.bjt-summary__head{display:flex;align-items:flex-start;justify-content:space-between;gap:24px}.bjt-summary__head-text{display:flex;flex-direction:column;gap:4px}.bjt-summary__eyebrow{margin:0}.bjt-summary__title{margin:0;font-size:clamp(28px,4vw,44px);letter-spacing:-.03em;color:var(--ink-0)}.bjt-summary__sub{margin:0;color:var(--ink-2);font-family:var(--font-mono);font-size:12px;letter-spacing:.02em}.bjt-summary__close{align-self:flex-start}.bjt-summary__grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:16px}.bjt-summary__stat{background:var(--panel-2);border:1px solid var(--line);border-radius:var(--r-3);padding:18px 20px;display:flex;flex-direction:column;gap:6px}.bjt-summary__stat-label{margin:0}.bjt-summary__stat-val{margin:0;font-size:36px;line-height:1;letter-spacing:-.04em;color:var(--ink-0)}.bjt-summary__stat-val.pos{color:var(--good)}.bjt-summary__stat-val.neg{color:var(--bad)}.bjt-summary__stat-unit{font-size:18px;margin-left:2px;color:var(--ink-3)}.bjt-summary__stat-sub{margin:0;color:var(--ink-3);font-size:11.5px}.bjt-summary__cols{display:grid;grid-template-columns:minmax(0,1fr) minmax(0,1fr);gap:24px}@media (max-width: 880px){.bjt-summary__cols{grid-template-columns:1fr}.bjt-summary__panel{padding:24px}}.bjt-summary__col-right{display:flex;flex-direction:column;gap:24px}.bjt-summary__card{background:var(--panel-2);border:1px solid var(--line);border-radius:var(--r-3);padding:20px;display:flex;flex-direction:column;gap:14px}.bjt-summary__card-title{margin:0;font-size:13px;font-weight:600;color:var(--ink-1);letter-spacing:-.005em}.bjt-summary__empty{margin:0;padding:18px 0;color:var(--ink-3);font-size:13px}.bjt-summary__wrong-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:10px}.bjt-summary__wrong-item{display:grid;grid-template-columns:auto 1fr auto;align-items:center;gap:14px;padding:10px 12px;border:1px solid var(--line);border-radius:10px;background:#0000002e}.bjt-summary__wrong-cards{display:flex;align-items:center;gap:4px}.bjt-summary__wrong-vs{margin:0 4px;font-family:var(--font-mono);font-size:10px;color:var(--ink-3)}.bjt-summary__wrong-text{display:flex;flex-direction:column;gap:2px;min-width:0}.bjt-summary__wrong-explain{margin:0;font-size:13px;color:var(--ink-1)}.bjt-summary__wrong-action{margin:0;display:flex;align-items:center;gap:8px;font-family:var(--font-mono);font-size:11px;color:var(--ink-2)}.bjt-summary__wrong-taken{color:var(--bad)}.bjt-summary__wrong-optimal{color:var(--good)}.bjt-summary__wrong-arrow{color:var(--ink-3)}.bjt-summary__wrong-drill{white-space:nowrap}.bjt-summary__trend{display:flex;align-items:flex-end;gap:4px;height:80px;padding:8px 0;border-bottom:1px solid var(--line)}.bjt-summary__trend-bar{flex:1;min-width:6px;background:var(--ink-4);border-radius:2px 2px 0 0;transform-origin:bottom;animation:trendRise .36s var(--ease-out) backwards}.bjt-summary__trend-bar[data-current=true]{background:var(--ink-0)}.bjt-summary__trend-axis{display:flex;justify-content:space-between;font-family:var(--font-mono);font-size:10px;color:var(--ink-3)}@keyframes trendRise{0%{transform:scaleY(0)}to{transform:scaleY(1)}}@media (prefers-reduced-motion: reduce){.bjt-summary__trend-bar{animation:none}}.bjt-summary__actions{display:flex;justify-content:flex-end;gap:12px;padding-top:8px;border-top:1px solid var(--line)}.imprint{display:flex;flex-direction:column;gap:18px;max-width:640px;padding:4px 4px 12px}.imprint__heading{margin:0 0 4px;font-size:clamp(24px,3.5vw,36px);letter-spacing:-.02em;color:var(--ink-0)}.imprint__intro{margin:0;color:var(--ink-2);font-size:13px;line-height:1.5}.imprint__section{display:flex;flex-direction:column;gap:4px;padding-top:12px;border-top:1px solid var(--line)}.imprint__section:first-of-type{border-top:0;padding-top:0}.imprint__h3{margin:0;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.16em;color:var(--ink-3)}.imprint__address{margin:0;font-style:normal;color:var(--ink-1);font-size:14px;line-height:1.6}.imprint__section p{margin:0;color:var(--ink-1);font-size:13.5px;line-height:1.55}.imprint__link{color:var(--info);text-decoration:none;border-bottom:1px solid currentColor;transition:color .16s}.imprint__link:hover,.imprint__link:focus-visible{color:var(--ink-0)}.imprint__footer{display:flex;justify-content:flex-end;padding-top:16px;border-top:1px solid var(--line)}.app-footer{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:10px 24px;border-top:1px solid var(--line);background:#00000040;font-size:11px;color:var(--ink-3);font-family:var(--font-mono)}.app-footer__brand{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.app-footer__nav{display:flex;gap:12px}.app-footer__link{appearance:none;background:transparent;border:0;padding:4px 8px;margin:0;cursor:pointer;color:var(--ink-2);font-family:var(--font-mono);font-size:11px;border-radius:4px;transition:color .16s,background .16s}.app-footer__link:hover,.app-footer__link:focus-visible{color:var(--ink-0);background:#ffffff0f;outline:none}@media (max-width: 600px){.app-footer{flex-direction:column;align-items:flex-start;gap:4px;padding:10px 14px}}
