@import url('fonts.css');

/* ============================================================
   Thomas Enterprises — Equipment Rentals
   Rugged coastal theme · black + gold · NC & VA
   ============================================================ */

:root{
  --ink:#0b0c0f;
  --ink-2:#101216;
  --surface:#15181e;
  --surface-2:#1b1f27;
  --line:rgba(255,255,255,.09);
  --line-strong:rgba(255,255,255,.16);

  --gold:#f6a724;
  --gold-bright:#ffc24d;
  --gold-deep:#c97f12;
  --gold-soft:rgba(246,167,36,.14);

  --text:#f4f2ee;
  --muted:#a7abb3;
  --dim:#777c86;

  --maxw:1200px;
  --r:16px;
  --r-sm:11px;
  --shadow:0 24px 60px -24px rgba(0,0,0,.7);
  --shadow-gold:0 18px 50px -18px rgba(246,167,36,.45);
  --ease:cubic-bezier(.22,.61,.36,1);
  --t:.32s var(--ease);
  --section-pad:clamp(4.5rem,9vw,8rem);
}

/* ---------- reset ---------- */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
@media (prefers-reduced-motion:reduce){html{scroll-behavior:auto}*{animation:none!important;transition:none!important}}
body{
  font-family:'Inter',system-ui,-apple-system,Segoe UI,Roboto,sans-serif;
  background:var(--ink);
  color:var(--text);
  line-height:1.65;
  font-size:clamp(1rem,.97rem + .2vw,1.075rem);
  letter-spacing:.005em;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
button{font:inherit;cursor:pointer;border:none;background:none;color:inherit}
ul{list-style:none}
:focus-visible{outline:2px solid var(--gold);outline-offset:3px;border-radius:4px}
::selection{background:var(--gold);color:#1a1205}

/* ---------- layout ---------- */
.container{width:min(100% - 2.5rem,var(--maxw));margin-inline:auto}
.section{padding-block:var(--section-pad);position:relative}
.section--tight{padding-block:clamp(3rem,6vw,5rem)}

/* ---------- typography ---------- */
.display{font-family:'Anton',Impact,sans-serif;font-weight:400;text-transform:uppercase;line-height:.96;letter-spacing:.01em}
.eyebrow{
  display:inline-flex;align-items:center;gap:.6rem;
  font-size:.78rem;font-weight:700;letter-spacing:.22em;text-transform:uppercase;
  color:var(--gold);margin-bottom:1.1rem;
}
.eyebrow::before{content:"";width:26px;height:2px;background:linear-gradient(90deg,var(--gold),transparent)}
.eyebrow--center{justify-content:center}
.eyebrow--center::before{background:var(--gold);width:18px}
.section-title{font-family:'Anton',sans-serif;font-weight:400;text-transform:uppercase;letter-spacing:.01em;line-height:.98;font-size:clamp(2.1rem,1.4rem + 3.2vw,3.9rem)}
.section-intro{color:var(--muted);max-width:54ch;margin-top:1.1rem;font-size:1.05rem}
.gold{color:var(--gold)}
.section-head{margin-bottom:clamp(2.5rem,5vw,3.75rem)}
.section-head--center{text-align:center;display:flex;flex-direction:column;align-items:center}

/* hazard stripe accent */
.stripe{height:6px;width:100%;
  background:repeating-linear-gradient(135deg,var(--gold) 0 18px,#0b0c0f 18px 36px);
  opacity:.9}

/* ---------- buttons ---------- */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:.55rem;
  font-weight:700;font-size:.98rem;letter-spacing:.01em;
  padding:.95rem 1.6rem;border-radius:var(--r-sm);
  transition:transform var(--t),box-shadow var(--t),background var(--t),border-color var(--t),color var(--t);
  will-change:transform;white-space:nowrap;
}
.btn svg{width:1.05em;height:1.05em}
.btn-primary{background:linear-gradient(180deg,var(--gold-bright),var(--gold));color:#1a1205;box-shadow:var(--shadow-gold)}
.btn-primary:hover{transform:translateY(-3px);box-shadow:0 24px 60px -16px rgba(246,167,36,.6)}
.btn-ghost{background:rgba(255,255,255,.04);color:var(--text);border:1px solid var(--line-strong)}
.btn-ghost:hover{background:rgba(255,255,255,.09);border-color:var(--gold);transform:translateY(-3px)}
.btn-dark{background:#0c0d10;color:var(--text);border:1px solid var(--line-strong)}
.btn-dark:hover{transform:translateY(-3px);border-color:var(--gold)}
.btn-lg{padding:1.1rem 2rem;font-size:1.05rem}
.btn-block{width:100%}

/* ---------- utility bar ---------- */
.util-bar{
  background:#070809;color:var(--muted);font-size:.82rem;
  border-bottom:1px solid var(--line);
}
.util-inner{display:flex;justify-content:space-between;align-items:center;gap:1rem;padding-block:.5rem}
.util-bar b{color:var(--text);font-weight:600}
.util-bar .sep{color:var(--gold);margin-inline:.55rem}
.util-bar a{transition:color var(--t)}
.util-bar a:hover{color:var(--gold)}
@media (max-width:760px){.util-left{display:none}.util-inner{justify-content:center}}

/* ---------- header ---------- */
.site-header{position:sticky;top:0;z-index:60;
  background:rgba(11,12,15,.72);backdrop-filter:blur(14px);
  border-bottom:1px solid transparent;transition:background var(--t),border-color var(--t),box-shadow var(--t)}
.site-header.scrolled{background:rgba(9,10,13,.92);border-bottom-color:var(--line);box-shadow:0 10px 30px -18px rgba(0,0,0,.8)}
.nav-inner{display:flex;align-items:center;justify-content:space-between;gap:1.5rem;padding-block:.7rem}
.brand{display:flex;align-items:center;gap:.7rem}
.brand-logo{width:46px;height:46px;border-radius:9px;background:#fff;padding:2px;flex:none;box-shadow:0 4px 14px rgba(0,0,0,.4)}
.brand-text{display:flex;flex-direction:column;line-height:1.05}
.brand-name{font-family:'Anton',sans-serif;font-size:1.18rem;letter-spacing:.04em;text-transform:uppercase}
.brand-sub{font-size:.62rem;letter-spacing:.24em;text-transform:uppercase;color:var(--gold);font-weight:600}
.nav-links{display:flex;align-items:center;gap:2rem}
.nav-links a{font-size:.94rem;font-weight:500;color:var(--muted);position:relative;transition:color var(--t)}
.nav-links a::after{content:"";position:absolute;left:0;bottom:-6px;height:2px;width:0;background:var(--gold);transition:width var(--t)}
.nav-links a:hover{color:var(--text)}.nav-links a:hover::after{width:100%}
.nav-right{display:flex;align-items:center;gap:1rem}
.nav-phone{display:inline-flex;align-items:center;gap:.45rem;font-weight:700;color:var(--text);font-size:.96rem}
.nav-phone svg{width:1rem;height:1rem;color:var(--gold)}
.nav-toggle{display:none;width:44px;height:44px;border-radius:10px;border:1px solid var(--line-strong);align-items:center;justify-content:center;flex-direction:column;gap:5px}
.nav-toggle span{width:20px;height:2px;background:var(--text);transition:transform var(--t),opacity var(--t)}
.nav-toggle[aria-expanded="true"] span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.nav-toggle[aria-expanded="true"] span:nth-child(2){opacity:0}
.nav-toggle[aria-expanded="true"] span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

.mobile-menu{position:fixed;inset:0 0 0 auto;width:min(86vw,360px);z-index:70;
  background:var(--ink-2);border-left:1px solid var(--line);
  transform:translateX(100%);transition:transform .4s var(--ease);
  display:flex;flex-direction:column;padding:1.4rem;gap:.3rem;
  box-shadow:-30px 0 70px -30px rgba(0,0,0,.8)}
.mobile-menu.open{transform:translateX(0)}
.mobile-menu .mm-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}
.mobile-menu a{padding:.95rem .6rem;border-radius:10px;font-weight:600;font-size:1.05rem;border-bottom:1px solid var(--line);transition:background var(--t),color var(--t)}
.mobile-menu a:hover{background:var(--gold-soft);color:var(--gold)}
.mm-close{width:42px;height:42px;border-radius:10px;border:1px solid var(--line-strong);font-size:1.5rem;line-height:1}
.mm-actions{margin-top:auto;display:grid;gap:.6rem;padding-top:1rem}
.scrim{position:fixed;inset:0;background:rgba(0,0,0,.55);backdrop-filter:blur(2px);z-index:65;opacity:0;visibility:hidden;transition:opacity var(--t),visibility var(--t)}
.scrim.show{opacity:1;visibility:visible}

/* ---------- hero ---------- */
.hero{position:relative;overflow:hidden;padding-block:clamp(3.5rem,7vw,6.5rem) clamp(4rem,7vw,7rem)}
.hero::before{content:"";position:absolute;inset:0;z-index:-2;
  background:
   radial-gradient(900px 520px at 78% 12%,rgba(246,167,36,.16),transparent 60%),
   radial-gradient(700px 500px at 8% 90%,rgba(246,167,36,.07),transparent 55%),
   linear-gradient(180deg,#0d0f13,#0b0c0f 60%)}
.hero::after{content:"";position:absolute;inset:0;z-index:-1;opacity:.5;
  background-image:radial-gradient(rgba(255,255,255,.04) 1px,transparent 1px);background-size:26px 26px;
  -webkit-mask-image:linear-gradient(180deg,#000,transparent 80%)}
.hero-grid{display:grid;grid-template-columns:1.08fr .92fr;gap:clamp(2rem,5vw,4.5rem);align-items:center}
.hero h1{font-family:'Anton',sans-serif;text-transform:uppercase;line-height:.94;letter-spacing:0;
  font-size:clamp(2.5rem,1.2rem + 5.6vw,5rem);margin-block:.2rem .3rem}
.hero h1 .ln{display:block;white-space:nowrap}
.hero-sub{color:var(--muted);font-size:clamp(1.05rem,1rem + .4vw,1.22rem);max-width:46ch;margin-top:1.2rem}
.hero-actions{display:flex;flex-wrap:wrap;gap:.9rem;margin-top:2rem}
.hero-chips{display:flex;flex-wrap:wrap;gap:.6rem;margin-top:2rem}
.chip{display:inline-flex;align-items:center;gap:.5rem;font-size:.85rem;font-weight:600;color:var(--muted);
  background:rgba(255,255,255,.04);border:1px solid var(--line);padding:.5rem .9rem;border-radius:999px}
.chip svg{width:1rem;height:1rem;color:var(--gold)}

.hero-media{position:relative}
.hero-frame{position:relative;border-radius:var(--r);overflow:hidden;border:1px solid var(--line-strong);
  box-shadow:var(--shadow);transform:rotate(.6deg)}
.hero-frame img{width:100%;height:clamp(320px,42vw,520px);object-fit:cover;transform:scale(1.02)}
.hero-frame::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 40%,rgba(8,9,11,.55))}
.hero-badge{position:absolute;z-index:2;background:rgba(13,15,19,.86);backdrop-filter:blur(8px);
  border:1px solid var(--line-strong);border-radius:14px;padding:.85rem 1.05rem;box-shadow:var(--shadow)}
.hero-badge--tr{top:1rem;right:-.6rem}
.hero-badge--bl{bottom:1rem;left:-.6rem;display:flex;align-items:center;gap:.7rem}
.hero-badge .big{font-family:'Anton',sans-serif;font-size:1.5rem;color:var(--gold);line-height:1}
.hero-badge .lbl{font-size:.72rem;color:var(--muted);text-transform:uppercase;letter-spacing:.12em}
.hb-stars{color:var(--gold);font-size:.95rem;letter-spacing:.05em}

/* ---------- stats strip ---------- */
.stats{border-block:1px solid var(--line);background:linear-gradient(180deg,#0e1014,#0b0c0f)}
.stats-grid{display:grid;grid-template-columns:repeat(4,1fr)}
.stat{padding:clamp(1.6rem,3vw,2.4rem) 1rem;text-align:center;border-left:1px solid var(--line)}
.stat:first-child{border-left:none}
.stat-num{font-family:'Anton',sans-serif;font-size:clamp(1.9rem,1.4rem + 2vw,2.9rem);color:var(--gold);line-height:1}
.stat-label{margin-top:.4rem;color:var(--muted);font-size:.86rem;font-weight:500;letter-spacing:.02em}
@media (max-width:640px){.stats-grid{grid-template-columns:1fr 1fr}.stat:nth-child(odd){border-left:none}.stat:nth-child(n+3){border-top:1px solid var(--line)}}

/* ---------- services ---------- */
.services-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.25rem}
.service-card{position:relative;background:linear-gradient(180deg,var(--surface),var(--ink-2));
  border:1px solid var(--line);border-radius:var(--r);padding:1.9rem 1.7rem;overflow:hidden;
  transition:transform var(--t),border-color var(--t),box-shadow var(--t)}
.service-card::before{content:"";position:absolute;left:0;top:0;height:3px;width:0;background:linear-gradient(90deg,var(--gold),var(--gold-bright));transition:width .4s var(--ease)}
.service-card:hover{transform:translateY(-6px);border-color:var(--line-strong);box-shadow:var(--shadow)}
.service-card:hover::before{width:100%}
.svc-icon{width:54px;height:54px;border-radius:13px;display:grid;place-items:center;margin-bottom:1.15rem;
  background:var(--gold-soft);border:1px solid rgba(246,167,36,.3);color:var(--gold)}
.svc-icon svg{width:26px;height:26px}
.service-card h3{font-size:1.3rem;font-weight:700;letter-spacing:-.01em;margin-bottom:.55rem}
.service-card p{color:var(--muted);font-size:.97rem}
.svc-more{margin-top:2.25rem;text-align:center}
.svc-more a{display:inline-flex;align-items:center;gap:.5rem;font-weight:700;color:var(--gold)}
.svc-more a svg{width:1.1em;height:1.1em;transition:transform var(--t)}
.svc-more a:hover svg{transform:translateX(5px)}
/* rentals-first layout */
.services-grid--rentals{grid-template-columns:1fr 1fr;gap:1.5rem;max-width:920px;margin-inline:auto}
.services-grid--also{grid-template-columns:repeat(3,1fr);gap:1.1rem;margin-top:1.5rem}
.service-card.feat{background:linear-gradient(180deg,rgba(246,167,36,.07),var(--ink-2));border-color:rgba(246,167,36,.35);padding-top:2.1rem}
.service-card.feat::before{width:100%;background:linear-gradient(90deg,var(--gold-deep),var(--gold),var(--gold-bright))}
.service-card.feat:hover{border-color:var(--gold);box-shadow:var(--shadow-gold)}
.svc-tag{position:absolute;top:1rem;right:1rem;background:var(--gold);color:#1a1205;font-size:.72rem;font-weight:800;
  letter-spacing:.06em;text-transform:uppercase;padding:.32rem .7rem;border-radius:999px}
.svc-link{display:inline-flex;align-items:center;gap:.45rem;margin-top:1.2rem;font-weight:700;color:var(--gold);font-size:.95rem}
.svc-link svg{width:1.05em;height:1.05em;transition:transform var(--t)}
.svc-link:hover svg{transform:translateX(5px)}
.svc-divider{text-align:center;color:var(--dim);font-weight:600;font-size:.92rem;margin-top:3rem;
  text-transform:uppercase;letter-spacing:.1em}
@media (max-width:720px){.services-grid--rentals,.services-grid--also{grid-template-columns:1fr}}

/* ---------- fleet ---------- */
.fleet{background:linear-gradient(180deg,#0b0c0f,#0e1014)}
.fleet-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.1rem}
.fleet-item{position:relative;border-radius:var(--r);overflow:hidden;border:1px solid var(--line);
  cursor:zoom-in;aspect-ratio:4/3;transition:transform var(--t),box-shadow var(--t),border-color var(--t)}
.fleet-item img{width:100%;height:100%;object-fit:cover;transition:transform .6s var(--ease)}
.fleet-item:hover{transform:translateY(-5px);box-shadow:var(--shadow);border-color:var(--line-strong)}
.fleet-item:hover img{transform:scale(1.07)}
.fleet-cap{position:absolute;left:0;right:0;bottom:0;padding:1.4rem 1.1rem .95rem;
  background:linear-gradient(transparent,rgba(7,8,10,.9));
  font-weight:600;font-size:.95rem;display:flex;align-items:center;justify-content:space-between}
.fleet-cap span{color:var(--gold);font-size:.78rem;text-transform:uppercase;letter-spacing:.1em;font-weight:700}
.fleet-zoom{position:absolute;top:.8rem;right:.8rem;width:34px;height:34px;border-radius:9px;
  background:rgba(13,15,19,.7);border:1px solid var(--line-strong);display:grid;place-items:center;color:#fff;opacity:0;transition:opacity var(--t)}
.fleet-item:hover .fleet-zoom{opacity:1}
.badges-row{display:flex;flex-wrap:wrap;justify-content:center;gap:.7rem;margin-top:2.25rem}
.badge{display:inline-flex;align-items:center;gap:.55rem;font-weight:600;font-size:.88rem;color:var(--muted);
  border:1px solid var(--line);background:rgba(255,255,255,.03);padding:.55rem 1.05rem;border-radius:999px}
.badge svg{width:1.05rem;height:1.05rem;color:var(--gold)}

/* ---------- reserve / how it works ---------- */
.reserve{background:radial-gradient(700px 460px at 50% 0%,rgba(246,167,36,.08),transparent 55%),var(--ink)}
.steps{display:grid;grid-template-columns:repeat(3,1fr);gap:1.25rem;counter-reset:step}
.step{position:relative;background:var(--ink-2);border:1px solid var(--line);border-radius:var(--r);
  padding:2.4rem 1.7rem 1.8rem;transition:transform var(--t),border-color var(--t)}
.step:hover{transform:translateY(-5px);border-color:var(--line-strong)}
.step-num{position:absolute;top:-22px;left:1.7rem;width:46px;height:46px;border-radius:12px;
  display:grid;place-items:center;font-family:'Anton',sans-serif;font-size:1.5rem;
  background:linear-gradient(180deg,var(--gold-bright),var(--gold));color:#1a1205;box-shadow:var(--shadow-gold)}
.step h3{font-size:1.2rem;font-weight:700;margin-bottom:.5rem}
.step p{color:var(--muted);font-size:.96rem}
.step--hl{background:linear-gradient(180deg,rgba(246,167,36,.08),var(--ink-2));border-color:rgba(246,167,36,.4)}
.step--hl .btn{margin-top:1.3rem}
.step-note{display:block;margin-top:.7rem;font-size:.78rem;color:var(--dim);letter-spacing:.04em}
@media (max-width:760px){.steps{grid-template-columns:1fr;gap:2rem}}

/* ---------- why ---------- */
.why-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.1rem}
.why-card{padding:1.7rem;border-radius:var(--r);border:1px solid var(--line);background:var(--ink-2);
  transition:transform var(--t),border-color var(--t),background var(--t)}
.why-card:hover{transform:translateY(-5px);border-color:rgba(246,167,36,.4);background:var(--surface)}
.why-icon{width:46px;height:46px;border-radius:11px;display:grid;place-items:center;margin-bottom:1rem;
  color:var(--gold);background:var(--gold-soft);border:1px solid rgba(246,167,36,.25)}
.why-icon svg{width:23px;height:23px}
.why-card h3{font-size:1.15rem;font-weight:700;margin-bottom:.4rem}
.why-card p{color:var(--muted);font-size:.95rem}

/* ---------- owners / about ---------- */
.owners-grid{display:grid;grid-template-columns:.85fr 1.15fr;gap:clamp(2rem,5vw,4.5rem);align-items:center}
.owners-media{position:relative;width:min(400px,82%);aspect-ratio:1/1;margin-inline:auto}
.owners-media::before{content:"";position:absolute;inset:-7px;border-radius:50%;z-index:0;
  background:conic-gradient(from 200deg,var(--gold),transparent 28%,transparent 72%,var(--gold));opacity:.55}
.owners-media img{position:relative;z-index:1;width:100%;height:100%;border-radius:50%;object-fit:cover;
  border:6px solid var(--ink-2);box-shadow:var(--shadow);background:var(--ink-2)}
.owners-media .tag{position:absolute;bottom:.6rem;right:-.4rem;z-index:2;background:var(--gold);color:#1a1205;
  font-weight:800;padding:.65rem 1.05rem;border-radius:999px;font-size:.88rem;box-shadow:var(--shadow);display:flex;gap:.5rem;align-items:center}
.owners-points{display:grid;grid-template-columns:1fr 1fr;gap:1.1rem 1.5rem;margin-top:1.9rem}
.point{display:flex;gap:.8rem;align-items:flex-start}
.point .pi{flex:none;width:34px;height:34px;border-radius:9px;display:grid;place-items:center;background:var(--gold-soft);color:var(--gold);border:1px solid rgba(246,167,36,.25)}
.point .pi svg{width:18px;height:18px}
.point h4{font-size:1rem;font-weight:700}
.point p{color:var(--muted);font-size:.9rem;line-height:1.5}

/* ---------- testimonials ---------- */
.testimonials{background:linear-gradient(180deg,#0e1014,#0b0c0f)}
.t-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.25rem}
.tcard{background:linear-gradient(180deg,var(--surface),var(--ink-2));border:1px solid var(--line);border-radius:var(--r);
  padding:1.9rem 1.7rem;position:relative;transition:transform var(--t),border-color var(--t)}
.tcard:hover{transform:translateY(-5px);border-color:var(--line-strong)}
.tcard .quote-mark{font-family:'Anton',sans-serif;font-size:3.4rem;color:var(--gold-soft);line-height:.6;position:absolute;top:1.2rem;right:1.3rem}
.stars{color:var(--gold);letter-spacing:.12em;font-size:1rem;margin-bottom:1rem}
.tcard blockquote{font-size:1.05rem;line-height:1.6;color:var(--text);font-weight:500}
.tauthor{margin-top:1.4rem;padding-top:1.1rem;border-top:1px solid var(--line)}
.tauthor b{display:block;font-weight:700}
.tauthor span{color:var(--dim);font-size:.86rem}
.reviews-cta{display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:1.2rem;
  margin-top:2.25rem;padding:1.4rem 1.6rem;border:1px solid var(--line-strong);border-radius:var(--r);
  background:linear-gradient(180deg,var(--surface),var(--ink-2))}
.rc-left{display:flex;align-items:center;gap:1rem}
.g-logo{flex:none;background:#fff;border-radius:8px;padding:5px;box-sizing:content-box;width:30px;height:30px}
.rc-text{display:flex;flex-direction:column}
.rc-text strong{font-size:1.05rem;font-weight:700}
.rc-text span{color:var(--muted);font-size:.9rem}
.rc-actions{display:flex;flex-wrap:wrap;gap:.7rem}
@media (max-width:560px){.reviews-cta{flex-direction:column;align-items:flex-start}.rc-actions{width:100%}.rc-actions .btn{flex:1}}

/* ---------- quote form ---------- */
.quote{background:radial-gradient(800px 500px at 85% 0%,rgba(246,167,36,.1),transparent 55%),var(--ink)}
.quote-grid{display:grid;grid-template-columns:.82fr 1.18fr;gap:clamp(2rem,5vw,3.5rem);align-items:start}
.quote-aside .section-title{font-size:clamp(2rem,1.5rem + 2.5vw,3.2rem)}
.qpoints{margin-top:2rem;display:grid;gap:1.2rem}
.qpoint{display:flex;gap:1rem;align-items:flex-start}
.qpoint .qi{flex:none;width:44px;height:44px;border-radius:11px;background:var(--gold-soft);border:1px solid rgba(246,167,36,.25);color:var(--gold);display:grid;place-items:center}
.qpoint .qi svg{width:22px;height:22px}
.qpoint h4{font-weight:700;font-size:1.05rem}
.qpoint p{color:var(--muted);font-size:.92rem}
.quote-contacts{margin-top:2rem;display:flex;flex-wrap:wrap;gap:.7rem}

.quote-form{background:linear-gradient(180deg,var(--surface),var(--ink-2));border:1px solid var(--line-strong);
  border-radius:var(--r);padding:clamp(1.5rem,3vw,2.4rem);box-shadow:var(--shadow)}
.field{margin-bottom:1.05rem}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
.field label{display:block;font-size:.84rem;font-weight:600;color:var(--muted);margin-bottom:.45rem;letter-spacing:.02em}
.field .req{color:var(--gold)}
.field input,.field select,.field textarea{
  width:100%;background:#0c0e12;border:1px solid var(--line-strong);border-radius:10px;
  padding:.85rem .95rem;color:var(--text);font-size:.97rem;transition:border-color var(--t),box-shadow var(--t),background var(--t)}
.field textarea{resize:vertical;min-height:110px}
.field input::placeholder,.field textarea::placeholder{color:#5e636d}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--gold);background:#0e1116;box-shadow:0 0 0 3px var(--gold-soft)}
.field select{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 24 24' fill='none' stroke='%23f6a724' stroke-width='3'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 1rem center;padding-right:2.5rem}
.radio-group{display:flex;flex-wrap:wrap;gap:.5rem}
.radio-group label{display:inline-flex;align-items:center;gap:.4rem;background:#0c0e12;border:1px solid var(--line-strong);
  border-radius:999px;padding:.5rem .95rem;font-size:.88rem;font-weight:500;color:var(--muted);cursor:pointer;margin:0;transition:all var(--t)}
.radio-group input{position:absolute;opacity:0;width:0;height:0}
.radio-group label:has(input:checked){background:var(--gold-soft);border-color:var(--gold);color:var(--gold)}
.field input[type=file]{padding:.6rem;font-size:.85rem;color:var(--muted)}
.field input[type=file]::file-selector-button{background:var(--gold-soft);color:var(--gold);border:1px solid rgba(246,167,36,.3);border-radius:8px;padding:.4rem .8rem;margin-right:.7rem;font-weight:600;cursor:pointer}
.hp{position:absolute;left:-9999px;opacity:0;height:0;width:0}
.form-note{margin-top:1rem;text-align:center;color:var(--dim);font-size:.84rem}
.form-error{color:#ff8b6b;font-size:.8rem;margin-top:.35rem;display:none}
.field.invalid input,.field.invalid select{border-color:#ff8b6b}
.field.invalid .form-error{display:block}
.form-success{display:none;text-align:center;padding:2rem 1rem}
.form-success.show{display:block;animation:pop .4s var(--ease)}
@keyframes pop{from{opacity:0;transform:scale(.96)}to{opacity:1;transform:scale(1)}}
.form-success .check{width:70px;height:70px;margin:0 auto 1.2rem;border-radius:50%;background:var(--gold-soft);border:1px solid var(--gold);display:grid;place-items:center;color:var(--gold)}
.form-success .check svg{width:34px;height:34px}
.form-success h3{font-family:'Anton',sans-serif;font-size:1.8rem;text-transform:uppercase;margin-bottom:.5rem}
.form-success p{color:var(--muted)}

/* ---------- FAQ ---------- */
.faq-list{max-width:820px;margin-inline:auto;border-top:1px solid var(--line)}
.faq-item{border-bottom:1px solid var(--line)}
.faq-item summary{display:flex;justify-content:space-between;align-items:center;gap:1rem;
  padding:1.4rem .4rem;font-weight:700;font-size:1.1rem;cursor:pointer;list-style:none;transition:color var(--t)}
.faq-item summary::-webkit-details-marker{display:none}
.faq-item summary:hover{color:var(--gold)}
.faq-item .fi-icon{flex:none;width:30px;height:30px;border-radius:8px;border:1px solid var(--line-strong);
  display:grid;place-items:center;color:var(--gold);transition:transform var(--t),background var(--t);font-size:1.3rem;line-height:1}
.faq-item[open] .fi-icon{transform:rotate(45deg);background:var(--gold-soft)}
.faq-item .fi-body{overflow:hidden;color:var(--muted);padding:0 .4rem 1.4rem;max-width:68ch}
.faq-item[open] .fi-body{animation:reveal .4s var(--ease)}
@keyframes reveal{from{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}

/* ---------- service area ---------- */
.area{background:linear-gradient(180deg,#0e1014,#0b0c0f)}
.area-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(2rem,5vw,4rem);align-items:center}
.area-chips{display:flex;flex-wrap:wrap;gap:.6rem;margin-top:1.6rem}
.area-chip{font-weight:600;font-size:.9rem;color:var(--muted);background:rgba(255,255,255,.03);
  border:1px solid var(--line);padding:.5rem 1rem;border-radius:8px}
.area-chip.hub{background:var(--gold-soft);border-color:var(--gold);color:var(--gold)}
.area-map{aspect-ratio:4/3;border-radius:var(--r);border:1px solid var(--line-strong);
  background:radial-gradient(500px 360px at 60% 40%,rgba(246,167,36,.1),transparent),#0c0e12;
  display:grid;place-items:center;overflow:hidden;position:relative}
.area-map svg{width:100%;height:100%}

/* ---------- cta band ---------- */
.cta-band{background:linear-gradient(110deg,var(--gold-deep),var(--gold) 55%,var(--gold-bright));color:#1a1205;text-align:center;position:relative;overflow:hidden}
.cta-band::before{content:"";position:absolute;inset:0;opacity:.13;background-image:radial-gradient(rgba(0,0,0,.5) 1.5px,transparent 1.5px);background-size:22px 22px}
.cta-band .container{position:relative}
.cta-band h2{font-family:'Anton',sans-serif;text-transform:uppercase;font-size:clamp(2rem,1.4rem + 3.5vw,3.6rem);line-height:1}
.cta-band p{font-size:1.15rem;font-weight:600;margin-top:.7rem;opacity:.85}
.cta-actions{display:flex;flex-wrap:wrap;gap:.9rem;justify-content:center;margin-top:2rem}
.cta-band .btn-dark{background:#0c0d10;color:#fff;border-color:#0c0d10}
.cta-band .btn-dark:hover{background:#000}
.cta-band .btn-light{background:#1a1205;color:var(--gold-bright)}

/* ---------- contact ---------- */
.contact-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.1rem}
.contact-card{background:var(--ink-2);border:1px solid var(--line);border-radius:var(--r);padding:1.8rem;
  display:flex;flex-direction:column;gap:.5rem;transition:transform var(--t),border-color var(--t)}
.contact-card:hover{transform:translateY(-5px);border-color:var(--line-strong)}
.contact-card .ci{width:48px;height:48px;border-radius:12px;background:var(--gold-soft);border:1px solid rgba(246,167,36,.25);color:var(--gold);display:grid;place-items:center;margin-bottom:.6rem}
.contact-card .ci svg{width:24px;height:24px}
.contact-card .lbl{font-size:.78rem;text-transform:uppercase;letter-spacing:.14em;color:var(--dim);font-weight:600}
.contact-card .val{font-size:1.25rem;font-weight:700}
.contact-card .val.sm{font-size:1.05rem;word-break:break-word}
.contact-card a.val:hover{color:var(--gold)}

/* ---------- footer ---------- */
.site-footer{background:#070809;border-top:1px solid var(--line);padding-block:clamp(3rem,5vw,4.5rem) 2rem}
.footer-grid{display:grid;grid-template-columns:1.6fr 1fr 1fr;gap:2.5rem}
.foot-brand .brand{margin-bottom:1rem}
.foot-brand p{color:var(--muted);font-size:.95rem;max-width:42ch}
.foot-col h4{font-size:.8rem;text-transform:uppercase;letter-spacing:.16em;color:var(--gold);margin-bottom:1.1rem;font-weight:700}
.foot-col a,.foot-col li{color:var(--muted);font-size:.95rem;padding-block:.3rem;display:block;transition:color var(--t)}
.foot-col a:hover{color:var(--gold)}
.foot-bottom{margin-top:2.8rem;padding-top:1.6rem;border-top:1px solid var(--line);
  display:flex;flex-wrap:wrap;justify-content:space-between;gap:1rem;align-items:center;color:var(--dim);font-size:.85rem}
.foot-bottom .tags{color:var(--dim)}

/* ---------- mobile action bar ---------- */
.mobile-bar{position:fixed;left:0;right:0;bottom:0;z-index:55;display:none;
  grid-template-columns:1fr 1fr 1.3fr;gap:1px;background:var(--line);
  border-top:1px solid var(--line-strong);box-shadow:0 -10px 30px -10px rgba(0,0,0,.6)}
.mbar-btn{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.2rem;
  padding:.6rem;background:var(--ink-2);font-size:.74rem;font-weight:700;color:var(--text)}
.mbar-btn svg{width:1.25rem;height:1.25rem;color:var(--gold)}
.mbar-btn.primary{background:var(--gold);color:#1a1205}
.mbar-btn.primary svg{color:#1a1205}

/* ---------- lightbox ---------- */
.lightbox{position:fixed;inset:0;z-index:90;background:rgba(5,6,8,.94);backdrop-filter:blur(6px);
  display:none;align-items:center;justify-content:center;padding:1.5rem}
.lightbox.open{display:flex;animation:fade .25s ease}
@keyframes fade{from{opacity:0}to{opacity:1}}
.lightbox img{max-width:92vw;max-height:86vh;border-radius:12px;box-shadow:0 30px 80px -20px #000}
.lb-btn{position:absolute;background:rgba(255,255,255,.08);border:1px solid var(--line-strong);
  width:50px;height:50px;border-radius:50%;color:#fff;font-size:1.4rem;display:grid;place-items:center;transition:background var(--t)}
.lb-btn:hover{background:var(--gold);color:#1a1205}
.lb-close{top:1.3rem;right:1.3rem}
.lb-prev{left:1.3rem;top:50%;transform:translateY(-50%)}
.lb-next{right:1.3rem;top:50%;transform:translateY(-50%)}
.lb-cap{position:absolute;bottom:1.4rem;left:0;right:0;text-align:center;color:var(--muted);font-weight:600}

/* ---------- back to top ---------- */
.to-top{position:fixed;right:1.3rem;bottom:1.3rem;z-index:50;width:48px;height:48px;border-radius:50%;
  background:var(--gold);color:#1a1205;display:grid;place-items:center;box-shadow:var(--shadow-gold);
  opacity:0;visibility:hidden;transform:translateY(12px);transition:all var(--t)}
.to-top.show{opacity:1;visibility:visible;transform:translateY(0)}
.to-top svg{width:22px;height:22px}

/* ---------- reveal on scroll ---------- */
.js [data-reveal]{opacity:0;transform:translateY(26px);transition:opacity .7s var(--ease),transform .7s var(--ease)}
.js [data-reveal].in{opacity:1;transform:none}
.js [data-reveal][data-delay="1"]{transition-delay:.08s}
.js [data-reveal][data-delay="2"]{transition-delay:.16s}
.js [data-reveal][data-delay="3"]{transition-delay:.24s}
.js [data-reveal][data-delay="4"]{transition-delay:.32s}
.js [data-reveal][data-delay="5"]{transition-delay:.4s}

/* ---------- responsive ---------- */
@media (max-width:1000px){
  .services-grid,.why-grid,.t-grid,.contact-grid{grid-template-columns:1fr 1fr}
  .footer-grid{grid-template-columns:1fr 1fr}
  .foot-brand{grid-column:1/-1}
}
@media (max-width:880px){
  .nav-links,.nav-phone{display:none}
  .nav-toggle{display:flex}
  .hero-grid{grid-template-columns:1fr}
  .hero-media{order:-1;max-width:540px}
  .owners-grid,.quote-grid,.area-grid{grid-template-columns:1fr}
  .owners-media{max-width:420px}
  .mobile-bar{display:grid}
  body{padding-bottom:64px}
  .to-top{bottom:78px}
}
@media (max-width:620px){
  .services-grid,.why-grid,.t-grid,.contact-grid,.footer-grid,.owners-points{grid-template-columns:1fr}
  .fleet-grid{grid-template-columns:1fr;gap:.9rem}
  .form-row{grid-template-columns:1fr}
  .hero-actions .btn{flex:1 1 100%}
  .hero-badge--tr{right:.4rem}.hero-badge--bl{left:.4rem}
}
