.top-navigation{background:linear-gradient(90deg,#0078d4,#0063b1);box-shadow:0 2px 4px #0000001a;position:-webkit-sticky;position:sticky;top:0;z-index:1000}.nav-container{width:100%;margin:0;padding:0 20px;display:flex;align-items:center;justify-content:space-between;height:56px}.nav-brand{display:flex;align-items:center;gap:12px}.brand-icon{flex-shrink:0}.brand-text h1{font-size:18px;font-weight:600;color:#fff;margin:0;line-height:1.2}.brand-text p{font-size:11px;color:#ffffffd9;margin:0;line-height:1}.nav-menu{display:flex;gap:0;flex:1;justify-content:center;max-width:900px}.nav-item{display:flex;align-items:center;gap:6px;padding:16px 20px;background:transparent;border:none;border-bottom:3px solid transparent;color:#ffffffe6;font-size:13px;font-weight:500;cursor:pointer;transition:all .2s;white-space:nowrap;height:56px}.nav-item:hover{background:#ffffff1a;color:#fff;border-bottom-color:#ffffff4d}.nav-item.active{background:#ffffff26;color:#fff;font-weight:600;border-bottom-color:#fff}.nav-item svg{flex-shrink:0;width:18px;height:18px}.nav-user{display:flex;align-items:center;gap:16px}.user-info{display:flex;flex-direction:column;align-items:flex-end;gap:2px}.user-name{font-size:13px;font-weight:600;color:#fff;line-height:1}.user-role{font-size:11px;color:#fffc;line-height:1}.logout-button{display:flex;align-items:center;justify-content:center;width:36px;height:36px;background:#ffffff26;border:none;border-radius:4px;color:#fff;cursor:pointer;transition:all .2s}.logout-button:hover{background:#ffffff40}@media (max-width: 1200px){.nav-item span{display:none}.nav-item{padding:16px 12px}}@media (max-width: 768px){.nav-container{padding:0 16px;height:56px}.brand-text p{display:none}.brand-text h1{font-size:16px}.user-info{display:none}.nav-menu{gap:0}}.nav-item.highlight{background:linear-gradient(135deg,#10b981,#059669);color:#fff;font-weight:600;box-shadow:0 2px 8px #10b9814d;animation:pulse 2s infinite}.nav-item.highlight:hover{background:linear-gradient(135deg,#059669,#047857);transform:translateY(-1px);box-shadow:0 4px 12px #10b98166}.nav-item.highlight.active{background:linear-gradient(135deg,#047857,#065f46);box-shadow:0 4px 16px #10b98180}@keyframes pulse{0%,to{box-shadow:0 2px 8px #10b9814d}50%{box-shadow:0 2px 12px #10b98180}}.notification-bell{position:relative;margin-right:20px;cursor:pointer;color:#ffffffe6;padding:8px;border-radius:50%;transition:all .2s}.notification-bell:hover{background:#ffffff1a;color:#fff}.notification-badge{position:absolute;top:0;right:0;background:#ef4444;color:#fff;font-size:10px;font-weight:700;height:18px;width:18px;display:flex;align-items:center;justify-content:center;border-radius:50%;border:2px solid white}.notif-dropdown{position:absolute;top:100%;right:-50px;width:300px;background:#fff;box-shadow:0 10px 15px -3px #0000001a;border-radius:8px;border:1px solid #e2e8f0;z-index:50;margin-top:10px;max-height:400px;overflow-y:auto}.notif-item{padding:12px;border-bottom:1px solid #f1f5f9;font-size:13px;color:#334155;transition:bg .2s}.notif-item:hover{background:#f8fafc}.notif-item:last-child{border-bottom:none}.notif-date{display:block;font-size:11px;color:#94a3b8;margin-top:4px}.notif-empty{padding:20px;text-align:center;color:#94a3b8;font-size:13px}.profile-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#00000080;display:flex;justify-content:center;align-items:center;z-index:2000;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px)}.profile-modal{background:#fff;border-radius:12px;width:450px;max-width:90%;box-shadow:0 10px 25px #0003;display:flex;flex-direction:column;overflow:hidden;animation:slideIn .3s ease-out}@keyframes slideIn{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.profile-header{background:#f8fafc;padding:16px 24px;border-bottom:1px solid #e2e8f0;display:flex;justify-content:space-between;align-items:center}.profile-header h2{margin:0;font-size:18px;color:#1e293b;font-weight:600}.close-button{background:none;border:none;font-size:24px;color:#64748b;cursor:pointer;line-height:1}.close-button:hover{color:#0f172a}.profile-content{padding:24px}.profile-avatar-section{display:flex;align-items:center;gap:16px;margin-bottom:24px}.profile-avatar{width:64px;height:64px;background:linear-gradient(135deg,#3b82f6,#1d4ed8);border-radius:50%;display:flex;justify-content:center;align-items:center;color:#fff;font-size:24px;font-weight:700;box-shadow:0 4px 6px #3b82f64d}.profile-main-info h3{margin:0 0 4px;font-size:18px;color:#1e293b}.profile-role{margin:0;color:#64748b;font-size:14px;background:#f1f5f9;padding:4px 8px;border-radius:4px;display:inline-block}.profile-details-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px}.detail-item{background:#f8fafc;padding:12px;border-radius:8px;border:1px solid #e2e8f0}.detail-item.full-width{grid-column:span 2}.detail-item label{display:block;font-size:11px;text-transform:uppercase;color:#64748b;margin-bottom:4px;font-weight:600;letter-spacing:.5px}.detail-item p{margin:0;font-size:14px;color:#334155;font-weight:500;word-break:break-all}.location-text{color:#0f172a!important;font-weight:600!important}.status-badge{font-size:12px;padding:2px 8px;border-radius:12px;font-weight:600}.status-badge.active{background:#dcfce7;color:#166534}.status-badge.inactive{background:#fee2e2;color:#991b1b}.province-tags{display:flex;flex-wrap:wrap;gap:6px;margin-top:4px}.province-tag{background:#e0f2fe;color:#0369a1;font-size:11px;padding:2px 8px;border-radius:10px;border:1px solid #bae6fd}.profile-footer{padding:16px 24px;background:#f8fafc;border-top:1px solid #e2e8f0;display:flex;justify-content:flex-end}.close-modal-btn{padding:8px 24px;background:#fff;border:1px solid #cbd5e1;border-radius:6px;color:#475569;font-weight:600;cursor:pointer;transition:all .2s}.close-modal-btn:hover{background:#f1f5f9;border-color:#94a3b8}.welcome-banner{background:linear-gradient(135deg,#1e3c72,#2a5298);padding:12px 24px;display:flex;justify-content:space-between;align-items:center;color:#fff;border-radius:0;margin:20px 0;box-shadow:0 2px 8px #0000001a}.welcome-content{display:flex;align-items:center;gap:16px;flex:1}.welcome-message{display:flex;align-items:center;gap:10px}.welcome-emoji{font-size:24px;animation:wave 1.5s ease-in-out infinite}@keyframes wave{0%,to{transform:rotate(0)}25%{transform:rotate(20deg)}75%{transform:rotate(-10deg)}}.welcome-text{font-size:16px;color:#fffffff2;display:flex;align-items:center;gap:8px}.welcome-text strong{font-weight:600;color:#fff}.user-role{font-size:13px;color:#ffffffbf;font-weight:400}.user-location{font-size:13px;color:#ffffffb3;font-weight:400}.welcome-time{display:flex;align-items:center;gap:6px;font-size:14px;color:#ffffffe6}.welcome-datetime{display:flex;align-items:center;gap:8px;background:#ffffff26;padding:8px 16px;border-radius:6px;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.datetime-icon{font-size:18px}.datetime-text{font-family:Courier New,monospace;font-size:14px;font-weight:600;letter-spacing:.5px}@media (max-width: 768px){.welcome-banner{flex-direction:column;gap:12px;padding:16px}.welcome-datetime{width:100%;justify-content:center}}.app-footer{text-align:center;padding:32px 16px 24px;margin-top:48px;border-top:1px solid #e2e8f0;background:#f8fafc;color:#64748b}.footer-copyright{margin:0 0 8px;font-size:14px;font-weight:500;color:#475569}.footer-dev{margin:0;font-size:13px;color:#94a3b8}body.dark .app-footer{background:#0f172a;border-color:#334155}body.dark .footer-copyright{color:#cbd5e1}body.dark .footer-dev{color:#94a3b8}.login-container{min-height:100vh;display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden}.login-background{position:absolute;top:0;left:0;right:0;bottom:0;background:linear-gradient(135deg,#003087,#002366,#001a4d);z-index:0}.gradient-overlay{position:absolute;top:0;left:0;right:0;bottom:0;background:radial-gradient(circle at 30% 50%,rgba(255,255,255,.1) 0%,transparent 50%)}.login-card{position:relative;z-index:1;background:#fff;border-radius:16px;box-shadow:0 20px 60px #0000004d;width:100%;max-width:440px;margin:20px;overflow:hidden}.login-header{padding:40px 40px 32px;text-align:center;background:linear-gradient(to bottom,#f8fafc,#fff);border-bottom:1px solid #e2e8f0}.logo-section{display:flex;flex-direction:column;align-items:center;gap:16px}.logo-icon{animation:fadeInDown .6s ease-out}.login-header h1{font-size:24px;font-weight:700;color:#1e293b;margin:0;line-height:1.3;animation:fadeInUp .6s ease-out .1s both}.subtitle{font-size:14px;color:#64748b;margin:0;animation:fadeInUp .6s ease-out .2s both}.login-form{padding:32px 40px 40px}.error-message{display:flex;align-items:center;gap:8px;padding:12px 16px;background:#fef2f2;border:1px solid #fecaca;border-radius:8px;color:#dc2626;font-size:14px;margin-bottom:24px;animation:shake .4s ease-out}.form-group label{display:block;font-size:14px;font-weight:500;color:#334155;margin-bottom:8px}.form-group input{width:100%;padding:12px 16px;font-size:15px;border:1px solid #e2e8f0;border-radius:8px;transition:all .2s;background:#fff}.form-group input:focus{outline:none;border-color:#003087;box-shadow:0 0 0 3px #0030871a}.form-group input::placeholder{color:#94a3b8}.login-button{width:100%;padding:14px;font-size:16px;font-weight:600;color:#fff;background:linear-gradient(135deg,#003087,#002366,#001a4d);border:none;border-radius:8px;cursor:pointer;transition:all .3s;margin-top:8px}.login-button:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 8px 20px #745ebe66}.login-button:active:not(:disabled){transform:translateY(0)}.login-button:disabled{opacity:.7;cursor:not-allowed}.login-footer{margin-top:24px;text-align:center}.forgot-password{color:#003087;font-size:14px;text-decoration:none;font-weight:500;transition:color .2s}.forgot-password:hover{color:#e31837;text-decoration:underline}.forgot-password-info{text-align:center;font-size:13px;color:#64748b;margin:0;line-height:1.6;display:flex;align-items:center;justify-content:center;flex-wrap:wrap;gap:4px}.forgot-password-info a{color:#003087;text-decoration:none;font-weight:600;transition:color .2s}.forgot-password-info a:hover{color:#002366;text-decoration:underline}@keyframes fadeInDown{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeInUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes shake{0%,to{transform:translate(0)}25%{transform:translate(-10px)}75%{transform:translate(10px)}}@media (max-width: 640px){.login-card{margin:0;border-radius:0;min-height:100vh}.login-header h1{font-size:20px}.login-form{padding:24px}.login-header{padding:32px 24px 24px}}.dashboard-container{height:100vh;display:flex;flex-direction:column;background-color:#f8fafc;font-family:Inter,system-ui,-apple-system,sans-serif;overflow:hidden;color:#334155}.dashboard-header{flex-shrink:0;padding:16px 24px;background:linear-gradient(135deg,#1e3c72,#bcc9e8);border-bottom:1px solid #e2e8f0;display:flex;justify-content:space-between;align-items:center;box-shadow:0 1px 2px #0000000d;z-index:20}.header-title-section h1{font-size:20px;font-weight:700;color:#fff;margin:0}.header-controls{display:flex;gap:12px;align-items:center}.date-inputs{display:flex;gap:8px;align-items:center;background:#f1f5f9;padding:4px;border-radius:8px}.date-inputs input{border:none;background:#fff;padding:4px 8px;border-radius:4px;font-size:13px;color:#475569;outline:none;border:1px solid transparent}.date-inputs input:focus{border-color:#3b82f6}.cards-row{flex-shrink:0;padding:16px 24px;display:flex;gap:12px;overflow-x:auto;background:#f8fafc;border-bottom:1px solid #e2e8f0;white-space:nowrap}.compact-card{background:#fff;border:1px solid #e2e8f0;border-radius:12px;padding:12px 16px;min-width:140px;flex:1;display:flex;flex-direction:column;cursor:pointer;transition:all .2s;-webkit-user-select:none;user-select:none;box-shadow:0 1px 2px #00000005}.compact-card:hover{transform:translateY(-2px);box-shadow:0 4px 6px -1px #0000000d}.compact-card.selected{border-color:#3b82f6;background:#eff6ff;box-shadow:0 0 0 2px #3b82f633}.card-label{font-size:11px;font-weight:600;color:#64748b;text-transform:uppercase;margin-bottom:4px}.card-value{font-size:20px;font-weight:700;color:#0f172a}.tabs-nav{flex-shrink:0;padding:0 24px;background:#fff;border-bottom:1px solid #e2e8f0;display:flex;gap:24px}.tab-button{padding:12px 4px;font-size:14px;font-weight:600;color:#64748b;background:none;border:none;border-bottom:2px solid transparent;cursor:pointer;transition:color .2s}.tab-button:hover{color:#334155}.tab-button.active{color:#3b82f6;border-bottom-color:#3b82f6}.dashboard-content{flex:1;overflow:hidden;position:relative;background:#fff}.tab-panel{height:100%;width:100%;overflow:hidden;display:flex;flex-direction:column}.analytics-layout{display:grid;grid-template-rows:1fr 1fr;gap:16px;padding:16px 24px;height:100%;overflow:hidden}.analytics-top,.analytics-bottom{display:flex;gap:16px;min-height:0}.chart-container{background:#fff;border:1px solid #e2e8f0;border-radius:12px;padding:16px;flex:1;display:flex;flex-direction:column;min-width:0;box-shadow:0 1px 3px #0000000d}.chart-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}.chart-title{font-size:14px;font-weight:600;color:#334155}.chart-actions select{padding:4px 8px;border-radius:6px;border:1px solid #cbd5e1;font-size:12px;color:#475569}.map-full-container{height:100%;width:100%}.tickets-list-container{height:100%;overflow:auto;padding:0}.loading-overlay{position:absolute;top:0;right:0;bottom:0;left:0;background:#fffc;display:flex;align-items:center;justify-content:center;z-index:50}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:4px}::-webkit-scrollbar-thumb:hover{background:#94a3b8}.status-indicator{width:8px;height:8px;border-radius:50%;display:inline-block;margin-right:6px}:root{--primary-blue: #0078D4;--primary-dark: #0063B1;--bg-light: #f5f5f5;--bg-dark: #0f172a;--bg-dark-surface: #1e293b;--bg-dark-input: #334155;--text-light: #333;--text-dark: #f1f5f9;--header-bg: linear-gradient(90deg, #1e3c72 0%, #bcc9e8 100%)}body{font-family:Ubuntu,sans-serif}.tickets-container{min-height:calc(100vh - 56px);background:var(--bg-light);padding:0;transition:background .3s}.tickets-container.dark{background:var(--bg-dark);--text-light: var(--text-dark)}.header-content{display:flex;justify-content:space-between;align-items:center;width:100%;margin:0}.tickets-header{background:var(--header-bg);padding:16px 20px;color:#fff!important;box-shadow:0 2px 4px #0000001a}.tickets-header h1{font-size:20px;font-weight:700;color:#fff!important;margin:0 0 2px}.header-subtitle{font-size:13px;color:#ffffffe6!important;margin:0;font-weight:400}.header-actions{display:flex;align-items:center;gap:12px}.theme-toggle{background:#ffffffd8;border:none;border-radius:50%;width:32px;height:32px;cursor:pointer;color:#fff;font-size:16px;display:flex;align-items:center;justify-content:center;transition:background .2s}.theme-toggle:hover{background:#ffffffd8}.filters-bar{background:#fff;padding:12px 32px;border-bottom:1px solid #e0e0e0;display:flex;align-items:center;gap:8px;flex-wrap:nowrap;overflow-x:auto;min-height:56px;scrollbar-width:thin}.filters-bar::-webkit-scrollbar{height:4px}.filter-item{flex:0 0 auto}.search-item{flex:0 0 200px}.search-item input{width:100%;padding:6px 10px;border:1px solid #ddd;border-radius:4px;font-size:13px;font-family:Ubuntu,sans-serif}.filters-bar select{padding:6px 10px;border:1px solid #ddd;border-radius:4px;font-size:13px;color:#444;background:#fff;cursor:pointer;max-width:140px;font-family:Ubuntu,sans-serif}.filter-spacer{flex:1;min-width:10px}.create-button{display:flex;align-items:center;gap:6px;padding:8px 16px;background:#0078d4;border:none;border-radius:4px;color:#fff;font-size:13px;font-weight:500;cursor:pointer;white-space:nowrap;box-shadow:0 2px 4px #0000001a;transition:all .2s;font-family:Ubuntu,sans-serif}.create-button:hover{background:#0063b1;transform:translateY(-1px);box-shadow:0 4px 6px #00000026}.results-count-bar{padding:8px 32px;font-size:12px;color:#666;background:#fafafa;border-bottom:1px solid #eee;text-align:right}.tickets-table-container{background:#fff;margin:0;height:calc(100vh - 165px);overflow-y:auto;overflow-x:auto;position:relative}.tickets-table{width:100%;border-collapse:separate;border-spacing:0;min-width:1400px}.tickets-table thead th{position:-webkit-sticky;position:sticky;top:0;background:#f8f9fa;z-index:10;padding:12px 16px;text-align:left;font-size:11px;font-weight:600;color:#555;text-transform:uppercase;letter-spacing:.5px;border-bottom:2px solid #e0e0e0;border-top:1px solid #eee;white-space:nowrap;box-shadow:0 2px 2px #00000005}.tickets-table th.sortable{cursor:pointer;-webkit-user-select:none;user-select:none;transition:background .1s}.tickets-table th.sortable:hover{background:#eef1f5;color:#0078d4}.tickets-table td{padding:12px 16px;border-bottom:1px solid #f0f0f0;font-size:13px;color:#333;vertical-align:middle}.tickets-table tbody tr:hover{background-color:#f0f7ff}.ticket-ref{font-family:Ubuntu,monospace;font-weight:500;color:#0078d4}.status-badge{padding:4px 8px;border-radius:4px;font-size:11px;font-weight:600;text-transform:uppercase;white-space:nowrap;display:inline-block}.status-new{background:#dbeafe;color:#1e40af}.status-assigned{background:#ede9fe;color:#5b21b6}.status-in-progress{background:#e0e7ff;color:#3730a3}.status-escalated{background:#fee2e2;color:#991b1b}.status-resolved{background:#d1fae5;color:#065f46}.status-closed{background:#f1f5f9;color:#475569}.status-on-hold{background:#fef3c7;color:#92400e}.fault-info{max-width:250px}.fault-title{font-weight:600;color:#333;display:block;margin-bottom:2px}.fault-description{font-size:12px;color:#666;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.actions-btn{border:none;background:none;cursor:pointer;font-weight:700;color:#999;padding:4px 8px;border-radius:4px}.actions-btn:hover{background:#eee;color:#333}.dropdown-menu{position:absolute;right:0;top:100%;background:#fff;border:1px solid #eee;box-shadow:0 4px 12px #0000001a;border-radius:4px;z-index:100;min-width:140px;text-align:left}.dropdown-item{display:block;width:100%;padding:8px 12px;background:none;border:none;text-align:left;font-size:13px;cursor:pointer;color:#333}.dropdown-item:hover{background:#f5f5f5}.dropdown-item-danger{color:#d32f2f}.dropdown-item-danger:hover{background:#ffebee}body.dark .tickets-container .filters-bar,body.dark .tickets-container .tickets-table-container,body.dark .tickets-table thead th,body.dark .tickets-table td{background:var(--bg-dark-surface);color:var(--text-dark);border-color:#555}body.dark .tickets-container .filters-bar select,body.dark .tickets-container .search-item input{background:var(--bg-dark-input);color:#f0f0f0;border-color:#666}body.dark .tickets-table tbody tr:hover{background-color:#505050}body.dark .ticket-ref{color:#90caf9}body.dark .fault-title{color:#fff}body.dark .fault-description{color:#ccc}body.dark .results-count-bar{background:var(--bg-dark);border-color:#555;color:#bbb}body.dark .dropdown-menu{background:var(--bg-dark-surface);border-color:#666}body.dark .dropdown-item{color:#f0f0f0}body.dark .dropdown-item:hover{background:#505050}body.dark .selected-row{background-color:#1a3e66!important}.chart-container{background:#fff;border-radius:12px;padding:24px;box-shadow:0 1px 3px #0000001a;border:1px solid #e2e8f0;margin-bottom:24px}.chart-header{margin-bottom:20px}.chart-header h3{margin:0 0 8px;font-size:18px;font-weight:600;color:#1e293b}.chart-subtitle{margin:0;font-size:14px;color:#64748b}.chart-legend{display:flex;gap:20px;margin-bottom:24px;flex-wrap:wrap}.legend-color{width:12px;height:12px;border-radius:2px}.legend-label{font-size:13px;color:#475569;font-weight:500}.chart-content{min-height:300px}.chart-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:300px;gap:12px}.chart-loading .spinner{width:40px;height:40px;border:3px solid #e2e8f0;border-top-color:#3b82f6;border-radius:50%;animation:spin .8s linear infinite}.chart-empty{display:flex;align-items:center;justify-content:center;min-height:200px;color:#94a3b8;font-size:14px}.bars-container{display:flex;flex-direction:column;gap:16px}.bar-row{position:relative;display:flex;align-items:center;gap:12px;padding:8px;border-radius:8px;transition:background-color .2s}.bar-row:hover{background-color:#f8fafc}.bar-label{min-width:140px;display:flex;justify-content:space-between;align-items:center;gap:8px}.province-name{font-size:13px;font-weight:600;color:#334155}.province-total{font-size:12px;font-weight:700;color:#64748b;background:#f1f5f9;padding:2px 8px;border-radius:10px}.bar-track{flex:1;height:40px;background:#f1f5f9;border-radius:6px;overflow:hidden;position:relative}.bar-stack{display:flex;height:100%;width:100%}.bar-segment{height:100%;display:flex;align-items:center;justify-content:center;transition:filter .2s;cursor:pointer;position:relative}.bar-segment:hover{filter:brightness(1.1)}.bar-value{font-size:11px;font-weight:700;color:#fff;text-shadow:0 1px 2px rgba(0,0,0,.3)}.bar-tooltip{position:absolute;right:0;top:100%;margin-top:8px;background:#fff;border:1px solid #e2e8f0;border-radius:8px;padding:12px;box-shadow:0 4px 12px #00000026;z-index:10;min-width:180px;animation:fadeIn .2s}.tooltip-row{display:flex;align-items:center;gap:8px;padding:4px 0;font-size:13px}.tooltip-row span:first-child{font-size:10px}.tooltip-row span:nth-child(2){flex:1;color:#64748b}.tooltip-row strong{color:#1e293b;font-weight:600}.tooltip-divider{height:1px;background:#e2e8f0;margin:6px 0}.tooltip-total{font-weight:600}.tooltip-total span{color:#1e293b!important}@keyframes fadeIn{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.bars-container.vertical{flex-direction:row;align-items:flex-end;height:500px;padding-bottom:80px;padding-top:20px;gap:12px}.bar-column{position:relative;display:flex;flex-direction:column;align-items:center;justify-content:flex-end;height:100%;flex:1;min-width:45px;transition:background-color .2s;border-radius:8px 8px 0 0}.bar-column:hover{background-color:#f8fafc}.bar-track-vertical{width:32px;background:#f1f5f9;border-radius:6px 6px 0 0;display:flex;flex-direction:column;justify-content:flex-end;overflow:hidden;position:relative;transition:height .5s ease-out;box-shadow:0 2px 4px #0000000d}.bar-track-vertical .bar-segment{width:100%;transition:height .5s ease-out;display:flex;align-items:center;justify-content:center;position:relative}.bar-value-vertical{font-size:10px;font-weight:700;color:#fff;text-shadow:0 1px 2px rgba(0,0,0,.4);z-index:2}.bar-label-vertical{position:absolute;bottom:-80px;left:50%;transform:translate(-50%) rotate(-45deg);transform-origin:top center;width:140px;text-align:right;white-space:nowrap;display:flex;align-items:center;justify-content:flex-end;gap:8px;padding-top:12px}.bar-label-vertical .province-name{font-size:12px;font-weight:600;color:#334155;overflow:hidden;text-overflow:ellipsis}.bar-label-vertical .province-total{font-size:11px;font-weight:700;background:#f1f5f9;color:#475569;padding:2px 6px;border-radius:10px;min-width:20px;text-align:center}.tooltip-header{font-weight:700;color:#1e293b;margin-bottom:8px;padding-bottom:8px;border-bottom:1px solid #e2e8f0;font-size:14px}.bars-container:not(.vertical){display:flex;flex-direction:column;gap:16px}@media (prefers-color-scheme: dark){.chart-container{background:#1e293b;border-color:#334155}.chart-header h3{color:#f1f5f9}.chart-subtitle,.legend-label{color:#94a3b8}.bar-row:hover{background-color:#334155}.province-name{color:#e2e8f0}.province-total{background:#334155;color:#cbd5e1}.bar-track{background:#334155}.bar-tooltip{background:#1e293b;border-color:#475569}.tooltip-row span:nth-child(2){color:#94a3b8}.tooltip-row strong,.tooltip-total span{color:#f1f5f9!important}.tooltip-divider{background:#475569}.bar-column:hover{background-color:#334155}.bar-label-vertical .province-name{color:#e2e8f0}.bar-label-vertical .province-total{background:#334155;color:#cbd5e1}.bar-track-vertical{background:#334155}.tooltip-header{color:#f1f5f9;border-bottom-color:#334155}}.ops-overview-container{display:flex;flex-direction:column;gap:20px;padding:0;width:100%}.ops-loading,.ops-error{display:flex;justify-content:center;align-items:center;height:300px;font-size:1.2rem;color:#64748b}.ops-error{color:#ef4444}.ops-kpi-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:20px}.ops-kpi-card{background:#fff;padding:20px;border-radius:12px;box-shadow:0 1px 3px #0000001a;border:1px solid #e2e8f0;display:flex;flex-direction:column;align-items:flex-start;text-align:left;transition:transform .2s,box-shadow .2s;position:relative;overflow:hidden}.ops-kpi-card:hover{transform:translateY(-2px);box-shadow:0 10px 15px -3px #0000001a,0 4px 6px -2px #0000000d}.ops-kpi-card.active-tickets{border-left:4px solid #3b82f6}.ops-kpi-card.new-tickets{border-left:4px solid #8b5cf6}.ops-kpi-card.avg-response{border-left:4px solid #f59e0b}.ops-kpi-card.avg-resol{border-left:4px solid #10b981}.ops-kpi-card.sla-comp{border-left:4px solid #ec4899}.ops-kpi-card.affected-fac{border-left:4px solid #ef4444}.ops-kpi-card.data-qual{border-left:4px solid #06b6d4}.kpi-label{font-size:.75rem;font-weight:600;color:#64748b;text-transform:uppercase;letter-spacing:1px;margin-bottom:8px}.kpi-value{font-size:2.2rem;font-weight:700;color:#1e293b;line-height:1.1;margin-bottom:4px}.kpi-sub{font-size:.8rem;color:#94a3b8;margin-top:auto}.ops-charts-row{display:flex;gap:20px;flex-wrap:wrap}.ops-chart-container{background:#fff;padding:20px;border-radius:12px;box-shadow:0 1px 3px #0000001a;border:1px solid #e2e8f0;flex:1;min-width:300px;display:flex;flex-direction:column}.ops-chart-container.extended{flex:2}.ops-chart-container h3{margin:0 0 20px;font-size:1.1rem;color:#334155;font-weight:600}.ops-bottom-row{display:flex;gap:20px;flex-wrap:wrap}.ops-list-container{background:#fff;padding:20px;border-radius:12px;box-shadow:0 1px 3px #0000001a;border:1px solid #e2e8f0;flex:1;min-width:300px}.ops-list-container h3{margin:0 0 15px;font-size:1.1rem;color:#334155;font-weight:600}.ops-table{width:100%;border-collapse:collapse}.ops-table th,.ops-table td{padding:10px;text-align:left;border-bottom:1px solid #f1f5f9;font-size:.9rem}.ops-table th{font-weight:600;color:#64748b}.ops-table tr:last-child td{border-bottom:none}.workload-bar-container{display:flex;align-items:center;gap:10px}.workload-bar-bg{flex:1;height:8px;background:#f1f5f9;border-radius:4px;overflow:hidden}.workload-bar-fill{height:100%;background:#3b82f6;border-radius:4px}.badge-critical{background:#fef2f2;color:#ef4444;padding:4px 8px;border-radius:12px;font-size:.75rem;font-weight:600}.badge-high{background:#fff7ed;color:#f97316;padding:4px 8px;border-radius:12px;font-size:.75rem;font-weight:600}.interactive-row:hover{background-color:#e2e8f0;transition:background-color .2s}.ops-loading-overlay{position:absolute;top:0;left:0;width:100%;height:100%;background:#ffffffb3;display:flex;flex-direction:column;justify-content:center;align-items:center;z-index:10;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);border-radius:12px}.spinner{width:40px;height:40px;border:4px solid #e2e8f0;border-top:4px solid #3b82f6;border-radius:50%;animation:spin 1s linear infinite;margin-bottom:10px}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.dashboard-charts{display:flex;flex-direction:column;gap:24px;padding:0}.charts-row{display:grid;grid-template-columns:repeat(2,1fr);gap:24px}.chart-card{background:#fff;border-radius:16px;padding:24px;box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;border:1px solid #e2e8f0;transition:all .3s ease}.chart-card:hover{box-shadow:0 10px 15px -3px #0000001a,0 4px 6px -2px #0000000d;transform:translateY(-2px)}.chart-card-full{grid-column:span 2}.chart-card-header{margin-bottom:20px}.chart-card-header h3{margin:0 0 4px;font-size:18px;font-weight:700;color:#1e293b;display:flex;align-items:center;gap:8px}.chart-card-header p{margin:0;font-size:13px;color:#64748b}.chart-content{min-height:300px;display:flex;align-items:center;justify-content:center}.chart-empty{color:#94a3b8;font-size:14px;font-weight:500;text-align:center;padding:40px}.charts-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:400px;gap:16px}.charts-loading .spinner{width:48px;height:48px;border:4px solid #e2e8f0;border-top-color:#3b82f6;border-radius:50%;animation:spin .8s linear infinite}.charts-loading p{color:#64748b;font-size:14px;margin:0}@media (max-width: 1200px){.charts-row{grid-template-columns:1fr}.chart-card-full{grid-column:span 1}}.recharts-tooltip-wrapper{z-index:100}.recharts-default-tooltip{background:#fff!important;border:1px solid #e2e8f0!important;border-radius:8px!important;box-shadow:0 4px 6px -1px #0000001a!important;padding:12px!important}.recharts-tooltip-label{font-weight:600;color:#1e293b;margin-bottom:8px}.recharts-tooltip-item{color:#475569!important;font-size:13px}.recharts-legend-wrapper{padding-top:16px!important}.recharts-legend-item-text{font-size:13px!important;color:#475569!important}.recharts-pie-label-text{font-size:11px;font-weight:600;fill:#1e293b}@media (prefers-color-scheme: dark){.chart-card{background:#1e293b;border-color:#334155}.chart-card-header h3{color:#f1f5f9}.chart-card-header p{color:#94a3b8}.chart-empty{color:#64748b}.recharts-default-tooltip{background:#1e293b!important;border-color:#475569!important}.recharts-tooltip-label{color:#f1f5f9}.recharts-tooltip-item,.recharts-legend-item-text{color:#cbd5e1!important}.recharts-pie-label-text{fill:#f1f5f9}}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn .2s ease-out}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal-content{background:#fff;border-radius:12px;box-shadow:0 20px 60px #0000004d;max-width:600px;width:90%;max-height:90vh;display:flex;flex-direction:column;animation:slideUp .3s ease-out}.modal-small{max-width:400px}@keyframes slideUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.modal-header{padding:20px 24px;border-bottom:1px solid #e2e8f0;display:flex;justify-content:space-between;align-items:center}.modal-header h2{margin:0;font-size:20px;font-weight:600;color:#1e293b}.modal-close{background:none;border:none;font-size:28px;color:#64748b;cursor:pointer;padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:6px;transition:all .2s}.modal-close:hover{background:#f1f5f9;color:#1e293b}.modal-footer{padding:16px 24px;border-top:1px solid #e2e8f0;display:flex;justify-content:flex-end;gap:12px}.form-group{margin-bottom:20px}.form-group label{display:block;margin-bottom:6px;font-size:14px;font-weight:600;color:#475569}.form-control{width:100%;padding:10px 12px;border:1px solid #e2e8f0;border-radius:6px;font-size:14px;color:#1e293b;background:#fff;transition:all .2s}.form-control:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.form-control:disabled{background:#f8fafc;color:#94a3b8;cursor:not-allowed}.btn{padding:10px 20px;border:none;border-radius:6px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:linear-gradient(135deg,#3b82f6,#2563eb);color:#fff}.btn-primary:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 4px 12px #3b82f64d}.btn-secondary{background:#f8fafc;color:#475569;border:1px solid #e2e8f0}.btn-secondary:hover:not(:disabled){background:#f1f5f9;border-color:#cbd5e1}.btn-danger{background:linear-gradient(135deg,#dc2626,#b91c1c);color:#fff}.btn-danger:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 4px 12px #dc26264d}.error-message{padding:12px;background:#fee2e2;border:1px solid #fecaca;border-radius:6px;color:#dc2626;font-size:14px;margin-top:12px}.ticket-details-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:24px}.detail-section{background:#f8fafc;padding:16px;border-radius:8px;border:1px solid #e2e8f0}.detail-section.full-width{grid-column:1 / -1}.detail-section h3{margin:0 0 12px;font-size:14px;font-weight:600;color:#64748b;text-transform:uppercase;letter-spacing:.5px}.detail-row{display:flex;justify-content:space-between;margin-bottom:8px;align-items:center}.detail-label{font-size:13px;color:#64748b;font-weight:500}.detail-value{font-size:14px;color:#1e293b;font-weight:500}.detail-text{font-size:14px;color:#475569;line-height:1.6;white-space:pre-wrap}.status-badge,.priority-badge{padding:4px 12px;border-radius:12px;font-size:12px;font-weight:600;color:#fff}.warning-icon{text-align:center;font-size:48px;margin-bottom:16px}.warning-text{text-align:center;font-size:16px;font-weight:600;color:#1e293b;margin-bottom:16px}.warning-subtext{text-align:center;font-size:14px;color:#64748b;margin-top:16px}.ticket-info{background:#f8fafc;padding:12px;border-radius:6px;font-size:14px;color:#475569;line-height:1.6}@media (max-width: 768px){.modal-content{width:95%;max-height:95vh}.ticket-details-grid{grid-template-columns:1fr}.modal-footer{flex-direction:column-reverse}.modal-footer .btn{width:100%}}.timeline{border-left:2px solid #e2e8f0;margin-left:10px;padding-left:20px;margin-top:20px}.timeline-item{position:relative;margin-bottom:24px}.timeline-item:last-child{margin-bottom:0}.timeline-marker{position:absolute;left:-27px;top:4px;width:12px;height:12px;border-radius:50%;background:#3b82f6;border:2px solid white;box-shadow:0 0 0 2px #e2e8f0}.timeline-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:6px}.timeline-type{font-size:12px;font-weight:700;color:#475569;background:#f1f5f9;padding:2px 8px;border-radius:4px}.timeline-date{font-size:12px;color:#94a3b8}.timeline-user{font-size:12px;color:#64748b;margin-bottom:4px;font-style:italic}.timeline-details{font-size:14px;color:#334155;background:#f8fafc;padding:10px;border-radius:6px;border:1px solid #e2e8f0}.ticket-details-modal .modal-content{display:flex;flex-direction:column;max-height:90vh;padding:0;overflow:hidden}.ticket-details-modal .modal-header{background:#fff;border-bottom:1px solid #e2e8f0;padding:20px 24px;display:flex;justify-content:space-between;align-items:center;flex-shrink:0}.ticket-details-modal .modal-header h2{margin:0;font-size:20px;display:flex;align-items:center;gap:12px}.ticket-ref-badge{background:#f1f5f9;color:#475569;font-size:14px;font-weight:500;padding:4px 10px;border-radius:6px}.modal-tabs{display:flex;padding:0 24px;border-bottom:1px solid #e2e8f0;background:#fafafa;flex-shrink:0}.modal-tab{padding:14px 20px;font-size:14px;font-weight:500;color:#64748b;cursor:pointer;border-bottom:2px solid transparent;transition:all .2s}.modal-tab:hover{color:#334155}.modal-tab.active{color:#0f172a;border-bottom-color:#0f172a}.modal-body-scroll{overflow-y:auto;padding:24px;flex:1}.status-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:16px;margin-bottom:24px;background:#f8fafc;border:1px solid #e2e8f0;border-radius:8px;padding:20px}.status-box{display:flex;flex-direction:column;gap:6px}.status-label{font-size:12px;text-transform:uppercase;color:#64748b;font-weight:600;letter-spacing:.5px}.status-value{font-size:15px;color:#0f172a;font-weight:500}.info-section{margin-bottom:32px}.info-section h3{font-size:16px;color:#1e293b;margin:0 0 16px;padding-bottom:10px;border-bottom:1px solid #f1f5f9}.info-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:20px}.info-item{display:flex;flex-direction:column;gap:4px}.info-item label{font-size:13px;color:#64748b}.info-item span{font-size:14px;color:#334155;font-weight:500}.description-text{background:#fff;border:1px solid #e2e8f0;border-radius:6px;padding:16px;font-size:14px;line-height:1.6;color:#334155;white-space:pre-wrap}.timeline-list{position:relative;padding-left:20px}.timeline-list:before{content:"";position:absolute;left:7px;top:10px;bottom:20px;width:2px;background:#e2e8f0}.timeline-item{position:relative;padding-left:30px;padding-bottom:32px}.timeline-item:last-child{padding-bottom:0}.timeline-dot{position:absolute;left:0;top:6px;width:16px;height:16px;border-radius:50%;background:#fff;border:3px solid #cbd5e1;z-index:2}.timeline-item.created .timeline-dot{border-color:#3b82f6}.timeline-item.resolved .timeline-dot{border-color:#10b981}.timeline-item.escalated .timeline-dot{border-color:#f59e0b}.timeline-content{background:#fff;border:1px solid #f1f5f9;border-radius:8px;padding:16px;box-shadow:0 1px 2px #0000000d}.timeline-header{display:flex;justify-content:space-between;margin-bottom:8px;font-size:13px}.timeline-user{font-weight:600;color:#0f172a}.timeline-date{color:#94a3b8}.timeline-details{font-size:14px;color:#475569;line-height:1.5}.timeline-type{display:inline-block;padding:2px 8px;border-radius:12px;font-size:11px;font-weight:600;text-transform:uppercase;margin-bottom:6px}.type-created{background:#dbeafe;color:#1e40af}.type-resolved{background:#d1fae5;color:#065f46}.type-escalated{background:#fef3c7;color:#92400e}.type-assigned{background:#e0e7ff;color:#3730a3}.loading-timeline{text-align:center;padding:40px;color:#64748b}.leaflet-control-measure h3,.leaflet-measure-resultpopup h3{margin:0 0 12px;padding-bottom:10px;border-bottom:1px solid #ddd}.leaflet-control-measure p,.leaflet-measure-resultpopup p{margin:10px 0 0;line-height:1.5em}.leaflet-control-measure p:first-child,.leaflet-measure-resultpopup p:first-child{margin-top:0}.leaflet-control-measure .tasks,.leaflet-measure-resultpopup .tasks{margin:12px 0 0;padding:10px 0 0;border-top:1px solid #ddd;text-align:right;list-style:none;list-style-image:none}.leaflet-control-measure .tasks li,.leaflet-measure-resultpopup .tasks li{display:inline;margin:0 10px 0 0}.leaflet-control-measure .tasks li:last-child,.leaflet-measure-resultpopup .tasks li:last-child{margin-right:0}.leaflet-control-measure .coorddivider,.leaflet-measure-resultpopup .coorddivider{color:#999}.leaflet-control-measure{max-width:280px;background:#fff}.leaflet-control-measure .leaflet-control-measure-toggle,.leaflet-control-measure .leaflet-control-measure-toggle:hover{background-size:14px 14px;background-image:url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABAAAAAQCAYAAAAf8/9hAAAABHNCSVQICAgIfAhkiAAAAAlwSFlzAAAOxAAADsQBlSsOGwAAAGJJREFUOI1jYGBgOM3AwPAfCTMwMDA8QxPDhT8xoAlIM5AG/jMi2QoDjKQYwITEkSFRM9w2qrkA5oqBc8EIDYNHDAzkp0I4QE/fMDF5YvnoBsiTwscWBiQBJgYGhpMU6D8CAJDrOVecOVsbAAAAAElFTkSuQmCC);border:0;border-radius:4px;text-indent:100%;white-space:nowrap;overflow:hidden}.leaflet-touch .leaflet-control-measure .leaflet-control-measure-toggle,.leaflet-touch .leaflet-control-measure .leaflet-control-measure-toggle:hover{border-radius:2px}.leaflet-retina .leaflet-control-measure .leaflet-control-measure-toggle,.leaflet-retina .leaflet-control-measure .leaflet-control-measure-toggle:hover{background-image:url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAACAAAAAgCAYAAABzenr0AAAABHNCSVQICAgIfAhkiAAAAAlwSFlzAAAOxAAADsQBlSsOGwAAALdJREFUWIXtl0EKwkAMRZ+iR1LwCC5ceekKHsSqN3ARF5pFi41lmGQU8iDQkkB/0k/aATgCV0AmQjkbNaXRAdy+FCmdgwDBSGzwRQBZGgUrZwEALBiOearGAwGwJhDCJwFbXl1rhAsIefdKesASoF5oJiD3QAi5B9IDuQeaeyDU8SNOwEOVRP4LDvirPSAe9yXd7oB1rXzJBKrm50ygasdj5kzAlZ/4FtwbPr8HOLwvPE6+VlyA/ROEjYEpRhLQZgAAAABJRU5ErkJggg==)}.leaflet-touch .leaflet-control-measure .leaflet-control-measure-toggle,.leaflet-touch .leaflet-control-measure .leaflet-control-measure-toggle:hover{background-size:16px 16px}.leaflet-control-measure .startprompt h3{margin-bottom:10px}.leaflet-control-measure .startprompt .tasks{margin-top:0;padding-top:0;border-top:0;text-align:left}.leaflet-control-measure .leaflet-control-measure-interaction{padding:10px 12px}.leaflet-control-measure .results .group{margin-top:10px;padding-top:10px;border-top:1px dotted #eaeaea}.leaflet-control-measure .results .group:first-child{margin-top:0;padding-top:0;border-top:0}.leaflet-control-measure .results .heading{margin-right:5px;color:#999}.leaflet-control-measure a.start{display:inline;width:auto;height:auto;padding-left:20px;margin-right:4px;line-height:1em;border:0;text-align:left;background-image:url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAwAAAAMCAYAAABWdVznAAAABHNCSVQICAgIfAhkiAAAAAlwSFlzAAALEwAACxMBAJqcGAAAAY1JREFUKJF9kL9PEwEcxd/3y+XaXrwKCZsx4uLQiQQRZHOUmYEU45mL1CCVpH+JwxEx6CB6HfixM7KQ8sM2TB2cHHRzMCTt2cbe+zrUSxsHP+PLey/v+xX8ZaXWKHgddxNAmcYSACjQNpW69jtv9vYe9QBAAKActu44TnpMwlXRyEQuhzW2IMAWgcSZ4OMPOw++yUqtUfC6TgvEl8QflI9eL/3CGJVK0+uB+4TencoV59TruJsk3MwcvLiaCZ635rLA7u79hIm7qqR/3bt+qQDKKhplzTROm6aNp+ufq1kojme7prpNsTWlsTTanKEuRKIn683DtVfnxeGxcqHUkuI/iBj/1RwF2gZbAHCWiST7KlL79G5+Z2TlQwBtNZW6AFuVStMDgHSAHxOwxY9j5jA89QGpQiSWIDjJpzm/qeBXJu5qHM92xyeE4an/W3MHgN2aLEzOCwA827i8PUj1WEnfVLcFcjGaIVUjfxJcrr9f/C5ZUxCc5M29sTF8nZaGqrUhEt/MF99G0b0+APwB15Gn8fy9beQAAAAASUVORK5CYII=);background-repeat:no-repeat;background-position:0 50%;background-size:12px 12px;color:#5e66cc;text-decoration:none}.leaflet-control-measure a.start,.leaflet-control-measure a.start:hover{background-color:transparent}.leaflet-retina .leaflet-control-measure a.start{background-image:url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABgAAAAYCAYAAADgdz34AAAABHNCSVQICAgIfAhkiAAAAAlwSFlzAAALEwAACxMBAJqcGAAAA41JREFUSImNlU9oVFcUxn/ne28UxKWIRKiYpRaqZpIUagm6aZfiQlLNRBzyT+nGNmiLe2nUtkLBJhnRxolRoVBc1GXqIoqZTEoW6sZN/VNqTXdWsJl553YxkzSkM5N8m/feved837mP891jNMCx44XmJFEnsA/3nQ6bAEzMG3pMYNIU3Rgb2f1bPQ6rtdjV82A7Fp8j+EFJalSEu7vJfkzKOjVxpeXpqgKZ3kImBIYlbagSlGS6G2Aa+APAjCag3d07JKWqUm/M1T92OX29rkB338xpsK8AHN5aCN/E5eji1at75muedGBus8oLJx1OSloPEEIYzOdav/6fQKa3kDHTNYDg4YlH0YHrI3seN/o9/wkV3rVEt81oroocyedaJ5YEunoebAc9lLQheHgS4tTe8eFdr9ZCvoijJ6a3eCm6Z0Yz7n8HaWd+NP1MAFI8JGmDw1uPogMrybPZ2SYINRtiEWOX2l8G6SD4AtJGgyEAO3a80Fwq8USSQghn87nWMyuTM30zA0Y4UEJdN0bTfzUS6u4pXED63N3dPWpWkqhTkty9FJeji/VT9VHkYe5IT/HDRgK2LlwAEkmKY+8UsA9Aprv1umVJQrY1Er909xa/rPfLxi61vwSmANzDfuG+E6Da52tBhHE201O880lfcVPNiBAKlYK0Q4v2p2qitcJkH0ce5jJ9xb01dn+vPH1zw2tgNUgWVo0xMQ9L9l87AndCKtmVH01P1djcWqV/FRt6DJW7ZU3ETtktnBnPpc9D7RN4oF0G4I9EYBLA3Tu6BuY2N+QOPHfzjvFc67l65NnsbJNkH1TibVKm6Ia7u6SUygsn65EH959tXbJ7PNd2v1ERpTgMAhGQmNlNA8j0zdwy7JC7/0NMeny47eHypKMnpreMXWr7s17Vi8gMFHaHMtOSUrhPXLvcdkQASVmnwN9IWm+Jbh89Mb1leWLFPI3Js9nZJnN+kpRyeJ3gpwEEMHGl5am5+gHMaPZSdK+r/9f3GhGurLwcJ/dB2wAM671++f0Xlfdl6O4tDmKcr3z5As53ti5cqNq/ZtWlOAwG90+XJlsIn13LtX67GFNjZM4cthBGkDZWlxJgqmL/RYeGrR5or3ZLBODw2rDe/GjLreV8NS+sTF/xHYMhdz+02tAHEtxvKcUXP3zf9nzlZsMhcjg7uy2OvdM97Je0A7zqE70Cf+TBJs3sZn40/awex78erYTTwi3/3gAAAABJRU5ErkJggg==)}.leaflet-control-measure a.start:hover{opacity:.5;text-decoration:none}.leaflet-control-measure a.cancel{display:inline;width:auto;height:auto;padding-left:20px;margin-right:4px;line-height:1em;border:0;text-align:left;background-image:url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAwAAAAMCAYAAABWdVznAAAABHNCSVQICAgIfAhkiAAAAAlwSFlzAAAOxAAADsQBlSsOGwAAAS9JREFUKJGFkDFOAlEURc8dRphJFNmBHYnQYbTHDnsa0BDBRq1YC4naIQbWYEloqKQyswIXQEgwDIn5z2IATUR95X/nvpz7xWqq7XEYztO3QM2wAoCkyLCBt5zf9XrlGEAAtebkwPfdM+iQLWMQpVKu8nh/8qZqexyG7zuT3+DvoVwme+QlGmtYTcMGG8h4MnOtlUpxFs9ufKD2BbjTULqMwZlhobhaoO5mL+q+YQUlVZB0HoMF0EKwwLpC9XVApoL3w9UwgOk00LYuvqQIKK2dEw3rBrmFhSR6wMXqXOQbNhAqJQ9utECJhiAGc7KRZ1oF1FejMQxcZu9FUPznW19zmeyx1+uV41TKVQyiv2DnPs46nfxyU6zRGAaW3r02UZepsHYG9feD7EOnk18CfAKwIX1qvqPBeQAAAABJRU5ErkJggg==);background-repeat:no-repeat;background-position:0 50%;background-size:12px 12px;color:#5e66cc;text-decoration:none}.leaflet-control-measure a.cancel,.leaflet-control-measure a.cancel:hover{background-color:transparent}.leaflet-retina .leaflet-control-measure a.cancel{background-image:url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABgAAAAYCAYAAADgdz34AAAABHNCSVQICAgIfAhkiAAAAAlwSFlzAAAOxAAADsQBlSsOGwAAApxJREFUSImtlr1PWlEYxp/ncE1KYWy6Gh3FwUZiOtiYuqlbGwxRaKJRjI5tqon/gf4BpqIxERC1doaNxLaD8SNxUOdqOukoiLHc83YALdwPhLbP+J5zfs977n3OPZeoo7Hp/XbTVGEArwEEBHhWHpErgmcQ5Kg8m+vLL364MehUjEzstZHGIiBvSKp6TYiIBvHFLKnZ9Fr3+aMG0cn9KKg+EXhaD+xgVaDm1PpqcKO6WtPdu9jBHKkSzcMBgD5RSEVjhx9qqtWdkyrRPNguAUaT8WD6wSAysddGZZz8XedODpIXMpCMBy8UAChlLNjgInmIHgTwvQ5qtzxHCjVV0k9gAQDU2PR+u4i8ta4kVSix0pMtGk8GAPnmBNc3xlBipScLkZB9EzI8Mn7UqkxThZ2iKNDzoZkT/85SZ75oeActJrv6xhhKpboKoZkTP6jm7Q1SGYYOK5QPkYP4ylsqZiKRY9/OUmde37QMiMhXK9xbus0C6HUiCNivAAScDcom9P7KRCLHvlSqqyDFlsFG4QBAoIPR2OEdgRZ3E6C6awBoBF7Zw13dz8D/kALk6pE5Nc/8z4t3TVeVeKkInjUK95Zus95SMVMnXRbJqYIg1ygcQG+ddNmkBTlF5dkUEW031wvuaalNF1T51FpkktwiAERjB9sEhy0OBYiEKofILS27Qlmk4DNAn2UsnYgHRw0AMEtq1jD0UO0k+kBmXMD36qOwz7Z54Frr0hxQuQ/Sa93n1Jx6BNaEOLmx+vLngwEArK8GNyD4+M9skffJePf2g5V1PBo7HKHIMkh/U1zgGuBkNRywXJkAkIwH00IGAGw5pssuE0Da49EBKxxw+au418j4Uath6LCA/QQ6AHleWXYJyKkW5EhuJePBCzfGbyl+TiY9AObiAAAAAElFTkSuQmCC)}.leaflet-control-measure a.cancel:hover{opacity:.5;text-decoration:none}.leaflet-control-measure a.finish{display:inline;width:auto;height:auto;padding-left:20px;margin-right:4px;line-height:1em;border:0;text-align:left;background-image:url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAwAAAAMCAYAAABWdVznAAAABHNCSVQICAgIfAhkiAAAAAlwSFlzAAAOxAAADsQBlSsOGwAAASVJREFUKJF1kDFLAgEYhp/37tQ7KPMftAnZZtjSkg2B7S5KHLRVk3O/IQiEakzQra2h0SannOR+QWuLYKF03teQwkHeO3483/e+7ydWanZGQTDLXwMtwyoAkiLDBs5idt/r1ecAAmhdjHc9L3kF7bFBBpHrJo2nh8MPNTujIPjKjbPg9FKpUDxw/mJkw2Y8G3wL9qfz6ZUDtLLP2l0gQiACMNF21gVX+kzDvnQzx14ENQCZKk7K+s39cSoGkzQMOkmbepIioCpxHOeW57l4ceR5/nITDBZ5hg2EqgBCt7FXyMXY6X8YQH2F4dBPCtvvgv3M8oDBpFQo1pxerz533aRhq09kwUkSn3W75YXWwzAc+pbfujTRlqmyzgzq7/jFx263vAD4BStdctyYQ7zEAAAAAElFTkSuQmCC);background-repeat:no-repeat;background-position:0 50%;background-size:12px 12px;color:#5e66cc;text-decoration:none}.leaflet-control-measure a.finish,.leaflet-control-measure a.finish:hover{background-color:transparent}.leaflet-retina .leaflet-control-measure a.finish{background-image:url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABgAAAAYCAYAAADgdz34AAAABHNCSVQICAgIfAhkiAAAAAlwSFlzAAAOxAAADsQBlSsOGwAAAlZJREFUSImllr9PU1EYhp/3tJMyGqIuBhYNnQyXhMRJNlcHg0AxIC3pqhFi4iCLCf4FtFaUFgok/AMmBldSqpOwuAhhghFx6r2fAwX641Jy6zu+57vP+30n5+Rc0UYTmXKv77th4CGQMLhxumJHQrsYm3Kx1aXs/d+XMRRmjk1t9Ujx92CPJbl2TZhZgNjwq26mtNi/d2VAMlVOIrcguNYOHBJ1okDTS3lvpd5t6G48vT0ruUJ0OICum2M5ma68bHDrO5dcITq4VQajxZxXOg8Ym9rqkYv/7KzzsAT7Y1KimPP2HYBz8fn/gRv8bTCkLsE8gCYy5d5qVb+uOi1ttOQH1Tcxxb8i7l4MYYHvu17n+264c7h97rnVP7mSHzxAZBqHkIvHg2HH6SXqEO49n5tT8CxduWdGqaUCDTkgERlt9qkeHhjfJG421wn63MX1b8F8waiGwXtve1NXwWvV3aF7b5At5LxHOHtaHxINfioHdtRq6gfICtmBjbOQTuCgQye02zpBsDCerkwB1EIeRIcD2I7GU5XXiHchixaI1HJ24OOZEw0Ogdmsk4utmlkQMp6c8SGZKk92Agd8SWsCSKa314WehNeZmektkIkABygVct6oA/CrbgbsJLxOkpiLAjc49oPqLNTeg9Ji/54CTUfo7goptZIfPDgPAFjKeysYr/6bbfaimOtfP49qXk+mKyMyyyJ1ReLCMShVD4emJxOgmPNKJiWAtfDT1SIfKMViQaIZDpf8VZxpZPL7nXg8GDY0JOgD6659dgi2ExibktaKOW//MsY/pXkXxnBJQFMAAAAASUVORK5CYII=)}.leaflet-control-measure a.finish:hover{opacity:.5;text-decoration:none}.leaflet-measure-resultpopup a.zoomto{display:inline;width:auto;height:auto;padding-left:20px;margin-right:4px;line-height:1em;border:0;text-align:left;background-image:url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAwAAAAMCAYAAABWdVznAAAABHNCSVQICAgIfAhkiAAAAAlwSFlzAAAOxAAADsQBlSsOGwAAAOhJREFUKJGVkTFug0AQRd+sgBOkyT1MvxVdipQpbDcBrsExAq4iipQWpbvt1xeJlBNgsZPCYK1sJ1GmfX//PM3CP0cAXqrjQwqVqmbG4N7b3AFsa29DwIrIeILuo1t9GYAUKqD4pbiYMyQAqpoBrt/lTZyaN7l16RsguzwwBreENq/HZ0TfEFEVrfs2H2Iu17s3pf/E8CSTmCDs+93qMebm9gyiMomZJNyyRWlbe7s4q2itInvBgFJe8wQgBOxc4Po2H4Ahbo15craQESjWpW9++AeLcrgonaBLzw3ZPW+UQxrG9i77a74B+z5bQloZOFAAAAAASUVORK5CYII=);background-repeat:no-repeat;background-position:0 50%;background-size:12px 12px;color:#5e66cc;text-decoration:none}.leaflet-measure-resultpopup a.zoomto,.leaflet-measure-resultpopup a.zoomto:hover{background-color:transparent}.leaflet-retina .leaflet-measure-resultpopup a.zoomto{background-image:url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABgAAAAYCAYAAADgdz34AAAABHNCSVQICAgIfAhkiAAAAAlwSFlzAAAOxAAADsQBlSsOGwAAAXBJREFUSIntlb8uBFEUxn/n7hAV1XoIpazYll5ETbays56AZ+AJGBJBoRPUotVsRCmeACsRiUQx636KRWbHnzvIavi6c/J95zvnzJ174R8BWDaozTdnMK1iNpzNbycV4x3U4qaysVALo76zNnbwknPddm+Lf61bK5snyeaibkan+Ecd55Hn1eKm8g12T9AD9NwgClNgtnE64uRXgAlDQhyb2eJWUjkPaYO7nm2cjpS8P8EYzOYFdw6qIZPgipz8CsYg0l4K5VLqhhEHBkMeloP6EAGYAEjNGrtJ5WZzc7TlS1EMYNLkjw0MCWAgda/rbKcPhY4xFPnI4hhj6jHy63MLZ3E7fbB+F6133O0oJA9PYLYouMOYdr591V/qu8RsCulW/nHpSwa1uKn8/bKVVM4dVAWHSPdI98C+5Ks7G+MXIX2h/+D5KE4X4X46QS/wu1eFUMuwcn6PRd+DZ1xlg9x7QB3p+nu9dop7rP4D/V/EE6UhikMKpx/oAAAAAElFTkSuQmCC)}.leaflet-measure-resultpopup a.zoomto:hover{opacity:.5;text-decoration:none}.leaflet-measure-resultpopup a.deletemarkup{display:inline;width:auto;height:auto;padding-left:20px;margin-right:4px;line-height:1em;border:0;text-align:left;background-image:url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAsAAAAMCAYAAAC0qUeeAAAABHNCSVQICAgIfAhkiAAAAAlwSFlzAAALEwAACxMBAJqcGAAAALlJREFUKJFjZEACcWmn5zMwMCbA+P///ZuzeI5ZKozPaF+/n4WBgYFB7gmfKiPj30PfeP/Irem3+h5SeIyT4yvLQxZGFuv7Eh/vMzAwMDDGpJz6wcTExM5AEPz7BbX+zH98ymDyTMiCsamnq7HRMICimJGRsQUbjVUxIUAvxf8ZqrDSSCoY49JO/UtLO8OFzbSkpCO8cSlnfjMwMDCwMDAw/mdgOD3nBwPDp7i0MxiK/0BsmMbAwMAAACl8PxDSJvyvAAAAAElFTkSuQmCC);background-repeat:no-repeat;background-position:0 50%;background-size:12px 12px;color:#5e66cc;text-decoration:none}.leaflet-measure-resultpopup a.deletemarkup,.leaflet-measure-resultpopup a.deletemarkup:hover{background-color:transparent}.leaflet-retina .leaflet-measure-resultpopup a.deletemarkup{background-image:url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABYAAAAYCAYAAAD+vg1LAAAABHNCSVQICAgIfAhkiAAAAAlwSFlzAAALEwAACxMBAJqcGAAAAW5JREFUSIntlbtKA2EQhc8/axIVrUQFBRsRRLCL+gIRQeuAxbpNLq2laGklpLYxVkkh2lip4AsIZkmZRiy0sPCCoEYwlxmLJLLZi+wmYpXTnRnmm/mHYVfBQ+uJq/EwhfJQHANItWdZAFxWQfrRQfTZrZ68wGEtlIHCshMKNGK0EhLsedW7FDWn1bR7ACGImsllF26teSNVmIaSG2ZUVEQm8/tLLw5wPH6iPc6NtjWYehjaVkrtQnCey0bX3JobKfMMCqsQ7NxNvGesubHSkygjaX6CMOD1pM7EZRJCBUD9L7ECqv0YI22KkTalU5i93vMqutX/g/XkdVlPm29+vV19nh2JBoN43xN3qx64B3bK847B/CFEdd/eLzh3uDgcxNvVXIVYPvTi+lf5Xc4ay465DAAbieJsUKyRKM43EPzaijVXoYSlcEoKutKkZKTNoBM3MXRsAwMRrm5+aeERMMeIKNC1MDMrogvur221Yt/I6IasMWr/dwAAAABJRU5ErkJggg==)}.leaflet-measure-resultpopup a.deletemarkup:hover{opacity:.5;text-decoration:none}.actions-cell{position:relative}.actions-dropdown{position:relative;display:inline-block}.actions-btn{background:transparent;border:none;color:#64748b;cursor:pointer;padding:6px;border-radius:6px;display:flex;align-items:center;justify-content:center;transition:all .2s}.actions-btn:hover{background:#f1f5f9;color:#1e293b}.dropdown-menu{position:absolute;right:0;top:100%;margin-top:4px;background:#fff;border:1px solid #e2e8f0;border-radius:8px;box-shadow:0 10px 25px -5px #0000001a,0 8px 10px -6px #0000001a;min-width:180px;z-index:100;animation:dropdownFadeIn .15s ease-out}@keyframes dropdownFadeIn{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.dropdown-item{display:flex;align-items:center;gap:10px;width:100%;padding:10px 16px;border:none;background:none;color:#475569;font-size:14px;font-weight:500;cursor:pointer;transition:all .15s;text-align:left}.dropdown-item:first-child{border-top-left-radius:8px;border-top-right-radius:8px}.dropdown-item:last-child{border-bottom-left-radius:8px;border-bottom-right-radius:8px}.dropdown-item:hover{background:#f8fafc;color:#1e293b}.dropdown-item svg{width:16px;height:16px;flex-shrink:0}.dropdown-item-danger{color:#dc2626}.dropdown-item-danger:hover{background:#fef2f2;color:#b91c1c}.dropdown-divider{height:1px;background:#e2e8f0;margin:4px 0}.global-filter-container{display:flex;flex-wrap:wrap;gap:12px;align-items:center;background:#fff;padding:12px;border-radius:8px;border:1px solid #e2e8f0;margin-bottom:20px}.filter-group{display:flex;align-items:center;gap:8px;background:#f8fafc;padding:6px 12px;border-radius:6px;border:1px solid #cbd5e1}.filter-label{font-size:11px;font-weight:700;text-transform:uppercase;color:#64748b;margin-right:4px}.filter-input{border:none;background:transparent;font-size:13px;color:#334155;outline:none;min-width:140px}.filter-input::placeholder{color:#94a3b8}.date-range-container{display:flex;align-items:center;gap:6px}.filter-date-input{border:none;background:transparent;font-size:12px;color:#334155;outline:none;font-family:inherit;cursor:pointer}.filter-separator{color:#cbd5e1}@media (max-width: 768px){.global-filter-container{flex-direction:column;align-items:stretch}}.ticket-modal{width:700px;max-width:95vw}.modal-tabs{display:flex;border-bottom:2px solid #e0e0e0;margin-bottom:20px}.tab-btn{flex:1;padding:12px 16px;background:none;border:none;border-bottom:2px solid transparent;cursor:pointer;font-weight:500;color:#666;transition:all .2s;margin-bottom:-2px}.tab-btn:hover{color:#333;background-color:#f9f9f9}.tab-btn.active{color:#2c3e50;border-bottom-color:#3498db;font-weight:600}.tab-pane{animation:fadeIn .3s ease}@keyframes fadeIn{0%{opacity:0;transform:translateY(5px)}to{opacity:1;transform:translateY(0)}}.form-group-row{display:flex;gap:16px}.form-group-row .form-group{flex:1}.form-group label{display:block;margin-bottom:6px;font-weight:500;font-size:.9em;color:#333}.form-group select,.form-group input,.form-group textarea{width:100%;padding:10px;border:1px solid #ddd;border-radius:6px;font-size:14px}.form-group select:disabled{background-color:#f5f5f5;cursor:not-allowed}.equipment-info-card{background-color:#f8fbff;border:1px solid #cce5ff;border-radius:8px;padding:16px;margin-top:10px}.equipment-info-card h4{margin-top:0;margin-bottom:12px;font-size:1em;color:#0056b3}.info-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px 16px;font-size:.9em}.priority-options{display:flex;gap:12px}.priority-radio{display:flex;align-items:center;gap:6px;padding:8px 12px;border:1px solid #eee;border-radius:20px;cursor:pointer;font-size:.9em;transition:all .2s}.priority-radio:hover{background-color:#f0f0f0}.priority-radio.low input:checked+span,.priority-radio.low:has(input:checked){background-color:#e8f5e9;border-color:#4caf50;color:#2e7d32}.priority-radio.medium input:checked+span,.priority-radio.medium:has(input:checked){background-color:#fff8e1;border-color:#ffc107;color:#ff8f00}.priority-radio.high input:checked+span,.priority-radio.high:has(input:checked){background-color:#ffebee;border-color:#ef5350;color:#c62828}.priority-radio.critical input:checked+span,.priority-radio.critical:has(input:checked){background-color:#2c3e50;border-color:#2c3e50;color:#fff}.required{color:red}.parts-row{display:flex;gap:10px;margin-bottom:10px;align-items:center}.parts-row-extended{display:grid;grid-template-columns:200px 1fr 1fr 80px 40px;gap:10px;margin-bottom:10px;align-items:center}.part-category,.part-name-select,.part-name-input{font-size:13px}.part-name{flex:2}.part-quantity{width:100%;text-align:center}.remove-btn{width:32px;height:32px;background:#fee2e2;border:1px solid #fecaca;color:#dc2626;border-radius:6px;font-size:20px;font-weight:600;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s}.remove-btn:hover{background:#fecaca;border-color:#fca5a5}.add-part-btn{width:100%;padding:8px 12px;background:#f8fafc;border:1px dashed #cbd5e1;color:#64748b;border-radius:6px;font-size:13px;font-weight:600;cursor:pointer;transition:all .2s}.add-part-btn:hover{background:#f1f5f9;border-color:#94a3b8;color:#475569}.category-reference{margin-top:24px;padding:20px;background:#f8fafc;border:1px solid #e2e8f0;border-radius:8px}.category-reference h4{margin:0 0 16px;font-size:14px;font-weight:600;color:#1e293b}.category-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:16px}.category-section{background:#fff;border:1px solid #e2e8f0;border-radius:6px;padding:12px}.category-section h5{margin:0 0 8px;font-size:12px;font-weight:600;color:#64748b;text-transform:uppercase;letter-spacing:.5px}.category-section ul{margin:0;padding:0;list-style:none}.category-section li{font-size:12px;color:#475569;padding:4px 0;border-bottom:1px solid #f1f5f9}.category-section li:last-child{border-bottom:none}.category-section li.more-items{color:#94a3b8;font-style:italic}.modal-large{max-width:900px;max-height:90vh;overflow-y:auto}.info-banner,.success-banner{display:flex;align-items:flex-start;gap:12px;padding:12px;border-radius:8px;font-size:13px;margin-bottom:16px}.info-banner{background:#eff6ff;border:1px solid #dbeafe;color:#1e40af}.success-banner{background:#d1fae5;border:1px solid #a7f3d0;color:#065f46}.info-banner svg,.success-banner svg{flex-shrink:0;margin-top:2px}.checkbox-label{display:flex;align-items:flex-start;gap:10px;cursor:pointer;font-size:14px;color:#475569}.checkbox-label input[type=checkbox]{width:18px;height:18px;cursor:pointer;margin-top:2px}.help-text{font-size:12px;color:#94a3b8;margin:-4px 0 12px;font-style:italic}@media (max-width: 768px){.parts-row-extended{grid-template-columns:1fr;gap:8px}.category-grid{grid-template-columns:1fr}.modal-large{max-width:95%}}.fault-category-list{border:1px solid #e2e8f0;border-radius:6px;max-height:300px;overflow-y:auto;background:#f8fafc;padding:10px}.fault-category-group{background:#fff;border:1px solid #e2e8f0;border-radius:6px;padding:12px;margin-bottom:12px}.fault-category-group:last-child{margin-bottom:0}.fault-category-title{margin:0 0 10px;font-size:13px;font-weight:600;color:#1e293b;padding-bottom:6px;border-bottom:1px solid #f1f5f9}.fault-issues-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:8px}.fault-issue-checkbox{display:flex;align-items:flex-start;gap:8px;font-size:13px;color:#475569;cursor:pointer;padding:2px 0}.fault-issue-checkbox input{margin-top:3px}.fault-issue-checkbox:hover{color:#1e293b}.grid-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}.loading-spinner-small{padding:20px;text-align:center;color:#64748b;font-size:13px;font-style:italic}.checkbox-wrapper{background:#f1f5f9;padding:12px;border-radius:6px;border:1px solid #e2e8f0}.header-title{display:flex;align-items:center;gap:12px}.ticket-ref{font-size:14px;background:#f1f5f9;padding:2px 8px;border-radius:4px;color:#64748b;font-weight:500}.status-banner{display:flex;gap:24px;padding:16px;background:#f8fafc;border:1px solid #e2e8f0;border-radius:8px;margin-bottom:24px}.status-item{display:flex;flex-direction:column;gap:4px}.status-item .label{font-size:11px;text-transform:uppercase;color:#64748b;font-weight:600}.status-item .value{font-size:14px;color:#1e293b;font-weight:500}.status-badge,.priority-badge{color:#fff;padding:2px 8px;border-radius:12px;font-size:12px!important;display:inline-block}.details-grid{display:grid;grid-template-columns:2fr 1fr;gap:24px}.details-column{display:flex;flex-direction:column;gap:24px}.details-section h3{font-size:14px;color:#1e293b;margin:0 0 12px;font-weight:600;border-bottom:1px solid #f1f5f9;padding-bottom:8px}.description-box,.resolution-box{background:#fff;border:1px solid #e2e8f0;border-radius:6px;padding:16px;font-size:14px;line-height:1.6;color:#334155;white-space:pre-wrap}.resolution-box{background:#f0fdf4;border-color:#bbf7d0;color:#065f46}.info-list{display:flex;flex-direction:column;gap:12px}.info-row{display:flex;justify-content:space-between;font-size:13px;padding-bottom:8px;border-bottom:1px dashed #e2e8f0}.info-row:last-child{border-bottom:none}.info-row .label{color:#64748b}.info-row .value{color:#1e293b;font-weight:500;text-align:right}@media (max-width: 768px){.details-grid{grid-template-columns:1fr}.status-banner{flex-direction:column;gap:12px}.header-title{flex-direction:column;align-items:flex-start;gap:4px}}.repairs-container{min-height:calc(100vh - 56px);background:#f8fafc;padding:0;transition:background .3s}.repairs-header{background:linear-gradient(135deg,#1e3c72,#bcc9e8);padding:16px 20px;color:#fff;box-shadow:0 2px 4px #0000001a;margin-bottom:0}.header-content{display:flex;justify-content:space-between;align-items:center;width:100%}.repairs-header h1{font-size:20px;font-weight:700;color:#fff;margin:0}.header-subtitle{font-size:13px;color:#ffffffe6}.create-button{background:#fff3;border:1px solid rgba(255,255,255,.3);color:#fff;padding:8px 16px;border-radius:6px;font-size:13px;cursor:pointer;font-weight:600}.create-button:hover{background:#ffffff4d}.sticky-header{position:-webkit-sticky;position:sticky;top:0;z-index:100;background:#f8fafc;padding-bottom:0;box-shadow:0 4px 6px -1px #0000001a}.repairs-controls{background:#fff;border-bottom:1px solid #e2e8f0;padding:12px 24px;display:flex;justify-content:space-between;align-items:center;gap:20px;flex-wrap:wrap}.tabs-bar{display:flex;gap:8px}.tab-btn{padding:8px 16px;border:none;background:transparent;color:#64748b;font-weight:600;font-size:14px;cursor:pointer;border-radius:6px;transition:all .2s}.tab-btn:hover{background:#f1f5f9;color:#334155}.tab-btn.active{background:#e0f2fe;color:#0284c7}.filters-row{display:flex;gap:12px}.search-box input{padding:8px 12px;border:1px solid #cbd5e1;border-radius:6px;font-size:13px;min-width:250px}.filters-row select{padding:8px 12px;border:1px solid #cbd5e1;border-radius:6px;font-size:13px;cursor:pointer}.repairs-content-area{padding:24px}.repairs-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:20px}.repair-card{background:#fff;border:1px solid #e2e8f0;border-radius:12px;padding:16px;cursor:pointer;transition:transform .2s,box-shadow .2s;display:flex;flex-direction:column}.repair-card:hover{transform:translateY(-2px);box-shadow:0 4px 12px #0000001a;border-color:#3b82f6}.repair-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}.ref-number{font-weight:700;color:#3b82f6;font-size:13px;font-family:monospace}.repair-details h3{font-size:15px;font-weight:600;margin:0 0 4px;color:#1e293b;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.equipment-type{font-size:13px;color:#64748b;font-weight:500;margin-bottom:8px}.fault-desc{font-size:13px;color:#475569;line-height:1.5;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;margin-bottom:12px}.repair-meta{margin-top:auto;font-size:12px;color:#94a3b8;display:flex;flex-direction:column;gap:4px}.view-btn{margin-top:12px;width:100%;padding:8px;background:#f8fafc;border:1px solid #e2e8f0;color:#475569;border-radius:6px;font-weight:600;font-size:12px;cursor:pointer}.repair-card:hover .view-btn{background:#3b82f6;color:#fff;border-color:#3b82f6}.status-badge{padding:2px 8px;border-radius:4px;font-size:11px;font-weight:600;text-transform:uppercase}.status-new{background:#3b82f6;color:#fff}.status-assigned{background:#8b5cf6;color:#fff}.status-in-progress{background:#6366f1;color:#fff}.status-resolved{background:#10b981;color:#fff}.status-escalated{background:#ef4444;color:#fff}.status-closed{background:#000!important;color:#fff!important;border:1px solid #333}.status-on-hold{background:#f59e0b;color:#fff}.status-dot{width:8px;height:8px;border-radius:50%;background:#cbd5e1}.status-dot.status-new{background:#3b82f6}.status-dot.status-assigned{background:#8b5cf6}.status-dot.status-in-progress{background:#6366f1}.status-dot.status-resolved{background:#10b981}.status-dot.status-escalated{background:#ef4444}.status-dot.status-closed{background:#000}.status-dot.status-on-hold{background:#f59e0b}.mini-desc{font-size:12px;color:#475569;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin:8px 0 4px}body.dark .repairs-container{background:#0f172a}body.dark .repairs-controls{background:#1e293b;border-color:#334155}body.dark .tab-btn{color:#94a3b8}body.dark .tab-btn:hover{background:#334155;color:#fff}body.dark .tab-btn.active{background:#1e40af;color:#fff}body.dark .repair-card,body.dark .group-section{background:#1e293b;border-color:#334155}body.dark .repair-details h3,body.dark .group-header h3{color:#fff}body.dark .equipment-type,body.dark .mini-desc,body.dark .repair-meta{color:#94a3b8}body.dark .search-box input,body.dark .filters-row select{background:#334155;color:#fff;border-color:#475569}.leaflet-pane,.leaflet-tile,.leaflet-marker-icon,.leaflet-marker-shadow,.leaflet-tile-container,.leaflet-pane>svg,.leaflet-pane>canvas,.leaflet-zoom-box,.leaflet-image-layer,.leaflet-layer{position:absolute;left:0;top:0}.leaflet-container{overflow:hidden}.leaflet-tile,.leaflet-marker-icon,.leaflet-marker-shadow{-webkit-user-select:none;user-select:none;-webkit-user-drag:none}.leaflet-tile::selection{background:transparent}.leaflet-safari .leaflet-tile{image-rendering:-webkit-optimize-contrast}.leaflet-safari .leaflet-tile-container{width:1600px;height:1600px;-webkit-transform-origin:0 0}.leaflet-marker-icon,.leaflet-marker-shadow{display:block}.leaflet-container .leaflet-overlay-pane svg{max-width:none!important;max-height:none!important}.leaflet-container .leaflet-marker-pane img,.leaflet-container .leaflet-shadow-pane img,.leaflet-container .leaflet-tile-pane img,.leaflet-container img.leaflet-image-layer,.leaflet-container .leaflet-tile{max-width:none!important;max-height:none!important;width:auto;padding:0}.leaflet-container img.leaflet-tile{mix-blend-mode:plus-lighter}.leaflet-container.leaflet-touch-zoom{touch-action:pan-x pan-y}.leaflet-container.leaflet-touch-drag{touch-action:none;touch-action:pinch-zoom}.leaflet-container.leaflet-touch-drag.leaflet-touch-zoom{touch-action:none}.leaflet-container{-webkit-tap-highlight-color:transparent}.leaflet-container a{-webkit-tap-highlight-color:rgba(51,181,229,.4)}.leaflet-tile{filter:inherit;visibility:hidden}.leaflet-tile-loaded{visibility:inherit}.leaflet-zoom-box{width:0;height:0;box-sizing:border-box;z-index:800}.leaflet-overlay-pane svg{-moz-user-select:none}.leaflet-pane{z-index:400}.leaflet-tile-pane{z-index:200}.leaflet-overlay-pane{z-index:400}.leaflet-shadow-pane{z-index:500}.leaflet-marker-pane{z-index:600}.leaflet-tooltip-pane{z-index:650}.leaflet-popup-pane{z-index:700}.leaflet-map-pane canvas{z-index:100}.leaflet-map-pane svg{z-index:200}.leaflet-vml-shape{width:1px;height:1px}.lvml{behavior:url(#default#VML);display:inline-block;position:absolute}.leaflet-control{position:relative;z-index:800;pointer-events:visiblePainted;pointer-events:auto}.leaflet-top,.leaflet-bottom{position:absolute;z-index:1000;pointer-events:none}.leaflet-top{top:0}.leaflet-right{right:0}.leaflet-bottom{bottom:0}.leaflet-left{left:0}.leaflet-control{float:left;clear:both}.leaflet-right .leaflet-control{float:right}.leaflet-top .leaflet-control{margin-top:10px}.leaflet-bottom .leaflet-control{margin-bottom:10px}.leaflet-left .leaflet-control{margin-left:10px}.leaflet-right .leaflet-control{margin-right:10px}.leaflet-fade-anim .leaflet-popup{opacity:0;transition:opacity .2s linear}.leaflet-fade-anim .leaflet-map-pane .leaflet-popup{opacity:1}.leaflet-zoom-animated{transform-origin:0 0}svg.leaflet-zoom-animated{will-change:transform}.leaflet-zoom-anim .leaflet-zoom-animated{transition:transform .25s cubic-bezier(0,0,.25,1)}.leaflet-zoom-anim .leaflet-tile,.leaflet-pan-anim .leaflet-tile{transition:none}.leaflet-zoom-anim .leaflet-zoom-hide{visibility:hidden}.leaflet-interactive{cursor:pointer}.leaflet-grab{cursor:grab}.leaflet-crosshair,.leaflet-crosshair .leaflet-interactive{cursor:crosshair}.leaflet-popup-pane,.leaflet-control{cursor:auto}.leaflet-dragging .leaflet-grab,.leaflet-dragging .leaflet-grab .leaflet-interactive,.leaflet-dragging .leaflet-marker-draggable{cursor:move;cursor:grabbing}.leaflet-marker-icon,.leaflet-marker-shadow,.leaflet-image-layer,.leaflet-pane>svg path,.leaflet-tile-container{pointer-events:none}.leaflet-marker-icon.leaflet-interactive,.leaflet-image-layer.leaflet-interactive,.leaflet-pane>svg path.leaflet-interactive,svg.leaflet-image-layer.leaflet-interactive path{pointer-events:visiblePainted;pointer-events:auto}.leaflet-container{background:#ddd;outline-offset:1px}.leaflet-container a{color:#0078a8}.leaflet-zoom-box{border:2px dotted #38f;background:#ffffff80}.leaflet-container{font-family:Helvetica Neue,Arial,Helvetica,sans-serif;font-size:12px;font-size:.75rem;line-height:1.5}.leaflet-bar{box-shadow:0 1px 5px #000000a6;border-radius:4px}.leaflet-bar a{background-color:#fff;border-bottom:1px solid #ccc;width:26px;height:26px;line-height:26px;display:block;text-align:center;text-decoration:none;color:#000}.leaflet-bar a,.leaflet-control-layers-toggle{background-position:50% 50%;background-repeat:no-repeat;display:block}.leaflet-bar a:hover,.leaflet-bar a:focus{background-color:#f4f4f4}.leaflet-bar a:first-child{border-top-left-radius:4px;border-top-right-radius:4px}.leaflet-bar a:last-child{border-bottom-left-radius:4px;border-bottom-right-radius:4px;border-bottom:none}.leaflet-bar a.leaflet-disabled{cursor:default;background-color:#f4f4f4;color:#bbb}.leaflet-touch .leaflet-bar a{width:30px;height:30px;line-height:30px}.leaflet-touch .leaflet-bar a:first-child{border-top-left-radius:2px;border-top-right-radius:2px}.leaflet-touch .leaflet-bar a:last-child{border-bottom-left-radius:2px;border-bottom-right-radius:2px}.leaflet-control-zoom-in,.leaflet-control-zoom-out{font:700 18px Lucida Console,Monaco,monospace;text-indent:1px}.leaflet-touch .leaflet-control-zoom-in,.leaflet-touch .leaflet-control-zoom-out{font-size:22px}.leaflet-control-layers{box-shadow:0 1px 5px #0006;background:#fff;border-radius:5px}.leaflet-control-layers-toggle{background-image:url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABoAAAAaCAQAAAADQ4RFAAACf0lEQVR4AY1UM3gkARTePdvdoTxXKc+qTl3aU5U6b2Kbkz3Gtq3Zw6ziLGNPzrYx7946Tr6/ee/XeCQ4D3ykPtL5tHno4n0d/h3+xfuWHGLX81cn7r0iTNzjr7LrlxCqPtkbTQEHeqOrTy4Yyt3VCi/IOB0v7rVC7q45Q3Gr5K6jt+3Gl5nCoDD4MtO+j96Wu8atmhGqcNGHObuf8OM/x3AMx38+4Z2sPqzCxRFK2aF2e5Jol56XTLyggAMTL56XOMoS1W4pOyjUcGGQdZxU6qRh7B9Zp+PfpOFlqt0zyDZckPi1ttmIp03jX8gyJ8a/PG2yutpS/Vol7peZIbZcKBAEEheEIAgFbDkz5H6Zrkm2hVWGiXKiF4Ycw0RWKdtC16Q7qe3X4iOMxruonzegJzWaXFrU9utOSsLUmrc0YjeWYjCW4PDMADElpJSSQ0vQvA1Tm6/JlKnqFs1EGyZiFCqnRZTEJJJiKRYzVYzJck2Rm6P4iH+cmSY0YzimYa8l0EtTODFWhcMIMVqdsI2uiTvKmTisIDHJ3od5GILVhBCarCfVRmo4uTjkhrhzkiBV7SsaqS+TzrzM1qpGGUFt28pIySQHR6h7F6KSwGWm97ay+Z+ZqMcEjEWebE7wxCSQwpkhJqoZA5ivCdZDjJepuJ9IQjGGUmuXJdBFUygxVqVsxFsLMbDe8ZbDYVCGKxs+W080max1hFCarCfV+C1KATwcnvE9gRRuMP2prdbWGowm1KB1y+zwMMENkM755cJ2yPDtqhTI6ED1M/82yIDtC/4j4BijjeObflpO9I9MwXTCsSX8jWAFeHr05WoLTJ5G8IQVS/7vwR6ohirYM7f6HzYpogfS3R2OAAAAAElFTkSuQmCC);width:36px;height:36px}.leaflet-retina .leaflet-control-layers-toggle{background-image:url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAADQAAAA0CAQAAABvcdNgAAAEsklEQVR4AWL4TydIhpZK1kpWOlg0w3ZXP6D2soBtG42jeI6ZmQTHzAxiTbSJsYLjO9HhP+WOmcuhciVnmHVQcJnp7DFvScowZorad/+V/fVzMdMT2g9Cv9guXGv/7pYOrXh2U+RRR3dSd9JRx6bIFc/ekqHI29JC6pJ5ZEh1yWkhkbcFeSjxgx3L2m1cb1C7bceyxA+CNjT/Ifff+/kDk2u/w/33/IeCMOSaWZ4glosqT3DNnNZQ7Cs58/3Ce5HL78iZH/vKVIaYlqzfdLu8Vi7dnvUbEza5Idt36tquZFldl6N5Z/POLof0XLK61mZCmJSWjVF9tEjUluu74IUXvgttuVIHE7YxSkaYhJZam7yiM9Pv82JYfl9nptxZaxMJE4YSPty+vF0+Y2up9d3wwijfjZbabqm/3bZ9ecKHsiGmRflnn1MW4pjHf9oLufyn2z3y1D6n8g8TZhxyzipLNPnAUpsOiuWimg52psrTZYnOWYNDTMuWBWa0tJb4rgq1UvmutpaYEbZlwU3CLJm/ayYjHW5/h7xWLn9Hh1vepDkyf7dE7MtT5LR4e7yYpHrkhOUpEfssBLq2pPhAqoSWKUkk7EDqkmK6RrCEzqDjhNDWNE+XSMvkJRDWlZTmCW0l0PHQGRZY5t1L83kT0Y3l2SItk5JAWHl2dCOBm+fPu3fo5/3v61RMCO9Jx2EEYYhb0rmNQMX/vm7gqOEJLcXTGw3CAuRNeyaPWwjR8PRqKQ1PDA/dpv+on9Shox52WFnx0KY8onHayrJzm87i5h9xGw/tfkev0jGsQizqezUKjk12hBMKJ4kbCqGPVNXudyyrShovGw5CgxsRICxF6aRmSjlBnHRzg7Gx8fKqEubI2rahQYdR1YgDIRQO7JvQyD52hoIQx0mxa0ODtW2Iozn1le2iIRdzwWewedyZzewidueOGqlsn1MvcnQpuVwLGG3/IR1hIKxCjelIDZ8ldqWz25jWAsnldEnK0Zxro19TGVb2ffIZEsIO89EIEDvKMPrzmBOQcKQ+rroye6NgRRxqR4U8EAkz0CL6uSGOm6KQCdWjvjRiSP1BPalCRS5iQYiEIvxuBMJEWgzSoHADcVMuN7IuqqTeyUPq22qFimFtxDyBBJEwNyt6TM88blFHao/6tWWhuuOM4SAK4EI4QmFHA+SEyWlp4EQoJ13cYGzMu7yszEIBOm2rVmHUNqwAIQabISNMRstmdhNWcFLsSm+0tjJH1MdRxO5Nx0WDMhCtgD6OKgZeljJqJKc9po8juskR9XN0Y1lZ3mWjLR9JCO1jRDMd0fpYC2VnvjBSEFg7wBENc0R9HFlb0xvF1+TBEpF68d+DHR6IOWVv2BECtxo46hOFUBd/APU57WIoEwJhIi2CdpyZX0m93BZicktMj1AS9dClteUFAUNUIEygRZCtik5zSxI9MubTBH1GOiHsiLJ3OCoSZkILa9PxiN0EbvhsAo8tdAf9Seepd36lGWHmtNANTv5Jd0z4QYyeo/UEJqxKRpg5LZx6btLPsOaEmdMyxYdlc8LMaJnikDlhclqmPiQnTEpLUIZEwkRagjYkEibQErwhkTAKCLQEbUgkzJQWc/0PstHHcfEdQ+UAAAAASUVORK5CYII=);background-size:26px 26px}.leaflet-touch .leaflet-control-layers-toggle{width:44px;height:44px}.leaflet-control-layers .leaflet-control-layers-list,.leaflet-control-layers-expanded .leaflet-control-layers-toggle{display:none}.leaflet-control-layers-expanded .leaflet-control-layers-list{display:block;position:relative}.leaflet-control-layers-expanded{padding:6px 10px 6px 6px;color:#333;background:#fff}.leaflet-control-layers-scrollbar{overflow-y:scroll;overflow-x:hidden;padding-right:5px}.leaflet-control-layers-selector{margin-top:2px;position:relative;top:1px}.leaflet-control-layers label{display:block;font-size:13px;font-size:1.08333em}.leaflet-control-layers-separator{height:0;border-top:1px solid #ddd;margin:5px -10px 5px -6px}.leaflet-default-icon-path{background-image:url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABkAAAApCAYAAADAk4LOAAAFgUlEQVR4Aa1XA5BjWRTN2oW17d3YaZtr2962HUzbDNpjszW24mRt28p47v7zq/bXZtrp/lWnXr337j3nPCe85NcypgSFdugCpW5YoDAMRaIMqRi6aKq5E3YqDQO3qAwjVWrD8Ncq/RBpykd8oZUb/kaJutow8r1aP9II0WmLKLIsJyv1w/kqw9Ch2MYdB++12Onxee/QMwvf4/Dk/Lfp/i4nxTXtOoQ4pW5Aj7wpici1A9erdAN2OH64x8OSP9j3Ft3b7aWkTg/Fm91siTra0f9on5sQr9INejH6CUUUpavjFNq1B+Oadhxmnfa8RfEmN8VNAsQhPqF55xHkMzz3jSmChWU6f7/XZKNH+9+hBLOHYozuKQPxyMPUKkrX/K0uWnfFaJGS1QPRtZsOPtr3NsW0uyh6NNCOkU3Yz+bXbT3I8G3xE5EXLXtCXbbqwCO9zPQYPRTZ5vIDXD7U+w7rFDEoUUf7ibHIR4y6bLVPXrz8JVZEql13trxwue/uDivd3fkWRbS6/IA2bID4uk0UpF1N8qLlbBlXs4Ee7HLTfV1j54APvODnSfOWBqtKVvjgLKzF5YdEk5ewRkGlK0i33Eofffc7HT56jD7/6U+qH3Cx7SBLNntH5YIPvODnyfIXZYRVDPqgHtLs5ABHD3YzLuespb7t79FY34DjMwrVrcTuwlT55YMPvOBnRrJ4VXTdNnYug5ucHLBjEpt30701A3Ts+HEa73u6dT3FNWwflY86eMHPk+Yu+i6pzUpRrW7SNDg5JHR4KapmM5Wv2E8Tfcb1HoqqHMHU+uWDD7zg54mz5/2BSnizi9T1Dg4QQXLToGNCkb6tb1NU+QAlGr1++eADrzhn/u8Q2YZhQVlZ5+CAOtqfbhmaUCS1ezNFVm2imDbPmPng5wmz+gwh+oHDce0eUtQ6OGDIyR0uUhUsoO3vfDmmgOezH0mZN59x7MBi++WDL1g/eEiU3avlidO671bkLfwbw5XV2P8Pzo0ydy4t2/0eu33xYSOMOD8hTf4CrBtGMSoXfPLchX+J0ruSePw3LZeK0juPJbYzrhkH0io7B3k164hiGvawhOKMLkrQLyVpZg8rHFW7E2uHOL888IBPlNZ1FPzstSJM694fWr6RwpvcJK60+0HCILTBzZLFNdtAzJaohze60T8qBzyh5ZuOg5e7uwQppofEmf2++DYvmySqGBuKaicF1blQjhuHdvCIMvp8whTTfZzI7RldpwtSzL+F1+wkdZ2TBOW2gIF88PBTzD/gpeREAMEbxnJcaJHNHrpzji0gQCS6hdkEeYt9DF/2qPcEC8RM28Hwmr3sdNyht00byAut2k3gufWNtgtOEOFGUwcXWNDbdNbpgBGxEvKkOQsxivJx33iow0Vw5S6SVTrpVq11ysA2Rp7gTfPfktc6zhtXBBC+adRLshf6sG2RfHPZ5EAc4sVZ83yCN00Fk/4kggu40ZTvIEm5g24qtU4KjBrx/BTTH8ifVASAG7gKrnWxJDcU7x8X6Ecczhm3o6YicvsLXWfh3Ch1W0k8x0nXF+0fFxgt4phz8QvypiwCCFKMqXCnqXExjq10beH+UUA7+nG6mdG/Pu0f3LgFcGrl2s0kNNjpmoJ9o4B29CMO8dMT4Q5ox8uitF6fqsrJOr8qnwNbRzv6hSnG5wP+64C7h9lp30hKNtKdWjtdkbuPA19nJ7Tz3zR/ibgARbhb4AlhavcBebmTHcFl2fvYEnW0ox9xMxKBS8btJ+KiEbq9zA4RthQXDhPa0T9TEe69gWupwc6uBUphquXgf+/FrIjweHQS4/pduMe5ERUMHUd9xv8ZR98CxkS4F2n3EUrUZ10EYNw7BWm9x1GiPssi3GgiGRDKWRYZfXlON+dfNbM+GgIwYdwAAAAASUVORK5CYII=)}.leaflet-container .leaflet-control-attribution{background:#fff;background:#fffc;margin:0}.leaflet-control-attribution,.leaflet-control-scale-line{padding:0 5px;color:#333;line-height:1.4}.leaflet-control-attribution a{text-decoration:none}.leaflet-control-attribution a:hover,.leaflet-control-attribution a:focus{text-decoration:underline}.leaflet-attribution-flag{display:inline!important;vertical-align:baseline!important;width:1em;height:.6669em}.leaflet-left .leaflet-control-scale{margin-left:5px}.leaflet-bottom .leaflet-control-scale{margin-bottom:5px}.leaflet-control-scale-line{border:2px solid #777;border-top:none;line-height:1.1;padding:2px 5px 1px;white-space:nowrap;box-sizing:border-box;background:#fffc;text-shadow:1px 1px #fff}.leaflet-control-scale-line:not(:first-child){border-top:2px solid #777;border-bottom:none;margin-top:-2px}.leaflet-control-scale-line:not(:first-child):not(:last-child){border-bottom:2px solid #777}.leaflet-touch .leaflet-control-attribution,.leaflet-touch .leaflet-control-layers,.leaflet-touch .leaflet-bar{box-shadow:none}.leaflet-touch .leaflet-control-layers,.leaflet-touch .leaflet-bar{border:2px solid rgba(0,0,0,.2);background-clip:padding-box}.leaflet-popup{position:absolute;text-align:center;margin-bottom:20px}.leaflet-popup-content-wrapper{padding:1px;text-align:left;border-radius:12px}.leaflet-popup-content{margin:13px 24px 13px 20px;line-height:1.3;font-size:13px;font-size:1.08333em;min-height:1px}.leaflet-popup-content p{margin:1.3em 0}.leaflet-popup-tip-container{width:40px;height:20px;position:absolute;left:50%;margin-top:-1px;margin-left:-20px;overflow:hidden;pointer-events:none}.leaflet-popup-tip{width:17px;height:17px;padding:1px;margin:-10px auto 0;pointer-events:auto;transform:rotate(45deg)}.leaflet-popup-content-wrapper,.leaflet-popup-tip{background:#fff;color:#333;box-shadow:0 3px 14px #0006}.leaflet-container a.leaflet-popup-close-button{position:absolute;top:0;right:0;border:none;text-align:center;width:24px;height:24px;font:16px/24px Tahoma,Verdana,sans-serif;color:#757575;text-decoration:none;background:transparent}.leaflet-container a.leaflet-popup-close-button:hover,.leaflet-container a.leaflet-popup-close-button:focus{color:#585858}.leaflet-popup-scrolled{overflow:auto}.leaflet-oldie .leaflet-popup-content-wrapper{-ms-zoom:1}.leaflet-oldie .leaflet-popup-tip{width:24px;margin:0 auto;-ms-filter:"progid:DXImageTransform.Microsoft.Matrix(M11=0.70710678, M12=0.70710678, M21=-0.70710678, M22=0.70710678)";filter:progid:DXImageTransform.Microsoft.Matrix(M11=.70710678,M12=.70710678,M21=-.70710678,M22=.70710678)}.leaflet-oldie .leaflet-control-zoom,.leaflet-oldie .leaflet-control-layers,.leaflet-oldie .leaflet-popup-content-wrapper,.leaflet-oldie .leaflet-popup-tip{border:1px solid #999}.leaflet-div-icon{background:#fff;border:1px solid #666}.leaflet-tooltip{position:absolute;padding:6px;background-color:#fff;border:1px solid #fff;border-radius:3px;color:#222;white-space:nowrap;-webkit-user-select:none;user-select:none;pointer-events:none;box-shadow:0 1px 3px #0006}.leaflet-tooltip.leaflet-interactive{cursor:pointer;pointer-events:auto}.leaflet-tooltip-top:before,.leaflet-tooltip-bottom:before,.leaflet-tooltip-left:before,.leaflet-tooltip-right:before{position:absolute;pointer-events:none;border:6px solid transparent;background:transparent;content:""}.leaflet-tooltip-bottom{margin-top:6px}.leaflet-tooltip-top{margin-top:-6px}.leaflet-tooltip-bottom:before,.leaflet-tooltip-top:before{left:50%;margin-left:-6px}.leaflet-tooltip-top:before{bottom:0;margin-bottom:-12px;border-top-color:#fff}.leaflet-tooltip-bottom:before{top:0;margin-top:-12px;margin-left:-6px;border-bottom-color:#fff}.leaflet-tooltip-left{margin-left:-6px}.leaflet-tooltip-right{margin-left:6px}.leaflet-tooltip-left:before,.leaflet-tooltip-right:before{top:50%;margin-top:-6px}.leaflet-tooltip-left:before{right:0;margin-right:-12px;border-left-color:#fff}.leaflet-tooltip-right:before{left:0;margin-left:-12px;border-right-color:#fff}@media print{.leaflet-control{-webkit-print-color-adjust:exact;print-color-adjust:exact}}.map-container{min-height:100vh;background:#f8fafc;padding:24px;display:flex;flex-direction:column}.map-container-modern{min-height:100vh;background:#f8fafc;display:flex;flex-direction:column}.map-header-modern{background:linear-gradient(135deg,#1e3c72,#bcc9e8);padding:16px 24px;border-bottom:1px solid #e2e8f0;box-shadow:0 1px 3px #0000000d}.header-title{display:flex;align-items:center;gap:16px}.header-title h1{font-size:24px;font-weight:700;color:#fff;margin:0}.facility-count-badge{background:#eff6ff;color:#1e40af;padding:4px 12px;border-radius:12px;font-size:13px;font-weight:600}.map-filters-bar{background:#fff;padding:12px 24px;border-bottom:1px solid #e2e8f0;box-shadow:0 1px 2px #00000008}.map-filters-bar .location-filters{display:flex;gap:16px;align-items:flex-end}.filters-compact{display:flex;gap:12px;flex-wrap:wrap}.map-area-fullwidth{flex:1;position:relative;background:#fff}.map-area-fullwidth .leaflet-container{height:100%;width:100%;min-height:calc(100vh - 180px)}.map-header{background:linear-gradient(135deg,#1e3c72,#bcc9e8);padding:24px 32px;margin-bottom:24px;box-shadow:0 4px 6px -1px #0000001a}.map-header h1{font-size:28px;font-weight:700;color:#fff;margin:0 0 4px}.map-layout{display:grid;grid-template-columns:350px 1fr;gap:24px;flex:1;min-height:0}.map-sidebar{background:#fff;border-radius:12px;padding:24px;box-shadow:0 1px 3px #0000001a;border:1px solid #e2e8f0;display:flex;flex-direction:column;max-height:calc(100vh - 180px)}.sidebar-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px;padding-bottom:16px;border-bottom:2px solid #f1f5f9}.sidebar-header h2{font-size:20px;font-weight:600;color:#1e293b;margin:0}.facility-count{background:#eff6ff;color:#1e40af;padding:4px 12px;border-radius:12px;font-size:14px;font-weight:600}.sidebar-filters{display:flex;flex-direction:column;gap:12px;margin-bottom:20px}.filter-select{width:100%;padding:10px 12px;border:1px solid #e2e8f0;border-radius:8px;font-size:14px;color:#334155;background:#fff;cursor:pointer;transition:all .2s}.filter-select:focus{outline:none;border-color:#1e40af;box-shadow:0 0 0 3px #1e40af1a}.checkbox-label{display:flex;align-items:center;gap:8px;font-size:14px;color:#475569;cursor:pointer}.checkbox-label input[type=checkbox]{width:16px;height:16px;cursor:pointer}.facility-list{flex:1;overflow-y:auto;margin:-8px;padding:8px}.facility-list::-webkit-scrollbar{width:6px}.facility-list::-webkit-scrollbar-track{background:#f1f5f9;border-radius:3px}.facility-list::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:3px}.facility-list::-webkit-scrollbar-thumb:hover{background:#94a3b8}.empty-list{display:flex;align-items:center;justify-content:center;padding:40px 20px;color:#94a3b8}.facility-item{padding:16px;border-radius:8px;margin-bottom:8px;cursor:pointer;transition:all .2s;border:1px solid transparent}.facility-item:hover{background:#f8fafc;border-color:#e2e8f0}.facility-item.selected{background:#eff6ff;border-color:#1e40af}.facility-item-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:8px}.facility-item h3{font-size:15px;font-weight:600;color:#1e293b;margin:0;line-height:1.4}.issue-badge{width:20px;height:20px;background:#fee2e2;color:#dc2626;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:700;flex-shrink:0}.facility-location{font-size:13px;color:#64748b;margin:0 0 4px}.facility-equipment{font-size:12px;color:#94a3b8;margin:0}.map-area{background:#fff;border-radius:12px;box-shadow:0 1px 3px #0000001a;border:1px solid #e2e8f0;position:relative;overflow:hidden;min-height:600px}.map-area .leaflet-container{height:100%;width:100%;min-height:600px;border-radius:12px}.map-placeholder{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;color:#94a3b8;padding:40px;text-align:center}.map-placeholder svg{margin-bottom:24px}.map-placeholder h2{font-size:24px;font-weight:600;color:#64748b;margin:0 0 8px}.map-placeholder p{font-size:16px;margin:0 0 8px}.map-note{max-width:400px;font-size:14px;color:#94a3b8;margin-top:16px}.facility-detail-panel{position:absolute;top:20px;right:20px;width:320px;background:#fff;border-radius:12px;box-shadow:0 8px 24px #00000026;border:1px solid #e2e8f0;overflow:hidden;animation:slideIn .3s ease-out}@keyframes slideIn{0%{opacity:0;transform:translate(20px)}to{opacity:1;transform:translate(0)}}.panel-header{display:flex;justify-content:space-between;align-items:center;padding:20px;background:linear-gradient(135deg,#eff6ff,#dbeafe);border-bottom:1px solid #e2e8f0}.panel-header h3{font-size:18px;font-weight:600;color:#1e293b;margin:0}.close-btn{background:transparent;border:none;color:#64748b;cursor:pointer;padding:4px;border-radius:4px;transition:all .2s}.close-btn:hover{background:#0000000d;color:#1e293b}.panel-content{padding:20px}.detail-section{margin-bottom:20px}.detail-section h4{font-size:13px;font-weight:600;color:#64748b;text-transform:uppercase;letter-spacing:.5px;margin:0 0 8px}.detail-section p{font-size:14px;color:#334155;margin:0 0 4px}.facility-code{font-family:Courier New,monospace;color:#64748b;font-size:13px}.status-item{padding:8px 12px;border-radius:6px;font-size:13px;font-weight:500;margin-bottom:6px}.status-ok{background:#d1fae5;color:#059669}.status-warning{background:#fef3c7;color:#d97706}.status-critical{background:#fee2e2;color:#dc2626}.panel-actions{display:flex;gap:10px;margin-top:20px}.action-btn{flex:1;padding:10px;border:none;border-radius:8px;font-size:13px;font-weight:600;cursor:pointer;transition:all .2s}.primary-btn{background:linear-gradient(135deg,#1e40af,#2563eb);color:#fff}.primary-btn:hover{transform:translateY(-1px);box-shadow:0 4px 12px #1e40af4d}.secondary-btn{background:#f8fafc;color:#475569;border:1px solid #e2e8f0}.secondary-btn:hover{background:#f1f5f9;border-color:#cbd5e1}@media (max-width: 1024px){.map-layout{grid-template-columns:1fr}.map-sidebar{max-height:400px}.facility-detail-panel{position:static;width:100%;margin-top:20px}}@media (max-width: 768px){.map-container{padding:16px}.map-header h1{font-size:24px}.map-sidebar{max-height:300px}}.reports-container{padding:0;background:#f8fafc;min-height:calc(100vh - 64px);overflow-x:hidden}.reports-header{background:linear-gradient(135deg,#1e3c72,#bcc9e8);color:#fff;padding:24px 32px;box-shadow:0 4px 6px -1px #0000001a}.sticky-header-shadow{position:-webkit-sticky;position:sticky;top:0;z-index:1100;width:100%}.reports-content{max-width:100%;margin:0;padding:32px}.metrics-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:24px;margin-bottom:32px}.metric-card{background:#fff;padding:24px;border-radius:16px;box-shadow:0 4px 6px -1px #0000000d;border:2px solid transparent;display:flex;align-items:flex-start;gap:16px;transition:all .3s cubic-bezier(.4,0,.2,1);cursor:pointer;position:relative;overflow:hidden}.metric-card:hover{transform:translateY(-4px) scale(1.02);box-shadow:0 12px 20px -3px #00000026}.metric-card:active{transform:translateY(-2px) scale(1.01)}.metric-card.active{background:#f8fafc;border-color:currentColor;transform:translateY(-4px);box-shadow:0 0 0 4px #3b82f61a}.metric-primary.active{border-color:#3b82f6}.metric-success.active{border-color:#10b981}.metric-info.active{border-color:#8b5cf6}.metric-warning.active{border-color:#ef4444}.metric-icon{padding:12px;border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:24px}.metric-primary .metric-icon{background:#eff6ff;color:#3b82f6}.metric-success .metric-icon{background:#f0fdf4;color:#10b981}.metric-info .metric-icon{background:#f5f3ff;color:#8b5cf6}.metric-warning .metric-icon{background:#fef2f2;color:#ef4444}.metric-content{flex:1}.metric-label{font-size:13px;color:#64748b;margin:0 0 4px;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.metric-value{font-size:28px;font-weight:700;color:#0f172a;margin:0 0 4px;line-height:1.2}.metric-subtitle{font-size:12px;color:#94a3b8;margin:0}.drill-down-section{background:#fff;border-radius:16px;padding:24px;margin-bottom:32px;border:1px solid #e2e8f0;box-shadow:0 4px 6px -1px #0000000d;animation:fadeIn .4s ease-out}@keyframes fadeIn{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px;padding-bottom:12px;border-bottom:1px solid #f1f5f9}.section-header h3{margin:0;color:#334155;font-size:18px}.close-btn-small{padding:6px 12px;background:#f1f5f9;border:none;border-radius:6px;font-size:12px;font-weight:600;color:#64748b;cursor:pointer;transition:all .2s}.close-btn-small:hover{background:#e2e8f0;color:#334155}.drill-down-table-container{max-height:400px;overflow-y:auto}.tech-row-interactive{cursor:pointer;transition:background .2s}.tech-row-interactive:hover{background:#f8fafc}.charts-row{display:grid;grid-template-columns:2fr 1fr;gap:24px;margin-bottom:32px}.chart-card{background:#fff;padding:24px;border-radius:16px;box-shadow:0 4px 6px -1px #0000000d;border:1px solid #e2e8f0}.chart-header{margin-bottom:24px}.chart-header h3{margin:0;font-size:18px;color:#1e293b;font-weight:700}.tech-table{width:100%;border-collapse:collapse}.tech-table th{background:#f8fafc;padding:12px 16px;text-align:left;font-size:12px;color:#64748b;font-weight:600;text-transform:uppercase;border-bottom:1px solid #e2e8f0}.tech-table td{padding:16px;border-bottom:1px solid #f1f5f9;font-size:14px;color:#334155}.tech-name{display:flex;align-items:center;gap:12px;font-weight:600}.tech-avatar{width:32px;height:32px;background:#e2e8f0;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:12px;color:#64748b}.rank-badge{padding:2px 8px;border-radius:12px;font-size:11px;font-weight:700}.rank-top{background:#dbeafe;color:#1e40af}.rank-mid{background:#f1f5f9;color:#475569}.reports-header h1{font-size:28px;margin:0 0 8px;color:#fff}.header-subtitle{color:#94a3b8;margin:0}.header-actions{display:flex;gap:12px;flex-wrap:wrap;align-items:center;justify-content:flex-end}.date-range-select{padding:8px 16px;border-radius:8px;border:1px solid rgba(255,255,255,.2);background:#ffffff1a;color:#fff;cursor:pointer}.date-range-select option{background:#1e293b;color:#fff}.date-input-custom{padding:8px 12px;border-radius:8px;border:1px solid #cbd5e1;background-color:#fff!important;color:#1e293b!important;font-family:inherit;font-size:13px;color-scheme:light;cursor:text;width:140px}.date-input-custom::-webkit-calendar-picker-indicator{opacity:.6;cursor:pointer;filter:none}.date-input-custom::-webkit-calendar-picker-indicator:hover{opacity:1}.export-button{display:flex;align-items:center;gap:8px;padding:8px 20px;border-radius:8px;border:none;background:#3b82f6;color:#fff;font-weight:600;cursor:pointer;transition:all .2s}body.dark .reports-container{background:#0f172a}body.dark .metric-card,body.dark .drill-down-section,body.dark .chart-card{background:#1e293b;border-color:#334155}body.dark .metric-value,body.dark .section-header h3,body.dark .chart-header h3,body.dark .tech-table td,body.dark .tech-name{color:#fff}body.dark .metric-card.active{background:#1e293b;border-color:currentColor}body.dark .tech-table th{background:#0f172a;border-color:#334155}body.dark .tech-table tr:hover{background:#334155}.tabs-navigation{display:flex;gap:24px;margin-bottom:24px;border-bottom:2px solid #e2e8f0;padding-bottom:0}.tab-btn{padding:12px 16px;background:transparent;border:none;border-bottom:3px solid transparent;font-size:14px;font-weight:600;color:#64748b;cursor:pointer;transition:all .2s;margin-bottom:-2px}.tab-btn:hover{color:#3b82f6;background:transparent}.tab-content{animation:fadeIn .3s ease-in-out}.facilities-container{min-height:100vh;background:#f8fafc;padding:24px}.facilities-header{background:linear-gradient(135deg,#1e3c72,#bcc9e8);padding:24px 32px;margin-bottom:24px;box-shadow:0 4px 6px -1px #0000001a;border-radius:0}.header-content{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:16px}.facilities-header h1{font-size:28px;font-weight:700;color:#fff;margin:0 0 4px}.header-subtitle{font-size:14px;color:#ffffffe6;margin:0}.create-button{display:flex;align-items:center;gap:8px;padding:12px 24px;background:linear-gradient(135deg,#1e40af,#2563eb);border:none;border-radius:8px;color:#fff;font-size:14px;font-weight:600;cursor:pointer;transition:all .3s}.create-button:hover{transform:translateY(-1px);box-shadow:0 8px 20px #1e40af4d}.spinner{width:48px;height:48px;border:4px solid #e2e8f0;border-top-color:#1e40af;border-radius:50%;animation:spin .8s linear infinite}.error-banner{display:flex;align-items:center;gap:12px;padding:16px;background:#fef2f2;border:1px solid #fecaca;border-radius:8px;color:#dc2626;margin-bottom:24px}.stats-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:20px;margin-bottom:24px}.stat-card{background:#fff;border-radius:12px;padding:20px;display:flex;align-items:center;gap:16px;box-shadow:0 1px 3px #0000001a;border:1px solid #e2e8f0;transition:all .3s}.stat-card:hover{transform:translateY(-2px);box-shadow:0 4px 12px #0000001a}.stat-icon{width:48px;height:48px;border-radius:10px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.stat-total{background:#eff6ff;color:#1e40af}.stat-provinces{background:#f3e8ff;color:#7c3aed}.stat-districts{background:#fef3c7;color:#d97706}.stat-filtered{background:#d1fae5;color:#059669}.stat-label{font-size:13px;color:#475569;margin:0 0 4px;font-weight:600}.stat-value{font-size:28px;font-weight:700;color:#1e293b;margin:0;line-height:1}.filters-section{background:#fff;border-radius:12px;padding:20px;margin-bottom:24px;box-shadow:0 1px 3px #0000001a;border:1px solid #e2e8f0;display:flex;gap:16px;flex-wrap:wrap;align-items:center}.search-box{flex:1;min-width:250px;position:relative;display:flex;align-items:center}.search-box input{width:100%;padding:10px 12px 10px 40px;border:1px solid #e2e8f0;border-radius:8px;font-size:14px;transition:all .2s}.search-box input:focus{outline:none;border-color:#1e40af;box-shadow:0 0 0 3px #1e40af1a}.filter-group{display:flex;gap:12px}.filter-group select{padding:10px 16px;border:1px solid #e2e8f0;border-radius:8px;font-size:14px;color:#334155;background:#fff;cursor:pointer;transition:all .2s}.filter-group select:focus{outline:none;border-color:#1e40af;box-shadow:0 0 0 3px #1e40af1a}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:80px 20px;background:#fff;border-radius:12px;color:#94a3b8;border:1px solid #e2e8f0}.table-container{background:#fff;border-radius:12px;box-shadow:0 1px 3px #0000001a;border:1px solid #e2e8f0;overflow-x:auto}.facilities-table{width:100%;border-collapse:collapse;min-width:1000px}.facilities-table th{background:#f8fafc;padding:16px;text-align:left;font-size:11px;font-weight:600;color:#64748b;text-transform:uppercase;letter-spacing:.05em;border-bottom:1px solid #e2e8f0}.facilities-table td{padding:16px;border-bottom:1px solid #f1f5f9;font-size:14px;color:#334155;vertical-align:middle}.facilities-table tr:hover{background-color:#f8fafc}.facilities-table tr:last-child td{border-bottom:none}.facility-name-cell{font-weight:500;color:#1e293b}.code-cell{font-family:Courier New,monospace;background:#eff6ff;color:#1e40af;padding:4px 8px;border-radius:4px;font-size:12px;font-weight:600;display:inline-block}.status-badge{display:inline-flex;align-items:center;padding:4px 10px;border-radius:20px;font-size:12px;font-weight:600}.status-open{background:#dcfce7;color:#047857;font-weight:600}.status-closed{background:#fee2e2;color:#dc2626;font-weight:600}.equip-count-cell{background:#f1f5f9;color:#475569;padding:4px 12px;border-radius:12px;font-size:12px;font-weight:600;display:inline-block}.icon-btn{width:32px;height:32px;display:flex;align-items:center;justify-content:center;border:1px solid #e2e8f0;background:#fff;border-radius:6px;color:#64748b;cursor:pointer;transition:all .2s;padding:0}.icon-btn:hover{background:#f8fafc;border-color:#cbd5e1;color:#1e293b}.edit-btn:hover{background:#eff6ff;border-color:#bfdbfe;color:#1e40af}.view-btn:hover{background:#f0fdf4;border-color:#bbf7d0;color:#166534}@media (max-width: 768px){.facilities-container{padding:16px}.facilities-header h1{font-size:24px}.stats-row{grid-template-columns:1fr}.filters-section{flex-direction:column;align-items:stretch}.search-box{min-width:100%}.filter-group{flex-direction:column}.filter-group select{width:100%}.facilities-grid{grid-template-columns:1fr}}.equipment-container{min-height:100vh;display:flex;flex-direction:column;padding:0;background:#f8fafc}.equipment-container>*{padding-left:24px;padding-right:24px}.equipment-container>*:first-child{padding-top:24px}.equipment-header{background:linear-gradient(135deg,#1e3c72,#bcc9e8);border-radius:12px;padding:32px;margin-bottom:24px;box-shadow:0 2px 8px #0000001a;color:#fff}.equipment-header h1{font-size:28px;margin:0 0 8px;font-weight:700}.equipment-header .header-subtitle{font-size:14px;color:#ffffffe6;margin:0}.stats-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:16px;margin-bottom:24px}.stat-card{background:#fff;border-radius:12px;padding:20px;display:flex;align-items:center;gap:16px;box-shadow:0 1px 3px #0000001a;transition:transform .2s,box-shadow .2s}.stat-card:hover{transform:translateY(-2px);box-shadow:0 4px 12px #00000026}.stat-card.active{box-shadow:0 0 0 3px #3b82f64d;border:2px solid #3b82f6}.stat-icon{width:48px;height:48px;border-radius:12px;display:flex;align-items:center;justify-content:center;color:#fff}.stat-icon.stat-total{background:linear-gradient(135deg,#667eea,#764ba2)}.stat-icon.stat-facilities{background:linear-gradient(135deg,#f093fb,#f5576c)}.stat-icon.stat-functioning{background:linear-gradient(135deg,#4facfe,#00f2fe)}.stat-icon.stat-not-functioning{background:linear-gradient(135deg,#fa709a,#fee140)}.stat-label{font-size:13px;color:#64748b;margin:0 0 4px;font-weight:500}.stat-value{font-size:28px;font-weight:700;color:#1e293b;margin:0}.filters-section{background:#fff;border-radius:12px;padding:20px;margin-bottom:24px;box-shadow:0 1px 3px #0000001a}.search-box{position:relative;margin-bottom:16px}.search-box svg{position:absolute;left:12px;top:50%;transform:translateY(-50%);color:#94a3b8;pointer-events:none}.search-box input{width:100%;padding:10px 12px 10px 40px;border:1px solid #e2e8f0;border-radius:8px;font-size:14px;transition:border-color .2s,box-shadow .2s}.filter-group{display:flex;gap:12px;flex-wrap:wrap}.status-filter{padding:10px 16px;border:1px solid #e2e8f0;border-radius:8px;font-size:14px;background:#fff;cursor:pointer;transition:border-color .2s}.status-filter:focus{outline:none;border-color:#3b82f6}.table-container{flex:1;background:#fff;border-radius:12px;overflow:hidden;box-shadow:0 1px 3px #0000001a;margin-bottom:24px;display:flex;flex-direction:column}.equipment-table{width:100%;border-collapse:collapse}.equipment-table thead{background:#f8fafc}.equipment-table th{padding:16px;text-align:left;font-size:11px;font-weight:700;color:#64748b;text-transform:uppercase;letter-spacing:.5px;border-bottom:2px solid #e2e8f0}.equipment-table tbody tr{border-bottom:1px solid #e2e8f0;transition:background-color .2s}.equipment-table tbody tr:hover{background-color:#f8fafc}.equipment-table td{padding:16px;font-size:14px;color:#1e293b}.facility-name-cell{font-weight:600;color:#1e293b}.code-cell{font-family:Courier New,monospace;color:#64748b;font-size:13px}.equip-count-badge{display:inline-flex;align-items:center;justify-content:center;min-width:32px;padding:4px 12px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border-radius:12px;font-weight:600;font-size:13px}.status-badge{display:inline-flex;align-items:center;padding:4px 12px;border-radius:12px;font-size:12px;font-weight:600;text-transform:capitalize}.status-badge.status-functioning{background:#dcfce7;color:#16a34a}.status-badge.status-not-functioning{background:#fee2e2;color:#dc2626}.icon-btn{padding:8px;border:none;background:none;cursor:pointer;border-radius:6px;transition:background-color .2s;display:flex;align-items:center;justify-content:center}.icon-btn.view-btn{color:#3b82f6}.icon-btn.view-btn:hover{background:#eff6ff}.empty-state{text-align:center;padding:80px 24px;background:#fff;border-radius:12px;box-shadow:0 1px 3px #0000001a}.empty-state svg{color:#cbd5e1;margin-bottom:16px}.loading-spinner{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:400px}.loading-spinner p{margin-top:16px;color:#64748b;font-size:14px}.error-banner{background:#fee2e2;color:#dc2626;padding:12px 16px;border-radius:8px;display:flex;align-items:center;gap:12px;margin-bottom:24px;font-size:14px}body.dark .equipment-container{background:#0f172a}body.dark .stat-card,body.dark .filters-section,body.dark .table-container,body.dark .empty-state{background:#1e293b}body.dark .equipment-table th{background:#0f172a;color:#94a3b8}body.dark .equipment-table tbody tr:hover{background:#334155}body.dark .stat-label{color:#94a3b8}body.dark .stat-value,body.dark .facility-name-cell{color:#f1f5f9}body.dark .search-box input,body.dark .status-filter{background:#0f172a;border-color:#334155;color:#f1f5f9}body.dark .search-box input::placeholder{color:#64748b}body.dark .equipment-table tbody tr{border-color:#334155}body.dark .equipment-table td{color:#cbd5e1}@media (max-width: 768px){.equipment-container{padding:16px}.equipment-header{padding:24px}.stats-row{grid-template-columns:1fr}.table-container{overflow-x:auto}.equipment-table{min-width:900px}}.equipment-table th{position:-webkit-sticky;position:sticky;top:0;z-index:10;background:#f8fafc;box-shadow:0 1px #e2e8f0}.pagination-controls{display:flex;justify-content:space-between;align-items:center;padding:12px 24px;background:#fff;border-top:1px solid #e2e8f0}.pagination-controls.top{border-top:none;border-bottom:1px solid #e2e8f0}.pagination-info{font-size:13px;color:#64748b}.pagination-actions{display:flex;gap:8px;align-items:center}.page-btn{padding:6px 12px;border:1px solid #e2e8f0;background:#fff;border-radius:6px;font-size:13px;font-weight:500;color:#475569;cursor:pointer;transition:all .2s}.page-btn:hover:not(:disabled){background:#f1f5f9;color:#0f172a;border-color:#cbd5e1}.page-btn:disabled{opacity:.5;cursor:not-allowed}.page-select{padding:6px;border:1px solid #e2e8f0;border-radius:6px;font-size:13px;color:#475569;outline:none;cursor:pointer}.page-select:hover{border-color:#cbd5e1}body.dark .equipment-table th{background:#1e293b;box-shadow:0 1px #334155}body.dark .pagination-controls{background:#1e293b;border-color:#334155}body.dark .page-btn,body.dark .page-select{background:#0f172a;border-color:#334155;color:#94a3b8}body.dark .page-btn:hover:not(:disabled){background:#334155;color:#f1f5f9}body.dark .pagination-info{color:#94a3b8}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#00000080;display:flex;justify-content:center;align-items:center;z-index:1000;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.modal-content{background:#fff;border-radius:12px;width:90%;max-width:600px;max-height:90vh;display:flex;flex-direction:column;box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a}.modal-header{padding:1.5rem;border-bottom:1px solid #e2e8f0;display:flex;justify-content:space-between;align-items:center}.modal-header h2{margin:0;font-size:1.25rem;font-weight:600;color:#1e293b}.close-btn{background:none;border:none;padding:.5rem;cursor:pointer;color:#64748b;border-radius:6px;transition:all .2s}.close-btn:hover{background-color:#f1f5f9;color:#0f172a}.modal-body{padding:1.5rem;overflow-y:auto}.detail-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:1.5rem}.detail-item{display:flex;flex-direction:column;gap:.25rem}.detail-item label{font-size:.75rem;font-weight:600;text-transform:uppercase;color:#64748b;letter-spacing:.05em}.detail-item .value{font-size:.95rem;color:#0f172a;word-break:break-word}.modal-footer{padding:1rem 1.5rem;border-top:1px solid #e2e8f0;display:flex;justify-content:flex-end;gap:1rem;background-color:#f8fafc;border-radius:0 0 12px 12px}.action-buttons-left{margin-right:auto}.danger-btn-outline{padding:.5rem 1rem;border:1px solid #fda4af;background:#fff1f2;color:#e11d48;border-radius:6px;font-weight:600;cursor:pointer;transition:all .2s;display:flex;align-items:center;gap:.5rem}.danger-btn-outline:hover{background:#ffe4e6;border-color:#fb7185}.report-fault-modal{max-width:600px;width:90%}.equipment-summary-banner{background-color:#f1f5f9;padding:12px;border-radius:6px;margin-bottom:20px;display:flex;flex-direction:column;gap:4px;font-size:.9em;border-left:4px solid #3b82f6}.equipment-summary-banner strong{color:#1e293b;font-size:1.1em}.equipment-summary-banner .serial{font-family:monospace;color:#64748b}.section-divider{display:flex;align-items:center;margin:20px 0 15px;color:#94a3b8;font-size:.85em;font-weight:500;text-transform:uppercase;letter-spacing:.5px}.section-divider:before,.section-divider:after{content:"";flex:1;height:1px;background-color:#e2e8f0}.section-divider span{padding:0 10px}.form-group{margin-bottom:1rem;display:flex;flex-direction:column;gap:.25rem}.form-group label{font-size:.875rem;font-weight:500;color:#475569}.required{color:#ef4444;margin-left:2px}.form-group input,.form-group select,.form-group textarea{padding:.5rem .75rem;border:1px solid #cbd5e1;border-radius:6px;font-size:.95rem;color:#1e293b;width:100%;transition:border-color .2s}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.primary-btn{padding:.5rem 1rem;background-color:#3b82f6;color:#fff;border:none;border-radius:6px;font-weight:500;cursor:pointer;transition:background-color .2s}.primary-btn:hover{background-color:#2563eb}.primary-btn:disabled{background-color:#94a3b8;cursor:not-allowed}.secondary-btn{padding:.5rem 1rem;border:1px solid #cbd5e1;background:#fff;color:#475569;border-radius:6px;font-weight:500;cursor:pointer;transition:all .2s}.secondary-btn:hover{background-color:#f1f5f9;border-color:#94a3b8}.error-message{background-color:#fee2e2;color:#991b1b;padding:.75rem;border-radius:6px;margin-bottom:1rem;font-size:.9rem}.loading-spinner{text-align:center;padding:2rem;color:#64748b}.audit-container{padding:0;background:#f8fafc;min-height:calc(100vh - 64px)}.sticky-header{position:-webkit-sticky;position:sticky;top:56px;z-index:100;background:linear-gradient(135deg,#1e3c72,#bcc9e8);color:#fff;padding:24px 32px;box-shadow:0 4px 6px -1px #0000001a}.audit-content{max-width:100%;margin:0;padding:24px}.header-content{display:flex;justify-content:space-between;align-items:flex-end}.audit-header h1{font-size:28px;font-weight:800;margin:0 0 8px;color:#fff}.header-subtitle{font-size:14px;color:#94a3b8;margin:0}.export-button{display:flex;align-items:center;gap:8px;padding:8px 20px;border-radius:8px;border:none;background:#3b82f6;color:#fff;font-weight:600;font-size:14px;cursor:pointer;transition:all .2s}.export-button:hover{background:#2563eb;transform:translateY(-1px)}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:24px;margin-bottom:32px}.stat-card{background:#fff;padding:20px;border-radius:16px;box-shadow:0 4px 6px -1px #0000000d;border:1px solid #e2e8f0;display:flex;align-items:center;gap:16px;transition:transform .2s}.stat-card:hover{transform:translateY(-4px);box-shadow:0 10px 15px -3px #0000001a}.stat-icon{padding:12px;border-radius:12px;font-size:24px}.stat-primary .stat-icon{background:#eff6ff}.stat-success .stat-icon{background:#f0fdf4}.stat-info .stat-icon{background:#f5f3ff}.stat-warning .stat-icon{background:#fef2f2}.stat-content{flex:1}.stat-label{font-size:13px;color:#64748b;margin:0 0 4px;font-weight:600;text-transform:uppercase}.stat-value{font-size:24px;font-weight:700;color:#0f172a;margin:0}.filters-section{background:#fff;border-radius:16px;padding:20px;margin-bottom:24px;box-shadow:0 4px 6px -1px #0000000d;border:1px solid #e2e8f0;display:flex;gap:12px;flex-wrap:wrap;align-items:center}.search-box{flex:1;min-width:250px}.search-box input{width:100%;padding:10px 16px;border:1px solid #e2e8f0;border-radius:8px;font-size:14px;transition:all .2s}.filters-section select{padding:10px 16px;border:1px solid #e2e8f0;border-radius:8px;font-size:14px;color:#334155;background:#fff;cursor:pointer;transition:all .2s}.filters-section select:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.results-count{font-size:14px;color:#64748b;font-weight:500;margin-left:auto}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:80px 20px;background:#fff;border-radius:16px;color:#94a3b8;border:1px solid #e2e8f0}.empty-icon{font-size:64px;margin-bottom:16px}.empty-state p{font-size:18px;font-weight:600;margin:0 0 8px;color:#64748b}.empty-state span{font-size:14px;color:#94a3b8}.audit-table-container{background:#fff;border-radius:16px;box-shadow:0 4px 6px -1px #0000000d;border:1px solid #e2e8f0;height:calc(100vh - 400px);min-height:400px;overflow-y:auto;overflow-x:auto}.audit-table{width:100%;border-collapse:collapse}.audit-table thead{background:#f8fafc;border-bottom:2px solid #e2e8f0}.audit-table th{position:-webkit-sticky;position:sticky;top:0;z-index:10;background:#f8fafc;padding:14px 16px;text-align:left;font-size:12px;font-weight:600;color:#475569;text-transform:uppercase;letter-spacing:.5px;box-shadow:0 2px 4px #0000000d}.audit-table td{padding:16px;border-bottom:1px solid #f1f5f9;font-size:14px;color:#334155}.audit-row{transition:background .2s}.audit-row:hover{background:#f8fafc}.timestamp{font-family:Courier New,monospace;color:#64748b;font-size:13px}.ip-address{font-family:Courier New,monospace;color:#64748b;font-size:13px}.action-badge{display:inline-block;padding:4px 12px;border-radius:12px;font-size:12px;font-weight:600}.loading-box{height:60vh;display:flex;flex-direction:column;justify-content:center;align-items:center;color:#64748b;gap:16px}.spinner{width:40px;height:40px;border:4px solid #e2e8f0;border-top-color:#3b82f6;border-radius:50%;animation:spin 1s linear infinite}.error-banner{background:#fee2e2;border:1px solid #fecaca;border-radius:12px;padding:16px;color:#dc2626;margin-bottom:24px;font-weight:600}.audit-footer{text-align:center;padding:32px 16px 16px;margin-top:48px;border-top:1px solid #e2e8f0;color:#64748b}.audit-footer p{margin:4px 0;font-size:14px}.footer-dev{font-size:13px;color:#94a3b8}.footer-dev a{color:#3b82f6;text-decoration:none;font-weight:600;transition:color .2s}.footer-dev a:hover{color:#2563eb;text-decoration:underline}body.dark .audit-container{background:#0f172a}body.dark .stat-card,body.dark .filters-section,body.dark .audit-table-container,body.dark .empty-state{background:#1e293b;border-color:#334155}body.dark .stat-value,body.dark .user-name{color:#fff}body.dark .audit-table th{background:#0f172a;border-color:#334155}body.dark .audit-table td{border-color:#334155;color:#cbd5e1}body.dark .audit-row:hover{background:#334155}.workspace-container{min-height:100vh;background:#f8fafc;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}.workspace-header-sticky{position:relative;background:linear-gradient(135deg,#1e3c72,#bcc9e8);border-bottom:2px solid #e2e8f0;padding:24px;margin-bottom:20px;box-shadow:0 2px 8px #0000001a}.workspace-header-content h1{font-size:28px;font-weight:700;color:#1e293b;margin:0 0 4px}.header-subtitle{font-size:14px;color:#64748b;margin:0 0 24px}.workspace-tabs{display:grid;grid-template-columns:repeat(5,1fr);gap:12px;margin-bottom:20px;padding:16px;background:#f1f5f9;border-radius:12px;border:2px dashed #cbd5e1}.tab-card{background:#fff;border:2px solid #e2e8f0;border-radius:8px;padding:12px 16px;text-align:center;cursor:pointer;transition:all .3s ease;display:flex;flex-direction:column;gap:4px;min-height:80px;justify-content:center}.tab-card:hover{border-color:#3b82f6;transform:translateY(-3px);box-shadow:0 8px 20px #3b82f626}.tab-card.workspace-header{background:linear-gradient(135deg,#1e3c72,#bcc9e8);color:#fff;padding:20px 24px;margin-bottom:24px;border-radius:12px;box-shadow:0 2px 8px #0000001a}.tab-card.active{background:linear-gradient(135deg,#3b82f6,#2563eb);border-color:#2563eb;box-shadow:0 8px 24px #3b82f666;transform:translateY(-3px)}.tab-value{display:block;font-size:24px;font-weight:700;color:#1e293b;line-height:1;margin-bottom:4px}.tab-card.active .tab-value{color:#fff}.tab-label{display:block;font-size:14px;font-weight:600;color:#475569;text-transform:uppercase;letter-spacing:.5px;margin-bottom:4px}.tab-card.active .tab-label{color:#fff}.tab-description{display:block;font-size:12px;color:#94a3b8;line-height:1.4}.tab-card.active .tab-description{color:#ffffffd9}.search-box-sticky{position:relative}.search-box-sticky svg{position:absolute;left:12px;top:50%;transform:translateY(-50%);color:#94a3b8}.search-box-sticky input{width:100%;padding:10px 12px 10px 40px;border:1px solid #e2e8f0;border-radius:8px;font-size:14px;font-family:inherit;transition:all .2s}.search-box-sticky input:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.workspace-content{padding:24px}.tickets-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:20px}.loading-spinner{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:400px;gap:16px}.spinner{width:48px;height:48px;border:4px solid #e2e8f0;border-top-color:#3b82f6;border-radius:50%;animation:spin .8s linear infinite}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:400px;color:#94a3b8;text-align:center}.empty-state svg{margin-bottom:16px}.empty-state p{font-size:18px;font-weight:600;color:#64748b;margin:0 0 8px}.empty-state span{font-size:14px}.error-banner{display:flex;align-items:center;gap:12px;padding:16px;background:#fee2e2;border:1px solid #fecaca;border-radius:8px;color:#dc2626;margin:24px}@media (max-width: 768px){.workspace-header-sticky{padding:16px}.workspace-tabs{grid-template-columns:1fr}.workspace-content{padding:16px}.tickets-grid{grid-template-columns:1fr}}.tech-ticket-card{background:#fff;border-radius:12px;padding:20px;border:1px solid #e2e8f0;box-shadow:0 1px 3px #0000001a;transition:all .2s;display:flex;flex-direction:column;gap:16px;cursor:pointer}.tech-ticket-card:hover{box-shadow:0 4px 12px #00000026;transform:translateY(-2px)}.card-header{display:flex;justify-content:space-between;align-items:flex-start;gap:12px}.ticket-ref-badge{background:linear-gradient(135deg,#f8fafc,#f1f5f9);border:1px solid #e2e8f0;padding:6px 12px;border-radius:6px;font-size:12px;font-weight:700;color:#475569;font-family:Courier New,monospace}.card-badges{display:flex;gap:6px;flex-wrap:wrap}.status-badge-small,.priority-badge-small{padding:4px 10px;border-radius:12px;font-size:11px;font-weight:600;color:#fff}.card-facility,.card-equipment{display:flex;align-items:center;gap:8px;color:#475569;font-size:14px;font-weight:500}.card-facility svg,.card-equipment svg{color:#64748b;flex-shrink:0}.card-description{font-size:14px;color:#64748b;line-height:1.5;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}.work-timer{display:flex;align-items:center;gap:8px;padding:10px 14px;background:linear-gradient(135deg,#fef3c7,#fde68a);border:1px solid #fde047;border-radius:8px;color:#92400e;font-size:14px;font-weight:600;font-family:Courier New,monospace}.work-timer svg{color:#d97706}.on-hold-banner{display:flex;align-items:center;gap:8px;padding:10px 14px;background:linear-gradient(135deg,#fff7ed,#ffedd5);border:1px solid #fed7aa;border-radius:8px;color:#c2410c;font-size:14px;font-weight:600}.on-hold-banner svg{color:#ea580c}.card-actions{display:flex;gap:10px}.action-btn{flex:1;display:flex;align-items:center;justify-content:center;gap:8px;padding:12px 16px;border:none;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s}.primary-action{background:linear-gradient(135deg,#10b981,#059669);color:#fff}.primary-action:hover{transform:translateY(-2px);box-shadow:0 4px 12px #10b9814d}.secondary-action{background:linear-gradient(135deg,#f59e0b,#d97706);color:#fff}.secondary-action:hover{transform:translateY(-2px);box-shadow:0 4px 12px #f59e0b4d}.success-action{background:linear-gradient(135deg,#3b82f6,#2563eb);color:#fff}.success-action:hover{transform:translateY(-2px);box-shadow:0 4px 12px #3b82f64d}.resolved-message{display:flex;align-items:center;justify-content:center;gap:8px;padding:12px;background:linear-gradient(135deg,#d1fae5,#a7f3d0);border:1px solid #6ee7b7;border-radius:8px;color:#065f46;font-weight:600}.resolved-message svg{color:#10b981}.card-secondary-actions{display:flex;gap:10px;padding-top:8px;border-top:1px solid #f1f5f9}.secondary-btn{flex:1;display:flex;align-items:center;justify-content:center;gap:6px;padding:8px 12px;background:#fff;border:1px solid #e2e8f0;border-radius:6px;font-size:13px;font-weight:500;color:#64748b;cursor:pointer;transition:all .2s}.secondary-btn:hover{background:#f8fafc;border-color:#cbd5e1;color:#475569}.card-footer{display:flex;justify-content:space-between;align-items:center;padding-top:12px;border-top:1px solid #f1f5f9}.footer-item{display:flex;align-items:center;gap:6px;font-size:12px;color:#94a3b8}.footer-item svg{color:#cbd5e1}@media (max-width: 480px){.tech-ticket-card{padding:16px}.card-actions{flex-direction:column}.action-btn{width:100%}}.user-management-container{min-height:100vh;background:#f8fafc;padding:24px}.um-header{background:linear-gradient(135deg,#1e3c72,#bcc9e8);border-radius:0;padding:24px 32px;margin-bottom:24px;box-shadow:0 4px 6px -1px #0000001a}.um-header h1{font-size:28px;font-weight:700;color:#fff;margin:0 0 4px}.um-subtitle{font-size:14px;color:#ffffffe6;margin:0}.um-tabs-container{background:#fff;border-radius:12px;box-shadow:0 1px 3px #0000001a;overflow:hidden}.um-tabs-header{display:flex;border-bottom:2px solid #f1f5f9;background:linear-gradient(to bottom,#fafbfc,#f8fafc)}.um-tab-button{flex:1;display:flex;align-items:center;justify-content:center;gap:8px;padding:16px 20px;border:none;background:transparent;color:#64748b;font-size:15px;font-weight:600;cursor:pointer;transition:all .2s;border-bottom:3px solid transparent;position:relative}.um-tab-button:hover{background:#3b82f60d;color:#475569}.um-tab-button.active{color:#3b82f6;background:#fff;border-bottom-color:#3b82f6}.um-tab-button.active:after{content:"";position:absolute;bottom:-2px;left:0;right:0;height:3px;background:linear-gradient(90deg,#3b82f6,#2563eb)}.um-tab-icon{font-size:20px}.um-tabs-content{padding:24px;min-height:600px}@media (max-width: 768px){.user-management-container{padding:16px}.um-tab-button{flex-direction:column;gap:4px;padding:12px 8px}.um-tab-label{font-size:12px}.um-tabs-content{padding:16px}}.users-tab{width:100%}.users-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:24px}.users-title h2{font-size:24px;font-weight:700;color:#1e293b;margin:0 0 4px}.users-title p{font-size:14px;color:#64748b;margin:0}.btn-create{padding:10px 20px;background:linear-gradient(135deg,#3b82f6,#2563eb);color:#fff;border:none;border-radius:8px;font-weight:600;cursor:pointer;transition:all .2s}.btn-create:hover{transform:translateY(-1px);box-shadow:0 4px 12px #3b82f666}.users-filters{display:flex;gap:16px;margin-bottom:20px}.search-box{flex:1;position:relative;display:flex;align-items:center}.search-box svg{position:absolute;left:12px;color:#94a3b8}.search-box input{width:100%;padding:10px 12px 10px 40px;border:1px solid #e2e8f0;border-radius:8px;font-size:14px}.role-filter{padding:10px 16px;border:1px solid #e2e8f0;border-radius:8px;font-size:14px;min-width:150px}.users-table-container{background:#fff;border-radius:12px;overflow:hidden;box-shadow:0 1px 3px #0000001a}.users-table{width:100%;border-collapse:collapse}.users-table thead{background:#f8fafc}.users-table th{padding:12px 16px;text-align:left;font-size:12px;font-weight:600;color:#64748b;text-transform:uppercase;letter-spacing:.5px}.users-table td{padding:16px;border-top:1px solid #f1f5f9}.users-table tbody tr:hover{background:#f8fafc}.user-cell{display:flex;align-items:center;gap:12px}.user-avatar{width:40px;height:40px;border-radius:50%;background:linear-gradient(135deg,#3b82f6,#8b5cf6);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:14px}.user-info{display:flex;flex-direction:column}.user-name{font-weight:600;color:#1e293b}.user-username{font-size:12px;color:#64748b}.role-badge{display:inline-block;padding:4px 12px;background:#eff6ff;color:#3b82f6;border-radius:12px;font-size:12px;font-weight:600}.status-toggle{display:flex;align-items:center;cursor:pointer}.status-toggle input{display:none}.status-slider{padding:4px 12px;border-radius:12px;font-size:12px;font-weight:600;background:#fee2e2;color:#dc2626;transition:all .2s}.status-slider.active{background:#dcfce7;color:#16a34a}.action-buttons{display:flex;gap:8px}.btn-icon{width:32px;height:32px;border:none;background:#f1f5f9;border-radius:6px;cursor:pointer;transition:all .2s;font-size:16px}.btn-icon:hover{background:#e2e8f0;transform:scale(1.1)}.users-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;backdrop-filter:blur(2px);-webkit-backdrop-filter:blur(2px)}.modal-content{background:#fff;border-radius:12px;width:90%;max-width:500px;box-shadow:0 20px 25px -5px #0000001a;max-height:90vh;display:flex;flex-direction:column}.modal-large{max-width:700px}.modal-header{padding:20px 24px;border-bottom:1px solid #f1f5f9;display:flex;justify-content:space-between;align-items:center;flex-shrink:0}.modal-header h3{margin:0;font-size:18px;font-weight:700}.modal-header button{background:none;border:none;font-size:24px;cursor:pointer;color:#94a3b8}.modal-body{padding:24px;overflow-y:auto;flex:1}.modal-footer{padding:16px 24px;border-top:1px solid #f1f5f9;display:flex;justify-content:flex-end;gap:12px;flex-shrink:0}.btn-primary,.btn-secondary{padding:10px 20px;border-radius:8px;font-weight:600;cursor:pointer;border:none;transition:all .2s}.btn-primary{background:#3b82f6;color:#fff}.btn-primary:hover:not(:disabled){background:#2563eb}.btn-primary:disabled{opacity:.5;cursor:not-allowed}.btn-secondary{background:#f1f5f9;color:#64748b}.btn-secondary:hover{background:#e2e8f0}.modal-tabs{display:flex;border-bottom:1px solid #e2e8f0;padding:0 24px;background:#f8fafc}.tab-btn{padding:16px 20px;border:none;background:none;color:#64748b;font-weight:600;cursor:pointer;border-bottom:2px solid transparent}.tab-btn.active{color:#3b82f6;border-bottom-color:#3b82f6}.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px}.form-group label{display:block;font-size:14px;font-weight:500;color:#475569;margin-bottom:6px}.form-group input,.form-group select{width:100%;padding:10px;border:1px solid #e2e8f0;border-radius:8px;font-size:14px;box-sizing:border-box}.form-group input:focus,.form-group select:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.full-width-select{width:100%}.role-preview{margin-top:6px;color:#64748b;font-size:13px}.location-selector{margin-top:20px;border:1px solid #e2e8f0;border-radius:8px;padding:16px;background:#f8fafc}.location-selector h4{margin:0 0 12px;font-size:14px;color:#1e293b}.checkbox-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:10px}.checkbox-item{display:flex;align-items:center;gap:8px;font-size:14px;color:#475569;cursor:pointer}.group-section{margin-bottom:16px}.group-section h5{margin:0 0 8px;font-size:13px;color:#64748b;text-transform:uppercase;border-bottom:1px solid #e2e8f0;padding-bottom:4px}.error-message{padding:12px;background:#fee2e2;color:#dc2626;border-radius:6px;margin-bottom:16px}.error-banner{padding:12px 16px;background:#fee2e2;color:#dc2626;border-radius:8px;margin-bottom:16px}.success-message{text-align:center}.success-icon{width:60px;height:60px;border-radius:50%;background:#dcfce7;color:#16a34a;display:flex;align-items:center;justify-content:center;font-size:32px;margin:0 auto 16px}.temp-password{background:#f8fafc;padding:16px;border-radius:8px;margin:16px 0}.temp-password code{display:block;padding:12px;background:#fff;border:2px dashed #e2e8f0;border-radius:6px;font-family:monospace;font-size:16px;margin-bottom:8px;user-select:all;-webkit-user-select:all}.temp-password button{width:100%;padding:8px;background:#3b82f6;color:#fff;border:none;border-radius:6px;cursor:pointer}.warning-text{color:#f59e0b;font-size:14px}.info-text{color:#64748b;font-size:13px}.sortable-header{cursor:pointer;user-select:none;-webkit-user-select:none}.sortable-header:hover{color:#3b82f6}.table-footer{display:flex;justify-content:space-between;align-items:center;padding:16px;border-top:1px solid #f1f5f9}.pagination-controls{display:flex;align-items:center;gap:8px}.pagination-btn{padding:6px 12px;border:1px solid #e2e8f0;background:#fff;border-radius:6px;cursor:pointer;font-size:14px;color:#64748b}.pagination-btn:disabled{opacity:.5;cursor:not-allowed}.pagination-btn:hover:not(:disabled){background:#f8fafc;border-color:#cbd5e1}.pagination-info{font-size:14px;color:#64748b}.groups-tab{width:100%}.groups-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:24px}.groups-header h2{font-size:24px;font-weight:700;color:#1e293b;margin:0 0 4px}.groups-header p{font-size:14px;color:#64748b;margin:0}.groups-search{margin-bottom:24px}.groups-search input{width:100%;padding:12px 16px;border:1px solid #e2e8f0;border-radius:8px;font-size:14px}.groups-search input:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.groups-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:20px}.group-card{background:#fff;border-radius:12px;padding:20px;box-shadow:0 1px 3px #0000001a;transition:all .2s}.group-card:hover{box-shadow:0 4px 12px #00000026;transform:translateY(-2px)}.group-card-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:12px}.group-card-header h3{font-size:18px;font-weight:700;color:#1e293b;margin:0}.group-actions{display:flex;gap:8px}.group-actions button{padding:6px 12px;border:none;background:#f1f5f9;border-radius:6px;font-size:12px;cursor:pointer;transition:all .2s}.group-actions button:hover{background:#e2e8f0}.group-description{color:#64748b;font-size:14px;margin-bottom:16px;min-height:40px}.group-stats{display:flex;gap:24px;padding-top:16px;border-top:1px solid #f1f5f9}.stat{display:flex;flex-direction:column;align-items:center}.stat-number{font-size:24px;font-weight:700;color:#3b82f6}.stat-label{font-size:12px;color:#64748b;text-transform:uppercase;letter-spacing:.5px}.modal-large{max-width:800px}.form-group{margin-bottom:16px}.form-group label{display:block;font-size:14px;font-weight:600;color:#475569;margin-bottom:6px}.form-group input,.form-group textarea{width:100%;padding:10px 12px;border:1px solid #e2e8f0;border-radius:6px;font-size:14px;font-family:inherit}.form-group input:focus,.form-group textarea:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.btn-danger{padding:10px 20px;background:#dc2626;color:#fff;border:none;border-radius:8px;font-weight:600;cursor:pointer}.btn-danger:hover{background:#b91c1c}.members-container{display:grid;grid-template-columns:1fr 1fr;gap:24px}.members-section h4{font-size:16px;font-weight:700;color:#1e293b;margin:0 0 12px}.user-list{max-height:400px;overflow-y:auto;border:1px solid #e2e8f0;border-radius:8px;padding:8px}.user-item{display:flex;justify-content:space-between;align-items:center;padding:10px;background:#f8fafc;border-radius:6px;margin-bottom:6px}.user-item:last-child{margin-bottom:0}.user-item span{font-size:14px;color:#475569}.user-item button{padding:4px 12px;border:none;background:#3b82f6;color:#fff;border-radius:4px;font-size:12px;font-weight:600;cursor:pointer}.user-item button:hover{background:#2563eb}.no-data-small{text-align:center;padding:20px;color:#94a3b8;font-size:14px}.spinner-small{width:24px;height:24px;border:3px solid #f1f5f9;border-top-color:#3b82f6;border-radius:50%;animation:spin .8s linear infinite;margin:20px auto}.no-groups{text-align:center;padding:60px;color:#94a3b8;grid-column:1 / -1}.groups-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px}@media (max-width: 768px){.groups-grid,.members-container{grid-template-columns:1fr}}.permissions-tab{width:100%;position:relative}.permissions-header{margin-bottom:24px}.permissions-header h2{font-size:24px;font-weight:700;color:#1e293b;margin:0 0 4px}.permissions-header p{font-size:14px;color:#64748b;margin:0}.permissions-filters{margin-bottom:20px}.search-box input{width:100%;padding:10px 16px;border:1px solid #e2e8f0;border-radius:8px;font-size:14px}.search-box input:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.category-tabs{display:flex;gap:8px;flex-wrap:wrap}.category-tab{padding:8px 16px;border:1px solid #e2e8f0;background:#fff;border-radius:6px;font-size:13px;font-weight:600;color:#64748b;cursor:pointer;transition:all .2s}.category-tab:hover{background:#f8fafc;border-color:#cbd5e1}.category-tab.active{background:#3b82f6;color:#fff;border-color:#3b82f6}.matrix-container{background:#fff;border-radius:12px;box-shadow:0 1px 3px #0000001a;overflow:hidden;margin-bottom:16px}.matrix-scroll{overflow-x:auto;max-width:100%}.permissions-matrix{width:100%;border-collapse:separate;border-spacing:0;min-width:800px}.permissions-matrix thead{background:linear-gradient(to bottom,#f8fafc,#f1f5f9)}.permissions-matrix th{padding:16px 12px;text-align:center;font-size:12px;font-weight:700;color:#475569;text-transform:uppercase;letter-spacing:.5px;border-bottom:2px solid #e2e8f0;white-space:nowrap}.sticky-col{position:-webkit-sticky;position:sticky;left:0;background:#fff;z-index:10;text-align:left!important;min-width:250px;box-shadow:2px 0 4px #0000000d}.permissions-matrix thead .sticky-col{background:linear-gradient(to bottom,#f8fafc,#f1f5f9)}.role-header{min-width:100px}.role-name{writing-mode:vertical-rl;text-orientation:mixed;transform:rotate(180deg);padding:8px 0}.permissions-matrix tbody tr:hover,.permissions-matrix tbody tr:hover .sticky-col{background:#f8fafc}.permissions-matrix td{padding:12px;border-bottom:1px solid #f1f5f9;vertical-align:middle;text-align:center}.permission-name{padding:12px!important}.perm-title{font-weight:600;color:#1e293b;font-size:14px;margin-bottom:4px}.perm-desc{font-size:12px;color:#64748b;line-height:1.4}.permission-cell{width:18px;height:18px;border-radius:3px;border:1px solid transparent;font-size:10px;font-weight:700;cursor:pointer;transition:all .2s;background:#fff;display:inline-flex;align-items:center;justify-content:center;line-height:1}.permission-cell.granted{background:linear-gradient(135deg,#dcfce7,#bbf7d0);color:#16a34a;border-color:#86efac}.permission-cell.granted:hover{background:linear-gradient(135deg,#bbf7d0,#86efac);transform:scale(1.3);box-shadow:0 2px 8px #16a34a4d}.permission-cell.denied{background:linear-gradient(135deg,#fee2e2,#fecaca);color:#dc2626;border-color:#fca5a5}.permission-cell.denied:hover{background:linear-gradient(135deg,#fecaca,#fca5a5);transform:scale(1.3);box-shadow:0 2px 8px #dc26264d}.permission-cell:disabled{opacity:.6;cursor:not-allowed}.matrix-legend{display:flex;align-items:center;gap:24px;padding:16px 20px;background:#f8fafc;border-radius:8px}.legend-item{display:flex;align-items:center;gap:8px}.legend-icon{width:24px;height:24px;border-radius:4px;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:12px}.legend-icon.granted{background:linear-gradient(135deg,#dcfce7,#bbf7d0);color:#16a34a}.legend-icon.denied{background:linear-gradient(135deg,#fee2e2,#fecaca);color:#dc2626}.legend-note{margin-left:auto;font-size:13px;color:#64748b;font-style:italic}.no-data{text-align:center;padding:40px;color:#94a3b8}.permissions-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px}.spinner{width:40px;height:40px;border:4px solid #f1f5f9;border-top-color:#3b82f6;border-radius:50%;animation:spin .8s linear infinite}.updating-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#0003;display:flex;align-items:center;justify-content:center;gap:12px;z-index:1000;color:#fff;font-weight:600}.spinner-small{width:24px;height:24px;border:3px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .8s linear infinite}@media (max-width: 1024px){.category-tabs{overflow-x:auto;flex-wrap:nowrap}.legend-note{display:none}}@media (max-width: 768px){.sticky-col{min-width:200px}.matrix-legend{flex-direction:column;align-items:flex-start}}.roles-tab{width:100%}.roles-header{margin-bottom:24px}.roles-header h2{font-size:24px;font-weight:700;color:#1e293b;margin:0 0 4px}.roles-header p{font-size:14px;color:#64748b;margin:0}.roles-table-container{background:#fff;border-radius:12px;box-shadow:0 1px 3px #0000001a;overflow:hidden}.roles-table{width:100%;border-collapse:collapse}.roles-table thead{background:#f8fafc}.roles-table th{padding:12px 16px;text-align:left;font-size:12px;font-weight:600;color:#64748b;text-transform:uppercase;letter-spacing:.5px;border-bottom:1px solid #e2e8f0}.roles-table tbody tr:last-child td{border-bottom:none}.roles-table tbody tr:hover{background:#f8fafc}.roles-table td{padding:16px;border-bottom:1px solid #f1f5f9;vertical-align:middle}.role-name-cell{display:flex;align-items:center;gap:12px}.role-icon-small{font-size:20px;width:32px;height:32px;display:flex;align-items:center;justify-content:center;background:#eff6ff;border-radius:6px}.role-name-text{font-weight:600;color:#1e293b;font-size:15px}.role-desc-cell{color:#64748b;font-size:14px}.btn-manage-simple{padding:8px 16px;background:#fff;border:1px solid #e2e8f0;color:#475569;border-radius:6px;font-size:13px;font-weight:500;cursor:pointer;transition:all .2s}.btn-manage-simple:hover{background:#f1f5f9;color:#1e293b;border-color:#cbd5e1}.permission-count{font-size:13px;color:#64748b;margin:4px 0 0}.modal-body{padding:24px}.search-box{margin-bottom:16px}.search-box input{width:100%;padding:10px 12px;border:1px solid #e2e8f0;border-radius:6px;font-size:14px}.permissions-list{max-height:500px;overflow-y:auto;padding-right:4px}.permission-category{margin-bottom:20px}.permission-category h4{font-size:13px;font-weight:700;color:#64748b;text-transform:uppercase;letter-spacing:.5px;margin:0 0 8px;padding-bottom:4px;border-bottom:1px solid #f1f5f9}.permission-items{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:8px}.permission-checkbox{display:flex;align-items:flex-start;gap:10px;padding:8px;cursor:pointer;transition:background .2s;border-radius:4px}.permission-checkbox:hover{background:#f8fafc}.permission-checkbox input[type=checkbox]{margin-top:3px;accent-color:#3b82f6;width:16px;height:16px;cursor:pointer}.checkbox-custom{display:none}.permission-info{flex:1}.permission-title{display:block;font-size:14px;color:#334155;font-weight:500}.permission-desc{display:block;font-size:12px;color:#94a3b8;margin-top:2px;line-height:1.3}.roles-loading,.no-roles{text-align:center;padding:40px;color:#94a3b8}.spinner{width:40px;height:40px;border:4px solid #f1f5f9;border-top-color:#3b82f6;border-radius:50%;animation:spin .8s linear infinite;margin:0 auto 16px}@keyframes spin{to{transform:rotate(360deg)}}.modal-large{max-width:700px;width:90%}@media (max-width: 768px){.permission-items{grid-template-columns:1fr}}.modal-instruction{font-size:13px;color:#64748b;margin:4px 0 0;font-style:italic}.modal-instruction strong{color:#3b82f6;font-weight:600}.notifications-container{padding:24px;max-width:100%;margin:0}.notifications-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px}.notifications-tabs{display:flex;gap:16px;margin-bottom:24px;border-bottom:1px solid #e2e8f0}.tab-btn{padding:12px 24px;border:none;background:none;font-weight:600;cursor:pointer;color:#64748b;border-bottom:2px solid transparent;transition:all .2s}.tab-btn:hover{color:#334155}.tab-btn.active{color:#0284c7;border-bottom-color:#0284c7}.notification-card{background:#fff;padding:16px;border-radius:8px;border:1px solid #e2e8f0;margin-bottom:12px;display:flex;gap:16px;transition:background-color .2s}.notification-card.unread{background:#f0f9ff;border-left:4px solid #0284c7}.notification-icon{width:40px;height:40px;background:#e2e8f0;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:20px}.notification-content{flex:1}.notification-time{font-size:12px;color:#94a3b8;margin-top:4px}.mark-read-btn{font-size:12px;color:#0284c7;background:none;border:none;cursor:pointer;white-space:nowrap}.mark-all-btn{background:#f1f5f9;color:#475569;border:1px solid #cbd5e1;padding:6px 12px;border-radius:6px;cursor:pointer;font-size:13px}*{margin:0;padding:0;box-sizing:border-box}body{font-family:Ubuntu,Segoe UI,-apple-system,Roboto,Oxygen,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:#f5f5f5;color:#333}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}:root{--primary-blue: #0078D4;--primary-blue-dark: #0063B1;--accent-green: #10B981;--accent-orange: #F59E0B;--accent-red: #EF4444;--text-primary: #333333;--text-secondary: #666666;--bg-primary: #f5f5f5;--bg-white: #ffffff;--border-color: #e0e0e0}#root{min-height:100vh}button,input,select,textarea{font-family:inherit}body.dark{--bg-primary: #0f172a;--bg-white: #1e293b;--text-primary: #f1f5f9;--text-secondary: #94a3b8;--border-color: #334155;background-color:var(--bg-primary);color:var(--text-primary)}body.dark .nav-container,body.dark .top-navigation{background-color:var(--bg-white);border-bottom-color:var(--border-color);color:var(--text-primary)}body.dark .nav-item{color:var(--text-secondary)}body.dark .nav-item:hover,body.dark .nav-item.active{background-color:#334155;color:#fff}body.dark .card,body.dark .summary-card,body.dark .ticket-card,body.dark .tickets-table,body.dark .modal-content{background-color:var(--bg-white);color:var(--text-primary);border-color:var(--border-color)}
