:root{--brand:#4f46e5;--brand-dark:#3730a3;--brand-light:#6366f1;--brand-pale:#eef2ff;--accent:#0ea5e9;--success:#10b981;--warning:#f59e0b;--danger:#ef4444;--bg:#f0f2f8;--bg-card:#fff;--bg-muted:#e8ecf4;--border:#d4d9e8;--border-focus:#a5b4fc;--text:#0f172a;--text-muted:#64748b;--text-light:#94a3b8;--radius-sm:8px;--radius:12px;--radius-lg:18px;--radius-xl:24px;--shadow-sm:0 1px 3px #0f172a0f, 0 1px 2px #0f172a0a;--shadow:0 4px 16px #0f172a14, 0 1px 4px #0f172a0a;--shadow-lg:0 12px 40px #0f172a1f, 0 4px 12px #0f172a0f;--shadow-brand:0 8px 24px #4f46e54d;--font:system-ui, -apple-system, "Segoe UI", Roboto, Arial, sans-serif}*,:before,:after{box-sizing:border-box}body{font-family:var(--font);background:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased;margin:0;line-height:1.6}a{color:inherit;text-decoration:none}button{cursor:pointer;font-family:inherit}#root,.layout{min-height:100vh}.muted{color:var(--text-muted)}.small{font-size:.85rem}.error{color:var(--danger);font-size:.9rem}.block{display:block}.center-box{place-items:center;min-height:100vh;display:grid}.stack{gap:20px;display:grid}.stack.gap-sm{gap:12px}.row{flex-wrap:wrap;align-items:center;gap:10px;display:flex}.field{gap:6px;display:grid}.card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-sm);padding:20px}.grid{grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:16px;display:grid}.btn{border-radius:var(--radius-sm);cursor:pointer;white-space:nowrap;background:var(--brand);color:#fff;border:2px solid #0000;justify-content:center;align-items:center;gap:6px;padding:10px 18px;font-size:.9rem;font-weight:600;transition:filter .15s,transform .1s,box-shadow .15s;display:inline-flex}.btn:hover:not(:disabled){filter:brightness(1.08);box-shadow:var(--shadow-brand);transform:translateY(-1px)}.btn:active:not(:disabled){transform:translateY(0)}.btn:disabled{opacity:.55;cursor:not-allowed}.btn-secondary{color:var(--brand);border-color:var(--brand);background:#fff}.btn-secondary:hover:not(:disabled){background:var(--brand-pale);box-shadow:none}.btn-ghost{color:var(--brand);background:0 0;border-color:#0000}.btn-ghost:hover:not(:disabled){background:var(--brand-pale);box-shadow:none;transform:none}.public-header .btn-ghost,.header .btn-ghost{color:#ffffffd9}.public-header .btn-ghost:hover,.header .btn-ghost:hover{color:#fff;background:#ffffff26}.public-header .btn-secondary,.header .btn-secondary{color:#fff;background:#ffffff1f;border-color:#ffffff59}.public-header .btn-secondary:hover,.header .btn-secondary:hover{box-shadow:none;background:#ffffff38}.btn-sm{padding:7px 14px;font-size:.85rem}.btn-block{width:100%;display:flex}.btn-continue{color:#fff;border-radius:var(--radius);background:linear-gradient(135deg,#4f46e5 0%,#7c3aed 100%);border:none;justify-content:center;align-items:center;padding:13px 24px;font-weight:700;display:inline-flex;box-shadow:0 4px 16px #4f46e566}.btn-continue:hover:not(:disabled){filter:brightness(1.1);box-shadow:0 6px 24px #4f46e580}input,select,textarea{border:1.5px solid var(--border);border-radius:var(--radius-sm);font:inherit;color:var(--text);background:#fff;width:100%;padding:10px 14px;transition:border-color .15s,box-shadow .15s}input:focus,select:focus,textarea:focus{border-color:var(--border-focus);outline:none;box-shadow:0 0 0 3px #6366f126}.progress-bar{background:var(--bg-muted);border-radius:999px;height:8px;overflow:hidden}.progress-bar-fill{background:linear-gradient(90deg, var(--brand) 0%, var(--accent) 100%);border-radius:999px;height:100%;transition:width .3s}.public-page{flex-direction:column;min-height:100vh;display:flex}.public-header{z-index:50;background:linear-gradient(135deg,#1e1b4b 0%,#312e81 50%,#1e3a8a 100%);border-bottom:none;justify-content:space-between;align-items:center;gap:16px;height:64px;padding:0 32px;display:flex;position:sticky;top:0;box-shadow:0 2px 16px #4f46e559}.public-nav--desktop{display:flex}.public-brand{color:#fff;letter-spacing:-.02em;align-items:center;gap:8px;font-size:1.1rem;font-weight:800;display:flex}.public-logo{background:linear-gradient(135deg, var(--brand) 0%, var(--accent) 100%);color:#fff;border-radius:8px;justify-content:center;align-items:center;width:32px;height:32px;font-size:.9rem;font-weight:900;display:flex}.public-nav{align-items:center;gap:4px;display:flex}.public-nav-link{color:#ffffffbf;border-radius:var(--radius-sm);padding:6px 12px;font-size:.9rem;font-weight:500;transition:background .15s,color .15s}.public-nav-link:hover,.public-nav-link.active{color:#fff;background:#ffffff26}.public-actions{align-items:center;gap:10px;display:flex}.public-user-name{color:#ffffffd9;text-overflow:ellipsis;white-space:nowrap;max-width:160px;font-size:.88rem;overflow:hidden}.public-main{flex:1;width:100%;max-width:1160px;margin:0 auto;padding:48px 24px 64px}.public-footer{text-align:center;border-top:1px solid var(--border);background:#fff;padding:24px}.hero-section{text-align:center;flex-direction:column;align-items:center;gap:16px;padding:64px 0 56px;display:flex}.hero-badge{background:var(--brand-pale);color:var(--brand);letter-spacing:.04em;border:1px solid #c7d2fe;border-radius:999px;align-items:center;gap:6px;padding:6px 14px;font-size:.8rem;font-weight:700;display:inline-flex}.hero-title{letter-spacing:-.04em;background:linear-gradient(135deg, var(--text) 0%, var(--brand) 60%, var(--accent) 100%);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;margin:0;font-size:clamp(2rem,5vw,3rem);font-weight:900;line-height:1.1}.hero-sub{color:var(--text-muted);max-width:520px;margin:0;font-size:1.2rem;line-height:1.6}.hero-cta-row{flex-wrap:wrap;justify-content:center;gap:12px;margin-top:8px;display:flex}.hero-cta{border-radius:var(--radius);background:linear-gradient(135deg, var(--brand) 0%, var(--brand-light) 100%);box-shadow:var(--shadow-brand);color:#fff;border:none;padding:14px 32px;font-size:1rem;font-weight:700}.hero-stats{border-radius:var(--radius-lg);border:1px solid var(--border);box-shadow:var(--shadow-sm);background:#fff;flex-wrap:wrap;justify-content:center;gap:32px;margin-top:12px;padding:20px 32px;display:flex}.hero-stat{text-align:center}.hero-stat-num{color:var(--brand);font-size:1.5rem;font-weight:900}.hero-stat-label{color:var(--text-muted);font-size:.8rem}.featured-section{margin-top:16px;scroll-margin-top:80px}.section-header{text-align:center;margin-bottom:32px}.section-title{letter-spacing:-.02em;color:var(--text);margin:0 0 8px;font-size:1.4rem;font-weight:800}.section-sub{color:var(--text-muted);margin:0}.featured-grid{grid-template-columns:repeat(auto-fill,minmax(256px,1fr));gap:20px;display:grid}.course-card{background:var(--bg-card);border-radius:var(--radius-lg);border:1px solid var(--border);box-shadow:var(--shadow-sm);flex-direction:column;transition:transform .2s,box-shadow .2s;display:flex;overflow:hidden}.course-card:hover{box-shadow:var(--shadow);transform:translateY(-3px)}.course-card-image{background:linear-gradient(135deg, var(--brand) 0%, var(--accent) 100%);background-position:50%;background-size:cover;height:130px;position:relative}.course-card-skill-badge{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);color:var(--brand);background:#ffffffe6;border-radius:999px;padding:4px 10px;font-size:.75rem;font-weight:700;position:absolute;top:10px;left:10px}.course-card-progress-badge{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);color:#fff;background:#10b981e6;border-radius:999px;padding:4px 10px;font-size:.75rem;font-weight:700;position:absolute;top:10px;right:10px}.course-card-body{flex-direction:column;flex:1;gap:8px;padding:16px;display:flex}.course-card-title{color:var(--text);margin:0;font-size:1rem;font-weight:700}.course-card-tier{color:var(--text-muted);margin:0;font-size:.85rem;font-weight:500}.course-card-meta{color:var(--text-light);margin:0;font-size:.82rem}.course-card-blurb{color:var(--text-muted);flex:1;margin:0;font-size:.85rem;line-height:1.5}.course-actions{flex-direction:column;gap:8px;margin-top:auto;padding-top:8px;display:flex}.enrolled-badge{color:var(--success);align-items:center;gap:4px;margin:0;font-size:.88rem;font-weight:700;display:flex}.course-lesson-buttons{flex-direction:column;gap:8px;width:100%;display:flex}@media (width>=480px){.course-lesson-buttons{flex-direction:row}.course-lesson-buttons .btn-block{flex:1}}.header{z-index:50;background:linear-gradient(135deg,#1e1b4b 0%,#312e81 50%,#1e3a8a 100%);border-bottom:none;justify-content:space-between;align-items:center;gap:16px;height:64px;padding:0 28px;display:flex;position:sticky;top:0;box-shadow:0 2px 16px #4f46e559}.brand{color:#fff;letter-spacing:-.02em;align-items:center;gap:8px;font-size:1rem;font-weight:800;display:flex}.brand-mark{color:#a5b4fc}.nav{gap:4px;display:flex}.nav-link{border-radius:var(--radius-sm);color:#ffffffbf;padding:6px 12px;font-size:.9rem;font-weight:500;transition:background .15s,color .15s}.nav-link:hover{color:#fff;background:#ffffff1f}.nav-link.active{color:#fff;background:#fff3;font-weight:600}.user-box{align-items:center;gap:10px;display:flex;position:relative}.user-avatar-btn{border-radius:var(--radius);cursor:pointer;background:#ffffff1f;border:1.5px solid #ffffff40;align-items:center;gap:8px;padding:5px 12px 5px 6px;font-family:inherit;transition:background .15s;display:flex}.user-avatar-btn:hover{background:#fff3}.user-avatar{color:#fff;background:linear-gradient(135deg,#818cf8 0%,#a5b4fc 100%);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:32px;height:32px;font-size:.85rem;font-weight:800;display:inline-flex}.user-name{color:#fff;text-overflow:ellipsis;white-space:nowrap;max-width:140px;font-size:.85rem;font-weight:600;overflow:hidden}.user-chevron{color:#ffffffb3;font-size:.65rem}.user-dropdown{border:1px solid var(--border);border-radius:var(--radius-lg);min-width:240px;box-shadow:var(--shadow-lg);z-index:100;background:#fff;animation:.15s dropdown-in;position:absolute;top:calc(100% + 10px);right:0;overflow:hidden}@keyframes dropdown-in{0%{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:translateY(0)}}.user-dropdown-header{background:linear-gradient(135deg, var(--brand-pale) 0%, #e0e7ff 100%);align-items:center;gap:12px;padding:16px;display:flex}.user-dropdown-avatar{background:linear-gradient(135deg, var(--brand) 0%, var(--brand-light) 100%);color:#fff;border:2px solid #a5b4fc;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:44px;height:44px;font-size:1.1rem;font-weight:900;display:flex}.user-dropdown-name{color:var(--text);font-size:.9rem;font-weight:700}.user-dropdown-email{color:var(--text-muted);margin-top:1px;font-size:.78rem}.user-dropdown-role{letter-spacing:.04em;background:var(--brand);color:#fff;border-radius:999px;margin-top:4px;padding:2px 8px;font-size:.72rem;font-weight:700;display:inline-block}.user-dropdown-divider{background:var(--border);height:1px;margin:4px 0}.user-dropdown-item{color:var(--text);cursor:pointer;text-align:left;background:0 0;border:none;align-items:center;gap:10px;width:100%;padding:10px 16px;font-family:inherit;font-size:.88rem;font-weight:500;text-decoration:none;transition:background .12s;display:flex}.user-dropdown-item:hover{background:var(--bg-muted)}.user-dropdown-item--danger{color:var(--danger)}.user-dropdown-item--danger:hover{background:#fff1f2}.main{max-width:1100px;margin:0 auto;padding:28px 24px}.main-wide{max-width:1200px}.page-title{letter-spacing:-.03em;margin:0 0 6px;font-size:1.6rem;font-weight:800}.auth-page{background:linear-gradient(135deg, var(--brand-pale) 0%, #f0f9ff 50%, var(--bg) 100%);place-items:center;min-height:100vh;padding:24px;display:grid}.auth-card{border-radius:var(--radius-xl);border:1px solid var(--border);width:100%;max-width:420px;box-shadow:var(--shadow-lg);background:#fff;padding:40px 36px}.auth-logo{color:var(--text);justify-content:center;align-items:center;gap:10px;margin-bottom:28px;font-size:1.2rem;font-weight:900;display:flex}.auth-logo-icon{background:linear-gradient(135deg, var(--brand) 0%, var(--accent) 100%);color:#fff;border-radius:10px;justify-content:center;align-items:center;width:40px;height:40px;font-size:1.1rem;display:flex}.auth-title{letter-spacing:-.03em;margin:0 0 6px;font-size:1.5rem;font-weight:800}.auth-sub{color:var(--text-muted);margin:0 0 28px;font-size:.9rem}.auth-card .field label{color:var(--text);margin-bottom:2px;font-size:.85rem;font-weight:600}.auth-divider{text-align:center;color:var(--text-muted);margin:4px 0;font-size:.85rem}.page-courses .course-desc{flex:1;font-size:.88rem}.courses-by-skill{flex-direction:column;gap:2.5rem;margin-top:8px;display:flex}.courses-skill-head{margin-bottom:16px}.courses-skill-title{color:var(--text);align-items:center;gap:8px;margin:0 0 4px;font-size:1.15rem;font-weight:800;display:flex}.skill-icon{font-size:1.1rem}.courses-skill-hint{color:var(--text-muted);margin:0;font-size:.85rem}.courses-skill-row{grid-template-columns:repeat(auto-fill,minmax(272px,1fr));gap:16px;display:grid}.courses-skill-section{border-bottom:1px solid var(--border);padding-bottom:1.5rem}.courses-skill-section:last-child{border-bottom:none}.courses-page-hero{flex-wrap:wrap;justify-content:space-between;align-items:flex-start;gap:20px;display:flex}.courses-stats-row{flex-shrink:0;gap:16px;display:flex}.courses-stat{text-align:center;border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-sm);background:#fff;padding:12px 20px}.courses-stat-num{color:var(--brand);font-size:1.5rem;font-weight:900;display:block}.courses-stat-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.04em;font-size:.75rem;font-weight:600;display:block}.skill-filter-tabs{border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);background:#fff;flex-wrap:wrap;gap:8px;padding:16px;display:flex}.skill-filter-tab{border:1.5px solid var(--border);background:var(--bg-muted);color:var(--text-muted);cursor:pointer;border-radius:999px;align-items:center;gap:6px;padding:7px 14px;font-family:inherit;font-size:.85rem;font-weight:600;transition:all .15s;display:inline-flex}.skill-filter-tab:hover{border-color:var(--brand-light);color:var(--brand);background:var(--brand-pale)}.skill-filter-tab--active{color:#fff;border-color:#0000;box-shadow:0 2px 10px #4f46e54d}.dashboard-kpi-grid{grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:16px;display:grid}.kpi-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);padding:20px;transition:box-shadow .2s;position:relative;overflow:hidden}.kpi-card:hover{box-shadow:var(--shadow)}.kpi-card:before{content:"";background:linear-gradient(90deg, var(--brand), var(--accent));border-radius:var(--radius-lg) var(--radius-lg) 0 0;height:3px;position:absolute;top:0;left:0;right:0}.kpi-icon{margin-bottom:10px;font-size:1.6rem}.kpi-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em;font-size:.75rem;font-weight:700}.kpi-value{color:var(--text);letter-spacing:-.03em;margin:4px 0 2px;font-size:1.8rem;font-weight:900}.kpi-hint{color:var(--text-light);font-size:.82rem}.dashboard-two-col{grid-template-columns:1fr 1fr;gap:20px;display:grid}@media (width<=900px){.dashboard-two-col{grid-template-columns:1fr}}.dashboard-panel{padding:24px}.dashboard-panel .panel-title{letter-spacing:.1em;text-transform:uppercase;color:var(--text-muted);align-items:center;gap:8px;margin:0 0 18px;font-size:.8rem;font-weight:800;display:flex}.dashboard-panel .panel-title:before{content:"";background:var(--brand);border-radius:2px;width:3px;height:14px;display:inline-block}.dashboard-panel .panel-title.spaced{margin-top:28px}.course-progress-item{margin-bottom:14px}.course-progress-head{justify-content:space-between;align-items:center;margin-bottom:6px;font-size:.88rem;font-weight:500;display:flex}.skill-row{grid-template-columns:110px 1fr 48px;align-items:center;gap:10px;margin-bottom:10px;font-size:.88rem;display:grid}.skill-label{color:var(--text);font-weight:500}.skill-bar-track{height:8px}.skill-bar-fill{background:linear-gradient(90deg, var(--brand-light), var(--accent))}.skill-pct{text-align:right;color:var(--brand);font-variant-numeric:tabular-nums;font-weight:700}.chart-wrap{width:100%;max-height:320px;margin-top:8px;position:relative}.radar-wrap{max-height:280px;margin-bottom:20px}.rec-list .rec-card{border:1px solid var(--border);border-radius:var(--radius);background:var(--bg);gap:14px;padding:14px;transition:border-color .15s,box-shadow .15s;display:flex}.rec-list .rec-card:hover{border-color:var(--brand-light);box-shadow:var(--shadow-sm)}.rec-rank{color:var(--brand);min-width:1.5rem;padding-top:2px;font-size:1rem;font-weight:900}.rec-title{margin-bottom:4px;font-size:.95rem;font-weight:700}.lesson-layout-doc{grid-template-columns:256px 1fr;align-items:start;gap:24px;display:grid}@media (width<=900px){.lesson-layout-doc{grid-template-columns:1fr}}.lesson-sidebar{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);padding:16px;position:sticky;top:80px}.sidebar-section-title{letter-spacing:.1em;text-transform:uppercase;color:var(--text-light);margin:14px 0 8px;font-size:.7rem;font-weight:800}.sidebar-section-title:first-child{margin-top:0}.lesson-nav-list{flex-direction:column;gap:4px;margin:0;padding:0;list-style:none;display:flex}.lesson-nav-item{border-radius:var(--radius-sm);color:var(--text-muted);border:1.5px solid #0000;align-items:flex-start;gap:6px;padding:9px 10px;font-size:.85rem;line-height:1.35;text-decoration:none;transition:background .15s,color .15s;display:flex}.lesson-nav-item:hover{background:var(--bg-muted);color:var(--text)}.lesson-nav-num{color:var(--text-light);flex-shrink:0;min-width:1.4rem;font-size:.8rem;font-weight:700}.lesson-nav-title{flex:1;min-width:0}.lesson-nav-item--done{color:#065f46;background:#ecfdf5;border-color:#a7f3d0}.lesson-nav-item--next:not(.lesson-nav-item--active){color:#075985;background:#e0f2fe;border-color:#7dd3fc}.lesson-nav-item--active{box-shadow:0 0 0 2px var(--brand);color:var(--brand-dark);background:var(--brand-pale);font-weight:700}.lesson-nav-item--done.lesson-nav-item--active{background:#d1fae5;border-color:#34d399}.sidebar-progress .progress-bar{margin-top:8px}.lesson-main-doc{min-width:0}.lesson-main-title{letter-spacing:-.03em;margin:0 0 8px;font-size:1.4rem;font-weight:800}.lesson-mode-tabs{flex-wrap:wrap;gap:8px;margin-bottom:16px;display:flex}.lesson-mode-tab{color:var(--text-muted);border:1.5px solid var(--border);background:#fff;border-radius:999px;padding:8px 18px;font-size:.88rem;font-weight:600;text-decoration:none;transition:all .15s}.lesson-mode-tab:hover{border-color:var(--brand-light);color:var(--brand);background:var(--brand-pale)}.lesson-mode-tab--active{background:var(--brand);color:#fff;border-color:var(--brand);box-shadow:0 2px 8px #4f46e54d}.lesson-content-shell{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);margin-bottom:16px;padding:28px}.lesson-doc-tabs{flex-wrap:wrap;gap:8px;margin-bottom:20px;display:flex}.lesson-doc-tab{border:1.5px solid var(--border);background:var(--bg-muted);color:var(--text-muted);cursor:pointer;border-radius:999px;padding:8px 16px;font-size:.85rem;font-weight:600;transition:all .15s}.lesson-doc-tab:hover{border-color:var(--brand-light);color:var(--brand)}.lesson-doc-tab--active{background:var(--brand);border-color:var(--brand);color:#fff;box-shadow:0 2px 8px #4f46e540}.lesson-doc-panel{min-height:120px}.lesson-doc-nav{border-top:1px dashed var(--border);justify-content:space-between;align-items:center;gap:12px;margin-top:20px;padding-top:16px;display:flex}.lesson-markdown-prose{max-width:52rem}.lesson-markdown-prose .md-h2,.lesson-markdown-prose .lesson-doc-page-title{color:var(--text);letter-spacing:-.03em;margin:0 0 1rem;font-size:1.2rem;font-weight:800}.lesson-markdown-prose .md-h3{color:var(--brand-dark);border-bottom:2px solid #c7d2fe;margin:1.75rem 0 .65rem;padding-bottom:8px;font-size:1.05rem;font-weight:700}.lesson-markdown-prose .md-h3:first-child{margin-top:0}.lesson-markdown-prose .md-p{color:#334155;margin:0 0 1rem;font-size:.97rem;line-height:1.75}.lesson-markdown-prose .md-hr{background:linear-gradient(90deg,transparent,var(--border),transparent);border:none;height:1px;margin:1.75rem 0}.lesson-markdown-prose .md-ul,.lesson-markdown-prose .md-ol{margin:0 0 1.15rem;padding-left:1.25rem}.lesson-markdown-prose .md-li{margin-bottom:.5em;line-height:1.65}.lesson-markdown-prose .md-strong{color:var(--text);font-weight:650}.lesson-markdown-prose .md-quote{border-left:4px solid var(--brand);border-radius:0 var(--radius-sm) var(--radius-sm) 0;background:var(--brand-pale);color:var(--brand-dark);margin:1.15rem 0;padding:14px 18px}.lesson-markdown-prose .md-table-wrap{margin:1rem 0 1.25rem;overflow-x:auto}.lesson-markdown-prose .md-table{border-collapse:collapse;border:1px solid var(--border);border-radius:var(--radius);width:100%;font-size:.92rem;overflow:hidden}.lesson-markdown-prose .md-th,.lesson-markdown-prose .md-td{text-align:left;border-bottom:1px solid var(--border);padding:10px 14px}.lesson-markdown-prose .md-th{background:var(--bg-muted);color:var(--text);font-weight:700}.lesson-markdown-prose .md-tr:last-child .md-td{border-bottom:none}.lesson-main-doc--with-hud{padding-bottom:96px}.lesson-top-bar{flex-wrap:wrap;justify-content:space-between;align-items:flex-start;gap:16px;margin-bottom:8px;display:flex}.lesson-top-bar-left{flex:1;min-width:200px}.lesson-progress-hud{border:1px solid var(--border);border-radius:var(--radius);min-width:200px;max-width:280px;box-shadow:var(--shadow-sm);background:#fff;flex-shrink:0;padding:14px 16px}.lesson-progress-hud-row{justify-content:space-between;align-items:baseline;gap:12px;margin-bottom:6px;font-size:.82rem;display:flex}.lesson-progress-hud-row:last-of-type{margin-bottom:10px}.lesson-progress-hud-label{color:var(--text-muted);font-weight:600}.lesson-progress-hud-value{color:var(--text);font-weight:800}.lesson-progress-hud-mono{font-variant-numeric:tabular-nums}.lesson-progress-hud-bar{background:var(--bg-muted);border-radius:999px;height:6px;overflow:hidden}.lesson-progress-hud-bar-fill{background:linear-gradient(90deg, var(--brand), var(--accent));border-radius:999px;height:100%;transition:width .35s}.lesson-main-header--flush{margin-top:4px;margin-bottom:16px}.lesson-study-actions{flex-wrap:wrap;align-items:center;gap:12px;display:flex}.lesson-study-actions--inline{margin-bottom:8px}.lesson-supplemental{border-top:2px solid var(--brand-pale);margin-top:24px;padding-top:8px}.lesson-continue-bar{z-index:40;padding:12px 16px calc(12px + env(safe-area-inset-bottom));-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-top:1px solid var(--border);background:#fffffff2;position:fixed;bottom:0;left:0;right:0;box-shadow:0 -8px 32px #0f172a1a}.lesson-continue-inner{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;max-width:960px;margin:0 auto;display:flex}.lesson-continue-text{color:var(--text-muted);flex:1;min-width:200px;margin:0;font-size:.9rem}.lesson-quiz-shell{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);padding:24px}.quiz-step-badge{letter-spacing:.08em;text-transform:uppercase;color:var(--brand);background:var(--brand-pale);border:1px solid #c7d2fe;border-radius:999px;margin-bottom:18px;padding:6px 12px;font-size:.75rem;font-weight:800;display:inline-block}.quiz-task-badge{color:#78350f;border-radius:var(--radius-sm);background:#fef3c7;border:1px solid #fcd34d;margin-bottom:12px;padding:8px 14px;font-size:.9rem;font-weight:700;display:inline-block}.question-stem-lg{color:var(--text);margin:0 0 20px;font-size:1.08rem;font-weight:500;line-height:1.6}.quiz-options-tiles{grid-template-columns:1fr;gap:10px;margin-bottom:20px;display:grid}@media (width>=640px){.quiz-options-tiles{grid-template-columns:1fr 1fr}}.quiz-option-tile{text-align:left;border-radius:var(--radius);border:2px solid var(--border);background:var(--bg);cursor:pointer;font:inherit;color:var(--text);align-items:flex-start;gap:14px;padding:14px 16px;transition:border-color .15s,background .15s,box-shadow .15s,transform .1s;display:flex}.quiz-option-tile:hover{border-color:var(--brand-light);background:#fff;transform:translateY(-1px);box-shadow:0 2px 10px #4f46e51a}.quiz-option-tile--selected{border-color:var(--brand);background:var(--brand-pale);box-shadow:0 0 0 3px #4f46e526}.quiz-option-tile-letter{border-radius:var(--radius-sm);border:2px solid var(--border);width:34px;height:34px;color:var(--text-muted);background:#fff;flex-shrink:0;justify-content:center;align-items:center;font-size:.9rem;font-weight:800;display:flex}.quiz-option-tile--selected .quiz-option-tile-letter{background:var(--brand);border-color:var(--brand);color:#fff}.quiz-option-tile-text{flex:1;padding-top:4px;font-size:.95rem;line-height:1.45}.quiz-actions-row{flex-wrap:wrap;justify-content:flex-end;align-items:center;gap:12px;display:flex}.btn-hint{margin-right:auto}.hint-box-soft{border-radius:var(--radius-sm);color:#92400e;background:#fffbeb;border:1px solid #fde68a;margin-top:14px;padding:12px 16px;font-size:.9rem}.lesson-quiz-audio-wrap{margin-bottom:16px}.lesson-quiz-audio{width:100%;max-width:560px;height:40px}.lesson-quiz-transcript-block{margin-bottom:16px}.lesson-quiz-transcript-btn{font-size:.9rem}.lesson-quiz-transcript-panel{background:var(--bg-muted);border:1px solid var(--border);border-radius:var(--radius);max-height:min(55vh,420px);margin-top:12px;padding:16px;overflow:auto}.quiz-question-image{border-radius:var(--radius);border:1px solid var(--border);max-width:min(100%,520px);height:auto;margin:0 0 16px;display:block}.lesson-quiz-header{margin-bottom:12px}.lesson-quiz-sub{margin:4px 0 0}.lesson-quiz-foot{margin-top:16px}.lesson-quiz-foot a{color:var(--brand-light);font-weight:600}.lesson-done-actions{flex-wrap:wrap;gap:10px}.lesson-quiz-progress{background:var(--bg-muted);border-radius:var(--radius-sm);border:1px solid var(--border);margin-top:20px;padding:14px}.small-title{margin-top:0!important;font-size:.7rem!important}@media (width<=700px){.lesson-top-bar{flex-direction:column}.lesson-progress-hud{width:100%;max-width:none}}.admin-shell{max-width:1100px}.admin-header-block{margin-bottom:24px}.admin-header-block h1{letter-spacing:-.03em;margin:0 0 6px;font-size:1.6rem;font-weight:900}.admin-app-layout{min-height:calc(100vh - 64px);display:flex}.admin-sidebar{border-right:1px solid var(--border);background:#fff;flex-shrink:0;width:230px;height:calc(100vh - 64px);padding:24px 16px;position:sticky;top:64px;overflow-y:auto}.admin-sidebar-title{text-transform:uppercase;letter-spacing:.1em;color:var(--text-light);margin:0 0 12px;padding:0 8px;font-size:.7rem;font-weight:800}.admin-sidebar-nav{flex-direction:column;gap:4px;display:flex}.admin-nav-link{border-radius:var(--radius-sm);color:var(--text-muted);align-items:center;gap:10px;padding:10px 12px;font-size:.88rem;font-weight:500;text-decoration:none;transition:background .15s,color .15s;display:flex}.admin-nav-link:hover{background:var(--bg-muted);color:var(--text)}.admin-nav-link.active{background:var(--brand-pale);color:var(--brand);font-weight:700}.admin-nav-icon{font-size:1rem}.admin-main{flex:1;min-width:0;padding:28px 32px;overflow-y:auto}.admin-kpi-grid{grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:16px;margin-bottom:24px;display:grid}.stat-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);padding:20px;transition:box-shadow .2s;position:relative;overflow:hidden}.stat-card:hover{box-shadow:var(--shadow)}.stat-card-accent{border-radius:var(--radius-lg) var(--radius-lg) 0 0;height:3px;position:absolute;top:0;left:0;right:0}.stat-icon{margin-bottom:10px;font-size:1.5rem}.stat-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em;font-size:.75rem;font-weight:700}.stat-value{color:var(--text);letter-spacing:-.04em;margin-top:4px;font-size:1.75rem;font-weight:900}.stat-sub{color:var(--text-light);margin-top:2px;font-size:.82rem}.admin-chart-card{padding:20px}.admin-chart-card h2{letter-spacing:.1em;text-transform:uppercase;color:var(--text-muted);margin:0 0 18px;font-size:.85rem;font-weight:800}.chart-section-title{letter-spacing:.08em;text-transform:uppercase;color:var(--text-muted);margin:0 0 14px;font-size:.85rem;font-weight:800}.admin-two-col{grid-template-columns:1fr 1fr;gap:20px;margin-top:20px;display:grid}@media (width<=800px){.admin-two-col{grid-template-columns:1fr}}.admin-card{padding:20px}.admin-card h2{letter-spacing:.08em;text-transform:uppercase;color:var(--text-muted);margin:0 0 14px;font-size:.85rem;font-weight:800}.admin-list{margin:0;padding-left:18px}.admin-list li{margin-bottom:8px;font-size:.9rem}.admin-recent{margin:0;padding:0;list-style:none}.admin-recent li{border-bottom:1px solid var(--bg-muted);margin-bottom:12px;padding-bottom:12px}.admin-recent li:last-child{border-bottom:none;margin-bottom:0;padding-bottom:0}.admin-recent-user{font-weight:700}.admin-muted{color:var(--text-muted);font-size:.88rem}.admin-table-wrap{border-radius:var(--radius);border:1px solid var(--border);margin-top:16px;overflow-x:auto}.admin-table{border-collapse:collapse;width:100%;font-size:.875rem}.admin-table th{background:var(--bg-muted);color:var(--text);text-align:left;border-bottom:2px solid var(--border);padding:12px 14px;font-weight:700}.admin-table td{border-bottom:1px solid var(--border);vertical-align:top;padding:12px 14px}.admin-table tr:last-child td{border-bottom:none}.admin-table tr:hover td{background:var(--bg-muted)}.admin-form-grid{gap:14px;margin-top:16px;display:grid}.admin-form-grid label{color:var(--text);flex-direction:column;gap:6px;font-size:.85rem;font-weight:600;display:flex}.admin-form-actions{flex-wrap:wrap;gap:10px;margin-top:12px;display:flex}.about-main{max-width:720px}.about-card h1{margin-top:0}.app-header-doc,.user-box-doc{flex-wrap:wrap}.audio-player-mock{background:var(--bg-muted);border-radius:var(--radius);border:1px solid var(--border);align-items:center;gap:12px;margin-bottom:16px;padding:12px 14px;display:flex}.audio-play-btn{border:1.5px solid var(--border);cursor:default;background:#fff;border-radius:50%;width:40px;height:40px}.audio-track{background:var(--border);border-radius:999px;flex:1;height:8px;overflow:hidden}.audio-track-fill{background:var(--brand);width:35%;height:100%}.option{align-items:center;gap:8px;display:flex}.lesson-lead{white-space:pre-wrap;max-height:min(70vh,36rem);margin:0;line-height:1.6;overflow-y:auto}.lesson-content-card{margin-bottom:20px}.lesson-markdown{color:#334155;font-size:.95rem;line-height:1.65}.lesson-markdown h1,.lesson-markdown h2,.lesson-markdown h3{color:var(--text);margin:1.25em 0 .5em;font-size:1.1rem}.lesson-markdown h1:first-child,.lesson-markdown h2:first-child,.lesson-markdown h3:first-child{margin-top:0}.lesson-markdown p{margin:0 0 .85em}.lesson-markdown hr{border:none;border-top:1px solid var(--border);margin:1.25rem 0}.lesson-markdown ul,.lesson-markdown ol{margin:0 0 1em;padding-left:1.35rem}.lesson-markdown li{margin-bottom:.35em}.lesson-markdown strong{color:var(--text)}.lesson-markdown blockquote{border-left:4px solid var(--border);background:var(--bg-muted);color:var(--text-muted);margin:1em 0;padding:.5em 1em}.lesson-quiz-card .quiz-meta{color:var(--text-muted);margin:0 0 12px;font-size:.85rem}.question-stem{margin:0 0 16px;font-size:1.05rem;line-height:1.5}.question-image-placeholder{background:var(--bg-muted);border:1px dashed var(--border);border-radius:var(--radius);min-height:160px;color:var(--text-light);justify-content:center;align-items:center;margin-bottom:16px;font-weight:700;display:flex}.options-doc{flex-direction:column;gap:10px;display:flex}.option-doc{border-radius:var(--radius-sm);border:1.5px solid var(--border);cursor:pointer;align-items:flex-start;gap:10px;padding:12px 14px;display:flex}.option-doc.selected{background:var(--brand-pale);border-color:#93c5fd}.option-letter{color:var(--brand);min-width:1.5rem;font-weight:700}.quiz-actions-doc{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;margin-top:20px;display:flex}.hint-box{border-radius:var(--radius-sm);color:#92400e;background:#fffbeb;margin-top:12px;padding:10px;font-size:.9rem}.lesson-transcript-hint{margin-top:1rem}.courses-grid{margin-top:8px}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:999px}::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}.sidebar-course-header{background:linear-gradient(135deg, var(--brand-pale) 0%, #e0e7ff 100%);border-radius:var(--radius);border:1px solid #c7d2fe;margin-bottom:12px;padding:14px}.sidebar-course-title{color:var(--brand-dark);margin-bottom:8px;font-size:.88rem;font-weight:800;line-height:1.3}.sidebar-course-progress-row{justify-content:space-between;align-items:center;margin-bottom:6px;font-size:.78rem;display:flex}.sidebar-course-progress-label{color:var(--text-muted);font-weight:600}.sidebar-course-progress-pct{color:var(--brand);font-weight:900}.sidebar-progress-bar{margin-top:0}.lesson-nav-icon{text-align:center;flex-shrink:0;width:1.2rem;font-size:.8rem}.sidebar-footer{border-top:1px solid var(--border);margin-top:16px;padding-top:12px}.sidebar-back-link{color:var(--text-muted);font-size:.82rem;font-weight:600}.sidebar-back-link:hover{color:var(--brand)}.profile-page{flex-direction:column;gap:24px;max-width:720px;display:flex}.profile-header-card{border-radius:var(--radius-xl);box-shadow:var(--shadow-lg);color:#fff;background:linear-gradient(135deg,#1e1b4b 0%,#312e81 60%,#1e3a8a 100%);align-items:center;gap:20px;padding:28px 32px;display:flex}.profile-avatar-lg{color:#fff;background:linear-gradient(135deg,#818cf8,#a5b4fc);border:3px solid #fff6;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:72px;height:72px;font-size:1.8rem;font-weight:900;display:flex;box-shadow:0 4px 16px #0003}.profile-display-name{margin:0 0 4px;font-size:1.3rem;font-weight:800}.profile-email{color:#ffffffbf;margin:0 0 8px;font-size:.88rem}.profile-role-badge{color:#fff;background:#fff3;border:1px solid #ffffff4d;border-radius:999px;padding:4px 12px;font-size:.78rem;font-weight:700;display:inline-block}.profile-tabs{flex-wrap:wrap;gap:8px;display:flex}.profile-tab{border:1.5px solid var(--border);color:var(--text-muted);cursor:pointer;background:#fff;border-radius:999px;padding:9px 18px;font-family:inherit;font-size:.88rem;font-weight:600;transition:all .15s}.profile-tab:hover{border-color:var(--brand-light);color:var(--brand)}.profile-tab--active{background:var(--brand);color:#fff;border-color:var(--brand);box-shadow:0 2px 10px #4f46e54d}.profile-form{flex-direction:column;gap:16px;display:flex}.profile-section-title{color:var(--text);margin:0 0 4px;font-size:1.1rem;font-weight:800}.profile-form-row{grid-template-columns:1fr 1fr;gap:16px;display:grid}@media (width<=560px){.profile-form-row{grid-template-columns:1fr}}.input-disabled{background:var(--bg-muted);color:var(--text-muted);cursor:not-allowed}.field-hint{color:var(--text-light);font-size:.78rem}.profile-success{color:var(--success);font-size:.9rem;font-weight:600}.avatar-preview-lg{color:#fff;width:88px;height:88px;box-shadow:var(--shadow);border:3px solid #fff6;border-radius:50%;justify-content:center;align-items:center;margin-bottom:16px;font-size:2rem;font-weight:900;display:flex}.avatar-color-grid{flex-wrap:wrap;gap:12px;display:flex}.avatar-color-swatch{cursor:pointer;border:3px solid #0000;border-radius:50%;width:44px;height:44px;transition:transform .15s,border-color .15s}.avatar-color-swatch:hover{transform:scale(1.1)}.avatar-color-swatch--selected{border-color:var(--text);box-shadow:0 0 0 2px #fff, 0 0 0 4px var(--brand);transform:scale(1.12)}.roadmap-page{max-width:900px}.roadmap-levels{grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:20px;display:grid}.roadmap-level-card{border-radius:var(--radius-lg);border:1px solid var(--border);box-shadow:var(--shadow);overflow:hidden}.roadmap-level-banner{color:#fff;text-align:center;padding:24px 20px}.roadmap-level-step{text-transform:uppercase;letter-spacing:.1em;opacity:.85;margin-bottom:4px;font-size:.75rem;font-weight:800}.roadmap-level-name{letter-spacing:-.03em;font-size:1.6rem;font-weight:900}.roadmap-level-cefr{opacity:.9;margin-top:4px;font-size:.9rem}.roadmap-level-body{background:#fff;padding:20px}.roadmap-skill-list{flex-direction:column;gap:8px;margin:0 0 12px;padding:0;list-style:none;display:flex}.roadmap-skill-list li{color:var(--text);gap:8px;font-size:.88rem;display:flex}.roadmap-check{color:var(--success);flex-shrink:0;font-weight:900}.roadmap-goal{background:var(--brand-pale);border-radius:var(--radius-sm);border-left:3px solid var(--brand);color:var(--brand-dark);padding:10px 14px;font-size:.85rem}.roadmap-tips-section{margin-top:8px}.roadmap-section-title{margin:0 0 16px;font-size:1.2rem;font-weight:800}.roadmap-tips-grid{grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:16px;display:grid}.roadmap-tip-card{text-align:center}.roadmap-tip-icon{margin-bottom:8px;font-size:2rem}.roadmap-tip-title{margin-bottom:6px;font-weight:800}.roadmap-tip-desc{margin:0}.roadmap-cta{text-align:center}.roadmap-cta h2{margin:0 0 8px;font-size:1.2rem;font-weight:800}.roadmap-cta .row{justify-content:center;margin-top:16px}.about-inapp-page{max-width:900px}.about-hero-banner{border-radius:var(--radius-xl);box-shadow:var(--shadow-lg);background:linear-gradient(135deg,#1e1b4b 0%,#312e81 50%,#1e3a8a 100%);padding:48px 40px}.about-hero-content{max-width:560px}.about-hero-badge{color:#ffffffe6;letter-spacing:.04em;background:#ffffff26;border:1px solid #ffffff40;border-radius:999px;align-items:center;gap:6px;margin-bottom:12px;padding:6px 14px;font-size:.8rem;font-weight:700;display:inline-flex}.about-hero-title{letter-spacing:-.04em;color:#fff;margin:0 0 12px;font-size:clamp(1.4rem,4vw,2rem);font-weight:900}.about-hero-sub{color:#fffc;margin:0 0 20px;font-size:1rem;line-height:1.6}.about-section-title{margin:0 0 16px;font-size:1.2rem;font-weight:800}.about-features-grid{grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:16px;display:grid}.about-feature-card{text-align:center;padding:24px 20px}.about-feature-icon{margin-bottom:10px;font-size:2.2rem}.about-feature-title{margin:0 0 8px;font-size:.95rem;font-weight:800}.about-team-grid{grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:16px;display:grid}.about-team-name{color:var(--text);margin-bottom:2px;font-size:1rem;font-weight:800}.about-team-role{color:var(--brand);font-size:.82rem;font-weight:600}.about-stats-row{flex-wrap:wrap;gap:24px;display:flex}.about-stat{text-align:center;flex:1;min-width:80px}.about-stat-num{color:var(--brand);font-size:1.6rem;font-weight:900;display:block}.about-stat-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.04em;margin-top:2px;font-size:.75rem;font-weight:600;display:block}
