@import"https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700&display=swap";*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--blue: #2557a7;--blue-dark: #1a3f7a;--blue-light: #3b7dd8;--sidebar-bg: #1e3a6e;--sidebar-w: 200px;--bg: #f0f2f5;--white: #ffffff;--border: #e2e6ea;--text: #1a1d23;--text-muted: #6b7280;--text-light: #9ca3af;--green: #16a34a;--red: #dc2626;--orange: #ea580c;--amber: #d97706;--purple: #7c3aed;--radius: 8px;--shadow: 0 1px 3px rgba(0,0,0,.08), 0 1px 2px rgba(0,0,0,.04);--shadow-md: 0 4px 12px rgba(0,0,0,.1)}body{font-family:Inter,system-ui,sans-serif;background:var(--bg);color:var(--text);font-size:14px;line-height:1.5;-webkit-font-smoothing:antialiased}.app-shell{display:flex;min-height:100vh}.main-content{flex:1;margin-left:var(--sidebar-w);min-height:100vh;background:var(--bg)}.sidebar{width:var(--sidebar-w);background:var(--sidebar-bg);position:fixed;top:0;left:0;bottom:0;display:flex;flex-direction:column;z-index:100}.sidebar-header{padding:20px 16px 16px;border-bottom:1px solid rgba(255,255,255,.1)}.sidebar-brand{display:flex;align-items:center;gap:10px}.sidebar-logo-mark{width:36px;height:36px;background:var(--blue-light);border-radius:8px;display:flex;align-items:center;justify-content:center;font-weight:800;font-size:18px;color:#fff;flex-shrink:0}.sidebar-brand-name{font-weight:700;font-size:15px;color:#fff;line-height:1.2}.sidebar-brand-sub{font-size:11px;color:#ffffff8c;font-weight:400}.sidebar-nav{flex:1;padding:12px 8px;display:flex;flex-direction:column;gap:2px;overflow-y:auto}.nav-item{display:flex;align-items:center;gap:10px;padding:9px 10px;border-radius:6px;border:none;background:none;color:#ffffffb3;cursor:pointer;font-size:13.5px;font-family:inherit;font-weight:500;text-align:left;width:100%;transition:all .15s;position:relative}.nav-item:hover{background:#ffffff14;color:#fff}.nav-item-active{background:#ffffff26!important;color:#fff!important}.nav-badge{margin-left:auto;background:#dc2626;color:#fff;font-size:11px;font-weight:700;padding:1px 6px;border-radius:10px;line-height:16px}.sidebar-footer{padding:12px 16px 16px;border-top:1px solid rgba(255,255,255,.1)}.sidebar-user{display:flex;align-items:center;gap:10px;margin-bottom:10px}.user-avatar{width:32px;height:32px;background:var(--blue-light);border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:14px;color:#fff;flex-shrink:0}.user-name{font-size:13px;font-weight:600;color:#fff;line-height:1.2}.user-role{font-size:11px;color:#ffffff80;text-transform:capitalize}.sidebar-meta{font-size:11px;color:#ffffff59;margin-bottom:10px;line-height:1.6}.signout-btn{display:flex;align-items:center;gap:6px;background:none;border:1px solid rgba(255,255,255,.2);color:#fff9;padding:6px 10px;border-radius:6px;cursor:pointer;font-size:12px;font-family:inherit;width:100%;transition:all .15s}.signout-btn:hover{border-color:#fff6;color:#fff}.page{padding:28px 32px;max-width:1400px}.page-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:24px}.page-title{font-size:22px;font-weight:700;color:var(--text)}.page-date{font-size:13px;color:var(--text-muted);margin-top:2px}.result-count{font-size:13px;color:var(--text-muted)}.page-loading{padding:40px;text-align:center;color:var(--text-muted)}.card{background:var(--white);border-radius:var(--radius);border:1px solid var(--border);box-shadow:var(--shadow);padding:20px}.card-title{font-size:15px;font-weight:600;margin-bottom:16px;color:var(--text)}.table-card{padding:0;overflow:hidden}.stats-grid-4{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}.stats-grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}.stat-card{background:var(--white);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);padding:20px;text-align:center}.stat-card-click{cursor:pointer;transition:box-shadow .15s,transform .15s}.stat-card-click:hover{box-shadow:var(--shadow-md);transform:translateY(-1px)}.stat-value{font-size:32px;font-weight:700;color:var(--text);line-height:1;margin-bottom:6px}.stat-label{font-size:13px;color:var(--text-muted);font-weight:500}.stat-sub{font-size:11px;color:var(--text-light);margin-top:4px}.data-table{width:100%;border-collapse:collapse;font-size:13.5px}.data-table thead tr{background:#f8f9fa;border-bottom:1px solid var(--border)}.data-table th{padding:11px 16px;text-align:left;font-size:12px;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.04em;white-space:nowrap}.data-table th.sortable{cursor:pointer;-webkit-user-select:none;user-select:none}.data-table th.sortable:hover{color:var(--text)}.data-table td{padding:11px 16px;border-bottom:1px solid #f0f2f5;vertical-align:middle}.table-row:last-child td{border-bottom:none}.table-row.clickable{cursor:pointer;transition:background .1s}.table-row.clickable:hover{background:#f8f9fa}.table-row.row-risk{border-left:3px solid var(--red)}.empty-cell{text-align:center;padding:48px;color:var(--text-muted)}.empty-state-large{text-align:center;padding:60px;font-size:16px;color:var(--green)}.ticket-num{font-weight:700;color:var(--text);font-size:13px}.risk-chip{display:inline-block;margin-left:6px;background:#fef2f2;color:#dc2626;font-size:10px;font-weight:700;padding:1px 5px;border-radius:4px;border:1px solid #fecaca}.text-main{font-weight:500}.text-sub{font-size:12px;color:var(--text-muted);margin-top:2px}.text-muted{color:var(--text-muted)}.text-blue{font-size:12px;color:var(--blue);margin-top:2px}.text-green{color:var(--green);font-weight:500}.icon-link{font-size:16px;text-decoration:none;margin-right:4px;opacity:.7}.icon-link:hover{opacity:1}.risk-reason-text{font-size:12px;color:#dc2626;font-weight:500}.badge{display:inline-block;font-size:11px;font-weight:600;padding:2px 8px;border-radius:12px;white-space:nowrap}.badge-overdue{background:#fef2f2;color:#dc2626;border:1px solid #fecaca}.badge-today{background:#fff7ed;color:#ea580c;border:1px solid #fed7aa}.badge-warn{background:#fffbeb;color:#d97706;border:1px solid #fde68a}.badge-soon{background:#f5f3ff;color:#7c3aed;border:1px solid #ddd6fe}.badge-ok{background:#f0fdf4;color:#16a34a;border:1px solid #bbf7d0}.badge-done{background:#f9fafb;color:#6b7280;border:1px solid #e5e7eb}.badge-gray{background:#f9fafb;color:#9ca3af;border:1px solid #e5e7eb}.badge-risk{background:#fef2f2;color:#dc2626;border:1px solid #fecaca}.status-pill{display:inline-block;font-size:11px;font-weight:600;padding:3px 10px;border-radius:12px;white-space:nowrap}.pill-open{background:#eff6ff;color:#2557a7;border:1px solid #bfdbfe}.pill-claimed{background:#fffbeb;color:#d97706;border:1px solid #fde68a}.pill-completed{background:#f0fdf4;color:#16a34a;border:1px solid #bbf7d0}.pill-atrisk{background:#fef2f2;color:#dc2626;border:1px solid #fecaca}.pill-expired{background:#f9fafb;color:#6b7280;border:1px solid #e5e7eb}.role-pill{display:inline-block;font-size:11px;font-weight:600;padding:2px 8px;border-radius:10px;text-transform:capitalize}.role-admin{background:#eff6ff;color:#2557a7;border:1px solid #bfdbfe}.role-technician{background:#f0fdf4;color:#16a34a;border:1px solid #bbf7d0}.role-viewer{background:#f9fafb;color:#6b7280;border:1px solid #e5e7eb}.filter-bar{display:flex;align-items:center;gap:12px;padding:14px 16px;margin-bottom:16px;flex-wrap:wrap}.filter-search{flex:1;min-width:220px}.filter-check{display:flex;align-items:center;gap:6px;font-size:13px;color:var(--text-muted);cursor:pointer;white-space:nowrap;font-weight:500}.filter-check input{accent-color:var(--blue);cursor:pointer}.loading-bar{height:2px;background:linear-gradient(90deg,transparent,var(--blue),transparent);animation:slide 1s infinite}@keyframes slide{0%{transform:translate(-100%)}to{transform:translate(100%)}}.pagination{display:flex;align-items:center;justify-content:center;gap:16px;padding:20px}.page-info{font-size:13px;color:var(--text-muted)}.form-group{display:flex;flex-direction:column;gap:6px}.form-label{font-size:13px;font-weight:500;color:var(--text)}.form-input{background:var(--white);border:1px solid var(--border);border-radius:6px;color:var(--text);padding:8px 12px;font-size:14px;font-family:inherit;transition:border-color .15s,box-shadow .15s;width:100%}.form-input:focus{outline:none;border-color:var(--blue);box-shadow:0 0 0 3px #2557a71a}.form-select{background:var(--white);border:1px solid var(--border);border-radius:6px;color:var(--text);padding:8px 12px;font-size:13.5px;font-family:inherit;cursor:pointer}.form-select:focus{outline:none;border-color:var(--blue)}.form-row{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:12px}.form-err{background:#fef2f2;border:1px solid #fecaca;color:#dc2626;padding:10px 14px;border-radius:6px;margin-bottom:12px;font-size:13px}.btn-primary{background:var(--blue);color:#fff;border:none;border-radius:6px;padding:8px 16px;font-size:13.5px;font-weight:600;font-family:inherit;cursor:pointer;transition:background .15s;text-decoration:none;display:inline-flex;align-items:center;gap:6px}.btn-primary:hover{background:var(--blue-dark)}.btn-primary:disabled{opacity:.5;cursor:not-allowed}.w-full{width:100%;justify-content:center;padding:10px 16px;margin-top:4px}.btn-outline{background:#fff;color:var(--text);border:1px solid var(--border);border-radius:6px;padding:8px 16px;font-size:13.5px;font-weight:500;font-family:inherit;cursor:pointer;transition:all .15s}.btn-outline:hover{border-color:var(--blue);color:var(--blue)}.btn-outline:disabled{opacity:.4;cursor:not-allowed}.btn-success{background:#16a34a;color:#fff;border:none;border-radius:6px;padding:8px 16px;font-size:13.5px;font-weight:600;font-family:inherit;cursor:pointer;transition:background .15s}.btn-success:hover{background:#15803d}.btn-success:disabled{opacity:.5;cursor:not-allowed}.btn-link-cable{display:inline-flex;align-items:center;gap:5px;font-size:12px;font-weight:600;padding:5px 10px;border-radius:6px;text-decoration:none;background:#fff7ed;color:#ea580c;border:1px solid #fed7aa;transition:background .15s}.btn-link-cable:hover{background:#ffedd5}.btn-link-map{display:inline-flex;align-items:center;gap:5px;font-size:12px;font-weight:600;padding:5px 10px;border-radius:6px;text-decoration:none;background:#eff6ff;color:#2557a7;border:1px solid #bfdbfe;transition:background .15s}.btn-link-map:hover{background:#dbeafe}.login-page{min-height:100vh;background:var(--bg);display:flex;align-items:center;justify-content:center}.login-card{background:var(--white);border:1px solid var(--border);border-radius:12px;padding:40px;width:380px;box-shadow:var(--shadow-md)}.login-brand{display:flex;align-items:center;gap:12px;margin-bottom:28px}.login-brand-name{font-size:18px;font-weight:700;color:var(--text)}.login-brand-sub{font-size:12px;color:var(--text-muted)}.login-title{font-size:18px;font-weight:600;margin-bottom:20px}.login-err{background:#fef2f2;border:1px solid #fecaca;color:#dc2626;padding:10px 14px;border-radius:6px;margin-bottom:16px;font-size:13px}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000073;z-index:200;display:flex;align-items:center;justify-content:center;padding:24px;overflow-y:auto}.modal{background:var(--white);border-radius:12px;width:100%;max-width:800px;box-shadow:0 20px 60px #0003;max-height:90vh;overflow-y:auto}.modal-header{display:flex;align-items:flex-start;justify-content:space-between;padding:20px 24px;border-bottom:1px solid var(--border)}.modal-title{font-size:18px;font-weight:700}.modal-header-right{display:flex;align-items:center;gap:8px;flex-wrap:wrap;justify-content:flex-end}.modal-close-btn{background:#f9fafb;border:1px solid var(--border);color:var(--text-muted);width:28px;height:28px;border-radius:50%;cursor:pointer;font-size:13px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.modal-close-btn:hover{border-color:#dc2626;color:#dc2626}.risk-alert{background:#fef3c7;border:1px solid #fde68a;color:#92400e;padding:12px 24px;font-size:13px;border-left:4px solid #f59e0b}.modal-body{padding:20px 24px}.modal-grid{display:grid;grid-template-columns:1fr 1fr;gap:20px}.modal-full{grid-column:1 / -1}.section-title{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted);margin-bottom:12px}.detail-list{display:grid;grid-template-columns:auto 1fr;gap:5px 12px;font-size:13px}.detail-list dt{color:var(--text-muted);white-space:nowrap;padding-top:1px}.detail-list dd{color:var(--text)}.detail-list dd a{color:var(--blue);text-decoration:none}.link-row{display:flex;gap:8px;margin-top:12px;flex-wrap:wrap}.remark-text{font-size:13px;color:var(--text-muted);line-height:1.6;margin-bottom:4px}.notes-pre{font-family:inherit;font-size:12.5px;color:var(--text-muted);white-space:pre-wrap;background:#f9fafb;border:1px solid var(--border);border-radius:6px;padding:12px;line-height:1.6}.modal-footer{padding:16px 24px;border-top:1px solid var(--border);display:flex;flex-direction:column;gap:12px}.modal-actions-left,.note-row{display:flex;gap:8px}code{background:#f3f4f6;border:1px solid var(--border);padding:2px 6px;border-radius:4px;font-size:12px;color:#374151}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:#d1d5db;border-radius:3px}::-webkit-scrollbar-thumb:hover{background:#9ca3af}.modal-wide{max-width:960px}.modal-grid-3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:20px}.modal-map-wrap{margin-top:20px;border:1px solid var(--border);border-radius:var(--radius);overflow:hidden}.modal-map-header{display:flex;align-items:center;justify-content:space-between;padding:10px 14px;background:#f8f9fa;border-bottom:1px solid var(--border)}.map-no-coords{display:flex;align-items:center;justify-content:center;height:120px;background:#f9fafb;color:var(--text-muted);font-size:13px;gap:12px}.btn-icon{display:flex;align-items:center;justify-content:center;width:32px;height:32px;background:#f9fafb;border:1px solid var(--border);border-radius:6px;cursor:pointer;color:var(--text-muted);transition:all .15s;flex-shrink:0}.btn-icon:hover{border-color:var(--blue);color:var(--blue)}@media print{.sidebar,.modal-overlay,.modal-footer,.filter-bar,.pagination,.btn-icon,.modal-close-btn{display:none!important}.main-content{margin-left:0!important}.modal{box-shadow:none!important;max-height:none!important;overflow:visible!important}.modal-map-wrap{page-break-inside:avoid}}.td-check{width:36px;padding:0 8px!important}.row-checkbox{width:16px;height:16px;cursor:pointer;accent-color:var(--blue)}.row-selected{background:#eff6ff!important}.row-selected:hover{background:#dbeafe!important}.bulk-bar{display:flex;align-items:center;gap:10px;padding:10px 16px;margin-bottom:12px;background:#eff6ff;border:1px solid #bfdbfe;border-radius:var(--radius);flex-wrap:wrap}.bulk-count{font-weight:700;font-size:13px;color:var(--blue);margin-right:4px}.btn-sm{padding:5px 12px!important;font-size:12px!important}.assignee-chip{display:inline-block;font-size:11px;font-weight:600;color:var(--blue);background:#eff6ff;border:1px solid #bfdbfe;border-radius:10px;padding:1px 7px;margin-top:3px}.assignee-bar{display:flex;align-items:center;justify-content:space-between;padding:10px 24px;background:#f8f9fa;border-bottom:1px solid var(--border);gap:12px}.assignee-info{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.assignee-label{font-size:12px;color:var(--text-muted);font-weight:500}.assignee-name{font-size:13px;font-weight:700;color:var(--blue)}.assignee-when{font-size:11px;color:var(--text-muted)}.history-panel{border-bottom:1px solid var(--border);background:#fafbfc}.history-list{padding:4px 16px 16px;display:flex;flex-direction:column;gap:0}.history-item{display:flex;gap:12px;align-items:flex-start;padding:8px 0;border-bottom:1px solid #f0f2f5;position:relative}.history-item:last-child{border-bottom:none}.history-dot{width:8px;height:8px;background:var(--blue);border-radius:50%;flex-shrink:0;margin-top:5px}.history-content{display:flex;flex-wrap:wrap;gap:6px;align-items:baseline;font-size:12px}.history-action{font-weight:700;color:var(--text)}.history-user{color:var(--text-muted)}.history-change{background:#f0fdf4;border:1px solid #bbf7d0;color:#15803d;padding:1px 6px;border-radius:4px;font-size:11px;font-weight:600}.history-note{color:var(--text-muted);font-style:italic}.history-time{color:var(--text-light);font-size:11px;margin-left:auto;white-space:nowrap}.workload-row{display:flex;align-items:center;gap:12px;padding:8px 0;border-bottom:1px solid #f0f2f5;font-size:13px}.workload-row:last-child{border-bottom:none}.workload-name{font-weight:600;flex:1}.workload-count{background:#eff6ff;color:var(--blue);font-weight:700;font-size:12px;padding:2px 8px;border-radius:10px;border:1px solid #bfdbfe}.stats-grid-2{display:grid;grid-template-columns:1fr 1fr;gap:16px}
