:root{--ink: #17212b;--muted: #5d6877;--app-bg: #f4f6f7;--card-bg: #ffffff;--border: #dfe7ec;--border-strong: #cbd8dd;--forest: #0f4f46;--teal: #13766e;--teal-soft: #e5f3f0;--warm: #b7791f;--warm-soft: #fff4d8;--danger: #9a2d2d;--shadow: 0 10px 28px rgba(23, 33, 43, .07);--shadow-soft: 0 4px 14px rgba(23, 33, 43, .06);color:var(--ink);background:var(--app-bg);font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;line-height:1.45}*{box-sizing:border-box}html,body,#root{width:100%;min-width:0;max-width:100%;min-height:100%;background:var(--app-bg)}body{margin:0;min-height:100%;overflow-x:clip;background:radial-gradient(circle at top left,rgba(19,118,110,.08),transparent 320px),var(--app-bg)}.appShell{width:100%;min-width:0;max-width:100%;min-height:100vh;min-height:100svh;overflow-x:clip;background:radial-gradient(circle at top left,rgba(19,118,110,.08),transparent 320px),var(--app-bg)}a{color:inherit;text-decoration:none}button,.button{border:0;background:var(--teal);color:#fff;min-height:42px;border-radius:8px;padding:0 16px;font-weight:700;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;max-width:100%;text-align:center;white-space:normal;box-shadow:0 2px #0000000f;transition:background .14s ease,border-color .14s ease,box-shadow .14s ease,transform .14s ease}button:hover:not(:disabled),.button:hover{background:var(--forest);transform:translateY(-1px)}button:focus-visible,.button:focus-visible,a:focus-visible,input:focus-visible,select:focus-visible,textarea:focus-visible{outline:3px solid rgba(19,118,110,.22);outline-offset:2px}button:disabled{background:#98a3ad;cursor:not-allowed;transform:none;box-shadow:none}.disabledAction{background:#98a3ad}.disabledAction[aria-disabled=true]{cursor:not-allowed}.secondary{background:#f5f8f8;color:#263445;border:1px solid var(--border-strong);box-shadow:none}.secondary:hover:not(:disabled),.button.secondary:hover{background:#eaf2f1;color:var(--forest)}.danger{color:var(--danger)}.compact{min-height:34px;padding:0 12px;font-size:.85rem}input,select,textarea{width:100%;border:1px solid var(--border-strong);border-radius:8px;min-height:42px;padding:9px 10px;background:var(--card-bg);font:inherit;transition:border-color .14s ease,box-shadow .14s ease}input:focus,select:focus,textarea:focus{border-color:var(--teal);box-shadow:0 0 0 3px #13766e1f}textarea{min-height:84px;resize:vertical}label{display:grid;gap:6px;font-weight:700;font-size:.9rem}h1{margin:0;font-size:1.85rem;letter-spacing:0}h2{margin:0;font-size:1.05rem;color:var(--ink)}.topbar{position:sticky;top:0;left:0;right:0;z-index:2;width:100%;min-width:0;max-width:100%;background:#fffffff0;border-bottom:1px solid var(--border);box-shadow:0 1px 12px #17212b0d;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);padding:12px 18px;display:flex;gap:14px;align-items:center;justify-content:space-between;flex-wrap:wrap;overflow:visible;isolation:isolate}.topbar:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;z-index:-1;background:#fffffff0;box-shadow:0 0 0 999px #fffffff0;clip-path:inset(0 -999px 0 -999px)}.brand{display:inline-flex;align-items:center;min-width:0;flex:0 1 auto}.brandImage{display:block;width:auto;max-width:100%;object-fit:contain}.brandImageHeader{max-width:min(260px,58vw);max-height:42px}.brandImageLogin{width:min(100%,360px);max-height:140px}.brandFallback{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}nav{display:flex;gap:8px;align-items:center;flex-wrap:wrap;font-size:.92rem}.desktopNav{justify-content:flex-end;flex:1 1 auto;min-width:0}nav a{border-radius:999px;color:#344354;font-weight:800;padding:7px 10px;position:relative;transition:background .14s ease,color .14s ease}nav a:hover{background:var(--teal-soft);color:var(--forest)}nav a.active{background:var(--teal-soft);color:var(--forest);box-shadow:inset 0 -2px 0 var(--teal)}.linkButton{background:transparent;color:var(--forest);min-height:auto;padding:7px 4px;box-shadow:none}.linkButton:hover{background:transparent;color:var(--teal);transform:none}.mobileMenuButton{display:none}.mobileNavPanel{display:none;width:100%}.page{width:min(1120px,100%);max-width:100%;min-width:0;margin:0 auto;padding:22px 16px 48px}.pageHeader{display:grid;gap:6px;margin-bottom:18px}.pageHeader p{margin:0;color:var(--muted);max-width:760px;overflow-wrap:anywhere}.backLink{margin-bottom:14px}.loginPanel{max-width:420px;margin:8vh auto}.loginBrand{display:flex;justify-content:center;margin-bottom:20px}.loginPanel{background:#fffffff0;border:1px solid var(--border);border-radius:14px;box-shadow:var(--shadow);padding:22px}.installNote{color:var(--muted);font-size:.92rem;margin-top:14px}.stack{display:grid;gap:14px;min-width:0;max-width:100%}.grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:14px;min-width:0;max-width:100%}.clientHome{width:min(1160px,100%);max-width:100%;min-width:0;margin:0 auto}.helperText{margin:0;color:var(--muted)}.clientCardGrid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px;min-width:0;max-width:100%}.clientServiceCard{display:grid;gap:12px;min-width:0;max-width:100%;transition:border-color .14s ease,box-shadow .14s ease,transform .14s ease}.clientServiceCard:hover{border-color:#13766e47;box-shadow:var(--shadow);transform:translateY(-1px)}.clientServiceCard h2{line-height:1.25;min-width:0;overflow-wrap:anywhere}.clientServiceCard p{margin:0;color:var(--muted);overflow-wrap:anywhere}.cardStats{display:grid;gap:7px;padding:12px;border:1px solid var(--border);border-radius:8px;background:linear-gradient(180deg,#fbfcfc,#f5f8f8)}.cardStats span{color:var(--muted)}.cardStats strong{color:var(--ink)}.tile,.card{background:var(--card-bg);border:1px solid var(--border);border-radius:12px;padding:16px;box-shadow:var(--shadow-soft);min-width:0;max-width:100%}.tile{display:grid;gap:6px;min-height:120px;transition:border-color .14s ease,box-shadow .14s ease,transform .14s ease}.tile:hover{border-color:#13766e59;box-shadow:var(--shadow);transform:translateY(-1px)}.tile strong{color:var(--forest)}.tile span,.rowButton span,.reportRow span{color:var(--muted)}.tile strong,.tile span,.card strong,.card span,.card p,.rowButton strong,.rowButton span,.reportRow strong,.reportRow span{min-width:0;overflow-wrap:anywhere}.twoCol{display:grid;grid-template-columns:minmax(0,1fr) minmax(0,1fr);gap:18px;align-items:start;min-width:0;max-width:100%}.list,.stopList{display:grid;gap:10px;margin-top:14px}.rowButtonWrap{display:grid;grid-template-columns:1fr auto;gap:8px;align-items:stretch}.rowButtonWrap.selected .rowButton{border-color:var(--teal);box-shadow:0 0 0 2px #12615d1f}.rowButton{width:100%;background:var(--card-bg);color:var(--ink);border:1px solid var(--border);justify-content:start;display:grid;text-align:left;min-height:62px;box-shadow:none}.rowButton:hover{background:#fbfdfd;border-color:#13766e59;transform:none}.maintenanceRequestRow{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:8px;align-items:stretch;min-width:0}.maintenanceRequestRow.selected .rowButton{border-color:var(--teal);box-shadow:0 0 0 2px #13766e24;background:#fbfdfd}.inlineForm,.toolbar,.actions{display:flex;gap:10px;align-items:center;flex-wrap:wrap}.workerToolbar select{flex:1 1 260px}.inlineForm input{flex:1 1 150px}.formGrid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:12px}fieldset{border:1px solid #e2e7ee;border-radius:8px;display:flex;gap:12px;flex-wrap:wrap}.check{display:flex;grid-template-columns:auto 1fr;align-items:center;gap:6px}.check input{width:auto;min-height:auto}.table{display:grid;gap:8px;margin-top:16px}.userRowWrap{display:grid;gap:8px}.tableRow,.reportRow{background:var(--card-bg);border:1px solid var(--border);border-radius:10px;padding:12px;display:grid;gap:10px;align-items:center}.tableRow{grid-template-columns:1.2fr 1.4fr .7fr .7fr auto}.reportRow{grid-template-columns:1.3fr .8fr 1.5fr auto}.rowActions{display:flex;gap:8px;justify-content:flex-end;flex-wrap:wrap}.editUserForm{margin-bottom:8px}.issueTypeRow{display:grid;grid-template-columns:1fr 90px auto auto auto;gap:8px;align-items:center}.split{display:flex;justify-content:space-between;gap:10px;align-items:center;min-width:0;max-width:100%}.split>*{min-width:0}.pill{border-radius:999px;padding:4px 10px;font-size:.8rem;font-weight:900;line-height:1.2;color:#344354;background:#edf2f5;border:1px solid rgba(93,104,119,.16);white-space:nowrap}.pill.in_progress,.pill.assigned,.pill.waiting_on_property{background:var(--warm-soft);color:#7a4b11;border-color:#f0d492}.pill.completed{background:#dff3e6;color:#22633a;border-color:#b9dfc6}.pill.not_started,.pill.submitted{background:#edf2f5;color:#405064}.pill.closed{background:var(--teal-soft);color:var(--forest);border-color:#b8dbd8}.pill.cancelled{background:#f7e8e8;color:var(--danger);border-color:#edc9c9}.pill.urgent{background:#fbe7df;color:#983916;border-color:#f1c1ad}.thumb{width:100%;max-width:100%;max-height:220px;object-fit:cover;border-radius:8px;border:1px solid #e2e7ee}.mini{width:72px;max-width:100%;height:72px;object-fit:cover;border-radius:8px}.notice{background:var(--teal-soft);border:1px solid #b8dbd8;color:#254d49;padding:10px 12px;border-radius:10px}.error{color:var(--danger);font-weight:700}.notice.error{background:#fff1f1;border-color:#edbcbc;color:var(--danger)}.status,.line{background:var(--card-bg);border:1px solid var(--border);border-radius:10px;padding:10px}.statusText{align-self:center;color:#2f6f3d;font-weight:800}.photoStatus{margin:0;color:#2f6f3d;font-weight:800}.timeLine{margin:0;color:var(--muted);font-weight:700}.uploadBox{display:grid;gap:10px;background:#f7f9fa;border:1px solid var(--border-strong);border-radius:10px;padding:12px}.uploadBox p{margin:3px 0 0;color:var(--muted)}.uploadButton{width:100%;min-height:48px}.finishRoutePanel{border-color:#b8dbd8;background:linear-gradient(180deg,#fff,#f3fbf9);box-shadow:var(--shadow),inset 3px 0 0 var(--teal);scroll-margin-top:88px}.finishRoutePanel button{min-height:50px;font-size:1rem}.visuallyHidden{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.violation,.inlinePanel{background:#f7f9fa;border:1px solid var(--border);border-radius:10px;padding:12px}.vendorUpdatePanel{border-color:#b8dbd8;background:linear-gradient(180deg,#eef8f7,#f8fcfb);box-shadow:inset 3px 0 0 var(--teal)}.maintenanceListColumn.attentionFirst .maintenanceAttentionCard{order:1}.maintenanceListColumn.attentionFirst .maintenanceRequestForm{order:2}.maintenanceListColumn.attentionFirst>.card:not(.maintenanceAttentionCard):not(.maintenanceRequestForm){order:3}.selectedRequestCard{scroll-margin-top:88px;transition:border-color .16s ease,box-shadow .16s ease}.selectedRequestCardActive{border-color:#13766e57;box-shadow:var(--shadow),inset 3px 0 0 var(--teal)}.selectedRequestLabel{color:var(--teal);font-size:.78rem;font-weight:900;letter-spacing:.04em;text-transform:uppercase}.report{width:min(1160px,100%);gap:14px;margin:16px auto 0}.snapshot{order:1;display:grid;grid-template-columns:minmax(240px,.9fr) minmax(0,2fr);gap:14px;align-items:stretch}.snapshotHero{display:grid;gap:8px;align-content:start;border-color:#cfe0dd;background:linear-gradient(180deg,#fff,#f7fbfa)}.snapshotHero>span{color:var(--teal);font-size:.86rem;font-weight:800;text-transform:uppercase}.snapshotHero p{margin:0;color:var(--muted)}.snapshotHero .pill,.snapshotHero button{justify-self:start}.snapshotGrid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:10px}.metric{background:var(--card-bg);border:1px solid var(--border);border-radius:10px;padding:12px;display:grid;gap:5px;box-shadow:0 1px #17212b08}.metric span{color:var(--muted);font-size:.82rem;font-weight:800}.metric strong{font-size:1.05rem}.copyStatus{margin:0;color:#2f6f3d;font-weight:800}.reportAccordion{order:5;padding:0;overflow:hidden}.issuesAccordion{order:3}.buildingsAccordion{order:4}.timelineAccordion{order:5}.accordionHeader{width:100%;min-height:56px;background:var(--card-bg);color:var(--ink);border-radius:0;padding:14px 16px;display:flex;justify-content:space-between;gap:12px;text-align:left;min-width:0}.accordionHeader:hover{background:#f8fbfa;transform:none}.accordionHeader span{font-size:1rem;font-weight:900;min-width:0;overflow-wrap:anywhere}.accordionHeader strong{color:var(--teal);white-space:nowrap;max-width:100%}.accordionBody{border-top:1px solid #e2e7ee;padding:14px 16px 16px}.timelineCard{display:grid;gap:12px}.timeline{display:grid;gap:0}.timelineItem{display:grid;grid-template-columns:110px 1fr;gap:14px;padding:12px 0;border-top:1px solid var(--border)}.timelineItem:first-child{border-top:0;padding-top:0}.timelineItem p{margin:3px 0 0;color:var(--muted)}.timelineTime{color:var(--teal);font-weight:900;white-space:nowrap}.reportHeader,.reportSummary{display:grid;gap:8px}.reportSummary{order:2}.reportHeader p,.reportSummary p{margin:0;color:var(--muted)}.summaryGrid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:10px;color:#556274}.report .list{margin-top:0;gap:12px}.reportRow{padding:14px;align-items:start}.buildingReportRow{grid-template-columns:minmax(180px,1.1fr) 130px minmax(160px,1fr) 84px}.issueReportRow{grid-template-columns:minmax(150px,1fr) minmax(110px,.75fr) minmax(120px,.85fr) minmax(150px,1fr) minmax(140px,.9fr) 84px}.reportRow strong{line-height:1.3}.reportStopMeta,.reportStopActions{display:grid;gap:6px;justify-items:start}.startLocationLink{width:fit-content;max-width:100%}.expiredPhotoBadge{display:inline-flex;width:fit-content;max-width:100%;padding:5px 9px;border:1px solid var(--border);border-radius:999px;background:#f7f9fa;color:var(--muted);font-size:.82rem;font-weight:800}.modalBackdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:10;display:grid;place-items:center;padding:18px;background:#17212b7a}.locationModal{width:min(720px,100%);max-height:min(760px,calc(100svh - 36px));overflow:auto;border-color:#cfe0dd;background:linear-gradient(180deg,#fff,#f7fbfa)}.locationMapShell{padding:8px;background:#eef4f3;border:1px solid var(--border);border-radius:12px}.locationMapFrame{display:block;width:100%;min-height:380px;border:1px solid var(--border);border-radius:8px;background:#f7f9fa}.photoModalShell{display:grid;place-items:center;padding:8px;background:#eef4f3;border:1px solid var(--border);border-radius:12px}.photoModalImage{display:block;max-width:100%;max-height:min(560px,62svh);object-fit:contain;border-radius:8px}.emptyState{margin:0;color:var(--muted);background:#f7f9fa;border:1px dashed var(--border-strong);border-radius:10px;padding:12px}@media(max-width:760px){.topbar{align-items:center;gap:10px;padding:10px 12px}.brand{flex:1 1 auto;max-width:calc(100% - 88px)}.brandImageHeader{max-width:100%;max-height:38px}.desktopNav{display:none}.mobileMenuButton{display:inline-flex;flex:0 0 auto;min-height:40px;padding:0 13px;margin-left:auto}.mobileNavPanel{display:grid;gap:6px;flex:1 0 100%;width:100%;min-width:0;max-width:100%;background:#fffffffa;border:1px solid var(--border);border-radius:12px;padding:8px;box-shadow:var(--shadow-soft)}.mobileNavPanel a,.mobileNavPanel .linkButton{width:100%;min-height:42px;justify-content:flex-start;text-align:left;padding:10px 12px;border-radius:10px}.mobileNavPanel a.active{box-shadow:inset 3px 0 0 var(--teal)}.page{padding:18px 12px 40px}h1{font-size:1.45rem;line-height:1.2}.pageHeader{margin-bottom:14px}.pageHeader p{font-size:.95rem;line-height:1.4}.card,.tile{padding:14px}.grid,.twoCol,.formGrid,.clientCardGrid,.snapshot,.snapshotGrid,.timelineItem,.summaryGrid{grid-template-columns:1fr}.timelineItem{gap:4px}.accordionHeader{align-items:flex-start;flex-direction:column;gap:5px;min-height:auto;padding:13px 14px}.accordionHeader strong{white-space:normal;overflow-wrap:anywhere}.metric{min-width:0}.metric strong{overflow-wrap:anywhere}.modalBackdrop{align-items:start;padding:12px}.locationModal{max-height:calc(100svh - 24px)}.locationMapFrame{min-height:320px}.photoModalImage{max-height:58svh}.toolbar>*{flex:1 1 100%}.tableRow,.reportRow,.issueTypeRow,.issueReportRow,.rowButtonWrap,.maintenanceRequestRow{grid-template-columns:1fr}.actions{align-items:stretch}.actions button,.actions .button,.clientServiceCard .actions a,.clientServiceCard .actions button{flex:1 1 100%;width:100%}.stopList .card{padding:14px}.split{align-items:flex-start;flex-direction:column}.split .pill{align-self:flex-start}.pill{white-space:normal;max-width:100%}.rowButton{padding:10px 12px}.workerToolbar{position:sticky;top:69px;z-index:1;background:var(--app-bg);padding:8px 0}}
