:root{--font-family-sans:"Inter",-apple-system,BlinkMacSystemFont,"Segoe UI","Roboto","Oxygen","Ubuntu","Cantarell","Fira Sans","Droid Sans","Helvetica Neue",sans-serif;--app-background:#f7f8fc;--content-background:#fff;--background-primary:#f7f8fc;--background-secondary:#f1f5f9;--background-tertiary:#e2e8f0;--background-hover:#f8fafc;--background-alt:#fafbfc;--background-body:#fff;--background-card:#fff;--sidebar-background:#fff;--sidebar-text:#6e758b;--sidebar-text-header:#b0b7c9;--sidebar-link-active:#4a69ff;--sidebar-link-active-background:#f0f3ff;--text-primary:#2d3748;--text-secondary:#5a647b;--text-tertiary:#94a3b8;--text-white:#fff;--primary:#4a69ff;--primary-hover:#3553e6;--primary-color:#4a69ff;--primary-light:#eef2ff;--primary-rgb:74,105,255;--primary-hsl:227,100%,65%;--light-blue:#eff6ff;--dark-blue:#1e40af;--border-color:#d1d5db;--border-color-light:#e6e8ee;--border-color-grey:#d1d5db;--border-color-strong:#cbd5e1;--status-green:#34c759;--status-green-bg:#dcfce7;--status-red:#ff3b30;--status-red-bg:#fee2e2;--status-yellow:#f59e0b;--status-yellow-bg:#fef3c7;--status-blue:#3b82f6;--status-blue-bg:#dbeafe;--chart-blue:#4a69ff;--chart-lightblue:#869dff;--chart-yellow:#ffd452;--chart-cyan:#32ade6;--chart-purple:#9060f9;--radius:12px;--shadow-subtle:0 4px 12px #d2d6e34d;--shadow-card:0px 2px 8px #bbc2d333;--shadow-sm:0 1px 2px #0000000d;--shadow-md:0 4px 6px #0000001a;--shadow-lg:0 10px 15px #0000001a}*,:before,:after{box-sizing:border-box}body{font-family:var(--font-family-sans);background-color:var(--app-background);color:var(--text-primary);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;margin:0}select{appearance:none;cursor:pointer;background-image:url(data:image/svg+xml;charset=US-ASCII,%3Csvg%20width%3D%2220%22%20height%3D%2220%22%20xmlns%3D%22http%3A//www.w3.org/2000/svg%22%3E%3Cpath%20d%3D%22M5%208l5%205%205-5z%22%20fill%3D%22%239CA3AF%22/%3E%3C/svg%3E);background-position:right 7px center;background-repeat:no-repeat;background-size:16px;padding-right:40px}.app-layout{height:100vh;display:flex}.main-content-area{flex-grow:1;height:100vh;padding:24px;overflow-y:auto}.main-content{background:var(--content-background);box-shadow:var(--shadow-subtle);border-radius:24px;padding:32px}.app-loading{background-color:var(--background-primary);justify-content:center;align-items:center;height:100vh;display:flex}.spinner{border:3px solid var(--border-color);border-top-color:var(--primary);border-radius:50%;width:40px;height:40px;animation:.8s linear infinite spin}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.sidebar{background-color:var(--content-background);border-right:1px solid var(--border-color-strong);border-radius:0 40px 40px 0;flex-direction:column;flex-shrink:0;justify-content:space-between;width:280px;height:100vh;padding:24px;display:flex}.sidebar-header{align-items:center;gap:12px;margin-bottom:24px;padding:8px;display:flex}.logo-icon{color:var(--primary)}.logo-text{color:var(--text-primary);font-size:1.5rem;font-weight:700}.nav-group{margin-bottom:24px}.nav-group-title{color:var(--sidebar-text-header);text-transform:uppercase;letter-spacing:1px;margin-bottom:8px;padding:0 16px;font-size:.75rem;font-weight:600}.sidebar-nav ul{margin:0;padding:0;list-style:none}.nav-item{border-radius:var(--radius);color:var(--sidebar-text);white-space:nowrap;align-items:center;gap:16px;margin-bottom:4px;padding:12px 16px;font-weight:600;text-decoration:none;transition:background-color .2s,color .2s;display:flex}.nav-item:hover{color:var(--text-primary)}.nav-item.active{background-color:var(--sidebar-link-active-background);color:var(--sidebar-link-active)}.sidebar-footer .nav-item{margin-top:auto}.logout-button{cursor:pointer;background:0 0;border:none;width:100%;font-family:inherit;font-size:1rem}.app-header{background-color:var(--content-background);box-shadow:var(--shadow-subtle);border-radius:16px;justify-content:space-between;align-items:center;margin-bottom:24px;padding:16px 24px;display:flex}.header-left-content{flex-direction:column;display:flex}.header-greeting{color:var(--text-primary);margin:0;font-size:1.75rem;font-weight:700}.header-date{color:var(--text-secondary);font-size:.9rem}.header-right-content{align-items:center;gap:16px;display:flex}.header-dept-tabs{background:var(--app-background);border:1px solid var(--border-color-strong);border-radius:12px;gap:4px;padding:4px;display:flex}.header-dept-tab{color:var(--text-secondary);cursor:pointer;white-space:nowrap;background:0 0;border:none;border-radius:9px;align-items:center;gap:6px;padding:7px 16px;font-family:inherit;font-size:.82rem;font-weight:600;transition:background-color .15s,color .15s,box-shadow .15s;display:flex}.header-dept-tab.active{background:var(--content-background);color:var(--primary);box-shadow:0 1px 4px #0000001f}.header-dept-tab:hover:not(.active){color:var(--text-primary);background:#0000000d}.search-bar{background-color:var(--app-background);border-radius:var(--radius);border:1px solid var(--border-color-strong);align-items:center;gap:8px;width:280px;padding:8px 12px;display:flex}.search-bar input{color:var(--text-primary);background:0 0;border:none;outline:none;width:100%;font-family:inherit;font-size:.9rem}.search-bar input::placeholder{color:var(--text-secondary)}.action-icons{align-items:center;gap:8px;display:flex}.icon-button{border:1px solid var(--border-color-strong);color:var(--text-secondary);cursor:pointer;background:0 0;border-radius:50%;justify-content:center;align-items:center;width:40px;height:40px;transition:all .2s;display:flex;position:relative}.icon-button:hover{background-color:var(--border-color-light);color:var(--text-primary)}.dept-container{position:relative}.dept-switcher-btn.dept-fleet{color:var(--primary);border-color:var(--primary);background:var(--primary-light,hsla(var(--primary-hsl),.08))}.dept-switcher-btn.dept-recruitment{color:#059669;background:#05966914;border-color:#059669}.dept-dropdown{background-color:var(--content-background);border-radius:var(--radius);min-width:180px;box-shadow:var(--shadow-md);border:1px solid var(--border-color-strong);z-index:100;padding:4px;position:absolute;top:calc(100% + 10px);right:0;overflow:hidden}.dept-dropdown-item{border-radius:calc(var(--radius) - 2px);cursor:pointer;color:var(--text-secondary);align-items:center;gap:10px;padding:10px 12px;font-size:.9rem;font-weight:500;transition:background-color .15s,color .15s;display:flex}.dept-dropdown-item:hover{background-color:var(--border-color-light);color:var(--text-primary)}.dept-dropdown-item.active{color:var(--primary);font-weight:600}.dept-dropdown-item .dept-check{color:var(--primary);margin-left:auto;font-size:.85rem}.dept-dot{border-radius:50%;flex-shrink:0;width:8px;height:8px}.dept-dot.dept-dot-fleet{background:var(--primary)}.dept-dot.dept-dot-recruitment{background:#059669}.language-container{position:relative}.language-dropdown{background-color:var(--content-background);border-radius:var(--radius);width:180px;box-shadow:var(--shadow-md);border:1px solid var(--border-color-strong);z-index:100;position:absolute;top:calc(100% + 10px);right:0;overflow:hidden}.language-dropdown ul{margin:0;padding:0;list-style:none}.language-dropdown li{cursor:pointer;color:var(--text-secondary);justify-content:center;align-items:center;gap:8px;padding:12px 16px;font-weight:500;transition:background-color .2s,color .2s;display:flex}.language-dropdown li:hover{background-color:var(--border-color-light);color:var(--text-primary)}.language-dropdown li span{align-items:center;gap:6px;display:flex}.profile-container{position:relative}.profile-wrapper{background-color:var(--app-background);width:40px;height:40px;color:var(--text-secondary);cursor:pointer;border-radius:50%;justify-content:center;align-items:center;transition:background-color .2s;display:flex}.profile-wrapper:hover{background-color:var(--border-color-light)}.profile-dropdown{background-color:var(--content-background);border-radius:var(--radius);width:200px;box-shadow:var(--shadow-md);border:1px solid var(--border-color-strong);z-index:100;position:absolute;top:calc(100% + 10px);right:0;overflow:hidden}.profile-dropdown ul{margin:0;padding:0;list-style:none}.profile-dropdown li{cursor:pointer;color:var(--text-secondary);align-items:center;gap:12px;padding:10px 12px;font-weight:500;transition:background-color .2s,color .2s;display:flex}.profile-dropdown li:hover{background-color:var(--border-color-light);color:var(--text-primary)}.profile-dropdown li:last-child{color:var(--status-red)}.profile-dropdown li:last-child:hover{background-color:var(--status-red-bg);color:var(--status-red)}.status-badge{border-radius:9999px;align-items:center;gap:6px;padding:5px 10px;font-size:.75rem;font-weight:600;line-height:1;display:inline-flex}.status-badge:before{content:"";border-radius:50%;width:7px;height:7px}.status-badge.green{color:var(--status-green);background-color:#eaf9ee}.status-badge.green:before{background-color:var(--status-green)}.status-badge.blue{color:var(--chart-blue);background-color:#ebf0ff}.status-badge.blue:before{background-color:var(--chart-blue)}.status-badge.orange{color:#c28f03;background-color:#fffbeb}.status-badge.orange:before{background-color:#ffd452}.status-badge.red{color:var(--status-red);background-color:#fff0f0}.status-badge.red:before{background-color:var(--status-red)}.status-badge.gray{color:var(--text-secondary);background-color:var(--border-color-light)}.status-badge.gray:before{background-color:var(--text-secondary)}.page-header{justify-content:space-between;align-items:center;margin-bottom:24px;display:flex}.tab-navigation{border-bottom:2px solid var(--border-color-light);gap:0;margin-bottom:24px;display:flex}.tab-button{color:var(--text-secondary);cursor:pointer;background:0 0;border:none;border-bottom:3px solid #0000;margin-bottom:-2px;padding:12px 24px;font-size:1rem;font-weight:600;transition:all .2s;position:relative;bottom:-2px}.tab-button:hover{color:var(--text-primary)}.header-actions{align-items:center;gap:12px;display:flex}.page-title{color:var(--text-primary);font-size:1.75rem;font-weight:700}.add-button{background-color:var(--primary);color:var(--content-background);border-radius:var(--radius);cursor:pointer;white-space:nowrap;border:none;justify-content:center;align-items:center;gap:8px;height:40px;padding:10px 16px;font-size:.9rem;font-weight:600;transition:background-color .2s;display:flex}.add-button:hover{background-color:var(--primary-hover)}.table-container{width:100%}table{border-collapse:separate;border-spacing:0 4px;width:100%}th,td{text-align:left;vertical-align:middle;border-bottom:1px solid var(--border-color-light);padding:16px 20px}thead tr{border-bottom:2px solid var(--border-color-strong)}th{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;font-size:.8rem;font-weight:600}tbody tr{background-color:var(--content-background);transition:background-color .2s}tbody tr:hover{background-color:#f7f8fc}tbody tr.clickable-row{cursor:pointer}td:first-child{border-top-left-radius:var(--radius);border-bottom-left-radius:var(--radius)}td:last-child{border-top-right-radius:var(--radius);border-bottom-right-radius:var(--radius)}.action-buttons{gap:6px;display:flex}.action-button{cursor:pointer;border-radius:var(--radius);border:none;justify-content:center;align-items:center;padding:8px;transition:all .2s;display:inline-flex}.action-button.view{color:#2563eb;background-color:#eff6ff}.action-button.view:hover{background-color:#dbeafe}.action-button.edit{color:#d97706;background-color:#fef3c7}.action-button.edit:hover{background-color:#fde68a}.action-button.delete{color:#dc2626;background-color:#fee2e2}.action-button.delete:hover{background-color:#fecaca}.action-button.approve{color:#16a34a;background-color:#dcfce7}.action-button.approve:hover{background-color:#bbf7d0}.action-button.reject{color:#dc2626;background-color:#fee2e2}.action-button.reject:hover{background-color:#fecaca}.status-text{color:var(--text-secondary);margin-left:8px;font-size:.9rem}.inventory-grid{grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:20px;display:grid}.inventory-card{background-color:var(--content-background);border-radius:var(--radius);border:1px solid var(--border-color-light);box-shadow:var(--shadow-sm);flex-direction:column;transition:all .2s;display:flex}.inventory-card:hover{box-shadow:var(--shadow-md);transform:translateY(-4px)}.card-header{border-bottom:1px solid var(--border-color-light);justify-content:space-between;align-items:flex-start;padding:16px;display:flex}.card-title{color:var(--text-primary);margin:0;font-size:1.1rem;font-weight:600;line-height:1.4}.card-body{flex-grow:1;padding:16px}.card-body p{color:var(--text-secondary);margin:0 0 10px;font-size:.9rem}.card-body p strong{color:var(--text-primary);font-weight:500}.card-footer{background-color:var(--background-alt);border-top:1px solid var(--border-color-light);border-bottom-left-radius:var(--radius);border-bottom-right-radius:var(--radius);justify-content:space-between;align-items:center;padding:12px 16px;display:flex}.card-footer .status-text{margin-left:0}.card-footer .card-actions{align-items:center;gap:8px;display:flex}.card-footer .action-button{border:1px solid var(--border-color);border-radius:var(--radius);cursor:pointer;color:var(--text-secondary);background-color:#0000;justify-content:center;align-items:center;padding:8px;transition:all .2s;display:inline-flex}.card-footer .action-button.purchase{color:#2563eb;background-color:#dbeafe;border-color:#2563eb}.card-footer .action-button.purchase:hover{background-color:#bfdbfe}.filters-row{flex-wrap:wrap;gap:15px;margin-bottom:20px;display:flex}.search-box{flex-grow:1;align-items:center;max-width:300px;display:flex;position:relative}.search-box svg{color:var(--text-tertiary);position:absolute;left:12px}.search-box input{border:1px solid var(--border-color-light);border-radius:var(--radius);width:100%;color:var(--text-primary);padding:10px 10px 10px 40px;font-size:.9rem;transition:all .2s}.search-box input:focus{border-color:var(--primary);box-shadow:0 0 0 3px rgba(var(--primary-rgb),.1);outline:none}.filter-select{border:1px solid var(--border-color-light);border-radius:var(--radius);background-color:var(--content-background);color:var(--text-primary);cursor:pointer;appearance:none;background-image:url(data:image/svg+xml;charset=US-ASCII,%3Csvg%20width%3D%2220%22%20height%3D%2220%22%20xmlns%3D%22http%3A//www.w3.org/2000/svg%22%3E%3Cpath%20d%3D%22M5%208l5%205%205-5z%22%20fill%3D%22%239CA3AF%22/%3E%3C/svg%3E);background-position:right 7px center;background-repeat:no-repeat;background-size:16px;padding:10px 40px 10px 12px;font-size:.9rem}.filter-select:focus{border-color:var(--primary);box-shadow:0 0 0 3px rgba(var(--primary-rgb),.1);outline:none}.purchase-history{width:100%}.purchase-history-table{overflow-x:auto}.purchase-history-table table{border-spacing:0}.purchase-history-table tbody tr.status-confirmed{border-left:3px solid #16a34a}.purchase-history-table tbody tr.status-draft{border-left:3px solid #f59e0b}.purchase-history-table tbody tr.status-cancelled{border-left:3px solid #ef4444}.status-cell{align-items:center;gap:8px;font-size:.9rem;display:flex}.status-cell .status-icon.confirmed{color:#16a34a}.status-cell .status-icon.draft{color:#f59e0b}.status-cell .status-icon.cancelled{color:#ef4444}.numeric{text-align:right;font-variant-numeric:tabular-nums}.font-bold{font-weight:600}.loading-state,.empty-state{text-align:center;color:var(--text-tertiary);padding:24px;font-size:.9rem}.purchases-list-container{width:100%}.table-container{background-color:var(--content-background);border-radius:var(--radius);border:1px solid var(--border-color-light);box-shadow:var(--shadow-sm);overflow:hidden}.empty-message{text-align:center;color:var(--text-tertiary);padding:48px 24px;font-size:.95rem}.error-message{color:#dc2626;border-radius:var(--radius);background-color:#fee2e2;border-left:4px solid #dc2626;margin-bottom:16px;padding:12px 16px}.loading-container{color:var(--text-secondary);flex-direction:column;justify-content:center;align-items:center;gap:12px;padding:48px 24px;display:flex}.loading-container .spinner{animation:1s linear infinite spin}.inline-search{align-items:center;height:40px;display:flex;position:relative}.inline-search .inline-search-icon{color:var(--text-tertiary);pointer-events:none;position:absolute;left:10px}.inline-search input{border:1px solid var(--border-color-strong);border-radius:var(--radius);background:var(--content-background);color:var(--text-primary);width:220px;height:40px;padding:9px 12px 9px 34px;font-family:inherit;font-size:.875rem}.inline-search input::placeholder{color:var(--text-tertiary)}.inline-search input:focus{border-color:var(--primary);box-shadow:0 0 0 3px rgba(var(--primary-rgb,74,105,255),.1);outline:none}.sort-select{border:1px solid var(--border-color-strong);border-radius:var(--radius);background:var(--content-background);color:var(--text-secondary);cursor:pointer;appearance:none;background-image:url(data:image/svg+xml;charset=US-ASCII,%3Csvg%20width%3D%2220%22%20height%3D%2220%22%20xmlns%3D%22http%3A//www.w3.org/2000/svg%22%3E%3Cpath%20d%3D%22M5%208l5%205%205-5z%22%20fill%3D%22%239CA3AF%22/%3E%3C/svg%3E);background-position:right 6px center;background-repeat:no-repeat;background-size:16px;height:40px;padding:9px 32px 9px 12px;font-family:inherit;font-size:.875rem;font-weight:500}.sort-select:focus{border-color:var(--primary);box-shadow:0 0 0 3px rgba(var(--primary-rgb,74,105,255),.1);outline:none}.add-button.secondary{background:var(--content-background);color:var(--text-secondary);border:1px solid var(--border-color-strong)}.add-button.secondary:hover{background:var(--background-alt);color:var(--text-primary)}.actions-cell{justify-content:flex-end;align-items:center;gap:6px;display:flex}.action-button.confirm{color:#16a34a;background-color:#dcfce7}.action-button.confirm:hover:not(:disabled){background-color:#bbf7d0}.action-button.confirm:disabled{opacity:.6;cursor:not-allowed}.action-button.cancel{color:#dc2626;background-color:#fee2e2}.action-button.cancel:hover:not(:disabled){background-color:#fecaca}.action-button.cancel:disabled{opacity:.6;cursor:not-allowed}.purchase-detail{max-width:1000px;margin:0 auto}.purchase-detail-header{flex-direction:column;gap:12px;margin-bottom:24px;display:flex}.back-button{color:var(--primary);cursor:pointer;background:0 0;border:none;align-items:center;gap:8px;width:fit-content;padding:8px 0;font-size:.95rem;font-weight:500;transition:color .2s;display:inline-flex}.back-button:hover{color:var(--primary-hover)}.purchase-detail-content{flex-direction:column;gap:20px;display:flex}.detail-card{background-color:var(--content-background);border:1px solid var(--border-color-light);border-radius:var(--radius);box-shadow:var(--shadow-sm);overflow:hidden}.detail-card .card-header{background-color:var(--background-alt);border-bottom:1px solid var(--border-color-light);justify-content:space-between;align-items:center;padding:16px 20px;display:flex}.detail-card .card-header h2{color:var(--text-primary);margin:0;font-size:1rem;font-weight:600}.items-count{color:var(--text-secondary);background-color:var(--content-background);border-radius:4px;padding:4px 8px;font-size:.85rem}.detail-grid{grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:20px;display:grid}.detail-row{flex-direction:column;gap:6px;display:flex}.detail-row label{text-transform:uppercase;letter-spacing:.5px;color:var(--text-secondary);font-size:.8rem;font-weight:600}.detail-row .value{color:var(--text-primary);word-break:break-word;font-size:.95rem}.totals-summary{border-top:2px solid var(--border-color-light);padding:20px}.total-row{justify-content:flex-end;align-items:center;gap:24px;font-size:1.1rem;font-weight:600;display:flex}.total-row .amount{color:var(--primary);font-size:1.3rem}.actions-section{background-color:var(--background-alt);border-radius:var(--radius);border:1px solid var(--border-color-light);gap:12px;padding:20px;display:flex}.btn{border-radius:var(--radius);cursor:pointer;border:none;justify-content:center;align-items:center;gap:8px;padding:10px 16px;font-size:.95rem;font-weight:500;transition:all .2s;display:inline-flex}.btn.btn-confirm{color:#fff;background-color:#16a34a}.btn.btn-confirm:hover:not(:disabled){background-color:#15803d}.btn.btn-cancel{color:#fff;background-color:#dc2626}.btn.btn-cancel:hover:not(:disabled){background-color:#b91c1c}.loading-state{color:var(--text-secondary);flex-direction:column;justify-content:center;align-items:center;gap:16px;padding:60px 24px;display:flex}.loading-state svg{width:32px;height:32px;animation:1s linear infinite spin}.gifts-dashboard{padding:0}.gifts-stats-grid{grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:32px;display:grid}@media (max-width:900px){.gifts-stats-grid{grid-template-columns:repeat(2,1fr)}}.gifts-stat-card{background:var(--content-background);border-radius:var(--radius);border:1px solid var(--border-color);align-items:center;gap:16px;padding:20px;display:flex}.gifts-stat-card .stat-icon{border-radius:12px;justify-content:center;align-items:center;width:48px;height:48px;display:flex}.gifts-stat-card .stat-icon.blue{color:#2563eb;background:#dbeafe}.gifts-stat-card .stat-icon.orange{color:#ea580c;background:#ffedd5}.gifts-stat-card .stat-icon.green{color:#16a34a;background:#dcfce7}.gifts-stat-card .stat-icon.purple{color:#9333ea;background:#f3e8ff}.gifts-stat-card .stat-info{flex-direction:column;display:flex}.gifts-stat-card .stat-info .stat-value{color:var(--text-primary);font-size:1.75rem;font-weight:700;line-height:1}.gifts-stat-card .stat-info .stat-label{color:var(--text-secondary);margin-top:4px;font-size:.85rem}.gifts-recent-section{background:var(--content-background);border-radius:var(--radius);border:1px solid var(--border-color);padding:24px}.gifts-recent-section h2{color:var(--text-primary);margin-bottom:16px;font-size:1.1rem;font-weight:600}.modal-backdrop{-webkit-backdrop-filter:blur(8px);z-index:1000;opacity:0;background-color:#64748b66;justify-content:center;align-items:center;width:100%;height:100%;animation:.3s forwards fadeIn;display:flex;position:fixed;top:0;left:0}@keyframes fadeIn{to{opacity:1}}.modal-content{background-color:var(--content-background);border-radius:var(--radius);scrollbar-width:none;-ms-overflow-style:none;width:80vw;min-width:520px;max-width:800px;max-height:90vh;box-shadow:var(--shadow-lg);border:1px solid var(--border-color-strong);opacity:0;padding:24px;animation:.3s .1s forwards scaleIn;overflow-y:auto;transform:scale(.95)}.modal-content::-webkit-scrollbar{display:none}@keyframes scaleIn{to{opacity:1;transform:scale(1)}}.form-group input,.form-group select,.form-group textarea{border:1px solid var(--border-color-strong);border-radius:var(--radius);background-color:var(--content-background);padding:12px 16px;font-family:inherit;font-size:1rem;transition:border-color .2s,box-shadow .2s}.form-group select{appearance:none;cursor:pointer;background-image:url(data:image/svg+xml;charset=US-ASCII,%3Csvg%20width%3D%2220%22%20height%3D%2220%22%20xmlns%3D%22http%3A//www.w3.org/2000/svg%22%3E%3Cpath%20d%3D%22M5%208l5%205%205-5z%22%20fill%3D%22%239CA3AF%22/%3E%3C/svg%3E);background-position:right 7px center;background-repeat:no-repeat;background-size:16px;padding-right:40px}.button-primary{background-color:var(--primary);color:#fff;box-shadow:var(--shadow-sm)}.button-primary:hover{background-color:var(--primary-hover);box-shadow:var(--shadow-md);transform:translateY(-1px)}.button-secondary{background-color:var(--background-secondary);color:var(--text-secondary);border:1px solid var(--border-color);box-shadow:var(--shadow-sm)}.button-secondary:hover{background-color:var(--background-tertiary);border-color:var(--text-secondary);color:var(--text-primary)}.purchase-items{flex-direction:column;gap:12px;margin-bottom:12px;display:flex}.purchase-item-card{border:1px solid var(--border-color-strong);border-radius:var(--radius);background-color:var(--content-background);flex-direction:column;gap:8px;padding:12px;display:flex}.purchase-item-card .item-top{align-items:center;gap:8px;display:flex}.purchase-item-card .item-top .item-select{border:1px solid var(--border-color-strong);border-radius:var(--radius);background-color:var(--background-secondary);color:var(--text-primary);flex:1;padding:10px 14px;font-family:inherit;font-size:.9rem;transition:border-color .2s}.purchase-item-card .item-top .item-select:focus{border-color:var(--primary);outline:none;box-shadow:0 0 0 3px #3f76ff33}.purchase-item-card .item-bottom{grid-template-columns:1fr 120px 1fr;gap:8px;display:grid}.purchase-item-card .item-field{flex-direction:column;gap:4px;display:flex}.purchase-item-card .item-field .item-field-label{color:var(--text-tertiary);font-size:.75rem;font-weight:500}.purchase-item-card .item-field input{border:1px solid var(--border-color-strong);border-radius:var(--radius);background-color:var(--content-background);width:100%;color:var(--text-primary);padding:8px 12px;font-family:inherit;font-size:.875rem;transition:border-color .2s}.purchase-item-card .item-field input:focus{border-color:var(--primary);outline:none;box-shadow:0 0 0 3px #3f76ff33}.purchase-item-card .item-field input[type=number]{text-align:right}.purchase-item-card .item-field .item-unit{background-color:var(--background-secondary);color:var(--text-secondary);cursor:default;text-align:center;font-weight:500}.remove-item-btn{background-color:var(--background-secondary);border:1px solid var(--border-color);border-radius:var(--radius);color:var(--text-secondary);cursor:pointer;justify-content:center;align-items:center;padding:8px;transition:all .2s;display:flex}.remove-item-btn:hover:not(:disabled){background-color:var(--danger);border-color:var(--danger);color:#fff}.remove-item-btn:disabled{opacity:.5;cursor:not-allowed}.add-item-btn{background-color:var(--background-secondary);border:1px solid var(--border-color);border-radius:var(--radius);color:var(--text-secondary);cursor:pointer;align-items:center;gap:8px;padding:10px 16px;font-size:.875rem;font-weight:500;transition:all .2s;display:inline-flex}.add-item-btn:hover{background-color:var(--primary);border-color:var(--primary);color:#fff}.secondary-btn{background-color:var(--background-secondary)!important;border:1px solid var(--border-color)!important;color:var(--text-secondary)!important}.secondary-btn:hover{background-color:var(--background-tertiary)!important}@keyframes skeleton-loading{0%{background-position:-200% 0}to{background-position:200% 0}}.skeleton{background:linear-gradient(90deg,var(--background-secondary)0%,var(--background-tertiary)50%,var(--background-secondary)100%);border-radius:var(--radius);background-size:200% 100%;animation:1.5s ease-in-out infinite skeleton-loading;display:inline-block}.skeleton-text-line{margin-bottom:.5rem}.skeleton-text-line:last-child{margin-bottom:0}.skeleton-card{background-color:var(--content-background);border:1px solid var(--border-color-light);border-radius:var(--radius);box-shadow:var(--shadow-card);padding:1.5rem}.skeleton-card__header{align-items:center;gap:1rem;margin-bottom:1rem;display:flex}.skeleton-card__title{flex-direction:column;flex:1;gap:.5rem;display:flex}.skeleton-card__content{margin-top:1rem}.skeleton-table{background-color:var(--content-background);border:1px solid var(--border-color-light);border-radius:var(--radius);overflow:hidden}.skeleton-table__header{background-color:var(--border-color-light);grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:1px;padding:1px;display:grid}.skeleton-table__body{background-color:var(--border-color-light);flex-direction:column;gap:1px;padding:1px;display:flex}.skeleton-table__row{background-color:var(--content-background);grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:1px;display:grid}.summary-card-skeleton{background-color:var(--content-background);align-items:center;gap:1rem;padding:1rem;display:flex}.summary-card-skeleton .skeleton-icon{width:40px;height:40px}.summary-card-skeleton .skeleton-content{flex-direction:column;flex:1;gap:.5rem;display:flex}.role-card-skeleton{background-color:var(--content-background);border:1px solid var(--border-color-light);border-radius:var(--radius);box-shadow:var(--shadow-card);padding:1.5rem}.role-card-skeleton .skeleton-header{justify-content:space-between;align-items:flex-start;margin-bottom:1rem;display:flex}.role-card-skeleton .skeleton-actions{gap:.5rem;display:flex}.role-card-skeleton .skeleton-footer{border-top:1px solid var(--border-color-light);justify-content:space-between;align-items:center;margin-top:1rem;padding-top:1rem;display:flex}.chart-skeleton{background-color:var(--content-background);border:1px solid var(--border-color-light);border-radius:var(--radius);flex-direction:column;gap:1rem;min-height:300px;padding:1.5rem;display:flex}.chart-skeleton .skeleton-chart-header{justify-content:space-between;align-items:center;display:flex}.chart-skeleton .skeleton-chart-body{flex:1;align-items:flex-end;gap:.5rem;padding:1rem 0;display:flex}.chart-skeleton .skeleton-bar{border-radius:4px;flex:1}.document-status-dots{align-items:center;gap:.375rem;display:flex}.document-status-dots .status-dot{cursor:help;border:1px solid #0000001a;border-radius:50%;width:10px;height:10px;display:inline-block}.document-status-dots .status-dot.green{background-color:#22c55e;box-shadow:0 0 4px #22c55e66}.document-status-dots .status-dot.yellow{background-color:#eab308;box-shadow:0 0 4px #eab30866}.document-status-dots .status-dot.red{background-color:#ef4444;box-shadow:0 0 4px #ef444466}.document-status-dots .status-dot.gray{background-color:#94a3b8}:root{--mf-background:var(--content-background);--mf-border-color:var(--border-color);--mf-header-background:var(--background-alt);--mf-radius:var(--radius);--mf-text-primary:var(--text-primary);--mf-text-secondary:var(--text-secondary);--mf-primary-color:var(--primary);--mf-primary-rgb:var(--primary-rgb,74,105,255)}.mf-view{background:var(--mf-background);border:1px solid var(--mf-border-color);border-radius:var(--mf-radius);margin-bottom:24px}.mf-header{cursor:pointer;background:var(--mf-header-background);border-radius:var(--mf-radius)var(--mf-radius)0 0;justify-content:space-between;align-items:center;padding:12px 16px;transition:background .2s;display:flex}.mf-header:hover{background:var(--mf-border-color)}.mf-header-left,.mf-header-right{align-items:center;gap:12px;display:flex}.mf-header-icon{color:var(--mf-text-secondary)}.mf-title{color:var(--mf-text-primary);margin:0;font-size:.95rem;font-weight:600}.mf-active-count{background-color:var(--mf-primary-color);color:#fff;border-radius:12px;padding:2px 8px;font-size:.8rem;font-weight:600;line-height:1}.mf-reset-btn{border:1px solid var(--border-color-strong);border-radius:var(--radius);color:var(--text-secondary);cursor:pointer;background:0 0;align-items:center;gap:6px;padding:6px 12px;font-size:.8rem;font-weight:600;transition:all .15s;display:inline-flex}.mf-reset-btn:hover{color:#dc2626;background:#fee2e2;border-color:#fecaca}.mf-chevron{color:var(--mf-text-secondary);transition:transform .2s ease-in-out}.mf-chevron-open{transform:rotate(180deg)}.mf-body{border-top:1px solid var(--mf-border-color);padding:20px}.mf-grid{grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:20px;display:grid}.mf-item{flex-direction:column;gap:8px;display:flex}.mf-label{color:var(--mf-text-secondary);font-size:.8rem;font-weight:500}.mf-control-wrap{align-items:center;display:flex;position:relative}.mf-control{border:1px solid var(--border-color-strong);border-radius:var(--mf-radius);background:var(--content-background);width:100%;color:var(--text-primary);padding:9px 12px;font-family:inherit;font-size:.9rem;transition:border-color .2s,box-shadow .2s}.mf-control:focus{border-color:var(--mf-primary-color);box-shadow:0 0 0 3px rgba(var(--mf-primary-rgb),.15);outline:none}.mf-control[type=number]{-moz-appearance:textfield}.mf-control[type=number]::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}.mf-control[type=number]::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}.mf-clear-btn{width:24px;height:24px;color:var(--text-tertiary,#9ca3af);cursor:pointer;background:0 0;border:none;border-radius:50%;justify-content:center;align-items:center;transition:background .15s,color .15s;display:flex;position:absolute;right:8px}.mf-clear-btn:hover{background:var(--background-alt,#f7f8fc);color:var(--text-primary)}select.mf-control{padding-right:30px}.modal-backdrop{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:1000;background:#00000080;justify-content:center;align-items:center;padding:1rem;display:flex;position:fixed;inset:0}.modal-content{background:var(--background);border-radius:12px;width:80vw;min-width:520px;max-width:800px;max-height:90vh;overflow-y:auto;box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a}.modal-content .modal-header{border-bottom:1px solid var(--border-color);justify-content:space-between;align-items:center;padding:1.5rem;display:flex}.modal-content .modal-header h2{color:var(--text-primary);margin:0;font-size:1.25rem;font-weight:600}.modal-content .modal-header .close-button{color:var(--text-secondary);cursor:pointer;background:0 0;border:none;border-radius:6px;padding:.25rem;transition:all .2s}.modal-content .modal-header .close-button:hover{background:var(--background-secondary);color:var(--text-primary)}.modal-content .error-banner{background:var(--status-red-bg);color:var(--status-red);border-radius:6px;margin:1rem 1.5rem;padding:.75rem 1rem;font-size:.875rem}.modal-content form{padding:1.5rem}.modal-content form .form-group{margin-bottom:1.25rem}.modal-content form .form-group label{color:var(--text-primary);margin-bottom:.5rem;font-size:.875rem;font-weight:600;display:block}.modal-content form .form-group input,.modal-content form .form-group textarea,.modal-content form .form-group select{border:1px solid var(--border-color);width:100%;color:var(--text-primary);background:var(--background);border-radius:6px;padding:.625rem .875rem;font-size:.875rem;transition:all .2s}.modal-content form .form-group input:focus,.modal-content form .form-group textarea:focus,.modal-content form .form-group select:focus{border-color:var(--primary);outline:none;box-shadow:0 0 0 3px #4a69ff1a}.modal-content form .form-group input::placeholder,.modal-content form .form-group textarea::placeholder,.modal-content form .form-group select::placeholder{color:var(--text-tertiary)}.modal-content form .form-group textarea{resize:vertical;font-family:inherit}.modal-content form .form-group .help-text{color:var(--text-secondary);margin-top:.375rem;font-size:.75rem;display:block}.modal-content form .form-row{grid-template-columns:repeat(2,1fr);gap:1rem;display:grid}@media (max-width:640px){.modal-content form .form-row{grid-template-columns:1fr}}.modal-content form .form-actions{border-top:1px solid var(--border-color);justify-content:flex-end;gap:.75rem;margin-top:1.5rem;padding-top:1.5rem;display:flex}.modal-content form .form-actions .btn{cursor:pointer;border:none;border-radius:6px;align-items:center;gap:.5rem;padding:.625rem 1.25rem;font-size:.875rem;font-weight:600;transition:all .2s;display:inline-flex}.modal-content form .form-actions .btn:disabled{opacity:.6;cursor:not-allowed}.modal-content form .form-actions .btn.btn-primary{background:var(--primary);color:#fff}.modal-content form .form-actions .btn.btn-primary:hover:not(:disabled){opacity:.9}.modal-content form .form-actions .btn.btn-secondary{background:var(--background-secondary);color:var(--text-primary);border:1px solid var(--border-color)}.modal-content form .form-actions .btn.btn-secondary:hover:not(:disabled){background:var(--background-tertiary,var(--background-secondary))}.vehicle-poa-section .section-header{justify-content:space-between;align-items:center;margin-bottom:1.5rem;display:flex}.vehicle-poa-section .section-header .header-left{align-items:center;gap:.75rem;display:flex}.vehicle-poa-section .section-header .header-left svg{color:var(--primary)}.vehicle-poa-section .section-header .header-left h2{color:var(--text-primary);margin:0;font-size:1.5rem;font-weight:600}.vehicle-poa-section .filters{margin-bottom:1rem}.vehicle-poa-section .filters .filter-select{border:1px solid var(--border-color);background:var(--background);color:var(--text-primary);border-radius:6px;padding:.5rem 1rem;font-size:.875rem}.vehicle-poa-section .filters .filter-select:focus{border-color:var(--primary);outline:none}.vehicle-poa-section .error-message{background-color:var(--status-red-bg);color:var(--status-red);border-radius:6px;margin-bottom:1rem;padding:.75rem 1rem}.vehicle-poa-section .loading-state{text-align:center;color:var(--text-secondary);padding:3rem}.vehicle-poa-section .empty-state{text-align:center;background:var(--background-secondary);border:2px dashed var(--border-color);border-radius:8px;padding:3rem}.vehicle-poa-section .empty-state .empty-icon{color:var(--text-tertiary);margin-bottom:1rem}.vehicle-poa-section .empty-state h3{color:var(--text-primary);margin:0 0 .5rem}.vehicle-poa-section .empty-state p{color:var(--text-secondary);margin-bottom:1.5rem}.vehicle-poa-section .table-container{background:var(--background);border:1px solid var(--border-color);border-radius:8px;overflow-x:auto}.vehicle-poa-section .table-container table{border-collapse:collapse;width:100%}.vehicle-poa-section .table-container table thead{background:var(--background-secondary)}.vehicle-poa-section .table-container table thead th{text-align:left;text-transform:uppercase;letter-spacing:.05em;color:var(--text-tertiary);border-bottom:1px solid var(--border-color);padding:.75rem 1rem;font-size:.75rem;font-weight:600}.vehicle-poa-section .table-container table tbody tr{border-bottom:1px solid var(--border-color)}.vehicle-poa-section .table-container table tbody tr:last-child{border-bottom:none}.vehicle-poa-section .table-container table tbody tr:hover{background:var(--background-secondary)}.vehicle-poa-section .table-container table tbody tr td{color:var(--text-primary);padding:1rem;font-size:.875rem}.vehicle-poa-section .table-container table tbody tr td.actions{gap:.5rem;display:flex}.vehicle-poa-section .badge{white-space:nowrap;border-radius:12px;align-items:center;gap:.25rem;padding:.25rem .75rem;font-size:.75rem;font-weight:600;display:inline-flex}.vehicle-poa-section .badge.badge-success{background:var(--status-green-bg);color:var(--status-green)}.vehicle-poa-section .badge.badge-danger{background:var(--status-red-bg);color:var(--status-red)}.vehicle-poa-section .badge.badge-warning{background:var(--status-yellow-bg);color:var(--status-yellow)}.vehicle-poa-section .badge.badge-secondary{background:var(--background-secondary);color:var(--text-secondary)}.vehicle-poa-section .btn-icon{cursor:pointer;color:var(--text-secondary);background:0 0;border:none;border-radius:6px;padding:.5rem;transition:all .2s}.vehicle-poa-section .btn-icon:hover{background:var(--background-secondary);color:var(--primary)}.vehicle-poa-section .btn-icon.btn-danger:hover{background:var(--status-red-bg);color:var(--status-red)}.vehicle-poa-section .btn{cursor:pointer;border:none;border-radius:6px;align-items:center;gap:.5rem;padding:.625rem 1.25rem;font-size:.875rem;font-weight:600;transition:all .2s;display:inline-flex}.vehicle-poa-section .btn.btn-primary{background:var(--primary);color:#fff}.vehicle-poa-section .btn.btn-primary:hover{opacity:.9}.vehicle-poa-section .font-semibold{font-weight:600}.vehicle-insurance-section .section-header{justify-content:space-between;align-items:center;margin-bottom:1.5rem;display:flex}.vehicle-insurance-section .section-header .header-left{align-items:center;gap:.75rem;display:flex}.vehicle-insurance-section .section-header .header-left svg{color:var(--primary)}.vehicle-insurance-section .section-header .header-left h2{color:var(--text-primary);margin:0;font-size:1.5rem;font-weight:600}.vehicle-insurance-section .filters{margin-bottom:1rem}.vehicle-insurance-section .filters .filter-select{border:1px solid var(--border-color);background:var(--background);color:var(--text-primary);border-radius:6px;padding:.5rem 1rem;font-size:.875rem}.vehicle-insurance-section .filters .filter-select:focus{border-color:var(--primary);outline:none}.vehicle-insurance-section .error-message{background-color:var(--status-red-bg);color:var(--status-red);border-radius:6px;margin-bottom:1rem;padding:.75rem 1rem}.vehicle-insurance-section .loading-state{text-align:center;color:var(--text-secondary);padding:3rem}.vehicle-insurance-section .empty-state{text-align:center;background:var(--background-secondary);border:2px dashed var(--border-color);border-radius:8px;padding:3rem}.vehicle-insurance-section .empty-state .empty-icon{color:var(--text-tertiary);margin-bottom:1rem}.vehicle-insurance-section .empty-state h3{color:var(--text-primary);margin:0 0 .5rem}.vehicle-insurance-section .empty-state p{color:var(--text-secondary);margin-bottom:1.5rem}.vehicle-insurance-section .table-container{background:var(--background);border:1px solid var(--border-color);border-radius:8px;overflow-x:auto}.vehicle-insurance-section .table-container table{border-collapse:collapse;width:100%}.vehicle-insurance-section .table-container table thead{background:var(--background-secondary)}.vehicle-insurance-section .table-container table thead th{text-align:left;text-transform:uppercase;letter-spacing:.05em;color:var(--text-tertiary);border-bottom:1px solid var(--border-color);padding:.75rem 1rem;font-size:.75rem;font-weight:600}.vehicle-insurance-section .table-container table tbody tr{border-bottom:1px solid var(--border-color)}.vehicle-insurance-section .table-container table tbody tr:last-child{border-bottom:none}.vehicle-insurance-section .table-container table tbody tr:hover{background:var(--background-secondary)}.vehicle-insurance-section .table-container table tbody tr td{color:var(--text-primary);padding:1rem;font-size:.875rem}.vehicle-insurance-section .table-container table tbody tr td.actions{gap:.5rem;display:flex}.vehicle-insurance-section .badge{white-space:nowrap;border-radius:12px;align-items:center;gap:.25rem;padding:.25rem .75rem;font-size:.75rem;font-weight:600;display:inline-flex}.vehicle-insurance-section .badge.badge-success{background:var(--status-green-bg);color:var(--status-green)}.vehicle-insurance-section .badge.badge-danger{background:var(--status-red-bg);color:var(--status-red)}.vehicle-insurance-section .badge.badge-warning{background:var(--status-yellow-bg);color:var(--status-yellow)}.vehicle-insurance-section .badge.badge-secondary{background:var(--background-secondary);color:var(--text-secondary)}.vehicle-insurance-section .btn-icon{cursor:pointer;color:var(--text-secondary);background:0 0;border:none;border-radius:6px;padding:.5rem;transition:all .2s}.vehicle-insurance-section .btn-icon:hover{background:var(--background-secondary);color:var(--primary)}.vehicle-insurance-section .btn-icon.btn-danger:hover{background:var(--status-red-bg);color:var(--status-red)}.vehicle-insurance-section .btn{cursor:pointer;border:none;border-radius:6px;align-items:center;gap:.5rem;padding:.625rem 1.25rem;font-size:.875rem;font-weight:600;transition:all .2s;display:inline-flex}.vehicle-insurance-section .btn.btn-primary{background:var(--primary);color:#fff}.vehicle-insurance-section .btn.btn-primary:hover{opacity:.9}.vehicle-oil-change-section .section-header{justify-content:space-between;align-items:center;margin-bottom:1.5rem;display:flex}.vehicle-oil-change-section .section-header .header-left{align-items:center;gap:.75rem;display:flex}.vehicle-oil-change-section .section-header .header-left svg{color:var(--primary)}.vehicle-oil-change-section .section-header .header-left h2{color:var(--text-primary);margin:0;font-size:1.5rem;font-weight:600}.vehicle-oil-change-section .filters{margin-bottom:1rem}.vehicle-oil-change-section .filters .filter-select{border:1px solid var(--border-color);background:var(--background);color:var(--text-primary);border-radius:6px;padding:.5rem 1rem;font-size:.875rem}.vehicle-oil-change-section .filters .filter-select:focus{border-color:var(--primary);outline:none}.vehicle-oil-change-section .error-message{background-color:var(--status-red-bg);color:var(--status-red);border-radius:6px;margin-bottom:1rem;padding:.75rem 1rem}.vehicle-oil-change-section .loading-state{text-align:center;color:var(--text-secondary);padding:3rem}.vehicle-oil-change-section .empty-state{text-align:center;background:var(--background-secondary);border:2px dashed var(--border-color);border-radius:8px;padding:3rem}.vehicle-oil-change-section .empty-state .empty-icon{color:var(--text-tertiary);margin-bottom:1rem}.vehicle-oil-change-section .empty-state h3{color:var(--text-primary);margin:0 0 .5rem}.vehicle-oil-change-section .empty-state p{color:var(--text-secondary);margin-bottom:1.5rem}.vehicle-oil-change-section .table-container{background:var(--background);border:1px solid var(--border-color);border-radius:8px;overflow-x:auto}.vehicle-oil-change-section .table-container table{border-collapse:collapse;width:100%}.vehicle-oil-change-section .table-container table thead{background:var(--background-secondary)}.vehicle-oil-change-section .table-container table thead th{text-align:left;text-transform:uppercase;letter-spacing:.05em;color:var(--text-tertiary);border-bottom:1px solid var(--border-color);padding:.75rem 1rem;font-size:.75rem;font-weight:600}.vehicle-oil-change-section .table-container table tbody tr{border-bottom:1px solid var(--border-color)}.vehicle-oil-change-section .table-container table tbody tr:last-child{border-bottom:none}.vehicle-oil-change-section .table-container table tbody tr:hover{background:var(--background-secondary)}.vehicle-oil-change-section .table-container table tbody tr td{color:var(--text-primary);padding:1rem;font-size:.875rem}.vehicle-oil-change-section .table-container table tbody tr td.actions{gap:.5rem;display:flex}.vehicle-oil-change-section .badge{white-space:nowrap;border-radius:12px;align-items:center;gap:.25rem;padding:.25rem .75rem;font-size:.75rem;font-weight:600;display:inline-flex}.vehicle-oil-change-section .badge.badge-success{background:var(--status-green-bg);color:var(--status-green)}.vehicle-oil-change-section .badge.badge-danger{background:var(--status-red-bg);color:var(--status-red)}.vehicle-oil-change-section .badge.badge-warning{background:var(--status-yellow-bg);color:var(--status-yellow)}.vehicle-oil-change-section .badge.badge-secondary{background:var(--background-secondary);color:var(--text-secondary)}.vehicle-oil-change-section .btn-icon{cursor:pointer;color:var(--text-secondary);background:0 0;border:none;border-radius:6px;padding:.5rem;transition:all .2s}.vehicle-oil-change-section .btn-icon:hover{background:var(--background-secondary);color:var(--primary)}.vehicle-oil-change-section .btn-icon.btn-danger:hover{background:var(--status-red-bg);color:var(--status-red)}.vehicle-oil-change-section .btn{cursor:pointer;border:none;border-radius:6px;align-items:center;gap:.5rem;padding:.625rem 1.25rem;font-size:.875rem;font-weight:600;transition:all .2s;display:inline-flex}.vehicle-oil-change-section .btn.btn-primary{background:var(--primary);color:#fff}.vehicle-oil-change-section .btn.btn-primary:hover{opacity:.9}.vehicle-oil-change-section .latest-oil-change-card{background:linear-gradient(135deg,var(--primary)0%,var(--primary-dark,#3b5bdb)100%);color:#fff;border-radius:12px;margin-bottom:2rem;padding:1.5rem;box-shadow:0 4px 6px #0000001a}.vehicle-oil-change-section .latest-oil-change-card h3{margin:0 0 1rem;font-size:1.125rem;font-weight:600}.vehicle-oil-change-section .latest-oil-change-card .summary-grid{grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem;display:grid}.vehicle-oil-change-section .latest-oil-change-card .summary-grid .summary-item.full-width{grid-column:1/-1}.vehicle-oil-change-section .latest-oil-change-card .summary-grid .summary-item .label{opacity:.9;text-transform:uppercase;letter-spacing:.05em;margin-bottom:.25rem;font-size:.75rem;display:block}.vehicle-oil-change-section .latest-oil-change-card .summary-grid .summary-item .value{font-size:1.125rem;font-weight:600;display:block}.vehicle-oil-change-section .latest-oil-change-card .summary-grid .summary-item .status-row{align-items:center;gap:1rem;margin-top:.5rem;display:flex}.vehicle-oil-change-section .progress-bar-container{flex:1;align-items:center;gap:.75rem;display:flex}.vehicle-oil-change-section .progress-bar-container .progress-bar{background:#fff3;border-radius:4px;flex:1;height:8px;overflow:hidden}.vehicle-oil-change-section .progress-bar-container .progress-bar .progress-bar-fill{border-radius:4px;height:100%;transition:width .3s}.vehicle-oil-change-section .progress-bar-container .progress-bar .progress-bar-fill.success{background:var(--status-green)}.vehicle-oil-change-section .progress-bar-container .progress-bar .progress-bar-fill.warning{background:var(--status-yellow)}.vehicle-oil-change-section .progress-bar-container .progress-bar .progress-bar-fill.danger{background:var(--status-red)}.vehicle-oil-change-section .progress-bar-container .progress-text{text-align:right;min-width:45px;font-size:.875rem;font-weight:600}.vehicle-oil-change-section .history-title{color:var(--text-primary);margin:2rem 0 1rem;font-size:1.125rem;font-weight:600}.vehicle-oil-change-section .latest-row{background:var(--background-tertiary,#4a69ff0d);font-weight:500}.vehicle-oil-change-section .text-sm{font-size:.8125rem}.vehicle-oil-change-section .text-gray{color:var(--text-secondary)}@media (max-width:1024px){.detail-grid{grid-template-columns:1fr}}.driver-assignment select{border:1px solid var(--border-color-strong);border-radius:var(--radius);background-color:var(--content-background);text-overflow:ellipsis;flex:1;min-width:0;padding:.625rem .875rem;font-size:.875rem}.driver-assignment select .driver-option{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.section-separator{border:none;border-top:1px solid var(--border-color);margin:2rem 0}.filter-bar{align-items:center;gap:16px;margin-bottom:20px;display:flex}.filter-bar .filter-item{flex-direction:column;display:flex}.filter-bar label{color:var(--text-secondary);margin-bottom:4px;font-size:.8rem;font-weight:500}.filter-bar select,.filter-bar input{border-radius:var(--radius);border:1px solid var(--border-color-strong);background-color:var(--content-background);color:var(--text-primary);min-width:180px;padding:8px 12px;font-size:.9rem}.filter-bar input{width:280px}.filter-bar select:focus,.filter-bar input:focus{border-color:var(--primary);box-shadow:0 0 0 2px var(--primary-light);outline:none}.filter-search-wrap{align-items:center;display:flex;position:relative}.filter-search-icon{color:var(--text-tertiary);pointer-events:none;position:absolute;left:10px}.filter-search-input{padding-left:32px!important}.filter-date-input{min-width:160px}.filter-number-input{min-width:140px}.base-select{appearance:none;border:1px solid var(--border-color-strong);border-radius:var(--radius);background-color:var(--content-background);color:var(--text-primary);cursor:pointer;background-image:url(data:image/svg+xml;charset=US-ASCII,%3Csvg%20width%3D%2220%22%20height%3D%2220%22%20xmlns%3D%22http%3A//www.w3.org/2000/svg%22%3E%3Cpath%20d%3D%22M5%208l5%205%205-5z%22%20fill%3D%22%239CA3AF%22/%3E%3C/svg%3E);background-position:right 7px center;background-repeat:no-repeat;background-size:16px;padding:10px 40px 10px 12px;font-family:inherit;font-size:.95rem;transition:border-color .2s,box-shadow .2s}.base-select:focus{border-color:var(--primary);outline:none;box-shadow:0 0 0 3px #4a69ff26}.base-select:disabled{opacity:.6;cursor:not-allowed}.currency-display{font-weight:500}.currency-display__converted{color:var(--text-secondary,#6b7280);margin-left:.25rem;font-size:.9em;font-weight:400}.exchange-rate-info{background-color:var(--info-bg,#eff6ff);color:var(--info-text,#1e40af);border-radius:.375rem;align-items:center;gap:.5rem;padding:.5rem .75rem;font-size:.875rem;display:inline-flex}.exchange-rate-info__icon{flex-shrink:0}.exchange-rate-info__text{font-weight:500}.exchange-rate-info__date{opacity:.8;font-weight:400}.exchange-rate-preview{background-color:var(--background-secondary);border:1px solid var(--border-color-light);border-radius:8px;margin-top:1rem;padding:1rem}.exchange-rate-preview .preview-header{border-bottom:1px solid var(--border-color-light);align-items:center;gap:.5rem;margin-bottom:.75rem;padding-bottom:.5rem;display:flex}.exchange-rate-preview .preview-header svg{color:var(--primary)}.exchange-rate-preview .preview-header .preview-title{color:var(--text-primary);font-size:.875rem;font-weight:600}.exchange-rate-preview .preview-loading,.exchange-rate-preview .preview-error{color:var(--text-secondary);align-items:center;gap:.5rem;padding:.5rem 0;font-size:.8125rem;display:flex}.exchange-rate-preview .preview-loading svg,.exchange-rate-preview .preview-error svg{flex-shrink:0}.exchange-rate-preview .preview-error,.exchange-rate-preview .preview-error svg{color:var(--status-red)}.exchange-rate-preview .preview-content{flex-direction:column;gap:.5rem;display:flex}.exchange-rate-preview .preview-content .preview-row{justify-content:space-between;align-items:center;font-size:.875rem;display:flex}.exchange-rate-preview .preview-content .preview-row .preview-label{color:var(--text-tertiary);font-weight:500}.exchange-rate-preview .preview-content .preview-row .preview-value{color:var(--text-primary);font-weight:600}.exchange-rate-preview .preview-content .preview-row .preview-value.highlight{color:var(--primary);font-size:1rem}.animate-spin{animation:1s linear infinite spin}@media (max-width:1024px){.detail-grid{grid-template-columns:1fr}}.driver-info{border-bottom:1px solid var(--border-color);grid-template-columns:repeat(2,1fr);gap:1rem;margin-bottom:1rem;padding-bottom:1rem;display:grid}.no-driver{color:var(--text-tertiary);margin-bottom:1rem;font-style:italic}.driver-assignment{gap:.75rem;margin-top:1rem;display:flex}.driver-assignment select{border:1px solid var(--border-color-strong);border-radius:var(--radius);background-color:var(--content-background);flex:1;padding:.625rem .875rem;font-size:.875rem}.assign-button{background-color:var(--primary);color:#fff;border-radius:var(--radius);cursor:pointer;border:none;padding:.625rem 1rem;font-size:.875rem;font-weight:500;transition:background-color .2s}.assign-button:hover:not(:disabled){background-color:var(--primary-hover)}.assign-button:disabled{opacity:.6;cursor:not-allowed}.documents-section{margin-top:0}.upload-button{background-color:var(--primary);color:#fff;border-radius:var(--radius);cursor:pointer;border:none;align-items:center;gap:.5rem;padding:.5rem 1rem;font-size:.875rem;font-weight:500;transition:background-color .2s;display:flex}.upload-button:hover{background-color:var(--primary-hover)}.no-documents{text-align:center;color:var(--text-tertiary);padding:2rem;font-style:italic}.doc-link{color:var(--primary);font-weight:500;text-decoration:none}.doc-link:hover{text-decoration:underline}.form-error{color:#dc2626;border-radius:var(--radius);background-color:#fee2e2;margin-bottom:1rem;padding:.75rem 1rem;font-size:.875rem}.form-group{flex-direction:column;display:flex}.form-group.full-width{grid-column:1/-1}.form-group label{color:var(--text-secondary);margin-bottom:.5rem;font-size:.875rem;font-weight:500}.form-group input,.form-group select,.form-group textarea{border:1px solid var(--border-color-strong);border-radius:var(--radius);background-color:var(--content-background);padding:.625rem .875rem;font-family:inherit;font-size:.9375rem}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:var(--primary);outline:none;box-shadow:0 0 0 3px #3f76ff33}.form-group input:disabled,.form-group select:disabled,.form-group textarea:disabled{opacity:.6;cursor:not-allowed}.form-group input[type=file]{padding:.5rem}.button-primary,.button-secondary{border-radius:var(--radius);cursor:pointer;padding:.625rem 1.25rem;font-size:.9375rem;font-weight:500;transition:all .2s}.button-primary{background-color:var(--primary);color:#fff;border:none}.modal-content{background-color:var(--content-background);border-radius:var(--radius);width:80vw;min-width:520px;max-width:800px;max-height:90vh;box-shadow:var(--shadow-lg);border:1px solid var(--border-color-strong);padding:1.5rem;overflow-y:auto}.close-button{cursor:pointer;color:var(--text-tertiary);background:0 0;border:none;padding:0;font-size:1.5rem;line-height:1}.card-header-with-action{justify-content:space-between;align-items:center;margin-bottom:1rem;display:flex}.card-header-with-action .card-title{margin-bottom:0}.card-header-with-action .add-button{cursor:pointer;border-radius:var(--radius);align-items:center;gap:8px;padding:10px 16px;font-size:.875rem;font-weight:600;transition:all .2s;display:flex}.card-header-with-action .add-button.secondary{background-color:var(--background-secondary);border:1px solid var(--border-color);color:var(--text-secondary)}.card-header-with-action .add-button.secondary:hover{background-color:var(--background-tertiary);color:var(--text-primary)}.add-button.secondary{background-color:var(--background-secondary);border:1px solid var(--border-color);color:var(--text-secondary);align-items:center;gap:8px;padding:10px 16px;display:flex}.add-button.secondary:hover{background-color:var(--background-tertiary);color:var(--text-primary)}.financials-page{flex-direction:column;gap:24px;display:flex}.financials-page .page-header{justify-content:space-between;align-items:center;display:flex}.financials-page .summary-grid{grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:20px;display:grid}.financials-page .stat-card{background:var(--background-card);border:1px solid var(--border-color);border-radius:12px;flex-direction:column;gap:8px;padding:20px;display:flex}.financials-page .stat-card .stat-label{color:var(--text-secondary);font-size:.95em;font-weight:500}.financials-page .stat-card .stat-value{font-size:1.8em;font-weight:700;line-height:1.2}.financials-page .stat-card .stat-detail{color:var(--text-tertiary);font-size:.9em}.financials-page .top-filters{background:var(--background-card);border:1px solid var(--border-color);border-radius:12px;flex-wrap:wrap;align-items:flex-end;gap:20px;margin-bottom:20px;padding:20px;display:flex}.financials-page .top-filters .filters-header{align-self:center;margin-bottom:0;margin-right:20px;font-size:1.1em;font-weight:600}.financials-page .top-filters .filter-group{flex-direction:column;gap:8px;min-width:150px;display:flex}.financials-page .top-filters .filter-group label{color:var(--text-secondary);font-size:.9em;font-weight:500}.financials-page .top-filters .filter-group select{border:1px solid var(--border-color);background:var(--background-body);width:100%;color:var(--text-primary);appearance:none;cursor:pointer;background-image:url(data:image/svg+xml;charset=US-ASCII,%3Csvg%20width%3D%2220%22%20height%3D%2220%22%20xmlns%3D%22http%3A//www.w3.org/2000/svg%22%3E%3Cpath%20d%3D%22M5%208l5%205%205-5z%22%20fill%3D%22%239CA3AF%22/%3E%3C/svg%3E);background-position:right 7px center;background-repeat:no-repeat;background-size:16px;border-radius:8px;padding:10px 40px 10px 12px;font-size:.95em}.financials-page .top-filters .filter-group select:focus{border-color:var(--primary-color);box-shadow:0 0 0 3px hsla(var(--primary-hsl),.1);outline:none}.financials-page .content-wrapper{gap:20px;display:flex}.financials-page .main-content{background:var(--background-card);border:1px solid var(--border-color);border-radius:12px;flex:1;overflow:hidden}.financials-page .table-header{border-bottom:1px solid var(--border-color);justify-content:space-between;align-items:center;padding:16px 20px;display:flex}.financials-page .table-header .table-title{font-size:1.1em;font-weight:600}.financials-page .view-toggle{background:var(--background-secondary);border:1px solid var(--border-color-light);border-radius:var(--radius);gap:2px;padding:3px;display:flex}.financials-page .view-toggle-btn{border-radius:calc(var(--radius) - 2px);width:32px;height:32px;color:var(--text-secondary);cursor:pointer;background:0 0;border:none;justify-content:center;align-items:center;transition:all .15s;display:flex}.financials-page .view-toggle-btn:hover:not(.active){background:var(--content-background);color:var(--text-primary)}.financials-page .view-toggle-btn.active{background:var(--content-background);color:var(--primary);box-shadow:var(--shadow-sm)}.financials-page .year-group-row td{border-bottom:none!important;padding:0!important}.financials-page .year-group-row{background:var(--background-secondary)!important}.financials-page .year-group-row:hover{background:var(--background-secondary)!important;cursor:default!important}.financials-page .year-group-content{border-top:2px solid var(--border-color-light);border-bottom:1px solid var(--border-color-light);align-items:center;gap:16px;padding:8px 16px;display:flex}.financials-page .year-group-label{text-transform:uppercase;letter-spacing:.06em;color:var(--text-secondary);min-width:36px;font-size:.75rem;font-weight:800}.financials-page .year-group-stats{font-variant-numeric:tabular-nums;align-items:center;gap:6px;font-size:.78rem;display:flex}.financials-page .year-stat{font-weight:600}.financials-page .year-stat.income{color:var(--status-green)}.financials-page .year-stat.expense{color:var(--status-red)}.financials-page .year-stat.positive{color:var(--status-green)}.financials-page .year-stat.negative{color:var(--status-red)}.financials-page .year-stat-sep{color:var(--border-color-strong)}.financials-page .year-stat-count{color:var(--text-tertiary);margin-left:4px;font-weight:500}.financials-page .transaction-type-badge{border-radius:12px;align-items:center;gap:6px;padding:4px 8px;font-size:.85em;font-weight:600;display:inline-flex}.financials-page .transaction-type-badge.income{background-color:var(--status-green-bg);color:var(--status-green)}.financials-page .transaction-type-badge.expense{background-color:var(--status-red-bg);color:var(--status-red)}.form-section .section-title{border-bottom:1px solid var(--border-color);margin-bottom:16px;padding-bottom:8px;font-size:1.1em;font-weight:600}.form-group input,.form-group select,.form-group textarea{border:1px solid var(--border-color);background:var(--background-body);width:100%;color:var(--text-primary);border-radius:8px;padding:12px;font-size:.95em;transition:border-color .2s,box-shadow .2s}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:var(--primary-color);box-shadow:0 0 0 3px hsla(var(--primary-hsl),.1);outline:none}.form-group select{appearance:none;background-image:url(data:image/svg+xml;charset=US-ASCII,%3Csvg%20width%3D%2220%22%20height%3D%2220%22%20xmlns%3D%22http%3A//www.w3.org/2000/svg%22%3E%3Cpath%20d%3D%22M5%208l5%205%205-5z%22%20fill%3D%22%239CA3AF%22/%3E%3C/svg%3E);background-position:right 7px center;background-repeat:no-repeat;background-size:16px;padding-right:40px}.form-group textarea{resize:vertical;min-height:80px}.bc-root{flex-direction:column;gap:16px;display:flex}.bc-empty{color:var(--text-tertiary);background:var(--content-background);border:1px solid var(--border-color-light);border-radius:var(--radius);flex-direction:column;align-items:center;gap:12px;padding:64px 24px;display:flex}.bc-empty p{font-size:.9375rem}.bc-strip{background:var(--content-background);border:1px solid var(--border-color-light);border-radius:var(--radius);display:flex;overflow:hidden}.bc-strip-item{flex-direction:column;flex:1;gap:4px;padding:16px 20px;display:flex}.bc-strip-divider{background:var(--border-color-light);align-self:stretch;width:1px}.bc-strip-label{text-transform:uppercase;letter-spacing:.05em;color:var(--text-secondary);font-size:.72rem;font-weight:600}.bc-strip-value{font-variant-numeric:tabular-nums;font-size:1.3rem;font-weight:700}.bc-strip-value.income{color:var(--status-green)}.bc-strip-value.expense{color:var(--status-red)}.bc-strip-value.positive{color:var(--status-green)}.bc-strip-value.negative{color:var(--status-red)}.bc-strip-value.neutral{color:var(--text-primary)}.bc-years{flex-direction:column;gap:10px;display:flex}.bc-year-card{background:var(--content-background);border:1px solid var(--border-color-light);border-radius:var(--radius);transition:box-shadow .15s;overflow:hidden}.bc-year-card:hover{box-shadow:var(--shadow-sm)}.bc-year-card.current{border-color:hsla(var(--primary-hsl),.35);box-shadow:0 0 0 3px hsla(var(--primary-hsl),.06)}.bc-year-header{cursor:pointer;text-align:left;background:0 0;border:none;align-items:center;gap:16px;width:100%;padding:16px 20px;transition:background-color .12s;display:flex}.bc-year-header:hover{background:var(--background-secondary)}.bc-year-left{align-items:center;gap:10px;min-width:120px;display:flex}.bc-year-num{color:var(--text-primary);font-size:1.4rem;font-weight:800;line-height:1}.bc-current-badge{text-transform:uppercase;letter-spacing:.04em;background:hsla(var(--primary-hsl),.12);color:var(--primary);border-radius:999px;padding:2px 7px;font-size:.68rem;font-weight:700}.bc-tx-count{color:var(--text-tertiary);margin-left:auto;font-size:.78rem;font-weight:500}.bc-year-stats{flex:1;justify-content:flex-end;align-items:center;gap:20px;display:flex}.bc-year-stat{font-variant-numeric:tabular-nums;align-items:center;gap:5px;font-size:.875rem;font-weight:600;display:flex}.bc-year-stat.income{color:var(--status-green)}.bc-year-stat.expense{color:var(--status-red)}.bc-year-balance{font-variant-numeric:tabular-nums;text-align:right;min-width:110px;font-size:.9375rem;font-weight:700}.bc-year-balance.positive{color:var(--status-green)}.bc-year-balance.negative{color:var(--status-red)}.bc-year-toggle{color:var(--text-secondary);flex-shrink:0}.bc-bars{flex-direction:column;gap:6px;padding:0 20px 16px;display:flex}.bc-bar-row{align-items:center;gap:10px;display:flex}.bc-bar-label{color:var(--text-secondary);flex-shrink:0;width:64px;font-size:.75rem;font-weight:500}.bc-bar-track{background:var(--background-tertiary,var(--border-color-light));border-radius:3px;flex:1;height:6px;overflow:hidden}.bc-bar-fill{border-radius:3px;height:100%;transition:width .4s}.bc-bar-fill.income{background:var(--status-green)}.bc-bar-fill.expense{background:var(--status-red)}.bc-bar-value{font-variant-numeric:tabular-nums;text-align:right;min-width:100px;font-size:.8rem;font-weight:600}.bc-bar-value.income{color:var(--status-green)}.bc-bar-value.expense{color:var(--status-red)}.bc-months{border-top:1px solid var(--border-color-light);background:var(--background-secondary)}.bc-months-head{text-transform:uppercase;letter-spacing:.05em;color:var(--text-secondary);border-bottom:1px solid var(--border-color-light);grid-template-columns:1fr 1fr 1fr 1fr;padding:8px 20px;font-size:.7rem;font-weight:700;display:grid}.bc-month-row{border-bottom:1px solid var(--border-color-light);grid-template-columns:1fr 1fr 1fr 1fr;padding:9px 20px;transition:background-color .1s;display:grid}.bc-month-row:last-child{border-bottom:none}.bc-month-row:hover:not(.totals){background:var(--content-background)}.bc-month-row.current-month{background:hsla(var(--primary-hsl),.04)}.bc-month-row.current-month:hover{background:hsla(var(--primary-hsl),.08)}.bc-month-row.totals{background:var(--content-background);border-top:2px solid var(--border-color-light);border-bottom:none}.bc-month-name{color:var(--text-primary);align-items:center;gap:6px;font-size:.875rem;font-weight:500;display:flex}.bc-cur-dot{background:var(--primary);border-radius:50%;flex-shrink:0;width:6px;height:6px}.bc-month-val{font-variant-numeric:tabular-nums;text-align:right;font-size:.875rem}.bc-month-val.income{color:var(--status-green)}.bc-month-val.expense{color:var(--status-red)}.bc-month-val.positive{color:var(--status-green)}.bc-month-val.negative{color:var(--status-red)}.bc-month-val.bold{font-weight:700}.bc-month-val.zero{color:var(--text-tertiary)}.bc-no-months{color:var(--text-tertiary);border-top:1px solid var(--border-color-light);padding:16px 20px;font-size:.875rem}.vehicle-detail{padding:0}.vehicle-title{color:var(--text-primary);margin:0;font-size:1.5rem;font-weight:600}.error-state{color:#dc2626}.error-banner{color:#dc2626;border-radius:var(--radius);background-color:#fee2e2;margin-bottom:1rem;padding:.75rem 1rem}.detail-grid{grid-template-columns:2fr 1fr;gap:1.5rem;margin-bottom:1.5rem;display:grid}@media (max-width:1024px){.detail-grid{grid-template-columns:1fr}}.detail-card{background-color:var(--content-background);border:1px solid var(--border-color);border-radius:var(--radius);padding:1.5rem}.card-header{justify-content:space-between;align-items:center;margin-bottom:1rem;display:flex}.card-title{color:var(--text-primary);align-items:center;gap:.5rem;margin:0 0 1rem;font-size:1.125rem;font-weight:600;display:flex}.card-header .card-title{margin-bottom:0}.form-section{margin-bottom:1.5rem}.section-title{color:var(--text-primary);border-bottom:1px solid var(--border-color-light);margin-bottom:1rem;padding-bottom:.5rem;font-size:1.1rem;font-weight:600}.form-grid{grid-template-columns:1fr 1fr;gap:1rem;display:grid}.form-group{flex-direction:column;gap:.5rem;display:flex}.dynamic-list{flex-direction:column;gap:.75rem;display:flex}.dynamic-list-item{grid-template-columns:3fr 1fr 1fr auto;align-items:center;gap:.75rem;display:grid}.dynamic-list-item select,.dynamic-list-item input{border:1px solid var(--border-color-strong);background-color:var(--content-background);width:100%;color:var(--text-primary);border-radius:8px;padding:10px 12px;font-family:inherit;font-size:.9rem;transition:border-color .2s,box-shadow .2s}.dynamic-list-item select:focus,.dynamic-list-item input:focus{border-color:var(--primary);outline:none;box-shadow:0 0 0 3px #4a69ff26}.dynamic-list-item select::placeholder,.dynamic-list-item input::placeholder{color:var(--text-tertiary)}.dynamic-list-item input[type=number]{text-align:right}.parts-item-card{border:1px solid var(--border-color-strong,#d1d5db);background-color:var(--content-background,#fff);border-radius:8px;flex-direction:column;gap:.5rem;padding:.75rem;display:flex}.parts-item-card .parts-item-top{align-items:center;gap:.5rem;display:flex}.parts-item-card .parts-item-top select{border:1px solid var(--border-color-strong,#d1d5db);background-color:var(--content-background,#fff);color:var(--text-primary,#111);appearance:none;cursor:pointer;background-image:url(data:image/svg+xml;charset=US-ASCII,%3Csvg%20width%3D%2220%22%20height%3D%2220%22%20xmlns%3D%22http%3A//www.w3.org/2000/svg%22%3E%3Cpath%20d%3D%22M5%208l5%205%205-5z%22%20fill%3D%22%239CA3AF%22/%3E%3C/svg%3E);background-position:right 8px center;background-repeat:no-repeat;background-size:16px;border-radius:8px;flex:1;padding:10px 36px 10px 12px;font-family:inherit;font-size:.9rem;transition:border-color .2s,box-shadow .2s}.parts-item-card .parts-item-top select:focus{border-color:var(--primary);outline:none;box-shadow:0 0 0 3px #4a69ff26}.parts-item-card .parts-item-bottom{grid-template-columns:1fr 120px 1fr;gap:.5rem;display:grid}.parts-item-card .parts-field{flex-direction:column;gap:4px;display:flex}.parts-item-card .parts-field .parts-field-label{color:var(--text-tertiary);font-size:.75rem;font-weight:500}.parts-item-card .parts-field input{border:1px solid var(--border-color-strong,#d1d5db);background-color:var(--content-background,#fff);width:100%;color:var(--text-primary,#111);border-radius:8px;padding:8px 10px;font-family:inherit;font-size:.9rem;transition:border-color .2s,box-shadow .2s}.parts-item-card .parts-field input:focus{border-color:var(--primary);outline:none;box-shadow:0 0 0 3px #4a69ff26}.parts-item-card .parts-field input[type=number]{text-align:right}.parts-item-card .parts-field .unit-readonly{background-color:var(--background-secondary,#f3f4f6);color:var(--text-secondary,#6b7280);cursor:default;text-align:center;font-weight:500}.add-button{background-color:var(--primary-light);color:var(--primary);border:1px solid var(--primary);border-radius:var(--radius);cursor:pointer;align-self:flex-start;align-items:center;gap:.5rem;padding:.5rem 1rem;font-weight:500;transition:all .2s;display:flex}.add-button:hover{background-color:var(--primary);color:#fff}.remove-button{width:36px;height:36px;color:var(--status-red);border:1px solid var(--status-red);border-radius:var(--radius);cursor:pointer;background-color:#0000;flex-shrink:0;justify-content:center;align-items:center;padding:0;transition:all .2s;display:flex}.remove-button:hover{background-color:var(--status-red);color:#fff}.loading-modal{text-align:center;color:var(--text-secondary);padding:40px}.form-error{background-color:var(--status-red-bg);color:var(--status-red);border-radius:var(--radius);margin-bottom:1rem;padding:.75rem 1rem;font-size:.9rem}.tabs{border-bottom:1px solid var(--border-color-light);gap:12px;margin-bottom:24px;display:flex}.tab-button{cursor:pointer;color:var(--text-secondary);background-color:#0000;border:none;border-bottom:2px solid #0000;margin-bottom:-1px;padding:10px 20px;font-size:.95rem;font-weight:600;transition:all .2s ease-in-out}.tab-button.active{color:var(--primary);border-bottom-color:var(--primary)}.tab-button:hover:not(.active){color:var(--text-primary);background-color:var(--background-hover);border-radius:var(--radius)var(--radius)0 0}.placeholder{background-color:var(--content-background);border-radius:var(--radius);border:1px dashed var(--border-color-light);color:var(--text-secondary);justify-content:center;align-items:center;padding:60px;font-size:1rem;font-weight:500;display:flex}.request-detail{padding:0}.detail-header{align-items:center;gap:1rem;margin-bottom:1.5rem;display:flex}.back-button{border:1px solid var(--border-color);border-radius:var(--radius);cursor:pointer;color:var(--text-secondary);background:0 0;align-items:center;gap:.5rem;padding:.5rem 1rem;font-size:.875rem;transition:all .2s;display:flex}.back-button:hover{background-color:var(--background-secondary);color:var(--text-primary)}.export-button{background:var(--primary);color:#fff;border-radius:var(--radius);cursor:pointer;border:none;align-items:center;gap:.5rem;padding:.5rem 1rem;font-size:.875rem;font-weight:500;transition:all .2s;display:flex}.export-button:hover{opacity:.9}.export-button:active{transform:scale(.98)}.page-title{color:var(--text-primary);margin:0;font-size:1.5rem;font-weight:600}.loading-state,.error-state{text-align:center;color:var(--text-secondary);padding:3rem}.error-state{color:var(--status-red);background-color:var(--status-red-bg);border-radius:var(--radius)}.error-banner{background-color:var(--status-red-bg);color:var(--status-red);border-radius:var(--radius);margin-bottom:1rem;padding:.75rem 1rem}.detail-card{background-color:var(--content-background);border:1px solid var(--border-color-light);border-radius:var(--radius);margin-bottom:1.5rem;padding:1.5rem}.card-title{color:var(--text-primary);border-bottom:1px solid var(--border-color-light);align-items:center;gap:.5rem;margin:0 0 1rem;padding-bottom:.75rem;font-size:1.125rem;font-weight:600;display:flex}.section-title{color:var(--text-primary);margin:1.5rem 0 1rem;font-size:1rem;font-weight:600}.info-grid{grid-template-columns:repeat(2,1fr);gap:1rem;display:grid}@media (max-width:768px){.info-grid{grid-template-columns:1fr}}.info-item{flex-direction:column;gap:.25rem;display:flex}.info-item.full-width{grid-column:1/-1}.info-label{text-transform:uppercase;letter-spacing:.05em;color:var(--text-tertiary);font-size:.75rem;font-weight:500}.info-value{color:var(--text-primary);font-size:.9375rem}.info-value.rejection-text{color:var(--status-red)}.price-input{border:1px solid var(--border-color-strong);text-align:right;background-color:var(--content-background);border-radius:6px;width:120px;padding:6px 10px;font-size:.875rem}.price-input:focus{border-color:var(--primary);outline:none;box-shadow:0 0 0 2px #4a69ff26}.date-input{border:1px solid var(--border-color-strong);background-color:var(--content-background);width:100%;max-width:300px;color:var(--text-primary);border-radius:6px;padding:10px 12px;font-family:inherit;font-size:.9375rem}.date-input:focus{border-color:var(--primary);outline:none;box-shadow:0 0 0 2px #4a69ff26}.info-help{color:var(--text-tertiary);margin-top:.25rem;font-size:.8125rem}.approved-value{color:var(--status-green);font-weight:600}.total-card{background-color:var(--background-secondary)}.total-row{justify-content:space-between;align-items:center;display:flex}.total-label{color:var(--text-primary);font-size:1rem;font-weight:600}.total-value{color:var(--primary);font-size:1.5rem;font-weight:700}.action-bar{border-top:1px solid var(--border-color-light);gap:1rem;margin-top:1.5rem;padding-top:1.5rem;display:flex}.btn{border-radius:var(--radius);cursor:pointer;border:none;align-items:center;gap:.5rem;padding:12px 24px;font-size:1rem;font-weight:600;transition:all .2s;display:flex}.btn:disabled{opacity:.6;cursor:not-allowed}.btn-success{background-color:var(--status-green);color:#fff}.btn-success:hover:not(:disabled){background-color:#2da44e}.btn-danger{background-color:var(--status-red);color:#fff}.btn-danger:hover:not(:disabled){background-color:#e53935}.modal-backdrop{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:1000;background-color:#64748b66;justify-content:center;align-items:center;width:100%;height:100%;display:flex;position:fixed;top:0;left:0}.modal-content{background-color:var(--content-background);border-radius:var(--radius);width:80vw;min-width:520px;max-width:800px;box-shadow:var(--shadow-lg);border:1px solid var(--border-color-strong);padding:32px}.modal-header{border-bottom:1px solid var(--border-color);justify-content:space-between;align-items:center;margin-bottom:24px;padding-bottom:16px;display:flex}.modal-header h2{color:var(--text-primary);margin:0;font-size:1.25rem;font-weight:600}.close-button{cursor:pointer;color:var(--text-tertiary);background:0 0;border:none;padding:4px;font-size:1.5rem;transition:color .2s}.close-button:hover{color:var(--text-primary)}.form-group{margin-bottom:1rem}.form-group label{color:var(--text-secondary);margin-bottom:.5rem;font-size:.875rem;font-weight:500;display:block}.form-group textarea{border:1px solid var(--border-color-strong);border-radius:var(--radius);background-color:var(--content-background);resize:vertical;width:100%;padding:12px 16px;font-family:inherit;font-size:1rem}.form-group textarea:focus{border-color:var(--primary);outline:none;box-shadow:0 0 0 3px #4a69ff26}.form-actions{justify-content:flex-end;gap:1rem;margin-top:1.5rem;display:flex}.button-primary,.button-secondary{border-radius:var(--radius);cursor:pointer;border:none;padding:12px 24px;font-size:1rem;font-weight:600;transition:all .2s}.button-primary:disabled,.button-secondary:disabled{opacity:.6;cursor:not-allowed}.button-primary{background-color:var(--primary);color:#fff}.button-primary:hover:not(:disabled){background-color:var(--primary-hover)}.button-primary.btn-danger{background-color:var(--status-red)}.button-primary.btn-danger:hover:not(:disabled){background-color:#e53935}.button-secondary{background-color:var(--background-secondary);color:var(--text-secondary);border:1px solid var(--border-color)}.button-secondary:hover:not(:disabled){background-color:var(--background-tertiary);color:var(--text-primary)}.auth-container{background-color:var(--background-primary);justify-content:center;align-items:center;min-height:100vh;padding:24px;display:flex}.auth-card{border-radius:var(--radius);width:100%;max-width:400px;box-shadow:var(--shadow-lg);border:1px solid var(--border-color);padding:40px}.auth-title{text-align:center;color:var(--text-primary);margin:0 0 8px;font-size:1.75rem;font-weight:700}.auth-subtitle{text-align:center;color:var(--text-secondary);margin:0 0 32px;font-size:1rem}.auth-form-group{margin-bottom:20px}.auth-form-group label{color:var(--text-secondary);margin-bottom:8px;font-size:.875rem;font-weight:600;display:block}.auth-form-group input{border:1px solid var(--border-color-grey);border-radius:var(--radius);background-color:var(--background-secondary);width:100%;padding:12px 16px;font-family:inherit;font-size:1rem;transition:border-color .2s,box-shadow .2s}.auth-form-group input:focus{border-color:var(--primary);outline:none;box-shadow:0 0 0 3px #3f76ff33}.auth-button{border-radius:var(--radius);cursor:pointer;background-color:var(--primary);width:100%;color:var(--text-white);box-shadow:var(--shadow-sm);border:none;margin-top:8px;padding:14px 24px;font-size:1rem;font-weight:600;transition:all .2s}.auth-button:hover{background-color:var(--primary-hover);box-shadow:var(--shadow-md);transform:translateY(-1px)}.auth-footer{text-align:center;color:var(--text-secondary);margin:24px 0 0;font-size:.9rem}.auth-footer a{color:var(--primary);font-weight:600;text-decoration:none}.auth-footer a:hover{text-decoration:underline}.auth-error{color:#dc2626;border-radius:var(--radius);text-align:center;background-color:#fef2f2;border:1px solid #fecaca;margin-bottom:20px;padding:12px 16px;font-size:.875rem}.auth-button:disabled{opacity:.7;cursor:not-allowed;transform:none}.auth-form-group input:disabled{opacity:.7;cursor:not-allowed}.password-input-wrapper{align-items:center;display:flex;position:relative}.password-input-wrapper input{width:100%;padding-right:40px}.password-input-wrapper .eye-button{cursor:pointer;color:#666;background:0 0;border:none;justify-content:center;align-items:center;padding:0;display:flex;position:absolute;right:10px}.password-input-wrapper .eye-button:hover{color:#333}.users-page .page-header{margin-bottom:2rem}.user-detail-page .detail-header{margin-bottom:1.5rem}.user-detail-page .back-button{border:1px solid var(--border-color);border-radius:var(--radius);background-color:var(--content-background);color:var(--text-secondary);cursor:pointer;align-items:center;gap:8px;padding:8px 16px;font-size:.9rem;transition:all .2s;display:inline-flex}.user-detail-page .back-button:hover{background-color:var(--background-secondary);color:var(--text-primary)}.user-detail-page .loading-state,.user-detail-page .error-state{text-align:center;color:var(--text-secondary);padding:3rem}.user-detail-page .error-state{color:var(--status-red);background-color:var(--status-red-bg);border-radius:var(--radius)}.user-detail-page .profile-header{background-color:var(--content-background);border-radius:var(--radius);border:1px solid var(--border-color-light);align-items:center;gap:1.5rem;margin-bottom:1.5rem;padding:1.5rem;display:flex}.user-detail-page .profile-avatar{background:linear-gradient(135deg,var(--primary)0%,var(--primary-hover)100%);color:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:72px;height:72px;font-size:1.5rem;font-weight:600;display:flex}.user-detail-page .profile-info{flex:1}.user-detail-page .profile-name{color:var(--text-primary);margin:0 0 .5rem;font-size:1.5rem;font-weight:600}.user-detail-page .profile-meta{align-items:center;gap:.75rem;display:flex}.user-detail-page .role-badge{background-color:var(--primary-light);color:var(--primary);border-radius:20px;align-items:center;padding:4px 12px;font-size:.85rem;font-weight:500;display:inline-flex}.user-detail-page .edit-button{background-color:var(--primary);color:#fff;border-radius:var(--radius);cursor:pointer;border:none;align-items:center;gap:8px;padding:10px 20px;font-size:.9rem;font-weight:500;transition:all .2s;display:flex}.user-detail-page .edit-button:hover{background-color:var(--primary-hover)}.user-detail-page .detail-grid{grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:1.5rem;margin-bottom:1.5rem;display:grid}.user-detail-page .detail-card{background-color:var(--content-background);border-radius:var(--radius);border:1px solid var(--border-color-light);padding:1.5rem}.user-detail-page .detail-card.driver-card{margin-top:0}.user-detail-page .card-title{color:var(--text-primary);border-bottom:1px solid var(--border-color-light);align-items:center;gap:.5rem;margin:0 0 1.25rem;padding-bottom:.75rem;font-size:1.1rem;font-weight:600;display:flex}.user-detail-page .card-title svg{color:var(--primary)}.user-detail-page .info-list{flex-direction:column;gap:1rem;display:flex}.user-detail-page .info-row{align-items:flex-start;gap:1rem;display:flex}.user-detail-page .info-icon{background-color:var(--background-secondary);width:36px;height:36px;color:var(--primary);border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;display:flex}.user-detail-page .info-content{flex-direction:column;gap:2px;display:flex}.user-detail-page .info-label{color:var(--text-tertiary);font-size:.8rem;font-weight:500}.user-detail-page .info-value{color:var(--text-primary);font-size:.95rem;font-weight:500}.user-detail-page .license-grid{grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1.25rem;display:grid}.user-detail-page .license-item.full-width{grid-column:1/-1}.user-detail-page .license-label{color:var(--text-tertiary);margin-bottom:4px;font-size:.8rem;font-weight:500;display:block}.user-detail-page .license-value{color:var(--text-primary);font-size:.95rem;font-weight:500;display:block}.user-detail-page .license-value.highlight{color:var(--primary)}.user-detail-page .no-license{text-align:center;color:var(--text-tertiary);flex-direction:column;justify-content:center;align-items:center;padding:2rem;display:flex}.user-detail-page .no-license svg{color:var(--text-tertiary);margin-bottom:.75rem}.user-detail-page .no-license p{margin:0 0 1rem;font-size:.95rem}.user-detail-page .add-license-button{background-color:var(--primary-light);color:var(--primary);border:1px solid var(--primary);border-radius:var(--radius);cursor:pointer;align-items:center;gap:8px;padding:8px 16px;font-size:.9rem;font-weight:500;transition:all .2s;display:inline-flex}.user-detail-page .add-license-button:hover{background-color:var(--primary);color:#fff}.user-form-container{background-color:var(--content-background);border-radius:var(--radius);max-width:600px;box-shadow:var(--shadow-card);border:1px solid var(--border-color-light);margin:0 auto;padding:2rem}.user-form-container h2{text-align:center;color:var(--text-primary);margin-bottom:2rem}.user-form-container .user-form{flex-direction:column;gap:1.25rem;display:flex}.user-form-container .dept-memberships-section{border:1px solid var(--border-color-light);border-radius:var(--radius);background-color:var(--background-secondary);padding:1.25rem}.user-form-container .dept-memberships-section h3{color:var(--text-primary);margin:0 0 .375rem;font-size:1rem;font-weight:600}.user-form-container .dept-memberships-section .dept-hint{color:var(--text-secondary);margin:0 0 1rem;font-size:.8125rem}.user-form-container .dept-row{border-bottom:1px solid var(--border-color-light);align-items:center;gap:1rem;padding:.5rem 0;display:flex}.user-form-container .dept-row:last-child{border-bottom:none}.user-form-container .dept-check-label{cursor:pointer;min-width:160px;color:var(--text-primary);align-items:center;gap:.5rem;font-size:.9rem;font-weight:500;display:flex}.user-form-container .dept-check-label input[type=checkbox]{width:16px;height:16px;accent-color:var(--primary);cursor:pointer}.user-form-container .dept-role-select{border:1px solid var(--border-color-strong);border-radius:var(--radius);background-color:var(--content-background);color:var(--text-primary);flex:1;padding:6px 10px;font-size:.875rem}.user-form-container .dept-role-select:focus{border-color:var(--primary);outline:none}.user-form-container .driver-profile-toggle{margin:1rem 0}.user-form-container .driver-profile-toggle .toggle-button{background-color:var(--background-secondary);border:1px dashed var(--border-color-strong);border-radius:var(--radius);width:100%;color:var(--text-primary);cursor:pointer;text-align:left;padding:12px 16px;font-size:.9rem;font-weight:500;transition:all .2s}.user-form-container .driver-profile-toggle .toggle-button:hover{background-color:var(--background-tertiary);border-color:var(--primary);color:var(--primary)}.user-form-container .driver-profile-toggle .toggle-button:focus{border-color:var(--primary);outline:none;box-shadow:0 0 0 3px #4a69ff26}.user-form-container .driver-profile-section{border:1px solid var(--border-color-light);border-radius:var(--radius);background-color:var(--background-secondary);margin-top:1.5rem;padding:1.5rem}.user-form-container .driver-profile-section h3{color:var(--text-primary);border-bottom:2px solid var(--primary);margin-top:0;margin-bottom:1.5rem;padding-bottom:.5rem;font-size:1.125rem}.user-form-container .driver-profile-section .form-group{margin-bottom:1rem}.user-form-container .driver-profile-section .full-width{grid-column:1/-1}.user-form-container .form-group{flex-direction:column;display:flex}.user-form-container .form-group label{color:var(--text-secondary);margin-bottom:.5rem;font-size:.875rem;font-weight:500}.user-form-container .form-group input,.user-form-container .form-group select,.user-form-container .form-group textarea{border:1px solid var(--border-color-strong);border-radius:var(--radius);background-color:var(--content-background);color:var(--text-primary);padding:12px 16px;font-family:inherit;font-size:1rem;transition:border-color .2s,box-shadow .2s}.user-form-container .form-group input:focus,.user-form-container .form-group select:focus,.user-form-container .form-group textarea:focus{border-color:var(--primary);outline:none;box-shadow:0 0 0 3px #4a69ff26}.user-form-container .form-group input:disabled,.user-form-container .form-group select:disabled,.user-form-container .form-group textarea:disabled{opacity:.6;cursor:not-allowed;background-color:var(--background-secondary)}.user-form-container .form-group textarea{resize:vertical;min-height:80px}.user-form-container .form-group .error{color:var(--status-red);margin-top:.25rem;font-size:.875rem}.user-form-container .error-message{background-color:var(--status-red-bg);color:var(--status-red);border-radius:var(--radius);margin-bottom:1rem;padding:.75rem 1rem;font-size:.875rem}.user-form-container .form-actions{justify-content:flex-end;gap:1rem;margin-top:1.5rem;display:flex}.user-form-container .form-actions .btn{border-radius:var(--radius);cursor:pointer;border:none;padding:12px 24px;font-size:1rem;font-weight:600;transition:all .2s}.user-form-container .form-actions .btn:disabled{opacity:.6;cursor:not-allowed}.user-form-container .form-actions .btn-primary{background-color:var(--primary);color:#fff;box-shadow:var(--shadow-sm)}.user-form-container .form-actions .btn-primary:hover:not(:disabled){background-color:var(--primary-hover);box-shadow:var(--shadow-md)}.user-form-container .form-actions .btn-secondary{background-color:var(--background-secondary);color:var(--text-secondary);border:1px solid var(--border-color)}.user-form-container .form-actions .btn-secondary:hover:not(:disabled){background-color:var(--background-tertiary);color:var(--text-primary)}.role-form-modal{max-width:800px;max-height:90vh;overflow-y:auto}.role-form-modal .modal-header{border-bottom:2px solid var(--border-color-light);justify-content:space-between;align-items:center;margin-bottom:1.5rem;padding-bottom:1rem;display:flex}.role-form-modal .modal-header h2{color:var(--text-primary);margin:0;font-size:1.5rem}.role-form-modal .modal-header .close-button{color:var(--text-secondary);cursor:pointer;border-radius:var(--radius);background:0 0;border:none;justify-content:center;align-items:center;width:32px;height:32px;padding:0;font-size:2rem;line-height:1;transition:all .2s;display:flex}.role-form-modal .modal-header .close-button:hover{background-color:var(--background-secondary);color:var(--text-primary)}.role-form-modal .error-message{background-color:var(--status-red-bg);color:var(--status-red);border-radius:var(--radius);margin-bottom:1.5rem;padding:.75rem 1rem;font-size:.875rem}.role-form-modal .form-section{margin-bottom:2rem}.role-form-modal .form-section h3{color:var(--text-primary);margin:0 0 1rem;font-size:1.125rem;font-weight:600}.role-form-modal .form-section .form-group{margin-bottom:1.25rem}.role-form-modal .form-section .form-group label{color:var(--text-secondary);margin-bottom:.5rem;font-size:.875rem;font-weight:500;display:block}.role-form-modal .form-section .form-group input,.role-form-modal .form-section .form-group textarea{border:1px solid var(--border-color-strong);border-radius:var(--radius);background-color:var(--content-background);width:100%;color:var(--text-primary);padding:.75rem;font-family:inherit;font-size:1rem;transition:border-color .2s,box-shadow .2s}.role-form-modal .form-section .form-group input:focus,.role-form-modal .form-section .form-group textarea:focus{border-color:var(--primary);outline:none;box-shadow:0 0 0 3px #4a69ff26}.role-form-modal .form-section .form-group input:disabled,.role-form-modal .form-section .form-group textarea:disabled{opacity:.6;cursor:not-allowed;background-color:var(--background-secondary)}.role-form-modal .form-section .form-group textarea{resize:vertical;min-height:80px}.role-form-modal .form-section .form-group .error{color:var(--status-red);margin-top:.25rem;font-size:.875rem}.role-form-modal .combine-departments-section{margin-bottom:1.25rem}.role-form-modal .combine-departments-toggle{border:1px solid var(--border-color-light);border-radius:var(--radius);background-color:var(--background-secondary);cursor:pointer;align-items:flex-start;gap:.875rem;padding:1rem;transition:border-color .2s,background-color .2s;display:flex}.role-form-modal .combine-departments-toggle:hover{border-color:var(--border-color-strong);background-color:var(--content-background)}.role-form-modal .combine-departments-toggle:has(input:checked){background-color:#4a69ff0d;border-color:#4a69ff66}.role-form-modal .combine-departments-toggle input[type=checkbox]{cursor:pointer;width:16px;height:16px;accent-color:var(--primary);flex-shrink:0;margin-top:3px}.role-form-modal .combine-departments-info{flex-direction:column;gap:3px;display:flex}.role-form-modal .combine-departments-label{color:var(--text-primary);font-size:.9375rem;font-weight:600}.role-form-modal .combine-departments-desc{color:var(--text-secondary);margin:0;font-size:.8125rem;line-height:1.4}.role-form-modal .scope-accordion{flex-direction:column;gap:.5rem;display:flex}.role-form-modal .scope-group{border:1px solid var(--border-color-light);border-radius:var(--radius);overflow:hidden}.role-form-modal .scope-group.expanded{border-color:var(--border-color-strong)}.role-form-modal .scope-group-header{background-color:var(--background-secondary);cursor:pointer;-webkit-user-select:none;user-select:none;justify-content:space-between;align-items:center;padding:.75rem 1rem;transition:background-color .15s;display:flex}.role-form-modal .scope-group-header:hover{background-color:var(--content-background)}.role-form-modal .scope-group-title{color:var(--text-primary);align-items:center;gap:.5rem;font-size:.9375rem;font-weight:600;display:flex}.role-form-modal .scope-chevron{color:var(--text-secondary);flex-shrink:0;transition:transform .2s}.role-form-modal .scope-chevron.open{transform:rotate(180deg)}.role-form-modal .scope-perm-badge{background-color:var(--primary);color:#fff;border-radius:10px;justify-content:center;align-items:center;min-width:20px;height:20px;padding:0 6px;font-size:.7rem;font-weight:700;line-height:1;display:inline-flex}.role-form-modal .scope-group-body{border-top:1px solid var(--border-color-light);background-color:var(--content-background);padding:.75rem}.role-form-modal .permissions-grid{gap:.625rem;display:grid}.role-form-modal .permission-module{background-color:var(--background-secondary);border:1px solid var(--border-color-light);border-radius:var(--radius);transition:border-color .2s,box-shadow .2s;overflow:hidden}.role-form-modal .permission-module:hover{border-color:var(--border-color-strong)}.role-form-modal .permission-module.has-perms{border-color:#4a69ff59}.role-form-modal .permission-module.has-perms:hover{border-color:#4a69ff8c}.role-form-modal .permission-module.has-perms .module-header{background-color:#4a69ff0a}.role-form-modal .module-header{cursor:pointer;-webkit-user-select:none;user-select:none;justify-content:space-between;align-items:center;gap:.75rem;padding:.875rem 1rem;transition:background-color .15s;display:flex}.role-form-modal .module-header:hover{background-color:var(--content-background)}.role-form-modal .module-header-left{flex:1;align-items:flex-start;gap:.75rem;min-width:0;display:flex}.role-form-modal .module-header-left input[type=checkbox]{cursor:pointer;width:16px;height:16px;accent-color:var(--primary);flex-shrink:0;margin-top:3px}.role-form-modal .module-info{flex-direction:column;gap:2px;min-width:0;display:flex}.role-form-modal .module-name{color:var(--text-primary);font-size:.9375rem;font-weight:600}.role-form-modal .module-description{color:var(--text-secondary);margin:0;font-size:.8125rem;line-height:1.4}.role-form-modal .module-chevron{color:var(--text-secondary);flex-shrink:0;transition:transform .2s}.role-form-modal .module-chevron.open{transform:rotate(180deg)}.role-form-modal .module-content{border-top:1px solid var(--border-color-light);background-color:var(--content-background);flex-direction:column;gap:.75rem;padding:.875rem 1rem 1rem;display:flex}.role-form-modal .simple-actions{flex-wrap:wrap;gap:.5rem;display:flex}.role-form-modal .action-checkbox{cursor:pointer;border-radius:var(--radius);border:1px solid var(--border-color-light);background-color:var(--background-secondary);white-space:nowrap;align-items:center;gap:.5rem;padding:.375rem .625rem;transition:all .15s;display:flex}.role-form-modal .action-checkbox:hover{border-color:var(--border-color-strong);background-color:var(--content-background)}.role-form-modal .action-checkbox input[type=checkbox]{cursor:pointer;width:14px;height:14px;accent-color:var(--primary)}.role-form-modal .action-checkbox span{color:var(--text-secondary);font-size:.8125rem}.role-form-modal .action-checkbox:has(input:checked){background-color:#4a69ff0f;border-color:#4a69ff66}.role-form-modal .action-checkbox:has(input:checked) span{color:var(--primary);font-weight:500}.role-form-modal .granular-actions{flex-direction:column;gap:.75rem;display:flex}.role-form-modal .permission-group{background-color:var(--background-secondary);border-radius:var(--radius);border:1px solid var(--border-color-light);flex-direction:column;gap:.375rem;padding:.625rem .75rem;display:flex}.role-form-modal .permission-group .group-label{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.03em;font-size:.8rem;font-weight:600}.role-form-modal .radio-options{flex-direction:column;gap:.25rem;display:flex}.role-form-modal .radio-options.horizontal{flex-flow:wrap;gap:.5rem}.role-form-modal .radio-option{cursor:pointer;border-radius:calc(var(--radius) - 2px);align-items:center;gap:.5rem;padding:.3rem .5rem;transition:background-color .15s;display:flex}.role-form-modal .radio-option:hover{background-color:var(--content-background)}.role-form-modal .radio-option input[type=radio]{cursor:pointer;width:14px;height:14px;accent-color:var(--primary)}.role-form-modal .radio-option span{color:var(--text-secondary);font-size:.8125rem}.role-form-modal .radio-option:has(input:checked) span{color:var(--primary);font-weight:500}.role-form-modal .form-actions{border-top:1px solid var(--border-color-light);justify-content:flex-end;gap:1rem;margin-top:2rem;padding-top:1.5rem;display:flex}.role-form-modal .form-actions button{border-radius:var(--radius);cursor:pointer;border:none;padding:.75rem 1.5rem;font-size:1rem;font-weight:600;transition:all .2s}.role-form-modal .form-actions button:disabled{opacity:.6;cursor:not-allowed}.role-form-modal .form-actions .button-primary{background-color:var(--primary);color:#fff;box-shadow:var(--shadow-sm)}.role-form-modal .form-actions .button-primary:hover:not(:disabled){background-color:var(--primary-hover);box-shadow:var(--shadow-md)}.role-form-modal .form-actions .button-secondary{background-color:var(--background-secondary);color:var(--text-secondary);border:1px solid var(--border-color)}.role-form-modal .form-actions .button-secondary:hover:not(:disabled){background-color:var(--background-tertiary);color:var(--text-primary)}.roles-page .page-header{justify-content:space-between;align-items:center;margin-bottom:2rem;display:flex}.roles-page .page-header .page-title{color:var(--text-primary);align-items:center;gap:.75rem;margin:0;font-size:1.75rem;font-weight:700;display:flex}.roles-page .page-header .add-button{background-color:var(--primary);color:#fff;border-radius:var(--radius);cursor:pointer;box-shadow:var(--shadow-sm);border:none;align-items:center;gap:.5rem;padding:.75rem 1.5rem;font-weight:600;transition:all .2s;display:flex}.roles-page .page-header .add-button:hover{background-color:var(--primary-hover);box-shadow:var(--shadow-md);transform:translateY(-1px)}.roles-page .page-header .add-button:active{transform:translateY(0)}.roles-page .error-message{background-color:var(--status-red-bg);color:var(--status-red);border-radius:var(--radius);margin-bottom:1rem;padding:1rem}.roles-page .empty-state{text-align:center;color:var(--text-secondary);grid-column:1/-1;padding:4rem 2rem}.roles-page .empty-state svg{opacity:.5;margin-bottom:1rem}.roles-page .empty-state p{font-size:1.125rem}.roles-page .roles-grid{grid-template-columns:repeat(auto-fill,minmax(350px,1fr));gap:1.5rem;display:grid}.roles-page .role-card{background-color:var(--content-background);border:1px solid var(--border-color-light);border-radius:var(--radius);box-shadow:var(--shadow-card);padding:1.5rem;transition:all .2s}.roles-page .role-card:hover{box-shadow:var(--shadow-md);border-color:var(--border-color-strong)}.roles-page .role-card .role-card-header{justify-content:space-between;align-items:flex-start;margin-bottom:1rem;display:flex}.roles-page .role-card .role-card-header .role-info{flex:1}.roles-page .role-card .role-card-header .role-info .role-name{color:var(--text-primary);margin:0 0 .5rem;font-size:1.25rem;font-weight:700}.roles-page .role-card .role-card-header .role-info .system-badge{background-color:var(--primary-light);color:var(--primary);text-transform:uppercase;letter-spacing:.5px;border-radius:12px;padding:.25rem .75rem;font-size:.75rem;font-weight:600;display:inline-block}.roles-page .role-card .role-card-header .role-info .combined-badge{color:#059669;text-transform:uppercase;letter-spacing:.5px;background-color:#10b9811f;border-radius:12px;margin-left:.375rem;padding:.25rem .75rem;font-size:.75rem;font-weight:600;display:inline-block}.roles-page .role-card .role-card-header .role-actions{gap:.5rem;display:flex}.roles-page .role-card .role-card-header .role-actions .icon-button{border-radius:var(--radius);cursor:pointer;background-color:var(--background-secondary);width:32px;height:32px;color:var(--text-secondary);border:none;justify-content:center;align-items:center;transition:all .2s;display:flex}.roles-page .role-card .role-card-header .role-actions .icon-button:hover{transform:scale(1.1)}.roles-page .role-card .role-card-header .role-actions .icon-button.view:hover{background-color:var(--background-tertiary);color:var(--text-primary)}.roles-page .role-card .role-card-header .role-actions .icon-button.edit:hover{background-color:var(--primary-light);color:var(--primary)}.roles-page .role-card .role-card-header .role-actions .icon-button.delete:hover{background-color:var(--status-red-bg);color:var(--status-red)}.roles-page .role-card .role-description{color:var(--text-secondary);min-height:3rem;margin-bottom:1.5rem;font-size:.9rem;line-height:1.5}.roles-page .role-card .role-footer{border-top:1px solid var(--border-color-light);justify-content:space-between;align-items:center;padding-top:1rem;display:flex}.roles-page .role-card .role-footer .role-stat{color:var(--text-secondary);align-items:center;gap:.5rem;font-size:.875rem;display:flex}.roles-page .role-card .role-footer .role-stat svg{color:var(--primary)}.roles-page .role-card .role-footer .role-date{color:var(--text-tertiary);font-size:.75rem}.organization-settings{max-width:800px;margin:0 auto;padding:2rem}.organization-settings .settings-header{margin-bottom:2rem}.organization-settings .settings-header .back-button{border:1px solid var(--border-color);color:var(--text-secondary);cursor:pointer;background:0 0;border-radius:.5rem;align-items:center;gap:.5rem;margin-bottom:1rem;padding:.5rem 1rem;font-size:.875rem;transition:all .2s;display:inline-flex}.organization-settings .settings-header .back-button:hover{background:var(--hover-bg);border-color:var(--border-color-strong);color:var(--text-primary)}.organization-settings .settings-header .settings-title{color:var(--text-primary);margin:0;font-size:1.75rem;font-weight:700}.organization-settings .alert{border-radius:.5rem;margin-bottom:1.5rem;padding:1rem;font-size:.875rem}.organization-settings .alert.alert-error{background:var(--status-red-bg);color:var(--status-red);border:1px solid var(--status-red)}.organization-settings .alert.alert-success{background:var(--status-green-bg);color:var(--status-green);border:1px solid var(--status-green)}.organization-settings .settings-content{flex-direction:column;gap:1.5rem;display:flex}.organization-settings .settings-content .settings-card{background:var(--content-background);border:1px solid var(--border-color);border-radius:.75rem;padding:2rem}.organization-settings .settings-content .settings-card .card-title{color:var(--text-primary);margin:0 0 .5rem;font-size:1.25rem;font-weight:600}.organization-settings .settings-content .settings-card .card-description{color:var(--text-secondary);margin:0 0 2rem;font-size:.875rem;line-height:1.5}.organization-settings .settings-content .settings-card .form-group{margin-bottom:1.5rem}.organization-settings .settings-content .settings-card .form-group .form-label{color:var(--text-primary);margin-bottom:.5rem;font-size:.875rem;font-weight:500;display:block}.organization-settings .settings-content .settings-card .form-group .form-input{border:1px solid var(--border-color);background:var(--input-background);width:100%;max-width:400px;color:var(--text-primary);border-radius:.5rem;padding:.75rem;font-family:inherit;font-size:.875rem;transition:all .2s}.organization-settings .settings-content .settings-card .form-group .form-input:focus{border-color:var(--primary-color);box-shadow:0 0 0 3px var(--primary-color-alpha-20);outline:none}.organization-settings .settings-content .settings-card .form-group select{border:1px solid var(--border-color);background:var(--input-background);width:100%;max-width:300px;color:var(--text-primary);border-radius:.5rem;padding:.75rem;font-size:.875rem;transition:all .2s}.organization-settings .settings-content .settings-card .form-group select:focus{border-color:var(--primary-color);box-shadow:0 0 0 3px var(--primary-color-alpha-20);outline:none}.organization-settings .form-actions{gap:1rem;display:flex}.organization-settings .form-actions .btn{cursor:pointer;border:none;border-radius:.5rem;align-items:center;gap:.5rem;padding:.75rem 1.5rem;font-size:.875rem;font-weight:500;transition:all .2s;display:inline-flex}.organization-settings .form-actions .btn.btn-primary{background:var(--primary);color:#fff}.organization-settings .form-actions .btn.btn-primary:hover:not(:disabled){background:var(--primary-hover)}.organization-settings .form-actions .btn.btn-primary:disabled{opacity:.6;cursor:not-allowed}.organization-settings .form-actions .btn .spinner{animation:1s linear infinite spin}
