*{box-sizing:border-box;margin:0;padding:0}html,body,#root{height:100%;margin:0;padding:0;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{background:linear-gradient(135deg,#f5f7fa,#c3cfe2);background-attachment:fixed;color:#1a202c;line-height:1.6}.app-container{max-width:1400px;margin:0 auto;padding:0;min-height:calc(100vh - 56px)}.page-header{margin-bottom:32px;padding-bottom:16px;border-bottom:2px solid #e2e8f0}.page-title{font-size:32px;font-weight:700;color:#1a202c;margin:0 0 8px;letter-spacing:-.5px;line-height:1.2}.page-subtitle{font-size:16px;color:#718096;margin:0;font-weight:400;line-height:1.5}.section-header{font-size:20px;font-weight:600;color:#2d3748;margin:32px 0 16px;padding-bottom:8px;border-bottom:1px solid #e2e8f0}.section-header:first-child{margin-top:0}.card{background:#fff;border-radius:16px;box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f,0 0 0 1px #0000000d;padding:24px;border:1px solid rgba(226,232,240,.8);transition:all .3s ease}.card:hover{box-shadow:0 10px 15px -3px #0000001a,0 4px 6px -2px #0000000d,0 0 0 1px #0000000d;transform:translateY(-2px)}.login-page{display:flex;align-items:center;justify-content:center;height:100vh;padding:24px}.login-card{width:420px;max-width:calc(100% - 48px);padding:28px;border-radius:14px;background:linear-gradient(180deg,#fffffffa,#fff);box-shadow:0 18px 50px #12285014;border:1px solid rgba(18,40,80,.04)}.login-title{margin:0 0 12px;font-size:20px;font-weight:700;color:#102231}.input{width:100%;padding:12px 16px;border-radius:10px;border:2px solid #e2e8f0;background:#fff;margin-top:8px;font-size:14px;transition:all .2s ease;font-family:inherit}.input:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a;background:#fff}.input:hover:not(:focus){border-color:#cbd5e0}.button{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:12px 24px;border-radius:10px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;cursor:pointer;font-weight:600;font-size:14px;transition:all .2s ease;box-shadow:0 4px 6px -1px #667eea4d}.button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 12px -2px #667eea66}.button:active:not(:disabled){transform:translateY(0)}.button:disabled{opacity:.6;cursor:not-allowed;transform:none}.button.secondary{background:#f7fafc;color:#4a5568;border:2px solid #e2e8f0;box-shadow:none}.button.secondary:hover:not(:disabled){background:#edf2f7;border-color:#cbd5e0;transform:translateY(-1px);box-shadow:0 2px 4px #0000001a}.table{width:100%;border-collapse:separate;border-spacing:0;font-size:14px;background:#fff;border-radius:12px;overflow:hidden;box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;border:1px solid #e2e8f0}.table thead tr{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;text-transform:none}.table th{padding:16px 20px;text-align:left;font-weight:600;font-size:13px;letter-spacing:.5px;text-transform:uppercase}.table td{padding:16px 20px;border-bottom:1px solid #f1f5f9;text-align:left;vertical-align:middle}.table tbody tr{transition:background-color .2s ease}.table tbody tr:nth-child(odd){background:#fff}.table tbody tr:nth-child(2n){background:#f8fafc}.table tbody tr:hover{background:#f1f5f9}.table tbody tr:last-child td{border-bottom:none}.table-wrap{overflow-x:auto;border-radius:8px}.hstack{display:flex;gap:16px;align-items:center;flex-wrap:wrap}.vstack{display:flex;flex-direction:column;gap:16px}.right{margin-left:auto}.center{text-align:center}.mt-1{margin-top:8px}.mt-2{margin-top:16px}.mt-3{margin-top:24px}.mt-4{margin-top:32px}.mb-1{margin-bottom:8px}.mb-2{margin-bottom:16px}.mb-3{margin-bottom:24px}.mb-4{margin-bottom:32px}.p-1{padding:8px}.p-2{padding:16px}.p-3{padding:24px}.p-4{padding:32px}.form-label{font-size:14px;color:#2d3748;margin-bottom:8px;display:block;font-weight:600;letter-spacing:-.1px}.helper{font-size:13px;color:#718096;line-height:1.5;margin-top:4px}.btn-small{padding:6px 10px;border-radius:8px;font-size:13px}.table .actions{white-space:nowrap}.dashboard-content{width:100%}p{font-size:var(--font-size-base);line-height:1.6;color:#4a5568;margin:0 0 1em}a{color:#667eea;text-decoration:none;font-weight:500;transition:color .2s ease}a:hover{color:#764ba2;text-decoration:underline}.loading-container{display:flex;align-items:center;justify-content:center;padding:48px;color:#718096;font-size:var(--font-size-lg)}.empty-state{text-align:center;padding:48px 24px;color:#718096}.empty-state-icon{font-size:48px;margin-bottom:16px;opacity:.5}.empty-state-title{font-size:var(--font-size-xl);font-weight:var(--font-weight-semibold);color:#4a5568;margin-bottom:8px}.empty-state-text{font-size:var(--font-size-base);color:#718096}@media (max-width: 760px){.app-container{padding:12px;margin:12px}.login-card{width:100%;padding:18px}.table th,.table td{padding:10px 8px;font-size:13px}.page-title{font-size:24px}.page-subtitle{font-size:14px}.main-content{padding:20px 16px}.school-header{padding:12px 16px}.school-header-name{font-size:16px}}.login-page{min-height:100vh;display:grid;grid-template-columns:1fr 1fr;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background:linear-gradient(135deg,#667eea,#764ba2);position:relative;overflow:hidden}.login-page:before{content:"";position:absolute;inset:0;background:radial-gradient(circle at 20% 50%,rgba(120,119,198,.3) 0%,transparent 50%),radial-gradient(circle at 80% 80%,rgba(255,255,255,.1) 0%,transparent 50%);pointer-events:none}.login-left{display:flex;flex-direction:column;justify-content:space-between;padding:4rem 3rem;color:#fff;position:relative;z-index:1}.login-branding{margin-top:2rem}.brand-logo{width:80px;height:80px;background:#fff3;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:20px;display:flex;align-items:center;justify-content:center;margin-bottom:2rem;box-shadow:0 8px 32px #0000001a}.brand-logo svg{color:#fff}.brand-title{font-size:2.5rem;font-weight:700;margin:0 0 1rem;line-height:1.2;text-shadow:0 2px 10px rgba(0,0,0,.2)}.brand-subtitle{font-size:1.1rem;opacity:.95;line-height:1.6;margin:0;font-weight:400}.feature-grid{display:flex;flex-direction:column;gap:1.5rem;margin:3rem 0}.feature-item{display:flex;align-items:flex-start;gap:1rem;padding:1.25rem;background:#ffffff1a;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:12px;border:1px solid rgba(255,255,255,.2);transition:all .3s ease}.feature-item:hover{background:#ffffff26;transform:translate(5px)}.feature-icon{width:48px;height:48px;background:#fff3;border-radius:12px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.feature-icon svg{color:#fff}.feature-content h3{margin:0 0 .25rem;font-size:1rem;font-weight:600}.feature-content p{margin:0;font-size:.9rem;opacity:.9;line-height:1.4}.login-footer-text{opacity:.8;font-size:.85rem}.login-footer-text p{margin:0}.login-right{display:flex;align-items:center;justify-content:center;padding:2rem;position:relative;z-index:1}.login-card{background:#fffffffa;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);padding:3rem;border-radius:24px;width:100%;max-width:450px;box-shadow:0 20px 60px #0000004d,0 0 0 1px #ffffff80;position:relative;overflow:hidden}.login-card:before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(90deg,#667eea,#764ba2)}.login-header{text-align:center;margin-bottom:2rem}.login-title{font-size:2rem;font-weight:700;color:#1a202c;margin:0 0 .5rem}.login-subtitle{color:#718096;font-size:.95rem;margin:0}.error-message{background:#fee;border:1px solid #fcc;color:#c33;padding:.75rem 1rem;border-radius:8px;margin-bottom:1.5rem;font-size:.9rem}.login-form{display:flex;flex-direction:column;gap:1.5rem}.form-group{display:flex;flex-direction:column;gap:.5rem}.form-label{display:block;color:#2d3748;font-weight:600;font-size:.9rem;margin-bottom:.25rem}.input{width:100%;padding:.875rem 1rem;border:2px solid #e2e8f0;border-radius:10px;font-size:1rem;outline:none;transition:all .2s ease;background:#fff;box-sizing:border-box}.input:focus{border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.input::placeholder{color:#a0aec0}.password-input-wrapper{position:relative;display:flex;align-items:center}.password-input-wrapper .input{padding-right:3rem}.password-toggle{position:absolute;right:1rem;background:none;border:none;cursor:pointer;color:#718096;display:flex;align-items:center;justify-content:center;padding:.25rem;transition:color .2s ease}.password-toggle:hover{color:#667eea}.form-actions{display:flex;flex-direction:column;gap:1rem;margin-top:.5rem}.button{padding:.875rem 1.5rem;border:none;border-radius:10px;font-weight:600;font-size:1rem;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center;gap:.5rem}.button-primary{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;box-shadow:0 4px 15px #667eea66}.button-primary:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 20px #667eea80}.button-primary:active:not(:disabled){transform:translateY(0)}.button-primary:disabled{opacity:.7;cursor:not-allowed;transform:none}.button-spinner{width:16px;height:16px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .6s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.form-secondary-actions{display:flex;justify-content:center;gap:1rem}.button-link{background:none;border:none;color:#667eea;font-size:.9rem;font-weight:500;cursor:pointer;padding:.5rem;transition:color .2s ease;text-decoration:none}.button-link:hover{color:#764ba2;text-decoration:underline}input::-ms-reveal,input::-ms-clear{display:none!important}@media (max-width: 968px){.login-page{grid-template-columns:1fr}.login-left{display:none}.login-right{padding:1rem}.login-card{padding:2rem 1.5rem}}@media (max-width: 480px){.login-card{padding:1.5rem;border-radius:16px}.login-title{font-size:1.5rem}.brand-title{font-size:2rem}}.sidebar{width:100%;height:100%;background:linear-gradient(180deg,#fff,#f8fafc);padding:24px 16px;border-right:1px solid #e2e8f0;transition:all .3s cubic-bezier(.4,0,.2,1);overflow:hidden;position:relative;box-shadow:2px 0 8px #0000000a;display:flex;flex-direction:column}.sidebar-title{font-size:28px;font-weight:800;margin-bottom:32px;margin-top:8px;background:linear-gradient(135deg,#667eea,#764ba2);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;transition:all .3s ease;white-space:nowrap;text-align:start;letter-spacing:-.5px}.sidebar-menu{display:flex;flex-direction:column;gap:10px;flex:1}.sidebar-menu a{display:flex;align-items:center;gap:12px;padding:12px 16px;font-size:15px;text-decoration:none;color:#4a5568;border-radius:12px;transition:all .2s cubic-bezier(.4,0,.2,1);font-weight:500;position:relative;margin-bottom:4px}.sidebar-menu a svg{font-size:20px;color:#718096;transition:all .2s ease-in-out;flex-shrink:0}.sidebar-menu a:not(.active):hover{background:linear-gradient(135deg,#667eea1a,#764ba21a);color:#667eea;transform:translate(4px)}.sidebar-menu a:not(.active):hover svg{color:#667eea;transform:scale(1.1)}.sidebar-menu a.active{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff!important;font-weight:600;border-radius:12px;box-shadow:0 4px 12px #667eea66}.sidebar-menu a.active:before{content:"";position:absolute;left:0;top:50%;transform:translateY(-50%);width:4px;height:60%;background:#ffffff80;border-radius:0 4px 4px 0}.sidebar-menu a.active svg,.sidebar-menu a.active .icon{color:#fff!important;fill:#fff!important}.dashboard-line{height:3px;width:100%;background:linear-gradient(90deg,#667eea,#764ba2);margin:0 0 32px;border-radius:2px;box-shadow:0 2px 4px #667eea33}.dashboard-title{color:#1a202c;font-weight:700;font-size:32px;margin-bottom:24px;margin-top:0;letter-spacing:-.5px;line-height:1.2}.dashboard-cards{display:grid;grid-template-columns:repeat(4,1fr);gap:20px}.info-card{background:#fff;border-radius:16px;box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;text-align:center;padding:24px;transition:all .3s cubic-bezier(.4,0,.2,1);cursor:pointer;border:1px solid #e2e8f0;position:relative;overflow:hidden}.info-card:before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(90deg,#667eea,#764ba2);transform:scaleX(0);transition:transform .3s ease}.info-card:hover{transform:translateY(-6px);box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a;border-color:#cbd5e0}.info-card:hover:before{transform:scaleX(1)}.card-icon{font-size:28px;margin-bottom:8px}.card-label{font-size:15px;color:#555}.card-value{font-size:20px;font-weight:700;color:#111;margin-top:6px}.info-card.schools .card-icon{color:#2563eb}.info-card.students .card-icon{color:#22c55e}.info-card.generated .card-icon{color:#0ea5e9}.info-card.pending .card-icon{color:#f59e0b}.sidebar:not(.expanded){width:80px;padding:20px 8px;align-items:center}.sidebar:not(.expanded) .sidebar-title{opacity:1;font-size:16px;text-align:center}.sidebar:not(.expanded) .sidebar-menu a{justify-content:center;padding:10px 0}.sidebar:not(.expanded) .sidebar-menu a span{display:none}.sidebar.expanded{width:220px}.sidebar.expanded .sidebar-menu a{justify-content:flex-start}.sidebar.expanded .sidebar-menu a span{display:inline}.footer{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;text-align:center;padding:16px 0;box-shadow:0 -4px 6px -1px #0000001a;width:100%;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;font-size:14px;letter-spacing:.3px;position:relative;margin-top:auto}.footer:before{content:"";position:absolute;top:0;left:0;right:0;height:1px;background:#fff3}.footer a{color:#fffffff2;text-decoration:none;font-weight:600;transition:all .2s ease;border-bottom:1px solid transparent}.footer a:hover{color:#fff;border-bottom-color:#ffffff80}.sidebar-footer{margin-top:auto;padding-top:16px;border-top:1px solid rgba(0,0,0,.05)}.sidebar-footer a{transition:color .2s ease}.sidebar-footer a:hover{color:#764ba2}.sidebar-toggle{position:absolute;top:30px;right:-12px;transform:translateY(-50%);width:32px;height:32px;display:flex;align-items:center;justify-content:center;border:2px solid #e2e8f0;border-radius:8px;background:#fff;color:#4a5568;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);box-shadow:0 2px 4px #0000001a;z-index:10}.sidebar-toggle:hover{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border-color:transparent;box-shadow:0 4px 8px #667eea4d;transform:translateY(-50%) scale(1.1)}.sidebar.expanded .sidebar-toggle{transform:rotate(0) translateY(6px)}.sidebar:not(.expanded) .sidebar-toggle{transform:rotate(180deg) translateY(6px)}.top-header-bar{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:16px 32px;box-shadow:0 2px 8px #0000001a;position:relative;z-index:100;display:flex;align-items:center;justify-content:space-between}.top-header-left{flex:1;display:flex;align-items:center}.top-header-center{flex:1;display:flex;justify-content:center;align-items:center}.top-header-right{flex:1;display:flex;justify-content:flex-end;align-items:center}.top-header-title{font-size:28px;font-weight:700;margin:0;color:#fff;background:linear-gradient(135deg,#fff,#f0f0f0);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.school-name-header{display:flex;align-items:center;gap:12px}.school-header-icon{font-size:24px;opacity:.95}.school-header-name{font-size:18px;font-weight:700;letter-spacing:-.3px}.main-content{padding:32px 40px;background:#f8fafc;min-height:calc(100vh - 60px);position:relative}@media (max-width: 768px){.main-content{padding:24px 20px}.top-header-bar{padding:12px 20px}.top-header-title{font-size:22px}.school-header-name{font-size:16px}}
