*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--color-bg: #fafaf8;--color-text: #1a1a1a;--color-primary: #2563eb;--color-primary-light: #dbeafe;--color-primary-hover: #1d4ed8;--color-selected: #ffd700;--color-active: #e8f0fe;--color-correct: #d4edda;--color-incorrect: #f8d7da;--color-revealed: #e2d9f3;--color-black: #1a1a1a;--color-border: #d4d4d4;--color-border-light: #d1d5db;--color-card-bg: #ffffff;--color-text-muted: #666666;--color-text-secondary: #555555;--color-text-dim: #888888;--color-surface: #f0f0ee;--color-success: #2e7d32;--color-success-border: #a5d6a7;--color-success-bg: #f1f8f1;--color-error: #d32f2f;--font-main: "Georgia", serif;--font-mono: "SF Mono", "Fira Code", monospace}[data-theme=dark]{--color-bg: #1a1a2e;--color-text: #e0e0e0;--color-primary: #5b8def;--color-primary-light: #1e3a5f;--color-primary-hover: #7ba4f7;--color-selected: #b8860b;--color-active: #2a2a4a;--color-correct: #1b4332;--color-incorrect: #4a1c1c;--color-revealed: #3d2d5c;--color-black: #0d0d1a;--color-border: #3a3a5c;--color-border-light: #4a4a6c;--color-card-bg: #242444;--color-text-muted: #9a9ab0;--color-text-secondary: #b0b0c0;--color-text-dim: #7a7a90;--color-surface: #2a2a4a;--color-success: #4caf50;--color-success-border: #2e7d32;--color-success-bg: #1b3a1b;--color-error: #ef5350}body{font-family:var(--font-main);background:var(--color-bg);color:var(--color-text);line-height:1.5;-webkit-font-smoothing:antialiased}.app{min-height:100vh;display:flex;flex-direction:column}.main-content{flex:1;padding:1rem;max-width:1200px;margin:0 auto;width:100%}.header{display:flex;align-items:center;justify-content:space-between;padding:.75rem 1.5rem;background:var(--color-card-bg);border-bottom:2px solid var(--color-border);box-shadow:0 1px 3px #0000000f}.header-left{display:flex;align-items:center;gap:1rem}.header-title{font-size:1.5rem;font-weight:700;letter-spacing:-.02em}.header-puzzle-title{font-size:1rem;font-weight:400;color:var(--color-text-muted);margin-left:.75rem}.header-back-btn{background:none;border:1px solid var(--color-border);border-radius:6px;padding:.25rem .75rem;cursor:pointer;font-family:var(--font-main);font-size:.875rem;color:var(--color-text);transition:background .15s}.header-back-btn:hover{background:var(--color-active)}.header-subtitle{font-style:italic;color:var(--color-text-muted);font-size:.95rem;font-weight:400;margin:0;margin-left:.75rem}.header-theme-btn{background:none;border:1px solid var(--color-border);border-radius:50%;width:2rem;height:2rem;display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:1rem;transition:background .15s,border-color .15s;flex-shrink:0;line-height:1;padding:0}.header-theme-btn:hover{background:var(--color-active);border-color:var(--color-primary)}.puzzle-info-bar{display:flex;align-items:center;justify-content:center;gap:.5rem;padding:.5rem 1.5rem;background:var(--color-bg);border-bottom:1px solid var(--color-border);font-size:.85rem;color:var(--color-text-muted);flex-wrap:wrap}.puzzle-info-topic{font-weight:700;color:var(--color-primary);text-transform:uppercase;letter-spacing:.04em;font-size:.75rem}.puzzle-info-topic:after{content:"—";margin-left:.5rem;color:var(--color-border);font-weight:400}.puzzle-info-description{color:var(--color-text-secondary)}.puzzle-info-separator{color:var(--color-border);font-weight:700}.puzzle-info-date{color:var(--color-text-dim)}.puzzle-info-difficulty{display:inline-flex;align-items:center}.difficulty-badge{display:inline-flex;align-items:center;gap:.35rem;padding:.15rem .6rem .15rem .45rem;border-radius:999px;font-size:.78rem;font-weight:700;text-transform:capitalize;color:#1a1a1a;line-height:1;white-space:nowrap;vertical-align:middle}.difficulty-icon{flex-shrink:0;display:block}.difficulty-label{line-height:1.2}.game-layout{display:grid;grid-template-areas:"toolbar toolbar" "grid clues";grid-template-columns:minmax(250px,480px) 1fr;grid-template-rows:auto 1fr;gap:1.5rem;align-items:start}.game-layout-large{grid-template-columns:minmax(400px,640px) 1fr}.game-layout-xlarge{grid-template-columns:minmax(500px,780px) 1fr}.game-toolbar{grid-area:toolbar;display:flex;align-items:center;justify-content:space-between;padding:.5rem 0}.game-grid-area{grid-area:grid;position:relative}.grid-zoom-viewport{overflow:hidden;overflow:clip;border-radius:4px}.grid-zoom-inner{transition:transform .3s ease-out;will-change:transform}.grid-zoom-viewport-zoomed{cursor:grab}.grid-zoom-viewport-dragging{cursor:grabbing}.game-clues-area{grid-area:clues;overflow-y:auto;scrollbar-width:thin;scroll-behavior:auto}.game-clues-area::-webkit-scrollbar{width:6px}.game-clues-area::-webkit-scrollbar-track{background:transparent}.game-clues-area::-webkit-scrollbar-thumb{background:var(--color-border);border-radius:3px}.toolbar-actions{display:flex;gap:.5rem;align-items:center}.crossword-grid{position:relative;background:var(--color-black);border:2px solid var(--color-black);border-radius:4px;padding:12px;-webkit-user-select:none;user-select:none}.crossword-hidden-input{position:absolute;top:50%;left:50%;width:1px;height:1px;border:none;padding:0;margin:0;outline:none;background:transparent;color:transparent;caret-color:transparent;font-size:16px;z-index:-1}.grid-cell{position:relative;background:var(--color-card-bg);display:flex;align-items:center;justify-content:center;cursor:pointer;aspect-ratio:1;min-width:0;overflow:hidden;transition:background .1s}.grid-cell:focus{outline:2px solid var(--color-primary);outline-offset:-2px;z-index:1}.grid-cell-black{background:var(--color-black);cursor:default}.grid-cell-active{background:var(--color-active)}.grid-cell-correct{background:var(--color-correct)!important}.grid-cell-incorrect{background:var(--color-incorrect)!important}.grid-cell-revealed{background:var(--color-revealed)!important}.grid-cell-selected{background:var(--color-selected)!important;position:relative;z-index:2}.cell-number{position:absolute;top:0;left:1px;font-size:clamp(6px,.55em,11px);font-weight:700;line-height:1;color:var(--color-text-secondary);z-index:2;white-space:nowrap;pointer-events:none;font-family:Arial,Helvetica,sans-serif}.cell-letter{font-size:clamp(6px,1.2em,20px);font-weight:600;text-transform:uppercase;font-family:var(--font-mono)}.clue-list{display:flex;flex-direction:column;gap:1.5rem}.clue-section-title{font-size:1rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;margin-bottom:.5rem;padding-bottom:.25rem;border-bottom:2px solid var(--color-primary)}.clue-items{list-style:none}.clue-item{display:flex;gap:.5rem;padding:.375rem .5rem;border-radius:4px;cursor:pointer;transition:background .1s;font-size:.9rem}.clue-item:hover{background:var(--color-active)}.clue-item-active{background:var(--color-primary-light)!important;font-weight:600}.clue-item-correct{opacity:.55}.clue-correct-icon{margin-left:auto;color:var(--color-success);font-weight:700;font-size:.95em;flex-shrink:0}.clue-number{font-weight:700;min-width:2rem;color:var(--color-text-secondary)}.puzzle-selector{max-width:800px;margin:2rem auto}.puzzle-selector-title{font-size:1.5rem;margin-bottom:1rem;text-align:center}.puzzle-sort-bar{display:flex;align-items:center;justify-content:center;gap:.75rem;margin-bottom:1.5rem;flex-wrap:wrap}.puzzle-sort-label{font-size:.85rem;color:var(--color-text-muted);font-weight:600}.puzzle-sort-options{display:flex;gap:.25rem;background:var(--color-surface);border-radius:8px;padding:3px}.puzzle-sort-btn{font-family:var(--font-main);font-size:.8rem;padding:.35rem .75rem;border:none;border-radius:6px;background:transparent;color:var(--color-text-muted);cursor:pointer;transition:all .15s;white-space:nowrap}.puzzle-sort-btn:hover{color:var(--color-text);background:#ffffff80}.puzzle-sort-btn-active{background:var(--color-card-bg);color:var(--color-text);font-weight:600;box-shadow:0 1px 3px #0000001a}.puzzle-selector-loading,.puzzle-selector-error,.puzzle-selector-empty{text-align:center;padding:3rem;color:var(--color-text-muted)}.puzzle-selector-error{color:var(--color-error)}.puzzle-cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1rem}.puzzle-card{background:var(--color-card-bg);border:1px solid var(--color-border);border-radius:8px;padding:1.25rem;cursor:pointer;text-align:left;font-family:var(--font-main);transition:transform .1s,box-shadow .15s;width:100%;display:flex;flex-direction:column}.puzzle-card:hover{transform:translateY(-2px);box-shadow:0 4px 12px #0000001a}.puzzle-card-topic-title{font-size:1.35rem;font-weight:800;letter-spacing:-.01em;margin-bottom:.25rem;color:var(--color-text);line-height:1.2}.puzzle-card-difficulty{display:block;font-size:.85rem;font-weight:700;text-transform:capitalize;margin-bottom:.2rem}.puzzle-card-stats{display:block;font-size:.8rem;color:var(--color-text-dim);margin-bottom:.6rem}.puzzle-card-footer{display:flex;justify-content:space-between;align-items:center;font-size:.8rem;border-top:1px solid var(--color-border);padding-top:.5rem;margin-top:auto}.puzzle-card-date{color:var(--color-text-dim)}.puzzle-card-progress{font-weight:600;font-size:.78rem}.puzzle-card-progress-done{color:var(--color-success)}.puzzle-card-progress-active{color:var(--color-primary)}.puzzle-card-completed{border-color:var(--color-success-border);background:var(--color-success-bg)}.btn{font-family:var(--font-main);border:1px solid var(--color-border);border-radius:6px;padding:.5rem 1rem;cursor:pointer;font-size:.875rem;transition:background .15s;background:var(--color-card-bg);color:var(--color-text)}.btn:hover{background:var(--color-active)}.btn-sm{padding:.25rem .625rem;font-size:.8rem}.btn-primary{background:var(--color-primary);color:#fff;border-color:var(--color-primary)}.btn-primary:hover{background:var(--color-primary-hover)}.btn-secondary{background:transparent}.btn-active{background:var(--color-primary);color:#fff;border-color:var(--color-primary)}.btn-active:hover{background:var(--color-primary-hover);border-color:var(--color-primary-hover)}.completion-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:100;animation:fadeIn .2s ease}.completion-modal{background:var(--color-card-bg);border-radius:12px;padding:2rem;max-width:400px;width:90%;text-align:center;box-shadow:0 8px 32px #0003;animation:slideUp .3s ease}.completion-title{font-size:1.75rem;margin-bottom:.5rem}.completion-subtitle{color:var(--color-text-muted);margin-bottom:1.5rem}.completion-stats{display:flex;justify-content:center;gap:2rem;margin-bottom:1.5rem}.completion-stat{display:flex;flex-direction:column}.stat-label{font-size:.75rem;text-transform:uppercase;letter-spacing:.05em;color:var(--color-text-dim)}.stat-value{font-size:1.5rem;font-weight:700;font-family:var(--font-mono)}.completion-actions{display:flex;flex-direction:column;gap:.5rem}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.help-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:200;animation:fadeIn .2s ease;padding:1rem}.help-panel{background:var(--color-card-bg);border-radius:12px;max-width:540px;width:100%;max-height:85vh;display:flex;flex-direction:column;box-shadow:0 8px 32px #0003;animation:slideUp .3s ease;overflow:hidden}.help-panel-header{display:flex;align-items:center;justify-content:space-between;padding:1.25rem 1.5rem 1rem;border-bottom:2px solid var(--color-border);position:sticky;top:0;background:var(--color-card-bg);z-index:1;flex-shrink:0}.help-panel-title{font-size:1.25rem;font-weight:700;letter-spacing:-.02em}.help-panel-close{background:none;border:1px solid var(--color-border);border-radius:6px;width:2rem;height:2rem;display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:.875rem;color:var(--color-text-muted);transition:background .15s,color .15s;flex-shrink:0}.help-panel-close:hover{background:var(--color-incorrect);color:var(--color-text);border-color:var(--color-border)}.help-panel-body{overflow-y:auto;padding:.5rem 0;scrollbar-width:thin}.help-panel-body::-webkit-scrollbar{width:6px}.help-panel-body::-webkit-scrollbar-track{background:transparent}.help-panel-body::-webkit-scrollbar-thumb{background:var(--color-border);border-radius:3px}.help-section{padding:1rem 1.5rem;border-bottom:1px solid var(--color-border)}.help-section:last-child{border-bottom:none}.help-section-title{font-size:.875rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--color-primary);margin-bottom:.625rem;display:flex;align-items:center;gap:.5rem}.help-section-icon{font-size:1em}.help-items{list-style:none;display:flex;flex-direction:column;gap:.4rem}.help-item{display:flex;align-items:baseline;gap:.5rem;font-size:.875rem;line-height:1.5;color:var(--color-text-secondary)}.help-item-keys{display:flex;gap:.2rem;flex-shrink:0;align-items:center}.help-key{display:inline-flex;align-items:center;justify-content:center;background:var(--color-surface);border:1px solid var(--color-border-light);border-bottom-width:2px;border-radius:4px;padding:.1rem .4rem;font-family:var(--font-mono);font-size:.75rem;font-weight:600;color:var(--color-text-secondary);white-space:nowrap;line-height:1.4}.help-item-text{flex:1}.header-right{display:flex;align-items:center;gap:.5rem;margin-left:auto}.header-help-btn{background:none;border:1px solid var(--color-border);border-radius:50%;width:2rem;height:2rem;display:flex;align-items:center;justify-content:center;cursor:pointer;font-family:var(--font-main);font-size:1rem;font-weight:700;color:var(--color-text);transition:background .15s,border-color .15s;flex-shrink:0;line-height:1}.header-help-btn:hover{background:var(--color-primary-light);border-color:var(--color-primary);color:var(--color-primary)}@media(max-width:768px){.game-layout{grid-template-areas:"toolbar" "grid" "clues";grid-template-columns:1fr;grid-template-rows:auto auto auto;gap:1rem}.header{flex-direction:column;gap:.25rem;padding:.5rem 1rem}.header-title{font-size:1.25rem}.cell-letter{font-size:.9em}.cell-number{font-size:clamp(5px,.45em,9px)}.game-layout-large,.game-layout-xlarge{grid-template-columns:1fr}.game-clues-area{max-height:40vh}}
