@import url("app-nav.css?v=20260606-operations-tab");
:root{--ops-ink:var(--ui-ink,#1d1d1f);--ops-muted:var(--ui-muted,#6e6e73);--ops-line:var(--ui-line,#d2d2d7);--ops-paper:var(--ui-paper,#fff);--ops-soft:var(--ui-surface,#f5f5f7);--ops-accent:var(--ui-accent,#1d1d1f);--ops-accent-hover:var(--ui-accent-hover,#333);--ops-on-accent:var(--ui-on-accent,#fff);--ops-danger:#dc2626;--ops-ok:#15803d;--ops-warn:#a16207}
*{box-sizing:border-box}
body{margin:0;background:var(--ops-soft);color:var(--ops-ink);font-family:"Inter",-apple-system,BlinkMacSystemFont,"Segoe UI",Arial,sans-serif;line-height:1.45}
.ops-page{width:min(100% - 32px,1440px);margin:0 auto;padding:18px 0 32px}
.ops-topbar{display:flex;justify-content:space-between;align-items:center;gap:16px;background:var(--ops-paper);border:1px solid var(--ops-line);border-radius:14px;padding:10px 12px;margin-bottom:16px;box-shadow:0 1px 2px rgba(16,24,40,.04),0 4px 14px rgba(16,24,40,.06)}
.ops-brand{display:flex;align-items:center;gap:10px}.ops-brand img{width:138px;height:54px;object-fit:contain}.ops-brand span{display:block;color:var(--ops-muted);font-size:11px;font-weight:700}.ops-brand h1{margin:0;font-size:20px}
.actions,.top-actions{display:flex;gap:8px;flex-wrap:wrap}.btn{border:1px solid var(--ops-line);border-radius:8px;padding:9px 11px;background:var(--ops-paper);color:var(--ops-ink);font:inherit;font-weight:700;cursor:pointer;text-decoration:none;display:inline-flex;align-items:center;justify-content:center;gap:6px;transition:background .16s ease,border-color .16s ease,color .16s ease}.btn:hover{background:#f5f5f7;border-color:#b8b8bd}.btn-primary{background:var(--ops-accent);border-color:var(--ops-accent);color:var(--ops-on-accent)}.btn-primary:hover{background:var(--ops-accent-hover);border-color:var(--ops-accent-hover)}.btn-danger{color:var(--ops-danger)}.nav-active{background:var(--ops-accent)!important;color:var(--ops-on-accent)!important;border-color:var(--ops-accent)!important}
.ops-head{display:flex;justify-content:space-between;align-items:flex-start;gap:16px;margin-bottom:14px}.ops-head h2{margin:0;font-size:26px}.ops-head p{margin:4px 0 0;color:var(--ops-muted)}
.ops-stats{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:12px;margin-bottom:14px}.ops-stat,.ops-panel{background:var(--ops-paper);border:1px solid var(--ops-line);border-radius:14px;box-shadow:0 1px 2px rgba(16,24,40,.04),0 4px 14px rgba(16,24,40,.06)}.ops-stat{padding:14px}.ops-stat span{display:block;color:var(--ops-muted);font-size:12px;font-weight:700}.ops-stat strong{display:block;font-size:22px;margin-top:5px}
.ops-layout{display:grid;grid-template-columns:minmax(0,1fr) 390px;gap:14px;align-items:start}.ops-panel-head{padding:15px 17px;border-bottom:1px solid var(--ops-line);display:flex;justify-content:space-between;align-items:center;gap:12px}.ops-panel-head h3{margin:0;font-size:18px}.ops-panel-body{padding:16px 17px}
.ops-toolbar{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:14px}.ops-toolbar input,.ops-toolbar select{min-width:160px;flex:1}
label{display:block;font-size:12px;color:var(--ops-muted);font-weight:700;margin-bottom:5px}input,select,textarea{width:100%;border:1px solid var(--ops-line);border-radius:8px;padding:10px 11px;background:#fff;color:var(--ops-ink);font:inherit}input:focus,select:focus,textarea:focus{outline:2px solid var(--ui-accent-soft,rgba(0,102,204,.18));border-color:var(--ops-accent)}textarea{min-height:90px;resize:vertical}.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:11px}.form-grid .full{grid-column:1/-1}.form-actions{display:flex;gap:9px;flex-wrap:wrap;margin-top:14px}.status-line{min-height:20px;margin-top:10px;color:var(--ops-muted);font-weight:700}.status-line.ok{color:var(--ops-ok)}.status-line.err{color:var(--ops-danger)}
.record-list{display:grid;gap:9px}.record-row{border:1px solid var(--ops-line);border-radius:8px;padding:13px;background:#fff;display:grid;grid-template-columns:minmax(0,1fr) auto;gap:12px}.record-row h4{margin:0 0 3px;font-size:16px}.record-row p{margin:0;color:var(--ops-muted);font-size:13px}.record-actions{display:flex;gap:7px;flex-wrap:wrap;justify-content:flex-end;align-items:center}.badge{display:inline-flex;border-radius:999px;padding:4px 8px;background:#f0f0f2;color:#4a4a4f;font-size:12px;font-weight:700}.badge.approved,.badge.completed,.badge.paid{background:#eaf8ef;color:var(--ops-ok)}.badge.declined,.badge.cancelled{background:#fff1f2;color:#be123c}.badge.scheduled,.badge.dispatched,.badge.sent{background:#eef2ff;color:#3730a3}.badge.in-progress,.badge.changes-requested{background:#fff7ed;color:#9a3412}
.record-row.has-record-menu{grid-template-columns:32px minmax(0,1fr) auto}.record-menu{position:relative;align-self:start}.record-menu-trigger{width:30px;height:30px;padding:0;border:1px solid var(--ops-line);border-radius:8px;background:#fff;color:var(--ops-ink);display:grid;place-items:center;cursor:pointer}.record-menu-trigger:hover,.record-menu.open .record-menu-trigger{background:var(--ops-soft)}.record-menu-dots{display:grid;gap:3px}.record-menu-dots:before,.record-menu-dots:after,.record-menu-dots span{content:"";display:block;width:4px;height:4px;border-radius:50%;background:currentColor}.record-menu-list{position:fixed;z-index:500;display:none;min-width:158px;padding:6px;background:#fff;border:1px solid var(--ops-line);border-radius:8px;box-shadow:0 14px 28px rgba(35,32,29,.16)}.record-menu.open .record-menu-list{display:grid;gap:3px}.record-menu-list button{border:0;border-radius:6px;background:transparent;padding:9px 10px;text-align:left;font:inherit;font-weight:700;color:var(--ops-ink);cursor:pointer;white-space:nowrap}.record-menu-list button:hover{background:var(--ops-soft)}.record-menu-list button.danger{color:#b42318}
.line-items{display:grid;gap:8px}.line-item{display:grid;grid-template-columns:1.2fr 1.5fr 80px 110px 36px;gap:7px}.icon-btn{width:36px;height:38px;padding:0}.empty{padding:28px;text-align:center;color:var(--ops-muted);border:1px dashed var(--ops-line);border-radius:8px;background:var(--ops-soft)}.empty-jobs{padding:48px 24px;text-align:center;display:grid;justify-items:center;gap:10px}.empty-jobs-icon{font-size:36px;line-height:1}.empty-jobs h3{margin:0;font-size:18px;font-weight:700;color:var(--ops-ink)}.empty-jobs p{margin:0;color:var(--ops-muted);font-size:14px;max-width:340px}.empty-jobs .btn{margin-top:6px}
.calendar{display:grid;grid-template-columns:repeat(7,minmax(150px,1fr));gap:8px;overflow-x:auto}.calendar-day{min-height:460px;border:1px solid var(--ops-line);border-radius:8px;background:var(--ops-paper)}.calendar-day-head{position:sticky;top:0;padding:10px;border-bottom:1px solid var(--ops-line);background:var(--ops-soft);font-weight:800}.calendar-day-body{padding:8px;display:grid;gap:7px}.job-card{border:1px solid var(--ops-line);border-left:4px solid var(--ops-accent);border-radius:7px;background:#fff;padding:9px;cursor:pointer}.job-card strong,.job-card span{display:block}.job-card span{font-size:12px;color:var(--ops-muted);margin-top:2px}.conflict{border-left-color:var(--ops-danger);background:#fff7f7}
.portal-shell{max-width:960px;margin:0 auto;padding:20px}.portal-header{display:flex;justify-content:space-between;align-items:center;gap:16px;margin-bottom:16px}.portal-tabs{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:14px}.portal-tabs button.active{background:var(--ops-accent);color:var(--ops-on-accent)}.portal-section{display:none}.portal-section.active{display:block}
.operations-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:14px}.operations-feature{display:flex;flex-direction:column;min-height:250px}.operations-feature .ops-panel-body{display:flex;flex:1;flex-direction:column}.operations-feature p{margin:0 0 18px;color:var(--ops-muted)}.operations-feature .btn{margin-top:auto;align-self:flex-start}.operations-metric{display:flex;align-items:baseline;justify-content:space-between;gap:12px;padding:9px 0;border-top:1px solid var(--ops-line)}.operations-metric strong{font-size:19px}.operations-metric span{color:var(--ops-muted);font-size:13px}.operations-activity{display:grid;gap:0}.operations-activity .record-row{border-width:1px 0 0;border-radius:0;padding-left:0;padding-right:0}.operations-activity .record-row:first-child{border-top:0}
.operations-quick-actions{display:flex;gap:9px;flex-wrap:wrap;margin-bottom:14px}.operations-quick-actions .btn{min-height:42px}
.operations-live-summary{max-width:760px}.operations-live-summary strong{color:var(--ops-ink)}.ops-stat{position:relative;transition:box-shadow .2s ease,border-color .2s ease}.ops-stat:hover{box-shadow:0 2px 4px rgba(16,24,40,.06),0 8px 22px rgba(16,24,40,.10);border-color:#cbd2dc}.ops-stat:before{content:"";position:absolute;right:16px;top:16px;width:7px;height:7px;border-radius:50%;background:#cbd2dc}.ops-stat[data-level="clear"]:before{background:#1a7f4b}.ops-stat[data-level="attention"]:before{background:#b7791f}.ops-stat[data-level="urgent"]:before{background:#b42318}.ops-stat[data-level="active"]:before{background:var(--ops-accent)}.ops-stat small{display:block;margin-top:4px;color:var(--ops-muted);font-size:11px}
.operations-feature{transition:box-shadow .2s ease,border-color .2s ease}.operations-feature:hover{box-shadow:0 2px 4px rgba(16,24,40,.06),0 8px 22px rgba(16,24,40,.10);border-color:#cbd2dc}.feature-type{background:var(--ops-soft);color:var(--ops-muted);border:1px solid var(--ops-line)}.feature-live-copy{min-height:48px;margin:0 0 14px!important;color:var(--ops-ink)!important;font-weight:750}.feature-live-copy span{display:block;margin-top:3px;color:var(--ops-muted);font-size:12px;font-weight:500}.operations-feature .btn-primary{margin-top:auto}
.pipeline-overview{margin-top:14px}.pipeline-bars{display:grid;grid-template-columns:repeat(5,minmax(0,1fr));gap:10px}.pipeline-stage{display:grid;gap:8px;min-width:0}.pipeline-stage-head{display:flex;justify-content:space-between;gap:8px;align-items:baseline}.pipeline-stage-head span{color:var(--ops-muted);font-size:12px;font-weight:700}.pipeline-stage-head strong{font-size:18px}.pipeline-track{height:12px;border-radius:999px;background:#e8e8eb;overflow:hidden}.pipeline-fill{display:block;height:100%;width:0;border-radius:inherit;background:var(--ops-accent);transition:width .75s cubic-bezier(.2,.8,.2,1);transition-delay:var(--pipeline-delay,0ms)}.pipeline-fill.awaiting{background:#94a3b8}.pipeline-fill.unscheduled{background:#b7791f}.pipeline-fill.scheduled{background:#2563eb}.pipeline-fill.progress{background:#3b82f6}.pipeline-fill.completed{background:#1a7f4b}.pipeline-overview.is-visible .pipeline-fill{width:var(--pipeline-width)}
.upcoming-date-group+.upcoming-date-group{margin-top:16px}.upcoming-date-head{display:flex;align-items:center;gap:10px;margin-bottom:7px}.upcoming-date-head strong{font-size:14px}.upcoming-date-head span{color:var(--ops-muted);font-size:12px}.upcoming-date-head:after{content:"";height:1px;flex:1;background:var(--ops-line)}.upcoming-date-group .record-row{border-width:1px;border-radius:8px;padding:12px}.upcoming-date-group .record-row+.record-row{margin-top:8px}.upcoming-time{display:inline-flex;min-width:74px;font-weight:800;color:var(--ops-ink)}.empty-operations{display:grid;justify-items:center;gap:8px}.empty-operations-icon{width:42px;height:42px;border-radius:50%;display:grid;place-items:center;background:var(--ui-accent-soft,#eef4ff);color:var(--ops-accent);font-size:20px}
.ops-reveal{opacity:0}.ops-reveal.is-visible{animation:opsReveal .3s ease forwards;animation-delay:var(--ops-delay,0ms)}.operations-activity .record-row{opacity:0}.operations-activity.is-visible .record-row{animation:opsRowIn .24s ease forwards;animation-delay:var(--row-delay,0ms)}@keyframes opsReveal{to{opacity:1}}@keyframes opsRowIn{to{opacity:1}}
.operations-workspace{display:grid;grid-template-columns:220px minmax(0,1fr);gap:18px;align-items:start}.operations-sidebar{position:sticky;top:16px;background:var(--ops-paper);border:1px solid var(--ops-line);border-radius:8px;overflow:hidden;box-shadow:0 1px 2px rgba(16,24,40,.04),0 4px 14px rgba(16,24,40,.06)}.operations-sidebar-title{padding:16px 17px;border-bottom:1px solid var(--ops-line);font-size:18px;font-weight:800}.operations-sidebar-nav{display:grid;padding:8px}.operations-sidebar-nav a{display:grid;gap:2px;padding:12px 11px;border-left:3px solid transparent;border-radius:4px;color:var(--ops-ink);text-decoration:none}.operations-sidebar-nav a:hover{background:var(--ops-soft)}.operations-sidebar-nav a.active{border-left-color:var(--ops-accent);background:var(--ops-soft)}.operations-sidebar-nav span{font-size:14px;font-weight:800}.operations-sidebar-nav small{color:var(--ops-muted);font-size:11px}.operations-content{min-width:0}.operations-content>.ops-head:first-child{padding-top:4px}
.approval-box{padding:12px;border:1px solid var(--ops-line);border-radius:8px;background:var(--ops-soft)}.approval-box .btn{margin-top:10px}.portal-link-result{padding-top:4px}.portal-link-row{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:8px}.portal-link-row input{min-width:0}
.dialog-open{overflow:hidden}.ops-dialog-backdrop{position:fixed;inset:0;z-index:4000;display:grid;place-items:center;padding:18px;background:rgba(0,0,0,.34);backdrop-filter:blur(6px)}.ops-dialog-backdrop[hidden]{display:none}.ops-dialog{width:min(100%,520px);max-height:calc(100vh - 36px);overflow:auto;background:var(--ops-paper);border:1px solid var(--ops-line);border-radius:14px;box-shadow:0 24px 70px rgba(0,0,0,.2)}.dialog-copy{margin:0 0 14px;color:var(--ops-muted)}.field-help{margin:5px 0 12px;color:var(--ops-muted);font-size:12px}
.estimate-group{border:1px solid var(--ops-line);border-radius:8px;background:var(--ops-soft);overflow:hidden}.estimate-group summary{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:13px;cursor:pointer;font-weight:800;list-style:none}.estimate-group summary::-webkit-details-marker{display:none}.estimate-group summary:before{content:"›";font-size:20px;line-height:1;transition:transform .16s ease}.estimate-group[open] summary:before{transform:rotate(90deg)}.estimate-group summary span:first-of-type{margin-right:auto}.estimate-group-list{display:grid;gap:9px;padding:0 10px 10px}.estimate-group-list .record-row{box-shadow:none}
.pipeline-group{border:1px solid var(--ops-line);border-radius:8px;background:var(--ops-soft);overflow:hidden}.pipeline-group+ .pipeline-group{margin-top:9px}.pipeline-group summary{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:13px;cursor:pointer;font-weight:800;list-style:none}.pipeline-group summary::-webkit-details-marker{display:none}.pipeline-group summary:before{content:"›";font-size:20px;line-height:1;transition:transform .16s ease}.pipeline-group[open] summary:before{transform:rotate(90deg)}.pipeline-group summary span:first-of-type{margin-right:auto}.pipeline-group-list{display:grid;gap:9px;padding:0 10px 10px}.pipeline-group-list .record-row{box-shadow:none}
.jobs-layout{grid-template-columns:minmax(0,1fr)}.job-detail-open{overflow:hidden}.job-detail-backdrop{position:fixed;inset:0;z-index:3500;display:flex;justify-content:flex-end;background:rgba(0,0,0,.3);backdrop-filter:blur(5px)}.job-detail-backdrop[hidden]{display:none}.job-detail-drawer{width:min(560px,100%);height:100vh;height:100dvh;border-radius:0;border-width:0 0 0 1px;overflow:auto;box-shadow:-18px 0 55px rgba(0,0,0,.18)}.job-detail-drawer .ops-panel-head{position:sticky;top:0;z-index:2;background:var(--ops-paper)}.job-detail-drawer .ops-panel-body{padding-bottom:36px}
.estimates-list-layout{grid-template-columns:minmax(0,1fr)}.estimate-editor-open{overflow:hidden}.estimate-editor-backdrop{position:fixed;inset:0;z-index:3500;display:flex;justify-content:flex-end;background:rgba(0,0,0,.3);backdrop-filter:blur(7px)}.estimate-editor-backdrop[hidden]{display:none}.estimate-editor-drawer{width:min(620px,100%);height:100vh;height:100dvh;border-radius:0;border-width:0 0 0 1px;overflow:auto;box-shadow:-18px 0 55px rgba(0,0,0,.18)}.estimate-editor-drawer .ops-panel-head{position:sticky;top:0;z-index:3;background:var(--ops-paper)}.estimate-editor-drawer .ops-panel-body{padding-bottom:36px}
.job-peek-open{overflow:hidden}.job-peek-backdrop{position:fixed;inset:0;z-index:3700;display:flex;align-items:flex-end;justify-content:center;background:rgba(0,0,0,.32);backdrop-filter:blur(5px)}.job-peek-backdrop[hidden]{display:none}.job-peek-sheet{width:min(720px,100%);max-height:85vh;max-height:85dvh;border-radius:16px 16px 0 0;border-width:1px 1px 0;overflow:auto;box-shadow:0 -18px 55px rgba(0,0,0,.18);transform:translateY(100%);transition:transform .32s cubic-bezier(.22,.68,0,1.05)}.job-peek-backdrop.is-open .job-peek-sheet{transform:translateY(0)}.job-peek-sheet .ops-panel-head{position:sticky;top:0;z-index:2;background:var(--ops-paper);border-radius:16px 16px 0 0}.job-peek-sheet .ops-panel-body{padding-bottom:28px}
.peek-grid{display:grid;grid-template-columns:1fr 1fr;gap:11px}.peek-grid .full{grid-column:1/-1}.peek-field{display:grid;gap:4px}.peek-label{font-size:12px;color:var(--ops-muted);font-weight:700}.peek-value{margin:0;border:1px solid var(--ops-line);border-radius:8px;padding:10px 11px;background:var(--ops-soft);color:var(--ops-ink);min-height:20px;white-space:pre-wrap;font-size:14px}.peek-section{margin-top:16px}.peek-section h4{margin:0 0 8px;font-size:14px}.peek-checklist{display:grid;gap:7px}.peek-checklist label{display:flex;align-items:center;gap:8px;margin:0;font-size:13px;font-weight:500;color:var(--ops-ink)}.peek-checklist input{width:auto;accent-color:var(--ops-accent)}.peek-notes{display:grid;gap:7px}.peek-note{border:1px solid var(--ops-line);border-radius:8px;padding:9px 11px;background:#fff;font-size:13px}.peek-note time{display:block;margin-top:3px;color:var(--ops-muted);font-size:11px}.peek-photos{display:grid;grid-template-columns:repeat(auto-fill,minmax(110px,1fr));gap:8px}.peek-photos img{width:100%;height:90px;object-fit:cover;border-radius:8px;border:1px solid var(--ops-line)}
@media(max-width:980px){.ops-layout,.ops-stats,.operations-grid{grid-template-columns:1fr 1fr}.operations-workspace{grid-template-columns:1fr}.operations-sidebar{position:static}.operations-sidebar-title{display:none}.operations-sidebar-nav{grid-template-columns:repeat(5,minmax(145px,1fr));overflow-x:auto;scroll-snap-type:x proximity}.operations-sidebar-nav a{border-left:0;border-bottom:3px solid transparent;scroll-snap-align:start}.operations-sidebar-nav a.active{border-left:0;border-bottom-color:var(--ops-accent);background:var(--ui-accent-soft,var(--ops-soft))}.ops-topbar{align-items:flex-start;flex-direction:column}.actions,.top-actions{width:100%;overflow-x:auto;flex-wrap:nowrap}.actions .btn,.top-actions .btn{white-space:nowrap}.pipeline-bars{grid-template-columns:repeat(5,minmax(130px,1fr));overflow-x:auto;padding-bottom:5px}}
@media(max-width:680px){.ops-page{width:min(100% - 20px,1440px);padding:10px 0 24px}.ops-layout,.ops-stats,.form-grid,.operations-grid{grid-template-columns:1fr}.operations-workspace{gap:12px}.operations-sidebar-nav{grid-template-columns:repeat(5,128px)}.operations-sidebar-nav small{display:none}.operations-sidebar-nav a{align-items:center;justify-items:center;padding:10px 8px}.operations-sidebar-nav a.active{box-shadow:inset 0 -3px var(--ops-accent)}.ops-head{display:grid}.line-item{grid-template-columns:1fr 1fr}.line-item input:nth-child(2){grid-column:1/-1}.record-row{grid-template-columns:1fr}.record-row.has-record-menu{grid-template-columns:32px minmax(0,1fr)}.record-row.has-record-menu .record-actions{grid-column:2}.record-actions{justify-content:flex-start}.portal-link-row{grid-template-columns:1fr}.ops-brand img{width:110px;height:auto}.ops-topbar{display:grid;grid-template-columns:1fr}.ops-topbar .actions{display:grid!important;grid-template-columns:1fr 1fr!important;overflow:visible!important;flex-wrap:wrap!important}.ops-topbar .operations-menu{grid-column:1/-1}.ops-topbar .operations-panel{grid-template-columns:1fr!important}.upcoming-time{min-width:0}.job-peek-sheet{max-height:92vh;max-height:92dvh;border-radius:14px 14px 0 0}.peek-grid{grid-template-columns:1fr}}
@media(prefers-reduced-motion:reduce){.ops-reveal,.ops-reveal.is-visible,.operations-activity .record-row,.operations-activity.is-visible .record-row,.pipeline-fill,.ops-stat,.operations-feature{animation:none!important;transition:none!important;opacity:1!important;transform:none!important}.pipeline-fill{width:var(--pipeline-width)!important}.job-peek-sheet{transition:none!important}}
