:root{--primary: #4a6fa5;--primary-dark: #2d4a7c;--primary-light: #6b8cce;--accent: #ffd700;--success: #059669;--success-light: #ecfdf5;--danger: #dc2626;--danger-light: #fef2f2;--warning: #d97706;--warning-light: #fffbeb;--background: #f8fafc;--surface: #ffffff;--surface-alt: #f1f5f9;--border: #e2e8f0;--border-focus: #4a6fa5;--text-primary: #1e293b;--text-secondary: #64748b;--text-muted: #94a3b8;--text-inverse: #ffffff;--shadow-sm: 0 1px 2px 0 rgb(0 0 0 / .05);--shadow-md: 0 4px 6px -1px rgb(0 0 0 / .1), 0 2px 4px -2px rgb(0 0 0 / .1);--shadow-lg: 0 10px 15px -3px rgb(0 0 0 / .1), 0 4px 6px -4px rgb(0 0 0 / .1);--shadow-blue: 0 4px 14px 0 rgba(74, 111, 165, .39);--radius-sm: .375rem;--radius-md: .5rem;--radius-lg: .75rem;--radius-xl: 1rem;--radius-2xl: 1.5rem;--radius-full: 9999px;--transition-fast: .15s cubic-bezier(.4, 0, .2, 1);--transition-normal: .3s cubic-bezier(.4, 0, .2, 1);--space-xs: .25rem;--space-sm: .5rem;--space-md: 1rem;--space-lg: 1.5rem;--space-xl: 2rem;--space-2xl: 3rem}*{margin:0;padding:0;box-sizing:border-box}html{font-size:16px;scroll-behavior:smooth}body{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,sans-serif;background:var(--background);color:var(--text-primary);line-height:1.6;min-height:100vh}h1,h2,h3,h4,h5,h6{font-weight:600;line-height:1.3;color:var(--text-primary)}h1{font-size:2rem}h2{font-size:1.5rem}h3{font-size:1.25rem}h4{font-size:1.125rem}p{color:var(--text-secondary)}a{color:var(--primary);text-decoration:none;transition:color var(--transition-fast)}a:hover{color:var(--primary-dark)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-sm);padding:var(--space-sm) var(--space-md);font-size:.875rem;font-weight:500;border:none;border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast);white-space:nowrap}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:var(--primary);color:var(--text-inverse)}.btn-primary:hover:not(:disabled){background:var(--primary-dark);transform:translateY(-1px);box-shadow:var(--shadow-md)}.btn-success{background:var(--success);color:var(--text-inverse)}.btn-success:hover:not(:disabled){background:#059669;transform:translateY(-1px);box-shadow:var(--shadow-md)}.btn-danger{background:var(--danger);color:var(--text-inverse)}.btn-danger:hover:not(:disabled){background:#dc2626;transform:translateY(-1px);box-shadow:var(--shadow-md)}.btn-outline{background:transparent;color:var(--text-secondary);border:1px solid var(--border)}.btn-outline:hover:not(:disabled){background:var(--surface-hover);border-color:var(--border-dark)}.btn-sm{padding:var(--space-xs) var(--space-sm);font-size:.75rem;height:32px}.btn-cancel{background:var(--surface-alt);color:var(--text-secondary)}.btn-cancel:hover:not(:disabled){background:var(--border);color:var(--text-primary)}.w-full{width:100%}.mt-xl{margin-top:var(--space-xl)}.p-xl{padding:var(--space-xl)}.gap-xs{gap:var(--space-xs)}.form-group{margin-bottom:var(--space-md)}.form-label{display:block;font-size:.875rem;font-weight:500;color:var(--text-primary);margin-bottom:var(--space-xs)}.form-input,.form-select,.form-textarea{width:100%;padding:var(--space-sm) var(--space-md);font-size:.9375rem;font-family:inherit;color:var(--text-primary);background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-md);transition:all var(--transition-fast)}.form-input:focus,.form-select:focus,.form-textarea:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px #2563eb1a}.form-input::placeholder,.form-textarea::placeholder{color:var(--text-muted)}.form-textarea{min-height:100px;resize:vertical}.card{background:var(--surface);border-radius:var(--radius-lg);box-shadow:var(--shadow-md);padding:var(--space-lg);transition:all var(--transition-normal)}.card:hover{box-shadow:var(--shadow-lg)}.badge{display:inline-flex;align-items:center;gap:var(--space-xs);padding:var(--space-xs) var(--space-sm);font-size:.75rem;font-weight:600;border-radius:var(--radius-full);text-transform:uppercase;letter-spacing:.025em}.badge-pending{background:var(--warning-light);color:#92400e}.badge-approved{background:var(--success-light);color:#065f46}.badge-rejected{background:var(--danger-light);color:#991b1b}.container{width:100%;max-width:1200px;margin:0 auto;padding:0 var(--space-md)}.grid{display:grid;gap:var(--space-lg)}.grid-2{grid-template-columns:repeat(2,1fr)}@media(max-width:768px){.grid-2{grid-template-columns:1fr}}.modal-overlay{position:fixed;inset:0;background:#00000080;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn var(--transition-fast) ease}.modal-content{background:var(--surface);border-radius:var(--radius-xl);padding:var(--space-xl);max-width:420px;width:90%;box-shadow:var(--shadow-xl);animation:slideUp var(--transition-normal) ease}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.text-center{text-align:center}.text-right{text-align:right}.text-success{color:var(--success)}.text-danger{color:var(--danger)}.text-warning{color:var(--warning)}.text-muted{color:var(--text-muted)}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-center{justify-content:center}.justify-between{justify-content:space-between}.gap-sm{gap:var(--space-sm)}.gap-md{gap:var(--space-md)}.gap-lg{gap:var(--space-lg)}.mb-sm{margin-bottom:var(--space-sm)}.mb-md{margin-bottom:var(--space-md)}.mb-lg{margin-bottom:var(--space-lg)}.mt-md{margin-top:var(--space-md)}.mt-lg{margin-top:var(--space-lg)}.loading-screen{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100vh;width:100vw;background:var(--background);color:var(--text-secondary)}.loader{width:48px;height:48px;border:5px solid var(--border);border-bottom-color:var(--primary);border-radius:50%;margin-bottom:var(--space-md);animation:rotation 1s linear infinite}@keyframes rotation{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@media(max-width:640px){html{font-size:14px}.container{padding:0 var(--space-sm)}}.alert{display:flex;align-items:center;gap:var(--space-sm);padding:var(--space-sm) var(--space-md);border-radius:var(--radius-md);font-size:.875rem;margin-bottom:var(--space-md)}.alert-danger{background:var(--danger-light);color:var(--danger);border:1px solid rgba(220,38,38,.2)}.alert svg{flex-shrink:0;font-size:1.1rem}.header{background:linear-gradient(135deg,#1e3a8a,#3b82f6);color:var(--text-inverse);padding:1.5rem 0;box-shadow:0 10px 30px -10px #2563eb66;position:relative;overflow:hidden}.header-container{position:relative;z-index:1;display:flex;flex-direction:column;gap:1.5rem}.header-top{display:flex;align-items:center;justify-content:space-between;gap:1rem}.header-brand{flex-shrink:0}.header-logo-link{display:flex;align-items:center;gap:1.25rem;text-decoration:none}.pln-logo-img{height:48px;width:auto}.brand-text h1{font-size:2.25rem;font-weight:800;margin:0;line-height:1;color:#fff;letter-spacing:-.01em}.brand-subtitle{font-size:1rem;margin:.25rem 0 0;color:#fbbf24;font-weight:600}.user-profile{display:flex;align-items:center;gap:0;background:#ffffff1a;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-radius:14px;border:1px solid rgba(255,255,255,.15);padding:.375rem;box-shadow:0 4px 15px #0000001a}.user-info{display:flex;flex-direction:column;align-items:flex-start;padding:0 1rem;border-right:1px solid rgba(255,255,255,.15)}.user-name{font-weight:600;font-size:.875rem;color:#fff;max-width:150px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.user-role{font-size:.625rem;padding:1px 6px;border-radius:4px;text-transform:uppercase;font-weight:800;letter-spacing:.02em;margin-bottom:2px}.badge-user{background:#fff3;color:#fff}.badge-admin{background:#fbbf24;color:#78350f}.badge-super_admin{background:#ef4444;color:#fff}.user-menu{display:flex;align-items:center;gap:.75rem;padding:0 .5rem 0 .75rem}.nav-links{display:flex;gap:.375rem}.nav-item{display:flex;align-items:center;gap:.5rem;padding:.5rem .875rem;font-size:.8125rem;font-weight:600;color:#fffc;text-decoration:none;border-radius:10px;transition:all .2s}.nav-item:hover{color:#fff;background:#ffffff1a}.nav-item.active{background:#fff;color:#1e40af;box-shadow:0 4px 12px #0000001a}.nav-item svg{font-size:1rem}.action-buttons{display:flex;align-items:center;gap:.375rem;margin-left:.25rem}.btn-icon-nav{background:#ffffff1a;border:1px solid rgba(255,255,255,.1);color:#fff;padding:.5rem;border-radius:10px;cursor:pointer;display:flex;transition:all .2s}.btn-icon-nav:hover{background:#fff3;border-color:#ffffff4d}.btn-logout-nav{background:#ef4444;color:#fff;border:none;padding:.5rem 1rem;font-size:.8125rem;font-weight:700;border-radius:10px;cursor:pointer;display:flex;align-items:center;gap:.5rem;transition:all .2s;box-shadow:0 4px 10px #ef444433}.btn-logout-nav:hover{background:#dc2626;transform:translateY(-1px);box-shadow:0 6px 15px #ef44444d}.header-main{text-align:center;padding-top:2rem;border-top:1px solid rgba(255,255,255,.1)}.header-main h2{font-size:2.25rem;font-weight:800;color:#fff;margin-bottom:.5rem;letter-spacing:-.02em}.header-description{font-size:1.0625rem;color:#e0f2fe;max-width:800px;margin:0 auto;opacity:.9}@media(max-width:1024px){.header-top{flex-direction:column;align-items:center;text-align:center}.user-profile{margin-top:1rem}}@media(max-width:768px){.nav-item span,.btn-logout-nav span{display:none}.user-profile{flex-direction:column;padding:1rem}.user-info{border-right:none;border-bottom:1px solid rgba(255,255,255,.1);padding:0 0 .5rem;align-items:center;width:100%}.user-menu{padding:.75rem 0 0}}.request-form-card{background:var(--surface);border-radius:var(--radius-xl);box-shadow:var(--shadow-lg);border:1px solid rgba(226,232,240,.8);position:relative;overflow:hidden}.request-form-card:before{content:"";position:absolute;top:0;left:0;width:100%;height:4px;background:linear-gradient(90deg,var(--primary) 0%,var(--primary-light) 100%)}.form-header{padding:var(--space-xl);border-bottom:1px solid var(--border);background:linear-gradient(to bottom,var(--surface) 0%,var(--surface-alt) 100%)}.form-header h2{font-size:1.5rem;color:var(--primary-dark);margin-bottom:var(--space-xs);display:flex;align-items:center;gap:var(--space-sm)}.form-header p{color:var(--text-secondary)}.form-body{padding:var(--space-xl)}.form-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--space-lg);margin-bottom:var(--space-xl)}.form-section{background:var(--surface-alt);border-radius:var(--radius-lg);padding:var(--space-lg);margin-bottom:var(--space-xl);border:1px solid var(--border)}.section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-md)}.section-header .form-label{font-size:1rem;color:var(--primary-dark);font-weight:600}.items-list{display:flex;flex-direction:column;gap:var(--space-md)}.item-row{display:flex;align-items:flex-start;gap:var(--space-sm);background:var(--surface);padding:var(--space-md);border-radius:var(--radius-md);border:1px solid var(--border);transition:all var(--transition-fast)}.item-row:hover{border-color:var(--primary-light);box-shadow:var(--shadow-sm)}.item-category{flex:2;min-width:180px}.item-name{flex:3;min-width:200px}.item-qty{width:80px;flex-shrink:0}.item-unit{width:100px;flex-shrink:0}.btn-remove{margin-top:1px;color:var(--text-muted);transition:color var(--transition-fast)}.btn-remove:hover{color:var(--danger);background:var(--danger-light)}.submit-btn{width:100%;padding:var(--space-md);font-size:1rem;font-weight:600;letter-spacing:.5px;margin-top:var(--space-md);box-shadow:var(--shadow-blue)}.form-input,.form-select,.form-textarea{border:1px solid var(--border);background-color:var(--surface);transition:all var(--transition-fast)}.form-input:focus,.form-select:focus,.form-textarea:focus{border-color:var(--primary);box-shadow:0 0 0 3px #4a6fa526}.form-select:disabled,.form-input.read-only{background-color:#f1f5f9;color:#64748b;cursor:default;border-color:#e2e8f0;pointer-events:none}@media(max-width:1024px){.item-row{flex-wrap:wrap}.item-category,.item-name{flex:1 1 45%}}@media(max-width:768px){.form-grid{grid-template-columns:1fr;gap:var(--space-md)}.form-header,.form-body{padding:var(--space-lg)}.item-category,.item-name{flex:1 1 100%;min-width:100%}.item-qty,.item-unit{flex:1}}.request-card{background:var(--surface);border-radius:var(--radius-lg);box-shadow:var(--shadow-md);overflow:hidden;transition:all var(--transition-normal);border:1px solid var(--border);display:flex;flex-direction:column}.request-card:hover{box-shadow:var(--shadow-lg);transform:translateY(-2px);border-color:var(--primary-light)}.request-card.pending{border-top:4px solid var(--warning)}.request-card.approved{border-top:4px solid var(--success)}.request-card.rejected{border-top:4px solid var(--danger)}.card-header{padding:var(--space-md) var(--space-lg);display:flex;align-items:center;justify-content:space-between;border-bottom:1px dashed var(--border);background:var(--surface-alt)}.card-id{display:flex;align-items:center;gap:var(--space-sm);color:var(--text-secondary);font-size:.875rem;font-weight:500}.card-body{padding:var(--space-lg);flex:1}.applicant-name{font-size:1.25rem;font-weight:700;color:var(--text-primary);margin-bottom:var(--space-xs)}.section-name{color:var(--primary);font-weight:500;font-size:.9375rem;margin-bottom:var(--space-md)}.date-info{display:flex;flex-wrap:wrap;gap:var(--space-md) var(--space-lg);margin-bottom:var(--space-lg);font-size:.875rem;color:var(--text-secondary);background:var(--surface-alt);padding:var(--space-sm) var(--space-md);border-radius:var(--radius-md)}.date-info span{display:flex;align-items:center;gap:var(--space-xs)}.items-preview{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-md);padding:var(--space-md)}.items-preview strong{display:block;font-size:.875rem;color:var(--text-muted);margin-bottom:var(--space-sm);text-transform:uppercase;letter-spacing:.5px}.items-preview ul{list-style:none;margin:0;padding:0}.items-preview li{font-size:.9375rem;padding:var(--space-xs) 0;border-bottom:1px solid var(--border);display:flex;align-items:center;gap:var(--space-sm)}.items-preview li:last-child{border-bottom:none}.items-preview .item-cat{font-size:.75rem;padding:2px 6px;background:#4a6fa51a;color:var(--primary);border-radius:4px;font-weight:600}.more-items{font-size:.875rem;color:var(--text-muted);font-style:italic;margin-top:var(--space-xs);text-align:center}.notes-preview{margin-top:var(--space-md);font-size:.875rem;color:var(--text-secondary);padding:var(--space-sm);background:var(--warning-light);border-radius:var(--radius-sm);border-left:3px solid var(--warning)}.card-footer{padding:var(--space-md) var(--space-lg);border-top:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;gap:var(--space-md);background:var(--surface-alt)}.export-buttons{display:flex;gap:var(--space-sm)}.export-buttons .btn{padding:var(--space-xs) var(--space-sm);font-size:.8125rem}@media(max-width:640px){.card-footer{flex-direction:column;align-items:stretch}.export-buttons{justify-content:center}}.dashboard-stats-wrapper{margin-bottom:2rem;animation:fadeIn .5s ease-out}.dashboard-stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1.25rem;margin-bottom:2rem}.stat-card-new{background:#fff;padding:1.5rem;border-radius:16px;display:flex;align-items:center;gap:1.25rem;box-shadow:0 4px 6px -1px #0000000d,0 2px 4px -1px #00000008;transition:transform .2s,box-shadow .2s;border:1px solid #f1f5f9}.stat-card-new:hover{transform:translateY(-4px);box-shadow:0 10px 15px -3px #0000001a}.stat-icon-wrapper{width:48px;height:48px;border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:1.5rem}.stat-card-new.pending .stat-icon-wrapper{background:#fef3c7;color:#d97706}.stat-card-new.approved .stat-icon-wrapper{background:#d1fae5;color:#059669}.stat-card-new.rejected .stat-icon-wrapper{background:#fee2e2;color:#dc2626}.stat-card-new.all .stat-icon-wrapper{background:#e0f2fe;color:#0284c7}.stat-details{display:flex;flex-direction:column}.stat-label-new{font-size:.875rem;color:#64748b;font-weight:500}.stat-value-new{font-size:1.5rem;font-weight:700;color:#1e293b}.charts-container{display:grid;grid-template-columns:repeat(auto-fit,minmax(400px,1fr));gap:2rem}.chart-card-new{background:#fff;padding:1.5rem;border-radius:16px;box-shadow:0 4px 6px -1px #0000000d;border:1px solid #f1f5f9}.chart-header-new{display:flex;align-items:center;gap:.75rem;margin-bottom:1.5rem;color:#334155}.chart-header-new h3{font-size:1rem;font-weight:600;margin:0}.chart-header-new svg{color:var(--primary)}.stats-loading{display:flex;justify-content:center;align-items:center;min-height:200px}@media(max-width:640px){.charts-container{grid-template-columns:1fr}.chart-card-new{padding:1rem}}.search-filter-bar{background:#fff;border-radius:12px;padding:12px;margin-bottom:2rem;box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;transition:all .3s ease;border:1px solid #e5e7eb}.search-filter-bar.expanded{padding-bottom:1rem}.filter-main{display:flex;align-items:center;gap:1rem}.search-input-wrapper{position:relative;flex:1;display:flex;align-items:center}.search-icon{position:absolute;left:1rem;color:#6b7280;pointer-events:none}.search-input{width:100%;padding:10px 2.5rem;border:1px solid #e5e7eb;border-radius:8px;font-size:.95rem;transition:all .2s ease;background:#f9fafb}.search-input:focus{outline:none;border-color:var(--primary);background:#fff;box-shadow:0 0 0 3px #00a2d11a}.clear-btn{position:absolute;right:.75rem;background:none;border:none;color:#9ca3af;cursor:pointer;padding:4px;display:flex;align-items:center;border-radius:50%}.clear-btn:hover{background:#f3f4f6;color:#6b7280}.filter-toggle{display:flex;align-items:center;gap:.5rem;padding:10px 1.25rem;white-space:nowrap;position:relative}.filter-toggle.has-active{border-color:var(--primary);color:var(--primary);background:#00a2d10d}.filter-dot{position:absolute;top:-2px;right:-2px;width:8px;height:8px;background:var(--primary);border-radius:50%;border:2px solid white}.clear-all-btn{color:#ef4444;font-weight:500}.clear-all-btn:hover{color:#dc2626;text-decoration:underline}.filter-dropdown{margin-top:1rem;padding-top:1rem;border-top:1px solid #f3f4f6}.filter-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1.5rem}.filter-group{display:flex;flex-direction:column;gap:.5rem}.filter-group label{font-size:.85rem;font-weight:600;color:#374151}.filter-group select,.filter-group input{padding:8px 12px;border:1px solid #e5e7eb;border-radius:6px;font-size:.9rem;outline:none;width:100%}.filter-group select:focus,.filter-group input:focus{border-color:var(--primary)}.date-input-wrapper{position:relative;display:flex;align-items:center}.date-icon{position:absolute;right:.75rem;color:#6b7280;pointer-events:none}@media(max-width:640px){.filter-main{flex-wrap:wrap}.search-input-wrapper{min-width:100%}}.request-list-section{margin-top:var(--space-xl)}.list-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-lg);flex-wrap:wrap;gap:var(--space-md)}.list-title{display:flex;align-items:center;gap:var(--space-sm)}.list-title svg{font-size:1.5rem;color:var(--primary)}.list-title h2{margin:0}.count-badge{background:var(--primary);color:#fff;font-size:.75rem;font-weight:600;padding:var(--space-xs) var(--space-sm);border-radius:var(--radius-full);min-width:24px;text-align:center}.filter-tabs{display:flex;gap:var(--space-sm);margin-bottom:var(--space-lg);padding:var(--space-xs);background:var(--surface);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);overflow-x:auto}.filter-tab{display:flex;align-items:center;gap:var(--space-xs);padding:var(--space-sm) var(--space-md);border:none;background:transparent;border-radius:var(--radius-md);font-size:.875rem;font-weight:500;color:var(--text-secondary);cursor:pointer;transition:all var(--transition-fast);white-space:nowrap}.filter-tab:hover{background:var(--background)}.filter-tab.active{background:var(--primary);color:#fff}.filter-tab.pending.active{background:var(--warning)}.filter-tab.approved.active{background:var(--success)}.filter-tab.rejected.active{background:var(--danger)}.tab-count{background:#0000001a;padding:2px 8px;border-radius:var(--radius-full);font-size:.75rem}.filter-tab.active .tab-count{background:#fff3}.requests-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--space-lg);margin-bottom:var(--space-xl)}.empty-state{text-align:center;padding:var(--space-xl);background:var(--surface);border-radius:var(--radius-lg);color:var(--text-secondary)}.empty-state svg{font-size:3rem;margin-bottom:var(--space-md);opacity:.5}.empty-state h3{margin:var(--space-md) 0 var(--space-sm);color:var(--text)}.pagination{display:flex;align-items:center;justify-content:center;gap:var(--space-lg);margin-top:var(--space-xl);padding:var(--space-lg);background:var(--surface);border-radius:var(--radius-lg)}.pagination-btn{display:flex;align-items:center;gap:var(--space-xs);padding:var(--space-sm) var(--space-md);background:var(--primary);color:#fff;border:none;border-radius:var(--radius-md);cursor:pointer;font-weight:500;transition:all .3s ease}.pagination-btn:hover:not(:disabled){background:var(--primary-dark);transform:translateY(-2px)}.pagination-btn:disabled{background:var(--surface-border);color:var(--text-secondary);cursor:not-allowed;opacity:.5}.pagination-info{font-weight:500;color:var(--text);min-width:150px;text-align:center}.empty-state{text-align:center;padding:var(--space-2xl);background:var(--surface);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm)}.empty-state svg{font-size:3rem;color:var(--text-muted);margin-bottom:var(--space-md)}.empty-state h3{color:var(--text-secondary);margin-bottom:var(--space-xs)}.empty-state p{color:var(--text-muted);font-size:.9375rem}.loading-state{text-align:center;padding:var(--space-2xl);background:var(--surface);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm)}.loading-state .spinner{width:48px;height:48px;border:4px solid var(--border);border-top-color:var(--primary);border-radius:50%;margin:0 auto var(--space-md);animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.loading-state p{color:var(--text-secondary);font-size:.9375rem}.error-state{text-align:center;padding:var(--space-2xl);background:var(--surface);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);border:2px solid var(--danger-light)}.error-state svg{font-size:3rem;color:var(--danger);margin-bottom:var(--space-md)}.error-state h3{color:var(--danger);margin-bottom:var(--space-sm)}.error-state p{color:var(--text-secondary);font-size:.9375rem;margin-bottom:var(--space-lg)}@media(max-width:1024px){.requests-grid{grid-template-columns:repeat(2,1fr)}}@media(max-width:640px){.requests-grid{grid-template-columns:1fr}.filter-tabs{padding:var(--space-xs)}.filter-tab{padding:var(--space-xs) var(--space-sm);font-size:.8125rem}.pagination{flex-direction:column;align-items:center;gap:var(--space-sm)}.pagination-btn{width:100%;font-size:.875rem}}.modal-close{position:absolute;top:var(--space-md);right:var(--space-md);background:none;border:none;font-size:1.25rem;color:var(--text-muted);cursor:pointer;padding:var(--space-xs);border-radius:var(--radius-full);transition:all var(--transition-fast)}.modal-close:hover{color:var(--text-primary);background:var(--background)}.modal-header{text-align:center;margin-bottom:var(--space-lg)}.modal-icon{width:56px;height:56px;background:linear-gradient(135deg,var(--primary) 0%,var(--primary-dark) 100%);border-radius:var(--radius-full);display:flex;align-items:center;justify-content:center;margin:0 auto var(--space-md);color:#fff;font-size:1.5rem}.modal-header h3{margin-bottom:var(--space-xs)}.action-selection{margin-top:var(--space-md)}.action-buttons{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-md)}.action-btn{display:flex;flex-direction:column;align-items:center;gap:var(--space-sm);padding:var(--space-lg);border:2px solid var(--border);border-radius:var(--radius-lg);background:var(--surface);cursor:pointer;transition:all var(--transition-fast)}.action-btn svg{font-size:2rem}.action-btn.approve:hover{border-color:var(--success);background:var(--success-light);color:#065f46}.action-btn.reject:hover{border-color:var(--danger);background:var(--danger-light);color:#991b1b}.action-indicator{text-align:center;margin-bottom:var(--space-lg)}.pin-form .form-group{margin-bottom:var(--space-lg)}.pin-input{text-align:center;font-size:1.5rem;letter-spacing:.5em;padding:var(--space-md);font-weight:600}.modal-actions{display:flex;gap:var(--space-md)}.modal-actions .btn{flex:1}.toast-container{position:fixed;bottom:24px;right:24px;z-index:1000;display:flex;flex-direction:column;gap:12px}.toast{display:flex;align-items:center;padding:16px;background:var(--surface);border-radius:var(--radius-md);box-shadow:var(--shadow-lg);min-width:300px;max-width:400px;animation:slideIn .3s ease-out;border-left:4px solid transparent}@keyframes slideIn{0%{transform:translate(100%);opacity:0}to{transform:translate(0);opacity:1}}.toast-success{border-left-color:var(--success)}.toast-success .toast-icon{color:var(--success)}.toast-error{border-left-color:var(--danger)}.toast-error .toast-icon{color:var(--danger)}.toast-info{border-left-color:var(--primary)}.toast-info .toast-icon{color:var(--primary)}.toast-icon{display:flex;align-items:center;justify-content:center;font-size:20px;margin-right:12px}.toast-message{flex:1;font-size:.9375rem;color:var(--text-primary);line-height:1.4}.toast-close{background:none;border:none;color:var(--text-muted);cursor:pointer;padding:4px;display:flex;align-items:center;justify-content:center;transition:color .2s}.toast-close:hover{color:var(--text-primary)}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#4a6fa5,#2d4a7c);padding:var(--space-md)}.login-card{background:var(--surface);width:100%;max-width:400px;padding:var(--space-2xl) var(--space-xl);border-radius:var(--radius-xl);box-shadow:0 20px 25px -5px #0003,0 10px 10px -5px #0000001a}.login-header{text-align:center;margin-bottom:var(--space-xl)}.login-logo{display:inline-flex;align-items:center;justify-content:center;width:160px;height:auto;background:transparent;margin-bottom:var(--space-md);overflow:hidden;padding:0}.login-pln-logo{width:100%;height:100%;object-fit:contain}.login-header h1{font-size:2.5rem;color:var(--primary-dark);margin-bottom:var(--space-xs);letter-spacing:-.025em}.login-header p{font-size:.875rem;font-weight:500}.login-error{background:var(--danger-light);color:var(--danger);padding:var(--space-sm) var(--space-md);border-radius:var(--radius-md);margin-bottom:var(--space-md);display:flex;align-items:center;gap:var(--space-sm);font-size:.875rem;border:1px solid rgba(220,38,38,.2)}.input-with-icon{position:relative}.input-icon{position:absolute;left:var(--space-md);top:50%;transform:translateY(-50%);color:var(--text-muted);font-size:1.1rem}.input-with-icon .form-input{padding-left:calc(var(--space-md) * 2 + 1rem)}.btn-block{width:100%}.login-footer{margin-top:var(--space-xl);text-align:center;font-size:.75rem;color:var(--text-muted)}@media(max-width:480px){.login-card{padding:var(--space-xl) var(--space-md)}}.card-header-flex{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-lg);flex-wrap:wrap;gap:var(--space-md)}.table-responsive{width:100%;overflow-x:auto}.user-table{width:100%;border-collapse:collapse;text-align:left}.user-table th{padding:var(--space-md);background:var(--surface-alt);font-size:.8rem;text-transform:uppercase;color:var(--text-muted);font-weight:700;border-bottom:2px solid var(--border)}.user-table td{padding:var(--space-md);border-bottom:1px solid var(--border);font-size:.9375rem}.user-table tr:hover{background-color:#f8fafc}.user-role-badge{padding:4px 12px;border-radius:var(--radius-full);font-size:.75rem;font-weight:700;text-transform:uppercase;display:inline-block}.badge-user{background:#f1f5f9;color:#475569;border:1px solid #e2e8f0}.badge-admin{background:#fef3c7;color:#92400e;border:1px solid #fde68a}.badge-super_admin{background:#fee2e2;color:#b91c1c;border:1px solid #fecaca}.flex-1{flex:1}@media(max-width:640px){.user-table th:nth-child(4),.user-table td:nth-child(4){display:none}}.request-timeline{margin-top:2rem;padding:1.5rem;background:#f8fafc;border-radius:12px;border:1px solid #e2e8f0}.timeline-title{font-size:.875rem;font-weight:600;color:#64748b;text-transform:uppercase;letter-spacing:.05em;margin-bottom:1.5rem}.timeline-items{display:flex;flex-direction:column;gap:1.5rem;position:relative;padding-left:1rem}.timeline-items:before{content:"";position:absolute;left:1.25rem;top:0;bottom:0;width:2px;background:#e2e8f0}.timeline-item{position:relative;display:flex;gap:1.25rem}.timeline-icon{flex-shrink:0;width:32px;height:32px;border-radius:50%;background:#fff;border:2px solid #e2e8f0;display:flex;align-items:center;justify-content:center;font-size:.875rem;color:#64748b;z-index:1}.timeline-item.created .timeline-icon{border-color:#3b82f6;color:#3b82f6;background:#eff6ff}.timeline-item.updated .timeline-icon{border-color:#f59e0b;color:#f59e0b;background:#fffbeb}.timeline-item.status_changed .timeline-icon{border-color:#10b981;color:#10b981;background:#ecfdf5}.timeline-content{flex:1}.timeline-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.25rem}.timeline-action{font-size:.95rem;font-weight:600;color:#1e293b}.timeline-time{font-size:.8rem;color:#94a3b8}.timeline-user{font-size:.85rem;color:#64748b}.timeline-detail{font-size:.85rem;color:#ef4444;margin-top:.5rem;padding:.5rem;background:#fee2e2;border-radius:4px}.timeline-loading{padding:2rem;text-align:center;color:#64748b;font-style:italic}.request-detail-page{padding:2rem 0;max-width:900px;margin:0 auto}.detail-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem}.back-link{display:flex;align-items:center;gap:.5rem;color:#6b7280;text-decoration:none;font-weight:500;transition:color .2s}.back-link:hover{color:var(--primary)}.header-actions{display:flex;gap:.75rem}.detail-container{padding:2.5rem;background:#fff;border-radius:16px;box-shadow:0 10px 25px -5px #0000000d}.detail-main-header{display:flex;justify-content:space-between;align-items:flex-start;padding-bottom:1.5rem;border-bottom:1px solid #f3f4f6;margin-bottom:2rem}.request-id-badge{display:flex;flex-direction:column}.request-id-badge .label{font-size:.8rem;color:#6b7280;text-transform:uppercase;letter-spacing:.05em;font-weight:600}.request-id-badge .value{font-size:1.5rem;font-weight:700;color:#111827}.detail-grid{display:grid;grid-template-columns:1fr 1fr;gap:2.5rem;margin-bottom:2.5rem}.detail-section h3{font-size:.875rem;font-weight:600;color:#6b7280;text-transform:uppercase;letter-spacing:.05em;margin-bottom:1.25rem;border-left:3px solid var(--primary);padding-left:.75rem}.info-list{display:flex;flex-direction:column;gap:1rem}.info-item{display:flex;flex-direction:column}.info-item .label{font-size:.85rem;color:#6b7280;margin-bottom:.25rem}.info-item .value{font-size:1rem;font-weight:600;color:#111827}.items-section{margin-top:1rem}.table-responsive{overflow-x:auto;border:1px solid #e5e7eb;border-radius:12px}.items-table{width:100%;border-collapse:collapse;text-align:left}.items-table th{background:#f9fafb;padding:1rem;font-size:.85rem;color:#374151;font-weight:600;border-bottom:1px solid #e5e7eb}.items-table td{padding:1rem;border-bottom:1px solid #f3f4f6;font-size:.95rem;color:#111827}.category-tag{background:#eff6ff;color:#1d4ed8;padding:.25rem .5rem;border-radius:4px;font-size:.8rem;font-weight:600}.item-name{font-weight:500}.item-qty{font-weight:600;text-align:center}.item-unit{color:#6b7280;font-size:.85rem}.notes-box,.rejection-box{padding:1.5rem;background:#f9fafb;border-left:4px solid #e1e1e1;border-radius:8px;font-size:.95rem;line-height:1.6;color:#374151;margin-top:1rem}.rejection-section{margin-top:2rem}.rejection-box{border-left-color:var(--danger);background:#fef2f2;color:#b91c1c}.detail-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:300px}@media(max-width:640px){.detail-header{flex-direction:column;align-items:flex-start;gap:1.5rem}.detail-grid{grid-template-columns:1fr}.detail-main-header{flex-direction:column;gap:1rem}.detail-container{padding:1.5rem}}.edit-request-modal{max-width:800px;width:90%;max-height:90vh;overflow-y:auto;padding:0;background:#fff;border-radius:12px;box-shadow:0 10px 25px #0000001a}.edit-request-modal .modal-header{padding:1.5rem;border-bottom:1px solid #e2e8f0;display:flex;justify-content:space-between;align-items:center;position:sticky;top:0;background:#fff;z-index:10}.edit-request-modal .modal-header h2{margin:0;font-size:1.25rem;color:#1e293b}.edit-request-modal .close-button{background:none;border:none;font-size:1.5rem;color:#64748b;cursor:pointer;padding:.5rem;border-radius:50%;display:flex;align-items:center;justify-content:center;transition:background-color .2s}.edit-request-modal .close-button:hover{background-color:#f1f5f9;color:#1e293b}.edit-request-modal .modal-body{padding:1.5rem}.modal-overlay{position:fixed;inset:0;background-color:#00000080;display:flex;justify-content:center;align-items:center;z-index:1000}.stock-update-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background:#0f172a66;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn .2s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.stock-update-modal{background:var(--surface);border-radius:20px;border:1px solid var(--border);width:90%;max-width:480px;max-height:90vh;overflow-y:auto;animation:slideUp .3s cubic-bezier(.16,1,.3,1);box-shadow:0 25px 50px -12px #00000026}@keyframes slideUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.stock-update-header{display:flex;align-items:center;justify-content:space-between;padding:1.5rem;border-bottom:1px solid var(--border)}.stock-update-header h3{font-size:1.25rem;font-weight:600;color:var(--text-primary);display:flex;align-items:center;gap:.625rem}.stock-update-header .close-btn{background:var(--surface-alt);border:none;color:var(--text-secondary);cursor:pointer;font-size:1.25rem;padding:.375rem;border-radius:10px;transition:all .2s;display:flex;align-items:center;justify-content:center}.stock-update-header .close-btn:hover{background:var(--danger-light);color:var(--danger)}.stock-update-body{padding:1.5rem;display:flex;flex-direction:column;gap:1.5rem}.stock-item-info{background:var(--surface-alt);border-radius:12px;padding:1.25rem;border:1px solid var(--border)}.stock-item-info .item-name{font-weight:600;color:var(--text-primary);font-size:1.0625rem;margin-bottom:.5rem}.stock-item-info .item-meta{font-size:.875rem;color:var(--text-secondary);display:flex;gap:1.25rem}.stock-preview{display:flex;align-items:center;justify-content:center;gap:1.5rem;padding:1.25rem;background:linear-gradient(to bottom right,#f8fafc,#eff6ff);border-radius:14px;border:1px solid rgba(37,99,235,.1)}.stock-preview-value{text-align:center}.stock-preview-value .label{font-size:.75rem;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);font-weight:600;margin-bottom:.375rem}.stock-preview-value .value{font-size:1.75rem;font-weight:800;font-variant-numeric:tabular-nums}.stock-preview-value .value.current{color:var(--text-primary)}.stock-preview-value .value.new{color:var(--success)}.stock-preview-value .value.new.danger{color:var(--danger)}.stock-preview-arrow{color:var(--primary);font-size:1.5rem;opacity:.5}.stock-update-form .form-group{display:flex;flex-direction:column;gap:.5rem}.change-type-selector{display:grid;grid-template-columns:repeat(3,1fr);gap:.625rem}.change-type-btn{display:flex;flex-direction:column;align-items:center;gap:.5rem;padding:.875rem .5rem;border:1px solid var(--border);border-radius:12px;background:var(--surface);color:var(--text-secondary);cursor:pointer;font-size:.75rem;font-weight:600;transition:all .2s cubic-bezier(.4,0,.2,1)}.change-type-btn:hover{border-color:var(--primary);background:#f8fafc;color:var(--primary)}.change-type-btn.active.in{border-color:var(--success);background:#ecfdf5;color:#065f46}.change-type-btn.active.out{border-color:var(--danger);background:#fef2f2;color:#991b1b}.change-type-btn.active.adjustment{border-color:var(--primary);background:#eff6ff;color:#1e40af}.change-type-btn svg{font-size:1.5rem}.stock-update-footer{display:flex;gap:1rem;justify-content:flex-end;padding:1.25rem 1.5rem;border-top:1px solid var(--border);background:#f8fafc}.stock-error{color:var(--danger);font-size:.875rem;padding:.75rem 1rem;background:var(--danger-light);border-radius:10px;border:1px solid rgba(220,38,38,.15);font-weight:500}.item-form-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background:#0f172a66;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn .2s ease}.item-form-modal{background:var(--surface);border-radius:20px;border:1px solid var(--border);width:90%;max-width:540px;max-height:90vh;overflow-y:auto;animation:slideUp .3s cubic-bezier(.16,1,.3,1);box-shadow:0 25px 50px -12px #0003}.item-form-header{display:flex;align-items:center;justify-content:space-between;padding:1.5rem;border-bottom:1px solid var(--border)}.item-form-header h3{font-size:1.25rem;font-weight:600;color:var(--text-primary);display:flex;align-items:center;gap:.625rem}.item-form-header .close-btn{background:var(--surface-alt);border:none;color:var(--text-secondary);cursor:pointer;font-size:1.25rem;padding:.375rem;border-radius:10px;transition:all .2s;display:flex;align-items:center;justify-content:center}.item-form-header .close-btn:hover{background:var(--danger-light);color:var(--danger)}.item-form-body{padding:1.5rem;display:flex;flex-direction:column;gap:1.25rem}.item-form-body .form-group{display:flex;flex-direction:column;gap:.5rem}.item-form-body .form-label .required{color:var(--danger);margin-left:2px}.item-form-row{display:grid;grid-template-columns:1fr 1fr;gap:1.25rem}.category-input-wrapper{position:relative}.category-suggestions{position:absolute;top:calc(100% + 5px);left:0;right:0;background:var(--surface);border:1px solid var(--border);border-radius:12px;max-height:200px;overflow-y:auto;z-index:100;box-shadow:var(--shadow-lg)}.category-suggestion{padding:.75rem 1rem;font-size:.875rem;color:var(--text-primary);cursor:pointer;transition:all .15s;border-bottom:1px solid var(--border)}.category-suggestion:last-child{border-bottom:none}.category-suggestion:hover{background:#f8fafc;color:var(--primary)}.category-suggestion.highlighted{background:#eff6ff;color:var(--primary);font-weight:500}.item-form-footer{display:flex;gap:1rem;justify-content:flex-end;padding:1.25rem 1.5rem;border-top:1px solid var(--border);background:#f8fafc}.item-form-error{color:var(--danger);font-size:.875rem;padding:.75rem 1rem;background:var(--danger-light);border-radius:10px;border:1px solid rgba(220,38,38,.15);font-weight:500}@media(max-width:480px){.item-form-row{grid-template-columns:1fr}}.stock-page{display:flex;flex-direction:column;gap:1.5rem}.stock-tabs{display:flex;gap:.5rem;background:var(--surface);border-radius:12px;padding:.375rem;border:1px solid var(--border);box-shadow:var(--shadow-sm)}.stock-tab{flex:1;display:flex;align-items:center;justify-content:center;gap:.5rem;padding:.75rem 1rem;border:none;background:transparent;color:var(--text-secondary);font-size:.875rem;font-weight:500;border-radius:8px;cursor:pointer;transition:all .2s ease}.stock-tab:hover{color:var(--primary);background:var(--surface-alt)}.stock-tab.active{background:var(--primary);color:#fff;box-shadow:var(--shadow-blue)}.stock-tab svg{font-size:1rem}.stock-card{background:var(--surface);border-radius:16px;border:1px solid var(--border);overflow:hidden;box-shadow:var(--shadow-md)}.stock-card-header{display:flex;align-items:center;justify-content:space-between;padding:1.25rem 1.5rem;border-bottom:1px solid var(--border);flex-wrap:wrap;gap:1rem;background:linear-gradient(to right,#f8fafc,#fff)}.stock-card-header h3{font-size:1.1rem;font-weight:600;color:var(--text-primary);display:flex;align-items:center;gap:.5rem}.stock-filters{display:flex;gap:.75rem;align-items:center;flex-wrap:wrap}.stock-filters .form-input{width:200px}.stock-filters .form-select{width:160px}.stock-table-wrapper{overflow-x:auto}.stock-table{width:100%;border-collapse:collapse}.stock-table thead{background:#f8fafc}.stock-table th{padding:.875rem 1rem;text-align:left;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--text-secondary);border-bottom:1px solid var(--border);white-space:nowrap}.stock-table td{padding:1rem;font-size:.875rem;color:var(--text-primary);border-bottom:1px solid var(--border);vertical-align:middle}.stock-table tbody tr{transition:background .15s ease}.stock-table tbody tr:hover{background:#fdfdfd}.stock-table tbody tr:last-child td{border-bottom:none}.stock-badge{display:inline-flex;align-items:center;gap:.375rem;padding:.25rem .75rem;border-radius:20px;font-size:.75rem;font-weight:600;white-space:nowrap}.stock-badge.available{background:#ecfdf5;color:#059669;border:1px solid rgba(5,150,105,.2)}.stock-badge.low{background:#fffbeb;color:#d97706;border:1px solid rgba(217,119,6,.2)}.stock-badge.out{background:#fef2f2;color:#dc2626;border:1px solid rgba(220,38,38,.2)}.stock-number{font-weight:700;font-variant-numeric:tabular-nums}.stock-number.zero{color:var(--danger)}.category-tag{display:inline-block;padding:.1875rem .625rem;background:#eef2ff;color:#4f46e5;border-radius:6px;font-size:.75rem;font-weight:500;border:1px solid rgba(79,70,229,.15)}.stock-actions{display:flex;gap:.375rem}.stock-actions .btn{padding:.375rem .625rem;font-size:.75rem;border-radius:6px}.stock-empty{text-align:center;padding:3rem 1.5rem;color:var(--text-muted)}.stock-empty svg{font-size:2.5rem;margin-bottom:.75rem;opacity:.5}.stock-empty p{font-size:.9375rem}.stock-loading{display:flex;justify-content:center;align-items:center;padding:3rem}.stock-pagination{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.5rem;border-top:1px solid var(--border);flex-wrap:wrap;gap:.75rem;background:#f8fafc}.stock-pagination-info{font-size:.8125rem;color:var(--text-secondary)}.stock-pagination-buttons{display:flex;gap:.375rem}.stock-pagination-buttons .btn{padding:.375rem .75rem;font-size:.8125rem}.stock-history-list{max-height:400px;overflow-y:auto}.history-item{display:flex;align-items:flex-start;gap:1rem;padding:1rem 1.5rem;border-bottom:1px solid var(--border);transition:background .2s}.history-item:hover{background:#fbfbfb}.history-item:last-child{border-bottom:none}.history-icon{width:36px;height:36px;border-radius:10px;display:flex;align-items:center;justify-content:center;flex-shrink:0;font-size:.875rem}.history-icon.in{background:#ecfdf5;color:#059669}.history-icon.out,.history-icon.auto_out{background:#fef2f2;color:#dc2626}.history-icon.adjustment{background:#eff6ff;color:#2563eb}.history-details{flex:1;min-width:0}.history-details .history-text{font-size:.875rem;color:var(--text-primary);margin-bottom:.25rem;font-weight:500}.history-details .history-meta{font-size:.75rem;color:var(--text-secondary)}.history-qty{font-weight:700;font-size:.875rem;white-space:nowrap}.history-qty.in{color:#059669}.history-qty.out,.history-qty.auto_out{color:#dc2626}.history-qty.adjustment{color:#2563eb}.item-toolbar{display:flex;justify-content:space-between;align-items:center;padding:1.25rem 1.5rem;border-bottom:1px solid var(--border);flex-wrap:wrap;gap:1rem;background:#f8fafc}@media(max-width:768px){.stock-tabs{flex-direction:column}.stock-card-header{flex-direction:column;align-items:flex-start}.stock-filters{width:100%}.stock-filters .form-input,.stock-filters .form-select{flex:1;width:auto;min-width:120px}.stock-table th:nth-child(n+5),.stock-table td:nth-child(n+5){display:none}}.app{min-height:100vh;display:flex;flex-direction:column}.main-content{flex:1;padding:var(--space-xl) 0}.footer{background:var(--surface);border-top:1px solid var(--border);padding:var(--space-lg) 0;margin-top:auto}.footer p{text-align:center;font-size:.875rem;color:var(--text-muted)}
