*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--primary:#1a56db;--primary-dark:#1442a8;--danger:#dc2626;--success:#16a34a;--warning:#f59e0b;--gray-50:#f9fafb;--gray-100:#f3f4f6;--gray-200:#e5e7eb;--gray-300:#d1d5db;--gray-500:#6b7280;--gray-700:#374151;--gray-900:#111827;--radius:10px;--shadow:0 1px 3px #0000001a, 0 1px 2px #0000000f;--shadow-md:0 4px 6px #00000012, 0 2px 4px #0000000f}body{background:var(--gray-100);color:var(--gray-900);-webkit-tap-highlight-color:transparent;overscroll-behavior:none;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif}#root{min-height:100dvh}.btn{border-radius:var(--radius);cursor:pointer;-webkit-user-select:none;user-select:none;border:none;justify-content:center;align-items:center;gap:6px;padding:12px 20px;font-size:15px;font-weight:600;transition:background .15s,transform .1s;display:inline-flex}.btn:active{transform:scale(.97)}.btn-primary{background:var(--primary);color:#fff}.btn-primary:hover{background:var(--primary-dark)}.btn-secondary{background:var(--gray-200);color:var(--gray-700)}.btn-danger{background:var(--danger);color:#fff}.btn-full{width:100%}.btn-sm{padding:8px 14px;font-size:13px}label{color:var(--gray-500);text-transform:uppercase;letter-spacing:.5px;margin-top:14px;margin-bottom:4px;font-size:13px;font-weight:600;display:block}input,select,textarea{border:1px solid var(--gray-300);border-radius:var(--radius);appearance:none;background:#fff;width:100%;padding:12px;font-size:16px}input[type=checkbox],input[type=radio]{appearance:auto;width:auto;accent-color:var(--primary);cursor:pointer;margin:0;padding:0}input:focus,select:focus,textarea:focus{border-color:var(--primary);outline:none;box-shadow:0 0 0 3px #1a56db26}textarea{resize:vertical}select{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%236b7280' d='M6 8L1 3h10z'/%3E%3C/svg%3E");background-position:right 12px center;background-repeat:no-repeat;padding-right:36px}.login-page{background:linear-gradient(135deg,#1a56db 0%,#1e3a8a 100%);justify-content:center;align-items:center;min-height:100dvh;padding:20px;display:flex}.login-card{width:100%;max-width:380px;box-shadow:var(--shadow-md);background:#fff;border-radius:16px;padding:32px 24px}.login-logo{text-align:center;margin-bottom:24px}.login-logo h1{color:var(--primary);margin:8px 0 0;font-size:28px}.logo-img{width:auto;height:48px}.header-logo{width:auto;height:28px}.login-subtitle{color:var(--gray-500);font-size:14px}.logo-icon{color:var(--primary);font-size:36px}.error-msg{color:var(--danger);margin-top:8px;font-size:13px}.demo-hint{text-align:center;color:var(--gray-500);margin-top:20px;font-size:12px}.app-shell{flex-direction:column;min-height:100dvh;display:flex}.app-header{background:var(--primary);color:#fff;z-index:50;justify-content:space-between;align-items:center;padding:10px 16px;display:flex;position:sticky;top:0}.header-left{align-items:center;display:flex}.header-title{text-align:center;flex:1;font-size:17px;font-weight:700}.header-right{align-items:center;display:flex;position:relative}.user-avatar{color:#fff;cursor:pointer;background:#ffffff40;border:none;border-radius:50%;justify-content:center;align-items:center;width:34px;height:34px;font-size:13px;font-weight:700;transition:background .15s;display:flex}.user-avatar:hover{background:#fff6}.notification-badge{color:#fff;background:#dc2626;border-radius:8px;justify-content:center;align-items:center;min-width:16px;height:16px;padding:0 4px;font-size:10px;font-weight:700;display:flex;position:absolute;top:2px;right:2px}.notification-dropdown{border-radius:var(--radius);z-index:1000;border:1px solid var(--gray-200);background:#fff;width:320px;max-width:90vw;position:absolute;top:100%;right:0;box-shadow:0 4px 20px #00000026}.notification-item{border-bottom:1px solid var(--gray-100);cursor:pointer;padding:10px 12px;transition:background .1s}.notification-item:hover{background:var(--gray-50)}.notification-item:last-child{border-bottom:none}.user-menu{border-radius:var(--radius);box-shadow:var(--shadow-md);z-index:100;min-width:200px;color:var(--gray-900);background:#fff;padding:16px;position:absolute;top:42px;right:0}.user-menu-name{font-size:15px;font-weight:700}.user-menu-role{color:var(--gray-500);margin-top:2px;font-size:13px}.user-menu-company{color:var(--gray-500);margin-top:2px;font-size:12px}.user-menu-version{color:var(--gray-400);text-align:center;margin-top:10px;font-size:11px}.changelog-modal{border-radius:var(--radius);box-shadow:var(--shadow-md);z-index:100;background:#fff;flex-direction:column;width:90%;max-width:480px;max-height:80vh;display:flex;position:fixed;top:50%;left:50%;overflow:hidden;transform:translate(-50%,-50%)}.changelog-header{border-bottom:1px solid var(--gray-200);justify-content:space-between;align-items:center;padding:16px 20px;display:flex}.changelog-header h3{margin:0;font-size:18px}.changelog-body{padding:16px 20px;overflow-y:auto}.changelog-version{margin-bottom:20px}.changelog-version h4{color:var(--primary);margin:0 0 8px;font-size:15px}.changelog-date{color:var(--gray-500);font-size:12px;font-weight:400}.changelog-version ul{margin:0;padding:0 0 0 18px}.changelog-version li{color:var(--gray-700);margin-bottom:6px;font-size:13px;line-height:1.5}.changelog-version li strong{color:var(--gray-900)}.app-main{flex:1;padding:16px 16px 80px;overflow-y:auto}.app-nav{border-top:1px solid var(--gray-200);padding:6px 0;padding-bottom:max(6px, env(safe-area-inset-bottom));z-index:50;background:#fff;display:flex;position:fixed;bottom:0;left:0;right:0;box-shadow:0 -2px 8px #0000000f}.nav-item,.nav-btn{color:var(--gray-500);cursor:pointer;background:0 0;border:none;flex-direction:column;flex:1;align-items:center;gap:2px;padding:6px 0;font-size:11px;font-weight:500;text-decoration:none;transition:color .15s;display:flex}.nav-item.active,.nav-btn.active{color:var(--primary)}.more-backdrop{z-index:60;background:#0000004d;position:fixed;inset:0}.more-popover{bottom:calc(60px + max(6px, env(safe-area-inset-bottom)));z-index:70;border-radius:var(--radius);box-shadow:var(--shadow-md);background:#fff;grid-template-columns:1fr 1fr;gap:4px;min-width:220px;padding:8px;display:grid;position:fixed;right:12px}.more-item{color:var(--gray-600);border-radius:8px;flex-direction:column;align-items:center;gap:4px;padding:14px 8px;font-size:12px;font-weight:500;text-decoration:none;transition:background .15s;display:flex}.more-item:hover{background:var(--gray-50)}.more-item.active{color:var(--primary);background:#eff6ff}.dashboard{max-width:1200px}.admin-layout{gap:24px;display:flex}.admin-main{flex:1;min-width:0;max-width:640px}.dash-alerts{flex-direction:column;gap:6px;margin-bottom:16px;display:flex}.alert-link{white-space:nowrap;font-size:12px;font-weight:600}.dash-actions{gap:8px;margin-bottom:20px;display:flex}.dash-action-btn{border-radius:var(--radius);border:1px solid var(--gray-200);cursor:pointer;color:var(--gray-700);box-shadow:var(--shadow);background:#fff;flex:1;justify-content:center;align-items:center;gap:6px;padding:12px 8px;font-size:13px;font-weight:500;transition:all .15s;display:flex}.dash-action-btn:hover{border-color:var(--primary);color:var(--primary);box-shadow:var(--shadow-md)}.dash-action-primary{background:var(--primary);color:#fff;border-color:var(--primary)}.dash-action-primary:hover{color:#fff;background:#1e429f}.dash-action-icon{background:#0000000f;border-radius:50%;justify-content:center;align-items:center;width:24px;height:24px;font-size:14px;font-weight:700;display:flex}.dash-action-primary .dash-action-icon{background:#fff3}.dash-section{margin-bottom:20px}.dash-section-header{align-items:center;gap:8px;margin-bottom:10px;display:flex}.dash-section-header h3{margin:0;font-size:15px}.dash-section-desc{color:var(--gray-500);margin:-6px 0 8px;font-size:12px}.dash-count-badge{background:var(--gray-100);color:var(--gray-600);border-radius:10px;padding:2px 8px;font-size:11px;font-weight:600}.dash-count-live{color:#166534;background:#dcfce7}.dash-kpi-strip{border-radius:var(--radius);box-shadow:var(--shadow);background:#fff;align-items:center;margin-bottom:20px;padding:16px 8px;display:flex}.dash-kpi{text-align:center;cursor:pointer;flex:1}.dash-kpi:hover .dash-kpi-value{color:var(--primary)}.dash-kpi-value{color:var(--gray-800);font-size:26px;font-weight:700;line-height:1.1;display:block}.dash-kpi-label{color:var(--gray-500);text-transform:uppercase;letter-spacing:.5px;margin-top:2px;font-size:10px;display:block}.dash-kpi-divider{background:var(--gray-200);flex-shrink:0;width:1px;height:32px}.dash-audit-card{border-radius:var(--radius);box-shadow:var(--shadow);background:#fff;margin-bottom:20px;padding:16px}.dash-audit-header{justify-content:space-between;align-items:baseline;margin-bottom:10px;display:flex}.dash-audit-header h3{margin:0;font-size:15px}.dash-audit-total{color:var(--gray-500);font-size:12px}.dash-audit-stats{gap:24px;display:flex}.dash-audit-stat{text-align:center}.dash-audit-value{color:var(--primary);font-size:28px;font-weight:700;line-height:1.1;display:block}.dash-audit-period{color:var(--gray-500);text-transform:uppercase;letter-spacing:.3px;margin-top:2px;font-size:11px;display:block}.admin-sidebar{border-radius:var(--radius);width:300px;box-shadow:var(--shadow);background:#fff;flex-shrink:0;height:fit-content;padding:16px;position:sticky;top:70px}.admin-sidebar h3{margin:0 0 12px;font-size:16px}.sidebar-card{border:1px solid var(--gray-200);cursor:pointer;border-radius:8px;margin-bottom:8px;padding:10px;font-size:13px;transition:background .15s}.sidebar-card:hover{background:var(--gray-50)}.sidebar-card strong{margin-bottom:2px;font-size:13px;display:block}.sidebar-card span{color:var(--gray-500);font-size:12px;display:block}.sidebar-card-haz{background:#fef2f2;border-color:#fecaca}.overlap-card{border-radius:var(--radius);background:#fff;border:2px solid #fde68a;margin-bottom:8px;padding:12px}.overlap-card-header{margin-bottom:8px}.overlap-card-header strong{font-size:15px;display:block}.overlap-card-case{background:var(--gray-50);cursor:pointer;border-radius:6px;margin-top:6px;padding:8px;transition:background .15s}.overlap-card-case:hover{background:var(--gray-100)}.sidebar-date-header{color:var(--gray-500);text-transform:uppercase;letter-spacing:.5px;margin-bottom:6px;font-size:12px;font-weight:600}.schedule-week{flex-direction:column;gap:4px;display:flex}.schedule-day{padding:8px 0}.schedule-day-today{background:var(--gray-50);border-radius:var(--radius);margin:0 -16px;padding:8px 16px}.schedule-day-header{border-bottom:1px solid var(--gray-100);justify-content:space-between;align-items:center;margin-bottom:6px;padding-bottom:4px;display:flex}.schedule-day-label{color:var(--gray-700);font-size:13px;font-weight:600}.schedule-day-today .schedule-day-label{color:var(--primary)}.schedule-day-count{background:var(--gray-100);color:var(--gray-500);text-align:center;border-radius:10px;min-width:20px;padding:1px 8px;font-size:11px;font-weight:600}.schedule-day-today .schedule-day-count{background:var(--primary);color:#fff}.schedule-day-empty{color:var(--gray-400);padding:4px 0;font-size:12px;font-style:italic}@media (width<=1024px){.admin-layout{flex-direction:column}.admin-sidebar{width:100%;position:static}.admin-main{max-width:600px}.dash-actions{flex-wrap:wrap}.dash-action-btn{min-width:100px}.dash-kpi-strip{flex-wrap:wrap;gap:8px;padding:12px}.dash-kpi-divider{display:none}.dash-kpi{min-width:70px}}.section-header{justify-content:space-between;align-items:center;margin:20px 0 10px;display:flex}.section-header h3{margin:0;font-size:16px}.stats-grid{grid-template-columns:1fr 1fr;gap:10px;display:grid}.stats-grid.three-col{grid-template-columns:repeat(3,1fr)}.stats-row{gap:10px;display:flex}.stats-row .stat-card{flex:1}.stat-card{border-radius:var(--radius);box-shadow:var(--shadow);text-align:center;background:#fff;padding:16px 14px}.stat-card.clickable:hover{box-shadow:var(--shadow-md)}.stat-number{color:var(--primary);font-size:24px;font-weight:700;display:block}.stat-label{color:var(--gray-500);text-transform:uppercase;letter-spacing:.5px;font-size:11px}.alert-bar{border-radius:var(--radius);cursor:pointer;justify-content:space-between;align-items:center;margin-bottom:12px;padding:10px 14px;font-size:14px;font-weight:500;display:flex}.alert-bar-amber{color:#92400e;background:#fef3c7;border:1px solid #fde68a}.alert-bar-red{color:#991b1b;background:#fee2e2;border:1px solid #fecaca}.quick-links-row{gap:10px;margin:16px 0;display:flex}.quick-link-card{border-radius:var(--radius);box-shadow:var(--shadow);text-align:center;cursor:pointer;color:var(--gray-700);background:#fff;flex:1;padding:14px 12px;font-size:13px;font-weight:600;text-decoration:none;transition:box-shadow .15s}.quick-link-card:hover{box-shadow:var(--shadow-md)}.quick-link-count{color:var(--primary);margin-bottom:2px;font-size:20px;font-weight:700;display:block}@media (width<=400px){.stats-grid.three-col{grid-template-columns:1fr 1fr}}.page-header{justify-content:space-between;align-items:center;margin-bottom:16px;display:flex}.page-header h2{font-size:22px}.record-list{flex-direction:column;gap:10px;display:flex}.record-card{border-radius:var(--radius);box-shadow:var(--shadow);cursor:pointer;background:#fff;padding:14px 16px;transition:box-shadow .15s}.record-card:active{box-shadow:var(--shadow-md)}.record-card-header{justify-content:space-between;align-items:center;margin-bottom:8px;display:flex}.record-card-body{color:var(--gray-500);justify-content:space-between;font-size:14px;display:flex}.record-card-footer{color:var(--gray-500);justify-content:space-between;margin-top:8px;font-size:12px;display:flex}.status-badge{text-transform:uppercase;letter-spacing:.5px;border-radius:20px;padding:3px 10px;font-size:11px;font-weight:600}.status-draft{background:var(--gray-200);color:var(--gray-700)}.status-submitted{color:#92400e;background:#fef3c7}.empty-state{text-align:center;color:var(--gray-500);padding:40px 0}.record-form{border-radius:var(--radius);box-shadow:var(--shadow);background:#fff;max-width:600px;padding:20px 16px}.record-form h2{margin-bottom:8px;font-size:20px}.form-row{grid-template-columns:1fr 1fr;gap:12px;display:grid}.form-field{flex:1}.gps-section{flex-wrap:wrap;align-items:center;gap:12px;margin-top:16px;display:flex}.gps-coords{color:var(--gray-500);font-family:monospace;font-size:13px}.splice-section{margin-top:20px}.splice-header{justify-content:space-between;align-items:center;margin-bottom:10px;display:flex}.splice-header h3{font-size:16px}.splice-table{border:1px solid var(--gray-200);border-radius:var(--radius);overflow:hidden}.splice-row{border-bottom:1px solid var(--gray-100);grid-template-columns:60px 1fr 100px;align-items:center;gap:8px;padding:8px 12px;display:grid}.splice-row:last-child{border-bottom:none}.splice-row-header{background:var(--gray-50);color:var(--gray-500);text-transform:uppercase;font-size:12px;font-weight:600}.splice-row input,.splice-row select{padding:8px;font-size:14px}.fibre-num{font-size:14px;font-weight:600}.splice-fail{background:#fef2f2}.result-pass{color:var(--success);font-weight:600}.result-fail{color:var(--danger);font-weight:600}.result-retest{color:var(--warning);font-weight:600}.photo-section{margin-top:16px}.photo-grid{flex-wrap:wrap;gap:10px;margin-top:10px;display:flex}.photo-thumb{cursor:pointer;border-radius:8px;width:100px;height:100px;position:relative;overflow:hidden}.photo-grid-large img{border-radius:8px;width:100%;max-width:300px}.record-detail{max-width:600px}.record-detail h2{margin:12px 0 8px;font-size:22px}.detail-grid{grid-template-columns:1fr 1fr;gap:12px;margin:16px 0;display:grid}.detail-item label{margin-top:0}.detail-item span{color:var(--gray-900);font-size:16px}.detail-notes{margin-bottom:16px}.detail-notes p{color:var(--gray-700)}.timesheet-page{max-width:600px}.timesheet-page h2{margin-bottom:16px;font-size:22px}.clock-controls{border-radius:var(--radius);box-shadow:var(--shadow);background:#fff;margin-bottom:20px;padding:20px 16px}.clock-active{text-align:center}.clock-status{justify-content:center;align-items:center;gap:8px;font-size:15px;font-weight:600;display:flex}.clock-dot{background:var(--success);border-radius:50%;width:10px;height:10px;display:inline-block}.clock-dot.pulse{animation:1.5s ease-in-out infinite pulse}@keyframes pulse{0%,to{opacity:1}50%{opacity:.3}}.clock-duration{color:var(--primary);margin:8px 0 16px;font-size:32px;font-weight:700}.clock-form label:first-child{margin-top:0}.timesheet-list h3{margin-bottom:10px;font-size:16px}.timesheet-card{border-radius:var(--radius);box-shadow:var(--shadow);background:#fff;margin-bottom:10px;padding:14px 16px}.timesheet-card-header{justify-content:space-between;margin-bottom:6px;display:flex}.timesheet-card-body{color:var(--gray-500);gap:16px;font-size:14px;display:flex}.timesheet-card-body .duration{color:var(--gray-700);margin-left:auto;font-weight:600}.timesheet-wo{color:var(--gray-500);margin-top:6px;font-size:13px}.timesheet-gps{color:var(--gray-500);margin-top:4px;font-family:monospace;font-size:12px}.active-visit-banner{color:#fff;cursor:pointer;background:#065f46;justify-content:space-between;align-items:center;padding:10px 16px;transition:background .15s;display:flex}.active-visit-banner:active{background:#064e3b}.banner-left{align-items:center;gap:8px;font-size:14px;display:flex}.banner-left .clock-dot{background:#34d399}.banner-right{align-items:center;gap:8px;display:flex}.banner-duration{font-size:15px;font-weight:700}.banner-arrow{opacity:.7;font-size:18px}.visit-banner{text-align:center;border-bottom:1px solid var(--gray-200);margin:12px 0;padding:16px 0}.visit-joint-info{margin-bottom:16px}.visit-map-card{border-radius:var(--radius);height:180px;box-shadow:var(--shadow);margin-bottom:8px;overflow:hidden}.visit-joint-meta{color:var(--gray-600);flex-wrap:wrap;align-items:center;gap:8px;padding:4px 0;font-size:13px;display:flex}.visit-card{border-radius:var(--radius);box-shadow:var(--shadow);cursor:pointer;background:#fff;margin-bottom:8px;padding:12px 16px;transition:box-shadow .15s}.visit-card:active{box-shadow:var(--shadow-md)}.visit-card-header{justify-content:space-between;align-items:center;margin-bottom:4px;display:flex}.visit-card-body{color:var(--gray-500);justify-content:space-between;align-items:center;font-size:14px;display:flex}.visit-card-body .duration{color:var(--gray-700);font-weight:600}.visit-card-footer{color:var(--gray-500);margin-top:4px;font-size:13px}.visit-history{margin-top:16px}.visit-history h3{margin-bottom:10px;font-size:16px}.check-in-btn{background:var(--success);padding:14px 20px;font-size:16px}.check-in-btn:hover{background:#15803d}.check-out-btn{padding:14px 20px;font-size:16px}.occupancy-indicator{color:var(--success);border-top:1px solid var(--gray-100);align-items:center;gap:6px;margin-top:8px;padding-top:8px;font-size:13px;font-weight:600;display:flex}.location-text{color:var(--gray-500);text-overflow:ellipsis;white-space:nowrap;font-size:12px;overflow:hidden}.active-visits-section{margin-top:20px}.active-visits-section h3{margin-bottom:10px;font-size:16px}.active-visit-dash{border-radius:var(--radius);background:#d1fae5;margin-bottom:16px;padding:12px 16px}.active-visit-dash.resume-card{cursor:pointer;box-shadow:var(--shadow);border:2px solid #34d399;padding:16px;transition:box-shadow .15s}.active-visit-dash.resume-card:hover{box-shadow:var(--shadow-md)}.resume-card-details{justify-content:space-between;align-items:center;gap:12px;margin-top:10px;display:flex}.resume-card-meta{color:#065f46;font-size:13px}.active-visit-dash .clock-status{color:#065f46}.visit-card-tags{flex-wrap:wrap;align-items:center;gap:6px;margin-top:6px;display:flex}.visit-tag{background:var(--gray-100);color:var(--gray-700);border-radius:4px;padding:2px 8px;font-size:11px;font-weight:500}.visit-tag-muted{color:var(--gray-500);padding:2px 8px;font-size:11px}.case-card{border-radius:var(--radius);box-shadow:var(--shadow);cursor:pointer;background:#fff;margin-bottom:8px;padding:14px 16px;transition:box-shadow .15s}.case-card:hover{box-shadow:var(--shadow-md)}.case-card-header{justify-content:space-between;align-items:center;margin-bottom:6px;display:flex}.case-card-body{color:var(--gray-500);flex-wrap:wrap;align-items:center;gap:8px;margin-bottom:8px;font-size:13px;display:flex}.case-progress{margin-top:6px}.case-progress-bar{background:var(--gray-200);border-radius:3px;height:6px;overflow:hidden}.case-progress-bar.large{border-radius:5px;height:10px}.case-progress-fill{background:var(--success);border-radius:inherit;height:100%;transition:width .3s}.case-progress-text{color:var(--gray-500);margin-top:4px;font-size:12px;display:block}.case-detail-header{margin:12px 0}.case-detail-header h2{margin-bottom:4px;font-size:22px}.case-admin-controls{background:var(--gray-50);border:1px solid var(--gray-200);border-radius:var(--radius);margin:12px 0;padding:14px}.case-joint-checklist{flex-direction:column;gap:4px;display:flex}.case-joint-item{border-radius:var(--radius);border:1px solid var(--gray-200);background:#fff;flex-direction:column;gap:0;padding:10px 12px;transition:background .15s;display:flex}.case-joint-item.visited{background:#f0fdf4;border-color:#bbf7d0}.case-joint-item.cannot_access{background:#fef2f2;border-color:#fecaca}.case-joint-seq{background:var(--gray-200);width:24px;height:24px;color:var(--gray-600);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:11px;font-weight:700;display:flex}.case-joint-item.visited .case-joint-seq{background:var(--success);color:#fff}.case-joint-info{flex:1;min-width:0}.case-joint-info strong{font-size:14px;display:block}.case-joint-loc{color:var(--gray-500);white-space:nowrap;text-overflow:ellipsis;font-size:12px;display:block;overflow:hidden}.case-joint-actions{flex-shrink:0;align-items:center;gap:6px;display:flex}.case-joint-check{color:var(--success);font-size:18px;font-weight:700}.case-joint-header{cursor:pointer;align-items:center;gap:10px;width:100%;display:flex}.case-joint-detail{border-top:1px solid var(--gray-100);margin-top:8px;padding:12px 0 8px}.expand-arrow{color:var(--gray-400);flex-shrink:0;font-size:10px}.assign-select{border:1px solid var(--gray-300);border-radius:4px;max-width:100px;padding:4px 6px;font-size:11px}.worker-assign-section{margin-top:10px}.worker-assign-label{color:var(--gray-500);text-transform:uppercase;letter-spacing:.3px;margin-bottom:6px;font-size:12px;font-weight:600;display:block}.worker-assign-list{border:1px solid var(--gray-200);border-radius:var(--radius);grid-template-columns:1fr;gap:4px;display:grid;overflow:hidden}.worker-assign-item{cursor:pointer;border-bottom:1px solid var(--gray-100);background:#fff;align-items:center;gap:10px;margin:0;padding:10px 12px;transition:background .15s;display:flex}.worker-assign-item:last-child{border-bottom:none}.worker-assign-item:hover{background:var(--gray-50)}.worker-assign-item.checked{background:#eff6ff}.worker-assign-item input[type=checkbox]{width:18px;height:18px;accent-color:var(--primary);cursor:pointer;flex-shrink:0}.worker-assign-info{flex:1;min-width:0}.worker-assign-name{color:var(--gray-800);font-size:14px;font-weight:500;display:block}.worker-assign-phone{color:var(--gray-400);font-size:12px;display:block}.worker-assign-tick{color:var(--primary);flex-shrink:0;font-size:16px;font-weight:700}.splice-ref{border-radius:var(--radius);color:var(--gray-800);background:#f0f9ff;border:1px solid #bfdbfe;flex-wrap:wrap;align-items:center;gap:6px;margin-top:6px;padding:10px 12px;font-family:monospace;font-size:14px;display:flex}.splice-ref-side{font-weight:600}.splice-ref-arrow{color:var(--primary);font-size:16px;font-weight:700}.splice-ref-sheath{color:var(--gray-500);width:100%;margin-top:2px;font-family:inherit;font-size:12px}.case-preview{background:var(--gray-50);border:1px solid var(--gray-200);border-radius:var(--radius);margin:12px 0;padding:14px}.case-joint-preview{max-height:300px;margin:8px 0;overflow-y:auto}.case-joint-preview-row{border-bottom:1px solid var(--gray-100);align-items:center;gap:8px;padding:6px 8px;font-size:13px;display:flex}.case-joint-preview-row.unmatched{background:#fef3c7}.case-joint-preview-row .seq{width:24px;color:var(--gray-500);text-align:right;flex-shrink:0;font-weight:600}.case-joint-preview-row .ref{flex-shrink:0;min-width:90px;font-weight:600}.case-joint-preview-row .loc{color:var(--gray-500);white-space:nowrap;text-overflow:ellipsis;flex:1;overflow:hidden}.overlap-warning{border-radius:var(--radius);background:#fef3c7;border:1px solid #fde68a;margin:12px 0;padding:14px;font-size:13px}.overlap-warning strong{color:#92400e;margin-bottom:4px;display:block}.overlap-warning ul{margin:4px 0 0 16px;padding:0}.overlap-warning li{margin:2px 0}.status-checked_in{color:#065f46;background:#d1fae5}.status-completed{color:#92400e;background:#fef3c7}.status-reviewed{color:#1e40af;background:#dbeafe}.status-rework_requested{color:#991b1b;background:#fee2e2}.status-active{color:#065f46;background:#d1fae5}.rag-badge{letter-spacing:.5px;border-radius:4px;padding:2px 8px;font-size:11px;font-weight:700;display:inline-block}.rag-red{color:#991b1b;background:#fee2e2}.rag-amber{color:#92400e;background:#fef3c7}.rag-green{color:#065f46;background:#d1fae5}.pathway-badge{color:#5b21b6;background:#ede9fe;border-radius:4px;padding:2px 8px;font-size:11px;font-weight:600;display:inline-block}.filter-bar{flex-wrap:wrap;gap:6px;margin:12px 0;display:flex}.calendar-page{padding:0}.calendar-layout{gap:16px;display:flex}.calendar-main{flex:1;min-width:0}.calendar-sidebar{flex-shrink:0;width:280px}.calendar-legend{flex-wrap:wrap;gap:12px;display:flex}.legend-item{color:var(--gray-500);align-items:center;gap:4px;font-size:12px;display:flex}.legend-dot{border-radius:50%;width:10px;height:10px;display:inline-block}@media (width<=768px){.calendar-layout{flex-direction:column}.calendar-sidebar{width:100%}}.rbc-calendar{font-family:inherit;font-size:13px}.rbc-header{padding:8px 4px;font-size:12px;font-weight:600}.rbc-today{background-color:#eff6ff}.rbc-toolbar button{border-radius:6px;padding:6px 12px;font-size:13px}.rbc-toolbar button.rbc-active{background:var(--primary);color:#fff;border-color:var(--primary)}.modal-overlay{z-index:1000;background:#00000080;justify-content:center;align-items:center;padding:20px;display:flex;position:fixed;inset:0}.modal-content{border-radius:var(--radius);width:100%;max-width:500px;box-shadow:var(--shadow-md);background:#fff;overflow:hidden}.modal-header{border-bottom:1px solid var(--gray-200);justify-content:space-between;align-items:center;padding:16px 20px;display:flex}.modal-header h3{font-size:16px}.modal-body{padding:20px}.reports-page{padding:0}.reports-grid{grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:16px;margin-top:12px;display:grid}.report-card{border-radius:var(--radius);box-shadow:var(--shadow);border:1px solid var(--gray-200);background:#fff;padding:16px}.report-card h3{margin-bottom:12px;font-size:15px}.report-card-header{justify-content:space-between;align-items:center;margin-bottom:12px;display:flex}.report-card-header h3{margin-bottom:0}.data-table{border-collapse:collapse;width:100%;font-size:14px}.data-table th{text-align:left;border-bottom:2px solid var(--gray-200);text-transform:uppercase;color:var(--gray-500);padding:10px 12px;font-size:12px;font-weight:600}.data-table td{border-bottom:1px solid var(--gray-100);padding:10px 12px}.data-table tr:hover td{background:var(--gray-50)}.review-panel{max-width:800px}.review-meta{color:var(--gray-500);flex-wrap:wrap;align-items:center;gap:12px;margin:12px 0;font-size:14px;display:flex}.review-section{background:var(--gray-50);border-radius:var(--radius);margin:20px 0;padding:16px}.review-section h3{color:var(--gray-700);margin-bottom:12px;font-size:14px}.review-notes{color:var(--gray-500);margin-top:8px;font-style:italic}.review-actions{flex-wrap:wrap;gap:8px;margin-top:20px;display:flex}.count-badge{background:var(--danger);color:#fff;border-radius:11px;justify-content:center;align-items:center;min-width:22px;height:22px;margin-left:6px;padding:0 6px;font-size:12px;font-weight:700;display:inline-flex}.warning-banner{border-radius:var(--radius);color:#92400e;background:#fef3c7;border:1px solid #f59e0b;margin:8px 0;padding:10px 14px;font-size:13px}.hazard-warning{border-radius:var(--radius);color:#991b1b;background:#fef2f2;border:1px solid #dc2626;margin:8px 0;padding:12px 14px;font-size:13px}.hazard-caution{border-radius:var(--radius);color:#991b1b;background:#fef2f2;border:2px solid #dc2626;margin:12px 0;padding:16px}.hazard-caution-header{align-items:center;gap:8px;margin-bottom:8px;display:flex}.hazard-caution-icon{font-size:24px}.hazard-caution-header strong{letter-spacing:.5px;font-size:16px}.hazard-caution p{margin:4px 0;font-size:13px}.hazard-caution-notes{border-top:1px solid #fecaca;margin-top:10px;padding-top:10px}.hazard-caution-notes strong{margin-bottom:4px;font-size:12px;display:block}.inline-form{background:var(--gray-50);border:1px solid var(--gray-200);border-radius:var(--radius);margin-bottom:16px;padding:16px}.card-actions{border-top:1px solid var(--gray-100);gap:6px;padding:8px 14px;display:flex}.error-message{border-radius:var(--radius);color:#dc2626;background:#fef2f2;border:1px solid #fecaca;margin-bottom:12px;padding:10px 14px;font-size:13px}.status-low{color:#1e40af;background:#dbeafe}.status-medium{color:#92400e;background:#fef3c7}.status-high{color:#9a3412;background:#fed7aa}.status-critical{color:#991b1b;background:#fecaca}.status-assigned{color:#1e40af;background:#dbeafe}.status-in_progress{color:#92400e;background:#fef3c7}.status-cancelled{background:var(--gray-200);color:var(--gray-500)}.status-contractor{color:#1e40af;background:#dbeafe}.status-fibreops{color:#5b21b6;background:#ede9fe}.status-gis_officer,.status-pass{color:#065f46;background:#d1fae5}.status-fail{color:#991b1b;background:#fecaca}.overstay-alert{border-radius:var(--radius);cursor:pointer;background:#fef2f2;border:1px solid #fecaca;justify-content:space-between;align-items:center;margin-bottom:8px;padding:10px 14px;display:flex}.overstay-alert:hover{background:#fee2e2}.overstay-alert .alert-text{color:#991b1b;font-size:13px}.overstay-alert .alert-time{color:#dc2626;font-size:14px;font-weight:700}.duration-green{color:var(--success)}.duration-amber{color:var(--warning)}.duration-red{color:var(--danger);font-weight:700}.live-activity-card{border:1px solid var(--gray-200);border-radius:var(--radius);background:#fff;justify-content:space-between;align-items:center;margin-bottom:6px;padding:10px 14px;display:flex}.live-activity-card .activity-info{font-size:13px}.live-activity-card .activity-info strong{display:block}.search-section{margin-bottom:12px}.search-input{border:1px solid var(--gray-300);border-radius:var(--radius);background:#fff;width:100%;margin-top:8px;padding:10px 14px;font-size:15px}.search-input:focus{border-color:var(--primary);outline:none;box-shadow:0 0 0 3px #1a56db1a}.work-type-grid{grid-template-columns:repeat(3,1fr);gap:6px;margin-top:8px;display:grid}.work-type-btn{border:2px solid var(--gray-200);border-radius:var(--radius);cursor:pointer;background:#fff;padding:12px 8px;font-size:14px;font-weight:500;transition:all .15s}.work-type-btn:hover{border-color:var(--primary)}.work-type-btn.active{border-color:var(--primary);color:var(--primary);background:#eff6ff;font-weight:600}.toggle-group{gap:8px;margin-top:4px;display:flex}.state-checkboxes{flex-wrap:wrap;gap:8px;margin-top:4px;display:flex}.state-checkbox{border:1px solid var(--gray-200);cursor:pointer;border-radius:6px;align-items:center;gap:6px;padding:6px 12px;font-size:14px;font-weight:500;display:flex}.state-checkbox input:checked+*{color:var(--primary)}.stat-card.clickable{cursor:pointer;transition:box-shadow .15s,border-color .15s}.stat-card.clickable:hover{box-shadow:var(--shadow-md);border-color:var(--primary)}.search-prompt{text-align:center;padding:40px 20px}.joint-detail-page{max-width:900px}.joint-detail-header{margin:12px 0}.joint-detail-header h2{margin-bottom:6px}.joint-badges{flex-wrap:wrap;gap:6px;display:flex}.joint-detail-top{gap:16px;margin:16px 0;display:flex}.joint-map-card{border-radius:var(--radius);border:1px solid var(--gray-200);flex:1;min-height:220px;overflow:hidden}.joint-info-card{border-radius:var(--radius);border:1px solid var(--gray-200);box-shadow:var(--shadow);background:#fff;flex:1;padding:16px}.joint-location-text{color:var(--gray-500);margin-top:8px;font-size:13px}.gps-coords-small{color:var(--gray-500);margin-top:4px;font-family:monospace;font-size:11px}@media (width<=768px){.joint-detail-top{flex-direction:column}.joint-map-card{min-height:180px}}.joint-actions{gap:10px;margin:12px 0;display:flex}.visit-history-section{margin-top:16px}.visit-history-section h3{margin-bottom:8px}.visit-history-card{border:1px solid var(--gray-200);border-radius:var(--radius);background:#fff;margin-bottom:8px;transition:box-shadow .15s;overflow:hidden}.visit-history-card.expanded{box-shadow:var(--shadow-md);border-color:var(--primary)}.visit-history-header{cursor:pointer;justify-content:space-between;align-items:center;padding:12px 16px;display:flex}.visit-history-header:hover{background:var(--gray-50)}.visit-history-left{flex-direction:column;gap:2px;display:flex}.visit-history-left strong{font-size:14px}.visit-history-meta{color:var(--gray-500);font-size:12px}.visit-history-right{align-items:center;gap:8px;display:flex}.expand-arrow{color:var(--gray-500);font-size:10px}.visit-history-body{border-top:1px solid var(--gray-100);padding:0 16px 16px}.visit-detail-section{background:var(--gray-50);border-radius:6px;margin:12px 0;padding:10px}.visit-detail-section strong{margin-bottom:4px;font-size:13px;display:block}.visit-detail-note{color:var(--gray-500);margin-top:6px;font-size:13px;font-style:italic}.photo-type-label{color:#fff;text-transform:uppercase;background:#0009;border-radius:3px;padding:1px 4px;font-size:9px;position:absolute;bottom:2px;left:2px}.photo-lightbox-overlay{z-index:1001;background:#000000eb;flex-direction:column;justify-content:center;align-items:center;padding:20px;display:flex;position:fixed;inset:0}.photo-lightbox-img{object-fit:contain;border-radius:8px;max-width:90vw;max-height:70vh;transition:transform .3s}.photo-lightbox-img.zoomed{cursor:zoom-out;max-width:none;max-height:none;transform:scale(2)}.photo-lightbox-zoom{color:#fff;cursor:pointer;background:#fff3;border:none;border-radius:4px;margin-left:12px;padding:4px 12px;font-size:12px;display:inline-block}.photo-lightbox-close{color:#fff;cursor:pointer;background:#fff3;border:none;border-radius:50%;justify-content:center;align-items:center;width:36px;height:36px;font-size:20px;display:flex;position:absolute;top:16px;right:16px}.photo-lightbox-info{color:#fff;text-align:center;margin-top:12px;font-size:14px}.photo-lightbox-type{text-transform:uppercase;font-weight:700}.photo-lightbox-delete{background:var(--danger);color:#fff;cursor:pointer;border:none;border-radius:6px;margin-top:8px;padding:6px 16px;font-size:13px;display:inline-block}.photo-warning{color:#92400e;text-align:center;background:#fef3c7;border-radius:6px;margin:8px 0;padding:8px 12px;font-size:13px}.photo-thumb-wrap{flex-direction:column;gap:2px;display:flex}.photo-caption-input{border:none;border-bottom:1px solid var(--gray-300);width:100px;color:var(--gray-700);background:0 0;padding:3px 6px;font-size:11px}.photo-caption-input:focus{border-color:var(--primary);outline:none}.photo-caption-display{color:var(--gray-500);text-overflow:ellipsis;white-space:nowrap;max-width:100px;padding:2px 4px;font-size:11px;display:block;overflow:hidden}.tap-select{margin:8px 0}.tap-select label{margin-bottom:4px;font-size:13px}.tap-select-options{flex-wrap:wrap;gap:6px;display:flex}.tap-select-btn{border:2px solid var(--gray-200);cursor:pointer;text-align:center;min-width:60px;color:var(--gray-600);background:#fff;border-radius:8px;flex:1;padding:8px 6px;font-size:12px;font-weight:600;transition:all .15s}.tap-select-btn:hover{border-color:var(--gray-400)}.tap-select-btn.active{border-color:var(--primary);color:var(--primary);background:#eff6ff}.issues-toggle{gap:8px;margin:12px 0;display:flex}.toggle-btn{border:2px solid var(--gray-200);border-radius:var(--radius);cursor:pointer;text-align:center;color:var(--gray-600);background:#fff;flex:1;padding:12px;font-size:14px;font-weight:600;transition:all .15s}.toggle-btn.active{border-color:var(--success);color:#065f46;background:#f0fdf4}.toggle-btn-warn.active{border-color:var(--warning);color:#92400e;background:#fef3c7}.assessment-group{border:1px solid var(--gray-200);border-radius:var(--radius);background:#fff;margin:12px 0;padding:12px}.assessment-group h4{color:var(--gray-700);margin:0 0 8px;font-size:14px}.structured-photo-section{margin:8px 0}.structured-progress{margin-bottom:12px}.structured-progress-bar{background:var(--gray-200);border-radius:3px;height:6px;overflow:hidden}.structured-progress-fill{background:var(--primary);border-radius:inherit;height:100%;transition:width .3s}.structured-progress-text{color:var(--gray-500);margin-top:4px;font-size:12px;display:block}.structured-step{padding:8px 0}.structured-step h3{margin-bottom:4px}.structured-step-desc{color:var(--gray-500);margin-bottom:12px;font-size:13px}.structured-summary-row{border-bottom:1px solid var(--gray-100);cursor:pointer;align-items:center;gap:10px;padding:10px 0;display:flex}.structured-summary-row:hover{background:var(--gray-50)}.structured-summary-status{border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:24px;height:24px;font-size:12px;font-weight:700;display:flex}.structured-summary-status.done{color:#065f46;background:#d1fae5}.structured-summary-status.missing{color:#991b1b;background:#fee2e2}.structured-summary-status.optional{background:var(--gray-100);color:var(--gray-500)}.structured-summary-label{flex:1;font-size:14px;font-weight:500}.structured-summary-count{color:var(--gray-500);font-size:12px}.condition-report-banner{border-radius:var(--radius);cursor:pointer;background:#eff6ff;border:2px solid #93c5fd;justify-content:space-between;align-items:center;margin:12px 0;padding:12px 14px;display:flex}.condition-report-banner-text{flex-direction:column;gap:2px;display:flex}.condition-report-banner-text strong{color:var(--primary);font-size:14px}.condition-report-banner-text span{color:var(--gray-500);font-size:12px}.condition-report-banner-tag{color:var(--primary);background:#dbeafe;border-radius:4px;padding:3px 8px;font-size:11px;font-weight:600}.close-out-section{border-top:2px solid var(--gray-200);padding-top:16px}.closeout-btn{border:2px solid var(--gray-200);border-radius:var(--radius);cursor:pointer;text-align:left;background:#fff;align-items:center;gap:12px;width:100%;margin-bottom:6px;padding:14px 12px;font-size:15px;transition:all .15s;display:flex}.closeout-btn:hover{border-color:var(--gray-400)}.closeout-btn.checked{border-color:var(--success);background:#f0fdf4}.closeout-tick{border:2px solid var(--gray-300);width:24px;height:24px;color:var(--gray-300);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:14px;font-weight:700;display:flex}.closeout-btn.checked .closeout-tick{background:var(--success);border-color:var(--success);color:#fff}.follow-up-fields{margin-bottom:12px;padding-left:30px}.visit-section{background:var(--gray-50);border-radius:var(--radius);border:1px solid var(--gray-200);margin:16px 0;padding:16px}.visit-section h3{margin-bottom:12px;font-size:15px}.rag-selector{gap:8px;margin:8px 0;display:flex}.rag-btn{border-radius:var(--radius);cursor:pointer;text-align:center;border:3px solid #0000;flex:1;padding:12px 8px;font-size:14px;font-weight:700;transition:all .15s}.rag-btn-green{color:#065f46;background:#d1fae5}.rag-btn-green.active{color:#fff;background:#16a34a;border-color:#16a34a}.rag-btn-amber{color:#92400e;background:#fef3c7}.rag-btn-amber.active{color:#fff;background:#f59e0b;border-color:#f59e0b}.rag-btn-red{color:#991b1b;background:#fef2f2}.rag-btn-red.active{color:#fff;background:#dc2626;border-color:#dc2626}.rag-desc{opacity:.8;margin-top:2px;font-size:10px;font-weight:400;display:block}.photo-capture-section{margin:8px 0}.photo-capture-header{justify-content:space-between;align-items:center;margin-bottom:8px;display:flex}.photo-grid{grid-template-columns:repeat(auto-fill,minmax(80px,1fr));gap:8px;display:grid}.photo-thumb{aspect-ratio:1;border-radius:6px;position:relative;overflow:hidden}.photo-thumb img{object-fit:cover;width:100%;height:100%}.photo-remove{color:#fff;cursor:pointer;background:#0009;border:none;border-radius:50%;justify-content:center;align-items:center;width:20px;height:20px;font-size:12px;display:flex;position:absolute;top:2px;right:2px}.material-add-row{align-items:center;gap:6px;margin:4px 0 8px;display:flex}.material-list{flex-direction:column;gap:4px;margin-bottom:12px;display:flex}.material-item{border:1px solid var(--gray-200);background:#fff;border-radius:6px;justify-content:space-between;align-items:center;padding:6px 10px;font-size:13px;display:flex}.joint-notes{margin:8px 0}.pinned-notes{flex-direction:column;gap:8px;display:flex}.pinned-note{border:1px solid var(--gray-200);border-left:4px solid var(--primary);border-radius:var(--radius);background:#fff;padding:10px 14px}.pinned-note-header{justify-content:space-between;align-items:center;margin-bottom:4px;display:flex}.pinned-note-content{margin:0;font-size:14px;line-height:1.4}.note-meta{color:var(--gray-500);font-size:11px}.note-type-badge{color:#fff;border-radius:4px;padding:2px 8px;font-size:11px;font-weight:600;display:inline-block}.note-type-badge-sm{color:#fff;border-radius:50%;justify-content:center;align-items:center;width:22px;height:22px;font-size:12px;display:inline-flex}.note-form{background:var(--gray-50);border:1px solid var(--gray-200);border-radius:var(--radius);margin-bottom:12px;padding:12px}.note-form textarea{width:100%;margin:8px 0}.note-type-selector{flex-wrap:wrap;gap:6px;margin-bottom:8px;display:flex}.note-type-btn{border:2px solid var(--gray-200);cursor:pointer;background:#fff;border-radius:6px;padding:4px 10px;font-size:12px}.note-type-btn.active{border-color:var(--primary);background:#eff6ff}.notes-timeline{flex-direction:column;gap:6px;display:flex}.timeline-note{border-left:3px solid var(--gray-200);padding:8px 12px}.timeline-note.resolved{opacity:.6}.timeline-note-header{align-items:center;gap:8px;font-size:13px;display:flex}.timeline-note-content{color:var(--gray-700);margin:4px 0 0;font-size:13px}@media print{.app-header,.bottom-nav,.filter-bar,.no-print{display:none!important}.app-shell,.admin-page{padding:0!important}.shipping-label{box-shadow:none!important;border:2px solid #000!important}body{background:#fff!important}}
