:root{--primary:#d4380d;--primary-dark:#ad2e0a;--primary-light:#ff7a45;--primary-bg:#fff2e8;--accent:#d4380d;--bg:#f5f6fa;--sidebar-bg:#1b2537;--sidebar-hover:#263347;--sidebar-active:#2d3d54;--sidebar-text:#8b95a5;--sidebar-text-active:#fff;--card-bg:#fff;--text:#1f2937;--text-secondary:#6b7280;--text-light:#9ca3af;--border:#e5e7eb;--border-light:#f3f4f6;--danger:#dc2626;--danger-bg:#fef2f2;--success:#16a34a;--success-bg:#f0fdf4;--warning:#f59e0b;--warning-bg:#fffbeb;--info:#3b82f6;--info-bg:#eff6ff;--radius:10px;--radius-sm:6px;--radius-lg:14px;--shadow-sm:0 1px 2px #0000000a;--shadow:0 1px 3px #0000000f, 0 1px 2px #0000000a;--shadow-md:0 4px 6px -1px #00000012, 0 2px 4px -2px #0000000d;--shadow-lg:0 10px 25px -3px #00000014, 0 4px 6px -4px #0000000a;--transition:.2s ease}*{box-sizing:border-box;margin:0;padding:0}body{background:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;line-height:1.5}#root{min-height:100vh}.login-container{background:var(--sidebar-bg);justify-content:center;align-items:center;min-height:100vh;display:flex;position:relative;overflow:hidden}.login-container:before{content:"";background:radial-gradient(circle,#d4380d26 0%,#0000 70%);border-radius:50%;width:600px;height:600px;position:absolute;top:-50%;right:-20%}.login-container:after{content:"";background:radial-gradient(circle,#ff7a451a 0%,#0000 70%);border-radius:50%;width:400px;height:400px;position:absolute;bottom:-30%;left:-10%}.login-form{background:var(--card-bg);border-radius:var(--radius-lg);width:420px;max-width:90vw;box-shadow:var(--shadow-lg);z-index:1;padding:40px;position:relative}.login-logo{background:var(--primary);border-radius:var(--radius);color:#fff;justify-content:center;align-items:center;width:48px;height:48px;margin-bottom:24px;font-size:22px;font-weight:700;display:flex}.login-logo-img{max-width:220px;height:auto;margin-bottom:24px}.login-form h1{color:var(--text);letter-spacing:-.3px;margin-bottom:4px;font-size:22px;font-weight:700}.login-subtitle{color:var(--text-secondary);margin-bottom:28px;font-size:14px}.form-group{flex:1;margin-bottom:18px}.form-group label{color:var(--text);letter-spacing:.01em;margin-bottom:6px;font-size:13px;font-weight:600;display:block}.form-group input,.report-selector{border:1.5px solid var(--border);border-radius:var(--radius-sm);width:100%;color:var(--text);background:var(--card-bg);transition:all var(--transition);padding:10px 14px;font-size:14px}.form-group input::placeholder{color:var(--text-light)}.form-group input:focus,.report-selector:focus{border-color:var(--primary);outline:none;box-shadow:0 0 0 3px #d4380d14}.form-row{gap:16px;display:flex}.form-actions{gap:12px;margin-top:20px;display:flex}button{border-radius:var(--radius-sm);cursor:pointer;transition:all var(--transition);background:var(--primary);color:#fff;letter-spacing:.01em;border:none;padding:10px 20px;font-size:14px;font-weight:600}button:hover{background:var(--primary-dark);box-shadow:var(--shadow);transform:translateY(-1px)}button:active{transform:translateY(0)}button:disabled{opacity:.5;cursor:not-allowed;transform:none}button.secondary{background:var(--bg);color:var(--text);border:1.5px solid var(--border)}button.secondary:hover{background:var(--border-light);border-color:var(--text-light)}button.danger{background:var(--danger-bg);color:var(--danger)}button.danger:hover{background:var(--danger);color:#fff}button.ghost{color:var(--text-secondary);background:0 0;padding:6px 12px}button.ghost:hover{background:var(--bg);color:var(--text);box-shadow:none;transform:none}.login-btn{border-radius:var(--radius-sm);width:100%;margin-top:4px;padding:12px;font-size:15px}.logout-btn{width:100%;color:var(--sidebar-text);background:0 0;border:1px solid #ffffff1f;padding:8px 16px;font-size:13px}.error-msg{background:var(--danger-bg);color:var(--danger);border-radius:var(--radius-sm);border-left:3px solid var(--danger);margin-bottom:16px;padding:12px 16px;font-size:13px;font-weight:500}.success-msg{background:var(--success-bg);color:var(--success);border-radius:var(--radius-sm);border-left:3px solid var(--success);margin-bottom:16px;padding:12px 16px;font-size:13px;font-weight:500}.app-layout{min-height:100vh;display:flex}.sidebar{background:var(--sidebar-bg);z-index:10;border-right:1px solid #ffffff0a;flex-direction:column;width:260px;height:100vh;transition:width .25s;display:flex;position:fixed}.sidebar-header{border-bottom:1px solid #ffffff0f;justify-content:center;align-items:center;padding:16px;display:flex}.sidebar-logo{background:linear-gradient(135deg, var(--primary) 0%, var(--primary-light) 100%);color:#fff;letter-spacing:-.5px;border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;width:38px;height:38px;font-size:17px;font-weight:800;display:flex}.sidebar-logo-img{background:#fff;border-radius:8px;max-width:200px;height:auto;padding:10px 16px}.sidebar-header h2{color:#fff;letter-spacing:-.3px;font-size:16px;font-weight:700}.sidebar-header p{color:#ffffff59;letter-spacing:.2px;margin-top:1px;font-size:11px}.sidebar-nav{flex:1;padding-top:4px;overflow-y:auto}.sidebar-section-label{color:#ffffff47;text-transform:uppercase;letter-spacing:1.2px;padding:18px 20px 6px;font-size:10px;font-weight:700}.nav-links{padding:4px 12px;list-style:none}.nav-links li a{color:#ffffff8c;border-radius:8px;align-items:center;gap:11px;margin-bottom:2px;padding:9px 12px;font-size:13.5px;font-weight:500;text-decoration:none;transition:all .15s;display:flex;position:relative}.nav-links li a .nav-icon{opacity:.7;flex-shrink:0;justify-content:center;align-items:center;width:20px;height:20px;display:flex}.nav-links li a .nav-label{flex:1}.nav-links li a .nav-chevron{opacity:0;align-items:center;transition:opacity .15s;display:flex}.nav-links li a:hover{color:#ffffffe6;background:#ffffff0f}.nav-links li a:hover .nav-icon{opacity:1}.nav-links li a:hover .nav-chevron{opacity:.5}.nav-links li a.active{color:#ff8a65;background:#d4380d26}.nav-links li a.active .nav-icon{opacity:1}.nav-links li a.active:before{content:"";background:var(--primary);border-radius:0 3px 3px 0;width:3px;height:20px;position:absolute;top:50%;left:-12px;transform:translateY(-50%)}.sidebar-footer{border-top:1px solid #ffffff0f;padding:14px}.sidebar-user{align-items:center;gap:10px;padding:8px 6px 12px;display:flex}.sidebar-avatar{background:linear-gradient(135deg, var(--primary) 0%, var(--primary-light) 100%);color:#fff;letter-spacing:.5px;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:34px;height:34px;font-size:12px;font-weight:700;display:flex}.sidebar-user-info{flex:1;min-width:0}.sidebar-user-name{color:#ffffffe6;white-space:nowrap;text-overflow:ellipsis;font-size:13px;font-weight:600;overflow:hidden}.sidebar-user-role{color:#ffffff59;margin-top:1px;font-size:11px}.logout-btn{color:#ffffff80;background:#ffffff0a;border:1px solid #ffffff14;border-radius:8px;justify-content:center;align-items:center;gap:8px;width:100%;padding:8px 14px;font-size:13px;display:flex}.logout-btn:hover{color:#fca5a5;box-shadow:none;background:#dc26261a;border-color:#dc262633;transform:none}.main-content{flex:1;min-height:100vh;margin-left:260px;padding:16px 20px}.page-header{margin-bottom:24px}.page-header h1{color:var(--text);letter-spacing:-.4px;font-size:24px;font-weight:700}.page-header p{color:var(--text-secondary);margin-top:4px;font-size:14px}.dashboard-header{justify-content:space-between;align-items:flex-start;margin-bottom:12px;display:flex}.dashboard-header h1{letter-spacing:-.4px;font-size:24px;font-weight:700}.dashboard-header-subtitle{color:var(--text-secondary);margin-top:4px;font-size:14px}.report-selector{border-radius:var(--radius-sm);width:auto;min-width:220px;padding:10px 14px;font-weight:500}.embed-container{background:var(--card-bg);border-radius:var(--radius);box-shadow:var(--shadow);border:1px solid var(--border);overflow:hidden}.powerbi-report{width:100%;height:calc(100vh - 90px)}.powerbi-report iframe{border:none}.page-message{text-align:center;color:var(--text-secondary);padding:80px 20px}.page-message .empty-icon{opacity:.4;margin-bottom:16px;font-size:48px}.page-message h2{color:var(--text);margin-bottom:8px;font-size:20px;font-weight:600}.page-message p{max-width:400px;margin:0 auto;font-size:14px}.loading-container{flex-direction:column;justify-content:center;align-items:center;padding:80px 20px;display:flex}.spinner{border:3px solid var(--border);border-top-color:var(--primary);border-radius:50%;width:36px;height:36px;margin-bottom:16px;animation:.8s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.loading-text{color:var(--text-secondary);font-size:14px}.admin-page .page-header{justify-content:space-between;align-items:flex-start;display:flex}.config-form{background:var(--card-bg);border-radius:var(--radius);box-shadow:var(--shadow);border:1px solid var(--border);margin-bottom:28px;padding:24px}.config-form-header{border-bottom:1px solid var(--border-light);align-items:center;gap:10px;margin-bottom:20px;padding-bottom:16px;display:flex}.config-form-header .form-icon{font-size:20px}.config-form h3{color:var(--text);font-size:16px;font-weight:600}.config-list h3{color:var(--text);align-items:center;gap:8px;margin-bottom:12px;font-size:16px;font-weight:600;display:flex}.config-list .list-icon{font-size:18px}.config-count{background:var(--primary-bg);color:var(--primary);border-radius:10px;padding:2px 8px;font-size:12px;font-weight:600}.empty-state{color:var(--text-secondary);text-align:center;background:var(--card-bg);border-radius:var(--radius);border:1px dashed var(--border);padding:40px;font-size:14px}.table-container{background:var(--card-bg);border-radius:var(--radius);border:1px solid var(--border);box-shadow:var(--shadow-sm);overflow-x:auto}table{border-collapse:collapse;width:100%;box-shadow:none;border-radius:0}th,td{text-align:left;padding:12px 16px;font-size:14px}th{background:var(--border-light);color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;border-bottom:1px solid var(--border);font-size:12px;font-weight:600}td{border-bottom:1px solid var(--border-light)}tr:last-child td{border-bottom:none}tr:hover td{background:var(--border-light)}td.mono{text-overflow:ellipsis;white-space:nowrap;max-width:200px;color:var(--text-secondary);font-family:SF Mono,Fira Code,Cascadia Code,monospace;font-size:12px;overflow:hidden}td.actions{gap:6px;display:flex}td.actions button{border-radius:5px;padding:5px 12px;font-size:12px;font-weight:500}.badge{letter-spacing:.01em;border-radius:20px;align-items:center;gap:5px;padding:3px 10px;font-size:12px;font-weight:600;display:inline-flex}.badge:before{content:"";border-radius:50%;width:6px;height:6px}.badge.active{background:var(--success-bg);color:var(--success)}.badge.active:before{background:var(--success)}.badge.inactive{background:var(--danger-bg);color:var(--danger)}.badge.inactive:before{background:var(--danger)}.expiry-header{justify-content:space-between;align-items:flex-start;margin-bottom:22px;display:flex}.expiry-header h1{letter-spacing:-.5px;color:var(--text);font-size:24px;font-weight:700}.expiry-subtitle{color:var(--text-light);margin-top:3px;font-size:13px}.view-toggle{background:var(--card-bg);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-sm);display:flex;overflow:hidden}.view-toggle button{color:var(--text-secondary);box-shadow:none;background:0 0;border:none;border-radius:0;align-items:center;gap:7px;padding:8px 16px;font-size:13px;display:flex;transform:none}.view-toggle button svg{width:15px;height:15px}.view-toggle button:hover{background:var(--border-light);box-shadow:none;transform:none}.view-toggle button.active{background:var(--primary);color:#fff}.stats-grid{grid-template-columns:repeat(auto-fill,minmax(155px,1fr));gap:12px;margin-bottom:22px;display:grid}.stat-card{background:var(--card-bg);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-sm);border-top:3px solid #0000;padding:16px 14px;transition:box-shadow .15s}.stat-card:hover{box-shadow:var(--shadow-md)}.stat-card-row{justify-content:space-between;align-items:flex-start;display:flex}.stat-card-icon{border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;width:40px;height:40px;display:flex}.stat-card-value{letter-spacing:-.5px;font-size:28px;font-weight:800;line-height:1}.stat-card-title{color:var(--text-secondary);margin-top:6px;font-size:12px;font-weight:500}.charts-grid{grid-template-columns:1fr 1fr;gap:14px;margin-bottom:22px;display:grid}.chart-card{background:var(--card-bg);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-sm);padding:20px}.chart-card.full-width{margin-bottom:22px}.chart-card-header{justify-content:space-between;align-items:center;margin-bottom:8px;display:flex}.chart-card-header h3{color:var(--text);font-size:15px;font-weight:600}.chart-badge{color:var(--text-light);background:var(--border-light);border-radius:20px;padding:3px 10px;font-size:11px;font-weight:600}.section-header{align-items:center;gap:10px;margin-bottom:14px;display:flex}.section-header h2{color:var(--text);font-size:17px;font-weight:700}.section-count{background:var(--border-light);color:var(--text-light);border-radius:20px;padding:2px 10px;font-size:11px;font-weight:600}.schools-grid{grid-template-columns:repeat(auto-fill,minmax(340px,1fr));gap:14px;margin-bottom:24px;display:grid}.school-card{background:var(--card-bg);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-sm);transition:box-shadow .15s;overflow:hidden}.school-card:hover{box-shadow:var(--shadow-md)}.school-card.has-issues{border-color:#fecaca}.school-card-header{background:var(--primary);color:#fff;justify-content:space-between;align-items:center;padding:14px 18px;display:flex}.school-card.has-issues .school-card-header{background:linear-gradient(135deg,#dc2626 0%,#b91c1c 100%)}.school-card-header h4{margin:0;font-size:14px;font-weight:600}.school-code-badge{letter-spacing:.5px;background:#fff3;border-radius:20px;padding:3px 10px;font-size:11px;font-weight:700}.school-card-stats{grid-template-columns:repeat(3,1fr);display:grid}.school-stat{text-align:center;border-bottom:1px solid var(--border-light);border-right:1px solid var(--border-light);padding:14px 8px;transition:background .1s}.school-stat:hover{background:#fafbfc}.school-stat:nth-child(3n){border-right:none}.school-stat:nth-last-child(-n+3){border-bottom:none}.school-stat-value{letter-spacing:-.5px;font-size:24px;font-weight:800;display:block}.school-stat-label{color:var(--text-light);text-transform:uppercase;letter-spacing:.5px;margin-top:3px;font-size:10px;font-weight:600;display:block}.expiring-section{margin-bottom:24px}.expiring-section-header{align-items:center;gap:12px;margin-bottom:12px;display:flex}.expiring-section-header h3{color:var(--text);font-size:15px;font-weight:600}.section-school-badge{color:var(--primary);background:var(--primary-bg);border-radius:20px;padding:3px 12px;font-size:11px;font-weight:600}.days-pill{white-space:nowrap;border-radius:20px;padding:3px 10px;font-size:12px;font-weight:700;display:inline-block}.text-muted{color:var(--text-light)}.table-toolbar{flex-wrap:wrap;justify-content:space-between;align-items:flex-end;gap:12px;margin-bottom:14px;display:flex}.table-filters{align-items:flex-end;gap:12px;display:flex}.table-meta{align-items:center;display:flex}.filter-group{flex-direction:column;gap:4px;display:flex}.filter-group label{color:var(--text-light);text-transform:uppercase;letter-spacing:.5px;font-size:11px;font-weight:600}.filter-group select{border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--card-bg);min-width:160px;color:var(--text);cursor:pointer;padding:8px 12px;font-size:13px;font-weight:500}.filter-group select:focus{border-color:var(--primary);outline:none;box-shadow:0 0 0 3px #d4380d14}.doc-count{color:var(--text-light);font-size:13px;font-weight:500}.status-badge{white-space:nowrap;letter-spacing:.01em;border-radius:20px;align-items:center;padding:3px 10px;font-size:11px;font-weight:600;display:inline-flex}.badge-active{color:#15803d;background:#dcfce7}.badge-expired{color:#b91c1c;background:#fef2f2}.badge-urgent{color:#c2410c;background:#fff7ed}.badge-warning{color:#b45309;background:#fffbeb}.badge-purple{color:#6d28d9;background:#f5f3ff}.badge-gray{color:#6b7280;background:#f3f4f6}.badge-cat{text-transform:capitalize;letter-spacing:.01em;border-radius:4px;padding:3px 10px;font-size:11px;font-weight:600;display:inline-block}.badge-cat.compliance{color:#1d4ed8;background:#dbeafe}.badge-cat.transport{color:#b45309;background:#fef3c7}.doc-table th{white-space:nowrap}th.sortable{cursor:pointer;-webkit-user-select:none;user-select:none;white-space:nowrap}th.sortable:hover{color:var(--primary)}.sort-icon{vertical-align:middle;align-items:center;margin-left:3px;display:inline-flex}.sort-icon{align-items:center;display:inline-flex}.sort-icon.muted{opacity:.3}.row-expired{background:#fef8f8}.row-expired:hover td{background:#fef2f2!important}.cell-school{flex-direction:column;gap:1px;display:flex}.cell-school span{color:var(--text-light);font-size:11px}.cell-truncate{text-overflow:ellipsis;white-space:nowrap;max-width:180px;overflow:hidden}.cell-date{align-items:center;gap:6px;display:flex}.btn-icon-edit{width:26px;height:26px;color:var(--text-light);cursor:pointer;opacity:0;background:0 0;border:none;border-radius:6px;justify-content:center;align-items:center;padding:0;transition:all .15s;display:inline-flex}tr:hover .btn-icon-edit{opacity:1}.btn-icon-edit:hover{background:var(--border-light);color:var(--primary);box-shadow:none;transform:none}.edit-date{align-items:center;gap:4px;display:flex}.edit-date input{border:1.5px solid var(--primary);border-radius:6px;outline:none;width:130px;padding:5px 8px;font-size:12px}.btn-icon{background:var(--border-light);width:26px;height:26px;color:var(--text-secondary);cursor:pointer;border:none;border-radius:6px;justify-content:center;align-items:center;padding:0;transition:all .15s;display:inline-flex}.btn-icon:hover{background:var(--border);box-shadow:none;transform:none}.btn-icon.success{color:#16a34a;background:#dcfce7}.btn-icon.success:hover{color:#fff;background:#16a34a}.btn-icon-toggle{background:var(--border-light);width:30px;height:30px;color:var(--text-light);cursor:pointer;border:none;border-radius:8px;justify-content:center;align-items:center;padding:0;transition:all .15s;display:inline-flex}.btn-icon-toggle:hover{color:#7c3aed;box-shadow:none;background:#f5f3ff;transform:none}.btn-icon-toggle.active{color:#7c3aed;background:#f5f3ff}.text-light{color:var(--text-light);font-size:12px}.meta-date-picker{background:var(--card-bg);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-sm);gap:4px;padding:4px;display:flex}.meta-date-btn{color:var(--text-secondary);cursor:pointer;box-shadow:none;background:0 0;border:none;border-radius:6px;padding:6px 14px;font-size:13px;font-weight:600;transition:all .15s;transform:none}.meta-date-btn:hover{background:var(--border-light);color:var(--text);box-shadow:none;transform:none}.meta-date-btn.active{background:var(--primary);color:#fff}.meta-kpi-grid{grid-template-columns:repeat(4,1fr);gap:12px;margin-bottom:22px;display:grid}.campaign-row{cursor:pointer;transition:background .1s}.campaign-row:hover td{background:var(--border-light)!important}.campaign-row.expanded td{background:#f8fafc;border-bottom-color:#0000}.expand-cell{text-align:center;width:30px}.expand-arrow{color:var(--text-light);transition:transform .2s;display:inline-flex}.expand-arrow.open{color:var(--primary);transform:rotate(90deg)}.drill-row td{background:#f8fafc!important;padding:0!important}.drill-content{padding:12px 20px 16px 48px}.drill-loading{color:var(--text-secondary);align-items:center;gap:10px;padding:16px;font-size:13px;display:flex}.drill-empty{color:var(--text-light);padding:16px;font-size:13px}.drill-table{border-collapse:collapse;background:var(--card-bg);border:1px solid var(--border);width:100%;box-shadow:none;border-radius:8px;overflow:hidden}.drill-table th{background:var(--border-light);padding:8px 12px;font-size:11px}.drill-table td{border-bottom:1px solid var(--border-light);padding:8px 12px;font-size:13px}.drill-table tr:last-child td{border-bottom:none}.totals-row{border-top:2px solid var(--border);background:#f8fafc!important}.totals-row td{color:var(--text);font-weight:700;background:#f8fafc!important}.sidebar-toggle{color:#fff6;cursor:pointer;z-index:11;width:26px;height:26px;box-shadow:none;background:#ffffff14;border:1px solid #ffffff1a;border-radius:50%;justify-content:center;align-items:center;padding:0;transition:all .2s;display:flex;position:absolute;bottom:80px;right:8px}.sidebar-toggle:hover{color:#fffc;box-shadow:none;background:#ffffff26;border-color:#fff3;transform:none}.sidebar.collapsed .sidebar-toggle{right:50%;transform:translate(50%)}.main-content{transition:margin-left .25s}.sidebar.collapsed{width:68px}.sidebar.collapsed .sidebar-header{padding:16px 12px}.sidebar.collapsed .sidebar-nav{padding-top:8px}.sidebar.collapsed .nav-links{padding:4px 8px}.sidebar.collapsed .nav-links li a{justify-content:center;padding:10px}.sidebar.collapsed .nav-links li a .nav-icon{margin:0}.sidebar.collapsed .sidebar-footer{padding:12px 8px}.sidebar.collapsed .logout-btn{justify-content:center;padding:8px}.sidebar-collapsed .main-content{margin-left:68px}.mobile-menu-btn{z-index:20;background:var(--sidebar-bg);color:#fff;width:40px;height:40px;box-shadow:var(--shadow-md);border:none;border-radius:8px;justify-content:center;align-items:center;padding:0;display:none;position:fixed;top:12px;left:12px}@media (width<=1024px){.sidebar:not(.collapsed){width:220px}.app-layout:not(.sidebar-collapsed) .main-content{margin-left:220px;padding:20px}.form-row{flex-direction:column;gap:0}}@media (width<=768px){.sidebar{z-index:20;position:fixed;transform:translate(-100%);width:260px!important}.sidebar:not(.collapsed){transform:translate(0)}.sidebar.collapsed{transform:translate(-100%)}.main-content{padding:60px 16px 16px;margin-left:0!important}.mobile-menu-btn{display:flex}.sidebar-toggle{display:none}}
