:root{font-family:Arial,Helvetica,sans-serif;line-height:1.5;font-weight:400;color:#0f172a;background:#f8fafc;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}*{box-sizing:border-box}html{scroll-behavior:smooth}body{margin:0;min-width:320px;background:#f8fafc;color:#0f172a}a{color:inherit;text-decoration:none}button,input,select,textarea{font:inherit}img{max-width:100%;display:block}.page-container{max-width:1200px;margin:0 auto;padding-left:24px;padding-right:24px}.section-space{padding-top:44px;padding-bottom:44px}.section-space-lg{padding-top:80px;padding-bottom:44px}.hide-desktop{display:none}.loading-screen{min-height:100vh;display:grid;place-items:center;background:#020617}.loading-card{background:#ffffff0f;color:#fff;padding:18px 26px;border-radius:18px;border:1px solid rgba(255,255,255,.08);font-weight:700}.login-page-shell{min-height:100vh;display:grid;place-items:center;background:radial-gradient(circle at top left,rgba(37,99,235,.15),transparent 25%),linear-gradient(180deg,#020617,#0f172a);padding:20px}.login-card{width:100%;max-width:430px;background:#ffffff0f;border:1px solid rgba(255,255,255,.08);-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);border-radius:24px;padding:28px;color:#fff;box-shadow:0 20px 40px #00000040}.login-header h1{margin:0;font-size:34px;font-weight:800;line-height:1.1}.login-header p{margin-top:10px;color:#cbd5e1;line-height:1.7}.login-form-grid{display:grid;gap:14px;margin-top:24px}.login-input{width:100%;padding:14px 16px;border-radius:14px;border:1px solid rgba(255,255,255,.12);outline:none;font-size:15px;background:#ffffff0f;color:#fff}.login-error{color:#fecaca;background:#ef444424;border:1px solid rgba(239,68,68,.2);padding:12px 14px;border-radius:14px;font-size:14px}.login-submit-btn{border:none;border-radius:16px;background:linear-gradient(90deg,#2563eb,#38bdf8);color:#fff;font-weight:800;cursor:pointer;padding:14px 18px;font-size:15px}.login-back-link{text-align:center;color:#93c5fd;margin-top:6px;font-weight:600}.portal-shell{display:flex;min-height:100vh;background:#020617}.portal-desktop-sidebar{display:block}.portal-main{flex:1;min-width:0;background:#f8fafc}.portal-content{padding:24px}.student-portal-content{background:#f8fafc;min-height:calc(100vh - 78px)}.portal-sidebar-overlay{position:fixed;inset:0;background:#0206178c;z-index:90}.portal-sidebar{width:290px;min-height:100vh;background:radial-gradient(circle at top left,rgba(37,99,235,.22),transparent 24%),linear-gradient(180deg,#020617,#0b1120);color:#fff;padding:24px 18px;border-right:1px solid rgba(255,255,255,.07);overflow-y:auto;flex-shrink:0}.portal-sidebar.desktop{position:sticky;top:0}.portal-sidebar.mobile{position:fixed;top:0;left:-320px;height:100vh;z-index:100;transition:left .25s ease}.portal-sidebar.mobile.open{left:0}.portal-sidebar-header{display:flex;justify-content:space-between;align-items:flex-start;gap:12px;margin-bottom:22px}.portal-sidebar-title{font-size:18px;font-weight:800;color:#60a5fa}.portal-sidebar-subtitle{margin-top:6px;font-size:13px;color:#cbd5e1;line-height:1.5}.portal-sidebar-close{border:none;background:transparent;color:#fff;font-size:22px;cursor:pointer}.sidebar-scroll{display:grid;gap:10px;padding-bottom:20px}.portal-menu-item{border:1px solid rgba(255,255,255,.08);background:#0f172aa6;color:#fff;text-align:left;padding:16px;border-radius:16px;cursor:pointer;font-size:15px;font-weight:600;transition:all .2s ease}.portal-menu-item:hover{background:#1e293bf2;transform:translateY(-1px)}.portal-menu-item.active{background:linear-gradient(90deg,#2563eb,#38bdf8);border-color:transparent;color:#fff;box-shadow:0 10px 24px #2563eb38}.portal-topbar{position:sticky;top:0;z-index:40;min-height:78px;background:#fffffff0;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-bottom:1px solid #e2e8f0;display:flex;justify-content:space-between;align-items:center;gap:14px;padding:14px 24px}.portal-topbar-left{display:flex;align-items:center;gap:14px;min-width:0}.portal-topbar-text{min-width:0}.portal-topbar-title{margin:0;font-size:30px;font-weight:800;color:#0f172a;line-height:1.15}.portal-topbar-subtitle{margin:6px 0 0;color:#64748b;font-size:14px;line-height:1.5}.portal-topbar-right{display:flex;align-items:center;gap:12px}.portal-topbar-actions{display:flex;gap:10px;align-items:center}.portal-menu-btn,.portal-action-btn{border:none;border-radius:14px;min-height:44px;padding:0 16px;cursor:pointer;font-weight:700}.portal-menu-btn{width:44px;padding:0;background:#eff6ff;color:#1d4ed8;font-size:22px}.portal-home-btn{background:#eff6ff;color:#1d4ed8}.portal-logout-btn{background:#ef4444;color:#fff}.student-dashboard-shell,.student-module-shell{display:grid;gap:24px}.student-hero-card{background:radial-gradient(circle at right top,rgba(56,189,248,.2),transparent 25%),linear-gradient(135deg,#10204f,#1d4ed8);color:#fff;border-radius:28px;padding:34px;box-shadow:0 18px 36px #0f172a1f}.admin-hero-card{background:radial-gradient(circle at right top,rgba(59,130,246,.16),transparent 24%),linear-gradient(135deg,#0f172a,#1e3a8a)}.student-hero-label{color:#dbeafe;font-size:12px;font-weight:800;letter-spacing:5px;margin-bottom:18px}.student-hero-title{margin:0;font-size:58px;line-height:1.04;font-weight:900;letter-spacing:-.04em}.student-hero-text{margin-top:18px;font-size:19px;line-height:1.9;color:#e0e7ff;max-width:900px}.student-quick-actions{margin-top:24px;display:flex;gap:12px;flex-wrap:wrap}.student-primary-btn{border:none;border-radius:16px;background:linear-gradient(90deg,#2563eb,#38bdf8);color:#fff;font-weight:800;padding:14px 20px;cursor:pointer;box-shadow:0 12px 24px #2563eb33}.student-info-grid,.student-module-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:18px}.student-info-card,.student-module-card{background:#fff;border:1px solid #e2e8f0;border-radius:22px;padding:24px;box-shadow:0 10px 24px #0f172a0f}.student-info-card h3,.student-module-card h3{margin:0 0 14px;font-size:22px;color:#0f172a}.student-info-card p,.student-module-card p{margin:0;color:#64748b;line-height:1.8;font-size:16px}.student-module-header h2{margin:0;font-size:36px;color:#0f172a}.student-module-header p{margin:10px 0 0;color:#64748b;line-height:1.7}.student-list-grid{display:grid;gap:16px}.student-list-card{background:#fff;border:1px solid #e2e8f0;border-radius:20px;padding:18px;display:flex;gap:14px;box-shadow:0 10px 24px #0f172a0d}.student-list-badge{width:42px;height:42px;border-radius:999px;background:#dbeafe;color:#1d4ed8;display:grid;place-items:center;font-weight:800;flex-shrink:0}.student-list-content h3{margin:0 0 8px;color:#0f172a;font-size:20px}.student-list-content p{margin:0;color:#64748b;line-height:1.7}.student-table-wrap{overflow-x:auto;background:#fff;border:1px solid #e2e8f0;border-radius:22px;box-shadow:0 10px 24px #0f172a0f}.student-table{width:100%;border-collapse:collapse;min-width:520px}.student-table th,.student-table td{padding:16px 18px;text-align:left;border-bottom:1px solid #e2e8f0}.student-table th{background:#eff6ff;color:#1e3a8a;font-weight:700}.student-quiz-card,.student-upload-card{background:#fff;border:1px solid #e2e8f0;border-radius:24px;padding:24px;box-shadow:0 10px 24px #0f172a0f;display:grid;gap:18px}.student-quiz-card h3{margin:0;font-size:24px;color:#0f172a}.student-quiz-options{display:grid;gap:12px}.student-quiz-option{border:1px solid #cbd5e1;background:#f8fafc;color:#0f172a;border-radius:16px;padding:14px 16px;text-align:left;cursor:pointer;font-weight:600}.student-quiz-option.active{background:#dbeafe;border-color:#60a5fa;color:#1d4ed8}.student-file-input{width:100%;padding:14px;border:1px solid #cbd5e1;border-radius:14px;background:#f8fafc}.student-status-badge{display:inline-flex;margin-top:14px;padding:8px 12px;border-radius:999px;font-size:13px;font-weight:700}.student-status-badge.pending{background:#fef3c7;color:#92400e}.student-status-badge.submitted{background:#dcfce7;color:#166534}.enrollment-shell{background:#ffffff0a;border:1px solid rgba(255,255,255,.08);border-radius:28px;padding:28px;box-shadow:0 18px 40px #0f172a1f;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px)}.enrollment-grid{display:grid;grid-template-columns:1fr 1fr;gap:28px;align-items:start}.enrollment-left{min-width:0}.enrollment-label{margin:0;color:#93c5fd;font-weight:800;letter-spacing:4px;font-size:12px}.enrollment-title{margin-top:12px;margin-bottom:12px;color:#fff;font-size:44px;line-height:1.12;font-weight:800}.enrollment-text{color:#cbd5e1;line-height:1.85;font-size:17px;margin-bottom:22px}.enrollment-points{display:grid;gap:12px}.enrollment-point-card{display:flex;align-items:flex-start;gap:12px;padding:14px 16px;background:#ffffff0d;border:1px solid rgba(147,197,253,.18);border-radius:16px}.enrollment-check{width:28px;height:28px;border-radius:999px;display:grid;place-items:center;background:#3b82f62e;color:#93c5fd;font-weight:700;flex-shrink:0}.enrollment-point-text{color:#e2e8f0;font-weight:600;line-height:1.5}.enrollment-form{display:grid;gap:14px}.enrollment-input{width:100%;padding:14px 16px;border-radius:14px;border:1px solid rgba(255,255,255,.12);outline:none;font-size:15px;background:#ffffff14;color:#fff}.enrollment-input::-moz-placeholder{color:#cbd5e1}.enrollment-input::placeholder{color:#cbd5e1}.enrollment-input option{color:#0f172a}.enrollment-textarea{resize:vertical;min-height:120px}.enrollment-submit-btn{border:none;border-radius:16px;background:linear-gradient(90deg,#2563eb,#38bdf8);color:#fff;font-weight:700;cursor:pointer;padding:14px 18px;font-size:15px;box-shadow:0 14px 28px #2563eb3d}@media(max-width:1200px){.student-info-grid,.student-module-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.student-hero-title{font-size:46px}}@media(max-width:1024px){.enrollment-grid{grid-template-columns:1fr}.enrollment-title{font-size:36px}}@media(max-width:900px){.portal-desktop-sidebar{display:none}.hide-desktop{display:inline-flex}.portal-topbar{padding:14px 16px;flex-wrap:wrap}.portal-content{padding:16px}.portal-topbar-title{font-size:24px}.portal-topbar-actions{width:100%;justify-content:stretch}.portal-action-btn{flex:1}.student-hero-card{padding:24px;border-radius:22px}.student-hero-title{font-size:34px}.student-hero-text{font-size:16px}.student-info-grid,.student-module-grid{grid-template-columns:1fr}}@media(max-width:768px){.page-container{padding-left:16px;padding-right:16px}.section-space,.section-space-lg{padding-top:24px;padding-bottom:24px}}@media(max-width:640px){.portal-topbar-left,.portal-topbar-right{width:100%}.portal-topbar-actions{flex-direction:column;width:100%}.portal-action-btn{width:100%}.student-quick-actions{flex-direction:column}.student-primary-btn{width:100%}.student-module-header h2,.student-hero-title{font-size:28px}.student-info-card,.student-module-card,.student-quiz-card,.student-upload-card,.student-list-card,.enrollment-shell{padding:18px;border-radius:18px}.enrollment-title{font-size:28px}}.landing-root{min-height:100vh;background:radial-gradient(circle at top left,rgba(37,99,235,.16),transparent 26%),radial-gradient(circle at 85% 8%,rgba(59,130,246,.14),transparent 18%),radial-gradient(circle at 90% 80%,rgba(34,197,94,.1),transparent 16%),linear-gradient(180deg,#020617,#081226 40%,#0b1730);color:#fff}.landing-navbar{position:sticky;top:0;z-index:60;background:#020617c7;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);border-bottom:1px solid rgba(255,255,255,.07);box-shadow:0 10px 30px #02061759}.landing-navbar-inner{max-width:1200px;margin:0 auto;padding:18px 24px;display:flex;justify-content:space-between;align-items:center;gap:18px;flex-wrap:wrap}.brand-title{font-weight:800;font-size:20px;letter-spacing:-.02em}.brand-subtitle{color:#94a3b8;font-size:13px;margin-top:3px}.hero-grid{display:grid;grid-template-columns:1.08fr .92fr;gap:34px;align-items:start}.hero-left,.hero-right{min-width:0}.hero-label{color:#93c5fd;letter-spacing:5px;font-weight:800;font-size:13px;margin-bottom:16px}.hero-title{font-size:74px;line-height:.98;margin:0;font-weight:900;letter-spacing:-.04em;word-break:break-word;text-shadow:0 12px 36px rgba(0,0,0,.26)}.hero-gradient-text{display:block;margin-top:12px;background:linear-gradient(90deg,#60a5fa,#38bdf8 45%,#a78bfa 90%);-webkit-background-clip:text;-webkit-text-fill-color:transparent}.hero-text{margin-top:24px;max-width:760px;color:#cbd5e1;font-size:20px;line-height:1.8}.hero-btn-row{display:flex;gap:16px;margin-top:28px;flex-wrap:wrap;align-items:center}.hero-stats-row{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:14px;margin-top:24px}.hero-stat-card{padding:18px 16px;border-radius:18px;background:#ffffff09;border:1px solid rgba(255,255,255,.07);box-shadow:inset 0 1px #ffffff08}.hero-stat-value{color:#fff;font-size:20px;font-weight:800;margin-bottom:6px}.hero-stat-label{color:#93c5fd;text-transform:uppercase;letter-spacing:3px;font-size:11px;font-weight:700}.info-grid-2{display:grid;grid-template-columns:1fr 1fr;gap:18px;margin-top:28px}.trust-grid{display:grid;grid-template-columns:1fr 1fr 1fr;gap:22px}.course-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:20px}.why-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-top:24px}.hero-benefits-top{margin-top:22px}.center-text{text-align:center}.big-cta-title{font-size:66px;margin:14px 0 12px;line-height:1.02;letter-spacing:-.04em;font-weight:900}.medium-title{font-size:44px;margin-top:12px;line-height:1.14;letter-spacing:-.03em;font-weight:850}.title-32{font-size:34px;line-height:1.16;letter-spacing:-.03em}.title-30{font-size:30px;line-height:1.16;letter-spacing:-.02em}.title-28{font-size:28px;line-height:1.18;letter-spacing:-.02em}.section-title{margin-top:12px;margin-bottom:18px;font-size:62px;line-height:1.08;font-weight:900;letter-spacing:-.04em}.light-text{color:#cbd5e1;line-height:1.85;word-break:break-word;font-size:18px}.soft-text{color:#e2e8f0;line-height:1.75;word-break:break-word;font-size:17px}.blue-section-label{color:#93c5fd;letter-spacing:5px;font-weight:800;font-size:12px}.purple-section-label{color:#c4b5fd;letter-spacing:5px;font-weight:800;font-size:12px}.glass-card{position:relative;overflow:hidden;background:linear-gradient(180deg,#ffffff0f,#ffffff09),#0f172a8c;border:1px solid rgba(255,255,255,.08);border-radius:28px;padding:30px;box-shadow:0 22px 50px #0000003d,inset 0 1px #ffffff09;-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px)}.glass-card:before{content:"";position:absolute;inset:0;background:linear-gradient(180deg,#ffffff0b,#fff0);pointer-events:none}.feature-highlight-card{min-height:280px;display:flex;flex-direction:column;justify-content:space-between}.hero-benefit-shell{min-height:100%}.trust-card{min-height:300px;display:flex;flex-direction:column;justify-content:flex-start}.trust-card-topline{width:54px;height:4px;border-radius:999px;background:linear-gradient(90deg,#2563eb,#38bdf8);margin-bottom:20px;box-shadow:0 0 22px #38bdf859}.course-card{min-height:360px;display:flex;flex-direction:column;justify-content:space-between}.course-card-glow{position:absolute;top:-40px;right:-30px;width:110px;height:110px;background:radial-gradient(circle,rgba(56,189,248,.22),transparent 70%);pointer-events:none}.better-systems-card{padding-top:34px;padding-bottom:34px}.list-card{display:flex;align-items:flex-start;gap:14px;padding:18px;border-radius:20px;border:1px solid rgba(255,255,255,.08);background:#ffffff09;transition:transform .22s ease,border-color .22s ease,background .22s ease}.elevated-list-card:hover{transform:translateY(-3px);border-color:#60a5fa38;background:#ffffff0d}.badge-circle{width:38px;height:38px;border-radius:999px;display:grid;place-items:center;font-weight:800;flex-shrink:0}.badge-blue{background:#3b82f62e;color:#93c5fd;box-shadow:inset 0 1px #ffffff0a}.btn-row{display:flex;gap:14px;flex-wrap:wrap;align-items:center}.nav-btn-row a,.hero-btn-row a,.cta-btn-row a{display:inline-flex}.btn-primary,.btn-secondary,.btn-outline,.btn-success{min-height:52px;padding:14px 22px;border-radius:18px;font-weight:800;cursor:pointer;display:flex;align-items:center;justify-content:center;white-space:nowrap;transition:transform .25s ease,box-shadow .25s ease,background .25s ease;font-size:16px}.btn-primary{border:none;color:#fff;background:linear-gradient(90deg,#2563eb,#38bdf8);box-shadow:0 16px 28px #2563eb42,0 0 40px #38bdf81a}.btn-secondary{border:1px solid rgba(255,255,255,.14);background:#ffffff0b;color:#fff}.btn-outline{border:1px solid rgba(255,255,255,.12);background:transparent;color:#fff}.btn-success{border:none;color:#fff;background:linear-gradient(90deg,#22c55e,#4ade80);box-shadow:0 16px 28px #22c55e33,0 0 40px #22c55e14}.premium-cta-shell{background:linear-gradient(90deg,#2563eb33,#6366f11f,#22c55e1a),#0f172a8c;border:1px solid rgba(96,165,250,.18)}.cta-description{max-width:820px;margin-left:auto;margin-right:auto}@media(max-width:1200px){.section-title{font-size:54px}.hero-title{font-size:66px}.big-cta-title{font-size:58px}}@media(max-width:1024px){.hero-grid,.trust-grid,.course-grid,.why-grid,.info-grid-2,.hero-stats-row{grid-template-columns:1fr}.hero-title{font-size:54px}.section-title{font-size:44px}.big-cta-title{font-size:46px}.trust-card,.course-card,.feature-highlight-card{min-height:auto}}@media(max-width:768px){.landing-navbar-inner{padding:14px 16px;flex-direction:column;align-items:stretch}.brand-title{font-size:18px}.hero-grid,.trust-grid,.course-grid,.why-grid,.info-grid-2,.hero-stats-row{grid-template-columns:1fr}.hero-grid{gap:22px}.hero-title{font-size:42px;line-height:1.04}.hero-text{font-size:16px;line-height:1.75}.section-title{font-size:32px;line-height:1.15}.medium-title{font-size:28px}.big-cta-title{font-size:36px;line-height:1.08}.title-32,.title-30,.title-28{font-size:22px;line-height:1.2}.glass-card{padding:20px;border-radius:22px}.list-card{padding:15px}.nav-btn-row,.hero-btn-row,.cta-btn-row{width:100%;flex-direction:column;align-items:stretch}.nav-btn-row a,.hero-btn-row a,.cta-btn-row a,.nav-btn-row button,.hero-btn-row button,.cta-btn-row button{width:100%}}@media(max-width:480px){.landing-navbar-inner{padding:12px 14px}.hero-title{font-size:34px}.hero-text{font-size:15px}.section-title{font-size:26px}.medium-title{font-size:24px}.big-cta-title{font-size:30px}.title-32,.title-30,.title-28{font-size:20px}.blue-section-label,.purple-section-label,.hero-label{font-size:11px;letter-spacing:3px}.glass-card{padding:16px}.btn-primary,.btn-secondary,.btn-outline,.btn-success{min-height:48px;font-size:15px}}
