*,:before,:after{--tw-border-spacing-x:0;--tw-border-spacing-y:0;--tw-translate-x:0;--tw-translate-y:0;--tw-rotate:0;--tw-skew-x:0;--tw-skew-y:0;--tw-scale-x:1;--tw-scale-y:1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness:proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width:0px;--tw-ring-offset-color:#fff;--tw-ring-color:#3b82f680;--tw-ring-offset-shadow:0 0 #0000;--tw-ring-shadow:0 0 #0000;--tw-shadow:0 0 #0000;--tw-shadow-colored:0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }::backdrop{--tw-border-spacing-x:0;--tw-border-spacing-y:0;--tw-translate-x:0;--tw-translate-y:0;--tw-rotate:0;--tw-skew-x:0;--tw-skew-y:0;--tw-scale-x:1;--tw-scale-y:1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness:proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width:0px;--tw-ring-offset-color:#fff;--tw-ring-color:#3b82f680;--tw-ring-offset-shadow:0 0 #0000;--tw-ring-shadow:0 0 #0000;--tw-shadow:0 0 #0000;--tw-shadow-colored:0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }*,:before,:after{box-sizing:border-box;border:0 solid #e5e7eb}:before,:after{--tw-content:""}html,:host{-webkit-text-size-adjust:100%;-moz-tab-size:4;tab-size:4;font-feature-settings:normal;font-variation-settings:normal;-webkit-tap-highlight-color:transparent;font-family:ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Noto Sans,Ubuntu,Cantarell,Helvetica Neue,sans-serif,Apple Color Emoji,Segoe UI Emoji,Segoe UI Symbol,Noto Color Emoji;line-height:1.5}body{line-height:inherit;margin:0}hr{height:0;color:inherit;border-top-width:1px}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;-webkit-text-decoration:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,samp,pre{font-feature-settings:normal;font-variation-settings:normal;font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace;font-size:1em}small{font-size:80%}sub,sup{vertical-align:baseline;font-size:75%;line-height:0;position:relative}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}button,input,optgroup,select,textarea{font-feature-settings:inherit;font-variation-settings:inherit;font-family:inherit;font-size:100%;font-weight:inherit;line-height:inherit;letter-spacing:inherit;color:inherit;margin:0;padding:0}button,select{text-transform:none}button{-webkit-appearance:button;background-color:#0000;background-image:none}input:where([type=button]){-webkit-appearance:button;background-color:#0000;background-image:none}input:where([type=reset]){-webkit-appearance:button;background-color:#0000;background-image:none}input:where([type=submit]){-webkit-appearance:button;background-color:#0000;background-image:none}:-moz-focusring{outline:auto}:-moz-ui-invalid{box-shadow:none}progress{vertical-align:baseline}::-webkit-inner-spin-button{height:auto}::-webkit-outer-spin-button{height:auto}[type=search]{-webkit-appearance:textfield;outline-offset:-2px}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-file-upload-button{-webkit-appearance:button;font:inherit}summary{display:list-item}blockquote,dl,dd,h1,h2,h3,h4,h5,h6,hr,figure,p,pre{margin:0}fieldset{margin:0;padding:0}legend{padding:0}ol,ul,menu{margin:0;padding:0;list-style:none}dialog{padding:0}textarea{resize:vertical}input::-moz-placeholder{opacity:1;color:#9ca3af}textarea::-moz-placeholder{opacity:1;color:#9ca3af}input::placeholder,textarea::placeholder{opacity:1;color:#9ca3af}button,[role=button]{cursor:pointer}:disabled{cursor:default}img,svg,video,canvas,audio,iframe,embed,object{vertical-align:middle;display:block}img,video{max-width:100%;height:auto}[hidden]:where(:not([hidden=until-found])){display:none}.container{width:100%}@media (min-width:640px){.container{max-width:640px}}@media (min-width:768px){.container{max-width:768px}}@media (min-width:1024px){.container{max-width:1024px}}@media (min-width:1280px){.container{max-width:1280px}}@media (min-width:1536px){.container{max-width:1536px}}.\!visible{visibility:visible!important}.visible{visibility:visible}.static{position:static}.fixed{position:fixed}.absolute{position:absolute}.relative{position:relative}.block{display:block}.inline-block{display:inline-block}.inline{display:inline}.flex{display:flex}.table{display:table}.grid{display:grid}.contents{display:contents}.hidden{display:none}.transform{transform:translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.border{border-width:1px}.uppercase{text-transform:uppercase}.italic{font-style:italic}.underline{text-decoration-line:underline}.outline{outline-style:solid}.filter{filter:var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow)}:root{--bg-base:#060c1a;--bg-app:#0c1428;--bg-surface:#111827;--bg-card:#1b2845;--bg-raised:#243356;--amber:#f59e0b;--amber-dark:#d97706;--amber-glow:#f59e0b26;--green:#27ae60;--green-glow:#27ae6033;--sky:#4fc3f7;--rose:#e11d48;--gold:#fcd34d;--mint:#86efac;--indigo:#a5b4fc;--orange-fitz:#fdba74;--text-primary:#ffffffeb;--text-secondary:#ffffff8c;--text-tertiary:#ffffff4d;--text-label:#ffffffd9;--border-subtle:#ffffff0f;--border-card:#ffffff17;--border-raised:#ffffff24;--border-accent:#f59e0b4d;--radius-sm:8px;--radius-md:12px;--radius-lg:16px;--radius-xl:20px;--radius-full:100px;--font-display:"Baloo 2", cursive;--font-body:"Nunito", sans-serif;--tap-duration:.12s;--appear-duration:.15s;--fade-duration:.2s}*,:before,:after{box-sizing:border-box;-webkit-tap-highlight-color:transparent;-webkit-touch-callout:none;margin:0;padding:0}html,body{overscroll-behavior:none;background:var(--bg-app);height:100%;overflow:hidden}html{-webkit-text-size-adjust:100%;-moz-text-size-adjust:100%;text-size-adjust:100%}*{touch-action:manipulation}body{font-family:var(--font-body);-webkit-user-select:none;user-select:none;color:var(--text-primary)}#root{background:var(--bg-app);flex-direction:column;height:100dvh;display:flex;overflow:hidden}#speech-bar{background:var(--bg-base);border-bottom:1px solid var(--border-subtle);flex-shrink:0;align-items:center;gap:8px;min-height:68px;padding:8px 10px;display:flex}#speech-output{background:var(--bg-surface);cursor:pointer;scrollbar-width:none;border:1px solid #ffffff1a;border-radius:14px;flex-wrap:nowrap;flex:1;align-items:center;gap:6px;min-height:52px;padding:8px 12px;display:flex;overflow:auto hidden}#speech-output::-webkit-scrollbar{display:none}.speech-placeholder{color:var(--text-tertiary);font-size:14px;font-style:italic;font-weight:700}.speech-token{background:var(--bg-card);border:1px solid var(--border-card);border-radius:var(--radius-sm);font-family:var(--font-body);color:var(--text-primary);animation:tokenPop var(--appear-duration) ease-out both;white-space:nowrap;flex-shrink:0;align-items:center;gap:5px;padding:4px 10px;font-size:13px;font-weight:800;display:flex}.speech-token .token-emoji{font-size:18px}@keyframes tokenPop{0%{opacity:0;transform:scale(.65)}to{opacity:1;transform:scale(1)}}.bar-btn{border-radius:var(--radius-md);width:52px;height:52px;font-family:var(--font-body);letter-spacing:.5px;text-transform:uppercase;cursor:pointer;-webkit-tap-highlight-color:transparent;border:none;flex-direction:column;flex-shrink:0;justify-content:center;align-items:center;gap:2px;font-size:9px;font-weight:900;transition:transform .1s ease-out,filter .1s ease-out;display:flex}.bar-btn:active{filter:brightness(.82);transform:scale(.91)}.bar-btn .btn-icon{font-size:20px;line-height:1}#btn-speak{background:var(--green);color:#fff}#btn-back{background:var(--amber-dark);color:#fff}#btn-clear{background:var(--rose);color:#fff}#btn-keyboard{background:var(--bg-raised);color:var(--text-secondary)}#btn-keyboard.keyboard-active{background:var(--sky);color:#fff}#btn-speak.speaking{animation:1.2s ease-in-out infinite speakPulse}@keyframes speakPulse{0%,to{box-shadow:0 0 0 0 var(--green-glow)}50%{box-shadow:0 0 0 10px #0000}}.speech-keyboard-input{background:var(--bg-surface);border:1px solid var(--amber);border-radius:var(--radius-sm);font-size:16px;font-weight:700;font-family:var(--font-body);color:var(--text-primary);outline:none;flex-shrink:0;min-width:100px;padding:4px 8px}.speech-keyboard-input:focus{box-shadow:0 0 0 3px #f59e0b1f}.quickfires-strip{background:var(--bg-base);border-bottom:1px solid var(--border-subtle);scrollbar-width:none;flex-shrink:0;gap:6px;padding:7px 10px;display:flex;overflow-x:auto}.quickfires-strip::-webkit-scrollbar{display:none}.quickfire-btn{background:var(--amber-glow);border:1px solid var(--border-accent);border-radius:var(--radius-full);font-family:var(--font-body);color:var(--gold);white-space:nowrap;cursor:pointer;-webkit-tap-highlight-color:transparent;flex-shrink:0;align-items:center;gap:4px;padding:6px 16px;font-size:12px;font-weight:800;transition:transform .1s ease-out,background .1s ease-out;display:flex}.quickfire-btn:active{background:#f59e0b40;transform:scale(.94)}.quickfire-emoji{font-size:16px}.quickfire-label{font-size:11px}.corewords-bar{background:var(--bg-base);border-bottom:1px solid var(--border-subtle);scrollbar-width:none;flex-shrink:0;gap:5px;padding:7px 10px;display:flex;overflow-x:auto}.corewords-bar::-webkit-scrollbar{display:none}.coreword-btn{font-family:var(--font-body);text-transform:uppercase;letter-spacing:.4px;white-space:nowrap;cursor:pointer;-webkit-tap-highlight-color:transparent;color:var(--indigo);background:#a5b4fc1a;border:1px solid #a5b4fc38;border-radius:8px;flex-shrink:0;padding:5px 11px;font-size:11px;font-weight:900;transition:transform .1s ease-out}.coreword-btn:active{transform:scale(.91)}.coreword-btn.cw-pronoun{color:#fcd34d;background:#fbd34d1f;border:1px solid #fbd34d40}.coreword-btn.cw-verb{color:#86efac;background:#86efac1a;border:1px solid #86efac38}.coreword-btn.cw-descriptor{color:#93c5fd;background:#93c5fd1a;border:1px solid #93c5fd38}.coreword-btn.cw-social{color:#a5b4fc;background:#a5b4fc1a;border:1px solid #a5b4fc38}.coreword-btn.cw-noun{color:#fdba74;background:#fdba741a;border:1px solid #fdba7438}#breadcrumb{background:var(--bg-surface);border-bottom:1px solid var(--border-subtle);scrollbar-width:none;flex-shrink:0;align-items:center;gap:4px;padding:8px 12px;display:flex;overflow-x:auto}#breadcrumb::-webkit-scrollbar{display:none}.crumb{font-family:var(--font-body);white-space:nowrap;cursor:pointer;-webkit-tap-highlight-color:transparent;color:#ffffff4d;background:0 0;border:1px solid #0000;border-radius:8px;padding:4px 10px;font-size:12px;font-weight:800;transition:background .12s ease-out}.crumb:hover{color:#ffffff80;background:#ffffff0d}.crumb.active{color:#f59e0b;background:#f59e0b24;border:1px solid #f59e0b47}.crumb-sep{color:var(--text-tertiary);flex-shrink:0;font-size:16px;font-weight:900}#grid-area{background:var(--bg-surface);scrollbar-width:thin;scrollbar-color:#ffffff1a transparent;-webkit-overflow-scrolling:touch;overscroll-behavior-y:contain;flex:1;min-height:0;padding:10px;overflow:hidden auto}#symbol-grid{grid-template-columns:repeat(4,1fr);align-content:start;gap:10px;width:100%;display:grid}@media (min-width:600px) and (orientation:landscape){#symbol-grid{grid-template-columns:repeat(5,1fr)}}@media (min-width:900px){#symbol-grid{grid-template-columns:repeat(6,1fr)}}@media (min-width:1200px){#symbol-grid{grid-template-columns:repeat(8,1fr)}}@media (min-width:1600px){#symbol-grid{grid-template-columns:repeat(10,1fr)}}#symbol-grid.cols-3{grid-template-columns:repeat(3,1fr)!important}#symbol-grid.cols-4{grid-template-columns:repeat(4,1fr)!important}#symbol-grid.cols-5{grid-template-columns:repeat(5,1fr)!important}#symbol-grid.cols-6{grid-template-columns:repeat(6,1fr)!important}#symbol-grid.cols-7{grid-template-columns:repeat(7,1fr)!important}#symbol-grid.cols-8{grid-template-columns:repeat(8,1fr)!important}.symbol-card{background:var(--bg-card);aspect-ratio:1;cursor:pointer;-webkit-tap-highlight-color:transparent;-webkit-user-select:none;user-select:none;width:100%;min-width:0;font-family:var(--font-body);border:1px solid #ffffff17;border-radius:20px;flex-direction:column;justify-content:center;align-items:center;gap:6px;padding:8px 4px 6px;transition:transform .12s ease-out,filter .12s ease-out;display:flex;position:relative;overflow:hidden}.symbol-card:before{content:"";background:var(--card-color,transparent);pointer-events:none;border-radius:20px 20px 0 0;height:3px;position:absolute;top:0;left:0;right:0}.symbol-card-highlight{display:none}.symbol-card:active{filter:brightness(.82);transform:scale(.93)}.symbol-card-nav-indicator{color:var(--text-tertiary);z-index:1;font-size:8px;position:absolute;bottom:6px;right:8px}.symbol-emoji{z-index:1;font-size:clamp(36px,9vw,64px);line-height:1}@media (min-width:900px){.symbol-emoji{font-size:clamp(44px,6vw,68px)}}.symbol-image-container{z-index:1;background:#ffffffeb;border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;width:clamp(52px,55%,90px);height:clamp(52px,55%,90px);padding:4px;display:flex}.symbol-image-container img{-o-object-fit:contain;object-fit:contain;width:100%;height:100%}.symbol-character-img{-o-object-fit:contain;object-fit:contain;z-index:1;border-radius:8px;width:clamp(52px,65%,96px);height:clamp(52px,65%,96px)}.symbol-image{-o-object-fit:contain;object-fit:contain;z-index:1;pointer-events:none;background:#ffffffeb;border-radius:10px;width:52px;height:52px;padding:4px}@media (min-width:900px){.symbol-image-container{width:clamp(60px,55%,100px);height:clamp(60px,55%,100px)}.symbol-image{width:60px;height:60px}}.symbol-size-small .symbol-image-container{width:clamp(40px,48%,72px);height:clamp(40px,48%,72px)}.symbol-size-small .symbol-image{width:40px;height:40px}.symbol-size-large .symbol-image-container{width:clamp(60px,60%,110px);height:clamp(60px,60%,110px)}.symbol-size-large .symbol-image{width:64px;height:64px}.symbol-label{font-family:var(--font-body);text-transform:uppercase;letter-spacing:.3px;color:#ffffffd9;text-align:center;word-break:break-word;-webkit-hyphens:auto;hyphens:auto;z-index:1;max-width:100%;font-size:clamp(9px,1.8vw,12px);font-weight:900;line-height:1.2}@keyframes cardSpeakPulse{0%{transform:scale(1)}50%{transform:scale(1.05)}to{transform:scale(1)}}.symbol-card.speaking{animation:.3s cardSpeakPulse}.add-word-card{border:2px dashed var(--border-raised);background:var(--bg-raised)!important}.symbol-size-small .symbol-emoji{font-size:clamp(28px,7vw,48px)}.symbol-size-small .symbol-label{font-size:clamp(8px,1.8vw,11px)}.symbol-size-large .symbol-emoji{font-size:clamp(44px,11vw,76px)}.symbol-size-large .symbol-label{font-size:clamp(11px,2.5vw,16px)}.symbol-hidden{opacity:.25;filter:grayscale(.8)}.symbol-previewed{outline:2px solid var(--amber);outline-offset:-2px}#tab-bar{background:var(--bg-base);border-top:1px solid #ffffff12;flex-shrink:0;gap:4px;padding:6px 8px;display:flex}@supports (padding-bottom:env(safe-area-inset-bottom)){#tab-bar{padding-bottom:calc(8px + env(safe-area-inset-bottom))}}.tab-btn{font-family:var(--font-body);letter-spacing:.5px;text-transform:uppercase;cursor:pointer;-webkit-tap-highlight-color:transparent;color:#ffffff47;background:0 0;border:none;border-radius:12px;flex-direction:column;flex:1;align-items:center;gap:3px;padding:8px 4px 6px;font-size:9px;font-weight:900;transition:background .15s ease-out;display:flex}.tab-btn .tab-icon{font-size:22px;line-height:1}.tab-btn.active{color:#f59e0b;background:#f59e0b24;border:1px solid #f59e0b47}.tab-btn:not(.active):active{background:#ffffff0d}.ripple-effect{pointer-events:none;z-index:10;background:#ffffff26;border-radius:50%;animation:.4s ease-out rippleAnim;position:absolute}@keyframes rippleAnim{0%{opacity:1;transform:scale(0)}to{opacity:0;transform:scale(4)}}.empty-state{text-align:center;color:var(--text-tertiary);grid-column:1/-1;padding:40px 20px}.empty-state-icon{margin-bottom:16px;font-size:64px}.empty-state p{font-size:18px;font-weight:700}.modal-overlay{-webkit-backdrop-filter:blur(4px);z-index:100;background:#000000a6;justify-content:center;align-items:flex-end;padding:0;display:flex;position:fixed;top:0;bottom:0;left:0;right:0}.modal{background:var(--bg-card);border-radius:var(--radius-xl) var(--radius-xl) 0 0;border-top:1px solid var(--border-raised);width:100%;max-height:85dvh;font-family:var(--font-body);padding:20px 20px 32px;animation:.22s ease-out both sheetUp;overflow-y:auto}@keyframes sheetUp{0%{transform:translateY(100%)}to{transform:translateY(0)}}.modal-title{font-family:var(--font-display);color:var(--text-primary);margin-bottom:20px;font-size:22px;font-weight:800}.modal-field{margin-bottom:14px}.modal-field label{font-family:var(--font-body);letter-spacing:2px;text-transform:uppercase;color:var(--text-tertiary);margin-bottom:6px;font-size:10px;font-weight:900;display:block}.modal-field input{background:var(--bg-surface);border:1px solid var(--border-raised);border-radius:var(--radius-md);width:100%;font-family:var(--font-body);color:var(--text-primary);-webkit-appearance:none;outline:none;padding:12px 14px;font-size:16px;font-weight:700}.modal-field input:focus{border-color:var(--amber);box-shadow:0 0 0 3px #f59e0b1f}.emoji-picker{background:var(--bg-surface);border-radius:var(--radius-md);border:1px solid var(--border-raised);grid-template-columns:repeat(8,1fr);gap:6px;max-height:160px;padding:8px;display:grid;overflow-y:auto}.emoji-opt{text-align:center;cursor:pointer;border-radius:var(--radius-sm);padding:4px;font-size:26px;line-height:1.2;transition:background .1s}.emoji-opt:hover,.emoji-opt.selected{background:var(--amber-glow)}.photo-upload-area{align-items:center;gap:12px;display:flex}.photo-upload-btn{border-radius:var(--radius-md);border:2px dashed var(--border-raised);background:var(--bg-surface);font-size:14px;font-weight:800;font-family:var(--font-body);cursor:pointer;color:var(--text-secondary);padding:10px 18px}.photo-upload-btn:hover{border-color:var(--amber)}.photo-preview-container{display:inline-block;position:relative}.photo-preview{border-radius:var(--radius-md);-o-object-fit:cover;object-fit:cover;border:1px solid var(--border-raised);width:64px;height:64px}.photo-remove-btn{background:var(--rose);color:#fff;cursor:pointer;border:none;border-radius:50%;justify-content:center;align-items:center;width:22px;height:22px;font-size:12px;font-weight:900;display:flex;position:absolute;top:-6px;right:-6px}.modal-actions{gap:10px;margin-top:20px;display:flex}.modal-btn{border-radius:var(--radius-full);font-size:16px;font-weight:900;font-family:var(--font-body);cursor:pointer;border:none;flex:1;padding:14px;transition:transform .1s ease-out,filter .1s ease-out}.modal-btn:active{filter:brightness(.88);transform:scale(.97)}.modal-btn.primary{background:var(--amber);color:#1c1400}.modal-btn.cancel{background:var(--bg-surface);border:1px solid var(--border-raised);color:var(--text-secondary)}.context-menu{background:var(--bg-card);border-radius:var(--radius-xl);border:1px solid var(--border-raised);width:260px;font-family:var(--font-body);flex-direction:column;gap:8px;margin:auto;padding:20px;display:flex;box-shadow:0 20px 60px #00000080}.context-menu-title{color:var(--text-primary);text-align:center;margin-bottom:4px;font-size:18px;font-weight:900}.context-menu-btn{border-radius:var(--radius-md);font-size:16px;font-weight:800;font-family:var(--font-body);cursor:pointer;text-align:center;border:none;padding:12px 16px;transition:transform .1s ease-out}.context-menu-btn:active{transform:scale(.97)}.context-menu-btn.edit{background:var(--sky);color:#fff}.context-menu-btn.delete{background:var(--rose);color:#fff}.context-menu-btn.cancel-btn{background:var(--bg-surface);border:1px solid var(--border-raised);color:var(--text-secondary)}.voice-download-banner{background:var(--bg-card);border-bottom:1px solid var(--border-accent);font-family:var(--font-body);flex-shrink:0;justify-content:space-between;align-items:center;gap:10px;padding:12px 14px;display:flex}.voice-download-banner.downloading{border-color:#4fc3f74d}.voice-download-banner.error{border-color:#e11d484d}.voice-download-content{flex:1;align-items:center;gap:10px;min-width:0;display:flex}.voice-download-icon{flex-shrink:0;font-size:28px}.voice-download-text{flex-direction:column;min-width:0;display:flex}.voice-download-text strong{color:var(--text-primary);font-size:14px;font-weight:900}.voice-download-sub{color:var(--text-secondary);font-size:12px;font-weight:700}.voice-download-actions{flex-shrink:0;gap:6px;display:flex}.voice-download-btn{border-radius:var(--radius-full);font-size:13px;font-weight:800;font-family:var(--font-body);cursor:pointer;border:none;padding:8px 14px;transition:transform .1s ease-out}.voice-download-btn:active{transform:scale(.95)}.voice-download-btn.primary{background:var(--amber);color:#1c1400}.voice-download-btn.dismiss{background:var(--bg-surface);color:var(--text-tertiary)}.voice-progress-bar{background:var(--bg-surface);border-radius:3px;height:6px;margin:6px 0 4px;overflow:hidden}.voice-progress-fill{background:linear-gradient(90deg, var(--amber), var(--sky));border-radius:3px;height:100%;transition:width .3s}.voice-progress-label{color:var(--text-tertiary);font-size:11px;font-weight:800}.parent-tap-zone{z-index:50;cursor:default;width:50px;height:50px;position:fixed;top:0;right:0}.search-trigger-btn{cursor:pointer;z-index:40;background:#ffffff0f;border:none;border-radius:50%;justify-content:center;align-items:center;width:36px;height:36px;font-size:18px;transition:background .15s;display:flex;position:fixed;top:14px;right:210px}.search-trigger-btn:hover{background:#ffffff1a}.search-modal{background:var(--bg-card);border-radius:var(--radius-xl) var(--radius-xl) 0 0;width:100%;max-height:80dvh;font-family:var(--font-body);flex-direction:column;animation:.22s ease-out both sheetUp;display:flex;box-shadow:0 -20px 60px #00000080}.search-header{border-bottom:1px solid var(--border-subtle);gap:10px;padding:16px;display:flex}.search-input{border-radius:var(--radius-md);border:1px solid var(--border-raised);font-size:16px;font-weight:700;font-family:var(--font-body);background:var(--bg-surface);color:var(--text-primary);outline:none;flex:1;padding:10px 14px}.search-input:focus{border-color:var(--amber);box-shadow:0 0 0 3px #f59e0b1f}.search-close{color:var(--text-tertiary);cursor:pointer;background:0 0;border:none;padding:4px 8px;font-size:20px}.search-results{flex:1;padding:8px;overflow-y:auto}.search-empty{text-align:center;color:var(--text-tertiary);padding:24px;font-weight:700}.search-result-item{border-radius:var(--radius-md);cursor:pointer;width:100%;font-family:var(--font-body);text-align:left;color:var(--text-primary);background:0 0;border:none;align-items:center;gap:10px;padding:10px 12px;transition:background .1s;display:flex}.search-result-item:hover{background:var(--bg-raised)}.search-result-emoji{flex-shrink:0;font-size:28px}.search-result-text{flex-direction:column;flex:1;display:flex}.search-result-text strong{color:var(--text-primary);font-size:14px}.search-result-text span{color:var(--text-secondary);font-size:12px}.search-result-board{color:var(--text-tertiary);background:var(--bg-raised);border-radius:var(--radius-sm);padding:2px 8px;font-size:10px;font-weight:800}.settings-page{background:var(--bg-app);height:100dvh;font-family:var(--font-body);flex-direction:column;display:flex}.settings-header{background:var(--bg-base);border-bottom:1px solid var(--border-subtle);flex-shrink:0;justify-content:space-between;align-items:center;padding:12px 16px;display:flex}.settings-back-btn{background:var(--bg-raised);border:1px solid var(--border-raised);border-radius:var(--radius-md);font-size:14px;font-weight:800;font-family:var(--font-body);cursor:pointer;color:var(--text-secondary);padding:8px 14px}.settings-title{font-family:var(--font-display);color:var(--text-primary);font-size:22px}.settings-lock-btn{background:var(--rose);color:#fff;border-radius:var(--radius-md);font-size:13px;font-weight:800;font-family:var(--font-body);cursor:pointer;border:none;padding:8px 14px}.settings-scroll{flex:1;padding:16px;overflow-y:auto}.settings-section{background:var(--bg-card);border:1px solid var(--border-card);border-radius:var(--radius-xl);margin-bottom:16px;padding:18px}.settings-section-title{font-family:var(--font-display);color:var(--text-primary);border-bottom:1px solid var(--border-subtle);margin-bottom:14px;padding-bottom:8px;font-size:18px}.settings-row{justify-content:space-between;align-items:center;gap:12px;padding:10px 0;display:flex}.settings-row label{color:var(--text-secondary);flex-shrink:0;font-size:14px;font-weight:800}.settings-row select{border-radius:var(--radius-sm);border:1px solid var(--border-raised);max-width:220px;font-size:13px;font-weight:700;font-family:var(--font-body);background:var(--bg-surface);color:var(--text-primary);outline:none;flex:1;padding:8px 10px}.settings-row select:focus{border-color:var(--amber)}.settings-row input[type=range]{max-width:180px;accent-color:var(--amber);flex:1}.settings-btn-group{flex-wrap:wrap;gap:6px;display:flex}.settings-btn-option{border-radius:var(--radius-sm);border:1px solid var(--border-raised);background:var(--bg-surface);font-size:13px;font-weight:800;font-family:var(--font-body);cursor:pointer;color:var(--text-tertiary);padding:6px 12px;transition:all .15s}.settings-btn-option.active{background:var(--amber-glow);color:var(--amber);border-color:var(--border-accent)}.settings-toggle{border-radius:var(--radius-full);border:1px solid var(--border-raised);background:var(--bg-surface);font-size:13px;font-weight:900;font-family:var(--font-body);cursor:pointer;color:var(--text-tertiary);text-align:center;min-width:60px;padding:6px 18px;transition:all .15s}.settings-toggle.on{background:var(--green);color:#fff;border-color:var(--green)}.settings-action-btn{border-radius:var(--radius-full);background:var(--amber);color:#1c1400;font-size:13px;font-weight:800;font-family:var(--font-body);cursor:pointer;border:none;padding:8px 16px;transition:transform .1s ease-out}.settings-action-btn:active{transform:scale(.95)}.settings-action-btn:disabled{opacity:.5;cursor:not-allowed}.settings-hint{color:var(--text-tertiary);margin-bottom:12px;font-size:12px;font-weight:700;line-height:1.4}.settings-about{color:var(--text-tertiary);margin-bottom:4px;font-size:13px;font-weight:700;line-height:1.5}.settings-input-sm{border-radius:var(--radius-sm);border:1px solid var(--border-raised);font-size:13px;font-weight:700;font-family:var(--font-body);background:var(--bg-surface);color:var(--text-primary);outline:none;flex:1;min-width:0;padding:8px 10px}.settings-input-sm:focus{border-color:var(--amber)}.skin-tone-btn{padding:4px 8px!important;font-size:18px!important}.settings-pron-list{margin-top:8px}.settings-pron-item{background:var(--bg-surface);border-radius:var(--radius-sm);color:var(--text-secondary);justify-content:space-between;align-items:center;margin-bottom:4px;padding:6px 10px;font-size:13px;font-weight:700;display:flex}.settings-pron-del{color:var(--rose);cursor:pointer;background:0 0;border:none;padding:2px 6px;font-size:16px}.pin-modal{background:var(--bg-card);border-radius:var(--radius-xl);border:1px solid var(--border-raised);width:300px;font-family:var(--font-body);text-align:center;margin:auto;padding:28px 24px;box-shadow:0 20px 60px #00000080}.pin-title{font-family:var(--font-display);color:var(--text-primary);margin-bottom:4px;font-size:22px}.pin-subtitle{color:var(--text-tertiary);margin-bottom:20px;font-size:13px;font-weight:700}.pin-dots{justify-content:center;gap:14px;margin-bottom:8px;display:flex}.pin-dot{border:2px solid var(--border-raised);background:0 0;border-radius:50%;width:18px;height:18px;transition:all .15s}.pin-dot.filled{background:var(--amber);border-color:var(--amber)}.pin-error{color:var(--rose);margin:8px 0;font-size:13px;font-weight:800}.pin-keypad{grid-template-columns:repeat(3,1fr);gap:8px;max-width:240px;margin:16px auto;display:grid}.pin-key{border-radius:var(--radius-md);background:var(--bg-raised);height:52px;font-size:22px;font-weight:900;font-family:var(--font-body);cursor:pointer;color:var(--text-primary);border:none;justify-content:center;align-items:center;transition:all .1s ease-out;display:flex}.pin-key:active{background:var(--amber);color:#1c1400;transform:scale(.95)}.pin-key.backspace{background:var(--amber-dark);color:#fff}.pin-key.empty{cursor:default;background:0 0}.pin-cancel{color:var(--text-tertiary);cursor:pointer;font-size:14px;font-weight:800;font-family:var(--font-body);background:0 0;border:none;margin-top:4px}.ios-install-banner{background:var(--bg-card);border-bottom:1px solid var(--border-accent);font-family:var(--font-body);flex-shrink:0;justify-content:space-between;align-items:center;gap:10px;padding:10px 14px;display:flex}.ios-install-content{flex:1;align-items:center;gap:10px;min-width:0;display:flex}.ios-install-icon{flex-shrink:0;font-size:28px}.ios-install-text{flex-direction:column;min-width:0;display:flex}.ios-install-text strong{color:var(--text-primary);font-size:13px;font-weight:900}.ios-install-sub{color:var(--text-secondary);font-size:11px;font-weight:700}.ios-share-icon{font-size:13px;font-weight:900}.ios-install-close{color:var(--text-tertiary);cursor:pointer;background:0 0;border:none;flex-shrink:0;padding:4px 8px;font-size:18px;font-weight:900}.voice-selector{font-family:var(--font-body)}.voice-section-header{justify-content:space-between;align-items:center;margin-bottom:10px;display:flex}.voice-download-pill{background:var(--amber-glow);color:var(--amber);border:1px solid var(--border-accent);border-radius:var(--radius-full);cursor:pointer;font-size:11px;font-weight:800;font-family:var(--font-body);padding:4px 12px;transition:all .1s}.voice-download-pill:active{transform:scale(.95)}.voice-device-badge{font-size:11px;font-weight:800;font-family:var(--font-body);border-radius:var(--radius-full);vertical-align:middle;margin-left:8px;padding:2px 8px;display:inline-block}.voice-device-badge.webgpu{color:var(--mint);background:#27ae6026;border:1px solid #86efac4d}.voice-device-badge.wasm{color:var(--text-tertiary);background:#ffffff14;border:1px solid #ffffff1a}.voice-status{border-radius:var(--radius-full);padding:4px 10px;font-size:11px;font-weight:800}.voice-status.ready{color:var(--green);background:#27ae601f}.voice-status.downloading{color:var(--sky);background:#4fc3f71f}.voice-status.error{color:var(--rose);background:#e11d481f}.voice-grid{grid-template-columns:repeat(2,1fr);gap:8px;display:grid}.voice-option{border-radius:var(--radius-md);border:1px solid var(--border-card);background:var(--bg-surface);text-align:left;cursor:pointer;font-family:var(--font-body);padding:10px 12px;transition:all .15s}.voice-option.wide{grid-column:1/-1}.voice-option.active{border-color:var(--border-accent);background:var(--amber-glow)}.voice-option:hover:not(.active){border-color:var(--border-raised)}.voice-option-name{color:var(--text-primary);font-size:13px;font-weight:900}.voice-option-desc{color:var(--text-tertiary);margin-top:2px;font-size:11px;font-weight:700;line-height:1.3}.voice-list{flex-direction:column;gap:4px;max-height:200px;display:flex;overflow-y:auto}.voice-placeholder{color:var(--text-tertiary);background:var(--bg-surface);border-radius:var(--radius-md);text-align:center;padding:14px;font-size:13px;font-weight:700}.voice-test-btn{border-radius:var(--radius-full);background:var(--amber);color:#1c1400;width:100%;font-size:15px;font-weight:900;font-family:var(--font-body);cursor:pointer;border:none;margin-top:8px;padding:14px;transition:transform .1s ease-out}.voice-test-btn:active{transform:scale(.97)}.onboarding-overlay{background:var(--bg-base);z-index:200;-webkit-overflow-scrolling:touch;justify-content:center;align-items:flex-start;padding:20px;display:flex;position:fixed;top:0;bottom:0;left:0;right:0;overflow-y:auto}.onboarding-card{background:var(--bg-card);border:1px solid var(--border-card);border-radius:var(--radius-xl);width:100%;max-width:400px;font-family:var(--font-body);text-align:center;margin:auto;padding:32px 28px;box-shadow:0 24px 80px #0006}.onboarding-steps{justify-content:center;gap:8px;margin-bottom:24px;display:flex}.onboarding-dot{background:var(--bg-raised);border-radius:50%;width:10px;height:10px;transition:all .2s}.onboarding-dot.active{background:var(--amber);transform:scale(1.3)}.onboarding-dot.done{background:var(--green)}.onboarding-title{font-family:var(--font-display);color:var(--text-primary);margin-bottom:6px;font-size:26px}.onboarding-subtitle{color:var(--text-secondary);white-space:pre-line;margin-bottom:20px;font-size:14px;font-weight:700;line-height:1.4}.onboarding-field{text-align:left;margin-bottom:20px}.onboarding-field label{color:var(--text-tertiary);text-transform:uppercase;margin-bottom:6px;font-size:13px;font-weight:800;display:block}.onboarding-field input{border-radius:var(--radius-md);border:1px solid var(--border-raised);width:100%;font-size:18px;font-weight:700;font-family:var(--font-body);background:var(--bg-surface);color:var(--text-primary);text-align:center;outline:none;padding:12px 14px}.onboarding-field input:focus{border-color:var(--amber)}.onboarding-skin-grid{grid-template-columns:repeat(3,1fr);gap:8px;margin-bottom:20px;display:grid}.onboarding-skin-btn{border-radius:var(--radius-md);border:1px solid var(--border-raised);background:var(--bg-surface);cursor:pointer;font-family:var(--font-body);flex-direction:column;align-items:center;gap:4px;padding:10px 6px;transition:all .15s;display:flex}.onboarding-skin-btn.active{border-color:var(--amber);background:var(--amber-glow)}.onboarding-skin-swatch{font-size:30px}.onboarding-skin-label{color:var(--text-tertiary);font-size:11px;font-weight:800}.onboarding-nav{gap:10px;display:flex}.onboarding-back{border-radius:var(--radius-full);border:1px solid var(--border-raised);background:var(--bg-surface);color:var(--text-secondary);font-size:16px;font-weight:800;font-family:var(--font-body);cursor:pointer;flex:1;padding:14px}.onboarding-next{border-radius:var(--radius-full);background:var(--amber);color:#1c1400;font-size:16px;font-weight:800;font-family:var(--font-body);cursor:pointer;border:none;flex:2;padding:14px;transition:transform .1s}.onboarding-next.done{background:var(--green);color:#fff}.onboarding-next:active{transform:scale(.97)}.onboarding-tips{text-align:left;flex-direction:column;gap:8px;margin-bottom:20px;display:flex}.onboarding-tip{background:var(--bg-surface);border:1px solid var(--border-subtle);border-radius:var(--radius-md);color:var(--text-secondary);padding:10px 14px;font-size:14px;font-weight:700}.card-style-pastel .symbol-card{filter:saturate(.6)brightness(1.1)}.card-style-high-contrast .symbol-card{border:3px solid var(--gold);background:#0a0a0a!important}.card-style-high-contrast .symbol-card-highlight{display:none}.card-style-high-contrast .symbol-emoji{filter:contrast(1.5)brightness(1.2)}.card-style-high-contrast .symbol-label{color:var(--gold);font-size:clamp(11px,2.5vw,15px)}.card-style-high-contrast .symbol-card-nav-indicator{color:var(--gold);opacity:.8}.card-style-high-contrast #speech-bar,.card-style-high-contrast #breadcrumb,.card-style-high-contrast #tab-bar{background:#050505;border-color:#222}.card-style-high-contrast #speech-output{background:#111;border-color:#333}.card-style-high-contrast .speech-placeholder{color:#555}.card-style-high-contrast .speech-token{color:var(--gold);background:#222;border-color:#444}.card-style-high-contrast .crumb{color:var(--gold);background:#222}.card-style-high-contrast .crumb.active{background:var(--gold);color:#050505;border-color:var(--gold)}.card-style-high-contrast .crumb-sep{color:#444}.card-style-high-contrast .tab-btn{color:#666;background:#111}.card-style-high-contrast .tab-btn.active{background:var(--gold);color:#050505}.card-style-high-contrast #grid-area{background:#050505}.card-style-high-contrast .bar-btn{box-shadow:none}.scroll-thin{scrollbar-width:thin;scrollbar-color:#ffffff1a transparent}.scroll-none{scrollbar-width:none}.scroll-none::-webkit-scrollbar{display:none}:focus-visible{outline:2px solid var(--amber);outline-offset:2px}.symbol-card:focus-visible{outline:3px solid var(--gold);outline-offset:2px}@media (prefers-reduced-motion:reduce){*,:before,:after{transition-duration:.01ms!important;animation-duration:.01ms!important;animation-iteration-count:1!important}}
