:root{--primary:#7c3aed;--secondary:#a78bfa;--accent:#f4a535;--bg:#fff;--surface:#f5f0ff;--text:#1a1a2e;--muted:#6b7280;--dark:#1a1a2e;--border:#ede9fe;--blue-dark:var(--primary);--blue-mid:var(--secondary);--blue-light:var(--surface);--yellow:var(--accent);--yellow-dark:#d4891a;--white:#fff;--grey-100:#f9f8ff;--grey-200:var(--border);--grey-400:#c4b5fd;--grey-600:var(--muted);--grey-800:#374151;--font-heading:"Fredoka", sans-serif;--font-body:"DM Sans", sans-serif;--radius:12px;--radius-sm:6px;--radius-lg:20px;--shadow:0 1px 4px #7c3aed14;--shadow-md:0 4px 16px #7c3aed1f;--shadow-lg:0 8px 32px #7c3aed26;--transition:.18s ease;--max-width:1200px;--sidebar-width:240px;--nav-height:64px}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth;font-size:16px}body{font-family:var(--font-body);color:var(--text);background:var(--bg);-webkit-font-smoothing:antialiased;font-weight:400;line-height:1.6}h1,h2,h3,h4,h5,h6{font-family:var(--font-heading);color:var(--text);font-weight:700;line-height:1.2}a{color:inherit;text-decoration:none}img{max-width:100%;display:block}button{cursor:pointer;background:0 0;border:none;font-family:inherit}input,textarea,select{font-family:inherit}ul,ol{list-style:none}.btn{border-radius:var(--radius);font-family:var(--font-body);cursor:pointer;transition:opacity var(--transition), box-shadow var(--transition), transform var(--transition);white-space:nowrap;border:2px solid #0000;justify-content:center;align-items:center;gap:8px;padding:10px 22px;font-size:.95rem;font-weight:600;line-height:1;text-decoration:none;display:inline-flex}.btn:hover:not(:disabled){opacity:.9;transform:translateY(-1px)}.btn:active:not(:disabled){transform:translateY(0)}.btn:disabled{opacity:.45;cursor:not-allowed;pointer-events:none;transform:none}.btn--primary{background:var(--primary);color:#fff;border-color:var(--primary)}.btn--secondary{background:var(--secondary);color:#fff;border-color:var(--secondary)}.btn--accent,.btn--yellow{background:var(--accent);color:var(--text);border-color:var(--accent)}.btn--ghost{color:var(--primary);border-color:var(--primary);background:0 0}.btn--ghost:hover:not(:disabled){background:var(--surface)}.btn--surface{background:var(--surface);color:var(--primary);border-color:var(--border)}.btn--danger{color:#fff;background:#dc2626;border-color:#dc2626}.btn--text{color:var(--primary);background:0 0;border-color:#0000;padding-left:0;padding-right:0}.btn--sm{padding:6px 14px;font-size:.85rem}.btn--lg{padding:14px 32px;font-size:1rem}.btn--full{width:100%}.form-group{flex-direction:column;gap:6px;display:flex}.form-label{color:var(--text);align-items:center;gap:6px;font-size:.88rem;font-weight:600;display:flex}.form-input,.form-select,.form-textarea{border:1.5px solid var(--border);border-radius:var(--radius-sm);color:var(--text);background:var(--bg);transition:border-color var(--transition), box-shadow var(--transition);width:100%;padding:11px 14px;font-size:.95rem}.form-input:focus,.form-select:focus,.form-textarea:focus{border-color:var(--primary);outline:none;box-shadow:0 0 0 3px #7c3aed1f}.form-input::placeholder,.form-textarea::placeholder{color:var(--muted)}.form-input:disabled,.form-select:disabled{opacity:.6;background:var(--surface);cursor:not-allowed}.form-error{color:#dc2626;font-size:.83rem}.form-hint{color:var(--muted);font-size:.83rem;line-height:1.4}.form-checkbox{cursor:pointer;-webkit-user-select:none;user-select:none;align-items:flex-start;gap:10px;display:flex}.form-checkbox input[type=checkbox]{width:18px;height:18px;accent-color:var(--primary);cursor:pointer;flex-shrink:0;margin-top:2px}.form-checkbox span{color:var(--text);font-size:.9rem;line-height:1.5}.form-checkbox a{color:var(--primary);text-decoration:underline}.card{background:var(--bg);border:1.5px solid var(--border);border-radius:var(--radius);padding:24px}.card--surface{background:var(--surface);border-color:var(--border)}.badge{white-space:nowrap;border-radius:999px;align-items:center;padding:3px 10px;font-size:.78rem;font-weight:600;display:inline-flex}.badge--primary{background:var(--surface);color:var(--primary)}.badge--accent{color:#92400e;background:#fef3c7}.badge--success{color:#065f46;background:#d1fae5}.badge--danger{color:#991b1b;background:#fee2e2}.badge--muted{color:var(--muted);background:#f3f4f6}.divider{border:none;border-top:1.5px solid var(--border)}.section-inner{max-width:var(--max-width);margin:0 auto;padding:0 24px}.spinner{border:2.5px solid var(--border);border-top-color:var(--primary);border-radius:50%;flex-shrink:0;width:20px;height:20px;animation:.7s linear infinite spin;display:inline-block}@keyframes spin{to{transform:rotate(360deg)}}.alert{border-radius:var(--radius-sm);align-items:flex-start;gap:8px;padding:12px 16px;font-size:.9rem;display:flex}.alert--success{color:#065f46;background:#d1fae5;border:1px solid #6ee7b7}.alert--error{color:#991b1b;background:#fee2e2;border:1px solid #fca5a5}.alert--warning{color:#92400e;background:#fef3c7;border:1px solid #fcd34d}.alert--info{background:var(--surface);border:1px solid var(--border);color:var(--primary)}.skeleton{background:linear-gradient(90deg, var(--border) 25%, var(--surface) 50%, var(--border) 75%);border-radius:var(--radius-sm);background-size:200% 100%;animation:1.4s infinite shimmer}@keyframes shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:var(--surface)}::-webkit-scrollbar-thumb{background:var(--border);border-radius:999px}::-webkit-scrollbar-thumb:hover{background:var(--secondary)}.tooltip-wrap{align-items:center;display:inline-flex;position:relative}.tooltip-content{background:var(--dark);color:#fff;border-radius:var(--radius-sm);white-space:normal;text-align:center;pointer-events:none;opacity:0;max-width:220px;transition:opacity var(--transition);z-index:1000;padding:6px 10px;font-size:.8rem;line-height:1.4;position:absolute;bottom:calc(100% + 8px);left:50%;transform:translate(-50%)}.tooltip-wrap:hover .tooltip-content{opacity:1}@media (width<=768px){.hide-mobile{display:none!important}}@media (width>=769px){.hide-desktop{display:none!important}}.navbar{background:var(--primary);height:var(--nav-height);z-index:200;position:sticky;top:0;box-shadow:0 1px #ffffff0f}.navbar__inner{max-width:var(--max-width);align-items:center;gap:24px;height:100%;margin:0 auto;padding:0 24px;display:flex}.navbar__logo{font-family:var(--font-heading);color:#fff;letter-spacing:.5px;flex-shrink:0;font-size:1.5rem}.navbar__links{flex:1;align-items:center;gap:4px;display:flex}.nav-link{border-radius:var(--radius-sm);color:#fffc;transition:background var(--transition), color var(--transition);padding:6px 14px;font-size:.9rem;font-weight:500}.nav-link:hover{color:#fff;background:#ffffff1a}.nav-link.active{color:#fff;background:#ffffff2e;font-weight:600}.navbar__actions{align-items:center;gap:8px;margin-left:auto;display:flex}.navbar__actions .btn--ghost{color:#ffffffd9;border-color:#ffffff59}.navbar__actions .btn--ghost:hover:not(:disabled){color:#fff;background:#ffffff1f}@media (width<=480px){.navbar__links{display:none}.navbar__inner{gap:12px}}.footer{background:var(--dark);color:#ffffffb3;padding:48px 24px 32px}.footer__inner{max-width:var(--max-width);flex-direction:column;gap:32px;margin:0 auto;display:flex}.footer__top{flex-wrap:wrap;gap:48px;display:flex}.footer__brand{flex:1;min-width:200px}.footer__logo{font-family:var(--font-heading);color:#fff;margin-bottom:10px;font-size:1.4rem;display:block}.footer__tagline{color:#ffffff80;max-width:240px;font-size:.85rem;line-height:1.6}.footer__links{flex-wrap:wrap;gap:48px;display:flex}.footer__col{flex-direction:column;gap:10px;min-width:120px;display:flex}.footer__col-title{text-transform:uppercase;letter-spacing:.5px;color:#ffffff80;margin-bottom:2px;font-size:.78rem;font-weight:700}.footer__col a{color:#ffffffa6;transition:color var(--transition);font-size:.88rem}.footer__col a:hover{color:#fff}.footer__bottom{border-top:1px solid #ffffff14;flex-wrap:wrap;justify-content:space-between;align-items:center;gap:16px;padding-top:24px;display:flex}.footer__copy{color:#fff6;font-size:.8rem}@media (width<=600px){.footer__top{flex-direction:column;gap:32px}.footer__links{gap:24px}}.site-wrapper{flex-direction:column;min-height:100vh;display:flex}.site-main{flex:1}.container{width:100%;max-width:var(--max-width);margin:0 auto;padding:0 24px}.app-shell{background:var(--surface);min-height:100vh;display:flex}.app-sidebar{width:var(--sidebar-width);background:var(--primary);z-index:100;flex-direction:column;flex-shrink:0;height:100vh;transition:width .22s;display:flex;position:fixed;top:0;left:0;overflow:hidden}.app-sidebar--collapsed{width:64px}.app-sidebar__top{height:var(--nav-height);border-bottom:1px solid #ffffff1a;flex-shrink:0;justify-content:space-between;align-items:center;gap:8px;padding:0 16px;display:flex}.app-sidebar--collapsed .app-sidebar__top{justify-content:center;padding:0}.app-sidebar__logo{font-family:var(--font-heading);color:#fff;letter-spacing:.5px;white-space:nowrap;font-size:1.5rem}.app-sidebar__hamburger{color:#fffc;cursor:pointer;border-radius:var(--radius-sm);transition:background var(--transition), color var(--transition);background:0 0;border:none;flex-shrink:0;padding:6px 9px;font-size:1.15rem;line-height:1}.app-sidebar__hamburger:hover{color:#fff;background:#ffffff1f}.app-nav{flex-direction:column;flex:1;gap:4px;padding:16px 12px;display:flex;overflow:hidden auto}.app-sidebar--collapsed .app-nav{align-items:center;padding:16px 8px}.app-nav__item{border-radius:var(--radius-sm);color:#ffffffbf;transition:background var(--transition), color var(--transition);white-space:nowrap;align-items:center;gap:12px;width:100%;padding:10px 12px;font-size:.92rem;font-weight:500;text-decoration:none;display:flex}.app-nav__item:hover{color:#fff;background:#ffffff1a}.app-nav__item--active{color:#fff;background:#ffffff2e;font-weight:600}.app-sidebar--collapsed .app-nav__item{justify-content:center;gap:0;width:44px;padding:10px}.app-nav__icon{flex-shrink:0;font-size:1.1rem;line-height:1}.app-sidebar__bottom{border-top:1px solid #ffffff1a;flex-direction:column;flex-shrink:0;gap:12px;padding:16px 12px;display:flex;overflow:hidden}.app-sidebar--collapsed .app-sidebar__bottom{align-items:center;padding:16px 8px}.app-sidebar__user{align-items:center;gap:10px;min-width:0;display:flex}.app-sidebar--collapsed .app-sidebar__user{justify-content:center}.app-sidebar__avatar{color:#fff;background:#fff3;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;font-size:.82rem;font-weight:700;display:flex}.app-sidebar__user-info{flex-direction:column;min-width:0;display:flex;overflow:hidden}.app-sidebar__user-name{color:#fff;white-space:nowrap;text-overflow:ellipsis;font-size:.88rem;font-weight:600;overflow:hidden}.app-sidebar__user-role{color:#fff9;font-size:.78rem}.app-sidebar__signout{color:#ffffffb3!important;border-color:#ffffff40!important}.app-sidebar__signout:hover:not(:disabled){color:#fff!important;background:#ffffff1a!important}.app-content{margin-left:var(--sidebar-width);flex-direction:column;flex:1;min-width:0;min-height:100vh;transition:margin-left .22s;display:flex}.app-shell--collapsed .app-content{margin-left:64px}.app-topbar{height:var(--nav-height);background:var(--primary);z-index:50;align-items:center;gap:8px;padding:0 16px;display:none;position:sticky;top:0}.app-topbar__hamburger{color:#ffffffe6;cursor:pointer;border-radius:var(--radius-sm);transition:background var(--transition);background:0 0;border:none;flex-shrink:0;padding:6px 8px;font-size:1.2rem;line-height:1}.app-topbar__hamburger:hover{background:#ffffff1f}.app-topbar__logo{font-family:var(--font-heading);color:#fff;text-align:center;flex:1;font-size:1.4rem}.app-topbar__spacer{flex-shrink:0;width:40px}.app-main{flex:1;width:100%;max-width:1100px;padding:32px}.app-overlay{z-index:99;background:#00000073;animation:.18s fadeIn;position:fixed;inset:0}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.app-shell--tutor .app-content{height:100vh;overflow:hidden}.app-shell--tutor .app-main{flex-direction:column;flex:1;max-width:none;min-height:0;padding:0;display:flex;overflow:hidden}@media (width<=768px){.app-sidebar{transition:transform .25s;transform:translate(-100%);width:var(--sidebar-width)!important}.app-sidebar--collapsed{width:var(--sidebar-width)!important}.app-sidebar--mobile-open{transform:translate(0)}.app-content,.app-shell--collapsed .app-content{margin-left:0;transition:none}.app-topbar{display:flex}.app-main{padding:20px 16px}.app-sidebar--collapsed .app-nav__item{justify-content:flex-start;gap:12px;width:100%;padding:10px 12px}.app-sidebar--collapsed .app-nav{align-items:stretch;padding:16px 12px}.app-sidebar--collapsed .app-sidebar__top{justify-content:space-between;padding:0 16px}.app-sidebar--collapsed .app-sidebar__bottom{align-items:stretch;padding:16px 12px}.app-sidebar--collapsed .app-sidebar__user{justify-content:flex-start}}.hero{max-width:var(--max-width);align-items:center;gap:48px;margin:0 auto;padding:80px 24px 0;display:flex}.hero__inner{flex:1;max-width:540px}.hero__badge{background:var(--surface);border:1.5px solid var(--border);color:var(--primary);border-radius:999px;align-items:center;gap:6px;margin-bottom:24px;padding:6px 14px;font-size:.82rem;font-weight:600;display:inline-flex}.hero__headline{color:var(--text);margin-bottom:20px;font-size:clamp(2rem,5vw,3rem);line-height:1.15}.hero__headline .highlight{color:var(--primary)}.hero__sub{color:var(--muted);margin-bottom:36px;font-size:1.05rem;line-height:1.7}.hero__cta{flex-wrap:wrap;gap:12px;display:flex}.hero__visual{flex:1;max-width:420px}.chat-preview{background:var(--bg);border:1.5px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-lg);flex-direction:column;gap:12px;padding:20px;display:flex}.chat-preview__msg{border-radius:14px;max-width:88%;padding:10px 14px;font-size:.9rem;line-height:1.5}.chat-preview__msg--user{background:var(--primary);color:#fff;border-bottom-right-radius:3px;align-self:flex-end}.chat-preview__msg--tutor{background:var(--surface);color:var(--text);border-bottom-left-radius:3px;align-self:flex-start}.tutor-label{color:var(--primary);margin-bottom:4px;font-size:.72rem;font-weight:700;display:block}.features{background:var(--surface);padding:80px 0}.features .section-inner{flex-direction:column;gap:48px;display:flex}.section-header{text-align:center}.section-header h2{color:var(--text);margin-bottom:10px;font-size:clamp(1.5rem,3vw,2rem)}.section-header p{color:var(--muted);font-size:1rem}.features__grid{grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:20px;display:grid}.feature-card{background:var(--bg);border:1.5px solid var(--border);border-radius:var(--radius);padding:28px 24px}.feature-card__icon{margin-bottom:12px;font-size:2rem}.feature-card h3{color:var(--text);margin-bottom:8px;font-size:1rem}.feature-card p{color:var(--muted);font-size:.88rem;line-height:1.6}.pricing{background:var(--bg);padding:80px 0}.pricing .section-inner{flex-direction:column;gap:48px;display:flex}.pricing__grid{flex-wrap:wrap;justify-content:center;gap:20px;display:flex}.pricing-card{background:var(--bg);border:2px solid var(--border);border-radius:var(--radius);flex-direction:column;flex:1;gap:20px;max-width:320px;padding:32px 28px;display:flex;position:relative}.pricing-card--featured{border-color:var(--primary);box-shadow:var(--shadow-md)}.pricing-card__badge{background:var(--accent);color:var(--text);border-radius:999px;padding:4px 16px;font-size:.76rem;font-weight:700;position:absolute;top:-14px;left:50%;transform:translate(-50%)}.pricing-card__header h3{color:var(--text);margin-bottom:8px;font-size:1.1rem}.pricing-card__price{align-items:baseline;gap:4px;display:flex}.price-amount{color:var(--primary);font-size:2.2rem;font-weight:800;font-family:var(--font-heading)}.price-period{color:var(--muted);font-size:.88rem}.pricing-card__features{flex-direction:column;flex:1;gap:8px;display:flex}.pricing-card__features li{color:var(--text);font-size:.88rem}.pricing-card__cta{text-align:center;justify-content:center}.pricing__all-plans{text-align:center;color:var(--muted);margin-top:8px;font-size:.88rem}.pricing__all-plans a{color:var(--primary);font-weight:500}.pricing__all-plans a:hover{text-decoration:underline}.cta-banner{background:var(--primary);text-align:center;padding:80px 0}.cta-banner .section-inner{flex-direction:column;align-items:center;gap:16px;display:flex}.cta-banner h2{color:#fff;font-size:clamp(1.4rem,3vw,1.8rem)}.cta-banner p{color:#fffc;font-size:1rem}@media (width<=768px){.hero{flex-direction:column;padding-top:48px}.hero__visual{max-width:100%}.hero__cta .btn{flex:1}}.auth-page{min-height:calc(100vh - var(--nav-height));background:var(--surface);justify-content:center;align-items:center;padding:48px 24px;display:flex}.auth-card{background:var(--bg);border:1.5px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-md);flex-direction:column;gap:0;width:100%;max-width:460px;padding:48px 40px;display:flex}.auth-logo{font-family:var(--font-heading);color:var(--primary);margin-bottom:28px;font-size:1.6rem;display:inline-block}.auth-card h1{color:var(--text);margin-bottom:6px;font-size:1.65rem}.auth-sub{color:var(--muted);margin-bottom:28px;font-size:.95rem}.auth-form{flex-direction:column;gap:18px;margin-bottom:20px;display:flex}.btn-google{border:1.5px solid var(--border);border-radius:var(--radius-sm);width:100%;font-family:var(--font-body);color:var(--text);cursor:pointer;background:#fff;justify-content:center;align-items:center;gap:10px;margin-bottom:4px;padding:11px 16px;font-size:.95rem;font-weight:500;transition:background .15s,border-color .15s,box-shadow .15s;display:flex}.btn-google:hover:not(:disabled){background:var(--surface);border-color:#c8c8d0;box-shadow:0 1px 4px #3c3c5014}.btn-google:disabled{opacity:.6;cursor:not-allowed}.auth-divider{color:var(--muted);align-items:center;gap:12px;margin:8px 0;font-size:.85rem;display:flex}.auth-divider:before,.auth-divider:after{content:"";background:var(--border);flex:1;height:1px}.auth-label-row{justify-content:space-between;align-items:center;display:flex}.auth-forgot{color:var(--primary);font-size:.83rem;font-weight:500}.auth-forgot:hover{text-decoration:underline}.auth-checkboxes{background:var(--surface);border-radius:var(--radius-sm);border:1.5px solid var(--border);flex-direction:column;gap:12px;margin-bottom:4px;padding:16px;display:flex}.auth-optional{flex-wrap:wrap;align-items:center;gap:8px;display:flex}.auth-optional-tag{background:var(--border);color:var(--muted);border-radius:999px;padding:1px 7px;font-size:.72rem;font-weight:600}.auth-switch{text-align:center;color:var(--muted);margin-top:8px;font-size:.9rem}.auth-switch a{color:var(--primary);font-weight:500}.auth-switch a:hover{text-decoration:underline}.auth-success{text-align:center;flex-direction:column;align-items:center;gap:12px;padding:24px 0;display:flex}.auth-success-icon{font-size:3rem}.auth-success h2{color:var(--primary);font-size:1.3rem}.auth-success p{color:var(--muted);max-width:320px;font-size:.95rem;line-height:1.5}@media (width<=480px){.auth-card{padding:32px 20px}}.ob-page{background:var(--surface);justify-content:center;align-items:center;min-height:100vh;padding:32px 16px;display:flex}.ob-card{background:var(--bg);border:1.5px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-md);flex-direction:column;gap:24px;width:100%;max-width:560px;padding:40px;display:flex}.ob-header{flex-direction:column;align-items:center;gap:16px;display:flex}.ob-logo{font-family:var(--font-heading);color:var(--primary);align-self:flex-start;font-size:1.5rem}.ob-step-count{color:var(--muted);font-size:.82rem}.ob-progress{align-items:center;gap:8px;display:flex}.ob-progress__dot{background:var(--border);width:10px;height:10px;transition:background var(--transition), transform var(--transition);border-radius:50%}.ob-progress__dot--done{background:var(--secondary)}.ob-progress__dot--active{background:var(--primary);transform:scale(1.25)}.ob-step{flex-direction:column;gap:20px;display:flex}.ob-step--center{text-align:center;align-items:center}.ob-step h1,.ob-step h2{color:var(--text);font-size:1.5rem}.ob-desc{color:var(--muted);font-size:.95rem;line-height:1.6}.ob-icon{font-size:3.5rem;line-height:1}.ob-note{font-size:.88rem}.ob-optional-label{font-size:.72rem;font-family:var(--font-body);background:var(--border);color:var(--muted);vertical-align:middle;border-radius:999px;margin-left:8px;padding:2px 8px;font-weight:600}.ob-form{flex-direction:column;gap:16px;display:flex}.ob-tooltip-icon{background:var(--border);width:16px;height:16px;color:var(--muted);cursor:help;font-size:.7rem;font-weight:700;font-family:var(--font-body);border-radius:50%;justify-content:center;align-items:center;display:inline-flex}.ob-actions{justify-content:space-between;align-items:center;gap:12px;margin-top:4px;display:flex}.ob-actions-right{gap:10px;display:flex}.ob-login-options{flex-direction:column;gap:12px;display:flex}.ob-login-option{border:1.5px solid var(--border);border-radius:var(--radius);cursor:pointer;transition:border-color var(--transition), background var(--transition);align-items:flex-start;gap:14px;padding:16px;display:flex}.ob-login-option input[type=radio]{display:none}.ob-login-option:hover{border-color:var(--secondary);background:var(--surface)}.ob-login-option--selected{border-color:var(--primary);background:var(--surface)}.ob-login-option__icon{flex-shrink:0;font-size:1.6rem}.ob-login-option__title{color:var(--text);margin-bottom:4px;font-size:.95rem;font-weight:600}.ob-login-option__desc{color:var(--muted);font-size:.85rem;line-height:1.5}.ob-pin-input{letter-spacing:.5em;text-align:center;max-width:160px;font-size:1.2rem}.ob-pin-strength{display:block}.ob-pin-strength--strong{color:#065f46}.ob-pin-strength--weak{color:#92400e}.ob-pin-match{color:#065f46}@media (width<=480px){.ob-card{padding:28px 20px}.ob-actions{flex-wrap:wrap}}.sp-page{background:var(--surface);justify-content:center;align-items:center;min-height:100vh;padding:32px 16px;display:flex;position:relative}.sp-inner{flex-direction:column;align-items:center;gap:32px;width:100%;max-width:600px;display:flex}.sp-header{text-align:center}.sp-logo{font-family:var(--font-heading);color:var(--primary);margin-bottom:8px;font-size:2rem;display:block}.sp-header p{color:var(--muted);font-size:1.1rem}.sp-grid{flex-wrap:wrap;justify-content:center;gap:20px;display:flex}.sp-card{background:var(--bg);border:2px solid var(--border);border-radius:var(--radius);cursor:pointer;min-width:140px;transition:border-color var(--transition), box-shadow var(--transition), transform var(--transition);text-align:center;flex-direction:column;align-items:center;gap:10px;padding:28px 20px;font-family:inherit;display:flex}.sp-card:hover{border-color:var(--primary);box-shadow:var(--shadow-md);transform:translateY(-2px)}.sp-card--skeleton{pointer-events:none}.sp-card__avatar{background:var(--surface);border:3px solid var(--border);border-radius:50%;justify-content:center;align-items:center;width:80px;height:80px;font-size:2rem;display:flex}.sp-card__name{color:var(--text);font-size:1rem;font-weight:700}.sp-card__year{color:var(--muted);font-size:.82rem}.sp-card__pin-badge{background:var(--surface);color:var(--primary);border:1px solid var(--border);border-radius:999px;padding:2px 8px;font-size:.75rem}.sp-empty{text-align:center;flex-direction:column;align-items:center;gap:12px;display:flex}.sp-empty p{color:var(--muted);font-size:.95rem}.sp-parent-btn{color:var(--muted);border-color:#0000;font-size:.85rem}.sp-parent-btn:hover:not(:disabled){background:var(--border);color:var(--primary)}.pin-overlay{z-index:500;background:#1a1a2e99;justify-content:center;align-items:center;padding:16px;display:flex;position:fixed;inset:0}.pin-card{background:var(--bg);border-radius:var(--radius);text-align:center;flex-direction:column;align-items:center;gap:14px;width:100%;max-width:320px;padding:40px 32px;display:flex}.pin-card__avatar{background:var(--surface);border:2px solid var(--border);border-radius:50%;justify-content:center;align-items:center;width:64px;height:64px;font-size:1.8rem;display:flex}.pin-card h2{font-size:1.2rem}.pin-card p{color:var(--muted);font-size:.9rem}.pin-card__form{flex-direction:column;gap:10px;width:100%;display:flex}.pin-card__input{text-align:center;letter-spacing:.6em;font-size:1.3rem}.pricing-page{background:var(--surface);min-height:calc(100vh - var(--nav-height));padding:72px 24px 96px}.pricing-page__inner{flex-direction:column;gap:64px;max-width:960px;margin:0 auto;display:flex}.pricing-page__header{text-align:center;flex-direction:column;align-items:center;gap:16px;display:flex}.pricing-page__header h1{color:var(--text);font-size:clamp(1.8rem,4vw,2.4rem)}.pricing-page__header p{color:var(--muted);font-size:1.05rem}.billing-toggle{background:var(--border);border-radius:var(--radius);gap:4px;padding:4px;display:inline-flex}.billing-toggle__btn{border-radius:calc(var(--radius) - 2px);color:var(--muted);cursor:pointer;transition:background var(--transition), color var(--transition);background:0 0;border:none;align-items:center;gap:8px;padding:8px 20px;font-size:.9rem;font-weight:500;display:flex}.billing-toggle__btn--active{background:var(--bg);color:var(--text);box-shadow:var(--shadow);font-weight:600}.billing-toggle__save{color:#065f46;background:#d1fae5;border-radius:999px;padding:2px 6px;font-size:.72rem;font-weight:600}.pricing-page__grid{grid-template-columns:repeat(auto-fit,minmax(260px,1fr));align-items:start;gap:20px;display:grid}.pc{background:var(--bg);border:2px solid var(--border);border-radius:var(--radius);transition:box-shadow var(--transition);flex-direction:column;gap:20px;padding:32px 28px;display:flex;position:relative}.pc:hover{box-shadow:var(--shadow-md)}.pc--featured{border-color:var(--primary);box-shadow:var(--shadow-md)}.pc__badge{background:var(--accent);color:var(--text);white-space:nowrap;border-radius:999px;padding:4px 16px;font-size:.76rem;font-weight:700;position:absolute;top:-14px;left:50%;transform:translate(-50%)}.pc__header h2{color:var(--text);margin-bottom:8px;font-size:1.2rem}.pc__price{align-items:baseline;gap:4px;display:flex}.pc__amount{color:var(--primary);font-size:2.4rem;font-weight:800;line-height:1;font-family:var(--font-heading)}.pc__period{color:var(--muted);font-size:.88rem}.pc__annual-note{color:var(--muted);font-size:.8rem}.pc__features{flex-direction:column;flex:1;gap:10px;list-style:none;display:flex}.pc__features li{color:var(--text);align-items:flex-start;gap:8px;font-size:.9rem;line-height:1.4;display:flex}.pc__check{color:var(--primary);flex-shrink:0;font-weight:700}.pc__check--no,.pc__feature--no{color:var(--muted)}.pc__footer{flex-direction:column;align-items:stretch;gap:10px;display:flex}.pc__cta{text-align:center;justify-content:center;width:100%}.pc__footnote{color:var(--muted);text-align:center;font-size:.78rem}.pricing-page__faq h3{color:var(--text);text-align:center;margin-bottom:24px;font-size:1.3rem}.faq-grid{grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:16px;display:grid}.faq-item{background:var(--bg);border:1.5px solid var(--border);border-radius:var(--radius);padding:20px}.faq-item h4{color:var(--text);margin-bottom:8px;font-size:.92rem;font-weight:700}.faq-item p{color:var(--muted);font-size:.86rem;line-height:1.6}@media (width<=480px){.pricing-page{padding:48px 16px 72px}.pc{padding:24px 20px}}.notfound{min-height:calc(100vh - var(--nav-height));background:var(--surface);text-align:center;justify-content:center;align-items:center;padding:48px 24px;display:flex}.notfound__inner{flex-direction:column;align-items:center;gap:16px;max-width:400px;display:flex}.notfound__code{font-family:var(--font-heading);color:var(--primary);opacity:.15;font-size:6rem;line-height:1}.notfound h1{color:var(--text);font-size:1.6rem}.notfound p{color:var(--muted);font-size:.95rem;line-height:1.6}.notfound__actions{flex-wrap:wrap;justify-content:center;gap:12px;margin-top:8px;display:flex}.dashboard{flex-direction:column;gap:32px;display:flex}.dashboard__header{flex-wrap:wrap;justify-content:space-between;align-items:flex-start;gap:16px;display:flex}.dashboard__header h1{color:var(--text);margin-bottom:4px;font-size:1.8rem}.dashboard__sub{color:var(--muted);font-size:.95rem}.dashboard__header-actions{flex-shrink:0;align-items:center;gap:10px;display:flex}.dashboard__upgrade-banner{margin-bottom:4px}.dashboard__section{flex-direction:column;gap:16px;display:flex}.dashboard__section-header{justify-content:space-between;align-items:center;gap:12px;display:flex}.dashboard__section-header h2{color:var(--text);font-size:1.15rem}.children-list{flex-direction:column;gap:10px;display:flex}.child-card{background:var(--bg);border:1.5px solid var(--border);border-radius:var(--radius);transition:border-color var(--transition), box-shadow var(--transition);align-items:center;gap:16px;padding:16px 20px;text-decoration:none;display:flex}.child-card:hover{border-color:var(--secondary);box-shadow:var(--shadow)}.child-card--skeleton{pointer-events:none}.child-card__avatar{background:var(--surface);border:2px solid var(--border);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:48px;height:48px;font-size:1.3rem;display:flex}.child-card__info{flex:1;min-width:0}.child-card__name{color:var(--text);font-size:1rem;font-weight:600}.child-card__year{color:var(--muted);margin-top:2px;font-size:.85rem}.child-card__stats{flex-shrink:0;gap:20px;display:flex}.child-card__stat{flex-direction:column;align-items:center;gap:2px;display:flex}.child-card__stat-val{color:var(--primary);font-size:1rem;font-weight:700}.child-card__stat-label{color:var(--muted);text-transform:uppercase;letter-spacing:.4px;font-size:.72rem}.child-card__arrow{color:var(--muted);flex-shrink:0;font-size:1rem}.empty-state{text-align:center;background:var(--bg);border:1.5px dashed var(--border);border-radius:var(--radius);flex-direction:column;align-items:center;gap:12px;padding:48px 24px;display:flex}.empty-state__icon{font-size:3rem}.empty-state h3{color:var(--text);font-size:1.1rem}.empty-state p{color:var(--muted);max-width:280px;font-size:.9rem}.ob-checklist{flex-direction:column;gap:12px;display:flex}.ob-checklist h3{color:var(--text);font-size:1rem}.ob-checklist__items{flex-direction:column;gap:8px;display:flex}.ob-checklist__item{color:var(--muted);align-items:center;gap:10px;font-size:.9rem;display:flex}.ob-checklist__item--done{color:var(--text)}.ob-checklist__icon{background:var(--border);width:20px;height:20px;color:var(--muted);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:.7rem;font-weight:700;display:flex}.ob-checklist__item--done .ob-checklist__icon{color:#065f46;background:#d1fae5}.referral-section{flex-direction:column;gap:12px;display:flex}.referral-section h3{color:var(--text);font-size:1rem}.referral-section__desc{color:var(--muted);font-size:.88rem}.referral-section__link-row{gap:8px;display:flex}.referral-section__input{color:var(--muted);font-size:.82rem}.referral-section__share{flex-wrap:wrap;gap:8px;display:flex}.child-entry{flex-direction:column;display:flex}.dash-progress{border-bottom:1px solid var(--border);scrollbar-width:none;gap:8px;padding:12px 14px 14px 64px;display:flex;overflow-x:auto}.dash-progress::-webkit-scrollbar{display:none}.dash-subject-card{text-align:center;border:1.5px solid #0000;border-radius:12px;flex-direction:column;flex-shrink:0;align-items:center;gap:5px;min-width:86px;padding:10px 14px 12px;display:flex}.dash-subject-card--high{background:#f0fdf4;border-color:#86efac}.dash-subject-card--medium{background:#fffbeb;border-color:#fcd34d}.dash-subject-card--low{background:#f5f0ff;border-color:#ddd6fe}.dash-subject-card__icon{font-size:1.5rem;line-height:1}.dash-subject-card__name{color:var(--text);white-space:nowrap;text-overflow:ellipsis;max-width:80px;font-size:.72rem;font-weight:600;overflow:hidden}.dash-subject-card__bar-track{background:#00000014;border-radius:3px;width:100%;height:5px;overflow:hidden}.dash-subject-card__bar-fill{border-radius:3px;height:100%}.dash-subject-card__bar-fill--high{background:#059669;width:100%}.dash-subject-card__bar-fill--medium{background:#d97706;width:66%}.dash-subject-card__bar-fill--low{background:#9ca3af;width:33%}.dash-subject-card__label{text-transform:uppercase;letter-spacing:.5px;font-size:.67rem;font-weight:700}.dash-subject-card__label--high{color:#059669}.dash-subject-card__label--medium{color:#d97706}.dash-subject-card__label--low{color:#9ca3af}.child-sessions{flex-direction:column;gap:4px;padding:6px 0 4px 56px;display:flex}.session-chip{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm);cursor:pointer;text-align:left;color:var(--text);transition:border-color var(--transition), box-shadow var(--transition);align-items:center;gap:10px;width:100%;padding:8px 14px;font-family:inherit;font-size:.84rem;display:flex}.session-chip:hover{border-color:var(--secondary);box-shadow:var(--shadow)}.session-chip__icon{flex-shrink:0;font-size:1rem}.session-chip__info{flex:1;min-width:0}.session-chip__subject{color:var(--text);white-space:nowrap;text-overflow:ellipsis;font-size:.84rem;font-weight:600;overflow:hidden}.session-chip__date{color:var(--muted);margin-top:1px;font-size:.76rem}.session-chip__badge{flex-shrink:0}.conv-modal-overlay{z-index:200;background:#1a1a2e80;justify-content:center;align-items:center;padding:20px;display:flex;position:fixed;inset:0}.conv-modal{background:var(--bg);border-radius:var(--radius);flex-direction:column;width:100%;max-width:620px;max-height:82vh;display:flex;box-shadow:0 16px 48px #0000002e}.conv-modal__header{border-bottom:1.5px solid var(--border);flex-shrink:0;justify-content:space-between;align-items:center;gap:12px;padding:16px 20px;display:flex}.conv-modal__header-info{align-items:center;gap:4px;min-width:0;display:flex}.conv-modal__header h3{color:var(--text);white-space:nowrap;margin:0;font-size:1rem}.conv-modal__close{cursor:pointer;color:var(--muted);border-radius:var(--radius-sm);transition:color var(--transition), background var(--transition);background:0 0;border:none;flex-shrink:0;padding:4px 6px;font-size:1rem;line-height:1}.conv-modal__close:hover{color:var(--text);background:var(--surface)}.conv-modal__meta{color:var(--muted);border-bottom:1px solid var(--border);flex-shrink:0;padding:8px 20px;font-size:.8rem}.conv-modal__body{flex-direction:column;flex:1;gap:14px;padding:16px 20px;display:flex;overflow-y:auto}.conv-modal__msg{align-items:flex-start;gap:10px;display:flex}.conv-modal__msg--user{flex-direction:row-reverse}.conv-modal__avatar{background:var(--primary);color:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:28px;height:28px;font-size:.75rem;font-weight:700;display:flex}.conv-modal__msg--user .conv-modal__avatar{background:var(--surface);border:1.5px solid var(--border);color:var(--muted);font-size:.85rem}.conv-modal__bubble{border-radius:16px;max-width:75%;padding:10px 14px;font-size:.88rem;line-height:1.65}.conv-modal__msg--assistant .conv-modal__bubble{background:var(--surface);color:var(--text);border-bottom-left-radius:4px}.conv-modal__msg--user .conv-modal__bubble{background:var(--primary);color:#fff;border-bottom-right-radius:4px}@media (width<=600px){.dashboard__header{flex-direction:column}.child-card__stats{display:none}.child-sessions{padding-left:16px}.conv-modal{max-height:90vh}.conv-modal__bubble{max-width:85%}}.cp-page{flex-direction:column;gap:24px;display:flex}.cp-loading{flex-direction:column;display:flex}.cp-breadcrumb{color:var(--muted);font-size:.85rem}.cp-breadcrumb a{color:var(--primary)}.cp-breadcrumb a:hover{text-decoration:underline}.cp-header{align-items:center;gap:16px;display:flex}.cp-header__avatar{background:var(--surface);border:2px solid var(--border);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:56px;height:56px;font-size:1.5rem;display:flex}.cp-header h1{color:var(--text);margin-bottom:6px;font-size:1.4rem}.cp-sections{flex-direction:column;gap:20px;display:flex}.cp-section{background:var(--bg);border:1.5px solid var(--border);border-radius:var(--radius);overflow:hidden}.cp-section__title{color:var(--primary);text-transform:uppercase;letter-spacing:.5px;background:var(--surface);border-bottom:1.5px solid var(--border);padding:14px 20px;font-size:.9rem;font-weight:700}.cp-section__content{flex-direction:column;display:flex}.cp-section__desc{color:var(--muted);padding:16px 20px 0;font-size:.88rem}.ef{border-bottom:1px solid var(--border);padding:14px 20px}.ef:last-child{border-bottom:none}.ef__header{justify-content:space-between;align-items:center;margin-bottom:4px;display:flex}.ef__label{color:var(--muted);align-items:center;gap:6px;font-size:.82rem;font-weight:600;display:flex}.ef__tooltip-icon{background:var(--border);width:14px;height:14px;color:var(--muted);cursor:help;border-radius:50%;justify-content:center;align-items:center;font-size:.65rem;font-weight:700;display:inline-flex}.ef__value{color:var(--text);font-size:.95rem}.ef__empty{color:var(--muted);font-size:.9rem;font-style:italic}.ef__edit{flex-direction:column;gap:8px;margin-top:6px;display:flex}.ef__actions{gap:8px;display:flex}.subject-toggles{flex-wrap:wrap;gap:8px;padding:16px 20px;display:flex}.subject-toggle{border:1.5px solid var(--border);border-radius:var(--radius-sm);align-items:center;display:flex;overflow:hidden}.subject-toggle--active{border-color:var(--primary)}.subject-toggle__btn{color:var(--text);cursor:pointer;transition:background var(--transition), color var(--transition);background:0 0;border:none;padding:6px 12px;font-size:.82rem;font-weight:500}.subject-toggle--active .subject-toggle__btn{background:var(--surface);color:var(--primary);font-weight:600}.cp-stats{flex-wrap:wrap;gap:0;padding:20px;display:flex}.cp-stat{text-align:center;border-right:1px solid var(--border);flex:1;min-width:80px;padding:0 16px}.cp-stat:first-child{padding-left:0}.cp-stat:last-child{border-right:none}.cp-stat__val{color:var(--primary);font-size:1.6rem;font-weight:700;font-family:var(--font-heading)}.cp-stat__label{color:var(--muted);margin-top:4px;font-size:.78rem}.progress-overview{border-bottom:1px solid var(--border);padding:20px 20px 16px}.progress-overview__title{color:var(--muted);text-transform:uppercase;letter-spacing:.5px;margin-bottom:14px;font-size:.8rem;font-weight:600}.progress-overview__rows{flex-direction:column;gap:11px;display:flex}.progress-overview__row{align-items:center;gap:12px;display:flex}.progress-overview__subject{color:var(--text);white-space:nowrap;text-overflow:ellipsis;flex:0 0 160px;align-items:center;gap:6px;min-width:0;font-size:.85rem;font-weight:600;display:flex;overflow:hidden}.progress-overview__subj-icon{flex-shrink:0;font-size:1rem}.progress-overview__bar-wrap{background:#f3f4f6;border-radius:4px;flex:1;height:8px;overflow:hidden}.progress-overview__fill{border-radius:4px;height:100%;transition:width .7s}.progress-overview__fill--high{background:#059669;width:100%}.progress-overview__fill--medium{background:#d97706;width:66%}.progress-overview__fill--low{background:#9ca3af;width:33%}.progress-overview__label{text-align:right;flex-shrink:0;min-width:74px;font-size:.75rem;font-weight:700}.progress-overview__label--high{color:#059669}.progress-overview__label--medium{color:#d97706}.progress-overview__label--low{color:#9ca3af}.progress-empty{text-align:center;flex-direction:column;align-items:center;gap:10px;padding:48px 24px;display:flex}.progress-empty__icon{font-size:2.8rem}.progress-empty h3{color:var(--text);font-size:1.05rem}.progress-empty p{color:var(--muted);max-width:300px;font-size:.88rem;line-height:1.6}.subj-profiles{flex-direction:column;display:flex}.subj-profile{border-bottom:1px solid var(--border)}.subj-profile:last-child{border-bottom:none}.subj-profile__header{cursor:pointer;text-align:left;width:100%;transition:background var(--transition);background:0 0;border:none;align-items:center;gap:10px;padding:14px 20px;font-family:inherit;display:flex}.subj-profile__header:hover,.subj-profile--open .subj-profile__header{background:var(--surface)}.subj-profile__icon{flex-shrink:0;font-size:1.1rem;line-height:1}.subj-profile__name{color:var(--text);flex:1;font-size:.92rem;font-weight:600}.subj-profile__board{flex-shrink:0;font-size:.72rem}.subj-profile__date-count{color:var(--muted);flex-shrink:0;font-size:.75rem}.subj-profile__chevron{color:var(--muted);flex-shrink:0;margin-left:4px;font-size:.65rem}.subj-config{border-top:1px solid var(--border);background:var(--bg)}.subj-config .ef{padding:12px 20px}.exam-dates{border-top:1px solid var(--border);flex-direction:column;gap:8px;padding:12px 20px 16px;display:flex}.exam-dates__label{color:var(--muted);margin-bottom:2px;font-size:.82rem;font-weight:600}.exam-dates__empty{color:var(--muted);margin:0;font-size:.85rem;font-style:italic}.exam-dates__add-btn{align-self:flex-start;padding-left:0}.exam-date-row{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm);align-items:center;gap:12px;padding:9px 14px;display:flex}.exam-date-row--editing{flex-direction:column;align-items:stretch;gap:8px;padding:12px 14px}.exam-date-row__info{flex:1;align-items:center;gap:12px;min-width:0;display:flex}.exam-date-row__name{color:var(--text);white-space:nowrap;text-overflow:ellipsis;flex:1;font-size:.875rem;font-weight:600;overflow:hidden}.exam-date-row__date{color:var(--primary);white-space:nowrap;flex-shrink:0;font-size:.82rem;font-weight:600}.exam-date-row__actions{flex-shrink:0;gap:4px;display:flex}.exam-date-row__remove{color:#dc2626!important}.exam-date-row__remove:hover{color:#991b1b!important}.exam-date-add{background:var(--surface);border:1.5px solid var(--secondary);border-radius:var(--radius-sm);flex-direction:column;gap:8px;padding:12px 14px;display:flex}.progress-cards{flex-direction:column;gap:0;display:flex}.progress-card{background:var(--bg);border-bottom:1px solid var(--border);flex-direction:column;gap:12px;padding:20px;display:flex}.progress-card:last-child{border-bottom:none}.progress-card__header{align-items:center;gap:14px;display:flex}.progress-card__subject{color:var(--text);font-size:1rem;font-weight:700}.progress-card__pct-badge{flex-shrink:0;margin-left:auto;font-size:.88rem;font-weight:800}.progress-card__pct-badge--high{color:#059669}.progress-card__pct-badge--medium{color:#d97706}.progress-card__pct-badge--low{color:#9ca3af}.progress-card__bar-row{align-items:center;gap:10px;display:flex}.progress-card__bar-track{background:#f3f4f6;border-radius:4px;flex:1;height:8px;overflow:hidden}.progress-card__bar-fill{border-radius:4px;height:100%}.progress-card__bar-fill--high{background:#059669;width:100%}.progress-card__bar-fill--medium{background:#d97706;width:66%}.progress-card__bar-fill--low{background:#9ca3af;width:33%}.progress-card__summary{color:var(--text);margin:0;font-size:.875rem;line-height:1.65}.progress-card__cols{flex-wrap:wrap;gap:16px;display:flex}.progress-card__col{flex-direction:column;flex:1;gap:7px;min-width:130px;display:flex}.progress-card__col-label{text-transform:uppercase;letter-spacing:.4px;font-size:.75rem;font-weight:700}.progress-card__col-label--topics{color:#059669}.progress-card__col-label--weak{color:#d97706}.progress-card__chips{flex-wrap:wrap;gap:5px;display:flex}.progress-chip{border-radius:20px;padding:3px 10px;font-size:.78rem;font-weight:500}.progress-chip--topic{color:#5b21b6;background:#ede9fe}.progress-chip--weak{color:#92400e;background:#fef3c7}.progress-card__footer{color:var(--muted);border-top:1px solid var(--border);padding-top:6px;font-size:.75rem}.cp-tabs{border-bottom:2px solid var(--border);gap:0;margin-bottom:4px;display:flex}.cp-tab{color:var(--muted);cursor:pointer;transition:color var(--transition), border-color var(--transition);background:0 0;border:none;border-bottom:2px solid #0000;margin-bottom:-2px;padding:10px 20px;font-family:inherit;font-size:.9rem;font-weight:600}.cp-tab:hover{color:var(--text)}.cp-tab--active{color:var(--primary);border-bottom-color:var(--primary)}.progress-card__icon-wrap{border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;width:40px;height:40px;font-size:1.4rem;line-height:1;display:flex}.progress-card__icon-wrap--high{background:#f0fdf4}.progress-card__icon-wrap--medium{background:#fffbeb}.progress-card__icon-wrap--low{background:var(--surface)}.progress-card__title{flex-direction:column;flex:1;gap:2px;min-width:0;display:flex}.progress-card__level{font-size:.75rem;font-weight:600}.progress-card__level--high{color:#059669}.progress-card__level--medium{color:#d97706}.progress-card__level--low{color:#9ca3af}.cp-danger-zone{border-radius:var(--radius);border:1.5px solid #fca5a5;flex-direction:column;gap:12px;padding:20px;display:flex}.cp-danger-zone h3{color:#991b1b;font-size:.9rem}.cp-confirm-delete{color:var(--text);flex-direction:column;gap:12px;font-size:.9rem;display:flex}.tutor{background:var(--surface);flex-direction:column;flex:1;min-height:0;display:flex}.tutor--primary .tutor__header{background:var(--accent)}.tutor--primary .tutor__header h1{color:var(--text)}.tutor--primary .tutor__title-icon{font-size:1.8rem}.tutor--primary .tutor__back-btn{color:var(--text)!important}.tutor--primary .tutor__new-chat{color:var(--text)!important;border-color:#0003!important}.tutor--primary .tutor__new-chat:hover:not(:disabled){background:#00000012!important}.tutor--primary .tutor__child-badge{color:var(--text);background:#0000001f}.tutor--primary .chat-msg--assistant .chat-msg__bubble{border:2px solid var(--border);background:#fff;font-size:1rem;line-height:1.75}.tutor--primary .tutor__send{background:var(--accent);color:var(--text);border-color:var(--accent)}.tutor--primary .tutor__limit-reached{border-top-color:var(--accent)}.tutor__header{background:var(--primary);border-bottom:1px solid #ffffff1a;flex-shrink:0}.tutor__header-inner{justify-content:space-between;align-items:center;gap:12px;max-width:800px;margin:0 auto;padding:12px 20px;display:flex}.tutor__title{align-items:center;gap:8px;min-width:0;display:flex}.tutor__title h1{color:#fff;white-space:nowrap;margin:0;font-size:1.05rem;font-weight:700}.tutor__back-btn{padding:4px 8px;font-size:1rem;color:#fffc!important}.tutor__back-btn:hover:not(:disabled){border-radius:var(--radius-sm);color:#fff!important;background:#ffffff1a!important}.tutor__title-icon{flex-shrink:0;font-size:1.3rem;line-height:1}.tutor__child-badge{color:#fff;background:#fff3;border:none;font-size:.75rem}.tutor__header-actions{flex-shrink:0;align-items:center;gap:8px;display:flex}.mode-toggle{border-radius:var(--radius-sm);background:#ffffff1f;gap:2px;padding:2px;display:flex}.mode-toggle__btn{border-radius:calc(var(--radius-sm) - 1px);color:#ffffffbf;cursor:pointer;transition:background var(--transition), color var(--transition);white-space:nowrap;background:0 0;border:none;padding:5px 12px;font-size:.8rem;font-weight:500}.mode-toggle__btn--active{color:var(--primary);background:#fff;font-weight:600}.tutor--primary .mode-toggle{background:#0000001f}.tutor--primary .mode-toggle__btn{color:#0009}.tutor--primary .mode-toggle__btn--active{color:var(--text);background:#fff}.tutor__new-chat{font-size:.82rem;color:#fffc!important;border-color:#ffffff4d!important}.tutor__new-chat:hover:not(:disabled){color:#fff!important;background:#ffffff1a!important}.tutor__disclaimer{color:#92400e;text-align:center;background:#fffbeb;border-bottom:1px solid #fcd34d;flex-shrink:0;padding:6px 16px;font-size:.8rem}.tutor__chat{flex-direction:column;flex:1;width:100%;max-width:800px;min-height:0;margin:0 auto;padding:0 20px;display:flex}.chat-messages{scroll-behavior:smooth;flex-direction:column;flex:1;gap:16px;padding:24px 0 16px;display:flex;overflow-y:auto}.chat-msg{align-items:flex-end;gap:10px;animation:.18s msg-in;display:flex}@keyframes msg-in{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}.chat-msg--user{flex-direction:row-reverse}.chat-msg__avatar{background:var(--primary);color:#fff;-webkit-user-select:none;user-select:none;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:32px;height:32px;font-size:.8rem;font-weight:700;display:flex}.chat-msg__bubble{border-radius:18px;max-width:68%;padding:11px 15px;font-size:.93rem;line-height:1.65}.chat-msg--assistant .chat-msg__bubble{background:var(--bg);color:var(--text);box-shadow:var(--shadow);border-bottom-left-radius:4px}.chat-msg--user .chat-msg__bubble{background:var(--primary);color:#fff;border-bottom-right-radius:4px}.chat-markdown{display:contents}.chat-markdown p{margin:0 0 .5em}.chat-markdown p:last-child{margin-bottom:0}.chat-markdown h1,.chat-markdown h2,.chat-markdown h3{color:var(--primary);margin:.75em 0 .25em;font-size:1rem;font-weight:700}.chat-markdown h1:first-child,.chat-markdown h2:first-child,.chat-markdown h3:first-child{margin-top:0}.chat-markdown ul,.chat-markdown ol{margin:.4em 0 .5em;padding-left:1.4em}.chat-markdown li{margin-bottom:.2em}.chat-markdown code{background:#0000000f;border-radius:3px;padding:1px 5px;font-family:ui-monospace,monospace;font-size:.87em}.chat-markdown pre{border-radius:var(--radius-sm);background:#0000000f;margin:.5em 0;padding:10px 12px;overflow-x:auto}.chat-markdown pre code{background:0 0;padding:0;font-size:.85em}.chat-markdown strong{font-weight:700}.chat-markdown em{font-style:italic}.chat-markdown blockquote{border-left:3px solid var(--border);color:var(--muted);margin:.5em 0;padding:2px 0 2px 12px}.chat-msg--user .chat-markdown code,.chat-msg--user .chat-markdown pre{background:#ffffff26}.chat-msg--user .chat-markdown h1,.chat-msg--user .chat-markdown h2,.chat-msg--user .chat-markdown h3{color:#fff}.chat-msg__bubble--typing{align-items:center;gap:5px;min-width:60px;padding:14px 18px;display:flex}.chat-msg__bubble--typing span{background:var(--secondary);border-radius:50%;width:7px;height:7px;animation:1.2s ease-in-out infinite typing-bounce}.chat-msg__bubble--typing span:nth-child(2){animation-delay:.2s}.chat-msg__bubble--typing span:nth-child(3){animation-delay:.4s}@keyframes typing-bounce{0%,60%,to{opacity:.5;transform:translateY(0)}30%{opacity:1;transform:translateY(-6px)}}.tutor__error{color:#991b1b;border-radius:var(--radius-sm);background:#fee2e2;border:1px solid #fca5a5;margin-bottom:8px;padding:9px 13px;font-size:.84rem}.tutor__msg-counter{color:var(--muted);text-align:right;padding:6px 0 2px;font-size:.75rem}.tutor__msg-counter--low{color:#b45309;font-weight:500}.tutor__input-bar{border-top:1.5px solid var(--border);background:var(--surface);flex-shrink:0;align-items:flex-end;gap:10px;padding:12px 0 20px;display:flex}.tutor__input{resize:none;border:1.5px solid var(--border);border-radius:var(--radius);background:var(--bg);color:var(--text);transition:border-color var(--transition), box-shadow var(--transition);field-sizing:content;flex:1;max-height:140px;padding:11px 15px;font-size:.93rem;line-height:1.5;overflow-y:auto}.tutor__input:focus{border-color:var(--primary);outline:none;box-shadow:0 0 0 3px #7c3aed1f}.tutor__input:disabled{opacity:.55;cursor:not-allowed}.tutor__send{border-radius:var(--radius);flex-shrink:0;align-items:center;gap:7px;padding:11px 18px;font-size:.9rem;display:flex}.tutor__send:disabled{opacity:.4;cursor:not-allowed}.tutor__limit-reached{text-align:center;border-top:2px solid var(--accent);background:var(--bg);flex-direction:column;flex-shrink:0;align-items:center;gap:10px;padding:24px 20px;display:flex}.tutor__limit-icon{font-size:2.2rem}.tutor__limit-reached h3{color:var(--text);margin:0;font-size:1rem;font-weight:700}.tutor__limit-reached p{color:var(--muted);max-width:380px;margin:0;font-size:.88rem;line-height:1.5}.tutor__upgrade-btn{margin-top:4px}.tutor__limit-reset{color:var(--muted);font-size:.78rem}.tutor__not-found{height:100%;color:var(--muted);flex-direction:column;justify-content:center;align-items:center;gap:16px;display:flex}.tutor-subject-grid{width:100%;max-width:800px;margin:0 auto;padding:32px 24px}.tutor-subject-grid h2{color:var(--text);margin-bottom:24px;font-size:1.4rem}.tutor-subject-group{margin-bottom:28px}.tutor-subject-group__label{text-transform:uppercase;letter-spacing:.5px;color:var(--muted);margin-bottom:10px;font-size:.78rem;font-weight:600}.tutor-subject-grid__cards{flex-wrap:wrap;gap:10px;display:flex}.tutor-subject-card{background:var(--bg);border:1.5px solid var(--border);border-radius:var(--radius);color:var(--text);cursor:pointer;transition:border-color var(--transition), box-shadow var(--transition), transform var(--transition);align-items:center;gap:8px;padding:10px 18px;font-family:inherit;font-size:.92rem;font-weight:500;display:flex}.tutor-subject-card:hover{border-color:var(--primary);box-shadow:var(--shadow);transform:translateY(-1px)}.tutor-subject-card__icon{font-size:1.1rem;line-height:1}.tutor-subject-empty{color:var(--muted);margin-top:0;font-size:.9rem}.tutor__body{flex:1;min-height:0;position:relative;overflow:hidden}.tutor__body .tutor__chat{max-width:800px;height:100%;min-height:0;margin:0 auto;padding:0 20px}.tutor__history{background:var(--bg);border-left:1.5px solid var(--border);z-index:10;flex-direction:column;width:320px;transition:transform .25s;display:flex;position:absolute;top:0;bottom:0;right:0;transform:translate(100%);box-shadow:-6px 0 20px #00000012}.tutor__history--open{transform:translate(0)}.tutor__history-header{border-bottom:1.5px solid var(--border);flex-shrink:0;justify-content:space-between;align-items:center;padding:14px 18px;display:flex}.tutor__history-header h3{color:var(--text);margin:0;font-size:.95rem;font-weight:700}.tutor__history-close{cursor:pointer;color:var(--muted);border-radius:var(--radius-sm);transition:color var(--transition), background var(--transition);background:0 0;border:none;padding:4px 6px;font-size:1rem;line-height:1}.tutor__history-close:hover{color:var(--text);background:var(--surface)}.tutor__history-list{flex:1;overflow-y:auto}.tutor__history-item{border-bottom:1px solid var(--border);cursor:pointer;text-align:left;width:100%;transition:background var(--transition);background:0 0;border-top:none;border-left:none;border-right:none;flex-direction:column;gap:5px;padding:13px 18px;font-family:inherit;display:flex}.tutor__history-item:hover{background:var(--surface)}.tutor__history-item--active{background:var(--surface);border-left:3px solid var(--primary);padding-left:15px}.tutor__history-item-date{color:var(--muted);font-size:.75rem;font-weight:500}.tutor__history-item-title-row{align-items:center;gap:5px;min-width:0;display:flex}.tutor__history-item-title{color:var(--text);white-space:nowrap;text-overflow:ellipsis;flex:1;min-width:0;font-size:.86rem;font-weight:500;overflow:hidden}.tutor__history-item-rename{cursor:pointer;border-radius:var(--radius-sm);opacity:0;transition:opacity var(--transition), background var(--transition);color:var(--muted);background:0 0;border:none;flex-shrink:0;padding:2px 3px;font-size:.7rem;line-height:1;transform:scaleX(-1)}.tutor__history-item:hover .tutor__history-item-rename,.tutor__history-item--active .tutor__history-item-rename{opacity:1}.tutor__history-item-rename:hover{background:var(--border);color:var(--text)}.tutor__history-item-input{color:var(--text);border:none;border-bottom:1.5px solid var(--primary);background:0 0;outline:none;width:100%;min-width:0;padding:0;font-family:inherit;font-size:.86rem;font-weight:500}.tutor__history-item-meta{align-items:center;gap:8px;display:flex}.tutor__history-item-count{color:var(--muted);font-size:.75rem}.tutor__history-empty{text-align:center;color:var(--muted);flex-direction:column;align-items:center;gap:10px;padding:48px 20px;font-size:.87rem;line-height:1.5;display:flex}.tutor__history-btn{font-size:.82rem;color:#fffc!important;border-color:#ffffff4d!important}.tutor__history-btn:hover:not(:disabled){color:#fff!important;background:#ffffff1a!important}.tutor--primary .tutor__history-btn{color:#0009!important;border-color:#0003!important}.tutor--primary .tutor__history-btn:hover:not(:disabled){background:#00000012!important}@media (width<=600px){.tutor__body .tutor__chat{padding:0 12px}.chat-msg__bubble{max-width:84%}.tutor__send span{display:none}.tutor__send{padding:11px 13px}.mode-toggle{display:none}.tutor__history{width:100%}.tutor__history-item-rename{opacity:1}}.practice-overlay{z-index:200;background:#1a1a2e73;justify-content:center;align-items:center;padding:16px;animation:.15s practice-fade-in;display:flex;position:fixed;inset:0}@keyframes practice-fade-in{0%{opacity:0}to{opacity:1}}.practice-panel{background:var(--bg);border-radius:var(--radius);border:1.5px solid var(--border);flex-direction:column;width:100%;max-width:680px;max-height:90vh;animation:.18s practice-slide-up;display:flex;box-shadow:0 20px 60px #0000002e}@keyframes practice-slide-up{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.practice-panel__header{border-bottom:1.5px solid var(--border);background:var(--surface);border-radius:var(--radius) var(--radius) 0 0;flex-shrink:0;justify-content:space-between;align-items:center;padding:18px 24px;display:flex}.practice-panel__title{align-items:center;gap:12px;display:flex}.practice-panel__title-icon{font-size:1.4rem;line-height:1}.practice-panel__title h2{color:var(--text);margin:0 0 2px;font-size:1.05rem}.practice-panel__title p{color:var(--muted);margin:0;font-size:.8rem}.practice-panel__close{cursor:pointer;color:var(--muted);border-radius:var(--radius-sm);transition:background var(--transition), color var(--transition);background:0 0;border:none;padding:4px 8px;font-size:1rem;line-height:1}.practice-panel__close:hover{background:var(--border);color:var(--text)}.practice-panel__body{flex-direction:column;flex:1;padding:24px;display:flex;overflow-y:auto}.practice-idle{text-align:center;flex-direction:column;align-items:center;gap:14px;padding:32px 0;display:flex}.practice-idle__icon{font-size:3rem;line-height:1}.practice-idle h3{color:var(--text);font-size:1.15rem}.practice-idle p{color:var(--muted);max-width:400px;font-size:.9rem;line-height:1.65}.practice-loading{color:var(--muted);flex-direction:column;align-items:center;gap:16px;padding:64px 0;font-size:.9rem;display:flex}.practice-questions{flex-direction:column;gap:20px;display:flex}.practice-q{background:var(--bg);border:1.5px solid var(--border);border-radius:var(--radius);flex-direction:column;gap:10px;padding:18px 20px;display:flex}.practice-q__header{flex-wrap:wrap;align-items:center;gap:8px;display:flex}.practice-q__num{color:var(--primary);background:var(--surface);font-size:.78rem;font-weight:800;font-family:var(--font-heading);border-radius:20px;padding:2px 8px}.practice-q__marks{color:var(--muted);font-size:.78rem;font-weight:600}.practice-q__type{text-transform:capitalize;font-size:.72rem}.practice-q__text{color:var(--text);margin:0;font-size:.95rem;font-weight:500;line-height:1.6}.practice-q__input{resize:vertical;min-height:80px;font-size:.9rem}.practice-questions__footer{justify-content:flex-end;padding-top:4px;display:flex}.practice-score{border-radius:var(--radius);text-align:center;flex-direction:column;align-items:center;gap:4px;margin-bottom:24px;padding:24px;display:flex}.practice-score--high{background:#f0fdf4;border:1.5px solid #6ee7b7}.practice-score--medium{background:#fffbeb;border:1.5px solid #fcd34d}.practice-score--low{border:1.5px solid var(--border);background:#f9fafb}.practice-score__val{font-size:2rem;font-weight:800;font-family:var(--font-heading);line-height:1}.practice-score--high .practice-score__val{color:#059669}.practice-score--medium .practice-score__val{color:#d97706}.practice-score--low .practice-score__val{color:#6b7280}.practice-score__pct{color:var(--muted);font-size:1rem;font-weight:700}.practice-score__label{color:var(--text);font-size:.9rem;font-weight:600}.practice-results{flex-direction:column;gap:16px;display:flex}.practice-result{border-radius:var(--radius);border:1.5px solid var(--border);overflow:hidden}.practice-result--correct{border-left:4px solid #059669}.practice-result--incorrect{border-left:4px solid #d97706}.practice-result__header{background:var(--surface);border-bottom:1px solid var(--border);align-items:center;gap:8px;padding:12px 16px;display:flex}.practice-result__icon{font-size:1rem;line-height:1}.practice-result__qnum{color:var(--text);flex:1;font-size:.82rem;font-weight:800}.practice-result__marks{color:var(--muted);font-size:.78rem;font-weight:700}.practice-result--correct .practice-result__marks{color:#059669}.practice-result__body{flex-direction:column;gap:12px;padding:14px 16px;display:flex}.practice-result__question{color:var(--text);margin:0;padding:14px 16px 0;font-size:.9rem;font-weight:600;line-height:1.5}.practice-result__section{flex-direction:column;gap:4px;padding:0 16px 14px;display:flex}.practice-result__section-label{text-transform:uppercase;letter-spacing:.4px;color:var(--muted);font-size:.72rem;font-weight:700}.practice-result__section-label--your{color:var(--muted)}.practice-result__section-label--feedback{color:var(--primary)}.practice-result__section-label--model{color:#059669}.practice-result__section p{color:var(--text);white-space:pre-wrap;margin:0;font-size:.875rem;line-height:1.6}.practice-result__section--model{border-radius:0 0 calc(var(--radius) - 2px) calc(var(--radius) - 2px);background:#f0fdf4;margin:0;padding:12px 16px}.practice-results__footer{justify-content:flex-end;gap:12px;padding-top:8px;display:flex}.practice-result__divider{background:var(--border);height:1px;margin:0 16px}.tutor__practice-btn{flex-shrink:0}@media (width<=600px){.practice-overlay{align-items:flex-end;padding:0}.practice-panel{border-radius:var(--radius) var(--radius) 0 0;border-bottom:none;max-height:95vh}}
