*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--font-display: "Kanit", sans-serif;--font-mono: "Atkinson Hyperlegible Mono", monospace;--transition-theme: background-color .2s ease, color .2s ease, border-color .2s ease;--radius-sm: 4px;--radius-md: 8px;--radius-lg: 16px}[data-theme=dark]{--bg-base: #0e0e10;--bg-surface: #18181b;--bg-elevated: #1f1f24;--bg-hover: #27272c;--text-primary: #f4f4f5;--text-secondary: #a1a1aa;--text-muted: #52525b;--border: #27272c;--border-strong: #3f3f46;--accent: #a6d5ff;--accent-dim: rgba(77, 159, 255, .12);--accent-text: #0e0e10;--success: #4ade80;--success-dim: rgba(74, 222, 128, .12);--danger: #f87171;--danger-dim: rgba(248, 113, 113, .12);--warning: #fbbf24;--warning-dim: rgba(251, 191, 36, .12)}[data-theme=light]{--bg-base: #fafafa;--bg-surface: #ffffff;--bg-elevated: #f4f4f5;--bg-hover: #e4e4e7;--text-primary: #09090b;--text-secondary: #52525b;--text-muted: #a1a1aa;--border: #e4e4e7;--border-strong: #d4d4d8;--accent: #1a1a1a;--accent-dim: rgba(26, 26, 26, .08);--accent-text: #fafafa;--success: #16a34a;--success-dim: rgba(22, 163, 74, .1);--danger: #dc2626;--danger-dim: rgba(220, 38, 38, .1);--warning: #d97706;--warning-dim: rgba(217, 119, 6, .1)}html{font-size:16px;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{font-family:var(--font-mono);background-color:var(--bg-base);color:var(--text-primary);min-height:100vh;transition:var(--transition-theme);line-height:1.6}a{color:inherit;text-decoration:none}button{font-family:var(--font-mono);cursor:pointer;border:none;background:none}input{font-family:var(--font-mono)}.app{display:flex;flex-direction:column;min-height:100vh}.main-content{flex:1;width:100%;max-width:900px;margin:0 auto;padding:2rem 1.5rem}.sr-only{position:absolute;width:1px;height:1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap}.header{position:sticky;top:0;z-index:100;background-color:var(--bg-base);border-bottom:1px solid var(--border);transition:var(--transition-theme)}.header-inner{max-width:900px;margin:0 auto;padding:0 1.5rem;height:56px;display:flex;align-items:center;gap:1.5rem}.header-logo{display:flex;align-items:center;font-family:Kanit,sans-serif;font-size:1.1rem;color:var(--text-primary);letter-spacing:.01em;transition:opacity .15s}.header-logo:hover{opacity:.65}.logo-bracket{color:var(--accent);font-weight:200}[data-theme=light] .logo-bracket{color:var(--text-primary)}.logo-text{color:var(--text-primary);font-weight:200;margin:0 1px}.header-nav{display:flex;align-items:center;gap:.25rem;flex:1}.nav-link{font-family:var(--font-mono);font-size:.8rem;color:var(--text-secondary);padding:.3rem .6rem;border-radius:var(--radius-sm);transition:color .15s,background-color .15s}.nav-link:hover{color:var(--text-primary);background-color:var(--bg-hover)}.nav-link.active{color:var(--text-primary)}.theme-toggle{display:flex;align-items:center;background:none;border:none;padding:4px;cursor:pointer;flex-shrink:0;border-radius:99px;transition:background-color .15s}.theme-toggle:hover{background-color:var(--bg-hover)}.toggle-pill{position:relative;width:36.25px;height:20.25px;background-color:var(--bg-elevated);border:1.25px solid var(--border-strong);border-radius:99px;transition:background-color .25s,border-color .25s;flex-shrink:0}.toggle-pill--dark{background-color:var(--accent-dim);border-color:var(--accent)}.toggle-thumb{position:absolute;top:2px;left:2px;width:14px;height:14px;background-color:var(--text-muted);border-radius:50%;transition:transform .25s cubic-bezier(.34,1.56,.64,1),background-color .25s}.toggle-pill--dark .toggle-thumb{transform:translate(16px);background-color:var(--accent)}[data-theme=light] .toggle-thumb{background-color:var(--text-secondary)}.home{display:flex;flex-direction:column;gap:3rem}.home-hero{padding-top:1.5rem}.home-title{font-family:var(--font-display);font-size:clamp(2.5rem,8vw,4.5rem);font-weight:800;letter-spacing:-.04em;line-height:1;color:var(--text-primary)}.title-accent{color:transparent;-webkit-text-stroke:1.25px var(--accent)}[data-theme=light] .title-accent{-webkit-text-stroke:1.25px var(--text-primary);color:transparent}.home-subtitle{margin-top:.75rem;font-size:.9rem;color:var(--text-secondary);font-family:var(--font-mono);letter-spacing:.02em}.game-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1rem}.game-card{position:relative;display:flex;flex-direction:column;align-items:flex-start;gap:.5rem;padding:1.5rem;background-color:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-lg);text-align:left;transition:border-color .15s,background-color .15s,transform .15s;cursor:pointer}.game-card:not(.game-card--disabled):hover{border-color:var(--border-strong);background-color:var(--bg-elevated);transform:translateY(-2px)}.game-card--disabled{opacity:.45;cursor:default}.game-card-tag{font-family:var(--font-mono);font-size:.65rem;letter-spacing:.1em;text-transform:uppercase;color:var(--text-muted);background-color:var(--bg-elevated);padding:.2rem .5rem;border-radius:var(--radius-sm);border:1px solid var(--border)}.game-card-title{font-family:var(--font-display);font-size:1.3rem;font-weight:700;color:var(--text-primary);letter-spacing:-.02em}.game-card-desc{font-size:.82rem;color:var(--text-secondary);line-height:1.6;flex:1}.game-card-play{font-size:.78rem;font-family:var(--font-mono);color:var(--accent);margin-top:.5rem;letter-spacing:.05em}[data-theme=light] .game-card-play{color:var(--text-primary)}.ll-page{display:flex;flex-direction:column;gap:2rem;max-width:560px}.ll-header{display:flex;align-items:flex-start;justify-content:space-between;gap:1rem;flex-wrap:wrap}.ll-title{font-family:var(--font-display);font-size:1.8rem;font-weight:800;letter-spacing:-.03em;color:var(--text-primary)}.ll-desc{margin-top:.3rem;font-size:.8rem;color:var(--text-secondary);max-width:340px;line-height:1.5}.ll-scores{display:flex;gap:1.25rem;flex-shrink:0}.ll-score-item{display:flex;flex-direction:column;align-items:center;gap:.1rem}.ll-score-label{font-size:.65rem;letter-spacing:.1em;text-transform:uppercase;color:var(--text-muted)}.ll-score-value{font-family:var(--font-display);font-size:1.6rem;font-weight:700;color:var(--text-primary);line-height:1}.ll-splash{display:flex;flex-direction:column;align-items:flex-start;gap:1rem;padding:2rem;background-color:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-lg)}.ll-splash-icon{font-size:2rem;line-height:1}.ll-splash-text{font-size:.9rem;color:var(--text-secondary);line-height:1.6;max-width:360px}.ll-splash-sub{font-size:1.1rem;font-family:var(--font-display);font-weight:700;color:var(--text-primary)}.ll-final-chain{display:flex;flex-wrap:wrap;gap:.4rem;margin-top:.25rem}.ll-final-word{font-family:var(--font-mono);font-size:.78rem;background-color:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius-sm);padding:.2rem .5rem;color:var(--text-secondary)}.ll-btn-start{font-family:var(--font-mono);font-size:.85rem;padding:.65rem 1.5rem;background-color:var(--accent);color:var(--accent-text);border-radius:var(--radius-md);font-weight:500;letter-spacing:.03em;transition:opacity .15s,transform .1s;margin-top:.5rem}.ll-btn-start:hover{opacity:.85;transform:translateY(-1px)}.ll-btn-start:active{transform:translateY(0)}[data-theme=light] .ll-btn-start{background-color:var(--text-primary);color:var(--bg-base)}.ll-game{display:flex;flex-direction:column;gap:1.5rem}.ll-timer-track{height:4px;background-color:var(--bg-elevated);border-radius:99px;overflow:hidden}.ll-timer-fill{height:100%;background-color:var(--success);border-radius:99px;transition:width .05s linear,background-color .3s}.ll-timer-fill.warning{background-color:var(--warning)}.ll-timer-fill.danger{background-color:var(--danger)}.ll-prompt-area{display:flex;flex-direction:column;gap:.4rem}.ll-prompt-label{font-size:.65rem;letter-spacing:.12em;text-transform:uppercase;color:var(--text-muted)}.ll-prompt{font-family:var(--font-display);font-size:3.5rem;font-weight:800;letter-spacing:-.02em;color:var(--accent);line-height:1}[data-theme=light] .ll-prompt{color:var(--text-primary)}.ll-form{display:flex;flex-direction:column;gap:.5rem}.ll-input-wrap{display:flex;align-items:center;background-color:var(--bg-surface);border:1px solid var(--border-strong);border-radius:var(--radius-md);overflow:hidden;transition:border-color .15s}.ll-input-wrap:focus-within{border-color:var(--accent)}[data-theme=light] .ll-input-wrap:focus-within{border-color:var(--text-primary)}.ll-input-wrap--error{border-color:var(--danger)!important;animation:shake .3s ease}@keyframes shake{0%,to{transform:translate(0)}25%{transform:translate(-4px)}75%{transform:translate(4px)}}.ll-input-prefix{font-family:var(--font-mono);font-size:1.1rem;font-weight:500;padding:.7rem 0 .7rem 1rem;color:var(--accent);white-space:nowrap;pointer-events:none;letter-spacing:.02em}[data-theme=light] .ll-input-prefix{color:var(--text-primary)}.ll-input{flex:1;background:none;border:none;outline:none;font-family:var(--font-mono);font-size:1.1rem;color:var(--text-primary);padding:.7rem 1rem .7rem .1rem;min-width:0}.ll-input::placeholder{color:var(--text-muted)}.ll-error{font-size:.78rem;color:var(--danger);padding-left:.2rem}.ll-btn-submit{font-family:var(--font-mono);font-size:.82rem;padding:.6rem 1.25rem;background-color:var(--bg-elevated);color:var(--text-primary);border:1px solid var(--border-strong);border-radius:var(--radius-md);letter-spacing:.03em;transition:background-color .15s,opacity .15s;align-self:flex-start}.ll-btn-submit:not(:disabled):hover{background-color:var(--bg-hover)}.ll-btn-submit:disabled{opacity:.35;cursor:default}.ll-chain{display:flex;flex-direction:column;gap:.6rem}.ll-chain-label{font-size:.65rem;letter-spacing:.1em;text-transform:uppercase;color:var(--text-muted)}.ll-chain-list{display:flex;flex-direction:column;gap:.3rem;max-height:260px;overflow-y:auto}.ll-chain-entry{font-family:var(--font-mono);font-size:.88rem;padding:.4rem .75rem;background-color:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-sm);display:inline-flex;align-self:flex-start}.ll-chain-overlap{color:var(--accent);font-weight:500}[data-theme=light] .ll-chain-overlap{color:var(--text-primary);font-weight:700}.ll-chain-rest{color:var(--text-secondary)}.wl-page{display:flex;flex-direction:column;gap:1.75rem;max-width:520px}.wl-title-row{display:flex;align-items:center;gap:.65rem}.wl-title{font-family:var(--font-display);font-size:1.6rem;font-weight:800;letter-spacing:-.03em;color:var(--text-primary);flex:1}.wl-title-meta{display:flex;gap:1.25rem}.wl-meta-par,.wl-meta-steps{font-size:.72rem;font-family:var(--font-mono);color:var(--text-muted);letter-spacing:.04em}.wl-meta-par strong,.wl-meta-steps strong{color:var(--text-secondary);font-weight:600}.wl-loading{font-family:var(--font-mono);font-size:.85rem;color:var(--text-muted);letter-spacing:.06em;animation:wl-pulse 1.2s ease-in-out infinite}@keyframes wl-pulse{0%,to{opacity:.4}50%{opacity:1}}.wl-card{display:flex;flex-direction:column;gap:1rem;padding:1.5rem;background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-lg)}.wl-card--solved{border-color:var(--border-strong)}.wl-card-pair{display:flex;align-items:baseline;gap:.75rem}.wl-card-word{font-family:var(--font-display);font-size:2rem;font-weight:800;letter-spacing:.04em;color:var(--text-primary);line-height:1}.wl-card-word--target{color:var(--accent)}[data-theme=light] .wl-card-word--target{color:var(--text-primary);text-decoration:underline;text-underline-offset:4px;text-decoration-thickness:2px}.wl-card-arrow{font-size:1rem;color:var(--text-muted)}.wl-card-par{font-family:var(--font-mono);font-size:.78rem;color:var(--text-muted);letter-spacing:.06em}.wl-card-par strong{color:var(--text-secondary)}.wl-card-desc{font-size:.85rem;color:var(--text-secondary);line-height:1.6;max-width:380px}.wl-card-actions{display:flex;gap:.6rem;align-items:center}.wl-endpoints{display:flex;align-items:center;gap:.75rem}.wl-endpoint{display:flex;flex-direction:column;gap:.2rem}.wl-endpoint--right{align-items:flex-end}.wl-endpoint-label{font-size:.6rem;letter-spacing:.12em;text-transform:uppercase;color:var(--text-muted)}.wl-endpoint-word{font-family:var(--font-display);font-size:2rem;font-weight:800;letter-spacing:.04em;color:var(--text-primary);line-height:1}.wl-endpoint-word--target{color:var(--accent)}[data-theme=light] .wl-endpoint-word--target{color:var(--text-primary)}.wl-endpoint-line{flex:1;height:1px;background:var(--border);margin-top:1.1rem}.wl-chain{display:flex;flex-direction:column}.wl-chain-row{display:flex;flex-direction:column;align-items:flex-start}.wl-chain-word{display:inline-flex;gap:1px;padding:.4rem .75rem;border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--bg-surface);font-family:var(--font-mono);font-size:1rem;letter-spacing:.1em}.wl-chain-word--start{border-color:var(--border-strong)}.wl-chain-word--latest{border-color:var(--accent);background:color-mix(in srgb,var(--accent) 8%,var(--bg-surface))}[data-theme=light] .wl-chain-word--latest{border-color:var(--text-primary);background:var(--bg-hover)}.wl-chain-word--end{border-color:var(--success, #4ade80)}.wl-letter{color:var(--text-secondary)}.wl-letter--changed{color:var(--accent);font-weight:700}[data-theme=light] .wl-letter--changed{color:var(--text-primary)}.wl-connector{font-size:.65rem;color:var(--border-strong);padding-left:.75rem;line-height:1.4;-webkit-user-select:none;user-select:none}.wl-input-section{display:flex;flex-direction:column;gap:.5rem}.wl-input-wrap{display:flex;align-items:center;background:var(--bg-surface);border:1px solid var(--border-strong);border-radius:var(--radius-md);overflow:hidden;transition:border-color .15s}.wl-input-wrap:focus-within{border-color:var(--accent)}[data-theme=light] .wl-input-wrap:focus-within{border-color:var(--text-primary)}.wl-input-wrap--error{border-color:var(--danger, #f87171)!important;animation:wl-shake .3s ease}@keyframes wl-shake{0%,to{transform:translate(0)}25%{transform:translate(-5px)}75%{transform:translate(5px)}}.wl-input{flex:1;background:none;border:none;outline:none;font-family:var(--font-mono);font-size:1.2rem;letter-spacing:.18em;color:var(--text-primary);padding:.7rem 1rem;min-width:0;text-transform:uppercase}.wl-input::placeholder{color:var(--text-muted);letter-spacing:.3em;font-size:.85rem}.wl-input-count{font-family:var(--font-mono);font-size:.72rem;color:var(--text-muted);padding-right:.9rem;flex-shrink:0}.wl-error{font-size:.78rem;color:var(--danger, #f87171);padding-left:.2rem}.wl-input-actions{display:flex;align-items:center;gap:.5rem}.wl-btn-ghost--right{margin-left:auto}.wl-btn-start{font-family:var(--font-mono);font-size:.85rem;padding:.6rem 1.4rem;background:var(--accent);color:var(--accent-text);border-radius:var(--radius-md);font-weight:500;letter-spacing:.03em;transition:opacity .15s,transform .1s}[data-theme=light] .wl-btn-start{background:var(--text-primary);color:var(--bg-base)}.wl-btn-start:hover{opacity:.85;transform:translateY(-1px)}.wl-btn-start:active{transform:translateY(0)}.wl-btn-enter{font-family:var(--font-mono);font-size:.82rem;padding:.55rem 1.1rem;background:var(--bg-elevated);color:var(--text-primary);border:1px solid var(--border-strong);border-radius:var(--radius-md);transition:background-color .15s,opacity .15s;margin-left:auto}.wl-btn-enter:not(:disabled):hover{background:var(--bg-hover)}.wl-btn-enter:disabled{opacity:.3;cursor:default}.wl-btn-ghost{font-family:var(--font-mono);font-size:.75rem;color:var(--text-muted);padding:.35rem .6rem;border-radius:var(--radius-sm);transition:color .15s,background-color .15s}.wl-btn-ghost:hover:not(:disabled){color:var(--text-secondary);background:var(--bg-hover)}.wl-btn-ghost:disabled{opacity:.3;cursor:default}.wl-btn-secondary{font-family:var(--font-mono);font-size:.82rem;padding:.55rem 1.1rem;background:var(--bg-elevated);color:var(--text-primary);border:1px solid var(--border-strong);border-radius:var(--radius-md);transition:background-color .15s}.wl-btn-secondary:hover{background:var(--bg-hover)}.wl-solved-row{display:flex;gap:2rem}.wl-solved-stat{display:flex;flex-direction:column;gap:.15rem}.wl-solved-label{font-size:.62rem;letter-spacing:.12em;text-transform:uppercase;color:var(--text-muted)}.wl-solved-value{font-family:var(--font-display);font-size:1.5rem;font-weight:700;color:var(--text-primary);line-height:1}.wl-score--eagle{color:var(--accent)}.wl-score--par{color:var(--text-secondary)}.wl-score--over{color:var(--text-muted)}:root{--ws-color-0: #4ade80;--ws-color-1: #60a5fa;--ws-color-2: #f472b6;--ws-color-3: #fb923c;--ws-color-4: #a78bfa;--ws-color-5: #34d399;--ws-color-6: #fbbf24;--ws-color-7: #f87171;--ws-selection-bg: rgba(99, 179, 237, .35);--ws-selection-border: #63b3ed;--ws-start-ring: #3b82f6}.ws-page{display:flex;flex-direction:column;gap:1.75rem;max-width:680px}.ws-title-row{display:flex;align-items:center;gap:.65rem}.ws-title{font-family:var(--font-display);font-size:1.6rem;font-weight:800;letter-spacing:-.03em;color:var(--text-primary);flex:1}.ws-title-meta{display:flex;align-items:center;gap:.75rem}.ws-meta-timer{font-family:var(--font-mono, monospace);font-size:1rem;opacity:.7}.ws-progress-track{height:4px;background:var(--border, #e2e8f0);border-radius:2px;overflow:hidden}.ws-progress-fill{height:100%;background:var(--ws-color-0);transition:width .3s ease;border-radius:2px}.ws-playing{display:flex;flex-direction:column;gap:1.25rem}.ws-body{display:flex;gap:1.5rem;align-items:flex-start}.ws-grid-wrap{flex:0 0 auto;width:min(480px,calc(100vw - 2rem - 160px));aspect-ratio:1 / 1;border-radius:8px;border:1px solid var(--border, #e2e8f0);overflow:hidden;box-sizing:border-box;transition:box-shadow .15s ease}.ws-grid-wrap--correct{box-shadow:0 0 0 3px var(--ws-color-0)}.ws-grid-wrap--wrong{box-shadow:0 0 0 3px var(--ws-color-7)}.ws-grid{display:grid;grid-template-columns:repeat(var(--ws-cols, 12),1fr);grid-template-rows:repeat(var(--ws-cols, 12),1fr);width:100%;height:100%}.ws-cell{display:flex;align-items:center;justify-content:center;font-size:clamp(.5rem,1.5vw,.95rem);font-family:var(--font-mono, monospace);font-weight:600;letter-spacing:.02em;cursor:pointer;user-select:none;-webkit-user-select:none;-webkit-tap-highlight-color:transparent;transition:background-color .1s,transform .08s;border-radius:3px}.ws-cell:hover{background-color:var(--bg-surface, #f1f5f9);transform:scale(1.1);z-index:1;position:relative}.ws-cell--start{outline:2.5px solid var(--ws-start-ring);outline-offset:-2px;border-radius:4px}.ws-cell--selecting{transform:scale(1.05);position:relative;z-index:1}.ws-cell--found{font-weight:700;border-radius:0}.ws-word-list{flex:1;min-width:110px;display:flex;flex-direction:column;gap:.3rem}.ws-word-list-label{font-size:.72rem;font-weight:600;text-transform:uppercase;letter-spacing:.08em;opacity:.5;margin-bottom:.2rem}.ws-word-item{display:flex;align-items:center;gap:.4rem;font-family:var(--font-mono, monospace);font-size:.8rem;font-weight:600;letter-spacing:.04em;padding:.18rem .3rem;border-radius:4px}.ws-word-item--found{text-decoration:line-through;opacity:.5}.ws-word-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0;background:var(--border, #cbd5e1);transition:background .2s}.ws-idle-card{display:flex;flex-direction:column;align-items:flex-start;gap:1rem;padding:1.75rem;background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-lg)}.ws-idle-desc{font-size:.85rem;color:var(--text-secondary);line-height:1.65;max-width:380px}.ws-btn-start{font-family:var(--font-mono);font-size:.85rem;padding:.6rem 1.4rem;background:var(--accent);color:var(--accent-text);border-radius:var(--radius-md);font-weight:500;letter-spacing:.03em;transition:opacity .15s,transform .1s}[data-theme=light] .ws-btn-start{background:var(--text-primary);color:var(--bg-base)}.ws-btn-start:hover{opacity:.85;transform:translateY(-1px)}.ws-btn-start:active{transform:translateY(0)}.ws-btn-secondary{font-family:var(--font-mono);font-size:.82rem;padding:.55rem 1.1rem;background:var(--bg-elevated);color:var(--text-primary);border:1px solid var(--border-strong);border-radius:var(--radius-md);transition:background-color .15s}.ws-btn-secondary:hover{background:var(--bg-hover)}.ws-solved-card{background:var(--bg-surface, #f8fafc);border:1px solid var(--border, #e2e8f0);border-radius:12px;padding:1.75rem;display:flex;flex-direction:column;align-items:center;gap:1.25rem}.ws-solved-stats{display:flex;gap:2.5rem}.ws-solved-stat{display:flex;flex-direction:column;align-items:center;gap:.15rem}.ws-solved-label{font-size:.72rem;text-transform:uppercase;letter-spacing:.08em;opacity:.5;font-weight:600}.ws-solved-value{font-size:2rem;font-weight:700;font-family:var(--font-display, sans-serif);line-height:1}@media(max-width:560px){.ws-page{padding:1rem .75rem 2.5rem}.ws-body{flex-direction:column;align-items:stretch}.ws-grid-wrap{width:100%}.ws-cell{font-size:clamp(.55rem,2.8vw,.85rem)}.ws-word-list{flex-direction:row;flex-wrap:wrap;gap:.2rem .6rem;min-width:unset}.ws-word-list-label{width:100%}}
