:root{--paper:#f6efd9;--panel:#fffaf0;--white:#fffdf7;--ink:#11100e;--muted:#6d6254;--line:#928879;--gold:#ffd84d;--gold-dark:#f0bb1f;--blue:#b7dcf2;--green:#74bd75;--red:#d95d54;--shadow:5px 5px 0 var(--ink);--small-shadow:3px 3px 0 var(--ink);--touch-keyboard-height:0px}*{box-sizing:border-box}html{background:var(--paper);min-height:100%}body{background:linear-gradient(90deg, #11100e09 1px, transparent 1px), linear-gradient(#11100e06 1px, transparent 1px), var(--paper);min-height:100%;color:var(--ink);background-size:34px 34px,34px 34px;margin:0;font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}button{font:inherit}.app-shell{min-height:100vh;padding:18px}.play-surface{outline:none;width:min(1180px,100%);min-height:calc(100vh - 36px);margin:0 auto}.topbar{justify-content:space-between;align-items:center;gap:16px;margin-bottom:16px;display:flex}.brand-lockup{align-items:center;gap:12px;display:flex}.brand-mark{border:3px solid var(--ink);background:var(--gold);width:52px;height:52px;box-shadow:var(--small-shadow);place-items:center;font-size:18px;font-weight:950;display:grid}.brand-lockup h1{letter-spacing:0;margin:0;font-size:28px;line-height:1}.daily-status{border:3px solid var(--ink);background:var(--white);min-width:150px;box-shadow:var(--small-shadow);text-align:right;gap:2px;padding:8px 12px;display:grid}.daily-status span{text-transform:uppercase;font-size:12px;font-weight:900}.daily-status strong{font-size:14px;font-weight:950;line-height:1}.mobile-timer{display:none}.game-layout{grid-template-columns:minmax(320px,1fr) minmax(330px,420px);align-items:start;gap:18px;display:grid}.grid-column{justify-items:center;gap:12px;display:grid}.stats-strip{border:3px solid var(--ink);background:var(--panel);width:min(100%,560px);box-shadow:var(--small-shadow);text-transform:capitalize;grid-template-columns:repeat(auto-fit,minmax(96px,1fr));align-items:center;gap:8px;padding:9px 11px;display:grid}.stats-strip span{font-variant-numeric:tabular-nums;text-align:center;min-width:0;font-size:14px;font-weight:950}.result-button{border:2px solid var(--ink);background:var(--gold);min-height:30px;box-shadow:2px 2px 0 var(--ink);color:var(--ink);cursor:pointer;background:var(--green);justify-content:center;align-items:center;gap:5px;padding:0 10px;font-size:13px;font-weight:950;display:inline-flex}.crossword-grid{aspect-ratio:1;border:5px solid var(--ink);background:var(--ink);width:min(92vw,560px);box-shadow:var(--shadow);grid-auto-rows:minmax(0,1fr);gap:1px;display:grid}.grid-cell{background:var(--white);min-width:0;min-height:0;color:var(--ink);cursor:pointer;font:inherit;border:0;place-items:center;padding:0;line-height:1;transition:transform .12s,background-color .12s;display:grid;position:relative}.grid-cell:not(.is-black):hover{background:#fff4bc}.grid-cell.is-black{cursor:default;background:#050504}.grid-cell.is-active-word{background:var(--blue)}.grid-cell.is-selected{background:var(--gold);transform:translate(-1px,-1px)}.grid-cell.is-correct{background:#d9f0d0}.grid-cell.is-wrong{background:#f4c4bb}.cell-number{font-size:clamp(10px,2vw,14px);font-weight:900;line-height:1;position:absolute;top:5px;left:6px}.cell-letter{max-height:1em;font-size:clamp(28px,8vw,68px);font-weight:850;line-height:1;display:block}.active-clue-tray{border:3px solid var(--ink);background:var(--gold);width:min(100%,560px);box-shadow:var(--small-shadow);grid-template-columns:auto 1fr;align-items:center;gap:10px;padding:12px;display:grid}.active-clue-tray span{text-transform:uppercase;font-size:13px;font-weight:950}.active-clue-tray strong{min-width:0;font-size:17px;line-height:1.2}.side-panel{gap:14px;display:grid}.action-bar{grid-template-columns:repeat(2,minmax(0,1fr)) 44px;gap:8px;display:grid}.tool-button,.icon-button{border:3px solid var(--ink);background:var(--white);min-height:44px;box-shadow:var(--small-shadow);color:var(--ink);cursor:pointer;justify-content:center;align-items:center;gap:7px;padding:0 12px;font-size:14px;font-weight:950;transition:box-shadow .12s,transform .12s;display:inline-flex}.tool-button:hover,.icon-button:hover,.clue-row:hover{box-shadow:2px 2px 0 var(--ink);transform:translate(1px,1px)}.tool-button.primary{background:var(--gold)}.tool-button.dark{background:var(--ink);color:var(--paper)}.tool-button:disabled,.icon-button:disabled{box-shadow:none;color:var(--muted);cursor:default;background:#efe8d4;transform:none}.icon-button{padding:0}.clue-board{border:3px solid var(--ink);background:var(--panel);box-shadow:var(--shadow);grid-template-columns:1fr 1fr;gap:12px;padding:12px;display:grid}.clue-section{min-width:0}.clue-section h2{text-transform:uppercase;margin:0 0 8px;font-size:15px;font-weight:950}.clue-list{gap:7px;display:grid}.clue-row{border:2px solid var(--ink);background:var(--white);width:100%;min-height:38px;color:var(--ink);cursor:pointer;text-align:left;box-shadow:none;grid-template-columns:24px 1fr;align-items:start;gap:7px;padding:8px;display:grid}.clue-row span{font-size:12px;font-weight:950}.clue-row strong{min-width:0;font-size:13px;line-height:1.15}.clue-row.is-current{background:var(--gold);box-shadow:2px 2px 0 var(--ink)}.clue-row.is-complete:not(.is-current){color:#6d6d61;background:#f3efe4}.ad-slot{border:2px dashed var(--line);min-height:92px;color:var(--muted);text-transform:uppercase;background:#fffdf7a6;place-items:center;font-size:12px;font-weight:950;display:grid}.completion-overlay{z-index:20;background:#11100e52;place-items:center;padding:18px;display:grid;position:fixed;inset:0}.completion-modal{z-index:2;border:5px solid var(--ink);background:var(--panel);width:min(100%,410px);box-shadow:8px 8px 0 var(--ink);text-align:center;justify-items:center;gap:14px;padding:26px 20px 20px;display:grid;position:relative}.completion-modal h2{margin:0;font-size:30px;font-weight:950;line-height:1}.completion-kicker{text-transform:uppercase;font-size:13px;font-weight:950}.completion-stats{grid-template-columns:repeat(3,minmax(0,1fr));gap:8px;width:100%;margin:2px 0 4px;display:grid}.completion-stats div{border:2px solid var(--ink);background:var(--white);gap:4px;padding:9px 6px;display:grid}.completion-stats dt,.completion-stats dd{margin:0}.completion-stats dt{color:var(--muted);text-transform:uppercase;font-size:11px;font-weight:950}.completion-stats dd{text-transform:capitalize;font-size:18px;font-weight:950}.modal-close{border:2px solid var(--ink);background:var(--white);width:34px;height:34px;color:var(--ink);cursor:pointer;place-items:center;display:grid;position:absolute;top:8px;right:8px}.confetti{z-index:1;pointer-events:none;position:fixed;inset:0;overflow:hidden}.confetti span{top:-16px;left:var(--x);background:var(--gold);width:10px;height:16px;animation:confetti-fall 1.3s cubic-bezier(.2, .6, .4, 1) var(--delay) both;transform:rotate(var(--spin));position:absolute}.confetti span:nth-child(3n){background:var(--blue)}.confetti span:nth-child(4n){background:var(--green)}.confetti span:nth-child(5n){background:var(--red)}.touch-keyboard{display:none}.keyboard-key{color:#12110f;cursor:pointer;letter-spacing:0;-webkit-user-select:none;user-select:none;-webkit-tap-highlight-color:transparent;background:#fffdf8;border:0;font-weight:900}@keyframes confetti-fall{0%{opacity:0;transform:translateY(-20px)rotate(0)}15%{opacity:1}to{opacity:1;transform:translateY(100vh) rotate(var(--spin))}}@media (max-width:900px){:root{--touch-keyboard-height:159px;--touch-clue-height:48px}.app-shell{padding:8px 10px calc(var(--touch-keyboard-height) + var(--touch-clue-height) + 22px)}.play-surface{min-height:calc(100vh - 24px)}.topbar{align-items:center;gap:8px;margin-bottom:8px}.brand-lockup{gap:8px}.brand-mark{width:40px;height:40px;box-shadow:2px 2px 0 var(--ink);border-width:2px;font-size:15px}.brand-lockup h1{font-size:23px}.mobile-timer{border:2px solid var(--ink);background:var(--panel);min-width:72px;min-height:34px;box-shadow:2px 2px 0 var(--ink);font-variant-numeric:tabular-nums;place-items:center;margin-left:auto;font-size:15px;font-weight:950;display:grid}.mobile-timer.is-complete{background:var(--green);cursor:pointer}.daily-status{min-width:122px;padding:6px 9px}.stats-strip{display:none}.game-layout{grid-template-columns:1fr;gap:10px}.side-panel{width:100%}.active-clue-tray{z-index:12;right:10px;bottom:calc(var(--touch-keyboard-height) + env(safe-area-inset-bottom) + 6px);width:auto;min-height:var(--touch-clue-height);padding:7px 10px;position:fixed;left:10px}.active-clue-tray span{font-size:11px}.active-clue-tray strong{font-size:15px;line-height:1.1}.play-surface.is-complete .active-clue-tray{width:min(100%,560px);position:static}.completion-modal{box-shadow:5px 5px 0 var(--ink)}.touch-keyboard{z-index:11;height:calc(var(--touch-keyboard-height) + env(safe-area-inset-bottom));padding:8px 7px calc(8px + env(safe-area-inset-bottom));-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);background:#cdd1d8f5;border-top:1px solid #11100e38;gap:6px;display:grid;position:fixed;bottom:0;left:0;right:0;box-shadow:0 -8px 22px #11100e2e}.keyboard-row{justify-content:center;gap:5px;min-width:0;display:flex}.keyboard-row-middle{padding:0 15px}.keyboard-key{touch-action:manipulation;border-radius:7px;flex:1 1 0;justify-content:center;align-items:center;min-width:0;max-width:44px;height:42px;font-size:20px;line-height:1;transition:background-color 80ms,box-shadow 80ms,transform 80ms;display:inline-flex;box-shadow:inset 0 1px #ffffffbf,0 2px #63676ed1}.keyboard-key:active{background:#e8e9ec;transform:translateY(1px)scale(.98);box-shadow:inset 0 1px #ffffff80,0 1px #63676ead}.keyboard-key-wide{background:#acb2bd;max-width:56px;font-size:19px}}@media (max-width:560px){.brand-mark{width:38px;height:38px}.brand-lockup h1{font-size:22px}.daily-status{display:none}.result-button{min-height:32px;padding:0 8px}.cell-number{top:4px;left:4px}.action-bar{grid-template-columns:repeat(2,minmax(0,1fr)) 44px}.clue-board{grid-template-columns:1fr}.active-clue-tray{grid-template-columns:1fr;gap:4px}}@media (max-width:380px){:root{--touch-keyboard-height:154px}.keyboard-key{height:40px;font-size:18px}}
