.tile{width:62px;height:62px;display:inline-flex;justify-content:center;align-items:center;font-size:2rem;font-weight:700;text-transform:uppercase;border:2px solid var(--color-border);background:var(--tile-bg, var(--color-empty));color:var(--tile-color, #ffffff);-webkit-user-select:none;user-select:none}@keyframes flip{0%{transform:rotateX(0)}50%{transform:rotateX(90deg)}to{transform:rotateX(0)}}.tile-flipping{animation:flip .5s ease-in-out;animation-delay:var(--animation-delay, 0s);animation-fill-mode:forwards;-webkit-backface-visibility:hidden;backface-visibility:hidden;transform-style:preserve-3d;will-change:transform}.tile-correct{--tile-bg: var(--color-correct);--tile-color: #ffffff}.tile-present{--tile-bg: var(--color-present);--tile-color: #ffffff}.tile-absent{--tile-bg: var(--color-absent);--tile-color: #818384}.tile-empty{--tile-bg: var(--color-empty)}.lp-display{font-size:2.5rem;font-weight:700;color:#fff;transition:color .3s ease-in-out;text-align:center;padding:8px 16px}.lp-low{color:var(--color-error);animation:pulse 1s ease-in-out infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.6}}.lp-label{font-size:.875rem;color:#818384;margin-bottom:4px}.lp-value{font-size:2.5rem;font-weight:700}.lp-bar-container{position:relative;width:60px;height:300px;background:#1a1a1b;border-radius:8px;border:1px solid #3a3a3c;overflow:hidden;display:flex;flex-direction:column;align-items:center;justify-content:flex-end}.lp-bar-fill{position:absolute;bottom:0;left:0;width:100%;background:linear-gradient(to top,var(--color-correct),var(--color-correct));transition:height .5s ease}.lp-bar-value{position:relative;z-index:1;font-size:.875rem;font-weight:700;color:#fff;margin-bottom:4px}.lp-bar-label{position:relative;z-index:1;font-size:.875rem;font-weight:700;color:#fff;text-shadow:0 1px 3px rgba(0,0,0,.7);margin-bottom:8px}.lp-bar-low .lp-bar-fill{background:var(--color-error);animation:pulse 1s ease-in-out infinite}.board{background:#121213;border-radius:12px;padding:16px 20px;display:grid;grid-template-columns:auto 1fr auto;gap:24px;align-items:start}.board-lp-left,.board-lp-right{display:flex;flex-direction:column;align-items:center}.board-center{flex:1;display:flex;flex-direction:column;align-items:center}.guess-grid{display:flex;flex-direction:column;gap:8px;max-height:400px;overflow-y:auto}.guess-row{display:flex;align-items:center;gap:12px}.guess-tiles{display:flex;gap:var(--tile-gap, 4px)}.guess-player{width:80px;font-size:14px;color:#818384}.guess-empty{color:#818384;font-style:italic;padding:20px}.turn-indicator{font-size:14px;color:var(--color-correct);margin-top:8px;min-height:20px}.keyboard{display:flex;flex-direction:column;align-items:center;gap:8px;max-width:500px;margin:0 auto;padding:16px 0;-webkit-user-select:none;user-select:none;-webkit-tap-highlight-color:transparent}.keyboard-row{display:flex;gap:6px;justify-content:center}.key{min-width:43px;height:58px;padding:0 12px;background:#818384;color:#fff;font-size:.875rem;font-weight:700;text-transform:uppercase;border:none;border-radius:4px;cursor:pointer;transition:transform 34ms;display:inline-flex;align-items:center;justify-content:center}.key:active:not(:disabled){transform:translateY(2px);outline:2px solid #ffffff;outline-offset:-2px}.key:hover:not(:disabled){background:#9a9b9c}.key-correct:hover:not(:disabled){background:var(--color-correct)}.key-present:hover:not(:disabled){background:var(--color-present)}.key-absent:hover:not(:disabled){background:var(--color-absent)}.key-wide{min-width:65px;font-size:.75rem}.key-correct{background:var(--color-correct)}.key-present{background:var(--color-present)}.key-absent{background:var(--color-absent);color:#818384}.key-disabled{opacity:.5;cursor:not-allowed}.key:disabled{opacity:.5;cursor:not-allowed}.input-wrapper{position:relative;width:100%;max-width:500px;margin:16px auto}.input-icon{position:absolute;left:14px;top:50%;transform:translateY(-50%);pointer-events:none;color:#818384;z-index:1;transition:color .3s ease-in-out}.unified-input{width:100%;padding:14px 16px 14px 44px;font-size:1.125rem;font-weight:500;letter-spacing:.1em;text-transform:uppercase;border:2px solid var(--input-border-color, #3a3a3c);border-radius:8px;background:#121213;color:#fff;transition:border-color .3s ease-in-out;outline:none}.unified-input::placeholder{color:#818384;letter-spacing:normal;text-transform:none;font-weight:400}.unified-input.mode-set-word{--input-border-color: var(--color-correct)}.unified-input.mode-guess{--input-border-color: var(--color-present)}.unified-input:disabled{--input-border-color: var(--color-absent);cursor:not-allowed;animation:input-pulse 2s ease-in-out infinite}.unified-input:focus:not(:disabled){box-shadow:0 0 0 2px var(--input-border-color)}@keyframes input-pulse{0%,to{opacity:1}50%{opacity:.6}}@media (prefers-reduced-motion: reduce){.unified-input:disabled{animation:none}}.solved-indicator{font-size:1.5rem;font-weight:700;color:var(--color-correct);text-transform:uppercase;letter-spacing:.1em;padding:12px 24px;margin-bottom:16px;background:color-mix(in srgb,var(--color-correct) 15%,transparent);border:2px solid var(--color-correct);border-radius:8px;animation:solved-bounce .6s ease-out}@keyframes solved-bounce{0%{opacity:0;transform:scale(.5)}50%{transform:scale(1.1)}to{opacity:1;transform:scale(1)}}@media (prefers-reduced-motion: reduce){.solved-indicator{animation:none}}@keyframes shake{0%,to{transform:translate(0)}10%,30%,50%,70%,90%{transform:translate(-8px)}20%,40%,60%,80%{transform:translate(8px)}}.unified-input-shake{animation:shake .5s cubic-bezier(.36,.07,.19,.97);border-color:var(--color-error)!important}@media (prefers-reduced-motion: reduce){.unified-input-shake{animation:none}}.input-error-message{color:var(--color-error);font-size:.875rem;text-align:center;margin-bottom:4px;animation:error-fade-in .3s ease-out}@keyframes error-fade-in{0%{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}@media (prefers-reduced-motion: reduce){.input-error-message{animation:none}}.reset-button{display:block;margin:16px auto;padding:10px 20px;background:transparent;border:1px solid #818384;border-radius:4px;color:#818384;font-size:.875rem;cursor:pointer;transition:color .2s,border-color .2s}.reset-button:hover{color:#fff;border-color:#fff}@media (max-width: 700px){.board{grid-template-columns:52px 1fr 52px;gap:8px;padding:12px 8px}.board-lp-left,.board-lp-right{flex-direction:column;justify-content:flex-start;gap:0}.board-lp-left .lp-bar-container,.board-lp-right .lp-bar-container{height:180px;width:44px;max-width:none}.board-lp-left .lp-bar-fill,.board-lp-right .lp-bar-fill{width:100%;height:inherit;top:auto;left:auto}.lp-bar-value{font-size:.65rem;letter-spacing:-.02em}.key{min-width:clamp(28px,calc((100vw - 94px)*.1),43px);height:clamp(44px,7.5vw,58px);padding:0 4px;font-size:clamp(.65rem,2.5vw,.875rem)}.key-wide{min-width:clamp(42px,calc((100vw - 94px) / 10 * 1.5),65px);font-size:clamp(.55rem,2vw,.75rem)}.keyboard-row{gap:clamp(4px,1vw,6px)}.keyboard{gap:clamp(5px,1.5vw,8px);padding:8px 0}.board{grid-template-columns:52px minmax(0,1fr) 52px}.guess-player{display:none}.guess-row{gap:0;justify-content:center}.tile{width:clamp(28px,calc((100vw - 152px) / var(--word-length, 5) - var(--tile-gap, 4px)),62px);height:clamp(28px,calc((100vw - 152px) / var(--word-length, 5) - var(--tile-gap, 4px)),62px);font-size:clamp(.75rem,calc(((100vw - 152px) / var(--word-length, 5) - var(--tile-gap, 4px)) * .55),2rem)}}.peek-button{background:#1a1a1b;border:2px solid #3a3a3c;border-radius:8px;padding:8px 16px;font-size:13px;color:#fff;cursor:pointer;transition:background .15s ease,border-color .15s ease;font-family:inherit;white-space:nowrap}.peek-button:hover:not(:disabled){background:#242426;border-color:#4a4a4c}.peek-button--active{border-color:var(--color-correct);background:#1e2a1e}.peek-button--disabled{opacity:.4;cursor:not-allowed}.peek-panel{position:fixed;top:0;right:0;height:100%;width:320px;background:#1a1a1b;border-left:2px solid #3a3a3c;padding:16px 20px;overflow-y:auto;z-index:100;transform:translate(100%);transition:transform .2s ease-out;will-change:transform}.peek-panel--visible{transform:translate(0)}@media (max-width: 768px){.peek-panel{width:85vw;max-width:320px}}@media (prefers-reduced-motion: reduce){.peek-panel{transition:none;display:none}.peek-panel--visible{display:block;transform:translate(0)}}.peek-panel__header{display:flex;justify-content:space-between;align-items:center;font-size:16px;font-weight:700;margin-bottom:16px;padding-bottom:12px;border-bottom:1px solid #3a3a3c}.peek-panel__close-btn{background:transparent;border:1px solid #3a3a3c;color:#818384;width:28px;height:28px;border-radius:50%;font-size:14px;cursor:pointer;display:flex;align-items:center;justify-content:center;padding:0;flex-shrink:0;transition:border-color .15s ease,color .15s ease}.peek-panel__close-btn:hover{border-color:#d7dadc;color:#d7dadc}.peek-panel__guess-grid{display:flex;flex-direction:column;gap:4px;margin-bottom:16px;font-size:.85em}.peek-panel__guess-row{display:flex;gap:4px;justify-content:center}.peek-panel__no-guesses{text-align:center;color:#818384;padding:20px 0;font-style:italic}.peek-panel__stats{background:#121213;border-radius:8px;padding:12px;margin-bottom:12px}.peek-panel__stat-row{display:flex;justify-content:space-between;margin-bottom:8px}.peek-panel__stat-row:last-child{margin-bottom:0}.peek-panel__stat-label{color:#818384}.peek-panel__stat-value{font-weight:700;color:#fff}.peek-panel__comparison{display:grid;grid-template-columns:1fr 1fr;gap:8px;font-size:13px;margin-bottom:12px}.peek-panel__comparison-player{background:#121213;border-radius:8px;padding:12px;text-align:center}.peek-panel__comparison-label{font-weight:700;margin-bottom:8px;color:#fff}.peek-panel__comparison-stats{color:#818384;margin-bottom:4px}.peek-panel__comparison-stats:last-child{margin-bottom:0}.peek-panel__finished-badge{color:var(--color-correct);font-weight:700;text-align:center;padding:8px;background:#1e2a1e;border-radius:8px;border:1px solid var(--color-correct)}.round-review__backdrop{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;z-index:200}.round-review__sheet{--sheet-height: 55vh;position:fixed;bottom:0;left:0;right:0;height:var(--sheet-height);background:#1a1a1b;border-top-left-radius:16px;border-top-right-radius:16px;border-top:2px solid #3a3a3c;z-index:201;transform:translateY(100%);transition:transform .3s ease-out;will-change:transform;overflow-y:auto;padding:0 16px 16px}.round-review__sheet--open{transform:translateY(0)}.round-review__sheet--expanded{--sheet-height: 95vh}.round-review__drag-handle{width:40px;height:4px;border-radius:2px;background:#3a3a3c;margin:8px auto 12px;cursor:grab}.round-review__header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}.round-review__title{font-size:16px;font-weight:700;color:#fff}.round-review__close-btn{background:transparent;border:1px solid #3a3a3c;color:#818384;width:28px;height:28px;border-radius:50%;font-size:14px;cursor:pointer;display:flex;align-items:center;justify-content:center;padding:0;flex-shrink:0;transition:border-color .15s ease,color .15s ease}.round-review__close-btn:hover{border-color:#d7dadc;color:#d7dadc}.round-review__pills{display:flex;flex-direction:row;gap:8px;overflow-x:auto;padding-bottom:12px;margin-bottom:12px;border-bottom:1px solid #3a3a3c;-webkit-overflow-scrolling:touch}.round-review__pills::-webkit-scrollbar{display:none}.round-review__pills{scrollbar-width:none}.round-review__pill{background:#121213;border:1px solid #3a3a3c;border-radius:16px;padding:6px 14px;font-size:13px;color:#818384;cursor:pointer;white-space:nowrap;transition:background .15s,border-color .15s;font-family:inherit}.round-review__pill--active{background:#1e2a1e;border-color:var(--color-correct);color:#fff}.round-review__pill--sudden-death{border-color:#b59410}.round-review__pill--sudden-death.round-review__pill--active{background:#2a2410;border-color:#d4a017;color:#f5c518}.round-review__boards{display:flex;flex-direction:column;gap:20px}.round-review__board-section{margin-bottom:20px}.round-review__board-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px;font-size:14px}.round-review__board-label{font-weight:700;color:#fff}.round-review__board-word{background:none;border:none;padding:0;font:inherit;color:var(--color-correct);font-weight:700;text-transform:uppercase;letter-spacing:2px;cursor:pointer;display:inline-flex;align-items:center;gap:.35rem}.round-review__board-word:focus-visible{outline:2px solid var(--color-focus);outline-offset:2px;border-radius:2px}.round-review__chevron{display:inline-block;transition:transform .15s ease-out;font-size:1.1em;color:#d7dadc;margin-left:.15em}.round-review__board-word.is-open .round-review__chevron{transform:rotate(90deg)}.round-review__board-lp{color:#818384}.round-review__def-panel{display:block;max-height:0;overflow:hidden;transition:max-height .15s ease-out}.round-review__def-panel--open{max-height:240px}.round-review__def-inner{padding:0 0 .5rem;line-height:1.35;font-size:13px;color:#d7dadc}.round-review__def-inner em{font-style:italic;margin-right:.25rem;color:#818384}.round-review__def-empty{font-style:italic;color:#818384}.round-review__guess-grid{display:flex;flex-direction:column;gap:4px;margin-bottom:12px}.round-review__guess-row{display:flex;gap:4px;justify-content:center}.round-review__guess-row--interactive{background:none;border:none;padding:0;margin:0;font:inherit;cursor:pointer;align-items:center;width:100%}.round-review__guess-row--interactive:focus-visible{outline:2px solid var(--color-focus);outline-offset:2px;border-radius:2px}.round-review__guess-row--interactive .round-review__chevron{margin-left:.35rem}.round-review__guess-row--interactive.is-open .round-review__chevron{transform:rotate(90deg)}.round-review__invalid-section{margin-top:6px;padding-top:6px;border-top:1px solid #3a3a3c;display:flex;flex-direction:column;gap:4px;align-items:center}.round-review__guess-row--invalid{outline:2px solid #b22222;outline-offset:2px;border-radius:4px;opacity:.7}.round-review__loading{text-align:center;color:#818384;padding:40px 0;font-style:italic}@media (max-width: 768px){.round-review__sheet{width:100%}.round-review__pill{font-size:12px;padding:5px 12px}}@media (prefers-reduced-motion: reduce){.round-review__sheet,.round-review__chevron,.round-review__def-panel{transition:none}}.round-review__source-badge{color:#6a6b6d;font-size:11px;font-style:normal;letter-spacing:.02em;white-space:nowrap}.sudden-death-lp-bar{background:linear-gradient(to bottom,#6464644d,#50505033);border:2px solid color-mix(in srgb,var(--color-sudden-death) 50%,transparent);box-shadow:0 0 15px color-mix(in srgb,var(--color-sudden-death) 30%,transparent),inset 0 0 20px #0003}.sudden-death-lp-bar.sudden-death-zero{background:linear-gradient(to bottom,#3c3c3c66,#2828284d);border-color:#96969699;box-shadow:0 0 10px #64646433,inset 0 0 15px #0000004d}.sudden-death-lp-value{color:#999!important;text-shadow:none!important;font-weight:500}.sudden-death-lp-loss{margin-top:8px;padding:6px 10px;background:linear-gradient(135deg,color-mix(in srgb,var(--color-sudden-death) 20%,transparent),color-mix(in srgb,var(--color-sudden-death) 15%,transparent));border:1px solid color-mix(in srgb,var(--color-sudden-death) 40%,transparent);border-radius:6px;display:flex;flex-direction:column;align-items:center;gap:2px;animation:sudden-death-pulse 2s ease-in-out infinite}.lp-loss-label{font-size:.7rem;color:color-mix(in srgb,var(--color-sudden-death) 80%,transparent);text-transform:uppercase;letter-spacing:.5px}.lp-loss-value{font-size:.9rem;font-weight:700;color:var(--color-sudden-death);text-shadow:0 0 8px color-mix(in srgb,var(--color-sudden-death) 40%,transparent)}.sudden-death-badge-wrapper{display:inline-flex;justify-content:center;margin-bottom:16px}.sudden-death-badge{display:inline-flex;align-items:center;gap:8px;padding:10px 20px;background:linear-gradient(135deg,color-mix(in srgb,var(--color-sudden-death),black 15%) 0%,var(--color-sudden-death) 50%,color-mix(in srgb,var(--color-sudden-death),white 15%) 100%);border:2px solid color-mix(in srgb,var(--color-sudden-death),black 25%);border-radius:25px;font-weight:800;font-size:1rem;color:#fff;text-shadow:0 1px 2px rgba(0,0,0,.3);box-shadow:0 0 20px color-mix(in srgb,var(--color-sudden-death) 50%,transparent),0 4px 15px color-mix(in srgb,var(--color-sudden-death) 30%,transparent);animation:badge-glow 2s ease-in-out infinite}.sudden-death-icon{font-size:1.2rem;animation:lightning-flash 1.5s ease-in-out infinite}.sudden-death-icon:last-child{animation-delay:.75s}.sudden-death-text{letter-spacing:1px}.sudden-death-overlay-container{position:fixed;top:0;left:0;right:0;bottom:0;z-index:1000;display:flex;align-items:center;justify-content:center;padding:20px}.sudden-death-backdrop{position:absolute;top:0;left:0;right:0;bottom:0;background:#000000d9;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.sudden-death-content{position:relative;z-index:1001;background:linear-gradient(145deg,#1a1a2e,#16213e,#1a1a2e);border:3px solid color-mix(in srgb,var(--color-sudden-death) 60%,transparent);border-radius:16px;padding:32px;max-width:500px;width:100%;box-shadow:0 0 40px color-mix(in srgb,var(--color-sudden-death) 30%,transparent),0 20px 60px #00000080;display:flex;flex-direction:column;align-items:center;text-align:center}.sudden-death-title{font-size:2rem;font-weight:800;color:var(--color-sudden-death);margin:0 0 12px;text-shadow:0 0 20px color-mix(in srgb,var(--color-sudden-death) 50%,transparent);letter-spacing:1px}.sudden-death-description{font-size:1rem;color:#ffffffe6;line-height:1.5;margin:0 0 20px;max-width:400px}.sudden-death-round-info{display:flex;gap:12px;margin-bottom:24px;flex-wrap:wrap;justify-content:center}.round-label,.sudden-death-number{padding:6px 12px;background:color-mix(in srgb,var(--color-sudden-death) 15%,transparent);border:1px solid color-mix(in srgb,var(--color-sudden-death) 30%,transparent);border-radius:20px;font-size:.85rem;color:var(--color-sudden-death)}.sudden-death-number{background:color-mix(in srgb,var(--color-sudden-death) 20%,transparent);border-color:color-mix(in srgb,var(--color-sudden-death) 40%,transparent);color:color-mix(in srgb,var(--color-sudden-death),white 15%);font-weight:600}.sudden-death-lp-counters{display:flex;gap:20px;margin-bottom:24px;width:100%;justify-content:center;flex-wrap:wrap}.lp-sudden-death-counter{background:#0000004d;border:2px solid color-mix(in srgb,var(--color-sudden-death) 40%,transparent);border-radius:12px;padding:16px 24px;display:flex;flex-direction:column;align-items:center;gap:6px;min-width:140px;transition:all .3s ease}.lp-sudden-death-counter.updating{border-color:#ffd70099;box-shadow:0 0 20px #ffd70033}.lp-bar-sudden-death-wrapper{display:flex;flex-direction:column;align-items:center;gap:8px;width:80px}.lp-bar-sudden-death-wrapper .lp-bar-label{font-size:.875rem;color:#818384}.lp-bar-sudden-death-wrapper .lp-sudden-death-counter{padding:10px 8px;min-width:auto;width:100%;border-radius:8px;background:linear-gradient(135deg,color-mix(in srgb,var(--color-sudden-death) 15%,transparent),color-mix(in srgb,var(--color-sudden-death) 10%,transparent));border:2px solid color-mix(in srgb,var(--color-sudden-death) 40%,transparent)}.lp-bar-sudden-death-wrapper .lp-sudden-death-counter.updating{border-color:#ffd700cc;box-shadow:0 0 15px #ffd7004d;background:linear-gradient(135deg,color-mix(in srgb,var(--color-sudden-death) 25%,transparent),color-mix(in srgb,var(--color-sudden-death) 20%,transparent))}.lp-bar-sudden-death-wrapper .lp-counter-label{font-size:.65rem}.lp-bar-sudden-death-wrapper .lp-counter-value{font-size:1.4rem}.lp-bar-sudden-death-wrapper .lp-counter-unit{font-size:.75rem}.lp-counter-label{font-size:.8rem;color:#ffffffb3;text-transform:uppercase;letter-spacing:.5px}.lp-counter-value{font-size:1.8rem;font-weight:800;color:var(--color-sudden-death);text-shadow:0 0 15px color-mix(in srgb,var(--color-sudden-death) 40%,transparent);transition:transform .15s ease}.lp-sudden-death-counter.updating .lp-counter-value{transform:scale(1.15)}.lp-counter-unit{font-size:1rem;font-weight:600;color:color-mix(in srgb,var(--color-sudden-death) 80%,transparent)}.sudden-death-status{display:flex;align-items:center;gap:10px;padding:12px 20px;border-radius:8px;margin-bottom:20px;font-weight:600;font-size:.95rem}.sudden-death-status.neutral{background:#64646433;border:1px solid rgba(150,150,150,.4);color:#ffffffe6}.sudden-death-status.winning{background:#22c55e26;border:1px solid rgba(34,197,94,.4);color:#22c55e}.sudden-death-status.losing{background:color-mix(in srgb,var(--color-error) 15%,transparent);border:1px solid color-mix(in srgb,var(--color-error) 40%,transparent);color:var(--color-error)}.sudden-death-status.tied{background:#ffffff14;border:1px solid rgba(255,255,255,.25);color:#ffffffb3}.status-icon{font-size:1.2rem}.sudden-death-current-lp{display:flex;gap:24px;margin-bottom:24px;flex-wrap:wrap;justify-content:center}.lp-display-player{display:flex;flex-direction:column;align-items:center;gap:4px}.lp-display-label{font-size:.75rem;color:#fff9;text-transform:uppercase;letter-spacing:.5px}.lp-display-value{font-size:1.2rem;font-weight:700;color:#fff}.lp-display-value.zero{color:#999;text-decoration:line-through;opacity:.7}.sudden-death-close{padding:12px 32px;background:linear-gradient(135deg,color-mix(in srgb,var(--color-sudden-death),black 15%) 0%,var(--color-sudden-death) 100%);border:none;border-radius:8px;color:#fff;font-weight:700;font-size:1rem;cursor:pointer;transition:all .2s ease;box-shadow:0 4px 15px color-mix(in srgb,var(--color-sudden-death) 30%,transparent)}.sudden-death-close:hover{transform:translateY(-2px);box-shadow:0 6px 20px color-mix(in srgb,var(--color-sudden-death) 40%,transparent)}.sudden-death-close:active{transform:translateY(0)}.sudden-death-close:focus{outline:2px solid var(--color-sudden-death);outline-offset:2px}@keyframes badge-glow{0%,to{box-shadow:0 0 20px color-mix(in srgb,var(--color-sudden-death) 50%,transparent),0 4px 15px color-mix(in srgb,var(--color-sudden-death) 30%,transparent)}50%{box-shadow:0 0 30px color-mix(in srgb,var(--color-sudden-death) 70%,transparent),0 4px 20px color-mix(in srgb,var(--color-sudden-death) 50%,transparent)}}@keyframes lightning-flash{0%,to{opacity:1;transform:scale(1)}50%{opacity:.6;transform:scale(1.1)}}@keyframes sudden-death-pulse{0%,to{box-shadow:0 0 10px color-mix(in srgb,var(--color-sudden-death) 20%,transparent)}50%{box-shadow:0 0 20px color-mix(in srgb,var(--color-sudden-death) 40%,transparent)}}@media (max-width: 600px){.sudden-death-content{padding:24px 16px;margin:10px}.sudden-death-title{font-size:1.5rem}.sudden-death-description{font-size:.9rem}.sudden-death-badge{padding:8px 16px;font-size:.9rem}.sudden-death-icon{font-size:1rem}.sudden-death-lp-counters{gap:12px}.lp-sudden-death-counter{padding:12px 16px;min-width:120px}.lp-counter-value{font-size:1.4rem}.sudden-death-current-lp{gap:16px}.sudden-death-lp-loss{padding:4px 8px}.lp-loss-value{font-size:.8rem}}@media (max-width: 400px){.sudden-death-lp-counters{flex-direction:column;width:100%}.lp-sudden-death-counter{width:100%}}@media (prefers-reduced-motion: reduce){.sudden-death-badge,.sudden-death-icon,.sudden-death-lp-loss,.lp-sudden-death-counter{animation:none}.sudden-death-close{transition:none}.lp-sudden-death-counter.updating{box-shadow:none}}.push-opt-in{width:100%;padding:16px 20px;background:color-mix(in srgb,var(--color-correct) 8%,transparent);border:1px solid color-mix(in srgb,var(--color-correct) 25%,transparent);border-radius:12px;display:flex;flex-direction:column;align-items:center;gap:12px}.push-opt-in__content{text-align:center}.push-opt-in__title{font-size:1rem;font-weight:700;color:#d7dadc;margin:0 0 4px}.push-opt-in__subtitle{font-size:.8rem;color:#818384;margin:0}.push-opt-in__actions{display:flex;gap:10px;width:100%;justify-content:center}.push-opt-in__enable{background:var(--color-correct);color:#fff;border:none;padding:10px 20px;border-radius:6px;font-size:.875rem;font-weight:600;cursor:pointer;transition:background .15s}.push-opt-in__enable:hover:not(:disabled){background:color-mix(in srgb,var(--color-correct),white 15%)}.push-opt-in__enable:disabled{opacity:.7;cursor:not-allowed}.push-opt-in__dismiss{background:transparent;color:#818384;border:1px solid #3a3a3c;padding:10px 16px;border-radius:6px;font-size:.875rem;cursor:pointer;transition:border-color .15s,color .15s}.push-opt-in__dismiss:hover:not(:disabled){border-color:#818384;color:#d7dadc}.push-opt-in__permanent{display:flex;align-items:center;gap:6px;font-size:.75rem;color:#818384;cursor:pointer}.push-opt-in__permanent input[type=checkbox]{accent-color:var(--color-correct);cursor:pointer}.toast{position:fixed;bottom:24px;left:50%;transform:translate(-50%) translateY(100%);background:#333;color:#fff;padding:12px 24px;border-radius:8px;font-size:.9rem;font-weight:500;z-index:1000;cursor:pointer;opacity:0;transition:transform .3s ease,opacity .3s ease;pointer-events:none;white-space:nowrap;box-shadow:0 4px 12px #0006}.toast--visible{transform:translate(-50%) translateY(0);opacity:1;pointer-events:auto}@media (prefers-reduced-motion: reduce){.toast{transition:opacity .15s ease}.toast--visible{transform:translate(-50%) translateY(0)}}.mode-length-badge{font-size:.875rem;color:var(--text-muted, #818384);font-weight:500;letter-spacing:.02em}.end-game-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#121213eb;display:flex;align-items:center;justify-content:center;z-index:100;padding:20px;overflow:hidden}.end-game-card{background:#1a1a1b;border:1px solid #3a3a3c;border-radius:16px;padding:20px 24px;max-width:420px;width:100%;max-height:90vh;overflow-y:auto;display:flex;flex-direction:column;align-items:center;gap:12px;animation:end-game-appear .3s ease-out}@keyframes end-game-appear{0%{opacity:0;transform:scale(.9)}to{opacity:1;transform:scale(1)}}@media (prefers-reduced-motion: reduce){.end-game-card{animation:none}}.end-game-result{font-size:2rem;font-weight:700;margin:0;text-transform:uppercase;letter-spacing:.05em}.result-win{color:var(--color-correct)}.result-lose{color:var(--color-error)}.end-game-word{display:flex;flex-direction:column;align-items:center;gap:4px}.word-label{font-size:.875rem;color:#818384}.word-value{font-size:1.5rem;font-weight:700;letter-spacing:.2em;color:var(--color-present)}.end-game-scores{display:flex;align-items:center;gap:16px;padding:12px 0}.score-player{display:flex;flex-direction:column;align-items:center;gap:4px;padding:8px 16px;border-radius:8px}.score-you{background:color-mix(in srgb,var(--color-correct) 10%,transparent);border:1px solid color-mix(in srgb,var(--color-correct) 30%,transparent)}.score-label{font-size:.75rem;color:#818384;text-transform:uppercase}.score-lp{font-size:1.25rem;font-weight:700;color:#fff}.score-divider{color:#818384;font-size:.875rem}.ready-up-container{display:flex;flex-direction:column;align-items:center;gap:12px;width:100%}.ready-up-button{background:var(--color-correct);color:#fff;border:none;padding:14px 32px;border-radius:8px;font-size:1.125rem;font-weight:700;cursor:pointer;transition:background .2s,transform .1s;width:100%;max-width:260px}.ready-up-button:hover:not(:disabled){background:color-mix(in srgb,var(--color-correct),white 15%);transform:translateY(-1px)}.ready-up-button:disabled{cursor:default}.ready-up-confirmed{background:#3a5a35;border:2px solid var(--color-correct)}.ready-up-status{display:flex;gap:24px}.ready-indicator{display:flex;align-items:center;gap:6px;font-size:.875rem;color:#818384}.ready-indicator.ready{color:var(--color-correct)}.ready-check{font-size:1rem;width:20px;text-align:center}.ready-waiting-text{font-size:.75rem;color:#818384;margin:0;animation:ready-pulse 1.5s infinite ease-in-out}@keyframes ready-pulse{0%,to{opacity:.5}50%{opacity:1}}.end-game-leave{background:transparent;border:1px solid #3a3a3c;color:#818384;padding:8px 16px;border-radius:4px;cursor:pointer;font-size:.875rem;margin-top:0;min-height:44px;width:100%;max-width:260px}.end-game-leave:hover{border-color:#818384;color:#fff}.sudden-death-overlay{background:#281e0af2;animation:sudden-death-pulse 2s infinite ease-in-out}@keyframes sudden-death-pulse{0%,to{background:#281e0af2}50%{background:#3c2d0ff2}}@media (prefers-reduced-motion: reduce){.sudden-death-overlay{animation:none}}.sudden-death-card{border:2px solid #e69138;box-shadow:0 0 30px #e691384d,inset 0 0 20px #e691381a;background:linear-gradient(180deg,#1a1a1b,#1f1a15);gap:14px;padding:24px 32px}.sudden-death-badge{display:flex;align-items:center;gap:8px;padding:8px 16px;background:linear-gradient(90deg,#e69138,#f9c74f,#e69138);border-radius:24px;font-weight:700;font-size:.875rem;color:#1a1a1b;text-transform:uppercase;letter-spacing:.1em;animation:badge-glow 1.5s infinite ease-in-out}@keyframes badge-glow{0%,to{box-shadow:0 0 10px #e6913880}50%{box-shadow:0 0 20px #e69138cc,0 0 30px #f9c74f66}}.sudden-death-icon{font-size:1rem;animation:lightning-flash .8s infinite alternate}@keyframes lightning-flash{0%{opacity:.7;transform:scale(.95)}to{opacity:1;transform:scale(1.05)}}.sudden-death-text{font-weight:900}.sudden-death-title{font-size:1.5rem;font-weight:700;color:#f9c74f;margin:0;text-align:center}.sudden-death-description{font-size:.9rem;color:#d7dadc;text-align:center;margin:0;line-height:1.5}.sudden-death-round-info{display:flex;flex-direction:column;align-items:center;gap:4px;padding:8px 16px;background:#e691381a;border:1px solid rgba(230,145,56,.3);border-radius:8px}.round-label{font-size:.875rem;color:#e69138;font-weight:700}.sudden-death-number{font-size:.75rem;color:#f9c74f;text-transform:uppercase;letter-spacing:.05em}.sudden-death-scores{padding:16px;background:#e691380d;border-radius:12px;border:1px solid rgba(230,145,56,.2)}.sudden-death-next{margin-top:8px}.next-indicator{font-size:.875rem;color:#818384;font-style:italic;animation:next-pulse 1.5s infinite ease-in-out}@keyframes next-pulse{0%,to{opacity:.5}50%{opacity:1}}.end-game-final-stats{display:flex;justify-content:center;padding:0;margin:0}.final-rounds{font-size:.75rem;color:#818384;font-style:italic}.end-game-review-btn{width:100%;max-width:260px;background:#ffffff0f;border:1px solid #3a3a3c;color:#d7dadc;border-radius:6px;padding:10px 14px;font-size:14px;font-weight:400;cursor:pointer;transition:background .15s,border-color .15s;min-height:40px}.end-game-review-btn:hover{background:#ffffff1a;border-color:#818384}.end-game-review-btn:focus-visible{outline:2px solid rgba(215,218,220,.6);outline-offset:2px}.end-game-card.sudden-death-winner{border:3px solid #ffd700;background:linear-gradient(145deg,#1a1a1b,#1f1a10 30%,#1a1a1b);box-shadow:0 0 50px #ffd70066,0 0 100px #ff8c0033,inset 0 0 30px #ffd7001a;animation:sudden-death-winner-glow 2s ease-in-out infinite}@keyframes sudden-death-winner-glow{0%,to{box-shadow:0 0 50px #ffd70066,0 0 100px #ff8c0033,inset 0 0 30px #ffd7001a}50%{box-shadow:0 0 70px #ffd70099,0 0 120px #ff8c004d,inset 0 0 40px #ffd70026}}.end-game-result.sudden-death-win{background:linear-gradient(90deg,gold,#ff8c00,gold);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;text-shadow:none;filter:drop-shadow(0 0 10px rgba(255,215,0,.5));animation:sudden-death-text-shimmer 2s linear infinite;font-size:1.2rem;white-space:nowrap;letter-spacing:.08em}@keyframes sudden-death-text-shimmer{0%{background-position:-200% center}to{background-position:200% center}}.sudden-death-winner-badge{display:flex;align-items:center;gap:6px;padding:6px 14px;background:linear-gradient(90deg,gold,#ff8c00);border-radius:20px;font-size:.75rem;font-weight:800;color:#1a1a1b;text-transform:uppercase;letter-spacing:.1em;margin-bottom:8px;box-shadow:0 2px 10px #ffd70066}.sudden-death-winner-badge:before{content:"👑";font-size:1rem}.sudden-death-win-message{font-size:1rem;color:gold;text-align:center;font-weight:600;line-height:1.5;padding:12px 20px;background:#ffd7001a;border:1px solid rgba(255,215,0,.3);border-radius:8px;margin:8px 0}.sudden-death-win-message strong{color:#ff8c00;display:block;font-size:1.1rem;margin-bottom:4px}.sudden-death-winner-stats{display:flex;flex-direction:column;gap:6px;width:100%;padding:14px;background:#ffd7000d;border:1px solid rgba(255,215,0,.2);border-radius:12px}.sudden-death-stat-row{display:flex;justify-content:space-between;align-items:center;font-size:.9rem}.sudden-death-stat-row.sudden-death-stat-diff{margin-top:4px;padding-top:8px;border-top:1px solid rgba(255,215,0,.15);font-size:1rem}.sudden-death-stat-diff .sudden-death-stat-value{font-size:1.1rem}.sudden-death-stat-label{color:#818384}.sudden-death-stat-value{color:gold;font-weight:700}.sudden-death-sparkles{position:absolute;top:0;left:0;right:0;bottom:0;pointer-events:none;overflow:hidden;border-radius:16px}.sudden-death-sparkles:before,.sudden-death-sparkles:after{content:"✦";position:absolute;color:gold;font-size:1.5rem;animation:sparkle-float 3s ease-in-out infinite;opacity:0}.sudden-death-sparkles:before{top:10%;left:10%;animation-delay:0s}.sudden-death-sparkles:after{top:20%;right:10%;animation-delay:1.5s}@keyframes sparkle-float{0%,to{opacity:0;transform:translateY(0) scale(.5) rotate(0)}50%{opacity:.8;transform:translateY(-20px) scale(1) rotate(180deg)}}.sudden-death-tie-message{font-size:1rem;color:#d7dadc;text-align:center;font-weight:600;padding:12px 20px;background:#64646433;border:1px solid rgba(150,150,150,.4);border-radius:8px;margin:8px 0}.sudden-death-scores.winner-display{background:#ffd7001a;border:2px solid rgba(255,215,0,.4);box-shadow:0 0 20px #ffd70026}.score-player.sudden-death-winner{background:#ffd70026;border:2px solid rgba(255,215,0,.5);box-shadow:0 0 15px #ffd70033;animation:winner-pulse 2s ease-in-out infinite}@keyframes winner-pulse{0%,to{box-shadow:0 0 15px #ffd70033;transform:scale(1)}50%{box-shadow:0 0 25px #ffd70066;transform:scale(1.02)}}@media (max-width: 600px){.end-game-card.sudden-death-winner{padding:20px 16px;gap:10px}.end-game-result.sudden-death-win{font-size:1.1rem}.sudden-death-win-message{font-size:.85rem;padding:8px 14px}.sudden-death-winner-stats{padding:10px}.sudden-death-stat-row{font-size:.8rem}}@media (max-width: 600px){.end-game-card{padding:16px;gap:10px}.end-game-leave{min-height:40px;font-size:.8rem;padding:8px 16px}.end-game-review-btn{padding:9px 12px;min-height:38px}}.end-game-sign-in{display:flex;flex-direction:column;align-items:center;gap:6px;width:100%;padding-top:8px;border-top:1px solid #3a3a3c}.end-game-sign-in__text{font-size:.75rem;color:#818384;margin:0}.end-game-sign-in__btn{background:transparent;border:1px solid #3a3a3c;color:#d7dadc;padding:8px 20px;border-radius:6px;font-size:.875rem;cursor:pointer;transition:border-color .15s,color .15s}.end-game-sign-in__btn:hover:not(:disabled){border-color:#818384;color:#fff}.end-game-sign-in__btn:disabled{opacity:.6;cursor:not-allowed}.end-game-sign-in__error{font-size:.75rem;color:#c84b31}@media (prefers-reduced-motion: reduce){.end-game-card.sudden-death-winner,.end-game-result.sudden-death-win,.score-player.sudden-death-winner{animation:none}.sudden-death-sparkles:before,.sudden-death-sparkles:after{animation:none;opacity:.5}}.end-game-badge-row{display:flex;justify-content:center;margin:-8px 0 16px}.help-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background:#000000bf;z-index:1000;display:flex;align-items:center;justify-content:center}.help-card{background:#121213;border:2px solid #3a3a3c;border-radius:12px;padding:2rem;max-width:440px;width:90%;max-height:80vh;overflow-y:auto;position:relative}.help-close-btn{position:absolute;top:12px;right:12px;background:transparent;border:1px solid #3a3a3c;color:#818384;width:32px;height:32px;border-radius:50%;font-size:20px;cursor:pointer;display:flex;align-items:center;justify-content:center;padding:0;line-height:1;transition:border-color .2s,color .2s}.help-close-btn:hover{border-color:#d7dadc;color:#d7dadc}.help-card h2{color:#fff;margin:0 0 1.25rem;font-size:1.5rem}.help-card h3{color:#d7dadc;margin:1.25rem 0 .5rem;font-size:1.1rem}.help-card p{color:#818384;line-height:1.6;margin:0 0 .75rem;font-size:.95rem}.help-card strong{color:#d7dadc}.help-tile{display:inline-flex;align-items:center;justify-content:center;width:24px;height:24px;border-radius:3px;font-size:13px;font-weight:700;color:#fff;vertical-align:middle}.help-tile-correct{background:var(--color-correct)}.help-tile-present{background:var(--color-present)}.help-tile-absent{background:#3a3a3c}.help-highlight-correct{color:var(--color-correct);font-weight:600}.help-highlight-present{color:var(--color-present);font-weight:600}.help-highlight-absent{color:#818384;font-weight:600}.help-card__footer{margin-top:1.5rem;padding-top:1rem;border-top:1px solid #3a3a3c}.help-card__footer-line{color:#6a6b6d;font-size:.8rem;line-height:1.4;margin:0 0 .4rem}@media (max-width: 480px){.help-card{padding:1.5rem}}.ios-sheet__overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0009;display:flex;align-items:flex-end;justify-content:center;z-index:1000;animation:ios-sheet-fade .2s ease-out}@keyframes ios-sheet-fade{0%{opacity:0}to{opacity:1}}.ios-sheet{position:relative;background:#1f1f22;border-radius:16px 16px 0 0;max-width:480px;width:100%;padding:24px 24px 32px;color:#d7dadc;animation:ios-sheet-slide .25s ease-out;box-shadow:0 -8px 32px #00000080}@keyframes ios-sheet-slide{0%{transform:translateY(100%)}to{transform:translateY(0)}}.ios-sheet__close{position:absolute;top:12px;right:12px;background:transparent;border:none;color:#818384;cursor:pointer;padding:8px;line-height:0;border-radius:4px}.ios-sheet__close:hover{color:#d7dadc}.ios-sheet__title{font-size:1.25rem;margin:0 0 16px;color:#fff;padding-right:32px}.ios-sheet__steps{margin:0 0 16px;padding-left:20px;line-height:1.7;font-size:.95rem}.ios-sheet__steps li{margin-bottom:8px}.ios-sheet__inline-icon{display:inline-block;vertical-align:-3px;margin:0 2px}.ios-sheet__benefit{font-size:.85rem;color:#818384;margin:0}.ios-sheet__warning{background:#2a2a2d;border-left:3px solid #ea580c;padding:12px 16px;border-radius:4px}.ios-sheet__warning p{margin:0}.ios-sheet__warning-sub{font-size:.85rem;color:#818384;margin-top:6px!important}@media (min-width: 600px){.ios-sheet__overlay{align-items:center}.ios-sheet{border-radius:16px}}.install-section{margin-top:24px;display:flex;flex-direction:column;align-items:center;gap:6px}.install-button{display:inline-flex;align-items:center;gap:8px;padding:10px 20px;background:transparent;border:1px solid #3a3a3c;border-radius:8px;color:#818384;font-size:.875rem;font-weight:500;cursor:pointer;transition:border-color .2s,color .2s;white-space:nowrap}.install-button:hover{border-color:#818384;color:#d7dadc}.install-hint{font-size:.75rem;color:#565758;margin:0}.install-button-compact{background:transparent;border:1px solid var(--wd-grey-700);color:var(--wd-grey-500);height:36px;width:36px;border-radius:6px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:border-color .2s,color .2s;padding:0}.install-button-compact:hover{border-color:#d7dadc;color:#d7dadc}.waiting-room{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:80vh;padding:32px 20px;text-align:center}.waiting-room h1{font-size:1.75rem;margin:0 0 24px;color:#fff}.waiting-dots{display:flex;gap:10px;justify-content:center;margin-bottom:32px}.waiting-dots span{width:12px;height:12px;border-radius:50%;background:var(--color-correct);animation:waiting-pulse 1.4s infinite ease-in-out}.waiting-dots span:nth-child(1){animation-delay:0s}.waiting-dots span:nth-child(2){animation-delay:.2s}.waiting-dots span:nth-child(3){animation-delay:.4s}@keyframes waiting-pulse{0%,to{opacity:.3;transform:scale(.8)}50%{opacity:1;transform:scale(1.2)}}@media (prefers-reduced-motion: reduce){.waiting-dots span{animation:none;opacity:1}}.room-code-display{background:#1a1a1b;border:1px solid #3a3a3c;border-radius:12px;padding:24px 32px;display:flex;flex-direction:column;align-items:center;gap:12px;max-width:400px;width:100%}.room-code-label{font-size:.875rem;color:#818384;text-transform:uppercase;letter-spacing:.1em}.room-code-value{display:flex;gap:6px}.room-code-char{width:48px;height:56px;display:inline-flex;justify-content:center;align-items:center;font-size:1.75rem;font-weight:700;font-family:monospace;background:#121213;border:2px solid var(--color-correct);border-radius:4px;color:#fff;letter-spacing:0}.room-code-qr{display:flex;justify-content:center;align-items:center;background:#fff;padding:12px;border-radius:8px;margin:16px auto;width:fit-content}.room-code-qr svg{display:block;width:176px;height:176px}.copy-button{background:var(--color-correct);color:#fff;border:none;padding:10px 20px;border-radius:8px;cursor:pointer;font-size:.875rem;font-weight:500;transition:background .2s;min-width:120px}.copy-button:hover{background:color-mix(in srgb,var(--color-correct),white 15%)}.copy-button-link{background:transparent;border:1px solid #3a3a3c;color:#818384}.copy-button-link:hover{border-color:#818384;color:#fff}.share-prompt{color:#818384;font-size:.875rem;margin:8px 0 0}.share-url{font-size:.75rem;color:#818384;word-break:break-all;max-width:100%;padding:8px 12px;background:#121213;border:1px solid #3a3a3c;border-radius:4px}.lobby-word-section{margin-top:24px;display:flex;flex-direction:column;align-items:center;gap:8px;max-width:400px;width:100%}.lobby-word-label{font-size:.875rem;color:#818384;margin:0}.lobby-word-input-row{display:flex;gap:8px;align-items:center}.lobby-word-input{width:120px;padding:10px 12px;font-size:1.25rem;font-family:monospace;font-weight:700;letter-spacing:.2em;text-align:center;text-transform:uppercase;background:#121213;border:2px solid #3a3a3c;border-radius:4px;color:#fff;outline:none}.lobby-word-input:focus{border-color:var(--color-correct)}.lobby-word-locked{font-size:.875rem;color:var(--color-correct);margin:0}.lobby-word-error{font-size:.75rem;color:#b44;margin:0}.waiting-cancel{margin-top:24px;background:transparent;border:1px solid #3a3a3c;color:#818384;padding:8px 16px;border-radius:4px;cursor:pointer;font-size:.875rem}.waiting-cancel:hover{border-color:#818384;color:#fff}.landing-screen{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:80vh;padding:32px 20px;text-align:center}.landing-wordmark{display:block;width:100%;max-width:min(80vw,320px);height:auto;margin:0 auto 8px}.landing-subtitle{font-size:1rem;color:#818384;margin:0 0 48px}.landing-actions{display:flex;flex-direction:column;gap:16px;width:100%;max-width:300px}.landing-button{padding:14px 28px;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:background .2s;width:100%}.landing-button-primary{background:var(--color-correct);color:#fff;border:none}.landing-button-primary:hover{background:color-mix(in srgb,var(--color-correct),white 15%)}.landing-button-secondary{background:transparent;border:1px solid #3a3a3c;color:#818384}.landing-button-secondary:hover{border-color:#818384;color:#fff}.mode-length-picker{display:flex;flex-direction:column;gap:14px;width:100%;max-width:300px;margin:0 0 24px;align-items:stretch}.mode-length-picker-row{display:flex;flex-direction:column;gap:6px;width:100%}.mode-length-picker-label{font-size:.75rem;text-transform:uppercase;letter-spacing:.08em;color:#818384;text-align:left}.mode-length-picker-segment{display:flex;gap:8px;width:100%}.mode-length-picker-option{flex:1 1 auto;min-height:44px;min-width:44px;padding:10px 12px;border-radius:8px;border:1px solid #3a3a3c;background:transparent;color:#d7dadc;font-size:.95rem;font-weight:600;cursor:pointer;transition:background .15s,border-color .15s,color .15s}.mode-length-picker-option:hover:not(:disabled){border-color:#818384;color:#fff}.mode-length-picker-option.active{background:var(--color-correct);border-color:var(--color-correct);color:#fff}.mode-length-picker-option.disabled,.mode-length-picker-option:disabled{color:#4b4b4d;border-color:#2a2a2c;cursor:not-allowed;background:transparent}.mode-length-picker-hint{font-size:.8rem;color:#818384;margin-top:4px;text-align:left;line-height:1.3;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.join-room-screen{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:80vh;padding:32px 20px;text-align:center}.join-room-screen h1{font-size:1.75rem;margin:0 0 8px;color:#fff}.join-subtitle{font-size:.875rem;color:#818384;margin:0 0 32px}.join-input{background:#121213;border:2px solid #3a3a3c;border-radius:8px;color:#fff;font-family:monospace;font-size:1.75rem;font-weight:700;letter-spacing:.3em;text-align:center;padding:16px;width:100%;max-width:280px;outline:none;text-transform:uppercase}.join-input:focus{border-color:var(--color-correct)}.join-input:disabled{opacity:.5}.join-error{color:var(--color-error);font-size:.875rem;margin:8px 0 0}.join-actions{display:flex;flex-direction:column;gap:12px;width:100%;max-width:280px;margin-top:24px}.join-submit{background:var(--color-correct);color:#fff;border:none;padding:14px;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;width:100%;transition:background .2s}.join-submit:disabled{opacity:.5;cursor:default}.join-submit:hover:not(:disabled){background:color-mix(in srgb,var(--color-correct),white 15%)}.join-cancel{background:transparent;border:1px solid #3a3a3c;color:#818384;padding:14px;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;width:100%;transition:border-color .2s,color .2s}.join-cancel:disabled{opacity:.5;cursor:default}.join-cancel:hover:not(:disabled){border-color:#818384;color:#fff}.nav-header{position:sticky;top:0;z-index:100;width:100%;background:#121213;border-bottom:1px solid #3a3a3c;display:flex;align-items:center;justify-content:space-between;padding:0 1.25rem;height:3rem;box-sizing:border-box}.nav-header__title{font-size:1rem;font-weight:700;color:#fff;letter-spacing:.05em;text-transform:uppercase;text-decoration:none;background:none;border:none;padding:0;cursor:pointer}.nav-header__logo{display:block;width:32px;height:32px}.nav-header__auth{display:flex;align-items:center;gap:.5rem}.nav-header__sign-in{background:transparent;border:none;color:#818384;font-size:.875rem;cursor:pointer;padding:.25rem .5rem;border-radius:.25rem;text-decoration:underline}.nav-header__sign-in:hover{color:#fff}.nav-header__avatar{width:2rem;height:2rem;border-radius:50%;display:inline-flex;align-items:center;justify-content:center;font-size:.75rem;font-weight:700;color:#fff;cursor:pointer;flex-shrink:0}.nav-header__sign-out{background:transparent;border:1px solid #3a3a3c;color:#818384;font-size:.8rem;cursor:pointer;padding:.25rem .625rem;border-radius:.25rem}.nav-header__sign-out:hover{border-color:#818384;color:#fff}.nav-header__dropdown-wrap{position:relative}.nav-header__dropdown{position:absolute;top:calc(100% + .5rem);right:0;background:#1a1a1b;border:1px solid #3a3a3c;border-radius:.375rem;padding:.5rem;min-width:10rem;display:flex;flex-direction:column;gap:.25rem;z-index:200}.nav-header__dropdown-name{font-size:.8125rem;color:#818384;padding:.25rem .5rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.nav-header__error{font-size:.75rem;color:#c84b31}.account-screen{max-width:480px;margin:0 auto;padding:1.5rem 1rem;color:#fff}.account-screen__title{font-size:1.4rem;font-weight:700;margin-bottom:1.5rem}.account-display-name{margin-bottom:1.5rem;padding-bottom:1.5rem;border-bottom:1px solid #3a3a3c}.account-display-name__label{font-size:.75rem;text-transform:uppercase;letter-spacing:.08em;color:#818384;margin-bottom:.375rem}.account-display-name__value{font-size:1.1rem;font-weight:600;margin-bottom:.5rem}.account-display-name__edit-btn{background:none;border:1px solid #3a3a3c;color:#818384;font-size:.8rem;cursor:pointer;padding:.25rem .75rem;border-radius:4px}.account-display-name__edit-btn:hover{border-color:#818384;color:#fff}.account-display-name__edit-form{display:flex;flex-direction:column;gap:.5rem}.account-display-name__form-actions{display:flex;gap:.5rem}.account-display-name__input{background:#1a1a1b;border:1px solid #3a3a3c;color:#fff;font-size:1rem;padding:.5rem .75rem;border-radius:4px;width:100%;box-sizing:border-box}.account-display-name__input:focus{outline:none;border-color:#818384}.account-display-name__save-btn{background:var(--color-correct);border:none;color:#fff;font-size:.9rem;cursor:pointer;padding:.4rem 1rem;border-radius:4px;font-weight:600}.account-display-name__save-btn:disabled{opacity:.6;cursor:not-allowed}.account-display-name__cancel-btn{background:none;border:1px solid #3a3a3c;color:#818384;font-size:.9rem;cursor:pointer;padding:.4rem .75rem;border-radius:4px}.account-display-name__feedback{font-size:.8rem;padding:.25rem 0}.account-display-name__feedback--success{color:var(--color-correct)}.account-display-name__feedback--error{color:#c84b31}.account-screen__email{margin-bottom:1.5rem;padding-bottom:1.5rem;border-bottom:1px solid #3a3a3c}.account-screen__email-label{font-size:.75rem;text-transform:uppercase;letter-spacing:.08em;color:#818384;margin-bottom:.375rem}.account-screen__email-value{font-size:.95rem;color:#818384}.account-screen__sign-out{background:none;border:1px solid #3a3a3c;color:#818384;font-size:.875rem;cursor:pointer;padding:.5rem 1rem;border-radius:4px}.account-screen__sign-out:hover{border-color:#818384;color:#fff}.account-screen__guest{text-align:center;padding:2rem 0}.account-screen__guest-text{color:#818384;margin-bottom:1rem}.account-screen__sign-in{background:var(--color-correct);border:none;color:#fff;font-size:.95rem;cursor:pointer;padding:.625rem 1.25rem;border-radius:4px;font-weight:600}.account-screen__sign-in:disabled{opacity:.6;cursor:not-allowed}.account-screen__sign-in-error{color:#c84b31;font-size:.8rem;margin-top:.5rem}.account-screen__sign-in--discord{background:#5865f2;border-color:#5865f2;color:#fff;margin-top:8px}.account-screen__sign-in--discord:hover:not(:disabled){background:#4752c4;border-color:#4752c4}.account-screen__sign-in--discord:disabled{opacity:.6;cursor:not-allowed}.nav-header__profile-link{display:block;padding:6px 12px;color:#fff;text-decoration:none;font-size:.9rem;border-radius:.25rem}.nav-header__profile-link:hover{background:#ffffff14}.update-toast{position:fixed;bottom:1.5rem;left:50%;transform:translate(-50%);display:flex;align-items:center;gap:1rem;background:#1a1a1b;border:1px solid #3a3a3c;color:#fff;padding:.75rem 1.25rem;border-radius:.5rem;box-shadow:0 4px 16px #00000080;z-index:9999;white-space:nowrap;font-size:.9rem}.update-toast__message{flex:1}.update-toast__actions{display:flex;gap:.5rem}.update-toast__btn{border:none;border-radius:.25rem;padding:.375rem .75rem;font-size:.85rem;cursor:pointer;font-weight:600}.update-toast__btn--primary{background:color-mix(in srgb,var(--color-correct),white 25%);color:#fff}.update-toast__btn--primary:hover{background:var(--color-correct)}.update-toast__btn--secondary{background:#3a3a3c;color:#d7dadc}.update-toast__btn--secondary:hover{background:#4a4a4c}.offline-banner{position:fixed;bottom:0;left:0;right:0;background:var(--color-present);color:#121213;text-align:center;padding:10px 16px;font-size:.85rem;font-weight:600;z-index:500}.reconnecting-screen{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;gap:1rem;padding:2rem;text-align:center}.reconnecting-screen h1{font-size:1.5rem;color:#fff;margin:0}.reconnecting-screen p{color:#818384;margin:0}.reconnect-modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000bf;display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem}.reconnect-modal{background:#1a1a1b;border:1px solid #3a3a3c;border-radius:.75rem;padding:2rem;max-width:360px;width:100%;text-align:center;display:flex;flex-direction:column;gap:1rem}.reconnect-modal h2{font-size:1.25rem;color:#fff;margin:0}.reconnect-modal p{color:#818384;font-size:.9rem;line-height:1.5;margin:0}.reconnect-modal__actions{display:flex;gap:.75rem;justify-content:center;flex-wrap:wrap;margin-top:.5rem}.reconnect-modal__btn{border:none;border-radius:.375rem;padding:.625rem 1.25rem;font-size:.9rem;font-weight:600;cursor:pointer}.reconnect-modal__btn--primary{background:color-mix(in srgb,var(--color-correct),white 25%);color:#fff}.reconnect-modal__btn--primary:hover{background:var(--color-correct)}.reconnect-modal__btn--secondary{background:#3a3a3c;color:#d7dadc}.reconnect-modal__btn--secondary:hover{background:#4a4a4c}.notif-toggle{display:flex;flex-direction:column;gap:4px}.notif-toggle__row{display:flex;justify-content:space-between;align-items:center}.notif-toggle__label{font-size:.95rem;color:#d7dadc}.notif-toggle__switch{position:relative;width:48px;height:26px;background:#3a3a3c;border:none;border-radius:13px;cursor:pointer;padding:0;transition:background .2s}.notif-toggle__switch--on{background:var(--color-correct)}.notif-toggle__switch--disabled{opacity:.4;cursor:not-allowed}.notif-toggle__switch--loading{opacity:.6;cursor:wait}.notif-toggle__knob{position:absolute;top:3px;left:3px;width:20px;height:20px;background:#fff;border-radius:50%;transition:transform .2s}.notif-toggle__switch--on .notif-toggle__knob{transform:translate(22px)}.notif-toggle__hint{font-size:.75rem;color:#818384;margin:0}.notif-toggle__hint--sub{font-size:.7rem;color:#6a6a6c}@media (prefers-reduced-motion: reduce){.notif-toggle__knob,.notif-toggle__switch{transition:none}}.profile-screen{max-width:480px;margin:0 auto;padding:1.5rem 1rem;color:#fff}.profile-header{margin-bottom:1.5rem}.profile-display-name{font-size:1.4rem;font-weight:700;margin:0}.profile-section{margin-bottom:2rem}.profile-section-title{font-size:.85rem;text-transform:uppercase;letter-spacing:.08em;color:#818384;margin-bottom:.75rem;margin-top:0}.profile-primary-stats{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.profile-primary-stat{display:flex;flex-direction:column}.profile-stat-value{font-size:1.8rem;font-weight:700}.profile-stat-label{font-size:.75rem;color:#818384}.profile-total-games{grid-column:1 / -1;font-size:.8rem;color:#818384;margin-top:.25rem}.profile-secondary-stats{border-top:1px solid #3a3a3c;padding-top:1.5rem}.profile-stat-list{display:flex;flex-direction:column;gap:.5rem;margin:0}.profile-stat-row{display:flex;justify-content:space-between;font-size:.95rem}.profile-stat-row dt{color:#818384}.profile-stat-row dd{font-weight:600;margin:0}.profile-notifications,.profile-h2h{border-top:1px solid #3a3a3c;padding-top:1.5rem}.profile-h2h-list{display:flex;flex-direction:column;gap:0}.profile-h2h-row{display:grid;grid-template-columns:1fr auto auto auto;gap:.75rem;align-items:center;font-size:.9rem;padding:.5rem 0;border-bottom:1px solid #3a3a3c}.profile-h2h-name{overflow:hidden;white-space:nowrap;text-overflow:ellipsis;max-width:120px}.profile-h2h-record{font-weight:600}.profile-h2h-rate{color:var(--color-correct)}.profile-h2h-last{color:#818384;font-size:.8rem}.profile-h2h-show-more{background:none;border:1px solid #3a3a3c;color:#818384;padding:.5rem 1rem;cursor:pointer;margin-top:.5rem;border-radius:4px;font-size:.85rem}.profile-h2h-show-more:hover{border-color:#818384;color:#fff}.profile-loading,.profile-error{text-align:center;color:#818384;padding:2rem}.opponent-label{max-width:120px;overflow:hidden;white-space:nowrap;text-overflow:ellipsis;display:inline-block;vertical-align:bottom}.dashboard{max-width:600px;margin:0 auto;padding:24px 16px 40px}.dashboard__title{font-size:1.5rem;font-weight:700;color:var(--color-text);margin-bottom:20px}.dashboard__loading{color:var(--color-text-muted);text-align:center;margin-top:40px}.dashboard__empty{text-align:center;padding:48px 16px}.dashboard__empty-text{font-size:1.1rem;color:var(--color-text-muted);margin-bottom:24px}.dashboard__completed{margin-bottom:24px}.dashboard__completed-title{font-size:16px;font-weight:700;color:#818384;margin-bottom:12px}.dashboard__completed-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:8px}.dashboard__completed-card{background:#1a1a1b;border-radius:8px;padding:12px 16px;border-left:3px solid}.dashboard__completed-card--win{border-left-color:var(--color-correct)}.dashboard__completed-card--loss{border-left-color:var(--color-present)}.dashboard__completed-header{display:flex;justify-content:space-between;align-items:center}.dashboard__completed-result{font-weight:600;color:#d7dadc;font-size:14px}.dashboard__completed-dismiss{background:transparent;border:none;color:#818384;font-size:18px;cursor:pointer;padding:0 4px}.dashboard__completed-dismiss:hover{color:#d7dadc}.dashboard__completed-opponent{color:#818384;font-size:13px;margin-top:4px}.dashboard__completed-detail{color:#565656;font-size:12px;margin-top:2px}.dashboard__list{list-style:none;padding:0;margin:0 0 24px;display:flex;flex-direction:column;gap:12px}.dashboard__card{background:var(--color-card-bg);border:2px solid var(--color-border);border-radius:8px;padding:16px;cursor:pointer;transition:border-color .15s ease,background .15s ease;outline:none}.dashboard__card:hover,.dashboard__card:focus{border-color:var(--color-text-muted)}.dashboard__card--your-turn{border-color:var(--color-correct);background:color-mix(in srgb,var(--color-correct) 8%,transparent)}.dashboard__card--your-turn:hover,.dashboard__card--your-turn:focus{border-color:#6aaf65}.dashboard__card--unseen{border-color:var(--color-present)}.dashboard__card-header{display:flex;align-items:center;gap:8px;margin-bottom:6px}.dashboard__card-opponent{font-weight:600;font-size:1rem;color:var(--color-text);flex:1}.dashboard__card-badge{background:var(--color-correct);color:#fff;font-size:.7rem;font-weight:700;padding:2px 8px;border-radius:12px;text-transform:uppercase;letter-spacing:.04em}.dashboard__card-dot{display:inline-block;width:8px;height:8px;border-radius:50%;background:var(--color-present);flex-shrink:0}.dashboard__card-status{font-size:.875rem;color:var(--color-text-muted);margin:0}.dashboard__actions{display:flex;gap:12px;flex-wrap:wrap;align-items:center}.dashboard__actions--at-cap{flex-direction:column;align-items:stretch}.dashboard__action-btn{flex:1;min-width:120px;padding:12px 20px;border-radius:6px;border:2px solid var(--color-border);background:transparent;color:var(--color-text);font-size:1rem;font-weight:600;cursor:pointer;transition:background .15s,border-color .15s}.dashboard__action-btn:hover:not(:disabled){background:#ffffff0f;border-color:var(--color-text-muted)}.dashboard__action-btn--primary{background:var(--color-correct);border-color:var(--color-correct);color:#fff}.dashboard__action-btn--primary:hover:not(:disabled){background:#6aaf65;border-color:#6aaf65}.dashboard__action-btn:disabled{opacity:.4;cursor:not-allowed}.dashboard__cap-message{width:100%;font-size:.85rem;color:var(--color-text-muted);text-align:center;margin:4px 0 0}@media (min-width: 480px){.dashboard__actions--at-cap{flex-direction:row;align-items:flex-start}}.dashboard__card-abandon{background:none;border:none;color:var(--color-text-muted);font-size:1.25rem;line-height:1;cursor:pointer;padding:2px 4px;border-radius:4px;flex-shrink:0;opacity:.5;transition:opacity .15s,color .15s}.dashboard__card-abandon:hover{opacity:1;color:#e06c75}.dashboard__card-invite{margin-top:.5rem}.dashboard__card-invite-btn{background:var(--color-surface);color:var(--color-text);border:1px solid var(--color-border);border-radius:6px;padding:.35rem .75rem;font-size:.8rem;cursor:pointer}.dashboard__card-invite-btn:hover{background:var(--color-surface-hover)}.history{max-width:540px;margin:0 auto;padding:24px 16px 40px}.history__title{font-size:1.5rem;font-weight:700;color:var(--color-text);margin-bottom:20px}.history__loading{color:var(--color-text-muted);text-align:center;margin-top:40px}.history__empty{text-align:center;padding:48px 16px;color:var(--color-text-muted);font-size:1.1rem}.history__list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:8px}.history__card{background:#1a1a1b;border-radius:8px;padding:12px 16px;border-left:3px solid;cursor:pointer}.history__card--win{border-left-color:var(--color-correct)}.history__card--loss{border-left-color:var(--color-present)}.history__card-header{display:flex;justify-content:space-between;align-items:center}.history__card-result{font-weight:600;color:#d7dadc;font-size:14px}.history__card-time{color:#565656;font-size:12px}.history__card-opponent{color:#818384;font-size:13px;margin-top:4px}.history__card-detail{color:#565656;font-size:12px;margin-top:2px}.history__load-more{display:block;width:100%;margin-top:16px;padding:10px;background:transparent;border:1px solid #3a3a3c;color:#818384;border-radius:6px;cursor:pointer;font-size:14px}.history__load-more:hover{border-color:#818384;color:#d7dadc}:root{--wd-blue-500: #3b82f6;--wd-orange-500: #ea580c;--wd-grey-700: #3a3a3c;--wd-grey-500: #818384;--wd-bg-900: #121213;--wd-red-500: #ef4444;--wd-purple-500: #8b5cf6;--color-correct: var(--wd-blue-500);--color-present: var(--wd-orange-500);--color-absent: var(--wd-grey-700);--color-empty: var(--wd-bg-900);--color-border: var(--wd-grey-700);--color-error: var(--wd-red-500);--color-sudden-death: var(--wd-purple-500);--color-brand-primary: var(--wd-blue-500);--color-brand-secondary: var(--wd-orange-500)}*{box-sizing:border-box}.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}body{margin:0;font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif;background:#121213;color:#fff}.app{max-width:960px;margin:0 auto;padding:32px 20px 48px;display:flex;flex-direction:column;gap:24px}.header h1{margin:0 0 6px;font-size:32px}.subtitle{margin:0;color:#818384}.status,.controls,.log,.error{background:#1a1a1b;border:1px solid #3a3a3c;border-radius:12px;padding:12px 16px}.log-header{display:flex;align-items:center;justify-content:space-between;cursor:pointer;gap:12px;-webkit-user-select:none;user-select:none}.log-latest{font-size:14px;color:#d7dadc;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;flex:1;min-width:0}.log-header svg{color:#818384;flex-shrink:0}.controls{display:grid;gap:16px;grid-template-columns:repeat(auto-fit,minmax(260px,1fr))}.control-group h3{margin-top:0}input{width:100%;padding:10px;border-radius:8px;border:1px solid #3a3a3c;background:#121213;color:#fff;margin-bottom:10px}button{background:var(--color-correct);color:#fff;border:none;padding:10px 14px;border-radius:8px;cursor:pointer}button:hover{background:color-mix(in srgb,var(--color-correct),white 15%)}button:disabled{opacity:.5;cursor:not-allowed}.dev-controls{display:flex;gap:10px;flex-wrap:wrap}.dev-active{background:var(--color-correct)}.error{border:1px solid var(--color-error);color:#ffb3b3}.log-list{display:flex;flex-direction:column;gap:8px;max-height:240px;overflow-y:auto}.log-entry{display:flex;gap:12px;font-size:14px}.log-time{color:#818384;width:80px;flex-shrink:0}.round-summary-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background:#000000bf;display:flex;align-items:center;justify-content:center;z-index:1000}.round-summary-card{background:var(--color-bg);border:2px solid #3a3a3c;border-radius:12px;padding:2rem;max-width:360px;width:90%;text-align:center;position:relative}.round-summary-card h2{color:#fff;margin:0 0 1.5rem;font-size:1.4rem}.lp-summary{margin-bottom:1.5rem}.lp-summary .lp-row{display:flex;justify-content:space-between;padding:.4rem 0;color:#d7dadc;font-size:1.1rem}.lp-summary .lp-value{font-weight:700}.lp-differential{margin-top:.8rem;padding-top:.8rem;border-top:1px solid #3a3a3c;font-size:1.2rem;font-weight:700}.lp-differential .gain{color:var(--color-correct)}.lp-differential .tie{color:#d7dadc}.lp-differential .loss{color:#c9453a}.lp-remaining{margin-bottom:1rem;color:#818384;font-size:.9rem}.lp-remaining .lp-row{display:flex;justify-content:space-between;padding:.2rem 0}.next-round-notice{color:#818384;font-size:.9rem;margin-top:1rem;font-style:italic}.round-summary-actions{display:flex;flex-direction:column;gap:8px;width:100%;margin-top:12px}.round-summary-card .continue-btn{width:100%;padding:12px;font-size:16px;font-weight:700;background:var(--color-correct);color:#fff;border:none;border-radius:6px;cursor:pointer;min-height:44px}.round-summary-card .continue-btn:hover{background:color-mix(in srgb,var(--color-correct),white 15%)}.round-summary-card .leave-btn{background:transparent;border:1px solid #3a3a3c;color:#818384;padding:8px 16px;border-radius:4px;cursor:pointer;font-size:.8rem;margin-top:0;min-height:44px}.round-summary-card .leave-btn:hover{border-color:#d7dadc;color:#d7dadc}.sudden-death-overlay{background:#281e0af2}@media (max-width: 480px){.round-summary-card,.end-game-card{padding:1.5rem;margin:1rem}.round-summary-card h2{font-size:1.2rem}.round-summary-actions{gap:10px}.end-game-result{font-size:1.5rem}.sudden-death-badge{font-size:.75rem;padding:6px 12px}.sudden-death-title{font-size:1.2rem}.score-player{padding:6px 12px}.score-lp{font-size:1rem}}.win-text{color:var(--color-correct)}.loss-text{color:var(--color-error)}.tie-text{color:#f9c74f}.sudden-death-warning{color:#e69138;font-weight:700}.round-display{font-size:.875rem;color:#818384}.round-display .current{color:#d7dadc;font-weight:700}.end-game-overlay,.round-summary-overlay{transition:opacity .3s ease-out}.end-game-card,.round-summary-card{transition:transform .3s ease-out,box-shadow .3s ease-out}.game-header{display:flex;justify-content:space-between;align-items:center;gap:8px}.game-header__actions{display:flex;align-items:center;gap:8px;flex-shrink:0}@media (max-width: 600px){.app{padding:16px 12px 48px}.game-header{flex-direction:column;align-items:flex-start;gap:10px}.game-header__actions{width:100%;justify-content:flex-end;gap:6px}.header h1{font-size:22px;margin-bottom:0}.subtitle{display:none}}
