:root{--primary:#1e3a5f;--primary-light:#2a5a8f;--primary-dark:#0f2440;--accent:#e8a838;--accent-light:#f5d090;--success:#22a06b;--success-bg:#e3fcef;--warning:#e8a838;--warning-bg:#fff8e6;--danger:#de350b;--danger-bg:#ffebe6;--info:#0065ff;--info-bg:#e6f0ff;--bg:#f5f6f8;--bg-card:#fff;--bg-sidebar:#0f2440;--text:#172b4d;--text-secondary:#5e6c84;--text-light:#97a0af;--border:#dfe1e6;--border-light:#ebecf0;--radius:8px;--radius-lg:12px;--shadow:0 1px 3px #00000014,0 1px 2px #0000000f;--shadow-md:0 4px 12px #0000001a;--font:"Plus Jakarta Sans",-apple-system,BlinkMacSystemFont,sans-serif;--transition:0.2s ease}*{box-sizing:border-box;margin:0;padding:0}body{-webkit-font-smoothing:antialiased;background:#f5f6f8;background:var(--bg);color:#172b4d;color:var(--text);font-family:Plus Jakarta Sans,-apple-system,BlinkMacSystemFont,sans-serif;font-family:var(--font)}.app-layout{display:flex;min-height:100vh}.sidebar{background:#0f2440;background:var(--bg-sidebar);bottom:0;color:#fff;display:flex;flex-direction:column;left:0;position:fixed;top:0;transition:width .25s ease;width:230px;z-index:100}.sidebar-collapsed{width:68px}.sidebar-collapsed .sidebar-header{padding:16px 12px}.sidebar-collapsed .nav-item{justify-content:center;padding:10px}.sidebar-collapsed .nav-item svg{margin:0}.sidebar-toggle-btn{align-items:center;background:none;border:1px solid #ffffff26;border-radius:6px;color:#fff6;cursor:pointer;display:flex;flex-shrink:0;height:28px;justify-content:center;transition:all .2s ease;transition:all var(--transition);width:28px}.sidebar-toggle-btn:hover{background:#ffffff1a;border-color:#ffffff4d;color:#fff}.sidebar-header{border-bottom:1px solid #ffffff14;padding:20px;position:relative}.sidebar-header h1{font-size:18px;font-weight:700;letter-spacing:-.3px}.sidebar-header p{color:#ffffff80;font-size:11px;letter-spacing:.5px;margin-top:4px;text-transform:uppercase}.sidebar-nav{flex:1 1;overflow-y:auto;padding:12px 8px}.nav-section{margin-bottom:8px}.nav-section-title{color:#ffffff59;font-size:10px;font-weight:600;letter-spacing:1px;padding:12px 12px 6px;text-transform:uppercase}.nav-item{align-items:center;background:none;border:none;border-radius:6px;color:#ffffffa6;cursor:pointer;display:flex;font-size:13.5px;font-weight:500;gap:10px;padding:10px 12px;text-align:left;text-decoration:none;transition:all .2s ease;transition:all var(--transition);width:100%}.nav-item:hover{background:#ffffff14;color:#fff}.nav-item.active{background:#e8a83826;color:#e8a838;color:var(--accent)}.nav-item svg{flex-shrink:0;height:18px;width:18px}.main-content{flex:1 1;margin-left:230px;min-height:100vh;min-width:0;position:relative;transition:margin-left .25s ease}.sidebar-is-collapsed .main-content{margin-left:68px}.top-bar{background:#fff;background:var(--bg-card);border-bottom:1px solid #dfe1e6;border-bottom:1px solid var(--border);height:56px;padding:0 24px;position:sticky;top:0;z-index:200}.top-bar,.top-bar-actions{align-items:center;display:flex}.top-bar-actions{gap:8px}.profile-dropdown-container{position:relative}.profile-trigger{background:none;border:2px solid #dfe1e6;border:2px solid var(--border);border-radius:50%;cursor:pointer;height:36px;overflow:hidden;padding:0;transition:border-color .2s ease;transition:border-color var(--transition);width:36px}.profile-trigger:hover{border-color:#1e3a5f;border-color:var(--primary)}.profile-avatar-img{border-radius:50%;height:100%;object-fit:cover;width:100%}.profile-avatar-initials{align-items:center;background:#e8a838;background:var(--accent);border-radius:50%;color:#0f2440;color:var(--primary-dark);display:flex;font-size:13px;font-weight:700;height:100%;justify-content:center;width:100%}.profile-dropdown{background:#fff;background:var(--bg-card);border:1px solid #dfe1e6;border:1px solid var(--border);border-radius:12px;border-radius:var(--radius-lg);box-shadow:0 12px 40px #00000026;overflow:hidden;position:absolute;right:0;top:calc(100% + 8px);width:300px;z-index:1000}.profile-dropdown-header{align-items:center;display:flex;gap:14px;padding:16px}.profile-dropdown-avatar{background:#e8a838;background:var(--accent);color:#0f2440;color:var(--primary-dark);cursor:pointer;flex-shrink:0;font-size:18px;font-weight:700;height:52px;overflow:hidden;position:relative;width:52px}.avatar-camera-overlay,.profile-dropdown-avatar{align-items:center;border-radius:50%;display:flex;justify-content:center}.avatar-camera-overlay{background:#00000080;color:#fff;inset:0;opacity:0;position:absolute;transition:opacity .2s ease;transition:opacity var(--transition)}.profile-dropdown-avatar:hover .avatar-camera-overlay{opacity:1}.profile-dropdown-info{flex:1 1;min-width:0}.profile-dropdown-name{color:#172b4d;color:var(--text);font-size:15px;font-weight:700}.profile-dropdown-email,.profile-dropdown-name{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.profile-dropdown-email{color:#5e6c84;color:var(--text-secondary);font-size:12px}.profile-dropdown-divider{background:#ebecf0;background:var(--border-light);height:1px;margin:0}.profile-dropdown-detail{color:#172b4d;color:var(--text);font-size:12.5px;padding:8px 16px}.profile-dropdown-detail .text-muted{color:#5e6c84;color:var(--text-secondary);margin-right:4px}.profile-dropdown-item{align-items:center;background:none;border:none;color:#172b4d;color:var(--text);cursor:pointer;display:flex;font-family:Plus Jakarta Sans,-apple-system,BlinkMacSystemFont,sans-serif;font-family:var(--font);font-size:13.5px;gap:10px;padding:10px 16px;text-align:left;transition:background .2s ease;transition:background var(--transition);width:100%}.profile-dropdown-item:hover{background:#f5f6f8;background:var(--bg)}.profile-dropdown-item-danger{color:#de350b;color:var(--danger)}.profile-dropdown-item-danger:hover{background:#ffebe6;background:var(--danger-bg)}.page-header{background:#fff;background:var(--bg-card);border-bottom:1px solid #dfe1e6;border-bottom:1px solid var(--border);padding:12px 36px}.page-header h2{color:#172b4d;color:var(--text);font-size:26px;font-weight:800;letter-spacing:-.5px;margin:0 0 6px}.page-header p{color:#5e6c84;color:var(--text-secondary);font-size:14px;margin:0}.page-content{margin:0 auto;max-width:1600px;padding:13px 36px 28px}.page-content>.card,.page-content>.dual-col,.page-content>.stats-grid{margin-bottom:24px}.page-content>.card:last-child,.page-content>.dual-col:last-child,.page-content>.stats-grid:last-child{margin-bottom:0}.card{background:#fff;background:var(--bg-card);border:1px solid #dfe1e6;border:1px solid var(--border);border-radius:12px;border-radius:var(--radius-lg);box-shadow:0 1px 3px #00000014,0 1px 2px #0000000f;box-shadow:var(--shadow);transition:all .2s ease;transition:all var(--transition)}.card:hover{border-color:#d1d5db;box-shadow:0 2px 8px #0000001a}.card-header{align-items:center;border-bottom:1px solid #ebecf0;border-bottom:1px solid var(--border-light);display:flex;justify-content:space-between;padding:18px 22px}.card-header h3{color:#172b4d;color:var(--text);font-size:16px;font-weight:700;letter-spacing:-.3px}.card-body{padding:22px}.stats-grid{grid-gap:16px;gap:16px;grid-template-columns:repeat(auto-fit,minmax(220px,1fr))}.dual-col,.stats-grid{display:grid;margin-bottom:24px}.dual-col{grid-gap:18px;gap:18px;grid-template-columns:repeat(auto-fit,minmax(420px,1fr))}.stat-card{align-items:flex-start;background:#fff;background:var(--bg-card);border:1px solid #dfe1e6;border:1px solid var(--border);border-radius:12px;border-radius:var(--radius-lg);box-shadow:0 1px 3px #00000014,0 1px 2px #0000000f;box-shadow:var(--shadow);display:flex;gap:16px;padding:22px;transition:all .2s ease;transition:all var(--transition)}.stat-card:hover{border-color:#d1d5db;box-shadow:0 4px 12px #0000001a;transform:translateY(-2px)}.stat-icon{align-items:center;border-radius:12px;display:flex;flex-shrink:0;font-size:20px;height:48px;justify-content:center;width:48px}.stat-icon.blue{background:#e6f0ff;background:var(--info-bg);color:#0065ff;color:var(--info)}.stat-icon.green{background:#e3fcef;background:var(--success-bg);color:#22a06b;color:var(--success)}.stat-icon.amber{background:#fff8e6;background:var(--warning-bg);color:#e8a838;color:var(--warning)}.stat-icon.red{background:#ffebe6;background:var(--danger-bg);color:#de350b;color:var(--danger)}.stat-content{flex:1 1}.stat-value{color:#172b4d;color:var(--text);font-size:32px;font-weight:800;letter-spacing:-1px;line-height:1}.stat-label{color:#5e6c84;color:var(--text-secondary);font-size:13px;font-weight:600;margin-top:6px}.table-container{border-radius:12px;border-radius:var(--radius-lg);overflow-x:auto}table{border-collapse:collapse;font-size:14px;width:100%}thead th{background:#c6e0b4;border:1px solid #7fa05f;color:#1f3d2b;font-size:12px;font-weight:700;letter-spacing:.5px;padding:14px 16px;text-align:left;text-transform:uppercase;white-space:nowrap}tbody td{border:1px solid #b4bcc4;color:#172b4d;color:var(--text);padding:13px 16px;vertical-align:middle}tbody tr{transition:background .2s ease;transition:background var(--transition)}tbody tr:hover{background:#f9fafb}.aip-grid td,.aip-grid th{border:1px solid #9aa3af;padding:8px 10px}.aip-grid thead th{background:#c6e0b4;border-color:#7fa05f;color:#1f3d2b}.table-container.aip-scroll{max-height:calc(100vh - 270px);overflow:auto}.aip-grid thead th{box-shadow:0 1px 0 #7fa05f;position:sticky;top:0;z-index:2}.aip-grid td:first-child,.aip-grid th:first-child{background:#fff;background:var(--bg-card,#fff);box-shadow:1px 0 0 #9aa3af;left:0;position:sticky;z-index:1}.aip-grid tbody tr:hover td:first-child{background:#f9fafb}.aip-grid thead th:first-child{background:#c6e0b4;z-index:3}.table-grid td,.table-grid th{border:1px solid #b4bcc4}.table-grid thead th{background:#c6e0b4;border-color:#7fa05f;color:#1f3d2b}.table-container.table-grid-scroll{max-height:calc(100vh - 270px);overflow:auto}.table-grid thead th{box-shadow:0 1px 0 #7fa05f;position:sticky;top:0;z-index:2}.table-grid td:first-child,.table-grid th:first-child{background:#fff;background:var(--bg-card,#fff);box-shadow:1px 0 0 #b4bcc4;left:0;position:sticky;z-index:1}.table-grid tbody tr:hover td:first-child{background:#f9fafb}.table-grid thead th:first-child{background:#c6e0b4;z-index:3}.badge{align-items:center;border-radius:20px;display:inline-flex;font-size:12px;font-weight:700;letter-spacing:-.2px;padding:4px 12px;white-space:nowrap}.badge-draft{background:#f3f4f6;color:#374151}.badge-submitted{background:#e6f0ff;background:var(--info-bg);color:#0065ff;color:var(--info)}.badge-under_review{background:#fff8e6;background:var(--warning-bg);color:#b8860b}.badge-pmt_reviewed{background:#dbeafe;color:#0369a1}.badge-approved{background:#e3fcef;background:var(--success-bg);color:#22a06b;color:var(--success)}.badge-returned{background:#ffebe6;background:var(--danger-bg);color:#de350b;color:var(--danger)}.badge-completed{background:#e3fcef;background:var(--success-bg);color:#22a06b;color:var(--success)}.badge-ongoing{background:#fff8e6;background:var(--warning-bg);color:#b8860b}.badge-not_started{background:#f3f4f6;color:#374151}.badge-active{background:#e3fcef;background:var(--success-bg);color:#22a06b;color:var(--success)}.badge-planning{background:#e6f0ff;background:var(--info-bg);color:#0065ff;color:var(--info)}.badge-review{background:#fff8e6;background:var(--warning-bg);color:#b8860b}.badge-closed{background:#f3f4f6;color:#374151}.btn{align-items:center;border:none;border-radius:8px;cursor:pointer;display:inline-flex;font-family:Plus Jakarta Sans,-apple-system,BlinkMacSystemFont,sans-serif;font-family:var(--font);font-size:14px;font-weight:700;gap:7px;letter-spacing:-.3px;padding:9px 18px;text-decoration:none;transition:all .2s ease;transition:all var(--transition);white-space:nowrap}.btn-primary{background:#1e3a5f;background:var(--primary);box-shadow:0 2px 8px #1e3a5f26;color:#fff}.btn-primary:hover{background:#2a5a8f;background:var(--primary-light);box-shadow:0 4px 12px #1e3a5f40;transform:translateY(-1px)}.btn-primary:active{box-shadow:0 1px 4px #1e3a5f33;transform:translateY(0)}.btn-accent{background:#e8a838;background:var(--accent);box-shadow:0 2px 8px #e8a83826;color:#0f2440;color:var(--primary-dark);font-weight:700}.btn-accent:hover{background:#d4952e;box-shadow:0 4px 12px #e8a83840;transform:translateY(-1px)}.btn-accent:active{transform:translateY(0)}.btn-outline{background:#0000;border:1.5px solid #1e3a5f;border:1.5px solid var(--primary);color:#1e3a5f;color:var(--primary)}.btn-outline:hover{background:#1e3a5f0d;border-color:#2a5a8f;border-color:var(--primary-light)}.btn-danger{background:#de350b;background:var(--danger);box-shadow:0 2px 8px #de350b26;color:#fff}.btn-danger:hover{background:#bf2600;box-shadow:0 4px 12px #de350b40;transform:translateY(-1px)}.btn-sm{font-size:12.5px;font-weight:600;padding:6px 12px}.btn-lg{font-size:15px;letter-spacing:-.3px;padding:13px 26px}.btn:disabled{cursor:not-allowed;opacity:.6;transform:none!important}.form-group{margin-bottom:16px}.form-label{color:#172b4d;color:var(--text);display:block;font-size:13px;font-weight:700;letter-spacing:-.2px;margin-bottom:8px}.form-input,.form-select,.form-textarea{background:#fff;border:1.5px solid #dfe1e6;border:1.5px solid var(--border);border-radius:8px;color:#172b4d;color:var(--text);font-family:Plus Jakarta Sans,-apple-system,BlinkMacSystemFont,sans-serif;font-family:var(--font);font-size:14px;padding:11px 13px;transition:all .2s ease;transition:all var(--transition);width:100%}.form-input::placeholder,.form-select::placeholder{color:#97a0af;color:var(--text-light)}.form-input:hover,.form-select:hover,.form-textarea:hover{border-color:#c1c7d0}.form-input:focus,.form-select:focus,.form-textarea:focus{background:#fafbfc;border-color:#1e3a5f;border-color:var(--primary);box-shadow:0 0 0 4px #1e3a5f14,inset 0 1px 2px #00000005;outline:none}.form-textarea{font-family:Plus Jakarta Sans,-apple-system,BlinkMacSystemFont,sans-serif;font-family:var(--font);min-height:90px;resize:vertical}.form-error{color:#de350b;color:var(--danger);display:block;font-size:12px;font-weight:500;margin-top:5px}.form-input-error{border-color:#de350b!important;border-color:var(--danger)!important}.form-row{grid-gap:18px;display:grid;gap:18px;grid-template-columns:repeat(2,1fr)}.form-row-3{grid-gap:18px;display:grid;gap:18px;grid-template-columns:repeat(3,minmax(0,1fr))}@media (max-width:720px){.form-row-3{gap:12px;grid-template-columns:1fr}}.form-row-4{grid-gap:18px;display:grid;gap:18px;grid-template-columns:repeat(4,minmax(0,1fr))}@media (max-width:900px){.form-row-4{grid-template-columns:repeat(2,1fr)}}@media (max-width:560px){.form-row-4{gap:12px;grid-template-columns:1fr}}.form-grid{grid-column-gap:18px;grid-row-gap:16px;column-gap:18px;display:grid;grid-template-columns:repeat(2,minmax(0,1fr));row-gap:16px}.form-grid>div{min-width:0}@media (max-width:640px){.form-grid{grid-template-columns:1fr}}.form-label span{color:#5e6c84;color:var(--text-secondary);display:inline;font-size:12px;font-weight:500}.rating-cell{font-size:14px;font-weight:600;text-align:center}.rating-outstanding{color:#22a06b}.rating-very-satisfactory{color:#0065ff}.rating-satisfactory{color:#e8a838}.rating-unsatisfactory{color:#de350b}.rating-poor{color:#bf2600}.login-page{align-items:center;background:#0f2440;background:var(--primary-dark);display:flex;justify-content:center;min-height:100vh;overflow:hidden;padding:20px;position:relative}.login-bg{animation:kenburns 30s ease-in-out infinite alternate;background-position:50%;background-size:cover;filter:blur(6px);inset:0;position:fixed;transform:scale(1.12);transition:filter .5s ease;z-index:0}.login-page.booting .login-bg{filter:blur(22px)}@keyframes kenburns{0%{transform:scale(1.12) translate(0)}to{transform:scale(1.2) translate(-1.5%,-1.2%)}}.login-bg-overlay{background:linear-gradient(135deg,#0f24409e,#1e3a5f80 50%,#2a5a8f99);inset:0;overflow:hidden;position:fixed;z-index:0}.login-bg-overlay:after,.login-bg-overlay:before{border-radius:50%;content:"";filter:blur(70px);opacity:.5;position:absolute}.login-bg-overlay:before{animation:drift1 18s ease-in-out infinite alternate;background:radial-gradient(circle,#6b46c18c,#0000 70%);height:420px;left:-100px;top:-120px;width:420px}.login-bg-overlay:after{animation:drift2 22s ease-in-out infinite alternate;background:radial-gradient(circle,#2a5a8f99,#0000 70%);bottom:-160px;height:480px;right:-120px;width:480px}@keyframes drift1{to{transform:translate(40px,30px)}}@keyframes drift2{to{transform:translate(-50px,-30px)}}.login-card{backdrop-filter:blur(18px) saturate(140%);-webkit-backdrop-filter:blur(18px) saturate(140%);background:#ffffff1a;border:1px solid #ffffff38;border-radius:20px;box-shadow:0 24px 60px #0006,inset 0 1px 0 #ffffff40;color:#fff;max-width:420px;padding:48px;position:relative;width:100%;z-index:1}.login-logo{animation:float 6s ease-in-out .4s infinite}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-6px)}}.login-card h1{color:#fff;font-size:24px;font-weight:800;letter-spacing:.12em;margin-bottom:0;text-align:center;text-shadow:0 2px 14px #0000004d}.login-card .title-rule{background:linear-gradient(90deg,#0000,#e6b84f,#0000);border-radius:3px;height:3px;margin:12px auto 0;width:180px}.login-card .subtitle{color:#ffffffd1;font-size:13px;margin-bottom:32px;text-align:center}.login-card .form-label{color:#ffffffe0}.login-card .form-input{background:#ffffff1a;border:1px solid #ffffff40;color:#fff}.login-card .form-input::placeholder{color:#ffffff8c}.login-card .form-input:focus{background:#ffffff24;border-color:#e6b84f;box-shadow:0 0 0 3px #e6b84f40}.login-card .form-input.has-error{border-color:#ff9b9b}.login-card .form-group button[type=button]{color:#ffffffb3}.login-card .form-error{color:#ffb4b4}.login-card .btn-primary{background:linear-gradient(135deg,#2f5d92,#16365c);border:1px solid #ffffff2e;box-shadow:0 10px 26px #1e3a5f8c;font-size:15px;justify-content:center;margin-top:8px;padding:12px;width:100%}.login-card .btn-primary:hover{filter:brightness(1.08)}.login-card a{color:#fffc!important}@media (prefers-reduced-motion:reduce){.login-bg,.login-bg-overlay:after,.login-bg-overlay:before,.login-logo{animation:none}}.logo-spinner{align-items:center;animation:ls-fade .3s ease;display:flex;justify-content:center;position:relative}.logo-spinner .ls-ring{border-color:#0000;border-radius:50%;border-style:solid;position:absolute}.logo-spinner .ls-ring.outer{animation:ls-spin 1.4s linear infinite;border-right-color:#0f2440;border-top-color:#0f2440}.logo-spinner .ls-ring.mid{animation:ls-spin 1s linear infinite reverse;border-bottom-color:#c0392b;border-left-color:#c0392b}.logo-spinner .ls-ring.inner{animation:ls-spin .8s linear infinite;border-top-color:#0f2440}.logo-spinner.on-dark .ls-ring.outer{border-right-color:#fff;border-top-color:#fff}.logo-spinner.on-dark .ls-ring.inner{border-top-color:#fff}.logo-spinner .ls-glow{animation:ls-pulse 1.8s ease-in-out infinite;background:radial-gradient(circle,#c0392b38,#0000 70%);border-radius:50%;position:absolute}.logo-spinner .ls-logo{animation:ls-breathe 2.2s ease-in-out infinite;border-radius:50%;object-fit:cover;position:relative;z-index:2}@keyframes ls-spin{to{transform:rotate(1turn)}}@keyframes ls-pulse{0%,to{opacity:.45;transform:scale(.9)}50%{opacity:1;transform:scale(1.06)}}@keyframes ls-breathe{0%,to{transform:scale(1)}50%{transform:scale(1.04)}}@keyframes ls-fade{0%{opacity:0}to{opacity:1}}.logo-spinner-overlay{animation:ls-fade .25s ease;backdrop-filter:blur(7px);-webkit-backdrop-filter:blur(7px);background:#f8fafc80;inset:0;opacity:1;position:fixed;transition:opacity .3s ease;z-index:4000}.logo-spinner-overlay .ls-center{align-items:center;display:flex;flex-direction:column;gap:18px;height:100%;justify-content:center}.logo-spinner-overlay.leaving{opacity:0;pointer-events:none}.logo-spinner-overlay.scoped{position:absolute;z-index:50}.logo-spinner-overlay.scoped .ls-center{height:100vh;position:sticky;top:0}.gantt-hscroll{scrollbar-width:none}.gantt-hscroll::-webkit-scrollbar{display:none}.logo-spinner-overlay .ls-label{animation:ls-blink 1.4s ease-in-out infinite;color:#5e6c84;color:var(--text-secondary);font-size:13px;font-weight:600;letter-spacing:.14em;text-transform:uppercase}@keyframes ls-blink{0%,to{opacity:.45}50%{opacity:1}}@media (prefers-reduced-motion:reduce){.logo-spinner .ls-glow,.logo-spinner .ls-logo,.logo-spinner-overlay .ls-label{animation:none}}.progress-bar{background:#ebecf0;background:var(--border-light);border-radius:3px;height:6px;overflow:hidden}.progress-fill{border-radius:3px;height:100%;transition:width .5s ease}.progress-fill.green{background:#22a06b;background:var(--success)}.progress-fill.amber{background:#e8a838;background:var(--warning)}.progress-fill.red{background:#de350b;background:var(--danger)}.progress-fill.blue{background:#0065ff;background:var(--info)}.empty-state{color:#5e6c84;color:var(--text-secondary);padding:48px 24px;text-align:center}.empty-state svg{height:48px;margin-bottom:12px;opacity:.4;width:48px}.empty-state p{font-size:14px}.flex{display:flex}.items-center{align-items:center}.justify-between{justify-content:space-between}.gap-1{gap:4px}.gap-2{gap:8px}.gap-3{gap:12px}.gap-4{gap:16px}.mt-4{margin-top:16px}.mb-4{margin-bottom:16px}.text-right{text-align:right}.text-center{text-align:center}.font-bold{font-weight:700}.text-sm{font-size:13px}.text-xs{font-size:11px}.text-muted{color:#5e6c84;color:var(--text-secondary)}.truncate{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.action-buttons{align-items:center;display:flex;flex-wrap:wrap;gap:8px}.action-buttons .badge,.action-buttons .btn{white-space:nowrap}td .action-buttons,td .flex.gap-1{align-items:center;display:flex;gap:6px}td .btn+.btn,td .icon-btn+.icon-btn{margin-left:0}.modal-overlay{align-items:center;animation:fadeIn .2s ease;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);background:#00000080;display:flex;inset:0;justify-content:center;padding:24px;position:fixed;z-index:1000}.modal{animation:slideUp .3s ease;background:#fff;border-radius:12px;border-radius:var(--radius-lg);box-shadow:0 20px 60px #0000004d;max-height:94vh;max-width:640px;overflow-y:auto;width:100%}.modal-body .form-group{margin-bottom:13px}.modal-body .form-textarea{min-height:70px}.modal-header{align-items:center;background:#fafbfc;border-bottom:1px solid #dfe1e6;border-bottom:1px solid var(--border);display:flex;justify-content:space-between;padding:24px}.modal-header h3{color:#172b4d;color:var(--text);font-size:18px;font-weight:700;letter-spacing:-.3px}.modal-body{padding:28px 24px}.modal-footer{border-top:1px solid #dfe1e6;border-top:1px solid var(--border);display:flex;flex-wrap:wrap;gap:10px;justify-content:flex-end;padding:16px 24px}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}@media (min-width:1920px){.page-content{margin:0 auto;max-width:1900px;padding:17px 48px 32px}.stats-grid{gap:20px;grid-template-columns:repeat(5,1fr)}.page-header{padding:16px 48px}.card-body{padding:28px}}@media (min-width:769px) and (max-width:1199px){.stats-grid{gap:16px;grid-template-columns:repeat(3,1fr)}.form-row{gap:14px}}@media (max-width:768px){.sidebar{width:68px}.sidebar .nav-item span,.sidebar .nav-section-title,.sidebar .sidebar-header h1,.sidebar .sidebar-header p{display:none}.sidebar .nav-item{justify-content:center;padding:12px 8px}.main-content{margin-left:68px}.page-header{padding:20px}.page-header h2{font-size:22px}.page-content{padding:16px}.stats-grid{gap:12px;grid-template-columns:repeat(2,1fr)}.stat-card{gap:12px;padding:16px}.stat-icon{height:40px;width:40px}.stat-value{font-size:24px}.form-row{gap:12px;grid-template-columns:1fr}.form-label{font-size:12px;margin-bottom:6px}.btn{font-size:13px;padding:8px 14px}table{font-size:12px}thead th{font-size:10px}tbody td,thead th{padding:10px 8px}.modal{max-height:95vh;max-width:95vw}.modal-header{padding:16px}.modal-header h3{font-size:16px}.modal-body{padding:16px}.top-bar{padding:0 16px}}@media (max-width:640px){:root{--radius:6px;--radius-lg:10px}.sidebar{left:-100%;transition:left .3s ease;width:0}.sidebar.open{left:0}.main-content{margin-left:0}.page-header{padding:16px 14px}.page-header h2{font-size:20px}.page-header p{font-size:12px}.page-content{padding:12px 14px}.card-header{padding:14px 16px}.card-header h3{font-size:14px}.card-body{padding:16px}.stats-grid{gap:10px;grid-template-columns:1fr}.stat-card{padding:14px}.stat-value{font-size:22px}.stat-label{font-size:11px;margin-top:4px}.form-label{font-size:11px;margin-bottom:5px}.form-input,.form-select,.form-textarea{font-size:13px;padding:9px 11px}.form-row{gap:10px;grid-template-columns:1fr}.btn{font-size:12px;padding:7px 12px}.btn-lg{justify-content:center;width:100%}.table-container{margin-bottom:16px;overflow-x:auto}table{font-size:11px;min-width:600px}thead th{font-size:9px}tbody td,thead th{padding:8px 6px}.login-card{padding:32px 24px}.login-card h1{font-size:22px}.modal-overlay{padding:12px}.modal{border-radius:12px 12px 0 0;max-width:100%}.modal-header{padding:14px 16px}.modal-header h3{font-size:15px}.modal-body{padding:14px 16px}.modal-footer{gap:8px;padding:12px 16px}.profile-dropdown{border-radius:20px 20px 0 0;bottom:0;left:0;max-height:80vh;position:fixed;right:0!important;top:auto!important;width:100%}.empty-state{padding:32px 16px}}@media (max-width:479px){:root{--radius:5px}html{font-size:14px}body{overflow-x:hidden}.sidebar{box-shadow:2px 0 12px #0003;height:100vh;left:-100%;width:100%;z-index:999}.sidebar.open{left:0}.main-content{margin-left:0}.top-bar{height:52px;padding:0 12px}.sidebar-toggle-btn{height:32px;width:32px}.page-header{padding:14px 12px}.page-header h2{font-size:18px;margin-bottom:2px}.page-header p{font-size:11px}.page-content{padding:10px 12px}.card-header{gap:10px;padding:12px 14px}.card-header h3{font-size:13px}.card-body{padding:14px}.stats-grid{gap:8px;grid-template-columns:1fr;margin-bottom:12px}.stat-card{gap:10px;padding:12px}.stat-icon{height:36px;width:36px}.stat-value{font-size:20px}.stat-label{font-size:10px}.form-group{margin-bottom:12px}.form-label{font-size:10px;margin-bottom:4px}.form-input,.form-select,.form-textarea{font-size:12px;padding:8px 10px}.form-row{gap:8px;grid-template-columns:1fr}.btn{border-radius:5px;font-size:11px;gap:3px;padding:6px 10px}.btn-lg{font-size:12px;padding:8px 12px;width:100%}.btn svg{height:14px;width:14px}.table-container{-webkit-overflow-scrolling:touch;margin-bottom:12px}table{font-size:10px;min-width:500px}thead th{font-size:8px}tbody td,thead th{padding:6px 4px}.badge{font-size:9px;padding:2px 8px}.login-card{border-radius:16px;padding:24px 16px}.login-card h1{font-size:20px;margin-bottom:2px}.login-card .subtitle{font-size:12px;margin-bottom:24px}.modal-overlay{padding:0}.modal{border-radius:20px 20px 0 0;margin-top:auto;max-height:100vh;max-width:100%}.modal-header{padding:12px 14px}.modal-header h3{font-size:14px}.modal-body{padding:12px 14px}.modal-footer{flex-wrap:wrap;gap:6px;padding:10px 14px}.modal-footer .btn{flex:1 1;min-width:48px}.profile-dropdown{border-radius:20px 20px 0 0;bottom:0;left:0;max-height:90vh;position:fixed;right:0!important;top:auto!important;width:100%}.notification-item{border-radius:6px}.flex{flex-wrap:wrap}}@media (max-width:640px) and (orientation:landscape){.sidebar{height:100vh}.page-header{padding:12px}.page-header h2{font-size:18px}.page-content{padding:8px 12px}.stats-grid{gap:8px;grid-template-columns:repeat(2,1fr)}.modal{max-height:90vh}}.app-spinner{animation:app-spin .7s linear infinite;border:2px solid #ffffff40;border-radius:50%;border-top-color:initial;display:inline-block;flex-shrink:0;vertical-align:-2px}.btn .app-spinner{border-color:#fff #ffffff59 #ffffff59}.btn-outline .app-spinner{border-color:#1e3a5f #1e3a5f33 #1e3a5f33;border-top-color:var(--primary)}@keyframes app-spin{to{transform:rotate(1turn)}}.skeleton-line{animation:skeleton-shimmer 1.4s ease-in-out infinite;background:linear-gradient(90deg,#eef0f3,#f6f7f9 50%,#eef0f3);background-size:200% 100%;border-radius:4px;display:block;height:12px;width:100%}@keyframes skeleton-shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.form-textarea.auto-grow{min-height:auto;overflow:hidden;resize:none}.modal-close-btn{align-items:center;background:#0000;border:none;border-radius:6px;color:#5e6c84;color:var(--text-secondary);cursor:pointer;display:inline-flex;height:32px;justify-content:center;transition:all .2s ease;transition:all var(--transition);width:32px}.modal-close-btn:hover{background:#f5f6f8;background:var(--bg);color:#172b4d;color:var(--text)}.modal-close-btn:focus-visible{outline:2px solid #1e3a5f;outline:2px solid var(--primary);outline-offset:2px}.icon-btn{align-items:center;background:#0000;border:1px solid #0000;border-radius:6px;color:#5e6c84;color:var(--text-secondary);cursor:pointer;display:inline-flex;font-family:Plus Jakarta Sans,-apple-system,BlinkMacSystemFont,sans-serif;font-family:var(--font);height:30px;justify-content:center;padding:0;transition:all .2s ease;transition:all var(--transition);width:30px}.icon-btn:hover{background:#f5f6f8;background:var(--bg);color:#172b4d;color:var(--text)}.icon-btn:focus-visible{outline:2px solid #1e3a5f;outline:2px solid var(--primary);outline-offset:2px}.icon-btn-danger:hover{background:#ffebe6;background:var(--danger-bg);border-color:#ffebe6;border-color:var(--danger-bg);color:#de350b;color:var(--danger)}.icon-btn-primary:hover{background:#e6f0ff;background:var(--info-bg);border-color:#e6f0ff;border-color:var(--info-bg);color:#0065ff;color:var(--info)}.icon-btn:disabled{cursor:not-allowed;opacity:.5}.btn-success{background:#22a06b;background:var(--success);box-shadow:0 2px 8px #22a06b26;color:#fff}.btn-success:hover{background:#1b8457;box-shadow:0 4px 12px #22a06b40;transform:translateY(-1px)}.btn-warning{background:#e8a838;background:var(--warning);box-shadow:0 2px 8px #e8a83826;color:#fff}.btn-warning:hover{background:#c99221;box-shadow:0 4px 12px #e8a83840;transform:translateY(-1px)}.btn-outline-danger{background:#0000;border:1.5px solid #de350b;border:1.5px solid var(--danger);color:#de350b;color:var(--danger)}.btn-outline-danger:hover{background:#ffebe6;background:var(--danger-bg)}.btn:focus-visible,.form-input:focus-visible,.form-select:focus-visible,.form-textarea:focus-visible{outline:2px solid #1e3a5f;outline:2px solid var(--primary);outline-offset:2px}.form-input.has-error,.form-select.has-error,.form-textarea.has-error{border-color:#de350b!important;border-color:var(--danger)!important;box-shadow:0 0 0 3px #de350b14}.alert{align-items:flex-start;border-radius:6px;display:flex;font-size:13px;font-weight:500;gap:8px;line-height:1.5;margin-bottom:16px;padding:10px 14px}.alert-danger{background:#ffebe6;background:var(--danger-bg);color:#de350b;color:var(--danger)}.alert-success{background:#e3fcef;background:var(--success-bg);color:#22a06b;color:var(--success)}.alert-info{background:#e6f0ff;background:var(--info-bg);color:#0065ff;color:var(--info)}.alert-warning{background:#fff8e6;background:var(--warning-bg);color:#b8860b}.rating-scale-strip{background:#f8f9fa;border-radius:6px;color:#5e6c84;color:var(--text-secondary);display:flex;flex-wrap:wrap;font-size:12px;gap:16px;margin-bottom:16px;padding:8px 14px}.empty-state h4{color:#172b4d;color:var(--text);font-size:15px;font-weight:700;margin-bottom:4px}.empty-state .empty-action{margin-top:16px}.sr-only{clip:rect(0,0,0,0);border:0;height:1px;margin:-1px;overflow:hidden;padding:0;position:absolute;white-space:nowrap;width:1px}
/*# sourceMappingURL=main.fd3fc3bd.css.map*/