/* ============================================================
   DROP ZONE PAINTING — Veteran-Owned Commercial & Residential
   Military / Tactical + Professional Painting design system
   ============================================================ */

/* ---- Tokens ------------------------------------------------ */
:root {
  /* Brand — official Drop Zone Painting palette */
  --olive:        #4e5230;   /* Olive */
  --olive-dark:   #3a3d23;
  --olive-deep:   #23260f;
  --olive-light:  #6a7046;
  --olive-haze:   #9aa06a;

  --ink:          #000000;   /* Black */
  --char:         #0d0d0c;
  --char-2:       #17171a;

  --red:          #862420;   /* Maroon */
  --red-bright:   #b23a30;    /* lifted maroon for text/accents on black (contrast) */
  --navy:         #213350;   /* Blue */
  --navy-light:   #2c4068;

  --cream:        #faf5e6;   /* Tan */
  --sand:         #efe8d4;
  --sand-2:       #e2d9c1;

  --white:        #ffffff;

  --khaki:        #faf5e6;   /* Tan — backing behind the logo */
  --khaki-2:      #f3ecda;
  --khaki-line:   #2a2c18;

  /* Semantic */
  --bg:           var(--cream);
  --bg-dark:      var(--ink);
  --surface:      #ffffff;
  --text:         #1b1b16;
  --text-soft:    #4a4a40;
  --text-invert:  #f1efe6;
  --line:         #d9d3c3;
  --line-dark:    rgba(244,241,232,.14);

  --cta:          var(--red);
  --cta-hover:    var(--red-bright);

  /* Type */
  --f-display: "Black Ops One", "Oswald", system-ui, sans-serif;
  --f-head:    "Oswald", "Arial Narrow", system-ui, sans-serif;
  --f-body:    "Barlow", system-ui, -apple-system, "Segoe UI", sans-serif;

  /* Rhythm */
  --maxw: 1200px;
  --gap: clamp(1.25rem, 4vw, 2.5rem);
  --section-y: clamp(3.5rem, 8vw, 7rem);
  --radius: 4px;
  --radius-lg: 8px;
  --shadow: 0 10px 30px -12px rgba(14,14,12,.35);
  --shadow-lg: 0 24px 60px -20px rgba(14,14,12,.5);

  --z-nav: 50;
  --z-drawer: 60;
  --z-drop: 80;

  --ease: cubic-bezier(.22,.61,.36,1);
}

/* ---- Reset ------------------------------------------------- */
*,*::before,*::after{ box-sizing:border-box; }
html{ -webkit-text-size-adjust:100%; scroll-behavior:smooth; }
@media (prefers-reduced-motion: reduce){ html{ scroll-behavior:auto; } }
body{
  margin:0; background:var(--bg); color:var(--text);
  font-family:var(--f-body); font-size:clamp(1rem,.96rem + .2vw,1.0625rem);
  line-height:1.65; -webkit-font-smoothing:antialiased; text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
img,svg,video{ max-width:100%; height:auto; display:block; }
a{ color:inherit; text-decoration:none; }
button{ font:inherit; cursor:pointer; }
ul{ margin:0; padding:0; list-style:none; }
h1,h2,h3,h4{ margin:0; line-height:1.05; font-weight:700; }
p{ margin:0; }
:focus-visible{ outline:3px solid var(--red); outline-offset:3px; border-radius:2px; }

/* ---- Layout helpers --------------------------------------- */
.wrap{ width:100%; max-width:var(--maxw); margin-inline:auto; padding-inline:clamp(1.1rem,5vw,2.5rem); }
.section{ padding-block:var(--section-y); }
.center{ text-align:center; }
.stack > * + *{ margin-top:1rem; }

/* Eyebrow / stencil section label */
.eyebrow{
  display:inline-flex; align-items:center; gap:.6rem;
  font-family:var(--f-head); text-transform:uppercase; letter-spacing:.28em;
  font-size:.8rem; font-weight:600; color:var(--red);
}
.eyebrow::before{ content:""; width:34px; height:2px; background:var(--red); display:inline-block; }
.eyebrow.on-dark{ color:var(--olive-haze); }
.eyebrow.on-dark::before{ background:var(--olive-haze); }

.h-display{
  font-family:var(--f-display); font-weight:400; line-height:.98;
  text-transform:uppercase; letter-spacing:.01em;
  font-size:clamp(2.05rem,6.2vw,4.6rem);
  overflow-wrap:break-word;
}
.h2{
  font-family:var(--f-head); font-weight:700; text-transform:uppercase;
  letter-spacing:.02em; font-size:clamp(1.9rem,4.5vw,3rem); line-height:1.02;
}
.h3{ font-family:var(--f-head); text-transform:uppercase; letter-spacing:.03em; font-size:1.3rem; font-weight:600; }
.lead{ font-size:clamp(1.06rem,1rem + .5vw,1.3rem); color:var(--text-soft); max-width:60ch; }
.muted{ color:var(--text-soft); }

/* ---- Buttons ---------------------------------------------- */
.btn{
  --b: var(--cta);
  display:inline-flex; align-items:center; justify-content:center; gap:.6rem;
  min-height:58px; padding:1.15rem 2.4rem;
  font-family:var(--f-head); font-weight:600; text-transform:uppercase; letter-spacing:.08em;
  font-size:1rem; color:#ffffff; background:var(--b);
  border:2px solid var(--b); border-radius:var(--radius);
  transition:transform .15s var(--ease), background .2s var(--ease), border-color .2s, color .2s;
  cursor:pointer; clip-path: polygon(10px 0, 100% 0, 100% calc(100% - 10px), calc(100% - 10px) 100%, 0 100%, 0 10px);
}
.btn:hover{ background:var(--cta-hover); border-color:var(--cta-hover); color:#ffffff; transform:translateY(-2px); }
.btn:active{ transform:translateY(0); }
.btn--ghost{ background:transparent; color:var(--text); border-color:var(--ink); }
.btn--ghost:hover{ background:var(--ink); color:var(--white); border-color:var(--ink); }
.btn--ghost.on-dark{ color:var(--text-invert); border-color:var(--text-invert); }
.btn--ghost.on-dark:hover{ background:var(--text-invert); color:var(--ink); }
.btn--olive{ --b:var(--olive); }
.btn--olive:hover{ background:var(--olive-dark); border-color:var(--olive-dark); }
.btn svg{ width:18px; height:18px; }
.btn-row{ display:flex; flex-wrap:wrap; gap:.9rem; }

/* ---- Header / Nav ----------------------------------------- */
.nav{
  position:sticky; top:0; z-index:var(--z-nav);
  background:var(--khaki);
  border-bottom:3px solid var(--olive-dark);
  box-shadow:0 6px 20px -10px rgba(14,14,12,.5);
}
.nav__inner{ display:flex; align-items:center; justify-content:space-between; gap:1rem; min-height:82px; }
.nav__brand{ display:flex; align-items:center; gap:.65rem; }
.nav__brand img{ height:72px; width:auto; }
@media (max-width:560px){ .nav__brand img{ height:58px; } }
.nav__brand b{
  font-family:var(--f-head); color:var(--ink); text-transform:uppercase;
  letter-spacing:.06em; font-size:1.05rem; line-height:1; font-weight:700;
}
.nav__brand span{ display:block; font-size:.62rem; letter-spacing:.32em; color:var(--olive-dark); font-weight:600; }
.nav__links{ display:flex; align-items:center; gap:1.6rem; }
.nav__links a{
  font-family:var(--f-head); text-transform:uppercase; letter-spacing:.08em;
  font-size:.9rem; color:var(--char); font-weight:600; position:relative; padding:.25rem 0;
  transition:color .2s;
}
.nav__links a::after{ content:""; position:absolute; left:0; bottom:-2px; height:2px; width:0; background:var(--red); transition:width .25s var(--ease); }
.nav__links a:hover, .nav__links a[aria-current="page"]{ color:var(--red); }
.nav__links a:hover::after, .nav__links a[aria-current="page"]::after{ width:100%; }
/* keep the nav CTA a real button (white on maroon), not a text link */
.nav__links a.btn{ color:#ffffff; min-height:46px; padding:.72rem 1.55rem; font-size:.92rem; border:2px solid var(--cta); }
.nav__links a.btn:hover, .nav__links a.btn[aria-current="page"]{ color:#ffffff; }
.nav__links a.btn::after{ display:none; }
.nav__cta{ display:flex; align-items:center; gap:.75rem; }
.nav__toggle{
  display:none; width:48px; height:48px; align-items:center; justify-content:center;
  background:transparent; border:2px solid rgba(35,37,15,.45); border-radius:var(--radius);
}
.nav__toggle span{ display:block; width:22px; height:2px; background:var(--ink); position:relative; }
.nav__toggle span::before,.nav__toggle span::after{ content:""; position:absolute; left:0; width:22px; height:2px; background:var(--ink); transition:.25s var(--ease); }
.nav__toggle span::before{ top:-7px; } .nav__toggle span::after{ top:7px; }
.nav[data-open="true"] .nav__toggle span{ background:transparent; }
.nav[data-open="true"] .nav__toggle span::before{ top:0; transform:rotate(45deg); }
.nav[data-open="true"] .nav__toggle span::after{ top:0; transform:rotate(-45deg); }

@media (max-width: 900px){
  .nav__toggle{ display:flex; }
  .nav__links{
    position:fixed; inset:82px 0 auto 0; flex-direction:column; align-items:stretch; gap:0;
    background:var(--khaki); padding:.5rem 1.25rem 1.5rem; border-bottom:3px solid var(--olive-dark);
    transform:translateY(-120%); transition:transform .3s var(--ease); z-index:var(--z-drawer);
    max-height:calc(100vh - 82px); overflow:auto; box-shadow:0 14px 24px -14px rgba(14,14,12,.6);
  }
  .nav[data-open="true"] .nav__links{ transform:translateY(0); }
  .nav__links a{ padding:1rem .25rem; border-bottom:1px solid rgba(35,37,15,.18); font-size:1.05rem; }
  .nav__links a::after{ display:none; }
  .nav__links a.btn{ margin-top:1rem; width:100%; min-height:54px; padding:1rem 1.5rem; font-size:1rem; }
  .nav__cta .btn span.hide-sm{ display:none; }
}

/* ---- Drop animation (parachute logo) ---------------------- */
.dropfx{
  position:fixed; left:50%; top:0; z-index:var(--z-drop); pointer-events:none;
  width:min(185px,47vw); translate:-50% 0; will-change:transform,opacity;
}
.dropfx img{ width:100%; display:block; filter:drop-shadow(0 16px 22px rgba(0,0,0,.5)); }
/* slow, smooth parachute descent with a gentle pendulum sway */
@keyframes paradrop{
  0%   { transform:translateY(-32vh) translateX(-10px) rotate(-3deg); opacity:0; animation-timing-function:ease-out; }
  9%   { opacity:1; }
  20%  { transform:translateY(15vh) translateX(14px) rotate(3.2deg); animation-timing-function:ease-in-out; }
  40%  { transform:translateY(42vh) translateX(-14px) rotate(-3.2deg); animation-timing-function:ease-in-out; }
  60%  { transform:translateY(69vh) translateX(14px) rotate(3.2deg); animation-timing-function:ease-in-out; }
  80%  { transform:translateY(96vh) translateX(-12px) rotate(-2.6deg); animation-timing-function:ease-in-out; }
  90%  { opacity:1; }
  100% { transform:translateY(124vh) translateX(6px) rotate(1.6deg); opacity:0; animation-timing-function:ease-in; }
}
.dropfx.run{ animation:paradrop 8.5s linear forwards; }
@media (prefers-reduced-motion: reduce){ .dropfx{ display:none !important; } }

/* ---- Hero -------------------------------------------------- */
.hero{
  position:relative; color:var(--text-invert); overflow:hidden;
  background:
    radial-gradient(120% 90% at 80% -10%, rgba(78,82,48,.55), transparent 60%),
    linear-gradient(180deg, #0a0a08 0%, #000000 55%, #060604 100%);
}
.hero::before{ /* subtle topographic / tactical grid */
  content:""; position:absolute; inset:0; opacity:.22; pointer-events:none;
  background-image:
    linear-gradient(rgba(154,160,106,.10) 1px, transparent 1px),
    linear-gradient(90deg, rgba(154,160,106,.10) 1px, transparent 1px);
  background-size:46px 46px; mask-image:radial-gradient(120% 80% at 50% 0%, #000 30%, transparent 80%);
}
.hero__inner{ position:relative; display:grid; gap:2.4rem; padding-block:clamp(3.5rem,9vw,6.5rem) clamp(3rem,7vw,5.5rem); }
.hero__flag{ display:flex; align-items:center; gap:.7rem; }
.hero__flag .stripe{ width:46px; height:4px; border-radius:2px; }
.hero h1{ max-width:16ch; }
.hero h1 .accent{ color:var(--red-bright); display:block; }
.hero h1 .olive{ color:var(--olive-haze); }
.hero__sub{ color:#d8d6c8; font-size:clamp(1.05rem,1rem + .5vw,1.3rem); max-width:54ch; }
.hero__badges{ display:flex; flex-wrap:wrap; gap:.6rem; margin-top:.4rem; }
.tag{
  display:inline-flex; align-items:center; gap:.45rem; padding:.5rem .9rem;
  font-family:var(--f-head); text-transform:uppercase; letter-spacing:.08em; font-size:.78rem; font-weight:600;
  background:rgba(244,241,232,.06); border:1px solid var(--line-dark); border-radius:999px; color:#e9e7da;
}
.tag svg{ width:15px; height:15px; color:var(--olive-haze); }

/* ---- Cards / grids ---------------------------------------- */
.grid{ display:grid; gap:1.4rem; }
.split{ display:grid; gap:2.2rem; align-items:start; grid-template-columns:1fr 1.5fr; }
@media (max-width:760px){ .split{ grid-template-columns:1fr; } }
.grid--3{ grid-template-columns:repeat(3,1fr); }
.grid--2{ grid-template-columns:repeat(2,1fr); }
.grid--4{ grid-template-columns:repeat(4,1fr); }
@media (max-width:980px){ .grid--3,.grid--4{ grid-template-columns:repeat(2,1fr); } }
@media (max-width:620px){ .grid--2,.grid--3,.grid--4{ grid-template-columns:1fr; } }

.card{
  background:var(--surface); border:1px solid var(--line); border-radius:var(--radius-lg);
  padding:1.6rem; position:relative; overflow:hidden; transition:transform .2s var(--ease), box-shadow .2s, border-color .2s;
}
.card::before{ content:""; position:absolute; left:0; top:0; bottom:0; width:4px; background:var(--olive); transform:scaleY(.0); transform-origin:top; transition:transform .3s var(--ease); }
.card:hover{ transform:translateY(-4px); box-shadow:var(--shadow); border-color:var(--sand-2); }
.card:hover::before{ transform:scaleY(1); }
.card .ico{ width:54px; height:54px; display:grid; place-items:center; border-radius:var(--radius); background:var(--olive); color:var(--cream); margin-bottom:1.1rem; }
.card .ico svg{ width:28px; height:28px; }
.card h3{ font-family:var(--f-head); text-transform:uppercase; letter-spacing:.03em; font-size:1.25rem; margin-bottom:.5rem; }
.card .num{ position:absolute; top:1rem; right:1.2rem; font-family:var(--f-display); font-size:1.5rem; color:var(--sand-2); }

/* Service card with image */
.svc{ display:flex; flex-direction:column; background:var(--surface); border:1px solid var(--line); border-radius:var(--radius-lg); overflow:hidden; transition:transform .2s var(--ease), box-shadow .2s; }
.svc:hover{ transform:translateY(-4px); box-shadow:var(--shadow); }
.svc__media{ aspect-ratio:4/3; background:var(--char); position:relative; overflow:hidden; }
.svc__media img{ width:100%; height:100%; object-fit:cover; transition:transform .5s var(--ease); }
.svc:hover .svc__media img{ transform:scale(1.05); }
.svc__media .badge{ position:absolute; left:0; top:1rem; background:var(--red); color:#fff; font-family:var(--f-head); text-transform:uppercase; letter-spacing:.1em; font-size:.72rem; padding:.35rem .8rem; }
.svc__body{ padding:1.4rem 1.4rem 1.6rem; display:flex; flex-direction:column; gap:.6rem; flex:1; }
.svc__body h3{ font-family:var(--f-head); text-transform:uppercase; letter-spacing:.03em; font-size:1.3rem; }
.svc__body .lk{ margin-top:auto; font-family:var(--f-head); text-transform:uppercase; letter-spacing:.08em; font-size:.85rem; color:var(--red); display:inline-flex; align-items:center; gap:.4rem; }
.svc__body .lk svg{ width:16px; height:16px; transition:transform .2s; }
.svc:hover .svc__body .lk svg{ transform:translateX(4px); }

/* ---- Section variants ------------------------------------- */
.bg-dark{ background:var(--bg-dark); color:var(--text-invert); }
.bg-dark .lead,.bg-dark .muted{ color:#c9c7b9; }
.bg-olive{ background:var(--olive-deep); color:var(--text-invert); }
.bg-olive .lead{ color:#d6d8c0; }
.bg-sand{ background:var(--sand); }

/* Stat strip */
.stats{ display:grid; grid-template-columns:repeat(4,1fr); gap:1px; background:var(--line-dark); border:1px solid var(--line-dark); border-radius:var(--radius-lg); overflow:hidden; }
@media (max-width:680px){ .stats{ grid-template-columns:repeat(2,1fr); } }
.stat{ background:var(--char); padding:1.6rem 1.2rem; text-align:center; }
.stat b{ font-family:var(--f-display); font-size:clamp(1.9rem,5vw,2.8rem); color:var(--cream); display:block; line-height:1; }
.stat span{ font-family:var(--f-head); text-transform:uppercase; letter-spacing:.12em; font-size:.74rem; color:var(--olive-haze); margin-top:.5rem; display:block; }

/* ---- Steps / process -------------------------------------- */
.steps{ display:grid; gap:1.4rem; grid-template-columns:repeat(4,1fr); }
@media (max-width:900px){ .steps{ grid-template-columns:repeat(2,1fr); } }
@media (max-width:520px){ .steps{ grid-template-columns:1fr; } }
.step{ position:relative; padding:1.6rem; background:var(--surface); border:1px solid var(--line); border-radius:var(--radius-lg); }
.step .n{ font-family:var(--f-display); font-size:2rem; color:var(--red); line-height:1; }
.step h3{ font-family:var(--f-head); text-transform:uppercase; font-size:1.1rem; letter-spacing:.03em; margin:.6rem 0 .4rem; }
.bg-dark .step,.bg-olive .step{ background:rgba(255,255,255,.04); border-color:var(--line-dark); }

/* ---- Before / After slider -------------------------------- */
.ba{ position:relative; aspect-ratio:3/2; border-radius:var(--radius-lg); overflow:hidden; user-select:none; touch-action:pan-y; border:1px solid var(--line); background:var(--char); }
.ba img{ position:absolute; inset:0; width:100%; height:100%; object-fit:cover; }
.ba .after{ clip-path:inset(0 0 0 var(--pos,50%)); }
.ba .lbl{ position:absolute; bottom:.8rem; font-family:var(--f-head); text-transform:uppercase; letter-spacing:.1em; font-size:.72rem; color:#fff; background:rgba(14,14,12,.7); padding:.3rem .7rem; border-radius:3px; }
.ba .lbl.l{ left:.8rem; } .ba .lbl.r{ right:.8rem; }
.ba__handle{ position:absolute; top:0; bottom:0; left:var(--pos,50%); width:3px; background:var(--cream); transform:translateX(-50%); }
.ba__handle::after{ content:""; position:absolute; top:50%; left:50%; width:44px; height:44px; transform:translate(-50%,-50%); background:var(--red); border:3px solid var(--cream); border-radius:50%; box-shadow:var(--shadow); }
.ba__handle::before{ content:"‹ ›"; position:absolute; top:50%; left:50%; transform:translate(-50%,-50%); color:#fff; font-size:1rem; font-weight:700; z-index:1; letter-spacing:-2px; }
.ba input[type=range]{ position:absolute; inset:0; width:100%; height:100%; margin:0; opacity:0; cursor:ew-resize; }

/* ---- Testimonials ----------------------------------------- */
.quote{ background:var(--surface); border:1px solid var(--line); border-left:4px solid var(--red); border-radius:var(--radius-lg); padding:1.7rem; display:flex; flex-direction:column; gap:1rem; }
.quote .stars{ display:flex; gap:.15rem; color:#d9a400; }
.quote .stars svg{ width:18px; height:18px; }
.quote p{ font-size:1.05rem; }
.quote .by{ display:flex; align-items:center; gap:.7rem; margin-top:auto; }
.quote .av{ width:42px; height:42px; border-radius:50%; background:var(--olive); color:var(--cream); display:grid; place-items:center; font-family:var(--f-head); font-weight:600; }
.quote .by b{ font-family:var(--f-head); text-transform:uppercase; letter-spacing:.03em; font-size:.95rem; }
.quote .by span{ font-size:.82rem; color:var(--text-soft); }

/* ---- FAQ -------------------------------------------------- */
.faq{ border:1px solid var(--line); border-radius:var(--radius-lg); overflow:hidden; background:var(--surface); }
.faq details{ border-bottom:1px solid var(--line); }
.faq details:last-child{ border-bottom:0; }
.faq summary{ list-style:none; cursor:pointer; padding:1.2rem 1.4rem; display:flex; justify-content:space-between; align-items:center; gap:1rem;
  font-family:var(--f-head); text-transform:uppercase; letter-spacing:.02em; font-size:1.02rem; font-weight:600; }
.faq summary::-webkit-details-marker{ display:none; }
.faq summary .pm{ flex:0 0 auto; width:26px; height:26px; position:relative; border:2px solid var(--olive); border-radius:4px; transition:.2s; }
.faq summary .pm::before,.faq summary .pm::after{ content:""; position:absolute; background:var(--olive); left:50%; top:50%; transform:translate(-50%,-50%); }
.faq summary .pm::before{ width:12px; height:2px; } .faq summary .pm::after{ width:2px; height:12px; transition:.2s; }
.faq details[open] summary .pm{ background:var(--olive); }
.faq details[open] summary .pm::before,.faq details[open] summary .pm::after{ background:var(--cream); }
.faq details[open] summary .pm::after{ transform:translate(-50%,-50%) scaleY(0); }
.faq .ans{ padding:0 1.4rem 1.3rem; color:var(--text-soft); }

/* ---- CTA band --------------------------------------------- */
.ctaband{ position:relative; overflow:hidden; background:linear-gradient(110deg,var(--red) 0%, #5e1a17 100%); color:#fff; }
.ctaband::after{ content:""; position:absolute; right:-40px; top:-40px; width:280px; height:280px; border:30px solid rgba(255,255,255,.06); border-radius:50%; }
.ctaband .wrap{ position:relative; display:flex; flex-wrap:wrap; align-items:center; justify-content:space-between; gap:1.6rem; padding-block:clamp(2.5rem,6vw,4rem); }
.ctaband h2{ color:#fff; }
.ctaband .btn--ghost{ color:#fff; border-color:#fff; }
.ctaband .btn--ghost:hover{ background:#fff; color:var(--red); }

/* ---- Footer ----------------------------------------------- */
.foot{ background:var(--ink); color:#cfcdc0; padding-block:clamp(2.5rem,6vw,4rem) 1.5rem; border-top:4px solid var(--olive); }
.foot__grid{ display:grid; grid-template-columns:1.4fr 1fr 1fr 1.2fr; gap:2rem; }
@media (max-width:880px){ .foot__grid{ grid-template-columns:1fr 1fr; gap:2rem 1.5rem; } }
@media (max-width:520px){ .foot__grid{ grid-template-columns:1fr; } }
.foot-brand{ display:flex; align-items:center; gap:16px; margin-bottom:1.2rem; flex-wrap:wrap; }
.foot-brand img{ height:62px; width:auto; }
.foot h4{ font-family:var(--f-head); text-transform:uppercase; letter-spacing:.1em; font-size:.85rem; color:var(--olive-haze); margin-bottom:1rem; }
.foot a{ color:#cfcdc0; transition:color .2s; }
.foot a:hover{ color:#fff; }
.foot li{ margin-bottom:.6rem; }
.foot .social{ display:flex; gap:.7rem; margin-top:1rem; }
.foot .social a{ width:44px; height:44px; display:grid; place-items:center; border:1px solid var(--line-dark); border-radius:var(--radius); transition:.2s; }
.foot .social a:hover{ background:var(--olive); border-color:var(--olive); color:#fff; }
.foot .social svg{ width:20px; height:20px; }
.foot__bar{ border-top:1px solid var(--line-dark); margin-top:2.5rem; padding-top:1.5rem; display:flex; flex-wrap:wrap; gap:.6rem 1.5rem; justify-content:space-between; align-items:center; font-size:.85rem; color:#9a988c; }
.foot__bar a{ color:#b9b7aa; }
.foot__bar a:hover{ color:#fff; }

/* ---- Page hero (interior pages) --------------------------- */
.phero{ position:relative; color:var(--text-invert); background:linear-gradient(180deg,#0a0a08,#000000); border-bottom:4px solid var(--olive); overflow:hidden; }
.phero::before{ content:""; position:absolute; inset:0; opacity:.18; background-image:linear-gradient(rgba(154,160,106,.12) 1px,transparent 1px),linear-gradient(90deg,rgba(154,160,106,.12) 1px,transparent 1px); background-size:42px 42px; mask-image:radial-gradient(120% 100% at 50% 0,#000,transparent 75%); }
.phero .wrap{ position:relative; padding-block:clamp(2.6rem,6vw,4rem); }
.crumbs{ font-family:var(--f-head); text-transform:uppercase; letter-spacing:.1em; font-size:.78rem; color:var(--olive-haze); display:flex; gap:.5rem; flex-wrap:wrap; margin-bottom:1rem; }
.crumbs a{ color:var(--olive-haze); } .crumbs a:hover{ color:#fff; }
.crumbs span{ color:#6f7152; }

/* ---- Misc -------------------------------------------------- */
.checklist li{ display:flex; gap:.7rem; align-items:flex-start; margin-bottom:.7rem; }
.checklist svg{ flex:0 0 auto; width:22px; height:22px; color:var(--red); margin-top:2px; }
.divider-rib{ height:8px; background:repeating-linear-gradient(45deg,var(--olive) 0 16px, var(--olive-dark) 16px 32px); }
.skip{ position:absolute; left:-999px; top:0; background:var(--red); color:#fff; padding:.7rem 1rem; z-index:100; }
.skip:focus{ left:.5rem; top:.5rem; }

/* Service areas */
.areas-grid{ display:grid; grid-template-columns:repeat(4,1fr); gap:.8rem; }
@media (max-width:760px){ .areas-grid{ grid-template-columns:repeat(2,1fr); } }
@media (max-width:420px){ .areas-grid{ grid-template-columns:1fr; } }
.area-chip{ display:flex; align-items:center; gap:.55rem; padding:.85rem 1rem; background:rgba(255,255,255,.04); border:1px solid var(--line-dark); border-radius:var(--radius); font-family:var(--f-head); text-transform:uppercase; letter-spacing:.04em; font-size:.92rem; color:#e9e7da; transition:border-color .2s, background .2s; }
.area-chip:hover{ border-color:var(--olive-haze); background:rgba(255,255,255,.07); }
.area-chip svg{ width:18px; height:18px; color:var(--olive-haze); flex:0 0 auto; }
.bg-sand .area-chip{ background:#fff; border-color:var(--line); color:var(--text); }
.bg-sand .area-chip svg{ color:var(--red); }

/* Reveal on scroll */
.reveal{ opacity:0; transform:translateY(24px); transition:opacity .6s var(--ease), transform .6s var(--ease); }
.reveal.in{ opacity:1; transform:none; }
@media (prefers-reduced-motion: reduce){ .reveal{ opacity:1 !important; transform:none !important; } }

/* Gallery */
.gallery{ display:grid; grid-template-columns:repeat(3,1fr); gap:1rem; }
@media (max-width:900px){ .gallery{ grid-template-columns:repeat(2,1fr); } }
@media (max-width:560px){ .gallery{ grid-template-columns:1fr; } }
.gallery figure{ margin:0; border-radius:var(--radius-lg); overflow:hidden; position:relative; aspect-ratio:4/3; background:var(--char); border:1px solid var(--line); }
.gallery img{ width:100%; height:100%; object-fit:cover; transition:transform .5s var(--ease); }
.gallery figure:hover img{ transform:scale(1.06); }
.gallery figcaption{ position:absolute; left:0; right:0; bottom:0; padding:1.4rem 1rem .9rem; color:#fff; font-family:var(--f-head); text-transform:uppercase; letter-spacing:.05em; font-size:.85rem; background:linear-gradient(transparent,rgba(14,14,12,.85)); }

/* Contact form */
.form{ display:grid; gap:1.1rem; }
.field{ display:flex; flex-direction:column; gap:.4rem; }
.field label{ font-family:var(--f-head); text-transform:uppercase; letter-spacing:.06em; font-size:.82rem; font-weight:600; }
.field input,.field select,.field textarea{
  font:inherit; padding:.85rem 1rem; border:1px solid var(--line); border-radius:var(--radius); background:#fff; color:var(--text); min-height:50px;
  transition:border-color .2s, box-shadow .2s;
}
.field textarea{ min-height:140px; resize:vertical; }
.field input:focus,.field select:focus,.field textarea:focus{ outline:none; border-color:var(--olive); box-shadow:0 0 0 3px rgba(74,77,46,.18); }
.form .row{ display:grid; grid-template-columns:1fr 1fr; gap:1.1rem; }
@media (max-width:560px){ .form .row{ grid-template-columns:1fr; } }

/* Info tiles */
.info{ display:flex; gap:1rem; align-items:flex-start; padding:1.2rem; border:1px solid var(--line); border-radius:var(--radius-lg); background:var(--surface); }
.info .ic{ flex:0 0 auto; width:46px; height:46px; border-radius:var(--radius); background:var(--olive); color:var(--cream); display:grid; place-items:center; }
.info .ic svg{ width:22px; height:22px; }
.info b{ font-family:var(--f-head); text-transform:uppercase; letter-spacing:.04em; font-size:.95rem; display:block; }
.info a,.info p{ color:var(--text-soft); }

/* Acuity embed frame */
.sched{ background:#fff; border:1px solid var(--line); border-radius:var(--radius-lg); overflow:hidden; box-shadow:var(--shadow); }
.sched iframe{ width:100%; min-height:850px; border:0; display:block; }
