*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--primary:#3b82f6;--primary-dark:#2563eb;--primary-light:#eff6ff;--primary-ring:#3b82f640;--sidebar-bg:#0f172a;--sidebar-hover:#ffffff12;--sidebar-active:#3b82f62e;--sidebar-text:#94a3b8;--sidebar-active-text:#fff;--sidebar-border:#ffffff0f;--bg:#f1f5f9;--surface:#fff;--border:#e2e8f0;--border-light:#f1f5f9;--text:#0f172a;--text-muted:#64748b;--text-light:#94a3b8;--success:#22c55e;--success-bg:#f0fdf4;--warning:#f59e0b;--warning-bg:#fffbeb;--danger:#ef4444;--danger-bg:#fef2f2;--info-bg:#eff6ff;--role-principal:#7c3aed;--role-principal-bg:#f5f3ff;--role-teacher:#0891b2;--role-teacher-bg:#ecfeff;--role-student:#2563eb;--role-student-bg:#eff6ff;--role-parent:#b45309;--role-parent-bg:#fffbeb;--radius-sm:6px;--radius:10px;--radius-lg:14px;--radius-xl:20px;--shadow-sm:0 1px 2px #0000000d;--shadow:0 1px 3px #00000014, 0 1px 2px #0000000d;--shadow-md:0 4px 6px #00000012, 0 2px 4px #0000000a;--shadow-lg:0 10px 15px #00000012, 0 4px 6px #0000000a;--sidebar-w:256px;--header-h:64px;--transition:.18s ease;color:var(--text);-webkit-font-smoothing:antialiased;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Inter,Helvetica,Arial,sans-serif;font-size:14px}body{background:var(--bg);min-height:100vh}.app-layout{min-height:100vh;display:flex}.sidebar{width:var(--sidebar-w);background:var(--sidebar-bg);z-index:100;flex-direction:column;display:flex;position:fixed;top:0;bottom:0;left:0;overflow:hidden}.sidebar-logo{border-bottom:1px solid var(--sidebar-border);align-items:center;gap:10px;padding:20px 20px 16px;display:flex}.sidebar-logo-icon{background:linear-gradient(135deg, var(--primary), var(--primary-dark));border-radius:var(--radius-sm);flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;font-size:18px;display:flex}.sidebar-logo-text{color:#fff;font-size:16px;font-weight:700;line-height:1.2}.sidebar-logo-sub{color:var(--sidebar-text);margin-top:1px;font-size:11px}.sidebar-user{border-bottom:1px solid var(--sidebar-border);align-items:center;gap:10px;padding:14px 20px;display:flex}.sidebar-avatar{background:linear-gradient(135deg, var(--primary) 0%, #6366f1 100%);color:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:34px;height:34px;font-size:13px;font-weight:700;display:flex}.sidebar-user-info{flex:1;min-width:0}.sidebar-user-name{color:#fff;white-space:nowrap;text-overflow:ellipsis;font-size:13px;font-weight:600;overflow:hidden}.role-badge{text-transform:uppercase;letter-spacing:.04em;border-radius:20px;margin-top:2px;padding:2px 7px;font-size:10px;font-weight:600;display:inline-block}.role-badge.principal{background:var(--role-principal-bg);color:var(--role-principal)}.role-badge.teacher{background:var(--role-teacher-bg);color:var(--role-teacher)}.role-badge.student{background:var(--role-student-bg);color:var(--role-student)}.role-badge.parent{background:var(--role-parent-bg);color:var(--role-parent)}.sidebar-nav{flex:1;padding:12px 10px;overflow-y:auto}.nav-section-label{letter-spacing:.08em;color:var(--sidebar-text);text-transform:uppercase;padding:8px 10px 4px;font-size:10px;font-weight:700}.nav-link{border-radius:var(--radius-sm);color:var(--sidebar-text);transition:all var(--transition);cursor:pointer;text-align:left;background:0 0;border:none;align-items:center;gap:10px;width:100%;margin-bottom:2px;padding:9px 12px;font-size:13.5px;font-weight:500;text-decoration:none;display:flex}.nav-link:hover{background:var(--sidebar-hover);color:#fff}.nav-link.active{background:var(--sidebar-active);color:#fff}.nav-link.active .nav-icon{color:var(--primary)}.nav-icon{flex-shrink:0;justify-content:center;align-items:center;width:20px;font-size:16px;display:flex}.sidebar-footer{border-top:1px solid var(--sidebar-border);padding:12px 10px}.main-area{margin-left:var(--sidebar-w);flex-direction:column;flex:1;min-height:100vh;display:flex}.top-header{height:var(--header-h);background:var(--surface);border-bottom:1px solid var(--border);z-index:50;align-items:center;gap:12px;padding:0 28px;display:flex;position:sticky;top:0}.top-header-title{flex:1;font-size:18px;font-weight:700}.top-header-sub{color:var(--text-muted);font-size:13px}.page-content{flex:1;padding:28px}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm)}.card-header{border-bottom:1px solid var(--border-light);justify-content:space-between;align-items:center;padding:18px 22px 14px;display:flex}.card-title{font-size:15px;font-weight:700}.card-subtitle{color:var(--text-muted);margin-top:2px;font-size:12px}.card-body{padding:20px 22px}.stats-grid{grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:16px;margin-bottom:24px;display:grid}.stat-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);transition:box-shadow var(--transition), transform var(--transition);align-items:flex-start;gap:14px;padding:20px;display:flex}.stat-card:hover{box-shadow:var(--shadow-md);transform:translateY(-1px)}.stat-icon{border-radius:var(--radius);flex-shrink:0;justify-content:center;align-items:center;width:44px;height:44px;font-size:20px;display:flex}.stat-icon.blue{background:var(--primary-light)}.stat-icon.green{background:var(--success-bg)}.stat-icon.yellow{background:var(--warning-bg)}.stat-icon.purple{background:var(--role-principal-bg)}.stat-icon.teal{background:var(--role-teacher-bg)}.stat-value{font-size:26px;font-weight:800;line-height:1}.stat-label{color:var(--text-muted);margin-top:3px;font-size:12px;font-weight:500}.btn{border-radius:var(--radius-sm);cursor:pointer;transition:all var(--transition);white-space:nowrap;border:none;align-items:center;gap:6px;padding:8px 16px;font-size:13.5px;font-weight:600;line-height:1.4;text-decoration:none;display:inline-flex}.btn:disabled{opacity:.55;cursor:not-allowed}.btn-primary{background:var(--primary);color:#fff}.btn-primary:hover:not(:disabled){background:var(--primary-dark)}.btn-danger{background:var(--danger);color:#fff}.btn-danger:hover:not(:disabled){background:#dc2626}.btn-ghost{color:var(--text-muted);border:1px solid var(--border);background:0 0}.btn-ghost:hover:not(:disabled){background:var(--bg);color:var(--text)}.btn-sm{padding:5px 11px;font-size:12.5px}.btn-lg{border-radius:var(--radius);padding:11px 22px;font-size:15px}.form-group{margin-bottom:16px}.form-label{margin-bottom:6px;font-size:13px;font-weight:600;display:block}.form-hint{color:var(--text-muted);margin-top:4px;font-size:11.5px}.form-input,.form-select{border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--surface);width:100%;color:var(--text);transition:border-color var(--transition), box-shadow var(--transition);appearance:none;outline:none;padding:9px 12px;font-size:14px}.form-input:focus,.form-select:focus{border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-ring)}.form-input::placeholder{color:var(--text-light)}.form-select{background-image:url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 20 20'%3e%3cpath stroke='%2364748b' stroke-linecap='round' stroke-linejoin='round' stroke-width='1.5' d='M6 8l4 4 4-4'/%3e%3c/svg%3e");background-position:right 10px center;background-repeat:no-repeat;background-size:16px;padding-right:36px}.form-row{grid-template-columns:1fr 1fr;gap:14px;display:grid}.table-wrap{overflow-x:auto}table{border-collapse:collapse;width:100%}thead th{text-align:left;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);background:var(--bg);border-bottom:1px solid var(--border);padding:10px 16px;font-size:11.5px;font-weight:700}thead th:first-child{border-radius:var(--radius-sm) 0 0 0}thead th:last-child{border-radius:0 var(--radius-sm) 0 0}tbody td{border-bottom:1px solid var(--border-light);vertical-align:middle;padding:12px 16px;font-size:13.5px}tbody tr:last-child td{border-bottom:none}tbody tr{transition:background var(--transition)}tbody tr:hover{background:var(--bg)}.badge{border-radius:20px;align-items:center;gap:4px;padding:3px 9px;font-size:11.5px;font-weight:600;display:inline-flex}.badge-success{background:var(--success-bg);color:#15803d}.badge-warning{background:var(--warning-bg);color:#92400e}.badge-danger{background:var(--danger-bg);color:#991b1b}.badge-info{background:var(--info-bg);color:var(--primary-dark)}.score-bar-wrap{align-items:center;gap:10px;min-width:130px;display:flex}.score-bar-track{background:var(--border);border-radius:99px;flex:1;height:6px;overflow:hidden}.score-bar-fill{border-radius:99px;height:100%;transition:width .5s}.score-bar-fill.high{background:var(--success)}.score-bar-fill.medium{background:var(--warning)}.score-bar-fill.low{background:var(--danger)}.empty-state{text-align:center;padding:48px 20px}.empty-state-icon{margin-bottom:12px;font-size:48px}.empty-state-title{margin-bottom:6px;font-size:16px;font-weight:700}.empty-state-text{color:var(--text-muted);max-width:320px;margin:0 auto;font-size:13.5px}.search-wrap{position:relative}.search-wrap .search-icon{color:var(--text-light);pointer-events:none;font-size:15px;position:absolute;top:50%;left:10px;transform:translateY(-50%)}.search-wrap .form-input{padding-left:34px}.page-header{justify-content:space-between;align-items:flex-start;gap:16px;margin-bottom:24px;display:flex}.page-header h1{font-size:22px;font-weight:800}.page-header p{color:var(--text-muted);margin-top:3px;font-size:13.5px}.modal-overlay{z-index:200;background:#0f172a73;justify-content:center;align-items:center;animation:.15s fadeIn;display:flex;position:fixed;inset:0}.modal{background:var(--surface);border-radius:var(--radius-xl);width:100%;max-width:480px;box-shadow:var(--shadow-lg);margin:20px;animation:.18s slideUp}.modal-header{border-bottom:1px solid var(--border-light);justify-content:space-between;align-items:center;padding:20px 24px 16px;display:flex}.modal-title{font-size:16px;font-weight:700}.modal-body{padding:20px 24px}.modal-footer{border-top:1px solid var(--border-light);justify-content:flex-end;gap:10px;padding:14px 24px 20px;display:flex}.avatar{background:linear-gradient(135deg, var(--primary) 0%, #818cf8 100%);color:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:32px;height:32px;font-size:13px;font-weight:700;display:flex}.avatar-lg{width:56px;height:56px;font-size:20px}.achievement-grid{grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:16px;display:grid}.achievement-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);transition:box-shadow var(--transition), transform var(--transition);flex-direction:column;gap:8px;padding:20px;display:flex}.achievement-card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}.achievement-card-icon{font-size:32px}.achievement-card-title{font-size:15px;font-weight:700}.achievement-card-desc{color:var(--text-muted);font-size:13px;line-height:1.5}.achievement-card-footer{justify-content:space-between;align-items:center;margin-top:4px;display:flex}.login-page{grid-template-columns:1fr 1fr;min-height:100vh;display:grid}.login-left{background:linear-gradient(145deg,#1e40af 0%,#1d4ed8 40%,#2563eb 70%,#3b82f6 100%);flex-direction:column;justify-content:center;padding:60px 56px;display:flex;position:relative;overflow:hidden}.login-left:before{content:"";background:#ffffff0f;border-radius:50%;width:300px;height:300px;position:absolute;top:-80px;right:-80px}.login-left:after{content:"";background:#ffffff0a;border-radius:50%;width:240px;height:240px;position:absolute;bottom:-60px;left:-60px}.login-brand{z-index:1;align-items:center;gap:12px;margin-bottom:48px;display:flex;position:relative}.login-brand-icon{border-radius:var(--radius);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#fff3;justify-content:center;align-items:center;width:48px;height:48px;font-size:24px;display:flex}.login-brand-name{color:#fff;font-size:22px;font-weight:800}.login-headline{color:#fff;z-index:1;margin-bottom:16px;font-size:34px;font-weight:800;line-height:1.2;position:relative}.login-tagline{color:#ffffffb8;z-index:1;max-width:360px;font-size:15px;line-height:1.65;position:relative}.login-features{z-index:1;flex-direction:column;gap:14px;margin-top:40px;display:flex;position:relative}.login-feature{color:#ffffffd9;align-items:center;gap:10px;font-size:14px;display:flex}.login-feature-dot{background:#fff9;border-radius:50%;flex-shrink:0;width:8px;height:8px}.login-right{background:var(--surface);justify-content:center;align-items:center;padding:60px 56px;display:flex}.login-form-box{width:100%;max-width:380px}.login-form-title{margin-bottom:6px;font-size:26px;font-weight:800}.login-form-sub{color:var(--text-muted);margin-bottom:32px;font-size:14px}.login-role-hints{border-top:1px solid var(--border);margin-top:28px;padding-top:22px}.login-role-hints-title{color:var(--text-muted);text-transform:uppercase;letter-spacing:.04em;margin-bottom:10px;font-size:12px;font-weight:600}.login-role-list{flex-wrap:wrap;gap:6px;display:flex}.login-error{background:var(--danger-bg);color:#991b1b;border-radius:var(--radius-sm);border:1px solid #fecaca;margin-bottom:16px;padding:10px 14px;font-size:13px}.marks-grid{grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:14px;display:grid}.mark-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);padding:18px}.mark-card-subject{text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);margin-bottom:6px;font-size:11.5px;font-weight:700}.mark-card-score{font-size:32px;font-weight:900;line-height:1}.mark-card-score.high{color:#15803d}.mark-card-score.medium{color:#92400e}.mark-card-score.low{color:#991b1b}.mark-card-term{color:var(--text-muted);margin-top:4px;font-size:11.5px}.top-student-row{border-bottom:1px solid var(--border-light);align-items:center;gap:12px;padding:10px 0;display:flex}.top-student-row:last-child{border-bottom:none}.top-student-rank{background:var(--bg);width:22px;height:22px;color:var(--text-muted);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:11px;font-weight:800;display:flex}.top-student-rank.rank-1{color:#92400e;background:#fef9c3}.top-student-rank.rank-2{color:#475569;background:#f1f5f9}.top-student-rank.rank-3{color:#9a3412;background:#fff7ed}.spinner-wrap{justify-content:center;align-items:center;padding:48px;display:flex}.spinner{border:3px solid var(--border);border-top-color:var(--primary);border-radius:50%;width:32px;height:32px;animation:.7s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}.flex{display:flex}.items-center{align-items:center}.justify-between{justify-content:space-between}.gap-2{gap:8px}.gap-3{gap:12px}.mt-4{margin-top:16px}.mt-6{margin-top:24px}.mb-4{margin-bottom:16px}.mb-6{margin-bottom:24px}.text-sm{font-size:12.5px}.text-muted{color:var(--text-muted)}.font-bold{font-weight:700}.w-full{width:100%}.truncate{white-space:nowrap;text-overflow:ellipsis;overflow:hidden}.classroom-page{background:#f0ebe3;min-height:100vh}.classroom-room{max-width:860px;margin:0 auto;padding:28px 20px 40px}.blackboard{border-radius:var(--radius-lg);text-align:center;background:linear-gradient(160deg,#2a5c24 0%,#1e4a19 60%,#163812 100%);border:6px solid #5d3a1a;margin-bottom:28px;padding:22px 32px;position:relative;overflow:hidden;box-shadow:inset 0 2px 12px #0006,0 6px 20px #00000040}.blackboard:before{content:"";pointer-events:none;background:repeating-linear-gradient(0deg,#0000,#0000 28px,#ffffff08 28px 29px);position:absolute;inset:0}.blackboard-title{color:#ffffffeb;letter-spacing:.04em;text-shadow:0 0 20px #ffffff26;font-family:Georgia,serif;font-size:28px;font-weight:900;position:relative}.blackboard-subtitle{color:#ffffff80;margin-top:6px;font-size:13px;position:relative}.blackboard-chalk{background:linear-gradient(90deg,#0000,#ffffff2e,#0000);height:3px;position:absolute;bottom:0;left:0;right:0}.classroom-meta{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:10px;margin-bottom:20px;display:flex}.seat-legend{align-items:center;gap:16px;display:flex}.legend-item{color:var(--text-muted);align-items:center;gap:6px;font-size:12.5px;font-weight:500;display:flex}.legend-dot{border-radius:4px;width:12px;height:12px}.legend-dot.occupied{background:var(--primary)}.legend-dot.empty{background:#d1c9bc;border:2px dashed #a89880}.seat-stats{gap:14px;display:flex}.seat-stat{text-align:center}.seat-stat-val{font-size:20px;font-weight:900;line-height:1}.seat-stat-val.occupied{color:var(--primary)}.seat-stat-val.empty{color:#a89880}.seat-stat-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;font-size:10.5px}.teacher-area{justify-content:center;margin-bottom:28px;display:flex}.teacher-desk{border-radius:var(--radius);color:#fffc;letter-spacing:.06em;text-transform:uppercase;background:linear-gradient(#8b4513 0%,#6b3410 100%);justify-content:center;align-items:center;width:140px;height:44px;font-size:11.5px;font-weight:600;display:flex;box-shadow:0 3px 8px #0000004d,inset 0 1px #ffffff1a}.seats-grid{grid-template-columns:repeat(8,1fr);gap:10px;display:grid}.seat{aspect-ratio:1;border-radius:var(--radius);cursor:pointer;flex-direction:column;justify-content:center;align-items:center;transition:transform .18s,box-shadow .18s;animation:.35s cubic-bezier(.34,1.56,.64,1) backwards seatIn;display:flex;position:relative}@keyframes seatIn{0%{opacity:0;transform:scale(0)rotate(-8deg)}to{opacity:1;transform:scale(1)rotate(0)}}.seat-occupied{background:linear-gradient(145deg,#fff,#f0f4ff);border:2px solid #bfdbfe;box-shadow:0 2px 6px #3b82f61f}.seat-occupied:hover{z-index:10;border-color:var(--primary);transform:scale(1.12)translateY(-4px);box-shadow:0 8px 20px #3b82f640}.seat-empty{background:repeating-linear-gradient(45deg,#f0ebe3,#f0ebe3 4px,#e8e1d8 4px 8px);border:2px dashed #c4b9a8;animation:.35s cubic-bezier(.34,1.56,.64,1) backwards seatIn,3s ease-in-out 1s infinite emptyPulse}.seat-empty:hover{border-color:#a89880;transform:scale(1.06)}@keyframes emptyPulse{0%,to{opacity:.6}50%{opacity:1}}.seat-avatar-sm{background:linear-gradient(135deg, var(--primary) 0%, #818cf8 100%);color:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:30px;height:30px;margin-bottom:3px;font-size:11px;font-weight:800;display:flex}.seat-name-sm{text-align:center;color:var(--text);text-overflow:ellipsis;white-space:nowrap;max-width:100%;padding:0 2px;font-size:7.5px;font-weight:700;line-height:1.2;overflow:hidden}.seat-score-sm{border-radius:3px;margin-top:1px;padding:1px 4px;font-size:8px;font-weight:700}.seat-score-sm.high{color:#15803d;background:#dcfce7}.seat-score-sm.medium{color:#92400e;background:#fef9c3}.seat-score-sm.low{color:#991b1b;background:#fee2e2}.seat-tooltip{background:var(--sidebar-bg);color:#fff;border-radius:var(--radius-sm);white-space:nowrap;opacity:0;pointer-events:none;z-index:20;padding:8px 12px;font-size:12px;transition:opacity .15s,transform .15s;position:absolute;bottom:calc(100% + 8px);left:50%;transform:translate(-50%)translateY(4px);box-shadow:0 4px 12px #0000004d}.seat-tooltip:after{content:"";border:5px solid #0000;border-top-color:var(--sidebar-bg);position:absolute;top:100%;left:50%;transform:translate(-50%)}.seat-tooltip-name{margin-bottom:2px;font-weight:700}.seat-tooltip-score{opacity:.75;font-size:11px}.seat-occupied:hover .seat-tooltip{opacity:1;transform:translate(-50%)translateY(0)}.seat-empty-icon{opacity:.4;font-size:18px}.seat-empty-label{color:#a89880;letter-spacing:.04em;text-transform:uppercase;margin-top:2px;font-size:7px}.seat-anon{cursor:default}.seat-anon:hover{box-shadow:none;transform:none}.seat-enquire{cursor:pointer;border-color:#10b98166!important}.seat-enquire:hover{transform:scale(1.08);background:#f0fdf4!important;border-color:#10b981!important}.seat-enquire .seat-empty-label{color:#10b981}.seat-clickable{cursor:pointer}.seat-clickable:hover{box-shadow:0 0 0 2px var(--primary)}.classroom-back{align-items:center;gap:8px;margin-bottom:20px;display:flex}.public-page{background:#05091a;overflow-x:hidden}.hero{text-align:center;background:linear-gradient(160deg,#05091a 0%,#0a1128 35%,#0d1b3e 65%,#112259 100%);flex-direction:column;justify-content:center;align-items:center;min-height:100vh;padding:60px 24px;display:flex;position:relative;overflow:hidden}.hero:before{content:"";pointer-events:none;background:radial-gradient(circle,#3b82f61f 0%,#0000 70%);border-radius:50%;width:600px;height:600px;position:absolute;top:-200px;right:-200px}.hero:after{content:"";pointer-events:none;background:radial-gradient(circle,#6366f11a 0%,#0000 70%);border-radius:50%;width:500px;height:500px;position:absolute;bottom:-150px;left:-150px}.hero-badge{color:#93c5fd;letter-spacing:.04em;background:#3b82f626;border:1px solid #3b82f64d;border-radius:20px;align-items:center;gap:6px;margin-bottom:24px;padding:5px 14px;font-size:12.5px;font-weight:600;animation:.6s fadeSlideDown;display:inline-flex}.hero-title{color:#fff;margin-bottom:20px;font-size:clamp(38px,7vw,72px);font-weight:900;line-height:1.1;animation:.7s .1s backwards fadeSlideDown}.hero-title-grad{background:linear-gradient(90deg,#60a5fa,#818cf8,#a78bfa);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text}.hero-sub{color:#fff9;max-width:580px;margin-bottom:40px;font-size:clamp(15px,2vw,18px);line-height:1.7;animation:.7s .2s backwards fadeSlideDown}.hero-cta{flex-wrap:wrap;justify-content:center;gap:12px;margin-bottom:64px;animation:.7s .3s backwards fadeSlideDown;display:flex}.btn-hero-primary{color:#fff;border-radius:var(--radius);cursor:pointer;background:linear-gradient(135deg,#3b82f6,#6366f1);border:none;padding:13px 28px;font-size:15px;font-weight:700;text-decoration:none;transition:all .2s;box-shadow:0 4px 20px #3b82f659}.btn-hero-primary:hover{transform:translateY(-2px);box-shadow:0 8px 30px #3b82f673}.btn-hero-ghost{color:#fffc;border-radius:var(--radius);cursor:pointer;background:#ffffff12;border:1px solid #ffffff26;padding:13px 28px;font-size:15px;font-weight:600;text-decoration:none;transition:all .2s}.btn-hero-ghost:hover{background:#ffffff1f}.hero-stats{flex-wrap:wrap;justify-content:center;gap:48px;animation:.7s .4s backwards fadeSlideDown;display:flex}.hero-stat{text-align:center}.hero-stat-value{color:#fff;font-size:clamp(36px,5vw,56px);font-weight:900;line-height:1;display:block}.hero-stat-label{color:#ffffff73;text-transform:uppercase;letter-spacing:.08em;margin-top:4px;font-size:12px;font-weight:600}.hero-stat-divider{background:#ffffff1a;align-self:stretch;width:1px}.scroll-indicator{color:#ffffff4d;letter-spacing:.08em;text-transform:uppercase;flex-direction:column;align-items:center;gap:4px;font-size:11px;animation:2s ease-in-out infinite bounce;display:flex;position:absolute;bottom:28px;left:50%;transform:translate(-50%)}.scroll-indicator-arrow{font-size:18px}@keyframes bounce{0%,to{transform:translate(-50%)translateY(0)}50%{transform:translate(-50%)translateY(6px)}}.ticker-section{background:#08111f;border-top:1px solid #ffffff0f;border-bottom:1px solid #ffffff0f;padding:20px 0;position:relative;overflow:hidden}.ticker-label{color:#93c5fd;letter-spacing:.1em;text-transform:uppercase;z-index:5;white-space:nowrap;background:linear-gradient(135deg,#0d1b3e,#1d4ed8);align-items:center;gap:6px;padding:0 20px;font-size:11px;font-weight:800;display:flex;position:absolute;top:0;bottom:0;left:0}.ticker-fade-l{z-index:4;pointer-events:none;background:linear-gradient(90deg,#08111f,#0000);width:160px;position:absolute;top:0;bottom:0;left:0}.ticker-fade-r{z-index:4;pointer-events:none;background:linear-gradient(270deg,#08111f,#0000);width:100px;position:absolute;top:0;bottom:0;right:0}.ticker-track{width:max-content;animation:40s linear infinite ticker;display:flex}.ticker-track:hover{animation-play-state:paused}.ticker-item{border-radius:var(--radius);white-space:nowrap;background:#ffffff0a;border:1px solid #ffffff12;align-items:center;gap:10px;margin:0 8px;padding:8px 20px;transition:background .2s;display:flex}.ticker-item:hover{background:#3b82f61f}.ticker-icon{font-size:18px}.ticker-text{color:#fffc;font-size:13px;font-weight:500}.ticker-student{color:#60a5fa;margin-left:4px;font-size:11px;font-weight:600}.ticker-sep{color:#ffffff26;margin:0 4px;font-size:20px}@keyframes ticker{0%{transform:translate(0)}to{transform:translate(-50%)}}.landing-section{max-width:1100px;margin:0 auto;padding:80px 24px}.section-label{text-transform:uppercase;letter-spacing:.1em;color:#60a5fa;margin-bottom:12px;font-size:11.5px;font-weight:700}.section-title{color:#fff;margin-bottom:14px;font-size:clamp(26px,4vw,40px);font-weight:900;line-height:1.2}.section-sub{color:#ffffff80;max-width:560px;font-size:15px;line-height:1.7}.features-grid{grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:18px;margin-top:48px;display:grid}.feature-card{border-radius:var(--radius-lg);background:#ffffff08;border:1px solid #ffffff12;padding:28px 24px;transition:all .2s}.feature-card:hover{background:#3b82f612;border-color:#3b82f640;transform:translateY(-3px)}.feature-card-icon{margin-bottom:14px;font-size:32px}.feature-card-title{color:#fff;margin-bottom:8px;font-size:16px;font-weight:700}.feature-card-desc{color:#ffffff80;font-size:13.5px;line-height:1.6}.students-strip{grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:14px;margin-top:40px;display:grid}.student-showcase-card{border-radius:var(--radius-lg);text-align:center;background:#ffffff0a;border:1px solid #ffffff12;padding:20px 16px;transition:all .2s}.student-showcase-card:hover{background:#3b82f614;border-color:#3b82f64d;transform:translateY(-3px)}.showcase-avatar{color:#fff;border-radius:50%;justify-content:center;align-items:center;width:52px;height:52px;margin:0 auto 10px;font-size:18px;font-weight:800;display:flex}.showcase-name{color:#fff;margin-bottom:2px;font-size:13.5px;font-weight:700}.showcase-class{color:#fff6;margin-bottom:8px;font-size:11.5px}.showcase-score{background:linear-gradient(90deg,#34d399,#60a5fa);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;font-size:22px;font-weight:900}.landing-cta{text-align:center;background:linear-gradient(135deg,#0d1b3e 0%,#1a2f5c 50%,#1d4ed8 100%);padding:80px 24px;position:relative;overflow:hidden}.landing-cta:before{content:"";pointer-events:none;background:radial-gradient(circle,#6366f126,#0000 70%);position:absolute;inset:0}.landing-nav{z-index:10;justify-content:space-between;align-items:center;padding:18px 32px;display:flex;position:absolute;top:0;left:0;right:0}.landing-nav-brand{color:#fff;align-items:center;gap:10px;font-size:18px;font-weight:800;text-decoration:none;display:flex}.landing-nav-icon{border-radius:var(--radius-sm);background:#ffffff26;justify-content:center;align-items:center;width:34px;height:34px;font-size:18px;display:flex}.fade-in-section{opacity:0;transition:opacity .6s,transform .6s;transform:translateY(24px)}.fade-in-section.visible{opacity:1;transform:translateY(0)}@keyframes fadeSlideDown{0%{opacity:0;transform:translateY(-16px)}to{opacity:1;transform:translateY(0)}}
