@import"https://fonts.googleapis.com/css2?family=Plus+Jakarta+Sans:wght@400;500;600;700;800&display=swap";:root{--midnight-navy: #0f172a;--deep-charcoal: #1e293b;--slate-dark: #334155;--cyber-blue: #00d4ff;--electric-blue: #3b82f6;--neon-emerald: #10b981;--tropical-emerald: #059669;--electric-violet: #8b5cf6;--neon-purple: #a855f7;--sunset-orange: #f97316;--crimson: #dc2626;--soft-crimson: #ef4444;--glass-white: rgba(255, 255, 255, .08);--glass-border: rgba(255, 255, 255, .1);--text-primary: #f8fafc;--text-secondary: #94a3b8;--text-muted: #64748b;--font-primary: "Plus Jakarta Sans", "Inter", -apple-system, BlinkMacSystemFont, sans-serif;--blur-heavy: blur(40px);--blur-medium: blur(20px);--transition-smooth: all .4s cubic-bezier(.4, 0, .2, 1);--transition-bounce: all .3s cubic-bezier(.34, 1.56, .64, 1)}*,*:before,*:after{margin:0;padding:0;box-sizing:border-box}html{scroll-behavior:smooth}body{font-family:var(--font-primary);background:var(--midnight-navy);min-height:100vh;color:var(--text-primary);overflow-x:hidden;line-height:1.6}body:before{content:"";position:fixed;top:0;left:0;width:100%;height:100%;z-index:-2;background:radial-gradient(ellipse 80% 50% at 20% 20%,rgba(0,212,255,.15) 0%,transparent 50%),radial-gradient(ellipse 60% 40% at 80% 30%,rgba(139,92,246,.12) 0%,transparent 50%),radial-gradient(ellipse 50% 50% at 60% 80%,rgba(16,185,129,.1) 0%,transparent 50%),radial-gradient(ellipse 100% 100% at 50% 50%,var(--deep-charcoal) 0%,var(--midnight-navy) 100%)}body:after{content:"";position:fixed;top:0;left:0;width:100%;height:100%;z-index:-1;background:radial-gradient(circle 400px at 10% 20%,rgba(0,212,255,.05) 0%,transparent 100%),radial-gradient(circle 300px at 90% 80%,rgba(16,185,129,.05) 0%,transparent 100%);animation:meshFloat 20s ease-in-out infinite}@keyframes meshFloat{0%,to{transform:translate(0) scale(1)}25%{transform:translate(2%,1%) scale(1.02)}50%{transform:translate(-1%,2%) scale(1)}75%{transform:translate(1%,-1%) scale(.98)}}#root{width:100%;min-height:100vh}.glass-card{background:var(--glass-white);backdrop-filter:var(--blur-heavy);-webkit-backdrop-filter:var(--blur-heavy);border-radius:24px;border:1px solid var(--glass-border);padding:2.5rem}.glass-card-subtle{background:#ffffff0a;backdrop-filter:var(--blur-medium);-webkit-backdrop-filter:var(--blur-medium);border-radius:20px;border:1px solid rgba(255,255,255,.06)}.login-container{display:flex;align-items:center;justify-content:center;min-height:100vh;padding:2rem}.login-card{background:#0f172a99;backdrop-filter:var(--blur-heavy);-webkit-backdrop-filter:var(--blur-heavy);border-radius:32px;border:1px solid var(--glass-border);padding:3rem 2.5rem;width:100%;max-width:420px;position:relative;overflow:hidden;box-shadow:0 0 60px #00d4ff1a,0 0 100px #8b5cf60d,0 25px 50px -12px #00000080}.login-card:before{content:"";position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,var(--cyber-blue),var(--electric-violet),transparent);opacity:.6}.login-header{text-align:center;margin-bottom:2.5rem}.login-header h2{font-size:2rem;font-weight:700;color:var(--text-primary);margin-bottom:.5rem;letter-spacing:-.02em}.login-header p{color:var(--text-secondary);font-size:.95rem}.input-group{margin-bottom:1.5rem}.input-label{display:block;color:var(--text-secondary);font-size:.85rem;font-weight:500;margin-bottom:.5rem;letter-spacing:.05em;text-transform:uppercase}.login-input{width:100%;padding:1rem 0;background:transparent;border:none;border-bottom:2px solid var(--slate-dark);font-size:1rem;color:var(--text-primary);font-family:var(--font-primary);transition:var(--transition-smooth);outline:none}.login-input::placeholder{color:var(--text-muted)}.login-input:focus{border-bottom-color:var(--cyber-blue);box-shadow:0 4px 20px #00d4ff33}.login-btn{width:100%;padding:1rem 2rem;margin-top:1rem;font-size:1rem;font-weight:600;font-family:var(--font-primary);color:#fff;background:linear-gradient(135deg,var(--electric-blue),var(--electric-violet),var(--neon-purple));background-size:200% 200%;border:none;border-radius:14px;cursor:pointer;text-transform:uppercase;letter-spacing:.1em;transition:var(--transition-smooth);position:relative;overflow:hidden;box-shadow:0 4px 20px #3b82f64d,0 0 40px #8b5cf633}.login-btn:hover:not(:disabled){background-position:100% 50%;transform:translateY(-2px);box-shadow:0 8px 30px #3b82f666,0 0 60px #8b5cf64d}.login-btn:disabled{opacity:.7;cursor:not-allowed}.error-banner{background:#ef444426;border:1px solid rgba(239,68,68,.3);color:#fca5a5;padding:1rem 1.25rem;border-radius:12px;margin-bottom:1.5rem;font-size:.9rem;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.dashboard-container{width:95%;max-width:1400px;margin:0 auto;padding:1.5rem 1rem 3rem;min-height:100vh}.dashboard-header{display:flex;justify-content:space-between;align-items:center;padding:1rem 2rem;background:#0f172ab3;backdrop-filter:var(--blur-heavy);-webkit-backdrop-filter:var(--blur-heavy);border-radius:16px;border:1px solid var(--glass-border);margin-bottom:2rem;position:sticky;top:1rem;z-index:100;box-shadow:0 10px 40px #0000004d}.school-name{font-size:1.4rem;font-weight:700;color:var(--text-primary);letter-spacing:-.01em;display:flex;align-items:center;gap:.75rem}.school-name:before{content:"🎓";font-size:1.5rem}.btn-logout{background:transparent;color:var(--soft-crimson);padding:.6rem 1.5rem;border-radius:10px;border:1.5px solid var(--soft-crimson);font-weight:600;font-family:var(--font-primary);font-size:.9rem;cursor:pointer;text-transform:uppercase;letter-spacing:.08em;transition:var(--transition-smooth)}.btn-logout:hover{background:var(--soft-crimson);color:#fff;box-shadow:0 0 30px #ef444466}.profile-section{background:#0f172a80;backdrop-filter:var(--blur-heavy);-webkit-backdrop-filter:var(--blur-heavy);padding:2rem 2.5rem;border-radius:24px;border:1px solid var(--glass-border);margin-bottom:2rem;display:flex;gap:2rem;align-items:center;flex-wrap:wrap;box-shadow:0 0 60px #00d4ff0d,0 20px 40px #0003}.profile-img{width:100px;height:100px;border-radius:50%;object-fit:cover;border:3px solid var(--cyber-blue);box-shadow:0 0 30px #00d4ff4d,0 0 60px #00d4ff1a}.profile-info h3{font-size:1.6rem;font-weight:700;color:var(--text-primary);margin-bottom:.5rem;letter-spacing:-.01em}.profile-info p{color:var(--text-secondary);font-size:1rem;margin-bottom:.25rem}.profile-info p strong{color:var(--text-primary);font-weight:500}.menu-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1.5rem;margin-bottom:2rem}.menu-card{padding:2rem;border-radius:20px;cursor:pointer;transition:var(--transition-bounce);border:1px solid rgba(255,255,255,.1);position:relative;overflow:hidden}.menu-card:before{content:"";position:absolute;inset:0;opacity:0;transition:var(--transition-smooth);z-index:0}.menu-card:hover{transform:translateY(-8px) scale(1.02);box-shadow:0 25px 50px -12px #00000080}.menu-card h4,.menu-card p{position:relative;z-index:1}.menu-card h4{font-size:1.4rem;font-weight:700;color:#fff;margin-bottom:.5rem;display:flex;align-items:center;gap:.75rem}.menu-card p{color:#fffc;font-size:.95rem}.menu-card:nth-child(1){background:linear-gradient(135deg,#0c4a6e,#0369a1,#0284c7);box-shadow:0 10px 40px #0369a14d,0 0 60px #00d4ff1a}.menu-card:nth-child(1):hover{box-shadow:0 25px 60px #0369a180,0 0 80px #00d4ff33}.menu-card:nth-child(2){background:linear-gradient(135deg,#064e3b,#047857,#059669);box-shadow:0 10px 40px #0478574d,0 0 60px #10b9811a}.menu-card:nth-child(2):hover{box-shadow:0 25px 60px #04785780,0 0 80px #10b98133}.menu-card:nth-child(3){background:linear-gradient(135deg,#9a3412,#ea580c,#f97316);box-shadow:0 10px 40px #ea580c4d,0 0 60px #f973161a}.menu-card:nth-child(3):hover{box-shadow:0 25px 60px #ea580c80,0 0 80px #f9731633}.results-container{background:#0f172a99;backdrop-filter:var(--blur-heavy);-webkit-backdrop-filter:var(--blur-heavy);padding:2rem;border-radius:24px;border:1px solid var(--glass-border);margin-top:2rem;animation:slideUp .5s ease-out;box-shadow:0 20px 50px #0000004d}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.results-container h3{font-size:1.5rem;font-weight:700;color:var(--text-primary);margin-bottom:1.5rem;padding-bottom:1rem;border-bottom:1px solid var(--glass-border)}table{width:100%;border-collapse:separate;border-spacing:0}thead{background:#1e293bcc}th{padding:1rem 1.25rem;text-align:left;color:var(--text-secondary);font-weight:600;font-size:.8rem;text-transform:uppercase;letter-spacing:.1em;border:none}th:first-child{border-radius:12px 0 0 12px}th:last-child{border-radius:0 12px 12px 0}td{padding:1rem 1.25rem;color:var(--text-primary);border:none;border-bottom:1px solid rgba(255,255,255,.05)}tbody tr{transition:var(--transition-smooth)}tbody tr:nth-child(odd){background:#ffffff05}tbody tr:nth-child(2n){background:transparent}tbody tr:hover{background:#00d4ff0d}.grade-badge{display:inline-flex;align-items:center;justify-content:center;padding:.35rem 1rem;border-radius:50px;font-weight:700;font-size:.85rem;letter-spacing:.05em}.grade-a{background:#10b98133;color:#34d399;box-shadow:0 0 20px #10b9814d;border:1px solid rgba(16,185,129,.3)}.grade-b{background:#facc1533;color:#fde047;box-shadow:0 0 20px #facc154d;border:1px solid rgba(250,204,21,.3)}.grade-c{background:#f9731633;color:#fb923c;box-shadow:0 0 20px #f973164d;border:1px solid rgba(249,115,22,.3)}.grade-d,.grade-f{background:#ef444433;color:#f87171;box-shadow:0 0 20px #ef44444d;border:1px solid rgba(239,68,68,.3)}.loading-container{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;gap:1.5rem}.pulse-loader{width:60px;height:60px;border-radius:50%;background:linear-gradient(135deg,var(--cyber-blue),var(--electric-violet));position:relative}.pulse-loader:before,.pulse-loader:after{content:"";position:absolute;top:0;left:0;width:100%;height:100%;border-radius:50%;background:inherit;animation:pulse 2s ease-out infinite}.pulse-loader:after{animation-delay:.5s}@keyframes pulse{0%{transform:scale(1);opacity:.8}to{transform:scale(2.5);opacity:0}}.loading-text{color:var(--text-secondary);font-size:1rem;letter-spacing:.1em;text-transform:uppercase}.skeleton{background:linear-gradient(90deg,#ffffff0a,#ffffff14,#ffffff0a);background-size:200% 100%;animation:shimmer 1.5s infinite;border-radius:8px}@keyframes shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.skeleton-text{height:1rem;margin-bottom:.75rem}.skeleton-title{height:1.5rem;width:60%;margin-bottom:1rem}.skeleton-avatar{width:100px;height:100px;border-radius:50%}@media(max-width:768px){.dashboard-header{flex-direction:column;gap:1rem;text-align:center;position:relative;top:0}.profile-section{flex-direction:column;text-align:center}.menu-grid{grid-template-columns:1fr}.login-card{padding:2rem 1.5rem;border-radius:24px}table{font-size:.9rem}th,td{padding:.75rem .5rem}}.text-gradient{background:linear-gradient(135deg,var(--cyber-blue),var(--electric-violet));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.glow-blue{box-shadow:0 0 40px #00d4ff4d}.glow-emerald{box-shadow:0 0 40px #10b9814d}.glow-violet{box-shadow:0 0 40px #8b5cf64d}.circular-progress-container{position:relative;display:inline-flex;align-items:center;justify-content:center}.circular-progress-svg{transform:rotate(-90deg)}.circular-progress-text{position:absolute;display:flex;align-items:baseline;justify-content:center;gap:1px}.progress-value{font-size:1.2rem;font-weight:700;color:var(--text-primary)}.progress-symbol{font-size:.7rem;font-weight:500;color:var(--text-secondary)}.attendance-calendar{background:#0f172a66;border-radius:16px;padding:1.5rem;border:1px solid var(--glass-border)}.calendar-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem}.calendar-header h3{font-size:1.2rem;font-weight:600;color:var(--text-primary);margin:0;border:none;padding:0}.nav-btn{background:#ffffff1a;border:1px solid var(--glass-border);color:var(--text-primary);padding:.5rem 1rem;border-radius:8px;cursor:pointer;transition:var(--transition-smooth)}.nav-btn:hover{background:#00d4ff33}.weekday-headers{display:grid;grid-template-columns:repeat(7,1fr);gap:4px;margin-bottom:.5rem}.weekday{text-align:center;font-size:.75rem;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em}.calendar-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:4px}.calendar-day{aspect-ratio:1;display:flex;flex-direction:column;align-items:center;justify-content:center;background:#ffffff08;border-radius:8px;position:relative;cursor:default;transition:var(--transition-smooth)}.calendar-day:hover:not(.empty){background:#ffffff14}.calendar-day.empty{background:transparent}.calendar-day.today{border:2px solid var(--cyber-blue);box-shadow:0 0 10px #00d4ff4d}.day-number{font-size:.9rem;font-weight:500;color:var(--text-primary)}.status-dot{width:8px;height:8px;border-radius:50%;margin-top:4px}.calendar-legend{display:flex;justify-content:center;gap:2rem;margin-top:1.5rem;padding-top:1rem;border-top:1px solid var(--glass-border)}.legend-item{display:flex;align-items:center;gap:.5rem;font-size:.85rem;color:var(--text-secondary)}.legend-dot{width:10px;height:10px;border-radius:50%}.page-container{width:95%;max-width:1200px;margin:0 auto;padding:1.5rem 1rem 3rem;min-height:100vh}.page-header{display:flex;align-items:center;gap:1.5rem;margin-bottom:2rem;padding:1rem 1.5rem;background:#0f172ab3;-webkit-backdrop-filter:var(--blur-heavy);backdrop-filter:var(--blur-heavy);border-radius:16px;border:1px solid var(--glass-border)}.page-header h1{font-size:1.5rem;font-weight:700;color:var(--text-primary);margin:0}.back-btn{background:transparent;color:var(--cyber-blue);text-decoration:none;font-weight:600;padding:.5rem 1rem;border-radius:8px;border:1px solid var(--cyber-blue);transition:var(--transition-smooth)}.back-btn:hover{background:#00d4ff1a}.empty-state{text-align:center;padding:4rem 2rem;color:var(--text-secondary)}.empty-state p{margin-top:1rem;font-size:1.1rem}.timetable-wrapper{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:1rem}.day-column{background:#0f172a99;-webkit-backdrop-filter:var(--blur-medium);backdrop-filter:var(--blur-medium);border-radius:16px;border:1px solid var(--glass-border);padding:1rem;transition:var(--transition-smooth)}.day-column.current-day{border-color:var(--cyber-blue);box-shadow:0 0 20px #00d4ff33}.day-header{font-size:1rem;font-weight:700;color:var(--text-primary);text-align:center;padding-bottom:.75rem;margin-bottom:.75rem;border-bottom:1px solid var(--glass-border)}.periods-list{display:flex;flex-direction:column;gap:.75rem}.period-card{background:#ffffff0d;border-radius:10px;padding:.75rem;border:1px solid rgba(255,255,255,.08)}.period-time{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem}.period-num{background:var(--electric-blue);color:#fff;font-size:.7rem;font-weight:700;padding:2px 8px;border-radius:4px}.time-slot{font-size:.7rem;color:var(--text-muted)}.period-subject{font-weight:600;color:var(--text-primary);font-size:.9rem}.period-teacher{font-size:.75rem;color:var(--text-secondary);margin-top:.25rem}.no-classes{text-align:center;color:var(--text-muted);font-size:.85rem;padding:1rem}.homework-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:1.5rem}.subject-group{background:#0f172a99;-webkit-backdrop-filter:var(--blur-medium);backdrop-filter:var(--blur-medium);border-radius:16px;border:1px solid var(--glass-border);padding:1.25rem}.subject-header{font-size:1.1rem;font-weight:700;color:var(--cyber-blue);margin-bottom:1rem;padding-bottom:.75rem;border-bottom:1px solid var(--glass-border)}.homework-card{background:#ffffff0d;border-radius:12px;padding:1rem;margin-bottom:.75rem;border:1px solid rgba(255,255,255,.08);cursor:pointer;transition:var(--transition-smooth)}.homework-card:hover{background:#ffffff14}.homework-card.overdue{border-color:#ef44444d}.homework-header{display:flex;justify-content:space-between;align-items:flex-start;gap:.75rem;margin-bottom:.5rem}.homework-title{font-weight:600;color:var(--text-primary)}.due-badge{font-size:.7rem;font-weight:600;padding:4px 8px;border-radius:6px;background:#10b98133;color:#4ade80;white-space:nowrap}.due-badge.overdue{background:#ef444433;color:#f87171}.homework-meta{display:flex;justify-content:space-between;align-items:center;font-size:.8rem;color:var(--text-secondary)}.status-pill{font-size:.7rem;font-weight:600;padding:3px 8px;border-radius:50px;text-transform:uppercase}.status-pill.pending{background:#facc1533;color:#fde047}.status-pill.submitted{background:#10b98133;color:#4ade80}.homework-details{margin-top:1rem;padding-top:1rem;border-top:1px solid var(--glass-border);color:var(--text-secondary);font-size:.9rem;animation:slideUp .3s ease}.teacher-info{margin-top:.5rem;font-style:italic;color:var(--text-muted)}.fee-summary-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem;margin-bottom:2rem}.summary-card{background:#0f172a99;-webkit-backdrop-filter:var(--blur-medium);backdrop-filter:var(--blur-medium);border-radius:16px;border:1px solid var(--glass-border);padding:1.5rem;text-align:center}.summary-label{display:block;font-size:.85rem;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em;margin-bottom:.5rem}.summary-value{font-size:1.8rem;font-weight:700;color:var(--text-primary)}.summary-card.total .summary-value{color:var(--cyber-blue)}.summary-card.paid .summary-value{color:#4ade80}.summary-card.due .summary-value{color:#f87171}.summary-card.clear .summary-value{color:#4ade80}.fee-tabs{display:flex;gap:.5rem;margin-bottom:1.5rem}.tab-btn{flex:1;padding:1rem;background:#ffffff0d;border:1px solid var(--glass-border);border-radius:12px;color:var(--text-secondary);font-family:var(--font-primary);font-size:.95rem;font-weight:600;cursor:pointer;transition:var(--transition-smooth)}.tab-btn:hover{background:#ffffff14}.tab-btn.active{background:#00d4ff1a;border-color:var(--cyber-blue);color:var(--cyber-blue)}.total-row{background:#00d4ff0d!important}.exam-selector{display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:1.5rem}.exam-btn{padding:.75rem 1.5rem;background:#ffffff0d;border:1px solid var(--glass-border);border-radius:10px;color:var(--text-secondary);font-family:var(--font-primary);font-weight:600;cursor:pointer;transition:var(--transition-smooth)}.exam-btn:hover{background:#ffffff14}.exam-btn.active{background:linear-gradient(135deg,#0c4a6e,#0369a1);border-color:transparent;color:#fff}.result-summary{display:flex;flex-wrap:wrap;align-items:center;gap:1rem;margin-bottom:1.5rem;padding:1.25rem;background:#0f172a99;border-radius:16px;border:1px solid var(--glass-border)}.stat-card{text-align:center;padding:.75rem 1.5rem}.stat-label{display:block;font-size:.75rem;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em}.stat-value{font-size:1.5rem;font-weight:700;color:var(--text-primary)}.stat-card.percentage .stat-value{color:#4ade80}.download-btn{margin-left:auto;padding:.75rem 1.5rem;background:linear-gradient(135deg,var(--electric-blue),var(--electric-violet));border:none;border-radius:10px;color:#fff;font-family:var(--font-primary);font-weight:600;cursor:pointer;transition:var(--transition-smooth)}.download-btn:hover{transform:translateY(-2px);box-shadow:0 8px 25px #3b82f666}.quick-nav-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:1rem;margin-top:1.5rem}.nav-card{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:1.5rem 1rem;background:#ffffff0d;-webkit-backdrop-filter:var(--blur-medium);backdrop-filter:var(--blur-medium);border-radius:16px;border:1px solid var(--glass-border);text-decoration:none;color:var(--text-primary);transition:var(--transition-bounce)}.nav-card:hover{transform:translateY(-4px);background:#ffffff14}.nav-icon{font-size:2rem;margin-bottom:.5rem}.nav-card span:last-child{font-size:.9rem;font-weight:600}.nav-card.timetable:hover{border-color:var(--electric-blue);box-shadow:0 10px 30px #3b82f633}.nav-card.homework:hover{border-color:var(--neon-emerald);box-shadow:0 10px 30px #10b98133}.nav-card.results-nav:hover{border-color:var(--neon-purple);box-shadow:0 10px 30px #a855f733}.nav-card.fees-nav:hover{border-color:var(--sunset-orange);box-shadow:0 10px 30px #f9731633}.no-data{text-align:center;color:var(--text-muted);padding:2rem;font-style:italic}.view-more-link{display:block;text-align:center;margin-top:1.5rem;color:var(--cyber-blue);text-decoration:none;font-weight:600;transition:var(--transition-smooth)}.view-more-link:hover{text-decoration:underline}.active-card{transform:scale(1.02);box-shadow:0 0 30px #00d4ff4d!important}.btn-spinner{width:18px;height:18px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}@media(max-width:768px){.timetable-wrapper{grid-template-columns:1fr 1fr}.homework-grid,.fee-summary-grid{grid-template-columns:1fr}.quick-nav-grid{grid-template-columns:repeat(2,1fr)}.result-summary{flex-direction:column;text-align:center}.download-btn{margin-left:0;width:100%}.calendar-legend{flex-wrap:wrap;gap:1rem}}
