:root{color:#17211f;background:#f5f3ec;font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;--ink: #17211f;--muted: #65716d;--line: #d8d7ce;--paper: #fffdf7;--paper-strong: #ffffff;--teal: #087f7a;--teal-soft: #d7f0ec;--gold: #d9921e;--gold-soft: #fff0c4;--green: #2c8f5f;--green-soft: #dcf4e6;--red: #b63a3a;--red-soft: #ffe3df;--blue: #2d6cdf;--blue-soft: #e4edff;--shadow: 0 18px 45px rgba(41, 47, 43, .12)}*{box-sizing:border-box}body{margin:0;min-width:320px;min-height:100vh;font-size:18px;line-height:1.5}button,input{font:inherit}button{cursor:pointer}button:disabled{cursor:default}.app-shell{min-height:100vh;overflow-x:hidden;padding:24px}.app-shell--loading{display:grid;place-items:center}.loading-panel{align-items:center;background:var(--paper-strong);border:1px solid var(--line);border-radius:8px;box-shadow:var(--shadow);display:flex;gap:12px;padding:18px 22px}.loading-panel svg{color:var(--teal)}.hidden-input{height:1px;left:0;opacity:0;position:fixed;top:0;width:1px;z-index:-1}.topbar{align-items:end;display:flex;gap:18px;justify-content:space-between;margin:0 auto 14px;max-width:1440px}.eyebrow{color:var(--teal);font-size:.84rem;font-weight:800;margin:0 0 4px}h1,h2,h3,p{margin:0}h1{font-size:2.2rem;line-height:1.1}.topbar-stats{display:flex;gap:10px}.topbar-stats span,.stage-summary span{align-items:center;background:var(--paper-strong);border:1px solid var(--line);border-radius:999px;display:inline-flex;font-weight:800;gap:6px;min-height:36px;padding:8px 14px;white-space:nowrap}.practice-guide{display:grid;gap:10px;grid-template-columns:repeat(3,minmax(0,1fr));margin:0 auto 18px;max-width:1440px}.practice-guide div{align-items:center;background:var(--paper-strong);border:2px solid var(--line);border-radius:8px;display:grid;gap:2px 10px;grid-template-columns:42px minmax(0,1fr);min-height:72px;padding:10px}.practice-guide span{align-items:center;background:var(--teal-soft);border-radius:999px;color:var(--teal);display:inline-flex;font-size:1.1rem;font-weight:900;grid-row:span 2;height:42px;justify-content:center;width:42px}.practice-guide strong{font-size:1.05rem}.practice-guide small{color:var(--muted);font-size:.86rem}.topbar-stats svg{color:var(--gold);height:18px;width:18px}.game-layout{align-items:start;display:grid;gap:14px;grid-template-columns:minmax(480px,1fr) minmax(320px,420px);margin:0 auto;max-width:1440px}.stage-panel,.board-panel,.clue-panel{background:#fffdf7eb;border:1px solid var(--line);border-radius:8px;box-shadow:var(--shadow);min-width:0}.stage-panel,.clue-panel,.board-panel{padding:16px}.board-panel{order:1}.clue-panel{order:2;position:sticky;top:16px}.stage-panel{grid-column:1 / -1;order:3;padding:0}.panel-heading{align-items:center;display:flex;justify-content:space-between;margin-bottom:12px}.panel-heading h2{font-size:1.1rem}.panel-heading span{background:var(--blue-soft);border:1px solid #bed0ff;border-radius:999px;color:#214f9c;font-size:.82rem;font-weight:800;padding:5px 10px}.stage-list{display:grid;gap:8px;grid-template-columns:repeat(auto-fit,minmax(210px,1fr));max-height:220px;overflow:auto;padding:0 16px 16px}.stage-toggle{align-items:center;cursor:pointer;display:flex;font-weight:900;justify-content:space-between;min-height:54px;padding:0 16px}.stage-toggle::marker{color:var(--teal)}.stage-toggle span{color:var(--ink)}.stage-toggle strong{background:var(--blue-soft);border:1px solid #bed0ff;border-radius:999px;color:#214f9c;font-size:.82rem;padding:5px 10px}.difficulty-picker{display:grid;gap:8px;grid-template-columns:repeat(3,minmax(0,1fr));padding:0 16px 12px}.difficulty-button{align-items:center;background:var(--paper-strong);border:2px solid var(--line);border-radius:8px;color:var(--ink);display:flex;font-weight:900;justify-content:space-between;min-height:50px;padding:8px 10px}.difficulty-button.is-active{background:var(--teal-soft);border-color:var(--teal);color:var(--teal)}.difficulty-button small{background:#ffffffb8;border-radius:999px;color:var(--muted);font-size:.78rem;min-width:28px;padding:3px 7px;text-align:center}.content-db{border-top:1px solid var(--line);margin-top:16px;padding-top:16px}.content-db .panel-heading{margin-bottom:10px}.word-stat-grid{display:grid;gap:7px;grid-template-columns:repeat(3,minmax(0,1fr))}.word-stat-grid span{background:var(--paper-strong);border:1px solid var(--line);border-radius:8px;color:var(--muted);display:grid;font-size:.78rem;gap:2px;min-height:58px;padding:8px;place-items:center;text-align:center}.word-stat-grid strong{color:var(--ink);font-size:1.15rem}.content-db p{color:var(--muted);font-size:.78rem;line-height:1.45;margin-top:9px}.stage-item{align-items:center;background:var(--paper-strong);border:2px solid var(--line);border-radius:8px;color:var(--ink);display:grid;gap:10px;grid-template-columns:34px minmax(0,1fr) auto;min-height:68px;padding:10px;text-align:left}.stage-helper{color:var(--muted);font-size:.9rem;margin:0;padding:0 16px 16px}.stage-item.is-active{border-color:var(--teal);box-shadow:inset 0 0 0 1px var(--teal)}.stage-index{align-items:center;background:var(--teal-soft);border-radius:8px;color:var(--teal);display:inline-flex;font-weight:900;height:34px;justify-content:center;width:34px}.stage-index svg{height:17px;width:17px}.stage-item strong,.stage-item small{display:block;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.stage-item small{color:var(--muted);font-size:.78rem;margin-top:3px}.stage-stars{color:var(--gold);font-size:.8rem;font-weight:900;min-width:30px;text-align:right}.stage-summary{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:12px}.stage-summary span{background:#fbfaf5;color:var(--muted);font-size:.95rem}.stage-summary .input-direction-chip{background:#e8fbf8;color:var(--teal);font-weight:950}.stage-summary .word-position-chip{background:#fff4d4;color:#7a4f0b;font-weight:950}.direct-input-guide{align-items:center;background:#f7fffd;border:2px solid #8fcec6;border-radius:8px;color:var(--ink);display:grid;gap:10px;grid-template-columns:34px minmax(0,1fr) auto;margin-bottom:12px;padding:11px 12px}.direct-input-guide svg{color:var(--teal);height:26px;width:26px}.direct-input-guide strong,.direct-input-guide span{display:block}.direct-input-guide strong{color:var(--teal);font-size:1rem;font-weight:950}.direct-input-guide span{color:#41615d;font-size:.92rem;font-weight:800;line-height:1.35;margin-top:2px}.direct-input-guide button{background:var(--teal);border:0;border-radius:8px;color:#fff;font-size:.9rem;font-weight:900;min-height:40px;padding:8px 12px}.crossword-board{aspect-ratio:1 / 1;display:grid;gap:4px;grid-template-columns:repeat(var(--grid-size),minmax(0,1fr));margin:0 auto;max-width:760px;width:min(100%,82vh)}.cell{align-items:center;aspect-ratio:1 / 1;background:var(--paper-strong);border:2px solid #bfc7c2;border-radius:6px;color:var(--ink);display:flex;justify-content:center;min-width:0;padding:0;position:relative}.cell.is-blocked{background:#dce2dc;border-color:#dce2dc}.cell.is-current-word{background:#fff4d4;border-color:#d9a82f}.cell.is-current-across{box-shadow:inset 0 -5px #087f7a52}.cell.is-current-down{box-shadow:inset 5px 0 #087f7a52}.cell.is-word-start{border-top-left-radius:10px}.cell.is-word-end{border-bottom-right-radius:10px}.cell.is-selected{border-color:var(--teal);box-shadow:inset 0 0 0 3px var(--teal),0 0 0 3px #087f7a26}.cell.is-selected:before{animation:selectedCellPulse 1.15s ease-in-out infinite;border:3px solid rgba(8,127,122,.35);border-radius:8px;content:"";top:4px;right:4px;bottom:4px;left:4px;pointer-events:none;position:absolute}.cell.is-completed{background:var(--green-soft);border-color:#9bd6b2}.cell.is-revealed:after{background:var(--gold);border-radius:999px;bottom:5px;content:"";height:6px;position:absolute;right:5px;width:6px}.cell.is-correct{background:var(--green-soft);border-color:var(--green)}.cell.is-wrong{background:var(--red-soft);border-color:var(--red)}.cell.is-empty{background:var(--blue-soft);border-color:#9bb7f2}.cell-number{color:var(--muted);font-size:.72rem;font-weight:900;left:4px;line-height:1;position:absolute;top:4px}.cell-letter{font-size:clamp(1.2rem,3.4vw,2.15rem);font-weight:900;line-height:1}.cell-crossing{border-bottom:7px solid var(--teal);border-left:7px solid transparent;bottom:4px;height:0;left:4px;position:absolute;width:0}.cell-direction-marker{align-items:center;background:var(--teal);border-radius:999px;bottom:4px;color:#fff;display:inline-flex;font-size:.72rem;font-weight:950;height:18px;justify-content:center;line-height:1;position:absolute;right:4px;width:18px}.direction-helper{background:#f7fffd;border:1px solid #bde3dd;border-radius:8px;color:#2d625e;font-size:.92rem;font-weight:850;line-height:1.4;margin:10px 0 0;padding:9px 11px}@keyframes selectedCellPulse{0%,to{opacity:.2}50%{opacity:1}}.control-bar{display:grid;gap:10px;grid-template-columns:repeat(5,minmax(0,1fr)) 44px;margin-top:16px}.control-button,.icon-button{align-items:center;border:1px solid var(--line);border-radius:8px;color:var(--ink);display:inline-flex;font-weight:900;gap:8px;justify-content:center;min-height:56px}.control-button{background:var(--paper-strong);padding:9px 10px}.control-button:disabled{color:#8b9c99;opacity:.62}.control-bar .control-button:nth-child(2){background:var(--teal);border-color:var(--teal);color:#fff}.control-button svg,.icon-button svg{flex:0 0 auto;height:18px;width:18px}.icon-button{background:#f3eee4;padding:0}.status-line{align-items:center;background:#fbfaf5;border:1px solid var(--line);border-radius:8px;color:var(--muted);display:flex;font-weight:800;gap:8px;margin-top:10px;min-height:50px;padding:11px 13px}.status-line svg{color:var(--teal);flex:0 0 auto;height:18px;width:18px}.clue-panel{display:grid;gap:14px}.current-clue{background:#eef9f6;border:2px solid #8fcec6;border-radius:8px;display:grid;gap:10px;padding:14px}.clue-title{color:var(--teal);font-size:.92rem;font-weight:900;margin-bottom:8px}.empty-hint{background:#ffffffb8;border:1px dashed #8fcec6;border-radius:8px;color:var(--muted);display:grid;gap:4px;min-height:118px;padding:16px}.empty-hint strong{color:var(--teal);font-size:1.12rem}.empty-hint span{font-size:.96rem}.selected-hint-card{background:#ffffffb8;border:1px solid #bde3dd;border-radius:8px;display:grid;grid-template-rows:auto auto;min-height:0;padding:12px}.selected-hint-body{min-height:0;position:relative}.current-clue .selected-hint-text{min-height:0;padding-right:54px}.hint-step-list{display:block}.hint-step{color:var(--ink);display:grid;gap:2px;font-size:.94rem;font-weight:850;line-height:1.3;margin:0 0 7px}.hint-step:last-child{margin-bottom:0}.hint-step-label{color:var(--teal);font-size:.72rem;font-weight:950}.hint-audio-button{align-items:center;background:#f7fffd;border:2px solid #8fcec6;border-radius:8px;color:var(--teal);display:inline-flex;height:42px;justify-content:center;padding:0;position:absolute;right:0;top:0;width:42px}.hint-audio-button svg{height:22px;width:22px}.hint-audio-button:hover,.hint-audio-button:focus-visible{background:#e8fbf8;border-color:var(--teal)}.hint-audio-button.is-speaking{background:#fff4d4;border-color:#d49a20;color:#8c5a00}.hint-step-action{align-items:center;background:#f7fffd;border:2px solid #8fcec6;border-radius:8px;color:var(--teal);display:inline-flex;font-size:.96rem;font-weight:900;gap:7px;justify-content:center;margin-top:10px;min-height:44px;padding:8px 12px;width:100%}.hint-step-action svg{height:19px;width:19px}.clue-meta{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:8px}.clue-meta span{background:#ffffffc7;border-radius:999px;color:var(--teal);font-size:.88rem;font-weight:900;padding:4px 9px}.initial-hint{color:#7a4f0b;font-size:1.05rem;font-weight:900;margin-top:12px}.description,.crossing-note{color:var(--muted);font-size:1rem;line-height:1.55;margin-top:10px}.support-note{background:#ffffffa3;border-radius:8px;color:#2d625e;font-size:.95rem;font-weight:800;margin-top:12px;padding:9px 10px}.clear-overlay{align-items:center;background:#17211f6b;display:flex;top:0;right:0;bottom:0;left:0;justify-content:center;padding:20px;position:fixed;z-index:10}.clear-dialog{background:var(--paper-strong);border:1px solid var(--line);border-radius:8px;box-shadow:0 24px 70px #17211f47;max-width:420px;padding:24px;text-align:center;width:min(100%,420px)}.clear-badge{align-items:center;background:var(--gold-soft);border:1px solid #edcb71;border-radius:999px;color:var(--gold);display:inline-flex;height:58px;justify-content:center;margin-bottom:10px;width:58px}.clear-badge svg{height:30px;width:30px}.clear-dialog h2{font-size:1.65rem;line-height:1.15}.clear-feedback{background:#eef9f6;border:1px solid #bde3dd;border-radius:8px;color:#2d625e;font-size:1.02rem;font-weight:850;line-height:1.45;margin:14px 0 4px;padding:12px}.clear-stars{display:flex;gap:6px;justify-content:center;margin:16px 0}.clear-stars svg{color:#d8d7ce;fill:currentColor;height:34px;width:34px}.clear-stars svg.is-earned{color:var(--gold)}.clear-summary{display:flex;flex-wrap:wrap;gap:8px;justify-content:center;margin-bottom:18px}.clear-summary span{background:#fbfaf5;border:1px solid var(--line);border-radius:999px;color:var(--muted);font-size:.86rem;font-weight:900;padding:7px 11px}.clear-actions{display:grid;gap:8px;grid-template-columns:1fr 1fr}.clear-actions .control-button:first-child{background:var(--teal);border-color:var(--teal);color:#fff}.clear-secondary{background:var(--paper-strong);color:var(--ink)}.sr-only{height:1px;margin:-1px;overflow:hidden;padding:0;position:absolute;width:1px;clip:rect(0,0,0,0);white-space:nowrap}@media(max-width:1180px){.game-layout{grid-template-columns:1fr}.clue-panel{grid-column:auto;grid-template-columns:1fr;position:static}}@media(max-width:820px){.app-shell{padding:14px}.topbar{align-items:start;flex-direction:column}h1{font-size:1.8rem}.game-layout{grid-template-columns:1fr}.stage-panel{order:3}.board-panel{order:2;padding:12px}.crossword-board{gap:3px;width:100%}.control-bar{grid-template-columns:repeat(2,minmax(0,1fr))}.control-button{min-width:0}.direct-input-guide{align-items:stretch;grid-template-columns:30px minmax(0,1fr)}.direct-input-guide button{grid-column:1 / -1}.clue-panel{grid-column:auto;grid-template-columns:1fr;order:1;padding:12px;position:sticky;top:8px;z-index:2}.current-clue{gap:8px;padding:12px}.clue-title{margin-bottom:2px}.selected-hint-card{padding:10px}.clue-meta{gap:6px;margin-bottom:7px}.clue-meta span{font-size:.82rem;padding:3px 8px}.hint-step{font-size:.9rem;line-height:1.32;margin-bottom:5px}.current-clue .selected-hint-text{padding-right:48px}.hint-audio-button{height:40px;width:40px}.hint-step-action{margin-top:4px;min-height:42px}.support-note,.description,.crossing-note{margin-top:4px}.empty-hint{min-height:72px;padding:12px}.empty-hint strong{font-size:1rem}.empty-hint span{font-size:.9rem}.cell{border-radius:4px}}@media(max-width:480px){body{font-size:17px}.app-shell{padding:12px}.topbar{gap:10px;margin-bottom:10px}h1{font-size:1.55rem}.topbar-stats{flex-wrap:wrap}.stage-summary span,.topbar-stats span{font-size:.84rem;min-height:34px;padding:6px 10px}.stage-summary{gap:6px;margin-bottom:10px}.board-panel,.clue-panel,.current-clue{padding:10px}.selected-hint-card{padding:9px}.hint-step{font-size:.86rem}.support-note{font-size:.86rem;padding:8px 9px}.crossword-board{gap:3px}.control-bar{gap:8px;grid-template-columns:1fr 1fr;margin-top:12px}.control-button,.icon-button{font-size:.95rem;min-height:52px}.status-line{font-size:.9rem;min-height:44px;padding:9px 10px}.icon-button{grid-column:span 2;width:100%}.cell-letter{font-size:1.1rem}.cell-number{font-size:.55rem;left:3px;top:3px}}
