:root{font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;line-height:1.5;font-weight:400;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}html,body,#root{margin:0;padding:0;min-height:100vh}body{background:#f5f3ff;color:#1e1b4b}#root{display:flex;flex-direction:column}button{font-family:inherit}h1,h2,h3,h4,h5,h6,p{margin:0}.grid{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;width:280px;margin:0 auto}.grid-cell{position:relative;display:flex;align-items:center;justify-content:center;width:80px;height:80px;border-radius:12px;border:2px solid #ddd;background:#fff;cursor:pointer;font-size:1.6rem;font-weight:700;letter-spacing:.05em;color:#333;transition:background .12s,transform .08s,border-color .12s,box-shadow .12s;-webkit-user-select:none;user-select:none;box-shadow:0 2px 6px #00000014}.grid-cell:hover{background:#f0f0ff;border-color:#7c3aed;transform:translateY(-1px);box-shadow:0 4px 12px #7c3aed26}.grid-cell:active{transform:translateY(0)}.grid-cell--center{background:#7c3aed;border-color:#7c3aed;color:#fff;box-shadow:0 4px 16px #7c3aed59}.grid-cell--center:hover{background:#6d28d9;border-color:#6d28d9;color:#fff}.grid-cell--selected{background:#ddd6fe;border-color:#7c3aed;color:#4c1d95;cursor:not-allowed;opacity:.6;transform:none!important;box-shadow:none}.grid-cell--center.grid-cell--selected{background:#5b21b6;border-color:#5b21b6;color:#fff}.grid-cell:disabled:hover{background:#ddd6fe;border-color:#7c3aed;transform:none;box-shadow:none}.grid-cell--center:disabled:hover{background:#5b21b6;border-color:#5b21b6}.grid-cell__letter{pointer-events:none}.grid-cell__order{position:absolute;top:4px;right:6px;font-size:.6rem;font-weight:600;color:#7c3aed;line-height:1}.grid-cell--center .grid-cell__order{color:#c4b5fd}@media(max-width:400px){.grid{width:240px;gap:8px}.grid-cell{width:68px;height:68px;font-size:1.4rem;border-radius:10px}}.word-input{display:flex;flex-direction:column;align-items:center;gap:8px;width:100%;max-width:320px;margin:0 auto}.word-input__display{min-height:52px;width:100%;display:flex;align-items:center;justify-content:center;background:#f8f7ff;border:2px solid #e5e7eb;border-radius:10px;padding:8px 16px;font-size:1.5rem;font-weight:700;letter-spacing:.12em;color:#1e1b4b;text-transform:uppercase;transition:border-color .15s}.word-input__placeholder{font-size:.9rem;font-weight:400;color:#9ca3af;letter-spacing:0;text-transform:none}.word-input__word{color:#4c1d95}.word-input__feedback{font-size:.85rem;font-weight:600;padding:4px 12px;border-radius:6px;min-height:28px;display:flex;align-items:center;justify-content:center;text-align:center;transition:opacity .2s}.word-input__feedback--valid{background:#d1fae5;color:#065f46}.word-input__feedback--invalid{background:#fee2e2;color:#991b1b}.word-input__actions{display:flex;gap:8px;align-items:center}.word-input__btn{padding:8px 18px;border-radius:8px;border:none;font-size:1rem;font-weight:600;cursor:pointer;transition:background .12s,transform .08s,opacity .12s;-webkit-user-select:none;user-select:none}.word-input__btn:disabled{opacity:.4;cursor:not-allowed}.word-input__btn:not(:disabled):active{transform:translateY(1px)}.word-input__btn--primary{background:#7c3aed;color:#fff;min-width:80px}.word-input__btn--primary:not(:disabled):hover{background:#6d28d9}.word-input__btn--secondary{background:#e5e7eb;color:#374151}.word-input__btn--secondary:not(:disabled):hover{background:#d1d5db}.found-words{width:100%;max-width:360px;background:#fff;border-radius:12px;border:1px solid #e5e7eb;overflow:hidden;box-shadow:0 2px 8px #0000000f}.found-words__header{display:flex;align-items:center;justify-content:space-between;padding:10px 14px;background:#f3f0ff;border-bottom:1px solid #e5e7eb}.found-words__count{font-size:.9rem;font-weight:700;color:#4c1d95}.found-words__reveal-btn{font-size:.8rem;font-weight:600;color:#7c3aed;background:none;border:1px solid #7c3aed;border-radius:6px;padding:2px 8px;cursor:pointer;transition:background .12s,color .12s}.found-words__reveal-btn:hover{background:#7c3aed;color:#fff}.found-words__groups{max-height:340px;overflow-y:auto;padding:10px;display:flex;flex-direction:column;gap:12px}.found-words__group{display:flex;flex-direction:column;gap:4px}.found-words__group-header{display:flex;justify-content:space-between;padding:2px 4px;border-bottom:1px solid #f0e9ff;margin-bottom:2px}.found-words__len-label{font-size:.75rem;font-weight:700;color:#7c3aed;text-transform:uppercase;letter-spacing:.05em}.found-words__len-count{font-size:.75rem;color:#9ca3af}.found-words__list{display:flex;flex-direction:column;gap:2px}.found-words__item{display:flex;align-items:center;gap:6px;padding:3px 6px;border-radius:5px;font-size:.85rem;min-height:24px}.found-words__item--found{background:#f0fdf4;color:#065f46}.found-words__item--blank{color:#d1d5db}.found-words__item--pangram{background:#fef9c3;color:#78350f}.found-words__word{font-weight:600;flex:1;text-transform:uppercase;letter-spacing:.04em}.found-words__pts{font-size:.75rem;font-weight:600;color:#059669;margin-left:auto}.found-words__item--pangram .found-words__pts{color:#d97706}.found-words__pangram-badge{color:#f59e0b;font-size:.8rem}.found-words__blank{font-family:monospace;letter-spacing:.15em;color:#e5e7eb}.found-words__groups::-webkit-scrollbar{width:5px}.found-words__groups::-webkit-scrollbar-track{background:#f9f7ff}.found-words__groups::-webkit-scrollbar-thumb{background:#c4b5fd;border-radius:3px}.score-panel{width:100%;max-width:320px;background:#fff;border-radius:12px;border:1px solid #e5e7eb;padding:14px 16px 20px;box-shadow:0 2px 8px #0000000f;display:flex;flex-direction:column;gap:10px}.score-panel__top{display:flex;align-items:center;gap:12px}.score-panel__score-block{display:flex;align-items:baseline;gap:4px}.score-panel__score{font-size:2rem;font-weight:800;color:#4c1d95;line-height:1}.score-panel__max{font-size:.8rem;color:#9ca3af}.score-panel__rank{font-size:.9rem;font-weight:700;color:#7c3aed;background:#f3f0ff;border-radius:6px;padding:3px 10px;margin-left:auto}.score-panel__words{font-size:.85rem;color:#6b7280;display:flex;align-items:baseline}.score-panel__found{font-weight:700;color:#4c1d95}.score-panel__progress{position:relative;height:8px;background:#e5e7eb;border-radius:4px;overflow:visible;margin-top:4px}.score-panel__progress-fill{height:100%;background:linear-gradient(90deg,#7c3aed,#a78bfa);border-radius:4px;transition:width .4s ease;min-width:0}.score-panel__tick{position:absolute;top:-3px;width:2px;height:14px;background:#d1d5db;border-radius:1px;transform:translate(-50%);transition:background .3s}.score-panel__tick--active{background:#7c3aed}.score-panel__rank-table{width:100%;border-collapse:collapse;margin-top:6px;font-size:.82rem}.score-panel__rank-row td{padding:3px 4px;color:#9ca3af}.score-panel__rank-row--active td{color:#4c1d95;font-weight:700}.score-panel__rank-dot{width:14px;color:#7c3aed;font-size:.6rem}.score-panel__rank-name{width:70px}.score-panel__rank-pts{width:55px;text-align:right;font-variant-numeric:tabular-nums}.score-panel__rank-next{text-align:right;color:#a78bfa;font-size:.75rem;font-style:italic}.modal-backdrop{position:fixed;inset:0;background:#4c1d9573;display:flex;align-items:center;justify-content:center;z-index:100;padding:16px}.modal{background:#fff;border-radius:16px;padding:32px 28px 28px;max-width:360px;width:100%;box-shadow:0 8px 40px #4c1d9540;text-align:center}.modal__title{margin:0 0 8px;font-size:1.4rem;font-weight:800;color:#4c1d95}.modal__sub{margin:0 0 20px;font-size:.9rem;color:#6b7280}.modal__form{display:flex;flex-direction:column;gap:12px}.modal__input{padding:12px 14px;border:2px solid #ddd6fe;border-radius:10px;font-size:16px;font-family:inherit;color:#1e1b4b;outline:none;transition:border-color .15s}.modal__input:focus{border-color:#7c3aed}.modal__btn{padding:12px;background:#7c3aed;color:#fff;border:none;border-radius:10px;font-size:1rem;font-weight:700;font-family:inherit;cursor:pointer;transition:background .12s}.modal__btn:hover:not(:disabled){background:#6d28d9}.modal__btn:disabled{opacity:.4;cursor:default}*,*:before,*:after{box-sizing:border-box}.app{min-height:100vh;display:flex;flex-direction:column;background:#f5f3ff;font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;color:#1e1b4b}.app__header{text-align:center;padding:20px 16px 12px;background:linear-gradient(135deg,#4c1d95,#7c3aed);color:#fff;box-shadow:0 2px 12px #4c1d954d}.app__title-row{display:flex;align-items:center;justify-content:center;gap:12px;margin-bottom:6px}.app__title{margin:0;font-size:1.8rem;font-weight:900;letter-spacing:.05em;color:#fff;text-shadow:0 2px 8px rgba(0,0,0,.25)}.app__mode-badge{font-size:.8rem;font-weight:600;background:#fff3;border-radius:12px;padding:3px 10px;color:#e9d5ff}.app__subtitle{margin:0;font-size:.85rem;color:#c4b5fd;font-weight:400}.app__user-row{margin-top:8px;font-size:.82rem;color:#e9d5ff;display:flex;align-items:center;justify-content:center;gap:8px}.app__user-name{font-weight:600}.app__user-change{background:none;border:none;color:#c4b5fd;font-size:.78rem;cursor:pointer;text-decoration:underline;font-family:inherit;padding:0}.app__user-change:hover{color:#fff}.app__loading{display:flex;flex-direction:column;align-items:center;justify-content:center;flex:1;gap:16px;color:#7c3aed;font-weight:600}.app__spinner{width:40px;height:40px;border:3px solid #ddd6fe;border-top-color:#7c3aed;border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.app__error{display:flex;flex-direction:column;align-items:center;justify-content:center;flex:1;gap:12px;color:#991b1b;text-align:center;padding:24px}.app__error button{background:#7c3aed;color:#fff;border:none;border-radius:8px;padding:10px 24px;font-size:1rem;font-weight:600;cursor:pointer}.app__main{display:flex;flex-direction:column;flex:1;gap:0;padding:0;max-width:520px;margin:0 auto;width:100%}.app__play-area{display:flex;flex-direction:column;align-items:center;gap:14px;padding:20px 16px 16px;background:#f5f3ff}.app__bottom{display:flex;flex-direction:column;gap:12px;padding:16px;background:#fff;border-top:1px solid #e5e7eb;flex:1}.app__hint{font-size:.82rem;color:#6b7280;text-align:center}.app__center-hint{color:#7c3aed;font-size:1rem}.app__hint-sep{margin:0 4px}.app__controls{display:flex;gap:8px;align-items:flex-end}.app__daily-group{display:flex;flex-direction:column;align-items:center;gap:4px}.app__date{font-size:.72rem;color:#9ca3af;font-weight:500;letter-spacing:.02em}.app__btn{padding:8px 16px;border-radius:8px;font-size:.85rem;font-weight:600;cursor:pointer;transition:background .12s,color .12s,transform .08s;border:2px solid #7c3aed;font-family:inherit}.app__btn:active{transform:translateY(1px)}.app__btn--outline{background:transparent;color:#7c3aed}.app__btn--outline:hover{background:#f3f0ff}.app__btn--active{background:#7c3aed;color:#fff}.app__btn--active:hover{background:#6d28d9}.app__my-words-btn{background:#7c3aed14;border:1.5px solid #c4b5fd;color:#6d28d9;border-radius:20px;padding:5px 18px;font-size:.82rem;font-weight:600;font-family:inherit;cursor:pointer;transition:background .12s,border-color .12s}.app__my-words-btn:hover{background:#7c3aed26;border-color:#7c3aed}.words-popup-backdrop{position:fixed;inset:0;background:#4c1d9566;display:flex;align-items:flex-end;justify-content:center;z-index:100;padding:0}.words-popup{background:#fff;border-radius:20px 20px 0 0;width:100%;max-width:520px;max-height:70vh;display:flex;flex-direction:column;box-shadow:0 -4px 24px #4c1d9533}.words-popup__header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px 12px;border-bottom:1px solid #e5e7eb}.words-popup__title{font-size:1rem;font-weight:700;color:#4c1d95}.words-popup__close{background:none;border:none;font-size:1rem;color:#9ca3af;cursor:pointer;padding:4px;line-height:1}.words-popup__close:hover{color:#4c1d95}.words-popup__body{overflow-y:auto;padding:14px 20px 24px;display:flex;flex-direction:column;gap:12px}.words-popup__empty{color:#9ca3af;text-align:center;font-size:.9rem;padding:20px 0;margin:0}.words-popup__group{display:flex;flex-direction:column;gap:6px}.words-popup__len{font-size:.72rem;font-weight:700;color:#7c3aed;text-transform:uppercase;letter-spacing:.06em}.words-popup__list{display:flex;flex-wrap:wrap;gap:6px}.words-popup__word{background:#f0fdf4;color:#065f46;border-radius:6px;padding:3px 10px;font-size:.85rem;font-weight:600;letter-spacing:.04em;text-transform:uppercase}.words-popup__word--pangram{background:#fef9c3;color:#78350f}.app__footer{text-align:center;padding:12px 16px 16px;font-size:.78rem;color:#9ca3af;border-top:1px solid #e5e7eb;background:#fff}.app__footer p{margin:2px 0}.app__keyboard-hint{font-style:italic}
