@font-face{font-family:Lexend;font-style:normal;font-display:swap;font-weight:400;src:url(./lexend-vietnamese-400-normal-DoLa7jNB.woff2) format("woff2"),url(./lexend-vietnamese-400-normal-mPlHoWg5.woff) format("woff");unicode-range:U+0102-0103,U+0110-0111,U+0128-0129,U+0168-0169,U+01A0-01A1,U+01AF-01B0,U+0300-0301,U+0303-0304,U+0308-0309,U+0323,U+0329,U+1EA0-1EF9,U+20AB}@font-face{font-family:Lexend;font-style:normal;font-display:swap;font-weight:400;src:url(./lexend-latin-ext-400-normal-D38JI5AK.woff2) format("woff2"),url(./lexend-latin-ext-400-normal-D9P7pMo-.woff) format("woff");unicode-range:U+0100-02BA,U+02BD-02C5,U+02C7-02CC,U+02CE-02D7,U+02DD-02FF,U+0304,U+0308,U+0329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:Lexend;font-style:normal;font-display:swap;font-weight:400;src:url(./lexend-latin-400-normal-CwRJVcUA.woff2) format("woff2"),url(./lexend-latin-400-normal-CHypAkT3.woff) format("woff");unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}@font-face{font-family:Lexend;font-style:normal;font-display:swap;font-weight:600;src:url(./lexend-vietnamese-600-normal-Cr1ePs6O.woff2) format("woff2"),url(./lexend-vietnamese-600-normal-BxEVPgxw.woff) format("woff");unicode-range:U+0102-0103,U+0110-0111,U+0128-0129,U+0168-0169,U+01A0-01A1,U+01AF-01B0,U+0300-0301,U+0303-0304,U+0308-0309,U+0323,U+0329,U+1EA0-1EF9,U+20AB}@font-face{font-family:Lexend;font-style:normal;font-display:swap;font-weight:600;src:url(./lexend-latin-ext-600-normal-hDcqLAH9.woff2) format("woff2"),url(./lexend-latin-ext-600-normal-BXtyp5LP.woff) format("woff");unicode-range:U+0100-02BA,U+02BD-02C5,U+02C7-02CC,U+02CE-02D7,U+02DD-02FF,U+0304,U+0308,U+0329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:Lexend;font-style:normal;font-display:swap;font-weight:600;src:url(./lexend-latin-600-normal-DdvlkEkX.woff2) format("woff2"),url(./lexend-latin-600-normal-DSBzZxpA.woff) format("woff");unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}@font-face{font-family:Lexend;font-style:normal;font-display:swap;font-weight:700;src:url(./lexend-vietnamese-700-normal-BrGlFDtO.woff2) format("woff2"),url(./lexend-vietnamese-700-normal-NEp7hM5T.woff) format("woff");unicode-range:U+0102-0103,U+0110-0111,U+0128-0129,U+0168-0169,U+01A0-01A1,U+01AF-01B0,U+0300-0301,U+0303-0304,U+0308-0309,U+0323,U+0329,U+1EA0-1EF9,U+20AB}@font-face{font-family:Lexend;font-style:normal;font-display:swap;font-weight:700;src:url(./lexend-latin-ext-700-normal-CcWyeg4T.woff2) format("woff2"),url(./lexend-latin-ext-700-normal-iR1cPiNX.woff) format("woff");unicode-range:U+0100-02BA,U+02BD-02C5,U+02C7-02CC,U+02CE-02D7,U+02DD-02FF,U+0304,U+0308,U+0329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:Lexend;font-style:normal;font-display:swap;font-weight:700;src:url(./lexend-latin-700-normal-DqO8md6r.woff2) format("woff2"),url(./lexend-latin-700-normal-DVyJlN8t.woff) format("woff");unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}@font-face{font-family:Lexend;font-style:normal;font-display:swap;font-weight:800;src:url(./lexend-vietnamese-800-normal-B27Hd6aN.woff2) format("woff2"),url(./lexend-vietnamese-800-normal-DLOhWP8n.woff) format("woff");unicode-range:U+0102-0103,U+0110-0111,U+0128-0129,U+0168-0169,U+01A0-01A1,U+01AF-01B0,U+0300-0301,U+0303-0304,U+0308-0309,U+0323,U+0329,U+1EA0-1EF9,U+20AB}@font-face{font-family:Lexend;font-style:normal;font-display:swap;font-weight:800;src:url(./lexend-latin-ext-800-normal-B0JWHALI.woff2) format("woff2"),url(./lexend-latin-ext-800-normal-r3QZLne4.woff) format("woff");unicode-range:U+0100-02BA,U+02BD-02C5,U+02C7-02CC,U+02CE-02D7,U+02DD-02FF,U+0304,U+0308,U+0329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:Lexend;font-style:normal;font-display:swap;font-weight:800;src:url(./lexend-latin-800-normal-sVzxf3WX.woff2) format("woff2"),url(./lexend-latin-800-normal-BcJVUnx_.woff) format("woff");unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}:root{--bg: #fbf9f4;--surface: #ffffff;--surface-2: #ebe9e2;--ink: #1e2a4a;--ink-soft: #54607a;--teal: #2d6cdf;--teal-dark: #1e50b8;--teal-tint: #dce7fb;--green: #12b5a5;--green-tint: #d2f2ee;--amber: #ff6b4a;--amber-tint: #ffe3db;--shadow: 0 4px 16px rgba(30, 42, 74, .1);--shadow-lift: 0 8px 24px rgba(30, 42, 74, .16);--radius: 20px;--radius-sm: 14px;--tap-min: 64px;--maxw: 480px;--font: "Lexend", "Segoe UI", Roboto, system-ui, -apple-system, sans-serif}*{box-sizing:border-box}html,body,#root{margin:0;padding:0}html,body{height:100%}body{font-family:var(--font);background:var(--bg);color:var(--ink);font-size:20px;line-height:1.45;-webkit-font-smoothing:antialiased;-webkit-tap-highlight-color:transparent;touch-action:manipulation;overflow:hidden}#root,.app{max-width:var(--maxw);margin:0 auto;height:100vh;height:100dvh;display:flex;flex-direction:column;background:var(--bg);overflow:hidden}.screen{flex:1;min-height:0;display:flex;flex-direction:column;padding:16px 18px 22px;overflow:hidden}.screen.home{overflow-y:auto;-webkit-overflow-scrolling:touch}.screen-body{flex:1;min-height:0;display:flex;flex-direction:column;justify-content:center;overflow-y:auto;-webkit-overflow-scrolling:touch}.topbar{display:flex;align-items:center;gap:12px;margin-bottom:8px;min-height:var(--tap-min)}.app-title{font-size:32px;font-weight:800;letter-spacing:-.5px;color:var(--teal-dark);margin:4px 0 2px}.app-subtitle{font-size:18px;color:var(--ink-soft);margin:0 0 16px}.btn{font-family:inherit;font-size:22px;font-weight:700;min-height:var(--tap-min);padding:16px 24px;border:none;border-radius:var(--radius-sm);cursor:pointer;display:inline-flex;align-items:center;justify-content:center;gap:10px;transition:transform .12s ease,background .15s ease,box-shadow .15s ease;-webkit-user-select:none;user-select:none}.btn:active{transform:scale(.97)}.btn-primary{background:var(--teal);color:#fff;box-shadow:var(--shadow);width:100%}.btn-primary:hover{background:var(--teal-dark)}.btn-secondary{background:var(--surface);color:var(--teal-dark);border:2px solid var(--teal);width:100%}.btn-secondary:hover{background:var(--teal-tint)}.btn-hint{background:var(--amber-tint);color:#b23a1e;border:2px solid var(--amber);width:100%}.btn-hint:hover{background:#ffd4c8}.btn-back{font-size:26px;width:var(--tap-min);height:var(--tap-min);min-height:var(--tap-min);padding:0;border-radius:50%;background:var(--surface);color:var(--teal-dark);border:2px solid var(--surface-2);box-shadow:var(--shadow);flex:0 0 auto}.btn-back:hover{background:var(--teal-tint)}.btn-row{display:flex;flex-direction:column;gap:12px;margin-top:auto;padding-top:16px;flex:0 0 auto}.card-list{display:flex;flex-direction:column;gap:12px}.mechanic-card{display:flex;align-items:center;gap:16px;text-align:left;background:var(--surface);border:2px solid transparent;border-radius:var(--radius);padding:14px 18px;min-height:80px;box-shadow:var(--shadow);cursor:pointer;width:100%;font-family:inherit;color:var(--ink);transition:transform .12s ease,box-shadow .15s ease,border-color .15s ease}.mechanic-card:hover{border-color:var(--teal);box-shadow:var(--shadow-lift)}.mechanic-card:active{transform:scale(.99)}.mechanic-card .card-icon{font-size:34px;line-height:1;flex:0 0 auto;width:56px;height:56px;display:flex;align-items:center;justify-content:center;background:var(--teal-tint);border-radius:50%}.mechanic-card .card-text{display:flex;flex-direction:column;gap:3px}.mechanic-card .card-name{font-size:23px;font-weight:800;line-height:1.15}.mechanic-card .card-skill{font-size:16px;font-weight:700;color:var(--teal)}.progress{flex:1;display:flex;flex-direction:column;gap:8px}.progress-label{font-size:18px;font-weight:700;color:var(--ink-soft)}.progress-track{height:14px;background:var(--surface-2);border-radius:999px;overflow:hidden}.progress-fill{height:100%;background:var(--teal);border-radius:999px;transition:width .35s ease}.prompt{text-align:center;margin:12px 0 8px}.prompt-instruction{font-size:28px;font-weight:700;margin:0 0 8px}.prompt-sentence{font-size:30px;font-weight:700;line-height:1.4;margin:8px 0 4px}.blank{color:var(--teal)}.picture{display:flex;align-items:center;justify-content:center;background:var(--surface);border-radius:var(--radius);box-shadow:var(--shadow)}.picture .emoji{line-height:1}.picture-hero{height:min(300px,32vh);aspect-ratio:1 / 1;width:auto;margin:10px auto;flex:0 1 auto}.picture-hero .emoji{font-size:min(150px,22vh)}.options{display:grid;gap:14px;margin-top:16px}.options.cols-1{grid-template-columns:1fr}.options.cols-2{grid-template-columns:1fr 1fr}.options.cols-3{grid-template-columns:1fr 1fr 1fr}.option{display:flex;flex-direction:column;align-items:center;gap:8px;background:var(--surface);border:3px solid var(--surface-2);border-radius:var(--radius);padding:18px 12px;min-height:140px;cursor:pointer;font-family:inherit;color:var(--ink);box-shadow:var(--shadow);transition:transform .12s ease,border-color .15s ease,background .15s ease}@media (hover: hover){.option:hover{border-color:var(--teal)}}.option:active{transform:scale(.98)}.option .emoji{font-size:72px;line-height:1}.option .option-word{font-size:22px;font-weight:700}.option .number-big{font-size:48px;font-weight:800;color:var(--ink);line-height:1}.qty-box{position:relative;width:100%;height:120px}.qty-icon{position:absolute;line-height:1}.options.cols-3 .option{min-height:110px;padding:14px 6px;min-width:0}.options.cols-3 .option .emoji{font-size:48px}.options.cols-3 .option .number-big{font-size:32px}.clock-wrap{display:flex;justify-content:center;margin:6px 0 4px}.clock-num{font-family:var(--font);font-size:17px;font-weight:700}.clock-num-lg{font-family:var(--font);font-size:22px;font-weight:800}.set-clock{width:min(300px,80vw);height:auto;touch-action:none;cursor:pointer;-webkit-user-select:none;user-select:none}.clock-target{font-size:44px;font-weight:800;color:var(--teal-dark);text-align:center;margin:0 0 8px;line-height:1}.clock-target.words{font-size:30px;line-height:1.15}.options.opts-words{gap:10px}.opts-words .option{min-height:64px;padding:14px 16px;flex-direction:row;justify-content:center}.option .time-words{font-size:24px;font-weight:700;color:var(--ink);text-align:center}.hand-select{display:flex;gap:12px;margin-top:14px}.hand-btn{flex:1;font-family:inherit;font-size:17px;font-weight:700;min-height:56px;border-radius:var(--radius-sm);border:3px solid var(--surface-2);background:var(--surface);color:var(--ink-soft);cursor:pointer}.hand-btn.active{border-color:var(--ink);color:var(--ink);background:#eef1f3}.hand-btn.active.minute{border-color:var(--teal);color:var(--teal-dark);background:var(--teal-tint)}.option.correct{border-color:var(--green);background:var(--green-tint)}.option.wrong{border-color:var(--surface-2);opacity:.55;animation:shake .4s ease}.option.hinted{border-color:var(--amber);background:var(--amber-tint);animation:pulse 1.2s ease infinite}.option:disabled{cursor:default}.cue-stack{display:flex;flex-direction:column;gap:8px;margin-top:10px;overflow:hidden}.cue{background:var(--amber-tint);border-left:6px solid var(--amber);border-radius:var(--radius-sm);padding:11px 16px;font-size:20px;text-align:left;animation:fade-in .3s ease}.cue strong{color:#b23a1e}.cue-answer{background:var(--green-tint);border-left-color:var(--green);text-align:center}.cue-answer .answer-word{font-size:44px;font-weight:800;color:var(--green);display:block;margin-top:4px}.buckets{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-bottom:18px}.bucket{background:var(--surface);border:3px dashed var(--surface-2);border-radius:var(--radius);padding:14px 10px;height:150px;display:flex;flex-direction:column;align-items:center;justify-content:flex-start;gap:8px;cursor:pointer;font-family:inherit;color:var(--ink);transition:border-color .15s ease,background .15s ease}.bucket.active{border-color:var(--teal);border-style:solid;background:var(--teal-tint)}.bucket:disabled{cursor:default}.bucket-head{font-size:20px;font-weight:800;display:flex;align-items:center;gap:6px}.bucket-head .emoji{font-size:26px}.bucket-items{display:flex;flex-wrap:wrap;gap:6px;justify-content:center}.bucket-chip{font-size:26px;background:var(--surface-2);border-radius:12px;padding:4px 6px;animation:fade-in .3s ease}.tray{background:var(--surface-2);border-radius:var(--radius);padding:14px;display:grid;grid-template-columns:1fr 1fr 1fr;grid-auto-rows:min-content;align-content:start;gap:12px;height:248px}.tray-card{display:flex;flex-direction:column;align-items:center;gap:4px;background:var(--surface);border:3px solid transparent;border-radius:var(--radius-sm);padding:12px 6px;cursor:pointer;font-family:inherit;color:var(--ink);box-shadow:var(--shadow);transition:transform .12s ease,border-color .15s ease}.tray-card .emoji{font-size:48px;line-height:1}.tray-card .tray-word{font-size:17px;font-weight:700}.tray-card.selected{border-color:var(--teal);transform:scale(1.04);background:var(--teal-tint)}.tray-card.returning{animation:shake .4s ease}.sort-hint{display:flex;align-items:center;justify-content:center;text-align:center;font-size:20px;color:var(--ink-soft);margin:4px 0 12px;height:52px}.status{text-align:center;font-size:22px;font-weight:700;min-height:32px;margin-top:14px}.status.good{color:var(--green)}.status.support{color:var(--amber)}.completion{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;gap:8px}.completion .badge{font-size:96px;animation:pop .5s ease}.completion h2{font-size:36px;margin:8px 0 4px;color:var(--teal-dark)}.completion p{font-size:22px;color:var(--ink-soft);margin:0 0 8px}@keyframes shake{0%,to{transform:translate(0)}20%{transform:translate(-7px)}40%{transform:translate(7px)}60%{transform:translate(-5px)}80%{transform:translate(5px)}}@keyframes pulse{0%,to{box-shadow:0 0 #ff6b4a80}50%{box-shadow:0 0 0 10px #ff6b4a00}}@keyframes fade-in{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}@keyframes pop{0%{transform:scale(.4);opacity:0}70%{transform:scale(1.15)}to{transform:scale(1);opacity:1}}:focus-visible{outline:4px solid var(--teal);outline-offset:3px}@media (prefers-reduced-motion: reduce){*,*:before,*:after{animation-duration:.001ms!important;animation-iteration-count:1!important;transition-duration:.001ms!important}}.mic-row{display:flex;flex-direction:column;align-items:center;gap:6px;margin-top:6px}.btn-mic{width:84px;height:84px;min-height:84px;border-radius:50%;border:none;background:var(--teal);color:#fff;font-size:38px;box-shadow:var(--shadow);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:transform .12s ease,background .15s ease}.btn-mic:hover{background:var(--teal-dark)}.btn-mic:active{transform:scale(.95)}.btn-mic.listening{background:var(--green);animation:mic-pulse 1.3s ease infinite}.btn-mic.busy{background:var(--ink-soft);opacity:.75;animation:mic-busy 1s ease infinite}.btn-mic:disabled{cursor:default}.mic-caption{font-size:17px;color:var(--ink-soft);min-height:22px;text-align:center}.mic-heard{font-weight:700;color:var(--teal-dark)}@keyframes mic-pulse{0%,to{box-shadow:0 0 #4f8a5b8c}50%{box-shadow:0 0 0 16px #4f8a5b00}}@keyframes mic-busy{0%,to{opacity:.55}50%{opacity:.9}}.tray-card{touch-action:none}.tray-card.dragging{position:fixed;z-index:1000;pointer-events:none;opacity:.95;box-shadow:var(--shadow-lift);transform:scale(1.08)}.bucket.drop-target{border-color:var(--green);border-style:solid;background:var(--green-tint)}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.path-screen{flex:1;min-height:0;display:flex;flex-direction:column;overflow:hidden}.streak-bar{flex:0 0 auto;display:flex;align-items:center;justify-content:space-between;padding:14px 20px 12px;background:var(--surface);border-bottom:2px solid var(--surface-2);box-shadow:0 2px 8px #2432400f}.app-name-small{font-size:19px;font-weight:800;color:var(--teal-dark);letter-spacing:-.4px;line-height:1.1;max-width:8.5em}.streak-right{display:flex;align-items:center;gap:6px}.streak-flame{font-size:28px;filter:grayscale(1);transition:filter .3s ease}.streak-flame.flame-active{filter:none}.streak-count{font-size:28px;font-weight:800;color:var(--ink);line-height:1}.streak-word{font-size:15px;font-weight:600;color:var(--ink-soft);line-height:1.2}.path-scroll{flex:1;min-height:0;overflow-y:auto;-webkit-overflow-scrolling:touch}.path-column{display:flex;flex-direction:column;align-items:center;padding:24px 0 0;position:relative}.path-node-slot{display:flex;flex-direction:column;align-items:center;margin-bottom:20px}.path-node{position:relative;width:80px;height:80px;border-radius:50%;border:none;background:transparent;cursor:pointer;padding:0;display:flex;align-items:center;justify-content:center;transition:transform .15s ease,box-shadow .15s ease}.path-node:active{transform:scale(.94)}.path-node:disabled{cursor:default}.node-done{opacity:1}.node-active{animation:node-pulse 2.2s ease-in-out infinite}.test-node.node-active{animation:node-pulse-gold 2.2s ease-in-out infinite}.node-locked{opacity:.38}.node-locked:active{transform:none}.test-node{border-radius:50%}.test-node:before{content:"";position:absolute;top:-7px;right:-7px;bottom:-7px;left:-7px;border-radius:50%;background:var(--amber-tint);z-index:-1}.node-label.label-gold{color:#b23a1e}.node-number{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;font-size:18px;font-weight:800;color:var(--teal-dark);pointer-events:none}.node-locked .node-number{color:var(--ink-soft)}.node-done .node-number{color:var(--teal-dark)}.node-lock-icon{position:absolute;bottom:-2px;right:-2px;font-size:18px;pointer-events:none}.node-resume-dot{position:absolute;bottom:2px;left:50%;transform:translate(-50%);width:8px;height:8px;background:var(--amber);border-radius:50%;pointer-events:none}.node-label{margin-top:4px;font-size:14px;font-weight:700;color:var(--teal);min-height:18px;text-align:center}.path-all-done{text-align:center;padding:12px 24px 20px;font-size:22px;color:var(--teal-dark);font-weight:700}.path-all-done span{font-size:48px;display:block;margin-bottom:8px}.session-tag{display:flex;align-items:center;justify-content:space-between;padding:6px 2px 8px;flex:0 0 auto}.session-node-num{font-size:15px;font-weight:700;color:var(--ink-soft)}.session-mechanic-label{font-size:15px;font-weight:700;color:var(--teal-dark);background:var(--teal-tint);padding:4px 12px;border-radius:999px}.session-mechanic-label.session-mechanic-gold{color:#b23a1e;background:var(--amber-tint)}.practice-tag{font-size:18px;font-weight:800;color:var(--teal-dark)}.node-complete{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:24px 20px;gap:4px}.node-complete-badge{font-size:96px;animation:pop .5s ease;line-height:1;margin-bottom:8px}.node-complete-title{font-size:34px;font-weight:800;color:var(--teal-dark);margin:0 0 6px}.node-complete-sub{font-size:20px;color:var(--ink-soft);margin:0}@keyframes node-pulse{0%,to{box-shadow:0 0 #2d6cdf59}50%{box-shadow:0 0 0 14px #2d6cdf00}}@keyframes node-pulse-gold{0%,to{box-shadow:0 0 #ff6b4a66}50%{box-shadow:0 0 0 14px #ff6b4a00}}.ring-number{font-family:var(--font);font-weight:800}.ring-seg-draw{stroke-dasharray:var(--seg-len);animation:ring-draw .7s ease-out both}@keyframes ring-draw{0%{stroke-dashoffset:var(--seg-len)}to{stroke-dashoffset:0}}.ring-resume-dot{animation:dot-pulse 1.8s ease-in-out infinite}@keyframes dot-pulse{0%,to{opacity:1}50%{opacity:.45}}.menu-wrap{position:relative;margin-left:6px}.menu-btn{font-family:inherit;font-size:24px;line-height:1;width:44px;height:44px;border-radius:50%;border:2px solid var(--surface-2);background:var(--surface);color:var(--teal-dark);cursor:pointer;display:flex;align-items:center;justify-content:center}.menu-btn:active{transform:scale(.94)}.menu-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:40}.menu-panel{position:absolute;top:calc(100% + 10px);right:0;z-index:50;background:var(--surface);border:2px solid var(--surface-2);border-radius:var(--radius-sm);box-shadow:var(--shadow-lift);padding:8px;min-width:210px;display:flex;flex-direction:column;gap:4px}.menu-item{font-family:inherit;font-size:18px;font-weight:700;color:var(--ink);background:transparent;border:none;border-radius:12px;padding:14px 12px;min-height:56px;display:flex;align-items:center;gap:12px;cursor:pointer;text-align:left}.menu-item:hover{background:var(--teal-tint)}.menu-item:active{transform:scale(.98)}.menu-item-icon{font-size:22px}.node-fill{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;gap:18px;padding:24px 20px}.node-fill-tag{font-size:17px;font-weight:700;color:var(--ink-soft)}.node-fill-count{font-size:24px;font-weight:800;color:var(--teal-dark);margin:0}.node-fill .btn-primary{width:auto;min-width:220px}.streak-summary{display:flex;align-items:center;justify-content:center;gap:8px;margin:4px 0 18px}.streak-summary .streak-flame{font-size:32px}.streak-summary-count{font-size:34px;font-weight:800;color:var(--ink);line-height:1}.streak-summary-word{font-size:18px;font-weight:600;color:var(--ink-soft)}.cal-card{background:var(--surface);border:2px solid var(--surface-2);border-radius:var(--radius);box-shadow:var(--shadow);padding:16px}.cal-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}.cal-title{font-size:20px;font-weight:800;color:var(--teal-dark)}.cal-nav{font-family:inherit;font-size:26px;line-height:1;width:44px;height:44px;border-radius:50%;border:2px solid var(--surface-2);background:var(--surface);color:var(--teal-dark);cursor:pointer}.cal-nav:disabled{opacity:.3;cursor:default}.cal-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:6px}.cal-weekdays{margin-bottom:6px}.cal-weekday{text-align:center;font-size:12px;font-weight:700;color:var(--ink-soft);padding:2px 0}.cal-cell{aspect-ratio:1 / 1;display:flex;align-items:center;justify-content:center;font-size:15px;font-weight:700;color:var(--ink);border-radius:50%}.cal-empty{visibility:hidden}.cal-done{background:var(--teal);color:#fff}.cal-today,.cal-done.cal-today{box-shadow:inset 0 0 0 3px var(--amber)}.cal-legend{display:flex;align-items:center;justify-content:center;gap:8px;font-size:14px;color:var(--ink-soft);margin-top:16px}.cal-dot{width:16px;height:16px;border-radius:50%;display:inline-block}.cal-dot-done{background:var(--teal)}.cal-dot-today{box-shadow:inset 0 0 0 3px var(--amber);background:var(--surface);margin-left:12px}@media (max-height: 700px){.screen{padding-top:12px;padding-bottom:14px}.picture-hero{height:min(220px,26vh);margin:6px auto}.picture-hero .emoji{font-size:min(120px,18vh)}.prompt-instruction{margin:4px 0}.btn-row{padding-top:10px;gap:10px}.cue-stack{gap:6px}.mic-row{margin:6px 0}}.auth-screen{justify-content:center;background:radial-gradient(70% 45% at 50% -5%,rgba(18,181,165,.12),transparent 70%),radial-gradient(55% 35% at 110% 0%,rgba(255,107,74,.1),transparent 70%),var(--bg)}.auth-body{max-width:420px;width:100%;margin:0 auto;display:flex;flex-direction:column;justify-content:center;flex:1;min-height:0}.auth-logo{display:block;width:100%;max-width:260px;height:auto;margin:0 auto 28px}.auth-logo-sm{max-width:180px;margin-bottom:22px}.auth-card{background:var(--surface);border:1px solid rgba(30,42,74,.06);border-radius:24px;box-shadow:var(--shadow-lift);padding:30px 26px}.auth-title{font-size:26px;font-weight:800;color:var(--ink);letter-spacing:-.3px;margin:0 0 6px;text-align:center}.auth-lead{font-size:18px;color:var(--ink-soft);margin:0 0 24px;line-height:1.5;text-align:center}.auth-form{display:flex;flex-direction:column;gap:14px}.auth-label{font-size:17px;font-weight:600;color:var(--ink)}.auth-input{font-family:inherit;font-size:18px;min-height:var(--tap-min);padding:16px 18px;border:2px solid var(--surface-2);border-radius:var(--radius-sm);background:var(--surface);color:var(--ink);width:100%;outline:none;transition:border-color .15s ease,box-shadow .15s ease}.auth-input:focus{border-color:var(--teal);box-shadow:0 0 0 4px var(--teal-tint)}.auth-input:disabled{opacity:.6}.otp-input{text-align:center;font-size:38px;font-weight:700;letter-spacing:14px;padding-left:28px}.auth-msg{font-size:17px;color:var(--ink-soft);margin:0;text-align:center}.auth-error{font-size:17px;color:#b23a1e;background:var(--amber-tint);border-radius:var(--radius-sm);padding:12px 14px;margin:0}.auth-foot{font-size:15px;color:var(--ink-soft);margin:18px 0 0;text-align:center}.auth-actions{display:flex;flex-direction:column;gap:4px;margin-top:20px;align-items:center}.auth-link{font-family:inherit;font-size:17px;font-weight:600;color:var(--teal-dark);background:none;border:none;padding:12px;min-height:48px;cursor:pointer;text-decoration:underline}.auth-link:disabled{opacity:.5;cursor:default}.auth-splash{flex:1;display:flex;align-items:center;justify-content:center;color:var(--ink-soft);font-size:20px}
