:root{--purple-50:#faf5ff;--purple-100:#f3e8ff;--purple-200:#e9d5ff;--purple-300:#d8b4fe;--purple-400:#c084fc;--purple-500:#a855f7;--purple-600:#9333ea;--purple-700:#7e22ce;--purple-800:#6b21a8;--purple-900:#581c87;--primary:var(--purple-600);--primary-light:var(--purple-100);--primary-hover:var(--purple-700);--primary-subtle:var(--purple-50);--text:#4b5563;--text-heading:#1f2937;--bg:#fff;--bg-secondary:var(--purple-50);--border:#e5e7eb;--border-focus:var(--purple-400);--shadow:#9333ea1a 0 10px 25px -5px, #9333ea0d 0 4px 10px -4px;--shadow-lg:#9333ea26 0 20px 40px -10px, #9333ea1a 0 8px 16px -6px;--success:#16a34a;--success-bg:#f0fdf4;--error:#dc2626;--error-bg:#fef2f2;--sans:system-ui, "Segoe UI", Roboto, sans-serif;font:16px/1.5 var(--sans);color:var(--text);background:var(--bg-secondary);-webkit-font-smoothing:antialiased}*{box-sizing:border-box}body{margin:0}h1,h2,h3,h4{color:var(--text-heading);font-weight:700}.app{max-width:800px;margin:0 auto;padding:24px 20px}.app-header{text-align:center;margin-bottom:16px}.logo{width:90px;height:auto;margin-bottom:-4px}@media (width<=480px){.logo{width:70px}}.app-header h1{letter-spacing:-1.5px;color:var(--primary);margin:0;font-size:2.8rem}@media (width<=480px){.app-header h1{font-size:2rem}}.subtitle{color:var(--text);margin-top:4px;font-size:1rem;font-weight:400}.date{color:var(--primary);margin-top:2px;font-size:.9rem;font-weight:600}.scoreboard{flex-direction:column;align-items:center;gap:12px;margin-bottom:20px;display:flex}.score-info{color:var(--text-heading);gap:24px;font-size:1.05rem;font-weight:600;display:flex}@media (width<=480px){.score-info{gap:16px;font-size:.9rem}}.game-over{text-align:center;background:var(--bg);box-shadow:var(--shadow);border-radius:12px;padding:16px 24px}.game-over-text{color:var(--text-heading);margin:0 0 8px;font-size:1.1rem;font-weight:600}.game-over-hint{color:var(--text);margin:0 0 12px;font-size:.85rem}.reset-button{background:var(--primary);color:#fff;cursor:pointer;border:none;border-radius:8px;padding:10px 28px;font-size:1rem;font-weight:600;transition:background .2s,transform .1s}.reset-button:hover{background:var(--primary-hover);transform:translateY(-1px)}.reset-button:active{transform:translateY(0)}.give-up-button{border:2px solid var(--border);background:var(--bg);color:var(--text);cursor:pointer;border-radius:8px;padding:8px 20px;font-size:.85rem;font-weight:500;transition:border-color .2s,color .2s}.give-up-button:hover{border-color:var(--error);color:var(--error)}.game-grid-container{-webkit-overflow-scrolling:touch;justify-content:center;display:flex;overflow-x:auto}.game-grid{background:var(--purple-200);border:3px solid var(--primary);border-radius:12px;flex-shrink:0;grid-template-rows:70px repeat(4,100px);grid-template-columns:120px repeat(4,110px);gap:2px;display:grid;overflow:hidden}@media (width<=620px){.game-grid{border-width:2px;border-radius:8px;flex-shrink:1;grid-template-rows:56px repeat(4,76px);grid-template-columns:80px repeat(4,1fr);width:100%;min-width:0}.game-grid-container{overflow-x:visible}}@media (width<=380px){.game-grid{grid-template-rows:48px repeat(4,68px);grid-template-columns:64px repeat(4,1fr)}}.grid-header{text-align:center;justify-content:center;align-items:center;padding:6px;font-size:.72rem;font-weight:700;line-height:1.2;display:flex}@media (width<=620px){.grid-header{padding:4px;font-size:.62rem}}@media (width<=380px){.grid-header{padding:3px;font-size:.55rem}}.grid-header.corner{background:var(--primary)}.grid-header.col-header,.grid-header.row-header{background:var(--primary);color:#fff}.grid-cell{background:var(--bg);cursor:pointer;text-align:center;word-break:break-word;border:none;justify-content:center;align-items:center;padding:6px;font-size:.72rem;line-height:1.2;transition:background .15s;display:flex}@media (width<=620px){.grid-cell{padding:3px;font-size:.6rem}}.grid-cell.empty:hover:not(:disabled){background:var(--primary-light)}.grid-cell.empty:disabled{cursor:default;opacity:.6}.grid-cell.correct{background:var(--success-bg);color:var(--success);font-weight:700}.grid-cell.incorrect{background:var(--error-bg);color:var(--error);font-weight:600;text-decoration:line-through}.grid-cell.revealed{background:var(--purple-50);color:var(--primary);opacity:.85;font-style:italic;font-weight:600}.grid-cell.viewable{cursor:pointer;transition:filter .15s}.grid-cell.viewable:hover{filter:brightness(.95)}.modal-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:100;background:#581c8766;justify-content:center;align-items:center;padding:16px;display:flex;position:fixed;inset:0}.modal{background:var(--bg);width:380px;max-width:100%;max-height:90vh;box-shadow:var(--shadow-lg);border:1px solid var(--purple-200);border-radius:16px;padding:24px;overflow-y:auto}@media (width<=480px){.modal{border-radius:12px;padding:18px}}.modal-header{justify-content:space-between;align-items:center;gap:8px;margin-bottom:16px;display:flex}.modal-header h3{color:var(--text-heading);margin:0;font-size:1rem;line-height:1.3}@media (width<=480px){.modal-header h3{font-size:.9rem}}.modal-plus{color:var(--primary);margin:0 4px;font-weight:400}.modal-close{cursor:pointer;color:var(--text);background:0 0;border:none;border-radius:6px;flex-shrink:0;padding:4px 8px;font-size:1.5rem;line-height:1}.modal-close:hover{background:var(--primary-light);color:var(--primary)}.attempts-indicator{align-items:center;gap:6px;margin-bottom:12px;display:flex}.attempt-dot{background:var(--primary-light);border:2px solid var(--primary);border-radius:50%;width:10px;height:10px;transition:background .2s}.attempt-dot.used{background:var(--error);border-color:var(--error)}.attempts-text{color:var(--text);margin-left:4px;font-size:.8rem;font-weight:500}.wrong-guesses{flex-wrap:wrap;gap:6px;margin-bottom:12px;display:flex}.wrong-guess-tag{background:var(--error-bg);color:var(--error);border-radius:20px;align-items:center;padding:4px 10px;font-size:.8rem;font-weight:500;text-decoration:line-through;display:inline-flex}.guess-input{border:2px solid var(--border);background:var(--bg);width:100%;color:var(--text-heading);box-sizing:border-box;border-radius:8px;padding:12px 14px;font-size:1rem;transition:border-color .2s}.guess-input:focus{border-color:var(--primary);box-shadow:0 0 0 3px var(--purple-100);outline:none}.search-results{border:1px solid var(--border);border-radius:8px;max-height:200px;margin:4px 0 0;padding:0;list-style:none;overflow:hidden auto}.search-result{cursor:pointer;color:var(--text-heading);border-bottom:1px solid var(--border);padding:10px 14px;font-size:.9rem;transition:background .1s}.search-result:last-child{border-bottom:none}.search-result:hover,.search-result.selected{background:var(--primary-light);color:var(--primary)}.guess-submit{background:var(--primary);color:#fff;cursor:pointer;border:none;border-radius:8px;width:100%;margin-top:12px;padding:12px;font-size:1rem;font-weight:700;transition:background .2s,transform .1s}.guess-submit:hover:not(:disabled){background:var(--primary-hover);transform:translateY(-1px)}.guess-submit:active:not(:disabled){transform:translateY(0)}.guess-submit:disabled{opacity:.4;cursor:not-allowed}.answers-modal{max-width:420px}.your-answer{border-radius:8px;margin-bottom:16px;padding:10px 14px;font-size:.9rem}.your-answer.correct{background:var(--success-bg);color:var(--success)}.your-answer.incorrect{background:var(--error-bg);color:var(--error)}.answers-section h4{text-transform:uppercase;letter-spacing:.5px;color:var(--text);margin:0 0 8px;font-size:.8rem;font-weight:600}.answers-list{margin:0;padding:0;list-style:none}.answer-item{color:var(--text-heading);border-radius:6px;margin-bottom:2px;padding:8px 12px;font-size:.9rem}.answer-item:nth-child(odd){background:var(--primary-subtle)}.answer-item.was-guessed{color:var(--primary);font-weight:700}.no-answers{color:var(--text);padding:8px 0;font-size:.85rem;font-style:italic}.instructions-wrapper{text-align:center;margin-bottom:16px}.instructions-toggle{color:var(--primary);cursor:pointer;background:0 0;border:none;border-radius:6px;padding:4px 12px;font-size:.9rem;font-weight:600;transition:background .15s}.instructions-toggle:hover{background:var(--primary-light)}.instructions{text-align:left;background:var(--bg);border:1px solid var(--border);border-radius:12px;max-width:520px;margin:12px auto 0;padding:16px 20px 16px 12px}.instructions ol{margin:0;padding-left:24px}.instructions li{color:var(--text);margin-bottom:6px;font-size:.85rem;line-height:1.5}.instructions li:last-child{margin-bottom:0}.instructions strong{color:var(--text-heading)}
