:root{--bg: #F5F5F5;--surface: #FFFFFF;--surface-variant: #EBEBEB;--surface-variant-2: #E3E3E3;--primary: #197dba;--primary-container: #CCE4F7;--on-primary: #FFFFFF;--on-primary-container: #002744;--accent: #9A4520;--accent-container: #FFDCC5;--on-accent: #FFFFFF;--correct: #2E7D32;--correct-container: #C8E6C9;--on-correct: #FFFFFF;--wrong: #B71C1C;--wrong-container: #FFCDD2;--on-wrong: #FFFFFF;--text: #1C1B1F;--text-muted: #6B6577;--text-on-surface: #1C1B1F;--border: #D4D4D4;--shadow-sm: 0 1px 3px rgba(0,0,0,.07), 0 2px 6px rgba(0,0,0,.05);--shadow-md: 0 4px 12px rgba(0,0,0,.1);--shadow-lg: 0 8px 32px rgba(0,0,0,.14);--overlay-scrim: rgba(0, 0, 0, .45);--radius-sm: 8px;--radius-md: 12px;--radius-lg: 18px;--radius-xl: 24px;--font-sans: "Roboto", system-ui, sans-serif;--font-brand: "Montserrat", system-ui, sans-serif;--font-display: "Roboto", system-ui, sans-serif;--font-serif: "Playfair Display", Georgia, serif}@media(prefers-color-scheme:dark){:root{--bg: #131016;--surface: #1E1B24;--surface-variant: #2B2733;--surface-variant-2: #332F3C;--primary: #4ECDD9;--primary-container: #004F58;--on-primary: #001F24;--on-primary-container: #97F0FF;--accent: #FFB77C;--accent-container: #5C2800;--on-accent: #1C0400;--correct: #66BB6A;--correct-container: #1B3A1E;--on-correct: #003A03;--wrong: #EF5350;--wrong-container: #3A1B1B;--on-wrong: #3A0000;--text: #E6E1E5;--text-muted: #9E9AA5;--text-on-surface: #E6E1E5;--border: #49454F;--shadow-sm: 0 1px 3px rgba(0,0,0,.3), 0 2px 6px rgba(0,0,0,.2);--shadow-md: 0 4px 12px rgba(0,0,0,.4);--shadow-lg: 0 8px 32px rgba(0,0,0,.55);--overlay-scrim: rgba(0, 0, 0, .65)}}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html,body,#root{height:100%}body{font-family:var(--font-sans);background:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;overflow-x:hidden}button{font-family:inherit;cursor:pointer;border:none;background:none;color:inherit}button:focus-visible{outline:2px solid var(--primary);outline-offset:2px}a{color:inherit;text-decoration:none}.app-shell{width:100%;max-width:430px;min-height:100dvh;margin:0 auto;position:relative;background:var(--bg);display:flex;flex-direction:column}.logo{display:inline-block;background:var(--primary);color:var(--bg);font-family:var(--font-brand);line-height:1;-webkit-user-select:none;user-select:none}.logo__solvey{font-weight:700;letter-spacing:-.02em}.logo__dotfun{font-weight:400}.logo--lg{font-size:2rem;padding:.22em .32em .34em;border-radius:.3em 1em .3em .3em}.logo--sm{font-size:.88rem;padding:.18em .28em .28em;border-radius:.18em .7em .18em .18em}.home{display:flex;flex-direction:column;min-height:100dvh}.home__header{padding:28px 20px 20px;text-align:center}.home__tagline{font-size:.82rem;color:var(--text-muted);margin-top:6px;letter-spacing:.03em}.home__list{flex:1;padding:0 16px 36px;display:flex;flex-direction:column;gap:10px}.section-divider{display:flex;align-items:center;gap:10px;padding:8px 2px 2px}.section-divider__line{flex:1;height:1px;background:var(--border)}.section-divider__label{font-size:.68rem;font-weight:600;letter-spacing:.12em;text-transform:uppercase;color:var(--text-muted)}.pack-card{background:var(--surface);border-radius:var(--radius-lg);padding:16px 12px 16px 16px;display:flex;align-items:center;gap:12px;box-shadow:var(--shadow-sm);cursor:pointer;transition:transform .12s ease,box-shadow .12s ease;-webkit-tap-highlight-color:transparent;border:none;width:100%;text-align:left}.pack-card:active{transform:scale(.97);box-shadow:none}.pack-card.pack-card--completed{opacity:.65}.pack-card__icon{flex-shrink:0;color:var(--text-muted)}.pack-card__body{flex:1;min-width:0}.pack-card__name{font-family:var(--font-display);font-weight:600;font-size:.97rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;color:var(--text)}.pack-card__meta{font-size:.78rem;color:var(--text-muted);margin-top:2px}.pack-card__countdown{font-size:.78rem;font-weight:500;color:var(--primary);margin-top:2px}.pack-card__cal-btn{padding:10px;border-radius:50%;color:var(--text-muted);flex-shrink:0;transition:background .15s;display:flex;align-items:center;justify-content:center}.pack-card__cal-btn:hover{background:var(--surface-variant)}.game{display:flex;flex-direction:column;height:100dvh;overflow:hidden}.game__header{padding:14px 18px 6px;flex-shrink:0;display:flex;align-items:center;gap:8px}.game__header-left{flex:1;min-width:0}.game__brand{margin-bottom:2px}.game__title{font-family:var(--font-display);font-size:1.3rem;color:var(--text)}.game__header-actions{display:flex;align-items:center;gap:2px;flex-shrink:0}.game__action-btn{width:36px;height:36px;border-radius:50%;color:var(--text-muted);display:flex;align-items:center;justify-content:center;transition:background .15s}.game__action-btn:hover{background:var(--surface-variant)}.game__title-pack{font-weight:900}.game__title-index{font-weight:400}.puzzle-area{flex:1;overflow-y:auto;display:flex;align-items:center;justify-content:center;padding:12px}.puzzle-words{display:flex;flex-wrap:wrap;justify-content:center;align-content:center;gap:6px 16px}.puzzle-word{display:flex;gap:4px}.letter-box{width:32px;height:38px;border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;font-family:var(--font-display);font-weight:700;font-size:.95rem;box-shadow:var(--shadow-sm);transition:background .2s ease,color .2s ease;will-change:transform}.letter-box--empty{background:var(--surface-variant);color:transparent}.letter-box--revealed{background:var(--primary);color:var(--on-primary)}.letter-box--pop{animation:letter-pop .3s ease forwards}@keyframes letter-pop{0%{transform:scale(.75)}55%{transform:scale(1.15)}to{transform:scale(1)}}.hearts{display:flex;justify-content:center;gap:5px;padding:6px 18px;flex-shrink:0}.heart{color:var(--wrong);transition:opacity .25s,transform .25s}.heart--lost{color:var(--border);opacity:.55;transform:scale(.85)}.hints{display:flex;gap:8px;padding:6px 18px;flex-shrink:0}.hint-chip{flex:1;background:var(--surface-variant);border-radius:var(--radius-md);padding:8px 10px;text-align:center;min-height:50px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;transition:background .35s ease,transform .35s ease;overflow:hidden}.hint-chip--unlocked{background:var(--primary-container);transform:scale(1.03)}.hint-chip__lock{color:var(--text-muted)}.hint-chip__countdown{font-size:.58rem;color:var(--text-muted);line-height:1.3}.hint-chip__text{font-size:.75rem;font-weight:600;color:var(--primary);display:none;line-height:1.3;text-align:center}.hint-chip--unlocked .hint-chip__lock,.hint-chip--unlocked .hint-chip__countdown{display:none}.hint-chip--unlocked .hint-chip__text{display:block}.game__body{display:contents}.keyboard{flex-shrink:0;padding:8px 8px max(16px,env(safe-area-inset-bottom))}.keyboard__row{display:flex;gap:4px;margin-bottom:5px;width:100%}.keyboard__row:last-child{margin-bottom:0}.key{flex:1;height:48px;border-radius:var(--radius-sm);background:var(--surface-variant);color:var(--text);font-family:var(--font-display);font-weight:700;font-size:.9rem;transition:background .15s ease,opacity .15s ease,transform .08s ease;-webkit-tap-highlight-color:transparent;-webkit-user-select:none;user-select:none;display:flex;align-items:center;justify-content:center;box-shadow:var(--shadow-sm)}.key:active:not(:disabled){transform:scale(.88)}.key:disabled{cursor:default;box-shadow:none}.key--vowel{opacity:.42}.key--correct{background:var(--correct);color:var(--on-correct)}.key--wrong{background:var(--wrong);color:var(--on-wrong)}.key-spacer{flex:.5}.overlay-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:var(--overlay-scrim);z-index:90;opacity:0;pointer-events:none;transition:opacity .3s ease}.overlay-backdrop--visible{opacity:1;pointer-events:all}.overlay{position:fixed;bottom:0;left:50%;transform:translate(-50%) translateY(102%);width:100%;max-width:430px;max-height:92dvh;background:var(--surface);border-radius:var(--radius-xl) var(--radius-xl) 0 0;z-index:100;overflow-y:auto;transition:transform .42s cubic-bezier(.34,1.4,.64,1);padding:10px 20px max(32px,env(safe-area-inset-bottom));display:flex;flex-direction:column;gap:20px}.overlay--visible{transform:translate(-50%) translateY(0)}.overlay__handle{width:36px;height:4px;background:var(--border);border-radius:2px;margin:4px auto 0;flex-shrink:0}.overlay__pack-label{font-size:.78rem;color:var(--text-muted);font-family:var(--font-display);text-align:center}.overlay__movie-name{font-family:var(--font-display);font-weight:700;font-size:1.25rem;color:var(--text);margin-top:4px;line-height:1.2;text-align:center}.overlay__hints-line{font-size:.82rem;color:var(--text-muted);margin-top:5px;font-weight:400;text-align:center}.result-card{background:var(--surface-variant);border-radius:var(--radius-md);padding:14px 16px;text-align:center}.result-card__label{font-size:.68rem;text-transform:uppercase;letter-spacing:.12em;font-weight:600;color:var(--text-muted);margin-bottom:8px}.result-card__emojis{font-size:1.45rem;letter-spacing:1px;line-height:1.6;word-break:break-all}.stats-cards{display:flex;gap:8px}.stats-card{flex:1;background:var(--surface-variant);border-radius:var(--radius-md);padding:12px 8px 10px;display:flex;flex-direction:column;align-items:center;gap:4px}.stats-card__value{display:flex;align-items:center;gap:5px;font-family:var(--font-display);font-weight:700;font-size:1.25rem;line-height:1;color:var(--text)}.stats-card__icon--accuracy{color:#c62828}.stats-card__icon--streak{color:#1565c0}.stats-card__icon--trophy{color:#e65100}.stats-card__icon--guess{color:#2e7d32}.stats-card__label{font-size:.65rem;text-transform:uppercase;letter-spacing:.08em;font-weight:600;color:var(--text-muted);text-align:center;line-height:1.3}.stats-inline{display:flex;align-items:center;gap:10px;margin-top:3px}.stats-inline__item{display:flex;align-items:center;gap:3px;font-size:.75rem;font-weight:600;color:var(--text-muted)}.stats-inline__item--accuracy svg{color:#c62828}.stats-inline__item--streak svg{color:#1565c0}.stats-inline__item--trophy svg{color:#e65100}.stats-inline__item--guess svg{color:#2e7d32}.overlay-section{display:flex;flex-direction:column;gap:10px}.overlay-section__label{font-size:.68rem;text-transform:uppercase;letter-spacing:.12em;font-weight:600;color:var(--text-muted);text-align:center}.overlay-section__sublabel{font-size:.78rem;color:var(--text-muted);margin-top:-4px;margin-bottom:2px}.btn-row{display:flex;gap:8px;flex-wrap:wrap}.btn{border-radius:var(--radius-md);padding:13px 16px;font-family:var(--font-sans);font-weight:500;font-size:.84rem;display:inline-flex;align-items:center;justify-content:center;gap:6px;transition:transform .1s ease,opacity .1s ease;-webkit-tap-highlight-color:transparent;white-space:nowrap}.btn:active{transform:scale(.95)}.btn--primary{background:var(--primary);color:var(--on-primary)}.btn--ghost{background:var(--surface-variant);color:var(--text)}.btn--flex{flex:1}.btn--instagram{background:linear-gradient(45deg,#f09433,#e6683c,#dc2743,#cc2366,#bc1888);background-size:300% 300%;animation:instagram-gradient 3s ease infinite;color:#fff}@keyframes instagram-gradient{0%{background-position:0% 50%}50%{background-position:100% 50%}to{background-position:0% 50%}}.social-row{display:flex;justify-content:center;gap:16px;margin-top:4px}.social-btn{width:52px;height:52px;border-radius:50%;background:var(--surface-variant);display:flex;align-items:center;justify-content:center;color:var(--text);transition:transform .1s ease,background .15s ease}.social-btn:active{transform:scale(.9)}.social-btn:hover{background:var(--surface-variant-2)}.calendar{display:flex;flex-direction:column;min-height:100dvh}.calendar__topbar{display:flex;align-items:center;gap:8px;padding:16px 14px 8px;flex-shrink:0}.calendar__back-btn{padding:8px;border-radius:50%;color:var(--primary);display:flex;align-items:center;justify-content:center;transition:background .15s}.calendar__back-btn:hover{background:var(--surface-variant)}.calendar__pack-name{font-family:var(--font-display);font-weight:700;font-size:1rem;flex:1}.calendar__month-nav{display:flex;align-items:center;justify-content:space-between;padding:4px 20px 14px}.calendar__month-btn{font-size:.85rem;font-weight:600;color:var(--primary);padding:6px 10px;border-radius:var(--radius-sm);transition:background .15s;font-family:var(--font-sans)}.calendar__month-btn:hover{background:var(--surface-variant)}.calendar__month-btn:disabled{opacity:.3;cursor:default}.calendar__month-label{font-family:var(--font-display);font-weight:700;font-size:1rem}.calendar__grid{padding:0 12px}.calendar__week-labels{display:grid;grid-template-columns:repeat(7,1fr);margin-bottom:6px}.calendar__week-label{text-align:center;font-size:.68rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);padding:2px 0}.calendar__cells{display:grid;grid-template-columns:repeat(7,1fr);gap:5px}.cal-cell{aspect-ratio:1;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:.85rem;font-weight:500;font-family:var(--font-sans);transition:transform .1s ease;-webkit-tap-highlight-color:transparent;cursor:default}.cal-cell--empty{background:none}.cal-cell--played{background:var(--primary);color:var(--on-primary);cursor:pointer}.cal-cell--unplayed{background:var(--surface-variant);color:var(--text);cursor:pointer}.cal-cell--future{background:var(--surface);color:var(--text-muted);opacity:.38}.cal-cell--today{outline:2.5px solid var(--primary);outline-offset:1px}.cal-cell--played:active,.cal-cell--unplayed:active{transform:scale(.88)}.calendar__legend{display:flex;justify-content:center;flex-wrap:wrap;gap:10px 20px;padding:16px 20px}.legend-item{display:flex;align-items:center;gap:6px;font-size:.74rem;color:var(--text-muted)}.legend-swatch{width:12px;height:12px;border-radius:3px;flex-shrink:0}.state-screen{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100dvh;gap:16px;padding:24px;text-align:center}.state-screen__title{font-family:var(--font-display);font-weight:700;font-size:1.15rem}.state-screen__body{font-size:.88rem;color:var(--text-muted);max-width:280px}.spinner{width:32px;height:32px;border:3px solid var(--surface-variant);border-top-color:var(--primary);border-radius:50%;animation:spin .7s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}
