@import"https://fonts.googleapis.com/css2?family=Playfair+Display:wght@700;900&family=DM+Mono:wght@400;500&family=DM+Sans:wght@400;500&display=swap";.htp-overlay{position:fixed;top:0;left:0;right:0;bottom:0;width:100vw;height:100vh;background:#1a151099;z-index:100000;display:flex;align-items:center;justify-content:center;padding:1.25rem}.htp-modal{background:var(--cream);border-radius:20px;border:1.5px solid rgba(26,21,16,.1);box-shadow:0 16px 56px #1a151047;width:100%;max-width:500px;max-height:88vh;overflow:hidden;position:relative;display:flex;flex-direction:column}.htp-inner{overflow-y:auto;padding:1.75rem 1.5rem;display:flex;flex-direction:column;gap:1.25rem;flex:1;border-radius:20px}.htp-inner::-webkit-scrollbar{width:4px}.htp-inner::-webkit-scrollbar-track{background:transparent}.htp-inner::-webkit-scrollbar-thumb{background:#1a151033;border-radius:4px}.htp-close{position:absolute;top:1rem;right:1rem;background:var(--surface);border:1px solid rgba(26,21,16,.1);font-size:14px;color:var(--muted);cursor:pointer;width:28px;height:28px;display:flex;align-items:center;justify-content:center;border-radius:6px;transition:background .15s,color .15s}.htp-close:hover{background:var(--ink);color:var(--cream)}.htp-title{font-family:var(--font-display);font-size:1.6rem;font-weight:700;color:var(--ink);padding-right:2.5rem}.htp-sections{display:flex;flex-direction:column;gap:.7rem}.htp-section{display:flex;gap:12px;align-items:flex-start;padding:11px 13px;background:var(--surface);border-radius:10px;border:.5px solid rgba(26,21,16,.07)}.htp-icon{font-size:18px;flex-shrink:0;margin-top:1px;width:24px;text-align:center}.htp-section-title{font-family:var(--font-body);font-size:13px;font-weight:500;color:var(--ink);margin-bottom:3px}.htp-text{font-family:var(--font-body);font-size:13px;color:var(--muted);line-height:1.55}.htp-text strong{color:var(--ink);font-weight:500}.htp-btn{width:100%;padding:13px;background:var(--red);color:#fff;border:none;border-radius:10px;font-family:var(--font-body);font-size:15px;font-weight:500;cursor:pointer;transition:background .15s;box-shadow:0 2px #8b1e1466;margin-top:.25rem}.htp-btn:hover{background:#b52f22}@media (max-width: 540px){.htp-overlay{padding:.75rem}.htp-modal{max-width:100%;border-radius:16px}.htp-inner{padding:1.5rem 1.25rem;border-radius:16px}}.br-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#1a151099;z-index:100000;display:flex;align-items:center;justify-content:center;padding:1.25rem}.br-modal{background:var(--cream);border-radius:20px;border:1.5px solid rgba(26,21,16,.1);box-shadow:0 16px 56px #1a151047;width:100%;max-width:460px;padding:1.75rem 1.5rem;position:relative;display:flex;flex-direction:column;gap:1.25rem}.br-close{position:absolute;top:1rem;right:1rem;background:var(--surface);border:1px solid rgba(26,21,16,.1);font-size:14px;color:var(--muted);cursor:pointer;width:28px;height:28px;display:flex;align-items:center;justify-content:center;border-radius:6px;transition:background .15s,color .15s}.br-close:hover:not(:disabled){background:var(--ink);color:var(--cream)}.br-close:disabled{opacity:.4;cursor:not-allowed}.br-title{font-family:var(--font-display);font-size:1.6rem;font-weight:700;color:var(--ink);padding-right:2.5rem}.br-form{display:flex;flex-direction:column;gap:1rem}.br-textarea{width:100%;background:var(--surface);border:1.5px solid rgba(26,21,16,.13);border-radius:10px;padding:12px 14px;font-family:var(--font-body);font-size:14px;color:var(--ink);resize:vertical;outline:none;transition:border-color .15s,box-shadow .15s;line-height:1.5}.br-textarea:focus{border-color:var(--red);box-shadow:0 0 0 3px #c8392b1a}.br-textarea::placeholder{color:var(--muted);opacity:.6}.br-textarea:disabled{opacity:.5}.br-error{font-family:var(--font-mono);font-size:12px;color:var(--red);background:#c8392b12;border:1px solid rgba(200,57,43,.18);border-radius:6px;padding:8px 12px}.br-btn{width:100%;padding:13px;background:var(--red);color:#fff;border:none;border-radius:10px;font-family:var(--font-body);font-size:15px;font-weight:500;cursor:pointer;transition:background .15s;box-shadow:0 2px #8b1e1466;display:flex;align-items:center;justify-content:center;gap:8px}.br-btn:hover:not(:disabled){background:#b52f22}.br-btn:disabled{opacity:.4;cursor:not-allowed;box-shadow:none}.br-spinner{display:inline-block;width:14px;height:14px;border:2px solid rgba(255,255,255,.35);border-top-color:#fff;border-radius:50%;animation:br-spin .7s linear infinite}@keyframes br-spin{to{transform:rotate(360deg)}}.br-success{display:flex;flex-direction:column;align-items:center;gap:1rem;padding:.5rem 0 .25rem;text-align:center}.br-success-icon{width:48px;height:48px;background:#eaf3de;color:#3b6d11;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:22px}.br-success p{font-family:var(--font-body);font-size:14px;color:var(--muted);line-height:1.5}@media (max-width: 540px){.br-overlay{padding:.75rem}.br-modal{border-radius:16px;padding:1.5rem 1.25rem}}.error-screen{height:100vh;display:flex;align-items:center;justify-content:center;background:var(--cream);padding:1.5rem}.error-card{text-align:center;padding:2.5rem 2rem;background:var(--surface);border-radius:20px;border:1.5px solid rgba(26,21,16,.1);box-shadow:0 8px 32px #1a151014;max-width:360px;width:100%;display:flex;flex-direction:column;align-items:center;gap:1rem}.error-icon{font-size:40px;line-height:1}.error-title{font-family:var(--font-display);font-size:1.4rem;font-weight:700;color:var(--ink)}.error-hint{font-family:var(--font-mono);font-size:12px;color:var(--muted);line-height:1.6;letter-spacing:.03em}.error-actions{display:flex;flex-direction:column;gap:8px;width:100%;margin-top:.5rem}.error-btn{padding:11px 20px;border-radius:10px;font-family:var(--font-body);font-size:14px;font-weight:500;cursor:pointer;transition:all .15s;border:1.5px solid transparent;width:100%}.error-btn--primary{background:var(--ink);color:var(--cream);box-shadow:0 2px #00000040}.error-btn--primary:hover{background:#2e2820;transform:translateY(-1px)}.error-btn--ghost{background:transparent;color:var(--muted);border-color:#1a151026}.error-btn--ghost:hover{background:var(--cream);color:var(--ink)}.lang-dropdown{position:relative;z-index:1}.lang-trigger{display:flex;align-items:center;gap:5px;font-family:var(--font-mono);font-size:11px;font-weight:500;letter-spacing:.08em;padding:5px 10px;border-radius:6px;border:1px solid rgba(26,21,16,.18);background:var(--cream);color:var(--ink);cursor:pointer;transition:all .15s}.lang-trigger:hover{border-color:#1a151059;background:var(--surface)}.lang-menu{z-index:2;position:absolute;top:calc(100% + 6px);right:0;background:var(--cream);border:1px solid rgba(26,21,16,.15);border-radius:8px;box-shadow:0 4px 16px #1a15101a;overflow:hidden;min-width:80px}.lang-option{display:block;width:100%;padding:8px 14px;font-family:var(--font-mono);font-size:11px;font-weight:500;letter-spacing:.08em;color:var(--muted);background:transparent;border:none;cursor:pointer;text-align:left;transition:background .1s,color .1s}.lang-option:hover{background:var(--surface);color:var(--ink)}.lang-option--active{color:var(--ink)}.home{min-height:100vh;display:flex;flex-direction:column;align-items:center;padding:2rem 1.25rem;position:relative;overflow:hidden}.home-topbar{position:absolute;top:1.25rem;right:1.25rem;z-index:1}.shape-tri{width:0;height:0;border-style:solid;transform-origin:center center}.shape-tri--1{border-width:0 100px 175px 100px;border-color:transparent transparent var(--red) transparent;opacity:.1;top:-20px;right:8%;animation:rotateSlow 18s linear infinite}.shape-tri--2{border-width:0 70px 120px 70px;border-color:transparent transparent var(--blue) transparent;opacity:.08;bottom:12%;left:4%;animation:rotateSlow 24s linear infinite reverse}.shape-tri--3{border-width:0 55px 95px 55px;border-color:transparent transparent var(--amber) transparent;opacity:.1;top:38%;right:2%;animation:rotateSlow 20s linear infinite}.shape-tri--4{border-width:0 45px 78px 45px;border-color:transparent transparent var(--gold) transparent;opacity:.08;bottom:5%;right:18%;animation:rotateSlow 28s linear infinite reverse}.shape-circle{width:280px;height:280px;border-radius:50%;border:24px solid var(--gold);opacity:.07;bottom:-70px;left:-70px;animation:rotateSlow 35s linear infinite}.home-header{position:relative;z-index:1;text-align:center;margin-top:2rem;margin-bottom:1rem}.home-title{font-family:var(--font-display);font-weight:900;line-height:.88;letter-spacing:-.02em}.title-cant{display:block;font-size:clamp(3.8rem,15vw,7rem);color:var(--ink);text-shadow:3px 3px 0 rgba(26,21,16,.08);opacity:0;animation:fadeUp .5s .15s forwards}.title-stop{display:block;font-size:clamp(5rem,20vw,9.5rem);color:var(--red);text-shadow:4px 4px 0 rgba(139,30,20,.15);opacity:0;animation:fadeUp .5s .28s forwards}.home-sub{font-family:var(--font-body);font-size:clamp(13px,3vw,15px);color:var(--muted);margin-top:1.75rem;line-height:1.5;max-width:340px;margin-left:auto;margin-right:auto;white-space:nowrap;opacity:0;animation:fadeUp .5s .4s forwards}.home-main{position:relative;z-index:1;width:100%;max-width:380px;opacity:0;animation:fadeUp .5s .5s forwards;margin-top:1.5rem}.menu-idle{display:flex;flex-direction:column;gap:.65rem}.menu-section-label{font-family:var(--font-mono);font-size:11px;font-weight:500;color:var(--ink);letter-spacing:.14em;text-transform:uppercase;text-align:center;margin-bottom:-.1rem}.menu-divider{display:flex;align-items:center;gap:12px;margin:.15rem 0}.menu-divider:before,.menu-divider:after{content:"";flex:1;height:1px;background:var(--muted);opacity:.25}.menu-divider span{font-family:var(--font-mono);font-size:11px;color:var(--muted);letter-spacing:.08em}.menu-secondary-links{display:flex;justify-content:center;gap:1.5rem;padding-top:.25rem}.link-btn{background:none;border:none;font-family:var(--font-mono);font-size:11px;color:var(--muted);cursor:pointer;padding:4px 0;letter-spacing:.05em;text-decoration:underline;text-underline-offset:3px;transition:color .15s}.menu-form{display:flex;flex-direction:column;gap:1.25rem;background:var(--surface);border:1.5px solid rgba(26,21,16,.1);border-radius:18px;padding:1.75rem 1.5rem;box-shadow:0 2px #1a15100f,0 8px 32px #1a15100d}.back-btn{background:none;border:none;font-family:var(--font-mono);font-size:11px;color:var(--muted);cursor:pointer;padding:0;text-align:left;letter-spacing:.05em;transition:color .15s}.form-title{font-family:var(--font-display);font-size:1.7rem;font-weight:700;color:var(--ink);line-height:1.1}.form-hint{font-family:var(--font-mono);font-size:11px;color:var(--muted);line-height:1.6}.field{display:flex;flex-direction:column;gap:6px}.field--row{flex-direction:row;align-items:center;justify-content:space-between}.field-label{font-family:var(--font-mono);font-size:11px;font-weight:500;text-transform:uppercase;letter-spacing:.1em;color:var(--muted)}.field-input{background:var(--cream);border:1.5px solid rgba(26,21,16,.13);border-radius:8px;padding:11px 13px;font-family:var(--font-body);font-size:16px;color:var(--ink);outline:none;transition:border-color .15s,box-shadow .15s}.field-input:focus{border-color:var(--red);box-shadow:0 0 0 3px #c8392b1a}.field-input::placeholder{color:var(--muted);opacity:.55}.field-input--code{font-family:var(--font-mono);font-size:22px;font-weight:500;letter-spacing:.25em;text-transform:uppercase;text-align:center}.picker{display:flex;gap:8px}.picker-btn{flex:1;padding:9px;background:var(--cream);border:1.5px solid rgba(26,21,16,.13);border-radius:8px;font-family:var(--font-mono);font-size:15px;font-weight:500;color:var(--muted);cursor:pointer;transition:all .15s}.picker-btn:hover{border-color:var(--red);color:var(--ink)}.picker-btn--active{background:var(--red);border-color:var(--red);color:#fff}.toggle{width:42px;height:24px;border-radius:12px;background:#1a151021;border:none;cursor:pointer;padding:3px;transition:background .2s;display:flex;align-items:center}.toggle--on{background:var(--green)}.toggle-knob{width:18px;height:18px;border-radius:50%;background:#fff;box-shadow:0 1px 3px #0000002e;transition:transform .2s;display:block}.toggle--on .toggle-knob{transform:translate(18px)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:10px;padding:15px 24px;border-radius:12px;font-family:var(--font-body);font-size:15px;font-weight:500;cursor:pointer;border:1.5px solid transparent;transition:all .15s;text-decoration:none}.btn--full{width:100%}.btn--primary{background:var(--red);color:#fff;border-color:var(--red);box-shadow:0 3px #8b1e1473}.btn--primary:hover:not(:disabled){background:#b52f22;transform:translateY(-1px);box-shadow:0 5px #8b1e1459}.btn--primary:active:not(:disabled){transform:translateY(1px);box-shadow:none}.btn--primary:disabled{opacity:.4;cursor:not-allowed}.btn--quickplay{background:var(--red);color:#fff;border-color:var(--red);box-shadow:0 3px #8b1e1473;font-size:16px;padding:17px 24px;animation:pulse-cta 2.5s ease-in-out infinite}.btn--quickplay:hover:not(:disabled){animation:none;background:#b52f22;transform:translateY(-1px);box-shadow:0 5px #8b1e1459}.btn--secondary{background:var(--ink);color:var(--cream);border-color:var(--ink);box-shadow:0 3px #00000040}.btn--secondary:hover{background:#2e2820;transform:translateY(-1px);box-shadow:0 5px #0003}.btn--ghost{background:transparent;color:var(--muted);border-color:#1a151021}.btn--ghost:hover{background:var(--surface);color:var(--ink);border-color:#1a151038}.btn-icon{font-size:14px;opacity:.85}.form-error{font-family:var(--font-mono);font-size:12px;color:var(--red);background:#c8392b12;border:1px solid rgba(200,57,43,.18);border-radius:6px;padding:8px 12px}.spinner{display:inline-block;width:16px;height:16px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .7s linear infinite}.home-footer{position:relative;z-index:1;margin-top:auto;padding-top:2rem;font-family:var(--font-mono);font-size:10px;color:var(--muted);letter-spacing:.08em;opacity:.5;display:flex;align-items:center;gap:1.25rem}@keyframes fadeUp{0%{opacity:0;transform:translateY(14px)}to{opacity:1;transform:translateY(0)}}@keyframes spin{to{transform:rotate(360deg)}}@keyframes pulse-cta{0%,to{box-shadow:0 3px #8b1e1473,0 0 #c8392b40}50%{box-shadow:0 3px #8b1e1473,0 0 0 8px #c8392b00}}@media (max-width: 480px){.home{padding:1.5rem 1rem}.home-main{max-width:100%}.menu-form{padding:1.5rem 1.25rem;border-radius:16px}}.lobby{min-height:100vh;display:flex;flex-direction:column;align-items:center;padding:0 1.25rem 2rem;position:relative;background:var(--cream)}.shape{position:absolute;will-change:transform}.lobby-header{position:relative;z-index:1;width:100%;max-width:480px;display:flex;align-items:center;gap:12px;padding:1.25rem 0 1rem}.back-btn{background:none;border:none;font-family:var(--font-mono);font-size:11px;color:var(--muted);cursor:pointer;padding:0;letter-spacing:.05em;white-space:nowrap;transition:color .15s;flex-shrink:0}.back-btn:hover{color:var(--ink)}.lobby-title-wrap{flex:1;min-width:0}.lobby-title{font-family:var(--font-display);font-size:1.6rem;font-weight:700;color:var(--ink);line-height:1;margin-bottom:.4rem}.room-code-wrap{display:flex;align-items:center;gap:8px}.room-code-label{font-family:var(--font-mono);font-size:10px;color:var(--muted);letter-spacing:.1em;text-transform:uppercase;flex-shrink:0}.room-code{font-family:var(--font-mono);font-size:15px;font-weight:500;letter-spacing:.18em;color:var(--ink);background:var(--surface);border:1.5px solid rgba(26,21,16,.13);border-radius:6px;padding:3px 10px;cursor:pointer;display:flex;align-items:center;gap:8px;transition:all .15s}.room-code:hover{border-color:var(--red);color:var(--red)}.copy-hint{font-size:10px;font-weight:400;letter-spacing:.05em;color:var(--muted);opacity:.7}.players-section{position:relative;z-index:10;width:100%;max-width:480px;margin-bottom:1rem}.players-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px}.player-card{background:var(--surface);border:1.5px solid rgba(26,21,16,.08);border-radius:14px;padding:.9rem 1rem;display:flex;align-items:center;gap:11px;transition:border-color .2s,background .2s;border-left:4px solid var(--player-color, rgba(26,21,16,.1))}.player-card--ready{background:color-mix(in srgb,var(--player-color, #2E6B4F) 6%,var(--surface));border-color:var(--player-color, #2E6B4F)}.player-card--disconnected{opacity:.45}.player-card--empty{border-left-color:#1a151014;border-style:dashed;background:transparent}.player-avatar{width:38px;height:38px;border-radius:50%;background:var(--player-color, rgba(26,21,16,.12));display:flex;align-items:center;justify-content:center;position:relative;flex-shrink:0}.player-avatar--empty{background:#1a151012}.player-initial{font-family:var(--font-display);font-size:15px;font-weight:700;color:#fff}.ready-badge{position:absolute;bottom:-2px;right:-2px;width:15px;height:15px;border-radius:50%;background:var(--green);color:#fff;font-size:8px;display:flex;align-items:center;justify-content:center;border:2px solid var(--cream)}.player-info{display:flex;flex-direction:column;gap:2px;min-width:0}.player-name-row{display:flex;align-items:center;gap:5px;flex-wrap:wrap}.player-name{font-family:var(--font-body);font-size:13px;font-weight:500;color:var(--ink);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.player-name-placeholder{font-family:var(--font-mono);font-size:12px;color:var(--muted);opacity:.5}.you-tag{font-family:var(--font-mono);font-size:9px;color:var(--muted);background:#1a151012;padding:1px 5px;border-radius:4px;flex-shrink:0}.host-tag{font-family:var(--font-mono);font-size:9px;font-weight:500;color:var(--gold);background:#c9a84c1f;border:1px solid rgba(201,168,76,.3);padding:1px 5px;border-radius:4px;flex-shrink:0}.player-status{font-family:var(--font-mono);font-size:10px;color:var(--muted);letter-spacing:.04em}.player-card--ready .player-status{color:var(--green)}.player-card--disconnected .player-status{color:var(--red)}.status-bar{position:relative;z-index:1;width:100%;max-width:480px;text-align:center;margin-bottom:1rem;padding:9px 16px;background:var(--surface);border:1px solid rgba(26,21,16,.08);border-radius:8px;transition:background .3s,border-color .3s}.status-bar--go{background:#2e6b4f14;border-color:#2e6b4f40}.status-text{font-family:var(--font-mono);font-size:11px;color:var(--muted);letter-spacing:.04em}.status-bar--go .status-text{color:var(--green);font-weight:500}.lobby-actions{position:relative;z-index:1;width:100%;max-width:480px;display:flex;flex-direction:column;align-items:center;gap:1rem}.btn-main{width:100%;padding:15px 24px;border-radius:12px;font-family:var(--font-body);font-size:16px;font-weight:500;cursor:pointer;border:1.5px solid transparent;transition:all .15s}.btn-main--active:hover:not(:disabled){background:#b52f22;transform:translateY(-1px);box-shadow:0 5px #8b1e144d}.btn-main--done{background:var(--green);color:#fff;border-color:var(--green);box-shadow:0 3px #14502859;cursor:default}.btn-main--disabled{background:var(--surface);color:var(--muted);border-color:#1a15101f;cursor:not-allowed}.lobby-footer-links{display:flex;align-items:center;gap:8px;flex-wrap:wrap;justify-content:center}.link-btn{background:none;border:none;font-family:var(--font-mono);font-size:11px;color:var(--muted);cursor:pointer;padding:2px 0;letter-spacing:.04em;text-decoration:underline;text-underline-offset:3px;transition:color .15s;flex-shrink:0}.link-btn:hover{color:var(--ink)}.link-btn--share{color:var(--red)}.link-btn--share:hover{color:#b52f22}.footer-sep{font-size:11px;color:var(--muted);opacity:.4}.invite-text{font-family:var(--font-mono);font-size:11px;color:var(--muted);letter-spacing:.03em}.invite-code{font-weight:500;color:var(--ink);letter-spacing:.12em}@media (max-width: 480px){.lobby{padding:0 1rem 2rem}.players-grid{gap:8px}.player-card{padding:.75rem .85rem}}.turn-timer{position:relative;display:inline-flex;align-items:center;justify-content:center;color:var(--muted);flex-shrink:0}.turn-timer--urgent{color:var(--amber)}.turn-timer--critical{color:var(--red);animation:pulse-timer .6s ease-in-out infinite;will-change:opacity}.turn-timer-num{position:absolute;font-family:var(--font-mono);font-size:11px;font-weight:600;line-height:1}.turn-timer-label{font-family:var(--font-mono);font-size:11px;font-weight:600;color:#fff;background:var(--red);padding:2px 8px;border-radius:20px;margin-left:6px;white-space:nowrap;flex-shrink:0;animation:pulse-timer .6s ease-in-out infinite;will-change:opacity}@keyframes pulse-timer{0%,to{opacity:1}50%{opacity:.65}}.mute-btn{background:none;border:none;font-size:14px;cursor:pointer;padding:4px 6px;border-radius:6px;opacity:.6;transition:opacity .15s;flex-shrink:0}.mute-btn:hover{opacity:1}.game{height:100vh;display:flex;flex-direction:column;background:var(--cream)}.game-header{flex-shrink:0;background:var(--surface);border-bottom:1.5px solid rgba(26,21,16,.1);padding:0 14px}.game-header-row1{display:flex;align-items:center;gap:10px;padding:8px 0 6px;border-bottom:1px solid rgba(26,21,16,.07)}.game-header-row2{display:flex;align-items:center;gap:7px;padding:6px 0 7px;overflow-x:auto;scrollbar-width:none}.game-header-row2::-webkit-scrollbar{display:none}.game-logo{font-family:var(--font-display);font-size:17px;font-weight:700;color:var(--red);white-space:nowrap;flex-shrink:0}.turn-indicator{display:flex;align-items:center;gap:7px;flex:1;min-width:0}.turn-dot{width:9px;height:9px;border-radius:50%;flex-shrink:0}.turn-name{font-family:var(--font-mono);font-size:12px;color:var(--ink);font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.header-right{display:flex;align-items:center;gap:8px;flex-shrink:0}.help-btn{background:none;border:none;font-family:var(--font-mono);font-size:10px;color:var(--muted);cursor:pointer;padding:2px 4px;letter-spacing:.04em;text-decoration:underline;text-underline-offset:2px;white-space:nowrap;transition:color .15s}.help-btn:hover{color:var(--ink)}.score-chip{display:flex;align-items:center;gap:5px;padding:3px 9px;border-radius:20px;border:1.5px solid;background:var(--cream);flex-shrink:0;transition:background .15s}.score-chip--active{background:color-mix(in srgb,var(--chip-color, #888) 8%,var(--cream))}.score-chip--mine{background:color-mix(in srgb,var(--chip-color, #888) 16%,var(--cream))}.score-chip--mine.score-chip--active{background:color-mix(in srgb,var(--chip-color, #888) 24%,var(--cream))}.score-you-tag{font-size:8px;color:var(--chip-color, #888);font-family:var(--font-mono);margin-left:2px;opacity:.8}.score-dot{width:7px;height:7px;border-radius:50%;flex-shrink:0}.score-name{font-family:var(--font-mono);font-size:10px;color:var(--ink)}.score-val{font-family:var(--font-mono);font-size:10px;font-weight:500;color:var(--ink);background:#1a151012;border-radius:3px;padding:0 4px}.game-canvas-wrap{flex:1;min-height:0;width:100%;position:relative;overflow:hidden;background:var(--cream)}.game-canvas-wrap>div{width:100%;height:100%}.game-footer{flex-shrink:0;height:calc(108px + env(safe-area-inset-bottom));min-height:calc(108px + env(safe-area-inset-bottom));max-height:calc(108px + env(safe-area-inset-bottom));padding-bottom:env(safe-area-inset-bottom);overflow:hidden;background:var(--surface);border-top:1px solid rgba(26,21,16,.07);box-shadow:0 -2px 12px #1a15100a;display:flex;flex-direction:column;align-items:stretch}.game-footer-inner{flex:1;min-height:0;padding:6px 10px;display:flex;flex-direction:column;align-items:stretch;justify-content:center;gap:4px;min-width:0}.action-row{display:flex;flex-direction:column;align-items:stretch;gap:8px;min-width:0;width:100%}.rolling-actions{display:flex;align-items:center;gap:10px;flex-wrap:wrap;justify-content:center}.btn-action{padding:10px 20px;border-radius:8px;font-family:var(--font-body);font-size:14px;font-weight:500;border:none;cursor:pointer;transition:all .15s}.btn-roll{background:var(--ink);color:var(--cream);box-shadow:0 2px #00000040}.btn-roll:hover{background:#2e2820;transform:translateY(-1px)}.btn-roll:active{transform:translateY(1px);box-shadow:none}.btn-stop{background:var(--red);color:#fff;box-shadow:0 2px #8b1e1459}.btn-stop:hover{background:#b52f22;transform:translateY(-1px)}.pairs-section{display:flex;flex-direction:column;align-items:stretch;gap:2px;width:100%;min-width:0}.pairs-choices{padding:4px 6px;display:flex;align-items:center;position:relative;overflow:visible}.pairs-choices:after{content:"";position:absolute;right:0;top:0;bottom:0;width:28px;background:linear-gradient(to right,transparent,var(--surface));pointer-events:none}.pairs-label{font-family:var(--font-mono);font-size:11px;color:var(--muted);letter-spacing:.06em;text-align:center;width:100%;font-weight:500}.pairs-row{display:flex;flex-direction:row;flex-wrap:nowrap;overflow-x:auto;overflow-y:visible;gap:8px;align-items:center;justify-content:safe center;width:100%;-webkit-overflow-scrolling:touch;scrollbar-width:none;padding:3px 2px}.pairs-row::-webkit-scrollbar{display:none}.pair-btn{display:flex;flex-direction:column;align-items:center;gap:4px;padding:8px 14px;background:var(--cream);border:2px solid var(--gold);border-radius:10px;cursor:pointer;transition:all .15s;min-width:72px}.pair-btn:hover{background:#c9a84c1f;transform:translateY(-2px);box-shadow:0 4px 10px #c9a84c33}.pair-cols{display:flex;align-items:center;gap:3px}.pair-col{font-family:var(--font-display);font-size:20px;font-weight:700;color:var(--ink);line-height:1}.pair-col--blocked{color:var(--muted)!important;text-decoration:line-through;opacity:.4}.pair-sep{font-family:var(--font-mono);font-size:12px;color:var(--muted)}.pair-dice{display:flex;align-items:center;gap:2px}.pair-dice-sep{font-size:9px;color:var(--muted);margin:0 2px}.pair-split-group{display:flex;align-items:center;gap:4px}.pair-split-or{font-family:var(--font-mono);font-size:10px;color:var(--muted)}.pair-btn--single{min-width:54px}.pair-dice-combo{display:inline-flex;align-items:center;gap:2px}.spectator-view{width:100%;display:flex;justify-content:center}.spectator-status{display:flex;align-items:center;gap:8px;padding:8px 14px;background:var(--cream);border:1px solid rgba(26,21,16,.1);border-radius:10px;flex-wrap:wrap;max-width:100%}.spectator-status--bust{border-color:#c8392b33;background:#c8392b0a}.spectator-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.spectator-text-col{display:flex;flex-direction:column;gap:5px}.spectator-text{font-family:var(--font-mono);font-size:11px;color:var(--muted)}.spectator-pairs{display:flex;gap:5px;flex-wrap:wrap}.spectator-pair-chip{display:flex;align-items:center;gap:2px;padding:2px 7px;border-radius:5px;background:#c9a84c1a;border:1px solid rgba(201,168,76,.3)}.spectator-pair-chip--bust{background:#c8392b12;border-color:#c8392b33}.spectator-pair-col{font-family:var(--font-display);font-size:14px;font-weight:700;color:var(--ink);line-height:1}.spectator-pair-sep{font-family:var(--font-mono);font-size:10px;color:var(--muted)}.spectator-runners{display:flex;gap:4px;margin-left:2px}.spectator-runner-badge{font-family:var(--font-mono);font-size:11px;font-weight:500;padding:1px 6px;border-radius:5px;background:#c9a84c1f;border:1px solid rgba(201,168,76,.35);color:var(--ink)}.waiting-hint{font-family:var(--font-mono);font-size:11px;color:var(--muted)}.bust-section{display:flex;flex-direction:column;align-items:center;gap:8px;width:100%}.bust-pairs{opacity:.55}.pair-btn--bust{cursor:default;border-color:var(--red)!important;pointer-events:none}.action-hint{font-family:var(--font-mono);font-size:11px;color:var(--muted)}.action-hint.bust{color:var(--red);font-weight:500}.game-finished{height:100vh;display:flex;align-items:center;justify-content:center;background:var(--cream);padding:1.5rem}.finished-card{text-align:center;padding:2.5rem 2rem;background:var(--surface);border-radius:20px;border:1.5px solid rgba(26,21,16,.1);box-shadow:0 8px 32px #1a151014;max-width:360px;width:100%;display:flex;flex-direction:column;align-items:center;gap:1rem}.finished-icon{font-size:44px;line-height:1}.finished-title{font-family:var(--font-display);font-size:1.8rem;font-weight:700;color:var(--ink)}.finished-scores{display:flex;flex-direction:column;gap:7px;width:100%}.finished-score-row{display:flex;align-items:center;gap:9px;padding:7px 11px;background:var(--cream);border-radius:8px;border:1px solid rgba(26,21,16,.07)}.finished-score-dot{width:9px;height:9px;border-radius:50%;flex-shrink:0}.finished-score-name{font-family:var(--font-body);font-size:13px;color:var(--ink);flex:1}.finished-score-val{font-family:var(--font-mono);font-size:12px;font-weight:500;color:var(--muted)}.finished-voted{font-family:var(--font-mono);font-size:10px;color:var(--green);font-weight:500}.finished-actions{display:flex;flex-direction:column;gap:9px;width:100%;margin-top:.25rem}.btn-rematch{padding:12px 24px;border-radius:10px;background:var(--red);color:#fff;border:none;font-family:var(--font-body);font-size:15px;font-weight:500;cursor:pointer;transition:all .15s;box-shadow:0 2px #8b1e1466}.btn-rematch:hover:not(:disabled){background:#b52f22;transform:translateY(-1px)}.btn-rematch--voted{background:var(--green)!important;box-shadow:0 2px #1450284d!important;cursor:default}.btn-home{padding:11px 24px;border-radius:10px;background:transparent;color:var(--muted);border:1.5px solid rgba(26,21,16,.15);font-family:var(--font-body);font-size:14px;font-weight:500;cursor:pointer;transition:all .15s}.btn-home:hover{background:var(--cream);color:var(--ink)}.game-error{height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1rem;font-family:var(--font-mono);color:var(--red)}@media (max-width: 480px){.game-header{padding:0 10px}.pair-col{font-size:17px}.btn-action{padding:9px 16px;font-size:13px}.score-name{display:none}}@media (max-width: 600px){.game{height:100dvh}.game-footer{height:calc(92px + env(safe-area-inset-bottom));min-height:calc(92px + env(safe-area-inset-bottom));max-height:calc(92px + env(safe-area-inset-bottom))}.game-canvas-wrap,.pairs-section{width:100%}.pairs-label{font-size:10px;margin-bottom:2px}.rolling-actions{flex-wrap:nowrap}.rolling-actions .btn-action{flex:1}}.bust-section{width:100%;display:flex;align-items:center;justify-content:center}.bust-row{display:flex;flex-direction:row;align-items:center;gap:8px;flex-wrap:nowrap;overflow-x:auto;overflow-y:hidden;padding:2px 0;scrollbar-width:none}.bust-row::-webkit-scrollbar{display:none}.bust-row .action-hint.bust{white-space:nowrap;flex-shrink:0}.pair-btn,.pair-split-group{flex-shrink:0;scroll-snap-align:start}@media (max-width: 600px){.pairs-row{justify-content:flex-start}.pair-btn{padding:5px 8px;min-width:56px;gap:3px}.pair-col{font-size:16px}.pair-btn .pair-dice{gap:1px}.pair-btn .pair-dice svg{width:17px;height:17px}.pair-split-group{gap:3px}}.lsetup{min-height:100vh;display:flex;flex-direction:column;align-items:center;padding:0 1.25rem 2rem;position:relative;background:var(--cream)}.lsetup-topbar{position:absolute;top:1.25rem;right:1.25rem;z-index:2}.bg-shapes{position:fixed;top:0;right:0;bottom:0;left:0;pointer-events:none;z-index:0}.shape{position:absolute}.shape-tri{width:0;height:0;border-style:solid}.shape-tri--1{border-width:0 100px 175px 100px;border-color:transparent transparent var(--red) transparent;opacity:.08;top:-20px;right:8%;animation:rotateSlow 18s linear infinite}.shape-circle{width:280px;height:280px;border-radius:50%;border:24px solid var(--gold);opacity:.06;bottom:-70px;left:-70px;animation:rotateSlow 35s linear infinite}@keyframes rotateSlow{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.lsetup-header{position:relative;z-index:1;width:100%;max-width:420px;padding:1.5rem 0 1rem;display:flex;flex-direction:column;gap:4px}.lsetup-title{font-family:var(--font-display);font-size:1.8rem;font-weight:700;color:var(--ink)}.lsetup-sub{font-family:var(--font-mono);font-size:11px;color:var(--muted);letter-spacing:.04em}.lsetup-main{position:relative;z-index:1;width:100%;max-width:420px;display:flex;flex-direction:column;gap:1rem}.lsetup-players{display:flex;flex-direction:column;gap:8px}.lsetup-player{display:flex;align-items:center;gap:12px;padding:12px 14px;background:var(--surface);border-radius:14px;border:1.5px solid rgba(26,21,16,.08);border-left:4px solid var(--pc, #888)}.lsetup-player-avatar{width:40px;height:40px;border-radius:50%;background:var(--pc, #888);display:flex;align-items:center;justify-content:center;flex-shrink:0;font-family:var(--font-display);font-size:16px;font-weight:700;color:#fff}.lsetup-player-fields{flex:1;display:flex;flex-direction:column;gap:6px;min-width:0}.lsetup-name-input{background:var(--cream);border:1.5px solid rgba(26,21,16,.12);border-radius:7px;padding:6px 10px;font-family:var(--font-body);font-size:16px;font-weight:500;color:var(--ink);outline:none;width:100%;transition:border-color .15s}.lsetup-name-input:focus{border-color:var(--pc, var(--red))}.lsetup-type-row{display:flex;gap:6px}.lsetup-type-btn{flex:1;padding:5px 10px;border-radius:7px;border:1.5px solid rgba(26,21,16,.12);background:var(--cream);font-family:var(--font-mono);font-size:11px;font-weight:500;color:var(--muted);cursor:pointer;transition:all .15s;display:flex;align-items:center;justify-content:center;gap:5px}.lsetup-type-btn.active{background:var(--pc, var(--red));border-color:var(--pc, var(--red));color:#fff}.lsetup-type-btn:not(.active):hover{border-color:#1a15104d;color:var(--ink)}.lsetup-diff-row{display:flex;gap:4px}.lsetup-diff-btn{flex:1;min-width:0;padding:5px 4px;border-radius:6px;border:1.5px solid rgba(26,21,16,.12);background:var(--cream);font-family:var(--font-mono);font-weight:500;color:var(--muted);cursor:pointer;transition:all .15s;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px}.lsetup-diff-emoji{font-size:14px;line-height:1}.lsetup-diff-label{font-size:9px;line-height:1}.lsetup-diff-btn:not(.active):hover{border-color:#1a15104d;color:var(--ink)}.lsetup-diff-btn--cautious.active{background:#2e6b4f;border-color:#2e6b4f;color:#fff}.lsetup-diff-btn--balanced.active{background:#2b4e8c;border-color:#2b4e8c;color:#fff}.lsetup-diff-btn--aggressive.active{background:var(--red);border-color:var(--red);color:#fff}.coming-soon{font-size:9px;opacity:.7;background:#ffffff40;padding:1px 4px;border-radius:3px}.lsetup-remove{background:none;border:none;color:var(--muted);cursor:pointer;font-size:14px;padding:4px;border-radius:4px;transition:color .15s;flex-shrink:0}.lsetup-remove:hover{color:var(--red)}.lsetup-add{padding:12px;border-radius:12px;border:1.5px dashed rgba(26,21,16,.18);background:transparent;font-family:var(--font-mono);font-size:12px;color:var(--muted);cursor:pointer;transition:all .15s;text-align:center}.lsetup-add:hover{border-color:var(--red);color:var(--red);background:#c8392b0a}.lsetup-footer{display:flex;flex-direction:column;align-items:center;gap:10px;margin-top:.5rem}.lsetup-start{width:100%;font-size:16px;padding:15px}.btn-main{border-radius:12px;font-family:var(--font-body);font-weight:500;cursor:pointer;border:1.5px solid transparent;transition:all .15s}.btn-main--active{background:var(--red);color:#fff;border-color:var(--red);box-shadow:0 3px #8b1e1466}.btn-main--active:hover:not(:disabled){background:#b52f22;transform:translateY(-1px)}.btn-main--active:disabled{opacity:.4;cursor:not-allowed;transform:none;box-shadow:none}.lg-handoff-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#1a151099;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);display:flex;align-items:center;justify-content:center;z-index:50;padding:1.5rem}.lg-handoff-card{text-align:center;display:flex;flex-direction:column;align-items:center;gap:1rem;background:var(--surface);border:1.5px solid rgba(26,21,16,.1);border-radius:20px;padding:2.5rem 2rem;max-width:340px;width:100%;box-shadow:0 8px 32px #1a151014}.lg-handoff-avatar{width:72px;height:72px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-family:var(--font-display);font-size:28px;font-weight:700;color:#fff;box-shadow:0 4px 12px #00000026}.lg-handoff-title{font-family:var(--font-display);font-size:1.6rem;font-weight:700;color:var(--ink)}.lg-handoff-sub{font-family:var(--font-mono);font-size:12px;color:var(--muted);letter-spacing:.05em;margin-top:-6px}.lg-handoff-btn{width:100%;padding:14px;background:var(--red);color:#fff;border:none;border-radius:12px;font-family:var(--font-body);font-size:16px;font-weight:500;cursor:pointer;box-shadow:0 3px #8b1e1466;transition:all .15s;margin-top:.5rem}.lg-handoff-btn:hover{background:#b52f22;transform:translateY(-1px)}.bot-turn-info{display:flex;flex-direction:column;align-items:center;gap:.6rem}.bot-dice-row{display:flex;gap:.4rem;justify-content:center}.bot-pairs-row{flex-wrap:wrap;justify-content:center}.pair-btn--bot{cursor:default;opacity:.6;pointer-events:none}.pair-btn--chosen{opacity:1!important;border-color:var(--red)!important;box-shadow:0 0 0 2px var(--red),0 3px #8b1e144d!important;transform:translateY(-2px)}.joingame{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--cream);padding:1.5rem;position:relative}.joingame-topbar{position:absolute;top:1.25rem;right:1.25rem}.joingame-card{width:100%;max-width:360px;background:var(--surface);border:1.5px solid rgba(26,21,16,.1);border-radius:20px;padding:2rem 1.75rem;box-shadow:0 2px #1a15100f,0 8px 32px #1a15100f;display:flex;flex-direction:column;align-items:center;gap:.6rem}.joingame-code-badge{font-family:var(--font-mono);font-size:22px;font-weight:500;letter-spacing:.22em;color:var(--red);background:#c8392b14;border:1.5px solid rgba(200,57,43,.18);border-radius:10px;padding:6px 18px;margin-bottom:.4rem}.joingame-title{font-family:var(--font-display);font-size:1.7rem;font-weight:700;color:var(--ink);text-align:center;line-height:1.1}.joingame-sub{font-family:var(--font-mono);font-size:11px;color:var(--muted);text-align:center;line-height:1.6;margin-bottom:.4rem}.joingame-form{width:100%;display:flex;flex-direction:column;gap:.75rem;margin-top:.4rem}.joingame-input{width:100%;background:var(--cream);border:1.5px solid rgba(26,21,16,.13);border-radius:8px;padding:11px 13px;font-family:var(--font-body);font-size:16px;color:var(--ink);outline:none;transition:border-color .15s,box-shadow .15s}.joingame-input:focus{border-color:var(--red);box-shadow:0 0 0 3px #c8392b1a}.joingame-input::placeholder{color:var(--muted);opacity:.55}.joingame-btn{width:100%;padding:13px;border-radius:10px;background:var(--red);color:#fff;border:none;font-family:var(--font-body);font-size:15px;font-weight:500;cursor:pointer;box-shadow:0 3px #8b1e1466;transition:all .15s}.joingame-btn:hover:not(:disabled){background:#b52f22;transform:translateY(-1px);box-shadow:0 5px #8b1e144d}.joingame-btn:disabled{opacity:.4;cursor:not-allowed}.joingame-error{font-family:var(--font-mono);font-size:12px;color:var(--red);background:#c8392b12;border:1px solid rgba(200,57,43,.18);border-radius:6px;padding:8px 12px}.joingame-back{background:none;border:none;font-family:var(--font-mono);font-size:11px;color:var(--muted);cursor:pointer;padding:4px 0;letter-spacing:.05em;margin-top:.4rem;transition:color .15s}.joingame-back:hover{color:var(--ink)}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--cream: #F5EFE0;--ink: #1A1510;--red: #C8392B;--amber: #E07B2A;--green: #2E6B4F;--blue: #2B4E8C;--gold: #C9A84C;--muted: #8A7E6E;--surface: #EDE5CF;--font-display: "Playfair Display", serif;--font-mono: "DM Mono", monospace;--font-body: "DM Sans", sans-serif}html,body,#root{height:100%;background:var(--cream);color:var(--ink);font-family:var(--font-body);-webkit-font-smoothing:antialiased}canvas{background:var(--cream)}body:before{content:"";position:fixed;top:0;right:0;bottom:0;left:0;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='noise'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23noise)' opacity='0.04'/%3E%3C/svg%3E");pointer-events:none;z-index:9999;opacity:.5;will-change:transform}@media (max-width: 600px){body:before{display:none}}.color-dropdown{position:relative}.color-trigger{display:flex;align-items:center;gap:7px;padding:5px 10px;width:100%;border-radius:7px;border:1.5px solid rgba(26,21,16,.14);background:var(--cream);font-family:var(--font-mono);font-size:11px;font-weight:500;color:var(--ink);cursor:pointer;transition:border-color .15s}.color-trigger:hover{border-color:#1a151052}.color-dot{width:12px;height:12px;border-radius:50%;flex-shrink:0}.color-chevron{margin-left:auto;font-size:9px;opacity:.45}.color-menu{position:absolute;top:calc(100% + 4px);left:0;right:0;background:var(--cream);border:1.5px solid rgba(26,21,16,.14);border-radius:8px;box-shadow:0 6px 18px #00000021;z-index:200;overflow:hidden}.color-option{display:flex;align-items:center;gap:8px;width:100%;padding:7px 10px;border:none;background:transparent;font-family:var(--font-mono);font-size:11px;color:var(--ink);cursor:pointer;text-align:left;transition:background .1s}.color-option:hover:not(:disabled){background:#1a15100d}.color-option.selected{font-weight:600}.color-option:disabled{opacity:.28;cursor:not-allowed}.color-check{margin-left:auto;font-size:10px}.color-dropdown--inline{display:inline-flex;margin-left:auto}.color-trigger--compact{display:flex;align-items:center;gap:3px;padding:2px 5px;border-radius:5px;border:1.5px solid rgba(26,21,16,.14);background:var(--cream);cursor:pointer;transition:border-color .15s;flex-shrink:0}.color-trigger--compact:hover{border-color:#1a151052}.color-trigger--compact .color-chevron{font-size:8px}.color-menu--right{left:auto;right:0;min-width:150px}
