:root{--bg: #f3f7ff;--surface: #ffffff;--primary: #22c55e;--primary-600: #16a34a;--primary-50: #e8f9ef;--success: #22c55e;--danger: #ef4444;--text: #24314d;--muted: #6f7d99;--border: #d9e4fa;--shadow: 0 18px 42px rgba(17, 45, 94, .09)}*{box-sizing:border-box}html,body{height:100%}body{margin:0;background:var(--bg);color:var(--text);font-family:Inter,ui-sans-serif,system-ui,-apple-system,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}input,button,select,textarea{font-family:inherit}.container{width:100%;max-width:none;padding:20px 24px}.header{position:sticky;top:0;z-index:10;background:var(--surface);box-shadow:var(--shadow)}.header .brand{display:flex;align-items:center;gap:12px;padding:16px 24px}.header h1{font-size:20px;margin:0}.nav{display:flex;gap:12px;padding:0 24px 16px;flex-wrap:wrap}.nav a{color:var(--muted);text-decoration:none;padding:8px 12px;border-radius:8px}.nav a:hover{background:#f1f5f9;color:var(--text)}.grid{display:grid;gap:16px}.grid.cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.grid.cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}.grid.cols-4{grid-template-columns:repeat(4,minmax(0,1fr))}@media (max-width: 1100px){.grid.cols-4{grid-template-columns:repeat(2,minmax(0,1fr))}}.card{background:var(--surface);border:1px solid var(--border);border-radius:16px;padding:20px;box-shadow:var(--shadow)}.card h2{margin:0 0 12px;font-size:18px}.form{display:grid;gap:12px}.form label{font-size:13px;color:var(--muted);font-weight:600}.input,.select,.textarea{width:100%;padding:12px 14px;border-radius:12px;border:1px solid var(--border);background:#fff;font-size:14px;outline:none;transition:border-color .2s,box-shadow .2s}.input:focus,.select:focus,.textarea:focus{border-color:var(--primary);box-shadow:0 0 0 3px #22c55e2e}.textarea{min-height:100px;resize:vertical}.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:10px 16px;border-radius:12px;border:1px solid transparent;cursor:pointer;font-weight:600}.btn-primary{background:var(--primary);color:#fff}.btn-primary:hover{background:var(--primary-600)}.btn-outline{background:#fff;color:var(--primary);border-color:var(--primary)}.btn-outline:hover{background:#eef4ff}.btn-danger{background:var(--danger);color:#fff}.btn-link{background:transparent;color:var(--primary);border-color:transparent;padding:0;justify-content:flex-start}.btn-block{width:100%}.btn-icon{width:40px;height:40px;padding:0;display:flex;align-items:center;justify-content:center;background:transparent;border:1px solid transparent;color:var(--muted);border-radius:50%;transition:all .2s}.btn-icon:hover{background:#f1f5f9;color:var(--text)}.btn:disabled{opacity:.6;cursor:not-allowed}.list{list-style:none;padding:0;margin:0}.list li{padding:12px;border-bottom:1px solid var(--border)}.section{margin:24px 0}.muted{color:var(--muted)}.table{width:100%;border-collapse:collapse}.table th,.table td{padding:12px;border-bottom:1px solid var(--border);text-align:left}.table th{color:var(--muted);font-weight:700;font-size:12px;text-transform:uppercase;letter-spacing:.06em}.space-y-2>*+*{margin-top:8px}.space-y-3>*+*{margin-top:12px}.space-y-4>*+*{margin-top:16px}.mt-2{margin-top:8px}.mt-3{margin-top:12px}.mt-4{margin-top:16px}.upload{border:2px dashed var(--border);border-radius:12px;padding:16px;text-align:center;color:var(--muted)}.upload:hover{border-color:var(--primary);color:var(--primary)}.layout{display:grid;grid-template-columns:252px 1fr;min-height:100vh}.layout.collapsed{grid-template-columns:72px 1fr}.sidebar{background:linear-gradient(180deg,#fff,#f8fbff);border-right:1px solid var(--border);display:flex;flex-direction:column;gap:0;padding:0;box-shadow:var(--shadow);position:sticky;top:0;height:100vh}.sidebar-header{height:74px;display:flex;align-items:center;padding:0 18px;gap:12px;border-bottom:1px solid var(--border)}.brand-name{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.layout.collapsed .brand-name,.layout.collapsed .sidebar-nav a span,.layout.collapsed .sidebar-footer{display:none}.sidebar-nav{padding:12px;display:flex;flex-direction:column;gap:4px;flex:1}.nav-section-title{font-size:11px;font-weight:600;color:var(--muted);margin:16px 0 8px 12px;letter-spacing:.5px}.nav-divider{height:1px;background:var(--border);margin:12px 0}.sidebar-nav a{display:flex;align-items:center;gap:12px;padding:10px 12px;color:var(--muted);text-decoration:none;border-radius:8px;font-weight:500;transition:all .2s;font-size:15px}.sidebar-nav a:hover{background:#f1f5f9;color:var(--text)}.sidebar-nav a.active{background:var(--primary-50);color:var(--primary-600)}.sidebar-nav a.active svg{color:var(--primary-600)}.sidebar-nav a.cta{border:1px solid var(--primary);color:var(--primary);justify-content:center;margin-top:8px}.nav-dot{width:8px;height:8px;border-radius:999px;background:#b7c9ec;display:inline-block}.sidebar-nav a.active .nav-dot{background:var(--primary)}.sidebar-footer{padding:14px 12px;border-top:1px solid var(--border);display:flex;align-items:center;justify-content:space-between}.user-profile{display:flex;align-items:center;gap:12px;overflow:hidden}.avatar{width:36px;height:36px;border-radius:50%;background:var(--primary-100, #dcfce7);color:var(--primary-600);display:flex;align-items:center;justify-content:center;font-weight:600;flex-shrink:0}.user-info{display:flex;flex-direction:column;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.user-info strong{font-size:14px;font-weight:600;color:var(--text);overflow:hidden;text-overflow:ellipsis}.user-info small{font-size:12px;color:var(--muted)}.btn-logout{background:transparent;border:none;color:var(--muted);cursor:pointer;padding:8px;border-radius:8px;display:flex;align-items:center;justify-content:center;transition:all .2s}.btn-logout:hover{background:#fee2e2;color:var(--danger)}.content{display:flex;flex-direction:column}.topbar{height:64px;display:flex;align-items:center;padding:0 18px;background:var(--surface);border-bottom:1px solid var(--border);gap:16px}.topbar-actions{display:flex;align-items:center;gap:8px}.topbar .spacer{flex:1}.topbar-chip{padding:8px 10px;border-radius:10px;background:#f5f8ff;color:var(--primary);font-size:12px;font-weight:700}.user{color:var(--text);font-weight:600;padding:8px 12px;border:1px solid var(--border);border-radius:999px;background:#fff}.auth-layout{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:24px;background:linear-gradient(135deg,#f8fafc,#e2e8f0)}.auth-card{background:#fff;padding:48px;width:100%;max-width:420px;border-radius:20px;box-shadow:0 24px 64px #0f172a0f}.auth-card-header{text-align:center;margin-bottom:32px}.auth-card-header img{height:40px;margin-bottom:16px}.auth-card-header h2{margin:0 0 8px;font-size:24px;font-weight:600;color:var(--text)}.auth-card-header p{margin:0;color:var(--muted);font-size:15px}.auth-card h2{margin:0;font-size:30px}.kpi-grid .kpi{display:grid;gap:10px}.kpi-grid .kpi h2{margin:0;font-size:30px;color:var(--primary)}.dashboard-page{display:grid;gap:16px}.kpi-card{display:grid;gap:10px;transition:transform .2s ease}.kpi-card:hover{transform:translateY(-2px)}.kpi-title{color:var(--muted);font-weight:600}.kpi-value{font-size:28px;color:var(--text)}.kpi-delta{color:var(--success);font-weight:700}.kpi-delta.down{color:var(--danger)}.chart-card{display:grid;gap:14px}.chart-title-row{display:flex;align-items:center;justify-content:space-between;gap:8px}.donut-wrap{grid-template-columns:1fr}.donut-wrap canvas{max-height:220px}.donut-legend{display:grid;gap:8px}.legend-item{display:grid;grid-template-columns:10px 1fr auto;align-items:center;gap:8px}.legend-dot{width:10px;height:10px;border-radius:999px}.heatmap-grid{display:grid;grid-template-columns:repeat(6,minmax(0,1fr));gap:8px}.heatmap-cell{border-radius:12px;min-height:64px;padding:8px;color:#14532d;display:grid;align-content:space-between;transition:transform .2s ease}.heatmap-cell:hover{transform:scale(1.02)}.filter-bar{display:grid;grid-template-columns:1.7fr 1fr 1fr;gap:12px}.table-wrapper{overflow:hidden}.table-title-row{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px}.status-chip{display:inline-flex;align-items:center;justify-content:center;border-radius:999px;padding:6px 10px;font-size:12px;font-weight:700;background:#eafaf0;color:#15803d}.status-chip.pending{background:#fff7e6;color:#b45309}.status-chip.late{background:#feeceb;color:#b91c1c}.table-pagination{display:flex;justify-content:space-between;align-items:center;margin-top:12px}.master-layout{display:grid;gap:16px}.master-header{display:flex;align-items:center;justify-content:space-between}.master-header h2{margin:0}.master-admin-page{padding-bottom:48px}.master-modal-backdrop{position:fixed;inset:0;background:#0f172a73;z-index:1000;display:flex;align-items:flex-start;justify-content:center;padding:40px 16px;overflow-y:auto}.master-modal{background:var(--surface);border-radius:16px;border:1px solid var(--border);box-shadow:var(--shadow);width:100%;max-width:560px;padding:24px;max-height:calc(100vh - 80px);overflow-y:auto}.master-modal h3{margin:0 0 8px;font-size:18px}.master-modal-actions{display:flex;gap:10px;flex-wrap:wrap;margin-top:16px}@media (max-width: 900px){.layout{grid-template-columns:72px 1fr}.grid.cols-2,.grid.cols-3,.grid.cols-4,.filter-bar{grid-template-columns:1fr}.heatmap-grid{grid-template-columns:repeat(3,minmax(0,1fr))}.auth-layout{grid-template-columns:1fr}.auth-hero{display:none}.auth-card{padding:32px 24px}.master-header{flex-direction:column;align-items:flex-start;gap:12px}}
