@import "https://fonts.googleapis.com/css2?family=DM+Serif+Display&family=DM+Sans:wght@300;400;500;600&display=swap";:root{--sidebar-bg:#1a2233;--sidebar-hover:#243049;--sidebar-active:#2e3d5c;--accent:#c8873a;--accent-light:#e8a55a;--canvas:#f7f4ef;--surface:#fff;--border:#e2ddd6;--text-primary:#1a2233;--text-secondary:#5a6478;--text-muted:#9aa0ad;--success:#2e7d52;--warning:#b5600d;--danger:#c0392b;--info:#1a5f8a;--font-display:"DM Serif Display", Georgia, serif;--font-body:"DM Sans", system-ui, sans-serif;--radius:6px;--shadow-sm:0 1px 3px #00000014;--shadow-md:0 4px 12px #0000001a;--shadow-lg:0 8px 24px #0000001f;--transition:.18s ease}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html,body,#root{height:100%;font-family:var(--font-body);background:var(--canvas);color:var(--text-primary);-webkit-font-smoothing:antialiased;font-size:14px;line-height:1.6}.app-shell{height:100vh;display:flex;overflow:hidden}.main-wrapper{flex-direction:column;flex:1;min-width:0;display:flex;overflow:hidden}.sidebar{background:var(--sidebar-bg);flex-direction:column;width:240px;min-width:240px;display:flex;overflow:hidden auto}.sidebar-logo{border-bottom:1px solid #ffffff14;padding:16px 20px 20px}.sidebar-logo h1{font-family:var(--font-display);color:#fff;letter-spacing:.01em;font-size:18px;line-height:1.2}.sidebar-logo span{color:var(--accent);text-transform:uppercase;letter-spacing:.12em;margin-bottom:4px;font-size:11px;font-weight:500;display:block}.sidebar-nav{flex:1;padding:16px 0}.nav-section-label{text-transform:uppercase;letter-spacing:.12em;color:#ffffff4d;padding:12px 20px 6px;font-size:10px;font-weight:600}.nav-item{color:#ffffffa6;transition:all var(--transition);cursor:pointer;border-left:3px solid #0000;align-items:center;gap:10px;padding:10px 20px;font-size:13.5px;font-weight:400;text-decoration:none;display:flex}.nav-item:hover{background:var(--sidebar-hover);color:#fff}.nav-item.active{background:var(--sidebar-active);color:#fff;border-left-color:var(--accent)}.sidebar-footer{border-top:1px solid #ffffff14;padding:16px 20px}.user-badge{align-items:center;gap:10px;display:flex}.user-avatar{background:var(--accent);color:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:32px;height:32px;font-size:13px;font-weight:600;display:flex}.user-info{flex:1;min-width:0}.user-name{color:#fff;white-space:nowrap;text-overflow:ellipsis;font-size:13px;font-weight:500;overflow:hidden}.user-role{color:#fff6;text-transform:capitalize;font-size:11px}.logout-btn{color:#fff6;cursor:pointer;transition:color var(--transition);background:0 0;border:none;border-radius:4px;padding:4px}.logout-btn:hover{color:var(--accent)}.main-content{flex-direction:column;flex:1;display:flex;overflow-y:auto}.page-header{background:var(--surface);border-bottom:1px solid var(--border);flex-shrink:0;justify-content:space-between;align-items:center;padding:20px 32px;display:flex}.page-title{font-family:var(--font-display);color:var(--text-primary);font-size:24px;font-weight:400}.page-subtitle{color:var(--text-secondary);margin-top:2px;font-size:13px}.page-body{flex:1;padding:28px 32px}.app-footer{background:var(--surface);border-top:1px solid var(--border);height:32px;color:var(--text-muted);letter-spacing:.03em;-webkit-user-select:none;user-select:none;flex-shrink:0;align-items:center;gap:8px;padding:0 32px;font-size:11px;display:flex}.app-footer-divider{color:var(--border);font-size:13px}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-sm)}.card-header{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:16px 20px;display:flex}.card-title{color:var(--text-primary);text-transform:uppercase;letter-spacing:.06em;font-size:13px;font-weight:600}.card-body{padding:20px}.stats-grid{grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px;margin-bottom:28px;display:grid}.stat-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:20px;position:relative;overflow:hidden}.stat-card:before{content:"";background:var(--accent);height:3px;position:absolute;top:0;left:0;right:0}.stat-label{text-transform:uppercase;letter-spacing:.1em;color:var(--text-muted);margin-bottom:8px;font-size:11px;font-weight:600}.stat-value{font-family:var(--font-display);color:var(--text-primary);margin-bottom:4px;font-size:32px;line-height:1}.stat-sub{color:var(--text-secondary);font-size:12px}.btn{border-radius:var(--radius);font-family:var(--font-body);cursor:pointer;transition:all var(--transition);white-space:nowrap;border:none;align-items:center;gap:6px;padding:8px 16px;font-size:13px;font-weight:500;text-decoration:none;display:inline-flex}.btn:disabled{opacity:.55;cursor:not-allowed}.btn-primary{background:var(--accent);color:#fff}.btn-primary:hover:not(:disabled){background:var(--accent-light)}.btn-secondary{background:var(--canvas);color:var(--text-primary);border:1px solid var(--border)}.btn-secondary:hover:not(:disabled){background:var(--border)}.btn-danger{background:var(--danger);color:#fff}.btn-danger:hover:not(:disabled){opacity:.88}.btn-sm{padding:5px 10px;font-size:12px}.btn-ghost{color:var(--text-secondary);background:0 0;padding:5px 8px}.btn-ghost:hover:not(:disabled){background:var(--canvas);color:var(--text-primary)}.badge{text-transform:uppercase;letter-spacing:.04em;white-space:nowrap;border-radius:20px;align-items:center;padding:3px 8px;font-size:11px;font-weight:600;display:inline-flex}.badge-active{color:#2e7d52;background:#e8f5e9}.badge-inactive{color:#666;background:#f0f0f0}.badge-approved{color:#2e7d52;background:#e8f5e9}.badge-pending{color:#5c4db1;background:#f3f0ff}.badge-denied{color:#c0392b;background:#fde8e8}.badge-hold{color:#b5600d;background:#fff3e0}.badge-completed{color:#1a5f8a;background:#e8f0fe}.badge-cancelled{color:#666;background:#f0f0f0}.badge-submitted{color:#1a5f8a;background:#e8f0fe}.badge-review{color:#b5600d;background:#fff3e0}.badge-overdue{color:#c0392b;background:#fde8e8}.badge-fulfilled{color:#2e7d52;background:#e8f5e9}.badge-waived{color:#666;background:#f0f0f0}.data-table{border-collapse:collapse;width:100%;font-size:13px}.data-table th{text-align:left;text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted);border-bottom:2px solid var(--border);background:var(--canvas);white-space:nowrap;padding:10px 16px;font-size:11px;font-weight:600}.data-table td{border-bottom:1px solid var(--border);color:var(--text-primary);vertical-align:middle;padding:12px 16px}.data-table tr:last-child td{border-bottom:none}.data-table tr:hover td{background:var(--canvas)}.table-link{color:var(--accent);font-weight:500;text-decoration:none}.table-link:hover{text-decoration:underline}.form-grid{grid-template-columns:1fr 1fr;gap:20px;display:grid}.form-grid-full{grid-column:1/-1}.form-group{flex-direction:column;gap:6px;display:flex}.form-label{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.06em;font-size:12px;font-weight:600}.form-label.required:after{content:" *";color:var(--danger)}.form-input,.form-select,.form-textarea{border:1px solid var(--border);border-radius:var(--radius);font-family:var(--font-body);color:var(--text-primary);background:var(--surface);transition:border-color var(--transition);width:100%;padding:9px 12px;font-size:13.5px}.form-input:focus,.form-select:focus,.form-textarea:focus{border-color:var(--accent);outline:none;box-shadow:0 0 0 3px #c8873a1f}.form-textarea{resize:vertical;min-height:90px}.form-error{color:var(--danger);font-size:12px}.alert{border-radius:var(--radius);align-items:flex-start;gap:10px;margin-bottom:16px;padding:12px 16px;font-size:13px;display:flex}.alert-danger{color:#c0392b;background:#fde8e8;border:1px solid #f5c0bb}.alert-success{color:#2e7d52;background:#e8f5e9;border:1px solid #b2dfbe}.alert-warning{color:#b5600d;background:#fff3e0;border:1px solid #ffe0b0}.tabs{border-bottom:2px solid var(--border);margin-bottom:24px;display:flex}.tab-btn{font-family:var(--font-body);color:var(--text-secondary);cursor:pointer;transition:all var(--transition);background:0 0;border:none;border-bottom:2px solid #0000;margin-bottom:-2px;padding:10px 20px;font-size:13.5px;font-weight:500}.tab-btn:hover{color:var(--text-primary)}.tab-btn.active{color:var(--accent);border-bottom-color:var(--accent)}.modal-overlay{z-index:1000;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);background:#1a22338c;justify-content:center;align-items:center;padding:24px;display:flex;position:fixed;inset:0}.modal-box{background:var(--surface);width:100%;max-width:520px;box-shadow:var(--shadow-lg);border-radius:10px;max-height:90vh;overflow-y:auto}.modal-header{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:20px 24px 16px;display:flex}.modal-title{font-family:var(--font-display);color:var(--text-primary);font-size:20px;font-weight:400}.modal-close{color:var(--text-muted);cursor:pointer;transition:all var(--transition);background:0 0;border:none;border-radius:4px;padding:4px 8px;font-size:16px}.modal-close:hover{color:var(--text-primary);background:var(--canvas)}.modal-body{padding:24px}.empty-state{text-align:center;color:var(--text-muted);padding:48px 24px}.empty-state-icon{margin-bottom:12px;font-size:36px}.empty-state h3{color:var(--text-secondary);margin-bottom:6px;font-size:15px}.empty-state p{font-size:13px}.spinner{border:3px solid var(--border);border-top-color:var(--accent);border-radius:50%;width:32px;height:32px;margin:40px auto;animation:.7s linear infinite spin;display:block}@keyframes spin{to{transform:rotate(360deg)}}.loading-center{justify-content:center;align-items:center;min-height:200px;display:flex}.search-input{border:1px solid var(--border);border-radius:var(--radius);font-family:var(--font-body);background:var(--surface) url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 24 24' fill='none' stroke='%239aa0ad' stroke-width='2'%3E%3Ccircle cx='11' cy='11' r='8'/%3E%3Cpath d='m21 21-4.35-4.35'/%3E%3C/svg%3E") no-repeat 10px center;width:240px;padding:8px 12px 8px 34px;font-size:13px}.search-input:focus{border-color:var(--accent);outline:none}.login-page{background:var(--sidebar-bg);background-image:radial-gradient(at 60% 40%,#243049 0%,#1a2233 70%);justify-content:center;align-items:center;min-height:100vh;display:flex}.login-card{background:var(--surface);width:380px;box-shadow:var(--shadow-lg);border-radius:10px;padding:48px 44px}.login-logo{text-align:center;margin-bottom:32px}.login-logo h1{font-family:var(--font-display);color:var(--text-primary);font-size:26px}.login-logo span{color:var(--accent);text-transform:uppercase;letter-spacing:.12em;font-size:12px;font-weight:600}.charts-row{grid-template-columns:1fr 1fr;gap:16px;margin-bottom:16px;display:grid}@media (width<=768px){.sidebar{display:none}.form-grid,.charts-row{grid-template-columns:1fr}}
