:root{--color-primary:#4f46e5;--color-primary-hover:#4338ca;--color-primary-light:#eef2ff;--color-primary-contrast:#fff;--color-success:#059669;--color-success-bg:#ecfdf5;--color-warning:#d97706;--color-warning-bg:#fffbeb;--color-danger:#dc2626;--color-danger-bg:#fef2f2;--color-neutral:#64748b;--color-neutral-bg:#f1f5f9;--color-bg:#f4f5f9;--color-surface:#fff;--color-sidebar-bg:#10122b;--color-sidebar-bg-elevated:#171a3d;--color-sidebar-text:#9497c4;--color-sidebar-text-active:#fff;--color-sidebar-border:rgba(255,255,255,.08);--color-text:#0f172a;--color-text-muted:#64748b;--color-text-faint:#94a3b8;--color-border:#e6e8f0;--color-border-strong:#d7dae3;--shadow-xs:0 1px 2px rgba(15,23,42,.04);--shadow-sm:0 1px 3px rgba(15,23,42,.06) , 0 1px 2px rgba(15,23,42,.04);--shadow-md:0 8px 24px -6px rgba(15,23,42,.10) , 0 2px 8px -2px rgba(15,23,42,.06);--shadow-lg:0 20px 40px -12px rgba(15,23,42,.18);--shadow-primary:0 8px 20px -6px rgba(79,70,229,.45);--radius-sm:8px;--radius-md:12px;--radius-lg:18px;--radius-full:999px;--sidebar-width:264px;--ease-out:cubic-bezier(.16,1,.3,1);--duration-fast:150ms;--duration-base:220ms}*{box-sizing:border-box;margin:0;padding:0}html{-webkit-text-size-adjust:100%}body{font-family:'Inter',system-ui,-apple-system,sans-serif;background-color:var(--color-bg);color:var(--color-text);line-height:1.55;font-size:15px;min-height:100vh}h1,h2,h3,h4{font-family:'Plus Jakarta Sans','Inter',system-ui,sans-serif;font-weight:700;letter-spacing:-.01em;color:var(--color-text)}h1{font-size:1.65rem}h2{font-size:1.15rem}a{color:inherit}::selection{background:var(--color-primary);color:#fff}:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px;border-radius:4px}.app-container{display:flex;width:100%;min-height:100vh}.sidebar{width:var(--sidebar-width);background:radial-gradient(120% 140% at 0% 0%,var(--color-sidebar-bg-elevated) 0%,var(--color-sidebar-bg) 55%);color:var(--color-sidebar-text);height:100vh;position:fixed;top:0;left:0;display:flex;flex-direction:column;padding:1.75rem 1.25rem;z-index:40}.main-content{flex:1;margin-left:var(--sidebar-width);padding:2.25rem 2.5rem 3rem;max-width:1400px;width:100%}.brand{font-family:'Plus Jakarta Sans',sans-serif;font-size:1.2rem;font-weight:700;color:#fff;margin-bottom:2.25rem;display:flex;align-items:center;gap:.65rem;padding:0 .5rem}.brand-mark{width:34px;height:34px;border-radius:var(--radius-sm);background:linear-gradient(135deg,var(--color-primary),#8b5cf6);display:flex;align-items:center;justify-content:center;font-size:1.15rem;color:#fff;box-shadow:var(--shadow-primary);flex-shrink:0}.sidebar-section-label{font-size:.68rem;font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:var(--color-sidebar-text);opacity:.55;padding:0 .75rem;margin-bottom:.5rem}.nav-links{list-style:none;display:flex;flex-direction:column;gap:.2rem}.nav-link{display:flex;align-items:center;gap:.75rem;padding:.65rem .75rem;text-decoration:none;color:var(--color-sidebar-text);border-radius:var(--radius-sm);font-weight:500;font-size:.9rem;transition:background-color var(--duration-fast) var(--ease-out) , color var(--duration-fast) var(--ease-out)}.nav-link i{font-size:1.15rem;width:1.15rem;text-align:center;flex-shrink:0}.nav-link:hover{background-color:rgba(255,255,255,.06);color:#fff}.nav-link.active{background:linear-gradient(135deg,var(--color-primary),#6d5ef0);color:var(--color-sidebar-text-active);box-shadow:var(--shadow-primary)}.sidebar-footer{margin-top:auto;padding-top:1rem;border-top:1px solid var(--color-sidebar-border)}.nav-link.nav-link-danger:hover{background-color:rgba(220,38,38,.15);color:#fca5a5}.page-header{display:flex;justify-content:space-between;align-items:flex-start;gap:1rem;margin-bottom:1.75rem;flex-wrap:wrap}.page-header h1{margin-bottom:.2rem}.page-subtitle{color:var(--color-text-muted);font-size:.9rem}.page-actions{display:flex;gap:.6rem;flex-wrap:wrap}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(230px,1fr));gap:1.25rem;margin-bottom:1.75rem}.stat-card{background-color:var(--color-surface);padding:1.4rem 1.5rem;border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);border:1px solid var(--color-border);display:flex;align-items:center;gap:1rem;transition:box-shadow var(--duration-base) var(--ease-out) , transform var(--duration-base) var(--ease-out)}.stat-card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}.stat-icon{width:46px;height:46px;border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;font-size:1.35rem;flex-shrink:0;background:var(--color-primary-light);color:var(--color-primary)}.stat-icon.icon-success{background:var(--color-success-bg);color:var(--color-success)}.stat-icon.icon-warning{background:var(--color-warning-bg);color:var(--color-warning)}.stat-icon.icon-danger{background:var(--color-danger-bg);color:var(--color-danger)}.stat-title{font-size:.8rem;color:var(--color-text-muted);margin-bottom:.2rem;font-weight:500}.stat-value{font-family:'Plus Jakarta Sans',sans-serif;font-size:1.6rem;font-weight:700;color:var(--color-text);line-height:1.1}.card{background-color:var(--color-surface);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);border:1px solid var(--color-border);padding:1.75rem;margin-bottom:1.75rem}.card-header{display:flex;align-items:center;justify-content:space-between;gap:1rem;margin-bottom:1.25rem}.card-header h2{display:flex;align-items:center;gap:.55rem}.card-accent-warning{border-left:4px solid var(--color-warning)}.card-accent-danger{border-left:4px solid var(--color-danger)}.form-card{max-width:720px}.table-toolbar{margin-bottom:1rem}.search-box{position:relative;max-width:340px}.search-box i{position:absolute;left:.9rem;top:50%;transform:translateY(-50%);color:var(--color-text-faint);font-size:1rem;pointer-events:none}.search-box input{padding-left:2.4rem}.table-container{background-color:var(--color-surface);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);overflow:hidden;border:1px solid var(--color-border)}table{width:100%;border-collapse:collapse}th,td{padding:.9rem 1.4rem;text-align:left;border-bottom:1px solid var(--color-border);font-size:.9rem}th{background-color:#fafbfd;font-weight:600;font-size:.7rem;text-transform:uppercase;letter-spacing:.06em;color:var(--color-text-muted)}tbody tr{transition:background-color var(--duration-fast) var(--ease-out)}tbody tr:hover{background-color:#fafbff}tr:last-child td{border-bottom:none}tr.row-overdue{background-color:var(--color-danger-bg)}tr.row-overdue:hover{background-color:#fde8e8}.text-danger{color:var(--color-danger);font-weight:600}.text-muted{color:var(--color-text-muted)}.cell-strong{font-weight:600;color:var(--color-text)}.cell-sub{display:block;font-size:.78rem;color:var(--color-text-faint);margin-top:.15rem}.empty-row td{text-align:center;color:var(--color-text-muted);padding:2.5rem 1rem}.empty-state{display:flex;flex-direction:column;align-items:center;gap:.35rem}.empty-state i{font-size:2rem;color:var(--color-text-faint);margin-bottom:.4rem}.badge{display:inline-flex;align-items:center;gap:.35rem;padding:.28rem .7rem;border-radius:var(--radius-full);font-size:.75rem;font-weight:600;white-space:nowrap}.badge i{font-size:.85rem}.badge-success{background:var(--color-success-bg);color:var(--color-success)}.badge-warning{background:var(--color-warning-bg);color:var(--color-warning)}.badge-danger{background:var(--color-danger-bg);color:var(--color-danger)}.badge-neutral{background:var(--color-neutral-bg);color:var(--color-neutral)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:.45rem;padding:.62rem 1.15rem;border-radius:var(--radius-sm);font-weight:600;font-size:.875rem;text-decoration:none;cursor:pointer;border:1px solid var(--color-border-strong);background-color:var(--color-surface);color:var(--color-text);transition:background-color var(--duration-fast) var(--ease-out) , border-color var(--duration-fast) var(--ease-out) , box-shadow var(--duration-fast) var(--ease-out) , transform var(--duration-fast) var(--ease-out)}.btn:hover{border-color:var(--color-text-faint);background-color:#f8fafc}.btn:active{transform:translateY(1px)}.btn-primary{background-color:var(--color-primary);border-color:var(--color-primary);color:#fff;box-shadow:var(--shadow-primary)}.btn-primary:hover{background-color:var(--color-primary-hover);border-color:var(--color-primary-hover)}.btn-success{background-color:var(--color-success);border-color:var(--color-success);color:#fff}.btn-success:hover{background-color:#047857;border-color:#047857}.btn-ghost{background:transparent;border-color:transparent;color:var(--color-text-muted)}.btn-ghost:hover{background-color:var(--color-neutral-bg);color:var(--color-text)}.btn-sm{padding:.4rem .75rem;font-size:.8rem}.btn-block{width:100%}.form-group{margin-bottom:1.25rem}.form-row{display:flex;gap:1.25rem;flex-wrap:wrap}.form-row .form-group{flex:1;min-width:200px}label{display:block;margin-bottom:.4rem;font-size:.85rem;font-weight:600;color:var(--color-text)}label .optional{font-weight:400;color:var(--color-text-faint)}.form-control,input[type="text"],input[type="email"],input[type="password"],input[type="number"],input[type="date"],input[type="file"],select,textarea{width:100%;padding:.7rem .85rem;border:1px solid var(--color-border-strong);border-radius:var(--radius-sm);font-size:.9rem;font-family:inherit;color:var(--color-text);background-color:var(--color-surface);transition:border-color var(--duration-fast) var(--ease-out) , box-shadow var(--duration-fast) var(--ease-out)}textarea{resize:vertical;min-height:90px}.form-control:focus,input:focus,select:focus,textarea:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px var(--color-primary-light)}.form-check{display:flex;align-items:center;gap:.55rem}.form-check input[type="checkbox"]{width:1.15rem;height:1.15rem;accent-color:var(--color-primary)}.form-check label{margin-bottom:0;font-weight:500}.form-checks{display:flex;gap:2rem;flex-wrap:wrap;margin-bottom:1.5rem}.form-actions{display:flex;gap:.75rem;margin-top:1.75rem;padding-top:1.5rem;border-top:1px solid var(--color-border)}.form-hint{font-size:.78rem;color:var(--color-text-faint);margin-top:.35rem}.inline-form{display:inline}.alert{padding:.85rem 1.1rem;border-radius:var(--radius-sm);font-size:.88rem;margin-bottom:1.25rem;display:flex;align-items:center;gap:.6rem}.alert-danger{background:var(--color-danger-bg);color:var(--color-danger);border:1px solid rgba(220,38,38,.2)}.auth-page{min-height:100vh;width:100%;display:flex;align-items:center;justify-content:center;background:radial-gradient(120% 120% at 15% 0%,#1c1f4d 0%,#10122b 45%,#0a0b1c 100%);padding:1.5rem}.auth-card{background:var(--color-surface);padding:2.5rem;border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);width:100%;max-width:400px}.auth-header{text-align:center;margin-bottom:2rem}.auth-header .brand-mark{margin:0 auto 1rem}.auth-header h1{font-size:1.4rem;margin-bottom:.3rem}.auth-header p{color:var(--color-text-muted);font-size:.9rem}.error-page{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100vh;text-align:center;width:100%;gap:.5rem;background:var(--color-bg)}.error-page .error-code{font-family:'Plus Jakarta Sans',sans-serif;font-size:4.5rem;font-weight:800;color:var(--color-primary);line-height:1}.error-page p{font-size:1.1rem;color:var(--color-text-muted);margin-bottom:1.5rem}.mb-4{margin-bottom:1rem}.flex{display:flex}.justify-between{justify-content:space-between}.items-center{align-items:center}.gap-2{gap:.5rem}@media (max-width:960px){.sidebar{width:76px;padding:1.25rem .65rem;align-items:center}.sidebar .brand span,.sidebar-section-label,.nav-link span{display:none}.nav-link{justify-content:center;padding:.75rem}.main-content{margin-left:76px;padding:1.5rem}.form-row{flex-direction:column}}@media (prefers-reduced-motion:reduce){*{transition-duration:.001ms!important;animation-duration:.001ms!important}}