/* ==========================================================================
   Valley Overhead Door — site.css  (shared shell for every page)
   Architecture: tokens → reset → type → layout → nav → buttons → hero →
   page-header → components → footer → call-bar → reveals → responsive → a11y
   ========================================================================== */

/* ---------- Tokens ---------- */
:root{
  --ink:#0E1620; --ink-2:#14202D; --ink-3:#1B2A39; --line-dark:#2A3B4D;
  --on-dark:#EAF1F8; --on-dark-dim:#A9BDD0;
  --paper:#F7F5F1; --paper-2:#FFFFFF; --paper-3:#EFEBE3; --line:#E2DBD0;
  --text:#15202B; --text-dim:#4F5B67; --text-mute:#5C6670;
  --brass:#C0883E; --brass-bright:#DDA24B; --brass-deep:#8C6126;
  --blue-deep:#2C5A86; --blue-glow:#4E86B8;
  --ring:rgba(192,136,62,.55); --ok:#2F8F5B; --cta-ink:#0E1620;

  --container:1180px; --container-wide:1320px; --pad-x:clamp(20px,5vw,32px);
  --section:clamp(64px,9vw,120px);
  --r-sm:8px; --r:14px; --r-lg:22px; --r-pill:999px;
  --shadow-sm:0 1px 2px rgba(16,24,32,.06),0 2px 8px rgba(16,24,32,.05);
  --shadow:0 6px 24px rgba(16,24,32,.08);
  --shadow-lg:0 18px 50px rgba(16,24,32,.14);
  --glow-brass:0 0 0 1px rgba(192,136,62,.40),0 12px 40px rgba(192,136,62,.22);

  --ff-display:"Fraunces",Georgia,"Times New Roman",serif;
  --ff-body:"Inter",system-ui,-apple-system,Segoe UI,Roboto,Helvetica,Arial,sans-serif;
  --nav-h:76px;
  color-scheme:light;
}

/* ---------- Reset / base ---------- */
*,*::before,*::after{box-sizing:border-box}
*{margin:0}
html{-webkit-text-size-adjust:100%;scroll-behavior:smooth}
body{
  font-family:var(--ff-body);font-size:var(--body,1.0625rem);line-height:1.65;
  color:var(--text);background:var(--paper);
  -webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
img,svg,video{display:block;max-width:100%}
img{height:auto}
a{color:var(--brass-deep);text-decoration:none}
a:hover{color:var(--brass)}
ul,ol{list-style:none;padding:0}
button{font:inherit;color:inherit;cursor:pointer;background:none;border:0}
input,textarea,select{font:inherit}
:focus-visible{outline:2px solid var(--brass);outline-offset:2px;border-radius:4px}
::selection{background:var(--brass);color:#fff}

/* ---------- Typography ---------- */
h1,h2,h3,h4{font-family:var(--ff-display);font-weight:500;line-height:1.1;color:var(--text);letter-spacing:-.01em}
h1{font-size:clamp(2.5rem,1.6rem + 4vw,4.75rem);line-height:1.04}
h2{font-size:clamp(1.9rem,1.4rem + 2.2vw,3rem);line-height:1.08}
h3{font-size:clamp(1.25rem,1.05rem + .8vw,1.6rem);font-weight:600;line-height:1.15}
h4{font-size:1.125rem;font-weight:600}
p{max-width:65ch}
strong{font-weight:600}
.lead{font-size:clamp(1.05rem,1rem + .4vw,1.3rem);line-height:1.6;color:var(--text-dim);font-weight:400}
.eyebrow{font-size:.8rem;font-weight:600;text-transform:uppercase;letter-spacing:.14em;color:var(--brass-deep);display:inline-flex;align-items:center;gap:.5rem}
.eyebrow::before{content:"";width:26px;height:1px;background:var(--brass)}

/* ---------- Layout ---------- */
[id]{scroll-margin-top:calc(var(--nav-h) + 16px)}
.container{width:100%;max-width:var(--container);margin-inline:auto;padding-inline:var(--pad-x)}
.container.wide{max-width:var(--container-wide)}
.section{padding-block:var(--section)}
.section.alt{background:var(--paper-3)}
.section.dark{background:var(--ink);color:var(--on-dark)}
.section.dark h1,.section.dark h2,.section.dark h3,.section.dark h4{color:var(--on-dark)}
.section.dark .lead{color:var(--on-dark-dim)}
.section.dark .eyebrow{color:var(--brass-bright)}
.section-head{max-width:62ch;margin-bottom:clamp(2rem,4vw,3.25rem)}
.section-head.center{margin-inline:auto;text-align:center}
.section-head .eyebrow{margin-bottom:1rem}
.section-head h2{margin-bottom:.85rem}
.grid{display:grid;gap:clamp(1.25rem,2.5vw,2rem)}
.skip-link{position:absolute;left:50%;top:-60px;transform:translateX(-50%);z-index:200;background:var(--ink);color:#fff;padding:.7rem 1.2rem;border-radius:0 0 var(--r) var(--r);transition:top .2s}
.skip-link:focus{top:0;color:#fff}

/* ---------- Buttons ---------- */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:.55rem;
  padding:14px 24px;min-height:48px;border-radius:var(--r-pill);
  font-weight:600;font-size:.95rem;letter-spacing:.01em;
  transition:transform .18s ease,background .18s ease,box-shadow .18s ease,color .18s ease;
  cursor:pointer;border:1px solid transparent;white-space:nowrap}
.btn svg{width:19px;height:19px}
.btn-call{background:var(--brass);color:var(--cta-ink)}
.btn-call:hover{background:var(--brass-bright);color:var(--cta-ink);transform:translateY(-1px);box-shadow:0 8px 22px rgba(192,136,62,.32)}
.btn-call:active{transform:translateY(0)}
.btn-ghost{border-color:var(--line);color:var(--text);background:transparent}
.btn-ghost:hover{border-color:var(--brass);color:var(--brass-deep);background:rgba(192,136,62,.06)}
.btn-light{background:var(--paper);color:var(--ink)}
.btn-light:hover{background:#fff;transform:translateY(-1px);box-shadow:var(--shadow)}
.on-dark .btn-ghost,.page-header .btn-ghost,.cta-band .btn-ghost,.section.dark .btn-ghost{border-color:var(--line-dark);color:var(--on-dark)}
.on-dark .btn-ghost:hover,.page-header .btn-ghost:hover,.cta-band .btn-ghost:hover,.section.dark .btn-ghost:hover{border-color:var(--brass-bright);color:var(--brass-bright);background:rgba(221,162,75,.10)}
.btn-lg{padding:17px 30px;min-height:56px;font-size:1.02rem}
.btn-block{width:100%}

/* ---------- Nav ---------- */
.site-nav{position:fixed;inset:0 0 auto 0;z-index:100;height:var(--nav-h);
  display:flex;align-items:center;transition:background .3s ease,box-shadow .3s ease,backdrop-filter .3s ease}
.site-nav .nav-inner{display:flex;align-items:center;justify-content:space-between;gap:1.5rem;width:100%;max-width:var(--container-wide);margin-inline:auto;padding-inline:var(--pad-x)}
.brand{display:inline-flex;align-items:center;gap:.6rem;color:var(--on-dark)}
.brand:hover{color:var(--on-dark)}
.brand-mark{width:34px;height:34px;flex:none;color:var(--brass)}
.brand-name{font-family:var(--ff-display);font-weight:600;font-size:1.12rem;letter-spacing:.01em;line-height:1.05}
.brand-name small{display:block;font-family:var(--ff-body);font-weight:600;font-size:.56rem;letter-spacing:.22em;text-transform:uppercase;color:var(--brass-bright);margin-top:2px}
.nav-links{display:flex;align-items:center;gap:.35rem}
.nav-links a{color:var(--on-dark);font-weight:500;font-size:.95rem;padding:.5rem .8rem;border-radius:var(--r-sm);transition:color .15s,background .15s}
.nav-links a:hover,.nav-links a[aria-current="page"]{color:#fff;background:rgba(255,255,255,.10)}
.nav-right{display:flex;align-items:center;gap:.75rem}
.nav-phone{display:inline-flex;align-items:center;gap:.45rem}
.nav-toggle{display:none;width:44px;height:44px;align-items:center;justify-content:center;color:var(--on-dark);border-radius:var(--r-sm)}
.nav-toggle svg{width:26px;height:26px}

/* scrolled / solid state */
.site-nav.scrolled{background:rgba(247,245,241,.92);backdrop-filter:saturate(140%) blur(10px);box-shadow:0 1px 0 var(--line),0 6px 24px rgba(16,24,32,.06)}
.site-nav.scrolled .brand,.site-nav.scrolled .nav-links a{color:var(--text)}
.site-nav.scrolled .brand-mark{color:var(--brass)}
.site-nav.scrolled .nav-links a:hover,.site-nav.scrolled .nav-links a[aria-current="page"]{color:var(--brass-deep);background:rgba(192,136,62,.10)}
.site-nav.scrolled .nav-toggle{color:var(--text)}
.site-nav.scrolled .brand-name small{color:var(--brass-deep)}

/* scroll progress */
.scroll-progress{position:fixed;top:0;left:0;height:2px;width:0;background:linear-gradient(90deg,var(--brass),var(--brass-bright));z-index:101;transition:width .08s linear}

/* mobile drawer */
.nav-drawer{position:fixed;inset:0;z-index:99;background:rgba(14,22,32,.55);opacity:0;visibility:hidden;transition:opacity .3s}
.nav-drawer-panel{position:absolute;top:0;right:0;height:100%;width:min(86vw,360px);background:var(--ink);transform:translateX(100%);transition:transform .32s cubic-bezier(.4,0,.2,1);display:flex;flex-direction:column;padding:calc(var(--nav-h) + 1rem) var(--s6) var(--s7);gap:.25rem}
body.nav-open{overflow:hidden}
body.nav-open .nav-drawer{opacity:1;visibility:visible}
body.nav-open .nav-drawer-panel{transform:translateX(0)}
.nav-drawer a{color:var(--on-dark);font-size:1.15rem;font-weight:500;padding:.85rem 0;border-bottom:1px solid var(--line-dark)}
.nav-drawer a:hover{color:var(--brass-bright)}
.nav-drawer .btn{margin-top:1.5rem}
.drawer-close{position:absolute;top:1.1rem;right:1.1rem;width:44px;height:44px;display:flex;align-items:center;justify-content:center;color:var(--on-dark)}
.drawer-close svg{width:26px;height:26px}

/* ---------- Hero (home) ---------- */
.hero{position:relative;min-height:100svh;display:flex;align-items:center;background:var(--ink);color:var(--on-dark);overflow:hidden;isolation:isolate}
.hero canvas#hero3d{position:absolute;inset:0;width:100%;height:100%;z-index:0;display:block}
.hero-fallback{position:absolute;inset:0;z-index:0;
  background:
    radial-gradient(120% 90% at 75% 18%,rgba(78,134,184,.22),transparent 60%),
    radial-gradient(90% 80% at 18% 90%,rgba(192,136,62,.20),transparent 55%),
    linear-gradient(160deg,#0c141e 0%,#13202e 48%,#0a1119 100%)}
.hero-fallback::after{content:"";position:absolute;inset:0;opacity:.5;
  background-image:repeating-linear-gradient(0deg,rgba(255,255,255,.035) 0 2px,transparent 2px 64px),repeating-linear-gradient(90deg,rgba(255,255,255,.025) 0 2px,transparent 2px 96px)}
.hero-overlay{position:absolute;inset:0;z-index:1;pointer-events:none;
  background:
    linear-gradient(90deg,rgba(8,13,21,.92) 0%,rgba(8,13,21,.72) 26%,rgba(8,13,21,.34) 50%,rgba(8,13,21,.06) 74%,transparent 100%),
    linear-gradient(180deg,rgba(8,13,21,.55) 0%,transparent 16% 64%,rgba(8,13,21,.86) 100%)}
@media (max-width:760px){.hero-overlay{background:linear-gradient(180deg,rgba(8,13,21,.62) 0%,rgba(8,13,21,.32) 38%,rgba(8,13,21,.6) 72%,rgba(8,13,21,.9) 100%)}}
.hero-content{position:relative;z-index:2;width:100%;max-width:760px;padding-block:calc(var(--nav-h) + 2rem) 4rem}
.hero .eyebrow{color:var(--brass-bright);margin-bottom:1.25rem}
.hero h1{color:#fff;margin-bottom:1.35rem}
.hero h1 .accent{color:var(--brass-bright);font-style:italic}
.hero .lead{color:var(--on-dark-dim);max-width:52ch;margin-bottom:2rem}
.hero-ctas{display:flex;flex-wrap:wrap;gap:.85rem;margin-bottom:2.25rem}
.hero-chips{display:flex;flex-wrap:wrap;gap:.6rem 1.4rem;align-items:center}
.hero-chip{display:inline-flex;align-items:center;gap:.5rem;font-size:.92rem;color:var(--on-dark);font-weight:500}
.hero-chip svg{width:18px;height:18px;color:var(--brass-bright);flex:none}
.hero-chip .stars{color:var(--brass-bright);letter-spacing:1px}
.scroll-cue{position:absolute;left:50%;bottom:22px;transform:translateX(-50%);z-index:2;color:var(--on-dark-dim);display:flex;flex-direction:column;align-items:center;gap:.4rem;font-size:.72rem;letter-spacing:.18em;text-transform:uppercase}
.scroll-cue .mouse{width:24px;height:38px;border:1.5px solid var(--on-dark-dim);border-radius:12px;position:relative}
.scroll-cue .mouse::after{content:"";position:absolute;top:7px;left:50%;width:3px;height:7px;background:var(--brass-bright);border-radius:2px;transform:translateX(-50%);animation:scrollwheel 1.6s ease-in-out infinite}
@keyframes scrollwheel{0%{opacity:0;transform:translate(-50%,0)}40%{opacity:1}80%{opacity:0;transform:translate(-50%,10px)}}

/* ---------- Page header (inner pages — dark, light CSS motion, no WebGL) ---------- */
.page-header{position:relative;background:var(--ink);color:var(--on-dark);overflow:hidden;isolation:isolate;padding:calc(var(--nav-h) + clamp(2.5rem,7vw,5rem)) 0 clamp(2.5rem,6vw,4.5rem)}
.page-header::before{content:"";position:absolute;inset:0;z-index:0;
  background:
    radial-gradient(100% 120% at 82% 0%,rgba(78,134,184,.20),transparent 58%),
    radial-gradient(80% 100% at 0% 100%,rgba(192,136,62,.16),transparent 55%),
    linear-gradient(160deg,#0c141e,#13202e 60%,#0a1119)}
.page-header::after{content:"";position:absolute;inset:0;z-index:0;opacity:.45;
  background-image:repeating-linear-gradient(0deg,rgba(255,255,255,.03) 0 1px,transparent 1px 56px),repeating-linear-gradient(90deg,rgba(255,255,255,.022) 0 1px,transparent 1px 84px);
  -webkit-mask-image:linear-gradient(90deg,transparent,#000 40%);mask-image:linear-gradient(90deg,transparent,#000 40%)}
.page-header .container{position:relative;z-index:1}
.page-header .eyebrow{color:var(--brass-bright);margin-bottom:1rem}
.page-header h1{color:#fff;margin-bottom:1.1rem;max-width:18ch;font-size:clamp(2.1rem,1.5rem + 2.4vw,3.5rem)}
.page-header .lead{color:var(--on-dark-dim);max-width:60ch}
.page-header .hero-ctas{margin-top:1.75rem}
.breadcrumb{display:flex;flex-wrap:wrap;gap:.4rem;align-items:center;font-size:.82rem;color:var(--on-dark-dim);margin-bottom:1.4rem}
.breadcrumb a{color:var(--on-dark-dim)}
.breadcrumb a:hover{color:var(--brass-bright)}
.breadcrumb svg{width:14px;height:14px;opacity:.6}

/* ---------- Trust stat strip ---------- */
.stat-strip{background:var(--paper-2);border:1px solid var(--line);border-radius:var(--r-lg);box-shadow:var(--shadow-lg);
  display:grid;grid-template-columns:repeat(5,1fr);gap:1px;overflow:hidden;background-clip:padding-box}
.stat-strip.overlap{position:relative;z-index:3;margin-top:calc(-1 * clamp(40px,7vw,72px))}
.stat{padding:clamp(1.4rem,2.5vw,2rem) 1rem;text-align:center;position:relative}
.stat + .stat::before{content:"";position:absolute;left:0;top:18%;height:64%;width:1px;background:var(--line)}
.stat .num{font-family:var(--ff-display);font-weight:500;font-size:clamp(1.7rem,2.6vw,2.5rem);color:var(--text);line-height:1;letter-spacing:-.02em}
.stat .num .star{color:var(--brass)}
.stat .label{font-size:.82rem;color:var(--text-dim);margin-top:.5rem;font-weight:500}

/* ---------- Cards: services ---------- */
.card-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(248px,1fr));gap:clamp(1rem,2vw,1.5rem)}
.s-card{background:var(--paper-2);border:1px solid var(--line);border-radius:var(--r);padding:clamp(1.5rem,2.5vw,2rem);transition:transform .2s ease,box-shadow .2s ease,border-color .2s ease;display:flex;flex-direction:column;height:100%}
.s-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg);border-color:rgba(192,136,62,.4)}
.s-icon{width:52px;height:52px;border-radius:12px;display:flex;align-items:center;justify-content:center;background:rgba(192,136,62,.12);color:var(--brass-deep);margin-bottom:1.1rem;flex:none;transition:background .2s,color .2s}
.s-card:hover .s-icon{background:var(--brass);color:#fff}
.s-icon svg{width:26px;height:26px}
.s-card h3{margin-bottom:.5rem}
.s-card p{color:var(--text-dim);font-size:.96rem;margin-bottom:1rem}
.card-link{font-weight:600;font-size:.9rem;color:var(--brass-deep);display:inline-flex;align-items:center;gap:.4rem}
.card-link svg{width:16px;height:16px;transition:transform .2s}
.card-link:hover svg{transform:translateX(4px)}
.s-card .card-link{margin-top:auto}
.s-card:hover .card-link svg{transform:translateX(4px)}

/* feature list (services/about) */
.feature-list{display:flex;flex-direction:column;gap:1.1rem}
.feature{display:flex;gap:1rem;align-items:flex-start}
.feature .fi{width:40px;height:40px;border-radius:10px;background:rgba(192,136,62,.12);color:var(--brass-deep);display:flex;align-items:center;justify-content:center;flex:none}
.feature .fi svg{width:22px;height:22px}
.feature h3,.feature h4{margin-bottom:.2rem;font-size:1.125rem;font-weight:600}
.feature p{color:var(--text-dim);font-size:.95rem}

/* split layout */
.split{display:grid;grid-template-columns:1fr 1fr;gap:clamp(2rem,5vw,4.5rem);align-items:center}
.split.narrow{gap:clamp(1.5rem,4vw,3rem)}
.media-frame{position:relative;border-radius:var(--r-lg);overflow:hidden;box-shadow:var(--shadow-lg);background:var(--ink-2)}
.media-frame img{width:100%;height:100%;object-fit:cover;display:block}
.media-frame.duo img{filter:grayscale(.35) contrast(1.04) brightness(.92)}
.media-frame.duo::after{content:"";position:absolute;inset:0;background:linear-gradient(150deg,rgba(192,136,62,.28),rgba(44,90,134,.30));mix-blend-mode:multiply}
.media-frame .tag{position:absolute;left:14px;bottom:14px;z-index:2;background:rgba(14,22,32,.78);color:var(--on-dark);font-size:.78rem;font-weight:600;padding:.4rem .8rem;border-radius:var(--r-pill);backdrop-filter:blur(4px)}

/* ---------- Reviews ---------- */
.reviews-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:clamp(1rem,2vw,1.5rem)}
.review-card{background:var(--paper-2);border:1px solid var(--line);border-radius:var(--r);padding:clamp(1.4rem,2.2vw,1.8rem);display:flex;flex-direction:column;gap:.9rem;box-shadow:var(--shadow-sm)}
.review-card .stars{color:var(--brass);letter-spacing:2px;font-size:1.05rem}
.review-card blockquote{font-size:1rem;line-height:1.6;color:var(--text);max-width:none}
.review-card .who{display:flex;align-items:center;gap:.7rem;margin-top:auto}
.avatar{width:42px;height:42px;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;font-weight:600;font-size:.95rem;flex:none}
.who .name{font-weight:600;font-size:.92rem}
.who .src{font-size:.78rem;color:var(--text-mute);display:flex;align-items:center;gap:.3rem}
.google-rating{display:inline-flex;align-items:center;gap:.9rem;background:var(--paper-2);border:1px solid var(--line);border-radius:var(--r-pill);padding:.6rem 1.2rem;box-shadow:var(--shadow-sm)}
.google-rating .g-logo{font-weight:700;font-size:1.1rem;letter-spacing:-.5px}
.google-rating .g-num{font-weight:700;font-size:1.15rem}
.google-rating .stars{color:var(--brass)}
.google-rating .g-meta{font-size:.82rem;color:var(--text-dim)}

/* ---------- City tags / brands ---------- */
.tag-row{display:flex;flex-wrap:wrap;gap:.6rem}
.tag{background:var(--paper-2);border:1px solid var(--line);border-radius:var(--r-pill);padding:.5rem 1rem;font-size:.88rem;font-weight:600;color:var(--text);display:inline-flex;align-items:center;gap:.4rem}
.tag svg{width:15px;height:15px;color:var(--brass-deep)}
.brands{display:flex;flex-wrap:wrap;align-items:center;justify-content:center;gap:1rem 2.2rem}
.brands .b-label{font-size:.82rem;font-weight:600;text-transform:uppercase;letter-spacing:.1em;color:var(--text-mute)}
.brand-name-tag{font-family:var(--ff-display);font-size:1.25rem;color:var(--text);font-weight:600;opacity:.78;transition:opacity .2s,color .2s}
.brand-name-tag:hover{opacity:1;color:var(--brass-deep)}

/* ---------- FAQ ---------- */
.faq{max-width:760px;margin-inline:auto;border-top:1px solid var(--line)}
.faq-item{border-bottom:1px solid var(--line)}
.faq-item summary{padding:1.25rem 2.5rem 1.25rem 0;cursor:pointer;font-weight:600;font-size:1.08rem;list-style:none;position:relative;color:var(--text);font-family:var(--ff-display)}
.faq-item summary::-webkit-details-marker{display:none}
.faq-item summary::after{content:"";position:absolute;right:.2rem;top:1.5rem;width:14px;height:14px;background:none;border-right:2px solid var(--brass);border-bottom:2px solid var(--brass);transform:rotate(45deg);transition:transform .25s}
.faq-item[open] summary::after{transform:rotate(225deg)}
.faq-item .faq-a{padding:0 2.5rem 1.4rem 0}
.faq-item .faq-a p{color:var(--text-dim)}

/* ---------- CTA band ---------- */
.cta-band{position:relative;background:var(--ink);color:var(--on-dark);overflow:hidden;isolation:isolate;text-align:center}
.cta-band::before{content:"";position:absolute;inset:0;z-index:0;background:radial-gradient(80% 140% at 50% 0%,rgba(192,136,62,.22),transparent 60%),radial-gradient(60% 120% at 50% 100%,rgba(44,90,134,.22),transparent 60%)}
.cta-band .container{position:relative;z-index:1}
.cta-band h2{color:#fff;margin-bottom:1rem}
.cta-band .lead{color:var(--on-dark-dim);margin-inline:auto;margin-bottom:2rem}
.cta-band .hero-ctas{justify-content:center}
.cta-phone{font-family:var(--ff-display);font-size:clamp(1.6rem,3vw,2.3rem);color:var(--brass-bright);font-weight:600;display:inline-flex;align-items:center;gap:.6rem}
.cta-phone svg{width:1em;height:1em}

/* ---------- Contact form ---------- */
.form-card{background:var(--paper-2);border:1px solid var(--line);border-radius:var(--r-lg);padding:clamp(1.5rem,3vw,2.5rem);box-shadow:var(--shadow)}
.field{margin-bottom:1.1rem}
.field label{display:block;font-weight:600;font-size:.88rem;margin-bottom:.4rem;color:var(--text)}
.field label .req{color:var(--brass-deep)}
.field input,.field textarea{width:100%;padding:.85rem 1rem;border:1px solid var(--line);border-radius:var(--r-sm);background:var(--paper);color:var(--text);transition:border-color .15s,box-shadow .15s}
.field input:focus,.field textarea:focus{outline:none;border-color:var(--brass);box-shadow:0 0 0 3px var(--ring)}
.field textarea{min-height:120px;resize:vertical}
.field.invalid input,.field.invalid textarea{border-color:#c0392b;box-shadow:0 0 0 3px rgba(192,57,43,.15)}
.field .err{display:none;color:#c0392b;font-size:.8rem;margin-top:.3rem}
.field.invalid .err{display:block}
.form-status{margin-top:.8rem;font-weight:600;font-size:.92rem;min-height:1.2em}
.form-status.ok{color:var(--ok)}
.form-status.bad{color:#c0392b}

/* ---------- Contact info list / map ---------- */
.info-list{display:flex;flex-direction:column;gap:1.25rem}
.info-row{display:flex;gap:.9rem;align-items:flex-start}
.info-row .fi{width:42px;height:42px;border-radius:10px;background:var(--ink);color:var(--brass-bright);display:flex;align-items:center;justify-content:center;flex:none}
.info-row .fi svg{width:21px;height:21px}
.info-row .k{display:block;font-size:.78rem;text-transform:uppercase;letter-spacing:.08em;color:var(--text-mute);font-weight:600;margin-bottom:2px}
.info-row .v{display:block;font-size:1.05rem;color:var(--text);font-weight:500}
.info-row a.v{color:var(--brass-deep)}
.map-frame{border-radius:var(--r-lg);overflow:hidden;border:1px solid var(--line);box-shadow:var(--shadow);aspect-ratio:16/10;background:var(--paper-3)}
.map-frame iframe{width:100%;height:100%;border:0;display:block}

/* ---------- Footer ---------- */
.site-footer{background:var(--ink);color:var(--on-dark-dim);padding-block:clamp(3rem,6vw,4.5rem) 0;border-top:1px solid var(--line-dark)}
.footer-grid{display:grid;grid-template-columns:1.6fr 1fr 1fr 1.3fr;gap:clamp(1.75rem,3vw,2.75rem)}
.site-footer .brand{color:var(--on-dark);margin-bottom:1rem}
.footer-about p{font-size:.92rem;color:var(--on-dark-dim);max-width:34ch}
.footer-rating{margin-top:1.1rem;display:inline-flex;align-items:center;gap:.5rem;font-size:.9rem;color:var(--on-dark)}
.footer-rating .stars{color:var(--brass-bright)}
.site-footer h4{color:var(--on-dark);font-family:var(--ff-body);font-size:.82rem;text-transform:uppercase;letter-spacing:.1em;margin-bottom:1.1rem}
.footer-col a{display:block;color:var(--on-dark-dim);padding:.32rem 0;font-size:.95rem}
.footer-col a:hover{color:var(--brass-bright)}
.footer-contact .info-row .fi{background:var(--ink-3);width:36px;height:36px}
.footer-contact .info-row{gap:.7rem}
.footer-contact .v{font-size:.95rem;color:var(--on-dark)}
.footer-contact a.v{color:var(--on-dark)}
.footer-contact a.v:hover{color:var(--brass-bright)}
.footer-contact .info-row .k{color:var(--on-dark-dim)}
.footer-bottom{border-top:1px solid var(--line-dark);margin-top:clamp(2.5rem,5vw,3.5rem);padding-block:1.5rem;display:flex;flex-wrap:wrap;gap:.5rem 1.5rem;justify-content:space-between;align-items:center;font-size:.82rem;color:var(--on-dark-dim)}
.footer-bottom a{color:var(--on-dark-dim)}
.footer-bottom a:hover{color:var(--brass-bright)}

/* ---------- Sticky mobile call bar ---------- */
.call-bar{position:fixed;left:0;right:0;bottom:0;z-index:95;display:none;
  align-items:center;justify-content:center;gap:.5rem;
  background:var(--brass);color:var(--cta-ink);font-weight:700;
  padding:.95rem;box-shadow:0 -4px 20px rgba(0,0,0,.18)}
.call-bar svg{width:20px;height:20px}

/* ---------- Reveals ---------- */
.reveal{opacity:0;transform:translateY(20px);transition:opacity .7s cubic-bezier(.22,.61,.36,1),transform .7s cubic-bezier(.22,.61,.36,1)}
.reveal.in{opacity:1;transform:none}
.reveal.from-left{transform:translateX(-28px)}
.reveal.from-right{transform:translateX(28px)}
.reveal.scale-up{transform:scale(.96)}
.reveal.in.from-left,.reveal.in.from-right,.reveal.in.scale-up{transform:none}

/* ---------- Responsive ---------- */
@media (max-width:980px){
  .footer-grid{grid-template-columns:1fr 1fr}
  .split{grid-template-columns:1fr;gap:2.25rem}
  .split .media-frame{order:-1}
}
@media (max-width:860px){
  .nav-links{display:none}
  .nav-toggle{display:flex}
  .stat-strip{grid-template-columns:repeat(2,1fr)}
  .stat-strip .stat:nth-child(5){grid-column:1 / -1}
  .stat + .stat::before{display:none}
}
@media (max-width:767px){
  .call-bar{display:flex}
  body{padding-bottom:60px}
  .site-nav.scrolled+.call-bar,.call-bar{}
  .hero{min-height:92svh}
  .hero-content{padding-top:calc(var(--nav-h) + 1rem)}
  .scroll-cue{display:none}
  .footer-grid{grid-template-columns:1fr;gap:1.75rem}
  .footer-bottom{flex-direction:column;text-align:center}
}
@media (max-width:520px){
  .stat-strip{grid-template-columns:1fr 1fr}
  .hero-ctas .btn{flex:1 1 auto}
  .brand-name small{display:none}
  .nav-phone-text{display:none}
}

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

/* ---------- Print ---------- */
@media print{.site-nav,.call-bar,.scroll-progress,.scroll-cue,.nav-drawer{display:none !important}body{padding:0}}
