:root{--color-bg: #0f0f13;--color-surface: #1a1a24;--color-surface-hover: #24243a;--color-primary: #7c5cfc;--color-primary-hover: #6a48e6;--color-text: #ece9f4;--color-text-muted: #8b89a0;--color-border: #2a2a3d;--color-success: #30d158;--color-error: #f87171;--radius: 12px;--radius-sm: 8px;--shadow: 0 4px 24px rgba(0, 0, 0, .4);--transition: .2s ease}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{font-family:Inter,system-ui,-apple-system,sans-serif;background:var(--color-bg);color:var(--color-text);min-height:100vh;display:flex;flex-direction:column;align-items:center;line-height:1.6}h1,h2,h3{line-height:1.2;font-weight:700}.logo{font-size:2rem;font-weight:800;letter-spacing:-.02em;background:linear-gradient(135deg,var(--color-primary),#c084fc);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;padding:.75rem 1.75rem;background:var(--color-primary);color:#fff;text-decoration:none;border:none;border-radius:var(--radius-sm);font-size:1rem;font-weight:600;cursor:pointer;transition:background var(--transition),transform var(--transition)}.btn:hover{background:var(--color-primary-hover);transform:translateY(-1px)}.btn:active{transform:translateY(0)}.btn--outline{background:transparent;border:2px solid var(--color-primary);color:var(--color-primary)}.btn--outline:hover{background:var(--color-primary);color:#fff}.site-header{width:100%;padding:1.25rem 1.5rem;display:flex;align-items:center;justify-content:center}.card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius);box-shadow:var(--shadow);overflow:hidden}.spinner{width:40px;height:40px;border:4px solid var(--color-border);border-top-color:var(--color-primary);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.fade-in{animation:fadeIn .5s ease forwards;opacity:0}@keyframes fadeIn{to{opacity:1}}@media(prefers-reduced-motion:reduce){.fade-in{animation:none;opacity:1}}.site-footer{padding:1.5rem;text-align:center;color:var(--color-text-muted);font-size:.85rem;border-top:1px solid var(--color-border)}.text-center{text-align:center}.text-muted{color:var(--color-text-muted)}.mt-1{margin-top:.5rem}.mt-2{margin-top:1rem}.mt-3{margin-top:1.5rem}.mt-4{margin-top:2rem}.mb-2{margin-bottom:1rem}.gap-1{gap:.5rem}@media(max-width:600px){.logo{font-size:1.6rem}.btn{padding:.65rem 1.25rem;font-size:.95rem}}.app{width:100%;max-width:420px;min-height:100vh;min-height:100dvh;margin:0 auto;display:flex;flex-direction:column;background:var(--color-bg)}.app-header{padding:14px 16px;text-align:center;border-bottom:1px solid var(--color-border);flex-shrink:0}.app:has(#screen-home.active) .app-header{display:none}.logo--sm{font-size:1.4rem;text-decoration:none}.logo-img{display:block;height:auto;object-fit:contain}.logo-img--sm{height:28px}.logo-img--md{height:100px;margin:0 auto 8px}.settings-row{padding:0 4px}.toggle-label{display:flex;align-items:center;justify-content:space-between;cursor:pointer;font-size:.9rem;color:var(--color-text-muted)}.toggle-switch{position:relative;display:inline-block;width:40px;height:22px;flex-shrink:0}.toggle-switch input{opacity:0;width:0;height:0}.toggle-track{position:absolute;inset:0;background:var(--color-border);border-radius:11px;transition:background .2s}.toggle-track:after{content:"";position:absolute;top:2px;left:2px;width:18px;height:18px;background:#fff;border-radius:50%;transition:transform .2s}.toggle-switch input:checked+.toggle-track{background:var(--color-primary)}.toggle-switch input:checked+.toggle-track:after{transform:translate(18px)}.screen{display:none;flex-direction:column;gap:16px;padding:20px 16px;overflow-y:auto}.screen.active{display:flex}#screen-game{flex:1}.screen-title{font-size:1.3rem;font-weight:700;text-align:center}.subsection-title{font-size:1rem;font-weight:600;color:var(--color-text-muted);margin-top:8px}.btn--primary{background:var(--color-primary);color:#fff}.btn--primary:hover{background:var(--color-primary-hover)}.btn--secondary{background:var(--color-surface);border:1px solid var(--color-border);color:var(--color-text)}.btn--secondary:hover{background:var(--color-surface-hover)}.btn--ghost{background:transparent;color:var(--color-text-muted);font-size:.9rem;padding:8px 16px}.btn--ghost:hover{color:var(--color-error)}.btn--save-image:hover{background:var(--color-surface-hover)}.btn-row{display:flex;gap:8px}.btn-row .btn{flex:1}.btn--confirm{color:var(--color-error)!important;font-weight:600}.btn--lg{padding:16px 24px;font-size:1.1rem;border-radius:var(--radius)}.screen-actions{display:flex;flex-direction:column;gap:10px}.ad-slot{margin-top:auto}.home-hero{text-align:center;padding:8px 0}.puzzle-number{font-size:1.5rem;font-weight:700}.puzzle-date{font-size:.9rem;color:var(--color-text-muted);margin-top:4px}.players-today{font-size:.8rem;color:var(--color-text-muted);text-align:center;margin-top:4px}.home-tagline{text-align:center;color:var(--color-text);font-size:.95rem;line-height:1.5;max-width:380px;margin:0 auto 8px}.how-to-play{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius);padding:16px 20px}.how-to-play-title{font-size:1rem;font-weight:700;margin-bottom:10px;color:var(--color-text)}.how-to-play-steps{list-style:decimal;padding-left:1.3em;margin:0;display:flex;flex-direction:column;gap:6px;font-size:.9rem;line-height:1.45}.how-to-play-steps li{color:var(--color-text)}.about-content{display:flex;flex-direction:column;gap:12px}.about-content p{font-size:.95rem;line-height:1.6;color:var(--color-text);margin:0}.faq-section{display:flex;flex-direction:column;gap:8px}.faq-item{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-sm);overflow:hidden}.faq-item summary{padding:12px 14px;font-size:.95rem;font-weight:600;cursor:pointer;list-style:none;display:flex;align-items:center;gap:8px}.faq-item summary:before{content:"▸";font-size:.85rem;color:var(--color-primary);transition:transform .2s ease}.faq-item[open] summary:before{transform:rotate(90deg)}.faq-item summary::-webkit-details-marker{display:none}.faq-item p{padding:0 14px 14px;margin:0;font-size:.9rem;line-height:1.55;color:var(--color-text)}.footer-links{display:flex;justify-content:center;align-items:center;gap:8px;flex-wrap:wrap}.footer-link{background:none;border:none;padding:0;font-size:.85rem;color:var(--color-text-muted);cursor:pointer;text-decoration:none;font-family:inherit}.footer-link:hover{color:var(--color-primary);text-decoration:underline}.footer-sep{color:var(--color-border);font-size:.85rem}.footer-copy{margin-top:6px;font-size:.75rem;color:var(--color-text-muted);opacity:.6}.app:not(:has(.screen.active)) .site-footer,#screen-game.active~.site-footer{display:none}.game-bar{display:flex;justify-content:space-between;align-items:center;font-size:.95rem;font-weight:600;color:var(--color-text-muted)}.game-bar-right{display:flex;align-items:center;gap:8px}#btn-giveup{font-size:.75rem;padding:3px 8px}.game-timer{font-variant-numeric:tabular-nums;font-size:1.1rem;color:var(--color-text);padding:4px 10px;background:var(--color-surface);border-radius:var(--radius-sm)}.image-frame{position:relative;width:100%;aspect-ratio:1 / 1;border-radius:var(--radius);overflow:hidden;background:var(--color-surface);flex-shrink:0}.image-frame canvas{width:100%;height:100%;display:block}#impressionist-overlay{position:absolute;inset:0;pointer-events:none;z-index:1;transition:opacity .4s ease-out}@keyframes painting-jitter{0%{transform:translate(0) rotate(0)}92%{transform:translate(0) rotate(0)}93%{transform:translate(.7px,-.5px) rotate(.2deg)}94.5%{transform:translate(-.5px,.4px) rotate(-.15deg)}96%{transform:translate(.3px,.6px) rotate(.1deg)}97.5%{transform:translate(-.6px,-.3px) rotate(-.12deg)}99%{transform:translate(.2px,-.2px) rotate(.05deg)}to{transform:translate(0) rotate(0)}}.image-frame.jitter canvas{animation:painting-jitter 3s ease-in-out infinite}@keyframes painting-shake{0%{transform:translate(0) rotate(0)}8%{transform:translate(-4px,3px) rotate(-4deg)}16%{transform:translate(3.5px,-3.5px) rotate(3.2deg)}24%{transform:translate(-3px,-2px) rotate(-2.8deg)}32%{transform:translate(2.5px,3px) rotate(2.4deg)}42%{transform:translate(-3.5px,1.5px) rotate(-1.8deg)}52%{transform:translate(2px,-2.5px) rotate(1.4deg)}62%{transform:translate(-1.5px,2px) rotate(-1deg)}72%{transform:translate(1.2px,-1px) rotate(.7deg)}82%{transform:translate(-.8px,.6px) rotate(-.4deg)}92%{transform:translate(.3px,-.3px) rotate(.15deg)}to{transform:translate(0) rotate(0)}}.image-frame.phase-shake canvas{animation:painting-shake .6s ease-out}.image-loading{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;background:var(--color-surface);z-index:2}.pregame-countdown{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;background:var(--color-surface);z-index:3;gap:8px}.pregame-label{position:absolute;top:20px;font-size:2rem;font-weight:800;color:var(--color-text-muted);letter-spacing:.05em;text-transform:uppercase;opacity:0;transition:opacity .3s ease}.pregame-label.visible{opacity:1;animation:label-pop 1s ease-out forwards}@keyframes label-pop{0%{transform:scale(.7) translateY(6px);opacity:0}25%{transform:scale(1.08) translateY(0);opacity:1}50%{transform:scale(.97) translateY(0);opacity:1}70%{transform:scale(1) translateY(0);opacity:1}to{transform:scale(1) translateY(0);opacity:1}}.pregame-number{font-size:6rem;font-weight:800;color:var(--color-primary);line-height:1;animation:countdown-pop 1s ease-out forwards}@keyframes countdown-pop{0%{transform:scale(.4);opacity:0}20%{transform:scale(1.15);opacity:1}40%{transform:scale(.95);opacity:1}55%{transform:scale(1);opacity:1}80%{transform:scale(1);opacity:1}to{transform:scale(1.4);opacity:0}}.hint-bar{display:flex;align-items:center;gap:8px;padding:10px 14px;background:var(--color-surface);border-radius:var(--radius-sm);font-size:.9rem;height:62px;overflow:hidden}.hint-icon{flex-shrink:0;align-self:center}.hint-text{flex:1;min-width:0;color:var(--color-text);transition:color .3s ease;line-height:1.3}.hint-text.hint-new{color:#ffd93d}.hint-aside{flex-shrink:0;display:flex;flex-direction:column;align-items:center;gap:6px}.hint-count{font-weight:600;color:var(--color-text-muted);font-size:.7rem;white-space:nowrap}.btn--next{font-size:.65rem;font-weight:700;height:26px;width:56px;padding:0;border-radius:4px;background:var(--color-surface);color:var(--color-text-muted);cursor:pointer;border:1px solid var(--color-text-muted);letter-spacing:.02em;touch-action:manipulation;-webkit-user-select:none;user-select:none;white-space:nowrap;text-align:center;transition:background var(--transition),color var(--transition)}.btn--next:active{background:var(--color-primary);color:#fff}.free-type-display{display:flex;align-items:center;justify-content:center;flex:1;min-height:52px;font-size:1.4rem;font-weight:700;letter-spacing:.08em;color:var(--color-text);text-align:center;word-break:break-all}@keyframes free-cursor-blink{0%,to{opacity:1}50%{opacity:0}}.free-type-cursor{display:inline-block;width:2px;height:1.2em;background:var(--color-primary);vertical-align:middle;margin-left:2px;animation:free-cursor-blink 1s step-end infinite}.char-count-hint{text-align:center;font-size:.8rem;color:var(--color-text-muted);opacity:.7;padding:0 0 10px;letter-spacing:.02em}.word-blanks{display:flex;flex-wrap:wrap;justify-content:center;align-content:center;flex:1;gap:4px;padding:8px 0;min-height:92px}.word-group{display:inline-flex;gap:2px}.blank-letter{display:inline-flex;align-items:center;justify-content:center;width:28px;height:36px;font-size:1.2rem;font-weight:700;letter-spacing:2px;color:var(--color-text-muted);border-bottom:2px solid var(--color-border)}.blank-letter.revealed{color:#f5c842;border-bottom-color:#f5c842}.blank-letter.special-char{color:#f5c842;border-bottom:none;width:auto;min-width:10px;padding:0 2px}.blank-letter.guessed-correct{color:#4caf50;border-bottom-color:#4caf50}.blank-letter.typing{color:var(--color-text);border-bottom-color:var(--color-text-muted)}.blank-letter.typing--mismatch{color:#ff4d4d;border-bottom-color:#ff4d4d}.blank-letter.typing--match,.word-blanks--correct .blank-letter{color:#4caf50;border-bottom-color:#4caf50}@keyframes letter-flash{0%{color:#fff;transform:scale(1.3)}to{color:#f5c842;transform:scale(1)}}.blank-letter.letter-flash{animation:letter-flash .4s ease-out forwards}.blank-space{display:inline-flex;align-items:center;justify-content:center;width:16px;height:36px;transition:width .15s ease}.blank-space.space--missing{width:28px;font-size:1.2rem;font-weight:700;color:#ff4d4d;border-bottom:2px solid #ff4d4d}@keyframes cursor-blink{0%,to{border-bottom-color:var(--color-primary)}50%{border-bottom-color:transparent}}.blank-letter.blank-cursor{border-bottom-color:var(--color-primary);animation:cursor-blink 1s step-end infinite}.blank-space.blank-cursor{border-bottom:2px solid var(--color-primary);animation:cursor-blink 1s step-end infinite}.guess-row{display:flex;gap:8px}.guess-input{flex:1;padding:12px 14px;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-sm);color:var(--color-text);font-size:1rem;outline:none;transition:border-color var(--transition)}.guess-input:focus{border-color:var(--color-primary)}.guess-input.shake{animation:shake .4s ease}@keyframes shake{0%,to{transform:translate(0)}20%{transform:translate(-8px)}40%{transform:translate(8px)}60%{transform:translate(-4px)}80%{transform:translate(4px)}}.word-blanks--shake{animation:shake .35s ease-out}.wrong-guesses{display:flex;flex-wrap:wrap;gap:6px;min-height:0}.wrong-guesses-label{flex-shrink:0;font-size:1rem;line-height:1;align-self:center}.wrong-guess{display:inline-block;padding:4px 10px;background:#f8717126;border:1px solid rgba(248,113,113,.3);border-radius:20px;font-size:.8rem;color:var(--color-error)}.result-banner{text-align:center;padding:16px 0}.result-banner--win .result-emoji{font-size:4rem;animation:win-pop .6s ease-out}@keyframes win-pop{0%{transform:scale(0)}60%{transform:scale(1.3)}80%{transform:scale(.9)}to{transform:scale(1)}}.result-banner--win .result-title{font-size:1.5rem;font-weight:700;color:var(--color-success)}.result-banner--lose .result-emoji{font-size:4rem;animation:lose-shake .5s ease-in-out}@keyframes lose-shake{0%,to{transform:translate(0) rotate(0)}15%{transform:translate(-10px) rotate(-5deg)}30%{transform:translate(10px) rotate(5deg)}45%{transform:translate(-8px) rotate(-3deg)}60%{transform:translate(8px) rotate(3deg)}75%{transform:translate(-4px)}90%{transform:translate(4px)}}.result-banner--lose .result-title{font-size:1.5rem;font-weight:700;color:var(--color-error)}.result-answer{text-align:center;font-size:1.3rem;font-weight:700;letter-spacing:.02em}.result-learn-more{display:block;text-align:center;font-size:.8rem;color:var(--color-text-muted);text-decoration:none}.result-learn-more:hover{text-decoration:underline}.result-row{display:flex;gap:12px;align-items:stretch}.result-image-frame{position:relative;border-radius:var(--radius);overflow:hidden;background:var(--color-surface);flex-shrink:0}.result-image-frame--sm{width:200px;height:200px}.result-image-frame canvas{width:100%;height:100%;display:block;object-fit:cover}.result-stats{flex:1;display:flex;flex-direction:column;gap:4px;justify-content:space-between}.ad-slot--results{margin-top:0}.stat-item{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap-reverse;gap:8px;flex:1;padding:4px 12px;background:var(--color-surface);border-radius:var(--radius-sm)}.stat-value{font-size:1.1rem;font-weight:700;font-variant-numeric:tabular-nums;min-width:32px}.stat-label{font-size:.75rem;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.05em;margin-left:auto}.stat-item--timeline .stat-value{font-size:.85rem;font-weight:600;word-break:break-word;line-height:1.3}.percentile-banner{text-align:center;font-size:.9rem;font-style:italic;color:#d4a843;margin:8px 0}.btn--challenge{font-size:.9rem}.countdown-box{text-align:center;padding:16px;background:var(--color-surface);border-radius:var(--radius-sm)}.countdown-label{font-size:.85rem;color:var(--color-text-muted);margin-bottom:4px}.countdown-digits{font-size:2rem;font-weight:700;font-variant-numeric:tabular-nums;letter-spacing:.05em;background:linear-gradient(135deg,var(--color-primary),#c084fc);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.stats-overview{display:grid;grid-template-columns:repeat(4,1fr);gap:8px}.stat-card{display:flex;flex-direction:column;align-items:center;padding:14px 4px;background:var(--color-surface);border-radius:var(--radius-sm);border:1px solid var(--color-border)}.stat-card-value{font-size:1.4rem;font-weight:700}.stat-card-label{font-size:.7rem;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.04em;margin-top:2px}.distribution-chart{display:flex;flex-direction:column;gap:6px}.dist-row{display:flex;align-items:center;gap:8px}.dist-label{width:60px;font-size:.8rem;color:var(--color-text-muted);text-align:right;flex-shrink:0}.dist-bar-track{flex:1;height:24px;background:var(--color-surface);border-radius:4px;overflow:hidden}.dist-bar{height:100%;background:var(--color-primary);border-radius:4px;display:flex;align-items:center;justify-content:flex-end;padding-right:8px;font-size:.75rem;font-weight:600;color:#fff;min-width:24px;transition:width .4s ease}.gallery-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:3px}.gallery-tile{position:relative;aspect-ratio:1;overflow:hidden;background:var(--color-surface);cursor:pointer;border-radius:2px}.gallery-tile-img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .3s ease}.gallery-tile:hover .gallery-tile-img{transform:scale(1.08)}.gallery-tile-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;background:var(--color-surface);color:var(--color-text-muted);font-size:2rem}.gallery-tile-overlay{position:absolute;inset:0;background:linear-gradient(to top,rgba(0,0,0,.88) 0%,rgba(0,0,0,.25) 55%,transparent 100%);display:flex;flex-direction:column;justify-content:flex-end;padding:8px;pointer-events:none}.gallery-tile-num{font-size:.65rem;font-weight:600;color:#fff9}.gallery-tile-subject{font-size:.8rem;font-weight:700;color:#fff;line-height:1.2;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.gallery-tile-date{font-size:.65rem;color:#fff9;margin-top:1px}.gallery-tile-badge{position:absolute;top:5px;right:5px;font-size:.75rem;line-height:1}.empty-state{text-align:center;padding:32px 16px;color:var(--color-text-muted);font-size:.95rem}@media(max-width:420px){.screen{padding:16px 12px}.blank-letter{width:24px;height:32px;font-size:1rem}.stats-overview{gap:6px}.stat-card-value{font-size:1.2rem}}@media(min-width:421px){body{display:flex;justify-content:center}}.soft-keyboard{display:flex;flex-direction:column;gap:8px;padding:0 8px;flex-shrink:0}#screen-game .guess-row{position:absolute;opacity:0;pointer-events:none;height:0;overflow:hidden;margin:0}.keyboard-row{display:flex;justify-content:center;gap:6px}.keyboard-row[hidden]{display:none}.key-spacer{flex:.5}.key{flex:1;height:58px;background:#3d3560;border:none;border-radius:4px;color:#fff;font-size:1.25rem;font-weight:700;cursor:pointer;touch-action:manipulation;-webkit-user-select:none;user-select:none;display:flex;align-items:center;justify-content:center;transition:background var(--transition),color var(--transition)}.key:active,.key--active{background:var(--color-primary);color:#fff}.key--action{flex:1.5;font-size:.75rem;letter-spacing:.02em}.key--action[data-key=BACKSPACE]{font-size:1.5rem}.key--num{font-size:1.1rem}.key--enter{background:var(--color-primary);color:#fff;font-weight:700;letter-spacing:.05em}.key--enter:active{background:var(--color-primary-hover)}.key--space{flex:1;max-width:220px;font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:#fff}.soft-keyboard.keyboard-disabled .key{opacity:.4;pointer-events:none}#screen-game .wrong-guesses:empty{display:none}@media(pointer:coarse){.app:has(#screen-game.active){height:100vh;height:100dvh;max-height:100vh;max-height:100dvh;overflow:hidden}.app-header{padding:8px 12px}.logo--sm{font-size:1.2rem}.logo-img--sm{height:24px}#screen-game.active{flex:1;min-height:0;gap:clamp(4px,.8dvh,8px);padding:8px 10px 0;overflow:hidden}#screen-game .game-bar{flex-shrink:0;font-size:.8rem}#screen-game .game-timer{font-size:.9rem;padding:2px 6px}#screen-game #btn-giveup{font-size:.65rem;padding:2px 6px}#screen-game .hint-actions{padding:0}#screen-game #btn-next{font-size:.65rem;padding:2px 8px}#screen-game .image-frame{flex:1 1 0;width:100%;aspect-ratio:auto;min-height:120px;max-height:min(calc(100vw - 20px),400px)}#screen-game .image-frame canvas{position:absolute;inset:0;margin:auto 0;width:100%;height:auto;aspect-ratio:1 / 1}#screen-game .hint-bar{flex-shrink:0;padding:8px 10px;font-size:1rem;gap:6px;height:66px;overflow:hidden}#screen-game .hint-count{font-size:.68rem}#screen-game .free-type-display{flex:0 0 auto;min-height:44px;font-size:1.2rem}#screen-game .word-blanks{flex:0 0 auto;padding:6px 0;min-height:44px;gap:3px}#screen-game .blank-letter{width:28px;height:32px;font-size:1.1rem;letter-spacing:1px}#screen-game .blank-space{width:14px;height:32px}#screen-game .blank-space.space--missing{width:28px;font-size:1.1rem}#screen-game .guess-input{padding:13px 10px;font-size:1.1rem}#screen-game .guess-row .btn--primary{display:none}#screen-game .wrong-guesses{flex-shrink:0;flex-wrap:nowrap;overflow-x:auto;-webkit-overflow-scrolling:touch;gap:4px;min-height:28px}#screen-game .wrong-guesses:empty{display:flex;visibility:hidden}#screen-game .wrong-guess{white-space:nowrap;font-size:.92rem;padding:2px 8px}.soft-keyboard{gap:clamp(4px,.8dvh,6px);padding:0;margin:0 -10px;padding-bottom:max(4px,env(safe-area-inset-bottom,0px));flex-shrink:0}.keyboard-row{gap:clamp(4px,1.2vw,6px)}.key{height:clamp(40px,6dvh,52px);font-size:clamp(.95rem,2.2dvh,1.15rem)}.key--action{font-size:clamp(.55rem,1.3dvh,.7rem)}.key--action[data-key=BACKSPACE]{font-size:clamp(1rem,2.2dvh,1.4rem)}.key--num{font-size:clamp(.85rem,2dvh,1.1rem)}.key--space{max-width:220px;height:clamp(30px,4dvh,40px);font-size:clamp(.55rem,1.3dvh,.7rem)}}.image-frame,.result-image-frame{cursor:zoom-in}.image-frame:after,.result-image-frame:after{content:"⛶";position:absolute;bottom:8px;right:8px;width:40px;height:40px;font-size:1.25rem;line-height:1;display:flex;align-items:center;justify-content:center;border-radius:50%;background:#0000008c;color:#fff;pointer-events:none;z-index:2;box-shadow:0 1px 4px #0006}.lightbox{position:fixed;inset:0;z-index:1000;display:flex;align-items:center;justify-content:center;background:#000000d9;padding:24px}.lightbox[hidden]{display:none}.lightbox-close{position:absolute;bottom:8px;right:8px;width:40px;height:40px;border:none;border-radius:50%;background:#0000008c;color:#fff;font-size:1.25rem;cursor:pointer;display:flex;align-items:center;justify-content:center;z-index:1;box-shadow:0 1px 4px #0006}.lightbox-close:hover{background:#000c}.lightbox-inner{position:relative;max-width:100%;max-height:100%}.lightbox-canvas{max-width:100%;max-height:100%;display:block;border-radius:var(--radius);object-fit:contain}.btn--install{margin-top:8px;font-size:.85rem}.install-modal{position:fixed;inset:0;z-index:1000;display:flex;align-items:center;justify-content:center;background:#000000d9;padding:24px}.install-modal[hidden]{display:none}.install-modal-content{position:relative;background:var(--color-surface);border-radius:var(--radius);padding:24px;max-width:360px;width:100%;box-shadow:var(--shadow)}.install-modal-close{position:absolute;top:12px;right:12px;width:32px;height:32px;border:none;border-radius:50%;background:#ffffff1a;color:#fff;font-size:1rem;cursor:pointer;display:flex;align-items:center;justify-content:center}.install-modal-close:hover{background:#fff3}.install-modal-title{font-size:1rem;margin-bottom:14px;text-align:center}.install-steps{list-style:none;padding:0;display:flex;flex-direction:column;gap:12px}.install-steps li{display:flex;align-items:flex-start;gap:10px;font-size:.82rem;line-height:1.4}.install-step-num{flex-shrink:0;width:24px;height:24px;border-radius:50%;background:var(--color-primary);color:#fff;font-size:.8rem;font-weight:700;display:flex;align-items:center;justify-content:center}.install-note{margin-top:14px;font-size:.75rem;color:var(--color-text-muted);text-align:center}
