/* ═══════════════════════════════════════════════════════════════════════
   Superior Water Truck Rental — standalone storefront design system
   2026-06-08 WDM. CRM-client build. Standalone per standing rules:
   no ATG family band, no sister-site links, no rebuild messaging.
   Water/steel palette · Inter · agency-grade.
   ═══════════════════════════════════════════════════════════════════════ */
:root{
  --bg:#f6f8fa; --surface:#fff; --surface-2:#eef2f6; --stripe:#e8eef3;
  --line:#dde5ec; --line-2:#c3d0db;
  --ink:#0d1b24; --ink-2:#2b3b46; --ink-3:#566773; --ink-4:#8595a0;
  --steel:#1f4e6b; --steel-dark:#14384e;
  --water:#1c84c6; --water-dark:#13639a; --water-soft:#e4f0f8;
  --cta:#0f7a52; --cta-dark:#0b5c3e;   /* go-green for book CTA */
  --gold:#c8901a;
  --f:#0d1b24;
  --f-display:"Inter",-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;
  --f-mono:"JetBrains Mono",ui-monospace,Consolas,monospace;
  --s1:4px;--s2:8px;--s3:12px;--s4:16px;--s5:20px;--s6:24px;--s7:32px;--s8:40px;--s9:48px;--s10:64px;--s11:80px;
  --r1:4px;--r2:8px;--r3:12px;--r4:16px;--rp:999px;
  --sh1:0 1px 2px rgba(13,27,36,.06),0 2px 6px rgba(13,27,36,.05);
  --sh2:0 4px 14px rgba(13,27,36,.07),0 8px 28px rgba(13,27,36,.05);
  --sh3:0 8px 24px rgba(13,27,36,.09),0 16px 48px rgba(13,27,36,.06);
  --w:1200px;
}
*,*::before,*::after{box-sizing:border-box}
html,body{margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{font-family:var(--f-display);font-size:16px;line-height:1.55;color:var(--ink);background:var(--bg);-webkit-font-smoothing:antialiased;min-height:100vh}
img{display:block;max-width:100%;height:auto}
svg{display:block}
a{color:var(--water-dark);text-decoration:none}
a:hover{color:var(--steel)}
button{font:inherit;cursor:pointer}

/* strip */
.strip{background:var(--ink);color:#fff;font-size:12.5px}
.strip__in{max-width:var(--w);margin:0 auto;padding:9px var(--s6);display:flex;flex-wrap:wrap;gap:var(--s3) var(--s5);align-items:center}
.strip__i{display:inline-flex;align-items:center;gap:7px;color:rgba(255,255,255,.85)}
.strip__i svg{width:14px;height:14px;color:var(--water)}
.strip__sep{color:rgba(255,255,255,.28)}
.strip__ph{margin-left:auto;font-weight:600;color:#fff}
@media(max-width:720px){.strip__sep{display:none}.strip__ph{margin-left:0;flex-basis:100%;border-top:1px solid rgba(255,255,255,.1);padding-top:5px;margin-top:3px}}

/* nav */
.nav{background:var(--surface);border-bottom:1px solid var(--line);position:sticky;top:0;z-index:50;transition:box-shadow .2s}
.nav--sc{box-shadow:var(--sh1)}
.nav__in{max-width:var(--w);margin:0 auto;padding:var(--s3) var(--s6);display:flex;align-items:center;gap:var(--s5)}
.brand{display:flex;align-items:center;gap:var(--s3);color:var(--ink)}
.brand__mk{width:40px;height:40px;border-radius:var(--r2);background:linear-gradient(135deg,var(--steel),var(--water-dark));display:grid;place-items:center;flex-shrink:0}
.brand__mk svg{width:24px;height:24px;color:#fff}
.brand__t{display:flex;flex-direction:column;line-height:1.1}
.brand__n{font-weight:800;font-size:16.5px;letter-spacing:-.02em}
.brand__s{font-family:var(--f-mono);font-size:10px;font-weight:500;letter-spacing:.06em;text-transform:uppercase;color:var(--ink-4);margin-top:2px}
.nav__sp{flex:1}
.nav__ph{display:inline-flex;align-items:center;gap:7px;font-weight:700;font-size:15px;color:var(--ink)}
.nav__ph svg{width:16px;height:16px;color:var(--cta)}
.nav__cta{display:inline-flex;align-items:center;gap:7px;background:var(--cta);color:#fff;padding:9px 18px;border-radius:var(--rp);font-weight:600;font-size:14px;transition:background .15s}
.nav__cta:hover{background:var(--cta-dark);color:#fff}
@media(max-width:640px){.nav__ph span{display:none}}

/* hero */
.hero{padding:clamp(40px,7vw,88px) var(--s6);background:linear-gradient(180deg,var(--bg),var(--surface-2));border-bottom:1px solid var(--line)}
.hero__in{max-width:var(--w);margin:0 auto;display:grid;grid-template-columns:1.1fr .9fr;gap:clamp(28px,5vw,64px);align-items:center}
@media(max-width:880px){.hero__in{grid-template-columns:1fr}}
.hero__eb{display:inline-block;font-family:var(--f-mono);font-size:11.5px;font-weight:600;letter-spacing:.12em;text-transform:uppercase;color:var(--water-dark);background:var(--water-soft);padding:5px 10px;border-radius:var(--r1);margin-bottom:18px}
.hero__h1{font-size:clamp(32px,5vw,54px);line-height:1.05;letter-spacing:-.025em;font-weight:800;margin:0 0 var(--s5);max-width:16ch}
.hero__lede{font-size:clamp(16px,1.4vw,18.5px);color:var(--ink-3);line-height:1.55;margin:0 0 var(--s7);max-width:52ch}
.hero__cta{display:flex;flex-wrap:wrap;gap:var(--s3)}
.hero__art{border-radius:var(--r4);overflow:hidden;box-shadow:var(--sh3);aspect-ratio:4/3;background:linear-gradient(160deg,#bfe0f3,#7fb9dc)}
.hero__art svg{width:100%;height:100%}

/* buttons */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:13px 24px;border-radius:var(--rp);font-weight:600;font-size:15px;border:1px solid transparent;transition:background .15s,transform .12s,border-color .15s;white-space:nowrap}
.btn svg{width:15px;height:15px}
.btn:hover{transform:translateY(-1px)}
.btn--p{background:var(--cta);color:#fff}
.btn--p:hover{background:var(--cta-dark);color:#fff}
.btn--g{background:transparent;color:var(--ink);border-color:var(--line-2)}
.btn--g:hover{background:var(--surface-2);color:var(--ink)}
.btn--w{background:var(--water-dark);color:#fff}
.btn--w:hover{background:var(--steel);color:#fff}
.btn--lg{padding:16px 30px;font-size:16px}
.btn--block{width:100%}
.btn:disabled{opacity:.5;cursor:not-allowed;transform:none}

/* sections */
.sec{padding:clamp(48px,7vw,88px) var(--s6)}
.sec__in{max-width:var(--w);margin:0 auto}
.sec__head{margin-bottom:var(--s8);max-width:60ch}
.eb{font-family:var(--f-mono);font-size:11.5px;font-weight:600;letter-spacing:.12em;text-transform:uppercase;color:var(--water-dark);margin-bottom:10px}
.h2{font-size:clamp(26px,3.4vw,38px);line-height:1.1;letter-spacing:-.02em;font-weight:800;margin:0}
.lede{font-size:16px;color:var(--ink-3);line-height:1.55;margin:var(--s4) 0 0;max-width:56ch}

/* truck grid */
.fleet{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:var(--s5)}
.tcard{background:var(--surface);border:1px solid var(--line);border-radius:var(--r3);overflow:hidden;display:flex;flex-direction:column;transition:transform .15s,box-shadow .2s,border-color .15s}
.tcard:hover{transform:translateY(-3px);box-shadow:var(--sh2);border-color:var(--water)}
.tcard__ph{aspect-ratio:4/3;background:var(--stripe);position:relative;overflow:hidden}
.tcard__ph img{width:100%;height:100%;object-fit:cover}
.tcard__ph .ph-fallback{width:100%;height:100%;display:grid;place-items:center;background:linear-gradient(160deg,#cfe6f4,#9cc8e3)}
.tcard__ph .ph-fallback svg{width:46%;height:46%;color:#fff;opacity:.85}
.tcard__badge{position:absolute;top:10px;left:10px;font-family:var(--f-mono);font-size:10px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;padding:4px 9px;border-radius:var(--r1)}
.tcard__badge--ok{background:var(--cta);color:#fff}
.tcard__badge--out{background:var(--ink-4);color:#fff}
.tcard__body{padding:var(--s5);display:flex;flex-direction:column;gap:8px;flex:1}
.tcard__title{font-weight:700;font-size:17px;letter-spacing:-.01em}
.tcard__stock{font-family:var(--f-mono);font-size:11.5px;font-weight:600;color:var(--ink-4)}
.tcard__desc{font-size:13.5px;color:var(--ink-3);line-height:1.45}
.tcard__foot{margin-top:auto;padding-top:var(--s3);border-top:1px solid var(--line);display:flex;justify-content:space-between;align-items:center;gap:var(--s3)}
.tcard__rate{font-weight:800;font-size:19px;letter-spacing:-.01em}
.tcard__rate small{font-weight:500;font-size:12px;color:var(--ink-4)}

/* demo banner */
.demobar{background:var(--gold);color:#1a1205;font-size:12.5px;font-weight:600;text-align:center;padding:7px var(--s4)}

/* booking flow */
.book{max-width:920px;margin:0 auto;padding:clamp(32px,5vw,56px) var(--s6)}
.steps{display:flex;gap:8px;margin-bottom:var(--s7);flex-wrap:wrap}
.step{flex:1;min-width:120px;font-family:var(--f-mono);font-size:11px;font-weight:600;letter-spacing:.04em;text-transform:uppercase;color:var(--ink-4);padding:10px 12px;border-radius:var(--r2);background:var(--surface-2);text-align:center}
.step.is-on{background:var(--steel);color:#fff}
.step.is-done{background:var(--cta);color:#fff}
.panel{background:var(--surface);border:1px solid var(--line);border-radius:var(--r3);padding:var(--s6);margin-bottom:var(--s5)}
.panel__h{font-size:18px;font-weight:700;letter-spacing:-.01em;margin:0 0 var(--s4);display:flex;align-items:center;gap:10px}
.field{display:flex;flex-direction:column;gap:6px;margin-bottom:var(--s4)}
.field:last-child{margin-bottom:0}
.field label{font-size:13px;font-weight:600;color:var(--ink-2)}
.req{color:#b4341c;font-weight:700}
.field input,.field select,.field textarea{font:inherit;font-size:15px;background:#fff;border:1px solid var(--line-2);border-radius:var(--r2);padding:11px 13px;color:var(--ink);width:100%}
.field input:focus,.field select:focus,.field textarea:focus{outline:0;border-color:var(--water);box-shadow:0 0 0 3px var(--water-soft)}
.row2{display:grid;grid-template-columns:1fr 1fr;gap:var(--s4)}
.row2 .field{margin-bottom:0}
@media(max-width:560px){.row2{grid-template-columns:1fr}}
.hint{font-size:12px;color:var(--ink-4);margin-top:4px}

/* lease */
.lease{background:var(--surface-2);border:1px solid var(--line-2);border-radius:var(--r2);padding:var(--s5);font-size:13.5px;max-height:340px;overflow-y:auto}
.lease__banner{background:#fbe9d6;border:1px solid #e0a878;color:#7a3d12;font-weight:600;font-size:12.5px;padding:10px 14px;border-radius:var(--r2);margin-bottom:var(--s4)}
.lease dl{display:grid;grid-template-columns:max-content 1fr;gap:7px var(--s4);margin:0}
.lease dt{font-family:var(--f-mono);font-size:10.5px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--ink-4);padding-top:2px}
.lease dd{margin:0;font-weight:500}
.esign{margin-top:var(--s5);padding-top:var(--s5);border-top:1px dashed var(--line-2)}
.consent{display:flex;align-items:flex-start;gap:10px;font-size:13.5px;color:var(--ink-2);cursor:pointer;margin-top:var(--s3)}
.consent input{width:18px;height:18px;margin-top:1px;accent-color:var(--cta)}

/* order summary */
.osum{background:var(--surface);border:1px solid var(--line);border-radius:var(--r3);padding:var(--s5);position:sticky;top:80px}
.osum__row{display:flex;justify-content:space-between;padding:7px 0;font-size:14px;color:var(--ink-2);border-bottom:1px solid var(--line)}
.osum__row:last-of-type{border-bottom:0}
.osum__total{font-weight:800;font-size:20px;border-top:2px solid var(--ink);margin-top:8px;padding-top:var(--s3)}
.osum__note{font-size:12px;color:var(--ink-4);margin-top:var(--s3);line-height:1.5}

/* pay state */
.paybox{border:1px solid var(--line-2);border-radius:var(--r2);padding:var(--s5);background:#fff}
.pay-pending{background:#fff7e6;border:1px solid #e6c878;color:#6b4a04;font-size:13px;padding:12px 14px;border-radius:var(--r2);line-height:1.5}

/* confirm */
.done{max-width:640px;margin:0 auto;text-align:center;padding:var(--s9) var(--s6)}
.done__ic{width:76px;height:76px;margin:0 auto var(--s5);color:var(--cta)}
.done__ref{font-family:var(--f-mono);font-size:12.5px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--cta-dark);background:#e3f3ea;display:inline-block;padding:5px 12px;border-radius:var(--rp);margin-bottom:var(--s4)}
.done__h{font-size:clamp(26px,3.4vw,34px);line-height:1.15;letter-spacing:-.02em;font-weight:800;margin:0 0 var(--s4)}
.done__card{background:var(--surface);border:1px solid var(--line);border-radius:var(--r3);padding:var(--s5);text-align:left;margin:var(--s6) 0}
.done__card dl{display:grid;grid-template-columns:max-content 1fr;gap:8px var(--s4);margin:0;font-size:13.5px}
.done__card dt{font-family:var(--f-mono);font-size:10.5px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--ink-4);padding-top:2px}
.done__card dd{margin:0}

/* footer */
.foot{background:#0a161e;color:rgba(255,255,255,.7);padding:clamp(40px,6vw,64px) var(--s6) var(--s6)}
.foot__in{max-width:var(--w);margin:0 auto}
.foot__top{display:flex;flex-wrap:wrap;justify-content:space-between;gap:var(--s6);padding-bottom:var(--s6);border-bottom:1px solid rgba(255,255,255,.1)}
.foot__n{font-weight:800;font-size:17px;color:#fff}
.foot__s{font-family:var(--f-mono);font-size:10.5px;letter-spacing:.06em;text-transform:uppercase;color:rgba(255,255,255,.45);margin-top:3px}
.foot__contact{font-size:14px;line-height:1.7}
.foot__contact a{color:#fff}
.foot__bottom{padding-top:var(--s5);font-family:var(--f-mono);font-size:11.5px;color:rgba(255,255,255,.5)}

a:focus-visible,button:focus-visible,input:focus-visible,select:focus-visible,textarea:focus-visible{outline:2px solid var(--water);outline-offset:2px}
@media(prefers-reduced-motion:reduce){*{transition-duration:.01ms!important;animation-duration:.01ms!important}}
