@import"https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800;900&family=JetBrains+Mono:wght@400;500;600;700&display=swap";:root{--accent: #0f766e;--accent-2: #0d9488;--accent-3: #134e4a;--accent-light: #ccfbf1;--gold: #d97706;--gold-light: #fef3c7;--gold-2: #f59e0b;--sidebar: #0f2d2b;--sidebar-2: #1a3c3a;--sidebar-bg: #f8f3ff;--sidebar-bg-2: #f1e9ff;--sidebar-surface: rgba(255,255,255,.84);--sidebar-surface-strong: #ffffff;--sidebar-border: #e7dafb;--sidebar-border-strong: #d7c1f7;--sidebar-text: #2f2442;--sidebar-text-soft: #7c7295;--sidebar-kicker: #9b90b5;--sidebar-active: #efe5ff;--sidebar-accent: #bea2f3;--sidebar-accent-2: #d6c0fb;--sidebar-sage: #a8d1bc;--sidebar-gold: #e9c56d;--success: #059669;--warning: #d97706;--danger: #dc2626;--info: #0369a1;--bg: #f0fafa;--bg-2: #e6f4f4;--white: #fff;--border: #b2dfdb;--border-2: #80cbc4;--t1: #0f1c1b;--t2: #3d6b68;--t3: #6b9e9b;--r-sm: 6px;--r-md: 8px;--r-lg: 12px;--r-xl: 16px;--r-2xl: 20px;--sh-sm: 0 1px 3px rgba(15,118,110,.08);--sh-md: 0 4px 16px rgba(15,118,110,.1);--sh-lg: 0 10px 40px rgba(15,118,110,.14);--sh-xl: 0 20px 60px rgba(15,46,43,.18)}*{box-sizing:border-box;margin:0;padding:0}body{font-family:Inter,system-ui,-apple-system,sans-serif;font-size:14px;background:var(--bg);color:var(--t1);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-feature-settings:"cv11","ss01"}img,video,iframe,object,svg,canvas{max-width:100%}h1,h2,h3,h4,h5,.font-display{font-family:Inter,system-ui,sans-serif}::-webkit-scrollbar{width:5px;height:5px}::-webkit-scrollbar-thumb{background:var(--border-2);border-radius:99px}@keyframes fadeUp{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes spin{to{transform:rotate(360deg)}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}@keyframes slideDown{0%{opacity:0;transform:translateY(-16px)}to{opacity:1}}button{cursor:pointer;font-family:inherit;border:none;background:none}input,textarea,select{font-family:inherit}a{text-decoration:none}.landing{min-height:100vh;overflow-x:hidden;background:radial-gradient(circle at top left,rgba(214,192,251,.18),transparent 26%),linear-gradient(180deg,#fcfaff,#f8f4ff 42%,#fff)}.landing-nav{display:flex;align-items:center;gap:16px;padding:20px 64px;background:#ffffffd1;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);position:sticky;top:0;z-index:100;border-bottom:1px solid rgba(231,218,251,.92);box-shadow:0 12px 28px #bea2f314}.landing-logo{display:flex;align-items:center;gap:12px;flex:1}.landing-logo-image{width:54px;height:54px;border-radius:16px;object-fit:cover;flex-shrink:0;background:#fff;border:3px solid rgba(255,255,255,.95);box-shadow:0 14px 30px #0f766e2e,0 0 0 1px #0f766e1f}.landing-logo-name{font-family:Inter,sans-serif;font-weight:800;font-size:20px;color:var(--sidebar-text);letter-spacing:-.02em}.landing-logo-sub{font-size:10px;color:#8f80ae;font-weight:600;letter-spacing:.12em;text-transform:uppercase;font-family:JetBrains Mono,monospace}.landing-nav-links,.landing-nav-actions{display:flex;align-items:center;gap:10px}.landing-nav-links{margin-left:auto}.landing-nav-link{border:0;background:transparent;color:#847899;font-size:13px;font-weight:600;padding:8px 10px;border-radius:10px;font-family:Inter,sans-serif;transition:background .2s,color .2s}.landing-nav-link:hover{background:#f6f0ffeb;color:var(--sidebar-text)}.landing-nav-btn{display:inline-flex;align-items:center;justify-content:center;padding:9px 22px;border-radius:8px;font-size:13px;font-weight:600;background:#ffffffe0;color:var(--sidebar-text-soft);border:1px solid var(--sidebar-border);transition:all .2s;font-family:Inter,sans-serif}.landing-nav-btn:hover{background:#f6f0ff;color:var(--sidebar-text);border-color:var(--sidebar-accent)}.landing-nav-btn.primary{background:linear-gradient(135deg,#cfbcfd,#b79af7);color:#34264d;border:1px solid #c6b0f5;box-shadow:0 10px 24px #b79af738}.landing-nav-btn.primary:hover{transform:translateY(-1px);box-shadow:0 12px 28px #b79af747}.hero{background:radial-gradient(circle at top right,rgba(233,197,109,.12),transparent 28%),linear-gradient(160deg,#fdfbff,#f5efff 48%,#f2f8fb);padding:90px 64px 100px;position:relative;overflow:hidden}.hero:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='60' height='60'%3E%3Ccircle cx='30' cy='30' r='1' fill='rgba(183,154,247,.14)'/%3E%3C/svg%3E");background-size:60px 60px}.hero:after{content:"";position:absolute;bottom:-60px;right:-60px;width:400px;height:400px;background:radial-gradient(circle,rgba(190,162,243,.22) 0%,transparent 70%);pointer-events:none}.hero-inner{max-width:1200px;margin:0 auto;position:relative;z-index:1;display:grid;grid-template-columns:minmax(0,1.06fr) minmax(380px,.94fr);gap:44px;align-items:center}.hero-copy{min-width:0}.hero-badge{display:inline-flex;align-items:center;gap:8px;background:#f6f0ffeb;border:1px solid rgba(215,193,247,.9);color:#8b72c8;font-size:12px;font-weight:600;padding:6px 14px;border-radius:99px;margin-bottom:24px;font-family:JetBrains Mono,monospace;letter-spacing:.04em;animation:fadeIn .6s ease}.hero-title{font-family:Inter,sans-serif;font-weight:800;font-size:56px;line-height:1.02;color:var(--sidebar-text);letter-spacing:-.03em;margin-bottom:24px;animation:fadeUp .7s ease .1s both;max-width:720px}.hero-title span{background:linear-gradient(135deg,#8e72d5,#baa0f3);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.hero-desc{font-size:17px;color:#6f6783;line-height:1.6;margin-bottom:26px;max-width:620px;animation:fadeUp .7s ease .2s both;font-weight:400}.hero-actions{display:flex;flex-wrap:wrap;gap:12px;margin-bottom:16px;animation:fadeUp .7s ease .23s both}.hero-trustline{max-width:620px;margin-bottom:22px;font-size:13px;line-height:1.6;color:#9286a7;font-family:JetBrains Mono,monospace;letter-spacing:.02em;animation:fadeUp .7s ease .25s both}.hero-highlights{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;max-width:760px;margin-bottom:18px;animation:fadeUp .7s ease .26s both}.hero-highlight{padding:14px;border-radius:20px;border:1px solid rgba(231,218,251,.92);background:#ffffffbd;box-shadow:0 12px 28px #bea2f314}.hero-highlight-icon{width:38px;height:38px;border-radius:12px;display:grid;place-items:center;background:#f3edff;color:#7f67ba;margin-bottom:10px}.hero-highlight-title{font-family:Inter,sans-serif;font-size:14px;font-weight:700;color:var(--sidebar-text);margin-bottom:6px;letter-spacing:-.01em}.hero-highlight-desc{font-size:12px;line-height:1.55;color:#7b7292}.hero-stats-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px;max-width:620px;animation:fadeUp .7s ease .32s both}.hero-stat-card{display:flex;align-items:center;gap:12px;padding:14px 16px;border-radius:20px;border:1px solid rgba(231,218,251,.92);background:#ffffffc7}.hero-stat-icon{width:38px;height:38px;border-radius:12px;display:grid;place-items:center;flex-shrink:0;background:#f6f0ff;color:#826abf}.hero-stat-copy{min-width:0}.hero-stat-v{font-family:Inter,sans-serif;font-weight:800;font-size:24px;color:var(--sidebar-text);line-height:1}.hero-stat-l{font-size:11px;color:#978aa8;margin-top:4px;letter-spacing:.07em;text-transform:uppercase;font-family:JetBrains Mono,monospace}.portal-panel{padding:18px;border-radius:28px;border:1px solid rgba(231,218,251,.92);background:#ffffff7a;box-shadow:0 22px 40px #bea2f31a;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.portal-panel-head{margin-bottom:16px}.portal-cards{display:flex;flex-direction:column;gap:12px;animation:fadeUp .7s ease .22s both}.portal-card{background:#ffffffd6;border:1px solid rgba(231,218,251,.95);border-radius:var(--r-xl);padding:20px 24px;cursor:pointer;transition:all .25s;display:flex;align-items:center;gap:16px;position:relative;overflow:hidden}.portal-card:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(135deg,rgba(214,192,251,.14),transparent 65%);opacity:0;transition:opacity .25s}.portal-card:hover{border-color:#bea2f3a6;transform:translate(4px);background:#fffffff5;box-shadow:0 18px 34px #bea2f31f}.portal-card:hover:before{opacity:1}.portal-card-icon{width:48px;height:48px;border-radius:12px;display:grid;place-items:center;font-size:22px;flex-shrink:0}.portal-card-icon.admin{background:linear-gradient(135deg,#eee6ff,#d8c6fb);color:#6f54ac}.portal-card-icon.instructor{background:linear-gradient(135deg,#eef8f2,#dcefe3);color:#4f876f}.portal-card-icon.learner{background:linear-gradient(135deg,#fff7ea,#f6e7bf);color:#a77d30}.portal-card-copy{flex:1;min-width:0}.portal-card-meta{font-size:10px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:#9b90b5;font-family:JetBrains Mono,monospace;margin-bottom:6px}.portal-card-title{font-family:Inter,sans-serif;font-weight:700;font-size:15px;color:var(--sidebar-text);margin-bottom:3px}.portal-card-sub{font-size:12.5px;line-height:1.45;color:#837796}.portal-card-arrow{margin-left:auto;color:#ab9fc1;font-size:18px;transition:transform .2s,color .2s}.portal-card:hover .portal-card-arrow{transform:translate(4px);color:#8d74c9}.portal-prompt{text-align:left;color:#9b90b5;font-size:12px;font-weight:500;letter-spacing:.06em;text-transform:uppercase;margin-bottom:8px;font-family:JetBrains Mono,monospace}.portal-panel-copy{font-size:13px;line-height:1.55;color:#7d7293;max-width:420px}.hero-framework-shell{display:grid;grid-template-columns:minmax(0,1fr);gap:16px}.hero-framework-card,.hero-side-card{border-radius:28px;border:1px solid rgba(231,218,251,.92);background:#ffffffbd;box-shadow:0 22px 40px #bea2f31a;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.hero-framework-card{padding:22px;animation:fadeUp .7s ease .22s both}.hero-framework-head{margin-bottom:18px}.hero-framework-kicker,.hero-side-kicker{font-size:11px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:#9c90b7;font-family:JetBrains Mono,monospace;margin-bottom:10px}.hero-framework-title{font-family:Inter,sans-serif;font-size:24px;font-weight:800;line-height:1.15;color:var(--sidebar-text);letter-spacing:-.02em}.hero-framework-list{display:grid;gap:12px}.hero-framework-step{display:grid;grid-template-columns:auto minmax(0,1fr);gap:12px;align-items:start;padding:12px 0;border-top:1px solid rgba(231,218,251,.78)}.hero-framework-step:first-child{border-top:0;padding-top:0}.hero-framework-marker{width:34px;height:34px;border-radius:12px;display:grid;place-items:center;background:linear-gradient(135deg,#f1e8ff,#dcc9fb);color:#6d52aa;font-family:Inter,sans-serif;font-weight:800;font-size:15px}.hero-framework-step-title{font-family:Inter,sans-serif;font-size:15px;font-weight:700;color:var(--sidebar-text);margin-bottom:4px}.hero-framework-step-desc{font-size:13px;line-height:1.55;color:#7b7191}.hero-framework-note{margin-top:16px;padding:14px 16px;border-radius:18px;background:linear-gradient(135deg,#f1e8ffeb,#f9f5fff5);color:#715f93;font-size:13px;line-height:1.6}.hero-framework-side{display:grid;grid-template-columns:minmax(0,1fr);gap:16px;animation:fadeUp .7s ease .28s both}.hero-side-card{padding:18px}.hero-side-list{display:grid;gap:10px}.hero-side-list span,.hero-side-tag{display:inline-flex;align-items:center;min-height:34px;border-radius:14px;border:1px solid rgba(231,218,251,.9);background:#fcf9fff5;color:#766a8d;font-size:12px;line-height:1.4;padding:8px 12px}.hero-side-tags{display:flex;flex-wrap:wrap;gap:8px}.sastra-overview{max-width:1200px;margin:0 auto;padding:44px 64px 18px}.sastra-overview-grid{display:grid;grid-template-columns:minmax(0,1.12fr) minmax(0,.88fr);gap:24px;align-items:start}.sastra-overview-desc{margin-bottom:28px;max-width:640px}.sastra-overview-points{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:16px}.sastra-point-card{background:linear-gradient(180deg,#fffffffa,#faf6fff2);border:1px solid var(--sidebar-border);border-radius:20px;padding:18px 18px 16px;box-shadow:0 14px 30px #bea2f314}.sastra-point-head{display:flex;align-items:center;gap:12px}.sastra-point-icon{width:42px;height:42px;border-radius:14px;display:grid;place-items:center;flex-shrink:0;background:#f3edff;color:#7f67ba}.sastra-point-title{font-family:Inter,sans-serif;font-size:15px;font-weight:700;color:var(--sidebar-text);letter-spacing:-.01em}.sastra-point-desc{margin-top:12px;font-size:13px;line-height:1.65;color:#7b7292}.sastra-overview-visual{min-width:0}.sastra-visual-shell{position:relative;overflow:hidden;background:radial-gradient(circle at top right,rgba(233,197,109,.16),transparent 30%),linear-gradient(180deg,#fffffffa,#f6f0fff2);border:1px solid rgba(231,218,251,.95);border-radius:28px;padding:24px;box-shadow:0 24px 46px #bea2f31f}.sastra-visual-shell:after{content:"";position:absolute;inset:auto -48px -72px auto;width:220px;height:220px;background:radial-gradient(circle,rgba(190,162,243,.18),transparent 70%);pointer-events:none}.sastra-visual-brand{position:relative;z-index:1;display:flex;align-items:center;gap:14px;margin-bottom:22px}.sastra-visual-logo{width:58px;height:58px;border-radius:18px;object-fit:cover;flex-shrink:0;box-shadow:0 16px 28px #bea2f329}.sastra-visual-kicker{font-size:10px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:#9b90b5;font-family:JetBrains Mono,monospace}.sastra-visual-title{margin-top:6px;font-family:Inter,sans-serif;font-size:22px;font-weight:800;line-height:1.16;color:var(--sidebar-text);letter-spacing:-.025em}.sastra-visual-flow{position:relative;z-index:1;display:grid;gap:12px}.sastra-flow-card{display:flex;align-items:flex-start;gap:12px;padding:14px;border-radius:18px;border:1px solid rgba(231,218,251,.96);background:#ffffffd1}.sastra-flow-icon{width:40px;height:40px;border-radius:13px;display:grid;place-items:center;flex-shrink:0;background:#f3edff;color:#7f67ba}.sastra-flow-label{font-size:10px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:#8f80ae;font-family:JetBrains Mono,monospace}.sastra-flow-text{margin-top:5px;font-size:13px;line-height:1.55;color:#786d8c}.sastra-visual-tags{position:relative;z-index:1;display:flex;flex-wrap:wrap;gap:8px;margin-top:18px}.sastra-tag{display:inline-flex;align-items:center;padding:6px 10px;border-radius:999px;background:#ffffffeb;border:1px solid var(--sidebar-border);font-size:11px;font-weight:700;letter-spacing:.04em;color:#6f54ac;font-family:JetBrains Mono,monospace}.sastra-visual-metrics{position:relative;z-index:1;display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:10px;margin-top:20px}.sastra-metric{background:#fffc;border:1px solid rgba(231,218,251,.96);border-radius:16px;padding:13px 10px;text-align:center}.sastra-metric-v{font-family:Inter,sans-serif;font-size:22px;font-weight:800;color:var(--sidebar-text);letter-spacing:-.03em}.sastra-metric-l{margin-top:4px;font-size:10px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:#988bab;font-family:JetBrains Mono,monospace}.features{padding:90px 64px;max-width:1200px;margin:0 auto}.section-label{font-size:11px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:#8b72c8;font-family:JetBrains Mono,monospace;margin-bottom:12px}.section-title{font-family:Inter,sans-serif;font-weight:800;font-size:38px;letter-spacing:-.025em;color:var(--t1);margin-bottom:16px;line-height:1.15}.section-desc{font-size:16px;color:var(--t2);max-width:520px;line-height:1.6;margin-bottom:60px}.features-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}.feature-card{background:linear-gradient(180deg,#fffffffa,#faf6fff5);border:1px solid var(--sidebar-border);border-radius:var(--r-xl);padding:28px;transition:all .25s;position:relative;overflow:hidden}.feature-card:after{content:"";position:absolute;bottom:0;left:0;right:0;height:3px;background:linear-gradient(90deg,#baa0f3,#a8d1bc);transform:scaleX(0);transform-origin:left;transition:transform .3s ease}.feature-card:hover{border-color:#d8c7fb;box-shadow:0 16px 34px #bea2f31f;transform:translateY(-3px)}.feature-card:hover:after{transform:scaleX(1)}.feature-icon{width:48px;height:48px;background:#f3edff;color:#7f67ba;border-radius:var(--r-lg);display:grid;place-items:center;font-size:22px;margin-bottom:18px}.feature-title{font-family:Inter,sans-serif;font-weight:700;font-size:16px;color:var(--t1);margin-bottom:8px}.feature-desc{font-size:13px;color:var(--t2);line-height:1.6}.feature-card-loop{position:relative;padding-top:26px}.feature-step-badge{width:36px;height:36px;border-radius:12px;display:grid;place-items:center;margin-bottom:16px;background:linear-gradient(135deg,#f0e6ff,#dcc7fb);color:#6d52aa;font-family:Inter,sans-serif;font-size:15px;font-weight:800}.framework-rule{max-width:920px;margin:22px auto 0;padding:16px 18px;border-radius:20px;border:1px solid rgba(231,218,251,.92);background:linear-gradient(180deg,#fffffff0,#f8f4fffa);color:#74698d;text-align:center;line-height:1.6;box-shadow:0 16px 32px #bea2f314}.roles-section{background:radial-gradient(circle at top right,rgba(233,197,109,.12),transparent 26%),linear-gradient(160deg,#fcf8ff,#f4efff);padding:90px 64px;border-top:1px solid rgba(231,218,251,.92);border-bottom:1px solid rgba(231,218,251,.92)}.roles-inner{max-width:1200px;margin:0 auto}.roles-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:56px}.roles-grid-compact{margin-top:34px}.role-card{background:#ffffffe6;border:1px solid rgba(231,218,251,.96);border-radius:var(--r-xl);padding:32px 28px;cursor:pointer;transition:all .25s;position:relative;overflow:hidden}.role-card:hover{background:#fffffffa;transform:translateY(-4px);box-shadow:0 20px 40px #bea2f324}.role-card-static{cursor:default}.role-card-static:hover{transform:none;background:#ffffffe6;box-shadow:none}.role-card-num{font-family:Inter,sans-serif;font-size:11px;font-weight:700;color:#b1a5c6;letter-spacing:.1em;margin-bottom:20px}.role-card-icon{font-size:36px;margin-bottom:16px;color:#8b72c8}.role-card-title{font-family:Inter,sans-serif;font-weight:800;font-size:20px;color:var(--sidebar-text);margin-bottom:8px}.role-card-meta{font-size:11px;color:#9b90b5;margin-bottom:12px;letter-spacing:.08em;text-transform:uppercase;font-family:JetBrains Mono,monospace}.role-card-desc{font-size:13px;color:#7b7292;line-height:1.6;margin-bottom:24px}.role-card-cta{display:inline-flex;align-items:center;gap:8px;font-size:13px;font-weight:600;color:#8b72c8;transition:gap .2s}.roles-section-desc{max-width:720px;margin-top:18px}.landing-cta-band{margin-top:30px;padding:22px 24px;border-radius:24px;border:1px solid rgba(231,218,251,.96);background:linear-gradient(135deg,#fffffff5,#f6f0fff0);display:flex;align-items:center;justify-content:space-between;gap:18px;box-shadow:0 18px 34px #bea2f31a}.landing-cta-kicker{font-size:11px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:#9b90b5;font-family:JetBrains Mono,monospace;margin-bottom:8px}.landing-cta-title{font-family:Inter,sans-serif;font-size:22px;line-height:1.25;font-weight:800;color:var(--sidebar-text);max-width:640px}.landing-cta-actions{display:flex;flex-wrap:wrap;gap:10px}.role-card:hover .role-card-cta{gap:12px}.landing-footer{background:#ffffffe0;border-top:1px solid rgba(231,218,251,.92);padding:40px 64px;display:flex;align-items:center;justify-content:space-between}.footer-brand{display:inline-flex;align-items:center;gap:10px;font-family:Inter,sans-serif;font-weight:800;font-size:18px;color:#716686}.footer-brand-image{width:28px;height:28px;border-radius:8px;object-fit:cover;flex-shrink:0}.footer-copy{font-size:12px;color:#a396ba;font-family:JetBrains Mono,monospace}.login-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0a1f1dd9;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);display:grid;place-items:center;z-index:200;padding:20px;animation:fadeIn .2s ease}.login-card{background:#fff;border-radius:var(--r-2xl);padding:44px 40px;width:100%;max-width:440px;box-shadow:var(--sh-xl);animation:slideDown .3s ease;position:relative}.access-picker-card{max-width:760px}.access-picker-sub{max-width:560px}.access-picker-list{display:grid;gap:12px;margin-top:18px}.access-picker-option{width:100%;border:1px solid rgba(231,218,251,.95);background:linear-gradient(180deg,#fffffffa,#f9f4fff5);border-radius:20px;padding:16px 18px;display:flex;align-items:center;gap:14px;text-align:left;transition:transform .2s,box-shadow .2s,border-color .2s}.access-picker-option:hover{transform:translateY(-2px);border-color:#bea2f3b3;box-shadow:0 18px 34px #bea2f31f}.access-picker-icon{width:50px;height:50px;border-radius:14px;display:grid;place-items:center;font-size:22px;flex-shrink:0}.access-picker-icon.admin{background:linear-gradient(135deg,#eee6ff,#d8c6fb);color:#6f54ac}.access-picker-icon.instructor{background:linear-gradient(135deg,#eef8f2,#dcefe3);color:#4f876f}.access-picker-icon.learner{background:linear-gradient(135deg,#fff7ea,#f6e7bf);color:#a77d30}.access-picker-copy{flex:1;min-width:0}.access-picker-meta{font-size:10px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:#9b90b5;font-family:JetBrains Mono,monospace;margin-bottom:6px}.access-picker-title{font-family:Inter,sans-serif;font-size:16px;font-weight:700;color:var(--sidebar-text);margin-bottom:4px}.access-picker-desc{font-size:13px;line-height:1.55;color:#7a718f}.access-picker-arrow{color:#a798bf;font-size:18px}.login-close{position:absolute;top:16px;right:16px;width:32px;height:32px;border-radius:8px;display:grid;place-items:center;background:var(--bg-2);color:var(--t2);font-size:16px;transition:all .15s}.login-close:hover{background:var(--bg);color:var(--t1)}.login-back{position:absolute;top:16px;left:16px;width:34px;height:34px;border-radius:10px;display:inline-flex;align-items:center;justify-content:center;background:var(--bg-2);color:var(--t2);transition:background .15s,color .15s,transform .15s}.login-back:hover{background:var(--bg);color:var(--t1);transform:translate(-1px)}.login-role-badge{display:inline-flex;align-items:center;gap:6px;background:#f3edff;color:#6f54ac;font-size:11px;font-weight:700;padding:4px 12px;border-radius:99px;margin-bottom:20px;letter-spacing:.06em;text-transform:uppercase;font-family:JetBrains Mono,monospace}.login-role-badge.admin{background:#ede9fe;color:#5b21b6}.login-role-badge.instructor{background:#eef8f2;color:#4f876f}.login-role-badge.learner{background:#fff7ea;color:#a77d30}.login-shell{min-height:100vh;display:grid;place-items:center;background:linear-gradient(160deg,#0f2d2b,#0f766e);padding:20px}.login-logo{display:flex;align-items:center;gap:12px;margin-bottom:28px}.login-brand-image{width:60px;height:60px;border-radius:18px;object-fit:cover;flex-shrink:0;background:#fff;border:3px solid rgba(255,255,255,.95);box-shadow:0 16px 32px #0f766e2e,0 0 0 1px #0f766e24}.login-mark{width:48px;height:48px;background:linear-gradient(135deg,var(--gold),var(--gold-2));border-radius:13px;display:grid;place-items:center;font-family:Inter,sans-serif;font-size:22px;font-weight:800;color:#0f2d2b;box-shadow:0 4px 12px #d9770659}.login-title{font-family:Inter,sans-serif;font-size:22px;font-weight:800;color:var(--t1);letter-spacing:-.02em}.login-sub{font-size:13px;color:var(--t2);margin-bottom:28px;line-height:1.5}.login-actions-row{display:flex;justify-content:flex-end;margin-top:14px}.login-actions-row-left{justify-content:flex-start;margin-bottom:18px}.login-overlay-nested{z-index:210;background:#0a1f1db8}.success-msg{margin-bottom:16px;padding:12px 14px;border-radius:12px;border:1px solid rgba(95,182,126,.28);background:#ecfdf2f5;color:#166534;font-size:13px}.shell{display:flex;height:100vh;overflow:hidden}.shell-backdrop{display:none}.sidebar{width:var(--learner-shell-sidebar-width, 324px);background:radial-gradient(circle at top right,rgba(190,162,243,.24),transparent 30%),linear-gradient(180deg,#fcf9ff 0%,var(--sidebar-bg) 52%,var(--sidebar-bg-2) 100%);border-right:1px solid var(--sidebar-border);flex-shrink:0;display:flex;flex-direction:column;overflow-y:auto;transition:width .2s;padding:16px 12px 14px;gap:12px;box-shadow:inset -1px 0 #ffffffc7}.sidebar-learner-collapsed{padding-inline:10px}.sidebar-learner-collapsed .sidebar-course-content,.sidebar-learner-collapsed .s-chip,.sidebar-learner-collapsed .s-name,.sidebar-learner-collapsed .s-link,.sidebar-learner-collapsed .s-user>div:not(.s-avatar),.sidebar-learner-collapsed .s-user-action{display:none}.sidebar-learner-collapsed .s-logo,.sidebar-learner-collapsed .s-user{justify-content:center}.sidebar-learner-collapsed .s-icon,.sidebar-learner-collapsed .s-avatar{margin-inline:auto}.sidebar-resizer-rail{width:10px;flex-shrink:0;display:flex;align-items:center;justify-content:center;position:relative;background:linear-gradient(180deg,#f8f4ffe6,#f4f9ffdb)}.sidebar-resizer-rail:before{content:"";position:absolute;top:16px;bottom:16px;width:1px;background:linear-gradient(180deg,#bea2f30a,#bea2f347,#a8d1bc42,#bea2f30a)}.sidebar-resizer-toggle,.sidebar-resizer-grip{position:relative;z-index:1;border:none;background:transparent;box-shadow:none}.sidebar-resizer-toggle{width:100%;height:72px;border-radius:0;display:inline-flex;align-items:center;justify-content:center;color:#8a73c1}.sidebar-resizer-toggle.collapsed svg{transform:rotate(180deg)}.sidebar-resizer-grip{position:absolute;top:50%;transform:translateY(-50%);width:100%;height:120px;border-radius:0;display:inline-flex;flex-direction:column;align-items:center;justify-content:center;gap:6px;cursor:ew-resize;opacity:.5;transition:opacity .18s ease,background .18s ease}.sidebar-resizer-grip span{width:2px;height:18px;border-radius:999px;background:linear-gradient(180deg,#b59de7,#79d0c3)}.sidebar-resizer-grip:hover{opacity:1;background:linear-gradient(180deg,#bea2f312,#a8d1bc0d,#bea2f312)}body.sidebar-resizing{cursor:ew-resize;-webkit-user-select:none;user-select:none}.topbar-menu-btn{display:none;width:40px;height:40px;border-radius:12px;border:1px solid var(--sidebar-border);background:#ffffffeb;align-items:center;justify-content:center;flex-direction:column;gap:4px;box-shadow:0 8px 20px #bea2f324}.topbar-menu-btn span{width:16px;height:2px;border-radius:999px;background:#7b68a9}.main{flex:1;display:flex;flex-direction:column;overflow:hidden;background:linear-gradient(180deg,#fbf9ff,#f7fafc)}.topbar{height:60px;background:#ffffffe0;border-bottom:1px solid #ece3fb;display:flex;align-items:center;padding:0 24px;gap:12px;box-shadow:0 1px #bea2f329;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.content{flex:1;overflow-y:auto;padding:28px 32px}.s-logo{display:flex;align-items:center;gap:10px;padding:14px;border:1px solid var(--sidebar-border);border-radius:22px;background:linear-gradient(180deg,#fffffffa,#faf6ffeb);box-shadow:0 14px 34px #bea2f321}.s-logo-image{width:48px;height:48px;border-radius:16px;object-fit:cover;flex-shrink:0;background:#fff;border:3px solid rgba(255,255,255,.95);box-shadow:0 14px 28px #0f766e2e,0 0 0 1px #0f766e1f}.s-name{font-family:Inter,sans-serif;font-size:15px;font-weight:800;color:var(--sidebar-text);letter-spacing:-.02em}.s-chip{font-size:9px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;background:#f7f1ff;color:#866ab8;padding:4px 9px;border-radius:999px;border:1px solid var(--sidebar-border);margin-left:auto}.s-chip.admin{background:#f1e8ff;color:#7b57bc;border-color:#dcc8ff}.s-chip.instructor{background:#eef8f2;color:#4f876f;border-color:#cae7d5}.s-chip.learner{background:#fff7e8;color:#b3822d;border-color:#f4dfaa}.s-section{font-size:10px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--sidebar-kicker);padding:10px 10px 2px}.sidebar nav{display:flex;flex-direction:column;gap:4px}.s-link{display:flex;align-items:center;gap:10px;padding:11px 14px;margin:0 2px;border-radius:14px;font-size:13.5px;font-weight:600;color:var(--sidebar-text-soft);cursor:pointer;transition:background .18s ease,box-shadow .18s ease,color .18s ease,transform .18s ease;text-decoration:none;font-family:Inter,sans-serif;position:relative}.sidebar-course-content{margin:8px 2px 0;background:linear-gradient(180deg,#fffffff0,#f8f4ffeb);border:1px solid var(--sidebar-border);border-radius:20px;overflow:hidden;box-shadow:0 18px 34px #bea2f31f}.sidebar-course-panel{color:var(--sidebar-text)}.sidebar-course-panelhead{padding:16px 16px 14px;border-bottom:1px solid rgba(215,193,247,.72);background:radial-gradient(circle at top right,rgba(233,197,109,.2),transparent 34%),linear-gradient(180deg,#fffffffa,#f4eeffeb);cursor:pointer;transition:background .18s ease,border-color .18s ease,box-shadow .18s ease}.sidebar-course-paneltop{display:flex;align-items:flex-start;gap:10px;justify-content:space-between}.sidebar-course-panelcopy{flex:1;min-width:0}.sidebar-course-panelhead:hover{background:radial-gradient(circle at top right,rgba(233,197,109,.24),transparent 36%),linear-gradient(180deg,#fffffffc,#f1eafff5);box-shadow:inset 0 -1px #bea2f324}.sidebar-course-panelhead.collapsed{border-bottom-color:transparent}.sidebar-course-paneltoggle{width:40px;height:40px;border-radius:999px;border:1px solid rgba(190,162,243,.3);background:linear-gradient(180deg,#fffffff0,#f9f4ffe0);color:#876fc1;display:inline-flex;align-items:center;justify-content:center;box-shadow:0 10px 22px #bea2f329}.sidebar-course-paneltoggle.collapsed svg{transform:rotate(180deg)}.sidebar-course-kicker{font-size:10px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--sidebar-kicker);font-family:JetBrains Mono,monospace}.sidebar-course-course{margin-top:6px;font-family:Inter,sans-serif;font-size:17px;font-weight:800;color:var(--sidebar-text);letter-spacing:-.02em}.sidebar-course-title{margin-top:10px;font-family:Inter,sans-serif;font-size:13px;font-weight:700;color:#7d67ab;letter-spacing:.04em;text-transform:uppercase}.sidebar-course-legend{margin-top:12px;display:flex;flex-wrap:wrap;gap:6px}.sidebar-course-legend span{padding:4px 10px;border-radius:999px;border:1px solid rgba(190,162,243,.34);background:#ffffffc7;color:#836cb8;font-size:10px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;font-family:JetBrains Mono,monospace}.sidebar-course-meta{margin-top:6px;font-size:12px;color:var(--sidebar-text-soft)}.sidebar-course-progressbar{margin-top:14px;height:7px;border-radius:999px;background:#efe6fb;overflow:hidden;box-shadow:inset 0 1px 2px #bea2f314}.sidebar-course-progressfill{height:100%;border-radius:inherit;background:linear-gradient(90deg,var(--sidebar-accent),var(--sidebar-sage))}.sidebar-course-tree{max-height:min(62vh,760px);overflow-y:auto;background:linear-gradient(180deg,#ffffffc7,#f5f0ffad);padding:8px 0 10px}.sidebar-course-tree.collapsed{display:none}.sidebar-course-section{margin:10px 10px 0;padding:14px;background:linear-gradient(180deg,#fffffff0,#f7f1ffe0);font-size:12px;color:var(--sidebar-text);border:1px solid rgba(215,193,247,.8);border-radius:18px;letter-spacing:.01em;display:flex;align-items:center;gap:10px;cursor:pointer;transition:background .18s ease,color .18s ease;min-width:0}.sidebar-course-subsection{margin:8px 10px 0;padding:12px 14px;background:#ffffffd1;font-size:12px;color:var(--sidebar-text-soft);border:1px solid rgba(215,193,247,.6);border-radius:16px;display:flex;align-items:center;gap:10px;cursor:pointer;transition:background .18s ease,color .18s ease;min-width:0}.sidebar-course-level-chapter{position:relative;background:radial-gradient(circle at top right,rgba(233,197,109,.18),transparent 34%),linear-gradient(135deg,#fffffffc,#f5edfff5);border-color:#baa2f3b3;box-shadow:0 18px 32px #bea2f329}.sidebar-course-level-chapter:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;border-radius:18px;padding:1px;background:linear-gradient(135deg,#bea2f3d9,#a8d1bc99,#e9c56d99);-webkit-mask:linear-gradient(#fff 0 0) content-box,linear-gradient(#fff 0 0);-webkit-mask-composite:xor;mask-composite:exclude;pointer-events:none}.sidebar-course-level-unit{position:relative;background:linear-gradient(135deg,#fffffff5,#f9f4fff0);border-color:#d7c1f7e0;box-shadow:0 10px 22px #bea2f31c}.sidebar-course-level-unit:before{content:"";position:absolute;left:12px;top:12px;bottom:12px;width:3px;border-radius:999px;background:linear-gradient(180deg,#bea2f3,#8dcbb2);opacity:.95}.sidebar-course-level-unit .sidebar-course-nodecopy{padding-left:10px}.sidebar-course-level-session{position:relative;background:linear-gradient(135deg,#fcfafff5,#f5f8ffeb);border-color:#e1e8fffa;box-shadow:0 8px 18px #94a3b817}.sidebar-course-level-session:before{content:"";position:absolute;left:12px;top:50%;width:14px;height:1px;background:linear-gradient(90deg,#bea2f3bf,#bea2f300)}.sidebar-course-level-session .sidebar-course-nodecopy{padding-left:12px}.sidebar-course-section:hover{background:#f2eaffe6}.sidebar-course-subsection:hover{background:#f7f1fff2;color:var(--sidebar-text)}.sidebar-course-nodecopy{flex:1;min-width:0;display:flex;flex-direction:column;gap:4px}.sidebar-course-nodekicker{display:flex;align-items:center;gap:6px;flex-wrap:wrap}.sidebar-course-nodepill,.sidebar-course-nodeindex{font-size:10px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;font-family:JetBrains Mono,monospace}.sidebar-course-nodepill{padding:3px 7px;border-radius:999px;background:#bea2f329;color:#7d67ab}.sidebar-course-level-chapter .sidebar-course-nodepill{background:linear-gradient(135deg,#bea2f338,#e9c56d2e);color:#6b549e}.sidebar-course-level-unit .sidebar-course-nodepill{background:linear-gradient(135deg,#bea2f32e,#a8d1bc29);color:#6d5ca2}.sidebar-course-level-session .sidebar-course-nodepill{background:#94a3b824;color:#66758e}.sidebar-course-nodeindex{color:var(--sidebar-kicker)}.sidebar-course-nodetitle{font-size:13px;line-height:1.4;font-weight:700;color:inherit;white-space:normal;overflow-wrap:anywhere}.sidebar-course-level-chapter .sidebar-course-nodetitle{font-size:15px;font-weight:800;letter-spacing:-.02em}.sidebar-course-level-unit .sidebar-course-nodetitle{font-size:14px;font-weight:750}.sidebar-course-level-session .sidebar-course-nodetitle{font-size:13px;font-weight:700}.sidebar-course-nodecount{flex-shrink:0;display:inline-flex;flex-direction:column;align-items:flex-end;gap:2px;font-size:10px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:#8d7da9;font-family:JetBrains Mono,monospace}.sidebar-course-level-chapter .sidebar-course-nodecount{min-width:64px;padding:7px 10px;border-radius:14px;background:#ffffffc2;border:1px solid rgba(215,193,247,.7)}.sidebar-course-level-unit .sidebar-course-nodecount{min-width:58px}.sidebar-course-level-session .sidebar-course-nodecount{opacity:.88}.sidebar-course-toggle{display:inline-flex;align-items:center;justify-content:center;color:#8d7da9;flex-shrink:0;width:28px;height:28px;border-radius:999px;background:#ffffffb8}.sidebar-course-level-chapter .sidebar-course-toggle{background:#ffffffeb;box-shadow:0 8px 18px #bea2f329}.sidebar-course-level-unit .sidebar-course-toggle{background:#f8f3ffeb}.sidebar-course-level-session .sidebar-course-toggle{width:24px;height:24px;background:#f5f8ffeb}.sidebar-lesson-row{margin:8px 10px 0;border:1px solid rgba(215,193,247,.45);border-radius:16px;min-width:0;transition:background .18s ease,box-shadow .18s ease,opacity .18s ease}.sidebar-lesson-row:hover{background:#f3ecffb8}.sidebar-lesson-row.active{background:linear-gradient(180deg,#e3f6f0f0,#eef8f4e0);box-shadow:inset 3px 0 #8dcbb2,0 12px 22px #8dcbb229}.sidebar-lesson-row.locked{opacity:.62}.sidebar-lesson-row.done .sidebar-lesson-title{color:#2f5a4f}.sidebar-lesson-icon{width:32px;height:32px;border-radius:10px;display:inline-grid;place-items:center;flex-shrink:0;background:#ffffffc7;border:1px solid var(--sidebar-border);color:#7d67ab;box-shadow:0 6px 18px #bea2f317}.sidebar-lesson-icon.type-video{color:#7e62b5;background:#f6efff}.sidebar-lesson-icon.type-pdf{color:#b55d76;background:#fff0f3}.sidebar-lesson-icon.type-pptx{color:#ac6d33;background:#fff5ea}.sidebar-lesson-icon.type-archive{color:#5d83b8;background:#eef5ff}.sidebar-lesson-icon.type-article{color:#6670ae;background:#f1f3ff}.sidebar-lesson-icon.type-quiz{color:#4c8a72;background:#edf8f1}.sidebar-lesson-icon.type-code{color:#5662b6;background:#eff1ff}.sidebar-lesson-copy{flex:1;min-width:0;display:flex;flex-direction:column;gap:4px}.sidebar-lesson-title{font-size:13px;line-height:1.38;font-weight:600;color:var(--sidebar-text);white-space:normal;overflow-wrap:anywhere}.sidebar-lesson-meta{display:flex;flex-wrap:wrap;gap:8px;align-items:center;font-size:10px;color:var(--sidebar-kicker);font-family:JetBrains Mono,monospace;letter-spacing:.04em;text-transform:uppercase}.sidebar-lesson-type{display:inline-flex;align-items:center;min-height:18px;padding:0 6px;border-radius:999px;border:1px solid var(--sidebar-border-strong);background:#ffffffbd;color:#7a62a8;font-weight:700}.sidebar-lesson-kicker{color:#8d7da9;font-weight:700}.sidebar-lesson-state{color:var(--sidebar-kicker);display:inline-flex;align-items:center;justify-content:center;flex-shrink:0}.sidebar-lesson-state.done{color:#4f8a72}.sidebar-lesson-state.locked{color:#aa9fbe}.s-link:hover{background:#ffffffb8;color:var(--sidebar-text);box-shadow:0 10px 22px #bea2f31f;transform:translate(2px)}.s-link.active{background:linear-gradient(180deg,#f2eaff 0%,var(--sidebar-active) 100%);color:var(--sidebar-text);box-shadow:inset 3px 0 0 var(--sidebar-accent),0 12px 24px #bea2f324}.s-icon{width:18px;min-width:18px;max-width:18px;text-align:center;font-size:14px;line-height:1;overflow:hidden;flex-shrink:0}.s-badge{margin-left:auto;font-size:10px;font-weight:700;min-width:18px;height:18px;border-radius:9px;background:#f8dce2;color:#8d3150;display:grid;place-items:center;padding:0 5px;font-family:JetBrains Mono,monospace}.s-user{display:flex;align-items:center;gap:10px;padding:12px 14px;border:1px solid var(--sidebar-border);border-radius:20px;background:linear-gradient(180deg,#fffffffa,#faf6ffeb);box-shadow:0 14px 32px #bea2f31f;margin-top:auto}.s-avatar{width:34px;height:34px;border-radius:50%;background:linear-gradient(135deg,#dcc7fb,#badfcd);display:grid;place-items:center;font-family:Inter,sans-serif;font-size:13px;font-weight:700;color:#443162;flex-shrink:0}.s-uname{font-size:13px;font-weight:700;color:var(--sidebar-text)}.s-urole{font-size:10px;color:var(--sidebar-text-soft);font-family:JetBrains Mono,monospace;text-transform:uppercase}.s-user-action{color:var(--sidebar-kicker);font-size:14px;flex-shrink:0;display:inline-flex}.t-title{font-family:Inter,sans-serif;font-weight:700;font-size:15px;color:var(--sidebar-text)}.t-right{display:flex;align-items:center;gap:10px}.topbar .btn-ghost{color:#6f628a;background:#ffffffa3;border:1px solid #ede4fb}.topbar .btn-ghost:hover{background:#f3ebff;color:#3e305d}.page{animation:fadeUp .35s ease;max-width:1100px}.page-header{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:28px;gap:16px}.page-title{font-family:Inter,sans-serif;font-weight:800;font-size:24px;color:var(--t1);letter-spacing:-.02em}.page-sub{font-size:13px;color:var(--t2);margin-top:4px}.stats{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:16px;margin-bottom:28px}.stat{background:var(--white);border:1px solid var(--border);border-radius:var(--r-xl);padding:22px 20px;box-shadow:var(--sh-sm);position:relative;overflow:hidden;transition:transform .2s,box-shadow .2s}.stat:hover{transform:translateY(-2px);box-shadow:var(--sh-md)}.stat:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:var(--c, var(--accent))}.stat-v{font-family:Inter,sans-serif;font-weight:800;font-size:30px;letter-spacing:-.03em;line-height:1;margin-bottom:6px}.stat-l{font-size:12px;color:var(--t2);font-weight:500}.analytics-hero{display:grid;grid-template-columns:minmax(0,1.5fr) minmax(280px,.9fr);gap:18px;margin-bottom:22px}.analytics-hero-copy,.analytics-hero-spotlight,.analytics-card,.revenue-hero,.revenue-mini-card{position:relative;overflow:hidden;border:1px solid rgba(190,162,243,.28);border-radius:24px;background:radial-gradient(circle at top right,rgba(233,197,109,.14),transparent 28%),linear-gradient(180deg,#fffffffa,#f6f1ffeb);box-shadow:0 18px 42px #3e276914}.analytics-hero-copy{padding:24px 26px}.analytics-hero-kicker,.revenue-hero-kicker{font-size:11px;letter-spacing:.16em;text-transform:uppercase;font-weight:800;color:#7e68a9}.analytics-hero-title{margin-top:10px;font-family:Inter,sans-serif;font-size:28px;line-height:1.05;font-weight:800;letter-spacing:-.03em;color:#1e1437;max-width:14ch}.analytics-hero-sub,.revenue-hero-sub{margin-top:10px;color:var(--t2);font-size:13px;line-height:1.6;max-width:58ch}.analytics-hero-chips{margin-top:16px;display:flex;flex-wrap:wrap;gap:10px}.analytics-chip{display:inline-flex;align-items:center;gap:6px;padding:8px 12px;border-radius:999px;background:#ffffffc7;border:1px solid rgba(190,162,243,.28);color:#67558f;font-size:12px;font-weight:700}.analytics-chip-strong{color:var(--accent-3);border-color:#0f766e2e;background:#0f766e14}.analytics-hero-spotlight{padding:22px 22px 18px;display:flex;flex-direction:column;justify-content:space-between;gap:12px}.analytics-spotlight-label{font-size:11px;font-weight:800;letter-spacing:.16em;text-transform:uppercase;color:#8b74b0}.analytics-spotlight-value{font-family:Inter,sans-serif;font-size:54px;line-height:.95;font-weight:900;letter-spacing:-.05em;color:#1f1442}.analytics-spotlight-copy{color:var(--t2);font-size:13px;line-height:1.55}.analytics-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:16px}.analytics-card{padding:18px 18px 16px}.analytics-card:before{content:"";position:absolute;inset:0 auto 0 0;width:4px;border-radius:24px 0 0 24px;background:var(--accent)}.analytics-card-accent:before{background:var(--accent)}.analytics-card-info:before{background:var(--info)}.analytics-card-success:before{background:var(--success)}.analytics-card-warning:before{background:var(--warning)}.analytics-card-label{font-size:11px;font-weight:800;letter-spacing:.14em;text-transform:uppercase;color:#8c79ad}.analytics-card-value{margin-top:14px;font-family:Inter,sans-serif;font-size:32px;line-height:1;font-weight:850;letter-spacing:-.04em;color:#1f1638}.analytics-card-note{margin-top:10px;color:var(--t2);font-size:12px;line-height:1.5}.revenue-hero{padding:22px 24px;display:grid;grid-template-columns:minmax(0,1.2fr) minmax(280px,.9fr);gap:18px;margin-bottom:16px}.revenue-hero-value{margin-top:10px;font-family:Inter,sans-serif;font-size:clamp(34px,4vw,52px);line-height:.98;letter-spacing:-.05em;font-weight:900;color:#114f4b}.revenue-hero-side{display:grid;gap:12px}.revenue-mini-card{padding:14px 16px;display:flex;align-items:center;justify-content:space-between;gap:12px}.revenue-mini-card span{color:var(--t2);font-size:12px;font-weight:600}.revenue-mini-card strong{font-family:Inter,sans-serif;font-size:22px;line-height:1;letter-spacing:-.03em;color:#1f1638}.revenue-table-card{border-color:#bea2f338}.card{background:var(--white);border:1px solid var(--border);border-radius:var(--r-xl);box-shadow:var(--sh-sm);overflow:hidden;transition:box-shadow .2s,border-color .2s}.card:hover{border-color:var(--border-2);box-shadow:var(--sh-md)}.card-hdr{padding:16px 20px;border-bottom:1px solid var(--border);font-weight:600;font-size:14px}.card-body{padding:20px}.mb-4{margin-bottom:16px}.table-wrap{background:var(--white);border:1px solid var(--border);border-radius:var(--r-xl);overflow:hidden;box-shadow:var(--sh-sm)}table{width:100%;border-collapse:collapse}thead tr{background:var(--bg-2)}th{text-align:left;padding:12px 16px;font-size:11px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--t2);white-space:nowrap;font-family:JetBrains Mono,monospace}td{padding:13px 16px;border-top:1px solid var(--border);font-size:13px;vertical-align:middle}tr:hover td{background:var(--bg)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;padding:9px 18px;border-radius:var(--r-md);font-size:13px;font-weight:600;transition:all .15s;white-space:nowrap;font-family:Inter,sans-serif;border:1px solid transparent}.btn-primary{background:var(--accent);color:#fff;border-color:var(--accent)}.btn-primary:hover{background:var(--accent-2);border-color:var(--accent-2);box-shadow:0 4px 12px #0f766e4d}.btn-gold{background:linear-gradient(135deg,#cfbcfd,#b79af7);color:#34264d;font-weight:700;border:1px solid #c6b0f5;box-shadow:0 8px 18px #b79af738}.btn-gold:hover{transform:translateY(-1px);box-shadow:0 10px 22px #b79af747}.btn-secondary{background:var(--white);color:var(--t1);border-color:var(--border-2)}.btn-secondary:hover{background:var(--bg-2);border-color:var(--border-2)}.btn-success{background:var(--success);color:#fff;border-color:var(--success)}.btn-success:hover{background:#047857}.btn-danger{background:var(--danger);color:#fff;border-color:var(--danger)}.btn-danger:hover{background:#b91c1c}.btn-ghost{color:var(--t2);padding:7px 12px}.btn-ghost:hover{background:var(--bg-2);color:var(--t1);border-radius:var(--r-md)}.btn-sm{padding:6px 14px;font-size:12px}.btn-xs{padding:4px 10px;font-size:11px}.btn-block{width:100%}.btn:disabled{opacity:.6;cursor:not-allowed;transform:none!important;box-shadow:none!important}.fg{margin-bottom:16px}.fl{display:block;font-size:12px;font-weight:600;color:var(--t1);margin-bottom:6px;letter-spacing:.02em}.fc{width:100%;padding:9px 12px;border:1.5px solid var(--border-2);border-radius:var(--r-md);font-size:13.5px;color:var(--t1);background:var(--white);transition:border-color .15s,box-shadow .15s;outline:none}.fc:focus{border-color:var(--accent);box-shadow:0 0 0 3px #0f766e1a}.fc::placeholder{color:var(--t3)}.fc-hint{font-size:11.5px;color:var(--t3);margin-top:5px;line-height:1.5}.badge{display:inline-flex;align-items:center;gap:4px;font-size:10.5px;font-weight:700;padding:3px 9px;border-radius:99px;letter-spacing:.04em;font-family:JetBrains Mono,monospace;white-space:nowrap}.badge-green{background:#dcfce7;color:#15803d}.badge-amber{background:#fef3c7;color:#92400e}.badge-red{background:#fee2e2;color:#991b1b}.badge-blue{background:#dbeafe;color:#1e40af}.badge-gray{background:#f1f5f9;color:#475569}.badge-purple{background:#ede9fe;color:#5b21b6}.badge-teal{background:var(--accent-light);color:var(--accent-3)}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0a1f1db3;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);display:grid;place-items:center;z-index:1000;padding:20px;animation:fadeIn .2s ease}.modal{background:var(--white);border-radius:var(--r-2xl);padding:32px;width:100%;max-width:520px;box-shadow:var(--sh-xl);animation:slideDown .25s ease;max-height:92vh;overflow-y:auto}.modal-title{font-family:Inter,sans-serif;font-weight:800;font-size:18px;color:var(--t1);margin-bottom:20px;letter-spacing:-.02em}.modal-footer{display:flex;justify-content:flex-end;gap:10px;margin-top:24px;padding-top:20px;border-top:1px solid var(--border)}.empty{padding:64px 40px;text-align:center;color:var(--t2);font-size:14px}.empty-icon{font-size:44px;margin-bottom:12px}.empty-rich{min-height:240px;display:grid;place-items:center;gap:10px;border:1px solid rgba(190,162,243,.24);border-radius:28px;background:radial-gradient(circle at top right,rgba(233,197,109,.16),transparent 30%),linear-gradient(180deg,#fffffffa,#f7f2ffeb);box-shadow:0 18px 38px #3e276914}.empty-rich-icon{width:64px;height:64px;border-radius:20px;display:inline-flex;align-items:center;justify-content:center;background:#ffffffdb;color:var(--accent-3);box-shadow:0 14px 28px #0f766e1f}.empty-rich-title{font-family:Inter,sans-serif;font-size:20px;font-weight:800;color:var(--t1);letter-spacing:-.02em}.empty-rich-copy{max-width:44ch;font-size:13px;line-height:1.65;color:var(--t2)}.toasts{position:fixed;bottom:24px;right:24px;display:flex;flex-direction:column;gap:8px;z-index:9999}.toast{display:flex;align-items:flex-start;gap:10px;background:#fff;border-radius:var(--r-lg);padding:13px 16px;box-shadow:var(--sh-lg);border-left:3px solid var(--border-2);cursor:pointer;animation:fadeUp .3s ease;max-width:320px;font-size:13px;font-family:Inter,sans-serif}.toast-success{border-color:var(--success)}.toast-error{border-color:var(--danger)}.toast-info{border-color:var(--info)}.error-msg{background:#fee2e2;color:#991b1b;border-radius:var(--r-md);padding:10px 14px;font-size:13px;margin-bottom:16px;border:1px solid #fca5a5}.success-msg{background:#dcfce7;color:#15803d;border-radius:var(--r-md);padding:12px 16px;font-size:13px;margin-bottom:16px;border:1px solid #bbf7d0}.spinner{display:inline-block;width:14px;height:14px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .7s linear infinite}.spinner-dark{border-color:#0f766e33;border-top-color:var(--accent)}.flex{display:flex}.flex.gap-2{gap:8px}.flex.gap-3{gap:12px}.items-center{align-items:center}.justify-between{justify-content:space-between}.mt-3{margin-top:12px}.mb-3{margin-bottom:12px}.course-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(290px,1fr));gap:18px}.course-card{background:var(--white);border:1px solid var(--border);border-radius:var(--r-xl);overflow:hidden;cursor:pointer;transition:all .25s;display:flex;flex-direction:column;box-shadow:var(--sh-sm)}.course-card:hover{transform:translateY(-4px);box-shadow:var(--sh-lg);border-color:var(--accent-light)}.course-card-thumb{height:148px;display:grid;place-items:center;font-size:30px;font-weight:800;letter-spacing:.08em;text-transform:uppercase;color:#fff;flex-shrink:0;overflow:hidden;line-height:1;text-align:center}.course-card-thumb img{width:100%;height:100%;object-fit:cover;display:block}.course-card-body{padding:16px;flex:1;display:flex;flex-direction:column}.course-card-cat{font-size:10px;color:var(--accent);font-weight:700;letter-spacing:.08em;text-transform:uppercase;font-family:JetBrains Mono,monospace;margin-bottom:6px}.course-card-title{font-family:Inter,sans-serif;font-weight:700;font-size:14px;color:var(--t1);line-height:1.35;margin-bottom:4px}.course-card-by{font-size:11.5px;color:var(--t2);margin-bottom:10px}.course-card-meta{font-size:11px;color:var(--t3);margin-bottom:14px}.course-card-footer{margin-top:auto;display:flex;justify-content:space-between;align-items:center}.student-list-table{table-layout:fixed;min-width:760px}.student-list-table th,.student-list-table td{white-space:normal;overflow-wrap:anywhere;vertical-align:middle}.student-list-table .btn{white-space:nowrap}.course-price{font-family:Inter,sans-serif;font-size:15px;font-weight:800;color:var(--success)}.progress-bar{height:5px;background:var(--bg-2);border-radius:99px;overflow:hidden}.progress-fill{height:100%;background:linear-gradient(90deg,var(--accent),var(--accent-2));border-radius:99px;transition:width .5s ease}.notif-dot{width:8px;height:8px;border-radius:50%;background:var(--danger);flex-shrink:0}.alert{padding:14px 16px;border-radius:var(--r-md);border:1px solid;display:flex;align-items:flex-start;gap:10px;font-size:13px}.alert-warning{background:#fef3c7;border-color:#fde68a;color:#92400e}.alert-info{background:#dbeafe;border-color:#93c5fd;color:#1e40af}.alert-danger{background:#fee2e2;border-color:#fca5a5;color:#991b1b}.alert-success{background:#dcfce7;border-color:#bbf7d0;color:#15803d}.course-workspace{display:grid;grid-template-areas:"sidebar main";grid-template-columns:360px minmax(0,1fr);gap:16px;align-items:stretch}.course-workspace-has-preview{grid-template-columns:360px minmax(0,1fr)}.course-workspace-sidebar{grid-area:sidebar;min-width:0;background:linear-gradient(180deg,#f8fffe,#eef8f7);border:1px solid #d7ece9;box-shadow:0 12px 32px #0f766e14}.course-workspace-main{grid-area:main;min-width:0}.course-player-topbar{display:flex;align-items:center;gap:10px;margin-bottom:10px;min-height:28px}.course-player-topbar .btn{padding:0;color:#8b72c8;font-size:12px;font-weight:700}.course-player-topbar .btn:hover{background:transparent}.course-player-topbar .btn:after{content:"/";margin-left:10px;color:var(--t3)}.course-player-topbar>span:nth-of-type(1){font-size:14px!important;color:var(--t1)!important;font-weight:800!important;letter-spacing:-.02em}.course-player-topbar>span:last-child{margin-left:auto;display:flex;align-items:center;gap:8px;padding:6px 10px;border-radius:999px;background:#ffffffeb;border:1px solid rgba(190,162,243,.24);color:var(--t2)!important;font-size:11.5px!important}.course-player-topbar>span:last-child>div{width:88px!important;height:5px!important}.course-player-topbar>span:last-child strong{color:#8b72c8!important}.course-player-workspace{grid-template-columns:280px minmax(0,1fr)}.course-player-workspace-shell{grid-template-areas:"main";grid-template-columns:minmax(0,1fr);gap:0}.course-player-workspace-shell .course-workspace-main{grid-area:main;width:100%;min-width:0}.course-player-workspace-collapsed{grid-template-columns:72px minmax(0,1fr)}.course-player-stage{height:100%;width:100%;max-width:100%;display:flex;flex-direction:column;background:linear-gradient(180deg,#fffffffa,#f9f5fff0);border:1px solid #e5daf8;border-radius:var(--r-xl);box-shadow:0 18px 36px #bea2f31f;overflow:hidden}.course-workspace-main{width:100%}.course-player-stage-head{padding:14px 18px 10px;border-bottom:1px solid rgba(215,193,247,.75);background:radial-gradient(circle at top right,rgba(233,197,109,.18),transparent 32%),linear-gradient(180deg,#bea2f314,#fffffff5)}.course-player-lesson-title{font-family:Inter,sans-serif;font-weight:800;font-size:20px;color:var(--t1);letter-spacing:-.03em}.course-player-lesson-sub{margin-top:4px;font-size:12px;color:var(--t2)}.course-player-stage-body{flex:1;min-height:0;padding:16px 18px 12px;overflow-y:auto}.course-player-stage-actions{padding:12px 18px 16px;border-top:1px solid rgba(215,193,247,.75);background:#fbf8fff5}.quiz-stage-shell{padding:4px 2px 0}.quiz-stage-shell .modal-title{margin-bottom:16px}.quiz-stage-shell .modal-footer{padding-bottom:4px}.quiz-inline-intro{border:1px solid rgba(215,193,247,.82);border-radius:var(--r-xl);padding:18px 18px 16px;background:radial-gradient(circle at top right,rgba(233,197,109,.18),transparent 34%),linear-gradient(180deg,#bea2f314,#fffffffa)}.quiz-inline-eyebrow{font-size:10px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--accent);font-family:JetBrains Mono,monospace}.quiz-inline-title{margin-top:10px;font-family:Inter,sans-serif;font-size:20px;font-weight:800;color:var(--t1);letter-spacing:-.03em}.quiz-inline-copy{margin-top:8px;font-size:13px;line-height:1.6;color:var(--t2)}.quiz-inline-meta{margin-top:14px;font-size:12px;font-weight:600;color:var(--accent-3)}.quiz-inline-actions{margin-top:16px;display:flex;align-items:center;gap:10px;flex-wrap:wrap}.quiz-inline-status{font-size:12px;font-weight:700;color:var(--success)}.quiz-result-hint{margin-top:16px;padding:12px 14px;border-radius:14px;border:1px solid rgba(190,162,243,.45);background:linear-gradient(180deg,#f8f3fffa,#fffffff0);color:#6b5a8d;font-size:13px;line-height:1.5;text-align:center}.course-player-stage .btn-primary{background:linear-gradient(135deg,#b79af7,#9f86ec);border-color:#9f86ec;color:#fff;box-shadow:0 10px 24px #b79af73d}.course-player-stage .btn-primary:hover{background:linear-gradient(135deg,#ad90f0,#9073e4);border-color:#9073e4;box-shadow:0 12px 28px #b79af74d}.course-player-stage .btn-secondary{background:#ffffffeb;color:#624f85;border-color:#dcccf7}.course-player-stage .btn-secondary:hover{background:#f6f0ff;border-color:#cdb7f5}.course-outline-hero{padding:18px 18px 14px;border-bottom:1px solid rgba(15,118,110,.08);background:radial-gradient(circle at top right,rgba(245,158,11,.18),transparent 35%),linear-gradient(135deg,#0f766e14,#ffffffeb)}.course-outline-hero-compact{padding-bottom:12px}.course-outline-eyebrow{font-size:10px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--accent);font-family:JetBrains Mono,monospace;margin-bottom:8px}.course-outline-title{font-family:Inter,sans-serif;font-size:20px;font-weight:800;color:var(--t1);letter-spacing:-.03em}.course-outline-sub{margin-top:6px;font-size:12.5px;line-height:1.55;color:var(--t2)}.course-outline-metrics{display:flex;flex-wrap:wrap;gap:8px;margin-top:14px}.course-outline-metric{display:inline-flex;align-items:center;min-height:28px;padding:0 10px;border-radius:999px;background:#ffffffb8;border:1px solid rgba(15,118,110,.1);color:var(--accent-3);font-size:11px;font-weight:700}.course-outline-tree{background:linear-gradient(180deg,rgba(255,255,255,.45),transparent)}.course-outline-panelhead{padding:14px 18px 16px;border-bottom:1px solid rgba(15,118,110,.08);background:radial-gradient(circle at top right,rgba(245,158,11,.14),transparent 34%),linear-gradient(180deg,#0f766e0d,#fffffff0)}.course-outline-panelhead-top{display:flex;align-items:flex-start;justify-content:space-between;gap:12px}.course-outline-paneltitle{font-family:Inter,sans-serif;font-size:18px;font-weight:800;color:var(--t1);letter-spacing:-.03em}.course-outline-panelmeta{margin-top:6px;font-size:12px;color:var(--t2)}.course-outline-progressbar{margin-top:12px;height:6px;border-radius:999px;background:#0f766e14;overflow:hidden}.course-outline-progressfill{height:100%;border-radius:inherit;background:linear-gradient(90deg,var(--accent),var(--gold-2))}.course-workspace-sidebar-collapsed{display:flex;align-items:flex-start;justify-content:center}.course-outline-collapsed{width:100%;padding:12px 8px;display:flex;justify-content:center}.course-outline-collapsed .btn{width:100%;padding-left:0;padding-right:0}.course-preview-empty{color:var(--t2);background:radial-gradient(circle at top,rgba(15,118,110,.06),transparent 45%),linear-gradient(180deg,#fbfffe,#f4fbfa);border-radius:var(--r-xl)}@media (max-width: 980px){.analytics-hero,.revenue-hero{grid-template-columns:minmax(0,1fr)}.analytics-hero-title{max-width:none}}@media (max-width: 640px){.analytics-hero-copy,.analytics-hero-spotlight,.analytics-card,.revenue-hero,.revenue-mini-card{border-radius:20px}.analytics-hero-title{font-size:23px}.analytics-spotlight-value{font-size:42px}.analytics-grid{grid-template-columns:minmax(0,1fr)}}@media (max-width: 980px){.course-workspace,.course-workspace-has-preview{grid-template-areas:"sidebar" "main";grid-template-columns:minmax(0,1fr);height:auto!important;min-height:0!important}.course-player-topbar{flex-wrap:wrap}.course-player-topbar>span:last-child{margin-left:0}}@media (max-width: 1280px){.hero{padding:48px 32px 56px}.hero-inner{grid-template-columns:minmax(0,1fr) 400px;gap:36px}.hero-title{font-size:clamp(38px,5vw,52px)}.hero-highlights{grid-template-columns:repeat(2,minmax(0,1fr))}.sastra-overview,.features,.roles-inner{padding-left:32px;padding-right:32px}.sastra-overview-grid{grid-template-columns:minmax(0,1fr)}.features-grid,.roles-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.sidebar{width:288px}.content{padding:24px}.course-workspace,.course-workspace-has-preview{grid-template-columns:320px minmax(0,1fr)}}@media (max-width: 980px){.landing-nav{padding:14px 18px;gap:10px;flex-wrap:wrap;justify-content:center}.landing-nav-links{display:none}.landing-nav-actions{width:100%;justify-content:center}.hero{padding:34px 20px 44px}.hero-inner{grid-template-columns:minmax(0,1fr);gap:28px}.hero-title{font-size:clamp(32px,9vw,44px)}.hero-desc,.section-desc{max-width:none}.hero-stats{flex-wrap:wrap;gap:18px}.hero-highlights,.hero-stats-grid{grid-template-columns:minmax(0,1fr);max-width:none}.hero-framework-side{grid-template-columns:minmax(0,1fr)}.sastra-overview,.features,.roles-inner{padding:56px 20px}.section-title{font-size:clamp(28px,7vw,36px)}.features-grid,.roles-grid,.course-grid{grid-template-columns:minmax(0,1fr)}.landing-cta-band{flex-direction:column;align-items:flex-start}.sastra-overview-points{grid-template-columns:minmax(0,1fr)}.shell{display:flex;flex-direction:column;height:auto;min-height:100dvh;overflow:visible;position:relative}.sidebar{position:fixed;left:0;top:0;bottom:0;width:min(90vw,360px);max-width:360px;z-index:1200;transform:translate(-100%);transition:transform .22s ease;overflow-y:auto;box-shadow:0 20px 60px #8567bf2e}.sidebar.sidebar-mobile-open{transform:translate(0)}.shell-backdrop{display:block;position:fixed;top:0;right:0;bottom:0;left:0;background:#6c539933;z-index:1100}.main{min-height:0;width:100%}.topbar{height:auto;min-height:60px;padding:14px 16px;flex-wrap:wrap;align-items:flex-start}.topbar-menu-btn{display:inline-flex}.content{padding:18px 16px 22px}.page{max-width:100%}.modal-overlay{padding:12px;align-items:end}.modal{padding:18px;max-width:100%;border-radius:20px;max-height:min(92dvh,100%)}.modal-footer{flex-wrap:wrap}table{display:block;overflow-x:auto;white-space:nowrap;-webkit-overflow-scrolling:touch}.course-player-topbar{align-items:flex-start}.course-player-stage-head,.course-player-stage-body,.course-player-stage-actions,.course-outline-hero,.course-outline-panelhead{padding-left:14px;padding-right:14px}.course-player-lesson-title,.course-outline-title,.course-outline-paneltitle,.quiz-inline-title{font-size:18px}}@media (max-width: 640px){.landing-logo{width:100%;justify-content:center}.landing-nav-actions{width:100%}.landing-nav-btn{flex:1 1 100%;justify-content:center}.hero-framework-card,.hero-side-card,.landing-cta-band{padding:18px}.hero-highlight,.hero-stat-card{padding:13px 14px}.sastra-overview{padding-top:34px}.sastra-visual-shell{padding:18px;border-radius:22px}.sastra-visual-title{font-size:18px}.sastra-visual-metrics{grid-template-columns:minmax(0,1fr)}.feature-desc,.role-card-desc,.section-desc,.hero-desc{font-size:14px}.hero-framework-title,.landing-cta-title{font-size:20px}.access-picker-option{align-items:flex-start}.access-picker-arrow{display:none}.topbar{padding:12px}.t-right{width:100%;display:flex;gap:8px;flex-wrap:wrap}.t-right .btn{flex:1 1 140px}.s-logo,.s-user{padding-left:12px;padding-right:12px}.s-link{margin-left:6px;margin-right:6px}.content{padding:14px 12px 18px}.empty{padding:40px 20px}.course-player-stage-head,.course-player-stage-body,.course-player-stage-actions,.course-outline-hero,.course-outline-panelhead{padding-left:12px;padding-right:12px}.course-player-topbar>span:last-child{width:100%;justify-content:space-between}.course-player-topbar>span:last-child>div{width:72px!important}.course-player-stage-body{padding-top:12px;padding-bottom:10px}.toasts{left:12px;right:12px;bottom:12px}.toast{width:100%}}
