/* =================================================================
   One Touch Heavy Equipment Repair Inc.
   Industrial / heavy-duty theme — asphalt black + hazard yellow
   ================================================================= */

:root{
  --bg:        #0c0c0e;
  --bg-2:      #111114;
  --surface:   #161619;
  --surface-2: #1d1d22;
  --line:      #2a2a31;
  --line-2:    #3a3a43;

  --hazard:    #ffc400;
  --hazard-2:  #ffb000;
  --hazard-soft: rgba(255,196,0,.10);

  --ink:    #f4f3ef;
  --muted:  #adadb6;
  --muted-2:#7c7c87;

  --maxw: 1680px;
  --pad: clamp(1.1rem, 3vw, 2.25rem);

  --radius: 6px;
  --shadow: 0 24px 60px -24px rgba(0,0,0,.85);
  --ease: cubic-bezier(.22,.61,.36,1);

  --font-display: 'Anton', 'Arial Narrow', sans-serif;
  --font-cond: 'Barlow Condensed', sans-serif;
  --font-body: 'Barlow', system-ui, sans-serif;
}

*,*::before,*::after{ box-sizing:border-box; }

html{ scroll-behavior:smooth; scroll-padding-top:120px; }

body{
  margin:0;
  background:var(--bg);
  color:var(--ink);
  font-family:var(--font-body);
  font-size:clamp(1.05rem, .98rem + .35vw, 1.18rem);
  line-height:1.65;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
  /* subtle grain texture */
  background-image:
    radial-gradient(1200px 600px at 80% -10%, rgba(255,196,0,.05), transparent 60%),
    url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.85' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='.035'/%3E%3C/svg%3E");
}

.wrap{ width:min(var(--maxw), 100% - 2*var(--pad)); margin-inline:auto; }

img{ max-width:100%; display:block; }
a{ color:inherit; text-decoration:none; }

/* ---------- Typography helpers ---------- */
.kicker{
  font-family:var(--font-cond);
  text-transform:uppercase;
  letter-spacing:.22em;
  font-weight:600;
  font-size:.82rem;
  color:var(--hazard);
  display:flex; align-items:center; gap:.7rem;
  margin:0 0 1.1rem;
}
.kicker__line{ width:34px; height:2px; background:var(--hazard); display:inline-block; }

.section__title{
  font-family:var(--font-display);
  font-weight:400;
  text-transform:uppercase;
  letter-spacing:.01em;
  line-height:.92;
  font-size:clamp(2.6rem, 5.9vw, 5.4rem);
  margin:0 0 1rem;
}
.section__intro{ color:var(--muted); max-width:50ch; margin:0; font-size:1.16rem; }
.section__head{ max-width:760px; margin-bottom:clamp(2.2rem,5vw,3.6rem); }

.hl{ color:var(--hazard); }

/* ---------- Buttons ---------- */
.btn{
  --bg-btn:var(--hazard);
  display:inline-flex; align-items:center; justify-content:center; gap:.55rem;
  font-family:var(--font-cond); font-weight:700; text-transform:uppercase;
  letter-spacing:.06em; font-size:.95rem;
  padding:.72rem 1.25rem; border-radius:var(--radius);
  border:2px solid transparent; cursor:pointer;
  transition:transform .18s var(--ease), background .2s, color .2s, border-color .2s, box-shadow .2s;
  white-space:nowrap;
}
.btn--lg{ padding:1rem 1.8rem; font-size:1.16rem; }
.btn--block{ width:100%; }
.btn--solid{ background:var(--hazard); color:#1a1408; }
.btn--solid:hover{ background:var(--hazard-2); transform:translateY(-2px); box-shadow:0 10px 26px -10px rgba(255,196,0,.6); }
.btn--outline{ background:transparent; color:var(--ink); border-color:var(--line-2); }
.btn--outline:hover{ border-color:var(--hazard); color:var(--hazard); transform:translateY(-2px); }
.btn--ghost{ background:rgba(255,255,255,.04); color:var(--ink); border-color:var(--line); }
.btn--ghost:hover{ background:rgba(255,255,255,.08); border-color:var(--line-2); }

/* ---------- Skip link ---------- */
.skip-link{
  position:fixed; top:-100px; left:1rem; z-index:200;
  background:var(--hazard); color:#000; padding:.6rem 1rem; border-radius:4px; font-weight:700;
  transition:top .2s;
}
.skip-link:focus{ top:1rem; }

/* ---------- Utility bar ---------- */
.utilitybar{ background:#000; border-bottom:1px solid var(--line); font-family:var(--font-cond); }
.utilitybar__inner{ display:flex; align-items:center; justify-content:space-between; min-height:38px; gap:1rem; }
.utilitybar__facts{ list-style:none; display:flex; gap:1.4rem; margin:0; padding:0; font-size:.84rem; color:var(--muted); text-transform:uppercase; letter-spacing:.08em; }
.utilitybar__facts strong{ color:var(--ink); }
.utilitybar__facts .dot{ width:7px; height:7px; border-radius:50%; background:var(--hazard); display:inline-block; margin-right:.35rem; animation:pulse 2.4s infinite; vertical-align:middle; }
.utilitybar__call{ display:inline-flex; align-items:center; gap:.4rem; color:var(--hazard); font-weight:700; font-size:.9rem; letter-spacing:.04em; white-space:nowrap; }
.utilitybar__call:hover{ color:var(--hazard-2); }

@keyframes pulse{ 0%,100%{ opacity:1; } 50%{ opacity:.3; } }

/* ---------- Header ---------- */
.header{
  position:sticky; top:0; z-index:100;
  background:rgba(12,12,14,.82);
  backdrop-filter:blur(12px); -webkit-backdrop-filter:blur(12px);
  border-bottom:1px solid var(--line);
  transition:background .3s, box-shadow .3s, border-color .3s;
}
.header.scrolled{ background:rgba(10,10,12,.95); box-shadow:0 10px 30px -18px rgba(0,0,0,.9); }
.header__inner{ display:flex; align-items:center; gap:1.3rem; height:96px; }

.brand{ display:flex; align-items:center; gap:.8rem; margin-right:auto; }
.brand__badge{ width:70px; height:70px; flex:none; display:grid; place-items:center; position:relative; }
.emblem{ width:100%; height:100%; }
/* Real logo image — shown only once it successfully loads (assets/logo.png); the SVG emblem is the fallback. */
.brand__logo{ display:none; width:100%; height:100%; object-fit:contain; }
.brand__logo.is-loaded{ display:block; }
.brand__badge.has-logo .emblem{ display:none; }
.emblem--xl{ width:128px; height:128px; }
.gear-teeth{ transform-origin:50px 50px; }
.brand__text{ display:flex; flex-direction:column; line-height:1; }
.brand__name{ font-family:var(--font-display); font-size:1.85rem; text-transform:uppercase; letter-spacing:.02em; white-space:nowrap; }
.brand__sub{ font-family:var(--font-cond); font-size:.78rem; text-transform:uppercase; letter-spacing:.15em; color:var(--muted); margin-top:.2rem; }

.nav{ display:flex; gap:1.2rem; font-family:var(--font-cond); text-transform:uppercase; letter-spacing:.05em; font-weight:600; font-size:1.22rem; }
.nav a{ color:var(--muted); position:relative; padding:.3rem 0; transition:color .2s; }
.nav a::after{ content:""; position:absolute; left:0; bottom:-2px; width:0; height:2px; background:var(--hazard); transition:width .25s var(--ease); }
.nav a:hover{ color:var(--ink); } .nav a:hover::after{ width:100%; }
.nav a[aria-current="page"]{ color:var(--hazard); } .nav a[aria-current="page"]::after{ width:100%; }

.header__actions{ display:flex; align-items:center; gap:.7rem; }
.header__actions .btn{ font-size:1.02rem; }

.hamburger{ display:none; width:44px; height:44px; background:transparent; border:1px solid var(--line-2); border-radius:6px; cursor:pointer; flex-direction:column; gap:5px; align-items:center; justify-content:center; }
.hamburger span{ width:20px; height:2px; background:var(--ink); transition:transform .25s, opacity .2s; }
.hamburger[aria-expanded="true"] span:nth-child(1){ transform:translateY(7px) rotate(45deg); }
.hamburger[aria-expanded="true"] span:nth-child(2){ opacity:0; }
.hamburger[aria-expanded="true"] span:nth-child(3){ transform:translateY(-7px) rotate(-45deg); }

/* ---------- Hero ---------- */
.hero{ position:relative; overflow:hidden; border-bottom:1px solid var(--line); }
.hero__bg{ position:absolute; inset:0; background:
  radial-gradient(900px 500px at 78% 15%, rgba(255,196,0,.10), transparent 55%),
  linear-gradient(180deg, #0e0e11, #0a0a0c);
  z-index:0; }
.hero__grid{ position:absolute; inset:0; z-index:0; opacity:.5;
  background-image:linear-gradient(var(--line) 1px, transparent 1px), linear-gradient(90deg, var(--line) 1px, transparent 1px);
  background-size:64px 64px; mask-image:radial-gradient(circle at 70% 30%, #000 0%, transparent 75%);
  -webkit-mask-image:radial-gradient(circle at 70% 30%, #000 0%, transparent 75%); }
.hero__inner{ position:relative; z-index:1; display:grid; grid-template-columns:1.15fr .85fr; gap:clamp(1.5rem,4vw,3.5rem); align-items:center; padding-block:clamp(3rem,7vw,6rem); }

.hero__title{
  font-family:var(--font-display); font-weight:400; text-transform:uppercase;
  font-size:clamp(2.9rem, 7.5vw, 6.2rem); line-height:.9; letter-spacing:.005em;
  margin:0 0 1.5rem;
}
.hero__title span{ display:block; }
.hero__lead{ color:var(--muted); max-width:52ch; font-size:1.34rem; margin:0 0 2rem; }
.hero__cta{ display:flex; flex-wrap:wrap; gap:.9rem; margin-bottom:1.8rem; }
.hero__chips{ list-style:none; display:flex; flex-wrap:wrap; gap:.6rem; padding:0; margin:0; }
.hero__chips li{ font-family:var(--font-cond); text-transform:uppercase; letter-spacing:.06em; font-size:.98rem; color:var(--muted); border:1px solid var(--line); border-radius:100px; padding:.42rem 1rem; }
.hero__chips strong{ color:var(--hazard); }

.hero__media{ position:relative; }
.hero__photo{
  position:relative; aspect-ratio:4/5; border-radius:var(--radius); overflow:hidden;
  border:1px solid var(--line); background:
    repeating-linear-gradient(45deg, rgba(255,196,0,.06) 0 14px, transparent 14px 28px),
    linear-gradient(160deg, var(--surface-2), var(--bg));
  display:grid; place-items:center; box-shadow:var(--shadow);
}
.hero__photo .emblem--xl{ opacity:.9; filter:drop-shadow(0 12px 24px rgba(0,0,0,.5)); animation:float 6s ease-in-out infinite; }
.hero__photo .photo-tag{ position:absolute; bottom:12px; left:12px; right:12px; font-family:var(--font-cond); font-size:.72rem; letter-spacing:.04em; text-transform:uppercase; color:var(--muted-2); text-align:center; }
.hero__photo .photo-tag code{ color:var(--hazard); font-family:var(--font-cond); }
.hero__photo[data-has-photo] .emblem--xl,
.hero__photo[data-has-photo] .photo-tag{ display:none; }
.hero__photo .hero__img{ position:absolute; inset:0; width:100%; height:100%; object-fit:cover; display:block; }

@keyframes float{ 0%,100%{ transform:translateY(0); } 50%{ transform:translateY(-10px); } }

.hero__sticker{
  position:absolute; bottom:-22px; left:-22px; background:var(--hazard); color:#1a1408;
  padding:.7rem 1.1rem; border-radius:var(--radius); transform:rotate(-4deg);
  box-shadow:0 14px 30px -10px rgba(255,196,0,.5); display:flex; flex-direction:column; line-height:1;
}
.hero__sticker-sm{ font-family:var(--font-cond); font-weight:700; text-transform:uppercase; letter-spacing:.1em; font-size:.7rem; }
.hero__sticker-lg{ font-family:var(--font-display); text-transform:uppercase; font-size:1.7rem; margin-top:.2rem; }

/* Marquee */
.marquee{ position:relative; z-index:1; border-top:1px solid var(--line); border-bottom:2px solid var(--hazard); background:#000; overflow:hidden; }
.marquee__track{ display:flex; align-items:center; gap:1.4rem; white-space:nowrap; padding:.7rem 0; width:max-content; animation:marquee 32s linear infinite; font-family:var(--font-display); text-transform:uppercase; font-size:1.15rem; letter-spacing:.04em; }
.marquee__track span{ color:var(--ink); }
.marquee__track .sep{ color:var(--hazard); font-size:.7rem; }
@keyframes marquee{ to{ transform:translateX(-50%); } }

/* ---------- Stats ---------- */
.stats{ background:var(--bg-2); border-bottom:1px solid var(--line); }
.stats__grid{ display:grid; grid-template-columns:repeat(4,1fr); }
.stat{ padding:clamp(1.4rem,3vw,2.4rem) 1rem; text-align:center; border-right:1px solid var(--line); }
.stat:last-child{ border-right:0; }
.stat__num{ display:block; font-family:var(--font-display); font-size:clamp(2rem,4vw,3rem); color:var(--hazard); line-height:1; }
.stat__label{ display:block; font-family:var(--font-cond); text-transform:uppercase; letter-spacing:.08em; font-size:.78rem; color:var(--muted); margin-top:.5rem; }

/* ---------- Sections ---------- */
.section{ padding-block:clamp(3.5rem,8vw,6.5rem); position:relative; }
.section--dark{ background:#08080a; border-block:1px solid var(--line); }
.section--muted{ background:var(--bg-2); border-block:1px solid var(--line); }

/* Cards */
.cards{ display:grid; grid-template-columns:repeat(3,1fr); gap:1.1rem; }
.card{
  background:var(--surface); border:1px solid var(--line); border-radius:var(--radius);
  padding:1.7rem 1.5rem; position:relative; overflow:hidden;
  transition:transform .25s var(--ease), border-color .25s, background .25s;
}
.card::before{ content:""; position:absolute; left:0; top:0; width:100%; height:3px; background:var(--hazard); transform:scaleX(0); transform-origin:left; transition:transform .3s var(--ease); }
.card:hover{ transform:translateY(-6px); border-color:var(--line-2); background:var(--surface-2); }
.card:hover::before{ transform:scaleX(1); }
.card__icon{ width:52px; height:52px; border-radius:var(--radius); display:grid; place-items:center; background:var(--hazard-soft); color:var(--hazard); margin-bottom:1.1rem; }
.card__icon svg{ width:28px; height:28px; }
.card h3{ font-family:var(--font-cond); text-transform:uppercase; letter-spacing:.04em; font-size:1.5rem; font-weight:700; margin:0 0 .5rem; }
.card p{ color:var(--muted); margin:0; font-size:.98rem; }
.card--accent{ background:linear-gradient(160deg, rgba(255,196,0,.14), var(--surface)); border-color:rgba(255,196,0,.35); }
.card--accent .card__icon{ background:var(--hazard); color:#1a1408; }

/* ---------- Advantage ---------- */
.advantage__inner{ display:grid; grid-template-columns:1fr 1fr; gap:clamp(2rem,5vw,4rem); align-items:center; }
.checks{ list-style:none; padding:0; margin:1.6rem 0 2rem; display:grid; gap:.8rem; }
.checks li{ position:relative; padding-left:2rem; color:var(--ink); }
.checks li::before{ content:""; position:absolute; left:0; top:.35em; width:14px; height:8px; border-left:2.5px solid var(--hazard); border-bottom:2.5px solid var(--hazard); transform:rotate(-45deg); }
.advantage__panels{ display:grid; grid-template-columns:1fr 1fr; gap:1rem; }
.vpanel{ background:var(--surface); border:1px solid var(--line); border-radius:var(--radius); padding:1.4rem; transition:transform .25s var(--ease), border-color .25s; }
.vpanel:hover{ transform:translateY(-5px); border-color:var(--hazard); }
.vpanel__big{ font-family:var(--font-display); font-size:2.4rem; color:var(--hazard); line-height:1; display:block; }
.vpanel h3{ font-family:var(--font-cond); text-transform:uppercase; letter-spacing:.05em; font-size:1.32rem; margin:.5rem 0 .3rem; }
.vpanel p{ color:var(--muted); margin:0; font-size:.92rem; }

/* Hazard bar */
.hazard-bar{ height:10px; background:repeating-linear-gradient(45deg, var(--hazard) 0 22px, #0c0c0e 22px 44px); }
.section--dark .hazard-bar{ position:absolute; top:0; left:0; right:0; }

/* ---------- Equipment ---------- */
.equip{ list-style:none; padding:0; margin:0; display:grid; grid-template-columns:repeat(4,1fr); gap:1rem; }
.equip__item{
  font-family:var(--font-display); text-transform:uppercase; font-size:clamp(1.3rem,2.5vw,1.95rem);
  letter-spacing:.01em; padding:1.4rem 1.2rem; border:1px solid var(--line); border-radius:var(--radius);
  background:var(--surface); position:relative; transition:color .25s, background .25s, transform .25s var(--ease);
  display:flex; align-items:flex-end; min-height:118px;
}
.equip__item::after{ content:"›"; position:absolute; top:.7rem; right:1rem; color:var(--hazard); font-size:1.4rem; opacity:0; transform:translateX(-6px); transition:.25s var(--ease); }
.equip__item:hover{ background:var(--hazard); color:#1a1408; transform:translateY(-5px); }
.equip__item:hover::after{ opacity:1; transform:translateX(0); color:#1a1408; }
.equip__note{ color:var(--muted); margin-top:1.6rem; }
.equip__note a{ color:var(--hazard); border-bottom:1px solid currentColor; }

/* ---------- Process ---------- */
.process{ list-style:none; padding:0; margin:0; display:grid; grid-template-columns:repeat(4,1fr); gap:1.1rem; counter-reset:step; }
.process__step{ border-top:3px solid var(--line); padding-top:1.3rem; position:relative; transition:border-color .3s; }
.process__step:hover{ border-color:var(--hazard); }
.process__num{ font-family:var(--font-display); font-size:2.6rem; color:var(--hazard); line-height:1; display:block; }
.process__step h3{ font-family:var(--font-cond); text-transform:uppercase; letter-spacing:.05em; font-size:1.45rem; margin:.6rem 0 .4rem; }
.process__step p{ color:var(--muted); margin:0; font-size:.96rem; }

/* ---------- Serve ---------- */
.serve__inner{ display:grid; grid-template-columns:1fr 1.1fr; gap:clamp(2rem,5vw,4rem); align-items:center; }
.serve__grid{ display:grid; grid-template-columns:1fr 1fr; gap:1rem; }
.serve__tile{ background:var(--surface); border:1px solid var(--line); border-left:3px solid var(--hazard); border-radius:var(--radius); padding:1.4rem; transition:transform .25s var(--ease), background .25s; }
.serve__tile:hover{ transform:translateX(5px); background:var(--surface-2); }
.serve__tile h3{ font-family:var(--font-cond); text-transform:uppercase; letter-spacing:.04em; font-size:1.34rem; margin:0 0 .4rem; }
.serve__tile p{ color:var(--muted); margin:0; font-size:.95rem; }

/* ---------- Service area ---------- */
.area__inner{ display:grid; grid-template-columns:1fr 1fr; gap:clamp(2rem,5vw,4rem); align-items:center; }
.area__cities{ list-style:none; padding:0; margin:0; display:grid; grid-template-columns:repeat(3,1fr); gap:.7rem; }
.area__cities li{ font-family:var(--font-cond); text-transform:uppercase; letter-spacing:.06em; font-weight:600; padding:.8rem 1rem; border:1px solid var(--line); border-radius:var(--radius); text-align:center; color:var(--muted); background:rgba(255,255,255,.02); transition:.25s var(--ease); }
.area__cities li:hover{ color:var(--hazard); border-color:var(--hazard); transform:translateY(-3px); }

/* ---------- Reviews ---------- */
.quotes{ display:grid; grid-template-columns:repeat(3,1fr); gap:1.1rem; }
.quote{ margin:0; background:var(--surface); border:1px solid var(--line); border-radius:var(--radius); padding:1.7rem; position:relative; }
.quote__stars{ color:var(--hazard); letter-spacing:.15em; margin-bottom:.8rem; }
.quote blockquote{ margin:0 0 1rem; font-size:1.05rem; line-height:1.55; }
.quote figcaption{ font-family:var(--font-cond); text-transform:uppercase; letter-spacing:.06em; font-size:.8rem; color:var(--muted-2); }
.reviews__cta{ margin-top:2rem; }

/* ---------- Contact ---------- */
.contact__inner{ display:grid; grid-template-columns:1fr 1fr; gap:clamp(2rem,5vw,4rem); align-items:start; }
.contact__list{ list-style:none; padding:0; margin:2rem 0; display:grid; gap:1.1rem; }
.contact__list li{ display:flex; gap:1rem; align-items:center; }
.contact__ico{ font-size:1.3rem; width:44px; height:44px; display:grid; place-items:center; background:var(--surface); border:1px solid var(--line); border-radius:var(--radius); }
.contact__k{ display:block; font-family:var(--font-cond); text-transform:uppercase; letter-spacing:.1em; font-size:.72rem; color:var(--muted-2); }
.contact__v{ font-size:1.1rem; font-weight:600; }
a.contact__v:hover{ color:var(--hazard); }

.hours{ border-collapse:collapse; width:100%; max-width:340px; font-family:var(--font-cond); }
.hours caption{ text-align:left; text-transform:uppercase; letter-spacing:.1em; font-size:.8rem; color:var(--muted-2); margin-bottom:.5rem; }
.hours th, .hours td{ text-align:left; padding:.55rem .2rem; border-bottom:1px solid var(--line); font-size:1.02rem; }
.hours th{ font-weight:600; color:var(--ink); }
.hours td{ color:var(--muted); }
.hours .closed{ color:var(--hazard-2); }

/* Form */
.form{ background:var(--surface); border:1px solid var(--line); border-radius:var(--radius); padding:clamp(1.4rem,3vw,2.2rem); box-shadow:var(--shadow); }
.form__title{ font-family:var(--font-cond); text-transform:uppercase; letter-spacing:.06em; font-size:1.9rem; font-weight:700; margin:0 0 1.3rem; }
.field{ margin-bottom:1.1rem; }
.field--row{ display:grid; grid-template-columns:1fr 1fr; gap:1rem; }
.field label{ display:block; font-family:var(--font-cond); text-transform:uppercase; letter-spacing:.07em; font-size:.98rem; color:var(--muted); margin-bottom:.45rem; }
.field .opt{ color:var(--muted-2); text-transform:none; letter-spacing:0; }
.field input, .field select, .field textarea{
  width:100%; background:var(--bg); border:1px solid var(--line-2); border-radius:var(--radius);
  color:var(--ink); font-family:var(--font-body); font-size:1.12rem; padding:.8rem .95rem; transition:border-color .2s, box-shadow .2s;
}
.field input:focus, .field select:focus, .field textarea:focus{ outline:none; border-color:var(--hazard); box-shadow:0 0 0 3px var(--hazard-soft); }
.field textarea{ resize:vertical; }
.form__note{ margin:1rem 0 0; font-family:var(--font-cond); letter-spacing:.04em; min-height:1.2em; }
.form__note.ok{ color:var(--hazard); }
.form__note.err{ color:#ff6b6b; }

/* ---------- Final CTA ---------- */
.cta{ background:linear-gradient(160deg, #15130b, #0a0a0c); }
.cta__inner{ text-align:center; padding-block:clamp(3rem,7vw,5rem); display:flex; flex-direction:column; align-items:center; gap:1.6rem; }
.cta__title{ font-family:var(--font-display); text-transform:uppercase; font-size:clamp(2.4rem,5.9vw,4.9rem); line-height:.95; margin:0; }

/* ---------- Footer ---------- */
.footer{ background:#000; border-top:1px solid var(--line); padding-top:clamp(2.5rem,5vw,4rem); }
.footer__grid{ display:grid; grid-template-columns:1.6fr 1fr 1fr 1fr; gap:2rem; padding-bottom:2.5rem; }
.brand--footer{ margin:0 0 1rem; }
.footer__tag{ color:var(--muted); max-width:38ch; font-size:.95rem; margin:0; }
.footer__col h4{ font-family:var(--font-cond); text-transform:uppercase; letter-spacing:.1em; font-size:.82rem; color:var(--hazard); margin:0 0 1rem; }
.footer__col a, .footer__col span{ display:block; color:var(--muted); margin-bottom:.55rem; transition:color .2s; }
.footer__col a:hover{ color:var(--ink); }
.footer__bottom{ display:flex; justify-content:space-between; gap:1rem; flex-wrap:wrap; border-top:1px solid var(--line); padding-block:1.4rem; font-family:var(--font-cond); text-transform:uppercase; letter-spacing:.06em; font-size:.8rem; color:var(--muted-2); }
.footer__credit{ color:var(--hazard); }

/* ---------- Mobile FAB ---------- */
.fab-call{ position:fixed; right:18px; bottom:18px; z-index:90; width:58px; height:58px; border-radius:50%; background:var(--hazard); color:#1a1408; display:none; place-items:center; box-shadow:0 12px 28px -8px rgba(255,196,0,.6); animation:pulse-ring 2.5s infinite; }

@keyframes pulse-ring{ 0%{ box-shadow:0 12px 28px -8px rgba(255,196,0,.6), 0 0 0 0 rgba(255,196,0,.5); } 70%{ box-shadow:0 12px 28px -8px rgba(255,196,0,.6), 0 0 0 16px rgba(255,196,0,0); } 100%{ box-shadow:0 12px 28px -8px rgba(255,196,0,.6), 0 0 0 0 rgba(255,196,0,0); } }

/* ---------- Reveal animation ---------- */
.reveal{ opacity:0; transform:translateY(26px); transition:opacity .7s var(--ease), transform .7s var(--ease); }
.reveal.in{ opacity:1; transform:none; }

/* ---------- Utilities ---------- */
.u-hide-sm{ } /* hidden on small via media query */

/* =================================================================
   Responsive
   ================================================================= */
@media (max-width:1000px){
  .cards{ grid-template-columns:repeat(2,1fr); }
  .equip{ grid-template-columns:repeat(2,1fr); }
  .process{ grid-template-columns:repeat(2,1fr); }
  .hero__inner{ grid-template-columns:1fr; }
  .hero__media{ max-width:420px; }
  .advantage__inner, .serve__inner, .area__inner, .contact__inner{ grid-template-columns:1fr; }
  .footer__grid{ grid-template-columns:1fr 1fr; }
  .quotes{ grid-template-columns:1fr; }
}

/* Collapse the nav to a slide-in menu early enough that the full
   header (7 links + phone + CTA) never crowds. */
@media (max-width:1400px){
  .nav{
    position:fixed; top:0; right:0; height:100vh; height:100dvh; width:min(80vw,340px);
    flex-direction:column; gap:0; overflow-y:auto;
    background:var(--bg-2); border-left:1px solid var(--line); padding:90px 1.5rem 2rem;
    transform:translateX(100%); transition:transform .3s var(--ease); z-index:99;
  }
  .nav.open{ transform:none; box-shadow:-20px 0 60px -20px rgba(0,0,0,.8); }
  .nav a{ padding:1rem 0; border-bottom:1px solid var(--line); font-size:1.2rem; width:100%; }
  .hamburger{ display:flex; position:relative; z-index:101; }
  .u-hide-md{ display:none; }
  .header__inner{ gap:.9rem; }
  .fab-call{ display:grid; }
}

@media (max-width:760px){
  .stats__grid{ grid-template-columns:repeat(2,1fr); }
  .stat:nth-child(2){ border-right:0; }
  .stat:nth-child(1),.stat:nth-child(2){ border-bottom:1px solid var(--line); }
  .advantage__panels, .serve__grid, .field--row{ grid-template-columns:1fr 1fr; }
}

@media (max-width:560px){
  .u-hide-sm{ display:none; }
  .cards, .equip, .area__cities{ grid-template-columns:1fr; }
  .area__cities{ grid-template-columns:repeat(2,1fr); }
  .footer__grid{ grid-template-columns:1fr; }
  .hero__sticker{ left:auto; right:8px; bottom:-18px; }
  .hero__cta .btn{ width:100%; }
  /* keep the top bar to a single tidy line */
  .brand__sub{ display:none; }
  .brand__name{ font-size:1.35rem; }
  .brand__badge{ width:40px; height:40px; }
  .header__actions .btn--solid{ display:none; }   /* CTA covered by hero + sticky call button */
  .header__inner{ height:64px; }
  .advantage__panels, .serve__grid, .field--row{ grid-template-columns:1fr; }
}

/* =================================================================
   Gallery page
   ================================================================= */
.page-hero{
  position:relative; overflow:hidden; border-bottom:1px solid var(--line);
  background:
    radial-gradient(900px 480px at 82% 0%, rgba(255,196,0,.10), transparent 55%),
    linear-gradient(180deg, #0e0e11, #0a0a0c);
  padding-block:clamp(2.6rem,6vw,4.8rem);
}
.page-hero::before{
  content:""; position:absolute; inset:0; opacity:.5; z-index:0;
  background-image:linear-gradient(var(--line) 1px, transparent 1px), linear-gradient(90deg, var(--line) 1px, transparent 1px);
  background-size:64px 64px;
  -webkit-mask-image:radial-gradient(circle at 75% 20%, #000, transparent 75%);
  mask-image:radial-gradient(circle at 75% 20%, #000, transparent 75%);
}
.page-hero .wrap{ position:relative; z-index:1; }
.page-hero__title{ font-family:var(--font-display); text-transform:uppercase; font-size:clamp(2.9rem,7vw,6.2rem); line-height:.92; margin:0 0 1rem; }
.page-hero__lead{ color:var(--muted); max-width:60ch; font-size:1.18rem; margin:0; }

.gallery{ display:grid; grid-template-columns:repeat(auto-fill, minmax(320px,1fr)); gap:1.1rem; }
.gallery__item{ margin:0; position:relative; border-radius:var(--radius); overflow:hidden; border:1px solid var(--line); background:var(--surface); }
.gallery__media{ position:relative; display:block; width:100%; aspect-ratio:4/3; }
.gallery__media img{ width:100%; height:100%; object-fit:cover; display:block; transition:transform .5s var(--ease); }
.gallery__media.has-photo{ cursor:zoom-in; }
.gallery__item:hover .gallery__media img{ transform:scale(1.06); }
.gallery__ph{
  position:absolute; inset:0; display:grid; place-items:center; align-content:center; gap:.55rem; padding:1rem; text-align:center;
  background:
    repeating-linear-gradient(45deg, rgba(255,196,0,.06) 0 14px, transparent 14px 28px),
    linear-gradient(160deg, var(--surface-2), var(--bg));
}
.gallery__ph .emblem{ width:60px; height:60px; opacity:.85; }
.gallery__ph small{ font-family:var(--font-cond); text-transform:uppercase; letter-spacing:.12em; font-size:.72rem; color:var(--muted-2); }
.gallery__ph code{ font-family:var(--font-cond); color:var(--hazard); font-size:.76rem; letter-spacing:.03em; }
.gallery__cap{
  position:absolute; left:0; right:0; bottom:0; z-index:2; padding:1.1rem 1rem .9rem;
  font-family:var(--font-cond); text-transform:uppercase; letter-spacing:.05em; font-size:.92rem;
  background:linear-gradient(to top, rgba(0,0,0,.85), transparent); pointer-events:none;
}
.gallery__hint{ color:var(--muted); margin:0 0 2rem; font-size:1.02rem; }
.gallery__hint a{ color:var(--hazard); border-bottom:1px solid currentColor; }

/* Lightbox */
.lightbox{ position:fixed; inset:0; z-index:200; background:rgba(5,5,7,.95); display:none; align-items:center; justify-content:center; padding:5vw; backdrop-filter:blur(4px); }
.lightbox.open{ display:flex; }
.lightbox img{ max-width:100%; max-height:88vh; border-radius:var(--radius); box-shadow:var(--shadow); }
.lightbox__close{ position:absolute; top:18px; right:22px; width:48px; height:48px; border-radius:50%; background:var(--hazard); color:#1a1408; border:0; font-size:1.5rem; line-height:1; cursor:pointer; display:grid; place-items:center; }
.lightbox__close:hover{ background:var(--hazard-2); }

/* ---------- Reduced motion ---------- */
@media (prefers-reduced-motion:reduce){
  *{ animation-duration:.001ms !important; animation-iteration-count:1 !important; transition-duration:.001ms !important; scroll-behavior:auto !important; }
  .reveal{ opacity:1; transform:none; }
  .marquee__track{ animation:none; }
}
