@import "https://fonts.googleapis.com/css2?family=Playfair+Display:ital,wght@0,700;0,800;1,700&family=Inter:wght@400;500;600;700&display=swap";@keyframes spin{to{transform:rotate(360deg)}}.spin{flex-shrink:0;animation:.9s linear infinite spin}.tab-icon{flex-shrink:0}:root{--radius-sm:4px;--radius-md:6px;--radius-lg:8px;--radius-xl:12px;--font-serif:"Playfair Display", Georgia, "Times New Roman", serif;--font-sans:"Inter", system-ui, sans-serif;--transition:.16s ease;--bg:#fff;--bg-secondary:#f7f7f7;--surface:#fff;--surface-2:#f7f7f7;--border:#e2e2e2;--border-strong:#999;--text-1:#121212;--text-2:#555;--text-3:#999;--accent:#121212;--accent-hover:#333;--accent-soft:#1212120f;--accent-text:#fff;--green:#538d4e;--green-soft:#538d4e1f;--yellow:#b59f3b;--yellow-soft:#b59f3b1f;--red:#cf4444;--shadow-sm:0 1px 2px #0000000f;--shadow-md:0 2px 8px #00000014;--shadow-lg:0 8px 24px #0000001a;--nav-height:56px;--cell-size:64px;--cell-gap:8px;--path-color:#538d4e}[data-theme=dark]{--bg:#111;--bg-secondary:#1a1a1a;--surface:#1a1a1a;--surface-2:#252525;--border:#2e2e2e;--border-strong:#555;--text-1:#fff;--text-2:#8a8a8a;--text-3:#555;--accent:#fff;--accent-hover:#e0e0e0;--accent-soft:#ffffff14;--accent-text:#111;--green:#538d4e;--green-soft:#538d4e2e;--yellow:#b59f3b;--yellow-soft:#b59f3b2e;--red:#cf4444;--shadow-sm:0 1px 2px #00000080;--shadow-md:0 2px 8px #00000080;--shadow-lg:0 8px 24px #0009;--path-color:#538d4e}*,:before,:after{box-sizing:border-box;margin:0;padding:0}input,button,select,textarea{font:inherit}button{cursor:pointer;background:0 0;border:none}ul{list-style:none}html{font-size:16px}body{font-family:var(--font-sans);background:var(--bg);color:var(--text-1);-webkit-font-smoothing:antialiased;min-height:100vh;transition:background var(--transition), color var(--transition);line-height:1.5}#root,.app-shell{flex-direction:column;min-height:100vh;display:flex}.nav{z-index:100;background:var(--bg);border-bottom:1px solid var(--border);height:var(--nav-height);align-items:stretch;padding:0;display:flex;position:sticky;top:0}.nav-brand{border-right:1px solid var(--border);align-items:center;gap:.6rem;min-width:160px;padding:0 1.5rem;text-decoration:none;display:flex}.nav-logo-text{font-family:var(--font-serif);color:var(--text-1);letter-spacing:-.5px;font-size:1.1rem;font-weight:800;line-height:1}.nav-logo-sub{font-family:var(--font-sans);letter-spacing:.12em;text-transform:uppercase;color:var(--text-3);font-size:.6rem;font-weight:600;display:block}.nav-tabs{scrollbar-width:none;flex:1;align-items:stretch;gap:0;padding:0 .5rem;display:flex;overflow-x:auto}.nav-tabs::-webkit-scrollbar{display:none}.nav-tab{letter-spacing:.04em;text-transform:uppercase;color:var(--text-2);transition:color var(--transition), border-color var(--transition);white-space:nowrap;background:0 0;border-bottom:2px solid #0000;border-radius:0;align-items:center;gap:.4rem;padding:0 1rem;font-size:.82rem;font-weight:600;display:flex}.nav-tab:hover{color:var(--text-1)}.nav-tab.active{color:var(--text-1);border-bottom-color:var(--text-1)}.nav-right{border-left:1px solid var(--border);align-items:center;gap:.5rem;padding:0 1rem;display:flex}.theme-toggle{border-radius:var(--radius-sm);width:32px;height:32px;color:var(--text-2);transition:all var(--transition);justify-content:center;align-items:center;display:flex}.theme-toggle:hover{color:var(--text-1);background:var(--surface-2)}.page{flex:1;width:100%;max-width:1100px;margin:0 auto;padding:2.5rem 2rem}.page-header{margin-bottom:1.75rem}.page-title{font-family:var(--font-serif);color:var(--text-1);letter-spacing:-.5px;font-size:2.2rem;font-weight:800;line-height:1.15}.page-subtitle{color:var(--text-2);margin-top:.4rem;font-size:.9rem;line-height:1.6}.page-header:after{content:"";border-bottom:1px solid var(--border);margin-top:1.25rem;display:block}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden}.card-body{padding:1.5rem}.form-label{letter-spacing:.1em;text-transform:uppercase;color:var(--text-2);margin-bottom:.4rem;font-size:.72rem;font-weight:700;display:block}.form-input{background:var(--surface);border:1px solid var(--border-strong);border-radius:var(--radius-sm);width:100%;color:var(--text-1);transition:border-color var(--transition), box-shadow var(--transition);outline:none;padding:.6rem .75rem;font-size:.95rem}.form-input:focus{border-color:var(--text-1);box-shadow:0 0 0 2px var(--accent-soft)}.btn{border-radius:var(--radius-sm);letter-spacing:.06em;text-transform:uppercase;transition:all var(--transition);white-space:nowrap;border:1px solid #0000;justify-content:center;align-items:center;gap:.4rem;padding:.55rem 1.1rem;font-size:.82rem;font-weight:700;display:inline-flex}.btn:disabled{opacity:.4;pointer-events:none}.btn-primary{background:var(--accent);color:var(--accent-text);border-color:var(--accent)}.btn-primary:hover{background:var(--accent-hover);border-color:var(--accent-hover)}.btn-ghost{color:var(--text-1);border-color:var(--border-strong);background:0 0}.btn-ghost:hover{background:var(--surface-2)}.status-chip{background:var(--surface-2);border:1px solid var(--border);letter-spacing:.04em;color:var(--text-2);white-space:nowrap;border-radius:2px;align-items:center;gap:.35rem;padding:.25rem .6rem;font-size:.75rem;font-weight:600;display:inline-flex}.status-chip.loading{color:var(--yellow);border-color:var(--yellow);background:var(--yellow-soft)}.status-chip.error{color:var(--red);border-color:var(--red);background:#cf44441a}.results-header{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;margin-bottom:1rem;padding-bottom:.75rem;display:flex}.results-title{font-family:var(--font-serif);color:var(--text-1);font-size:1rem;font-weight:700}.results-count{color:var(--text-3);font-size:.8rem}.results-scroll{scrollbar-width:thin;scrollbar-color:var(--border-strong) transparent;overflow-y:auto}.results-scroll::-webkit-scrollbar{width:4px}.results-scroll::-webkit-scrollbar-thumb{background:var(--border-strong);border-radius:2px}.word-row{border-radius:var(--radius-sm);cursor:pointer;transition:background var(--transition);border:1px solid #0000;align-items:center;gap:.75rem;padding:.5rem .75rem;display:flex}.word-row:hover{background:var(--surface-2)}.word-row.active{background:var(--accent);border-color:var(--accent)}.word-row.active .word-label,.word-row.active .word-index,.word-row.active .word-badges span{color:var(--accent-text);background:#ffffff26}.word-index{color:var(--text-3);text-align:right;font-variant-numeric:tabular-nums;flex-shrink:0;width:18px;font-size:.7rem;font-weight:600}.word-label{letter-spacing:.06em;color:var(--text-1);flex:1;font-size:.95rem;font-weight:600}.word-badges{flex-shrink:0;gap:.3rem;display:flex}.badge{letter-spacing:.05em;white-space:nowrap;border-radius:2px;padding:.1rem .4rem;font-size:.68rem;font-weight:700}.badge-score{background:var(--accent-soft);color:var(--text-2)}.badge-turns{background:var(--green-soft);color:var(--green)}.empty-state{text-align:center;color:var(--text-3);flex-direction:column;align-items:center;padding:3rem 1rem;font-size:.9rem;display:flex}.boggle-layout{grid-template-columns:auto 1fr;gap:2rem;display:grid}@media (width<=720px){.boggle-layout{grid-template-columns:1fr}}.board-panel{flex-direction:column;gap:1rem;display:flex}.board-wrapper{background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius-md);padding:12px;display:inline-block;position:relative}.board-grid{grid-template-columns:repeat(4, var(--cell-size));grid-template-rows:repeat(4, var(--cell-size));gap:var(--cell-gap);display:grid}.board-cell{width:var(--cell-size);height:var(--cell-size);background:var(--surface);border:1px solid var(--border-strong);border-radius:var(--radius-sm);font-size:1.5rem;font-weight:700;font-family:var(--font-serif);color:var(--text-1);text-transform:uppercase;text-align:center;transition:border-color var(--transition), box-shadow var(--transition);caret-color:#0000;outline:none}.board-cell:focus{border-color:var(--text-1);box-shadow:0 0 0 2px var(--accent-soft)}.path-svg{pointer-events:none;z-index:10;width:calc(4 * var(--cell-size) + 3 * var(--cell-gap));height:calc(4 * var(--cell-size) + 3 * var(--cell-gap));position:absolute;top:12px;left:12px;overflow:visible}.path-line{stroke:var(--path-color);stroke-width:3px;stroke-linecap:round;stroke-linejoin:round;fill:none;opacity:.85;stroke-dasharray:1200;stroke-dashoffset:1200px;animation:.6s forwards draw-path}.path-step{fill:var(--path-color)}.path-step-start{fill:var(--text-1)}@keyframes draw-path{to{stroke-dashoffset:0}}.board-actions{flex-direction:column;gap:.6rem;display:flex}.results-panel{flex-direction:column;display:flex}.sudoku-layout{flex-direction:column;align-items:center;gap:1.5rem;display:flex}.sudoku-grid{border:2px solid var(--text-1);border-radius:2px;grid-template-rows:repeat(9,44px);grid-template-columns:repeat(9,44px);display:inline-grid;overflow:hidden}.sudoku-cell{text-align:center;width:44px;height:44px;color:var(--text-1);background:var(--surface);border:1px solid var(--border);transition:background var(--transition);font-size:1rem;font-weight:500;font-family:var(--font-sans);outline:none}.sudoku-cell:focus{background:var(--surface-2)}.sudoku-cell.given{font-weight:800}.sudoku-cell.solved{color:var(--green);font-weight:600}.sudoku-actions{flex-wrap:wrap;justify-content:center;gap:.75rem;display:flex}.woodle-layout{grid-template-columns:340px 1fr;gap:1.5rem;display:grid}@media (width<=720px){.woodle-layout{grid-template-columns:1fr}}.possible-word{border-radius:var(--radius-sm);background:var(--surface-2);letter-spacing:.1em;color:var(--text-1);cursor:default;padding:.35rem .6rem;font-size:.88rem;font-weight:600}@media (width<=600px){.nav-brand{min-width:auto;padding:0 1rem}.nav-logo-sub{display:none}.page{padding:1.5rem 1rem}:root{--cell-size:54px;--cell-gap:7px}}.mode-toggle{border:1px solid var(--border-strong);border-radius:var(--radius-sm);display:inline-flex;overflow:hidden}.mode-btn{letter-spacing:.06em;text-transform:uppercase;color:var(--text-2);transition:all var(--transition);background:0 0;border:none;border-radius:0;align-items:center;gap:.35rem;padding:.35rem .9rem;font-size:.78rem;font-weight:700;display:flex}.mode-btn:hover{color:var(--text-1);background:var(--surface-2)}.mode-btn.active{background:var(--text-1);color:var(--bg)}.page-header-row{flex-wrap:wrap;justify-content:space-between;align-items:flex-start;gap:1rem;display:flex}.game-banner{border-radius:var(--radius-md);text-align:center;letter-spacing:.03em;margin-bottom:1rem;padding:1rem 1.5rem;font-size:1rem;font-weight:700}.game-banner.won{background:var(--green-soft);color:var(--green);border:1px solid var(--green)}.game-banner.lost{color:var(--red);border:1px solid var(--red);background:#cf44441a}.game-banner.info{background:var(--surface-2);color:var(--text-2);border:1px solid var(--border)}.timer-display{font-variant-numeric:tabular-nums;letter-spacing:-.5px;color:var(--text-1);font-size:1.5rem;font-weight:800;font-family:var(--font-sans)}.timer-display.urgent{color:var(--red)}.timer-bar-track{background:var(--border);border-radius:2px;height:4px;margin-top:.35rem;overflow:hidden}.timer-bar-fill{background:var(--green);border-radius:2px;height:100%;transition:width 1s linear,background .5s}.timer-bar-fill.urgent{background:var(--red)}.game-input-row{align-items:center;gap:.5rem;display:flex}.game-input{background:var(--surface);border:1.5px solid var(--border-strong);border-radius:var(--radius-sm);color:var(--text-1);letter-spacing:.15em;text-transform:uppercase;transition:border-color var(--transition);font-size:1.1rem;font-weight:700;font-family:var(--font-sans);outline:none;flex:1;padding:.65rem .9rem}.game-input:focus{border-color:var(--text-1)}.game-input:disabled{opacity:.4}.found-words-wrap{flex-wrap:wrap;gap:5px;max-height:280px;display:flex;overflow-y:auto}.found-chip{background:var(--surface-2);border:1px solid var(--border);letter-spacing:.06em;color:var(--text-1);border-radius:2px;padding:.25rem .6rem;font-size:.82rem;font-weight:600}.found-chip.pangram{background:var(--accent-soft);border-color:var(--accent);color:var(--accent);font-weight:800}.score-display{font-size:2.5rem;font-weight:800;font-family:var(--font-serif);color:var(--text-1);line-height:1}.rank-label{letter-spacing:.1em;text-transform:uppercase;color:var(--text-2);margin-top:.25rem;font-size:.78rem;font-weight:700}.rank-bar{background:var(--border);border-radius:3px;height:6px;margin:.5rem 0;display:flex;overflow:hidden}.rank-bar-fill{background:var(--yellow);border-radius:3px;transition:width .4s}.difficulty-row{gap:.4rem;display:flex}.diff-btn{letter-spacing:.06em;text-transform:uppercase;color:var(--text-2);background:var(--surface-2);border:1px solid var(--border-strong);transition:all var(--transition);border-radius:2px;padding:.3rem .8rem;font-size:.75rem;font-weight:700}.diff-btn:hover{color:var(--text-1)}.diff-btn.active{background:var(--text-1);color:var(--bg);border-color:var(--text-1)}.sudoku-cell.error{background:#cf444414;color:var(--red)!important}.sudoku-cell.hint-revealed{color:var(--green);font-weight:700}@keyframes shake{0%,to{transform:translate(0)}20%{transform:translate(-6px)}40%{transform:translate(6px)}60%{transform:translate(-4px)}80%{transform:translate(4px)}}.shake{animation:.4s shake}@keyframes pop{0%{transform:scale(1)}50%{transform:scale(1.08)}to{transform:scale(1)}}.pop{animation:.25s pop}@keyframes blink{0%,to{opacity:1}50%{opacity:0}}.boggle-board-play{cursor:crosshair;touch-action:none;-webkit-user-select:none;user-select:none;-webkit-touch-callout:none;-webkit-tap-highlight-color:transparent;position:relative}.boggle-board-play ::selection{background:0 0}.boggle-board-play ::selection{background:0 0}
