/* ============================================================
   OpsFlo — product UI stylesheet
   ============================================================ */
@font-face{font-family:'Space Grotesk';src:url('../../../assets/fonts/SpaceGrotesk-700.ttf') format('truetype');font-weight:700;font-display:swap}
@font-face{font-family:'Space Grotesk';src:url('../../../assets/fonts/SpaceGrotesk-500.ttf') format('truetype');font-weight:500;font-display:swap}
@font-face{font-family:'Hanken Grotesk';src:url('../../../assets/fonts/HankenGrotesk-400.ttf') format('truetype');font-weight:400;font-display:swap}
@font-face{font-family:'Hanken Grotesk';src:url('../../../assets/fonts/HankenGrotesk-500.ttf') format('truetype');font-weight:500;font-display:swap}
@font-face{font-family:'Hanken Grotesk';src:url('../../../assets/fonts/HankenGrotesk-600.ttf') format('truetype');font-weight:600;font-display:swap}
@font-face{font-family:'Hanken Grotesk';src:url('../../../assets/fonts/HankenGrotesk-700.ttf') format('truetype');font-weight:700;font-display:swap}

:root{
  --blue:#084182;--navy:#032044;--navy-deep:#02152e;--green:#6BBF54;--green-light:#8CCB6E;
  --cloud:#F0F1F3;--sky:#8FC8F0;--slate:#8B929B;--white:#fff;
  --bg:#0a1830;--surface:#102744;--surface-2:#0c1f3a;--line:rgba(255,255,255,.09);
  --txt:#eaf0f7;--txt-dim:rgba(234,240,247,.62);--txt-faint:rgba(234,240,247,.4);
  --font-head:'Space Grotesk',-apple-system,system-ui,sans-serif;
  --font-body:'Hanken Grotesk',-apple-system,system-ui,sans-serif;
  --r:12px;--r-lg:16px;--t:.25s cubic-bezier(.22,.61,.36,1);
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
body{font-family:var(--font-body);background:var(--bg);color:var(--txt);line-height:1.55;-webkit-font-smoothing:antialiased}
h1,h2,h3{font-family:var(--font-head);font-weight:700;letter-spacing:-.02em;line-height:1.1}
button{font-family:inherit;cursor:pointer;border:none;background:none;color:inherit}
input,select{font-family:inherit}
a{color:var(--green);text-decoration:none}
svg{display:block}
.mono{font-variant-numeric:tabular-nums;font-feature-settings:"tnum"}
.sm{font-size:.82rem}.muted{color:var(--txt-dim)}
::selection{background:var(--green);color:var(--navy)}

/* logo mark */
.lm{display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:8px;background:var(--blue);color:var(--green);flex:none}
.lm svg,.lm i{width:18px;height:18px}

/* buttons */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;font-family:var(--font-head);font-weight:500;border-radius:999px;padding:.7rem 1.3rem;font-size:.95rem;transition:transform var(--t),background var(--t),box-shadow var(--t)}
.btn i,.btn svg{width:17px;height:17px}
.btn-primary{background:var(--green);color:var(--navy);box-shadow:0 6px 20px -8px rgba(107,191,84,.6)}
.btn-primary:hover{background:var(--green-light);transform:translateY(-2px)}
.btn-ghost{background:rgba(255,255,255,.07);color:var(--txt);border:1px solid var(--line)}
.btn-ghost:hover{background:rgba(255,255,255,.13)}
.btn.big{width:100%;padding:.95rem 1.4rem;font-size:1rem}
.btn-mini{background:rgba(107,191,84,.14);color:var(--green-light);border:1px solid rgba(107,191,84,.3);border-radius:8px;padding:.4rem .8rem;font-size:.82rem;font-weight:600}
.btn-mini:hover{background:rgba(107,191,84,.24)}
.btn-mini.full{width:100%;margin-top:.7rem}
.icon-btn{width:40px;height:40px;border-radius:10px;display:flex;align-items:center;justify-content:center;color:var(--txt-dim);position:relative;transition:background var(--t),color var(--t)}
.icon-btn:hover{background:rgba(255,255,255,.07);color:var(--txt)}
.icon-btn i,.icon-btn svg{width:20px;height:20px}

/* ============ AUTH ============ */
.auth-wrap{display:grid;grid-template-columns:1fr;min-height:100svh}
.auth-visual{display:none;position:relative;background:radial-gradient(120% 90% at 30% 10%,#0a4e95,var(--navy) 55%,var(--navy-deep));overflow:hidden;padding:3rem}
.auth-visual canvas{position:absolute;inset:0;width:100%;height:100%;opacity:.5}
.mode-badge{position:relative;display:inline-block;background:rgba(107,191,84,.15);border:1px solid rgba(107,191,84,.4);color:var(--green-light);font-size:.78rem;font-weight:600;padding:.35rem .8rem;border-radius:999px;font-family:var(--font-head)}
.auth-quote{position:absolute;bottom:3rem;left:3rem;right:3rem;font-family:var(--font-head);font-size:1.3rem;font-weight:500;line-height:1.4;color:#fff}
.auth-quote span{display:block;margin-top:1rem;font-size:.9rem;color:var(--green-light);font-family:var(--font-body)}
.auth-panel{display:flex;align-items:center;justify-content:center;padding:2rem 1.4rem;background:var(--bg)}
.auth-card{width:100%;max-width:400px}
.auth-logo{font-family:var(--font-head);font-size:1.5rem;font-weight:500;display:flex;align-items:center;gap:.6rem;margin-bottom:2rem}
.auth-logo b{color:var(--green);font-weight:700}
.auth-card h1{font-size:1.9rem;margin-bottom:.7rem;line-height:1.12}
.auth-sub{color:var(--txt-dim);margin-bottom:1.8rem}
.auth-card .btn{margin-bottom:.8rem}
.auth-alt{margin-top:1.2rem;font-size:.9rem;color:var(--txt-dim);text-align:center}
.demo-note{margin-top:1.6rem;font-size:.82rem;color:var(--txt-faint);border-top:1px solid var(--line);padding-top:1.2rem}
.auth-form{display:flex;flex-direction:column;gap:.9rem;margin-bottom:.4rem}
.fld{display:flex;flex-direction:column;gap:.35rem}
.fld span{font-size:.82rem;font-weight:500;color:var(--txt-dim)}
.fld input,.fld select{background:var(--surface-2);border:1px solid var(--line);border-radius:10px;padding:.8rem .9rem;color:var(--txt);font-size:.98rem;transition:border-color var(--t),box-shadow var(--t)}
.fld input:focus,.fld select:focus{outline:none;border-color:var(--green);box-shadow:0 0 0 3px rgba(107,191,84,.18)}
@media(min-width:900px){.auth-wrap{grid-template-columns:1.05fr .95fr}.auth-visual{display:block}}

/* loading */
.loading{min-height:100svh;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1rem;color:var(--txt-dim)}
.loading .lm{width:46px;height:46px;animation:pulse 1.4s infinite}
.loading .lm svg{width:28px;height:28px}
@keyframes pulse{0%,100%{opacity:.5;transform:scale(.94)}50%{opacity:1;transform:scale(1)}}

/* ============ SHELL ============ */
.shell{display:grid;grid-template-columns:1fr;min-height:100svh}
.sidebar{position:fixed;top:0;left:0;bottom:0;width:264px;background:var(--navy-deep);border-right:1px solid var(--line);display:flex;flex-direction:column;z-index:50;transform:translateX(-100%);transition:transform var(--t)}
.sidebar.open{transform:none}
.side-logo{display:flex;align-items:center;gap:.6rem;padding:1.2rem 1.3rem;font-family:var(--font-head);font-size:1.25rem;font-weight:500;border-bottom:1px solid var(--line)}
.side-logo b{color:var(--green);font-weight:700}
.side-nav{flex:1;overflow-y:auto;padding:.8rem .6rem;display:flex;flex-direction:column;gap:2px}
.side-link{display:flex;align-items:center;gap:.8rem;padding:.7rem .8rem;border-radius:10px;color:var(--txt-dim);font-size:.92rem;font-weight:500;text-align:left;width:100%;transition:background var(--t),color var(--t)}
.side-link i,.side-link svg{width:19px;height:19px;flex:none}
.side-link:hover{background:rgba(255,255,255,.05);color:var(--txt)}
.side-link.active{background:rgba(107,191,84,.13);color:var(--green-light)}
.side-foot{border-top:1px solid var(--line);padding:.8rem .6rem}
.org{padding:.6rem .8rem;margin-bottom:.4rem}
.org-name{font-weight:600;font-size:.92rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.org-plan{font-size:.78rem;color:var(--green-light)}
.main{display:flex;flex-direction:column;min-height:100svh}
.scrim{position:fixed;inset:0;background:rgba(0,0,0,.5);z-index:40;opacity:0;visibility:hidden;transition:opacity var(--t)}
.scrim.show{opacity:1;visibility:visible}

.topbar{position:sticky;top:0;z-index:30;display:flex;align-items:center;gap:1rem;padding:.8rem 1.2rem;background:rgba(10,24,48,.85);backdrop-filter:blur(12px);border-bottom:1px solid var(--line)}
.search{flex:1;max-width:440px;display:flex;align-items:center;gap:.6rem;background:var(--surface-2);border:1px solid var(--line);border-radius:10px;padding:.55rem .85rem}
.search i,.search svg{width:18px;height:18px;color:var(--txt-faint)}
.search input{flex:1;background:none;border:none;color:var(--txt);font-size:.92rem}
.search input:focus{outline:none}
.top-actions{display:flex;align-items:center;gap:.6rem;margin-left:auto}
.badge{position:absolute;top:4px;right:4px;background:var(--green);color:var(--navy);font-size:.62rem;font-weight:700;min-width:16px;height:16px;border-radius:9px;display:flex;align-items:center;justify-content:center;padding:0 4px}
.avatar{width:40px;height:40px;border-radius:50%;background:var(--blue);color:#fff;font-family:var(--font-head);font-weight:700;font-size:.92rem;display:flex;align-items:center;justify-content:center}
.only-mobile{display:flex}

.view{padding:1.6rem 1.2rem 3rem;max-width:1180px;width:100%;margin:0 auto}
.page-head{display:flex;align-items:flex-end;justify-content:space-between;gap:1rem;margin-bottom:1.5rem;flex-wrap:wrap}
.page-head h1{font-size:1.7rem}
.page-head p{color:var(--txt-dim);margin-top:.3rem;font-size:.95rem;max-width:60ch}

@media(min-width:980px){
  .shell{grid-template-columns:264px 1fr}
  .sidebar{position:sticky;transform:none}
  .only-mobile{display:none}
  .scrim{display:none}
  .view{padding:2rem 2rem 4rem}
}

/* ============ KPI ============ */
.kpi-row{display:grid;grid-template-columns:repeat(2,1fr);gap:.9rem;margin-bottom:1.5rem}
.kpi{background:var(--surface);border:1px solid var(--line);border-radius:var(--r);padding:1.2rem}
.kpi-ic{display:inline-flex;width:38px;height:38px;border-radius:10px;align-items:center;justify-content:center;background:rgba(255,255,255,.06);color:var(--txt-dim);margin-bottom:.8rem}
.kpi-ic i,.kpi-ic svg{width:20px;height:20px}
.kpi.good .kpi-ic{background:rgba(107,191,84,.15);color:var(--green-light)}
.kpi.warn .kpi-ic{background:rgba(239,159,39,.15);color:#EF9F27}
.kpi-big{font-family:var(--font-head);font-weight:700;font-size:1.8rem;line-height:1}
.kpi-label{color:var(--txt-dim);font-size:.85rem;margin-top:.3rem}
@media(min-width:760px){.kpi-row{grid-template-columns:repeat(4,1fr)}}

/* ============ PANELS / GRID ============ */
.grid-2{display:grid;grid-template-columns:1fr;gap:1.2rem}
@media(min-width:900px){.grid-2{grid-template-columns:1fr 1fr}}
.panel{background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg);padding:1.3rem}
.panel-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:1rem}
.panel-head h2{font-size:1.1rem}
.link{font-size:.85rem;font-weight:600}

/* feed */
.feed{display:flex;flex-direction:column;gap:.2rem}
.feed-item{display:flex;align-items:center;gap:.7rem;padding:.6rem 0;border-bottom:1px solid var(--line);font-size:.9rem}
.feed-item:last-child{border-bottom:none}
.fi-ic{width:30px;height:30px;border-radius:8px;display:flex;align-items:center;justify-content:center;flex:none;background:rgba(255,255,255,.06);color:var(--txt-dim)}
.fi-ic i,.fi-ic svg{width:16px;height:16px}
.fi-check{background:rgba(107,191,84,.15);color:var(--green-light)}
.fi-ticket{background:rgba(143,200,240,.15);color:var(--sky)}
.fi-alert{background:rgba(239,159,39,.15);color:#EF9F27}
.fi-invoice{background:rgba(107,191,84,.13);color:var(--green-light)}
.fi-truck{background:rgba(143,200,240,.13);color:var(--sky)}

/* mini job */
.mini-job{display:flex;align-items:center;justify-content:space-between;gap:1rem;width:100%;text-align:left;padding:.8rem 0;border-bottom:1px solid var(--line);font-size:.9rem}
.mini-job:last-child{border-bottom:none}
.mj-right{display:flex;align-items:center;gap:.7rem;flex:none}
.bar{width:90px;height:6px;border-radius:6px;background:rgba(255,255,255,.1);overflow:hidden}
.bar span{display:block;height:100%;background:var(--green);border-radius:6px;transition:width .4s}
.assign{background:var(--surface-2);border:1px solid var(--line);border-radius:8px;color:var(--txt);padding:.45rem .6rem;font-size:.85rem}

/* ============ TABLES ============ */
.table-wrap{background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg);overflow-x:auto}
.tbl{width:100%;border-collapse:collapse;font-size:.9rem;min-width:680px}
.tbl thead th{text-align:left;padding:.9rem 1rem;color:var(--txt-faint);font-weight:600;font-size:.78rem;text-transform:uppercase;letter-spacing:.06em;border-bottom:1px solid var(--line)}
.tbl tbody td{padding:.85rem 1rem;border-bottom:1px solid var(--line)}
.tbl tbody tr:last-child td{border-bottom:none}
.tbl tr.click{cursor:pointer;transition:background var(--t)}
.tbl tr.click:hover{background:rgba(255,255,255,.03)}
.empty{text-align:center;color:var(--txt-faint);padding:2rem!important}

/* filters / chips */
.filters{display:flex;gap:.5rem;flex-wrap:wrap;margin-bottom:1rem}
.chip{background:var(--surface);border:1px solid var(--line);border-radius:999px;padding:.45rem .9rem;font-size:.82rem;font-weight:500;color:var(--txt-dim);transition:all var(--t)}
.chip:hover{color:var(--txt)}
.chip.active{background:rgba(107,191,84,.15);border-color:rgba(107,191,84,.4);color:var(--green-light)}

/* pills */
.pill{display:inline-block;font-size:.72rem;font-weight:600;padding:.22rem .6rem;border-radius:999px;font-family:var(--font-head);white-space:nowrap}
.s-scheduled{background:rgba(143,200,240,.16);color:var(--sky)}
.s-dispatched{background:rgba(143,200,240,.2);color:var(--sky)}
.s-in_progress{background:rgba(239,159,39,.16);color:#EF9F27}
.s-completed{background:rgba(107,191,84,.16);color:var(--green-light)}
.s-validated{background:rgba(107,191,84,.2);color:var(--green-light)}
.s-invoiced{background:rgba(107,191,84,.26);color:var(--green-light)}
.s-pass,.s-active,.s-paid,.s-billed{background:rgba(107,191,84,.18);color:var(--green-light)}
.s-fail,.s-down,.s-overdue,.s-disputed{background:rgba(226,75,74,.18);color:#F09595}
.s-pending,.s-draft,.s-idle,.s-submitted,.s-maintenance,.s-sent{background:rgba(239,159,39,.16);color:#EF9F27}
.s-off_shift,.s-on_job,.s-available{background:rgba(143,200,240,.16);color:var(--sky)}
.pri{font-size:.72rem;font-weight:600;padding:.22rem .55rem;border-radius:6px;font-family:var(--font-head)}
.p-low{background:rgba(255,255,255,.08);color:var(--txt-dim)}
.p-medium{background:rgba(143,200,240,.15);color:var(--sky)}
.p-high{background:rgba(239,159,39,.16);color:#EF9F27}
.p-critical{background:rgba(226,75,74,.18);color:#F09595}

/* callout */
.callout{display:flex;align-items:center;gap:.8rem;background:rgba(239,159,39,.1);border:1px solid rgba(239,159,39,.3);border-radius:var(--r);padding:1rem 1.2rem;margin-bottom:1.3rem;font-size:.92rem}
.callout i,.callout svg{width:22px;height:22px;color:#EF9F27;flex:none}
.callout strong{font-family:var(--font-head)}
.callout.good{background:rgba(107,191,84,.1);border-color:rgba(107,191,84,.3)}
.callout.good i,.callout.good svg{color:var(--green-light)}

/* cards */
.cards{display:grid;grid-template-columns:1fr;gap:1rem}
@media(min-width:680px){.cards{grid-template-columns:repeat(2,1fr)}}
@media(min-width:1040px){.cards{grid-template-columns:repeat(3,1fr)}}
.card{background:var(--surface);border:1px solid var(--line);border-radius:var(--r);padding:1.2rem;position:relative}
.card.r-bad{border-color:rgba(226,75,74,.35)}
.card.r-warn{border-color:rgba(239,159,39,.3)}
.card.r-good{border-color:var(--line)}
.card-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:.7rem;font-size:.8rem;color:var(--txt-faint)}
.card h3{font-size:1.05rem;margin-bottom:.3rem}
.insp-meta{display:flex;justify-content:space-between;margin:.9rem 0;font-size:.82rem;color:var(--txt-dim)}
.ok-line{display:flex;align-items:center;gap:.5rem;color:var(--green-light);font-size:.85rem;margin-top:.8rem}
.ok-line i,.ok-line svg{width:16px;height:16px}
.predict{display:flex;align-items:center;gap:.5rem;color:#EF9F27;font-size:.85rem;margin:.8rem 0}
.predict i,.predict svg{width:16px;height:16px}

/* dispatch board */
.board{display:grid;grid-template-columns:1fr;gap:1rem;margin-bottom:1.4rem}
@media(min-width:680px){.board{grid-template-columns:repeat(2,1fr)}}
@media(min-width:1040px){.board{grid-template-columns:repeat(4,1fr)}}
.crew-col{background:var(--surface);border:1px solid var(--line);border-radius:var(--r);padding:1rem}
.crew-head{display:flex;justify-content:space-between;align-items:flex-start;gap:.5rem;margin-bottom:.5rem}
.loc{display:flex;align-items:center;gap:.4rem;margin-bottom:.8rem}
.loc i,.loc svg{width:14px;height:14px}
.crew-jobs{display:flex;flex-direction:column;gap:.5rem}
.cj{background:var(--surface-2);border:1px solid var(--line);border-radius:8px;padding:.6rem .7rem;font-size:.85rem;cursor:pointer;transition:border-color var(--t)}
.cj:hover{border-color:rgba(107,191,84,.4)}
.pad{padding:.6rem 0}

/* health */
.health{display:flex;align-items:center;gap:.6rem}
.health-bar{width:80px;height:6px;border-radius:6px;background:rgba(255,255,255,.1);overflow:hidden}
.health-bar span{display:block;height:100%;border-radius:6px}
.h-good{background:var(--green)}.h-warn{background:#EF9F27}.h-bad{background:#E24B4A}

/* analytics */
.vbars{display:flex;align-items:flex-end;gap:.8rem;height:180px;padding-top:1rem}
.vbar{flex:1;display:flex;flex-direction:column;align-items:center;gap:.5rem;height:100%}
.vb{flex:1;width:100%;display:flex;align-items:flex-end;background:rgba(255,255,255,.04);border-radius:6px;overflow:hidden}
.vb span{display:block;width:100%;background:linear-gradient(var(--green-light),var(--green));border-radius:6px 6px 0 0;min-height:8px}
.vb-label{font-size:.72rem;color:var(--txt-faint);text-align:center}
.vb-num{font-family:var(--font-head);font-weight:700;font-size:.9rem}
.spark{width:100%;height:90px}

/* ============ MODAL ============ */
.modal-scrim{position:fixed;inset:0;background:rgba(2,12,28,.7);backdrop-filter:blur(4px);z-index:100;display:flex;align-items:center;justify-content:center;padding:1.2rem}
.modal{background:var(--bg);border:1px solid var(--line);border-radius:var(--r-lg);width:100%;max-width:540px;max-height:90vh;overflow-y:auto;box-shadow:0 30px 80px -20px rgba(0,0,0,.6)}
.modal-head{display:flex;align-items:center;justify-content:space-between;padding:1.2rem 1.4rem;border-bottom:1px solid var(--line);position:sticky;top:0;background:var(--bg)}
.modal-head h3{font-size:1.15rem}
.modal-body{padding:1.4rem}
.job-detail .jd-meta{display:flex;gap:.5rem;align-items:center;margin-bottom:1.2rem}
.jd-val{margin-left:auto;font-family:var(--font-head);font-weight:700;font-size:1.1rem}
.jd-grid{display:grid;grid-template-columns:1fr 1fr;gap:1rem;margin-bottom:1.4rem}
.jd-grid .lbl,.jd-steps .lbl{display:block;font-size:.74rem;text-transform:uppercase;letter-spacing:.06em;color:var(--txt-faint);margin-bottom:.25rem}
.jd-steps{margin-bottom:1.4rem}
.step{display:flex;align-items:center;gap:.7rem;padding:.6rem .2rem;cursor:pointer;font-size:.92rem;border-bottom:1px solid var(--line)}
.step:last-child{border-bottom:none}
.step input{position:absolute;opacity:0;width:0;height:0}
.step-box{width:24px;height:24px;border-radius:7px;border:2px solid var(--line);display:flex;align-items:center;justify-content:center;color:transparent;flex:none;transition:all var(--t)}
.step-box i,.step-box svg{width:15px;height:15px}
.step.done .step-box{background:var(--green);border-color:var(--green);color:var(--navy)}
.step.done span:last-child{color:var(--txt-faint);text-decoration:line-through}
.jd-actions{display:flex;gap:.7rem;flex-wrap:wrap}

/* ============ TOASTS ============ */
.toasts{position:fixed;bottom:1.2rem;right:1.2rem;z-index:200;display:flex;flex-direction:column;gap:.6rem}
.toast{display:flex;align-items:center;gap:.6rem;background:var(--surface);border:1px solid rgba(107,191,84,.4);border-radius:10px;padding:.8rem 1.1rem;font-size:.9rem;box-shadow:0 14px 40px -12px rgba(0,0,0,.5);animation:slidein .3s var(--t)}
.toast i,.toast svg{width:18px;height:18px;color:var(--green-light);flex:none}
.toast.bad{border-color:rgba(226,75,74,.4)}
.toast.bad i,.toast.bad svg{color:#F09595}
.toast.out{opacity:0;transform:translateX(20px);transition:.3s}
@keyframes slidein{from{opacity:0;transform:translateX(20px)}to{opacity:1;transform:none}}

@media(prefers-reduced-motion:reduce){*{animation-duration:.001ms!important;transition-duration:.001ms!important}}
