:root{--bg: #f7f7f7;--panel: #ffffff;--ink: #111111;--muted: #5f6670;--line: #d8dde4;--blue: #0F6CBD;--blue-dark: #0A3D62;--steel: #8A8F98;--silver: #C9C9C9;--green: #16835a;--amber: #b66b00;--red: #b42318;--shadow: 0 18px 50px rgba(10, 61, 98, .1)}*{box-sizing:border-box}body{margin:0;min-height:100vh;color:var(--ink);background:radial-gradient(circle at top left,rgba(15,108,189,.12),transparent 34%),linear-gradient(180deg,rgba(10,61,98,.06),transparent 360px),var(--bg);font-family:Montserrat,Helvetica,Arial,Lucida Grande,sans-serif;font-size:14px;line-height:1.45}button,input,textarea,select{font:inherit}.app-shell{width:min(1680px,calc(100% - 24px));margin:0 auto;padding:22px 0 42px}.login-screen{min-height:calc(100vh - 44px);display:grid;place-items:center}.login-card,.panel,.table-panel,.modal-form,.file-drawer,.stat-card,.topbar,.sidebar{background:#fffffff0;border:1px solid var(--line);border-radius:12px;box-shadow:var(--shadow)}.login-card{width:min(520px,100%);padding:26px}.login-logo{width:100%;height:160px;object-fit:contain}.boot-card{text-align:left}.boot-card h1{font-size:clamp(1.55rem,3vw,2.15rem)}.boot-progress{position:relative;height:8px;margin-top:22px;overflow:hidden;border-radius:999px;background:#dceaf6}.boot-progress span{position:absolute;inset:0 auto 0 0;width:42%;border-radius:inherit;background:var(--blue);animation:boot-progress 1.25s ease-in-out infinite}@keyframes boot-progress{0%{transform:translate(-115%)}50%{transform:translate(85%)}to{transform:translate(255%)}}h1,h2,h3,p{margin-top:0}.login-card h1,.page-heading h1{margin-bottom:10px;font-size:clamp(1.7rem,4vw,2.5rem);letter-spacing:0}.login-card p,.muted{color:var(--muted);line-height:1.5}.form-grid{display:grid;gap:14px}.form-grid>*{min-width:0}.form-grid .form-grid-span{grid-column:1 / -1}.form-grid.two{grid-template-columns:repeat(2,minmax(0,1fr))}.form-grid.four{grid-template-columns:repeat(4,minmax(0,1fr))}.inline-editor-block{display:grid;gap:14px;margin:14px 0;padding:14px;border:1px solid var(--line);border-radius:10px;background:#ffffff9e}.inline-editor-block h3{margin:0;font-size:1rem}.checkbox-group{display:flex;flex-wrap:wrap;gap:10px 16px;margin:0;padding:12px;border:1px solid var(--line);border-radius:10px}.checkbox-group legend{padding:0 6px;color:var(--muted);font-size:.9rem;font-weight:800}.smart-detect-panel{display:grid;gap:8px;margin:8px 0 14px;padding:12px 14px;border:1px dashed var(--line);border-radius:10px;background:#0f6cbd0f}.smart-detect-panel strong{font-size:.94rem}.smart-detect-panel p,.smart-detect-output{margin:0;font-size:.9rem;line-height:1.45}label{display:grid;gap:7px;min-width:0;max-width:100%;color:var(--muted);font-size:.92rem;font-weight:700}.checkbox-line{display:inline-flex;align-items:center;justify-content:flex-start;gap:10px;width:fit-content;min-height:42px;padding:10px 12px;border:1px solid var(--line);border-radius:10px;color:var(--ink);background:#ffffffb8}.checkbox-line input[type=checkbox]{flex:0 0 auto;width:18px;height:18px;margin:0}input,textarea,select{width:100%;min-width:0;max-width:100%;border:1px solid var(--line);border-radius:10px;padding:12px;color:var(--ink);background:#fff}.file-upload-native-input{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.file-upload-ui{display:grid;gap:10px}.file-upload-dropzone{display:grid;gap:4px;width:100%;padding:16px;text-align:left;border:1px dashed rgba(15,108,189,.38);border-radius:12px;background:linear-gradient(180deg,#0f6cbd0f,#0a3d6205);color:var(--ink);cursor:pointer;transition:border-color .18s ease,background .18s ease,transform .18s ease}.file-upload-dropzone:hover,.file-upload-ui.is-drag-active .file-upload-dropzone{border-color:var(--blue);background:linear-gradient(180deg,#0f6cbd1c,#0a3d620d);transform:translateY(-1px)}.file-upload-title{font-size:.98rem;font-weight:800;color:var(--blue-dark)}.file-upload-helper,.file-upload-accept,.file-upload-empty,.file-upload-item-meta{color:var(--muted);font-size:.86rem;font-weight:600}.file-upload-list{display:grid;gap:8px;margin:0;padding:0;list-style:none}.file-upload-item{display:grid;grid-template-columns:46px minmax(0,1fr) auto;align-items:center;gap:8px;padding:10px 12px;border:1px solid var(--line);border-radius:12px;background:#ffffffe6}.file-upload-thumb{display:grid;place-items:center;width:42px;height:42px;overflow:hidden;border:1px solid rgba(15,108,189,.18);border-radius:10px;background:#0f6cbd14;color:var(--blue-dark);font-size:.72rem;font-weight:900}.file-upload-thumb img{width:100%;height:100%;object-fit:cover}.file-upload-item-main,.file-upload-item-actions{display:flex;align-items:center;gap:10px;justify-content:space-between;min-width:0}.file-upload-item-name{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-weight:700;color:var(--ink)}.file-upload-status-chip{display:inline-flex;align-items:center;min-height:28px;padding:4px 10px;border-radius:999px;font-size:.76rem;font-weight:800;letter-spacing:0;border:1px solid transparent}.file-upload-status-chip.ready{background:#0f6cbd14;color:var(--blue-dark);border-color:#0f6cbd2e}.file-upload-status-chip.uploading{background:#b66b001a;color:var(--amber);border-color:#b66b002e}.file-upload-status-chip.complete{background:#16835a1a;color:var(--green);border-color:#16835a2e}.file-upload-remove{flex:0 0 auto;min-width:30px;min-height:30px;padding:0;border:1px solid var(--line);border-radius:999px;background:#fff;color:var(--muted);font-weight:800;cursor:pointer}.file-upload-remove:hover:not(:disabled){color:var(--red);border-color:#b4231847}.file-upload-remove:disabled{opacity:.45;cursor:not-allowed}.file-upload-progress{position:relative;height:8px;overflow:hidden;border-radius:999px;background:#0f6cbd1f}.file-upload-progress span{position:absolute;inset:0 auto 0 0;border-radius:inherit;background:linear-gradient(90deg,var(--blue-dark),var(--blue));transition:width .18s ease}select{text-overflow:ellipsis}.button{display:inline-flex;align-items:center;justify-content:center;min-height:40px;padding:0 14px;border:1px solid var(--line);border-radius:10px;background:#fff;color:var(--ink);font-weight:800;text-decoration:none;cursor:pointer}.button.primary{border-color:var(--blue);background:var(--blue);color:#fff}.button.secondary{background:transparent}.button.danger{border-color:var(--red);background:var(--red);color:#fff}.button.small{min-height:32px;padding:0 10px;font-size:.86rem}.button.full{width:100%;margin-top:10px}.topbar{display:flex;justify-content:flex-start;gap:28px;align-items:center;min-height:86px;margin-bottom:18px;padding:14px 22px;overflow:visible}.brand{flex:0 0 auto;display:flex;align-items:center}.brand img{width:196px;height:62px;object-fit:contain}.top-nav{position:relative;z-index:20;display:flex;flex:1 1 auto;align-items:stretch;gap:4px;min-width:0}.top-nav-group{position:relative}.top-nav-trigger{display:inline-flex;align-items:center;gap:7px;min-height:54px;padding:0 20px 0 0;border:0;border-radius:0;background:transparent;color:#424242;font-size:14px;font-weight:600;cursor:pointer;white-space:nowrap}.top-nav-trigger.active,.top-nav-trigger:hover,.top-nav-group:focus-within .top-nav-trigger,.top-nav-group:hover .top-nav-trigger{color:var(--blue)}.top-nav-trigger.active:after,.top-nav-group:focus-within .top-nav-trigger:after,.top-nav-group:hover .top-nav-trigger:after{position:absolute;right:20px;bottom:0;left:0;height:3px;background:var(--blue);content:""}.top-nav-icon{font-size:.95rem;line-height:1}.top-nav-menu{position:absolute;top:100%;left:0;z-index:30;display:none;width:max-content;min-width:230px;max-width:min(320px,calc(100vw - 32px));padding:14px;border:1px solid var(--line);border-top:3px solid var(--blue-dark);background:#fffffffa;box-shadow:var(--shadow)}.top-nav-group:focus-within .top-nav-menu,.top-nav-group:hover .top-nav-menu{display:grid;gap:4px}.top-nav-item{display:flex;align-items:center;width:100%;min-height:42px;padding:0 12px;border:0;border-radius:8px;background:transparent;color:#424242;font-size:14px;font-weight:600;text-align:left;cursor:pointer}.top-nav-item.active,.top-nav-item:hover{background:#e8f2fb;color:var(--blue)}.mobile-nav-account-actions{display:none}.topbar-actions{display:flex;align-items:center;margin-left:auto}.mobile-nav-trigger{display:none}.hamburger-button{display:inline-grid}.mobile-nav-trigger,.hamburger-button{width:48px;height:44px;border:0;border-radius:10px;background:transparent;cursor:pointer;padding:0;place-items:center}.mobile-nav-trigger span,.hamburger-button span{display:none}.mobile-nav-trigger:before,.hamburger-button:before{display:block;width:24px;height:18px;background:linear-gradient(var(--ink),var(--ink)) 0 1px / 24px 2px no-repeat,linear-gradient(var(--ink),var(--ink)) 0 8px / 24px 2px no-repeat,linear-gradient(var(--ink),var(--ink)) 0 15px / 24px 2px no-repeat;content:""}.account-menu{position:relative}.account-menu-trigger{display:inline-grid}.account-menu-panel{position:absolute;top:calc(100% + 10px);right:0;z-index:25;display:none;min-width:200px;padding:8px;border:1px solid var(--line);border-radius:12px;background:#fffffffa;box-shadow:var(--shadow)}.account-menu.open .account-menu-panel{display:grid;gap:6px}.account-menu-item{display:flex;align-items:center;width:100%;min-height:40px;padding:0 12px;border:0;border-radius:10px;background:transparent;color:var(--ink);cursor:pointer;font-weight:800;text-align:left}.account-menu-item:hover{background:#0f6cbd14}.button-row{display:flex;flex-wrap:wrap;gap:10px}.layout{display:block}.sidebar{align-self:start;display:grid;gap:10px;padding:12px}.nav-section{border:1px solid var(--line);border-radius:10px;background:#fff;overflow:hidden}.nav-section-toggle{display:flex;justify-content:space-between;align-items:center;width:100%;min-height:44px;padding:0 14px;border:0;background:transparent;color:var(--ink);text-align:left;font-weight:900;cursor:pointer}.nav-section-toggle.active,.nav-section-toggle:hover{background:#fdecec;color:var(--blue-dark)}.nav-section-icon{min-width:16px;text-align:center;font-size:1rem;font-weight:900}.nav-section-items{display:none;padding:6px;border-top:1px solid var(--line)}.nav-section.open .nav-section-items{display:grid;gap:6px}.nav-item{min-height:42px;border:0;border-radius:8px;background:transparent;color:var(--ink);text-align:left;font-weight:800;cursor:pointer;padding:0 12px}.nav-item.active,.nav-item:hover{background:#fdecec;color:var(--blue-dark)}.content{min-width:0}@media (min-width: 1500px){.app-shell{width:min(1800px,calc(100% - 20px))}.layout{display:block}.stat-grid{grid-template-columns:repeat(4,minmax(220px,1fr))}.defect-layout.wide{grid-template-columns:minmax(860px,1.6fr) minmax(520px,1fr)}}.page-heading{display:flex;justify-content:space-between;gap:16px;align-items:center;margin-bottom:16px}.eyebrow{margin-bottom:8px;color:var(--blue-dark);font-size:.76rem;font-weight:800;text-transform:uppercase}.compact-select{min-width:220px}.stat-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:14px;margin-bottom:16px}.stat-grid.compact{grid-template-columns:repeat(4,minmax(130px,1fr));margin-top:14px}.timesheet-week-details{margin-top:14px}.timesheet-week-details>summary{display:inline-flex;align-items:center;gap:8px;padding:8px 0;cursor:pointer;font-weight:800;list-style:none}.timesheet-week-details>summary::-webkit-details-marker{display:none}.expand-icon{display:inline-grid;width:24px;height:24px;place-items:center;border:1px solid var(--line);border-radius:999px;background:#fff;color:var(--red);font-size:1.1rem;line-height:1;transition:transform .15s ease}.timesheet-week-details[open] .expand-icon{transform:rotate(45deg)}.home-layout{display:grid;gap:18px}.home-hero{display:grid;grid-template-columns:minmax(0,1.15fr) minmax(0,1fr);gap:18px;align-items:stretch}.home-hero-copy{display:grid;align-content:start;gap:12px}.home-hero-copy h2{margin:0;font-size:clamp(1.5rem,3vw,2.2rem);letter-spacing:0}.home-hero-summary{align-self:stretch;margin:0;grid-template-columns:repeat(3,minmax(0,1fr))}.home-next-step{display:flex;justify-content:space-between;gap:16px;align-items:center}.home-next-step h2{margin:0 0 8px;font-size:1.35rem;letter-spacing:0}.home-next-step .action-row{flex-wrap:wrap;justify-content:flex-end}.home-grid{display:grid;grid-template-columns:minmax(0,1.2fr) minmax(340px,.8fr);gap:18px;align-items:start}.home-task-list{display:grid;gap:12px}.home-task-item{display:grid;gap:10px;padding:14px;border:1px solid var(--line);border-radius:10px;background:#fff}.home-task-topline{display:flex;justify-content:space-between;gap:12px;align-items:start}.home-task-topline strong{display:block;margin-bottom:4px;font-size:1rem}.home-task-topline p{margin:0}.home-task-meta{display:flex;flex-wrap:wrap;gap:8px}.shortcut-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}.shortcut-card{display:grid;gap:8px;align-content:start;min-height:118px;padding:16px;border:1px solid var(--line);border-radius:12px;background:linear-gradient(180deg,#0f6cbd0d,#fff);color:var(--ink);text-align:left;cursor:pointer;box-shadow:none}.shortcut-card strong{font-size:1.02rem}.shortcut-card span{color:var(--muted);line-height:1.45}.shortcut-card.primary{border-color:var(--blue);background:linear-gradient(180deg,#0f6cbd24,#0f6cbd0d)}.shortcut-card:hover,.shortcut-card:focus-visible{border-color:var(--blue);transform:translateY(-1px);outline:none}.home-hero-summary .stat-card{min-height:100%}.kpi-section{margin-bottom:18px}.kpi-section h2{margin:0 0 12px;font-size:1.2rem}.check-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}.check-list{margin:0;padding-left:18px}.check-list li+li{margin-top:8px}.csv-column-checklist{display:grid;gap:6px;margin:8px 0}.csv-column-check-item{display:grid;grid-template-columns:minmax(220px,max-content) 110px;align-items:center;gap:10px}.csv-column-check-item .pill{justify-self:start}.audit-action-row{padding:12px 0;border-top:1px solid var(--line)}.audit-action-row:first-child{padding-top:0;border-top:0}.compliance-meter{display:grid;gap:12px;margin-bottom:16px;padding:18px;border:1px solid var(--line);border-radius:8px;background:#fffffff0;box-shadow:var(--shadow)}.compliance-meter div:first-child{display:flex;justify-content:space-between;gap:16px;align-items:end}.compliance-meter span{color:var(--muted);font-weight:800}.compliance-meter strong{font-size:2rem;color:var(--blue-dark)}.meter-track{overflow:hidden;height:12px;border-radius:999px;background:#e6edf4}.meter-fill{height:100%;border-radius:inherit;background:linear-gradient(90deg,var(--blue),var(--green))}.stat-card{padding:18px}.stat-card.interactive-card,.compliance-meter.interactive-card{cursor:pointer;transition:transform .15s ease,border-color .15s ease,box-shadow .15s ease}.stat-card.interactive-card:hover,.stat-card.interactive-card:focus-visible,.compliance-meter.interactive-card:hover,.compliance-meter.interactive-card:focus-visible{border-color:var(--red);box-shadow:var(--shadow-strong);outline:none;transform:translateY(-1px)}.stat-card span{display:block;color:var(--muted);font-weight:700}.stat-card strong{display:block;margin-top:8px;font-size:2.1rem}.stat-card.amber-card strong{color:var(--amber)}.stat-card.blue-card strong{color:var(--blue-dark)}.stat-card.red-card strong{color:var(--red)}.panel,.table-panel,.modal-form,.file-drawer{padding:18px}.table-panel{overflow-x:auto}.panel-title-row{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:12px}.panel-title-row h2{margin:0;font-size:1.15rem}.nested-panel{margin:14px 0;border-color:#0f6cbd38;background:#ffffffdb}.record-card-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;margin-top:14px}.record-card-grid article{min-width:0;padding:14px;border:1px solid var(--line);border-radius:10px;background:#fff}.record-card-grid h4{margin:0 0 10px;font-size:1rem}table{width:100%;border-collapse:collapse}th,td{border-bottom:1px solid var(--line);padding:13px 10px;text-align:left;vertical-align:top}th{color:var(--muted);font-size:.8rem;text-transform:uppercase}.empty{color:var(--muted);text-align:center}.pill,.date-cell{display:inline-flex;align-items:center;min-height:26px;padding:0 9px;border-radius:999px;font-size:.78rem;font-weight:800;white-space:nowrap}.green{background:#e2f4ed;color:var(--green)}.amber{background:#fff1d6;color:var(--amber)}.red{background:#fde7e4;color:var(--red)}.blue{background:#e1f0fb;color:var(--blue-dark)}.grey{background:#edf2f7;color:var(--muted)}.detail-grid{display:grid;grid-template-columns:repeat(5,minmax(0,1fr));gap:10px;margin-bottom:14px}.detail-card,.notes-panel{border:1px solid var(--line);border-radius:8px;background:#fff;padding:12px}.detail-card span{display:block;color:var(--muted);font-size:.82rem;font-weight:800}.detail-card strong{overflow-wrap:anywhere}.notes-panel{margin:12px 0}.notes-panel pre{white-space:pre-wrap;overflow-wrap:anywhere;font:inherit;margin:0}.notice{margin-bottom:14px;padding:12px 14px;border:1px solid var(--line);border-radius:8px;background:#fff;color:var(--blue-dark);font-weight:700}.notice.alert-red{border-color:#ef9a9a;color:#8a1f1f;background:#fff6f6}.toast-stack{position:fixed;right:20px;bottom:20px;z-index:1200;display:grid;gap:10px;width:min(360px,calc(100vw - 24px));pointer-events:none}.toast{padding:14px 16px;border:1px solid var(--line);border-radius:12px;background:#fffffffa;box-shadow:var(--shadow);pointer-events:auto}.toast-title{margin-bottom:4px;font-size:.82rem;font-weight:900;text-transform:uppercase;letter-spacing:.04em}.toast-message{color:var(--ink);font-weight:700;line-height:1.45}.toast-success{border-left:4px solid var(--green)}.toast-success .toast-title{color:var(--green)}.toast-error{border-left:4px solid var(--red)}.toast-error .toast-title{color:var(--red)}.list-usage-panel{display:grid;gap:4px}.list-usage-panel span{color:var(--muted);font-weight:700;line-height:1.45}.action-row,.form-actions{display:flex;flex-wrap:wrap;gap:8px;align-items:center}.inline-filter{display:flex;flex-direction:column;gap:2px;font-size:12px;color:var(--muted)}.inline-filter select{min-width:140px}.asset-search-results{display:flex;flex-wrap:wrap;gap:6px;margin-top:8px}.search-select-field{position:relative}.search-select-clear{position:absolute;right:8px;top:30px;min-height:28px;padding:0 10px}.search-select-results{display:none;position:absolute;z-index:40;top:calc(100% + 4px);left:0;right:0;max-height:260px;overflow-y:auto;border:1px solid var(--line);border-radius:10px;background:#fff;box-shadow:0 18px 38px #11111124}.search-select-results.open{display:grid}.search-select-option{display:grid;gap:3px;width:100%;padding:11px 12px;border:0;border-bottom:1px solid var(--line);background:#fff;color:var(--ink);font:inherit;text-align:left;cursor:pointer}.search-select-option:hover,.search-select-option:focus{background:#0f6cbd14;outline:none}.search-select-option span,.search-select-empty{color:var(--muted);font-size:.86rem;font-weight:600}.search-select-empty{padding:12px}.dropdown-list-key-results{display:grid;gap:6px;margin-top:8px;padding:10px;border:1px solid var(--line);border-radius:10px;background:#fff}.dropdown-list-key-option{justify-content:flex-start;width:100%}.dropdown-list-option-field{display:grid;gap:4px;padding:6px 10px 8px;border:1px solid var(--line);border-radius:10px;background:#fff}.dropdown-list-option-field input{min-height:34px;padding:8px 10px}.help-text{color:var(--muted);font-size:.84rem;font-weight:600;line-height:1.35}.planner-entry-btn{border:none;background:transparent;color:inherit;font:inherit;font-weight:700;cursor:pointer;padding:0}.form-actions{justify-content:space-between;margin-top:14px}.form-actions.compact{justify-content:flex-start;margin-top:0}.button.disabled,.button[aria-disabled=true]{pointer-events:none;opacity:.6}.modal-form,.file-drawer{margin-top:16px}.form-header{display:flex;justify-content:space-between;gap:12px;align-items:center;margin-bottom:16px}.form-header h2{margin:0}.task-create-drawer.collapsed .task-create-body{display:none}.task-create-drawer .form-header{align-items:center}.button-row .pill{align-self:center}@media (max-width: 1100px){.topbar{flex-wrap:wrap;gap:12px 16px;align-items:center}.brand img{width:168px;height:54px}.mobile-nav-trigger{display:inline-grid;margin-left:auto}.topbar-actions{display:none}.top-nav{order:3;flex-basis:100%;display:none;grid-template-columns:1fr;gap:0;margin-top:10px;padding:16px;border-top:1px solid var(--line);background:#fffffffa}.topbar.mobile-nav-open .top-nav{display:grid}.top-nav-group{border-bottom:1px solid var(--line)}.top-nav-menu{position:static;width:auto;max-width:none;min-width:0;padding:0 0 8px 22px;border:0;border-left:2px solid var(--blue);background:transparent;box-shadow:none}.top-nav-group:hover .top-nav-menu,.top-nav-group:focus-within .top-nav-menu{display:none}.top-nav-group.open .top-nav-menu{display:grid}.top-nav-trigger{justify-content:space-between;width:100%;min-height:48px;padding:0}.top-nav-trigger.active:after,.top-nav-group:focus-within .top-nav-trigger:after,.top-nav-group:hover .top-nav-trigger:after{display:none}.top-nav-item{min-height:40px;padding:0 12px}.mobile-nav-account-actions{display:grid;gap:4px;margin-top:14px;padding-top:14px;border-top:1px solid var(--line)}.mobile-nav-account-actions .top-nav-item{font-weight:900}.home-hero,.home-grid,.shortcut-grid{grid-template-columns:1fr}}@media (max-width: 700px){.home-hero-summary,.stat-grid{grid-template-columns:1fr}}.schedule-list{display:grid;gap:12px}.upcoming-panel{display:grid;gap:12px;margin-top:16px}.upcoming-panel h2,.alerts-panel h2{margin-bottom:0}.alerts-panel{display:grid;gap:12px;margin-bottom:16px}.report-accordion{display:grid;gap:10px}.report-item{border:1px solid var(--line);border-radius:10px;background:#fff;overflow:hidden}.report-item>summary{list-style:none;cursor:pointer;padding:12px 14px;display:grid;gap:4px}.report-item>summary::-webkit-details-marker{display:none}.report-item[open]>summary{background:#f3f8fd;border-bottom:1px solid var(--line)}.report-item>form{padding:12px 14px}.upcoming-row,.alert-row{display:flex;justify-content:space-between;gap:16px;align-items:center;padding:14px;border:1px solid var(--line);border-left:5px solid var(--blue);border-radius:8px;background:#fff}.upcoming-row.red,.alert-row.red{border-left-color:var(--red)}.upcoming-row.amber,.alert-row.amber{border-left-color:var(--amber)}.upcoming-row strong,.upcoming-row p,.alert-row strong,.alert-row p{display:block;margin-top:8px}.upcoming-row p,.alert-row p{margin-bottom:0;color:var(--muted);font-weight:700}.upcoming-meta{display:flex;flex-wrap:wrap;justify-content:flex-end;gap:10px;align-items:center;min-width:220px}.upcoming-meta span{font-weight:800}.summary-row{display:flex;justify-content:space-between;align-items:center;gap:14px;padding:12px 0;border-bottom:1px solid var(--line)}.summary-row:last-child{border-bottom:0}.summary-row>div:first-child{min-width:0;flex:1 1 auto}.summary-row>div:first-child strong,.summary-row>div:first-child p{overflow-wrap:anywhere}.onboarding-step-actions{display:flex;align-items:center;justify-content:flex-end;gap:8px;flex:0 0 auto;white-space:nowrap}.planner-panel{margin-bottom:16px;padding:18px;border:1px solid rgba(15,108,189,.18);border-radius:12px;background:linear-gradient(180deg,#0f6cbd0d,#fffffffa 120px),#fff;box-shadow:0 10px 28px #11111114}.planner-head{display:flex;justify-content:space-between;gap:14px;align-items:center;margin-bottom:14px}.planner-head h2{margin-bottom:5px}.planner-head p{margin-bottom:0;color:var(--muted)}.muted-pill{background:#0f6cbd14;color:var(--blue-dark)}.planner-controls{display:flex;flex-wrap:wrap;justify-content:flex-end;gap:8px}.planner-scroll{overflow-x:auto;border:1px solid rgba(15,108,189,.12);border-radius:10px;background:#fff}.planner-table{min-width:1120px;border-collapse:separate;border-spacing:0;table-layout:fixed;background:#fff}.planner-table th,.planner-table td{border-right:1px solid #d5e2f0;border-bottom:1px solid #d5e2f0;padding:0;text-align:center;vertical-align:middle}.planner-table tr>*:first-child{border-left:1px solid #d5e2f0}.planner-table thead tr:first-child>*{border-top:1px solid #d5e2f0}.planner-table th{height:86px;background:#f9f4f4;color:#111;font-size:.8rem;text-transform:none}.planner-table .sticky-col{position:sticky;left:0;z-index:3;width:92px;min-width:92px;background:#fff;text-align:left;padding:0 8px;font-weight:800;color:#111}.planner-table .sticky-col.second{left:92px;width:110px;min-width:110px;font-weight:700}.week-heading{width:36px;min-width:36px;position:relative}.week-heading span{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%) rotate(-90deg);transform-origin:center;white-space:nowrap}.planner-cell{width:36px;height:28px;font-size:.76rem;font-weight:800;color:#111;background:#fff;transition:background .15s ease}.planner-cell span{display:block;line-height:1.05}.planner-cell.completed-mot{background:#0a3d6229;color:var(--blue-dark)}.planner-cell.completed-service{background:#0f6cbd1a;color:var(--blue-dark)}.planner-cell.completed-tacho{background:#11111114;color:#111}.planner-legend{display:flex;flex-wrap:wrap;gap:16px;margin-top:12px;color:var(--muted);font-weight:800}.legend-box{display:inline-block;width:16px;height:16px;margin-right:6px;border:1px solid rgba(17,17,17,.16);border-radius:4px;vertical-align:-3px}.legend-box.mot{background:#0a3d6229}.legend-box.service{background:#0f6cbd1a}.legend-box.tacho{background:#11111114}.schedule-row{display:flex;justify-content:space-between;gap:16px;align-items:center;padding:14px;border:1px solid var(--line);border-radius:8px}.schedule-row strong{margin-right:8px}.attention-reason{margin:8px 0 0;color:var(--red);font-size:.9rem;font-weight:800}.schedule-row dl{display:flex;flex-wrap:wrap;gap:12px;margin:0}.schedule-row div{min-width:90px}dt{color:var(--muted);font-size:.78rem;font-weight:800}dd{margin:3px 0 0;font-weight:800}.file-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:10px}.file-field{min-width:0;padding:12px;border:1px solid var(--line);border-radius:8px}.file-field span{display:block;color:var(--muted);font-size:.72rem;font-weight:800;line-height:1.25}.file-field strong{display:block;margin-top:5px;overflow-wrap:anywhere;line-height:1.25;word-break:break-word}.file-sections{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px;margin-top:14px}.file-sections article{min-height:130px;padding:14px;border:1px solid var(--line);border-radius:8px}.file-sections .wide-file-section{grid-column:1 / -1;min-height:0}.file-sections .two-column-file-section{grid-column:span 2}.wide-file-section .compact-form .form-grid.two{grid-template-columns:repeat(4,minmax(0,1fr))}.compact-form{display:grid;gap:12px}.checkbox-grid{display:grid;gap:8px;margin-top:10px}.checkbox-grid>span{color:var(--muted);font-size:.92rem;font-weight:800}.check-row{display:flex;gap:8px;align-items:center;color:var(--ink);font-weight:700}.check-row input{width:auto}.accident-vehicle-fields[hidden]{display:none}.inline-checkbox{display:flex;align-items:flex-start;gap:12px;padding:12px 14px;border:1px solid var(--line);border-radius:8px;background:#f8fbff;font-weight:700;line-height:1.4}.inline-checkbox input[type=checkbox]{width:20px;height:20px;margin-top:1px;flex:0 0 auto}.consent-checkbox{font-size:1rem}.checkbox-row{display:inline-flex;align-items:center;gap:10px;color:var(--muted);font-size:.92rem;font-weight:700}.checkbox-row input[type=checkbox]{width:18px;height:18px;margin:0;flex:0 0 auto}.checklist-builder{display:grid;gap:10px;margin:8px 0 12px}.checklist-builder-row{display:grid;grid-template-columns:minmax(220px,2fr) minmax(160px,1fr) minmax(160px,1fr) auto;gap:10px;align-items:end;padding:12px;border:1px solid var(--line);border-radius:8px;background:#fff}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.history-item{display:grid;gap:5px;padding:10px 0;border-bottom:1px solid var(--line)}.history-item:last-child{border-bottom:0}.history-item span{color:var(--muted);font-size:.9rem}.brief-requirements{display:grid;gap:8px;margin-top:8px}.brief-shift-alerts{display:grid;gap:7px;margin-top:10px;padding:10px 12px;border:1px solid rgba(194,65,12,.22);border-left:4px solid var(--amber);border-radius:8px;background:#fff7edc7}.brief-shift-alerts.ok{border-color:#0f6cbd33;border-left-color:var(--blue);background:#0f6cbd0d}.brief-shift-alerts strong{color:var(--ink)}.brief-shift-alerts span{color:var(--ink);font-size:.92rem}.brief-shift-alerts .pill{margin-right:6px}.brief-requirements-section{display:grid;gap:5px;padding:10px 12px;border:1px solid rgba(15,108,189,.18);border-left:4px solid var(--red);border-radius:8px;background:#0f6cbd0a}.brief-requirements-section strong{color:var(--ink)}.brief-requirements-section span{color:var(--ink);font-size:.92rem}.bullet-list{margin:8px 0 0;padding-left:20px;display:grid;gap:8px}.training-document{margin:14px 0;padding:16px;border:1px solid var(--line);border-radius:8px;background:#f8fbff}.training-document h3{margin:0 0 8px}.training-document p{margin:6px 0;color:var(--ink)}.signature-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;margin:14px 0}.signature-pad,.signature-display{display:grid;gap:8px;padding:12px;border:1px solid var(--line);border-radius:8px;background:#fff}.signature-pad-header{display:flex;align-items:center;justify-content:space-between;gap:10px;color:var(--muted);font-size:.9rem;font-weight:800}.signature-pad canvas{width:100%;height:180px;border:1px dashed #9eb8cf;border-radius:8px;background:#f8fbff;cursor:crosshair;touch-action:none}.signature-display span{color:var(--muted);font-size:.9rem;font-weight:800}.signature-display img{width:100%;max-height:180px;object-fit:contain;border:1px solid var(--line);border-radius:8px;background:#fff}.training-matrix-wrap{overflow-x:auto}.training-matrix{min-width:760px;border-collapse:collapse}.training-matrix th,.training-matrix td{min-width:96px;padding:9px;border-bottom:1px solid var(--line);text-align:center;vertical-align:middle}.training-matrix th:first-child,.training-matrix td:first-child{position:sticky;left:0;z-index:1;min-width:190px;background:#fff;text-align:left}.training-matrix td:first-child{display:grid;gap:3px}.training-matrix td:first-child span{color:var(--muted);font-size:.82rem;font-weight:700}.link-button{width:fit-content;border:0;background:transparent;color:var(--blue-dark);font:inherit;font-weight:900;cursor:pointer;padding:0;text-align:left}.matrix-status{display:inline-flex;align-items:center;justify-content:center;min-width:72px;min-height:30px;padding:0 9px;border:1px solid transparent;border-radius:999px;font-size:.78rem;font-weight:900;cursor:pointer}.matrix-status.green{background:#dcfce7;color:#166534}.matrix-status.amber{background:#fef3c7;color:#b45309}.matrix-status.red{background:#fee2e2;color:#b91c1c}.matrix-status.muted{background:#eef4f8;color:var(--muted);cursor:default}.defect-layout{display:grid;grid-template-columns:320px minmax(0,1fr);gap:16px}.defect-layout.wide{grid-template-columns:minmax(620px,1.45fr) minmax(420px,.9fr);overflow-x:auto}.licence-checks-layout{align-items:start}.licence-checks-table table{table-layout:fixed}.licence-checks-table th,.licence-checks-table td{vertical-align:top}.licence-checks-table th:nth-child(1),.licence-checks-table td:nth-child(1){width:16%}.licence-checks-table th:nth-child(2),.licence-checks-table td:nth-child(2){width:20%}.licence-checks-table th:nth-child(3),.licence-checks-table td:nth-child(3){width:17%}.licence-checks-table th:nth-child(4),.licence-checks-table td:nth-child(4){width:12%}.licence-checks-table th:nth-child(5),.licence-checks-table td:nth-child(5){width:15%}.licence-checks-table th:nth-child(6),.licence-checks-table td:nth-child(6){width:8%;text-align:center}.licence-checks-table th:nth-child(7),.licence-checks-table td:nth-child(7){width:12%;text-align:right}.licence-checks-table td strong,.licence-checks-table td span{overflow-wrap:anywhere}.licence-checks-detail-panel{min-width:0}.licence-check-detail-grid{grid-template-columns:repeat(3,minmax(0,1fr))}.licence-check-detail-grid .detail-card{min-height:104px}.licence-check-detail-grid .detail-card strong{display:block;margin-top:6px;font-size:1.02rem;line-height:1.35}.filter-bar{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:12px;margin-bottom:16px;padding:14px;border:1px solid var(--line);border-radius:8px;background:#fffffff0;box-shadow:var(--shadow)}.pdf-viewer{width:100%;min-height:620px;border:1px solid var(--line);border-radius:8px;background:#fff}.clickable-row{cursor:pointer}.clickable-row:hover,.clickable-row.selected{background:#f1f8fd}.defect-list{display:grid;align-content:start;gap:10px}.defect-list-item{display:grid;gap:7px;width:100%;border:1px solid var(--line);border-radius:8px;background:#fff;color:var(--ink);padding:12px;text-align:left;cursor:pointer}.defect-list-item.active,.defect-list-item:hover{border-color:var(--blue);background:#f1f8fd}.defect-list-item span:not(.pill){color:var(--muted);font-size:.9rem}.defect-detail{display:grid;gap:16px;min-width:0}.defect-detail h2,.defect-detail p{overflow-wrap:anywhere}.description-box{padding:14px;border:1px solid var(--line);border-radius:8px;background:#fff}.description-box h3{margin-bottom:8px}.description-box p{margin-bottom:0;line-height:1.55}.defect-action-form{display:grid;gap:14px;padding-top:14px;border-top:1px solid var(--line)}.evidence-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}.evidence-card{display:grid;gap:6px;min-height:82px;border:1px solid var(--line);border-radius:8px;background:#fff;color:var(--ink);padding:12px;text-align:left;cursor:pointer}.evidence-card:hover{border-color:var(--blue);background:#f1f8fd}.evidence-card span{overflow-wrap:anywhere;color:var(--muted);font-size:.86rem}.batch-review-layout{display:grid;gap:16px;margin:16px 0}.document-preview-panel{min-height:420px}.document-preview-frame{width:100%;min-height:620px;border:1px solid var(--line);border-radius:10px;background:#fff}.document-preview-image{display:block;width:100%;max-height:720px;object-fit:contain;border:1px solid var(--line);border-radius:10px;background:#fff}.ai-step-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:12px;margin:16px 0}.ai-step-card{display:grid;grid-template-columns:minmax(0,1fr) auto;align-items:center;gap:8px 12px;border:1px solid var(--line);border-radius:10px;background:#fff;padding:14px}.ai-step-card.active{border-color:var(--blue);box-shadow:0 0 0 2px #0f66b224}.ai-step-card.complete{border-color:#bfe8d8;background:#f2fbf7}.ai-step-card strong{font-size:1.05rem;min-width:0}.ai-step-card .pill{justify-self:end}.ai-step-card em{grid-column:1 / -1;color:#b45309;font-style:normal;font-size:.86rem}.ai-step-card img{width:100%;max-height:120px;object-fit:cover;border-radius:8px;border:1px solid var(--line)}.ai-ready-panel{display:grid;gap:12px;justify-items:center;padding:28px;text-align:center}.ai-camera-frame{position:relative;width:min(100%,760px);aspect-ratio:4 / 3;margin:0 auto;overflow:hidden;border-radius:14px;background:#111}.ai-camera-frame video{display:block;width:100%;height:100%;object-fit:cover}.truck-outline-overlay{position:absolute;inset:9% 8%;pointer-events:none;border:3px solid rgba(34,197,94,.9);border-radius:22px 36px 18px 18px;box-shadow:0 0 0 999px #0000002e}.truck-outline-overlay.front{inset:10% 25%;border-radius:22px 22px 12px 12px}.truck-outline-overlay.passenger_side{transform:scaleX(-1)}.truck-outline-overlay:before,.truck-outline-overlay:after{content:"";position:absolute;bottom:-18px;width:44px;height:44px;border:3px solid rgba(34,197,94,.9);border-radius:50%;background:#1113}.truck-outline-overlay:before{left:16%}.truck-outline-overlay:after{right:16%}.truck-outline-overlay.front:before{left:18%}.truck-outline-overlay.front:after{right:18%}.truck-outline.cab{position:absolute;right:4%;top:12%;width:26%;height:42%;border:3px solid rgba(34,197,94,.9);border-radius:12px 26px 10px 10px}.truck-outline-overlay.front .truck-outline.cab{left:18%;right:auto;top:11%;width:64%;height:38%;border-radius:18px 18px 10px 10px}.truck-outline.body{position:absolute;left:4%;top:18%;width:61%;height:48%;border:3px solid rgba(34,197,94,.9);border-radius:14px}.truck-outline-overlay.front .truck-outline.body{left:9%;top:50%;width:82%;height:21%;border-radius:10px}.truck-outline.wheel{display:none}.ai-camera-guidance{display:grid;gap:10px;justify-items:center;margin-top:14px;text-align:center}@media (max-width: 860px){.layout{display:block}.sidebar,.stat-grid,.detail-grid,.check-grid,.form-grid.two,.form-grid.four,.checklist-builder-row,.file-grid,.file-sections{grid-template-columns:1fr}.page-heading,.schedule-row{align-items:stretch;flex-direction:column}.defect-layout,.filter-bar,.evidence-grid{grid-template-columns:1fr}.home-next-step{flex-direction:column;align-items:flex-start}.home-next-step .action-row{justify-content:flex-start}.signature-grid{grid-template-columns:1fr}.summary-row{flex-direction:column;align-items:flex-start}.onboarding-step-actions{justify-content:flex-start;white-space:normal}.document-preview-frame{min-height:420px}}@media (max-width: 560px){.app-shell{width:100%;padding-right:8px;padding-left:8px;overflow-x:hidden}.content,.panel,.table-panel,.modal-form,.file-drawer,.notice,.smart-detect-panel,.signature-pad,.ai-walkaround-card{min-width:0;max-width:100%}.panel,.table-panel,.modal-form,.file-drawer{padding:14px}.form-grid,.form-grid.two,.form-grid.four,.check-grid,.detail-grid{grid-template-columns:minmax(0,1fr)}.compact-form,.compact-form *,.walkaround-check-table,.walkaround-check-table *{max-width:100%}.action-row,.panel-title-row{flex-wrap:wrap}.file-upload-item{grid-template-columns:40px minmax(0,1fr)}.file-upload-item-actions{grid-column:1 / -1;justify-content:flex-start}.file-upload-thumb{width:38px;height:38px}}
