@import"https://fonts.googleapis.com/css2?family=Plus+Jakarta+Sans:wght@300;400;500;600;700;800&family=Sora:wght@400;600;700;800&display=swap";:root{--navy: #0d1f3c;--navy-mid: #163057;--blue: #1e4d8c;--blue-light: #2563c0;--sky: #e8f0fb;--sky2: #d4e3f7;--white: #ffffff;--off: #f7f9fc;--gray1: #f0f4f9;--gray2: #e2e8f2;--gray3: #b8c6d9;--gray4: #7a92b0;--gray5: #4a6080;--text: #0d1f3c;--text2: #3a5068;--text3: #7a92b0;--green: #0fa870;--green-light: #e6f9f2;--gold: #c9972a;--gold-light: #fdf3e0;--red: #e05050;--red-light: #fef0f0;--shadow-sm: 0 1px 4px rgba(13,31,60,.07);--shadow: 0 4px 16px rgba(13,31,60,.1);--shadow-lg: 0 8px 32px rgba(13,31,60,.14);--radius-sm: 10px;--radius: 14px;--radius-lg: 20px;--radius-xl: 26px;--font: "Plus Jakarta Sans", sans-serif;--font-display: "Sora", sans-serif;--sp-xs: 8px;--sp-sm: 12px;--sp-md: 16px;--sp-lg: 20px;--sp-xl: 24px;--nav-h: 64px;--top-h: 56px;--safe-bottom: env(safe-area-inset-bottom, 0px)}*,*:before,*:after{margin:0;padding:0;box-sizing:border-box;-webkit-tap-highlight-color:transparent}html{font-size:16px;-webkit-text-size-adjust:100%}body{font-family:var(--font);background:var(--off);color:var(--text);height:100%;overflow:hidden;overscroll-behavior:none;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}#app{max-width:430px;width:100%;height:100dvh;height:100vh;margin:0 auto;position:relative;overflow:hidden;background:var(--off);display:flex;flex-direction:column;box-shadow:0 0 60px #0d1f3c26}.screen{display:none;flex-direction:column;flex:1;min-height:0;overflow:hidden}.screen.active{display:flex}.scroll-body{flex:1;overflow-y:auto;overflow-x:hidden;-webkit-overflow-scrolling:touch;overscroll-behavior-y:contain;padding-bottom:var(--sp-xl)}.scroll-body::-webkit-scrollbar{display:none}.topbar{height:var(--top-h);display:flex;align-items:center;justify-content:space-between;padding:0 var(--sp-lg);background:var(--white);border-bottom:1px solid var(--gray2);flex-shrink:0;z-index:20}.topbar-logo{font-family:var(--font-display);font-size:1.2rem;font-weight:800;color:var(--navy);letter-spacing:-.02em;-webkit-user-select:none;user-select:none}.topbar-logo span{color:var(--blue-light)}.lang-pill{display:flex;background:var(--gray1);border-radius:50px;padding:3px;border:1px solid var(--gray2);flex-shrink:0}.lang-pill button{padding:5px 16px;border-radius:50px;border:none;background:transparent;font-family:var(--font);font-size:.75rem;font-weight:700;color:var(--text3);cursor:pointer;transition:background .18s,color .18s;letter-spacing:.04em;min-height:30px}.lang-pill button.active{background:var(--navy);color:#fff}.bottom-nav{background:var(--white);border-top:1px solid var(--gray2);display:flex;align-items:stretch;flex-shrink:0;padding-bottom:var(--safe-bottom);height:calc(var(--nav-h) + var(--safe-bottom))}.nav-item{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;cursor:pointer;padding:8px 2px;border:none;background:transparent;position:relative;min-height:44px;transition:opacity .15s}.nav-item:active{opacity:.7}.nav-icon{font-size:1.2rem;line-height:1;display:block}.nav-label{font-size:.6rem;font-weight:700;color:var(--text3);letter-spacing:.02em;transition:color .18s;line-height:1;white-space:nowrap}.nav-item.active .nav-label{color:var(--blue-light)}.nav-dot{position:absolute;top:6px;width:4px;height:4px;background:var(--blue-light);border-radius:50%;opacity:0;transition:opacity .18s}.nav-item.active .nav-dot{opacity:1}.section-hd{display:flex;align-items:center;justify-content:space-between;padding:var(--sp-md) var(--sp-lg) var(--sp-xs)}.section-title{font-family:var(--font-display);font-size:.93rem;font-weight:700;color:var(--navy)}.section-link{font-size:.75rem;font-weight:600;color:var(--blue-light);cursor:pointer;background:none;border:none;font-family:var(--font);padding:4px 0}.card{background:var(--white);border-radius:var(--radius);border:1.5px solid var(--gray2);box-shadow:var(--shadow-sm);overflow:hidden}.card-pad{padding:var(--sp-md)}.chip{display:inline-flex;align-items:center;gap:5px;background:var(--gray1);border:1.5px solid var(--gray2);border-radius:50px;padding:7px 14px;font-size:.77rem;font-weight:600;color:var(--text2);cursor:pointer;transition:background .15s,border-color .15s,color .15s;white-space:nowrap;font-family:var(--font);flex-shrink:0;min-height:36px}.chip:active,.chip.active{background:var(--sky);border-color:var(--blue-light);color:var(--blue-light)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:7px;border:none;border-radius:var(--radius-sm);font-family:var(--font);font-weight:700;cursor:pointer;transition:filter .15s,opacity .15s;letter-spacing:.01em}.btn-primary{background:var(--blue-light);color:#fff;padding:14px 22px;font-size:.88rem;width:100%;border-radius:var(--radius);min-height:48px}.btn-primary:active{filter:brightness(.92)}.btn-primary:disabled{opacity:.45;cursor:not-allowed}.btn-icon{padding:8px;border-radius:10px;background:var(--gray1);border:1.5px solid var(--gray2);color:var(--text2);font-size:1rem;min-width:36px;min-height:36px}.badge{display:inline-flex;align-items:center;gap:4px;padding:3px 9px;border-radius:50px;font-size:.68rem;font-weight:700;letter-spacing:.04em}.badge-blue{background:var(--sky);color:var(--blue)}.badge-green{background:var(--green-light);color:var(--green)}.hero-banner{margin:var(--sp-md);background:linear-gradient(135deg,var(--navy) 0%,var(--blue) 100%);border-radius:var(--radius-lg);padding:18px var(--sp-lg) 16px;position:relative;overflow:hidden}.hero-banner:before{content:"";position:absolute;top:-24px;right:-24px;width:120px;height:120px;background:#ffffff0d;border-radius:50%;pointer-events:none}.hero-eyebrow{font-size:.67rem;font-weight:700;color:#ffffff8c;letter-spacing:.1em;text-transform:uppercase;margin-bottom:4px}.hero-title{font-family:var(--font-display);font-size:1.2rem;font-weight:800;color:#fff;line-height:1.25;margin-bottom:6px}.hero-sub{font-size:.78rem;color:#ffffffad;line-height:1.45;margin-bottom:14px}.hero-stats{display:flex;gap:var(--sp-lg)}.hero-stat-num{font-family:var(--font-display);font-size:1.15rem;font-weight:800;color:#fff;line-height:1}.hero-stat-lbl{font-size:.65rem;color:#ffffff80;margin-top:2px}.search-bar{margin:0 var(--sp-md) var(--sp-md);display:flex;align-items:center;gap:var(--sp-xs);background:var(--white);border:1.5px solid var(--gray2);border-radius:var(--radius);padding:0 var(--sp-md);box-shadow:var(--shadow-sm);min-height:50px}.search-bar input{flex:1;border:none;outline:none;font-family:var(--font);font-size:.88rem;color:var(--text);padding:14px 0;background:transparent;min-width:0}.search-bar input::placeholder{color:var(--text3)}.search-bar .search-icon{font-size:.95rem;color:var(--text3);flex-shrink:0}.search-bar .search-btn{background:var(--blue-light);color:#fff;border:none;border-radius:8px;padding:7px 14px;font-family:var(--font);font-size:.76rem;font-weight:700;cursor:pointer;white-space:nowrap;flex-shrink:0;min-height:34px}.search-bar .search-btn:active{filter:brightness(.92)}.chips-scroll{display:flex;gap:var(--sp-xs);padding:2px var(--sp-lg) var(--sp-xs);overflow-x:auto;scrollbar-width:none;flex-wrap:nowrap;-webkit-overflow-scrolling:touch}.chips-scroll::-webkit-scrollbar{display:none}.cat-helper-text{font-size:.72rem;color:var(--text3);font-weight:500;padding:0 var(--sp-md) 6px;letter-spacing:.01em}.journey-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--sp-xs);padding:2px var(--sp-md) var(--sp-xs)}.journey-card{background:var(--white);border:1.5px solid var(--gray2);border-radius:var(--radius);padding:15px 12px 13px;cursor:pointer;transition:border-color .15s,background .15s,transform .15s,box-shadow .15s;display:flex;flex-direction:column;align-items:center;text-align:center;gap:8px;box-shadow:var(--shadow-sm);min-height:96px}.journey-card:active{transform:scale(.97);box-shadow:var(--shadow)}.journey-card.selected{border-color:var(--blue-light);box-shadow:0 0 0 3px #2563c01f}.journey-card-icon{width:42px;height:42px;border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:1.45rem;flex-shrink:0}.journey-card-label{font-size:.76rem;font-weight:700;color:var(--text2);line-height:1.3}.phases-list{padding:0 var(--sp-md) var(--sp-xs);display:flex;flex-direction:column;gap:var(--sp-xs)}.phase-card{background:var(--white);border:1.5px solid var(--gray2);border-radius:var(--radius);overflow:hidden;cursor:pointer;transition:border-color .15s,box-shadow .15s;box-shadow:var(--shadow-sm)}.phase-card:active{box-shadow:var(--shadow)}.phase-header{display:flex;align-items:center;gap:13px;padding:13px var(--sp-md);min-height:64px}.phase-num{width:30px;height:30px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.72rem;font-weight:800;flex-shrink:0;letter-spacing:.02em}.phase-icon{width:40px;height:40px;border-radius:11px;display:flex;align-items:center;justify-content:center;font-size:1.25rem;flex-shrink:0}.phase-info{flex:1;min-width:0}.phase-title{font-size:.86rem;font-weight:700;color:var(--text);margin-bottom:2px}.phase-meta{font-size:.71rem;color:var(--text3)}.phase-chevron{color:var(--text3);font-size:.9rem;flex-shrink:0;transition:transform .2s}.phase-chevron.open{transform:rotate(180deg)}.phase-badge{font-size:.65rem;font-weight:700;padding:2px 8px;border-radius:50px;letter-spacing:.06em}.phase-body{border-top:1px solid var(--gray1);padding:var(--sp-sm) var(--sp-md);display:flex;flex-direction:column;gap:var(--sp-xs)}.phase-section-label{font-size:.67rem;font-weight:800;letter-spacing:.09em;text-transform:uppercase;color:var(--text3);margin-bottom:4px;margin-top:4px}.phase-lesson-row{display:flex;align-items:center;gap:10px;padding:9px 12px;background:var(--off);border-radius:var(--radius-sm);cursor:pointer;transition:background .12s;min-height:42px}.phase-lesson-row:active{background:var(--sky)}.phase-lesson-emoji{font-size:1.1rem;flex-shrink:0}.phase-lesson-text{flex:1;font-size:.82rem;font-weight:600;color:var(--text2)}.phase-lesson-arrow{color:var(--text3);font-size:.85rem}.phase-q-chip{display:inline-flex;align-items:center;gap:5px;background:var(--gray1);border:1.5px solid var(--gray2);border-radius:50px;padding:6px 12px;font-size:.75rem;font-weight:600;color:var(--text2);cursor:pointer;transition:all .15s;white-space:nowrap;font-family:var(--font);min-height:34px}.phase-q-chip:active{background:var(--sky);border-color:var(--blue-light);color:var(--blue-light)}.phase-qs-wrap{display:flex;flex-wrap:wrap;gap:6px}.phase-checklist-item{display:flex;align-items:center;gap:9px;padding:7px 0;border-bottom:1px solid var(--gray1);font-size:.8rem;color:var(--text2);line-height:1.35}.phase-checklist-item:last-child{border-bottom:none}.phase-check-dot{width:7px;height:7px;border-radius:50%;flex-shrink:0}.phase-ask-btn{display:flex;align-items:center;justify-content:center;gap:7px;background:var(--blue-light);color:#fff;border:none;border-radius:var(--radius-sm);padding:10px 14px;font-family:var(--font);font-size:.8rem;font-weight:700;cursor:pointer;width:100%;margin-top:2px;transition:filter .15s}.phase-ask-btn:active{filter:brightness(.9)}.tax-cta-card{margin:var(--sp-md) var(--sp-md) var(--sp-xs);background:linear-gradient(135deg,#0d2247,#1a4a8a);border-radius:var(--radius);padding:18px var(--sp-md);display:flex;align-items:flex-start;gap:13px;border:1px solid rgba(74,143,212,.3)}.tax-cta-icon{font-size:1.8rem;flex-shrink:0;margin-top:2px}.tax-cta-body{flex:1;min-width:0}.tax-cta-title{font-size:.88rem;font-weight:700;color:#fff;margin-bottom:4px;line-height:1.3}.tax-cta-sub{font-size:.75rem;color:#ffffffb3;margin-bottom:12px;line-height:1.4}.tax-cta-btn{display:inline-flex;align-items:center;background:#fff;color:var(--navy);border:none;border-radius:8px;padding:8px 14px;font-family:var(--font);font-size:.77rem;font-weight:800;cursor:pointer;transition:filter .15s;letter-spacing:.01em}.tax-cta-btn:active{filter:brightness(.92)}.reminder-card{margin:0 var(--sp-md) var(--sp-xs);background:var(--white);border-radius:var(--radius);border:1.5px solid var(--gray2);border-left:4px solid var(--gold);padding:12px var(--sp-md);display:flex;align-items:flex-start;gap:var(--sp-sm)}.reminder-icon{font-size:1.1rem;flex-shrink:0;margin-top:1px}.reminder-title{font-size:.82rem;font-weight:700;color:var(--text);margin-bottom:2px}.reminder-sub{font-size:.73rem;color:var(--text3);line-height:1.4}.ai-cat-bar{display:flex;gap:7px;padding:var(--sp-sm) var(--sp-md);overflow-x:auto;scrollbar-width:none;background:var(--white);border-bottom:1px solid var(--gray2);flex-shrink:0;-webkit-overflow-scrolling:touch}.ai-cat-bar::-webkit-scrollbar{display:none}.chat-window{flex:1;overflow-y:auto;overflow-x:hidden;padding:var(--sp-md);display:flex;flex-direction:column;gap:var(--sp-md);scrollbar-width:none;overscroll-behavior-y:contain}.chat-window::-webkit-scrollbar{display:none}.elisa-welcome{display:flex;flex-direction:column;align-items:center;gap:0;flex:1}.elisa-welcome-top{display:flex;flex-direction:column;align-items:center;text-align:center;padding:24px var(--sp-xl) 16px;gap:10px}.elisa-avatar-ring{position:relative;display:inline-block;margin-bottom:4px}.elisa-welcome-img{width:88px;height:88px;border-radius:50%;object-fit:cover;border:3px solid var(--blue-light);box-shadow:0 4px 20px #2563c038;display:block;position:relative;z-index:1}.elisa-avatar-pulse{position:absolute;inset:-6px;border-radius:50%;border:2.5px solid rgba(37,99,192,.25);animation:ringPulse 2.4s ease-in-out infinite;pointer-events:none}@keyframes ringPulse{0%,to{transform:scale(1);opacity:.5}50%{transform:scale(1.07);opacity:1}}.elisa-welcome-name{font-family:var(--font-display);font-size:1.2rem;font-weight:800;color:var(--text);margin:0}.elisa-welcome-sub{font-size:.82rem;color:var(--text3);line-height:1.5;max-width:250px;margin:0}.elisa-cta-group{display:flex;flex-direction:column;gap:10px;width:100%;max-width:290px;padding:0 0 16px}.elisa-cta-primary{display:flex;align-items:center;justify-content:center;gap:10px;background:linear-gradient(135deg,#2563c0,#1a4a9c);color:#fff;border:none;border-radius:16px;padding:15px 20px;font-family:var(--font);font-size:.95rem;font-weight:700;cursor:pointer;transition:transform .15s,box-shadow .15s;box-shadow:0 4px 16px #2563c059;letter-spacing:.01em;min-height:52px}.elisa-cta-primary:active,.elisa-cta-primary:hover{transform:scale(.98);box-shadow:0 2px 8px #2563c040}.elisa-cta-primary.listening{background:linear-gradient(135deg,#c0392b,#962020);box-shadow:0 4px 16px #c0392b66}.mic-icon{font-size:1.2rem;transition:transform .2s}.mic-icon.pulse{animation:micPulse .8s ease-in-out infinite}@keyframes micPulse{0%,to{transform:scale(1)}50%{transform:scale(1.3)}}.elisa-cta-secondary{display:flex;align-items:center;justify-content:center;gap:8px;background:var(--white);color:var(--blue-light);border:2px solid var(--blue-light);border-radius:14px;padding:12px 20px;font-family:var(--font);font-size:.88rem;font-weight:600;cursor:pointer;transition:background .15s;min-height:46px}.elisa-cta-secondary:active{background:var(--sky)}.elisa-cta-tertiary{display:flex;align-items:center;justify-content:center;gap:8px;background:var(--gray1);color:var(--text2);border:1.5px solid var(--gray2);border-radius:12px;padding:10px 20px;font-family:var(--font);font-size:.85rem;font-weight:600;cursor:pointer;transition:background .15s;min-height:42px}.elisa-cta-tertiary:active{background:var(--gray2)}.elisa-cta-note{font-size:.75rem;color:var(--text3);text-align:center;padding:8px}.guided-prompts{display:flex;flex-direction:column;gap:7px;width:100%;padding:0 0 8px}.guided-prompts--inline{flex-direction:column;padding:0 0 6px}.guided-chip{display:flex;align-items:center;gap:8px;background:var(--white);border:1.5px solid var(--gray2);border-radius:12px;padding:11px 14px;font-family:var(--font);font-size:.82rem;color:var(--text2);cursor:pointer;text-align:left;transition:border-color .15s,background .15s;line-height:1.4}.guided-chip:active{border-color:var(--blue-light);background:var(--sky);color:var(--blue-light)}.guided-chip-icon{flex-shrink:0;font-size:.85rem}.guided-chip--sm{font-size:.79rem;padding:9px 12px}.voice-listening-bar{display:flex;align-items:center;gap:10px;background:#fff0f0;border:1.5px solid #f8b0b0;border-radius:12px;padding:10px 14px;animation:msgIn .2s ease;flex-shrink:0}.voice-pulse-dot{width:10px;height:10px;border-radius:50%;background:#e03030;flex-shrink:0;animation:pulseDot .8s ease-in-out infinite}@keyframes pulseDot{0%,to{transform:scale(1);opacity:.9}50%{transform:scale(1.5);opacity:.5}}.voice-listening-text{flex:1;font-size:.83rem;color:#8a2020;font-style:italic;min-width:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.voice-stop-btn{background:none;border:none;font-size:.85rem;color:#8a2020;cursor:pointer;padding:2px 4px;flex-shrink:0}.msg-user{display:flex;justify-content:flex-end;animation:msgIn .22s ease}.msg-user-bubble{background:linear-gradient(135deg,#2563c0,#1a4a9c);color:#fff;padding:11px 15px;border-radius:18px 18px 4px;max-width:82%;font-size:.86rem;line-height:1.5;font-weight:500;word-break:break-word;box-shadow:0 2px 8px #2563c033}.msg-ai{display:flex;gap:var(--sp-xs);align-items:flex-start;animation:msgIn .22s ease}.ai-avatar{width:40px;height:40px;border-radius:50%;overflow:hidden;flex-shrink:0;margin-top:2px;border:2px solid var(--blue-light);box-shadow:0 2px 8px #2563c040;background:var(--sky)}.ai-avatar img{width:100%;height:100%;object-fit:cover;border-radius:50%}.msg-ai-bubble{background:var(--white);border:1.5px solid var(--gray2);padding:13px 15px;border-radius:4px 18px 18px;max-width:calc(100% - 52px);font-size:.84rem;line-height:1.6;box-shadow:var(--shadow-sm);word-break:break-word;overflow:hidden}@keyframes msgIn{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}.ai-actions{display:flex;gap:7px;margin-top:12px;flex-wrap:wrap}.ai-action-btn{display:inline-flex;align-items:center;gap:5px;padding:6px 12px;border-radius:8px;font-size:.73rem;font-weight:600;cursor:pointer;border:1.5px solid var(--gray2);background:var(--gray1);color:var(--text2);font-family:var(--font);transition:all .15s;min-height:32px}.ai-action-btn:active{border-color:var(--blue-light);color:var(--blue-light);background:var(--sky)}.ai-action-btn.saved{border-color:var(--green);color:var(--green);background:var(--green-light)}.ai-action-btn.speaking{border-color:#c0392b;color:#c0392b;background:#fff0f0}.typing-wrap{display:flex;gap:var(--sp-xs);align-items:flex-end;animation:msgIn .22s ease}.typing-bubble{background:var(--white);border:1.5px solid var(--gray2);padding:12px 16px;border-radius:4px 18px 18px;display:flex;gap:5px;align-items:center}.typing-bubble span{width:7px;height:7px;background:var(--gray3);border-radius:50%;animation:typeBounce 1.1s infinite}.typing-bubble span:nth-child(2){animation-delay:.18s}.typing-bubble span:nth-child(3){animation-delay:.36s}@keyframes typeBounce{0%,60%,to{transform:translateY(0)}30%{transform:translateY(-5px)}}.ai-input-bar{background:var(--white);border-top:1px solid var(--gray2);padding:10px var(--sp-md);display:flex;gap:8px;align-items:flex-end;flex-shrink:0}.ai-textarea-wrap{flex:1;min-width:0}.ai-textarea{width:100%;background:var(--gray1);border:1.5px solid var(--gray2);border-radius:13px;padding:10px 14px;font-family:var(--font);font-size:.86rem;color:var(--text);resize:none;outline:none;transition:border-color .18s,background .18s;line-height:1.5;min-height:42px;max-height:100px;display:block}.ai-textarea:focus{border-color:var(--blue-light);background:var(--white)}.ai-textarea::placeholder{color:var(--text3)}.mic-btn{width:44px;height:44px;border-radius:14px;border:1.5px solid var(--gray2);background:var(--gray1);color:var(--blue-light);cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:all .18s}.mic-btn:active,.mic-btn:hover{background:var(--sky);border-color:var(--blue-light)}.mic-btn--active{background:#fff0f0;border-color:#e03030;color:#e03030;animation:micRing 1s ease-in-out infinite}.mic-stop-icon{font-size:.85rem}@keyframes micRing{0%,to{box-shadow:0 0 #e030304d}50%{box-shadow:0 0 0 6px #e0303000}}.ai-send{width:44px;height:44px;background:var(--blue-light);border:none;border-radius:14px;cursor:pointer;display:flex;align-items:center;justify-content:center;color:#fff;flex-shrink:0;transition:filter .15s;min-width:44px}.ai-send:active{filter:brightness(.88)}.ai-send:disabled{opacity:.35;cursor:not-allowed}.learn-hero{background:linear-gradient(135deg,var(--navy-mid),var(--blue-light));padding:18px var(--sp-lg) 16px;position:relative;overflow:hidden;flex-shrink:0}.learn-hero:after{content:"📚";position:absolute;right:16px;bottom:-6px;font-size:3.5rem;opacity:.12;pointer-events:none}.learn-hero-title{font-family:var(--font-display);font-size:1.15rem;font-weight:800;color:#fff;margin-bottom:4px}.learn-hero-sub{font-size:.79rem;color:#ffffffb3}.learn-progress-row{display:flex;align-items:center;gap:var(--sp-sm);margin-top:12px}.learn-progress-text{font-size:.73rem;color:#fffc;font-weight:600;white-space:nowrap}.learn-progress-bar{flex:1;background:#fff3;border-radius:50px;height:5px;overflow:hidden;min-width:0}.learn-progress-fill{height:100%;background:#fff;border-radius:50px;width:30%}.topic-grid{padding:var(--sp-sm) var(--sp-md) var(--sp-xs);display:grid;grid-template-columns:repeat(2,1fr);gap:var(--sp-xs)}.topic-card{background:var(--white);border-radius:var(--radius);border:1.5px solid var(--gray2);padding:14px 12px;cursor:pointer;transition:transform .15s,box-shadow .15s,border-color .15s;position:relative;overflow:hidden;min-height:110px;display:flex;flex-direction:column}.topic-card:active{transform:scale(.98);box-shadow:var(--shadow);border-color:var(--blue-light)}.topic-card-icon{font-size:1.6rem;margin-bottom:7px;display:block;flex-shrink:0}.topic-card-title{font-size:.81rem;font-weight:700;color:var(--text);line-height:1.3;margin-bottom:4px;flex:1}.topic-card-time{font-size:.68rem;color:var(--text3)}.topic-card-bar{position:absolute;bottom:0;left:0;right:0;height:3px;background:var(--gray2)}.topic-card-bar-fill{height:100%;background:var(--blue-light);border-radius:0 2px 2px 0;transition:width .3s ease}.lesson-modal{display:none;position:absolute;inset:0;background:var(--off);z-index:100;flex-direction:column;animation:slideUp .28s cubic-bezier(.32,.72,0,1)}.lesson-modal.open{display:flex}@keyframes slideUp{0%{transform:translateY(100%)}to{transform:translateY(0)}}.modal-header{background:var(--white);border-bottom:1px solid var(--gray2);padding:13px var(--sp-lg);display:flex;align-items:center;gap:var(--sp-sm);flex-shrink:0;min-height:var(--top-h)}.modal-back{width:34px;height:34px;border-radius:9px;background:var(--gray1);border:1.5px solid var(--gray2);display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:.95rem;color:var(--text2);flex-shrink:0}.modal-back:active{background:var(--gray2)}.modal-title{font-family:var(--font-display);font-size:.92rem;font-weight:700;color:var(--text);flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.modal-body{flex:1;overflow-y:auto;overflow-x:hidden;padding:var(--sp-md);scrollbar-width:none}.modal-body::-webkit-scrollbar{display:none}.lesson-block{background:var(--white);border-radius:var(--radius);border:1.5px solid var(--gray2);padding:var(--sp-md);margin-bottom:var(--sp-xs)}.lesson-block-label{font-size:.67rem;font-weight:800;letter-spacing:.08em;text-transform:uppercase;margin-bottom:7px;display:flex;align-items:center;gap:5px}.lesson-block-text{font-size:.85rem;line-height:1.65;color:var(--text2)}.lesson-example{background:var(--sky);border-left:3px solid var(--blue-light);border-radius:0 var(--radius-sm) var(--radius-sm) 0;padding:11px 14px;margin-top:6px}.lesson-action{background:var(--green-light);border-left:3px solid var(--green);border-radius:0 var(--radius-sm) var(--radius-sm) 0;padding:11px 14px;margin-top:6px}.cl-screen-header{background:var(--white);padding:16px var(--sp-lg);border-bottom:1px solid var(--gray2);flex-shrink:0}.cl-screen-title{font-family:var(--font-display);font-size:1.05rem;font-weight:800;color:var(--navy)}.cl-screen-sub{font-size:.78rem;color:var(--text3);margin-top:2px}.checklist-list{padding:var(--sp-md);display:flex;flex-direction:column;gap:var(--sp-xs)}.checklist-card{background:var(--white);border-radius:var(--radius);border:1.5px solid var(--gray2);overflow:hidden}.cl-header{display:flex;align-items:center;gap:var(--sp-sm);padding:var(--sp-md);cursor:pointer;min-height:68px}.cl-header:active{background:var(--off)}.cl-icon-wrap{width:42px;height:42px;border-radius:11px;display:flex;align-items:center;justify-content:center;font-size:1.25rem;flex-shrink:0}.cl-info{flex:1;min-width:0}.cl-title{font-size:.86rem;font-weight:700;color:var(--text);margin-bottom:2px}.cl-meta{font-size:.71rem;color:var(--text3)}.cl-chevron{color:var(--text3);font-size:.85rem;flex-shrink:0;transition:transform .2s}.cl-chevron.open{transform:rotate(180deg)}.cl-progress{padding:0 var(--sp-md) 12px;display:flex;align-items:center;gap:var(--sp-xs)}.cl-prog-text{font-size:.69rem;font-weight:700;color:var(--blue);min-width:30px}.progress-bar-wrap{background:var(--gray2);border-radius:50px;height:4px;overflow:hidden}.progress-bar-fill{height:100%;background:var(--blue-light);border-radius:50px;transition:width .4s ease}.cl-items{padding:0 var(--sp-md) var(--sp-md);display:flex;flex-direction:column;gap:6px}.cl-item{display:flex;align-items:flex-start;gap:var(--sp-sm);padding:11px 13px;background:var(--off);border-radius:var(--radius-sm);cursor:pointer;transition:background .12s;min-height:44px}.cl-item.checked{background:var(--green-light)}.cl-item:active{opacity:.8}.cl-checkbox{width:20px;height:20px;border:2px solid var(--gray3);border-radius:6px;flex-shrink:0;display:flex;align-items:center;justify-content:center;font-size:.68rem;color:transparent;transition:background .15s,border-color .15s,color .15s;margin-top:1px}.cl-item.checked .cl-checkbox{background:var(--green);border-color:var(--green);color:#fff}.cl-item-text{font-size:.82rem;line-height:1.4;color:var(--text2);flex:1}.cl-item.checked .cl-item-text{color:var(--text3);text-decoration:line-through}.saved-header{background:var(--white);padding:15px var(--sp-lg);border-bottom:1px solid var(--gray2);flex-shrink:0}.saved-header-title{font-family:var(--font-display);font-size:1.05rem;font-weight:800;color:var(--navy)}.saved-tabs{display:flex;background:var(--white);border-bottom:1px solid var(--gray2);flex-shrink:0}.saved-tab{flex:1;text-align:center;padding:13px var(--sp-xs);font-size:.78rem;font-weight:600;color:var(--text3);cursor:pointer;border-bottom:2px solid transparent;transition:color .18s,border-color .18s;min-height:44px;display:flex;align-items:center;justify-content:center;-webkit-user-select:none;user-select:none}.saved-tab.active{color:var(--blue-light);border-bottom-color:var(--blue-light)}.saved-items{padding:var(--sp-md);display:flex;flex-direction:column;gap:var(--sp-xs)}.saved-empty{text-align:center;padding:48px var(--sp-xl);color:var(--text3)}.saved-empty-icon{font-size:2.4rem;margin-bottom:var(--sp-xs);display:block}.saved-empty-text{font-size:.83rem;line-height:1.55}.saved-card{background:var(--white);border-radius:var(--radius);border:1.5px solid var(--gray2);padding:13px var(--sp-md);display:flex;align-items:flex-start;gap:var(--sp-sm);min-height:56px}.saved-card-icon{width:36px;height:36px;border-radius:9px;display:flex;align-items:center;justify-content:center;font-size:1rem;flex-shrink:0;background:var(--sky)}.saved-card-info{flex:1;min-width:0}.saved-card-title{font-size:.83rem;font-weight:700;color:var(--text);margin-bottom:2px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.saved-card-meta{font-size:.71rem;color:var(--text3)}.saved-card-del{color:var(--text3);font-size:.85rem;cursor:pointer;padding:4px;flex-shrink:0;min-width:28px;min-height:28px;display:flex;align-items:center;justify-content:center}.profile-hero{background:linear-gradient(150deg,var(--navy),var(--blue-light));padding:24px var(--sp-lg) 20px;text-align:center;flex-shrink:0}.profile-avatar{width:64px;height:64px;background:#ffffff26;border:2px solid rgba(255,255,255,.3);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:1.8rem;margin:0 auto 10px}.profile-name{font-family:var(--font-display);font-size:1.05rem;font-weight:700;color:#fff;margin-bottom:3px}.profile-role{font-size:.76rem;color:#ffffff9e}.profile-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--gray2);margin:var(--sp-md) var(--sp-md) 0;border-radius:var(--radius);overflow:hidden}.profile-stat{background:var(--white);padding:12px var(--sp-xs);text-align:center}.profile-stat-num{font-family:var(--font-display);font-size:1.25rem;font-weight:800;color:var(--text)}.profile-stat-lbl{font-size:.66rem;color:var(--text3);margin-top:2px}.profile-section{padding:var(--sp-md) var(--sp-md) 0}.profile-group{border-radius:var(--radius);overflow:hidden;border:1.5px solid var(--gray2)}.profile-group-title{font-size:.68rem;font-weight:800;letter-spacing:.09em;text-transform:uppercase;color:var(--text3);margin-bottom:7px;padding:0 2px}.profile-row{display:flex;align-items:center;gap:var(--sp-sm);padding:13px var(--sp-md);background:var(--white);border-bottom:1px solid var(--gray1);cursor:pointer;transition:background .12s;min-height:50px}.profile-row:last-child{border-bottom:none}.profile-row:active{background:var(--off)}.profile-row-icon{font-size:1rem;width:22px;text-align:center;flex-shrink:0}.profile-row-label{flex:1;font-size:.84rem;font-weight:500;color:var(--text2)}.profile-row-value{font-size:.77rem;color:var(--text3)}.profile-row-arrow{font-size:.82rem;color:var(--text3);flex-shrink:0}.premium-banner{margin:var(--sp-md);background:linear-gradient(135deg,var(--gold),#e8b238);border-radius:var(--radius);padding:16px var(--sp-md);display:flex;align-items:center;gap:var(--sp-sm)}.premium-icon{font-size:1.7rem;flex-shrink:0}.premium-text{flex:1;min-width:0}.premium-title{font-size:.88rem;font-weight:800;color:#fff;margin-bottom:2px}.premium-sub{font-size:.72rem;color:#ffffffd1;line-height:1.35}.premium-btn{background:#fff;color:var(--gold);border:none;border-radius:8px;padding:8px 14px;font-family:var(--font);font-size:.76rem;font-weight:800;cursor:pointer;white-space:nowrap;flex-shrink:0;min-height:34px}.premium-btn:active{filter:brightness(.95)}
