*,:before,:after{--tw-border-spacing-x: 0;--tw-border-spacing-y: 0;--tw-translate-x: 0;--tw-translate-y: 0;--tw-rotate: 0;--tw-skew-x: 0;--tw-skew-y: 0;--tw-scale-x: 1;--tw-scale-y: 1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness: proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width: 0px;--tw-ring-offset-color: #fff;--tw-ring-color: rgb(59 130 246 / .5);--tw-ring-offset-shadow: 0 0 #0000;--tw-ring-shadow: 0 0 #0000;--tw-shadow: 0 0 #0000;--tw-shadow-colored: 0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }::backdrop{--tw-border-spacing-x: 0;--tw-border-spacing-y: 0;--tw-translate-x: 0;--tw-translate-y: 0;--tw-rotate: 0;--tw-skew-x: 0;--tw-skew-y: 0;--tw-scale-x: 1;--tw-scale-y: 1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness: proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width: 0px;--tw-ring-offset-color: #fff;--tw-ring-color: rgb(59 130 246 / .5);--tw-ring-offset-shadow: 0 0 #0000;--tw-ring-shadow: 0 0 #0000;--tw-shadow: 0 0 #0000;--tw-shadow-colored: 0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }*,:before,:after{box-sizing:border-box;border-width:0;border-style:solid;border-color:#e5e7eb}:before,:after{--tw-content: ""}html,:host{line-height:1.5;-webkit-text-size-adjust:100%;-moz-tab-size:4;-o-tab-size:4;tab-size:4;font-family:ui-sans-serif,system-ui,sans-serif,"Apple Color Emoji","Segoe UI Emoji",Segoe UI Symbol,"Noto Color Emoji";font-feature-settings:normal;font-variation-settings:normal;-webkit-tap-highlight-color:transparent}body{margin:0;line-height:inherit}hr{height:0;color:inherit;border-top-width:1px}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,samp,pre{font-family:JetBrains Mono,monospace;font-feature-settings:normal;font-variation-settings:normal;font-size:1em}small{font-size:80%}sub,sup{font-size:75%;line-height:0;position:relative;vertical-align:baseline}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}button,input,optgroup,select,textarea{font-family:inherit;font-feature-settings:inherit;font-variation-settings:inherit;font-size:100%;font-weight:inherit;line-height:inherit;letter-spacing:inherit;color:inherit;margin:0;padding:0}button,select{text-transform:none}button,input:where([type=button]),input:where([type=reset]),input:where([type=submit]){-webkit-appearance:button;background-color:transparent;background-image:none}:-moz-focusring{outline:auto}:-moz-ui-invalid{box-shadow:none}progress{vertical-align:baseline}::-webkit-inner-spin-button,::-webkit-outer-spin-button{height:auto}[type=search]{-webkit-appearance:textfield;outline-offset:-2px}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-file-upload-button{-webkit-appearance:button;font:inherit}summary{display:list-item}blockquote,dl,dd,h1,h2,h3,h4,h5,h6,hr,figure,p,pre{margin:0}fieldset{margin:0;padding:0}legend{padding:0}ol,ul,menu{list-style:none;margin:0;padding:0}dialog{padding:0}textarea{resize:vertical}input::-moz-placeholder,textarea::-moz-placeholder{opacity:1;color:#9ca3af}input::placeholder,textarea::placeholder{opacity:1;color:#9ca3af}button,[role=button]{cursor:pointer}:disabled{cursor:default}img,svg,video,canvas,audio,iframe,embed,object{display:block;vertical-align:middle}img,video{max-width:100%;height:auto}[hidden]:where(:not([hidden=until-found])){display:none}.visible{visibility:visible}.fixed{position:fixed}.table{display:table}.grid{display:grid}@keyframes dealIn{0%{transform:translateY(-40px) rotate(-5deg);opacity:0}to{transform:translateY(0) rotate(0);opacity:1}}.animate-deal-in{animation:dealIn .3s ease-out forwards}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.animate-fade-in{animation:fadeIn .2s ease-out forwards}.border{border-width:1px}.filter{filter:var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow)}:root{--felt: #1a4731;--felt-dark: #122e20;--felt-light: #245f40;--felt-border: #2d7a53;--gold: #d4a843;--gold-light: #f0c84a;--gold-dark: #b8862a;--card-bg: #fffef9;--card-border: #ccc;--card-red: #c0392b;--card-black: #1a1a1a;--text-primary: #f5f0e8;--text-secondary: #b0a890;--radius: 8px;--radius-lg: 12px;--radius-card: 6px;--shadow-card: 0 2px 8px rgba(0,0,0,.4), 0 1px 2px rgba(0,0,0,.25)}*,*:before,*:after{box-sizing:border-box}html{font-size:16px;-webkit-text-size-adjust:100%}body{margin:0;font-family:Inter,system-ui,sans-serif;background:var(--felt-dark);color:var(--text-primary);height:100vh;height:100dvh;overflow:hidden}.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}.app{display:flex;flex-direction:column;height:100vh;height:100dvh;overflow:hidden}.site-header{background:var(--felt-dark);border-bottom:1px solid var(--felt-border);position:sticky;top:0;z-index:50}.site-header__inner{padding:0 1rem;height:56px;display:flex;align-items:center;gap:.5rem}.header-left{display:flex;align-items:center;gap:.5rem;min-width:0;flex:1}.header-right{display:flex;align-items:center;gap:.4rem;flex-shrink:0}.site-logo{min-width:0;display:flex;align-items:center;gap:.5rem;text-decoration:none;color:var(--gold);font-family:Playfair Display,Georgia,serif;font-size:1.2rem;font-weight:700;letter-spacing:.02em;overflow:hidden}.site-logo__suit{font-size:1.1rem;flex-shrink:0}.site-logo__name{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;min-width:0}.site-logo:hover .site-logo__name{color:var(--gold-light)}.site-nav{display:flex;gap:.25rem;flex-shrink:0}.nav-link{color:var(--text-secondary);text-decoration:none;padding:.4rem .85rem;border-radius:var(--radius);font-weight:500;font-size:.9rem;transition:background .15s,color .15s}.nav-link:hover{background:var(--felt-light);color:var(--text-primary)}.nav-link--active{color:var(--gold);background:#d4a8431f}.site-main{flex:1;min-height:0;overflow-y:auto;overflow-x:hidden;display:flex;flex-direction:column}.btn{display:inline-flex;align-items:center;justify-content:center;gap:.4rem;border:none;border-radius:var(--radius);cursor:pointer;font-weight:600;font-size:.9rem;padding:.55rem 1.2rem;transition:all .15s;min-height:44px;-webkit-user-select:none;-moz-user-select:none;user-select:none}.btn:disabled{opacity:.4;cursor:not-allowed}.btn--primary{background:var(--gold);color:#1a1a1a}.btn--primary:not(:disabled):hover{background:var(--gold-light)}.btn--ghost{background:transparent;color:var(--text-secondary);border:1px solid var(--felt-border)}.btn--ghost:not(:disabled):hover{background:var(--felt-light);color:var(--text-primary)}.btn--ghost.btn--active{color:var(--gold);border-color:var(--gold);background:#d4a8431a}.btn--sm{padding:.4rem .8rem;font-size:.8rem;min-height:36px}.btn--lg{padding:.75rem 2rem;font-size:1rem;min-height:52px}.icon-btn{display:inline-flex;align-items:center;justify-content:center;width:34px;height:34px;flex-shrink:0;border:1px solid rgba(255,255,255,.2);border-radius:var(--radius);background:transparent;color:var(--text-secondary);cursor:pointer;transition:background .15s,color .15s,border-color .15s}.icon-btn:hover{background:var(--felt-light);color:var(--text-primary);border-color:#ffffff59}.icon-btn--active{color:var(--gold);background:#d4a8431f;border-color:#d4a8434d}.playing-card{position:relative;width:64px;height:90px;background:var(--card-bg);border:1px solid var(--card-border);border-radius:var(--radius-card);box-shadow:var(--shadow-card);display:flex;align-items:center;justify-content:center;flex-shrink:0;-webkit-user-select:none;-moz-user-select:none;user-select:none;overflow:hidden}@media (min-width: 640px){.playing-card{width:72px;height:100px}}@media (min-width: 1024px){.playing-card{width:80px;height:112px}}.playing-card--red .card-corner,.playing-card--red .card-center-suit{color:var(--card-red)}.playing-card--black .card-corner,.playing-card--black .card-center-suit{color:var(--card-black)}.card-corner{position:absolute;display:flex;flex-direction:column;align-items:center;line-height:1}.card-corner--tl{top:4px;left:5px}.card-corner--br{bottom:4px;right:5px;transform:rotate(180deg)}.card-rank{font-size:.85rem;font-weight:700}.card-suit{font-size:.7rem}.card-center-suit{font-size:1.6rem;line-height:1}.playing-card--back{background:#1e40af;cursor:default}.card-back-pattern{width:100%;height:100%;background:repeating-linear-gradient(45deg,rgba(255,255,255,.05) 0px,rgba(255,255,255,.05) 2px,transparent 2px,transparent 8px),repeating-linear-gradient(-45deg,rgba(255,255,255,.05) 0px,rgba(255,255,255,.05) 2px,transparent 2px,transparent 8px)}.bj-hand{display:flex;flex-direction:column;align-items:center;gap:.5rem;border-radius:var(--radius-lg);padding:.5rem .75rem;transition:box-shadow .2s,background .2s}.bj-hand--active{box-shadow:0 0 0 2px var(--gold),0 0 20px #d4a84359;background:#d4a8430f}.bj-hand--active .bj-hand__cards{filter:drop-shadow(0 0 10px rgba(212,168,67,.7))}.bj-hand--active .bj-hand__label{color:var(--gold-light)}.bj-hand__turn-badge{font-size:.65rem;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:var(--gold);background:#d4a84326;border:1px solid rgba(212,168,67,.45);border-radius:20px;padding:.15rem .6rem;animation:turn-pulse 1.4s ease-in-out infinite}@keyframes turn-pulse{0%,to{opacity:1;box-shadow:0 0 #d4a84300}50%{opacity:.75;box-shadow:0 0 6px 2px #d4a84340}}.bj-hand__label{font-size:.75rem;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.06em}.bj-hand__bet{color:var(--gold)}.bj-hand__cards{display:flex;gap:-4px}.bj-hand__cards .playing-card+.playing-card{margin-left:-12px}.bj-hand__total{background:#0006;color:var(--text-primary);font-size:.85rem;font-weight:700;padding:.2rem .6rem;border-radius:20px;border:1px solid var(--felt-border)}.bj-hand__total--bust{background:#c0392b66;border-color:#e74c3c;color:#fc8181}.bj-hand__total--soft{color:var(--gold-light)}.result-badge{padding:.25rem .75rem;border-radius:20px;font-size:.8rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em}.badge--win{background:#27ae6040;color:#6ee7b7;border:1px solid #27ae60}.badge--blackjack{background:#d4a8434d;color:var(--gold-light);border:1px solid var(--gold)}.badge--push{background:#64748b4d;color:#94a3b8;border:1px solid #64748b}.badge--lose{background:#c0392b40;color:#fc8181;border:1px solid #c0392b}.badge--surrender{background:#7c3aed40;color:#c4b5fd;border:1px solid #7c3aed}.play-page{display:flex;flex-direction:column;flex:1;min-height:0;overflow:hidden}.toolbar-ruleset-badge{background:#d4a84326;color:var(--gold);border:1px solid rgba(212,168,67,.3);border-radius:20px;padding:.2rem .7rem;font-size:.78rem;font-weight:600}.select-sm{background:var(--felt-dark);color:var(--text-secondary);border:1px solid var(--felt-border);border-radius:var(--radius);padding:.35rem .6rem;font-size:.8rem;cursor:pointer}.select-sm:focus{outline:2px solid var(--gold);outline-offset:1px}.play-layout{display:flex;flex:1;position:relative;min-height:0;overflow:hidden}.chart-sidebar{width:420px;min-width:320px;background:var(--felt-dark);border-left:1px solid var(--felt-border);padding:1rem;overflow-y:auto;position:sticky;top:0;max-height:calc(100dvh - 104px)}.chart-sidebar__header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.chart-sidebar__header h2{margin:0;font-size:1rem;color:var(--gold)}@media (max-width: 900px){.chart-sidebar{position:fixed;bottom:0;left:0;right:0;top:auto;width:100%;max-height:70vh;border:none;border-top:1px solid var(--felt-border);z-index:40}}.game-table{flex:1;display:flex;flex-direction:column;position:relative;overflow:hidden;min-height:0}.table-felt{flex:1;background:radial-gradient(ellipse at 50% 40%,var(--felt-light) 0%,var(--felt) 50%,var(--felt-dark) 100%);box-shadow:inset 0 0 60px #0006;display:flex;flex-direction:column;align-items:center;justify-content:space-between;padding:1.5rem 1rem;min-height:0;gap:.75rem;position:relative;overflow-y:auto}.zone-label{font-size:.7rem;color:#fff6;text-transform:uppercase;letter-spacing:.1em;margin-bottom:.4rem}.dealer-zone,.player-zone{display:flex;flex-direction:column;align-items:center;width:100%}.table-logo{display:flex;flex-direction:column;align-items:center;pointer-events:none;-webkit-user-select:none;-moz-user-select:none;user-select:none}.table-logo__text{font-family:Playfair Display,serif;font-size:1.4rem;color:#d4a84333;letter-spacing:.1em}.table-logo__sub{font-size:.65rem;color:#d4a84326;letter-spacing:.12em;text-transform:uppercase}.player-hands{display:flex;gap:2rem;flex-wrap:wrap;justify-content:center}.empty-hand-placeholder{width:80px;height:112px;border:2px dashed rgba(255,255,255,.1);border-radius:var(--radius-card)}.game-message{background:#000000b3;padding:.5rem 1.5rem;border-radius:20px;font-weight:700;font-size:1.1rem;letter-spacing:.03em;align-self:center;text-align:center}.game-message--win{color:#6ee7b7;border:1px solid #27ae60}.game-message--push{color:#94a3b8;border:1px solid #64748b}.game-message--lose{color:#fc8181;border:1px solid #c0392b}.controls-area{background:#00000040;border-top:1px solid var(--felt-border);padding:.65rem 1rem 1rem;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.6rem;flex-shrink:0}.controls-hint{display:flex;justify-content:center}.complete-actions{display:flex;gap:.75rem;align-items:center;flex-wrap:wrap;justify-content:center}.bust-message{text-align:center}.bust-message p{margin-bottom:.75rem;color:var(--text-secondary)}.bust-message__actions{display:flex;gap:.75rem;align-items:center;justify-content:center}.action-bar{display:flex;gap:.5rem;flex-wrap:wrap;justify-content:center}.action-btn{display:flex;flex-direction:column;align-items:center;gap:.15rem;min-width:72px;min-height:56px;padding:.6rem 1rem;border:1px solid var(--felt-border);border-radius:var(--radius);background:#ffffff0d;color:var(--text-primary);cursor:pointer;font-weight:600;font-size:.9rem;transition:all .15s;-webkit-user-select:none;-moz-user-select:none;user-select:none}.action-btn:not(.action-btn--disabled):hover{background:#ffffff1f;border-color:var(--gold);color:var(--gold)}.action-btn--primary{background:#d4a84326;border-color:var(--gold);color:var(--gold)}.action-btn--danger{border-color:#c0392b80;color:#fc8181}.action-btn--disabled{opacity:.35;cursor:not-allowed}.action-btn__hotkey{font-size:.65rem;color:var(--text-secondary);background:#0000004d;border-radius:3px;padding:0 4px}.bet-panel{display:flex;flex-direction:column;align-items:center;gap:.75rem;width:100%}.bet-panel__chips{display:flex;gap:.6rem;flex-wrap:wrap;justify-content:center}.chip{width:54px;height:54px;border-radius:50%;border:3px dashed rgba(255,255,255,.25);display:flex;align-items:center;justify-content:center;cursor:pointer;font-weight:700;font-size:.75rem;color:#fff;text-shadow:0 1px 2px rgba(0,0,0,.5);box-shadow:0 3px 8px #00000080,inset 0 1px #ffffff26;transition:transform .1s,box-shadow .1s;-webkit-user-select:none;-moz-user-select:none;user-select:none}.chip:not(:disabled):hover{transform:translateY(-2px);box-shadow:0 5px 12px #00000080}.chip:not(:disabled):active{transform:translateY(0)}.chip:disabled{opacity:.35;cursor:not-allowed}.chip-5{background:radial-gradient(circle,#e74c3c,#c0392b)}.chip-25{background:radial-gradient(circle,#3498db,#2980b9)}.chip-100{background:radial-gradient(circle,#2ecc71,#27ae60)}.chip-500{background:radial-gradient(circle,#2c2c2c,#1a1a1a);border-color:var(--gold)}.bet-panel__info{display:flex;gap:2rem;align-items:center}.bet-display,.bankroll-display{display:flex;flex-direction:column;align-items:center;gap:.1rem}.bet-display__label,.bankroll-display__label{font-size:.65rem;text-transform:uppercase;letter-spacing:.1em;color:var(--text-secondary)}.bet-display__amount{font-size:1.4rem;font-weight:700;color:var(--gold)}.bankroll-display__amount{font-size:1.2rem;font-weight:600;color:var(--text-primary)}.bet-panel__actions{display:flex;gap:.75rem}.stats-bar{display:flex;align-items:center;justify-content:center;gap:1rem;padding:.4rem 1rem;background:#0000004d;border-bottom:1px solid var(--felt-border);font-size:.8rem}.stats-bar__item{display:flex;align-items:center;gap:.4rem}.stats-bar__label{color:var(--text-secondary)}.stats-bar__value{font-weight:700;color:var(--text-primary)}.stats-bar__value--gold{color:var(--gold-light)}.stats-bar__value--good{color:#6ee7b7}.stats-bar__value--ok{color:var(--gold-light)}.stats-bar__value--warn{color:#fc8181}.stats-bar__divider{width:1px;height:16px;background:var(--felt-border)}.balance-add-btn{width:18px;height:18px;border-radius:50%;background:#d4a84326;border:1px solid rgba(212,168,67,.4);color:var(--gold);font-size:.8rem;font-weight:700;line-height:1;cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:background .15s}.balance-add-btn:hover{background:#d4a8434d}.balance-add-popup{position:fixed;background:var(--felt-dark);border:1px solid var(--felt-border);border-radius:var(--radius);padding:.45rem .5rem;display:flex;align-items:center;gap:.35rem;z-index:100;box-shadow:0 4px 16px #00000080;white-space:nowrap}.balance-add-popup__label{color:var(--gold);font-weight:700;font-size:.85rem}.balance-add-popup__input{width:80px;background:#ffffff0f;border:1px solid var(--felt-border);border-radius:var(--radius);color:var(--text-primary);font-size:.85rem;padding:.3rem .4rem}.balance-add-popup__input:focus{outline:2px solid var(--gold);outline-offset:1px}.balance-add-popup__input::-webkit-inner-spin-button,.balance-add-popup__input::-webkit-outer-spin-button{-webkit-appearance:none}.strategy-hint{position:relative;display:inline-flex}.strategy-hint__trigger{display:inline-flex;align-items:center;gap:.4rem;padding:.45rem .85rem;border-radius:var(--radius);border:1px solid;font-size:.82rem;font-weight:600;cursor:pointer;transition:all .15s;min-height:36px;background:transparent}.strategy-hint__trigger--correct{color:#6ee7b7;border-color:#6ee7b759}.strategy-hint__trigger--correct:hover{background:#6ee7b71a;border-color:#6ee7b7}.strategy-hint__trigger--incorrect{color:#fc8181;border-color:#fc818166}.strategy-hint__trigger--incorrect:hover{background:#fc81811a;border-color:#fc8181}.strategy-hint__icon{font-size:.9rem}.strategy-hint__popup{position:absolute;bottom:calc(100% + 8px);left:50%;transform:translate(-50%);width:300px;background:#0f2318;border:1px solid var(--felt-border);border-radius:var(--radius-lg);padding:.85rem;box-shadow:0 8px 24px #0009;z-index:200;display:flex;flex-direction:column;gap:.6rem}.strategy-hint__popup:after{content:"";position:absolute;top:100%;left:50%;transform:translate(-50%);border:7px solid transparent;border-top-color:var(--felt-border)}.strategy-hint__popup:before{content:"";position:absolute;top:calc(100% - 1px);left:50%;transform:translate(-50%);border:6px solid transparent;border-top-color:#0f2318;z-index:1}@media (max-width: 500px){.strategy-hint__popup{width:240px}}.hint-comparison{display:flex;align-items:center;gap:.5rem;font-size:.8rem;padding-bottom:.6rem;border-bottom:1px solid rgba(255,255,255,.08)}.hint-comparison__played{color:#fc8181}.hint-comparison__arrow{color:var(--text-secondary)}.hint-comparison__optimal{color:#6ee7b7}.hint-explanation{margin:0;font-size:.82rem;line-height:1.55;color:var(--text-secondary)}.strategy-chart{display:flex;flex-direction:column;gap:.75rem}.chart-tabs{display:flex;gap:.25rem;flex-wrap:wrap}.chart-tab{padding:.4rem .8rem;border-radius:var(--radius);background:transparent;border:1px solid var(--felt-border);color:var(--text-secondary);cursor:pointer;font-size:.82rem;font-weight:500;transition:all .15s}.chart-tab:hover{background:var(--felt-light);color:var(--text-primary)}.chart-tab--active{background:#d4a84326;color:var(--gold);border-color:var(--gold)}.chart-legend{display:flex;gap:.6rem;flex-wrap:wrap;font-size:.75rem;color:var(--text-secondary)}.legend-item{display:flex;align-items:center;gap:.3rem}.legend-swatch{width:18px;height:18px;border-radius:3px;display:inline-block}.chart-scroll-wrapper{overflow-x:auto;-webkit-overflow-scrolling:touch;max-width:100%}.strategy-table{border-collapse:collapse;font-size:.78rem;width:100%}.chart-header-cell{background:#0000004d;color:var(--text-secondary);padding:.3rem .4rem;text-align:center;font-weight:600;border:1px solid rgba(255,255,255,.06);min-width:30px;white-space:nowrap}.chart-header-cell--corner{width:40px}.chart-row-header{background:#0003;color:var(--text-secondary);padding:.25rem .5rem;text-align:right;font-weight:600;border:1px solid rgba(255,255,255,.06);white-space:nowrap}.chart-cell{padding:.25rem .3rem;text-align:center;font-weight:700;font-size:.75rem;border:1px solid rgba(255,255,255,.06);cursor:pointer;-webkit-user-select:none;-moz-user-select:none;user-select:none;transition:filter .1s}.chart-cell:hover{filter:brightness(1.25)}.chart-cell--selected{outline:2px solid white;outline-offset:-2px}.chart-cell--mini{width:24px;height:24px;border-radius:4px;display:inline-flex;align-items:center;justify-content:center}.chart-cell--hit{background:#eab3088c;color:#1a1a1a}.chart-cell--stand{background:#22c55e8c;color:#1a1a1a}.chart-cell--double{background:#3b82f68c;color:#fff}.chart-cell--split{background:#a855f78c;color:#fff}.chart-cell--surrender{background:#ef44448c;color:#fff}.legend-swatch--hit{background:#eab3088c}.legend-swatch--stand{background:#22c55e8c}.legend-swatch--double{background:#3b82f68c}.legend-swatch--split{background:#a855f78c}.legend-swatch--surrender{background:#ef44448c}.chart-tooltip{background:var(--felt-dark);border:1px solid var(--felt-border);border-radius:var(--radius);padding:.75rem;position:relative;margin-top:.5rem}.chart-tooltip__close{position:absolute;top:.5rem;right:.5rem;background:none;border:none;color:var(--text-secondary);cursor:pointer;font-size:.8rem;padding:.2rem}.chart-tooltip__header{display:flex;align-items:center;gap:.5rem;font-size:.85rem;color:var(--text-primary)}.learn-page{max-width:880px;margin:0 auto;padding:0 1rem 3rem}.learn-hero{text-align:center;padding:2.5rem 1rem 1.5rem}.learn-hero__title{font-family:Playfair Display,serif;font-size:clamp(1.8rem,4vw,2.8rem);color:var(--gold);margin:0 0 .5rem}.learn-hero__subtitle{color:var(--text-secondary);font-size:1rem;margin:0}.learn-tabs{display:flex;gap:.25rem;border-bottom:1px solid var(--felt-border);margin-bottom:1.5rem;overflow-x:auto}.learn-tab{padding:.6rem 1rem;background:none;border:none;border-bottom:2px solid transparent;color:var(--text-secondary);cursor:pointer;font-size:.9rem;font-weight:500;white-space:nowrap;transition:color .15s}.learn-tab:hover{color:var(--text-primary)}.learn-tab--active{color:var(--gold);border-bottom-color:var(--gold)}.learn-section{display:flex;flex-direction:column;gap:1.5rem}.rules-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1rem}.rules-card{background:#0003;border:1px solid var(--felt-border);border-radius:var(--radius-lg);padding:1.25rem}.rules-card--wide{grid-column:1 / -1}.rules-card h2{font-family:Playfair Display,serif;color:var(--gold);font-size:1.1rem;margin:0 0 .75rem}.rules-card p,.rules-card li{color:var(--text-secondary);font-size:.9rem;line-height:1.65}.card-values-list,.payout-list,.rules-steps{margin:0;padding:0 0 0 .5rem;list-style:none;display:flex;flex-direction:column;gap:.4rem}.card-value-demo{display:inline-block;background:#d4a84326;color:var(--gold);border-radius:4px;padding:.1rem .4rem;font-weight:600;margin-right:.4rem;font-size:.85rem}.payout-label{display:inline-block;width:90px;font-weight:600;color:var(--text-primary)}.rules-steps{padding-left:1rem;list-style:decimal}.rules-steps li{padding-left:.25rem}.actions-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:.75rem}.action-explain{padding:.75rem;background:#0003;border-radius:var(--radius)}.action-explain__name{display:block;font-weight:700;color:var(--gold);margin-bottom:.3rem;font-size:.9rem}.action-explain p{margin:0;font-size:.85rem;color:var(--text-secondary)}.strategy-intro{margin-bottom:1rem}.strategy-intro h2{font-family:Playfair Display,serif;color:var(--gold);margin:0 0 .5rem}.strategy-intro p{color:var(--text-secondary);font-size:.9rem;line-height:1.6;margin:0 0 .5rem}.section-lead{color:var(--text-secondary);font-size:.9rem;line-height:1.6;margin:0 0 1rem}.mistakes-list{display:flex;flex-direction:column;gap:.75rem}.mistake-card{background:#0003;border:1px solid var(--felt-border);border-radius:var(--radius-lg);overflow:hidden}.mistake-card__header{display:flex;align-items:flex-start;gap:.75rem;padding:.85rem 1rem;background:#0003}.mistake-number{width:24px;height:24px;border-radius:50%;background:#d4a84326;color:var(--gold);display:flex;align-items:center;justify-content:center;font-size:.75rem;font-weight:700;flex-shrink:0;margin-top:1px}.mistake-scenario{margin:0;font-size:.9rem;font-weight:600;color:var(--text-primary)}.mistake-card__body{padding:.85rem 1rem;display:flex;flex-direction:column;gap:.4rem}.mistake-correct{display:flex;align-items:baseline;gap:.4rem;flex-wrap:wrap}.mistake-correct__label{font-size:.75rem;text-transform:uppercase;letter-spacing:.07em;color:var(--text-secondary)}.mistake-correct__action{font-weight:700;color:#6ee7b7;font-size:.9rem}.mistake-why{margin:0;font-size:.875rem;color:var(--text-secondary);line-height:1.6}.glossary-list{display:flex;flex-direction:column;gap:.75rem}.glossary-entry{padding:.75rem 1rem;background:#0003;border:1px solid var(--felt-border);border-radius:var(--radius);display:grid;grid-template-columns:160px 1fr;gap:.5rem}@media (max-width: 500px){.glossary-entry{grid-template-columns:1fr}}.glossary-term{font-weight:700;color:var(--gold);font-size:.9rem}.glossary-def{margin:0;color:var(--text-secondary);font-size:.875rem;line-height:1.55}.stats-page{max-width:960px;margin:0 auto;padding:1.5rem 1rem 3rem;display:flex;flex-direction:column;gap:2rem}.stats-empty{text-align:center;padding:4rem 1rem;color:var(--text-secondary)}.stats-empty h1{color:var(--gold);font-family:Playfair Display,serif;margin-bottom:.5rem}.stats-header{display:flex;justify-content:space-between;align-items:center}.stats-header h1{font-family:Playfair Display,serif;color:var(--gold);font-size:1.8rem;margin:0}.stats-summary-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:.75rem}@media (min-width: 640px){.stats-summary-grid{grid-template-columns:repeat(4,1fr)}}.summary-card{background:#00000040;border:1px solid var(--felt-border);border-radius:var(--radius-lg);padding:1rem;display:flex;flex-direction:column;align-items:center;gap:.25rem}.summary-card__value{font-size:1.8rem;font-weight:700}.summary-card__value--good{color:#6ee7b7}.summary-card__value--ok{color:var(--gold-light)}.summary-card__value--warn{color:#fc8181}.summary-card__label{font-size:.75rem;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.07em}.stats-chart-section{display:flex;flex-direction:column;gap:1rem}.stats-chart-section h2{font-family:Playfair Display,serif;color:var(--gold);font-size:1.2rem;margin:0}.chart-container{background:#0003;border:1px solid var(--felt-border);border-radius:var(--radius-lg);padding:1rem;min-width:0;max-width:100%}.sessions-table-wrapper{overflow-x:auto;max-width:100%}.sessions-table{width:100%;border-collapse:collapse;font-size:.875rem}.sessions-table th,.sessions-table td{padding:.6rem 1rem;text-align:left;border-bottom:1px solid rgba(255,255,255,.06)}.sessions-table th{color:var(--text-secondary);font-weight:600;font-size:.75rem;text-transform:uppercase;letter-spacing:.07em}.sessions-table tr:hover td{background:#ffffff08}.accuracy-badge{display:inline-block;padding:.15rem .5rem;border-radius:20px;font-weight:700;font-size:.8rem}.accuracy-badge--good{background:#27ae6033;color:#6ee7b7}.accuracy-badge--ok{background:#d4a84333;color:var(--gold-light)}.accuracy-badge--warn{background:#c0392b33;color:#fc8181}.session-row--live td{background:#d4a8430d}.session-row--live:hover td{background:#d4a8431a!important}.live-badge{display:inline-block;padding:.1rem .45rem;border-radius:20px;font-size:.72rem;font-weight:700;background:#d4a84333;color:var(--gold);border:1px solid rgba(212,168,67,.4);animation:turn-pulse 1.4s ease-in-out infinite}.streak-cell{white-space:nowrap}.streak-value{font-weight:700}.streak-fire{margin-left:.2rem;font-size:.85rem}.stat-positive{color:#6ee7b7;font-weight:600}.stat-negative{color:#fc8181;font-weight:600}.mistakes-detail-list{display:flex;flex-direction:column;gap:.75rem}.mistake-detail-card{background:#0003;border:1px solid var(--felt-border);border-radius:var(--radius);padding:.85rem}.mistake-detail-header{display:flex;align-items:center;gap:.75rem;flex-wrap:wrap;margin-bottom:.4rem}.mistake-detail-count{background:#ef444433;color:#fc8181;border-radius:20px;padding:.1rem .5rem;font-weight:700;font-size:.8rem}.mistake-detail-title{font-weight:600;font-size:.9rem}.mistake-detail-actions{color:var(--text-secondary);font-size:.82rem}.mistake-detail-explanation{margin:0;font-size:.85rem;color:var(--text-secondary);line-height:1.6}@media (max-width: 640px){.site-logo{font-size:1.05rem}.nav-link{padding:.35rem .7rem;font-size:.85rem}}@media (max-width: 480px){.site-header__inner{height:48px;padding:0 .75rem;gap:.35rem}.site-logo{font-size:1rem}.site-logo__name{display:none}.nav-link{padding:.3rem .45rem;font-size:.8rem}.site-nav{gap:.1rem}.icon-btn{width:30px;height:30px}.toolbar-ruleset-badge{font-size:.72rem;padding:.15rem .5rem}.stats-bar{font-size:.72rem;gap:.6rem;padding:.3rem .75rem;overflow-x:auto;justify-content:flex-start;-webkit-overflow-scrolling:touch}.stats-bar::-webkit-scrollbar{display:none}.playing-card,.empty-hand-placeholder{width:52px;height:72px}.card-center-suit{font-size:1.2rem}.card-rank{font-size:.75rem}.bj-hand__cards .playing-card+.playing-card{margin-left:-10px}.table-felt{padding:.5rem .75rem;gap:.35rem}.zone-label{font-size:.65rem;margin-bottom:.2rem}.game-message{font-size:.9rem;padding:.35rem .9rem}.player-hands{gap:.5rem}.bj-hand{padding:.25rem .4rem;gap:.25rem}.bj-hand--active{box-shadow:0 0 0 2px var(--gold),0 0 12px #d4a8434d}.bj-hand__label{font-size:.7rem}.bj-hand__total{font-size:.75rem;padding:.1rem .45rem}.result-badge{font-size:.72rem;padding:.15rem .55rem}.controls-area{padding:.4rem .75rem .5rem;min-height:0;gap:.35rem}.complete-actions{gap:.5rem}.btn--lg{padding:.55rem 1.1rem;font-size:.88rem;min-height:42px}.action-btn{min-width:58px;min-height:48px;padding:.45rem .5rem;font-size:.8rem}.action-btn__hotkey{display:none}.chip{width:46px;height:46px;font-size:.7rem}.bet-panel{gap:.5rem}.bet-panel__info{gap:1.25rem}.bet-display__amount{font-size:1.2rem}.bankroll-display__amount{font-size:1rem}.strategy-hint__popup{width:220px}}@media (max-height: 700px){.site-header__inner{height:44px}.stats-bar{padding:.2rem .75rem;font-size:.72rem}.table-felt{padding:.6rem .75rem;gap:.4rem}.controls-area{padding:.4rem .75rem .5rem;gap:.35rem}.zone-label{margin-bottom:.2rem}.bj-hand{padding:.25rem .5rem;gap:.25rem}.bj-hand__total{font-size:.75rem;padding:.1rem .45rem}.action-btn{min-height:44px;padding:.4rem .75rem}.btn--lg{padding:.5rem 1.25rem;min-height:40px;font-size:.9rem}.chip{width:46px;height:46px;font-size:.7rem}.bet-panel{gap:.4rem}.bet-display__amount{font-size:1.1rem}.bankroll-display__amount{font-size:.95rem}}@media (max-height: 520px){.playing-card,.empty-hand-placeholder{width:52px;height:72px}.card-center-suit{font-size:1.2rem}.table-felt{padding:.4rem .5rem;gap:.25rem}.controls-area{padding:.3rem .5rem .4rem;gap:.25rem}.bj-hand__turn-badge,.table-logo{display:none}}.user-menu-wrap{position:relative}.user-avatar-btn{width:34px;height:34px;border-radius:50%;background:#d4a84333;border:1.5px solid var(--gold);color:var(--gold);font-weight:700;font-size:.85rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .15s}.user-avatar-btn:hover{background:#d4a84359}.user-menu{position:absolute;top:calc(100% + 8px);right:0;min-width:180px;background:var(--felt-dark);border:1px solid var(--felt-border);border-radius:var(--radius-lg);box-shadow:0 8px 24px #0006;z-index:200;overflow:hidden}.user-menu__name{padding:.65rem 1rem;font-size:.8rem;color:var(--text-secondary);border-bottom:1px solid var(--felt-border);word-break:break-all}.user-menu__item{display:block;width:100%;padding:.65rem 1rem;background:none;border:none;color:var(--text-primary);font-size:.875rem;cursor:pointer;text-align:left;transition:background .12s}.user-menu__item:hover{background:#ffffff12}.auth-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000a6;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:500;display:flex;align-items:center;justify-content:center;padding:1rem}.auth-modal{background:var(--felt-dark);border:1px solid var(--felt-border);border-radius:var(--radius-lg);width:100%;max-width:400px;padding:2rem;position:relative;display:flex;flex-direction:column;gap:1.25rem;box-shadow:0 20px 60px #00000080}.auth-modal__close{position:absolute;top:.75rem;right:.75rem;background:none;border:none;color:var(--text-secondary);font-size:1.1rem;cursor:pointer;padding:.25rem .5rem;border-radius:var(--radius);transition:color .12s}.auth-modal__close:hover{color:var(--text-primary)}.auth-modal__header{text-align:center}.auth-modal__suit{font-size:1.5rem;color:var(--gold)}.auth-modal__title{font-family:Playfair Display,serif;color:var(--gold);font-size:1.3rem;margin:.25rem 0}.auth-modal__sub{color:var(--text-secondary);font-size:.85rem;margin:0}.btn-google{display:flex;align-items:center;justify-content:center;gap:.6rem;width:100%;padding:.7rem 1rem;background:#fff;color:#3c4043;border:1px solid #dadce0;border-radius:var(--radius);font-size:.9rem;font-weight:500;cursor:pointer;transition:background .15s,box-shadow .15s}.btn-google:hover:not(:disabled){background:#f8f8f8;box-shadow:0 1px 3px #0003}.btn-google:disabled{opacity:.6;cursor:not-allowed}.auth-divider{display:flex;align-items:center;gap:.75rem;color:var(--text-secondary);font-size:.8rem}.auth-divider:before,.auth-divider:after{content:"";flex:1;height:1px;background:var(--felt-border)}.auth-tabs{display:flex;gap:.25rem;background:#0003;border-radius:var(--radius);padding:.2rem}.auth-tab{flex:1;padding:.4rem .75rem;background:none;border:none;color:var(--text-secondary);font-size:.875rem;font-weight:500;cursor:pointer;border-radius:calc(var(--radius) - 2px);transition:background .15s,color .15s}.auth-tab--active{background:var(--felt-light);color:var(--text-primary)}.auth-form-area{display:flex;flex-direction:column}.auth-form{display:flex;flex-direction:column;gap:.75rem}.auth-label{font-size:.8rem;color:var(--text-secondary);font-weight:500}.auth-input{width:100%;padding:.65rem .9rem;background:#00000040;border:1px solid var(--felt-border);border-radius:var(--radius);color:var(--text-primary);font-size:.95rem;outline:none;box-sizing:border-box;transition:border-color .15s}.auth-input:focus{border-color:var(--gold)}.auth-input--otp{letter-spacing:.3em;text-align:center;font-size:1.4rem;font-weight:700}.auth-hint{font-size:.78rem;color:var(--text-secondary);margin:0}.auth-error{font-size:.82rem;color:#fc8181;background:#fc81811a;border:1px solid rgba(252,129,129,.3);border-radius:var(--radius);padding:.5rem .75rem;margin:0}.auth-success{display:flex;align-items:flex-start;gap:.5rem;background:#6ee7b71a;border:1px solid rgba(110,231,183,.3);border-radius:var(--radius);padding:.75rem 1rem;color:#6ee7b7}.auth-success__icon{font-size:1rem;flex-shrink:0;margin-top:1px}.auth-success p{margin:0;font-size:.875rem}.auth-submit{width:100%}.auth-switch{text-align:center;font-size:.85rem;color:var(--text-secondary);margin:0}.auth-switch__link{background:none;border:none;color:var(--gold);font-size:inherit;cursor:pointer;padding:0;text-decoration:underline}
