@import "https://fonts.googleapis.com/css2?family=Inter:ital,opsz,wght@0,14..32,400;0,14..32,500;0,14..32,600;0,14..32,700;0,14..32,800;1,14..32,400&display=swap";:root{--primary:#6366f1;--primary-dark:#4f46e5;--primary-light:#6366f126;--primary-muted:#6366f11a;--success:#10b981;--success-light:#10b98126;--warning:#f59e0b;--warning-light:#f59e0b26;--danger:#ef4444;--danger-light:#ef444426;--info:#06b6d4;--info-light:#06b6d426;--bg:#12121e;--surface:#1a1a2e;--surface-hover:#22223a;--sidebar-bg:#1e1b2e;--sidebar-hover:#2d2a3e;--sidebar-active:#6366f1;--sidebar-text:#a1a1aa;--sidebar-text-active:#fff;--text:#e2e8f0;--text-secondary:#94a3b8;--text-muted:#64748b;--text-placeholder:#475569;--border:#2d2d4a;--border-focus:#6366f1;--shadow-xs:0 1px 2px #0000000a;--shadow-sm:0 1px 3px #0000000f, 0 1px 2px #0000000a;--shadow-md:0 4px 6px -1px #0000000f, 0 2px 4px -1px #0000000a;--shadow-lg:0 10px 15px -3px #0000000f, 0 4px 6px -2px #0000000a;--shadow-xl:0 20px 25px -5px #00000012, 0 10px 10px -5px #00000008;--radius-sm:6px;--radius-md:10px;--radius-lg:14px;--radius-xl:18px;--radius-2xl:24px;--sidebar-width:248px;--font-xs:12px;--font-sm:13px;--font-base:15px;--font-md:16px;--font-lg:18px;--font-xl:20px;--font-2xl:24px;--font-3xl:30px;--touch-min:44px}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{font-size:var(--font-base);scroll-behavior:smooth}body{background:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;line-height:1.6}#root{flex-direction:column;min-height:100vh;display:flex}a{color:var(--primary);text-decoration:none}a:hover{color:var(--primary-dark)}input,button,textarea,select{font:inherit}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--border);border-radius:99px}::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}@keyframes fadeUp{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideRight{0%{opacity:0;transform:translate(-12px)}to{opacity:1;transform:translate(0)}}@keyframes spin{to{transform:rotate(360deg)}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.6}}.animate-fade-up{animation:.3s ease-out forwards fadeUp}.animate-fade-in{animation:.25s ease-out forwards fadeIn}.animate-slide-in{animation:.3s ease-out forwards slideRight}.text-primary{color:var(--primary)}.text-success{color:var(--success)}.text-warning{color:var(--warning)}.text-danger{color:var(--danger)}.text-muted{color:var(--text-muted)}.text-center{text-align:center}.mt-1{margin-top:.5rem}.mt-2{margin-top:1rem}.mt-3{margin-top:1.5rem}.mt-4{margin-top:2rem}.mb-1{margin-bottom:.5rem}.mb-2{margin-bottom:1rem}.full-width{width:100%}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm)}.badge{font-size:var(--font-sm);border-radius:99px;align-items:center;gap:4px;padding:3px 10px;font-weight:600;display:inline-flex}.badge-blue{background:var(--primary-light);color:var(--primary)}.badge-green{background:var(--success-light);color:var(--success)}.badge-amber{background:var(--warning-light);color:var(--warning)}.badge-red{background:var(--danger-light);color:var(--danger)}.status-pill{font-size:var(--font-sm);border-radius:99px;align-items:center;gap:5px;padding:4px 12px;font-weight:600;display:inline-flex}:focus-visible{outline:2px solid var(--primary);outline-offset:2px;border-radius:var(--radius-sm)}@media (prefers-reduced-motion:reduce){*,:before,:after{transition-duration:.01ms!important;animation-duration:.01ms!important}}:root{--bg-color:var(--bg);--bg-surface:var(--surface);--bg-surface-hover:var(--surface-hover);--bg-elevated:var(--surface);--text-main:var(--text);--accent:#7c3aed;--accent-hover:#6d28d9;--accent-light:#7c3aed26;--primary-hover:var(--primary-dark);--primary-glow:#2563eb4d;--shadow-glow:0 0 20px #2563eb4d;--font-size-base:var(--font-base);--font-size-lg:var(--font-lg);--font-size-xl:var(--font-xl);--font-size-2xl:var(--font-2xl);--radius-xl:20px;--touch-min:44px}.glass{background:var(--surface);border:1px solid var(--border);box-shadow:var(--shadow-sm);-webkit-backdrop-filter:none}.bg-primary{background:var(--primary)!important}.bg-accent{background:#7c3aed!important}.bg-success{background:var(--success)!important}.loading-spinner{color:var(--text-muted);justify-content:center;align-items:center;gap:.75rem;font-size:1rem;display:flex}.loading-spinner-icon{border:3px solid var(--border);border-top-color:var(--primary);border-radius:50%;width:24px;height:24px;animation:.8s linear infinite spin}.navbar{-webkit-backdrop-filter:blur(12px);border-bottom:1px solid var(--border);z-index:100;background:#ffffffd9;height:64px;position:fixed;top:0;left:0;right:0}.nav-container{justify-content:space-between;align-items:center;max-width:1200px;height:100%;margin:0 auto;padding:0 2rem;display:flex}.nav-logo{font-size:var(--font-xl);color:var(--text);letter-spacing:-.03em;align-items:center;gap:10px;font-weight:800;text-decoration:none;display:flex}.nav-logo-icon{background:var(--primary);border-radius:var(--radius-md);color:#fff;justify-content:center;align-items:center;width:36px;height:36px;display:flex;box-shadow:0 2px 8px #6366f14d}.nav-logo-text em{color:var(--primary);font-style:normal}.nav-actions{align-items:center;gap:.625rem;display:flex}@media (width<=640px){.nav-container{padding:0 1rem}}.navbar.dark{border-bottom-color:var(--border);background:#0f0f11d9}.navbar.dark .nav-logo-text{color:#fff}.navbar.dark .nav-actions .btn-ghost{color:#fffc}.navbar.dark .nav-actions .btn-ghost:hover{color:#fff;background:#ffffff14}.navbar.dark .nav-actions .btn-secondary{color:#fff;background:#ffffff1a;border-color:#fff3}.navbar.dark .nav-actions .btn-secondary:hover{background:#ffffff26}.cg-loading{height:100%;min-height:200px;color:var(--text-muted);font-size:var(--font-base);justify-content:center;align-items:center;gap:.75rem;display:flex}.spinner{border:3px solid var(--border);border-top-color:var(--primary);border-radius:50%;width:22px;height:22px;animation:.8s linear infinite spin;display:inline-block}.cg-block{z-index:500;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#f1f5f9f2;justify-content:center;align-items:center;padding:2rem;display:flex;position:fixed;inset:0}.cg-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-2xl);box-shadow:var(--shadow-xl);text-align:center;flex-direction:column;align-items:center;gap:1rem;width:100%;max-width:420px;padding:3rem 2.5rem;display:flex}.cg-icon{background:var(--danger-light);width:80px;height:80px;color:var(--danger);border-radius:50%;justify-content:center;align-items:center;margin-bottom:.5rem;display:flex}.cg-card h2{font-size:var(--font-2xl);color:var(--text);letter-spacing:-.03em;margin:0;font-weight:800}.cg-card p{color:var(--text-muted);font-size:var(--font-base);margin:0;line-height:1.6}.credits-badge{font-size:var(--font-xs);background:var(--primary-light);color:var(--primary);border-radius:99px;align-items:center;gap:4px;padding:3px 10px;font-weight:700;display:inline-flex}.credits-badge.warning{background:var(--warning-light);color:var(--warning)}.credits-badge.expired{background:var(--danger-light);color:var(--danger)}.home-page{background:var(--bg);min-height:100vh}.hero-section{grid-template-columns:1fr 1fr;align-items:center;gap:4rem;max-width:1100px;margin:0 auto;padding:5rem 2rem 3rem;display:grid}.hero-left{flex-direction:column;gap:1.5rem;display:flex}.hero-eyebrow{background:var(--primary-muted);color:var(--primary);font-size:var(--font-sm);border:1px solid var(--primary-light);border-radius:99px;align-items:center;gap:6px;width:fit-content;padding:5px 14px;font-weight:600;display:inline-flex}.hero-title{color:var(--text);letter-spacing:-.04em;font-size:clamp(2rem,4vw,3rem);font-weight:900;line-height:1.15}.hero-title span{color:var(--primary)}.hero-subtitle{font-size:var(--font-lg);color:var(--text-muted);max-width:480px;line-height:1.7}.hero-cta{flex-wrap:wrap;gap:.875rem;display:flex}.hero-stats{border-top:1px solid var(--border);gap:2rem;padding-top:1rem;display:flex}.hero-stat strong{font-size:var(--font-xl);color:var(--text);letter-spacing:-.03em;font-weight:800;display:block}.hero-stat span{font-size:var(--font-sm);color:var(--text-muted);font-weight:500}.hero-visual{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-2xl);box-shadow:var(--shadow-xl);flex-direction:column;display:flex;overflow:hidden}.preview-browser-bar{border-bottom:1px solid var(--border);background:#f8fafc;align-items:center;gap:12px;padding:12px 16px;display:flex}.preview-dots{gap:6px;display:flex}.preview-dots span{background:var(--border);border-radius:50%;width:10px;height:10px}.preview-dots span:first-child{background:#fca5a5}.preview-dots span:nth-child(2){background:#fde68a}.preview-dots span:nth-child(3){background:#86efac}.preview-url{background:var(--bg);color:var(--text-muted);letter-spacing:.01em;border-radius:6px;flex:1;padding:5px 12px;font-size:11px;font-weight:500}.preview-body{min-height:320px;display:flex}.preview-sidebar{background:#1e293b;flex-direction:column;flex-shrink:0;gap:2px;width:100px;padding:12px 8px;display:flex}.preview-sidebar-logo{color:#f8fafc;border-bottom:1px solid #ffffff14;align-items:center;gap:5px;margin-bottom:8px;padding:8px;font-size:10px;font-weight:800;display:flex}.preview-sidebar-logo em{color:#60a5fa;font-style:normal}.preview-sidebar-item{color:#94a3b8;white-space:nowrap;text-overflow:ellipsis;border-radius:5px;padding:6px 8px;font-size:8px;font-weight:500;overflow:hidden}.preview-sidebar-item.active{background:var(--primary);color:#fff;font-weight:600}.preview-content{background:var(--bg);flex-direction:column;flex:1;gap:14px;padding:16px;display:flex}.preview-skeleton-text{background:var(--border);border-radius:4px;height:8px}.preview-skeleton-text.title{background:#cbd5e1;width:55%;height:12px}.preview-skeleton-text.subtitle{width:35%;margin-top:6px}.preview-skeleton-text.short{flex-shrink:0;width:70px;height:7px}.preview-skeleton-text.shorter{flex-shrink:0;width:50px;height:7px}.preview-skeleton-dot{background:var(--primary-light);border-radius:4px;flex-shrink:0;width:8px;height:8px}.preview-content-bar{flex-direction:column;gap:2px;display:flex}.preview-stat-row{grid-template-columns:repeat(3,1fr);gap:10px;display:grid}.preview-stat-block{background:var(--surface);border:1px solid var(--border);border-radius:8px;flex-direction:column;gap:8px;padding:10px;display:flex}.preview-stat-block-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.04em;font-size:9px;font-weight:600}.preview-stat-block-bar{background:var(--border);border-radius:4px;height:20px}.preview-stat-block.blue .preview-stat-block-bar{background:var(--primary-light)}.preview-stat-block.green .preview-stat-block-bar{background:var(--success-light)}.preview-stat-block.purple .preview-stat-block-bar{background:#f3e8ff}.preview-table-area{background:var(--surface);border:1px solid var(--border);border-radius:8px;flex-direction:column;flex:1;gap:8px;padding:10px;display:flex}.preview-table-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.04em;font-size:9px;font-weight:700}.preview-table-rows{flex-direction:column;gap:6px;display:flex}.preview-table-row{background:var(--bg);border-radius:5px;align-items:center;gap:8px;padding:6px 8px;display:flex}.features-section{background:var(--surface);border-top:1px solid var(--border);border-bottom:1px solid var(--border);padding:4rem 2rem}.features-inner{max-width:1100px;margin:0 auto}.features-title{text-align:center;font-size:var(--font-2xl);color:var(--text);letter-spacing:-.03em;margin-bottom:.5rem;font-weight:800}.features-sub{text-align:center;color:var(--text-muted);margin-bottom:3rem}.features-grid{grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:1.5rem;display:grid}.feature-card{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-lg);flex-direction:column;gap:1rem;padding:1.75rem;transition:box-shadow .2s,transform .2s;display:flex}.feature-card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}.feature-icon{border-radius:var(--radius-md);color:#fff;flex-shrink:0;justify-content:center;align-items:center;width:48px;height:48px;display:flex}.feature-icon.blue{background:var(--primary)}.feature-icon.green{background:var(--success)}.feature-icon.amber{background:var(--warning)}.feature-icon.purple{background:#7c3aed}.feature-icon.rose{background:#e11d48}.feature-icon.cyan{background:var(--info)}.feature-card h3{font-size:var(--font-lg);color:var(--text);margin:0;font-weight:700}.feature-card p{color:var(--text-muted);font-size:var(--font-base);margin:0;line-height:1.65}.cta-section{text-align:center;flex-direction:column;align-items:center;gap:1.25rem;max-width:700px;margin:0 auto;padding:5rem 2rem;display:flex}.cta-section h2{font-size:var(--font-2xl);color:var(--text);letter-spacing:-.03em;font-weight:800}.cta-section p{color:var(--text-muted);font-size:var(--font-lg)}.cta-btns{flex-wrap:wrap;justify-content:center;gap:1rem;display:flex}@media (width<=900px){.hero-section{grid-template-columns:1fr;gap:2rem;padding-top:3rem}.hero-visual{display:none}}@media (width<=640px){.hero-section{padding:2rem 1rem}.hero-title{font-size:1.75rem}.hero-stats{flex-wrap:wrap;gap:1.25rem}.features-section{padding:2.5rem 1rem}.cta-section{padding:3rem 1rem}}.input-wrapper{flex-direction:column;gap:6px;width:100%;display:flex}.input-label{font-size:var(--font-sm);color:var(--text-secondary);letter-spacing:.01em;align-items:center;gap:4px;font-weight:600;display:flex}.input-required{color:var(--danger)}.input-field{background:var(--surface);border:1.5px solid var(--border);border-radius:var(--radius-md);width:100%;color:var(--text);font-size:var(--font-base);min-height:var(--touch-min);padding:.625rem .875rem;line-height:1.5;transition:border-color .15s,box-shadow .15s}.input-field::placeholder{color:var(--text-placeholder)}.input-field:hover:not(:disabled){border-color:#94a3b8}.input-field:focus{border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-light);outline:none}.input-field:disabled{background:var(--bg);color:var(--text-muted);cursor:not-allowed}.input-field.input-error{border-color:var(--danger)}.input-field.input-error:focus{box-shadow:0 0 0 3px var(--danger-light)}.input-error-text{font-size:var(--font-xs);color:var(--danger);font-weight:500}.input-helper{font-size:var(--font-xs);color:var(--text-muted)}.auth-page{background:var(--bg);justify-content:center;align-items:center;min-height:100vh;padding:2rem 1rem;display:flex}.auth-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-2xl);width:100%;max-width:440px;box-shadow:var(--shadow-xl);padding:2.5rem 2.5rem 2rem}.auth-logo{align-items:center;gap:10px;margin-bottom:2rem;display:flex}.auth-logo-icon{background:var(--primary);border-radius:var(--radius-md);color:#fff;justify-content:center;align-items:center;width:42px;height:42px;display:flex;box-shadow:0 2px 8px #6366f159}.auth-logo span{font-size:var(--font-xl);color:var(--text);letter-spacing:-.03em;font-weight:800}.auth-logo span em{color:var(--primary);font-style:normal}.auth-form-header{margin-bottom:1.75rem}.auth-form-header h2{font-size:var(--font-2xl);color:var(--text);letter-spacing:-.03em;margin-bottom:.25rem;font-weight:800}.auth-form-header p{color:var(--text-muted);font-size:var(--font-base)}.auth-form{flex-direction:column;gap:1rem;display:flex}.auth-form-grid{grid-template-columns:1fr 1fr;gap:1rem;display:grid}.auth-form-grid .span-2{grid-column:span 2}.auth-error{background:var(--danger-light);border-radius:var(--radius-md);color:var(--danger);font-size:var(--font-sm);border:1px solid #fca5a5;padding:.875rem 1rem;font-weight:500}.auth-success{background:var(--success-light);border-radius:var(--radius-md);color:var(--success);font-size:var(--font-sm);border:1px solid #6ee7b7;margin-bottom:.5rem;padding:.875rem 1rem;font-weight:500}.auth-divider{align-items:center;gap:1rem;margin:.5rem 0;display:flex}.auth-divider hr{background:var(--border);flex:1;height:1px}.auth-divider span{font-size:var(--font-sm);color:var(--text-muted)}.auth-footer{text-align:center;font-size:var(--font-sm);color:var(--text-muted);margin-top:1.5rem}.auth-footer a{color:var(--primary);font-weight:600}@media (width<=480px){.auth-card{border-radius:var(--radius-xl);padding:2rem 1.5rem 1.5rem}.auth-form-grid{grid-template-columns:1fr}.auth-form-grid .span-2{grid-column:span 1}}@page{size:A4;margin:0}@media screen{.invoice-print-overlay{z-index:9999;background:#f0f0f0;width:100%;height:100%;padding:1rem 0;position:fixed;top:0;left:0;overflow-y:auto}}.invoice-page{color:#000;box-sizing:border-box;background:#fff;width:210mm;min-height:297mm;margin:0 auto;padding:10mm;font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif}@media print{body *{visibility:hidden}.invoice-print-overlay,.invoice-print-overlay *{visibility:visible}.invoice-print-overlay{background:0 0;width:210mm;margin:0;padding:0;position:absolute;top:0;left:0}.invoice-page{border:none;width:210mm;margin:0;padding:10mm}.no-print{display:none!important}.invoice-item{border-bottom:1px dashed #777!important}}.invoice-item{page-break-inside:avoid;box-sizing:border-box;border-bottom:1px dashed #ccc;width:100%;padding:5mm 0}.invoice-header{border-bottom:1px solid #000;justify-content:space-between;align-items:center;margin-bottom:3mm;padding-bottom:2mm;display:flex}.invoice-meta{align-items:center;gap:8px;margin-top:1px;font-size:.75rem;display:flex}.invoice-meta .separator{opacity:.3}.students-table{border-collapse:collapse;width:100%;margin-bottom:5px}.students-table th{text-align:left;border-top:1px solid #000;border-bottom:1px solid #000;padding:4px;font-size:.75rem}.students-table td{border-bottom:1px solid #eee;padding:4px;font-size:.75rem}.invoice-footer{justify-content:space-between;align-items:flex-end;margin-top:4px;display:flex}.due-date-note{text-align:left;border-left:2px solid #000;max-width:60%;padding-left:6px;font-size:.7rem}.print-controls{z-index:100;background:#f8f9fa;border-bottom:1px solid #ddd;flex-direction:column;gap:.75rem;padding:.75rem 1.5rem;display:flex;position:sticky;top:0}.main-actions{justify-content:center;gap:1rem;display:flex}.filter-toolbar{background:#fff;border:1px solid #eee;border-radius:8px;justify-content:center;align-items:center;gap:1.5rem;padding:.5rem;display:flex;box-shadow:0 1px 3px #0000001a}.filter-group{color:#666;align-items:center;gap:.5rem;display:flex}.filter-group input,.filter-group select{border:1px solid #ddd;border-radius:4px;outline:none;padding:6px 10px;font-size:.85rem}.filter-group input:focus,.filter-group select:focus{border-color:#000}.filter-group.search input{width:200px}.batch-nav{border-left:1px solid #eee;align-items:center;gap:.75rem;padding-left:1rem;font-size:.85rem;font-weight:600;display:flex}.no-invoices-message{text-align:center;color:#666;padding:3rem;font-style:italic}@page{size:A4;margin:0}@media screen{.receipt-print-overlay{z-index:9999;background:#f0f0f0;width:100%;height:100%;padding:1rem 0;position:fixed;top:0;left:0;overflow-y:auto}}.receipt-page{color:#000;box-sizing:border-box;background:#fff;width:210mm;min-height:297mm;margin:0 auto;padding:5mm 10mm;font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif;line-height:1.2}@media print{body *{visibility:hidden}.receipt-print-overlay,.receipt-print-overlay *{visibility:visible}.receipt-print-overlay{background:0 0;width:210mm;margin:0;padding:0;position:absolute;top:0;left:0}.receipt-page{border:none;width:210mm;margin:0;padding:10mm}.no-print{display:none!important}}.receipt-item{page-break-inside:avoid;box-sizing:border-box;width:100%;padding:2mm 0}.receipt-header{border-bottom:1px solid #000;justify-content:space-between;align-items:center;margin-bottom:2mm;padding-bottom:1mm;display:flex}.school-info h1{letter-spacing:-.02em;margin:0;font-size:1.1rem}.receipt-meta{align-items:center;gap:8px;margin-top:1px;font-size:.75rem;display:flex}.receipt-meta .separator{opacity:.3}.school-logo-wrap{justify-content:flex-end;align-items:center;width:15mm;height:15mm;display:flex}.school-logo{object-fit:contain;filter:grayscale();max-width:100%;max-height:100%}.parent-info{margin-bottom:2mm;font-size:.8rem}.parent-info table{width:100%}.receipt-details-table{border-collapse:collapse;width:100%;margin-bottom:8px}.receipt-details-table th{text-align:left;background-color:#f9f9f9;border-top:1px solid #000;border-bottom:1px solid #000;padding:6px;font-size:.8rem}.receipt-details-table td{border-bottom:1px solid #eee;padding:4px 6px;font-size:.85rem}.receipt-footer{justify-content:space-between;align-items:flex-start;margin-top:10px;display:flex}.summary-box{width:220px}.summary-row{justify-content:space-between;padding:2px 0;font-size:.8rem;display:flex}.summary-row.total{border-top:1px solid #000;margin-top:4px;padding-top:4px;font-size:1rem;font-weight:800}.receipt-note{text-align:left;border-left:2px solid #000;max-width:60%;padding-left:8px;font-size:.75rem;font-style:italic}.print-controls{z-index:100;background:#f8f9fa;border-bottom:1px solid #ddd;justify-content:center;gap:1rem;padding:1rem 1.5rem;display:flex;position:sticky;top:0}.signature-wrap{justify-content:flex-end;margin-top:40px;display:flex}.signature-line{text-align:center;border-top:1px solid #000;width:200px;padding-top:4px;font-size:.75rem}.payment-status-watermark{color:#0000000d;text-transform:uppercase;pointer-events:none;z-index:0;font-size:8rem;font-weight:900;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)rotate(-30deg)}.dash-shell{background:var(--bg);height:100vh;display:flex;overflow:hidden}.dash-sidebar{width:var(--sidebar-width);min-width:var(--sidebar-width);background:var(--sidebar-bg);flex-direction:column;flex-shrink:0;height:100vh;display:flex;overflow:hidden auto}.sidebar-logo{border-bottom:1px solid #ffffff14;align-items:center;gap:10px;padding:1.25rem 1rem;text-decoration:none;display:flex}.sidebar-logo-icon{background:var(--primary);border-radius:var(--radius-md);width:36px;height:36px;color:var(--text);box-shadow:var(--shadow-glow);flex-shrink:0;justify-content:center;align-items:center;display:flex}.sidebar-logo-text{font-size:var(--font-lg);color:var(--text);letter-spacing:-.03em;font-weight:800}.sidebar-logo-text em{color:var(--primary);font-style:normal}.sidebar-nav{flex-direction:column;gap:2px;padding:0 .5rem;display:flex}.sidebar-nav-item{border-radius:var(--radius-md);color:var(--sidebar-text);cursor:pointer;font-size:var(--font-base);text-align:left;background:0 0;border:none;align-items:center;gap:10px;width:100%;min-height:42px;padding:.65rem .875rem;font-weight:500;transition:all .15s;display:flex}.sidebar-nav-item:hover{color:#f1f5f9;background:#ffffff12}.sidebar-nav-item.active{background:var(--primary);color:#fff;font-weight:600;box-shadow:0 2px 8px #2563eb59}.sidebar-nav-item svg{flex-shrink:0}.sidebar-section,.sidebar-section-header{flex-direction:column;display:flex}.sidebar-nav-item.has-sub{justify-content:flex-start}.sidebar-nav-item.has-sub .sub-chevron{margin-left:auto;transition:transform .2s}.sidebar-sub-items{flex-direction:column;gap:1px;padding-left:1.5rem;display:none}.sidebar-section-header.is-open .sidebar-sub-items{display:flex}.sidebar-sub-item{border-radius:var(--radius-sm);color:var(--sidebar-text);cursor:pointer;font-size:var(--font-sm);text-align:left;opacity:.8;background:0 0;border:none;align-items:center;width:100%;min-height:34px;padding:.4rem .75rem;transition:all .15s;display:flex}.sidebar-sub-item:hover{color:#f1f5f9;opacity:1;background:#ffffff0f}.sidebar-sub-item.active{color:var(--primary);opacity:1;background:#2563eb40;font-weight:600}.sidebar-bottom{border-top:1px solid #ffffff0f;flex-direction:column;gap:2px;margin-top:auto;padding:.5rem;display:flex}.sidebar-logout{border-radius:var(--radius-md);width:100%;color:var(--text-muted);cursor:pointer;font-size:var(--font-sm);background:0 0;border:none;align-items:center;gap:10px;min-height:40px;padding:.65rem .875rem;font-weight:500;transition:all .15s;display:flex}.sidebar-logout:hover{color:var(--danger);background:#dc26261f}.dash-main{flex-direction:column;flex:1;min-width:0;display:flex;overflow:hidden}.dash-topbar{background:var(--surface);border-bottom:1px solid var(--border);height:60px;box-shadow:var(--shadow-xs);flex-shrink:0;align-items:center;gap:1rem;padding:0 1.75rem;display:flex}.dash-topbar-title{font-size:var(--font-lg);color:var(--text);letter-spacing:-.02em;flex:1;font-weight:700}.dash-topbar-actions{align-items:center;gap:.75rem;display:flex}.dash-content{flex:1;padding:1.75rem;overflow-y:auto}.overview-welcome{margin-bottom:1.75rem}.overview-welcome h2{font-size:var(--font-2xl);color:var(--text);letter-spacing:-.03em;margin-bottom:.25rem;font-weight:800}.overview-welcome p{color:var(--text-muted);font-size:var(--font-base)}.overview-stats{grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:1rem;margin-bottom:2rem;display:grid}.ov-stat-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);flex-direction:column;gap:.5rem;padding:1.25rem 1.25rem 1rem;transition:box-shadow .2s,transform .2s;display:flex;box-shadow:0 1px 3px #0000000f,0 1px 2px #0000000a}.ov-stat-card:hover{transform:translateY(-1px);box-shadow:0 4px 12px #00000014}.ov-stat-icon{border-radius:10px;justify-content:center;align-items:center;width:36px;height:36px;margin-bottom:.25rem;display:flex}.ov-stat-card.blue .ov-stat-icon{color:var(--primary);background:#3b82f626}.ov-stat-card.green .ov-stat-icon{color:#4ade80;background:#22c55e26}.ov-stat-card.purple .ov-stat-icon{color:#c084fc;background:#a855f726}.ov-stat-card.danger .ov-stat-icon{color:#f87171;background:#ef444426}.ov-stat-card.rose .ov-stat-icon{color:#fb7185;background:#f43f5e26}.ov-stat-card.cyan .ov-stat-icon{color:#22d3ee;background:#06b6d426}.ov-stat-card.amber .ov-stat-icon{color:#fbbf24;background:#f59e0b26}.ov-stat-label{font-size:var(--font-xs);color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em;font-weight:600}.ov-stat-value{font-size:var(--font-2xl);color:var(--text);letter-spacing:-.03em;font-weight:800;line-height:1}.ov-stat-sub{font-size:var(--font-xs);color:var(--text-muted)}.overview-hero-actions{margin-bottom:2rem}.overview-hero-title{font-size:var(--font-xs);color:var(--text-muted);text-transform:uppercase;letter-spacing:.07em;margin-bottom:.875rem;font-weight:700}.hero-actions{grid-template-columns:repeat(4,1fr);gap:1rem;display:grid}.hero-action-btn{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);cursor:pointer;text-align:left;box-shadow:var(--shadow-xs);align-items:center;gap:1rem;min-height:120px;padding:1.25rem;transition:all .18s;display:flex}.hero-action-btn:hover{box-shadow:var(--shadow-lg);border-color:#0000;transform:translateY(-3px)}.hero-action-btn.purple:hover{background:#a855f71f;border-color:#a855f766}.hero-action-btn.blue:hover{background:#6366f11f;border-color:#6366f166}.hero-action-btn.rose:hover{background:#f43f5e1f;border-color:#f43f5e66}.hero-action-btn.cyan:hover{background:#06b6d41f;border-color:#06b6d466}.hero-action-icon{border-radius:var(--radius-md);flex-shrink:0;justify-content:center;align-items:center;width:52px;height:52px;display:flex}.hero-action-btn.purple .hero-action-icon{color:#c084fc;background:#a855f726}.hero-action-btn.blue .hero-action-icon{color:#818cf8;background:#6366f126}.hero-action-btn.rose .hero-action-icon{color:#fb7185;background:#f43f5e26}.hero-action-btn.cyan .hero-action-icon{color:#22d3ee;background:#06b6d426}.hero-action-content{flex-direction:column;gap:.25rem;display:flex}.hero-action-label{font-size:var(--font-base);color:var(--text);font-weight:700;line-height:1.3}.hero-action-sub{font-size:var(--font-xs);color:var(--text-muted)}.overview-section-title{font-size:var(--font-base);color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em;font-weight:700;font-size:var(--font-xs);margin-bottom:.875rem}.quick-actions{grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:.875rem;margin-bottom:2rem;display:grid}.qa-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);cursor:pointer;box-shadow:var(--shadow-xs);text-align:left;flex-direction:column;align-items:flex-start;gap:.75rem;padding:1.25rem 1rem;transition:all .15s;display:flex}.qa-card:hover{box-shadow:var(--shadow-md);border-color:var(--primary);transform:translateY(-2px)}.qa-icon{border-radius:var(--radius-md);width:44px;height:44px;color:var(--text);justify-content:center;align-items:center;display:flex}.qa-icon.blue{background:var(--primary)}.qa-icon.green{background:var(--success)}.qa-icon.amber{background:var(--warning)}.qa-icon.purple{background:#7c3aed}.qa-icon.rose{background:#e11d48}.qa-icon.cyan{background:#0891b2}.qa-label{font-size:var(--font-sm);color:var(--text);font-weight:700;line-height:1.3}.qa-sub{font-size:var(--font-xs);color:var(--text-muted)}.school-info-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-xs);align-items:center;gap:1.25rem;padding:1.25rem 1.5rem;display:flex}.school-info-avatar{background:linear-gradient(135deg, var(--primary), #60a5fa);border-radius:var(--radius-lg);width:52px;height:52px;font-size:var(--font-xl);color:var(--text);flex-shrink:0;justify-content:center;align-items:center;font-weight:800;display:flex}.school-info-details h3{font-size:var(--font-lg);color:var(--text);margin-bottom:.25rem;font-weight:700}.school-info-details p{font-size:var(--font-sm);color:var(--text-muted)}.buy-section{flex-direction:column;gap:1.5rem;max-width:720px;display:flex}.alert-banner{border-radius:var(--radius-md);background:var(--danger-light);border:1px solid var(--border);color:var(--danger);align-items:flex-start;gap:1rem;padding:1rem 1.25rem;display:flex}.alert-banner.warning{background:var(--warning-light);border-color:var(--border);color:var(--warning)}.alert-banner svg{flex-shrink:0;margin-top:2px}.alert-banner strong{margin-bottom:2px;font-weight:700;display:block}.alert-banner p{font-size:var(--font-sm);opacity:.9;margin:0}.pricing-grid{grid-template-columns:1fr 1fr;gap:1rem;display:grid}.pricing-card{background:var(--surface);border:2px solid var(--border);border-radius:var(--radius-lg);cursor:pointer;box-shadow:var(--shadow-xs);padding:1.5rem;transition:all .15s;position:relative}.pricing-card:hover{border-color:var(--primary);box-shadow:var(--shadow-md)}.pricing-card.selected{border-color:var(--primary);background:var(--primary-muted);box-shadow:0 0 0 3px var(--primary-light)}.popular-badge{background:var(--primary);color:#fff;font-size:var(--font-xs);white-space:nowrap;border-radius:99px;padding:3px 14px;font-weight:700;position:absolute;top:-12px;left:50%;transform:translate(-50%);box-shadow:0 2px 8px #2563eb4d}.plan-name{font-size:var(--font-sm);color:var(--text-muted);margin-bottom:.5rem;font-weight:600}.plan-price{color:var(--text);letter-spacing:-.04em;margin-bottom:.25rem;font-size:2rem;font-weight:900}.plan-credits{font-size:var(--font-sm);color:var(--primary);font-weight:600}.plan-duration{font-size:var(--font-xs);color:var(--text-muted);margin-top:2px}.plan-check{border:2px solid var(--border);border-radius:50%;width:22px;height:22px;transition:all .15s;position:absolute;top:1rem;right:1rem}.pricing-card.selected .plan-check{background:var(--primary);border-color:var(--primary)}.pricing-card.selected .plan-check:after{content:"✓";color:#fff;font-size:12px;font-weight:700;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.checkout-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-xs);padding:1.5rem}.checkout-card h3{font-size:var(--font-lg);margin-bottom:1.25rem;font-weight:700}.summary-table{border-collapse:collapse;width:100%;margin-bottom:1.25rem}.summary-table td{font-size:var(--font-base);border-bottom:1px solid var(--border);padding:.625rem 0}.summary-table td:last-child{text-align:right;font-weight:600}.summary-table tr:last-child td{font-size:var(--font-lg);color:var(--text);border-bottom:none;font-weight:800}.pay-method-row{grid-template-columns:1fr 1fr;gap:.75rem;margin:1rem 0;display:grid}.pay-method-btn{border:2px solid var(--border);border-radius:var(--radius-md);background:var(--bg);color:var(--text-muted);cursor:pointer;font-weight:600;font-size:var(--font-base);text-align:center;padding:.875rem;transition:all .15s}.pay-method-btn:hover{border-color:var(--primary);color:var(--primary)}.pay-method-btn.active{border-color:var(--primary);background:var(--primary-muted);color:var(--primary);font-weight:700}.pay-instructions{background:var(--bg);border-radius:var(--radius-md);font-size:var(--font-sm);color:var(--text-secondary);border:1px solid var(--border);margin:1rem 0;padding:1rem;line-height:1.7}.pay-instructions strong{color:var(--primary)}.history-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-xs);overflow:hidden}.data-table{border-collapse:collapse;width:100%;font-size:var(--font-sm)}.data-table th{background:var(--bg);text-align:left;font-size:var(--font-xs);color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em;border-bottom:1px solid var(--border);padding:.875rem 1.25rem;font-weight:700}.data-table td{border-bottom:1px solid var(--border);color:var(--text-secondary);padding:1rem 1.25rem}.data-table tr:last-child td{border-bottom:none}.data-table tr:hover td{background:var(--surface-hover)}.status-cell{align-items:center;gap:6px;display:flex}.dash-loading{height:100vh;color:var(--text-muted);background:var(--bg);justify-content:center;align-items:center;gap:.75rem;display:flex}.section-empty{color:var(--text-muted);text-align:center;flex-direction:column;justify-content:center;align-items:center;gap:1rem;padding:4rem 2rem;display:flex}.section-empty svg{opacity:.3}.section-empty p{font-size:var(--font-lg);font-weight:600}@media (width<=1024px){.hero-actions{grid-template-columns:repeat(2,1fr)}}@media (width<=768px){.dash-shell{flex-direction:column;height:auto;min-height:100vh}.dash-sidebar{flex-flow:wrap;width:100%;height:auto}.sidebar-logo{flex:none}.sidebar-nav{flex-flow:wrap;flex:1;padding:.5rem}.sidebar-nav-item{min-height:38px;font-size:var(--font-xs);flex:none;gap:6px;padding:.5rem .75rem}.sidebar-bottom{display:none}.dash-main{overflow:visible}.dash-content{padding:1rem;overflow:visible}.pricing-grid{grid-template-columns:1fr}.quick-actions{grid-template-columns:1fr 1fr}}@media (width<=480px){.overview-stats,.quick-actions{grid-template-columns:1fr 1fr}.hero-actions{grid-template-columns:1fr}.hero-action-btn{min-height:80px}}.buy-credit-link{color:var(--text-muted)!important;font-size:var(--font-xs)!important}.buy-credit-link:hover{color:var(--primary)!important;background:#ffffff12!important}.quick-fee-modal{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-xl);width:100%;max-width:440px;box-shadow:var(--shadow-xl);animation:.2s ease-out fadeUp;overflow:hidden}.qfm-header{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:1rem 1.25rem;display:flex}.qfm-title{font-size:var(--font-md);color:var(--text);align-items:center;gap:.625rem;font-weight:700;display:flex}.qfm-close{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-md);cursor:pointer;width:32px;height:32px;color:var(--text-muted);justify-content:center;align-items:center;transition:all .15s;display:flex}.qfm-close:hover{background:var(--danger-light);color:var(--danger);border-color:#0000}.qfm-step-label{font-size:var(--font-xs);color:var(--text-muted);text-transform:uppercase;letter-spacing:.07em;margin-bottom:.75rem;font-weight:700}.qfm-search-box{background:var(--bg);border:1.5px solid var(--border);border-radius:var(--radius-md);align-items:center;gap:.625rem;margin-bottom:.875rem;padding:0 .875rem;display:flex}.qfm-search-box svg{color:var(--text-muted);flex-shrink:0}.qfm-search-box input{color:var(--text);width:100%;font-size:var(--font-base);background:0 0;border:none;outline:none;padding:.625rem 0}.qfm-search-box input::placeholder{color:var(--text-placeholder)}.qfm-parent-list{flex-direction:column;gap:.5rem;max-height:280px;display:flex;overflow-y:auto}.qfm-parent-item{border:1px solid var(--border);border-radius:var(--radius-md);background:var(--bg);cursor:pointer;text-align:left;align-items:center;gap:.875rem;padding:.75rem;transition:all .15s;display:flex}.qfm-parent-item:hover{border-color:var(--primary);background:var(--primary-muted)}.qfm-parent-avatar{width:40px;height:40px;font-size:var(--font-sm);color:var(--text);background:linear-gradient(135deg, var(--primary), #60a5fa);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-weight:800;display:flex}.qfm-parent-avatar.sm{width:32px;height:32px;font-size:var(--font-xs)}.qfm-parent-info{flex:1;min-width:0}.qfm-parent-name{font-size:var(--font-sm);color:var(--text);font-weight:700;display:block}.qfm-parent-contact{font-size:var(--font-xs);color:var(--text-muted);margin-top:2px;display:block}.qfm-empty{text-align:center;color:var(--text-muted);font-size:var(--font-sm);padding:2rem}.qfm-success{color:var(--success);font-weight:700;font-size:var(--font-lg);flex-direction:column;justify-content:center;align-items:center;gap:1rem;padding:3rem 2rem;display:flex}.qfm-selected-parent{margin-bottom:1rem}.qfm-back-btn{cursor:pointer;color:var(--primary);font-size:var(--font-xs);background:0 0;border:none;align-items:center;gap:.375rem;margin-bottom:.75rem;padding:0;font-weight:600;display:inline-flex}.qfm-back-btn:hover{color:var(--primary-dark)}.qfm-parent-badge{background:var(--primary-muted);border-radius:var(--radius-md);font-size:var(--font-sm);color:var(--primary);align-items:center;gap:.625rem;padding:.625rem 1rem;font-weight:700;display:flex}.qfm-children-info{flex-wrap:wrap;gap:.5rem;margin:.75rem 0;display:flex}.qfm-child-chip{background:var(--bg);border:1px solid var(--border);font-size:var(--font-xs);color:var(--text);border-radius:99px;padding:4px 12px;font-weight:600}.qfm-form{flex-direction:column;gap:.875rem;display:flex}.qfm-form-group{flex-direction:column;gap:6px;display:flex}.qfm-form-group label{font-size:var(--font-sm);color:var(--text-secondary);font-weight:600}.qfm-form-group input,.qfm-form-group select{background:var(--bg);border:1.5px solid var(--border);border-radius:var(--radius-md);color:var(--text);font-size:var(--font-base);padding:.625rem .875rem;transition:border-color .15s}.qfm-form-group input:focus,.qfm-form-group select:focus{border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-light);outline:none}.qfm-search-step{padding:1.25rem}.qfm-pay-step{flex-direction:column;gap:1rem;padding:1.25rem;display:flex}.dash-toast{border-radius:var(--radius-lg);font-size:var(--font-sm);box-shadow:var(--shadow-lg);z-index:300;align-items:center;gap:.75rem;padding:.875rem 1.25rem;font-weight:600;animation:.25s ease-out fadeUp;display:flex;position:fixed;bottom:1.5rem;right:1.5rem}.dash-toast.success{background:var(--success);color:#fff}.dash-toast.error{background:var(--danger);color:#fff}.admin-shell{background:var(--bg);flex-direction:column;min-height:100vh;display:flex}.admin-header{background:var(--sidebar-bg);flex-shrink:0;align-items:center;gap:1rem;height:64px;padding:0 1.75rem;display:flex}.admin-logo{align-items:center;gap:10px;text-decoration:none;display:flex}.admin-logo-icon{background:var(--primary);border-radius:var(--radius-md);color:#fff;justify-content:center;align-items:center;width:36px;height:36px;display:flex;box-shadow:0 2px 8px #2563eb66}.admin-logo-text{font-size:var(--font-lg);color:var(--text);letter-spacing:-.03em;font-weight:800}.admin-logo-text em{color:var(--primary);font-style:normal}.admin-badge{font-size:var(--font-xs);color:var(--sidebar-text);letter-spacing:.05em;text-transform:uppercase;background:#ffffff1f;border-radius:99px;padding:2px 8px;font-weight:700}.admin-header-right{align-items:center;gap:.75rem;margin-left:auto;display:flex}.admin-body{flex:1;width:100%;max-width:1300px;margin:0 auto;padding:1.75rem}.admin-stats{grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:1rem;margin-bottom:1.75rem;display:grid}.admin-stat{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-xs);align-items:center;gap:1rem;padding:1.25rem;display:flex}.admin-stat-icon{border-radius:var(--radius-md);color:#fff;flex-shrink:0;justify-content:center;align-items:center;width:44px;height:44px;display:flex}.admin-stat-icon.blue{background:var(--primary)}.admin-stat-icon.amber{background:var(--warning)}.admin-stat-icon.green{background:var(--success)}.admin-stat-icon.purple{background:#7c3aed}.admin-stat-number{font-size:var(--font-2xl);color:var(--text);letter-spacing:-.04em;margin-bottom:2px;font-weight:800;line-height:1}.admin-stat-label{font-size:var(--font-xs);color:var(--text-muted);font-weight:600}.admin-tabs{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);width:fit-content;box-shadow:var(--shadow-xs);gap:2px;margin-bottom:1.25rem;padding:4px;display:flex}.admin-tab{border-radius:var(--radius-md);color:var(--text-muted);cursor:pointer;font-size:var(--font-sm);background:0 0;border:none;align-items:center;gap:6px;padding:.5rem 1.25rem;font-weight:600;transition:all .15s;display:flex}.admin-tab:hover{color:var(--text);background:var(--bg)}.admin-tab.active{background:var(--primary);color:#fff;box-shadow:0 1px 4px #2563eb4d}.admin-panel{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-xl);box-shadow:var(--shadow-sm);overflow:hidden}.admin-panel-header{border-bottom:1px solid var(--border);flex-wrap:wrap;justify-content:space-between;align-items:center;gap:1rem;padding:1.25rem 1.5rem;display:flex}.admin-panel-header h2{font-size:var(--font-lg);color:var(--text);margin:0;font-weight:700}.admin-filter-bar{flex-wrap:wrap;align-items:center;gap:.75rem;display:flex}.admin-search{background:var(--bg);border:1.5px solid var(--border);border-radius:var(--radius-md);align-items:center;gap:6px;min-width:220px;padding:0 .875rem;display:flex}.admin-search svg{color:var(--text-muted);flex-shrink:0}.admin-search input{color:var(--text);font-size:var(--font-sm);background:0 0;border:none;outline:none;width:100%;padding:.625rem 0}.admin-search input::placeholder{color:var(--text-placeholder)}.filter-chips{flex-wrap:wrap;gap:4px;display:flex}.filter-chip{border:1.5px solid var(--border);color:var(--text-muted);cursor:pointer;font-size:var(--font-xs);background:0 0;border-radius:99px;padding:4px 12px;font-weight:600;transition:all .15s}.filter-chip:hover{border-color:var(--primary);color:var(--primary)}.filter-chip.active{background:var(--primary-muted);border-color:var(--primary);color:var(--primary)}.admin-table-wrap{overflow-x:auto}.admin-table{border-collapse:collapse;width:100%;font-size:var(--font-sm)}.admin-table th{background:var(--bg);text-align:left;font-size:var(--font-xs);color:var(--text-muted);text-transform:uppercase;letter-spacing:.07em;border-bottom:1px solid var(--border);white-space:nowrap;padding:.75rem 1.25rem;font-weight:700}.admin-table td{border-bottom:1px solid var(--border);color:var(--text-secondary);vertical-align:middle;padding:1rem 1.25rem}.admin-table tr:last-child td{border-bottom:none}.admin-table tr:hover td{background:var(--surface-hover)}.school-cell{flex-direction:column;gap:2px;display:flex}.school-cell strong{color:var(--text);font-weight:600;font-size:var(--font-base)}.school-cell span{color:var(--text-muted);font-size:var(--font-xs)}.ref-cell{font-family:monospace;font-size:var(--font-xs);color:var(--text-muted);text-overflow:ellipsis;white-space:nowrap;max-width:140px;overflow:hidden}.action-btns{gap:6px;display:flex}.status-pill{font-size:var(--font-xs);white-space:nowrap;border-radius:99px;align-items:center;gap:4px;padding:3px 10px;font-weight:700;display:inline-flex}.status-pill.pending{background:var(--warning-light);color:var(--warning)}.status-pill.approved{background:var(--success-light);color:var(--success)}.status-pill.rejected{background:var(--danger-light);color:var(--danger)}.admin-empty{color:var(--text-muted);text-align:center;flex-direction:column;justify-content:center;align-items:center;gap:.75rem;padding:4rem 2rem;display:flex}.admin-empty svg{opacity:.2}.admin-empty p{font-size:var(--font-lg);color:var(--text-secondary);font-weight:600}.schools-grid{grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1rem;padding:1.25rem;display:grid}.school-card{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-lg);padding:1.25rem;transition:all .15s}.school-card:hover{box-shadow:var(--shadow-md);border-color:#94a3b8}.school-card-top{border-bottom:1px solid var(--border);align-items:center;gap:.875rem;margin-bottom:.875rem;padding-bottom:.875rem;display:flex}.school-avatar{border-radius:var(--radius-md);background:linear-gradient(135deg, var(--primary), #60a5fa);width:44px;height:44px;font-size:var(--font-lg);color:#fff;flex-shrink:0;justify-content:center;align-items:center;font-weight:800;display:flex}.school-card-top h3{font-size:var(--font-base);color:var(--text);margin:0;font-weight:700}.school-card-details{flex-direction:column;gap:4px;display:flex}.school-detail{font-size:var(--font-xs);color:var(--text-muted);align-items:center;gap:6px;display:flex}.school-card-footer{border-top:1px solid var(--border);justify-content:space-between;align-items:center;margin-top:.875rem;padding-top:.875rem;display:flex}.credit-pill{font-size:var(--font-xs);border-radius:99px;align-items:center;gap:4px;padding:3px 10px;font-weight:700;display:inline-flex}.credit-pill.active{background:var(--success-light);color:var(--success)}.credit-pill.warning{background:var(--warning-light);color:var(--warning)}.credit-pill.expired{background:var(--danger-light);color:var(--danger)}.pay-settings-grid{grid-template-columns:1fr 1fr;gap:1.25rem;padding:1.25rem;display:grid}.pay-settings-card{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-lg);padding:1.25rem}.pay-settings-card h3{font-size:var(--font-base);align-items:center;gap:8px;margin-bottom:1rem;font-weight:700;display:flex}.pay-settings-form{flex-direction:column;gap:.875rem;display:flex}.pay-settings-form label{font-size:var(--font-sm);color:var(--text-secondary);flex-direction:column;gap:6px;font-weight:600;display:flex}.pay-settings-form input{background:var(--surface);border:1.5px solid var(--border);border-radius:var(--radius-md);color:var(--text);font-size:var(--font-base);padding:.625rem .875rem;transition:border-color .15s}.pay-settings-form input:focus{border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-light);outline:none}.pay-settings-actions{border-top:1px solid var(--border);justify-content:flex-end;padding:1.25rem;display:flex}.admin-loading{height:100vh;color:var(--text-muted);background:var(--bg);flex-direction:column;justify-content:center;align-items:center;gap:1rem;display:flex}.spinner{border:3px solid var(--border);border-top-color:var(--primary);border-radius:50%;width:32px;height:32px;animation:.8s linear infinite spin}.flash{border-radius:var(--radius-md);font-size:var(--font-sm);margin:.5rem 0;padding:.75rem 1rem;font-weight:600;animation:.25s ease-out fadeUp}.flash.success{background:var(--success-light,#d1fae5);color:var(--success,#059669);border:1px solid #6ee7b7}.flash.error{background:var(--danger-light,#fee2e2);color:var(--danger,#dc2626);border:1px solid #fca5a5}.modal-backdrop{z-index:200;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#0f172a8c;justify-content:center;align-items:center;padding:1rem;display:flex;position:fixed;inset:0}.confirm-box{background:var(--surface,#fff);border-radius:var(--radius-xl,16px);text-align:center;width:100%;max-width:360px;padding:2rem;animation:.2s ease-out fadeUp;box-shadow:0 25px 50px -12px #00000040}.confirm-box h3{font-size:var(--font-xl,1.25rem);margin:1rem 0 1.5rem;font-weight:700}.confirm-box-btns{justify-content:center;gap:.75rem;display:flex}@media (width<=768px){.admin-body{padding:1rem}.admin-stats{grid-template-columns:1fr 1fr}.pay-settings-grid,.schools-grid{grid-template-columns:1fr}.admin-tabs{flex-wrap:wrap;width:100%}}.reject-notes-input{border:1.5px solid var(--border);border-radius:var(--radius-md);width:100%;font-size:var(--font-sm);resize:vertical;min-height:80px;margin-bottom:1rem;padding:.75rem}.app-layout{flex-direction:column;min-height:100vh;display:flex}.main-content{flex:1;padding-top:68px}.main-content.admin-page{padding-top:0}
