.landing{color:var(--text-main);background:radial-gradient(900px at 12% 10%,#3b82f61f,#0000 60%),radial-gradient(850px at 88% 22%,#22c55e1c,#0000 62%),radial-gradient(900px at 60% 92%,#a855f71a,#0000 62%),linear-gradient(#f8fafc 0%,#fff 45%,#f8fafc 100%)}.landing .wrap{width:min(1160px,100% - 40px);margin:0 auto}.landing section[id]{scroll-margin-top:88px}.landing-hero{color:#f1f5f9f2;background:radial-gradient(900px at 15% 20%,#3b82f652,#0000 58%),radial-gradient(900px at 85% 35%,#22c55e2e,#0000 58%),radial-gradient(900px at 55% 85%,#a855f72e,#0000 60%),linear-gradient(#070b18 0%,#0b1020 100%);border-bottom:1px solid #94a3b81f;padding:clamp(4.5rem,7vw,6.5rem) 0 4.5rem;position:relative;overflow:hidden}.landing-hero:before{content:"";pointer-events:none;background:radial-gradient(800px at 30% 10%,#ffffff0f,#0000 52%),radial-gradient(800px at 85% 85%,#ffffff0a,#0000 55%);position:absolute;inset:0}.landing-hero-grid{z-index:1;grid-template-columns:minmax(0,1.15fr) minmax(320px,.85fr);align-items:center;gap:3rem;display:grid;position:relative}.landing-badge{-webkit-backdrop-filter:blur(12px);background:#ffffff14;border:1px solid #ffffff24;border-radius:999px;align-items:center;gap:.6rem;padding:.45rem .75rem;font-size:.8125rem;line-height:1;display:inline-flex}.landing-dot{background:#22c55e;border-radius:50%;width:9px;height:9px;box-shadow:0 0 0 4px #22c55e2e}.landing-badge-pill{color:#bfdbfe;background:#2563eb38;border:1px solid #2563eb59;border-radius:999px;padding:.25rem .55rem;font-weight:700}.landing-hero h1{letter-spacing:-.02em;color:#fff;margin:1rem 0 .85rem;font-size:clamp(2.35rem,4.5vw,3.4rem);line-height:1.03}.landing-gradient-text{background:linear-gradient(90deg,#60a5fa,#a78bfa,#34d399);color:#0000;-webkit-background-clip:text;background-clip:text}.landing-lead{color:#e2e8f0db;max-width:62ch;margin:0;font-size:clamp(1rem,1.45vw,1.1rem);line-height:1.85}.landing-cta{flex-wrap:wrap;gap:.75rem;margin-top:1.6rem;display:flex}.landing-btn{min-height:46px;color:var(--text-main);background:#ffffffeb;border:1px solid #e2e8f0f2;border-radius:999px;justify-content:center;align-items:center;padding:0 1.05rem;font-size:.9375rem;font-weight:700;text-decoration:none;transition:transform .18s,box-shadow .18s,background .18s,border-color .18s,filter .18s;display:inline-flex}.landing-btn:hover{border-color:#3b82f638;transform:translateY(-1px);box-shadow:0 16px 30px #02061714}.landing-btn:focus-visible{outline:none;box-shadow:0 0 0 4px #2563eb47,0 16px 30px #02061714}.landing-btn.primary{color:#fff;background:linear-gradient(135deg,#60a5fa,#2563eb,#a78bfa);border:none;box-shadow:0 18px 36px #2563eb40}.landing-btn.primary:hover{filter:brightness(1.03);box-shadow:0 22px 44px #2563eb4d}.landing-btn.ghost{background:0 0}.landing-btn.soft{color:#1d4ed8;background:#2563eb1a;border-color:#bfdbfee6}.landing-hero .landing-btn{color:#f1f5f9f2;-webkit-backdrop-filter:blur(12px);box-shadow:none;background:#ffffff14;border-color:#e2e8f02e}.landing-hero .landing-btn:hover{background:#ffffff1c;border-color:#e2e8f047;box-shadow:0 18px 42px #02061759}.landing-hero .landing-btn.primary{color:#fff;border:none;box-shadow:0 18px 44px #2563eb47}.landing-hero .landing-btn.ghost{background:0 0}.landing-hero .landing-btn.soft{color:#dbeafe;background:#2563eb29;border-color:#3b82f659}.landing-tags{flex-wrap:wrap;gap:.5rem;margin-top:1.25rem;display:flex}.landing-tags span{color:#e2e8f0db;background:#0f172a38;border:1px solid #e2e8f01a;border-radius:999px;padding:.35rem .65rem;font-size:.75rem}.landing-metrics{grid-template-columns:repeat(2,minmax(0,1fr));gap:.75rem;margin-top:1.25rem;display:grid}.landing-metric{-webkit-backdrop-filter:blur(12px);background:#ffffff0f;border:1px solid #e2e8f024;border-radius:18px;padding:.95rem}.landing-metric strong{color:#fff;margin-bottom:.25rem;font-size:.95rem;display:block}.landing-metric span{color:#e2e8f0c7;font-size:.8125rem;line-height:1.5}.landing-hero-visual{position:relative}.preview-card{-webkit-backdrop-filter:blur(16px);background:#ffffff14;border:1px solid #e2e8f029;border-radius:26px;padding:1.25rem;box-shadow:0 32px 90px #0206178c}.preview-top{justify-content:space-between;align-items:center;gap:1rem;margin-bottom:1rem;display:flex}.preview-brand{align-items:center;gap:.75rem;display:flex}.preview-logo{letter-spacing:-.03em;color:#0b1020;background:linear-gradient(135deg,#60a5fa,#a78bfa,#34d399);border-radius:14px;place-items:center;width:44px;height:44px;font-weight:900;display:grid}.preview-title{color:#fff;font-size:.95rem;font-weight:800;line-height:1.2}.preview-subtitle{color:#e2e8f0bd;font-size:.8rem}.preview-pill{color:#34d399;background:#22c55e1f;border:1px solid #22c55e59;border-radius:999px;padding:.35rem .65rem;font-size:.75rem;font-weight:800}.preview-list{gap:.6rem;margin:.85rem 0 1rem;display:grid}.preview-row{color:#e2e8f0db;background:#0f172a38;border:1px solid #e2e8f01a;border-radius:14px;justify-content:space-between;align-items:center;gap:.75rem;padding:.55rem .65rem;font-size:.82rem;display:flex}.status{border:1px solid #0000;border-radius:999px;padding:.22rem .55rem;font-size:.72rem;font-weight:900}.status.ok{color:#34d399;background:#22c55e1f;border-color:#22c55e59}.status.warn{color:#fbbf24;background:#f59e0b1f;border-color:#f59e0b59}.status.info{color:#60a5fa;background:#3b82f61f;border-color:#3b82f659}.preview-bars{gap:.6rem;padding-top:.25rem;display:grid}.bar-row{color:#e2e8f0b8;grid-template-columns:86px 1fr;align-items:center;gap:.6rem;font-size:.78rem;display:grid}.bar{background:#ffffff14;border:1px solid #e2e8f024;border-radius:999px;height:10px;overflow:hidden}.bar i{background:linear-gradient(90deg,#60a5fa,#a78bfa,#34d399);border-radius:999px;height:100%;display:block;box-shadow:0 10px 24px #60a5fa38}.preview-actions{gap:.6rem;margin-top:1rem;display:flex}.mini-btn{text-align:center;color:#f1f5f9e6;background:#ffffff0f;border:1px solid #e2e8f024;border-radius:14px;flex:1;padding:.6rem .75rem;font-size:.8rem;font-weight:900}.mini-btn.primary{color:#0b1020;background:linear-gradient(135deg,#60a5fa,#2563eb,#a78bfa);border:none}.floating-badge{color:#e2e8f0eb;-webkit-backdrop-filter:blur(12px);background:#0f172a59;border:1px solid #e2e8f029;border-radius:999px;padding:.55rem .75rem;font-size:.75rem;font-weight:900;animation:6s ease-in-out infinite floaty;position:absolute;box-shadow:0 18px 42px #02061759}.floating-badge.one{top:-14px;left:-10px}.floating-badge.two{animation-delay:1.2s;bottom:18px;left:-12px}.floating-badge.three{animation-delay:2.2s;top:28px;right:-10px}@keyframes floaty{0%,to{transform:translateY(0)}50%{transform:translateY(-12px)}}.landing-strip{margin-top:-2.2rem;padding:0 0 4.5rem}.landing-strip-grid{z-index:2;grid-template-columns:repeat(4,minmax(0,1fr));gap:1rem;display:grid;position:relative}.strip-card{background:#fffffff0;border:1px solid #e2e8f0f2;border-radius:18px;padding:1rem 1.1rem;box-shadow:0 18px 46px #0206170f}.strip-card strong{color:var(--text-main);margin-bottom:.25rem;font-size:.95rem;display:block}.strip-card span{color:var(--text-secondary);font-size:.82rem;display:block}.landing #services,.landing #features,.landing #about,.landing #contact{padding:clamp(3.5rem,5vw,5rem) 0}.landing #services,.landing #about{background:0 0}.landing #features,.landing #contact,.landing-section.alt{background:linear-gradient(#fff 0%,#f1f5f9 100%)}.section-head h2{letter-spacing:-.02em;color:var(--text-main);margin:0 0 .5rem;font-size:clamp(1.8rem,2.6vw,2.2rem);font-weight:900}.section-head p{max-width:70ch;color:var(--text-secondary);margin:0 auto;font-size:1rem;line-height:1.8}.landing-grid{grid-template-columns:repeat(4,minmax(0,1fr));gap:1.2rem;display:grid}.landing-card{background:#ffffffeb;border:1px solid #e2e8f0f2;border-radius:22px;padding:1.4rem 1.35rem;transition:transform .2s,box-shadow .2s,border-color .2s;box-shadow:0 18px 46px #0206170f}.landing-card:hover{border-color:#3b82f647;transform:translateY(-4px);box-shadow:0 28px 70px #02061714}.landing-icon{color:#0b1020;border-radius:16px;place-items:center;width:46px;height:46px;margin-bottom:.9rem;font-size:1.25rem;display:grid}.landing-icon.blue{background:linear-gradient(135deg,#60a5faf2,#2563ebf2)}.landing-icon.violet{background:linear-gradient(135deg,#a78bfaf2,#a855f7eb)}.landing-icon.green{background:linear-gradient(135deg,#34d399f2,#22c55eeb)}.landing-icon.amber{background:linear-gradient(135deg,#fbbf24f2,#f59e0beb)}.landing-card h3{color:var(--text-main);letter-spacing:-.01em;margin:0 0 .5rem;font-size:1.05rem;font-weight:900}.landing-card p{color:var(--text-secondary);margin:0;font-size:.925rem;line-height:1.7}.landing-feature-grid{grid-template-columns:minmax(0,1fr) minmax(0,1fr);align-items:start;gap:1.5rem;display:grid}.feature-list{gap:.9rem;display:grid}.feature-item{background:#ffffffeb;border:1px solid #e2e8f0f2;border-radius:22px;gap:.85rem;padding:1.05rem;display:flex;box-shadow:0 18px 46px #0206170f}.check{background:linear-gradient(135deg,#34d399,#60a5fa);border-radius:999px;flex:0 0 22px;width:22px;height:22px;margin-top:.15rem;position:relative;box-shadow:0 10px 24px #34d39933}.check:after{content:"";border-bottom:2px solid #0b1020;border-left:2px solid #0b1020;width:9px;height:5px;position:absolute;top:7px;left:7px;transform:rotate(-45deg)}.feature-item strong{color:var(--text-main);margin-bottom:.2rem;font-weight:900;display:block}.feature-item p{color:var(--text-secondary);margin:0;font-size:.92rem;line-height:1.7}.feature-callout{background:linear-gradient(#fffffff5,#f8fafcf5);border:1px solid #e2e8f0f2;border-radius:24px;padding:1.4rem;position:relative;overflow:hidden;box-shadow:0 18px 46px #0206170f}.feature-callout:before{content:"";pointer-events:none;background:radial-gradient(700px at 0 0,#3b82f62e,#0000 60%),radial-gradient(700px at 100% 100%,#a855f724,#0000 60%);position:absolute;inset:-1px}.feature-callout>*{z-index:1;position:relative}.callout-top{justify-content:space-between;align-items:flex-start;gap:1rem;margin-bottom:1rem;display:flex}.callout-kicker{text-transform:uppercase;letter-spacing:.09em;color:#1d4ed8;font-size:.72rem;font-weight:900}.callout-title{color:var(--text-main);letter-spacing:-.01em;margin-top:.25rem;font-size:1.1rem;font-weight:900}.callout-badge{color:#1d4ed8;background:#2563eb1f;border:1px solid #2563eb40;border-radius:999px;padding:.35rem .6rem;font-size:.75rem;font-weight:900}.steps{gap:.6rem;margin:0;padding:0;list-style:none;display:grid}.steps li{color:var(--text-secondary);background:#ffffffdb;border:1px solid #e2e8f0e6;border-radius:16px;align-items:center;gap:.6rem;padding:.6rem .7rem;font-size:.92rem;display:flex}.step-num{color:#0b1020;background:linear-gradient(135deg,#60a5fa,#a78bfa);border-radius:10px;place-items:center;width:26px;height:26px;font-size:.85rem;font-weight:900;display:grid}.callout-actions{flex-wrap:wrap;gap:.75rem;margin-top:1.1rem;display:flex}.landing-about-grid{grid-template-columns:minmax(0,1.25fr) minmax(0,.75fr);align-items:stretch;gap:1.2rem;display:grid}.about-card,.about-highlight{background:#ffffffeb;border:1px solid #e2e8f0f2;border-radius:24px;padding:1.6rem;box-shadow:0 18px 46px #0206170f}.about-card h2{letter-spacing:-.02em;color:var(--text-main);margin:0 0 .75rem;font-size:1.6rem;font-weight:900}.landing .muted{color:var(--text-secondary);line-height:1.85}.about-pills{flex-wrap:wrap;gap:.5rem;margin-top:1.2rem;display:flex}.about-pills span{color:#334155;background:#f1f5f9;border:1px solid #e2e8f0f2;border-radius:999px;padding:.4rem .65rem;font-size:.78rem;font-weight:700}.about-highlight{background:linear-gradient(135deg,#2563eb1a,#22c55e1a);border-color:#bfdbfed9}.about-highlight-title{letter-spacing:-.01em;color:var(--text-main);margin-bottom:.5rem;font-weight:900}.about-mini-stats{grid-template-columns:repeat(3,minmax(0,1fr));gap:.65rem;margin-top:1.2rem;display:grid}.about-mini-stats>div{text-align:center;background:#ffffffc7;border:1px solid #e2e8f0e6;border-radius:20px;padding:.85rem}.about-mini-stats strong{font-size:1.25rem;display:block}.about-mini-stats span{color:var(--text-secondary);margin-top:.35rem;font-size:.75rem;font-weight:700;display:block}.landing-contact-grid{grid-template-columns:minmax(0,1.15fr) minmax(0,.85fr);align-items:start;gap:1.2rem;display:grid}.contact-card{background:#ffffffeb;border:1px solid #e2e8f0f2;border-radius:24px;padding:1.6rem;box-shadow:0 18px 46px #0206170f}.contact-card h2{letter-spacing:-.02em;color:var(--text-main);margin:0 0 .75rem;font-size:1.6rem;font-weight:900}.contact-actions{flex-wrap:wrap;gap:.75rem;margin-top:1.25rem;display:flex}.contact-note{color:#334155;background:#f1f5f9;border:1px solid #e2e8f0f2;border-radius:18px;margin-top:1rem;padding:.75rem .9rem;font-size:.875rem;font-weight:700}.contact-chip{color:#1d4ed8;background:#2563eb1f;border:1px solid #2563eb38;border-radius:999px;align-items:center;margin-right:.35rem;padding:.2rem .5rem;font-size:.75rem;font-weight:900;display:inline-flex}.contact-side{gap:1.2rem;display:grid}.side-card{background:#ffffffeb;border:1px solid #e2e8f0f2;border-radius:24px;padding:1.4rem;box-shadow:0 18px 46px #0206170f}.side-card.accent{background:linear-gradient(135deg,#60a5fa1f,#a78bfa1a);border-color:#bfdbfed9}.side-card strong{color:var(--text-main);margin-bottom:.75rem;font-weight:900;display:block}.side-card ul{color:var(--text-secondary);margin:0;padding-left:1.1rem;font-weight:600;line-height:1.85}.side-card p{color:var(--text-secondary);margin:0;font-weight:600;line-height:1.85}.landing-header{z-index:50;border-bottom:1px solid var(--border-color);background:#fff;position:sticky;top:0}.landing-header .nav-container{justify-content:space-between;align-items:center;max-width:1200px;height:64px;margin:0 auto;padding:0 1.5rem;display:flex}.landing-header .logo{color:var(--text-main);font-size:1.125rem;font-weight:700;text-decoration:none;transition:color .2s}.landing-header .logo:hover{color:var(--primary)}.landing-header .nav-links{align-items:center;gap:.25rem;display:flex}.landing-header .nav-links a{color:var(--text-secondary);border-radius:var(--border-radius);padding:.5rem 1rem;font-size:.875rem;font-weight:500;text-decoration:none;transition:all .2s}.landing-header .nav-links a:hover{color:var(--primary);background:var(--primary-bg)}.landing-header .nav-links a:last-child{background:var(--primary);color:#fff;margin-left:.5rem;padding:.5rem 1.25rem}.landing-header .nav-links a:last-child:hover{background:var(--primary-dark)}.landing-header .mobile-toggle{cursor:pointer;background:0 0;border:none;flex-direction:column;gap:5px;padding:.5rem;display:none}.landing-header .mobile-toggle span{background:var(--text-main);border-radius:2px;width:24px;height:2px}@media (width<=768px){.landing-header .mobile-toggle{display:flex}.landing-header .nav-links{display:none}.landing-header .nav-links.mobile-open{border-bottom:1px solid var(--border-color);background:#fff;flex-direction:column;gap:.5rem;padding:1rem;display:flex;position:absolute;top:64px;left:0;right:0;box-shadow:0 4px 12px #0000001a}.landing-header .nav-links.mobile-open a{padding:.75rem 1rem;display:block}.landing-header .nav-links.mobile-open a:last-child{text-align:center;background:var(--primary);color:#fff;margin-left:0}}.landing footer{text-align:center;color:var(--text-muted);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#ffffffb3;border-top:1px solid #e2e8f099;padding:1.5rem 0;font-size:.8125rem}@media (width<=980px){.landing-hero-grid{grid-template-columns:1fr;gap:2.25rem}.landing-metrics{grid-template-columns:1fr}.landing-strip-grid,.landing-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.landing-feature-grid,.landing-about-grid,.landing-contact-grid{grid-template-columns:1fr}}@media (width<=560px){.landing .wrap{width:min(1160px,100% - 24px)}.landing-strip-grid,.landing-grid{grid-template-columns:1fr}.floating-badge{display:none}.preview-actions{flex-direction:column}}@media (prefers-reduced-motion:reduce){.floating-badge{animation:none!important}.landing-btn,.landing-card{transition:none!important}}.login-page{--text:#0f172a;--muted:#64748b;--primary:#2563eb;--primary-700:#1d4ed8;--ring:#2563eb47;--card-border:#0f172a14;--card-shadow:0 24px 70px #02061747;background:radial-gradient(850px at 12% 12%,#2563eb40,#0000 55%),radial-gradient(750px at 90% 86%,#0ea5e92e,#0000 60%),linear-gradient(#0b1220 0%,#0a1020 100%);place-items:center;min-height:100svh;padding:clamp(1rem,3.5vw,2.75rem);display:grid}.login-split-page{border:1px solid var(--card-border);width:min(1120px,100%);box-shadow:var(--card-shadow);background:#fff;border-radius:24px;grid-template-columns:1.05fr .95fr;display:grid;overflow:hidden}.login-left{text-align:center;isolation:isolate;color:#fff;background:linear-gradient(135deg,#1e3a5f 0%,#2563eb 55%,#1e40af 100%);align-content:center;justify-items:center;padding:clamp(2rem,3vw,2.75rem);display:grid;position:relative;overflow:hidden}.login-left:before{content:"";opacity:.55;z-index:0;background:url("data:image/svg+xml,%3Csvg width='60' height='60' viewBox='0 0 60 60' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='none' fill-rule='evenodd'%3E%3Cg fill='%23ffffff' fill-opacity='0.05'%3E%3Cpath d='M36 34v-4h-2v4h-4v2h4v4h2v-4h4v-2h-4zm0-30V0h-2v4h-4v2h4v4h2V6h4V4h-4zM6 34v-4H4v4H0v2h4v4h2v-4h4v-2H6zM6 4V0H4v4H0v2h4v4h2V6h4V4H6z'/%3E%3C/g%3E%3C/g%3E%3C/svg%3E");position:absolute;inset:0}.school-illustration,.school-info,.floating-elements{z-index:1;position:relative}.school-illustration{place-items:center;width:100%;max-width:360px;height:290px;display:grid}.school-building{align-items:flex-end;gap:12px;display:flex;position:relative}.building-main{flex-direction:column;align-items:center;display:flex}.building-roof{clip-path:polygon(0 100%,50% 0,100% 100%);background:linear-gradient(135deg,#dc2626,#b91c1c);width:160px;height:40px;position:relative}.building-roof:after{content:"";background:#94a3b8;width:4px;height:30px;position:absolute;top:-25px;left:50%;transform:translate(-50%)}.building-body{background:linear-gradient(#f8fafc,#e2e8f0);border:3px solid #1e3a5f;border-top:none;flex-direction:column;gap:10px;width:160px;padding:15px;display:flex;position:relative;box-shadow:0 12px 35px #00000029}.window-row{justify-content:space-around;gap:6px;display:flex}.window{background:linear-gradient(#60a5fa,#3b82f6);border:2px solid #1e3a5f;border-radius:4px;width:30px;height:35px;position:relative}.window:before{content:"";background:#1e3a5f;height:2px;position:absolute;top:50%;left:0;right:0}.window:after{content:"";background:#1e3a5f;width:2px;position:absolute;top:0;bottom:0;left:50%}.door{background:linear-gradient(#92400e,#78350f);border:2px solid #1e3a5f;border-radius:4px 4px 0 0;width:40px;height:50px;margin:0 auto;position:relative}.door:after{content:"";background:#fbbf24;border-radius:50%;width:6px;height:6px;position:absolute;top:50%;right:8px}.flag-pole{background:linear-gradient(#fffffff2,#e2e8f099);border-radius:999px;width:6px;height:190px;position:relative;box-shadow:0 8px 20px #0000002e}.flag{clip-path:polygon(0 0,100% 16%,82% 50%,100% 84%,0 100%);background:linear-gradient(135deg,#f59e0b,#f97316);border-radius:6px;width:54px;height:30px;position:absolute;top:18px;left:6px;box-shadow:0 10px 24px #0000002e}.tree{flex-direction:column;align-items:center;display:flex}.tree-top{clip-path:polygon(50% 0%,0% 100%,100% 100%);background:linear-gradient(#22c55e,#16a34a);width:40px;height:50px}.tree-trunk{background:linear-gradient(#a16207,#854d0e);width:12px;height:25px}.tree-1{position:absolute;bottom:0;left:-50px;transform:scale(.8)}.tree-2{position:absolute;bottom:0;right:-50px;transform:scale(.9)}.floating-elements{pointer-events:none;position:absolute;inset:0}.float-icon{opacity:.85;filter:drop-shadow(0 10px 25px #00000038);font-size:24px;animation:4s ease-in-out infinite floatUp;position:absolute}.float-icon.book{animation-delay:0s;top:20%;left:10%}.float-icon.pencil{animation-delay:1s;top:30%;right:15%}.float-icon.star{animation-delay:2s;top:50%;left:5%}.float-icon.clock{animation-delay:.5s;top:15%;right:25%}.float-icon.trophy{animation-delay:1.5s;top:40%;right:5%}@keyframes floatUp{0%,to{transform:translateY(0)rotate(0)}50%{transform:translateY(-14px)rotate(10deg)}}.school-info{width:100%;margin-top:2rem}.school-info h2{margin:0 0 .5rem;font-size:1.75rem;font-weight:700}.school-info p{opacity:.92;max-width:340px;margin:0 auto;font-size:1rem}.login-right{text-align:center;background:#fff;align-content:center;justify-items:center;padding:clamp(2rem,3.2vw,3rem);display:grid}.login-form-container{flex-direction:column;align-items:center;width:100%;max-width:450px;display:flex}.login-header-section{width:100%;margin-bottom:2rem}.logo-container{justify-content:center;align-items:center;gap:.75rem;margin-bottom:.5rem;display:flex}.logo-icon{background:linear-gradient(135deg, var(--primary), var(--primary-700));border-radius:14px;justify-content:center;align-items:center;width:48px;height:48px;display:flex;box-shadow:0 10px 28px #2563eb47}.logo-icon svg{color:#fff;width:28px;height:28px}.logo-container h1{color:var(--text);margin:0;font-size:1.5rem;font-weight:800}.tagline{color:var(--muted);margin:0;font-size:.875rem}.login-form{flex-direction:column;align-items:center;width:100%;display:flex}.login-form h2{color:var(--text);margin:0 0 .25rem;font-size:1.5rem;font-weight:800}.login-form .subtitle{color:var(--muted);margin:0 0 1.5rem;font-size:.9rem}.error-message{background:#fef2f2;border:1px solid #fecaca;border-radius:4px;align-items:center;gap:.5rem;width:100%;margin-bottom:1rem;padding:.75rem 1rem;animation:.5s ease-in-out shake;display:flex}@keyframes shake{0%,to{transform:translate(0)}20%,60%{transform:translate(-5px)}40%,80%{transform:translate(5px)}}.error-message svg{color:#dc2626;flex-shrink:0;width:20px;height:20px}.error-message span{color:#dc2626;text-align:left;font-size:.8125rem;font-weight:600}.input-group{width:100%;margin-bottom:1.25rem}.input-group label{color:#334155;text-align:left;margin-bottom:.5rem;font-size:.8125rem;font-weight:600;display:block}.input-wrapper{align-items:center;width:100%;display:flex;position:relative}.input-icon{color:#9ca3af;pointer-events:none;align-items:center;width:20px;height:20px;transition:color .2s;display:flex;position:absolute;left:1rem}.input-icon svg{width:100%;height:100%}.input-wrapper input{width:100%;color:var(--text);background:#f8fafc;border:1.5px solid #e2e8f0;border-radius:4px;padding:.875rem 1rem .875rem 3rem;font-size:.95rem;transition:border-color .15s,box-shadow .15s,background .15s}.input-wrapper input#password{padding-right:3.5rem}.input-wrapper input::placeholder{color:#9ca3af}.input-wrapper input:focus{border-color:var(--primary);box-shadow:0 0 0 4px var(--ring);background:#fff;outline:none}.input-wrapper:focus-within .input-icon{color:var(--primary)}.input-wrapper input:disabled{opacity:.65;cursor:not-allowed}.password-toggle{cursor:pointer;color:#9ca3af;background:0 0;border:none;border-radius:10px;justify-content:center;align-items:center;padding:.45rem;transition:background .2s,color .2s,box-shadow .2s;display:flex;position:absolute;right:.75rem}.password-toggle:hover{color:#64748b;background:#0f172a0f}.password-toggle:focus-visible{box-shadow:0 0 0 4px var(--ring);outline:none}.password-toggle svg{width:20px;height:20px}.form-options{justify-content:space-between;align-items:center;gap:1rem;width:100%;margin-bottom:1.5rem;display:flex}.checkbox-wrapper{cursor:pointer;-webkit-user-select:none;user-select:none;align-items:center;gap:.5rem;display:flex;position:relative}.checkbox-wrapper input{opacity:0;clip:rect(0 0 0 0);clip-path:inset(50%);white-space:nowrap;width:1px;height:1px;margin:0;position:absolute;overflow:hidden}.checkmark{background:#fff;border:2px solid #cbd5e1;border-radius:5px;justify-content:center;align-items:center;width:18px;height:18px;transition:background .2s,border-color .2s,box-shadow .2s;display:flex}.checkbox-wrapper input:focus-visible+.checkmark{border-color:var(--primary);box-shadow:0 0 0 4px var(--ring)}.checkbox-wrapper input:checked+.checkmark{background:var(--primary);border-color:var(--primary)}.checkbox-wrapper input:checked+.checkmark:after{content:"";border:2px solid #fff;border-width:0 2px 2px 0;width:5px;height:9px;margin-bottom:2px;transform:rotate(45deg)}.checkbox-label{color:#475569;font-size:.8125rem}.forgot-link{color:var(--primary);font-size:.8125rem;font-weight:600;text-decoration:none;transition:color .2s,text-decoration-color .2s}.forgot-link:hover{color:var(--primary-700);text-decoration:underline}.forgot-link:focus-visible{box-shadow:0 0 0 4px var(--ring);border-radius:8px;outline:none}.login-btn{background:linear-gradient(135deg, var(--primary), var(--primary-700));color:#fff;cursor:pointer;border:none;border-radius:4px;justify-content:center;align-items:center;gap:.5rem;width:100%;padding:1rem;font-size:1rem;font-weight:700;transition:transform .2s,box-shadow .2s,filter .2s;display:flex;box-shadow:0 10px 28px #2563eb47}.login-btn:hover:not(:disabled){filter:brightness(1.02);transform:translateY(-2px);box-shadow:0 16px 38px #2563eb52}.login-btn:active:not(:disabled){transform:translateY(0)}.login-btn:focus-visible{box-shadow:0 0 0 4px var(--ring), 0 16px 38px #2563eb52;outline:none}.login-btn:disabled{opacity:.75;cursor:not-allowed}.login-btn svg{width:20px;height:20px}.spinner{border:2px solid #ffffff4d;border-top-color:#fff;border-radius:50%;width:20px;height:20px;animation:.8s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.login-footer{text-align:center;width:100%;margin-top:1.5rem}.divider{justify-content:center;align-items:center;gap:1rem;margin-bottom:1rem;display:flex}.divider:before,.divider:after{content:"";background:#e2e8f0;flex:1;height:1px}.divider span{color:#94a3b8;text-transform:uppercase;letter-spacing:.06em;font-size:.75rem;font-weight:600}.quick-links{justify-content:center;gap:.75rem;display:flex}.quick-link{color:#475569;background:#f8fafc;border:1px solid #e2e8f0;border-radius:4px;flex:1;justify-content:center;align-items:center;gap:.5rem;max-width:200px;padding:.8rem;font-size:.8125rem;font-weight:600;text-decoration:none;transition:background .2s,border-color .2s,box-shadow .2s,transform .2s;display:flex}.quick-link:hover{background:#f1f5f9;border-color:#cbd5e1;transform:translateY(-1px);box-shadow:0 10px 22px #02061714}.quick-link:focus-visible{box-shadow:0 0 0 4px var(--ring);outline:none}.quick-link svg{width:18px;height:18px}.login-footer-text{text-align:center;border-top:1px solid #e2e8f0;width:100%;margin-top:1.5rem;padding-top:1rem}.login-footer-text p{color:#94a3b8;margin:0 0 .25rem;font-size:.75rem}.login-footer-text a{color:var(--primary);font-size:.75rem;font-weight:600;text-decoration:none}.login-footer-text a:hover{text-decoration:underline}.login-footer-text a:focus-visible{box-shadow:0 0 0 4px var(--ring);border-radius:8px;outline:none}@media (width<=960px){.login-split-page{grid-template-columns:1fr}.login-left{padding:2rem 1.5rem}.school-illustration{max-width:320px;height:230px}.login-right{padding:2rem 1.25rem}.form-options{flex-direction:column;align-items:center;gap:.75rem}.quick-links{flex-direction:column;align-items:stretch}.quick-link{max-width:100%}}@media (width<=480px){.login-page{padding:1rem}.login-split-page{border-radius:18px}.school-illustration{max-width:220px;height:165px}.school-info{margin-top:1.5rem}.school-info h2{font-size:1.25rem}.school-info p{max-width:280px;font-size:.875rem}.building-roof{width:110px;height:28px}.building-body{gap:8px;width:110px;padding:10px}.window{width:20px;height:24px}.door{width:28px;height:34px}.flag-pole{height:155px}.flag{width:46px;height:25px}.tree-top{width:28px;height:36px}.tree-trunk{width:8px;height:18px}.tree-1{left:-30px;transform:scale(.75)}.tree-2{right:-30px;transform:scale(.8)}.float-icon{font-size:18px}.logo-icon{border-radius:4px;width:42px;height:42px}.logo-container h1{font-size:1.25rem}.tagline{font-size:.8rem}.input-wrapper input{padding:.78rem 1rem .78rem 2.75rem;font-size:.9rem}.input-wrapper input#password{padding-right:3.25rem}.input-icon{left:.9rem}.password-toggle{right:.55rem}.login-footer-text p,.login-footer-text a{font-size:.7rem}}@media (prefers-reduced-motion:reduce){.float-icon,.error-message,.spinner{animation:none!important}.login-btn,.input-wrapper input,.quick-link,.forgot-link,.password-toggle{transition:none!important}}:root{--primary:#2563eb;--primary-dark:#1d4ed8;--primary-light:#60a5fa;--primary-bg:#eff6ff;--bg-color:#f8fafc;--surface-color:#fff;--surface-hover:#f1f5f9;--text-main:#0f172a;--text-secondary:#475569;--text-muted:#94a3b8;--border-color:#e2e8f0;--success:#059669;--success-bg:#d1fae5;--warning:#ea580c;--warning-bg:#ffedd5;--danger:#dc2626;--danger-bg:#fee2e2;--info:#0284c7;--info-bg:#e0f2fe;--sidebar-bg:#0f172a;--sidebar-text:#f8fafc;--sidebar-width:280px;--border-radius:4px;--border-radius-sm:2px;--transition:all .2s ease;--shadow-sm:0 1px 3px #00000014;--shadow-md:0 4px 12px #0000001a}*,:before,:after{box-sizing:border-box}.kpi-card{background:var(--surface-color);border:1px solid var(--border-color);box-shadow:var(--shadow-sm);flex-direction:column;gap:.75rem;padding:1.25rem;transition:all .2s;display:flex}.kpi-card:hover{transform:translateY(-2px);box-shadow:0 8px 25px #0000001a}.kpi-icon{border-radius:4px;justify-content:center;align-items:center;width:44px;height:44px;display:flex}.kpi-icon.blue{color:#2563eb;background:#dbeafe}.kpi-icon.green{color:#059669;background:#d1fae5}.kpi-icon.orange{color:#ea580c;background:#ffedd5}.kpi-icon.purple{color:#7c3aed;background:#ede9fe}.kpi-title{color:var(--text-secondary);font-size:.8125rem;font-weight:500}.kpi-value{color:var(--text-main);font-size:1.75rem;font-weight:700;line-height:1}.chart-card{background:var(--surface-color);border:1px solid var(--border-color);box-shadow:var(--shadow-sm);border-radius:4px;padding:1.5rem}.chart-container{width:100%;overflow:hidden}.class-toppers-card{background:var(--surface-color);border:1px solid var(--border-color);box-shadow:var(--shadow-sm);border-radius:4px;margin-bottom:1.5rem;padding:1.5rem}.class-toppers-card h3{color:var(--text-main);margin-bottom:.25rem;font-size:1.0625rem;font-weight:600}.class-toppers-grid{grid-template-columns:repeat(3,1fr);gap:1rem;margin-top:1rem;display:grid}.topper-item{border:1px solid var(--border-color);transition:var(--transition);background:#f8fafc;border-radius:4px;align-items:center;gap:.875rem;padding:.875rem;display:flex}.topper-item:hover{border-color:var(--primary-light);background:#f1f5f9}.topper-rank{color:#fff;background:linear-gradient(135deg,#fbbf24,#f59e0b);border-radius:4px;flex-shrink:0;justify-content:center;align-items:center;width:32px;height:32px;font-size:.875rem;font-weight:700;display:flex}.topper-info{flex:1;min-width:0}.topper-name{color:var(--text-main);white-space:nowrap;text-overflow:ellipsis;font-size:.875rem;font-weight:600;overflow:hidden}.topper-class{color:var(--text-muted);font-size:.75rem}.topper-score{text-align:right;flex-shrink:0}.topper-percentage{color:var(--text-main);font-size:1rem;font-weight:700}.topper-change{font-size:.6875rem;font-weight:600}.topper-change.positive{color:#059669}.topper-change.negative{color:#dc2626}@media (width<=1024px){.kpi-grid{grid-template-columns:repeat(2,1fr)}.charts-grid{grid-template-columns:1fr}.class-toppers-grid{grid-template-columns:repeat(2,1fr)}}@media (width<=640px){.kpi-grid,.class-toppers-grid{grid-template-columns:1fr}}*{box-sizing:border-box;margin:0;padding:0}html,body{height:100%;overflow-x:hidden}body{background-color:var(--bg-color);color:var(--text-main);-webkit-font-smoothing:antialiased;max-width:100vw;min-height:100vh;margin:0;padding:0;font-family:Poppins,system-ui,-apple-system,sans-serif;line-height:1.6;overflow-x:hidden}#root{flex:auto;width:100%;min-height:100%}a{color:inherit;text-decoration:none}button{cursor:pointer;border-radius:4px;font-family:inherit}ul{list-style:none}img{max-width:100%;display:block}input,select,textarea{border:1.5px solid var(--border-color);border-radius:var(--border-radius);color:var(--text-main);background:#fff;width:100%;padding:.75rem 1rem;font-family:inherit;font-size:.875rem;transition:all .2s}input::placeholder,textarea::placeholder{color:var(--text-muted)}input:focus,select:focus,textarea:focus{border-color:var(--primary);background:#fff;outline:none;box-shadow:0 0 0 4px #2563eb1a}input:disabled,select:disabled,textarea:disabled{background:var(--bg-color);cursor:not-allowed;opacity:.7}.card{border:1px solid var(--border-color);background:#fff;padding:1.5rem;transition:all .2s}.card:hover{box-shadow:0 4px 20px #00000014}table{border-collapse:collapse;width:100%;font-size:.875rem}thead tr{background:var(--bg-color)}thead tr th{text-align:left;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em;border-bottom:2px solid var(--border-color);padding:.875rem 1rem;font-size:.75rem;font-weight:600}tbody tr{border-bottom:1px solid var(--border-color);transition:background .15s}tbody tr td{vertical-align:middle;padding:.875rem 1rem}.field-row{flex-wrap:wrap;align-items:flex-end;gap:1rem;margin-bottom:1rem;display:flex}.field-row>*{flex:1;min-width:150px}.field-row label{color:var(--text-secondary);margin-bottom:.375rem;font-size:.8125rem;font-weight:600;display:block}.tag,.status-badge{text-transform:capitalize;letter-spacing:.02em;align-items:center;gap:.3rem;width:fit-content;padding:.25rem .75rem;font-size:.75rem;font-weight:600;display:inline-flex}.status-active,.tag-success{background:var(--success-bg);color:var(--success)}.status-inactive,.tag-danger{background:var(--danger-bg);color:var(--danger)}.tag-warning{background:var(--warning-bg);color:var(--warning)}.tag-info{background:var(--info-bg);color:var(--info)}.tag-primary{background:var(--primary-bg);color:var(--primary)}.kpi-grid{grid-template-columns:repeat(4,1fr);gap:1rem;margin-bottom:1.5rem;display:grid}.kpi-card{background:var(--surface-color);border:1px solid var(--border-color);box-shadow:var(--shadow-sm);border-left:4px solid var(--primary);transition:var(--transition);cursor:default;padding:1.25rem}.kpi-card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}.kpi-card.success{border-left-color:var(--success)}.kpi-card.success:hover{box-shadow:0 4px 12px #05966933}.kpi-card.warning{border-left-color:var(--warning)}.kpi-card.warning:hover{box-shadow:0 4px 12px #ea580c33}.kpi-card.danger{border-left-color:var(--danger)}.kpi-card.danger:hover{box-shadow:0 4px 12px #dc262633}.kpi-title{color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;font-size:.75rem;font-weight:600}.kpi-value{color:var(--text-main);margin-top:.25rem;font-size:1.75rem;font-weight:700}.kpi-icon{border-radius:var(--border-radius-sm);justify-content:center;align-items:center;width:2.5rem;height:2.5rem;margin-bottom:.75rem;display:flex}.kpi-icon.blue{background:var(--primary-bg);color:var(--primary)}.kpi-icon.green{background:var(--success-bg);color:var(--success)}.kpi-icon.orange{background:var(--warning-bg);color:var(--warning)}.kpi-icon.red{background:var(--danger-bg);color:var(--danger)}.charts-grid{grid-template-columns:repeat(2,1fr);gap:1.5rem;margin-bottom:1.5rem;display:grid}.chart-card{padding:1.5rem}.chart-card h3{color:var(--text-main);margin-bottom:.25rem;font-size:1rem;font-weight:600}.chart-subtitle{color:var(--text-muted);margin-bottom:1rem;font-size:.8125rem}.chart-container{width:100%;height:300px}.table-wrap{border:1px solid var(--border-color);background:var(--surface-color);box-shadow:var(--shadow-sm);width:100%;overflow-x:auto}table{border-collapse:collapse;text-align:left;width:100%;font-size:.875rem}thead tr th{background:var(--bg-color);color:var(--text-muted);text-transform:uppercase;letter-spacing:.07em;border-bottom:2px solid var(--border-color);white-space:nowrap;padding:.875rem 1rem;font-size:.7rem;font-weight:600}tbody tr:nth-child(2n){background:#f8fafc80}tbody tr:hover{background:var(--primary-bg)!important}tbody tr:last-child td{border-bottom:none}td{color:var(--text-main);border-bottom:1px solid var(--border-color);padding:.875rem 1rem}td .btn{margin-right:.375rem}h1{color:var(--text-main);width:100%;margin:0 0 1.25rem;font-size:1.5rem;font-weight:700}.loading-text{text-align:center;color:var(--text-muted);padding:2rem;font-size:.875rem}.hero{background:radial-gradient(circle at 100% 0,#2563eb1f,#0000 40%),radial-gradient(circle at 0 100%,#05966914,#0000 35%),linear-gradient(#f8fafc,#f1f5f9);align-items:center;min-height:100vh;padding:4rem 0;display:flex}.hero-grid{grid-template-columns:1fr 1fr;align-items:center;gap:3rem;display:grid}.hero-copy h1{color:var(--text-main);margin-bottom:1rem;font-size:clamp(2rem,4vw,3rem);font-weight:800;line-height:1.1}.hero-copy>p{color:var(--text-secondary);margin-bottom:1.5rem;font-size:1.125rem;line-height:1.7}.hero-actions{gap:1rem;margin-bottom:2rem;display:flex}.btn-soft{background:var(--surface-color);border:1.5px solid var(--border-color);color:var(--text-secondary)}.btn-soft:hover{border-color:var(--primary);color:var(--primary)}.hero-points{flex-direction:column;gap:1rem;display:flex}.point strong{color:var(--text-main);margin-bottom:.25rem;font-size:.9375rem;display:block}.point div{color:var(--text-muted);font-size:.8125rem}.hero-card{background:var(--surface-color);border:1px solid var(--border-color);box-shadow:var(--shadow-md);padding:2rem}.hero-card h3{color:var(--text-main);margin-bottom:.75rem;font-size:1.25rem}.hero-card>p{color:var(--text-secondary);margin-bottom:1.5rem;font-size:.9375rem}.stat-grid{grid-template-columns:repeat(2,1fr);gap:1rem;display:grid}.stat{text-align:center;background:var(--primary-bg);padding:1rem}.stat strong{color:var(--primary);font-size:1.5rem;font-weight:700;display:block}.stat span{color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;font-size:.75rem}#services,#features,#about,#contact{background:var(--surface-color);padding:4rem 0}.section-head{text-align:center;margin-bottom:3rem}.admin-container,.superadmin-container{background:var(--bg-color);flex-direction:column;min-height:100vh;display:flex}.top-header-bar{border-bottom:1px solid var(--border-color);z-index:100;background:#fff;justify-content:space-between;align-items:center;height:64px;padding:0 1.5rem;display:flex;position:fixed;top:0;left:0;right:0}.admin-body,.superadmin-body{flex:1;min-height:calc(100vh - 64px);margin-top:64px;margin-left:280px;padding:1.5rem;transition:margin-left .3s}.admin-body .section,.superadmin-body .section,.admin-body .card,.superadmin-body .card{max-width:1400px;margin-left:auto;margin-right:auto}.admin-body .section.active,.superadmin-body .section.active{width:100%;display:block}.sidebar{background:var(--sidebar-bg);width:280px;height:calc(100vh - 64px);color:var(--sidebar-text);z-index:30;flex-direction:column;display:flex;position:fixed;top:64px;left:0;overflow-y:auto}.sidebar-header{border-bottom:1px solid #ffffff1a;padding:1.5rem}.sidebar-header h2{margin:0 0 .25rem;font-size:1.125rem;font-weight:600}.sidebar-header p{color:#fff9;margin:0;font-size:.75rem}.teacher-identity-card{background:#ffffff0d;border-bottom:1px solid #ffffff1a;align-items:center;gap:.75rem;padding:1rem 1.5rem;display:flex}.teacher-identity-avatar{background:var(--primary);color:#fff;border-radius:4px;justify-content:center;align-items:center;width:40px;height:40px;font-size:1rem;font-weight:600;display:flex}.teacher-identity-copy{flex:1;min-width:0}.teacher-identity-copy strong{white-space:nowrap;text-overflow:ellipsis;font-size:.875rem;font-weight:500;display:block;overflow:hidden}.teacher-identity-copy span{color:#fff9;white-space:nowrap;text-overflow:ellipsis;font-size:.75rem;display:block;overflow:hidden}.sidebar-actions{flex:1;padding:1rem 0;overflow-y:auto}.sidebar-actions button{color:#ffffffb3;text-align:left;cursor:pointer;background:0 0;border:none;border-left:3px solid #0000;align-items:center;gap:.75rem;width:100%;padding:.75rem 1.5rem;font-size:.875rem;font-weight:500;transition:all .2s;display:flex}.sidebar-actions button:hover{color:#fff;background:#ffffff1a}.sidebar-actions button.active{color:#fff;border-left-color:var(--primary);background:#2563eb26}.sidebar-actions button span:first-child{text-align:center;width:24px;font-size:1rem}.top-header-left{align-items:center;gap:1rem;display:flex}.top-logo{align-items:center;gap:.5rem;display:flex}.logo-icon{font-size:1.5rem}.logo-text{color:var(--text-main);font-size:1rem;font-weight:600}.top-header-right{align-items:center;gap:.5rem;display:flex}.top-header-item{position:relative}.top-header-btn{color:var(--text-secondary);cursor:pointer;background:0 0;border:none;justify-content:center;align-items:center;gap:.375rem;padding:.5rem;transition:all .2s;display:flex}.top-header-btn:hover{background:var(--bg-color);color:var(--text-main)}.top-header-btn svg{width:20px;height:20px}.mobile-menu-btn{background:var(--sidebar-bg);color:#fff;cursor:pointer;border:none;justify-content:center;align-items:center;width:36px;height:36px;font-size:1.25rem;display:none}.year-selector-top-btn{border:1px solid var(--border-color);background:#fff;padding:.5rem .75rem}.year-label{font-size:.875rem;font-weight:500}.user-btn{gap:.5rem;padding:.375rem .75rem}.user-avatar-small{background:var(--primary);color:#fff;justify-content:center;align-items:center;width:28px;height:28px;font-size:.75rem;font-weight:600;display:flex}.user-name-small{color:var(--text-main);font-size:.875rem;font-weight:500}.notification-badge{background:var(--danger);color:#fff;justify-content:center;align-items:center;min-width:18px;height:18px;padding:0 4px;font-size:.625rem;font-weight:600;display:flex;position:absolute;top:2px;right:2px}.notification-dropdown,.year-dropdown-top,.user-dropdown{border:1px solid var(--border-color);z-index:100;background:#fff;min-width:280px;position:absolute;top:calc(100% + 8px);right:0;box-shadow:0 10px 40px #00000026}.notification-header,.user-dropdown-header{border-bottom:1px solid var(--border-color);justify-content:space-between;align-items:center;padding:.75rem 1rem;display:flex}.notification-header h4,.user-dropdown-header strong{color:var(--text-main);margin:0;font-size:.875rem;font-weight:600}.notification-list{max-height:300px;overflow-y:auto}.notification-item{border-bottom:1px solid var(--border-color);padding:.75rem 1rem}.notification-item:last-child{border-bottom:none}.notification-item p{color:var(--text-main);margin:0;font-size:.875rem}.notification-time{color:var(--text-muted);font-size:.75rem}.notification-empty,.year-loading,.year-empty{text-align:center;color:var(--text-muted);padding:1.5rem;font-size:.875rem}.year-dropdown-top{min-width:200px}.year-option-top{text-align:left;cursor:pointer;width:100%;color:var(--text-main);background:0 0;border:none;justify-content:space-between;align-items:center;padding:.625rem 1rem;font-size:.875rem;transition:background .15s;display:flex}.year-option-top:hover{background:var(--bg-color)}.year-option-top.active{background:var(--primary-bg);color:var(--primary);font-weight:500}.inactive-tag{color:var(--text-muted);font-size:.75rem}.user-dropdown-header{gap:.75rem}.user-avatar-large{background:var(--primary);color:#fff;justify-content:center;align-items:center;width:48px;height:48px;font-size:1.25rem;font-weight:600;display:flex}.user-info-dropdown{flex:1}.user-info-dropdown strong{font-size:.9375rem;display:block}.user-info-dropdown span{color:var(--text-muted);font-size:.75rem;display:block}.user-dropdown-divider{background:var(--border-color);height:1px}.user-dropdown-item{text-align:left;cursor:pointer;width:100%;color:var(--text-main);background:0 0;border:none;align-items:center;gap:.75rem;padding:.75rem 1rem;font-size:.875rem;transition:background .15s;display:flex}.user-dropdown-item:hover{background:var(--bg-color)}.user-dropdown-item.logout-item{color:var(--danger)}.user-dropdown-item svg{width:18px;height:18px}.sidebar-backdrop{display:none}.admin-container .admin-body,.superadmin-container .superadmin-body{padding-top:80px}.section-head h2{color:var(--text-main);margin-bottom:.5rem;font-size:1.75rem;font-weight:700}.section-head p{color:var(--text-secondary);max-width:500px;margin:0 auto;font-size:1rem}.card-grid{grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:1.5rem;display:grid}.service-card,.feature-card{background:var(--bg-color);border:1px solid var(--border-color);transition:var(--transition);padding:1.5rem}.service-card:hover,.feature-card:hover{box-shadow:var(--shadow-md);border-color:var(--primary-light);transform:translateY(-3px)}.service-card span,.feature-card span{color:var(--primary);background:var(--primary-bg);margin-bottom:1rem;padding:.25rem .625rem;font-size:.75rem;font-weight:700;display:inline-block}.service-card h3,.feature-card h3{color:var(--text-main);margin-bottom:.5rem;font-size:1.125rem}.service-card p,.feature-card p{color:var(--text-secondary);font-size:.875rem;line-height:1.6}.about-shell{grid-template-columns:2fr 1fr;gap:2rem;display:grid}.about-card{background:var(--bg-color);padding:2rem}.about-card p{color:var(--text-secondary);font-size:1rem;line-height:1.8}.about-highlight{background:var(--success-bg);padding:2rem}.about-highlight h3{color:var(--success);margin-bottom:.5rem;font-size:1rem}.about-highlight p{color:var(--text-secondary);font-size:.875rem}.contact-grid{grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:1.5rem;display:grid}.contact-card{background:var(--bg-color);border:1px solid var(--border-color);padding:1.5rem}.contact-card h3{color:var(--text-main);margin-bottom:.5rem;font-size:1rem}.contact-card p{color:var(--text-secondary);font-size:.875rem}@media (width<=1024px){.hero-grid{text-align:center;grid-template-columns:1fr;gap:2rem}.hero-actions{justify-content:center}.hero-points{flex-flow:wrap;justify-content:center}.point{text-align:center;padding:.5rem}.about-shell{grid-template-columns:1fr}.sidebar{width:240px}.admin-body,.superadmin-body{margin-left:240px;padding:80px 1.5rem 1.5rem}.kpi-grid,.charts-grid{grid-template-columns:repeat(2,1fr)}.section{width:100%}.field-row{flex-wrap:wrap}.field-row>*{flex:calc(50% - .5rem);min-width:200px}}@media (width<=768px){.admin-container,.superadmin-container{flex-direction:column}.sidebar{z-index:100;width:260px;max-width:85vw;height:calc(100vh - 56px);transition:transform .3s;position:fixed;top:56px;left:0;transform:translate(-100%)}.admin-container.nav-open .sidebar,.superadmin-container.nav-open .sidebar{transform:translate(0)}.sidebar-backdrop{z-index:99;opacity:0;pointer-events:none;background:#00000080;transition:opacity .3s;display:block;position:fixed;inset:0}.admin-container.nav-open .sidebar-backdrop,.superadmin-container.nav-open .sidebar-backdrop{opacity:1;pointer-events:auto}.admin-body,.superadmin-body{min-height:calc(100vh - 56px);width:100vw!important;margin-left:0!important;padding:64px .625rem .625rem!important}.top-header-bar{justify-content:space-between;gap:.375rem;height:56px;padding:0 .5rem 0 .625rem;top:0;left:0;right:0;overflow:auto hidden}.top-header-left{flex-shrink:0;align-items:center;gap:.375rem;display:flex}.top-header-right{flex-shrink:0;align-items:center;gap:.125rem;display:flex}.mobile-menu-btn{background:var(--sidebar-bg);color:#fff;border:none;border-radius:4px;justify-content:center;align-items:center;width:32px;min-width:32px;height:32px;margin-right:.125rem;padding:0;font-size:1rem;display:flex}.top-logo{gap:.25rem}.top-logo .logo-icon{font-size:1.125rem}.top-logo .logo-text,.user-name-small{display:none}.top-header-item{flex-shrink:0;position:relative}.top-header-btn{cursor:pointer;background:0 0;border:none;justify-content:center;align-items:center;min-width:28px;height:28px;padding:.25rem;transition:all .15s;display:flex}.top-header-btn svg{stroke-width:2px;width:16px;height:16px}.top-header-btn:hover{background:var(--bg-color)}.top-header-item:first-child{display:none}.superadmin-container .logout-btn{border:1px solid var(--danger);color:var(--danger);background:0 0;padding:.375rem .625rem;font-size:.75rem}.superadmin-container .logout-btn:hover{background:var(--danger);color:#fff}.user-avatar-small{width:26px;height:26px;font-size:.6875rem}.year-selector-top-btn{border:1px solid var(--border-color);background:#fff;border-radius:4px;gap:.125rem;min-width:auto;padding:.25rem .375rem}.year-selector-top-btn svg{stroke-width:2px;width:12px!important;height:12px!important}.year-selector-top-btn svg:last-child{display:none}.year-label{font-size:.6875rem;display:none}.notification-wrapper .notification-btn{padding:.25rem;position:relative}.notification-badge{justify-content:center;align-items:center;min-width:14px;height:14px;padding:0 2px;font-size:.5rem;display:flex;position:absolute;top:0;right:0}.user-btn{gap:.125rem!important;padding:.25rem .375rem!important}.user-btn svg{display:none}.notification-dropdown,.year-dropdown-top,.user-dropdown{border-radius:16px 16px 0 0;width:100%;min-width:auto;max-height:60vh;animation:.2s slideUp;position:fixed;inset:auto 0 0}@keyframes slideUp{0%{transform:translateY(100%)}to{transform:translateY(0)}}.notification-header,.user-dropdown-header{z-index:1;background:#fff;border-radius:16px 16px 0 0;padding:.75rem 1rem;position:sticky;top:0}.notification-list{max-height:50vh;overflow-y:auto}.notification-item{padding:.5rem 1rem}.notification-header h4{margin:0;font-size:.875rem}.year-dropdown-top{max-height:50vh;overflow-y:auto}.year-option-top{padding:.5rem 1rem;font-size:.875rem}.user-dropdown{padding-bottom:.75rem}.user-dropdown-header{align-items:center;gap:.625rem;display:flex}.user-avatar-large{width:36px;height:36px;font-size:.9375rem}.user-info-dropdown strong{font-size:.8125rem}.user-info-dropdown span{font-size:.625rem}.user-dropdown-divider{margin:.375rem 0}.user-dropdown-item{padding:.5rem 1rem;font-size:.8125rem}.section{width:100%;padding:0;overflow-x:hidden}.section.active{width:100%;overflow-x:hidden}.main{width:100%;min-height:calc(100vh - 64px);margin-left:0;padding:80px 1rem 1rem}.kpi-grid,.charts-grid{grid-template-columns:1fr}.chart-card{padding:1rem}.chart-container{height:250px}.field-row{flex-direction:column}.field-row>*{width:100%}.card{padding:1rem;overflow-x:auto}.hero{min-height:auto;padding:2rem 0}.hero-card{padding:1.5rem}.stat-grid{grid-template-columns:1fr 1fr}.card-grid{grid-template-columns:1fr}.section-head h2{font-size:1.5rem}.hero-copy h1{font-size:1.75rem}.hero-copy>p{font-size:1rem}.table-wrap{-webkit-overflow-scrolling:touch;scroll-behavior:smooth;background:var(--surface-color);border-left:none;border-right:none;border-bottom:1px solid var(--border-color);border-radius:0;margin:0 -.75rem;overflow-x:auto}td .status-active,td .status-inactive{padding:.0625rem .375rem;font-size:.5625rem}.table-wrap:after{content:"→";background:var(--text-muted);color:#fff;opacity:.5;pointer-events:none;border-radius:50%;justify-content:center;align-items:center;width:24px;height:24px;font-size:.75rem;animation:2s infinite pulse;display:none;position:fixed;bottom:50%;right:.5rem}@keyframes pulse{0%,to{opacity:.3}50%{opacity:.7}}table{min-width:500px;font-size:.75rem}thead tr th{white-space:nowrap;background:var(--bg-color);z-index:1;padding:.5rem .625rem;font-size:.625rem;position:sticky;top:0}tbody tr{background:var(--surface-color)}tbody tr:hover{background:var(--primary-bg)}tbody tr:nth-child(2n){background:#f8fafc80}td{white-space:nowrap;vertical-align:middle;padding:.5rem .625rem}td>div{flex-wrap:wrap!important;gap:.25rem!important;display:flex!important}td>div .btn{white-space:nowrap;padding:.25rem .5rem!important;font-size:.625rem!important}td .status-active,td .status-inactive,td[data-label=Status],td[data-label=Status] *{padding:.125rem .5rem;font-size:.625rem}td[colSpan]{text-align:center;white-space:nowrap;padding:1.5rem!important}.report-actions{flex-direction:column;gap:.5rem}.report-actions .btn{width:100%}.marksheet-preview{overflow-x:auto;padding:1rem!important}.report-header h2{font-size:1.25rem}.student-details{font-size:.875rem;flex-direction:column!important;gap:.5rem!important}.report-table{font-size:.75rem}.report-table th,.report-table td{padding:.5rem!important}.report-footer{flex-direction:column;gap:.5rem}.Teachers .field-row{flex-direction:column}.Teachers .table-wrap{overflow-x:auto}.Teachers table{min-width:700px}.Teachers td>div{max-width:180px;flex-wrap:wrap!important;gap:4px!important;display:flex!important}.Teachers td>div .btn{text-align:center;flex:auto!important;min-width:60px!important}.Schools .field-row{flex-direction:column}.Schools .field-row>*{min-width:100%}.Schools .panel{border-left:none;border-right:none;border-radius:0;margin:0 -1rem;padding:1rem}.Schools .kpi-grid{gap:.75rem;grid-template-columns:repeat(2,1fr)!important}.Schools .kpi-card{padding:.875rem}.Schools .kpi-value{font-size:1.25rem}.Schools .kpi-title{font-size:.6875rem}.Schools .table-wrap{overflow-x:auto}.Schools table{min-width:600px}.Schools td .btn{margin:2px 4px 2px 0;padding:.375rem .5rem;font-size:.6875rem;display:inline-block!important}}@media (width<=480px){.hero-actions{flex-direction:column}.hero-actions .btn{width:100%}.stat-grid,.kpi-grid,.charts-grid{grid-template-columns:1fr}.chart-container{height:220px}.contact-grid,.card-grid{grid-template-columns:1fr}.sidebar button,.sidebar .nav-link{padding:.625rem .875rem;font-size:.8125rem}.sidebar button span,.sidebar .nav-link span{margin-right:.375rem}.mobile-header{padding:.75rem}.mobile-menu-btn{color:#fff;cursor:pointer;background:#1a1a1a;border:none;border-radius:4px;justify-content:center;align-items:center;width:2.25rem;height:2.25rem;margin-right:.75rem;font-size:1.25rem;display:flex}.mobile-header-copy strong{font-size:.875rem}.reports-filters{padding:.75rem}.report-card{border-left:none;border-right:none;border-radius:4px;margin:0 -.5rem;padding:.75rem}.report-actions .btn{width:100%;padding:.875rem}.Teachers .field-row{padding:.5rem}.Teachers .field-row>*{min-width:100%}.Teachers table{min-width:550px;font-size:.75rem}.Teachers td>div{max-width:150px}.Teachers td>div .btn{min-width:50px!important;padding:.25rem .375rem!important;font-size:.625rem!important}.Schools .kpi-grid{grid-template-columns:1fr 1fr!important}.Schools .kpi-card{padding:.625rem}.Schools .kpi-value{font-size:1rem}.Schools .kpi-title{font-size:.625rem}.Schools table{min-width:500px;font-size:.75rem}.Schools td .btn{padding:.25rem .375rem;font-size:.625rem}}@media print{body *{visibility:hidden}.marksheet-preview,.marksheet-preview *{visibility:visible}.marksheet-preview{width:100%;position:absolute;top:0;left:0;background:#fff!important;padding:2rem!important}.report-actions{display:none!important}.section.active{background:#fff!important;margin:0!important;padding:0!important}.report-table,.report-table th,.report-table td{border:1px solid #333!important}}.page-header{flex-wrap:wrap;justify-content:space-between;align-items:flex-start;gap:1rem;margin-bottom:1.5rem;display:flex}.page-header h1{margin-bottom:0}.filter-tabs{gap:.5rem;margin-bottom:1rem;display:flex}.filter-tab{background:var(--surface-color);border:1px solid var(--border-color);border-radius:var(--border-radius-sm);color:var(--text-secondary);cursor:pointer;transition:var(--transition);padding:.5rem 1rem;font-size:.875rem;font-weight:500}.filter-tab:hover{border-color:var(--primary);color:var(--primary)}.filter-tab.active{background:var(--primary);border-color:var(--primary);color:#fff}.target-options{gap:1rem;margin-bottom:1rem;display:flex}.radio-option{background:var(--bg-color);border:2px solid var(--border-color);border-radius:var(--border-radius-sm);cursor:pointer;transition:var(--transition);align-items:center;gap:.5rem;padding:.75rem 1rem;display:flex}.radio-option input{width:auto;margin:0}.radio-option.selected{border-color:var(--primary);background:var(--primary-bg)}.school-selector{background:var(--bg-color);border:1px solid var(--border-color);border-radius:var(--border-radius-sm);margin-top:1rem;padding:1rem}.school-selector-header{color:var(--text-secondary);justify-content:space-between;align-items:center;margin-bottom:.75rem;font-size:.875rem;font-weight:600;display:flex}.school-selector-actions{gap:.5rem;display:flex}.school-list{grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:.5rem;max-height:250px;display:grid;overflow-y:auto}.school-item{background:var(--surface-color);border:1px solid var(--border-color);border-radius:var(--border-radius-sm);cursor:pointer;transition:var(--transition);align-items:center;gap:.5rem;padding:.5rem .75rem;font-size:.875rem;display:flex}.school-item:hover{border-color:var(--primary-light)}.school-item.selected{border-color:var(--primary);background:var(--primary-bg)}.school-item input{width:auto;margin:0}.school-item .status-badge{margin-left:auto;padding:.125rem .375rem;font-size:.625rem}.priority-badge{text-transform:uppercase;letter-spacing:.03em;border-radius:20px;align-items:center;padding:.125rem .5rem;font-size:.6875rem;font-weight:600;display:inline-flex}.priority-badge.low{background:var(--bg-color);color:var(--text-muted)}.priority-badge.normal{background:var(--info-bg);color:var(--info)}.priority-badge.high{background:var(--warning-bg);color:var(--warning)}.priority-badge.urgent{background:var(--danger-bg);color:var(--danger)}.notification-list{flex-direction:column;gap:.75rem;display:flex}.notification-card{background:var(--surface-color);border:1px solid var(--border-color);border-left:4px solid var(--primary);border-radius:var(--border-radius-sm);transition:var(--transition);gap:1rem;padding:1rem;display:flex}.notification-card:hover{box-shadow:var(--shadow-sm)}.notification-card.unread{background:var(--primary-bg)}.notification-icon{border-radius:var(--border-radius-sm);flex-shrink:0;justify-content:center;align-items:center;width:40px;height:40px;font-size:1.25rem;display:flex}.notification-content{flex:1;min-width:0}.notification-header{align-items:center;gap:.5rem;margin-bottom:.25rem;display:flex}.notification-header strong{color:var(--text-main);font-size:.9375rem}.unread-badge{background:var(--primary);color:#fff;text-transform:uppercase;border-radius:20px;padding:.125rem .5rem;font-size:.625rem;font-weight:700}.notification-message{color:var(--text-secondary);margin-bottom:.5rem;font-size:.875rem;line-height:1.5}.notification-meta{flex-wrap:wrap;align-items:center;gap:.5rem;display:flex}.notification-date{color:var(--text-muted);margin-left:auto;font-size:.75rem}.notification-actions{flex-direction:column;flex-shrink:0;gap:.5rem;display:flex}.empty-state{text-align:center;color:var(--text-muted);padding:2rem}.view-all-link{color:var(--primary);font-size:.75rem;text-decoration:none}.view-all-link:hover{text-decoration:underline}.reports-page{width:100%;max-width:100%;overflow-x:hidden}.reports-page h1{color:var(--text-main);margin-bottom:1.5rem;font-size:1.5rem}.reports-filters{flex-wrap:wrap;align-items:flex-end;gap:1rem;margin-bottom:1.5rem;display:flex}.filter-group{flex:1;min-width:150px}.filter-group label{color:var(--text-secondary);margin-bottom:.5rem;font-size:.8125rem;font-weight:600;display:block}.filter-group select{width:100%}.filter-btn{white-space:nowrap;height:42px}.student-select{max-width:400px;margin-bottom:1rem}.report-actions{gap:.5rem;margin-bottom:1rem;display:flex}.report-card{border:1px solid var(--border-color);box-shadow:var(--shadow-sm);background:#fff;border-radius:4px;padding:1.5rem}.report-card-header{text-align:center;border-bottom:2px solid var(--primary);margin-bottom:1.5rem;padding-bottom:1rem}.report-card-header h2{color:var(--text-main);margin:0 0 .5rem;font-size:1.5rem}.report-card-header p{color:var(--text-secondary);margin:0;font-size:.875rem}.report-info-grid{background:var(--bg-color);border-radius:4px;grid-template-columns:repeat(3,1fr);gap:1rem;margin-bottom:1.5rem;padding:1rem;display:grid}.info-item{flex-direction:column;gap:.25rem;display:flex}.info-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;font-size:.75rem}.info-value{color:var(--text-main);font-size:.9375rem;font-weight:600}.report-subjects{border:1px solid var(--border-color);border-radius:4px;margin-bottom:1.5rem;overflow:hidden}.subject-header{background:var(--primary);color:#fff;justify-content:space-between;padding:.75rem 1rem;font-size:.875rem;font-weight:600;display:flex}.subject-row{border-bottom:1px solid var(--border-color);justify-content:space-between;padding:.75rem 1rem;font-size:.9375rem;display:flex}.subject-row:last-child{border-bottom:none}.subject-row span:first-child{color:var(--text-main)}.mark-value{color:var(--primary);font-weight:600}.total-row{background:var(--bg-color);font-weight:700}.total-row .mark-value{color:var(--success)}.report-summary{background:var(--bg-color);border-radius:4px;gap:2rem;margin-bottom:1.5rem;padding:1rem;display:flex}.summary-item{flex-direction:column;gap:.25rem;display:flex}.summary-item span{color:var(--text-muted);font-size:.75rem}.summary-item strong{color:var(--text-main);font-size:1.25rem}.report-signatures{justify-content:space-between;margin-top:2rem;padding-top:1rem;display:flex}.signature-line{text-align:center;border-top:1px solid var(--text-main);width:45%;color:var(--text-secondary);padding-top:.5rem;font-size:.875rem}.class-report-table{border:1px solid var(--border-color);border-radius:4px;overflow:hidden}.class-report-header{background:var(--primary);color:#fff;gap:.5rem;padding:.75rem 1rem;font-size:.8125rem;font-weight:600;display:flex}.class-report-header span,.class-report-row span{flex:1;min-width:0}.class-report-header span:first-child,.class-report-row span:first-child{flex:.8}.class-report-header span:nth-child(2),.class-report-row span:nth-child(2){flex:1.5}.class-report-row{border-bottom:1px solid var(--border-color);align-items:center;gap:.5rem;padding:.75rem 1rem;font-size:.875rem;display:flex}.class-report-row:last-child{border-bottom:none}.class-report-row.alt{background:var(--bg-color)}.student-name{white-space:nowrap;text-overflow:ellipsis;overflow:hidden}.no-data{text-align:center;color:var(--text-muted);padding:2rem}.text-center{text-align:center}.fw-bold{font-weight:700}@media (width<=1024px){.reports-filters{flex-direction:column;align-items:stretch}.filter-group{min-width:100%}.filter-btn{width:100%}.report-info-grid{grid-template-columns:repeat(2,1fr)}.report-summary{flex-direction:column;gap:1rem}.class-report-header span:nth-child(n+3),.class-report-row span:nth-child(n+3){display:none}.class-report-header:after,.class-report-row:after{content:"";flex:.5}}@media (width<=768px){.reports-page{padding:1rem}.reports-filters{flex-direction:column;gap:.75rem}.filter-group{min-width:100%}.filter-btn{width:100%;height:48px;font-size:1rem}.student-select{max-width:100%}.report-card{padding:1rem}.report-card-header h2{font-size:1.25rem}.report-info-grid{grid-template-columns:1fr;gap:.75rem}.info-item{border-bottom:1px solid var(--border-color);flex-direction:row;justify-content:space-between;padding:.5rem 0}.info-item:last-child{border-bottom:none}.subject-header,.subject-row{padding:.625rem .75rem;font-size:.8125rem}.report-summary{padding:.75rem}.report-signatures{flex-direction:column;align-items:center;gap:2rem;margin-top:1.5rem}.signature-line{width:60%}.report-actions{flex-direction:column}.report-actions .btn{width:100%;padding:.875rem}.class-report-table{overflow-x:auto}.class-report-header,.class-report-row{min-width:500px}}@media (width<=480px){.reports-page{padding:.75rem}.reports-page h1{margin-bottom:1rem;font-size:1.25rem}.report-card{padding:.75rem}.report-card-header h2{font-size:1.125rem}.report-card-header p{font-size:.75rem}.subject-header span:last-child,.subject-row span:last-child{text-align:right}.summary-item strong{font-size:1.125rem}.signature-line{width:80%;font-size:.75rem}}.attendance-stats{background:var(--bg-secondary);border-radius:var(--border-radius);gap:1.5rem;margin-bottom:1rem;padding:1rem;display:flex}.attendance-stats .stat{border-radius:var(--border-radius);background:var(--bg-primary);padding:.25rem .75rem;font-weight:600}.attendance-stats .stat.present{background:var(--success-bg);color:var(--success)}.attendance-stats .stat.absent{background:var(--danger-bg);color:var(--danger)}.attendance-list{flex-direction:column;gap:.5rem;margin-top:1rem;display:flex}.attendance-item{background:var(--bg-secondary);border-radius:var(--border-radius);justify-content:space-between;align-items:center;padding:.75rem 1rem;display:flex}.attendance-item .student-info{flex-direction:column;gap:.25rem;display:flex}.attendance-item .student-name{color:var(--text-primary);font-weight:600}.attendance-item .student-reg{color:var(--text-muted);font-size:.75rem}.attendance-buttons{gap:.5rem;display:flex}.attendance-buttons .btn{min-width:80px;padding:.5rem 1rem}.form-actions{border-top:1px solid var(--border-color);margin-top:1.5rem;padding-top:1rem}.modal-overlay{z-index:1000;background:#00000080;justify-content:center;align-items:center;padding:1rem;display:flex;position:fixed;inset:0}.modal-content{background:var(--surface-color);border-radius:4px;width:100%;max-width:500px;max-height:90vh;padding:1.5rem;overflow-y:auto;box-shadow:0 25px 50px -12px #00000040}.modal-content h3{color:var(--text-main);margin-bottom:.5rem;font-size:1.125rem;font-weight:600}@media (width<=768px){.modal-overlay{align-items:flex-end;padding:.5rem}.modal-content{border-radius:16px 16px 0 0;max-width:100%;max-height:85vh;padding:1rem}.modal-content .field-row{flex-direction:column}.modal-content .field-row>*{min-width:100%}.TeacherMarks .field-row,.TeacherReports .field-row{flex-direction:column}.TeacherMarks .field-row>*,.TeacherReports .field-row>*{min-width:100%}.TeacherMarks .table-wrap,.TeacherReports .table-wrap{overflow-x:auto}.TeacherMarks table,.TeacherReports table{min-width:500px;font-size:.8125rem}.TeacherMarks .marks-grid{flex-direction:column;gap:.5rem;display:flex}.TeacherMarks .mark-input{width:100%;min-width:auto;padding:.5rem;font-size:.875rem}.TeacherMarks .marks-header,.TeacherMarks .marks-row{grid-template-columns:2fr 2fr 1.5fr;gap:.5rem;padding:.5rem;display:grid}.TeacherMarks .marks-header{display:none}.TeacherMarks .marks-row{border-bottom:1px solid var(--border-color);align-items:center}.TeacherMarks .student-name{white-space:nowrap;text-overflow:ellipsis;font-size:.875rem;font-weight:500;overflow:hidden}}.btn{border-radius:var(--border-radius);cursor:pointer;border:none;justify-content:center;align-items:center;gap:.5rem;padding:.625rem 1.25rem;font-size:.875rem;font-weight:500;transition:all .2s;display:inline-flex}.btn-primary{background:var(--primary);color:#fff}.btn-primary:hover{background:var(--primary-dark)}.btn-secondary{background:var(--bg-color);color:var(--text-main);border:1px solid var(--border-color)}.btn-secondary:hover{background:var(--surface-hover)}.btn-success{background:var(--success);color:#fff;border:none}.btn-success:hover{background:#047857}.btn-warning{background:var(--warning);color:#fff;border:none}.btn-warning:hover{background:#c2410c}.result-body{background:0 0!important;height:100vh!important;margin:0!important;padding:0!important;overflow:hidden!important}.result-page-container{box-sizing:border-box;background:linear-gradient(135deg,#667eea 0%,#764ba2 50%,#f093fb 100%);flex-direction:column;justify-content:center;align-items:center;gap:.75rem;width:100%;height:100dvh;padding:1rem;display:flex;position:relative;overflow:hidden}.result-page-container .section{width:100%;max-width:800px}.result-hero{text-align:center;flex-shrink:0;margin-bottom:0}.school-badge{background:#fffffff2;border-radius:50px;align-items:center;gap:.75rem;padding:.625rem 1.25rem;display:inline-flex;box-shadow:0 8px 30px #00000026}.school-icon{color:#fff;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:4px;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;display:flex}.school-icon svg{width:20px;height:20px}.school-badge h1{background:linear-gradient(135deg,#667eea,#764ba2);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;margin:0;font-size:1.125rem}.school-badge p{color:var(--text-secondary);margin:0;font-size:.75rem}.result-search-card{text-align:center;background:#fffffffa;border-radius:20px;flex-shrink:0;width:100%;max-width:380px;padding:1.25rem 1.5rem;box-shadow:0 15px 45px #0003}.student-login-form .input-wrapper input{text-align:left}.search-icon{background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);border-radius:50%;justify-content:center;align-items:center;width:48px;height:48px;margin:0 auto 1rem;display:flex}.search-icon svg{color:#fff;width:24px;height:24px}.result-search-card h2{color:var(--text-main);margin:0 0 .375rem;font-size:1.25rem}.result-search-card>p{color:var(--text-secondary);margin:0 0 1rem;font-size:.875rem}.error-message{color:#dc2626;background:#fef2f2;border-radius:4px;justify-content:center;align-items:center;gap:.5rem;margin-top:.75rem;padding:.75rem;font-size:.8125rem;display:flex}.error-message svg{flex-shrink:0;width:18px;height:18px}.student-login-form .input-wrapper input{border:2px solid #e5e7eb;border-radius:4px;width:100%;padding:.875rem 1rem .875rem 3rem;font-size:1rem;transition:all .3s}.student-login-form{flex-direction:column;gap:.75rem;display:flex}.student-login-form .input-group{text-align:left}.student-login-form .input-group label{color:var(--text-main);margin-bottom:.375rem;font-size:.8125rem;font-weight:600;display:block}.student-login-form .input-wrapper{align-items:center;display:flex;position:relative}.student-login-form .input-icon{width:18px;height:18px;color:var(--text-secondary);justify-content:center;align-items:center;display:flex;position:absolute;left:.875rem}.student-login-form .input-icon svg{width:18px;height:18px}.student-login-form .input-wrapper input{text-align:left;border:2px solid #e5e7eb;border-radius:4px;width:100%;padding:.75rem 1rem .75rem 2.75rem;font-size:.9375rem;transition:all .3s}.student-login-form .input-wrapper input:focus{border-color:#667eea;outline:none;box-shadow:0 0 0 4px #667eea26}.student-info-card{background:#fffffffa;border-radius:16px;flex-shrink:0;align-items:center;gap:1rem;width:100%;max-width:380px;padding:1rem 1.25rem;display:flex;box-shadow:0 10px 40px #00000026}.student-details{flex:1;min-width:0}.student-details h3{color:var(--text-main);white-space:nowrap;text-overflow:ellipsis;margin:0 0 .25rem;font-size:1rem;overflow:hidden}.student-info-card .logout-btn{color:#dc2626;cursor:pointer;white-space:nowrap;background:#fef2f2;border:1px solid #fecaca;border-radius:4px;padding:.375rem .75rem;font-size:.75rem;font-weight:500;transition:all .3s}.exam-select-card{text-align:center;background:#fffffffa;border-radius:14px;flex-shrink:0;width:100%;max-width:380px;padding:1rem 1.25rem;box-shadow:0 10px 40px #00000026}.exam-select-card select:focus{border-color:#667eea;outline:none;box-shadow:0 0 0 4px #667eea26}.loading-state{text-align:center;padding:1rem}.loading-state .spinner{border:3px solid #ffffff4d;border-top-color:#fff;border-radius:50%;width:36px;height:36px;margin:0 auto .75rem;animation:.8s linear infinite spin}.loading-state p{color:#fff;margin:0;font-size:.875rem}.result-error-card h2{color:var(--text-main);margin:0 0 .75rem;font-size:1.25rem}.result-error-card p{color:var(--text-secondary);margin:0 0 1.5rem;font-size:.875rem}.btn-home{color:#fff;background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);border-radius:4px;align-items:center;gap:.5rem;padding:.75rem 1.5rem;font-size:.875rem;font-weight:600;text-decoration:none;transition:all .3s;display:inline-flex}.result-card{background:#fffffffa;border-radius:20px;flex-shrink:0;width:100%;max-width:380px;max-height:calc(100vh - 150px);overflow:hidden auto;box-shadow:0 20px 60px #00000040}.result-header{background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);justify-content:space-between;align-items:center;padding:1rem 1.25rem;display:flex}.result-avatar{background:#fff3;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:40px;height:40px;display:flex}.result-student h2{color:#fff;margin:0;font-size:1rem}.result-student p{color:#fffc;margin:.125rem 0 0;font-size:.75rem}.result-marks th{text-align:left;text-transform:uppercase;letter-spacing:.5px;color:var(--text-secondary);border-bottom:2px solid #e5e7eb;padding:.5rem .375rem;font-size:.6875rem}.result-marks td{color:var(--text-main);border-bottom:1px solid #f3f4f6;padding:.5rem .375rem;font-size:.8125rem}.result-marks tr:last-child td{border-bottom:none}.result-summary{background:#f9fafb;padding:1rem 1.25rem}.summary-main{justify-content:space-around;align-items:center;gap:1rem;margin-bottom:1rem;display:flex}.percent-value{color:var(--text-main);font-size:1.25rem;font-weight:700;display:block}.percent-label{text-transform:uppercase;color:var(--text-secondary);font-size:.5625rem;display:block}.grade-letter{background:linear-gradient(135deg,#667eea,#764ba2);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;font-size:2rem;font-weight:800;display:block}.grade-label{text-transform:uppercase;color:var(--text-secondary);font-size:.625rem;display:block}.item-value{color:var(--text-main);font-size:.9375rem;font-weight:700;display:block}.item-label{color:var(--text-secondary);margin-top:.125rem;font-size:.625rem;display:block}.text-success{color:#16a34a}.text-danger{color:#dc2626}.status-item.pass svg,.status-item.pass .item-value{color:#16a34a}.status-item.fail svg,.status-item.fail .item-value{color:#dc2626}.result-footer{text-align:center;flex-shrink:0;padding:.5rem}.result-footer p{color:#fffc;margin:0;font-size:.75rem}.loading-spinner{flex-direction:column;justify-content:center;align-items:center;height:100vh;display:flex}.loading-spinner .spinner{border:3px solid #ffffff4d;border-top-color:#fff;border-radius:50%;width:40px;height:40px;margin-bottom:1rem;animation:.8s linear infinite spin}.loading-spinner p{color:#fff;margin:0;font-size:.875rem}@media (width<=768px){.result-page-container{justify-content:flex-start;gap:1rem;height:auto;min-height:100dvh;padding:2rem 1rem 1rem;overflow-y:auto}.school-badge{gap:.5rem;padding:.5rem 1rem}.school-icon{border-radius:4px;width:32px;height:32px}.school-icon svg{width:18px;height:18px}.school-badge h1{font-size:1rem}.school-badge p{font-size:.6875rem}.result-search-card,.student-info-card,.exam-select-card,.result-card,.result-error-card{max-width:100%}.result-search-card{padding:1.5rem}.result-card{max-height:none}.search-icon{width:56px;height:56px}.search-icon svg{width:28px;height:28px}.result-search-card h2{font-size:1.5rem}.summary-grid{grid-template-columns:repeat(3,1fr)}}@media (width<=480px){.result-page-container{padding:1.5rem .75rem .75rem}.school-badge h1{font-size:.875rem}.result-search-card{border-radius:16px;padding:1.25rem}.result-search-card h2{font-size:1.25rem}.result-search-card>p{font-size:.8125rem}.result-card{border-radius:16px}.result-header{flex-direction:column;align-items:flex-start;gap:.5rem;padding:.875rem 1rem}.result-exam-badge{align-self:flex-end}.percentage-circle{width:70px;height:70px}.grade-letter{font-size:1.75rem}.summary-grid{gap:.375rem}.summary-item{padding:.5rem}.summary-item svg{width:16px;height:16px}.item-value{font-size:.8125rem}.result-footer{margin-top:auto}}.student-login-form .login-btn{color:#fff;cursor:pointer;background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);border:none;border-radius:4px;justify-content:center;align-items:center;gap:.5rem;margin-top:.5rem;padding:1rem 2rem;font-size:1rem;font-weight:600;transition:all .3s;display:flex}.student-login-form .login-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 8px 25px #667eea66}.student-login-form .login-btn:disabled{opacity:.7;cursor:not-allowed}.student-login-form .login-btn svg{width:20px;height:20px}.login-toggle{border-top:1px solid #e5e7eb;margin-top:1.5rem;padding-top:1.5rem}.toggle-link{color:#667eea;cursor:pointer;background:0 0;border:none;font-size:.875rem;text-decoration:underline}.toggle-link:hover{color:#764ba2}.student-info-card{background:#fffffffa;border-radius:20px;align-items:center;gap:1.5rem;width:100%;max-width:420px;padding:1.5rem 2rem;display:flex;box-shadow:0 10px 40px #00000026}.student-avatar{background:linear-gradient(135deg,#667eea,#764ba2);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:64px;height:64px;display:flex}.student-avatar svg{color:#fff;width:32px;height:32px}.student-details h3{color:var(--text-main);margin:0 0 .5rem;font-size:1.25rem}.detail-row{flex-wrap:wrap;gap:1.5rem;display:flex}.detail-row span{color:var(--text-secondary);font-size:.875rem}.student-info-card .logout-btn{color:#dc2626;cursor:pointer;background:#fef2f2;border:1px solid #fecaca;border-radius:4px;margin-left:auto;padding:.5rem 1rem;font-size:.875rem;font-weight:500;transition:all .3s}.student-info-card .logout-btn:hover{color:#fff;background:#dc2626}.exam-select-card{text-align:center;background:#fffffffa;border-radius:16px;width:100%;max-width:420px;padding:1.5rem 2rem;box-shadow:0 10px 40px #00000026}.exam-select-card label{color:var(--text-secondary);margin-bottom:.75rem;font-size:.875rem;display:block}.exam-select-card select{cursor:pointer;background:#fff;border:2px solid #e5e7eb;border-radius:4px;width:100%;padding:.875rem 1rem;font-size:1rem}.exam-select-card select:focus{border-color:#667eea;outline:none}.loading-state{text-align:center;color:#fff;padding:2rem}.spinner{border:4px solid #ffffff4d;border-top-color:#fff;border-radius:50%;width:48px;height:48px;margin:0 auto 1rem;animation:.8s linear infinite spin}.loading-spinner{color:#fff;flex-direction:column;justify-content:center;align-items:center;min-height:100vh;display:flex}.loading-spinner .spinner{border-color:#fff #ffffff4d #ffffff4d}.result-card{background:#fffffffa;border-radius:24px;width:100%;max-width:420px;overflow:hidden;box-shadow:0 20px 60px #00000040}.result-header{background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);flex-wrap:wrap;justify-content:space-between;align-items:center;gap:1rem;padding:1.5rem 2rem;display:flex}.result-student{align-items:center;gap:1rem;display:flex}.result-avatar{background:#fff3;border-radius:50%;justify-content:center;align-items:center;width:56px;height:56px;display:flex}.result-avatar svg{color:#fff;width:28px;height:28px}.result-header h2{color:#fff;margin:0;font-size:1.5rem}.result-header p{color:#fffc;margin:0;font-size:.875rem}.result-exam-badge{color:#fff;background:#fff3;border-radius:20px;padding:.5rem 1rem;font-size:.875rem;font-weight:500}.result-marks{padding:1.5rem 2rem}.result-marks table{border-collapse:collapse;width:100%}.result-marks th{text-align:left;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em;border-bottom:2px solid #e5e7eb;padding:.75rem;font-size:.75rem}.result-marks td{color:var(--text-main);border-bottom:1px solid #f3f4f6;padding:1rem .75rem}.result-marks tbody tr:last-child td{border-bottom:none}.result-marks tbody tr:hover{background:#f9fafb}.grade-badge{border-radius:20px;padding:.25rem .75rem;font-size:.875rem;font-weight:600;display:inline-block}.grade-a-plus{color:#059669;background:#d1fae5}.grade-a{color:#2563eb;background:#dbeafe}.grade-b-plus{color:#d97706;background:#fef3c7}.grade-b{color:#4f46e5;background:#e0e7ff}.grade-c{color:#ea580c;background:#fed7aa}.grade-d{color:#db2777;background:#fce7f3}.grade-f{color:#dc2626;background:#fee2e2}.result-summary{background:#f9fafb;border-top:1px solid #e5e7eb;padding:2rem}.summary-main{flex-wrap:wrap;justify-content:center;align-items:center;gap:3rem;margin-bottom:2rem;display:flex}.percentage-circle{width:140px;height:140px;position:relative}.percentage-circle svg{width:100%;height:100%;transform:rotate(-90deg)}.percentage-text{text-align:center;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.percent-value{color:var(--text-main);font-size:2rem;font-weight:700;line-height:1;display:block}.percent-label{color:var(--text-secondary);margin-top:.25rem;font-size:.75rem;display:block}.grade-display{text-align:center}.grade-letter{background:linear-gradient(135deg,#667eea,#764ba2);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;font-size:4rem;font-weight:800;line-height:1;display:block}.grade-label{color:var(--text-secondary);margin-top:.5rem;font-size:.875rem;display:block}.summary-grid{grid-template-columns:repeat(auto-fit,minmax(100px,1fr));gap:1rem;display:grid}.summary-item{text-align:center;background:#fff;border-radius:16px;padding:1rem;box-shadow:0 2px 8px #0000000d}.summary-item svg{width:24px;height:24px;color:var(--text-secondary);margin-bottom:.5rem}.summary-item .item-value{color:var(--text-main);font-size:1.25rem;font-weight:700;display:block}.summary-item .item-label{color:var(--text-secondary);margin-top:.25rem;font-size:.75rem;display:block}.status-item.pass{background:#d1fae5}.status-item.pass svg,.status-item.pass .item-value{color:#059669}.status-item.fail{background:#fee2e2}.status-item.fail svg,.status-item.fail .item-value{color:#dc2626}.result-error-card{text-align:center;background:#fffffffa;border-radius:24px;max-width:400px;padding:3rem;box-shadow:0 20px 60px #00000040}.error-icon{color:#dc2626;background:#fee2e2;border-radius:50%;justify-content:center;align-items:center;width:80px;height:80px;margin:0 auto 1.5rem;font-size:3rem;font-weight:700;display:flex}.result-error-card h2{color:var(--text-main);margin:0 0 .5rem}.result-error-card p{color:var(--text-secondary);margin:0 0 1.5rem}.btn-home{color:#fff;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:4px;padding:.875rem 2rem;font-weight:600;text-decoration:none;transition:all .3s;display:inline-block}.btn-home:hover{transform:translateY(-2px);box-shadow:0 8px 25px #667eea66}.result-footer{text-align:center;color:#fffc;margin-top:auto;padding-top:2rem;font-size:.875rem}.result-footer strong{color:#fff}@media (width<=640px){.result-page-container{padding:1rem .75rem}.school-badge{text-align:center;flex-direction:column;padding:.75rem 1.25rem}.result-search-card{border-radius:20px;padding:1.5rem}.result-card{border-radius:20px}.result-header{text-align:center;flex-direction:column}.result-marks{padding:1rem;overflow-x:auto}.result-summary{padding:1.5rem 1rem}.summary-main{gap:1.5rem}.percentage-circle{width:100px;height:100px}.grade-letter{font-size:2.5rem}}
