@import "https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700&family=Plus+Jakarta+Sans:wght@400;500;600;700;800&display=swap";:root{--color-primary:#4f46e5;--color-primary-dark:#4338ca;--color-primary-light:#818cf8;--color-primary-lighter:#c7d2fe;--color-primary-surface:#eef2ff;--color-navy:#1e1b4b;--color-navy-mid:#312e81;--color-navy-light:#3730a3;--color-violet:#7c3aed;--color-white:#fff;--color-surface:#f9fafb;--color-border:#e0e7ff;--color-border-light:#eef2ff;--color-text-primary:#1e1b4b;--color-text-secondary:#4b5563;--color-text-muted:#9ca3af;--color-text-white:#fff;--color-success:#27ae60;--color-error:#e74c3c;--color-warning:#f39c12;--gradient-primary:linear-gradient(135deg, #4f46e5 0%, #7c3aed 100%);--gradient-hero:linear-gradient(140deg, #1e1b4b 0%, #4338ca 55%, #7c3aed 100%);--gradient-surface:linear-gradient(135deg, #eef2ff 0%, #f5f7ff 100%);--font-heading:"Plus Jakarta Sans", sans-serif;--font-body:"Inter", sans-serif;--text-xs:.75rem;--text-sm:.875rem;--text-base:1rem;--text-lg:1.125rem;--text-xl:1.25rem;--text-2xl:1.5rem;--text-3xl:1.875rem;--text-4xl:2.25rem;--space-1:.25rem;--space-2:.5rem;--space-3:.75rem;--space-4:1rem;--space-5:1.25rem;--space-6:1.5rem;--space-8:2rem;--space-10:2.5rem;--space-12:3rem;--space-16:4rem;--radius-sm:6px;--radius-md:10px;--radius-lg:16px;--radius-xl:24px;--radius-full:9999px;--shadow-sm:0 1px 3px #1e1b4b14, 0 1px 2px #1e1b4b0a;--shadow-md:0 4px 16px #1e1b4b1a, 0 2px 6px #1e1b4b0f;--shadow-lg:0 8px 32px #1e1b4b24, 0 4px 12px #1e1b4b14;--shadow-xl:0 20px 60px #1e1b4b2e;--transition-fast:.15s ease;--transition-base:.25s ease;--transition-slow:.4s ease}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-size:16px}body{font-family:var(--font-body);color:var(--color-text-primary);background:var(--color-surface);min-height:100vh;line-height:1.6;overflow-x:hidden}h1,h2,h3,h4,h5,h6{font-family:var(--font-heading);color:var(--color-text-primary);line-height:1.2}a{color:var(--color-primary);text-decoration:none}a:hover{text-decoration:underline}img{max-width:100%;display:block}button{cursor:pointer;font-family:var(--font-body);border:none;outline:none}input,textarea,select{font-family:var(--font-body);outline:none}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeInLeft{0%{opacity:0;transform:translate(-20px)}to{opacity:1;transform:translate(0)}}@keyframes spin{to{transform:rotate(360deg)}}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}@keyframes float{0%{transform:translateY(0)}50%{transform:translateY(-8px)}to{transform:translateY(0)}}@keyframes pulseRing{0%{opacity:1;transform:scale(1)}to{opacity:0;transform:scale(1.5)}}.animate-fadeIn{animation:.4s both fadeIn}.animate-fadeInLeft{animation:.4s both fadeInLeft}.animate-float{animation:3s ease-in-out infinite float}.spinner{border:2.5px solid #ffffff59;border-top-color:#fff;border-radius:50%;width:20px;height:20px;animation:.7s linear infinite spin;display:inline-block}.spinner--dark{border-color:#1e1b4b33;border-top-color:var(--color-navy)}.sl-root{background:#f9fafb;min-height:100vh;display:flex}.sl-sidebar{background:var(--color-navy);z-index:100;width:260px;min-height:100vh;transition:width var(--transition-base);flex-direction:column;display:flex;position:fixed;top:0;bottom:0;left:0;overflow:hidden}.sl-root--collapsed .sl-sidebar{width:72px}.sl-logo{border-bottom:1px solid #ffffff12;align-items:center;gap:10px;min-height:72px;padding:20px 18px 16px;display:flex}.sl-logo__img{object-fit:cover;border-radius:8px;flex-shrink:0;width:36px;height:36px}.sl-logo__text{font-family:var(--font-heading);color:#fff;white-space:nowrap;letter-spacing:.01em;font-size:15px;font-weight:700}.sl-logo__text em{color:var(--color-primary-lighter);margin-top:-2px;font-size:11px;font-style:normal;font-weight:500;display:block}.sl-collapse-btn{background:var(--color-primary);color:#fff;cursor:pointer;z-index:110;width:24px;height:24px;transition:all var(--transition-fast);border:2px solid #ffffff26;border-radius:50%;justify-content:center;align-items:center;display:flex;position:absolute;top:22px;right:8px;box-shadow:0 2px 8px #0003}.sl-collapse-btn:hover{background:var(--color-navy-mid);transform:scale(1.05)}.sl-nav{scrollbar-width:none;flex-direction:column;flex:1;gap:1px;padding:8px 10px;display:flex;overflow:hidden auto}.sl-nav::-webkit-scrollbar{display:none}.sl-nav__item{color:#fff9;transition:background var(--transition-fast), color var(--transition-fast);white-space:nowrap;border-radius:10px;align-items:center;gap:10px;padding:7px 12px;font-size:14px;font-weight:500;text-decoration:none;display:flex;position:relative}.sl-nav__item:hover{color:#ffffffe6;background:#ffffff12;text-decoration:none}.sl-nav__item--active{background:var(--color-primary);color:#fff;box-shadow:0 4px 12px #2563eb66}.sl-nav__item--active:hover{background:var(--color-primary);color:#fff}.sl-nav__icon{flex-shrink:0;width:20px}.sl-nav__label{text-overflow:ellipsis;overflow:hidden}.sl-nav__divider{background:#ffffff12;height:1px;margin:6px 4px}.sl-nav__item--secondary{color:#ffffff73;padding:6px 12px;font-size:13px}.sl-nav__item--secondary .sl-nav__icon{width:18px}.sl-upgrade-btn{color:#fff;background:linear-gradient(135deg,#b45309,#d97706);border-radius:10px;align-items:center;gap:8px;margin:0 10px 10px;padding:9px 14px;font-size:13px;font-weight:600;text-decoration:none;transition:opacity .15s;display:flex}.sl-upgrade-btn:hover{opacity:.9;color:#fff;text-decoration:none}.sl-bottom{border-top:1px solid #ffffff12;flex-direction:column;gap:8px;padding:12px 10px 16px;display:flex}.sl-exam-chip{color:var(--color-primary-lighter);white-space:nowrap;background:#2563eb33;border:1px solid #60a5fa4d;border-radius:8px;align-items:center;gap:8px;padding:8px 12px;font-size:12px;font-weight:600;display:flex;overflow:hidden}.sl-exam-chip__dot{background:var(--color-primary-light);border-radius:50%;flex-shrink:0;width:7px;height:7px;animation:1.5s ease-in-out infinite pulseRing}.sl-user{background:#ffffff0d;border-radius:10px;align-items:center;gap:10px;padding:8px 12px;display:flex}.sl-user__avatar{background:var(--color-primary);color:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:34px;height:34px;font-size:13px;font-weight:700;display:flex}.sl-user__info{flex-direction:column;display:flex;overflow:hidden}.sl-user__name{color:#ffffffe6;white-space:nowrap;text-overflow:ellipsis;font-size:13px;font-weight:600;overflow:hidden}.sl-user__tier{color:var(--color-primary-light);font-size:11px;font-weight:500}.sl-demo-chip{color:#ffd180;background:#ffbe3c24;border:1px solid #ffbe3c59;border-radius:8px;align-items:center;gap:6px;padding:7px 10px;font-size:11px;font-weight:700;display:inline-flex}.sl-quick-access{border-top:1px solid #ffffff0f;border-bottom:1px solid #ffffff0f;flex-direction:column;gap:1px;padding:4px 0;display:flex}.sl-quick-btn{color:#fff6;cursor:pointer;transition:background var(--transition-fast), color var(--transition-fast);white-space:nowrap;background:0 0;border:none;border-radius:8px;align-items:center;gap:10px;width:100%;padding:6px 12px;font-family:inherit;font-size:12.5px;font-weight:500;text-decoration:none;display:flex;position:relative}.sl-quick-btn:hover{color:#fffc;background:#ffffff12;text-decoration:none}.sl-quick-btn__icon{flex-shrink:0;width:15px}.sl-root--collapsed .sl-quick-btn{justify-content:center;padding:6px 0}.sl-quick-badge{color:#fff;background:#e74c3c;border-radius:999px;margin-left:auto;padding:1px 5px;font-size:9px;font-weight:700;line-height:1.4}.sl-logout{color:#ffffff80;cursor:pointer;transition:all var(--transition-fast);white-space:nowrap;background:0 0;border:1px solid #ffffff1a;border-radius:10px;align-items:center;gap:10px;padding:9px 12px;font-size:13px;font-weight:500;display:flex}.sl-logout:hover{color:#ff8a80;background:#e74c3c1f;border-color:#e74c3c4d}.sl-main{min-height:100vh;transition:margin-left var(--transition-base);flex-direction:column;flex:1;margin-left:260px;display:flex}.sl-root--collapsed .sl-main{margin-left:72px}.sl-topbar{z-index:50;background:#fff;border-bottom:1px solid #eef2ff;justify-content:flex-end;align-items:center;gap:8px;height:64px;padding:0 28px;display:flex;position:sticky;top:0;box-shadow:0 1px 4px #1e1b4b0d}.sl-topbar__menu{color:var(--color-navy);cursor:pointer;background:0 0;border:none;border-radius:8px;margin-right:auto;padding:6px;display:none}.sl-topbar__left{flex:1}.sl-topbar__right{align-items:center;gap:6px;display:flex}.sl-topbar__icon-btn{color:#4b5563;cursor:pointer;width:38px;height:38px;transition:all var(--transition-fast);background:0 0;border:1px solid #eef2ff;border-radius:10px;justify-content:center;align-items:center;display:flex;position:relative}.sl-topbar__icon-btn:hover{background:var(--color-primary-surface);border-color:var(--color-primary-lighter);color:var(--color-primary)}.sl-topbar__badge{color:#fff;background:#e74c3c;border:2px solid #fff;border-radius:50%;justify-content:center;align-items:center;width:16px;height:16px;font-size:10px;font-weight:700;display:flex;position:absolute;top:-4px;right:-4px}.sl-topbar__avatar{color:#4f46e5;cursor:pointer;background:#eef2ff;border-radius:50%;justify-content:center;align-items:center;width:34px;height:34px;margin-left:2px;text-decoration:none;transition:background .15s;display:flex}.sl-topbar__avatar--link:hover{background:#d0e5f5}.sl-content{flex:1;padding:28px;overflow:hidden auto}.sl-overlay{z-index:99;background:#0006;display:none;position:fixed;inset:0}@media (width<=1024px){.sl-sidebar{transition:transform var(--transition-base), width var(--transition-base);transform:translate(-100%);width:260px!important}.sl-root--mobile-open .sl-sidebar{transform:translate(0)}.sl-main{margin-left:0!important}.sl-topbar__menu{display:flex}.sl-overlay,.sl-root--mobile-open .sl-overlay{display:block}.sl-collapse-btn{display:none}.sl-content{padding:20px 16px}}@media (width<=640px){.sl-topbar{height:56px;padding:0 10px}.sl-topbar__right{gap:4px}.sl-topbar__icon-btn{width:34px;height:34px}.sl-topbar__avatar{width:32px;height:32px;margin-left:2px;font-size:11px}.sl-content{padding:12px}}@media (width<=420px){.sl-topbar{padding:0 8px}.sl-topbar__right{gap:2px}.sl-topbar__icon-btn{width:30px;height:30px}.sl-topbar__badge{width:14px;height:14px;font-size:9px}.sl-topbar__avatar{width:28px;height:28px}}.admin-layout{background:#f4f8fc;min-height:100vh;display:flex;overflow-x:hidden}.admin-layout__overlay{display:none}.admin-sidebar{color:#dcecff;z-index:200;background:#1e1b4b;flex-direction:column;gap:.75rem;width:240px;padding:1rem;display:flex;position:fixed;top:0;bottom:0;left:0;overflow:hidden}.admin-sidebar__brand{justify-content:space-between;align-items:center;display:flex}.admin-sidebar__logo-wrap{align-items:center;gap:.7rem;display:flex}.admin-sidebar__logo{border-radius:8px;width:36px;height:36px}.admin-sidebar__logo-wrap div{flex-direction:column;display:flex}.admin-sidebar__logo-wrap strong{color:#fff;font-size:.95rem}.admin-sidebar__logo-wrap span{color:#9fc1e4;font-size:.72rem}.admin-sidebar__close{color:#dcecff;background:0 0;display:none}.admin-sidebar__nav{scrollbar-width:thin;scrollbar-color:#ffffff1f transparent;flex-direction:column;flex:1;gap:.15rem;margin-top:.25rem;display:flex;overflow:hidden auto}.admin-sidebar__nav::-webkit-scrollbar{width:4px}.admin-sidebar__nav::-webkit-scrollbar-thumb{background:#ffffff1f;border-radius:99px}.admin-sidebar__group{flex-direction:column;gap:.1rem;margin-bottom:.5rem;display:flex}.admin-sidebar__group-label{text-transform:uppercase;letter-spacing:.09em;color:#ffffff59;padding:.5rem .75rem .2rem;font-size:.65rem;font-weight:700}.admin-sidebar__link{color:#ffffffb8;border-radius:8px;align-items:center;gap:.55rem;padding:.48rem .75rem;font-size:.85rem;text-decoration:none;transition:all .15s;display:flex}.admin-sidebar__link:hover{color:#fff;background:#ffffff14;text-decoration:none}.admin-sidebar__link--active{color:#fff;background:#4f46e5}.admin-sidebar__bottom{flex-direction:column;gap:.8rem;margin-top:auto;display:flex}.admin-sidebar__user{background:#ffffff14;border-radius:10px;align-items:center;gap:.6rem;padding:.65rem;display:flex}.admin-sidebar__avatar{color:#fff;background:#4f46e5;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:32px;min-width:32px;height:32px;display:flex}.admin-sidebar__user strong{color:#fff;text-overflow:ellipsis;white-space:nowrap;font-size:.82rem;display:block;overflow:hidden}.admin-sidebar__user span{color:#b8d1eb;text-overflow:ellipsis;white-space:nowrap;font-size:.72rem;display:block;overflow:hidden}.admin-sidebar__user>div{min-width:0}.admin-sidebar__logout{color:#dcecff;background:0 0;border:1px solid #fff3;border-radius:10px;justify-content:center;align-items:center;gap:.45rem;min-height:36px;font-weight:600;display:flex}.admin-sidebar__logout:hover{background:#ffffff14}.admin-main{flex-direction:column;flex:1;min-width:0;min-height:100vh;margin-left:240px;display:flex}.admin-topbar{z-index:100;background:#fff;border-bottom:1px solid #e0e7ff;justify-content:space-between;align-items:center;gap:1rem;height:68px;padding:0 1.25rem;display:flex;position:sticky;top:0}.admin-topbar__menu{color:#1e1b4b;background:#f1f7ff;border-radius:8px;justify-content:center;align-items:center;width:34px;height:34px;display:none}.admin-topbar__meta{flex-direction:column;min-width:0;display:flex}.admin-topbar__title{color:#1e1b4b;white-space:nowrap;text-overflow:ellipsis;font-size:.96rem;font-weight:700;overflow:hidden}.admin-topbar__subtitle{color:#6b7280;font-size:.78rem}.admin-topbar__badge{color:#4f46e5;background:#eef2ff;border-radius:999px;align-items:center;gap:.35rem;padding:.36rem .58rem;font-size:.75rem;font-weight:700;display:inline-flex}.admin-content{min-width:0;padding:1.5rem}.admin-shell-page{flex-direction:column;gap:1rem;display:flex}.admin-shell-page__header h1{color:#1e1b4b;margin:0;font-size:1.45rem}.admin-shell-page__header p{color:#6b7280;margin:.25rem 0 0}.admin-shell-grid{grid-template-columns:repeat(3,minmax(0,1fr));gap:1rem;display:grid}.admin-shell-card{background:#fff;border:1px solid #e0e7ff;border-radius:14px;min-height:130px;padding:1rem}.admin-shell-card h3{color:#1e1b4b;margin:0;font-size:1rem}.admin-shell-card p{color:#6b7280;margin:.5rem 0 0;font-size:.92rem}.admin-shell-chip{color:#4f46e5;background:#eef6ff;border-radius:999px;align-items:center;gap:.35rem;margin-top:.75rem;padding:.28rem .55rem;font-size:.74rem;font-weight:700;display:inline-flex}@media (width<=1080px){.admin-shell-grid{grid-template-columns:1fr 1fr}}@media (width<=900px){.admin-layout__overlay{z-index:160;background:#03122673;border:none;display:block;position:fixed;inset:0}.admin-sidebar{transition:transform .22s;transform:translate(-102%)}.admin-layout--mobile-open .admin-sidebar{transform:translate(0)}.admin-sidebar__close{justify-content:center;align-items:center;display:inline-flex}.admin-main{margin-left:0}.admin-topbar__menu{display:inline-flex}}@media (width<=700px){.admin-shell-grid{grid-template-columns:1fr}.admin-topbar__subtitle,.admin-topbar__badge{display:none}.admin-content{padding:1rem}.admin-topbar{padding:0 .8rem}.admin-topbar__title{font-size:.88rem}}@media (width<=480px){.admin-sidebar{width:min(88vw,320px)}.admin-content{padding:.75rem}.admin-shell-card{min-height:110px;padding:.85rem}.admin-topbar{height:58px}}.affiliate-layout{background:#f4f8fc;min-height:100vh;display:flex;overflow-x:hidden}.affiliate-layout__overlay{display:none}.affiliate-sidebar{color:#dcecff;z-index:200;background:#1e1b4b;flex-direction:column;gap:1rem;width:260px;padding:1rem;display:flex;position:fixed;top:0;bottom:0;left:0}.affiliate-sidebar__brand{justify-content:space-between;align-items:center;display:flex}.affiliate-sidebar__logo-wrap{align-items:center;gap:.7rem;display:flex}.affiliate-sidebar__logo{border-radius:8px;width:36px;height:36px}.affiliate-sidebar__logo-wrap div{flex-direction:column;display:flex}.affiliate-sidebar__logo-wrap strong{color:#fff;font-size:.95rem}.affiliate-sidebar__logo-wrap span{color:#9fc1e4;font-size:.72rem}.affiliate-sidebar__close{color:#dcecff;background:0 0;display:none}.affiliate-sidebar__code-wrap{background:#ffffff12;border:1px solid #ffffff1f;border-radius:10px;padding:.65rem .75rem}.affiliate-sidebar__code-label{color:#9fc1e4;text-transform:uppercase;letter-spacing:.04em;margin-bottom:.3rem;font-size:.7rem;display:block}.affiliate-sidebar__code{color:#5bbfff;letter-spacing:.05em;align-items:center;gap:.4rem;font-size:.96rem;font-weight:700;display:flex}.affiliate-sidebar__nav{flex-direction:column;gap:.3rem;display:flex}.affiliate-sidebar__link{color:#ffffffbf;border-radius:10px;align-items:center;gap:.6rem;padding:.65rem .75rem;text-decoration:none;transition:all .2s;display:flex}.affiliate-sidebar__link:hover{color:#fff;background:#ffffff14;text-decoration:none}.affiliate-sidebar__link--active{color:#fff;background:#4f46e5}.affiliate-sidebar__bottom{flex-direction:column;gap:.8rem;margin-top:auto;display:flex}.affiliate-sidebar__user{background:#ffffff14;border-radius:10px;align-items:center;gap:.6rem;padding:.65rem;display:flex}.affiliate-sidebar__avatar{color:#fff;background:#4f46e5;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:32px;height:32px;font-size:.85rem;font-weight:700;display:flex}.affiliate-sidebar__user strong{color:#fff;font-size:.85rem;display:block}.affiliate-sidebar__user span{color:#b8d1eb;font-size:.75rem;display:block}.affiliate-sidebar__logout{color:#dcecff;cursor:pointer;background:0 0;border:1px solid #fff3;border-radius:10px;justify-content:center;align-items:center;gap:.45rem;min-height:36px;font-weight:600;display:flex}.affiliate-sidebar__logout:hover{background:#ffffff14}.affiliate-main{flex-direction:column;flex:1;min-width:0;min-height:100vh;margin-left:260px;display:flex}.affiliate-topbar{z-index:100;background:#fff;border-bottom:1px solid #e0e7ff;justify-content:space-between;align-items:center;gap:1rem;height:68px;padding:0 1.25rem;display:flex;position:sticky;top:0}.affiliate-topbar__menu{color:#1e1b4b;cursor:pointer;background:#f1f7ff;border:none;border-radius:8px;justify-content:center;align-items:center;width:34px;height:34px;display:none}.affiliate-topbar__meta{flex-direction:column;min-width:0;display:flex}.affiliate-topbar__title{color:#1e1b4b;font-size:.96rem;font-weight:700}.affiliate-topbar__subtitle{color:#6b7280;font-size:.78rem}.affiliate-topbar__badge{color:#4f46e5;letter-spacing:.04em;background:#eef2ff;border-radius:999px;align-items:center;gap:.35rem;padding:.36rem .65rem;font-size:.75rem;font-weight:700;display:inline-flex}.affiliate-content{min-width:0;padding:1.5rem}@media (width<=900px){.affiliate-layout__overlay{z-index:160;cursor:pointer;background:#03122673;border:none;display:block;position:fixed;inset:0}.affiliate-sidebar{transition:transform .22s;transform:translate(-102%)}.affiliate-layout--mobile-open .affiliate-sidebar{transform:translate(0)}.affiliate-sidebar__close{cursor:pointer;justify-content:center;align-items:center;display:inline-flex}.affiliate-main{margin-left:0}.affiliate-topbar__menu{display:inline-flex}}@media (width<=600px){.affiliate-topbar__subtitle,.affiliate-topbar__badge{display:none}.affiliate-content{padding:1rem}}.teacher-layout{background:#f4f8fc;min-height:100vh;display:flex;overflow-x:hidden}.teacher-layout__overlay{display:none}.teacher-sidebar{color:#dcecff;z-index:200;background:#1e1b4b;flex-direction:column;gap:1rem;width:260px;padding:1rem;display:flex;position:fixed;top:0;bottom:0;left:0}.teacher-sidebar__brand{justify-content:space-between;align-items:center;display:flex}.teacher-sidebar__logo-wrap{align-items:center;gap:.7rem;display:flex}.teacher-sidebar__logo{border-radius:8px;width:36px;height:36px}.teacher-sidebar__logo-wrap div{flex-direction:column;display:flex}.teacher-sidebar__logo-wrap strong{color:#fff;font-size:.95rem}.teacher-sidebar__logo-wrap span{color:#9fc1e4;font-size:.72rem}.teacher-sidebar__close{color:#dcecff;background:0 0;display:none}.teacher-sidebar__role-badge{color:#9fc1e4;background:#ffffff12;border:1px solid #ffffff1f;border-radius:10px;align-items:center;gap:.5rem;padding:.5rem .75rem;font-size:.8rem;display:flex}.teacher-sidebar__role-badge strong{color:#5bbfff;text-transform:uppercase;letter-spacing:.05em;font-size:.78rem}.teacher-sidebar__nav{flex-direction:column;gap:.3rem;display:flex}.teacher-sidebar__link{color:#ffffffbf;border-radius:10px;align-items:center;gap:.6rem;padding:.65rem .75rem;font-size:.9rem;text-decoration:none;transition:all .2s;display:flex}.teacher-sidebar__link:hover{color:#fff;background:#ffffff14;text-decoration:none}.teacher-sidebar__link--active{color:#fff;background:#4f46e5}.teacher-sidebar__bottom{flex-direction:column;gap:.8rem;margin-top:auto;display:flex}.teacher-sidebar__user{background:#ffffff14;border-radius:10px;align-items:center;gap:.6rem;padding:.65rem;display:flex}.teacher-sidebar__avatar{color:#fff;background:#4f46e5;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:32px;height:32px;font-size:.85rem;font-weight:700;display:flex}.teacher-sidebar__user strong{color:#fff;white-space:nowrap;text-overflow:ellipsis;max-width:140px;font-size:.85rem;display:block;overflow:hidden}.teacher-sidebar__user span{color:#b8d1eb;font-size:.75rem;display:block}.teacher-sidebar__logout{color:#dcecff;cursor:pointer;background:0 0;border:1px solid #fff3;border-radius:10px;justify-content:center;align-items:center;gap:.45rem;min-height:36px;font-size:.875rem;font-weight:600;display:flex}.teacher-sidebar__logout:hover{background:#ffffff14}.teacher-main{flex-direction:column;flex:1;min-width:0;min-height:100vh;margin-left:260px;display:flex}.teacher-topbar{z-index:100;background:#fff;border-bottom:1px solid #e0e7ff;justify-content:space-between;align-items:center;gap:1rem;height:68px;padding:0 1.25rem;display:flex;position:sticky;top:0}.teacher-topbar__menu{color:#1e1b4b;cursor:pointer;background:#f1f7ff;border:none;border-radius:8px;justify-content:center;align-items:center;width:34px;height:34px;display:none}.teacher-topbar__meta{flex-direction:column;min-width:0;display:flex}.teacher-topbar__title{color:#1e1b4b;font-size:.96rem;font-weight:700}.teacher-topbar__subtitle{color:#6b7280;font-size:.78rem}.teacher-topbar__badge{color:#2e7d32;background:#e8f5e9;border-radius:999px;align-items:center;gap:.35rem;padding:.36rem .65rem;font-size:.75rem;font-weight:700;display:inline-flex}.teacher-content{min-width:0;padding:1.5rem}@media (width<=900px){.teacher-layout__overlay{z-index:160;cursor:pointer;background:#03122673;border:none;display:block;position:fixed;inset:0}.teacher-sidebar{transition:transform .22s;transform:translate(-102%)}.teacher-layout--mobile-open .teacher-sidebar{transform:translate(0)}.teacher-sidebar__close{cursor:pointer;justify-content:center;align-items:center;display:inline-flex}.teacher-main{margin-left:0}.teacher-topbar__menu{display:inline-flex}}@media (width<=600px){.teacher-topbar__subtitle,.teacher-topbar__badge{display:none}.teacher-content{padding:1rem}}.editor-layout{background:#f4f8fc;min-height:100vh;display:flex;overflow-x:hidden}.editor-layout__overlay{display:none}.editor-sidebar{color:#dcecff;z-index:200;background:#1e1b4b;flex-direction:column;gap:1rem;width:260px;padding:1rem;display:flex;position:fixed;top:0;bottom:0;left:0}.editor-sidebar__brand{justify-content:space-between;align-items:center;display:flex}.editor-sidebar__logo-wrap{align-items:center;gap:.7rem;display:flex}.editor-sidebar__logo{border-radius:8px;width:36px;height:36px}.editor-sidebar__logo-wrap div{flex-direction:column;display:flex}.editor-sidebar__logo-wrap strong{color:#fff;font-size:.95rem}.editor-sidebar__logo-wrap span{color:#9fc1e4;font-size:.72rem}.editor-sidebar__close{color:#dcecff;background:0 0;display:none}.editor-sidebar__role-badge{color:#9fc1e4;background:#ffffff12;border:1px solid #ffffff1f;border-radius:10px;align-items:center;gap:.5rem;padding:.5rem .75rem;font-size:.8rem;display:flex}.editor-sidebar__role-badge strong{color:#ffd280;text-transform:uppercase;letter-spacing:.05em;font-size:.78rem}.editor-sidebar__nav{flex-direction:column;gap:.3rem;display:flex}.editor-sidebar__link{color:#ffffffbf;border-radius:10px;align-items:center;gap:.6rem;padding:.65rem .75rem;font-size:.9rem;text-decoration:none;transition:all .2s;display:flex}.editor-sidebar__link:hover{color:#fff;background:#ffffff14;text-decoration:none}.editor-sidebar__link--active{color:#fff;background:#4f46e5}.editor-sidebar__bottom{flex-direction:column;gap:.8rem;margin-top:auto;display:flex}.editor-sidebar__user{background:#ffffff14;border-radius:10px;align-items:center;gap:.6rem;padding:.65rem;display:flex}.editor-sidebar__avatar{color:#fff;background:#b45309;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:32px;height:32px;font-size:.85rem;font-weight:700;display:flex}.editor-sidebar__user strong{color:#fff;font-size:.85rem;display:block}.editor-sidebar__user span{color:#b8d1eb;font-size:.75rem;display:block}.editor-sidebar__logout{color:#dcecff;cursor:pointer;background:0 0;border:1px solid #fff3;border-radius:10px;justify-content:center;align-items:center;gap:.45rem;min-height:36px;font-size:.875rem;font-weight:600;display:flex}.editor-sidebar__logout:hover{background:#ffffff14}.editor-main{flex-direction:column;flex:1;min-width:0;min-height:100vh;margin-left:260px;display:flex}.editor-topbar{z-index:100;background:#fff;border-bottom:1px solid #e0e7ff;justify-content:space-between;align-items:center;gap:1rem;height:68px;padding:0 1.25rem;display:flex;position:sticky;top:0}.editor-topbar__menu{color:#1e1b4b;cursor:pointer;background:#f1f7ff;border:none;border-radius:8px;justify-content:center;align-items:center;width:34px;height:34px;display:none}.editor-topbar__meta{flex-direction:column;min-width:0;display:flex}.editor-topbar__title{color:#1e1b4b;font-size:.96rem;font-weight:700}.editor-topbar__subtitle{color:#6b7280;font-size:.78rem}.editor-topbar__badge{color:#b45309;background:#fff8e1;border-radius:999px;align-items:center;gap:.35rem;padding:.36rem .65rem;font-size:.75rem;font-weight:700;display:inline-flex}.editor-content{min-width:0;padding:1.5rem}@media (width<=900px){.editor-layout__overlay{z-index:160;cursor:pointer;background:#03122673;border:none;display:block;position:fixed;inset:0}.editor-sidebar{transition:transform .22s;transform:translate(-102%)}.editor-layout--mobile-open .editor-sidebar{transform:translate(0)}.editor-sidebar__close{cursor:pointer;justify-content:center;align-items:center;display:inline-flex}.editor-main{margin-left:0}.editor-topbar__menu{display:inline-flex}}@media (width<=600px){.editor-topbar__subtitle,.editor-topbar__badge{display:none}.editor-content{padding:1rem}}.public-layout{background:#fff;flex-direction:column;min-height:100vh;display:flex}.public-nav{z-index:100;background:#fff;border-bottom:1px solid #eef2ff;justify-content:space-between;align-items:center;gap:1rem;height:68px;padding:0 2rem;display:flex;position:sticky;top:0}.public-nav__brand{flex-shrink:0;align-items:center;gap:.65rem;text-decoration:none;display:flex}.public-nav__logo{border-radius:8px;width:36px;height:36px}.public-nav__brand-text{flex-direction:column;display:flex}.public-nav__brand-text strong{color:#1e1b4b;font-size:.95rem;font-weight:800;line-height:1.1}.public-nav__brand-text span{color:#6b7280;font-size:.68rem;font-weight:500}.public-nav__links{align-items:center;gap:.25rem;display:flex}.public-nav__link{color:#374151;border-radius:8px;padding:.45rem .75rem;font-size:.875rem;font-weight:500;text-decoration:none;transition:all .15s}.public-nav__link:hover{color:#1e1b4b;background:#f1f7ff;text-decoration:none}.public-nav__link--active{color:#4f46e5;background:#eef2ff;font-weight:600}.public-nav__actions{flex-shrink:0;align-items:center;gap:.5rem;display:flex}.public-nav__btn{cursor:pointer;border:none;border-radius:8px;align-items:center;gap:.4rem;padding:.45rem .9rem;font-size:.83rem;font-weight:600;text-decoration:none;transition:all .15s;display:inline-flex}.public-nav__btn--outline{color:#4f46e5;background:0 0;border:1.5px solid #c7d2fe}.public-nav__btn--outline:hover{background:#f0f8ff;text-decoration:none}.public-nav__btn--primary{color:#fff;background:#4f46e5}.public-nav__btn--primary:hover{background:#145a91;text-decoration:none}.public-nav__mobile-toggle{color:#1e1b4b;cursor:pointer;background:#f1f7ff;border:none;border-radius:8px;justify-content:center;align-items:center;width:36px;height:36px;display:none}.public-main{flex:1}.public-footer{color:#9fc1e4;background:#1e1b4b;padding:2.5rem 2rem 1.5rem}.public-footer__inner{grid-template-columns:1.5fr repeat(2,1fr);gap:2rem;max-width:1100px;margin:0 auto;display:grid}.public-footer__brand-text strong{color:#fff;margin-bottom:.35rem;font-size:1rem;font-weight:800;display:block}.public-footer__brand-text p{color:#7ea8cc;max-width:240px;margin:0;font-size:.82rem;line-height:1.6}.public-footer__col h4{color:#fff;margin:0 0 .75rem;font-size:.85rem;font-weight:700}.public-footer__col ul{flex-direction:column;gap:.4rem;margin:0;padding:0;list-style:none;display:flex}.public-footer__col ul li a{color:#7ea8cc;font-size:.82rem;text-decoration:none;transition:color .15s}.public-footer__col ul li a:hover{color:#fff}.public-footer__bottom{color:#5a82a8;border-top:1px solid #ffffff14;flex-wrap:wrap;justify-content:space-between;gap:.5rem;max-width:1100px;margin:2rem auto 0;padding-top:1.25rem;font-size:.78rem;display:flex}@media (width<=768px){.public-nav{padding:0 1rem}.public-nav__links{display:none}.public-nav__mobile-toggle{display:inline-flex}.public-footer__inner{grid-template-columns:1fr}}.landing-page{--mouse-x:50%;--mouse-y:45%;--mx-float:0px;--my-float:0px;background:radial-gradient(circle at 10% 10%,#60a5fa57,#0000 36%),radial-gradient(circle at 90% 0,#2563eb47,#0000 42%),linear-gradient(#eef2ff 0% 46%,#f8fcff 100%);min-height:100vh;padding-bottom:4rem;position:relative;overflow-x:hidden}.landing-page:before{content:"";background:radial-gradient(circle 360px at var(--mouse-x) var(--mouse-y), #60a5fa33, #60a5fa00 62%);pointer-events:none;z-index:1;transition:background-position .12s linear;position:absolute;inset:0}@keyframes landingReveal{0%{opacity:0;transform:translateY(20px)scale(.98)}to{opacity:1;transform:translateY(0)scale(1)}}@keyframes gradientShift{0%{background-position:0%}50%{background-position:100%}to{background-position:0%}}@keyframes softFloat{0%,to{transform:translateY(0)}50%{transform:translateY(-6px)}}@keyframes drift{0%{transform:translate(0,0)scale(1)}50%{transform:translate(16px,-14px)scale(1.04)}to{transform:translate(0,0)scale(1)}}@keyframes chipBounce{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@keyframes shimmerSweep{0%{transform:translate(-120%)skew(-15deg)}to{transform:translate(220%)skew(-15deg)}}@keyframes pulseGlow{0%,to{box-shadow:0 0 #2563eb57}50%{box-shadow:0 0 0 10px #2563eb00}}.landing-reveal{opacity:0;animation:.65s forwards landingReveal}.landing-reveal--top{animation-delay:20ms}.landing-reveal--left{animation-delay:60ms}.landing-reveal--right{animation-delay:.14s}.landing-bg-orb{filter:blur(70px);opacity:.35;pointer-events:none;z-index:0;border-radius:50%;width:420px;height:420px;position:absolute}.landing-bg-orb--left{translate:calc(var(--mx-float) * .45) calc(var(--my-float) * .45);background:#7ec3eb;animation:9s ease-in-out infinite drift;top:-120px;left:-120px}.landing-bg-orb--right{translate:calc(var(--mx-float) * -.4) calc(var(--my-float) * -.35);background:#9cc9ef;animation:11s ease-in-out infinite reverse drift;top:-180px;right:-130px}.landing-bg-orb--mid{opacity:.2;width:340px;height:340px;translate:calc(var(--mx-float) * .55) calc(var(--my-float) * -.4);background:#4295d6b3;animation:12s ease-in-out infinite drift;top:30%;left:42%}.landing-wa-float{z-index:999;flex-direction:column;align-items:flex-end;gap:.5rem;display:flex;position:fixed;bottom:1.5rem;right:1.5rem}.landing-wa-float__btn{color:#fff;cursor:pointer;background:#25d366;border-radius:50%;justify-content:center;align-items:center;width:52px;height:52px;transition:transform .2s,box-shadow .2s;display:flex;box-shadow:0 4px 16px #25d36666}.landing-wa-float__btn:hover{transform:scale(1.08);box-shadow:0 6px 20px #25d36680}.landing-wa-float__bubble{opacity:0;pointer-events:none;background:#fff;border:1px solid #e0e7ff;border-radius:12px;flex-direction:column;gap:.3rem;min-width:160px;padding:.65rem .9rem;transition:opacity .2s,transform .2s;display:flex;transform:translateY(6px);box-shadow:0 4px 20px #0000001a}.landing-wa-float:hover .landing-wa-float__bubble{opacity:1;pointer-events:auto;transform:translateY(0)}.landing-wa-float__label{color:#6b7280;text-transform:uppercase;letter-spacing:.06em;margin:0 0 2px;font-size:.7rem;font-weight:700}.landing-wa-float__bubble a{color:#25d366;font-size:.85rem;font-weight:700;text-decoration:none}.landing-wa-float__bubble a:hover{text-decoration:underline}.landing-topbar,.landing-main{z-index:2;width:min(1150px,100% - 2.5rem);margin:0 auto;position:relative}.landing-topbar{justify-content:space-between;align-items:center;padding-top:1.15rem;display:flex}.landing-brand{align-items:center;gap:.6rem;display:inline-flex}.landing-brand img{border-radius:10px;width:38px;height:38px}.landing-brand span{font-family:var(--font-heading);color:var(--color-navy);font-size:1.05rem;font-weight:800}.landing-topbar-actions{align-items:center;gap:.65rem;display:flex}.landing-btn{transition:transform var(--transition-fast), box-shadow var(--transition-fast), background var(--transition-fast);border:1px solid #0000;border-radius:999px;align-items:center;gap:.42rem;padding:.55rem 1rem;font-size:.9rem;font-weight:700;text-decoration:none;display:inline-flex}.landing-btn:hover{text-decoration:none;transform:translateY(-1px)}.landing-btn--primary{color:#fff;background:linear-gradient(135deg,#4f46e5,#6366f1,#4f46e5) 0 0/220% 220%;animation:7s infinite gradientShift;box-shadow:0 10px 20px #2563eb3d}.landing-btn--primary:hover{transform:translateY(-2px)scale(1.01);box-shadow:0 14px 28px #2563eb4d}.landing-btn--pulse{animation:2.6s infinite pulseGlow}.landing-btn--ghost{color:var(--color-navy);background:#ffffffa8;border-color:#2563eb38}.landing-btn--outline{color:var(--color-primary);background:#ffffffa6;border-color:#2563eb47}.landing-btn--lg{padding:.74rem 1.24rem;font-size:.95rem}.landing-main{flex-direction:column;gap:2.4rem;margin-top:2.2rem;display:flex}.landing-hero{grid-template-columns:.8fr 1.3fr;align-items:stretch;gap:1.35rem;display:grid}.landing-hero-copy{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);translate:calc(var(--mx-float) * .35) calc(var(--my-float) * .3);background:#ffffffbf;border:1px solid #2563eb29;border-radius:24px;align-self:stretch;padding:1.25rem 1.4rem;transition:translate .16s;box-shadow:0 14px 42px #1e1b4b1a}.landing-chip{color:#165f95;background:#eef2ff;border-radius:999px;align-items:center;gap:.4rem;padding:.28rem .65rem;font-size:.74rem;font-weight:700;animation:3.4s ease-in-out infinite softFloat;display:inline-flex}.landing-hero-copy h1{letter-spacing:-.02em;margin-top:.65rem;font-size:clamp(1.6rem,3.2vw,2.5rem);line-height:1.12}.landing-hero-copy h1 span{background:linear-gradient(120deg,#4f46e5,#818cf8 45%,#4f46e5) 0 0/200% 200%;color:#0000;-webkit-background-clip:text;background-clip:text;animation:8s infinite gradientShift}.landing-hero-copy p{color:#47698d;max-width:92%;margin-top:.6rem;font-size:.92rem}.landing-hero-ctas{flex-wrap:wrap;gap:.65rem;margin-top:.9rem;display:flex}.landing-hero-points{grid-template-columns:repeat(3,minmax(0,1fr));gap:.5rem;margin-top:.85rem;display:grid}.landing-hero-points div{color:#2f577f;opacity:0;background:#f4fafe;border:1px solid #e4f0fb;border-radius:10px;align-items:center;gap:.35rem;padding:.4rem .55rem;font-size:.74rem;font-weight:600;animation:.5s forwards chipBounce;display:inline-flex}.landing-hero-panel{color:#e0e7ff;translate:calc(var(--mx-float) * -.3) calc(var(--my-float) * -.25);background:linear-gradient(#1e1b4b,#312e81);border:1px solid #2563eb33;border-radius:24px;padding:1.6rem;transition:translate .16s;position:relative;overflow:hidden;box-shadow:0 18px 40px #1e1b4b42}.landing-hero-panel-glow{filter:blur(8px);background:radial-gradient(circle,#60a5fa6b,#0000 64%);border-radius:50%;width:220px;height:220px;position:absolute;top:-90px;right:-90px}.landing-panel-badge{z-index:2;color:#d5ebff;background:#ffffff1a;border-radius:999px;align-items:center;gap:.35rem;padding:.3rem .62rem;font-size:.73rem;font-weight:700;display:inline-flex;position:relative}.landing-hero-panel h3{color:#fff;margin:.82rem 0 0;font-size:1.2rem}.landing-panel-metrics{grid-template-columns:1fr;gap:.5rem;margin-top:.82rem;display:grid}.landing-panel-metric-card{background:#ffffff0f;border:1px solid #ffffff24;border-radius:12px;align-items:center;gap:.52rem;padding:.55rem .62rem;animation:4.2s ease-in-out infinite softFloat;display:flex}.landing-panel-metric-card:nth-child(2){animation-delay:.8s}.landing-panel-metric-card strong{color:#fff;font-size:.95rem;display:block}.landing-panel-metric-card span{color:#b7d4ee;font-size:.73rem}.landing-hero-panel ul{flex-direction:column;gap:.55rem;margin-top:.95rem;padding-left:1.05rem;display:flex}.landing-hero-panel li{font-size:.93rem}.landing-panel-rating{border-top:1px solid #ffffff29;margin-top:1.35rem;padding-top:1rem}.landing-panel-rating div{color:#ffd166;gap:.2rem;display:inline-flex}.landing-panel-rating p{color:#c7d2fe;margin-top:.35rem;font-size:.8rem}.landing-trust-strip{background:#e0f0ffe6;border:1px solid #c6def4;border-radius:999px;flex-wrap:wrap;justify-content:center;gap:.45rem;padding:.52rem .85rem;display:flex}.landing-trust-strip span{color:#164a76;opacity:0;background:#dcefff;border-radius:999px;padding:.28rem .62rem;font-size:.74rem;font-weight:700;animation:.5s forwards chipBounce}.landing-stats{grid-template-columns:repeat(3,minmax(0,1fr));gap:.8rem;display:grid}.landing-stat-card{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);transition:transform var(--transition-base), box-shadow var(--transition-base);background:#e4f2ffe6;border:1px solid #2563eb47;border-radius:16px;padding:1rem}.landing-stat-card:hover{transform:translateY(-4px);box-shadow:0 14px 24px #1e1b4b1c}.landing-stat-card h3{color:var(--color-primary);margin:0;font-size:1.5rem}.landing-stat-card h4{color:#21476d;margin-top:.2rem;font-size:.9rem}.landing-stat-card p{color:#6484a6;margin-top:.4rem;font-size:.77rem}.landing-section{box-shadow:var(--shadow-md);background:linear-gradient(#f9fafb,#eef2ff);border:1px solid #c9def2;border-radius:22px;padding:1.6rem}.landing-section-head h2{margin:0;font-size:clamp(1.35rem,2.4vw,1.85rem)}.landing-section-head p{color:#5b7ca0;margin-top:.45rem}.landing-features-grid{grid-template-columns:repeat(4,minmax(0,1fr));gap:.72rem;margin-top:1rem;display:grid}.landing-feature-card{transition:transform var(--transition-base), box-shadow var(--transition-base), border-color var(--transition-base);background:#eaf4ff;border:1px solid #cde1f3;border-radius:14px;padding:.85rem;position:relative;overflow:hidden}.landing-feature-card:after{content:"";pointer-events:none;background:linear-gradient(90deg,#0000,#ffffff8c,#0000);width:45%;height:100%;position:absolute;top:0;left:0;transform:translate(-120%)skew(-15deg)}.landing-feature-card:hover{border-color:#c8e0f5;transform:translateY(-6px);box-shadow:0 16px 24px #1e1b4b21}.landing-feature-card:hover:after{animation:.9s shimmerSweep}.landing-feature-icon{color:#4f46e5;background:#eef2ff;border-radius:10px;justify-content:center;align-items:center;width:36px;height:36px;display:inline-flex}.landing-feature-card h3{margin-top:.58rem;font-size:.94rem}.landing-feature-card p{color:#5c7da0;margin-top:.35rem;font-size:.82rem}.landing-demo-wrap{background:#deeeff;border:1px solid #bdd9f2;border-radius:18px;margin-top:1rem;position:relative;overflow:hidden;box-shadow:0 14px 30px #1e1b4b24}.landing-demo-wrap:after{content:"";pointer-events:none;border:1px solid #5faae666;border-radius:18px;animation:3s ease-in-out infinite pulseGlow;position:absolute;inset:0}.landing-demo-video{width:100%;max-height:540px;display:block}.landing-demo-points{grid-template-columns:repeat(3,minmax(0,1fr));gap:.6rem;margin-top:.9rem;display:grid}.landing-demo-points div{color:#28567f;background:#ebf5ff;border:1px solid #cfe2f4;border-radius:11px;align-items:center;gap:.35rem;padding:.5rem .62rem;font-size:.78rem;font-weight:600;display:inline-flex}.landing-testimonials-grid{grid-template-columns:repeat(3,minmax(0,1fr));gap:.8rem;margin-top:1rem;display:grid}.landing-testimonial-card{transition:transform var(--transition-base), box-shadow var(--transition-base);background:#eaf4ff;border:1px solid #c7d2fe;border-radius:16px;padding:1rem;position:relative;overflow:hidden}.landing-testimonial-card:before{content:"";opacity:.9;background:linear-gradient(#4f46e5,#818cf8);width:4px;height:100%;position:absolute;top:0;left:0}.landing-testimonial-card:hover{transform:translateY(-6px);box-shadow:0 16px 26px #1e1b4b1f}.landing-quote-icon{color:#818cf8}.landing-testimonial-quote{color:#1e40af;margin-top:.72rem;font-size:.88rem;line-height:1.55}.landing-testimonial-author{flex-direction:column;margin-top:.72rem;padding-left:2.15rem;display:flex;position:relative}.landing-testimonial-avatar{color:#4f46e5;background:#cfe7ff;border-radius:50%;justify-content:center;align-items:center;width:1.65rem;height:1.65rem;font-size:.82rem;font-weight:800;display:inline-flex;position:absolute;top:0;left:0}.landing-testimonial-author strong{color:#1d3a9a;font-size:.85rem}.landing-testimonial-author span{color:#4b5563;font-size:.75rem}.landing-testimonial-result{color:#4338ca;background:#eef2ff;border-radius:999px;margin-top:.45rem;padding:.28rem .56rem;font-size:.73rem;font-weight:700;display:inline-block}.landing-final-cta{color:#e0e7ff;text-align:center;translate:calc(var(--mx-float) * .15) calc(var(--my-float) * .1);background:linear-gradient(135deg,#1e1b4b 0%,#4338ca 50%,#7c3aed 100%) 0 0/220% 220%;border:1px solid #2563eb38;border-radius:24px;padding:2.1rem 1.1rem;transition:translate .18s;animation:9s infinite gradientShift;position:relative;overflow:hidden}.landing-final-cta:after{content:"";background:radial-gradient(circle,#60a5fa66,#0000 68%);border-radius:50%;width:220px;height:220px;animation:8s ease-in-out infinite drift;position:absolute;top:-80px;right:-80px}.landing-final-cta h2{color:#fff;margin:0}.landing-final-cta p{color:#c7d2fe;margin-top:.55rem}.landing-final-cta div{margin-top:1rem}@media (width<=1060px){.landing-hero{grid-template-columns:1fr}.landing-features-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.landing-testimonials-grid,.landing-demo-points{grid-template-columns:1fr}}@media (width<=760px){.landing-topbar,.landing-main{width:min(1150px,100% - 1.2rem)}.landing-hero-copy{padding:1.25rem}.landing-hero-copy p{max-width:100%}.landing-hero-points,.landing-stats,.landing-features-grid{grid-template-columns:1fr}.landing-topbar-actions{gap:.45rem}.landing-btn{padding:.52rem .8rem}}@media (pointer:coarse){.landing-page:before{display:none}.landing-hero-copy,.landing-hero-panel,.landing-final-cta,.landing-bg-orb--left,.landing-bg-orb--right,.landing-bg-orb--mid{transition:none;translate:0}}.landing-programs-grid{grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:20px;margin-top:8px;display:grid}.landing-program-card{background:#ffffff08;border:1px solid #ffffff14;border-radius:16px;flex-direction:column;gap:12px;padding:24px;display:flex}.landing-program-card__tag{color:#7ec8f0;letter-spacing:.06em;text-transform:uppercase;background:#2563eb40;border-radius:20px;width:fit-content;padding:3px 10px;font-size:11px;font-weight:700;display:inline-block}.landing-program-card h3{color:#fff;margin:0;font-size:1.1rem;font-weight:700}.landing-program-card p{color:#ffffff8c;margin:0;font-size:.85rem;line-height:1.55}.landing-program-card__meta{gap:12px;display:flex}.landing-program-card__meta span{color:#ffffff73;align-items:center;gap:5px;font-size:.78rem;display:flex}.landing-program-card__price{color:#ffffff80;font-size:.85rem}.landing-program-card__price strong{color:#7ec8f0;font-size:1rem}.landing-section-eyebrow{text-transform:uppercase;letter-spacing:.1em;color:#4f46e5;margin-bottom:.5rem;font-size:.72rem;font-weight:700;display:block}.landing-section-highlight{background:linear-gradient(120deg,#4f46e5,#7c3aed);color:#0000;-webkit-background-clip:text;background-clip:text}.landing-how-section{background:#fff;border:1px solid #e0e7ff;border-radius:24px;padding:3rem 2.5rem}.landing-how-steps{align-items:flex-start;gap:0;margin-top:2.5rem;display:flex}.landing-how-step{text-align:center;flex:1;padding:0 1rem;position:relative}.landing-how-step__icon{color:#4f46e5;background:linear-gradient(135deg,#eef2ff,#e0e7ff);border:2px solid #c7d2fe;border-radius:50%;justify-content:center;align-items:center;width:68px;height:68px;margin:0 auto .9rem;transition:transform .2s,box-shadow .2s;display:flex}.landing-how-step:hover .landing-how-step__icon{color:#fff;background:linear-gradient(135deg,#4f46e5,#7c3aed);border-color:#0000;transform:translateY(-4px);box-shadow:0 8px 20px #2563eb2e}.landing-how-step__label{text-transform:uppercase;letter-spacing:.08em;color:#4f46e5;margin-bottom:.4rem;font-size:.72rem;font-weight:700}.landing-how-step__title{color:#1e1b4b;margin:0 0 .4rem;font-size:1rem;font-weight:800}.landing-how-step__desc{color:#4b5563;margin:0;max-width:180px;margin-inline:auto;font-size:.83rem;line-height:1.6}.landing-how-connector{color:#818cf8;opacity:.7;flex-shrink:0;align-items:center;gap:3px;padding-top:34px;display:flex}.landing-how-connector span{background:currentColor;border-radius:50%;width:6px;height:6px;display:block}@media (width<=800px){.landing-how-steps{flex-direction:column;align-items:center;gap:1.5rem}.landing-how-connector{padding-top:0;transform:rotate(90deg)}.landing-how-step{width:100%;max-width:280px}}.landing-dashboard-section{padding-bottom:0}.landing-dashboard-frame{border:1px solid #c7d2fe;border-radius:20px;margin-top:2rem;position:relative;overflow:hidden;box-shadow:0 24px 60px #0f1f6a24}.landing-dashboard-frame__glow{pointer-events:none;background:radial-gradient(at 80% 10%,#7c3aed0f,#0000 60%);border-radius:20px;position:absolute;inset:0}.landing-dashboard-img{border-radius:20px;width:100%;display:block}.landing-dashboard-mockup{min-height:340px;font-family:var(--font-body);background:#1e1b4b;display:flex}.landing-db-sidebar{background:#0a1852;flex-direction:column;flex-shrink:0;gap:.25rem;width:140px;padding:1.2rem .75rem;display:flex}.landing-db-logo{background:linear-gradient(135deg,#4f46e5,#7c3aed);border-radius:8px;width:32px;height:32px;margin-bottom:1.2rem}.landing-db-nav-item{color:#ffffff80;cursor:default;border-radius:7px;padding:.42rem .6rem;font-size:.72rem;font-weight:600}.landing-db-nav-item--active{color:#818cf8;background:#2563eb40}.landing-db-main{background:#f9fafb;flex-direction:column;flex:1;gap:1rem;padding:1.4rem 1.5rem;display:flex}.landing-db-header{justify-content:space-between;align-items:flex-start;display:flex}.landing-db-greeting{color:#1e1b4b;font-size:.95rem;font-weight:700}.landing-db-sub{color:#4b5563;margin-top:2px;font-size:.75rem}.landing-db-streak{color:#c2410c;background:#fff7ed;border:1px solid #fed7aa;border-radius:99px;padding:.3rem .65rem;font-size:.78rem;font-weight:700}.landing-db-cards{grid-template-columns:repeat(4,1fr);gap:.75rem;display:grid}.landing-db-card{background:#fff;border:1px solid #e0e7ff;border-radius:10px;flex-direction:column;gap:.2rem;padding:.75rem .9rem;display:flex}.landing-db-card--live{background:#f0fdf4;border-color:#bbf7d0;position:relative}.landing-db-live-dot{background:#16a34a;border-radius:50%;width:8px;height:8px;margin-bottom:.2rem;animation:1.5s ease-out infinite pulseRing}.landing-db-card__label{color:#4b5563;text-transform:uppercase;letter-spacing:.04em;font-size:.68rem;font-weight:600}.landing-db-card__value{color:#1e1b4b;font-size:1.3rem;font-weight:800;line-height:1}.landing-db-card--live .landing-db-card__value{color:#15803d;font-size:.8rem}.landing-db-card__sub{color:#9ca3af;font-size:.68rem}.landing-db-ring{width:52px;height:52px;margin:.2rem 0;position:relative}.landing-db-ring svg{width:100%;height:100%}.landing-db-ring span{color:#1e1b4b;justify-content:center;align-items:center;font-size:.82rem;font-weight:800;display:flex;position:absolute;inset:0}.landing-db-card--progress{align-items:flex-start}.landing-db-today{background:#fff;border:1px solid #e0e7ff;border-radius:10px;padding:.75rem 1rem}.landing-db-today__label{color:#1e1b4b;text-transform:uppercase;letter-spacing:.05em;margin-bottom:.6rem;font-size:.72rem;font-weight:700}.landing-db-task{color:#4b5563;border-bottom:1px solid #eef2ff;align-items:center;gap:.55rem;padding:.3rem 0;font-size:.78rem;display:flex}.landing-db-task:last-child{border-bottom:none}.landing-db-task__dot{border:2px solid #c7d2fe;border-radius:50%;flex-shrink:0;width:10px;height:10px}.landing-db-task__dot--done{background:#16a34a;border-color:#16a34a}@media (width<=700px){.landing-db-sidebar{display:none}.landing-db-cards{grid-template-columns:repeat(2,1fr)}}.landing-about-section{background:linear-gradient(135deg,#eef2ff 0%,#f9fafb 100%);border:1px solid #e0e7ff;border-radius:24px}.landing-about-inner{grid-template-columns:1fr 1fr;align-items:start;gap:3rem;display:grid}.landing-about-text h2{color:#1e1b4b;margin:.6rem 0 1rem;font-size:clamp(1.4rem,2.8vw,2rem);font-weight:900;line-height:1.2}.landing-about-text p{color:#4b5563;margin:0 0 .9rem;font-size:.9rem;line-height:1.75}.landing-about-stats{border-top:1px solid #e0e7ff;flex-wrap:wrap;gap:1.5rem;margin-top:1.5rem;padding-top:1.5rem;display:flex}.landing-about-stats>div{flex-direction:column;gap:.15rem;display:flex}.landing-about-stats strong{color:#1e1b4b;font-size:1.4rem;font-weight:900}.landing-about-stats span{color:#4b5563;font-size:.75rem;font-weight:500}.landing-about-values{flex-direction:column;gap:1rem;display:flex}.landing-about-value-card{background:#fff;border:1px solid #e0e7ff;border-radius:14px;flex-direction:column;gap:.35rem;padding:1.1rem 1.25rem;transition:box-shadow .18s;display:flex}.landing-about-value-card:hover{box-shadow:0 6px 20px #2563eb1a}.landing-about-value-card__icon{color:#4f46e5;background:linear-gradient(135deg,#eef2ff,#e0e7ff);border-radius:10px;justify-content:center;align-items:center;width:38px;height:38px;margin-bottom:.2rem;display:flex}.landing-about-value-card h4{color:#1e1b4b;margin:0;font-size:.92rem;font-weight:800}.landing-about-value-card p{color:#4b5563;margin:0;font-size:.8rem;line-height:1.6}@media (width<=750px){.landing-about-inner{grid-template-columns:1fr;gap:2rem}}.landing-hero-dashboard{translate:calc(var(--mx-float) * -.3) calc(var(--my-float) * -.25);border:1px solid #2563eb33;border-radius:20px;align-self:stretch;transition:translate .16s;position:relative;overflow:hidden;box-shadow:0 24px 60px #0f1f6a38,0 4px 16px #0f1f6a1f}.landing-hero-dashboard__img{object-fit:cover;object-position:top left;width:100%;height:100%;display:block}.landing-hero-dashboard__glow{pointer-events:none;z-index:1;background:radial-gradient(at 80% 10%,#7c3aed14,#0000 60%);border-radius:20px;position:absolute;inset:0}.lsg-wrap{border:1px solid #e0e7ff;border-radius:16px;align-items:stretch;width:100%;margin:0 0 1rem;display:flex;overflow:hidden;box-shadow:0 4px 24px #4f46e512}.lsg-left{background:#eef2ff;flex-direction:row;flex-shrink:0;align-items:flex-start;gap:1.25rem;width:420px;padding:2rem 1.75rem 1.5rem;display:flex}.lsg-cal{background:#4f46e5;border-radius:14px;flex-shrink:0;width:90px;height:96px;padding:10px 8px 8px;position:relative;overflow:visible;box-shadow:0 8px 20px #4f46e559}.lsg-cal__header{background:#ffffff40;border-radius:4px;height:10px;margin-bottom:7px}.lsg-cal__body{grid-template-columns:repeat(5,1fr);gap:4px;display:grid}.lsg-cal__cell{background:#ffffff4d;border-radius:3px;height:10px}.lsg-cal__cell:first-child,.lsg-cal__cell:nth-child(3),.lsg-cal__cell:nth-child(6),.lsg-cal__cell:nth-child(11){background:#ffffffa6}.lsg-cal__badge{color:#fff;background:#4f46e5;border:3px solid #eef2ff;border-radius:50%;justify-content:center;align-items:center;width:30px;height:30px;display:flex;position:absolute;bottom:-10px;right:-10px;box-shadow:0 2px 8px #4f46e566}.lsg-left-text{flex-direction:column;gap:.5rem;padding-top:.1rem;display:flex}.lsg-badge{color:#4f46e5;text-transform:uppercase;letter-spacing:.06em;align-items:center;gap:.3rem;width:fit-content;font-size:.67rem;font-weight:700;display:inline-flex}.lsg-title{color:#1e1b4b;margin:0;font-size:1.1rem;font-weight:800;line-height:1.3}.lsg-sub{color:#6b7280;margin:0;font-size:.78rem;line-height:1.55}.lsg-arrow{opacity:.75;align-self:flex-end;width:72px;margin-top:.25rem}.lsg-form{background:#fff;flex-direction:column;flex:1;justify-content:center;gap:1rem;padding:1.75rem 2rem;display:flex}.lsg-fields{grid-template-columns:repeat(4,1fr);gap:.9rem;display:grid}.lsg-field{flex-direction:column;gap:.3rem;display:flex}.lsg-label{color:#6b7280;font-size:.72rem;font-weight:600}.lsg-select{color:#1e1b4b;cursor:pointer;appearance:auto;background:#fff;border:1px solid #e0e7ff;border-radius:8px;outline:none;width:100%;padding:.55rem .75rem;font-family:inherit;font-size:.84rem;transition:border-color .15s}.lsg-select:focus{border-color:#4f46e5}.lsg-btn{color:#fff;cursor:pointer;background:#4f46e5;border:none;border-radius:9px;width:100%;padding:.75rem;font-size:.9rem;font-weight:700;transition:background .15s}.lsg-btn:hover{background:#4338ca}.lsg-footnote{color:#4f46e5;justify-content:center;align-items:center;gap:.3rem;margin:0;font-size:.72rem;display:flex}@media (width<=900px){.lsg-left{width:340px}.lsg-fields{grid-template-columns:1fr 1fr}}@media (width<=680px){.lsg-wrap{flex-direction:column}.lsg-left{width:100%}.lsg-arrow{display:none}}.public-hero{color:#fff;text-align:center;background:linear-gradient(140deg,#1e1b4b 0%,#4f46e5 60%,#7c3aed 100%);padding:5rem 2rem 4rem;position:relative;overflow:hidden}.public-hero:before{content:"";background:radial-gradient(at 70%,#ffffff0f 0%,#0000 70%);position:absolute;inset:0}.public-hero__inner{z-index:1;max-width:780px;margin:0 auto;position:relative}.public-hero__eyebrow{letter-spacing:.06em;text-transform:uppercase;color:#9dd4ff;background:#ffffff1f;border:1px solid #fff3;border-radius:999px;align-items:center;gap:.4rem;margin-bottom:1.5rem;padding:.35rem .85rem;font-size:.78rem;font-weight:600;display:inline-flex}.public-hero__title{color:#fff;margin:0 0 1rem;font-size:clamp(2rem,5vw,3.2rem);font-weight:900;line-height:1.12}.public-hero__title span{color:#7ecfff}.public-hero__subtitle{color:#fffc;max-width:560px;margin:0 auto 2.5rem;font-size:1.05rem;line-height:1.7}.public-hero__actions{flex-wrap:wrap;justify-content:center;gap:1rem;display:flex}.public-hero__btn{cursor:pointer;border:none;border-radius:10px;align-items:center;gap:.5rem;padding:.8rem 1.75rem;font-size:.95rem;font-weight:700;text-decoration:none;transition:all .18s;display:inline-flex}.public-hero__btn--primary{color:#1e1b4b;background:#fff;box-shadow:0 4px 20px #0003}.public-hero__btn--primary:hover{color:#1e1b4b;text-decoration:none;transform:translateY(-2px);box-shadow:0 8px 28px #00000047}.public-hero__btn--outline{color:#fff;background:#ffffff1a;border:1.5px solid #ffffff59}.public-hero__btn--outline:hover{color:#fff;background:#ffffff2e;text-decoration:none}.public-section{padding:4rem 2rem}.public-section--alt{background:#f9fafb}.public-section__inner{max-width:1100px;margin:0 auto}.public-section__header{text-align:center;margin-bottom:2.5rem}.public-section__eyebrow{color:#4f46e5;text-transform:uppercase;letter-spacing:.08em;margin-bottom:.5rem;font-size:.75rem;font-weight:700;display:inline-block}.public-section__title{color:#1e1b4b;margin:0 0 .6rem;font-size:clamp(1.5rem,3vw,2.1rem);font-weight:800}.public-section__desc{color:#4b5563;max-width:540px;margin:0 auto;font-size:.97rem;line-height:1.7}.public-card-grid{gap:1.25rem;display:grid}.public-card-grid--2{grid-template-columns:repeat(2,1fr)}.public-card-grid--3{grid-template-columns:repeat(3,1fr)}.public-card-grid--4{grid-template-columns:repeat(4,1fr)}.public-card{background:#fff;border:1px solid #e0e7ff;border-radius:16px;padding:1.5rem}.public-card--hover{transition:transform .18s,box-shadow .18s}.public-card--hover:hover{transform:translateY(-3px);box-shadow:0 12px 28px #2563eb1f}.public-product-card{background:#fff;border:1px solid #e0e7ff;border-radius:16px;gap:1.1rem;padding:1.75rem;transition:box-shadow .18s;display:grid}.public-product-card:hover{box-shadow:0 8px 24px #2563eb1f}.public-product-card__badge{text-transform:uppercase;letter-spacing:.06em;color:#4f46e5;background:#eef2ff;border-radius:999px;align-items:center;gap:.3rem;padding:.25rem .6rem;font-size:.72rem;font-weight:700;display:inline-flex}.public-product-card__name{color:#1e1b4b;margin:0;font-size:1.2rem;font-weight:800}.public-product-card__desc{color:#4b5563;margin:0;font-size:.88rem;line-height:1.65}.public-product-card__pricing{flex-wrap:wrap;gap:1rem;display:flex}.public-product-card__price-block{background:#f4f9ff;border:1px solid #d6e9fa;border-radius:10px;padding:.6rem .9rem}.public-product-card__price-label{color:#6b7280;text-transform:uppercase;letter-spacing:.05em;font-size:.7rem;font-weight:600;display:block}.public-product-card__price-value{color:#1e1b4b;font-size:1.3rem;font-weight:800}.public-product-card__price-value span{color:#6b7280;font-size:.8rem;font-weight:500}.public-product-card__features{gap:.45rem;margin:0;padding:0;list-style:none;display:grid}.public-product-card__features li{color:#374151;align-items:center;gap:.5rem;font-size:.87rem;display:flex}.public-product-card__features li svg{color:#16a34a;flex-shrink:0}.public-product-card__cta{color:#fff;cursor:pointer;background:#4f46e5;border:none;border-radius:10px;justify-content:center;align-items:center;gap:.5rem;padding:.7rem 1.25rem;font-size:.9rem;font-weight:700;text-decoration:none;transition:background .15s;display:inline-flex}.public-product-card__cta:hover{color:#fff;background:#145a91;text-decoration:none}.public-steps{grid-template-columns:repeat(3,1fr);gap:1.5rem;display:grid}.public-step{text-align:center;padding:1.5rem 1rem}.public-step__num{color:#fff;background:#4f46e5;border-radius:50%;justify-content:center;align-items:center;width:48px;height:48px;margin:0 auto 1rem;font-size:1.1rem;font-weight:800;display:flex}.public-step__title{color:#1e1b4b;margin:0 0 .4rem;font-size:1rem;font-weight:700}.public-step__desc{color:#4b5563;margin:0;font-size:.87rem;line-height:1.6}.public-feature-card{background:#fff;border:1px solid #e0e7ff;border-radius:14px;flex-direction:column;gap:.7rem;padding:1.5rem;display:flex}.public-feature-card__icon{color:#4f46e5;background:#eef2ff;border-radius:12px;justify-content:center;align-items:center;width:44px;height:44px;display:flex}.public-feature-card__title{color:#1e1b4b;margin:0;font-size:.97rem;font-weight:700}.public-feature-card__desc{color:#4b5563;margin:0;font-size:.85rem;line-height:1.6}.public-testimonial{background:#fff;border:1px solid #e0e7ff;border-radius:14px;padding:1.5rem}.public-testimonial__quote{color:#374151;margin:0 0 1rem;font-size:.9rem;font-style:italic;line-height:1.7}.public-testimonial__author{align-items:center;gap:.6rem;display:flex}.public-testimonial__avatar{color:#fff;background:#4f46e5;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;font-size:.85rem;font-weight:700;display:flex}.public-testimonial__name{color:#1e1b4b;margin:0;font-size:.88rem;font-weight:700}.public-testimonial__role{color:#6b7280;margin:0;font-size:.78rem}.public-cta-banner{text-align:center;color:#fff;background:linear-gradient(135deg,#1e1b4b 0%,#4f46e5 55%,#7c3aed 100%);padding:3.5rem 2rem}.public-cta-banner h2{margin:0 0 .75rem;font-size:clamp(1.4rem,3vw,2rem);font-weight:800}.public-cta-banner p{color:#fffc;margin:0 0 2rem;font-size:.97rem}.public-page-hero{text-align:center;background:linear-gradient(140deg,#1e1b4b 0%,#4f46e5 60%,#7c3aed 100%);padding:3.5rem 2rem}.public-page-hero h1{color:#fff;margin:0 0 .6rem;font-size:clamp(1.6rem,4vw,2.5rem);font-weight:900}.public-page-hero p{color:#fffc;max-width:480px;margin:0 auto;font-size:.97rem;line-height:1.65}.public-contact-grid{grid-template-columns:1.2fr 1fr;align-items:start;gap:3rem;display:grid}.public-contact-form{gap:1rem;display:grid}.public-form-field{gap:.4rem;display:grid}.public-form-label{color:#3730a3;font-size:.85rem;font-weight:600}.public-form-input,.public-form-textarea{color:#1e1b4b;box-sizing:border-box;background:#f9fafb;border:1.5px solid #c7d2fe;border-radius:10px;outline:none;width:100%;padding:.65rem .9rem;font-family:inherit;font-size:.9rem;transition:border-color .15s,box-shadow .15s}.public-form-input:focus,.public-form-textarea:focus{background:#fff;border-color:#4f46e5;box-shadow:0 0 0 3px #2563eb1a}.public-form-textarea{resize:vertical;min-height:120px}.public-form-submit{color:#fff;cursor:pointer;background:#4f46e5;border:none;border-radius:10px;align-items:center;gap:.5rem;padding:.75rem 1.5rem;font-size:.95rem;font-weight:700;transition:background .15s;display:inline-flex}.public-form-submit:hover{background:#145a91}.public-form-submit:disabled{opacity:.65;cursor:not-allowed}.public-contact-info{gap:1rem;display:grid}.public-contact-info-card{background:#fff;border:1px solid #e0e7ff;border-radius:12px;align-items:flex-start;gap:.75rem;padding:1rem 1.25rem;display:flex}.public-contact-info-card__icon{color:#4f46e5;background:#eef2ff;border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;display:flex}.public-contact-info-card__label{color:#6b7280;text-transform:uppercase;letter-spacing:.04em;margin-bottom:.15rem;font-size:.75rem;font-weight:600}.public-contact-info-card__value{color:#1e1b4b;font-size:.9rem;font-weight:600}.public-faq-category{margin-bottom:2.5rem}.public-faq-category h3{color:#4f46e5;text-transform:uppercase;letter-spacing:.05em;margin:0 0 .75rem;font-size:.82rem;font-weight:700}.public-faq-item{background:#fff;border:1px solid #e0e7ff;border-radius:12px;margin-bottom:.5rem;overflow:hidden}.public-faq-item__trigger{cursor:pointer;text-align:left;color:#1e1b4b;background:0 0;border:none;justify-content:space-between;align-items:center;gap:1rem;width:100%;padding:1rem 1.25rem;font-size:.93rem;font-weight:600;transition:background .15s;display:flex}.public-faq-item__trigger:hover{background:#f9fafb}.public-faq-item__chevron{color:#6b7280;flex-shrink:0;transition:transform .2s}.public-faq-item--open .public-faq-item__chevron{transform:rotate(180deg)}.public-faq-item__body{color:#4b5563;padding:0 1.25rem 1rem;font-size:.88rem;line-height:1.7}@media (width<=900px){.public-card-grid--3,.public-card-grid--4{grid-template-columns:1fr 1fr}.public-steps,.public-contact-grid{grid-template-columns:1fr}}@media (width<=600px){.public-section{padding:2.5rem 1rem}.public-hero{padding:3rem 1rem}.public-card-grid--2,.public-card-grid--3,.public-card-grid--4{grid-template-columns:1fr}}.product-detail-page{flex-direction:column;gap:28px;max-width:900px;margin:0 auto;padding:32px 20px;display:flex}.product-hero{color:#fff;background:linear-gradient(135deg,#1e1b4b 0%,#4f46e5 55%,#7c3aed 100%);border-radius:18px;padding:36px 32px}.product-hero h1{margin:0 0 8px;font-size:1.6rem;font-weight:800}.product-hero p{opacity:.85;margin:0 0 20px;font-size:.9rem;line-height:1.6}.product-hero-stats{flex-wrap:wrap;gap:20px;display:flex}.product-hero-stat{opacity:.9;align-items:center;gap:6px;font-size:.82rem;font-weight:600;display:flex}.product-pricing-card{background:#fff;border:1px solid #e0e7ff;border-radius:16px;padding:24px}.product-pricing-card h2{color:#1e1b4b;margin:0 0 16px;font-size:1.05rem;font-weight:800}.pricing-toggle{background:#f0f4f8;border-radius:10px;gap:4px;width:fit-content;margin-bottom:20px;padding:4px;display:flex}.pricing-toggle__btn{cursor:pointer;color:#4b5563;background:0 0;border:none;border-radius:8px;padding:7px 20px;font-size:.85rem;font-weight:600;transition:all .15s}.pricing-toggle__btn--active{color:#1e1b4b;background:#fff;box-shadow:0 1px 4px #0000001a}.pricing-option-card{background:#f9fafb;border:1px solid #e0e7ff;border-radius:12px;margin-bottom:12px;padding:16px 18px}.pricing-option-card__price{color:#1e1b4b;margin:0;font-size:1.6rem;font-weight:900}.pricing-option-card__price span{color:#6b7280;font-size:.85rem;font-weight:500}.pricing-option-card__note{color:#4b5563;margin:4px 0 0;font-size:.78rem}.coupon-input-row{gap:8px;margin-bottom:16px;display:flex}.coupon-input{text-transform:uppercase;letter-spacing:.04em;color:#1e1b4b;border:1px solid #c7d2fe;border-radius:8px;flex:1;padding:9px 14px;font-size:.87rem}.coupon-input:focus{border-color:#4f46e5;outline:none}.coupon-apply-btn{color:#4f46e5;cursor:pointer;white-space:nowrap;background:#eef2ff;border:1px solid #c7d2fe;border-radius:8px;padding:9px 16px;font-size:.85rem;font-weight:700}.coupon-apply-btn:hover{background:#d8eafe}.coupon-discount{color:#16a34a;align-items:center;gap:6px;margin-bottom:12px;font-size:.82rem;font-weight:600;display:flex}.coupon-error{color:#dc2626;margin-bottom:12px;font-size:.82rem}.product-pricing-actions{flex-wrap:wrap;gap:10px;display:flex}.product-enroll-btn{color:#fff;cursor:pointer;text-align:center;background:#4f46e5;border:none;border-radius:11px;flex:1;justify-content:center;align-items:center;gap:8px;padding:13px 24px;font-size:.95rem;font-weight:800;text-decoration:none;display:flex}.product-enroll-btn:hover{background:#3730a3}.product-demo-btn{color:#4f46e5;cursor:pointer;text-align:center;white-space:nowrap;background:#fff;border:1px solid #c7d2fe;border-radius:11px;align-items:center;gap:8px;padding:13px 24px;font-size:.95rem;font-weight:700;text-decoration:none;display:flex}.product-demo-btn:hover{background:#f9fafb}.checkout-page{grid-template-columns:1fr 1.1fr;gap:24px;max-width:900px;margin:0 auto;display:grid}@media (width<=700px){.checkout-page{grid-template-columns:1fr}}.checkout-page h1{color:#1e1b4b;grid-column:1/-1;margin:0 0 20px;font-size:1.2rem;font-weight:800}.checkout-summary{background:#fff;border:1px solid #e0e7ff;border-radius:14px;padding:22px}.checkout-summary h2{color:#1e1b4b;margin:0 0 14px;font-size:.95rem;font-weight:700}.checkout-line{color:#374151;border-bottom:1px solid #f9fafb;justify-content:space-between;padding:7px 0;font-size:.85rem;display:flex}.checkout-line:last-of-type{color:#1e1b4b;border-bottom:none;font-size:.95rem;font-weight:700}.checkout-line--discount{color:#16a34a}.checkout-features{border-top:1px solid #eef2ff;margin-top:14px;padding-top:14px}.checkout-feature{color:#374151;align-items:center;gap:8px;padding:4px 0;font-size:.8rem;display:flex}.checkout-form-card{background:#fff;border:1px solid #e0e7ff;border-radius:14px;padding:22px}.checkout-form-card h2{color:#1e1b4b;margin:0 0 16px;font-size:.95rem;font-weight:700}.checkout-form-field{margin-bottom:14px}.checkout-form-field label{color:#374151;margin-bottom:5px;font-size:.78rem;font-weight:600;display:block}.checkout-form-input{color:#1e1b4b;box-sizing:border-box;border:1px solid #c7d2fe;border-radius:8px;width:100%;padding:9px 12px;font-size:.87rem}.checkout-form-input:focus{border-color:#4f46e5;outline:none}.checkout-form-row{grid-template-columns:1fr 1fr;gap:10px;display:grid}.checkout-submit-btn{color:#fff;cursor:pointer;background:#4f46e5;border:none;border-radius:10px;width:100%;margin-top:6px;padding:13px;font-size:.95rem;font-weight:800;transition:background .15s}.checkout-submit-btn:hover{background:#3730a3}.checkout-submit-btn:disabled{opacity:.6;cursor:not-allowed}.checkout-cancel{text-align:center;color:#6b7280;margin-top:10px;font-size:.82rem;text-decoration:none;display:block}.checkout-cancel:hover{color:#374151}.payment-success-page{justify-content:center;align-items:center;min-height:60vh;padding:2rem;display:flex}.payment-success-card{text-align:center;background:#fff;border:1px solid #e0e7ff;border-radius:20px;width:100%;max-width:460px;padding:52px 40px;box-shadow:0 4px 24px #1e1b4b0f}.payment-success-check{color:#16a34a;background:#dcfce7;border:3px solid #16a34a;border-radius:50%;justify-content:center;align-items:center;width:72px;height:72px;margin:0 auto 20px;animation:.4s popIn;display:flex}@keyframes popIn{0%{opacity:0;transform:scale(.5)}80%{transform:scale(1.1)}to{opacity:1;transform:scale(1)}}.payment-success-card h1{color:#1e1b4b;margin:0 0 6px;font-size:1.5rem;font-weight:800}.payment-success-card p{color:#4b5563;margin:0 0 4px;font-size:.87rem}.payment-success-card__actions{flex-wrap:wrap;justify-content:center;gap:10px;margin-top:24px;display:flex}.billing-page{flex-direction:column;gap:20px;display:flex}.billing-plan-card{background:#fff;border:1px solid #e0e7ff;border-radius:14px;padding:22px}.billing-plan-card h2{color:#1e1b4b;margin:0 0 16px;font-size:1rem;font-weight:800}.billing-plan-meta{grid-template-columns:repeat(3,1fr);gap:14px;margin-bottom:16px;display:grid}@media (width<=600px){.billing-plan-meta{grid-template-columns:1fr}}.billing-meta-item{background:#f9fafb;border:1px solid #eef2ff;border-radius:10px;padding:12px 14px}.billing-meta-item label{color:#6b7280;text-transform:uppercase;letter-spacing:.05em;margin-bottom:4px;font-size:.72rem;font-weight:700;display:block}.billing-meta-item p{color:#1e1b4b;margin:0;font-size:.9rem;font-weight:700}.billing-status-chip{border-radius:99px;align-items:center;gap:5px;padding:4px 10px;font-size:.72rem;font-weight:700;display:inline-flex}.billing-status-chip--active{color:#15803d;background:#dcfce7}.billing-status-chip--paused{color:#854d0e;background:#fef9c3}.billing-status-chip--cancelled{color:#991b1b;background:#fee2e2}.billing-history-table{border-collapse:collapse;width:100%;font-size:.85rem}.billing-history-table th{text-align:left;color:#6b7280;text-transform:uppercase;letter-spacing:.05em;border-bottom:1px solid #eef2ff;padding:8px 12px;font-size:.72rem;font-weight:700}.billing-history-table td{color:#374151;border-bottom:1px solid #f9fafb;padding:10px 12px}.billing-history-table tr:last-child td{border-bottom:none}.billing-cancel-section{border-top:1px solid #fee2e2;margin-top:4px;padding-top:16px}.billing-cancel-btn{color:#dc2626;cursor:pointer;background:#fff;border:1px solid #fca5a5;border-radius:9px;align-items:center;gap:7px;padding:9px 18px;font-size:.85rem;font-weight:700;display:inline-flex}.billing-cancel-btn:hover{background:#fee2e2}.auth-success{border-radius:var(--radius-md);padding:var(--space-3) var(--space-4);font-size:var(--text-sm);color:#1e874b;margin-bottom:var(--space-4);background:#27ae6014;border:1px solid #27ae6040;font-weight:500}@media (width<=768px){.auth-left{display:none}.auth-right{padding:var(--space-8) var(--space-6)}.auth-right--scroll{padding-top:var(--space-8)}}@media (width<=480px){.auth-right{padding:var(--space-5) var(--space-3)}.auth-form-title{font-size:var(--text-2xl)}.auth-btn{height:46px;font-size:var(--text-sm)}}.onboarding-container{min-height:100vh;padding:var(--space-8);background:linear-gradient(135deg,#eef2ff 0%,#f9fafb 100%);justify-content:center;align-items:center;display:flex}.onboarding-card{background:var(--color-white);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);width:100%;max-width:600px;overflow:hidden}.onboarding-header{padding:var(--space-8);border-bottom:1px solid var(--color-border-light);justify-content:space-between;align-items:center;display:flex}.onboarding-logo{align-items:center;gap:var(--space-3);font-family:var(--font-heading);font-size:var(--text-lg);color:var(--color-navy);font-weight:700;display:flex}.onboarding-logo img{width:32px;height:32px}.onboarding-logo em{color:var(--color-primary);font-style:normal}.onboarding-step-label{font-size:var(--text-sm);color:var(--color-text-muted);font-weight:500}.onboarding-progress-track{background:var(--color-border-light);height:4px;position:relative}.onboarding-progress-fill{background:var(--color-primary);height:100%;transition:width .4s}.onboarding-content{padding:var(--space-12) var(--space-8);min-height:400px}.onboarding-step{animation:.3s fadeIn}.step-icon{color:var(--color-primary);margin-bottom:var(--space-4)}.onboarding-step h2{font-size:var(--text-2xl);margin-bottom:var(--space-2);color:var(--color-navy)}.step-subtitle{color:var(--color-text-secondary);margin-bottom:var(--space-8);line-height:1.5}.exam-options{gap:var(--space-3);flex-direction:column;display:flex}.exam-option{align-items:center;gap:var(--space-4);padding:var(--space-5);border:2px solid var(--color-border);border-radius:var(--radius-md);background:var(--color-white);cursor:pointer;transition:all var(--transition-fast);font-size:var(--text-base);color:var(--color-text-primary);display:flex}.exam-option:hover{border-color:var(--color-primary-light);background:var(--color-primary-surface)}.exam-option.active{border-color:var(--color-primary);background:var(--color-primary-surface)}.exam-radio{border:2px solid var(--color-border);width:20px;height:20px;transition:all var(--transition-fast);border-radius:50%;position:relative}.exam-option.active .exam-radio{border-color:var(--color-primary)}.exam-option.active .exam-radio:after{content:"";background:var(--color-primary);border-radius:50%;width:10px;height:10px;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.date-input-wrap{margin-top:var(--space-6)}.date-input{width:100%;padding:var(--space-4);border:2px solid var(--color-border);border-radius:var(--radius-md);font-size:var(--text-base);font-family:var(--font-body);color:var(--color-text-primary);transition:border-color var(--transition-fast)}.date-input:focus{border-color:var(--color-primary);outline:none}.slider-wrap{margin-top:var(--space-8);text-align:center}.hour-slider{background:var(--color-border-light);-webkit-appearance:none;border-radius:3px;outline:none;width:100%;height:6px}.hour-slider::-webkit-slider-thumb{-webkit-appearance:none;background:var(--color-primary);cursor:pointer;border-radius:50%;width:20px;height:20px}.hour-slider::-moz-range-thumb{background:var(--color-primary);cursor:pointer;border:none;border-radius:50%;width:20px;height:20px}.slider-value{margin-top:var(--space-4);font-size:var(--text-2xl);color:var(--color-primary);font-weight:700}.study-days-options{gap:var(--space-3);margin-top:var(--space-6);flex-direction:column;display:flex}.study-day-option{align-items:center;gap:var(--space-3);padding:var(--space-4);border:2px solid var(--color-border);border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast);display:flex}.study-day-option:hover{border-color:var(--color-primary-light);background:var(--color-primary-surface)}.study-day-option input[type=radio]{width:18px;height:18px;accent-color:var(--color-primary)}.subject-grid{gap:var(--space-3);margin-top:var(--space-6);grid-template-columns:repeat(auto-fill,minmax(180px,1fr));display:grid}.subject-chip{align-items:center;gap:var(--space-2);padding:var(--space-4);border:2px solid var(--color-border);border-radius:var(--radius-md);background:var(--color-white);cursor:pointer;transition:all var(--transition-fast);font-size:var(--text-sm);color:var(--color-text-primary);display:flex}.subject-chip:hover{border-color:var(--color-primary-light);background:var(--color-primary-surface)}.subject-chip.selected{border-color:var(--color-primary);background:var(--color-primary-surface);color:var(--color-primary);font-weight:600}.subject-check{border:2px solid var(--color-border);width:18px;height:18px;transition:all var(--transition-fast);border-radius:4px;justify-content:center;align-items:center;font-size:12px;display:flex}.subject-chip.selected .subject-check{background:var(--color-primary);border-color:var(--color-primary);color:#fff}.onboarding-nav{padding:var(--space-6) var(--space-8);border-top:1px solid var(--color-border-light);gap:var(--space-4);display:flex}.nav-spacer{flex:1}.btn-back,.btn-next{padding:var(--space-4) var(--space-6);border-radius:var(--radius-md);font-size:var(--text-base);cursor:pointer;transition:all var(--transition-fast);border:none;font-weight:600}.btn-back{color:var(--color-text-secondary);background:0 0}.btn-back:hover{color:var(--color-navy)}.btn-next{background:var(--color-primary);color:#fff}.btn-next:hover:not(:disabled){background:var(--color-navy)}.btn-next:disabled{opacity:.5;cursor:not-allowed}@media (width<=768px){.onboarding-container{padding:var(--space-4)}.onboarding-content{padding:var(--space-8) var(--space-6);min-height:350px}.subject-grid{grid-template-columns:1fr}.onboarding-nav{padding:var(--space-4) var(--space-6)}}@media (width<=480px){.onboarding-container{padding:var(--space-2)}.onboarding-header{padding:var(--space-5) var(--space-4);gap:var(--space-2);flex-wrap:wrap}.onboarding-content{padding:var(--space-6) var(--space-4);min-height:300px}.onboarding-step h2{font-size:var(--text-xl)}.onboarding-nav{padding:var(--space-4);gap:var(--space-2);flex-wrap:wrap}.nav-spacer{display:none}.btn-back,.btn-next{justify-content:center;width:100%}}.create-test-page{max-width:1200px;padding:var(--space-6) var(--space-4);margin:0 auto;animation:.4s ease-out fadeIn}.ct-header{margin-bottom:var(--space-8)}.ct-header h1{font-size:var(--text-3xl);color:var(--color-navy);margin-bottom:var(--space-2)}.ct-header p{color:var(--color-text-secondary);font-size:var(--text-lg)}.ct-grid{gap:var(--space-8);align-items:flex-start;display:flex}.ct-config{flex:0 0 calc(60% - var(--space-4))}.ct-subjects{flex:0 0 calc(40% - var(--space-4))}.create-test-page .page-header{margin-bottom:var(--space-8)}.create-test-page .page-header h1{font-size:var(--text-3xl);color:var(--color-navy);margin-bottom:var(--space-2)}.create-test-page .page-header p{color:var(--color-text-secondary);font-size:var(--text-lg)}.create-test-layout{gap:var(--space-8);align-items:flex-start;display:flex}.layout-left{flex:1;max-width:780px;margin:0 auto}.layout-right{flex:0 0 calc(40% - var(--space-4));gap:var(--space-6);flex-direction:column;display:flex}.builder-header{margin-bottom:var(--space-6);border-bottom:1px solid var(--color-border);padding-bottom:var(--space-4);justify-content:space-between;align-items:center;display:flex}.builder-title{align-items:center;gap:var(--space-3);color:var(--color-navy);display:flex}.builder-title h2{font-size:var(--text-xl);margin:0}.text-navy{color:var(--color-navy)}.builder-toggle{align-items:center;gap:var(--space-3);font-weight:500;font-size:var(--text-sm);display:flex}.active-label{color:var(--color-primary)}.muted-label{color:var(--color-text-muted)}.switch{width:44px;height:24px;display:inline-block;position:relative}.switch input{opacity:0;width:0;height:0}.slider{cursor:pointer;background-color:var(--color-surface-blue);transition:all .4s;position:absolute;inset:0}.slider:before{content:"";background-color:var(--color-primary);width:18px;height:18px;transition:all .4s;position:absolute;bottom:3px;left:3px}input:checked+.slider{background-color:var(--color-primary)}input:checked+.slider:before{background-color:#fff;transform:translate(20px)}.slider.round{border-radius:24px}.slider.round:before{border-radius:50%}.roadmap-context-banner,.custom-context-banner{align-items:flex-start;gap:var(--space-4);padding:var(--space-4);background:var(--color-surface-blue);border-left:4px solid var(--color-primary);border-radius:var(--radius-md);margin-bottom:var(--space-6);display:flex}.custom-context-banner{background:#f9f9f9;border-left-color:#888}.banner-icon{color:var(--color-primary);flex-shrink:0}.custom-context-banner .banner-icon{color:#666}.roadmap-context-banner h4,.custom-context-banner h4{color:var(--color-navy);margin:0 0 var(--space-1) 0;font-size:var(--text-base)}.roadmap-context-banner p,.custom-context-banner p{color:var(--color-text-secondary);font-size:var(--text-sm);margin:0;line-height:1.5}.form-group{margin-bottom:var(--space-6)}.form-group label{color:var(--color-navy);margin-bottom:var(--space-3);font-weight:600;display:block}.taxonomy-select{border:1px solid var(--color-border);border-radius:var(--radius-md);width:100%;padding:var(--space-3);font-size:var(--text-sm);color:var(--color-navy);background:var(--color-white)}.taxonomy-select:focus{border-color:var(--color-primary);outline:none;box-shadow:0 0 0 2px #2563eb26}.subject-chips{gap:var(--space-2);flex-wrap:wrap;display:flex}.subject-chip{padding:var(--space-2) var(--space-4);border-radius:var(--radius-full);font-size:var(--text-sm);color:#666;background:#f0f0f0;font-weight:500}.subject-chip.active{background:var(--color-surface-blue);color:var(--color-primary);border:1px solid var(--color-primary)}.range-container{align-items:center;gap:var(--space-4);display:flex}.range-container input{accent-color:var(--color-primary);flex:1}.range-val{font-weight:700;font-size:var(--text-lg);color:var(--color-navy);text-align:right;width:40px}.mode-selectors{gap:var(--space-3);display:flex}.mode-btn{padding:var(--space-3);border:1px solid var(--color-border);border-radius:var(--radius-md);background:var(--color-white);color:var(--color-navy);cursor:pointer;transition:all var(--transition-fast);flex:1;font-weight:600}.mode-btn.active,.mode-btn:hover{border-color:var(--color-primary);background:var(--color-surface-blue);color:var(--color-primary)}.btn{padding:var(--space-3) var(--space-4);border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast);border:none;font-weight:600}.start-btn{justify-content:center;align-items:center;gap:var(--space-2);width:100%;font-size:var(--text-lg);padding:var(--space-4);margin-top:var(--space-4);background:var(--color-primary);color:#fff;border-radius:var(--radius-md);font-weight:700;display:flex}.start-btn:hover{opacity:.9;transform:translateY(-1px)}.card-header{align-items:center;gap:var(--space-2);margin-bottom:var(--space-4);display:flex}.card-header h3{font-size:var(--text-lg);color:var(--color-navy);margin:0}.timeline-stats{margin-bottom:var(--space-6);padding-bottom:var(--space-4);border-bottom:1px solid var(--color-border);justify-content:space-between;gap:var(--space-4);flex-wrap:wrap;display:flex}.stat{flex-direction:column;display:flex}.stat-val{font-size:var(--text-3xl);color:var(--color-navy);font-weight:800}.stat-label{font-size:var(--text-xs);color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.5px;margin-top:var(--space-1)}.stat.highlight .stat-val{color:var(--color-primary)}.adjuster-section input{width:100%;accent-color:var(--color-primary);margin-bottom:var(--space-2)}.adjuster-header{align-items:center;gap:var(--space-2);margin-bottom:var(--space-4);color:var(--color-navy);font-weight:600;display:flex}.slider-labels{font-size:var(--text-xs);color:var(--color-text-muted);justify-content:space-between;display:flex}.recalc-alert{margin-top:var(--space-4);padding:var(--space-4);border-radius:var(--radius-md);background:#fff9e6;border-left:4px solid #f39c12}.recalc-alert p{font-size:var(--text-sm);color:#8a6d3b;margin:0 0 var(--space-3) 0;line-height:1.4}.btn-secondary{border:1px solid var(--color-border);color:var(--color-navy);background:#fff}.btn-secondary:hover:not(:disabled){background:var(--color-surface-blue);border-color:var(--color-primary);color:var(--color-primary)}.btn-secondary:disabled{opacity:.6;cursor:not-allowed}.mt-2{margin-top:var(--space-2)}.text-muted{color:var(--color-text-muted)}.text-sm{font-size:var(--text-sm)}.weakness-card h4{color:#e74c3c;margin:0 0 var(--space-3) 0;font-size:var(--text-base)}.weakness-list{margin-left:var(--space-4);color:var(--color-text-secondary);font-size:var(--text-sm);padding-left:0}.weakness-list li{margin-bottom:var(--space-2)}@media (width<=900px){.create-test-layout,.ct-grid{flex-direction:column}.layout-left,.layout-right,.ct-config,.ct-subjects{flex:100%;width:100%}.builder-header{align-items:flex-start;gap:var(--space-3);flex-direction:column}.builder-toggle{justify-content:space-between;width:100%}.mode-selectors{flex-direction:column}}@media (width<=640px){.create-test-page{padding:var(--space-4) var(--space-2)}.create-test-page .page-header h1{font-size:var(--text-2xl)}.card{padding:var(--space-4)}.start-btn{font-size:var(--text-base);padding:var(--space-3)}.builder-toggle{row-gap:var(--space-2);flex-wrap:wrap}.range-container{gap:var(--space-2)}.range-val{width:auto;min-width:3ch}.timeline-stats{align-items:flex-start;gap:var(--space-3);flex-direction:column}}.roadmap-preview-container{background:var(--color-surface);min-height:100vh;padding:var(--space-8);justify-content:center;display:flex}.roadmap-preview-card{background:var(--color-white);border-radius:var(--radius-lg);width:100%;max-width:900px;box-shadow:var(--shadow-md);overflow:hidden}.roadmap-header{padding:var(--space-10);text-align:center;border-bottom:1px solid var(--color-border-light);background:linear-gradient(135deg, var(--color-primary-surface) 0%, var(--color-white) 100%)}.roadmap-icon{color:var(--color-primary);margin-bottom:var(--space-4)}.roadmap-header h1{font-size:var(--text-3xl);margin-bottom:var(--space-2);color:var(--color-navy)}.roadmap-subtitle{color:var(--color-text-secondary);font-size:var(--text-base);margin-bottom:var(--space-4)}.roadmap-stats{gap:var(--space-3);flex-wrap:wrap;justify-content:center;display:flex}.stat-chip{align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-4);background:var(--color-white);border:1px solid var(--color-border);border-radius:var(--radius-full);font-size:var(--text-sm);color:var(--color-text-secondary);display:inline-flex}.roadmap-timeline{padding:var(--space-6);max-height:500px;overflow-y:auto}.roadmap-velocity-section{padding:var(--space-6);border-top:1px solid var(--color-border-light);border-bottom:1px solid var(--color-border-light);background:var(--color-surface)}.roadmap-velocity-section .timeline-card{max-width:620px;margin:0 auto}.week-card{margin-bottom:var(--space-4);border:1px solid var(--color-border-light);border-radius:var(--radius-md);transition:box-shadow var(--transition-fast);overflow:hidden}.week-card:hover{box-shadow:var(--shadow-sm)}.week-header{width:100%;padding:var(--space-5);background:var(--color-surface);cursor:pointer;transition:background var(--transition-fast);border:none;justify-content:space-between;align-items:center;display:flex}.week-header:hover{background:var(--color-primary-surface)}.week-title{align-items:center;gap:var(--space-4);flex:1;display:flex}.week-number{color:var(--color-navy);font-weight:700;font-size:var(--text-base)}.week-dates{color:var(--color-text-muted);font-size:var(--text-sm)}.week-sessions{padding:var(--space-4)}.session-row{padding:var(--space-4);border-bottom:1px solid var(--color-border-light)}.session-row:last-child{border-bottom:none}.session-row-top{gap:var(--space-4);grid-template-columns:100px 1fr 60px;align-items:center;display:grid}.session-day{color:var(--color-text-secondary);font-weight:600;font-size:var(--text-sm)}.session-content{flex:1}.session-subject{color:var(--color-primary);font-weight:600;font-size:var(--text-sm)}.session-topic{color:var(--color-text-secondary);font-size:var(--text-sm);margin-top:2px}.session-hours{text-align:right;color:var(--color-text-muted);font-size:var(--text-sm);font-weight:500}.session-tasks{margin-top:var(--space-3);flex-direction:column;gap:6px;margin-left:116px;display:flex}.session-task-row{font-size:var(--text-xs);align-items:flex-start;gap:6px;display:flex}.session-task-icon{color:var(--color-primary);flex-shrink:0;margin-top:1px}.session-task-label{color:var(--color-text-secondary);white-space:nowrap;font-weight:600}.session-task-ids{color:var(--color-text-muted);font-family:monospace;font-size:.72rem;line-height:1.5}.session-task-links{flex-wrap:wrap;gap:4px;display:flex}.session-resource-link{border:1px solid var(--color-primary-lighter);border-radius:var(--radius-sm);color:var(--color-primary);cursor:pointer;transition:background var(--transition-fast);background:0 0;padding:1px 8px;font-family:inherit;font-size:.72rem}.session-resource-link:hover{background:var(--color-primary-surface)}.session-task-row--test{margin-top:4px}.session-test-btn{background:var(--gradient-primary);color:#fff;border-radius:var(--radius-sm);cursor:pointer;transition:opacity var(--transition-fast);border:none;padding:3px 12px;font-family:inherit;font-size:.72rem;font-weight:600}.session-test-btn:hover{opacity:.88}.session-test-done{color:#16a34a;align-items:center;gap:4px;font-size:.72rem;font-weight:600;display:inline-flex}.collapsed-indicator{background:var(--color-primary-surface);border-style:dashed}.roadmap-insights{padding:var(--space-8);background:var(--color-primary-surface);border-top:1px solid var(--color-border-light);gap:var(--space-6);display:flex}.insight-icon{color:var(--color-primary)}.roadmap-insights h3{font-size:var(--text-lg);color:var(--color-navy);margin-bottom:var(--space-3)}.priority-list{margin:0 0 var(--space-4) 0;padding:0;list-style:none}.priority-list li{padding:var(--space-2) 0;color:var(--color-text-secondary)}.milestone-info{margin-top:var(--space-4);font-size:var(--text-sm)}.milestone-info p{color:var(--color-navy);margin-bottom:var(--space-2);font-weight:600}.milestone-info ul{padding-left:var(--space-5);color:var(--color-text-secondary);margin:0}.roadmap-cta{padding:var(--space-8);text-align:center;border-top:1px solid var(--color-border-light)}.btn-get-started{padding:var(--space-5) var(--space-10);background:var(--color-primary);color:#fff;border-radius:var(--radius-md);font-size:var(--text-lg);cursor:pointer;transition:all var(--transition-fast);border:none;font-weight:700}.btn-get-started:hover{background:var(--color-navy);box-shadow:var(--shadow-md);transform:translateY(-2px)}@media (width<=768px){.roadmap-preview-container{padding:var(--space-4)}.roadmap-header{padding:var(--space-6)}.roadmap-header h1{font-size:var(--text-2xl)}.session-row-top{gap:var(--space-2);grid-template-columns:80px 1fr 50px}.session-tasks{margin-left:96px}.roadmap-insights{flex-direction:column}.roadmap-velocity-section{padding:var(--space-4)}}@media (width<=520px){.roadmap-preview-container{padding:var(--space-2)}.roadmap-header,.roadmap-velocity-section,.roadmap-timeline,.roadmap-insights,.roadmap-cta{padding-left:var(--space-4);padding-right:var(--space-4)}.session-row-top{grid-template-columns:1fr;gap:6px}.session-hours{text-align:left}.session-tasks{margin-left:0}.btn-get-started{width:100%;padding:var(--space-4) var(--space-6)}}.dashboard-container{padding:0}.welcome-bar{margin-bottom:var(--space-8);justify-content:space-between;align-items:center;animation:.3s fadeIn;display:flex}.welcome-greeting{font-size:var(--text-3xl);color:var(--color-navy);margin-bottom:var(--space-1)}.welcome-subtitle{color:var(--color-text-secondary);font-size:var(--text-base)}.welcome-plan-row{margin-top:var(--space-3);align-items:center;gap:var(--space-2);flex-wrap:wrap;display:inline-flex}.welcome-plan-chip,.welcome-demo-chip{border-radius:999px;align-items:center;padding:6px 10px;font-size:12px;font-weight:700;display:inline-flex}.welcome-plan-chip{color:#1a5f9a;background:#eef2ff;border:1px solid #c7ddf3}.welcome-demo-chip{color:#a86c17;background:#fff6e7;border:1px solid #f1c17b}.welcome-left{flex:1}.welcome-right{flex-shrink:0}.exam-badge{background:linear-gradient(135deg,#312e81 0%,#4f46e5 100%);border-radius:18px;align-items:center;gap:14px;padding:16px 26px;display:flex}.exam-icon{color:#fff;opacity:.85;flex-shrink:0}.exam-info{flex-direction:column;gap:2px;display:flex}.exam-name{color:#ffffffbf;text-transform:uppercase;letter-spacing:.06em;font-size:.72rem;font-weight:600}.exam-days{color:#fff;font-size:1.15rem;font-weight:800;line-height:1.2}.wb-prediction{border:1px solid #e0e7ff;border-radius:12px;align-items:stretch;display:flex;overflow:hidden;box-shadow:0 2px 10px #4f46e514}.wb-prediction__score-panel{background:linear-gradient(160deg,#1e1b4b 0%,#3730a3 100%);flex-direction:column;justify-content:center;align-items:center;gap:.05rem;padding:.85rem 1.1rem;display:flex}.wb-prediction__exam{text-transform:uppercase;letter-spacing:.07em;color:#a5b4fc;font-size:.6rem;font-weight:700}.wb-prediction__score{color:#fff;font-size:1.9rem;font-weight:800;line-height:1.1;font-family:var(--font-heading)}.wb-prediction__out{color:#818cf8;font-size:.62rem}.wb-prediction__info{background:#fff;flex-direction:column;justify-content:center;gap:.3rem;min-width:130px;padding:.75rem 1rem;display:flex}.wb-prediction__title{color:#6b7280;text-transform:uppercase;letter-spacing:.05em;font-size:.68rem;font-weight:600}.wb-prediction__badge{color:#1e1b4b;font-size:.75rem;font-weight:700}.wb-prediction__badge--high{color:#16a34a}.wb-prediction__badge--moderate{color:#d97706}.wb-prediction__badge--low{color:#6b7280}.wb-prediction__range{color:#9ca3af;font-size:.68rem}.db-banner{border-radius:10px;align-items:center;gap:10px;margin-bottom:16px;padding:10px 16px;font-size:.85rem;display:flex}.db-banner--amber{color:#92400e;background:#fffbeb;border:1px solid #fcd34d}.db-banner--red{color:#991b1b;background:#fef2f2;border:1px solid #fca5a5}.db-banner__cta{color:inherit;white-space:nowrap;margin-left:auto;font-weight:600}.db-row{gap:20px;margin-bottom:20px;display:grid}.db-row--3{grid-template-columns:repeat(3,1fr)}.db-row--2{grid-template-columns:repeat(2,1fr)}@media (width<=1100px){.db-row--3{grid-template-columns:repeat(2,1fr)}}@media (width<=768px){.db-row--3,.db-row--2{grid-template-columns:1fr}.welcome-bar{align-items:flex-start;gap:var(--space-4);flex-direction:column}.welcome-greeting{font-size:var(--text-2xl)}}.db-card{background:#fff;border:1px solid #eef2ff;border-radius:14px;flex-direction:column;padding:20px;display:flex;box-shadow:0 1px 4px #0f1f6a0f,0 4px 16px #0f1f6a0a}.db-card__head{justify-content:space-between;align-items:center;margin-bottom:16px;display:flex}.db-card__title{color:var(--color-navy);margin:0;font-size:15px;font-weight:700}.db-card__link{color:var(--color-primary);cursor:pointer;transition:color var(--transition-fast);background:0 0;border:none;align-items:center;gap:2px;padding:0;font-family:inherit;font-size:12px;font-weight:600;text-decoration:none;display:inline-flex}.db-card__link:hover{color:var(--color-navy);text-decoration:none}.db-progress-body{flex:1;align-items:center;gap:20px;display:flex}.db-progress-stats{flex-direction:column;flex:1;gap:16px;display:flex}.db-progress-stat{flex-direction:column;gap:2px;display:flex}.db-progress-stat__label{color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.04em;font-size:11px;font-weight:600}.db-progress-stat__val{color:var(--color-navy);font-size:22px;font-weight:800;line-height:1.1}.db-progress-stat__val--blue{color:#4f46e5}.db-progress-stat__sub{color:var(--color-text-muted);align-items:center;gap:3px;font-size:11px;display:inline-flex}.db-trend--up{color:#27ae60}.db-trend--down{color:#e74c3c}.db-progress-bar-track{background:#eef2ff;border-radius:999px;height:6px;overflow:hidden}.db-progress-bar-fill{border-radius:999px;height:100%;transition:width .8s}.db-progress-bar-fill--blue{background:var(--color-primary)}.db-weak-list{flex-direction:column;gap:12px;display:flex}.db-weak-row{flex-direction:column;gap:5px;display:flex}.db-weak-top{justify-content:space-between;align-items:center;display:flex}.db-weak-name{color:var(--color-text-secondary);font-size:13px;font-weight:500}.db-weak-pct{font-size:12px;font-weight:700}.db-last-test{flex-direction:column;gap:16px;display:flex}.db-last-test__score-row{align-items:center;gap:16px;display:flex}.db-last-test__score{flex-shrink:0;font-size:52px;font-weight:800;line-height:1}.db-last-test__meta{flex-direction:column;gap:3px;display:flex}.db-last-test__subject{color:var(--color-navy);font-size:16px;font-weight:700}.db-last-test__mode{color:var(--color-text-secondary);font-size:12px}.db-last-test__date{color:var(--color-text-muted);font-size:12px}.db-last-test__tests-row{gap:8px;display:flex}.db-stat-chip{background:#f9fafb;border-radius:10px;flex-direction:column;flex:1;align-items:center;gap:2px;padding:10px 8px;display:flex}.db-stat-chip__label{color:var(--color-text-muted);font-size:11px;font-weight:500}.db-stat-chip__val{color:var(--color-navy);font-size:20px;font-weight:700}.db-upcoming{flex:1;align-items:center;gap:20px;display:flex}.db-upcoming__teacher{text-align:center;flex-direction:column;flex-shrink:0;align-items:center;gap:8px;display:flex}.db-upcoming__teacher-avatar{object-fit:cover;border:3px solid #e0e7ff;border-radius:50%;flex-shrink:0;width:72px;height:72px}.db-upcoming__teacher-avatar--fallback{color:#fff;background:linear-gradient(135deg,#3730a3,#4f46e5);justify-content:center;align-items:center;font-size:1.1rem;font-weight:700;display:flex}.db-upcoming__teacher-name{color:#6b7280;font-size:.75rem;font-weight:600}.db-upcoming__details{flex-direction:column;flex:1;gap:6px;display:flex}.db-upcoming__class-name{color:var(--color-navy);font-size:15px;font-weight:700}.db-upcoming__topic{color:var(--color-text-secondary);font-size:13px}.db-upcoming__time{color:var(--color-text-muted);align-items:center;gap:5px;font-size:12px;font-weight:500;display:inline-flex}.db-upcoming__join{background:var(--color-primary);color:#fff;border-radius:8px;align-self:flex-start;align-items:center;gap:6px;margin-top:4px;padding:9px 16px;font-size:13px;font-weight:600;text-decoration:none;transition:opacity .15s;display:inline-flex}.db-upcoming__join:hover{opacity:.88;color:#fff;text-decoration:none}.db-browse{text-align:center;flex-direction:column;flex:1;justify-content:center;align-items:center;gap:12px;padding:16px 0;display:flex}.db-browse__icon{color:#c7ddf3}.db-browse__text{color:var(--color-text-secondary);max-width:280px;margin:0;font-size:13px;line-height:1.6}.db-browse__cta{background:var(--color-primary);color:#fff;border-radius:8px;align-items:center;gap:6px;padding:9px 18px;font-size:13px;font-weight:600;text-decoration:none;transition:opacity .15s;display:inline-flex}.db-browse__cta:hover{opacity:.88;color:#fff;text-decoration:none}.todays-plan-header{align-items:center;gap:var(--space-2);margin-bottom:var(--space-4);color:var(--color-primary);display:flex}.todays-plan-header h2{font-size:var(--text-lg);color:var(--color-navy);flex:1;margin:0;font-weight:700}.todays-plan-badge{font-size:var(--text-xs);background:var(--color-primary-surface);color:var(--color-primary);border-radius:var(--radius-full);padding:3px 10px;font-weight:600}.todays-plan-subject{align-items:center;gap:var(--space-3);padding:var(--space-3) var(--space-4);background:var(--color-primary-surface);border-radius:var(--radius-md);margin-bottom:var(--space-4);display:flex}.todays-plan-subject-label{color:var(--color-primary);font-weight:700;font-size:var(--text-sm)}.todays-plan-topic{font-size:var(--text-sm);color:var(--color-text-secondary);flex:1}.todays-plan-hours{font-size:var(--text-sm);color:var(--color-text-muted);font-weight:600}.todays-plan-tasks{gap:var(--space-3);margin-bottom:var(--space-4);flex-direction:column;display:flex}.todays-plan-task-row{gap:var(--space-2);align-items:flex-start;display:flex}.todays-plan-task-icon{color:var(--color-primary);flex-shrink:0;margin-top:2px}.todays-plan-task-label{color:var(--color-text-secondary);margin-bottom:3px;font-size:.72rem;font-weight:600;display:block}.todays-plan-task-ids{color:var(--color-text-muted);font-family:monospace;font-size:.72rem;line-height:1.5}.todays-plan-links{flex-wrap:wrap;gap:4px;display:flex}.todays-plan-link{border:1px solid var(--color-primary-lighter);border-radius:var(--radius-sm);color:var(--color-primary);cursor:pointer;transition:background var(--transition-fast);background:0 0;padding:2px 8px;font-family:inherit;font-size:.72rem}.todays-plan-link:hover{background:var(--color-primary-surface)}.todays-plan-empty{font-size:var(--text-sm);color:var(--color-text-muted);margin-bottom:var(--space-4)}.todays-plan-cta{align-items:center;gap:var(--space-2);color:var(--color-primary);font-size:var(--text-sm);cursor:pointer;transition:gap var(--transition-fast);background:0 0;border:none;padding:0;font-family:inherit;font-weight:600;display:inline-flex}.todays-plan-cta:hover{gap:var(--space-3)}.donut-wrap{justify-content:center;align-items:center;display:inline-flex;position:relative}.donut-center{text-align:center;z-index:10;pointer-events:none;flex-direction:column;justify-content:center;align-items:center;display:flex;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.donut-value{color:var(--color-navy);margin-bottom:4px;font-size:28px;font-weight:700;line-height:1}.donut-label{color:var(--color-text-secondary);font-size:13px;font-weight:500}.db-empty-text{color:var(--color-text-muted);font-size:13px}.db-prediction{background:#fff;border:1px solid #e0e7ff;border-radius:14px;align-items:center;gap:0;width:100%;margin-bottom:1rem;display:flex;overflow:hidden}.db-prediction__score-panel{text-align:center;background:linear-gradient(160deg,#1e1b4b 0%,#3730a3 100%);border-radius:13px 0 0 13px;flex-direction:column;flex-shrink:0;justify-content:center;align-items:center;gap:.1rem;min-width:130px;padding:1rem 1.75rem;display:flex}.db-prediction__exam-label{text-transform:uppercase;letter-spacing:.09em;color:#a5b4fc;font-size:.6rem;font-weight:700}.db-prediction__score{color:#fff;font-size:2rem;font-weight:800;line-height:1;font-family:var(--font-heading)}.db-prediction__range{color:#c7d2fe;font-size:.68rem}.db-prediction__out{color:#818cf8;font-size:.58rem}.db-prediction__info{flex:1;align-items:center;gap:1.5rem;padding:1rem 1.5rem;display:flex}.db-prediction__top-row{flex-direction:column;gap:.25rem;min-width:140px;display:flex}.db-prediction__title{color:#1e1b4b;font-size:.82rem;font-weight:700}.db-prediction__badge{border-radius:999px;width:fit-content;padding:.15rem .55rem;font-size:.65rem;font-weight:600}.db-prediction__badge--high{color:#16a34a;background:#e8f8f0}.db-prediction__badge--moderate{color:#92400e;background:#fef3c7}.db-prediction__badge--low{color:#6b7280;background:#f3f4f6}.db-prediction__message{color:#6b7280;flex:1;margin:0;font-size:.78rem;line-height:1.5}.db-prediction__signals{flex-direction:column;flex-shrink:0;gap:.3rem;display:flex}.db-prediction__signal{border-radius:6px;justify-content:space-between;align-items:center;gap:1rem;min-width:180px;padding:.2rem .5rem;font-size:.71rem;display:flex}.db-prediction__signal span{color:#9ca3af}.db-prediction__signal strong{font-weight:700}.db-prediction__signal--positive{background:#f0fdf4}.db-prediction__signal--positive strong{color:#16a34a}.db-prediction__signal--neutral{background:#f9fafb}.db-prediction__signal--neutral strong{color:#374151}.db-prediction__signal--negative{background:#fef2f2}.db-prediction__signal--negative strong{color:#dc2626}.db-prediction__bar-wrap{display:none}@media (width<=768px){.db-prediction{flex-direction:column;align-items:stretch}.db-prediction__info{flex-direction:column;align-items:flex-start;gap:.75rem}.db-prediction__signals{flex-flow:wrap}.db-prediction__signal{min-width:unset}}.test-session-page{min-height:calc(100vh - 64px);margin:calc(var(--space-6) * -1);background:#fff;flex-direction:column;display:flex;overflow-x:hidden}.test-header{padding:var(--space-4) var(--space-6);background:var(--color-navy);color:#fff;z-index:10;justify-content:space-between;align-items:center;display:flex}.test-header-left,.test-header-center,.test-header-right{align-items:center;gap:var(--space-4);display:flex}.exam-mode-badge{border-radius:var(--radius-full);font-size:var(--text-xs);text-transform:uppercase;background:#fff3;align-items:center;gap:6px;padding:4px 10px;font-weight:600;display:inline-flex}.question-counter{font-weight:500}.timer{font-size:var(--text-lg);align-items:center;gap:6px;font-family:monospace;font-weight:700;display:flex}.tool-btn{color:#fff;cursor:pointer;opacity:.8;background:0 0;border:none;align-items:center;gap:6px;padding:6px;transition:opacity .2s;display:flex}.tool-btn:hover{opacity:1}.btn-end-block{color:#fff;border-radius:var(--radius-md);cursor:pointer;background:#e74c3c;border:none;padding:6px 14px;font-weight:600}.btn-end-block:hover{background:#c0392b}.test-content-scrollable{padding:var(--space-8);background:var(--color-surface-blue);flex:1;overflow-y:auto}.test-body{max-width:900px;padding:var(--space-8);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);margin:0 auto;margin-bottom:var(--space-6);background:#fff}.vignette-text{color:var(--color-navy);margin-bottom:var(--space-8);font-size:1.1rem;line-height:1.7}.choices-title{margin-bottom:var(--space-4);color:var(--color-text-secondary);font-size:var(--text-sm);text-transform:uppercase}.choices-list{gap:var(--space-3);flex-direction:column;display:flex}.choice-item{align-items:center;gap:var(--space-4);padding:var(--space-4);border:1px solid var(--color-border);border-radius:var(--radius-md);cursor:pointer;text-align:left;background:#fff;transition:all .2s;display:flex;position:relative}.choice-item:not(.dimmed):not(.correct-reveal):not(.incorrect-reveal):hover{border-color:var(--color-primary);background:var(--color-surface-blue)}.choice-letter{background:var(--color-surface-blue);width:30px;height:30px;color:var(--color-primary);border-radius:4px;flex-shrink:0;justify-content:center;align-items:center;font-weight:700;display:flex}.choice-text{color:var(--color-navy);flex:1;font-size:1.05rem}.choice-item.selected{border-color:var(--color-primary);box-shadow:0 0 0 1px var(--color-primary)}.choice-item.dimmed{opacity:.5;cursor:default}.choice-item.correct-reveal{background:#eafcf1;border-color:#27ae60}.choice-item.correct-reveal .choice-letter{color:#fff;background:#27ae60}.choice-item.incorrect-reveal{background:#fdedec;border-color:#e74c3c}.choice-status{right:var(--space-4);font-weight:700;font-size:var(--text-sm);color:#27ae60;position:absolute}.choice-status.error{color:#e74c3c}.tutor-drawer{border:2px solid var(--color-primary);border-radius:var(--radius-lg);max-width:900px;box-shadow:var(--shadow-lg);margin:0 auto;margin-bottom:var(--space-8);background:#fff;overflow:hidden}.animate-slide-up{animation:.4s cubic-bezier(.16,1,.3,1) slideUp}@keyframes slideUp{0%{opacity:0;transform:translateY(40px)}to{opacity:1;transform:translateY(0)}}.tutor-header{padding:var(--space-4) var(--space-6);border-bottom:1px solid var(--color-border);background:#2563eb0d;justify-content:space-between;align-items:center;display:flex}.tutor-title{align-items:center;gap:var(--space-2);color:var(--color-primary);font-weight:700;font-size:var(--text-lg);display:flex}.tutor-tags span{border:1px solid var(--color-border);border-radius:var(--radius-full);font-size:var(--text-xs);color:var(--color-text-secondary);background:#fff;margin-left:8px;padding:4px 10px;font-weight:600}.tutor-content{padding:var(--space-6);gap:var(--space-6);display:flex}.tutor-text{color:var(--color-navy);white-space:pre-wrap;flex:1;font-size:1.05rem;line-height:1.7}.tutor-sidebar{border-left:1px solid var(--color-border);padding-left:var(--space-6);flex:0 0 280px}.tutor-sidebar h4{font-size:var(--text-sm);text-transform:uppercase;color:var(--color-text-secondary);margin:0 0 var(--space-4) 0}.reference-card{gap:var(--space-3);padding:var(--space-3);background:var(--color-surface-blue);border-radius:var(--radius-md);border:1px solid var(--color-border);cursor:pointer;transition:all .2s;display:flex}.reference-card:hover{border-color:var(--color-primary);transform:translateY(-2px)}.video-card .ref-icon{color:#e74c3c}.text-card .ref-icon{color:var(--color-primary)}.ref-details{flex-direction:column;display:flex}.ref-type{text-transform:uppercase;color:#e74c3c;font-size:10px;font-weight:700}.ref-title{font-weight:600;font-size:var(--text-sm);color:var(--color-navy);margin:2px 0}.ref-timestamp{font-size:var(--text-xs);color:var(--color-text-secondary)}.test-footer-actions{max-width:900px;padding-bottom:var(--space-8);justify-content:flex-end;margin:0 auto;display:flex}.btn-next{align-items:center;gap:var(--space-2);background:var(--color-primary);color:#fff;padding:var(--space-3) var(--space-6);border-radius:var(--radius-full);font-weight:700;font-size:var(--text-lg);cursor:pointer;border:none;transition:all .2s;display:flex;box-shadow:0 4px 12px #2563eb4d}.btn-next:hover{background:var(--color-navy);transform:translate(4px)}@media (width<=768px){.test-session-page{min-height:calc(100vh - 56px);margin:-12px}.test-header{gap:var(--space-2);padding:var(--space-3);flex-wrap:wrap}.test-header-left,.test-header-center,.test-header-right{justify-content:space-between;gap:var(--space-2);flex-wrap:wrap;width:100%}.tool-btn{font-size:var(--text-xs);padding:4px}.btn-end-block{font-size:var(--text-xs);padding:6px 10px}.test-content-scrollable,.test-body{padding:var(--space-4)}.choice-item{align-items:flex-start;gap:var(--space-3);padding-right:54px}.choice-text{font-size:.95rem;line-height:1.45}.choice-status{font-size:11px;top:10px;right:10px}.tutor-header{align-items:flex-start;gap:var(--space-2);flex-direction:column}.tutor-content{flex-direction:column}.tutor-sidebar{border-left:none;border-top:1px solid var(--color-border);padding-left:0;padding-top:var(--space-4)}.btn-next{width:100%;font-size:var(--text-base);justify-content:center}}@media (width<=480px){.test-session-page{margin:-8px}.test-content-scrollable,.test-body,.tutor-content{padding:var(--space-3)}.timer{font-size:var(--text-base)}.exam-mode-badge{font-size:10px}}.test-review-page{max-width:1200px;padding:var(--space-6) var(--space-4);margin:0 auto}.animate-fade-in{animation:.4s ease-out fadeIn}.page-header{margin-bottom:var(--space-8)}.back-link{color:var(--color-text-secondary);margin-bottom:var(--space-4);align-items:center;gap:6px;font-weight:500;text-decoration:none;display:inline-flex}.back-link:hover{color:var(--color-primary)}.page-header h1{font-size:var(--text-3xl);color:var(--color-navy);margin:0}.review-layout{gap:var(--space-8);align-items:flex-start;display:flex}.review-left{gap:var(--space-6);flex-direction:column;flex:0 0 380px;display:flex}.review-right{flex:1}.card{background:var(--color-white);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);padding:var(--space-6)}.score-card{padding:var(--space-8) var(--space-6)}.score-ring-container{margin-bottom:var(--space-6);justify-content:center;display:flex}.score-ring{border:12px solid var(--color-surface-blue);border-top-color:#f39c12;border-right-color:#f39c12;border-radius:50%;justify-content:center;align-items:center;width:160px;height:160px;display:flex}.score-value{color:var(--color-navy);align-items:baseline;font-size:3.5rem;font-weight:800;display:flex}.score-value small{color:var(--color-text-secondary);margin-left:2px;font-size:1.5rem}.score-card h2{font-size:var(--text-xl);color:var(--color-navy);margin:0 0 var(--space-2) 0}.text-secondary{color:var(--color-text-secondary)}.score-stats{justify-content:space-between;gap:var(--space-4);margin-top:var(--space-6);padding-top:var(--space-6);border-top:1px solid var(--color-border);flex-wrap:wrap;display:flex}.stat-item{font-weight:600;font-size:var(--text-sm);color:var(--color-navy);flex-direction:column;align-items:center;gap:8px;width:45%;display:flex}.text-error{color:#e74c3c}.text-warning{color:#f39c12}.text-primary{color:var(--color-primary)}.ai-warning-card{border:2px solid var(--color-primary);background:var(--color-surface-blue)}.ai-warning-header{align-items:center;gap:var(--space-2);color:var(--color-primary);margin-bottom:var(--space-4);display:flex}.ai-warning-header h3{font-size:var(--text-lg);margin:0}.warning-content{gap:var(--space-4);display:flex}.warning-icon{color:#e74c3c;flex-shrink:0}.warning-text h4{margin:0 0 var(--space-2) 0;color:#e74c3c;font-size:var(--text-base)}.warning-text p{font-size:var(--text-sm);color:var(--color-text-secondary);margin:0;line-height:1.6}.warning-text strong{color:var(--color-navy)}.review-list h3{margin:0 0 var(--space-4) 0;color:var(--color-navy);font-size:var(--text-xl)}.review-item{margin-bottom:var(--space-4)}.border-success{border-left:6px solid #27ae60}.border-error{border-left:6px solid #e74c3c}.review-item-header{margin-bottom:var(--space-4);justify-content:space-between;align-items:center;display:flex}.question-number{color:var(--color-navy);font-weight:700;font-size:var(--text-lg)}.status-badge{border-radius:var(--radius-full);font-size:var(--text-xs);text-transform:uppercase;align-items:center;gap:4px;padding:6px 12px;font-weight:700;display:flex}.status-badge.success{color:#27ae60;background:#eafcf1}.status-badge.error{color:#e74c3c;background:#fdedec}.vignette-snippet{color:var(--color-text-muted);margin-bottom:var(--space-5);padding:var(--space-4);background:var(--color-surface);border-radius:var(--radius-sm);font-size:1.05rem;font-style:italic;line-height:1.6}.answer-comparison{gap:var(--space-3);padding:var(--space-4);border-radius:var(--radius-md);border:1px solid var(--color-border);background:#fff;flex-direction:column;display:flex}.comparison-row{align-items:center;gap:var(--space-3);font-size:var(--text-base);display:flex}.comparison-label{color:var(--color-text-secondary);width:140px;font-weight:600}.comparison-value{border-radius:6px;justify-content:center;align-items:center;width:32px;height:32px;font-weight:700;display:inline-flex}.correct-choice{color:#fff;background:#27ae60}.wrong-choice{color:#fff;background:#e74c3c}.btn-secondary{border:1px solid var(--color-border);border-radius:var(--radius-md);padding:var(--space-3);color:var(--color-navy);cursor:pointer;text-align:center;font-weight:600;font-size:var(--text-sm);background:#fff;transition:all .2s}.btn-secondary:hover{background:var(--color-surface-blue);border-color:var(--color-primary);color:var(--color-primary)}.w-full{width:100%}.mt-3{margin-top:var(--space-4)}@media (width<=900px){.review-layout{flex-direction:column}.review-left,.review-right{flex:100%;width:100%}}@media (width<=640px){.test-review-page{padding:var(--space-4) var(--space-2)}.page-header h1{font-size:var(--text-2xl)}.score-card{padding:var(--space-5) var(--space-4)}.score-ring{width:130px;height:130px}.score-value{font-size:2.5rem}.comparison-row{gap:var(--space-2);flex-wrap:wrap}.comparison-label{width:auto}.review-item-header{align-items:flex-start;gap:var(--space-2);flex-wrap:wrap}.answer-comparison{padding:var(--space-3)}}.content-hub-page{padding:var(--space-6) var(--space-4);max-width:1200px;margin:0 auto}.hub-controls{margin-bottom:var(--space-8);justify-content:space-between;align-items:center;gap:var(--space-4);flex-wrap:wrap;display:flex}.search-bar{width:300px;position:relative}.search-icon{color:var(--color-text-muted);position:absolute;top:10px;left:12px}.search-bar input{width:100%;padding:var(--space-2) var(--space-3) var(--space-2) 36px;border:1px solid var(--color-border);border-radius:var(--radius-md);outline:none}.search-bar input:focus{border-color:var(--color-primary)}.video-grid{gap:var(--space-6);grid-template-columns:repeat(auto-fill,minmax(280px,1fr));display:grid}.video-card{cursor:pointer;padding:0;transition:transform .2s;overflow:hidden}.video-card:hover{border-color:var(--color-primary);transform:translateY(-4px)}.video-card:focus-visible{outline-offset:2px;border-color:var(--color-primary);outline:3px solid #2563eb59}.video-thumbnail{background:var(--color-navy);justify-content:center;align-items:center;height:180px;display:flex;position:relative}.play-overlay{color:#fff;opacity:.7;transition:opacity .2s}.video-card:hover .play-overlay{opacity:1;transform:scale(1.1)}.duration-badge{color:#fff;background:#000c;border-radius:4px;padding:2px 6px;font-size:12px;font-weight:600;position:absolute;bottom:8px;right:8px}.video-info,.pdf-info{padding:var(--space-4)}.video-info h3,.pdf-info h3{font-size:var(--text-lg);color:var(--color-navy);margin:0 0 var(--space-3) 0;line-height:1.3}.subject-tag{text-transform:uppercase;color:var(--color-primary);margin-bottom:var(--space-2);font-size:10px;font-weight:700;display:inline-block}.progress-container{align-items:center;gap:var(--space-3);display:flex}.progress-bar{background:var(--color-border);border-radius:3px;flex:1;height:6px;overflow:hidden}.progress-fill{background:#27ae60;height:100%}.progress-text{font-size:var(--text-xs);color:var(--color-text-secondary);width:30px;font-weight:700}.video-modal-backdrop{padding:var(--space-4);z-index:50;background:#111827b8;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.video-modal-card{border-radius:var(--radius-lg);width:min(920px,100%);padding:var(--space-5);background:#fff;box-shadow:0 24px 64px #00000040}.video-modal-header{justify-content:space-between;align-items:flex-start;gap:var(--space-4);margin-bottom:var(--space-4);display:flex}.video-modal-subject{color:var(--color-primary);font-size:var(--text-xs);text-transform:uppercase;margin:0 0 4px;font-weight:700}.video-modal-header h2{color:var(--color-navy);font-size:var(--text-xl);margin:0;line-height:1.3}.video-modal-close{border:1px solid var(--color-border);color:var(--color-text-secondary);cursor:pointer;background:#fff;border-radius:999px;flex-shrink:0;width:34px;height:34px}.video-modal-player{border-radius:var(--radius-md);background:#000;width:100%}.video-modal-note{margin:var(--space-3) 0 0;color:var(--color-text-secondary);font-size:var(--text-sm)}.pdf-grid{gap:var(--space-6);grid-template-columns:repeat(auto-fill,minmax(280px,1fr));display:grid}.pdf-card{flex-direction:column;padding:0;display:flex;overflow:hidden}.pdf-card:focus-visible{outline-offset:2px;border-color:var(--color-primary);outline:3px solid #2563eb59}.pdf-icon-wrapper{background:var(--color-surface-blue);justify-content:center;align-items:center;height:120px;display:flex}.pages-text{font-size:var(--text-sm);color:var(--color-text-secondary)}.pdf-modal-card{width:min(980px,100%)}.pdf-modal-frame{border:1px solid var(--color-border);border-radius:var(--radius-md);background:#f8fafc;width:100%;height:min(70vh,760px)}@media (width<=768px){.content-hub-page{padding:var(--space-4)}.hub-controls{flex-direction:column;align-items:stretch}.search-bar{width:100%}.tab-btn{white-space:nowrap;flex:none}.video-modal-card{padding:var(--space-4)}.video-modal-header h2{font-size:var(--text-lg)}}.ch-playlist-grid{grid-template-columns:repeat(3,1fr);gap:20px;display:grid}@media (width<=1024px){.ch-playlist-grid{grid-template-columns:repeat(2,1fr)}}@media (width<=640px){.ch-playlist-grid{grid-template-columns:1fr}}.ch-playlist-card{background:#fff;border:1px solid #e0e7ff;border-radius:14px;flex-direction:column;gap:10px;padding:20px;transition:box-shadow .2s,border-color .2s;display:flex}.ch-playlist-card:hover{border-color:#4f46e5;box-shadow:0 6px 24px #4f46e51a}.ch-playlist-card__subject{text-transform:uppercase;color:#4f46e5;letter-spacing:.05em;font-size:10px;font-weight:700;display:inline-block}.ch-playlist-card__title{color:#1e1b4b;margin:0;font-size:1rem;font-weight:700;line-height:1.35}.ch-playlist-card__meta{color:#6b7280;align-items:center;gap:12px;font-size:.8rem;display:flex}.ch-playlist-card__meta span{align-items:center;gap:4px;display:flex}.ch-playlist-card__instructor{color:#6b7280;margin:0;font-size:.82rem}.ch-playlist-card__price-row{justify-content:space-between;align-items:center;margin-top:4px;display:flex}.ch-playlist-card__price{color:#4f46e5;font-size:1.1rem;font-weight:700}.ch-playlist-card__price--purchased{color:#16a34a;background:#f0fdf4;border:1px solid #bbf7d0;border-radius:20px;padding:3px 10px;font-size:.85rem;font-weight:700}.ch-playlist-card__btn{cursor:pointer;border-radius:8px;width:100%;height:36px;margin-top:6px;font-size:.88rem;font-weight:600;transition:background .18s,color .18s;display:block}.ch-playlist-card__btn--buy{color:#4f46e5;background:0 0;border:2px solid #4f46e5}.ch-playlist-card__btn--buy:hover{background:#eef2ff}.ch-playlist-card__btn--watch{color:#fff;background:#4f46e5;border:2px solid #4f46e5}.ch-playlist-card__btn--watch:hover{background:#3730a3;border-color:#3730a3}.ch-playlist-modal-videos{flex-direction:column;gap:6px;max-height:420px;margin-top:12px;display:flex;overflow-y:auto}.ch-playlist-modal-video-row{cursor:pointer;background:#fafbff;border:1px solid #e0e7ff;border-radius:8px;align-items:center;gap:12px;padding:10px 14px;transition:background .15s;display:flex}.ch-playlist-modal-video-row:hover{background:#eef2ff}.ch-playlist-modal-video-row__title{color:#1e1b4b;flex:1;font-size:.88rem;font-weight:500}.ch-playlist-modal-video-row__duration{color:#6b7280;white-space:nowrap;font-size:.78rem}.ai-tutor-page{padding:var(--space-6) var(--space-4);flex-direction:column;max-width:1200px;min-height:calc(100vh - 80px);margin:0 auto;display:flex}.tutor-layout{gap:var(--space-6);flex:1;min-height:0;display:flex}.chat-interface{flex-direction:column;flex:0 0 60%;padding:0;display:flex;overflow:hidden}.chat-history{padding:var(--space-6);gap:var(--space-6);background:#fdfdfd;flex-direction:column;flex:1;display:flex;overflow-y:auto}.chat-bubble-container{gap:var(--space-3);max-width:85%;display:flex}.chat-bubble-container.is-user{flex-direction:row-reverse;align-self:flex-end}.bubble-avatar{background:var(--color-surface-blue);width:36px;height:36px;color:var(--color-primary);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;display:flex}.is-user .bubble-avatar{background:var(--color-navy);color:#fff}.chat-bubble{padding:var(--space-3) var(--space-4);border:1px solid var(--color-border);color:var(--color-navy);white-space:pre-wrap;background:#fff;border-radius:18px 18px 18px 4px;font-size:1.05rem;line-height:1.5;box-shadow:0 2px 4px #00000005}.is-user .chat-bubble{background:var(--color-primary);color:#fff;border-color:var(--color-primary);border-radius:18px 18px 4px}.typing-indicator span{margin:0 2px;font-size:1.5rem;line-height:.5;animation:1s infinite alternate typing;display:inline-block}.typing-indicator span:nth-child(2){animation-delay:.2s}.typing-indicator span:nth-child(3){animation-delay:.4s}@keyframes typing{0%{opacity:.3;transform:translateY(0)}to{opacity:1;transform:translateY(-4px)}}.chat-input-area{padding:var(--space-4);border-top:1px solid var(--color-border);gap:var(--space-3);background:#fff;display:flex}.chat-input-area input{padding:var(--space-3) var(--space-4);border:1px solid var(--color-border);border-radius:var(--radius-full);outline:none;flex:1;font-size:1rem}.chat-input-area input:focus{border-color:var(--color-primary)}.send-btn{background:var(--color-primary);color:#fff;cursor:pointer;border:none;border-radius:50%;justify-content:center;align-items:center;width:48px;height:48px;transition:transform .2s;display:flex}.send-btn:hover{transform:scale(1.05)}.rag-context-panel{flex-direction:column;flex:1;display:flex}.empty-context{text-align:center;color:var(--color-text-muted);padding:var(--space-8);border:2px dashed var(--color-border);background:#ffffff80;flex-direction:column;flex:1;justify-content:center;align-items:center;display:flex}.empty-context h3{color:var(--color-text-secondary);margin:var(--space-4) 0 var(--space-2) 0}.context-card{background:#eafcf1;border:2px solid #27ae60}.context-header{align-items:center;gap:var(--space-3);margin-bottom:var(--space-6);padding-bottom:var(--space-3);border-bottom:1px solid #27ae6033;display:flex}.context-header h4{color:#27ae60;font-size:var(--text-lg);text-transform:uppercase;letter-spacing:1px;margin:0}.pulsing-dot{background:#27ae60;border-radius:50%;width:12px;height:12px;animation:1.5s infinite pulse}@keyframes pulse{0%{box-shadow:0 0 #27ae6066}70%{box-shadow:0 0 0 10px #27ae6000}to{box-shadow:0 0 #27ae6000}}.retrieved-doc{border-radius:var(--radius-md);padding:var(--space-4);margin-bottom:var(--space-4);align-items:flex-start;gap:var(--space-4);border:1px solid var(--color-border);background:#fff;display:flex}.text-doc .doc-icon{color:var(--color-primary)}.video-doc .doc-icon{color:#e74c3c}.doc-meta{flex-direction:column;width:100%;display:flex}.doc-meta strong{color:var(--color-navy);margin-bottom:4px;font-size:1.05rem}.doc-meta span{color:var(--color-text-secondary);font-size:var(--text-sm)}.fake-diagram{background:var(--color-navy);color:#fff;border-radius:var(--radius-md);height:150px;margin-top:var(--space-6);font-family:monospace;font-size:var(--text-sm);opacity:.8;justify-content:center;align-items:center;display:flex}@media (width<=900px){.tutor-layout{flex-direction:column}.chat-interface{flex:500px;padding:0}.rag-context-panel{height:auto;padding-top:var(--space-4);border-top:1px solid var(--color-border);flex:none}}@media (width<=768px){.ai-tutor-page{padding:var(--space-2);min-height:calc(100vh - 56px)}.chat-history{padding:var(--space-3);gap:var(--space-4)}.chat-input-area{padding:var(--space-3)}.chat-input-area input{font-size:.95rem}.send-btn{width:42px;height:42px}.chat-bubble-container{max-width:95%}.chat-bubble{font-size:.95rem}}.analytics-page{padding:var(--space-6) var(--space-4);max-width:1200px;margin:0 auto}.analytics-page-header{margin-bottom:1.5rem}.analytics-tabs{width:fit-content;max-width:100%;margin-bottom:1.25rem}.analytics-page .taxonomy-filter{gap:var(--space-4);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:var(--space-4);background:#fff;grid-template-columns:repeat(3,minmax(180px,1fr));margin-bottom:1rem;display:grid}.analytics-page .taxonomy-filter__field{flex-direction:column;gap:.35rem;display:flex}.analytics-page .taxonomy-filter__field label{font-size:var(--text-xs);text-transform:uppercase;color:var(--color-text-secondary);font-weight:700}.analytics-page .taxonomy-filter__field select{border:1px solid var(--color-border);border-radius:var(--radius-sm);color:var(--color-navy);background:#fff;padding:.55rem .6rem}.analytics-overview-grid{margin-bottom:1.5rem}.analytics-matrix-layout{grid-template-columns:1fr}.analytics-matrix-banner{margin-bottom:.75rem}.analytics-matrix-note{color:#4b5563;margin-bottom:1rem}.analytics-history-title{color:#1e1b4b}.tabs{border-radius:var(--radius-md);box-shadow:var(--shadow-sm);border:1px solid var(--color-border);background:#fff;max-width:100%;padding:4px;display:flex;overflow-x:auto}.tab-btn{align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-6);color:var(--color-text-secondary);border-radius:var(--radius-sm);cursor:pointer;background:0 0;border:none;font-weight:600;transition:all .2s;display:flex}.tab-btn.active{background:var(--color-surface-blue);color:var(--color-primary)}.tabs::-webkit-scrollbar{height:6px}.tabs::-webkit-scrollbar-thumb{background:#c5dcef;border-radius:999px}.stats-overview{gap:var(--space-6);grid-template-columns:repeat(auto-fit,minmax(280px,1fr));display:grid}.stat-card{align-items:center;gap:var(--space-4);padding:var(--space-6);display:flex}.stat-icon{background:var(--color-surface-blue);border-radius:50%;justify-content:center;align-items:center;width:64px;height:64px;display:flex}.stat-value{color:var(--color-navy);font-size:2rem;font-weight:800;line-height:1.1}.stat-label{font-size:var(--text-sm);color:var(--color-text-secondary);text-transform:uppercase;font-weight:600}.analytics-layout{gap:var(--space-6);grid-template-columns:1fr 1fr;display:grid}.analytics-chart-wrap{margin-top:1rem}.analytics-chart-wrap--md{height:260px}.analytics-chart-wrap--sm{height:240px}.analytics-card--full{grid-column:1/-1}.matrix-card h3,.performance-card h3{color:var(--color-navy);font-size:var(--text-xl);margin:0}.matrix-list{gap:var(--space-5);flex-direction:column;display:flex}.matrix-item{flex-direction:column;gap:8px;display:flex}.matrix-header{color:var(--color-navy);justify-content:space-between;font-weight:600;display:flex}.matrix-header.text-error{color:#e74c3c}.heatmap-grid{gap:var(--space-3);grid-template-columns:repeat(auto-fit,minmax(180px,1fr));display:grid}.heatmap-cell{border-radius:var(--radius-md);text-align:left;cursor:pointer;border:1px solid;padding:.6rem .75rem}.heatmap-cell__topic{color:var(--color-navy);font-size:var(--text-sm);font-weight:600;display:block}.heatmap-cell__score{color:var(--color-text-secondary);font-size:var(--text-xs);margin-top:.15rem;display:block}.bg-success{background-color:#27ae60}.bg-primary{background-color:var(--color-primary)}.bg-warning{background-color:#f39c12}.bg-error{background-color:#e74c3c}.progress-bar{background:var(--color-border);border-radius:4px;width:100%;height:8px;overflow:hidden}.progress-fill{border-radius:4px;height:100%}.ai-diagnosis-box{gap:var(--space-3);padding:var(--space-4);border-radius:var(--radius-md);background:#fdedec;border:1px solid #e74c3c;display:flex}.ai-diagnosis-text{color:var(--color-navy);font-size:.95rem;line-height:1.5}.fake-chart-container{align-items:flex-end;height:300px;padding-bottom:20px;display:flex}.fake-chart{border-bottom:2px solid var(--color-border);justify-content:space-around;align-items:flex-end;width:100%;height:250px;padding-bottom:10px;display:flex;position:relative}.bar-col{flex-direction:column;justify-content:flex-end;align-items:center;gap:10px;height:100%;display:flex}.bar{background:var(--color-surface-blue);border-radius:6px 6px 0 0;width:40px;transition:all .3s}.bar:hover{background:var(--color-primary);filter:brightness(1.1);transform:translateY(-4px)}.bar-col span{color:var(--color-text-secondary);font-weight:600}.bar.highlight{box-shadow:0 0 15px #27ae6066}.mb-4{margin-bottom:var(--space-4)}.history-table{border-collapse:collapse;width:100%}.history-table th{padding:var(--space-3) var(--space-4);background:var(--color-surface-blue);color:var(--color-text-secondary);text-transform:uppercase;font-weight:600;font-size:var(--text-xs);border-bottom:1px solid var(--color-border);text-align:left}.history-table td{padding:var(--space-4);border-bottom:1px solid var(--color-border);color:var(--color-navy);font-size:var(--text-base)}.history-table tr:last-child td{border-bottom:none}.history-table tr:hover td{background:#fdfdfd}.btn-secondary-sm{border:1px solid var(--color-border);color:var(--color-navy);padding:var(--space-2) var(--space-3);border-radius:var(--radius-sm);font-size:var(--text-xs);cursor:pointer;background:#fff;align-items:center;gap:4px;font-weight:600;display:flex}.btn-secondary-sm:hover{background:var(--color-surface-blue);border-color:var(--color-primary);color:var(--color-primary)}@media (width<=900px){.analytics-layout{grid-template-columns:1fr}.table-responsive{overflow-x:auto}.analytics-page .taxonomy-filter{grid-template-columns:1fr}}@media (width<=768px){.analytics-page{padding:var(--space-4) var(--space-2)}.analytics-page-header{margin-bottom:1rem}.analytics-tabs{width:100%}.tabs{white-space:nowrap;width:100%}.tab-btn{padding:var(--space-2) var(--space-4);font-size:var(--text-sm);flex:none}.stats-overview{gap:var(--space-4);grid-template-columns:1fr}.stat-card{padding:var(--space-4)}.history-table th,.history-table td{padding:var(--space-2) var(--space-3);font-size:var(--text-sm)}.analytics-chart-wrap--md{height:230px}.analytics-chart-wrap--sm{height:220px}}@media (width<=480px){.analytics-page{padding:var(--space-3) var(--space-2)}.stat-icon{width:52px;height:52px}.stat-value{font-size:1.6rem}}.leaderboard-page{padding:var(--space-6) var(--space-4);max-width:1000px;margin:0 auto}.top-podium{justify-content:center;align-items:flex-end;gap:var(--space-4);height:250px;margin-bottom:var(--space-8);display:flex}.podium-item{flex-direction:column;align-items:center;display:flex;position:relative}.avatar{box-shadow:var(--shadow-md);z-index:2;background:#fff;border-radius:50%;justify-content:center;align-items:center;margin-bottom:-20px;display:flex}.avatar.gold{color:#f1c40f;border:4px solid #f1c40f;width:80px;height:80px}.avatar.silver{color:#bdc3c7;border:4px solid #bdc3c7;width:64px;height:64px}.avatar.bronze{color:#cd7f32;border:4px solid #cd7f32;width:56px;height:56px}.gold-trophy{color:#f1c40f;margin-bottom:10px;animation:3s ease-in-out infinite float}.podium-block{width:120px;padding-top:var(--space-6);color:#fff;border-radius:var(--radius-md) var(--radius-md) 0 0;justify-content:center;align-items:flex-start;font-size:2.5rem;font-weight:800;display:flex}.place-1 .podium-block{background:linear-gradient(#f1c40f,#f39c12);height:160px}.place-2 .podium-block{background:linear-gradient(#bdc3c7,#95a5a6);height:120px}.place-3 .podium-block{background:linear-gradient(#cd7f32,#a86422);height:90px}.podium-name{margin-top:var(--space-3);font-size:var(--text-lg);color:var(--color-navy)}.leaderboard-list{padding:0;overflow:hidden}.list-header{padding:var(--space-4) var(--space-6);background:var(--color-surface-blue);border-bottom:1px solid var(--color-border);color:var(--color-text-secondary);text-transform:uppercase;font-weight:700;font-size:var(--text-xs);display:flex}.list-row{padding:var(--space-4) var(--space-6);border-bottom:1px solid var(--color-border);align-items:center;transition:background .2s;display:flex}.list-row:last-child{border-bottom:none}.list-row:hover{background:#fdfdfd}.current-user-row{background:#eafcf1;border-color:#27ae60}.current-user-row:hover{background:#eafcf1}.col-rank{width:100px;color:var(--color-navy);align-items:center;gap:8px;font-weight:700;display:flex}.col-user{flex:1;align-items:center;gap:12px;font-size:1.1rem;display:flex}.user-name{color:var(--color-navy);font-weight:500}.user-name.font-bold{font-weight:700}.col-streak{width:150px}.col-score{width:120px;color:var(--color-navy);font-size:1.1rem;font-weight:700}.streak-badge{color:#f39c12;border-radius:var(--radius-full);font-weight:600;font-size:var(--text-sm);background:#fef9e7;border:1px solid #f39c1233;align-items:center;gap:6px;padding:4px 12px;display:inline-flex}.text-gold{color:#f1c40f}.text-silver{color:#bdc3c7}.text-bronze{color:#cd7f32}@media (width<=768px){.leaderboard-page{padding:var(--space-4)}.top-podium{gap:var(--space-2);height:210px}.podium-name{font-size:var(--text-sm);text-align:center}.podium-block{width:90px}.col-rank{width:72px}.col-streak,.list-header .col-streak{display:none}.list-row{padding:var(--space-3) var(--space-4)}.col-user{font-size:.95rem}.col-score{width:80px;font-size:.95rem}}@media (width<=520px){.podium-block{width:70px;font-size:1.5rem}.avatar.gold{width:60px;height:60px}.avatar.silver{width:50px;height:50px}.avatar.bronze{width:44px;height:44px}.list-header,.list-row{padding-left:var(--space-2);padding-right:var(--space-2)}.col-score{text-align:right;width:64px}}.partners-page{padding:var(--space-6) var(--space-4);max-width:1000px;margin:0 auto}.partners-layout{gap:var(--space-8);margin-top:var(--space-8);grid-template-columns:1fr 1fr;display:grid}.section-title{color:var(--color-navy);font-size:var(--text-xl);margin-bottom:var(--space-6);margin-top:0;font-weight:700}.matches-list,.connections-list{gap:var(--space-4);flex-direction:column;display:flex}.modern-partner-card{align-items:center;gap:var(--space-4);padding:var(--space-4);border-radius:var(--radius-lg);border:1px solid var(--color-border);background:#fff;transition:all .2s;display:flex}.hover-elevate:hover{box-shadow:var(--shadow-md);border-color:var(--color-primary);transform:translateY(-2px)}.partner-avatar-large{background:var(--color-surface-blue);width:64px;height:64px;color:var(--color-primary);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:1.5rem;font-weight:800;display:flex}.success-ring{color:#27ae60;background:#eafcf1;border:2px solid #27ae60}.partner-info-rich{flex:1;min-width:0}.partner-name-row{align-items:center;gap:8px;margin-bottom:4px;display:flex}.partner-name-row h4{color:var(--color-navy);margin:0;font-size:1.15rem;font-weight:700}.match-pill{color:#27ae60;text-transform:uppercase;background:#eafcf1;border-radius:12px;padding:2px 8px;font-size:10px;font-weight:800}.partner-meta{color:var(--color-text-secondary);font-size:var(--text-sm);align-items:center;margin:0 0 6px;display:flex}.partner-weakness{font-size:var(--text-sm);color:var(--color-text-secondary);white-space:nowrap;text-overflow:ellipsis;overflow:hidden}.partner-weakness strong{color:var(--color-warning);font-weight:600}.partner-action{justify-content:flex-end;align-items:center;width:60px;display:flex}.btn-icon-circular{background:var(--color-surface-blue);width:44px;height:44px;color:var(--color-primary);cursor:pointer;border:none;border-radius:50%;justify-content:center;align-items:center;transition:all .2s;display:flex}.btn-icon-circular:hover{background:var(--color-primary);color:#fff;transform:scale(1.05)}.requested-state{flex-direction:column;align-items:center;gap:4px;font-size:10px;font-weight:700;display:flex}.text-success{color:#27ae60}.empty-match-card{text-align:center;color:var(--color-text-muted);border:1px dashed var(--color-border);box-shadow:none;padding:var(--space-8);background:#00000005;flex-direction:column;justify-content:center;align-items:center;display:flex}.mb-2{margin-bottom:var(--space-2)}.connection-card{border-left:4px solid #27ae60}.conn-badge{background:var(--color-primary);color:#fff;text-transform:uppercase;border-radius:12px;padding:4px 10px;font-size:10px;font-weight:700}.conn-contact-box{background:var(--color-surface-blue);padding:var(--space-3) var(--space-4);border-radius:var(--radius-sm);border:1px solid var(--color-border);display:inline-block}.phone-display{align-items:center;gap:var(--space-3);color:var(--color-navy);font-size:1.05rem;font-weight:700;display:flex}@media (width<=900px){.partners-layout{grid-template-columns:1fr}}@media (width<=640px){.partners-page{padding:var(--space-4) var(--space-2)}.partners-layout{gap:var(--space-5);margin-top:var(--space-4)}.modern-partner-card{padding:var(--space-3);align-items:flex-start;gap:var(--space-3)}.partner-avatar-large{width:50px;height:50px;font-size:1.2rem}.partner-name-row{flex-wrap:wrap}.partner-name-row h4{font-size:1rem}.partner-meta,.partner-weakness{white-space:normal;text-overflow:clip;overflow:visible}.btn-icon-circular{width:40px;height:40px}.phone-display{gap:var(--space-2);flex-wrap:wrap;font-size:.9rem}}.notes-page{padding:var(--space-6) var(--space-4);max-width:1200px;margin:0 auto}.notes-toolbar{align-items:center;gap:var(--space-3);margin-bottom:var(--space-6);flex-wrap:wrap;display:flex}.notes-search{align-items:center;gap:var(--space-2);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:0 var(--space-3);background:#fff;flex:1;min-width:260px;min-height:40px;display:flex}.notes-search svg{color:var(--color-text-muted)}.notes-search input{width:100%;min-width:0;color:var(--color-text-primary);background:0 0;border:none}.notes-toolbar select{border:1px solid var(--color-border);border-radius:var(--radius-md);min-height:40px;padding:0 var(--space-3);color:var(--color-text-primary);background:#fff}.notes-new-btn{border-radius:var(--radius-md);background:var(--color-primary);color:#fff;align-items:center;gap:var(--space-2);min-height:40px;padding:0 var(--space-4);font-weight:600;display:inline-flex}.notes-layout{gap:var(--space-5);grid-template-columns:330px 1fr;align-items:start;display:grid}.notes-sidebar{border:1px solid var(--color-border);border-radius:var(--radius-lg);max-height:68vh;padding:var(--space-2);background:#fff;overflow:auto}.note-sidebar-link{text-align:left;border-radius:var(--radius-md);width:100%;padding:var(--space-3);background:0 0;border:1px solid #0000;transition:all .2s}.note-sidebar-link:hover{background:#f8fcff}.note-sidebar-link.active{border-color:var(--color-primary-lighter);background:var(--color-primary-surface)}.note-sidebar-link__top{justify-content:space-between;align-items:center;gap:var(--space-2);color:var(--color-text-primary);margin-bottom:6px;display:flex}.note-sidebar-link__top h4{font-size:var(--text-base);line-height:1.3}.note-sidebar-link p{font-size:var(--text-sm);color:var(--color-text-secondary);margin-bottom:var(--space-2);line-clamp:2;-webkit-line-clamp:2;-webkit-box-orient:vertical;display:-webkit-box;overflow:hidden}.note-sidebar-link__meta{justify-content:space-between;align-items:center;gap:var(--space-2);color:var(--color-text-muted);font-size:var(--text-xs);display:flex}.note-sidebar-link__meta span{align-items:center;gap:4px;display:inline-flex}.subject-pill{color:var(--color-primary);border-radius:var(--radius-full);background:#edf7ff;padding:3px 8px;font-weight:600}.notes-editor-panel{border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--space-4);background:#fff;min-height:520px}.notes-editor-header{justify-content:flex-start;align-items:center;gap:var(--space-3);margin-bottom:var(--space-4);flex-wrap:nowrap;display:flex}.notes-title-input{border:1px solid var(--color-border);border-radius:var(--radius-md);font-size:var(--text-lg);color:var(--color-text-primary);flex:1;min-width:0;padding:8px 12px;font-weight:700}.notes-subject-select{border:1px solid var(--color-border);border-radius:var(--radius-md);min-height:40px;padding:0 var(--space-3);color:var(--color-text-primary);background:#fff;flex-shrink:0;width:140px;font-weight:600}.notes-editor-actions{align-items:center;gap:var(--space-3);color:var(--color-text-secondary);font-size:var(--text-sm);white-space:nowrap;flex-wrap:nowrap;flex-shrink:0;margin-left:auto;display:flex}.notes-editor-actions>span{text-overflow:ellipsis;text-align:right;width:120px;overflow:hidden}.notes-editor-actions button{border-radius:var(--radius-md);background:var(--color-navy);color:#fff;min-height:34px;padding:0 var(--space-3);flex-shrink:0;align-items:center;gap:6px;font-weight:600;display:inline-flex}.notes-editor-actions .notes-delete-btn{color:#c0392b;background:#feecee;border:1px solid #f7c3c8}.notes-editor-actions .notes-delete-btn:hover{background:#fbd6db;border-color:#f0aeb6}.notes-editor-actions .notes-pin-btn{color:var(--color-primary);border:1px solid var(--color-primary-lighter);background:#edf7ff;justify-content:center;width:96px}.notes-editor-actions .notes-pin-btn.is-pinned{color:#9a6700;background:#fff6de;border-color:#f1cf7a}.rich-editor{border:1px solid var(--color-border-light);border-radius:var(--radius-md);overflow:hidden}.rich-editor__toolbar{gap:var(--space-2);padding:var(--space-2);border-bottom:1px solid var(--color-border-light);background:#f9fcff;flex-wrap:wrap;display:flex}.rich-editor__toolbar button{border-radius:var(--radius-sm);width:32px;height:32px;color:var(--color-text-secondary);border:1px solid var(--color-border-light);background:#fff;justify-content:center;align-items:center;display:inline-flex}.rich-editor__toolbar button:hover{border-color:var(--color-primary-lighter);color:var(--color-primary)}.rich-editor__editable{width:100%;min-height:360px;padding:var(--space-4);color:var(--color-text-primary);line-height:1.6;font-size:var(--text-base);border:none;outline:none}.rich-editor__editable ul,.rich-editor__editable ol{margin:.5rem 0;padding-left:1.5rem;list-style-position:outside}.rich-editor__editable li{margin:.15rem 0;padding-left:.1rem}.rich-editor__editable p,.rich-editor__editable h2{margin:.45rem 0}.rich-editor__editable:empty:before{content:attr(data-placeholder);color:var(--color-text-muted)}.rich-editor__footer{padding:var(--space-2) var(--space-4);border-top:1px solid var(--color-border-light);color:var(--color-text-secondary);font-size:var(--text-sm);justify-content:space-between;align-items:center;display:flex}.notes-empty{color:var(--color-text-secondary);font-size:var(--text-sm);padding:var(--space-4);text-align:center}.notes-empty--large{justify-content:center;align-items:center;min-height:360px;display:flex}@media (width<=980px){.notes-layout{grid-template-columns:1fr}.notes-sidebar{max-height:280px}}@media (width<=640px){.notes-page{padding:var(--space-4) var(--space-2)}.notes-toolbar{gap:var(--space-2)}.notes-search{min-width:100%}.notes-toolbar select,.notes-new-btn{width:100%}.notes-editor-header{flex-wrap:wrap}.notes-title-input{min-width:100%}.notes-subject-select{width:100%}.notes-editor-actions{justify-content:flex-start;gap:var(--space-2);flex-wrap:wrap;width:100%;margin-left:0}.notes-editor-actions>span{text-align:left;order:3;width:100%;max-width:100%}.notes-editor-actions button{margin-left:0}.rich-editor__editable{min-height:280px}}.student-comments-page{flex-direction:column;gap:1rem;display:flex}.student-comments-header h1{color:#1e1b4b;align-items:center;gap:.4rem;margin:0;display:flex}.student-comments-header p{color:#6b7280;margin:.35rem 0 0}.student-comments-layout{grid-template-columns:minmax(280px,.95fr) minmax(0,1.4fr);align-items:start;gap:1rem;display:grid}.student-comment-form{background:#f9fafb;border:1px solid #dcebf9;border-radius:12px;gap:.65rem;padding:.9rem;display:grid}.student-comment-form h3{color:#1e1b4b;margin:0;font-size:1rem}.student-comment-form input,.student-comment-form textarea{font:inherit;color:#1e1b4b;background:#fff;border:1px solid #e0e7ff;border-radius:10px;padding:.58rem .68rem}.student-comment-form textarea{resize:vertical;min-height:120px}.student-comment-notice{color:#4f46e5;margin:0;font-size:.82rem;font-weight:700}.student-comment-list{flex-direction:column;gap:.65rem;max-height:560px;padding-right:.2rem;display:flex;overflow-y:auto}.student-comment-item{background:#fff;border:1px solid #e0e7ff;border-radius:12px;padding:.72rem}.student-comment-item header{justify-content:space-between;align-items:baseline;gap:.5rem;display:flex}.student-comment-item strong{color:#1e1b4b;font-size:.92rem}.student-comment-item span{color:#6b7280;font-size:.75rem}.student-comment-item p{color:#234568;margin:.4rem 0 0;font-size:.84rem;line-height:1.48}@media (width<=860px){.student-comments-layout{grid-template-columns:1fr}.student-comment-list{max-height:none}}@keyframes msg-in{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}@keyframes send-pop{0%{transform:scale(1)}40%{transform:scale(.88)}to{transform:scale(1)}}.community-page{flex-direction:column;max-width:780px;height:calc(100vh - 120px);margin:0 auto;display:flex}.community-header{flex-shrink:0;justify-content:space-between;align-items:flex-start;gap:16px;margin-bottom:20px;display:flex}.community-title{background:linear-gradient(90deg, var(--color-navy), #4f46e5);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;margin:0 0 4px;font-size:22px;font-weight:700}.community-subtitle{color:var(--color-text-secondary);margin:0;font-size:13px}.community-readonly-badge{color:#c2410c;white-space:nowrap;background:#fff7ed;border:1px solid #fed7aa;border-radius:999px;flex-shrink:0;align-items:center;gap:6px;padding:6px 12px;font-size:12px;font-weight:600;display:inline-flex}.community-feed{scrollbar-width:thin;scrollbar-color:#d1e3f5 transparent;flex-direction:column;flex:1;gap:16px;padding:4px 0 12px;display:flex;overflow-y:auto}.community-msg{align-items:flex-start;gap:12px;animation:.2s both msg-in;display:flex}.community-msg__avatar{border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;font-size:12px;font-weight:700;display:flex;box-shadow:0 2px 6px #0000001a}.community-msg__body{background:#fff;border:1px solid #eef2ff;border-radius:0 14px 14px;flex:1;padding:10px 14px;transition:box-shadow .15s;box-shadow:0 2px 8px #0f1f6a0d}.community-msg:hover .community-msg__body{box-shadow:0 4px 14px #0f1f6a17}.community-msg--own .community-msg__body{background:linear-gradient(135deg,#eef2ff,#e0e7ff);border-color:#c7d2fe;border-radius:14px 0 14px 14px}.community-msg--own{flex-direction:row-reverse}.community-msg--own .community-msg__avatar{color:#fff;background:#4f46e5}.community-msg__meta{align-items:center;gap:8px;margin-bottom:4px;display:flex}.community-msg__name{color:var(--color-navy);align-items:center;gap:5px;font-size:13px;font-weight:600;display:flex}.community-msg__admin-tag{background:linear-gradient(90deg, var(--color-navy), #4f46e5);color:#fff;letter-spacing:.02em;border-radius:999px;padding:2px 7px;font-size:10px;font-weight:700}.community-msg__time{color:var(--color-text-muted);margin-left:auto;font-size:11px}.community-msg__text{color:var(--color-text-primary,#1e293b);white-space:pre-wrap;word-break:break-word;margin:0;font-size:14px;line-height:1.55}.community-composer{border-top:1px solid #eef2ff;flex-shrink:0;align-items:center;gap:10px;padding:14px 0 0;display:flex}.community-composer__input{color:var(--color-navy);background:#fff;border:1px solid #d1e3f5;border-radius:10px;outline:none;flex:1;padding:10px 14px;font-family:inherit;font-size:14px;transition:border-color .15s}.community-composer__input:focus{border-color:var(--color-primary)}.community-composer__send{color:#fff;cursor:pointer;background:linear-gradient(135deg,#4f46e5,#4338ca);border:none;border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;width:40px;height:40px;transition:opacity .15s,transform .15s;display:flex;box-shadow:0 2px 8px #2563eb59}.community-composer__send:disabled{opacity:.35;cursor:default;box-shadow:none}.community-composer__send:not(:disabled):hover{opacity:.9;transform:scale(1.06)}.community-composer__send:not(:disabled):active{animation:.25s send-pop}.community-composer__disabled{color:var(--color-text-muted);background:#f8fafc;border:1px solid #eef2ff;border-radius:10px;flex:1;align-items:center;gap:8px;padding:10px 14px;font-size:13px;display:flex}.student-inbox-page{flex-direction:column;gap:1rem;display:flex}.student-inbox-header h1{color:#1e1b4b;align-items:center;gap:.45rem;margin:0;display:flex}.student-inbox-header p{color:#6b7280;margin:.25rem 0 0}.student-inbox-summary{border:1px solid #e0e7ff;justify-content:space-between;align-items:center;gap:1rem;display:flex}.student-inbox-summary h3{color:#1e1b4b;margin:0}.student-inbox-summary p{color:#6b7280;margin:.25rem 0 0}.student-inbox-read-all{color:#fff;background:#4f46e5;border:none;border-radius:999px;align-items:center;gap:.45rem;padding:.6rem .95rem;font-weight:700;display:inline-flex}.student-inbox-read-all:disabled{opacity:.5;cursor:not-allowed}.student-inbox-list{flex-direction:column;gap:.75rem;display:flex}.student-inbox-item{border:1px solid #e0e7ff;transition:border-color .2s,box-shadow .2s}.student-inbox-item.unread{border-color:#9fc7ea;box-shadow:0 6px 20px #2563eb14}.student-inbox-item.read{opacity:.92}.student-inbox-item header{justify-content:space-between;gap:.8rem;display:flex}.student-inbox-item h3{color:#1e1b4b;margin:0}.student-inbox-item header p{color:#6b7280;margin:.25rem 0 0;font-size:.82rem}.student-inbox-item-status{color:#3b5f85;background:#edf5fd;border-radius:999px;align-items:center;gap:.35rem;height:fit-content;padding:.32rem .55rem;font-size:.78rem;font-weight:700;display:inline-flex}.student-inbox-message{color:#294f75;white-space:pre-wrap;margin:.7rem 0;line-height:1.5}.student-inbox-item footer{justify-content:space-between;align-items:center;gap:.7rem;display:flex}.student-inbox-item footer span{color:#6b7280;font-size:.8rem}.student-inbox-item footer button{color:#4f46e5;background:#fff;border:1px solid #4f46e5;border-radius:999px;padding:.35rem .65rem;font-size:.78rem;font-weight:700}.student-inbox-empty{color:#6b7280;margin:0}@media (width<=760px){.student-inbox-summary,.student-inbox-item header,.student-inbox-item footer{flex-direction:column;align-items:flex-start}}.flashcards-page{gap:16px;padding:2px;display:grid;position:relative}.flashcards-page>*{z-index:1;position:relative}.glass{background:linear-gradient(150deg, color-mix(in oklab, var(--surface) 92%, #1d3a9a 8%), var(--surface));border:1px solid color-mix(in oklab, var(--line) 80%, #5d7aa6 20%);-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);box-shadow:0 8px 26px #0e29632e}.flashcards-header h1{align-items:center;gap:8px;margin:0;display:flex}.flashcards-header p{color:var(--text-2);margin:6px 0 0}.flashcards-shortcuts{flex-wrap:wrap;gap:8px;margin-top:10px;display:inline-flex}.flashcards-shortcuts span{text-transform:uppercase;letter-spacing:.04em;color:var(--text-2);border:1px solid var(--line);border-radius:999px;padding:4px 8px;font-size:11px}.flashcards-kpis{grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:12px;display:grid}.flashcards-kpi{border-radius:12px;padding:12px;transition:transform .18s,box-shadow .18s;animation:.42s both flashcards-float-in;transform:translateY(0)}.flashcards-kpi:hover{transform:translateY(-2px);box-shadow:0 10px 24px #00000029}.flashcards-kpi h4{color:var(--text-2);text-transform:uppercase;letter-spacing:.04em;margin:0;font-size:12px}.flashcards-kpi p{margin:6px 0 0;font-size:20px;font-weight:700}.flashcards-progress{gap:10px;display:grid}.flashcards-progress__title{justify-content:space-between;align-items:center;gap:12px;display:flex}.flashcards-progress__title h3{align-items:center;gap:8px;margin:0;display:inline-flex}.flashcards-progress__title strong{font-size:14px}.flashcards-progress__track{background:color-mix(in oklab, var(--surface) 75%, #486fbe 25%);border-radius:999px;width:100%;height:10px;overflow:hidden}.flashcards-progress__track span{border-radius:inherit;background:linear-gradient(90deg,#2f79ff 0%,#40c0ff 45%,#5de38f 100%);height:100%;transition:width .26s;display:block;box-shadow:0 0 20px #4a97ffa6}.flashcards-complete-banner{border:1px solid color-mix(in oklab, #4ab786 65%, var(--line) 35%);background:linear-gradient(145deg, color-mix(in oklab, var(--surface) 84%, #2f8565 16%), color-mix(in oklab, var(--surface) 92%, #1f4335 8%));border-radius:12px;gap:6px;margin-top:2px;padding:12px;animation:.42s both flashcards-complete-pop;display:grid;box-shadow:0 8px 20px #134d3a33}.flashcards-complete-banner strong{color:#7be7b4;align-items:center;gap:8px;font-size:14px;display:inline-flex}.flashcards-complete-banner p{color:color-mix(in oklab, var(--text-2) 75%, white 25%);margin:0;font-size:13px}.flashcards-weak-topics{gap:10px;display:grid}.flashcards-weak-topics h3{align-items:center;gap:8px;margin:0;display:flex}.flashcards-topic-chip{background:color-mix(in oklab, var(--surface) 70%, #2b7cff 30%);border:1px solid color-mix(in oklab, var(--line) 60%, #2b7cff 40%);border-radius:999px;align-items:center;margin-bottom:8px;margin-right:8px;padding:6px 10px;font-size:12px;transition:transform .18s,box-shadow .18s;display:inline-flex}.flashcards-topic-chip:hover{transform:translateY(-1px);box-shadow:0 8px 14px #19408833}.flashcards-layout{grid-template-columns:320px minmax(0,1fr);gap:12px;display:grid}.flashcards-deck-list h3,.flashcards-viewer h3{margin:0 0 10px}.flashcards-deck-items{gap:8px;max-height:520px;display:grid;overflow:auto}.flashcards-deck-item{border:1px solid var(--line);background:color-mix(in oklab, var(--surface) 90%, #2d69d6 10%);text-align:left;color:inherit;border-radius:10px;grid-template-columns:28px minmax(0,1fr);gap:10px;padding:10px;transition:transform .18s,border-color .18s,box-shadow .18s;display:grid}.flashcards-deck-item:hover{border-color:color-mix(in oklab, var(--line) 60%, #5f8df8 40%);transform:translateY(-1px);box-shadow:0 8px 14px #0820522e}.flashcards-deck-item.active{border-color:color-mix(in oklab, var(--brand) 65%, white 35%);background:color-mix(in oklab, var(--surface) 64%, var(--brand) 36%)}.flashcards-deck-item span{background:color-mix(in oklab, var(--surface) 70%, #5a8fff 30%);border-radius:999px;place-items:center;width:28px;height:28px;font-size:12px;font-weight:700;display:inline-grid}.flashcards-deck-item strong,.flashcards-deck-item small{display:block}.flashcards-deck-item small{text-transform:capitalize;color:var(--text-2)}.status-known{color:#3db67d!important}.status-review{color:#e37b4f!important}.flashcards-viewer{gap:12px;display:grid}.flashcards-viewer-head{justify-content:space-between;align-items:center;gap:12px;display:flex}.flashcards-viewer-head p{color:var(--text-2);margin:6px 0 0}.flashcards-viewer-meta{flex-wrap:wrap;align-items:center;gap:8px;display:inline-flex}.flashcards-card-state{border:1px solid var(--line);text-transform:uppercase;letter-spacing:.05em;border-radius:999px;padding:4px 10px;font-size:11px}.flashcards-card-state.state-known{border-color:color-mix(in oklab, #48ba83 65%, var(--line) 35%);color:#4ece93}.flashcards-card-state.state-review{border-color:color-mix(in oklab, #f08f5f 65%, var(--line) 35%);color:#f3a47d}.flashcards-reset-btn{border:1px solid var(--line);background:color-mix(in oklab, var(--surface) 84%, #2b6fff 16%);color:inherit;border-radius:8px;align-items:center;gap:6px;padding:8px 10px;transition:transform .18s;display:inline-flex}.flashcards-reset-btn:hover{transform:translateY(-1px)}.flashcards-card-shell{perspective:1000px;text-align:left;min-height:290px;color:inherit;background:0 0;border:0;padding:0;position:relative}.flashcards-card-face{border:1px solid color-mix(in oklab, var(--line) 75%, #3d7dff 25%);background:linear-gradient(165deg, color-mix(in oklab, var(--surface) 90%, #1e40af 10%), var(--surface));backface-visibility:hidden;transform-style:preserve-3d;border-radius:16px;align-content:start;gap:12px;padding:18px;transition:transform .42s cubic-bezier(.23,1,.32,1),border-color .25s;display:grid;position:absolute;inset:0}.flashcards-card-face--back{border-color:color-mix(in oklab, #3fb27f 60%, var(--line) 40%);background:linear-gradient(165deg, color-mix(in oklab, var(--surface) 90%, #2a745a 10%), var(--surface));transform:rotateY(180deg)}.flashcards-card-shell.revealed .flashcards-card-face--front{transform:rotateY(180deg)}.flashcards-card-shell.revealed .flashcards-card-face--back{transform:rotateY(360deg)}.flashcards-card-shell:hover .flashcards-card-face--front{border-color:color-mix(in oklab, #60a0ff 60%, var(--line) 40%)}.flashcards-card-shell.revealed:hover .flashcards-card-face--back{border-color:color-mix(in oklab, #3fb27f 60%, var(--line) 40%)}.flashcards-card-label{text-transform:uppercase;letter-spacing:.08em;background:color-mix(in oklab, var(--surface) 74%, #4c89ff 26%);border-radius:999px;align-items:center;width:fit-content;padding:5px 11px;font-size:10px;font-weight:700;display:inline-flex}.flashcards-main-text{letter-spacing:.01em;margin:0;font-size:clamp(1.08rem,1.2vw,1.4rem);font-weight:600;line-height:1.55}.flashcards-card-hint{border:1px solid color-mix(in oklab, var(--line) 80%, #4f7ad4 20%);background:color-mix(in oklab, var(--surface) 84%, #315aa8 16%);color:var(--text-2);border-radius:12px;margin-top:6px;padding:10px 12px;font-size:13px;line-height:1.45}.flashcards-card-hint strong{color:var(--text-1);margin-right:4px}.flashcards-card-hint.success{border-color:color-mix(in oklab, var(--line) 75%, #4ab786 25%);background:color-mix(in oklab, var(--surface) 86%, #2f8565 14%)}.flashcards-card-tip{color:color-mix(in oklab, var(--text-2) 80%, white 20%);letter-spacing:.01em;font-size:12px}.flashcards-actions{grid-template-columns:auto 1fr 1fr auto;gap:10px;display:grid}.flashcards-nav-btn,.flashcards-mark-btn{border:1px solid var(--line);background:color-mix(in oklab, var(--surface) 88%, #2f6ff5 12%);color:inherit;border-radius:10px;justify-content:center;align-items:center;gap:6px;padding:10px 12px;font-weight:600;transition:transform .18s,box-shadow .18s;display:inline-flex}.flashcards-nav-btn:hover,.flashcards-mark-btn:hover{transform:translateY(-1px);box-shadow:0 8px 14px #0a265f38}.flashcards-nav-btn:disabled{opacity:.5}.flashcards-mark-btn.review{border-color:color-mix(in oklab, #f08f5f 65%, var(--line) 35%)}.flashcards-mark-btn.known{border-color:color-mix(in oklab, #48ba83 65%, var(--line) 35%)}.flashcards-mark-btn.known.pulse{animation:.38s known-pulse}.flashcards-footnote{color:var(--text-2);align-items:center;gap:8px;font-size:13px;display:inline-flex}@keyframes flashcards-float-in{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}@keyframes known-pulse{0%{transform:scale(1)}50%{transform:scale(1.03)}to{transform:scale(1)}}@keyframes flashcards-complete-pop{0%{opacity:0;transform:translateY(8px)scale(.985)}to{opacity:1;transform:translateY(0)scale(1)}}@media (width<=1024px){.flashcards-layout{grid-template-columns:1fr}.flashcards-deck-items{max-height:220px}.flashcards-actions{grid-template-columns:1fr 1fr}.flashcards-card-shell{min-height:260px}}@media (prefers-reduced-motion:reduce){.flashcards-kpi,.flashcards-deck-item,.flashcards-topic-chip,.flashcards-progress__track span,.flashcards-reset-btn,.flashcards-nav-btn,.flashcards-mark-btn,.flashcards-card-face{transition:none!important;animation:none!important}.flashcards-complete-banner{animation:none!important}}.flashcards-session-brief{background:#fff;border:1px solid #e0e7ff;border-radius:16px;flex-direction:column;gap:1.1rem;padding:1.5rem;animation:.4s both fadeIn;display:flex}.fsb-score-row{gap:1rem;display:flex}.fsb-score{background:#f9fafb;border-radius:12px;flex-direction:column;flex:1;align-items:center;gap:.25rem;padding:.85rem;display:flex}.fsb-score span{font-size:1.5rem;font-weight:700;line-height:1}.fsb-score small{color:#6b7280;font-size:.72rem;font-weight:500}.fsb-score--known{color:#16a34a}.fsb-score--review{color:#dc2626}.fsb-score--total{color:#4f46e5}.fsb-heading{color:#1e1b4b;border-top:1px solid #f3f4f6;align-items:center;gap:.5rem;padding-top:1rem;font-size:.95rem;font-weight:700;display:flex}.fsb-body{color:#374151;margin:0;font-size:.9rem;line-height:1.7}.fsb-keypoints{background:#eef2ff;border-radius:10px;padding:.9rem 1rem}.fsb-keypoints-label{color:#4f46e5;text-transform:uppercase;letter-spacing:.05em;align-items:center;gap:.4rem;margin-bottom:.6rem;font-size:.75rem;font-weight:700;display:flex}.fsb-keypoints ul{flex-direction:column;gap:.4rem;margin:0;padding-left:1.2rem;display:flex}.fsb-keypoints li{color:#1e1b4b;font-size:.85rem;line-height:1.5}.fsb-perfect{color:#16a34a;text-align:center;margin:0;padding:.5rem 0;font-size:.9rem;font-weight:500}.billing-upgrade-page{gap:16px;display:grid}.billing-referral-section{background:#fff;border:1px solid #e0e7ff;border-radius:12px;flex-direction:column;gap:.6rem;padding:1rem 1.25rem;display:flex}.billing-referral-header{color:#1f2937;align-items:center;gap:.4rem;font-size:.875rem;font-weight:600;display:flex}.billing-referral-input-row{gap:.5rem;display:flex}.billing-referral-input{color:#1f2937;letter-spacing:.04em;background:#f9fafb;border:1px solid #e0e7ff;border-radius:8px;outline:none;flex:1;padding:.55rem .85rem;font-size:.875rem;font-weight:600;transition:border-color .15s}.billing-referral-input:focus{background:#fff;border-color:#818cf8}.billing-referral-input--valid{background:#f0fdf4;border-color:#16a34a}.billing-referral-input--invalid{background:#fef2f2;border-color:#dc2626}.billing-referral-apply-btn{color:#fff;cursor:pointer;white-space:nowrap;background:#4f46e5;border:none;border-radius:8px;padding:.55rem 1.1rem;font-size:.875rem;font-weight:600;transition:background .15s}.billing-referral-apply-btn:hover{background:#155d96}.billing-referral-apply-btn:disabled{opacity:.6;cursor:not-allowed}.billing-referral-feedback{align-items:center;gap:.4rem;margin:0;font-size:.82rem;display:flex}.billing-referral-feedback--valid{color:#16a34a}.billing-referral-feedback--invalid{color:#dc2626}.billing-referral-locked-badge{color:#b45309;background:#fef9e7;border:1px solid #fde68a;border-radius:999px;align-items:center;gap:.25rem;margin-left:.4rem;padding:.18rem .5rem;font-size:.72rem;font-weight:600;display:inline-flex}.billing-upgrade-header h1{align-items:center;gap:8px;margin:0;display:flex}.billing-upgrade-header p{color:var(--text-2);margin:6px 0 0}.billing-current-banner{color:#0f4e83;background:#f3f9ff;border:1px solid #e0e7ff;border-radius:12px;flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;padding:12px;display:flex}.billing-countdown-chip{border:1px solid #bad6f5;border-radius:999px;align-items:center;gap:6px;padding:4px 10px;font-size:12px;font-weight:700;display:inline-flex}.billing-plan-grid{grid-template-columns:repeat(3,minmax(0,1fr));gap:12px;display:grid}.billing-plan-card{background:var(--surface,#fff);border:1px solid #dce9f7;border-radius:14px;gap:12px;padding:14px;display:grid;position:relative}.billing-plan-card.popular{border-color:#6fa9e6;box-shadow:0 8px 20px #2563eb26}.billing-popular-badge{color:#fff;background:#4f46e5;border-radius:999px;padding:4px 10px;font-size:11px;font-weight:700;position:absolute;top:-10px;right:12px}.billing-plan-card h3{margin:0}.billing-plan-price{color:#1e1b4b;font-size:24px;font-weight:800}.billing-feature-list{gap:8px;margin:0;padding:0;list-style:none;display:grid}.billing-feature-list li{color:#374151;align-items:center;gap:8px;font-size:14px;display:flex}.billing-primary-btn,.billing-secondary-btn{border:1px solid #0000;border-radius:10px;justify-content:center;align-items:center;gap:8px;padding:10px 12px;font-weight:700;text-decoration:none;display:inline-flex}.billing-primary-btn{color:#fff;background:#4f46e5}.billing-primary-btn:hover{background:#145a91;text-decoration:none}.billing-primary-btn:disabled{opacity:.65;cursor:not-allowed}.billing-secondary-btn{color:#28537b;background:#f6f9fd;border-color:#d5e6f7}.billing-lock-card{background:#fff;border:1px solid #e0e7ff;border-radius:14px;align-items:flex-start;gap:12px;padding:18px;display:flex}.billing-lock-card__icon{color:#4f46e5;background:#e9f3ff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:34px;height:34px;display:inline-flex}.billing-lock-card__body h2{color:#1e1b4b;margin:0}.billing-lock-card__body p{color:#4b5563;margin:6px 0 0}.billing-lock-card__actions{margin-top:12px}.billing-admin-page{gap:16px;display:grid}.billing-admin-toolbar{background:#f9fafb;border:1px solid #e0e7ff;border-radius:12px;flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;padding:10px 12px;display:flex}.billing-admin-status{color:#295d8c;align-items:center;gap:8px;font-size:13px;font-weight:600;display:inline-flex}.billing-admin-actions{gap:8px;display:inline-flex}.billing-admin-grid{grid-template-columns:repeat(3,minmax(0,1fr));gap:12px;display:grid}.billing-admin-card{background:#fff;border:1px solid #e0e7ff;border-radius:14px;gap:12px;padding:14px;display:grid}.billing-admin-card--span-2{grid-column:span 2}.billing-feature-access-block{border:1px solid #e1edf9;border-radius:12px;gap:10px;padding:10px;display:grid}.billing-feature-access-block h4{color:#3730a3;margin:0;font-size:.9rem}.billing-feature-toggle-grid{grid-template-columns:repeat(auto-fit,minmax(190px,1fr));gap:8px;display:grid}.billing-feature-toggle{color:#2f608e;text-align:left;background:#fff;border:1px solid #cbe0f5;border-radius:10px;padding:8px 10px;font-size:12px;font-weight:700}.billing-feature-toggle.enabled{color:#fff;background:#4f46e5;border-color:#4f46e5}.billing-admin-field{gap:6px;display:grid}.billing-admin-field label{color:#32577b;font-size:14px;font-weight:600}.billing-admin-field input{appearance:textfield;border:1px solid #c8ddf3;border-radius:10px;outline:none;height:40px;padding:0 10px;transition:border-color .12s,box-shadow .12s}.billing-admin-field input::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}.billing-admin-field input::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}.billing-admin-field input:focus{border-color:#5e9ddf;box-shadow:0 0 0 3px #4084d329}.billing-admin-field small{color:#6988a8;margin-top:-1px;font-size:12px}.billing-admin-presets{flex-wrap:wrap;gap:8px;display:inline-flex}.billing-preset-btn{color:#2f608e;background:#fff;border:1px solid #cbe0f5;border-radius:999px;padding:6px 10px;font-size:12px;font-weight:700}.billing-preset-btn.active{color:#fff;background:#4f46e5;border-color:#4f46e5}.billing-admin-warning{color:#9f5c1a;background:#fff6e7;border:1px solid #f2d19d;border-radius:10px;margin:-4px 0 0;padding:8px 10px;font-size:13px}.billing-admin-footer{justify-content:flex-end;display:flex}@media (width<=980px){.billing-plan-grid,.billing-admin-grid{grid-template-columns:1fr}.billing-admin-card--span-2{grid-column:auto}.billing-admin-toolbar{align-items:flex-start}}.lms-classes-page{gap:16px;display:grid}@keyframes lms-student-pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.7;transform:scale(1.1)}}.lms-live-banner{color:#fff;background:linear-gradient(135deg,#16a34a,#15803d);border-radius:12px;flex-wrap:wrap;justify-content:space-between;align-items:center;gap:10px;padding:12px 16px;display:flex}.lms-live-banner__pulse{background:#fff;border-radius:50%;flex-shrink:0;width:10px;height:10px;animation:1.5s infinite lms-student-pulse}.lms-live-banner__text{flex:1;font-size:.9rem;font-weight:700}.lms-classes-grid{grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:14px;display:grid}.lms-class-card{background:#fff;border:1px solid #e0e7ff;border-radius:16px;gap:12px;padding:16px;transition:border-color .15s,box-shadow .15s;display:grid}.lms-class-card:hover{border-color:#8ec4e8;box-shadow:0 2px 12px #2563eb14}.lms-class-card--live{border-color:#86efac;box-shadow:0 0 0 3px #16a34a1a}.lms-class-card__header{justify-content:space-between;align-items:flex-start;gap:8px;display:flex}.lms-class-card__name{color:#1e1b4b;margin:0;font-size:1rem;font-weight:800;line-height:1.3}.lms-class-card__product-badge{color:#4f46e5;white-space:nowrap;background:#eef2ff;border-radius:999px;flex-shrink:0;padding:3px 8px;font-size:.72rem;font-weight:700;display:inline-block}.lms-class-card__teacher{color:#4b5563;align-items:center;gap:4px;font-size:.83rem;display:flex}.lms-countdown-chip{border-radius:999px;align-items:center;gap:6px;padding:5px 10px;font-size:.78rem;font-weight:700;display:inline-flex}.lms-countdown-chip--live{color:#15803d;background:#dcfce7;border:1px solid #bbf7d0}.lms-countdown-chip--today{color:#4338ca;background:#e0e7ff;border:1px solid #c7d2fe}.lms-countdown-chip--upcoming{color:#374151;background:#f3f4f6;border:1px solid #e5e7eb}.lms-countdown-chip--none{color:#9ca3af;background:#f9fafb;border:1px solid #f3f4f6}.lms-class-card__attendance{color:#6b7280;align-items:center;gap:4px;font-size:.78rem;display:flex}.lms-class-card__actions{gap:8px;display:flex}.lms-join-btn{color:#fff;cursor:pointer;background:#16a34a;border:none;border-radius:8px;align-items:center;gap:6px;padding:7px 14px;font-size:.83rem;font-weight:700;text-decoration:none;transition:background .15s;display:inline-flex}.lms-join-btn:hover{background:#15803d}.lms-view-btn{color:#4f46e5;cursor:pointer;background:#f9fafb;border:1px solid #c7d2fe;border-radius:8px;align-items:center;gap:6px;padding:7px 14px;font-size:.83rem;font-weight:600;text-decoration:none;transition:background .15s;display:inline-flex}.lms-view-btn:hover{background:#e0f0ff}.lms-session-page{gap:16px;display:grid}.lms-session-header{background:#fff;border:1px solid #e0e7ff;border-radius:14px;flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;padding:16px;display:flex}.lms-session-layout{grid-template-columns:1fr 320px;align-items:start;gap:16px;display:grid}.lms-zoom-frame{aspect-ratio:16/9;color:#fff;background:#0d1117;border-radius:16px;flex-direction:column;justify-content:center;align-items:center;gap:1rem;display:flex;position:relative;overflow:hidden}.lms-zoom-frame:before{content:"";background:radial-gradient(circle,#2563eb26 0%,#0000 70%);position:absolute;inset:0}.lms-zoom-frame__label{color:#ffffff80;text-transform:uppercase;letter-spacing:.08em;font-size:.78rem;position:relative}.lms-zoom-frame__title{text-align:center;padding:0 2rem;font-size:1.1rem;font-weight:700;position:relative}.lms-zoom-frame__subtitle{color:#fff9;font-size:.83rem;position:relative}.lms-countdown-large{text-align:center;background:#fff;border:1px solid #e0e7ff;border-radius:16px;padding:3rem 2rem}.lms-countdown-large__time{color:#1e1b4b;letter-spacing:-.02em;font-variant-numeric:tabular-nums;font-size:clamp(2rem,6vw,3.5rem);font-weight:900}.lms-countdown-large__label{color:#6b7280;margin-top:.5rem;font-size:.83rem}.lms-countdown-large__date{color:#374151;margin-top:.75rem;font-size:.87rem;font-weight:600}.lms-sidebar{background:#fff;border:1px solid #e0e7ff;border-radius:14px;gap:12px;padding:14px;display:grid}.lms-sidebar__title{color:#1e1b4b;margin:0;font-size:.87rem;font-weight:700}.lms-notice-item{background:#f9fafb;border:1px solid #eef4fc;border-radius:8px;align-items:flex-start;gap:8px;padding:8px;display:flex}.lms-notice-item__icon{border-radius:7px;flex-shrink:0;justify-content:center;align-items:center;width:28px;height:28px;display:flex}.lms-notice-item__icon--announcement{color:#4f46e5;background:#eef2ff}.lms-notice-item__icon--pdf{color:#dc2626;background:#fef2f2}.lms-notice-item__title{color:#1e1b4b;font-size:.83rem;font-weight:600;line-height:1.3}.lms-notice-item__date{color:#6b7280;margin-top:2px;font-size:.72rem}.lms-notice-item__filename{color:#4f46e5;margin-top:2px;font-size:.72rem}.lms-empty-state{text-align:center;color:#6b7280;padding:2rem}@media (width<=900px){.lms-session-layout{grid-template-columns:1fr}}@media (width<=600px){.lms-classes-grid{grid-template-columns:1fr}}.demo-banner{border-radius:10px;flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;margin-bottom:16px;padding:10px 20px;font-size:.84rem;font-weight:600;display:flex}.demo-banner--amber{color:#92400e;background:#fffbeb;border:1px solid #fde68a}.demo-banner--red{color:#991b1b;background:#fef2f2;border:1px solid #fca5a5;animation:2s ease-in-out infinite pulseBorder}@keyframes pulseBorder{0%,to{border-color:#fca5a5}50%{border-color:#ef4444}}.demo-banner__left{align-items:center;gap:8px;display:flex}.demo-banner__cta{cursor:pointer;white-space:nowrap;border:none;border-radius:8px;padding:6px 14px;font-size:.8rem;font-weight:700;text-decoration:none}.demo-banner--amber .demo-banner__cta{color:#fff;background:#d97706}.demo-banner--red .demo-banner__cta{color:#fff;background:#dc2626}.demo-banner__cta:hover{opacity:.88}.demo-banner__dismiss{cursor:pointer;color:inherit;opacity:.5;background:0 0;border:none;margin-left:4px;padding:2px;line-height:1}.demo-banner__dismiss:hover{opacity:.8}.demo-gate{border-radius:12px;position:relative;overflow:hidden}.demo-gate__overlay{-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);text-align:center;z-index:1;background:#f8fafce0;flex-direction:column;justify-content:center;align-items:center;gap:8px;padding:1.5rem;display:flex;position:absolute;inset:0}.demo-gate__lock-icon{color:#6b7280}.demo-gate__reason{color:#374151;margin:0;font-size:.85rem;font-weight:600}.demo-gate__cta{color:#fff;cursor:pointer;background:#4f46e5;border:none;border-radius:8px;margin-top:4px;padding:7px 16px;font-size:.8rem;font-weight:700;text-decoration:none;display:inline-block}.demo-gate__cta:hover{background:#3730a3}.demo-expired-page{justify-content:center;align-items:center;min-height:60vh;padding:2rem;display:flex}.demo-expired-card{text-align:center;background:#fff;border:1px solid #e0e7ff;border-radius:18px;width:100%;max-width:500px;padding:48px 40px;box-shadow:0 4px 24px #1e1b4b0f}.demo-expired-card__icon{color:#6b7280;margin:0 auto 16px;display:block}.demo-expired-card h1{color:#1e1b4b;margin:0 0 8px;font-size:1.4rem;font-weight:800}.demo-expired-card__sub{color:#4b5563;margin:0 0 24px;font-size:.87rem}.demo-expired-card__features{grid-template-columns:1fr 1fr;gap:8px;margin-bottom:24px;display:grid}.demo-expired-feature{color:#374151;background:#f9fafb;border:1px solid #eef2ff;border-radius:10px;align-items:center;gap:7px;padding:10px 12px;font-size:.8rem;font-weight:600;display:flex}.demo-expired-feature--locked{color:#4f46e5;background:#eef2ff}.demo-expired-card__actions{flex-wrap:wrap;justify-content:center;gap:10px;display:flex}.demo-btn-primary{color:#fff;cursor:pointer;background:#4f46e5;border:none;border-radius:10px;align-items:center;gap:8px;padding:11px 24px;font-size:.9rem;font-weight:700;text-decoration:none;display:inline-flex}.demo-btn-primary:hover{background:#3730a3}.demo-btn-ghost{color:#4b5563;cursor:pointer;background:#fff;border:1px solid #c7d2fe;border-radius:10px;align-items:center;gap:8px;padding:11px 24px;font-size:.9rem;font-weight:600;text-decoration:none;display:inline-flex}.demo-btn-ghost:hover{background:#f9fafb}.fomo-page{flex-direction:column;gap:24px;display:flex}.fomo-hero{color:#fff;background:linear-gradient(135deg,#1e1b4b 0%,#4f46e5 55%,#7c3aed 100%);border-radius:16px;flex-wrap:wrap;justify-content:space-between;align-items:center;gap:16px;padding:32px 28px;display:flex}.fomo-hero__left h1{margin:0 0 6px;font-size:1.35rem;font-weight:800}.fomo-hero__left p{opacity:.8;margin:0;font-size:.87rem}.fomo-expiry-chip{white-space:nowrap;border-radius:99px;align-items:center;gap:6px;padding:6px 12px;font-size:.8rem;font-weight:700;display:inline-flex}.fomo-expiry-chip--amber{color:#fbbf24;background:#fbbf2433;border:1px solid #fbbf2466}.fomo-expiry-chip--red{color:#f87171;background:#ef444433;border:1px solid #ef444466}.fomo-features-grid{grid-template-columns:repeat(4,1fr);gap:14px;display:grid}@media (width<=900px){.fomo-features-grid{grid-template-columns:repeat(2,1fr)}}@media (width<=480px){.fomo-features-grid{grid-template-columns:1fr}}.fomo-feature-card{text-align:center;background:#fff;border:1px solid #e0e7ff;border-radius:14px;flex-direction:column;align-items:center;gap:10px;padding:18px;display:flex}.fomo-feature-card__icon{color:#4f46e5;background:#eef2ff;border-radius:50%;justify-content:center;align-items:center;width:40px;height:40px;display:flex}.fomo-feature-card h3{color:#1e1b4b;margin:0;font-size:.9rem;font-weight:700}.fomo-feature-card p{color:#6b7280;margin:0;font-size:.75rem}.fomo-roadmap-section{background:#fff;border:1px solid #e0e7ff;border-radius:14px;padding:22px 20px}.fomo-roadmap-section h2{color:#1e1b4b;margin:0 0 16px;font-size:1rem;font-weight:800}.fomo-session-list{flex-direction:column;gap:8px;display:flex}.fomo-session-item{border:1px solid #eef2ff;border-radius:10px;align-items:center;gap:12px;padding:10px 14px;display:flex}.fomo-session-item--unlocked{background:#f0fff4;border-color:#bbf7d0}.fomo-session-item--locked{opacity:.75;background:#f9fafb;border-color:#e0e7ff}.fomo-session-num{border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:24px;height:24px;font-size:.72rem;font-weight:700;display:flex}.fomo-session-item--unlocked .fomo-session-num{color:#fff;background:#16a34a}.fomo-session-item--locked .fomo-session-num{color:#6b7280;background:#eef2ff}.fomo-session-topic{color:#374151;flex:1;font-size:.85rem;font-weight:600}.fomo-session-item--locked .fomo-session-topic{color:#9ca3af}.fomo-social-strip{background:#f9fafb;border:1px solid #e0e7ff;border-radius:14px;flex-wrap:wrap;align-items:center;gap:20px;padding:18px 20px;display:flex}.fomo-social-stat{color:#1e1b4b;white-space:nowrap;font-size:.87rem;font-weight:700}.fomo-social-stat span{color:#4f46e5}.fomo-quotes{flex-wrap:wrap;flex:1;gap:12px;display:flex}.fomo-quote{color:#4b5563;flex:1;min-width:120px;font-size:.75rem;font-style:italic}.fomo-cta-banner{background:linear-gradient(135deg,#1e1b4b 0%,#4f46e5 55%,#7c3aed 100%);border-radius:14px;flex-wrap:wrap;justify-content:space-between;align-items:center;gap:16px;padding:28px 24px;display:flex}.fomo-cta-banner h2{color:#fff;margin:0;font-size:1.1rem;font-weight:800}.fomo-cta-btn{color:#1e1b4b;cursor:pointer;white-space:nowrap;background:#fff;border:none;border-radius:10px;align-items:center;gap:8px;padding:12px 28px;font-size:.95rem;font-weight:800;text-decoration:none;display:inline-flex}.fomo-cta-btn:hover{background:#eef2ff}.chat-page{flex-direction:column;gap:20px;display:flex}.chat-page__header{background:#fff;border:1px solid #e0e7ff;border-radius:14px;flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;padding:18px 20px;display:flex}.chat-page__title{color:#1e1b4b;margin:0;font-size:1.1rem;font-weight:800}.chat-page__subtitle{color:#4b5563;margin:3px 0 0;font-size:.83rem}.chat-panel{background:#fff;border:1px solid #e0e7ff;border-radius:14px;grid-template-columns:280px 1fr;min-height:560px;display:grid;overflow:hidden}@media (width<=768px){.chat-panel{grid-template-columns:1fr;min-height:auto}}.chat-sidebar{border-right:1px solid #eef2ff;flex-direction:column;display:flex;overflow:hidden}.chat-sidebar__header{color:#6b7280;text-transform:uppercase;letter-spacing:.06em;border-bottom:1px solid #eef2ff;padding:14px 16px 10px;font-size:.72rem;font-weight:700}.chat-sidebar__list{flex:1;overflow-y:auto}.chat-sidebar__item{cursor:pointer;border-bottom:1px solid #f9fafb;padding:12px 16px;transition:background .15s}.chat-sidebar__item:hover{background:#f9fafb}.chat-sidebar__item--active{background:#eef2ff;border-left:3px solid #4f46e5}.chat-sidebar__name{color:#1e1b4b;justify-content:space-between;align-items:center;gap:6px;font-size:.87rem;font-weight:600;display:flex}.chat-sidebar__preview{color:#6b7280;white-space:nowrap;text-overflow:ellipsis;margin-top:2px;font-size:.75rem;overflow:hidden}.chat-unread-badge{color:#fff;text-align:center;background:#4f46e5;border-radius:99px;flex-shrink:0;min-width:18px;padding:1px 6px;font-size:.65rem;font-weight:700}.chat-main{flex-direction:column;display:flex;overflow:hidden}.chat-main__header{border-bottom:1px solid #eef2ff;flex-shrink:0;justify-content:space-between;align-items:center;gap:12px;padding:14px 20px;display:flex}.chat-main__name{color:#1e1b4b;font-size:.95rem;font-weight:700}.chat-main__class{color:#4b5563;margin-top:1px;font-size:.78rem}.chat-privacy-bar{color:#92400e;background:#fffbeb;border-bottom:1px solid #fef3c7;flex-shrink:0;align-items:center;gap:6px;padding:8px 20px;font-size:.75rem;font-weight:500;display:flex}.chat-supervision-bar{color:#0369a1;background:#f0f9ff;border-bottom:1px solid #bae6fd;flex-shrink:0;align-items:center;gap:6px;padding:8px 20px;font-size:.75rem;font-weight:600;display:flex}.chat-messages{flex-direction:column;flex:1;gap:10px;padding:16px 20px;display:flex;overflow-y:auto}.chat-message{align-items:flex-end;gap:8px;width:fit-content;max-width:75%;display:flex}.chat-message--right{justify-content:flex-end;margin-left:auto}.chat-message--left{margin-right:auto}.chat-message__avatar{color:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:28px;height:28px;font-size:11px;font-weight:700;display:flex}.chat-message__avatar--student{background:#4f46e5}.chat-message__avatar--teacher{background:#1e1b4b}.chat-message__body{flex-direction:column;gap:2px;display:flex}.chat-message__bubble{word-break:break-word;border-radius:14px;padding:9px 13px;font-size:.87rem;line-height:1.5}.chat-message--right .chat-message__body{align-items:flex-end}.chat-message--right .chat-message__bubble{color:#fff;background:#4f46e5;border-bottom-right-radius:4px}.chat-message--left .chat-message__bubble{color:#1a2d45;background:#f0f4f8;border-bottom-left-radius:4px}.chat-message__meta{color:#9ca3af;align-items:center;gap:4px;font-size:.68rem;display:flex}.chat-message--right .chat-message__meta{text-align:right;justify-content:flex-end}.chat-input-bar{border-top:1px solid #eef2ff;flex-shrink:0;align-items:flex-end;gap:10px;padding:12px 20px;display:flex}.chat-input-bar__textarea{resize:none;color:#1e1b4b;border:1px solid #c7d2fe;border-radius:10px;flex:1;min-height:40px;max-height:120px;padding:10px 14px;font-family:inherit;font-size:.87rem;line-height:1.5;transition:border-color .15s}.chat-input-bar__textarea:focus{border-color:#4f46e5;outline:none}.chat-input-bar__send{color:#fff;cursor:pointer;background:#4f46e5;border:none;border-radius:10px;flex-shrink:0;align-items:center;gap:6px;padding:10px 18px;font-size:.87rem;font-weight:700;transition:background .15s;display:flex}.chat-input-bar__send:hover{background:#3730a3}.chat-input-bar__send:disabled{opacity:.6;cursor:not-allowed}.chat-empty{color:#9ca3af;text-align:center;flex-direction:column;flex:1;justify-content:center;align-items:center;gap:10px;padding:2rem;display:flex}.chat-empty p{margin:0;font-size:.87rem}.chat-empty p:first-of-type{color:#4b5563;font-weight:600}.chat-readonly-note{color:#9ca3af;text-align:center;background:#f9fafb;border-top:1px solid #eef2ff;flex-shrink:0;padding:10px 20px;font-size:.75rem}.chat-flag-btn{color:#dc2626;cursor:pointer;background:#fff;border:1px solid #fca5a5;border-radius:6px;align-items:center;gap:4px;padding:4px 10px;font-size:.72rem;font-weight:600;transition:background .15s;display:inline-flex}.chat-flag-btn:hover{background:#fee2e2}.programs-page{max-width:1100px;padding:28px 32px}.programs-loading,.programs-empty{color:#64748b;text-align:center;flex-direction:column;justify-content:center;align-items:center;gap:12px;padding:80px 0;display:flex}.programs-empty h2{color:#1e293b;margin:0;font-size:1.2rem}.programs-empty p{margin:0;font-size:.9rem}.programs-header{margin-bottom:28px}.programs-header h1{color:#1e1b4b;margin:0 0 6px;font-size:1.5rem;font-weight:700}.programs-header p{color:#64748b;margin:0;font-size:.9rem}.programs-grid{grid-template-columns:repeat(auto-fill,minmax(340px,1fr));gap:20px;display:grid}.program-card{background:#fff;border:1px solid #e0e7ff;border-radius:14px;flex-direction:column;transition:box-shadow .15s;display:flex;position:relative;overflow:hidden}.program-card:hover{box-shadow:0 4px 20px #1e1b4b1a}.program-card__enrolled-badge{color:#166534;background:#dcfce7;border-bottom:1px solid #bbf7d0;align-items:center;gap:5px;padding:6px 14px;font-size:.75rem;font-weight:600;display:flex}.program-card__body{flex:1;padding:20px 20px 16px}.program-card__name{color:#1e1b4b;margin:0 0 8px;font-size:1.05rem;font-weight:700;line-height:1.3}.program-card__desc{color:#475569;margin:0 0 14px;font-size:.85rem;line-height:1.55}.program-card__meta{flex-wrap:wrap;gap:10px;display:flex}.program-card__meta span{color:#64748b;background:#f1f5f9;border-radius:20px;align-items:center;gap:5px;padding:4px 10px;font-size:.78rem;display:flex}.program-card__footer{border-top:1px solid #eef2ff;flex-direction:column;gap:12px;padding:14px 20px 18px;display:flex}.program-card__pricing{justify-content:space-between;align-items:center;display:flex}.program-pricing-toggle{background:#f1f5f9;border-radius:8px;gap:2px;padding:3px;display:flex}.program-pricing-btn{color:#64748b;cursor:pointer;background:0 0;border:none;border-radius:6px;padding:4px 12px;font-size:.78rem;font-weight:500;transition:all .15s}.program-pricing-btn--active{color:#1e1b4b;background:#fff;box-shadow:0 1px 3px #0000001a}.program-card__price{color:#1e1b4b;font-size:1.2rem;font-weight:700}.program-card__price em{color:#64748b;font-size:.8rem;font-style:normal;font-weight:400}.program-card__actions{gap:8px;display:flex}.program-card__details-btn{color:#4f46e5;white-space:nowrap;border:1px solid #e0e7ff;border-radius:9px;justify-content:center;align-items:center;padding:10px 14px;font-size:.85rem;font-weight:500;text-decoration:none;transition:background .15s;display:flex}.program-card__details-btn:hover{background:#eef2ff;text-decoration:none}.program-card__cta{color:#fff;background:#4f46e5;border-radius:9px;flex:1;justify-content:center;align-items:center;gap:6px;padding:10px 18px;font-size:.88rem;font-weight:600;text-decoration:none;transition:background .15s;display:flex}.program-card__cta:hover{background:#155d91}.program-card__cta--enrolled{background:#1e1b4b}.program-card__cta--enrolled:hover{background:#0a2349}.program-card__demo-btn{color:#3730a3;cursor:pointer;background:#fff;border:1.5px solid #c7d2fe;border-radius:9px;flex:1;justify-content:center;align-items:center;gap:6px;padding:10px 18px;font-size:.85rem;font-weight:600;transition:background .15s,border-color .15s;display:flex}.program-card__demo-btn:hover{background:#eef2ff;border-color:#3730a3}.program-card__demo-btn:disabled{opacity:.6;cursor:not-allowed}@media (width<=640px){.programs-page{padding:16px}.programs-grid{grid-template-columns:1fr}}.auth-container{background:var(--color-white);min-height:100vh;display:flex}.auth-left{background:linear-gradient(145deg, var(--color-primary) 0%, var(--color-navy) 100%);padding:var(--space-12);flex:0 0 45%;justify-content:center;align-items:center;display:flex;position:relative;overflow:hidden}.auth-left__inner{z-index:1;max-width:400px;position:relative}.auth-logo{border-radius:var(--radius-lg);width:160px;margin-bottom:var(--space-8);box-shadow:0 8px 32px #00000040}.auth-left__heading{font-family:var(--font-heading);font-size:var(--text-3xl);color:var(--color-white);margin-bottom:var(--space-4);font-weight:800;line-height:1.15}.auth-left__sub{font-size:var(--text-base);color:#fffc;margin-bottom:var(--space-8);line-height:1.7}.auth-left__features{gap:var(--space-3);flex-direction:column;display:flex}.auth-left__feature{align-items:center;gap:var(--space-3);font-size:var(--text-sm);color:#ffffffe6;font-weight:500;display:flex}.auth-left__feature-dot{background:#fff9;border-radius:50%;flex-shrink:0;width:8px;height:8px}.auth-left__stats{gap:var(--space-4);margin-bottom:var(--space-6);grid-template-columns:repeat(3,1fr);display:grid}.auth-stat{border-radius:var(--radius-md);padding:var(--space-4);text-align:center;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#ffffff1f;border:1px solid #ffffff26}.auth-stat__num{font-family:var(--font-heading);font-size:var(--text-xl);color:var(--color-white);font-weight:800;display:block}.auth-stat__label{font-size:var(--text-xs);color:#ffffffb3;margin-top:2px;display:block}.auth-left__blob{filter:blur(60px);opacity:.15;pointer-events:none;border-radius:50%;position:absolute}.auth-left__blob--1{background:#fff;width:300px;height:300px;top:-80px;right:-80px}.auth-left__blob--2{background:var(--color-primary-lighter);width:200px;height:200px;bottom:-50px;left:-60px}.auth-right{padding:var(--space-12) var(--space-8);background:var(--color-white);flex:1;justify-content:center;align-items:center;display:flex}.auth-right--scroll{padding-top:var(--space-10);align-items:flex-start;overflow-y:auto}.auth-form-card{width:100%;max-width:420px}.auth-form-header{margin-bottom:var(--space-8)}.auth-form-title{font-size:var(--text-3xl);color:var(--color-navy);margin-bottom:var(--space-2);font-weight:800}.auth-form-subtitle{font-size:var(--text-sm);color:var(--color-text-secondary)}.auth-form{gap:var(--space-5);flex-direction:column;display:flex}.auth-field{gap:var(--space-2);flex-direction:column;display:flex}.auth-label{font-size:var(--text-sm);color:var(--color-text-primary);font-weight:600}.auth-label--optional{color:var(--color-text-muted);font-weight:400}.auth-label-row{justify-content:space-between;align-items:center;display:flex}.auth-forgot{font-size:var(--text-xs);color:var(--color-primary);cursor:pointer;transition:color var(--transition-fast);background:0 0;border:none;padding:0;font-weight:500}.auth-forgot:hover{color:var(--color-navy)}.auth-input-wrap{align-items:center;display:flex;position:relative}.auth-input-icon{color:var(--color-text-muted);pointer-events:none;flex-shrink:0;position:absolute;left:14px}.auth-input{border:1.5px solid var(--color-border);border-radius:var(--radius-md);width:100%;height:48px;font-size:var(--text-sm);color:var(--color-text-primary);background:var(--color-surface);transition:border-color var(--transition-fast), box-shadow var(--transition-fast), background var(--transition-fast);padding:0 16px 0 42px}.auth-input::placeholder{color:var(--color-text-muted)}.auth-input:focus{border-color:var(--color-primary);background:var(--color-white);box-shadow:0 0 0 3px #2563eb1a}.auth-input--password{padding-right:44px}.auth-input--error{border-color:var(--color-error)!important;box-shadow:0 0 0 3px #e74c3c1a!important}.auth-eye{color:var(--color-text-muted);cursor:pointer;transition:color var(--transition-fast);background:0 0;border:none;align-items:center;padding:0;display:flex;position:absolute;right:14px}.auth-eye:hover{color:var(--color-primary)}.auth-field-error{font-size:var(--text-xs);color:var(--color-error);font-weight:500}.auth-btn{border-radius:var(--radius-md);width:100%;height:50px;font-size:var(--text-base);justify-content:center;align-items:center;gap:var(--space-2);transition:all var(--transition-base);margin-top:var(--space-2);letter-spacing:.01em;font-weight:600;display:flex}.auth-btn--primary{background:linear-gradient(135deg, var(--color-primary), var(--color-primary-light));color:var(--color-white);box-shadow:0 4px 16px #2563eb59}.auth-btn--primary:hover:not(:disabled){background:linear-gradient(135deg, var(--color-navy), var(--color-primary));transform:translateY(-1px);box-shadow:0 6px 24px #2563eb73}.auth-btn--primary:active:not(:disabled){transform:translateY(0)}.auth-btn--navy{background:linear-gradient(135deg, var(--color-navy), var(--color-navy-mid));color:var(--color-white);box-shadow:0 4px 16px #1e1b4b59}.auth-btn--navy:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 6px 24px #1e1b4b73}.auth-btn:disabled{opacity:.7;cursor:not-allowed;transform:none!important}.auth-error{border-radius:var(--radius-md);padding:var(--space-3) var(--space-4);font-size:var(--text-sm);color:var(--color-error);margin-bottom:var(--space-4);background:#e74c3c14;border:1px solid #e74c3c40;font-weight:500}.auth-divider{align-items:center;gap:var(--space-4);margin:var(--space-6) 0;color:var(--color-text-muted);font-size:var(--text-sm);display:flex}.auth-divider:before,.auth-divider:after{content:"";background:var(--color-border);flex:1;height:1px}.auth-switch{text-align:center;font-size:var(--text-sm);color:var(--color-text-secondary)}.auth-switch a{color:var(--color-primary);font-weight:600}.auth-demo-hint{margin-top:var(--space-6);padding:var(--space-3) var(--space-4);background:var(--color-primary-surface);border:1px solid var(--color-primary-lighter);border-radius:var(--radius-md);font-size:var(--text-xs);color:var(--color-text-secondary);text-align:center}.auth-demo-hint span{color:var(--color-primary);margin-right:var(--space-1);font-weight:700}.auth-terms{margin-top:var(--space-4);text-align:center;font-size:var(--text-xs);color:var(--color-text-muted);line-height:1.6}.auth-terms a{color:var(--color-primary)}.auth-input-wrap--dark .auth-input-icon{color:#ffffff80}.auth-input--dark{color:var(--color-white);background:#ffffff14;border-color:#ffffff26}.auth-input--dark::placeholder{color:#fff6}.auth-input--dark:focus{border-color:var(--color-primary-light);background:#ffffff1f;box-shadow:0 0 0 3px #60a5fa33}.auth-label--dark{color:#ffffffd9}.auth-eye--dark{color:#ffffff80}.auth-eye--dark:hover{color:#ffffffe6}@media (width<=768px){.auth-left{display:none}.auth-right{padding:var(--space-8) var(--space-6)}.auth-right--scroll{padding-top:var(--space-8)}}@media (width<=480px){.auth-right{padding:var(--space-5) var(--space-3)}.auth-form-title{font-size:var(--text-2xl)}.auth-btn{height:46px;font-size:var(--text-sm)}}.admin-auth-container{background:linear-gradient(160deg, var(--color-navy) 0%, #101f6b 60%, #0b1858 100%);min-height:100vh;padding:var(--space-8);flex-direction:column;justify-content:center;align-items:center;display:flex;position:relative;overflow:hidden}.admin-blob{filter:blur(80px);opacity:.12;pointer-events:none;border-radius:50%;position:absolute}.admin-blob--1{background:var(--color-primary);width:500px;height:500px;top:-150px;right:-100px}.admin-blob--2{background:var(--color-primary-light);width:350px;height:350px;bottom:-100px;left:-80px}.admin-auth-card{-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-radius:var(--radius-xl);padding:var(--space-10) var(--space-10);z-index:1;background:#ffffff0d;border:1px solid #ffffff1a;width:100%;max-width:420px;position:relative;box-shadow:0 24px 80px #0006,inset 0 1px #ffffff14}.admin-auth-header{text-align:center;margin-bottom:var(--space-8)}.admin-shield-icon{background:linear-gradient(135deg, var(--color-primary), var(--color-primary-light));border-radius:var(--radius-lg);width:56px;height:56px;margin:0 auto var(--space-4);color:#fff;justify-content:center;align-items:center;display:flex;box-shadow:0 8px 24px #2563eb66}.admin-auth-logo{border-radius:var(--radius-md);width:120px;margin:0 auto var(--space-4);box-shadow:0 4px 16px #0000004d}.admin-auth-title{font-size:var(--text-2xl);color:var(--color-white);margin-bottom:var(--space-1);font-weight:800}.admin-auth-subtitle{color:#ffffff80;letter-spacing:.03em;text-transform:uppercase;font-size:11px;font-weight:600}.admin-auth-divider{height:1px;margin-bottom:var(--space-6);background:#ffffff14}.admin-auth-error{border-radius:var(--radius-md);padding:var(--space-3) var(--space-4);font-size:var(--text-sm);color:#ff8a80;margin-bottom:var(--space-4);align-items:center;gap:var(--space-2);background:#e74c3c1f;border:1px solid #e74c3c4d;font-weight:500;display:flex}.admin-demo-hint{margin-top:var(--space-6);padding:var(--space-3) var(--space-4);border-radius:var(--radius-md);font-size:var(--text-xs);color:#ffffff80;text-align:center;background:#ffffff0f;border:1px solid #ffffff1a}.admin-demo-hint span{color:var(--color-primary-light);margin-right:var(--space-1);font-weight:700}.admin-auth-footer{margin-top:var(--space-6);justify-content:center;align-items:center;gap:var(--space-2);color:#ffffff40;text-align:center;font-size:11px;line-height:1.5;display:flex}.admin-portal-back{margin-top:var(--space-6);z-index:1;position:relative}.admin-portal-back a{font-size:var(--text-sm);color:#fff6;transition:color var(--transition-fast)}.admin-portal-back a:hover{color:#fffc;text-decoration:none}@media (width<=640px){.admin-auth-container{padding:var(--space-4)}.admin-auth-card{padding:var(--space-8) var(--space-6);max-width:100%}.admin-auth-title{font-size:var(--text-xl)}}@media (width<=420px){.admin-auth-card{padding:var(--space-6) var(--space-4)}.admin-auth-logo{width:92px}}.admin-overview-page{flex-direction:column;gap:1rem;display:flex}.admin-overview-header h1{color:#1e1b4b;margin:0;font-size:1.6rem}.admin-overview-header p{color:#6b7280;margin:.35rem 0 0}.admin-kpi-grid{grid-template-columns:repeat(4,minmax(0,1fr));gap:.9rem;display:grid}.admin-kpi-card{background:#fff;border:1px solid #e0e7ff;border-radius:14px;padding:.95rem}.admin-kpi-card h4{color:#6b7280;margin:0;font-size:.83rem;font-weight:700}.admin-kpi-value{color:#1e1b4b;margin:.45rem 0 0;font-size:1.65rem;font-weight:800}.admin-overview-grid{grid-template-columns:1.15fr 1fr;align-items:start;gap:1rem;display:grid}.admin-panel{background:#fff;border:1px solid #e0e7ff;border-radius:14px;height:fit-content;padding:.95rem}.admin-panel h3{color:#1e1b4b;margin:0;font-size:1rem}.admin-panel p{color:#6b7280;margin:.35rem 0 .8rem;font-size:.86rem}.admin-chart-wrap{height:220px}.admin-chart-canvas{width:100%;height:100%}.admin-risk-table-wrap{overflow-x:auto}.admin-risk-table-wrap::-webkit-scrollbar{height:6px}.admin-risk-table-wrap::-webkit-scrollbar-thumb{background:#c5dcef;border-radius:999px}.admin-activity-list{flex-direction:column;gap:.7rem;display:flex}.admin-panel--events .admin-activity-list{max-height:220px;padding-right:.25rem;overflow-y:auto}.admin-panel--events .admin-activity-list::-webkit-scrollbar{width:6px}.admin-panel--events .admin-activity-list::-webkit-scrollbar-thumb{background:#c5dcef;border-radius:999px}.admin-activity-item{background:#f9fafb;border:1px solid #e5eff9;border-radius:10px;padding:.62rem .72rem}.admin-activity-item.alert{background:#fff6f6;border-color:#ffd4d4}.admin-activity-message{color:#274869;margin:0;font-size:.87rem}.admin-activity-time{color:#6b7280;margin:.28rem 0 0;font-size:.75rem;font-weight:700}.admin-risk-table{border-collapse:collapse;width:100%}.admin-risk-table th,.admin-risk-table td{text-align:left;border-bottom:1px solid #e7f0f9;padding:.62rem .35rem;font-size:.84rem}.admin-risk-table th{color:#6b7280;font-weight:700}.admin-risk-table td{color:#183a61}.admin-risk-score{color:#d64545;font-weight:700}.admin-risk-chip{color:#d64545;background:#fff2f2;border-radius:999px;align-items:center;padding:.18rem .45rem;font-size:.72rem;font-weight:700;display:inline-flex}@media (width<=1100px){.admin-kpi-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.admin-overview-grid{grid-template-columns:1fr}.admin-chart-wrap{height:240px}}@media (width<=700px){.admin-kpi-grid{grid-template-columns:1fr}.admin-overview-header h1{font-size:1.35rem}.admin-panel{padding:.8rem}.admin-chart-wrap{-webkit-overflow-scrolling:touch;height:210px;overflow:auto hidden}.admin-chart-canvas,.admin-risk-table{min-width:560px}}@media (width<=480px){.admin-overview-page{gap:.8rem}.admin-overview-header h1{font-size:1.2rem}.admin-kpi-card,.admin-panel{padding:.7rem}.admin-kpi-value{font-size:1.35rem}.admin-chart-wrap{height:190px}.admin-chart-canvas,.admin-risk-table{min-width:520px}}.admin-students-page{flex-direction:column;gap:1rem;display:flex}.admin-students-header h1{color:#1e1b4b;margin:0;font-size:1.55rem}.admin-students-header p{color:#6b7280;margin:.3rem 0 0}.admin-students-kpis{grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:.8rem;display:grid}.admin-students-kpi{background:#fff;border:1px solid #e0e7ff;border-radius:12px;padding:.75rem}.admin-students-kpi h4{color:#6b7280;margin:0;font-size:.76rem;font-weight:700}.admin-students-kpi p{color:#1e1b4b;margin:.4rem 0 0;font-size:1.45rem;font-weight:800}.admin-students-filters{grid-template-columns:1.6fr repeat(2,minmax(0,1fr));align-items:center;gap:.6rem;display:grid}.admin-students-filters select,.admin-students-input input{font:inherit;color:#1e1b4b;background:#fff;border:1px solid #e0e7ff;border-radius:10px;padding:.6rem .7rem}.admin-students-input{border:1px solid #e0e7ff;border-radius:10px;align-items:center;gap:.45rem;padding:0 .6rem;display:flex}.admin-students-input input{border:none;outline:none;width:100%;padding:.6rem 0}.admin-students-grid{grid-template-columns:1.2fr 1fr;align-items:stretch;gap:1rem;display:grid}.admin-students-table-card,.admin-students-detail-card{align-self:stretch;min-height:100%}.admin-students-table-card{flex-direction:column;display:flex}.admin-students-table-card h3,.admin-students-detail-card h3{color:#1e1b4b;margin:0}.admin-students-table-card>p{color:#6b7280;margin:.35rem 0 .75rem;font-size:.86rem}.admin-students-table-wrap{border:1px solid #e6f0f9;border-radius:12px;flex:1;min-height:0;overflow-x:auto}.admin-students-table{border-collapse:collapse;width:100%;min-width:760px}.admin-students-table th,.admin-students-table td{text-align:left;color:#1e1b4b;border-bottom:1px solid #e7f0f9;padding:.62rem;font-size:.83rem}.admin-students-table th{color:#6b7280;background:#f9fafb}.admin-students-table td strong{color:#1e1b4b;display:block}.admin-students-table td span{color:#6b7280;font-size:.75rem}.admin-students-table tbody tr{cursor:pointer}.admin-students-table tbody tr:hover{background:#f8fcff}.admin-students-table tbody tr.selected{background:#eef6ff}.ops-chip{text-transform:capitalize;border-radius:999px;align-items:center;gap:.25rem;padding:.2rem .45rem;font-size:.72rem;font-weight:700;display:inline-flex}.status-active{color:#1e9655;background:#ebfaf1}.status-inactive{color:#546b87;background:#f1f4f8}.status-suspended{color:#cf4040;background:#fff3f3}.status-pending{color:#b67211;background:#fff7ea}.risk-low{color:#1e9655;background:#ebfaf1}.risk-medium{color:#b67211;background:#fff7ea}.risk-high{color:#c45b00;background:#fff3e5}.risk-critical{color:#cf4040;background:#fff0f0}.admin-students-detail-card{flex-direction:column;gap:.9rem;display:flex}.admin-students-detail-header{justify-content:space-between;align-items:flex-start;gap:.8rem;display:flex}.admin-students-detail-header p{color:#6b7280;margin:.26rem 0 0;font-size:.84rem}.admin-students-meta{grid-template-columns:repeat(2,minmax(0,1fr));gap:.45rem;display:grid}.admin-students-meta span{color:#315476;background:#f9fafb;border:1px solid #e0e7ff;border-radius:10px;padding:.45rem .55rem;font-size:.78rem}.admin-students-progress-grid{gap:.5rem;display:grid}.admin-students-progress-grid label{color:#4c6f94;margin-bottom:.2rem;font-size:.78rem;display:block}.ops-progress{background:#e7f0f9;border-radius:999px;height:8px;overflow:hidden}.ops-progress span{border-radius:inherit;background:linear-gradient(90deg,#4f46e5,#818cf8);height:100%;display:block}.admin-students-actions h4,.admin-students-notes h4,.admin-students-interventions h4,.admin-students-activity h4{color:#1e1b4b;align-items:center;gap:.35rem;margin:0;font-size:.9rem;display:flex}.admin-students-actions-row{flex-wrap:wrap;gap:.45rem;margin-top:.55rem;display:flex}.admin-students-actions-row button,.admin-students-note-compose button{color:#4f46e5;background:#eff7ff;border:1px solid #c7ddf2;border-radius:9px;align-items:center;gap:.35rem;padding:.45rem .65rem;font-size:.78rem;font-weight:700;display:inline-flex}.admin-students-notice{color:#4f46e5;margin:.5rem 0 0;font-size:.78rem;font-weight:700}.admin-students-note-compose{grid-template-columns:1fr auto;gap:.45rem;margin-top:.45rem;display:grid}.admin-students-note-compose textarea{resize:vertical;min-height:68px}.admin-students-note-list,.admin-students-intervention-list,.admin-students-activity-list{flex-direction:column;gap:.45rem;margin-top:.5rem;display:flex}.admin-students-note-list article,.admin-students-intervention-list article,.admin-students-activity-list article{background:#fafdff;border:1px solid #e0e7ff;border-radius:10px;padding:.52rem .58rem}.admin-students-note-list p,.admin-students-intervention-list p,.admin-students-activity-list p{color:#234568;margin:0;font-size:.82rem}.admin-students-note-list span,.admin-students-intervention-list span,.admin-students-activity-list span{color:#6b7280;margin-top:.24rem;font-size:.74rem;display:block}.admin-students-empty,.admin-students-empty-inline{color:#6b7280;font-size:.84rem}.admin-students-empty{padding:.7rem}@media (width<=1200px){.admin-students-filters{grid-template-columns:1fr 1fr 1fr}.admin-students-input{grid-column:1/-1}.admin-students-grid{grid-template-columns:1fr}}@media (width<=760px){.admin-students-kpis{grid-template-columns:1fr 1fr}.admin-students-filters,.admin-students-meta,.admin-students-note-compose{grid-template-columns:1fr}}@media (width<=480px){.admin-students-header h1{font-size:1.3rem}.admin-students-kpis{grid-template-columns:1fr}}.admin-metrics-page,.admin-financials-page{flex-direction:column;gap:1rem;display:flex}.admin-metrics-header h1{color:#1e1b4b;margin:0;font-size:1.55rem}.admin-metrics-header p{color:#6b7280;margin:.3rem 0 0}.admin-metrics-controls{flex-wrap:wrap;align-items:center;gap:.7rem;display:flex}.admin-metrics-controls label{color:#4f7093;font-size:.82rem;font-weight:700}.admin-metrics-controls select{color:#1e1b4b;font:inherit;background:#fff;border:1px solid #e0e7ff;border-radius:9px;padding:.42rem .58rem}.admin-metrics-controls__hint{color:#6b7280;font-size:.78rem}.admin-metrics-taxonomy h3,.admin-metrics-ai-insight h3{color:#1e1b4b;margin:0;font-size:.95rem}.admin-metrics-taxonomy{flex-direction:column;gap:.6rem;display:flex}.taxonomy-filter{grid-template-columns:repeat(3,minmax(0,1fr));gap:.65rem;display:grid}.taxonomy-filter__field{flex-direction:column;gap:.3rem;display:flex}.taxonomy-filter__field label{color:#4f7093;font-size:.78rem;font-weight:700}.taxonomy-filter__field select{color:#1e1b4b;font:inherit;background:#fff;border:1px solid #e0e7ff;border-radius:9px;padding:.42rem .58rem}.admin-metrics-ai-insight{flex-direction:column;gap:.5rem;display:flex}.admin-metrics-ai-insight p{color:#6b7280;margin:0;font-size:.82rem}.admin-metrics-ai-insight__chips{flex-wrap:wrap;gap:.45rem;display:flex}.admin-metrics-ai-insight__chips span{color:#2f5477;background:#f4f9ff;border-radius:999px;align-items:center;padding:.28rem .6rem;font-size:.75rem;font-weight:700;display:inline-flex}.admin-metrics-kpis,.admin-financials-kpis{gap:.8rem;display:grid}.admin-metrics-kpis{grid-template-columns:repeat(4,minmax(0,1fr))}.admin-financials-kpis{grid-template-columns:repeat(3,minmax(0,1fr))}.admin-metrics-kpi,.admin-financials-kpi{background:#fff;border:1px solid #e0e7ff;border-radius:12px;padding:.8rem}.admin-metrics-kpi h4,.admin-financials-kpi h4{color:#6b7280;margin:0;font-size:.78rem;font-weight:700}.admin-metrics-kpi .value,.admin-financials-kpi .value{color:#1e1b4b;margin:.42rem 0 0;font-size:1.32rem;font-weight:800}.admin-metrics-kpi .delta,.admin-financials-kpi .delta{margin:.25rem 0 0;font-size:.76rem;font-weight:700}.delta.up{color:#1d9b57}.delta.down{color:#d64545}.delta.neutral{color:#6b7280}.admin-metrics-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:1rem;display:grid}.admin-metrics-panel{flex-direction:column;gap:.55rem;display:flex}.admin-metrics-panel--full-row{grid-column:1/-1}.admin-metrics-panel h3{color:#1e1b4b;margin:0;font-size:1rem}.admin-metrics-panel>p{color:#6b7280;margin:0;font-size:.84rem}.admin-metrics-chart-wrap{height:250px}.admin-metrics-chart-canvas{width:100%;height:100%}.admin-metrics-legend{flex-wrap:wrap;gap:.45rem;display:flex}.admin-metrics-legend span{color:#2f5477;background:#f4f9ff;border-radius:999px;align-items:center;gap:.35rem;padding:.2rem .5rem;font-size:.74rem;font-weight:700;display:inline-flex}.admin-metrics-legend i{border-radius:50%;width:10px;height:10px;display:inline-block}.admin-metrics-table-wrap{border:1px solid #e6f0f9;border-radius:12px;overflow-x:auto}.admin-metrics-table{border-collapse:collapse;width:100%;min-width:540px}.admin-metrics-table th,.admin-metrics-table td{text-align:left;color:#1e1b4b;border-bottom:1px solid #e7f0f9;padding:.58rem;font-size:.82rem}.admin-metrics-table th{color:#6b7280;background:#f9fafb}.admin-financials-invoices{grid-column:1/-1}.admin-financials-status{text-transform:capitalize;border-radius:999px;align-items:center;padding:.2rem .45rem;font-size:.72rem;font-weight:700;display:inline-flex}.admin-financials-status.paid{color:#1e9655;background:#ebfaf1}.admin-financials-status.failed{color:#cf4040;background:#fff0f0}.admin-financials-status.refunded{color:#4f46e5;background:#eef6ff}@media (width<=1280px){.admin-metrics-kpis,.admin-financials-kpis{grid-template-columns:repeat(3,minmax(0,1fr))}}@media (width<=980px){.admin-metrics-grid{grid-template-columns:1fr}}@media (width<=760px){.taxonomy-filter{grid-template-columns:1fr}.admin-metrics-kpis,.admin-financials-kpis{grid-template-columns:1fr 1fr}.admin-metrics-chart-wrap{-webkit-overflow-scrolling:touch;height:220px;overflow:auto hidden}.admin-metrics-chart-canvas{min-width:560px}}@media (width<=520px){.admin-metrics-header h1{font-size:1.3rem}.admin-metrics-kpis,.admin-financials-kpis{grid-template-columns:1fr}.admin-metrics-chart-wrap{height:205px}.admin-metrics-chart-canvas{min-width:520px}}.admin-comments-page{flex-direction:column;gap:1rem;display:flex}.admin-comments-header h1{color:#1e1b4b;margin:0;font-size:1.5rem}.admin-comments-header p{color:#6b7280;margin:.3rem 0 0}.admin-comments-kpis{grid-template-columns:repeat(4,minmax(0,1fr));gap:.8rem;display:grid}.admin-comments-kpi{background:#fff;border:1px solid #e0e7ff;border-radius:12px;padding:.8rem}.admin-comments-kpi h4{color:#6b7280;margin:0;font-size:.76rem;font-weight:700}.admin-comments-kpi p{color:#1e1b4b;margin:.4rem 0 0;font-size:1.4rem;font-weight:800}.admin-comments-filters{grid-template-columns:1.8fr 1fr;gap:.6rem;display:grid}.admin-comments-search{border:1px solid #e0e7ff;border-radius:10px;align-items:center;gap:.45rem;padding:0 .6rem;display:flex}.admin-comments-search input,.admin-comments-filters select{font:inherit;color:#1e1b4b;background:#fff;border:1px solid #e0e7ff;border-radius:10px;padding:.58rem .68rem}.admin-comments-search input{border:none;outline:none;width:100%;padding:.58rem 0}.admin-comments-grid{grid-template-columns:1.08fr 1fr;align-items:stretch;gap:1rem;display:grid}.admin-comments-queue-card,.admin-comments-detail-card{align-self:stretch;min-height:100%}.admin-comments-queue-card{flex-direction:column;display:flex}.admin-comments-queue-card h3,.admin-comments-detail-card h3{color:#1e1b4b;align-items:center;gap:.35rem;margin:0;font-size:1rem;display:flex}.admin-comments-queue-card>p{color:#6b7280;margin:.35rem 0 .75rem;font-size:.85rem}.admin-comments-queue-list{flex-direction:column;gap:.5rem;max-height:720px;padding-right:.15rem;display:flex;overflow-y:auto}.admin-comment-item{cursor:pointer;background:#f9fafb;border:1px solid #e0e7ff;border-radius:12px;padding:.62rem}.admin-comment-item.selected{background:#f2f9ff;border-color:#9ec6e8}.admin-comment-item header{justify-content:space-between;align-items:flex-start;gap:.6rem;display:flex}.admin-comment-item header strong{color:#1e1b4b;font-size:.88rem}.admin-comment-item header span{color:#6b7280;margin-top:.2rem;font-size:.74rem;display:block}.admin-comment-item p{color:#26486b;margin:.45rem 0;font-size:.83rem;line-height:1.45}.admin-comment-item footer{flex-wrap:wrap;justify-content:space-between;gap:.45rem;display:flex}.admin-comment-item footer span{color:#6b7280;font-size:.74rem}.admin-comment-item-chips{flex-wrap:wrap;justify-content:flex-end;gap:.3rem;display:flex}.comment-chip{text-transform:capitalize;border-radius:999px;align-items:center;gap:.24rem;padding:.2rem .45rem;font-size:.72rem;font-weight:700;display:inline-flex}.status-visible{color:#32895a;background:#edf7f1}.status-hidden{color:#495f7b;background:#f2f4f8}.admin-comments-detail-card{flex-direction:column;gap:.85rem;display:flex}.admin-comments-detail-header{justify-content:space-between;align-items:flex-start;gap:.75rem;display:flex}.admin-comments-detail-header p{color:#6b7280;margin:.25rem 0 0;font-size:.83rem}.admin-comments-detail-meta{grid-template-columns:repeat(2,minmax(0,1fr));gap:.45rem;display:grid}.admin-comments-detail-meta span{color:#315476;background:#f9fafb;border:1px solid #e0e7ff;border-radius:9px;padding:.42rem .5rem;font-size:.77rem}.admin-comments-detail-body h4,.admin-comments-actions h4,.admin-comments-history h4{color:#1e1b4b;align-items:center;gap:.35rem;margin:0;font-size:.9rem;display:flex}.admin-comments-detail-body p{color:#244669;background:#f9fafb;border:1px solid #e4eef9;border-radius:10px;margin:.45rem 0 0;padding:.58rem;font-size:.84rem;line-height:1.45}.admin-comments-actions-row{flex-wrap:wrap;gap:.45rem;margin-top:.52rem;display:flex}.admin-comments-actions-row button{color:#4f46e5;background:#eff7ff;border:1px solid #c7ddf2;border-radius:9px;align-items:center;gap:.32rem;padding:.45rem .62rem;font-size:.78rem;font-weight:700;display:inline-flex}.admin-comments-notice{color:#4f46e5;margin:.5rem 0 0;font-size:.78rem;font-weight:700}.admin-comments-history-list{flex-direction:column;gap:.45rem;margin-top:.5rem;display:flex}.admin-comments-history-list article{background:#fafdff;border:1px solid #e0e7ff;border-radius:10px;padding:.52rem .58rem}.admin-comments-history-list p{color:#234568;margin:0;font-size:.82rem}.admin-comments-history-list span{color:#6b7280;margin-top:.2rem;font-size:.74rem;display:block}.admin-comments-empty{color:#6b7280;font-size:.83rem}@media (width<=1220px){.admin-comments-kpis{grid-template-columns:repeat(3,minmax(0,1fr))}.admin-comments-filters{grid-template-columns:1fr 1fr}.admin-comments-search{grid-column:1/-1}.admin-comments-grid{grid-template-columns:1fr}}@media (width<=760px){.admin-comments-kpis{grid-template-columns:1fr 1fr}.admin-comments-filters,.admin-comments-detail-meta{grid-template-columns:1fr}}@media (width<=500px){.admin-comments-header h1{font-size:1.3rem}.admin-comments-kpis{grid-template-columns:1fr}}.adm-community{flex-direction:column;height:calc(100vh - 120px);display:flex}.adm-community__header{flex-wrap:wrap;flex-shrink:0;justify-content:space-between;align-items:flex-start;gap:20px;margin-bottom:20px;display:flex}.adm-community__title{color:var(--color-navy,#1e1b4b);margin:0 0 4px;font-size:22px;font-weight:700}.adm-community__subtitle{color:#64748b;margin:0;font-size:13px}.adm-community__mode-wrap{flex-direction:column;align-items:flex-end;gap:6px;display:flex}.adm-community__mode-label{color:#64748b;text-transform:uppercase;letter-spacing:.04em;font-size:11px;font-weight:600}.adm-community__mode-toggle{background:#f8fafc;border:1px solid #e2e8f0;border-radius:10px;display:flex;overflow:hidden}.adm-community__mode-btn{color:#64748b;cursor:pointer;background:0 0;border:none;align-items:center;gap:6px;padding:8px 14px;font-family:inherit;font-size:13px;font-weight:500;transition:background .15s,color .15s;display:flex}.adm-community__mode-btn--active{color:#fff;background:#4f46e5}.adm-community__mode-btn--readonly.adm-community__mode-btn--active{background:#dc2626}.adm-community__feed{scrollbar-width:thin;scrollbar-color:#d1e3f5 transparent;flex-direction:column;flex:1;gap:14px;padding:4px 0 12px;display:flex;overflow-y:auto}.adm-community__msg{align-items:flex-start;gap:12px;display:flex}.adm-community__avatar{color:#4338ca;background:#e0e7ff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;font-size:12px;font-weight:700;display:flex}.adm-community__avatar--admin{color:#fff;background:#1e1b4b}.adm-community__msg-body{background:#fff;border:1px solid #eef2ff;border-radius:0 12px 12px;flex:1;padding:10px 14px;box-shadow:0 1px 3px #0f1f6a0a}.adm-community__msg-meta{align-items:center;gap:8px;margin-bottom:4px;display:flex}.adm-community__msg-name{color:#1e1b4b;align-items:center;gap:5px;font-size:13px;font-weight:600;display:flex}.adm-community__admin-tag{color:#fff;background:#1e1b4b;border-radius:999px;padding:1px 6px;font-size:10px;font-weight:700}.adm-community__msg-time{color:#94a3b8;margin-left:auto;font-size:11px}.adm-community__delete{color:#94a3b8;cursor:pointer;background:0 0;border:none;border-radius:4px;align-items:center;padding:2px;transition:color .15s;display:flex}.adm-community__delete:hover{color:#dc2626}.adm-community__msg-text{color:#1e293b;white-space:pre-wrap;word-break:break-word;margin:0;font-size:14px;line-height:1.55}.adm-community__composer{border-top:1px solid #eef2ff;flex-shrink:0;align-items:center;gap:10px;padding:14px 0 0;display:flex}.adm-community__input{color:#1e1b4b;background:#fff;border:1px solid #d1e3f5;border-radius:10px;outline:none;flex:1;padding:10px 14px;font-family:inherit;font-size:14px;transition:border-color .15s}.adm-community__input:focus{border-color:#4f46e5}.adm-community__send{color:#fff;cursor:pointer;background:#4f46e5;border:none;border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;width:40px;height:40px;transition:opacity .15s;display:flex}.adm-community__send:disabled{opacity:.4;cursor:default}.adm-community__send:not(:disabled):hover{opacity:.88}.admin-announcements-page{flex-direction:column;gap:1rem;display:flex}.admin-announcements-header h1{color:#1e1b4b;align-items:center;gap:.45rem;margin:0;display:flex}.admin-announcements-header p{color:#6b7280;margin:.25rem 0 0}.admin-announcements-kpis{grid-template-columns:repeat(2,minmax(0,1fr));gap:.8rem;display:grid}.admin-announcements-kpi{background:#fff;border:1px solid #e0e7ff;border-radius:12px;padding:.9rem 1rem}.admin-announcements-kpi h4{color:#6b7280;margin:0;font-size:.82rem;font-weight:600}.admin-announcements-kpi p{color:#1e1b4b;margin:.35rem 0 0;font-size:1.1rem;font-weight:700}.admin-announcements-grid{grid-template-columns:1fr 1.35fr;gap:1rem;display:grid}.admin-announcements-form-card,.admin-announcements-history-card{border:1px solid #e0e7ff}.admin-announcements-form-card h3,.admin-announcements-history-card h3{color:#1e1b4b;margin:0}.admin-announcements-form{flex-direction:column;gap:.8rem;margin-top:.85rem;display:flex}.admin-announcements-form label{color:#456789;flex-direction:column;gap:.45rem;font-size:.82rem;font-weight:600;display:flex}.admin-announcements-form input,.admin-announcements-form textarea{font:inherit;color:#1e1b4b;background:#f9fafb;border:1px solid #d3e6f8;border-radius:10px;padding:.65rem .75rem}.admin-announcements-form textarea{resize:vertical;min-height:124px}.admin-announcements-send{color:#fff;background:#4f46e5;border:none;border-radius:999px;align-items:center;gap:.45rem;width:fit-content;padding:.62rem .95rem;font-weight:700;display:inline-flex}.admin-announcements-notice{color:#4f46e5;margin:.75rem 0 0;font-size:.86rem;font-weight:600}.admin-announcements-history-list{flex-direction:column;gap:.65rem;max-height:560px;margin-top:.8rem;display:flex;overflow:auto}.admin-announcement-item{background:#f9fafb;border:1px solid #e0e7ff;border-radius:11px;padding:.8rem}.admin-announcement-item header{justify-content:space-between;align-items:baseline;gap:.75rem;display:flex}.admin-announcement-item strong{color:#1e1b4b}.admin-announcement-item header span,.admin-announcement-item footer span{color:#6b7280;font-size:.77rem}.admin-announcement-item p{color:#244667;white-space:pre-wrap;margin:.55rem 0;line-height:1.45}.admin-announcements-empty{color:#6b7280;margin:0}@media (width<=1080px){.admin-announcements-grid{grid-template-columns:1fr}}@media (width<=640px){.admin-announcements-kpis{grid-template-columns:1fr}}.admin-affiliates-page{flex-direction:column;gap:1.25rem;display:flex}.admin-affiliates-kpis{grid-template-columns:repeat(4,1fr);gap:1rem;display:grid}.admin-affiliates-kpi{background:#fff;border:1px solid #e0e7ff;border-radius:14px;align-items:center;gap:.85rem;padding:1.1rem;display:flex}.admin-affiliates-kpi__icon{color:#4f46e5;background:#eef2ff;border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;width:40px;height:40px;display:flex}.admin-affiliates-kpi__icon--green{color:#16a34a;background:#e8f8f0}.admin-affiliates-kpi__icon--blue{color:#4f46e5;background:#eef2ff}.admin-affiliates-kpi__icon--navy{color:#1e1b4b;background:#e8ecf5}.admin-affiliates-kpi__label{color:#6b7280;margin:0;font-size:.78rem;font-weight:500}.admin-affiliates-kpi__value{color:#1e1b4b;margin:.2rem 0 0;font-size:1.3rem;font-weight:700}.admin-affiliates-table-section{flex-direction:column;gap:0;padding:1.25rem;display:flex}.admin-affiliates-table-header{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:1rem;margin-bottom:1rem;display:flex}.admin-affiliates-create-btn{color:#fff;cursor:pointer;white-space:nowrap;background:#4f46e5;border:none;border-radius:8px;align-items:center;gap:.4rem;padding:.55rem 1.1rem;font-size:.875rem;font-weight:600;transition:background .15s;display:inline-flex}.admin-affiliates-create-btn:hover{background:#155d96}.admin-affiliates-pay-btn{color:#16a34a;cursor:pointer;background:#e8f8f0;border:1px solid #bbf0d5;border-radius:6px;align-items:center;gap:.35rem;padding:.38rem .8rem;font-size:.8rem;font-weight:600;transition:all .15s;display:inline-flex}.admin-affiliates-pay-btn:hover{color:#fff;background:#16a34a}.admin-affiliates-pay-btn--done{color:#16a34a;cursor:default;background:#dcfce7}.admin-affiliates-paid-label{color:#8fa8c4;font-size:.8rem}.admin-affiliates-modal-overlay{z-index:500;background:#05142d80;justify-content:center;align-items:center;padding:1rem;display:flex;position:fixed;inset:0}.admin-affiliates-modal{background:#fff;border-radius:16px;flex-direction:column;gap:1rem;width:100%;max-width:480px;padding:1.5rem;display:flex}.admin-affiliates-modal__header{justify-content:space-between;align-items:center;display:flex}.admin-affiliates-modal__header h3{color:#1e1b4b;margin:0;font-size:1.1rem}.admin-affiliates-modal__close{cursor:pointer;color:#6b7280;background:#f4f8fc;border:none;border-radius:8px;justify-content:center;align-items:center;width:32px;height:32px;display:flex}.admin-affiliates-modal__close:hover{color:#1e1b4b;background:#e8f0fa}.admin-affiliates-form-error{color:#dc2626;background:#fef2f2;border:1px solid #fecaca;border-radius:8px;padding:.65rem .85rem;font-size:.875rem}.admin-affiliates-form{flex-direction:column;gap:.85rem;display:flex}.admin-affiliates-form__field{flex-direction:column;gap:.35rem;display:flex}.admin-affiliates-form__field label{color:#1f2937;font-size:.82rem;font-weight:600}.admin-affiliates-form__field input{color:#1f2937;background:#f9fafb;border:1px solid #e0e7ff;border-radius:8px;outline:none;padding:.6rem .85rem;font-size:.875rem;transition:border-color .15s}.admin-affiliates-form__field input:focus{background:#fff;border-color:#818cf8}.admin-affiliates-form__row{grid-template-columns:1fr 1fr;gap:.75rem;display:grid}.admin-affiliates-form__actions{justify-content:flex-end;gap:.6rem;margin-top:.25rem;display:flex}.admin-affiliates-form__cancel{color:#6b7280;cursor:pointer;background:#f4f8fc;border:1px solid #e0e7ff;border-radius:8px;padding:.55rem 1.1rem;font-weight:600}.admin-affiliates-form__submit{color:#fff;cursor:pointer;background:#4f46e5;border:none;border-radius:8px;padding:.55rem 1.25rem;font-weight:600;transition:background .15s}.admin-affiliates-form__submit:hover{background:#155d96}.admin-affiliates-form__submit:disabled{opacity:.6;cursor:not-allowed}@media (width<=900px){.admin-affiliates-kpis{grid-template-columns:1fr 1fr}}@media (width<=500px){.admin-affiliates-kpis,.admin-affiliates-form__row{grid-template-columns:1fr}}.admin-teachers-page{gap:16px;display:grid}.admin-teachers-kpi-grid{grid-template-columns:repeat(4,1fr);gap:12px;display:grid}.admin-teachers-kpi-card{background:#fff;border:1px solid #e0e7ff;border-radius:14px;padding:14px;position:relative;overflow:hidden}.admin-teachers-kpi-card--pending{background:#fffbeb;border-color:#fde68a}.admin-teachers-kpi-card__label{color:#6b7280;text-transform:uppercase;letter-spacing:.06em;font-size:.78rem;font-weight:600}.admin-teachers-kpi-card--pending .admin-teachers-kpi-card__label{color:#92400e}.admin-teachers-kpi-card__value{color:#1e1b4b;margin-top:4px;font-size:1.6rem;font-weight:800;line-height:1.1}.admin-teachers-kpi-card--pending .admin-teachers-kpi-card__value{color:#b45309}.admin-teachers-kpi-card__sub{color:#4b5563;margin-top:2px;font-size:.78rem}.admin-teachers-kpi-card__icon{float:right;color:#4f46e5;background:#eef2ff;border-radius:10px;justify-content:center;align-items:center;width:36px;height:36px;display:flex}.admin-teachers-section{background:#fff;border:1px solid #e0e7ff;border-radius:14px;gap:12px;padding:16px;display:grid}.admin-teachers-section__header{justify-content:space-between;align-items:center;display:flex}.admin-teachers-section__title{color:#1e1b4b;margin:0;font-size:.92rem;font-weight:700}.admin-teachers-table{border-collapse:collapse;width:100%;font-size:.87rem}.admin-teachers-table th{text-align:left;color:#6b7280;text-transform:uppercase;letter-spacing:.05em;border-bottom:1px solid #eef2ff;padding:8px 12px;font-size:.78rem;font-weight:600}.admin-teachers-table td{color:#374151;vertical-align:middle;border-bottom:1px solid #f3f4f6;padding:10px 12px}.admin-teachers-table tr:last-child td{border-bottom:none}.admin-teachers-table tr:hover td{background:#f9fafb}.admin-teachers-badge{border-radius:999px;align-items:center;gap:4px;padding:3px 10px;font-size:.75rem;font-weight:700;display:inline-flex}.admin-teachers-badge--approved{color:#15803d;background:#dcfce7}.admin-teachers-badge--pending{color:#b45309;background:#fef3c7}.admin-teachers-badge--suspended{color:#dc2626;background:#fee2e2}.admin-teachers-tabs{border-bottom:2px solid #eef2ff;gap:4px;margin-bottom:4px;display:flex}.admin-teachers-tab{color:#6b7280;cursor:pointer;background:0 0;border:none;border-bottom:2px solid #0000;margin-bottom:-2px;padding:7px 14px;font-size:.85rem;font-weight:600;transition:color .15s,border-color .15s}.admin-teachers-tab--active{color:#4f46e5;border-bottom-color:#4f46e5}.admin-teachers-empty{text-align:center;color:#6b7280;padding:2.5rem}.admin-teachers-modal-overlay{z-index:500;background:#03122673;justify-content:center;align-items:center;padding:1rem;display:flex;position:fixed;inset:0}.admin-teachers-modal{background:#fff;border-radius:16px;gap:16px;width:100%;max-width:460px;padding:1.5rem;display:grid}.admin-teachers-modal__title{color:#1e1b4b;margin:0;font-size:1rem;font-weight:700}.admin-teachers-toast{color:#fff;z-index:600;background:#1e1b4b;border-radius:10px;padding:10px 16px;font-size:.87rem;font-weight:600;position:fixed;bottom:1.5rem;right:1.5rem;box-shadow:0 4px 16px #1e1b4b40}@media (width<=900px){.admin-teachers-kpi-grid{grid-template-columns:repeat(2,1fr)}}@media (width<=600px){.admin-teachers-kpi-grid{grid-template-columns:1fr 1fr}}.admin-products-page{gap:16px;display:grid}.admin-products-kpi-grid{grid-template-columns:repeat(3,1fr);gap:12px;display:grid}.admin-products-kpi-card{background:#fff;border:1px solid #e0e7ff;border-radius:14px;padding:14px;position:relative;overflow:hidden}.admin-products-kpi-card__label{color:#6b7280;text-transform:uppercase;letter-spacing:.06em;font-size:.78rem;font-weight:600}.admin-products-kpi-card__value{color:#1e1b4b;margin-top:4px;font-size:1.6rem;font-weight:800;line-height:1.1}.admin-products-kpi-card__sub{color:#4b5563;margin-top:2px;font-size:.78rem}.admin-products-kpi-card__icon{float:right;color:#4f46e5;background:#eef2ff;border-radius:10px;justify-content:center;align-items:center;width:36px;height:36px;display:flex}.admin-products-section{background:#fff;border:1px solid #e0e7ff;border-radius:14px;gap:12px;padding:16px;display:grid}.admin-products-section__header{justify-content:space-between;align-items:center;display:flex}.admin-products-section__title{color:#1e1b4b;margin:0;font-size:.92rem;font-weight:700}.admin-products-grid{grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:14px;display:grid}.admin-products-card{background:#fff;border:1px solid #e0e7ff;border-radius:14px;gap:12px;padding:16px;transition:border-color .15s;display:grid}.admin-products-card:hover{border-color:#8ec4e8}.admin-products-card--inactive{opacity:.7;border-style:dashed}.admin-products-card__header{justify-content:space-between;align-items:flex-start;gap:8px;display:flex}.admin-products-card__name{color:#1e1b4b;margin:0;font-size:1rem;font-weight:800}.admin-products-card__active-badge{white-space:nowrap;border-radius:999px;flex-shrink:0;align-items:center;gap:4px;padding:3px 10px;font-size:.73rem;font-weight:700;display:inline-flex}.admin-products-card__active-badge--active{color:#15803d;background:#dcfce7}.admin-products-card__active-badge--inactive{color:#6b7280;background:#f3f4f6}.admin-products-card__desc{color:#4b5563;margin:0;font-size:.83rem;line-height:1.6}.admin-products-card__prices{flex-wrap:wrap;gap:10px;display:flex}.admin-products-card__price{background:#f9fafb;border:1px solid #eef2ff;border-radius:8px;gap:2px;padding:6px 10px;display:grid}.admin-products-card__price-label{color:#6b7280;text-transform:uppercase;letter-spacing:.05em;font-size:.7rem;font-weight:600}.admin-products-card__price-value{color:#1e1b4b;font-size:.92rem;font-weight:800}.admin-products-card__meta{color:#6b7280;gap:10px;font-size:.78rem;display:flex}.admin-products-card__footer{flex-wrap:wrap;gap:8px;display:flex}.admin-products-table{border-collapse:collapse;width:100%;font-size:.87rem}.admin-products-table th{text-align:left;color:#6b7280;text-transform:uppercase;letter-spacing:.05em;border-bottom:1px solid #eef2ff;padding:8px 12px;font-size:.78rem;font-weight:600}.admin-products-table td{color:#374151;vertical-align:middle;border-bottom:1px solid #f3f4f6;padding:10px 12px}.admin-products-table tr:last-child td{border-bottom:none}.admin-products-modal-overlay{z-index:500;background:#03122673;justify-content:center;align-items:center;padding:1rem;display:flex;position:fixed;inset:0}.admin-products-modal{background:#fff;border-radius:16px;gap:16px;width:100%;max-width:540px;max-height:90vh;padding:1.5rem;display:grid;overflow-y:auto}.admin-products-modal__title{color:#1e1b4b;margin:0;font-size:1rem;font-weight:700}.admin-products-toast{color:#fff;z-index:600;background:#1e1b4b;border-radius:10px;padding:10px 16px;font-size:.87rem;font-weight:600;position:fixed;bottom:1.5rem;right:1.5rem;box-shadow:0 4px 16px #1e1b4b40}.admin-products-empty{text-align:center;color:#6b7280;padding:2.5rem}@media (width<=900px){.admin-products-kpi-grid{grid-template-columns:repeat(2,1fr)}}.admin-lms-sessions-page{gap:16px;display:grid}.admin-lms-kpi-grid{grid-template-columns:repeat(4,1fr);gap:12px;display:grid}.admin-lms-kpi-card{background:#fff;border:1px solid #e0e7ff;border-radius:14px;padding:14px;position:relative;overflow:hidden}.admin-lms-kpi-card--live{background:linear-gradient(135deg,#f0fdf4,#dcfce7);border-color:#bbf7d0}.admin-lms-kpi-card__label{color:#6b7280;text-transform:uppercase;letter-spacing:.06em;font-size:.78rem;font-weight:600}.admin-lms-kpi-card--live .admin-lms-kpi-card__label{color:#166534}.admin-lms-kpi-card__value{color:#1e1b4b;margin-top:4px;font-size:1.6rem;font-weight:800;line-height:1.1}.admin-lms-kpi-card--live .admin-lms-kpi-card__value{color:#15803d}.admin-lms-kpi-card__sub{color:#4b5563;margin-top:2px;font-size:.78rem}.admin-lms-kpi-card__icon{float:right;color:#4f46e5;background:#eef2ff;border-radius:10px;justify-content:center;align-items:center;width:36px;height:36px;display:flex}.admin-lms-kpi-card--live .admin-lms-kpi-card__icon{color:#16a34a;background:#dcfce7}@keyframes lms-pulse{0%,to{opacity:1}50%{opacity:.5}}.admin-lms-live-banner{color:#fff;background:linear-gradient(135deg,#16a34a,#15803d);border-radius:12px;flex-wrap:wrap;align-items:center;gap:10px;padding:12px 16px;display:flex}.admin-lms-live-banner__pulse{background:#fff;border-radius:50%;flex-shrink:0;width:10px;height:10px;animation:1.5s infinite lms-pulse}.admin-lms-live-banner__label{font-size:.87rem;font-weight:800}.admin-lms-live-banner__sessions{flex-wrap:wrap;flex:1;gap:8px;display:flex}.admin-lms-live-session-chip{background:#fff3;border:1px solid #ffffff4d;border-radius:999px;padding:3px 10px;font-size:.78rem;font-weight:600}.admin-lms-section{background:#fff;border:1px solid #e0e7ff;border-radius:14px;gap:12px;padding:16px;display:grid}.admin-lms-section__header{justify-content:space-between;align-items:center;display:flex}.admin-lms-section__title{color:#1e1b4b;margin:0;font-size:.92rem;font-weight:700}.admin-lms-table{border-collapse:collapse;width:100%;font-size:.87rem}.admin-lms-table th{text-align:left;color:#6b7280;text-transform:uppercase;letter-spacing:.05em;border-bottom:1px solid #eef2ff;padding:8px 12px;font-size:.78rem;font-weight:600}.admin-lms-table td{color:#374151;vertical-align:middle;border-bottom:1px solid #f3f4f6;padding:10px 12px}.admin-lms-table tr:last-child td{border-bottom:none}.admin-lms-table tr:hover td{background:#f9fafb}.admin-lms-badge{border-radius:999px;align-items:center;gap:4px;padding:3px 10px;font-size:.75rem;font-weight:700;display:inline-flex}.admin-lms-badge--live{color:#15803d;background:#dcfce7}.admin-lms-badge--scheduled{color:#4338ca;background:#e0e7ff}.admin-lms-badge--completed{color:#6b7280;background:#f3f4f6}.admin-lms-badge--cancelled{color:#dc2626;background:#fee2e2}.admin-lms-filter-bar{flex-wrap:wrap;align-items:center;gap:6px;display:flex}.admin-lms-filter-btn{cursor:pointer;color:#6b7280;background:0 0;border:1px solid #eef2ff;border-radius:999px;padding:5px 12px;font-size:.8rem;font-weight:600;transition:all .15s}.admin-lms-filter-btn--active{color:#fff;background:#4f46e5;border-color:#4f46e5}.admin-lms-modal-overlay{z-index:500;background:#03122673;justify-content:center;align-items:center;padding:1rem;display:flex;position:fixed;inset:0}.admin-lms-modal{background:#fff;border-radius:16px;gap:16px;width:100%;max-width:560px;max-height:90vh;padding:1.5rem;display:grid;overflow-y:auto}.admin-lms-modal__title{color:#1e1b4b;margin:0;font-size:1rem;font-weight:700}.admin-lms-toast{color:#fff;z-index:600;background:#1e1b4b;border-radius:10px;padding:10px 16px;font-size:.87rem;font-weight:600;position:fixed;bottom:1.5rem;right:1.5rem;box-shadow:0 4px 16px #1e1b4b40}.admin-lms-empty{text-align:center;color:#6b7280;padding:2.5rem}@media (width<=900px){.admin-lms-kpi-grid{grid-template-columns:repeat(2,1fr)}}@media (width<=600px){.admin-lms-kpi-grid{grid-template-columns:1fr 1fr}}.admin-classes-page{flex-direction:column;gap:20px;display:flex}.admin-classes-header{flex-wrap:wrap;justify-content:space-between;align-items:flex-start;gap:12px;display:flex}.admin-classes-header h1{color:#1e1b4b;margin:0;font-size:1.2rem;font-weight:800}.admin-classes-header p{color:#4b5563;margin:4px 0 0;font-size:.85rem}.admin-classes-kpis{grid-template-columns:repeat(3,1fr);gap:14px;display:grid}@media (width<=600px){.admin-classes-kpis{grid-template-columns:1fr}}.admin-classes-kpi{background:#fff;border:1px solid #e0e7ff;border-radius:12px;padding:16px 18px}.admin-classes-kpi h4{color:#6b7280;text-transform:uppercase;letter-spacing:.05em;margin:0 0 6px;font-size:.75rem;font-weight:700}.admin-classes-kpi p{color:#1e1b4b;margin:0;font-size:1.5rem;font-weight:900}.admin-classes-table-card{background:#fff;border:1px solid #e0e7ff;border-radius:14px;padding:20px}.admin-classes-table-card h3{color:#1e1b4b;margin:0 0 14px;font-size:.95rem;font-weight:800}.admin-classes-table-wrap{overflow-x:auto}.admin-classes-table{border-collapse:collapse;width:100%;font-size:.85rem}.admin-classes-table th{text-align:left;color:#6b7280;text-transform:uppercase;letter-spacing:.05em;white-space:nowrap;border-bottom:1px solid #eef2ff;padding:8px 12px;font-size:.72rem;font-weight:700}.admin-classes-table td{color:#374151;vertical-align:middle;border-bottom:1px solid #f9fafb;padding:11px 12px}.admin-classes-table tr:last-child td{border-bottom:none}.admin-classes-table tr:hover td{background:#f9fafb}.admin-classes-actions{flex-wrap:wrap;gap:6px;display:flex}.admin-classes-btn{cursor:pointer;white-space:nowrap;color:#4f46e5;background:#f9fafb;border:1px solid #c7d2fe;border-radius:7px;align-items:center;gap:4px;padding:5px 10px;font-size:.75rem;font-weight:600;transition:background .15s;display:inline-flex}.admin-classes-btn:hover{background:#daeeff}.admin-classes-btn--primary{color:#fff;background:#4f46e5;border-color:#0000}.admin-classes-btn--primary:hover{background:#3730a3}.enrollment-drawer-overlay{z-index:500;background:#00000059;justify-content:flex-end;display:flex;position:fixed;inset:0}.enrollment-drawer{background:#fff;flex-direction:column;width:420px;max-width:95vw;height:100%;display:flex;overflow-y:auto;box-shadow:-4px 0 24px #0000001f}.enrollment-drawer__header{border-bottom:1px solid #eef2ff;flex-shrink:0;justify-content:space-between;align-items:flex-start;padding:20px 22px 16px;display:flex}.enrollment-drawer__header h2{color:#1e1b4b;margin:0;font-size:.95rem;font-weight:800}.enrollment-drawer__header p{color:#4b5563;margin:3px 0 0;font-size:.78rem}.enrollment-drawer__close{cursor:pointer;color:#6b7280;background:0 0;border:none;padding:2px}.enrollment-drawer__body{flex-direction:column;flex:1;gap:20px;padding:18px 22px;display:flex}.enrollment-section h3{color:#6b7280;text-transform:uppercase;letter-spacing:.05em;margin:0 0 10px;font-size:.82rem;font-weight:700}.enrollment-item{background:#f9fafb;border:1px solid #eef2ff;border-radius:9px;justify-content:space-between;align-items:center;gap:10px;margin-bottom:7px;padding:10px 12px;display:flex}.enrollment-item__info{flex-direction:column;gap:2px;display:flex}.enrollment-item__name{color:#1e1b4b;font-size:.85rem;font-weight:600}.enrollment-item__meta{color:#6b7280;font-size:.73rem}.enrollment-demo-chip{white-space:nowrap;border-radius:99px;padding:3px 7px;font-size:.68rem;font-weight:700}.enrollment-demo-chip--full{color:#15803d;background:#dcfce7}.enrollment-demo-chip--active{color:#854d0e;background:#fef9c3}.enrollment-demo-chip--expired{color:#991b1b;background:#fee2e2}.enrollment-remove-btn{color:#dc2626;cursor:pointer;white-space:nowrap;background:0 0;border:1px solid #fca5a5;border-radius:6px;padding:3px 8px;font-size:.72rem;font-weight:600}.enrollment-remove-btn:hover{background:#fee2e2}.enrollment-add-form{flex-direction:column;gap:10px;display:flex}.enrollment-add-form input,.enrollment-add-form select{color:#1e1b4b;box-sizing:border-box;border:1px solid #c7d2fe;border-radius:8px;width:100%;padding:8px 12px;font-size:.85rem}.enrollment-add-form input:focus,.enrollment-add-form select:focus{border-color:#4f46e5;outline:none}.enrollment-add-btn{color:#fff;cursor:pointer;background:#4f46e5;border:none;border-radius:9px;width:100%;padding:10px;font-size:.87rem;font-weight:700}.enrollment-add-btn:hover{background:#3730a3}.enrollment-add-btn:disabled{opacity:.6;cursor:not-allowed}.admin-modal-overlay{z-index:1000;background:#0006;justify-content:center;align-items:center;padding:16px;display:flex;position:fixed;inset:0}.admin-modal{background:#fff;border-radius:16px;width:100%;max-width:440px;padding:26px 26px 22px;box-shadow:0 8px 32px #0000002e}.admin-modal__header{justify-content:space-between;align-items:center;margin-bottom:18px;display:flex}.admin-modal__title{color:#1e1b4b;margin:0;font-size:1rem;font-weight:800}.admin-modal__close{cursor:pointer;color:#6b7280;background:0 0;border:none;padding:2px}.admin-modal-field{margin-bottom:13px}.admin-modal-field label{color:#374151;margin-bottom:5px;font-size:.78rem;font-weight:600;display:block}.admin-modal-field input,.admin-modal-field select,.admin-modal-field textarea{color:#1e1b4b;box-sizing:border-box;border:1px solid #c7d2fe;border-radius:8px;width:100%;padding:8px 12px;font-family:inherit;font-size:.87rem}.admin-modal-field input:focus,.admin-modal-field select:focus,.admin-modal-field textarea:focus{border-color:#4f46e5;outline:none}.admin-modal__actions{justify-content:flex-end;gap:8px;margin-top:6px;display:flex}.admin-modal__cancel{color:#4b5563;cursor:pointer;background:#fff;border:1px solid #e0e7ff;border-radius:8px;padding:9px 16px;font-size:.85rem;font-weight:600}.admin-modal__submit{color:#fff;cursor:pointer;background:#4f46e5;border:none;border-radius:8px;padding:9px 18px;font-size:.85rem;font-weight:700}.admin-modal__submit:disabled{opacity:.6;cursor:not-allowed}.admin-coupons-page{flex-direction:column;gap:20px;display:flex}.admin-coupons-header{flex-wrap:wrap;justify-content:space-between;align-items:flex-start;gap:12px;display:flex}.admin-coupons-header h1{color:#1e1b4b;margin:0;font-size:1.2rem;font-weight:800}.admin-coupons-header p{color:#4b5563;margin:4px 0 0;font-size:.85rem}.admin-coupons-kpis{grid-template-columns:repeat(3,1fr);gap:14px;display:grid}@media (width<=600px){.admin-coupons-kpis{grid-template-columns:1fr}}.admin-coupons-kpi{background:#fff;border:1px solid #e0e7ff;border-radius:12px;padding:16px 18px}.admin-coupons-kpi h4{color:#6b7280;text-transform:uppercase;letter-spacing:.05em;margin:0 0 6px;font-size:.75rem;font-weight:700}.admin-coupons-kpi p{color:#1e1b4b;margin:0;font-size:1.5rem;font-weight:900}.admin-coupons-table-card{background:#fff;border:1px solid #e0e7ff;border-radius:14px;padding:20px}.admin-coupons-table-card h3{color:#1e1b4b;margin:0 0 14px;font-size:.95rem;font-weight:800}.admin-coupons-table-wrap{overflow-x:auto}.admin-coupons-table{border-collapse:collapse;width:100%;font-size:.85rem}.admin-coupons-table th{text-align:left;color:#6b7280;text-transform:uppercase;letter-spacing:.05em;white-space:nowrap;border-bottom:1px solid #eef2ff;padding:8px 12px;font-size:.72rem;font-weight:700}.admin-coupons-table td{color:#374151;vertical-align:middle;border-bottom:1px solid #f9fafb;padding:11px 12px}.admin-coupons-table tr:last-child td{border-bottom:none}.admin-coupons-table tr:hover td{background:#f9fafb}.coupon-code-badge{color:#1e1b4b;letter-spacing:.04em;background:#f0f4f8;border:1px solid #e0e7ff;border-radius:6px;padding:2px 7px;font-family:Courier New,monospace;font-size:.82rem;font-weight:700}.coupon-status-chip{border-radius:99px;align-items:center;gap:4px;padding:3px 8px;font-size:.72rem;font-weight:700;display:inline-flex}.coupon-status-chip--active{color:#15803d;background:#dcfce7}.coupon-status-chip--inactive{color:#6b7280;background:#f1f5f9}.coupon-status-chip--expired{color:#991b1b;background:#fee2e2}.coupon-actions{gap:6px;display:flex}.coupon-action-btn{cursor:pointer;color:#4f46e5;white-space:nowrap;background:#f9fafb;border:1px solid #c7d2fe;border-radius:7px;align-items:center;gap:3px;padding:4px 9px;font-size:.73rem;font-weight:600;display:inline-flex}.coupon-action-btn:hover{background:#daeeff}.coupon-action-btn--danger{color:#dc2626;background:#fff;border-color:#fca5a5}.coupon-action-btn--danger:hover{background:#fee2e2}.coupon-type-toggle{background:#f0f4f8;border-radius:8px;gap:3px;padding:3px;display:flex}.coupon-type-toggle__btn{cursor:pointer;color:#4b5563;background:0 0;border:none;border-radius:6px;flex:1;padding:6px 12px;font-size:.82rem;font-weight:600;transition:all .15s}.coupon-type-toggle__btn--active{color:#1e1b4b;background:#fff;box-shadow:0 1px 3px #00000014}.affiliate-page{flex-direction:column;gap:1.25rem;display:flex}.affiliate-page-header{flex-wrap:wrap;justify-content:space-between;align-items:flex-start;gap:1rem;display:flex}.affiliate-page-header h1{color:#1e1b4b;margin:0;font-size:1.45rem}.affiliate-page-header p{color:#6b7280;margin:.2rem 0 0;font-size:.9rem}.affiliate-kpi-grid{grid-template-columns:repeat(4,1fr);gap:1rem;display:grid}.affiliate-kpi-grid--3{grid-template-columns:repeat(3,1fr)}.affiliate-kpi-card{background:#fff;border:1px solid #e0e7ff;border-radius:14px;align-items:center;gap:.9rem;padding:1.1rem;display:flex}.affiliate-kpi-icon{color:#4f46e5;background:#eef2ff;border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;width:40px;height:40px;display:flex}.affiliate-kpi-icon--green{color:#16a34a;background:#e8f8f0}.affiliate-kpi-icon--blue{color:#4f46e5;background:#eef2ff}.affiliate-kpi-icon--navy{color:#1e1b4b;background:#e8ecf5}.affiliate-kpi-icon--teal{color:#0891b2;background:#e6f7fa}.affiliate-kpi-label{color:#6b7280;margin:0;font-size:.78rem;font-weight:500}.affiliate-kpi-value{color:#1e1b4b;margin:.2rem 0 0;font-size:1.35rem;font-weight:700}.affiliate-kpi-sub{color:#8fa8c4;margin:.15rem 0 0;font-size:.74rem}.affiliate-card{background:#fff;border:1px solid #e0e7ff;border-radius:14px;padding:1.25rem}.affiliate-card h3{color:#1e1b4b;margin:0;font-size:1rem;font-weight:700}.affiliate-card-sub{color:#6b7280;margin:.2rem 0 1rem;font-size:.84rem}.affiliate-dash-grid{grid-template-columns:1fr 1fr;gap:1rem;display:grid}.affiliate-table-wrap{overflow-x:auto}.affiliate-table{border-collapse:collapse;width:100%;font-size:.875rem}.affiliate-table--full{min-width:600px}.affiliate-table th{text-align:left;color:#6b7280;text-transform:uppercase;letter-spacing:.04em;border-bottom:1px solid #e8f0fa;padding:.6rem .75rem;font-size:.75rem;font-weight:600}.affiliate-table td{color:#1f2937;vertical-align:middle;border-bottom:1px solid #f0f6ff;padding:.75rem}.affiliate-table tbody tr:last-child td{border-bottom:none}.affiliate-table tfoot td{border-top:2px solid #e0e7ff;padding:.75rem}.affiliate-table tbody tr:hover td{background:#f9fafb}.affiliate-plan-badge{color:#4f46e5;text-transform:capitalize;background:#eef2ff;border-radius:999px;padding:.22rem .55rem;font-size:.74rem;font-weight:600;display:inline-block}.affiliate-status-badge{border-radius:999px;padding:.22rem .55rem;font-size:.74rem;font-weight:600;display:inline-block}.affiliate-status-badge--active{color:#16a34a;background:#e8f8f0}.affiliate-status-badge--deactivated{color:#dc2626;background:#fef2f2}.affiliate-amount{color:#1f2937;font-weight:600}.affiliate-amount--highlight{color:#16a34a}.affiliate-date{color:#6b7280;font-size:.84rem}.affiliate-student-cell{flex-direction:column;gap:.1rem;display:flex}.affiliate-student-name{color:#1e1b4b;font-weight:600}.affiliate-student-email{color:#6b7280;font-size:.78rem}.affiliate-table-controls{flex-wrap:wrap;align-items:center;gap:.75rem;margin-bottom:1rem;display:flex}.affiliate-search-wrap{flex:1;min-width:200px;position:relative}.affiliate-search-icon{color:#6b7280;pointer-events:none;position:absolute;top:50%;left:.7rem;transform:translateY(-50%)}.affiliate-search{color:#1f2937;background:#f9fafb;border:1px solid #e0e7ff;border-radius:8px;outline:none;width:100%;padding:.55rem .75rem .55rem 2.1rem;font-size:.875rem}.affiliate-search:focus{background:#fff;border-color:#818cf8}.affiliate-filter-tabs{gap:.4rem;display:flex}.affiliate-filter-tab{color:#6b7280;cursor:pointer;background:#f9fafb;border:1px solid #e0e7ff;border-radius:8px;padding:.45rem .85rem;font-size:.82rem;font-weight:500;transition:all .15s}.affiliate-filter-tab:hover{color:#4f46e5;border-color:#818cf8}.affiliate-filter-tab--active{color:#fff;background:#4f46e5;border-color:#4f46e5}.affiliate-referrals-stats{align-items:center;gap:.5rem;display:flex}.affiliate-stat-chip{border-radius:999px;padding:.3rem .7rem;font-size:.78rem;font-weight:600}.affiliate-stat-chip--active{color:#16a34a;background:#e8f8f0}.affiliate-stat-chip--inactive{color:#dc2626;background:#fef2f2}.affiliate-copy-btn{color:#4f46e5;cursor:pointer;letter-spacing:.04em;background:#eef2ff;border:1.5px solid #818cf8;border-radius:8px;align-items:center;gap:.45rem;padding:.55rem 1rem;font-size:.88rem;font-weight:700;transition:all .15s;display:inline-flex}.affiliate-copy-btn:hover{color:#fff;background:#4f46e5}.affiliate-overview-stats{grid-template-columns:1fr 1fr;gap:.75rem;display:grid}.affiliate-overview-stat{background:#f4f8fc;border-radius:10px;flex-direction:column;gap:.3rem;padding:.85rem;display:flex}.affiliate-overview-stat__label{color:#6b7280;font-size:.75rem;font-weight:500}.affiliate-overview-stat__value{color:#1e1b4b;font-size:1.2rem;font-weight:700}.affiliate-overview-stat__value--active{color:#16a34a}.affiliate-overview-stat__value--inactive{color:#dc2626}.affiliate-empty{color:#6b7280;text-align:center;padding:1.5rem 0;font-size:.9rem}@media (width<=900px){.affiliate-kpi-grid,.affiliate-kpi-grid--3{grid-template-columns:1fr 1fr}.affiliate-dash-grid{grid-template-columns:1fr}}@media (width<=500px){.affiliate-kpi-grid,.affiliate-kpi-grid--3{grid-template-columns:1fr}}.si-controls{flex-wrap:wrap;align-items:center;gap:.75rem;margin-bottom:1.25rem;display:flex}.si-search{flex:1;min-width:200px}.si-sort-select{color:#1e1b4b;cursor:pointer;background:#f9fafb;border:1px solid #e0e7ff;border-radius:8px;outline:none;padding:.5rem .75rem;font-family:inherit;font-size:.82rem}.si-sort-select:focus{border-color:#818cf8}.si-list-head{color:#9ca3af;text-transform:uppercase;letter-spacing:.05em;border-bottom:1px solid #f3f4f6;grid-template-columns:2.5fr 1.6fr .7fr .7fr .7fr 1.4fr .9fr;gap:.5rem;padding:0 .75rem .6rem;font-size:.72rem;font-weight:600;display:grid}.si-list{flex-direction:column;display:flex}.si-row{border-bottom:1px solid #f9fafb;grid-template-columns:2.5fr 1.6fr .7fr .7fr .7fr 1.4fr .9fr;align-items:center;gap:.5rem;padding:.85rem .75rem;transition:background .12s;display:grid}.si-row:last-child{border-bottom:none}.si-row:hover{background:#fafbff}.si-row--inactive{opacity:.6}.si-col-student{align-items:center;gap:.75rem;min-width:0;display:flex}.si-avatar{color:#4f46e5;text-transform:uppercase;background:#eef2ff;border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;font-size:.78rem;font-weight:700;display:flex}.si-identity{flex-direction:column;gap:.25rem;min-width:0;display:flex}.si-name{color:#1e1b4b;white-space:nowrap;text-overflow:ellipsis;font-size:.88rem;font-weight:600;overflow:hidden}.si-meta-row{flex-wrap:wrap;align-items:center;gap:.4rem;display:flex}.si-email{color:#9ca3af;white-space:nowrap;text-overflow:ellipsis;max-width:140px;font-size:.74rem;overflow:hidden}.si-plan-badge{text-transform:capitalize;border-radius:999px;padding:.12rem .45rem;font-size:.68rem;font-weight:600;display:inline-block}.si-plan-badge--basic{color:#374151;background:#f3f4f6}.si-plan-badge--standard{color:#4f46e5;background:#eef2ff}.si-plan-badge--premium{color:#92400e;background:#fef3c7}.si-status{border-radius:999px;padding:.12rem .45rem;font-size:.68rem;font-weight:600;display:inline-block}.si-status--active{color:#16a34a;background:#e8f8f0}.si-status--deactivated{color:#dc2626;background:#fef2f2}.si-col-progress{align-items:center;display:flex}.si-bar-wrap{align-items:center;gap:.5rem;width:100%;display:flex}.si-bar-track{background:#f3f4f6;border-radius:999px;flex:1;height:6px;overflow:hidden}.si-bar-fill{border-radius:999px;height:100%}.si-bar-pct{white-space:nowrap;text-align:right;min-width:32px;font-size:.8rem;font-weight:700}.si-col-stat{align-items:center;display:flex}.si-stat-val{color:#1e1b4b;font-size:.85rem;font-weight:600}.si-stat-none{color:#d1d5db;font-size:.85rem}.si-col-weak{flex-wrap:wrap;align-items:center;gap:.3rem;display:flex}.si-weak-tag{color:#dc2626;background:#fef2f2;border-radius:999px;padding:.15rem .5rem;font-size:.68rem;font-weight:500;display:inline-block}.si-weak-more{color:#9ca3af;font-size:.68rem;font-weight:500}.si-col-meta{align-items:center;display:flex}.si-last-active{color:#9ca3af;align-items:center;gap:.3rem;font-size:.78rem;display:flex}@media (width<=900px){.si-list-head,.si-row{grid-template-columns:2fr 1.4fr .7fr .7fr 1.2fr .9fr}.si-list-head .si-col-stat:nth-child(5),.si-row .si-col-stat:nth-child(5){display:none}}@media (width<=650px){.si-list-head{display:none}.si-row{grid-template-columns:1fr;gap:.6rem}.si-col-progress,.si-col-stat,.si-col-weak,.si-col-meta{display:none}}.teacher-page{gap:16px;display:grid}.teacher-kpi-grid{grid-template-columns:repeat(4,1fr);gap:12px;display:grid}.teacher-kpi-card{background:#fff;border:1px solid #e0e7ff;border-radius:14px;padding:14px;position:relative;overflow:hidden}.teacher-kpi-card__label{color:#6b7280;text-transform:uppercase;letter-spacing:.06em;font-size:.78rem;font-weight:600}.teacher-kpi-card__value{color:#1e1b4b;margin-top:4px;font-size:1.6rem;font-weight:800;line-height:1.1}.teacher-kpi-card__sub{color:#4b5563;margin-top:2px;font-size:.78rem}.teacher-kpi-card__icon{float:right;color:#4f46e5;background:#eef2ff;border-radius:10px;justify-content:center;align-items:center;width:36px;height:36px;display:flex}.teacher-section{background:#fff;border:1px solid #e0e7ff;border-radius:14px;gap:12px;padding:16px;display:grid}.teacher-section__header{justify-content:space-between;align-items:center;display:flex}.teacher-section__title{color:#1e1b4b;margin:0;font-size:.92rem;font-weight:700}.teacher-table{border-collapse:collapse;width:100%;font-size:.87rem}.teacher-table th{text-align:left;color:#6b7280;text-transform:uppercase;letter-spacing:.05em;border-bottom:1px solid #eef2ff;padding:8px 12px;font-size:.78rem;font-weight:600}.teacher-table td{color:#374151;vertical-align:middle;border-bottom:1px solid #f3f4f6;padding:10px 12px}.teacher-table tr:last-child td{border-bottom:none}.teacher-table tr:hover td{background:#f9fafb}.teacher-status-badge{border-radius:999px;align-items:center;gap:4px;padding:3px 10px;font-size:.75rem;font-weight:700;display:inline-flex}.teacher-status-badge--live{color:#15803d;background:#dcfce7}.teacher-status-badge--scheduled{color:#4338ca;background:#e0e7ff}.teacher-status-badge--completed{color:#6b7280;background:#f3f4f6}.teacher-status-badge--cancelled{color:#dc2626;background:#fee2e2}@keyframes teacher-pulse{0%,to{opacity:1}50%{opacity:.5}}.teacher-live-pulse{animation:2s infinite teacher-pulse}.teacher-btn{cursor:pointer;white-space:nowrap;border:none;border-radius:8px;align-items:center;gap:6px;padding:7px 14px;font-size:.83rem;font-weight:600;text-decoration:none;transition:background .15s,border-color .15s;display:inline-flex}.teacher-btn--primary{color:#fff;background:#4f46e5}.teacher-btn--primary:hover{background:#145a91}.teacher-btn--danger{color:#dc2626;background:#fee2e2;border:1px solid #fecaca}.teacher-btn--danger:hover{background:#fecaca}.teacher-btn--secondary{color:#4f46e5;background:#f9fafb;border:1px solid #c7d2fe}.teacher-btn--secondary:hover{background:#e0f0ff}.teacher-btn--ghost{color:#6b7280;background:0 0;border:1px solid #eef2ff}.teacher-btn--ghost:hover{background:#f9fafb}.teacher-class-card{background:#fff;border:1px solid #e0e7ff;border-radius:14px;gap:10px;padding:16px;display:grid}.teacher-class-card__name{color:#1e1b4b;margin:0;font-size:1rem;font-weight:700}.teacher-class-card__meta{flex-wrap:wrap;align-items:center;gap:8px;display:flex}.teacher-class-card__badge{color:#4f46e5;background:#eef2ff;border-radius:999px;align-items:center;gap:4px;padding:2px 8px;font-size:.72rem;font-weight:700;display:inline-flex}.teacher-class-card__desc{color:#4b5563;margin:0;font-size:.85rem;line-height:1.6}.teacher-class-card__footer{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:8px;display:flex}.teacher-class-grid{grid-template-columns:repeat(2,1fr);gap:14px;display:grid}.teacher-tabs{border-bottom:2px solid #eef2ff;gap:4px;margin-bottom:16px;display:flex}.teacher-tab{color:#6b7280;cursor:pointer;background:0 0;border:none;border-bottom:2px solid #0000;margin-bottom:-2px;padding:8px 14px;font-size:.87rem;font-weight:600;transition:color .15s,border-color .15s}.teacher-tab--active{color:#4f46e5;border-bottom-color:#4f46e5}.teacher-tab:hover:not(.teacher-tab--active){color:#374151}.teacher-notice-item{background:#f9fafb;border:1px solid #eef2ff;border-radius:10px;align-items:flex-start;gap:10px;padding:10px;display:flex}.teacher-notice-item__icon{border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;width:32px;height:32px;display:flex}.teacher-notice-item__icon--pdf{color:#dc2626;background:#fef2f2}.teacher-notice-item__icon--announcement{color:#4f46e5;background:#eef2ff}.teacher-notice-item__title{color:#1e1b4b;font-size:.87rem;font-weight:600}.teacher-notice-item__date{color:#6b7280;font-size:.75rem}.teacher-modal-overlay{z-index:500;background:#03122673;justify-content:center;align-items:center;padding:1rem;display:flex;position:fixed;inset:0}.teacher-modal{background:#fff;border-radius:16px;gap:16px;width:100%;max-width:520px;max-height:90vh;padding:1.5rem;display:grid;overflow-y:auto}.teacher-modal__header{justify-content:space-between;align-items:center;display:flex}.teacher-modal__title{color:#1e1b4b;margin:0;font-size:1rem;font-weight:700}.teacher-form-field{gap:6px;display:grid}.teacher-form-label{color:#3730a3;font-size:.83rem;font-weight:600}.teacher-form-input,.teacher-form-textarea,.teacher-form-select{color:#1e1b4b;box-sizing:border-box;background:#f9fafb;border:1.5px solid #c7d2fe;border-radius:10px;outline:none;width:100%;padding:8px 12px;font-family:inherit;font-size:.9rem;transition:border-color .15s}.teacher-form-input:focus,.teacher-form-textarea:focus,.teacher-form-select:focus{background:#fff;border-color:#4f46e5;box-shadow:0 0 0 3px #2563eb1a}.teacher-form-textarea{resize:vertical;min-height:80px}.teacher-form-select{appearance:none;cursor:pointer}.teacher-form-hint{color:#6b7280;font-size:.78rem}.teacher-form-required-note{color:#dc2626;background:#fef2f2;border:1px solid #fecaca;border-radius:8px;padding:6px 10px;font-size:.78rem}.teacher-change-note-section{background:#fff8e1;border:1px solid #fde68a;border-radius:10px;gap:8px;padding:10px;display:grid}.teacher-empty-state{text-align:center;color:#6b7280;padding:2.5rem}.teacher-empty-state svg{opacity:.4;margin:0 auto .75rem;display:block}.teacher-toast{color:#fff;z-index:600;background:#1e1b4b;border-radius:10px;padding:10px 16px;font-size:.87rem;font-weight:600;animation:.2s teacher-toast-in;position:fixed;bottom:1.5rem;right:1.5rem;box-shadow:0 4px 16px #1e1b4b40}@keyframes teacher-toast-in{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.teacher-quick-actions{flex-wrap:wrap;gap:10px;display:flex}.teacher-filter-bar{flex-wrap:wrap;align-items:center;gap:6px;display:flex}.teacher-filter-btn{cursor:pointer;color:#6b7280;background:0 0;border:1px solid #eef2ff;border-radius:999px;padding:5px 12px;font-size:.8rem;font-weight:600;transition:all .15s}.teacher-filter-btn--active{color:#fff;background:#4f46e5;border-color:#4f46e5}@media (width<=900px){.teacher-kpi-grid{grid-template-columns:repeat(2,1fr)}.teacher-class-grid{grid-template-columns:1fr}}@media (width<=600px){.teacher-kpi-grid{grid-template-columns:1fr 1fr}}.editor-page{gap:16px;display:grid}.editor-kpi-grid{grid-template-columns:repeat(4,1fr);gap:12px;display:grid}.editor-kpi-card{background:#fff;border:1px solid #e0e7ff;border-radius:14px;padding:14px;position:relative;overflow:hidden}.editor-kpi-card--amber{background:#fffbeb;border-color:#fde68a}.editor-kpi-card__label{color:#6b7280;text-transform:uppercase;letter-spacing:.06em;font-size:.78rem;font-weight:600}.editor-kpi-card--amber .editor-kpi-card__label{color:#92400e}.editor-kpi-card__value{color:#1e1b4b;margin-top:4px;font-size:1.6rem;font-weight:800;line-height:1.1}.editor-kpi-card--amber .editor-kpi-card__value{color:#b45309}.editor-kpi-card__sub{color:#4b5563;margin-top:2px;font-size:.78rem}.editor-kpi-card__icon{float:right;color:#4f46e5;background:#eef2ff;border-radius:10px;justify-content:center;align-items:center;width:36px;height:36px;display:flex}.editor-section{background:#fff;border:1px solid #e0e7ff;border-radius:14px;gap:12px;padding:16px;display:grid}.editor-section__header{justify-content:space-between;align-items:center;display:flex}.editor-section__title{color:#1e1b4b;margin:0;font-size:.92rem;font-weight:700}.editor-table{border-collapse:collapse;width:100%;font-size:.87rem}.editor-table th{text-align:left;color:#6b7280;text-transform:uppercase;letter-spacing:.05em;border-bottom:1px solid #eef2ff;padding:8px 12px;font-size:.78rem;font-weight:600}.editor-table td{color:#374151;vertical-align:middle;border-bottom:1px solid #f3f4f6;padding:10px 12px}.editor-table tr:last-child td{border-bottom:none}.editor-table tr:hover td{background:#f9fafb}.editor-status-badge{border-radius:999px;align-items:center;gap:4px;padding:3px 10px;font-size:.75rem;font-weight:700;display:inline-flex}.editor-status-badge--live{color:#15803d;background:#dcfce7}.editor-status-badge--scheduled{color:#4338ca;background:#e0e7ff}.editor-status-badge--completed{color:#6b7280;background:#f3f4f6}.editor-status-badge--cancelled{color:#dc2626;background:#fee2e2}@keyframes editor-pulse{0%,to{opacity:1}50%{opacity:.5}}.editor-live-pulse{animation:2s infinite editor-pulse}.editor-btn{cursor:pointer;white-space:nowrap;border:none;border-radius:8px;align-items:center;gap:6px;padding:7px 14px;font-size:.83rem;font-weight:600;text-decoration:none;transition:background .15s,border-color .15s;display:inline-flex}.editor-btn--primary{color:#fff;background:#4f46e5}.editor-btn--primary:hover{background:#145a91}.editor-btn--danger{color:#dc2626;background:#fee2e2;border:1px solid #fecaca}.editor-btn--danger:hover{background:#fecaca}.editor-btn--secondary{color:#4f46e5;background:#f9fafb;border:1px solid #c7d2fe}.editor-btn--secondary:hover{background:#e0f0ff}.editor-btn--ghost{color:#6b7280;background:0 0;border:1px solid #eef2ff}.editor-btn--ghost:hover{background:#f9fafb}.editor-alert{color:#92400e;background:#fff8e1;border:1px solid #fde68a;border-radius:12px;align-items:flex-start;gap:10px;padding:12px 14px;display:flex}.editor-alert__icon{flex-shrink:0;margin-top:1px}.editor-alert__title{color:#92400e;margin:0 0 2px;font-size:.87rem;font-weight:700}.editor-alert__body{color:#78350f;margin:0;font-size:.82rem}.editor-chat-panel{background:#fff;border:1px solid #e0e7ff;border-radius:14px;grid-template-columns:280px 1fr;min-height:400px;display:grid;overflow:hidden}.editor-chat-sidebar{border-right:1px solid #eef2ff;flex-direction:column;gap:4px;padding:12px;display:flex}.editor-chat-class-item{cursor:pointer;color:#374151;border-radius:8px;padding:8px 10px;font-size:.87rem;transition:background .12s}.editor-chat-class-item:hover{background:#f9fafb}.editor-chat-class-item--active{color:#1e1b4b;background:#eef2ff;font-weight:600}.editor-chat-main{flex-direction:column;min-height:400px;padding:16px;display:flex}.editor-chat-placeholder{text-align:center;color:#6b7280;flex-direction:column;flex:1;justify-content:center;align-items:center;gap:8px;padding:2rem;display:flex}.editor-supervision-note{color:#0369a1;background:#f0f9ff;border:1px solid #bae6fd;border-radius:10px;padding:10px 14px;font-size:.83rem}.editor-chat-messages{flex-direction:column;flex:1;gap:10px;margin-bottom:12px;display:flex;overflow-y:auto}.editor-chat-message{align-items:flex-start;gap:8px;display:flex}.editor-chat-message__avatar{border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:30px;height:30px;font-size:.72rem;font-weight:700;display:flex}.editor-chat-message__avatar--student{color:#4f46e5;background:#eef2ff}.editor-chat-message__avatar--teacher{color:#15803d;background:#dcfce7}.editor-chat-message__bubble{background:#f9fafb;border:1px solid #eef2ff;border-radius:10px;max-width:80%;padding:8px 12px}.editor-chat-message__sender{color:#6b7280;margin-bottom:2px;font-size:.72rem;font-weight:700}.editor-chat-message__text{color:#1e1b4b;font-size:.85rem;line-height:1.5}.editor-chat-readonly-note{color:#6b7280;text-align:center;background:#f9fafb;border-top:1px solid #eef2ff;border-radius:0 0 8px 8px;padding:8px;font-size:.75rem}.editor-form-field{gap:6px;display:grid}.editor-form-label{color:#3730a3;font-size:.83rem;font-weight:600}.editor-form-input,.editor-form-textarea,.editor-form-select{color:#1e1b4b;box-sizing:border-box;background:#f9fafb;border:1.5px solid #c7d2fe;border-radius:10px;outline:none;width:100%;padding:8px 12px;font-family:inherit;font-size:.9rem;transition:border-color .15s}.editor-form-input:focus,.editor-form-textarea:focus,.editor-form-select:focus{background:#fff;border-color:#4f46e5;box-shadow:0 0 0 3px #2563eb1a}.editor-form-textarea{resize:vertical;min-height:80px}.editor-form-select{appearance:none;cursor:pointer}.editor-modal-overlay{z-index:500;background:#03122673;justify-content:center;align-items:center;padding:1rem;display:flex;position:fixed;inset:0}.editor-modal{background:#fff;border-radius:16px;gap:16px;width:100%;max-width:560px;max-height:90vh;padding:1.5rem;display:grid;overflow-y:auto}.editor-modal__header{justify-content:space-between;align-items:center;display:flex}.editor-modal__title{color:#1e1b4b;margin:0;font-size:1rem;font-weight:700}.editor-change-note-section{background:#fff8e1;border:1px solid #fde68a;border-radius:10px;gap:8px;padding:10px;display:grid}.editor-toast{color:#fff;z-index:600;background:#1e1b4b;border-radius:10px;padding:10px 16px;font-size:.87rem;font-weight:600;animation:.2s editor-toast-in;position:fixed;bottom:1.5rem;right:1.5rem;box-shadow:0 4px 16px #1e1b4b40}@keyframes editor-toast-in{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.editor-filter-bar{flex-wrap:wrap;align-items:center;gap:6px;display:flex}.editor-filter-btn{cursor:pointer;color:#6b7280;background:0 0;border:1px solid #eef2ff;border-radius:999px;padding:5px 12px;font-size:.8rem;font-weight:600;transition:all .15s}.editor-filter-btn--active{color:#fff;background:#4f46e5;border-color:#4f46e5}.editor-empty-state{text-align:center;color:#6b7280;padding:2.5rem}.editor-empty-state svg{opacity:.4;margin:0 auto .75rem;display:block}.editor-live-banner{color:#fff;background:linear-gradient(135deg,#16a34a,#15803d);border-radius:12px;flex-wrap:wrap;justify-content:space-between;align-items:center;gap:10px;padding:12px 16px;display:flex}.editor-live-banner__pulse{background:#fff;border-radius:50%;flex-shrink:0;width:10px;height:10px;animation:1.5s infinite editor-pulse}@media (width<=900px){.editor-kpi-grid{grid-template-columns:repeat(2,1fr)}.editor-chat-panel{grid-template-columns:1fr}.editor-chat-sidebar{border-bottom:1px solid #eef2ff;border-right:none}}@media (width<=600px){.editor-kpi-grid{grid-template-columns:1fr 1fr}}
