*,*:before,*:after{box-sizing:border-box}*{margin:0}html{-webkit-text-size-adjust:100%;scroll-behavior:smooth}:root{--color-bg: #1a1a2e;--color-bg-mid: #16213e;--color-bg-end: #0f3460;--color-text: #ffffff;--color-text-muted: rgba(255, 255, 255, .5);--color-surface: rgba(255, 255, 255, .08);--color-surface-hover: rgba(255, 255, 255, .12);--color-surface-elevated: #2a2a3e;--color-border: rgba(255, 255, 255, .15);--color-border-active: rgba(255, 255, 255, .4);--color-slot-filled: rgba(255, 255, 255, .08);--color-accent: #667eea;--color-accent-bg: rgba(102, 126, 234, .15);--color-correct: #538d4e;--color-misplaced: #b59f3b;--color-decoy: #3a3a4c}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Open Sans,Helvetica Neue,sans-serif;line-height:1.5;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:linear-gradient(135deg,var(--color-bg) 0%,var(--color-bg-mid) 50%,var(--color-bg-end) 100%);color:var(--color-text);min-height:100vh;min-height:100dvh}#root{min-height:100vh;min-height:100dvh}button{font-family:inherit;-webkit-tap-highlight-color:transparent}.word-button,.answer-slots__slot{-webkit-user-select:none;user-select:none}@media(pointer:coarse){.word-button{min-height:44px;min-width:44px}}:focus-visible{outline:2px solid var(--color-accent);outline-offset:2px}.word-tile{width:100%;height:3rem;display:flex;align-items:center;justify-content:center;font-size:.9rem;font-weight:600;color:var(--color-text);background:var(--color-surface, rgba(255, 255, 255, .08));border:2px solid var(--color-border, rgba(255, 255, 255, .15));border-radius:.5rem;cursor:pointer;-webkit-user-select:none;user-select:none;-webkit-tap-highlight-color:transparent;transition:background .15s,border-color .15s;text-transform:lowercase}.word-tile:hover{background:var(--color-surface-hover, rgba(255, 255, 255, .12))}.word-tile--selected{background:var(--color-accent, #667eea);border-color:var(--color-accent, #667eea);color:#fff}.puzzle-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:.5rem;width:100%;padding:0 .5rem}.solved-phrases{display:flex;flex-direction:column;gap:.4rem;width:100%;padding:0 .5rem}.solved-phrases__item{display:flex;align-items:center;gap:.5rem;padding:.6rem .75rem;border-radius:.5rem;color:#fff;overflow:hidden}.solved-phrases__emoji{font-size:1rem;flex-shrink:0}.solved-phrases__text{font-size:.85rem;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;flex:1}.solved-phrases__stars{font-size:.75rem;flex-shrink:0}.mistake-dots{display:flex;align-items:center;gap:.5rem}.mistake-dots__label{font-size:.8rem;color:var(--color-text-muted);font-weight:500}.mistake-dots__dots{display:flex;gap:.35rem}.mistake-dots__dot{width:.6rem;height:.6rem;border-radius:50%;background:var(--color-surface, rgba(255, 255, 255, .15));border:1px solid var(--color-border, rgba(255, 255, 255, .25));transition:background .2s}.mistake-dots__dot--used{background:#e74c3c;border-color:#e74c3c}.stats-screen{width:100%;max-width:400px;margin:0 auto;padding:1.5rem}.stats-screen__header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1.5rem}.stats-screen__title{font-size:1.25rem;font-weight:700;color:var(--color-text)}.stats-screen__close{background:none;border:none;color:var(--color-text-muted);font-size:1.25rem;cursor:pointer;padding:.25rem}.stats-screen__summary{display:flex;justify-content:space-between;margin-bottom:1.5rem}.stats-screen__stat{display:flex;flex-direction:column;align-items:center;flex:1}.stats-screen__stat-value{font-size:1.75rem;font-weight:700;color:var(--color-text)}.stats-screen__stat-label{font-size:.7rem;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.05em}.stats-screen__freezes{text-align:center;font-size:.85rem;color:var(--color-accent);background:var(--color-accent-bg);padding:.5rem 1rem;border-radius:.5rem;margin-bottom:1.5rem}.stats-screen__distribution{margin-bottom:1rem}.stats-screen__section-title{font-size:.85rem;font-weight:600;color:var(--color-text);margin-bottom:.75rem}.stats-screen__dist-row{display:flex;align-items:center;gap:.5rem;margin-bottom:.35rem}.stats-screen__dist-label{width:1rem;text-align:right;font-size:.85rem;font-weight:600;color:var(--color-text)}.stats-screen__dist-bar-container{flex:1}.stats-screen__dist-bar{background:linear-gradient(135deg,#667eea,#764ba2);border-radius:.25rem;padding:.2rem .5rem;min-width:1.5rem;display:flex;justify-content:flex-end}.stats-screen__dist-bar--fail{background:var(--color-decoy, #3a3a4c)}.stats-screen__dist-count{font-size:.75rem;font-weight:600;color:#fff}.tutorial{width:100%;max-width:400px;margin:0 auto;display:flex;flex-direction:column;gap:1.5rem;padding:1.5rem;background:var(--color-surface);border-radius:1.5rem}.tutorial__step{display:flex;flex-direction:column;align-items:center;gap:1rem;text-align:center;min-height:240px}.tutorial__title{font-size:1.4rem;font-weight:700;color:var(--color-text);margin:0}.tutorial__body{font-size:.95rem;color:#fffc;line-height:1.5;margin:0}.tutorial__visual{display:flex;justify-content:center;width:100%}.tutorial__grid-demo{display:flex;flex-wrap:wrap;gap:.4rem;justify-content:center;align-items:center}.tutorial__tile{padding:.4rem .7rem;font-size:.8rem;font-weight:600;background:var(--color-surface, rgba(255, 255, 255, .08));border:2px solid var(--color-border, rgba(255, 255, 255, .15));border-radius:.4rem;color:var(--color-text)}.tutorial__tile--selected{background:var(--color-accent, #667eea);border-color:var(--color-accent, #667eea);color:#fff}.tutorial__tile--trap{background:#f0c040;border-color:#f0c040;color:#1a1a2e;font-size:1rem;padding:.5rem 1rem}.tutorial__arrow{width:100%;text-align:center;font-size:1.5rem;color:var(--color-text-muted);margin:.25rem 0}.tutorial__phrase-demo{padding:.6rem 1rem;background:var(--color-correct, #538d4e);border-radius:.5rem;color:#fff;font-size:.85rem;font-weight:600}.tutorial__trap-demo{display:flex;flex-direction:column;align-items:center;gap:.75rem}.tutorial__trap-arrows{display:flex;flex-direction:column;gap:.4rem;font-size:.8rem;color:#ffffffb3}.tutorial__trap-arrows strong{color:#f0c040}.tutorial__lives-demo{display:flex;flex-direction:column;align-items:center;gap:.75rem}.tutorial__dots{display:flex;gap:.4rem}.tutorial__dot{width:.75rem;height:.75rem;border-radius:50%;background:#ffffff26;border:1px solid rgba(255,255,255,.25)}.tutorial__near-miss{font-size:.9rem;font-weight:600;color:#f0c040;padding:.4rem .8rem;background:#f0c04026;border-radius:.5rem}.tutorial__nav{display:flex;flex-direction:column;align-items:center;gap:.75rem}.tutorial__dots-nav{display:flex;gap:.4rem}.tutorial__dot-nav{width:.5rem;height:.5rem;border-radius:50%;background:#fff3;transition:background .2s}.tutorial__dot-nav--active{background:var(--color-accent, #667eea)}.tutorial__next-btn{width:100%;padding:.85rem;font-size:1rem;font-weight:700;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:.75rem;cursor:pointer;box-shadow:0 4px 15px #667eea66}.tutorial__skip-btn{background:none;border:none;color:var(--color-text-muted);font-size:.85rem;cursor:pointer;padding:.25rem}.tutorial__rounds-demo{display:flex;flex-direction:column;gap:.5rem;width:100%}.tutorial__round-row{display:flex;align-items:center;justify-content:space-between;padding:.5rem .75rem;background:var(--color-surface, rgba(255, 255, 255, .08));border-radius:.5rem}.tutorial__round-label{font-size:.8rem;font-weight:600;color:var(--color-text);width:4rem}.tutorial__round-words{font-size:.8rem;color:var(--color-text-muted)}.tutorial__round-stars{font-size:.85rem}.tutorial__skip-btn:hover{color:var(--color-text)}.app{min-height:100vh;min-height:100dvh;display:flex;flex-direction:column;padding:1rem;padding-bottom:env(safe-area-inset-bottom,1rem);max-width:500px;margin:0 auto}.app__header{padding:.5rem 0 1rem}.app__header-row{display:flex;align-items:center;justify-content:space-between}.app__header-center{flex:1;text-align:center}.app__icon-button{background:none;border:none;font-size:1.25rem;cursor:pointer;padding:.5rem;border-radius:.5rem;width:2.5rem;height:2.5rem;display:flex;align-items:center;justify-content:center}.app__icon-button:hover{background:var(--color-surface-hover)}.app__icon-button:disabled{opacity:.4;cursor:not-allowed}.app__hard-toggle--active{background:var(--color-accent-bg)}.app__title{font-size:2rem;font-weight:800;margin:0;background:linear-gradient(135deg,#667eea,#764ba2);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.app__subtitle{font-size:.75rem;color:var(--color-text-muted);margin:.15rem 0 0;text-transform:uppercase;letter-spacing:.15em}.app__main{flex:1;display:flex;flex-direction:column;align-items:center}.app__panel{width:100%}.app__game{width:100%;display:flex;flex-direction:column;gap:1rem}.app__hint-text{font-size:.85rem;color:var(--color-text-muted);text-align:center;margin:0;padding:0 1rem;line-height:1.4}.app__near-miss{text-align:center;font-size:.9rem;font-weight:600;color:#f0c040;margin:0}.app__controls{display:flex;align-items:center;justify-content:space-between;padding:0 .5rem}.app__shuffle-btn{background:var(--color-surface);border:1px solid var(--color-border);color:var(--color-text);padding:.4rem .75rem;border-radius:.5rem;font-size:.8rem;font-weight:500;cursor:pointer}.app__round-info{display:flex;justify-content:space-between;align-items:center;padding:0 .5rem;width:100%}.app__round-label{font-size:.8rem;font-weight:600;color:var(--color-text-muted);background:var(--color-surface);padding:.3rem .6rem;border-radius:.4rem}.app__stars-label{font-size:.8rem;color:var(--color-text-muted)}.app__reveal-btn{width:100%;padding:.6rem;margin:0 .5rem;font-size:.85rem;font-weight:600;background:var(--color-surface);border:1px dashed var(--color-border);color:var(--color-text);border-radius:.75rem;cursor:pointer}.app__reveal-btn:hover{background:var(--color-surface-hover)}.app__controls-right{display:flex;align-items:center;gap:.5rem}.app__timer{font-size:.8rem;font-weight:500;color:var(--color-text-muted);font-variant-numeric:tabular-nums}.app__shuffle-btn:hover{background:var(--color-surface-hover)}.app__actions{display:flex;gap:.75rem;padding:0 .5rem}.app__deselect-btn{flex:1;padding:.75rem;font-size:.9rem;font-weight:600;background:var(--color-surface);border:1px solid var(--color-border);color:var(--color-text);border-radius:.75rem;cursor:pointer}.app__deselect-btn:disabled{opacity:.3;cursor:not-allowed}.app__submit-button{flex:1;padding:.75rem;font-size:.9rem;font-weight:600;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:.75rem;cursor:pointer;box-shadow:0 4px 15px #667eea66}.app__submit-button:disabled{opacity:.3;cursor:not-allowed;box-shadow:none}.start-screen{padding:2rem;background:var(--color-surface);border-radius:1.5rem;display:flex;flex-direction:column;align-items:center;gap:1.25rem;text-align:center}.start-screen__title{font-size:1.5rem;font-weight:700;color:var(--color-text);margin:0}.start-screen__rules{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:.5rem;width:100%;text-align:left}.start-screen__rules li{font-size:.875rem;color:#fffc;padding:.5rem .75rem;background:var(--color-surface);border-radius:.5rem}.start-screen__streak{font-size:1.25rem;font-weight:700;color:var(--color-accent)}.start-screen__play-button{width:100%;padding:1rem;font-size:1.125rem;font-weight:700;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:.75rem;cursor:pointer;box-shadow:0 4px 15px #667eea66}.completion{display:flex;flex-direction:column;align-items:center;gap:1.25rem;padding:1.5rem 0}.completion__header{text-align:center}.completion__emoji{font-size:3rem}.completion__title{font-size:1.5rem;font-weight:700;color:var(--color-text);margin:.25rem 0 0}.completion__phrases{display:flex;flex-direction:column;gap:.5rem;width:100%}.completion__phrase{padding:.75rem;border-radius:.5rem;color:#fff}.completion__phrase--d1{background:var(--color-correct, #538d4e)}.completion__phrase--d2{background:#4a90d9}.completion__phrase--d3{background:#7b5ea7}.completion__phrase-text{font-size:.9rem;font-weight:700}.completion__phrase-fact{font-size:.75rem;opacity:.9;margin-top:.25rem;line-height:1.4}.completion__stats{display:flex;gap:2rem;justify-content:center}.completion__stat{display:flex;flex-direction:column;align-items:center;gap:.25rem}.completion__stat-value{font-size:1.5rem;font-weight:700;color:var(--color-text)}.completion__stat-label{font-size:.7rem;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.1em}.completion__milestone{font-size:1.25rem;font-weight:700;color:var(--color-accent);padding:.5rem 1rem;background:var(--color-accent-bg);border-radius:.75rem}.completion__buttons{display:flex;flex-direction:column;gap:.75rem;width:100%}.completion__share-btn{width:100%;padding:1rem;font-size:1rem;font-weight:600;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:.75rem;cursor:pointer}.completion__another-btn{width:100%;padding:1rem;font-size:1rem;font-weight:600;background:var(--color-surface);color:#fff;border:1px solid var(--color-border);border-radius:.75rem;cursor:pointer}.completion__comeback{font-size:.85rem;color:var(--color-text-muted);margin:0}
