: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}*{box-sizing:border-box}html,body{margin:0;padding:0}button{font-family:inherit;cursor:default}@media (prefers-reduced-motion: reduce){*{animation:none!important;transition:none!important}}.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:-28px}.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)}.hand-result{font-family:var(--font-mono);font-size:9.5px;letter-spacing:.1em;padding:2px 6px;border-radius:3px;border:1px solid var(--line-2)}.hand-result-win,.hand-result-bj{background:#2d8c4b33;color:var(--good);border-color:var(--good)}.hand-result-lose{background:#b43c3c2e;color:var(--bad);border-color:var(--bad)}.hand-result-push{color:var(--ink-2)}.hand-result-surrender{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}.chip-tray-btn{appearance:none;border:0;background:transparent;padding:0;cursor:default}.chip-clear{font-size:11px;color:var(--ink-3);margin-left:8px}.deal-btn{font-size:14px;padding:10px 20px;display:inline-flex;align-items:center;gap:10px}.result-banner{display:flex;align-items:center;gap:18px;padding:14px 20px;background:#0006;border-radius:12px;border:1px solid var(--line-2)}.result-text{font-size:22px}.result-good .result-text{color:var(--good)}.result-bad .result-text{color:var(--bad)}.result-neutral .result-text{color:var(--ink-1)}.coach-banner{padding:8px 14px;border-radius:8px;font-size:12.5px;background:#00000080;border:1px solid var(--line-2)}.coach-hint{border-color:var(--act-hit);color:var(--ink-0)}.coach-block{border-color:var(--bad);color:var(--ink-0)}.insurance-prompt{display:flex;align-items:center;gap:10px;padding:8px 12px;background:#ffa50014;border:1px solid var(--act-insurance);border-radius:10px;font-size:12.5px}.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}.streak{display:flex;flex-direction:column;gap:2px;align-items:flex-start}.streak-val{font-size:18px;font-weight:600;line-height:1}.streak-best{font-size:10px;color:var(--ink-3);font-family:var(--font-mono)}.hand-counter{display:flex;flex-direction:column;align-items:flex-end;gap:2px}.hand-counter .num{font-size:16px;font-weight:600}.toggle{display:inline-flex;align-items:center;gap:6px;font-size:12px;color:var(--ink-2);cursor:default}.toggle input{accent-color:var(--ink-0);width:14px;height:14px}.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-dealer .eyebrow,.drill-player .eyebrow{color:#ffffff8c}.drill-vs{font-family:var(--font-mono);color:var(--ink-3);font-size:11px;letter-spacing:.2em}.drill-hand-info{font-size:13px;color:var(--ink-2)}.drill-actions{padding:18px 24px;border-top:1px solid var(--line);display:flex;gap:8px;justify-content:center;background:#0000004d}.drill-feedback{position:absolute;left:0;right:0;bottom:80px;display:flex;justify-content:center;pointer-events:none}.feedback-card{pointer-events:auto;padding:14px 20px;max-width:540px;background:#14161af2;border:1px solid var(--line-2);border-radius:12px;display:flex;flex-direction:column;gap:6px;animation:fadeUp .2s var(--ease-out)}.feedback-correct{border-color:var(--good)}.feedback-wrong{border-color:var(--bad)}.feedback-title{display:flex;align-items:center;gap:8px;font-size:13px;font-weight:600}.feedback-title.t-correct{color:var(--good)}.feedback-title.t-wrong{color:var(--bad)}.feedback-explain{color:var(--ink-1);font-size:12.5px;line-height:1.5}.drill-sidebar{display:flex;flex-direction:column;gap:16px;background:#ffffff05;border:1px solid var(--line);border-radius:16px;padding:20px;overflow-y:auto}.drill-sb-section{display:flex;flex-direction:column;gap:10px}.drill-sb-row{display:flex;justify-content:space-between;align-items:baseline;padding:6px 0;border-bottom:1px solid var(--line)}.drill-sb-row:last-child{border:0}.drill-sb-row span:first-child{color:var(--ink-2);font-size:12px}.drill-sb-row .num{color:var(--ink-0);font-size:14px;font-weight:600}.drill-filters{display:flex;flex-wrap:wrap;gap:6px}.drill-filter{appearance:none;padding:5px 10px;background:#ffffff0a;border:1px solid var(--line);border-radius:999px;font-size:11px;color:var(--ink-2);cursor:default;font-family:inherit}.drill-filter:hover{background:#ffffff14}.drill-filter-on{background:var(--ink-0);color:var(--ink-8);border-color:var(--ink-0)}.drill-filter:disabled{opacity:.4}.drill-streak{display:flex;flex-direction:column;gap:6px;padding:14px;background:linear-gradient(135deg,#ffffff0a,#ffffff05);border:1px solid var(--line);border-radius:12px}.drill-streak-val{font-size:32px;font-weight:600;line-height:1;letter-spacing:-.02em;font-family:var(--font-display)}.drill-streak-bar{height:4px;background:#ffffff0f;border-radius:2px;overflow:hidden}.drill-streak-bar-fill{height:100%;background:var(--good);transition:width .2s}.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-display{position:absolute;top:32px;left:50%;transform:translate(-50%);display:flex;flex-direction:column;align-items:center;gap:4px}.count-display-val{font-family:var(--font-mono);font-size:96px;font-weight:300;letter-spacing:-.04em;line-height:1;color:var(--ink-0)}.count-display-val.dim{color:var(--ink-4)}.count-shoe-meter{position:absolute;top:60px;right:60px;display:flex;flex-direction:column;align-items:flex-end;gap:4px;font-family:var(--font-mono);font-size:11px;color:var(--ink-3)}.count-shoe-bar{width:160px;height:3px;background:#ffffff0f;border-radius:2px;overflow:hidden}.count-shoe-bar-fill{height:100%;background:var(--ink-0)}.count-controls{padding:18px 32px;border-top:1px solid var(--line);display:flex;align-items:center;justify-content:space-between}.count-mode-tabs{display:flex;gap:4px;padding:3px;background:#ffffff08;border:1px solid var(--line);border-radius:8px}.count-mode-tab{appearance:none;padding:6px 14px;border:0;background:transparent;font-size:12px;color:var(--ink-2);border-radius:5px;cursor:default;font-family:inherit}.count-mode-tab-on{background:var(--ink-7);color:var(--ink-0)}.count-speed{display:flex;align-items:center;gap:16px}.count-input-prompt{display:flex;flex-direction:column;align-items:center;gap:16px;padding:28px;background:#00000080;border:1px solid var(--line-2);border-radius:16px}.count-input{width:160px;padding:12px;font-family:var(--font-mono);font-size:32px;text-align:center;background:#ffffff0a;border:1px solid var(--line-2);border-radius:8px;color:var(--ink-0);outline:none}.count-input:focus{border-color:var(--ink-1)}.summary{position:fixed;inset:0;z-index:150;background:var(--ink-8);overflow-y:auto}.summary-inner{max-width:1200px;margin:0 auto;padding:56px 48px}.summary-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:40px}.summary-eyebrow{font-family:var(--font-mono);font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--ink-3)}.summary-title{font-family:var(--font-display);font-size:44px;letter-spacing:-.025em;margin:8px 0 0;line-height:1.05}.summary-sub{color:var(--ink-2);font-size:14px;margin-top:6px}.summary-grid{display:grid;grid-template-columns:1fr 1fr 1fr 1fr;gap:1px;background:var(--line);margin-bottom:32px;border:1px solid var(--line);border-radius:14px;overflow:hidden}.summary-stat{padding:24px;background:var(--ink-8)}.summary-stat-label{font-family:var(--font-mono);font-size:10.5px;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-3)}.summary-stat-val{font-family:var(--font-display);font-size:40px;font-weight:500;line-height:1;letter-spacing:-.03em;margin-top:12px}.summary-stat-sub{font-size:12px;color:var(--ink-2);margin-top:6px;font-family:var(--font-mono)}.summary-stat .pos{color:var(--good)}.summary-stat .neg{color:var(--bad)}.summary-cols{display:grid;grid-template-columns:1.4fr 1fr;gap:24px}.summary-card{padding:28px;background:#ffffff05;border:1px solid var(--line);border-radius:14px}.summary-card-title{font-family:var(--font-display);font-size:18px;margin:0 0 18px;letter-spacing:-.01em}.wrong-list{display:flex;flex-direction:column;gap:10px}.wrong-item{display:grid;grid-template-columns:auto 1fr auto;gap:14px;align-items:center;padding:12px;background:#ffffff05;border:1px solid var(--line);border-radius:10px}.wrong-item-cards{display:flex;gap:4px}.wrong-item-cards .card{box-shadow:0 1px 4px #0006}.wrong-item-text{display:flex;flex-direction:column;gap:2px;min-width:0}.wrong-item-line1{font-size:12.5px;color:var(--ink-1)}.wrong-item-line2{font-size:11.5px;color:var(--ink-3)}.wrong-item-line2 .right{color:var(--good)}.wrong-item-line2 .wrong{color:var(--bad);text-decoration:line-through;opacity:.7;margin-right:8px}.wrong-item-drill{appearance:none;padding:6px 10px;background:#ffffff0a;border:1px solid var(--line-2);border-radius:6px;font-size:11px;color:var(--ink-1);white-space:nowrap;cursor:default}.trend-chart{display:flex;align-items:flex-end;gap:4px;height:120px;padding:0 0 4px}.trend-bar{flex:1;min-width:6px;background:var(--ink-5);border-radius:2px 2px 0 0;transition:height .2s;position:relative}.trend-bar.cur{background:var(--ink-0)}.trend-axis{display:flex;justify-content:space-between;font-family:var(--font-mono);font-size:10px;color:var(--ink-3);margin-top:6px}.summary-actions{display:flex;gap:10px;justify-content:flex-end;margin-top:28px}*,*: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)}body{background:radial-gradient(ellipse 90% 70% at 50% 35%,#0d281859,#08090b00 60%),var(--bg)}:root{--font-display: "Fraunces", "Newsreader", Georgia, serif;--font-body: "Inter", ui-sans-serif, system-ui, sans-serif;--font-mono: "JetBrains Mono", ui-monospace, "SF Mono", Menlo, monospace;--gold: oklch(.78 .14 80);--gold-glow: oklch(.85 .16 85 / .45);--felt-0: #0a3a26;--felt-1: #0e4a30;--felt-2: #126040;--felt-3: #186e4a;--felt-edge: #041c12}:root[data-theme=charcoal]{--felt-0: #1c1c1f;--felt-1: #232328;--felt-2: #2c2c33;--felt-3: #34343d;--felt-edge: #050506}:root[data-theme=oxblood]{--felt-0: #3a1418;--felt-1: #481b20;--felt-2: #56222a;--felt-3: #642a35;--felt-edge: #1a0608}:root[data-theme=midnight]{--felt-0: #0e1a2e;--felt-1: #122140;--felt-2: #182d52;--felt-3: #1d3a64;--felt-edge: #04080f}.play-felt{background:radial-gradient(ellipse 70% 80% at 50% 40%,var(--felt-3) 0%,var(--felt-2) 35%,var(--felt-1) 65%,var(--felt-0) 88%,var(--felt-edge) 100%)!important;position:relative;margin:16px 22px 8px;border-radius:240px/36px;box-shadow:inset 0 0 0 1px #b88a2a38,inset 0 0 0 6px #00000080,inset 0 0 0 7px #b88a2a1f,inset 0 0 100px #0000008c,0 12px 30px #00000080,0 30px 80px #00000073}.drill-felt{background:radial-gradient(ellipse 75% 85% at 50% 40%,var(--felt-3) 0%,var(--felt-2) 35%,var(--felt-1) 65%,var(--felt-0) 88%,var(--felt-edge) 100%)!important;position:relative;border-radius:18px;margin:0;box-shadow:inset 0 0 0 1px #b88a2a33,inset 0 0 0 5px #00000073,inset 0 0 0 6px #b88a2a1a,inset 0 0 80px #00000080}.count-stage{background:radial-gradient(ellipse 60% 80% at 50% 50%,var(--felt-2) 0%,var(--felt-1) 50%,var(--felt-0) 80%,var(--felt-edge) 100%)!important;position:relative;margin:14px 22px 0;border-radius:24px;box-shadow:inset 0 0 0 1px #b88a2a2e,inset 0 0 80px #00000080,0 12px 30px #00000080}.drill-stage{min-height:0!important;height:100%;overflow:hidden!important}.drill-felt{min-height:0!important;overflow:hidden!important}.drill-actions{background:linear-gradient(180deg,#0000008c,#000000b3)!important;-webkit-backdrop-filter:blur(16px) saturate(140%);backdrop-filter:blur(16px) saturate(140%);border-top:1px solid rgba(184,138,42,.2)!important;padding:18px 28px!important;display:flex;gap:10px;justify-content:center;align-items:center;flex-wrap:wrap}.drill-action{display:inline-flex}.count-mode{display:flex!important;flex-direction:column!important}.count-controls{background:linear-gradient(180deg,#0009,#000000c7)!important;-webkit-backdrop-filter:blur(16px) saturate(140%);backdrop-filter:blur(16px) saturate(140%);border-top:1px solid rgba(184,138,42,.18)!important;padding:18px 32px!important;display:flex;gap:24px;flex-wrap:wrap;align-items:center;justify-content:space-between;font-family:var(--font-mono);font-size:12px}.count-submodes,.count-submode-nav{padding:14px 22px;display:flex;gap:10px;background:linear-gradient(180deg,rgba(0,0,0,.4),transparent);border-bottom:1px solid rgba(255,255,255,.04)}.count-submodes button,.count-submode-nav button{background:#ffffff0a;border:1px solid rgba(255,255,255,.08);color:#ffffffb3;padding:10px 18px;border-radius:11px;font-family:var(--font-display);font-size:14px;font-weight:600;cursor:pointer;transition:all .18s var(--ease-out)}.count-submodes button:hover,.count-submode-nav button:hover{background:#ffffff14;color:var(--ink-0)}.count-submodes button[aria-current=true],.count-submodes button.is-active,.count-submode-nav button[aria-current=true],.count-submode-nav button[aria-selected=true],.count-submode-nav button.is-active,.count-submode-tab-on{background:#b88a2a26!important;border-color:#b88a2a73!important;color:var(--gold)!important;box-shadow:0 0 24px #b88a2a2e!important}.count-submode-label{display:block;font-family:var(--font-display);font-weight:600;font-size:14px;letter-spacing:-.005em}.count-submode-description{display:block;font-family:var(--font-mono);font-size:10px;letter-spacing:.06em;color:#fff6;margin-top:3px;text-transform:uppercase}.count-submode-tab-on .count-submode-description{color:#b88a2ab3}.mode-tab[aria-selected=true],[data-mode-active=true]{color:var(--gold)!important;background:#b88a2a14!important;border-color:#b88a2a38!important}.filter-btn[aria-pressed=true],.filter-btn.is-active,.distribution-toggle [aria-pressed=true],.distribution-toggle .is-active,.system-picker [aria-pressed=true],.system-picker .is-active,.count-controls [data-active=true]{background:#b88a2a26!important;border-color:#b88a2a66!important;color:var(--gold)!important}.play-felt:after,.drill-felt:after,.count-stage:after{content:"";position:absolute;inset:0;pointer-events:none;background-image:radial-gradient(circle at 20% 30%,rgba(255,255,255,.015) 1px,transparent 1px),radial-gradient(circle at 80% 70%,rgba(255,255,255,.012) 1px,transparent 1px),radial-gradient(circle at 60% 20%,rgba(255,255,255,.01) 1px,transparent 1px);background-size:180px 180px,220px 220px,300px 300px;opacity:.6;z-index:1}.play-felt:before{border:1px solid rgba(184,138,42,.18)!important;box-shadow:inset 0 0 0 6px #00000040,inset 0 0 0 7px #b88a2a14,inset 0 0 80px #00000080}.dealer-zone,.player-zone,.play-center,.drill-prompt,.drill-felt-title,.count-card-area,.hands-row{z-index:2}h1,h2,.display,.bjt-summary__title,.bet-amount,.result-text,.count-display{font-family:var(--font-display);font-feature-settings:"ss01" on,"cv11" on;letter-spacing:-.025em;font-weight:600}.bet-amount{font-size:56px;background:linear-gradient(180deg,var(--ink-0) 0%,var(--gold) 100%);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;filter:drop-shadow(0 1px 0 rgba(0,0,0,.5))}.eyebrow,.zone-label{letter-spacing:.22em;font-size:9.5px;color:#fff6}.chip{position:relative;border-radius:50%;display:flex!important;align-items:center;justify-content:center;font-family:var(--font-mono);font-weight:700;cursor:pointer;isolation:isolate;box-shadow:inset 0 0 0 2px #ffffffd9,inset 0 0 0 4px var(--chip-color, currentColor),inset 0 0 0 14px #ffffffd9,inset 0 0 0 16px var(--chip-color, currentColor),0 1px 2px #0009,0 6px 14px #00000073,0 0 0 1px #0006;transition:transform .2s var(--ease-out),box-shadow .2s var(--ease-out)}.chip[data-chip="5"]{--chip-color: #c43a3a;background:#c43a3a}.chip[data-chip="25"]{--chip-color: #1f7a4a;background:#1f7a4a}.chip[data-chip="100"]{--chip-color: #1a1d22;background:#1a1d22}.chip[data-chip="500"]{--chip-color: #6b3aa6;background:#6b3aa6}.chip[data-chip="1000"]{--chip-color: #b88a2a;background:#b88a2a}.chip:before{content:"";position:absolute;inset:5px;border-radius:50%;background:repeating-conic-gradient(from 0deg,var(--chip-color) 0deg 30deg,rgba(255,255,255,.85) 30deg 38deg);z-index:-1;filter:blur(.5px);opacity:.55}.chip:hover{transform:translateY(-3px) scale(1.04);box-shadow:inset 0 0 0 2px #fffffff2,inset 0 0 0 4px var(--chip-color, currentColor),inset 0 0 0 14px #fffffff2,inset 0 0 0 16px var(--chip-color, currentColor),0 2px 4px #0009,0 12px 26px #0000008c,0 0 0 1px #00000080}.chip__value{position:relative;z-index:2;color:#fffffff5;font-size:13px;letter-spacing:.02em;text-shadow:0 1px 2px rgba(0,0,0,.6)}.chip[data-chip="1"] .chip__value,.chip[data-chip="1000"] .chip__value{color:#140e00eb;text-shadow:0 1px 1px rgba(255,255,255,.3)}.card{border-radius:10px;box-shadow:0 1px 1px #00000040,0 2px 4px #00000059,0 8px 18px #00000073,0 0 0 1px #0000004d;background:#fcfaf6;overflow:hidden;transition:transform .22s var(--ease-out)}.card img{border-radius:inherit}.card.card--back{background:radial-gradient(circle at 50% 50%,#193550,#031c30 70%,oklch(.16 .04 240));border:1px solid rgba(184,138,42,.3)}.cards-row>*{transition:transform .24s var(--ease-out)}.hand-active{background:#b88a2a0f!important;box-shadow:0 0 0 1px #b88a2a66,0 0 28px #b88a2a2e,inset 0 0 0 1px #ffffff0a!important;border-radius:14px}.bet-prompt{background:linear-gradient(180deg,#00000073,#0009)!important;border:1px solid rgba(255,255,255,.07)!important;border-top:1px solid rgba(184,138,42,.18)!important;box-shadow:inset 0 1px #ffffff0a,0 12px 40px #0009,0 0 0 1px #0006;padding:32px 48px!important;border-radius:18px!important;-webkit-backdrop-filter:blur(24px) saturate(140%);backdrop-filter:blur(24px) saturate(140%)}.action-btn{font-family:var(--font-display);font-weight:600;letter-spacing:0;text-transform:none;font-size:15px;padding:12px 22px;border-radius:11px;border:1px solid rgba(255,255,255,.08);background:linear-gradient(180deg,#ffffff0a,#ffffff03);color:var(--ink-0);transition:transform .16s var(--ease-out),box-shadow .16s var(--ease-out),background .16s var(--ease-out);position:relative}.action-btn:hover:not(:disabled){transform:translateY(-1px);border-color:var(--act-color, rgba(255, 255, 255, .2));background:linear-gradient(180deg,color-mix(in oklch,var(--act-color, white) 18%,transparent),#ffffff05);box-shadow:0 8px 22px color-mix(in oklch,var(--act-color, black) 25%,transparent)}.action-btn .action-btn__kbd,.action-btn__kbd{font-family:var(--font-mono);font-size:10px;padding:2px 6px;margin-left:8px;border:1px solid rgba(255,255,255,.14);border-radius:4px;color:#ffffff8c;background:#00000040}.action-btn.is-hint{border-color:var(--act-color, var(--gold));box-shadow:0 0 0 1px var(--act-color, var(--gold)),0 0 24px color-mix(in oklch,var(--act-color, var(--gold)) 25%,transparent)}.topbar{background:linear-gradient(180deg,#08090beb,#08090bc7)!important;-webkit-backdrop-filter:blur(20px) saturate(160%)!important;backdrop-filter:blur(20px) saturate(160%)!important;border-bottom:1px solid rgba(184,138,42,.08)!important;box-shadow:0 1px #ffffff05}.topbar__brand-mark,.brand-mark{font-size:22px;background:linear-gradient(135deg,var(--gold),oklch(.66 .13 65));-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;filter:drop-shadow(0 1px 1px rgba(0,0,0,.5))}.topbar__brand-name,.brand-name{font-family:var(--font-display);font-weight:600;font-size:18px;letter-spacing:-.01em;color:var(--ink-0)}.mode-tab,.modes button{font-family:var(--font-mono);font-size:11px;letter-spacing:.16em;text-transform:uppercase;padding:10px 16px;border-radius:9px;border:1px solid transparent;background:transparent;color:#ffffff8c;cursor:pointer;transition:all .18s var(--ease-out)}.mode-tab:hover,.modes button:hover{color:var(--ink-0);background:#ffffff0a}.mode-tab[aria-current=true],.mode-tab.is-active,.modes button[aria-current=true],.modes button.is-active{color:var(--gold);background:#b88a2a14;border-color:#b88a2a38;box-shadow:inset 0 0 0 1px #b88a2a0f}.result-banner{background:linear-gradient(180deg,#0000008c,#000000b3)!important;border:1px solid rgba(255,255,255,.08)!important;border-radius:18px!important;padding:28px 44px!important;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);box-shadow:inset 0 1px #ffffff0d,0 16px 48px #0009}.result-banner.result-good{border-color:#78c88266!important;box-shadow:inset 0 1px #ffffff0d,0 0 0 1px #78c8822e,0 16px 48px #14502866}.result-banner.result-bad{border-color:#dc646466!important}.result-text{font-size:32px!important;letter-spacing:-.025em!important}.streak-val{font-family:var(--font-display)!important;font-size:22px!important;background:linear-gradient(180deg,var(--ink-0),var(--gold));-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}.app-footer{background:linear-gradient(180deg,transparent,rgba(0,0,0,.35))!important;border-top:1px solid rgba(255,255,255,.04)!important}.drill-prompt .card{filter:drop-shadow(0 8px 24px rgba(0,0,0,.5))}@media (prefers-reduced-motion: reduce){.chip,.card,.action-btn,.cards-row>*,.mode-tab{transition:none!important}.chip:hover,.action-btn:hover{transform:none!important}}.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}}
