@import"https://fonts.googleapis.com/css2?family=Material+Symbols+Outlined:opsz,wght,FILL,GRAD@20..48,100..700,0..1,-50..200";:root{--primary: #123a7a;--primary-700: #0f2f63;--secondary: #60a5fa;--accent: #2563eb;--ink: #0f172a;--muted: #64748b;--line: #e2e8f0;--canvas: #f8fafc;--radius: 8px}*{-webkit-font-smoothing:antialiased}html{scroll-behavior:smooth}body{font-family:DM Sans,ui-sans-serif,system-ui,sans-serif;color:var(--ink);background:var(--canvas)}.font-display,h1,h2,h3,h4,h5,.heading{font-family:Syne,ui-sans-serif,system-ui,sans-serif;letter-spacing:-.01em}.t-display{font-size:clamp(2.25rem,4vw,3.25rem);line-height:1.05;font-weight:800}.t-h1{font-size:clamp(1.75rem,3vw,2.25rem);line-height:1.12;font-weight:700}.t-h2{font-size:1.5rem;line-height:1.2;font-weight:700}.t-h3{font-size:1.125rem;line-height:1.3;font-weight:600}.t-eyebrow{font-size:.8125rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--primary)}.t-muted{color:var(--muted)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;font-family:DM Sans,sans-serif;font-weight:600;font-size:.9375rem;line-height:1;padding:.7rem 1.15rem;border-radius:10px;cursor:pointer;border:1px solid transparent;transition:background-color .15s ease,border-color .15s ease,color .15s ease,box-shadow .15s ease;white-space:nowrap;text-decoration:none}.btn:focus-visible{outline:2px solid var(--primary);outline-offset:2px}.btn .material-symbols-outlined{font-size:1.15rem}.btn-primary{background:var(--primary);color:#fff}.btn-primary:hover{background:var(--primary-700)}.btn-secondary{background:var(--secondary);color:#fff}.btn-secondary:hover{background:#3b82f6}.btn-accent{background:var(--accent);color:#fff}.btn-accent:hover{background:#1d4ed8}.btn-outline{background:#fff;color:var(--ink);border-color:var(--line)}.btn-outline:hover{border-color:#cbd5e1;background:#f8fafc}.btn-ghost{background:transparent;color:var(--ink)}.btn-ghost:hover{background:#f1f5f9}.btn-sm{padding:.45rem .8rem;font-size:.85rem;border-radius:8px}.btn-lg{padding:.85rem 1.5rem;font-size:1rem}.btn-block{width:100%}.card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);box-shadow:0 1px 3px #0f172a0d,0 4px 12px #0f172a0a}.card-pad{padding:1.25rem}.card-hover{transition:box-shadow .18s ease,transform .18s ease,border-color .18s ease}.card-hover:hover{box-shadow:0 8px 24px #0f172a1a;border-color:#dbeafe;transform:translateY(-2px)}.label{display:block;font-size:.85rem;font-weight:600;color:#334155;margin-bottom:.35rem}.input,.select,.textarea{width:100%;font-family:inherit;font-size:.9375rem;color:var(--ink);background:#fff;border:1px solid var(--line);border-radius:10px;padding:.6rem .8rem;transition:border-color .15s ease,box-shadow .15s ease}.input::placeholder,.textarea::placeholder{color:#94a3b8}.input:focus,.select:focus,.textarea:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px #1e40af1f}.input-icon{position:relative}.input-icon .material-symbols-outlined{position:absolute;left:.65rem;top:50%;transform:translateY(-50%);color:#94a3b8;font-size:1.25rem}.input-icon .input{padding-left:2.4rem}.badge{display:inline-flex;align-items:center;gap:.3rem;font-size:.75rem;font-weight:600;padding:.2rem .55rem;border-radius:999px}.badge-primary{background:#dbe5ff;color:#1c399c}.badge-secondary{background:#dbeafe;color:#1d4ed8}.badge-accent{background:#e0f2fe;color:#0369a1}.badge-muted{background:#f1f5f9;color:#475569}.chip{display:inline-flex;align-items:center;gap:.4rem;font-size:.85rem;font-weight:500;padding:.45rem .8rem;border-radius:999px;border:1px solid var(--line);background:#fff;color:#334155;cursor:pointer;transition:background .15s,border-color .15s}.chip:hover{background:#f8fafc;border-color:#cbd5e1}.table{width:100%;border-collapse:collapse;font-size:.9rem}.table thead th{text-align:left;font-weight:600;color:var(--muted);font-size:.78rem;text-transform:uppercase;letter-spacing:.04em;padding:.7rem 1rem;border-bottom:1px solid var(--line)}.table tbody td{padding:.85rem 1rem;border-bottom:1px solid #f1f5f9;color:#334155}.table tbody tr:last-child td{border-bottom:none}.table tbody tr:hover{background:#f8fafc}.progress{height:8px;width:100%;background:#eef2f7;border-radius:999px;overflow:hidden}.progress>span{display:block;height:100%;border-radius:999px;background:var(--primary)}.progress.is-secondary>span{background:var(--secondary)}.progress.is-accent>span{background:var(--accent)}.ring{--val: 0;width:96px;height:96px;border-radius:50%;background:conic-gradient(var(--secondary) calc(var(--val) * 1%),#eef2f7 0);display:grid;place-items:center}.ring>div{width:72px;height:72px;border-radius:50%;background:#fff;display:grid;place-items:center;font-weight:700;font-family:Syne,sans-serif}.nav-link{display:flex;align-items:center;gap:.75rem;padding:.6rem .8rem;border-radius:10px;color:#475569;font-weight:500;font-size:.92rem;text-decoration:none;transition:background .15s,color .15s}.nav-link .material-symbols-outlined{font-size:1.35rem}.nav-link:hover{background:#f1f5f9;color:var(--ink)}.nav-link.active{background:#eff4ff;color:var(--primary);font-weight:600}.nav-link.active .material-symbols-outlined{color:var(--primary);font-variation-settings:"FILL" 1}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0f172a73;display:none;align-items:center;justify-content:center;padding:1rem;z-index:60}.modal-overlay.open{display:flex}.modal-box{background:#fff;border-radius:16px;box-shadow:0 20px 60px #0f172a40;width:100%;max-width:440px}.toast-stack{position:fixed;bottom:1.25rem;right:1.25rem;display:flex;flex-direction:column;gap:.6rem;z-index:80}.toast{display:flex;align-items:center;gap:.6rem;background:var(--ink);color:#fff;padding:.75rem 1rem;border-radius:10px;box-shadow:0 8px 24px #0f172a40;font-size:.9rem}.toast.success{background:#047857}.toast.accent{background:#b45309}.empty-state{text-align:center;padding:2.5rem 1rem;color:var(--muted)}.empty-state .material-symbols-outlined{font-size:2.5rem;color:#cbd5e1}.skeleton{background:linear-gradient(90deg,#eef2f7 25%,#e2e8f0 37%,#eef2f7 63%);background-size:400% 100%;border-radius:8px;animation:skeleton 1.4s ease infinite}@keyframes skeleton{0%{background-position:100% 0}to{background-position:-100% 0}}.app-shell{display:grid;grid-template-columns:260px 1fr;min-height:100vh}.sidebar{background:#fff;border-right:1px solid var(--line);position:sticky;top:0;height:100vh;overflow-y:auto}@media (max-width: 1023px){.app-shell{grid-template-columns:1fr}.sidebar{position:fixed;top:0;left:0;width:260px;z-index:50;transform:translate(-100%);transition:transform .22s ease}.sidebar.open{transform:translate(0)}}.icon-btn{display:inline-grid;place-items:center;width:40px;height:40px;border-radius:10px;color:#475569;background:transparent;border:none;cursor:pointer;transition:background .15s}.icon-btn:hover{background:#f1f5f9}.material-symbols-outlined{font-variation-settings:"wght" 400,"GRAD" 0,"opsz" 24}html.dark,[data-theme=dark]{--ink: #f1f5f9;--muted: #94a3b8;--line: #334155;--canvas: #0f172a}html.dark body,[data-theme=dark] body{background:var(--canvas);color:var(--ink)}html.dark .card,[data-theme=dark] .card{background:#1e293b;border-color:var(--line)}html.dark .input,html.dark .select,html.dark .textarea,[data-theme=dark] .input,[data-theme=dark] .select,[data-theme=dark] .textarea{background:#1e293b;color:#f1f5f9;border-color:#334155}html.dark .label,[data-theme=dark] .label{color:#94a3b8}html.dark .modal-box,[data-theme=dark] .modal-box{background:#1e293b;color:var(--ink)}html.dark .sidebar,[data-theme=dark] .sidebar{background:#1e293b;border-right-color:#334155}html.dark .btn-outline,[data-theme=dark] .btn-outline{background:#1e293b;color:#f1f5f9;border-color:#334155}html.dark .btn-outline:hover,[data-theme=dark] .btn-outline:hover{background:#334155;border-color:#475569}html.dark .btn-ghost:hover,[data-theme=dark] .btn-ghost:hover{background:#334155}html.dark header,[data-theme=dark] header{background:#1e293b;border-bottom-color:#334155}html.dark .table tbody td,[data-theme=dark] .table tbody td{color:#cbd5e1;border-bottom-color:#334155}html.dark .table tbody tr:hover,[data-theme=dark] .table tbody tr:hover{background:#1e293b}html.dark .table thead th,[data-theme=dark] .table thead th{border-bottom-color:var(--line)}html.dark .nav-link,[data-theme=dark] .nav-link{color:#94a3b8}html.dark .nav-link:hover,[data-theme=dark] .nav-link:hover{background:#334155;color:#f1f5f9}html.dark .nav-link.active,[data-theme=dark] .nav-link.active{background:#1e3a8a;color:#60a5fa}html.dark .badge-muted,[data-theme=dark] .badge-muted{background:#334155;color:#cbd5e1}html.dark .ring>div,[data-theme=dark] .ring>div{background:#1e293b;color:var(--ink)}html.dark .ring,[data-theme=dark] .ring{background:conic-gradient(var(--secondary) calc(var(--val) * 1%),#334155 0)}html.dark .progress,[data-theme=dark] .progress{background:#334155}html.dark .chip,[data-theme=dark] .chip{background:#1e293b;color:#cbd5e1;border-color:#334155}html.dark .chip:hover,[data-theme=dark] .chip:hover{background:#334155;border-color:#475569}html.dark .dropdown,html.dark .shadow-pop,[data-theme=dark] #notif-dropdown,[data-theme=dark] #user-dropdown{background:#1e293b!important;border-color:#334155!important}html.dark #notif-dropdown a:hover,html.dark #user-dropdown button:hover,[data-theme=dark] #notif-dropdown a:hover,[data-theme=dark] #user-dropdown button:hover{background-color:#334155!important}html.dark #notif-dropdown div,html.dark #user-dropdown div,[data-theme=dark] #notif-dropdown div,[data-theme=dark] #user-dropdown div{border-color:#334155!important}
