/* ============================================================
   BWS Blinds — premium rebuild
   Sans-forward: Clash Display (headlines) + Switzer (body).
   Warm neutral palette, one dark espresso accent.
   Photography first, scroll-reveal motion, full-bleed hero.
   ============================================================ */

/* ===== Fonts ===== */
@font-face { font-family:"Clash Display"; src:url("../fonts/clash-500.woff2") format("woff2"); font-weight:500; font-display:swap; }
@font-face { font-family:"Clash Display"; src:url("../fonts/clash-600.woff2") format("woff2"); font-weight:600; font-display:swap; }
@font-face { font-family:"Clash Display"; src:url("../fonts/clash-700.woff2") format("woff2"); font-weight:700; font-display:swap; }
@font-face { font-family:"Switzer"; src:url("../fonts/switzer-400.woff2") format("woff2"); font-weight:400; font-display:swap; }
@font-face { font-family:"Switzer"; src:url("../fonts/switzer-500.woff2") format("woff2"); font-weight:500; font-display:swap; }
@font-face { font-family:"Switzer"; src:url("../fonts/switzer-600.woff2") format("woff2"); font-weight:600; font-display:swap; }
/* Wordmark only: Playfair Display (the "BWS Blinds" logotype, not headings) */
@font-face { font-family:"Playfair Display"; src:url("../fonts/playfair-700.woff2") format("woff2"); font-weight:700; font-display:swap; }

/* ===== Tokens ===== */
:root {
  /* Declare our own theming so phone browsers (Samsung Internet / Chrome auto dark)
     do NOT force-dark the page and repaint the white hero heading black. */
  color-scheme: light dark;
  --ink:#1b1712;
  --espresso:#241d16;       /* dark accent: bands + the one action */
  --paper:#fbfaf6;
  --paper-2:#f1ece3;
  --sand:#e7dfd2;
  --muted:#8c8377;
  --muted-d:#b4a994;
  --line:#ddd5c7;
  --line-dk:rgba(255,255,255,.14);

  /* ===== Heading font options (client review, Jun 28) =====
     The old Clash Display read too "trendy" for an old-school fabricator.
     Two plainer choices below. Body copy (Switzer) is unchanged.
       Option A — Impact: heavy, condensed, old-school.
       Option B — Helvetica / Arial: clean, neutral, timeless.  [ACTIVE]
     To switch, comment Option B and uncomment Option A. */
  /* --font-display:"Impact","Haettenschweiler","Franklin Gothic Bold","Arial Narrow Bold",sans-serif; */  /* Option A */
  --font-display:"Helvetica Neue",Helvetica,Arial,sans-serif;                                              /* Option B */
  --font-body:"Switzer",system-ui,-apple-system,"Segoe UI",sans-serif;

  --maxw:1280px;
  --gutter:clamp(1.25rem,5vw,4.5rem);
  --section-y:clamp(4.5rem,10vw,9rem);
  --radius:4px;
  --header-h:78px;
  --ease:cubic-bezier(.2,.7,.2,1);
}

/* ===== Reset ===== */
*,*::before,*::after{box-sizing:border-box;}
*{margin:0;}
html{-webkit-text-size-adjust:100%;scroll-behavior:smooth;scroll-padding-top:calc(var(--header-h) + 1rem);}
body{
  font-family:var(--font-body);
  color:var(--ink);
  background:var(--paper);
  line-height:1.6;
  font-size:1.0625rem;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
body.nav-open{overflow:hidden;}
img{display:block;max-width:100%;height:auto;}
a{color:inherit;text-decoration:none;}
:focus-visible{outline:2px solid var(--ink);outline-offset:3px;}

/* ===== Type ===== */
h1,h2,h3,h4{font-family:var(--font-display);font-weight:600;line-height:1.02;letter-spacing:-0.02em;color:var(--ink);text-wrap:balance;}
h1{font-size:clamp(2.9rem,7.5vw,6rem);font-weight:600;}
h2{font-size:clamp(2.1rem,4.6vw,3.7rem);}
h3{font-size:clamp(1.35rem,2.2vw,1.9rem);letter-spacing:-0.01em;}
.display-xl{font-size:clamp(3.4rem,9vw,7.5rem);line-height:.95;}
.italic{font-style:italic;}
p{color:var(--ink);opacity:.82;max-width:60ch;text-wrap:pretty;}
.lead{font-size:clamp(1.1rem,1.7vw,1.35rem);line-height:1.5;opacity:.85;text-wrap:pretty;}
.eyebrow{display:inline-flex;align-items:center;gap:.6rem;font-family:var(--font-body);font-size:.72rem;font-weight:600;letter-spacing:.24em;text-transform:uppercase;color:var(--muted);}
.eyebrow::before{content:"";width:26px;height:1px;background:currentColor;opacity:.6;}
.section--ink .eyebrow,.nav-overlay .eyebrow{color:var(--muted-d);}

/* ===== Layout ===== */
.container{width:100%;max-width:var(--maxw);margin-inline:auto;padding-inline:var(--gutter);}
.section{padding-block:var(--section-y);}
.section--warm{background:var(--paper-2);}
.section--ink{background:var(--espresso);color:#efe9df;}
.section--ink h1,.section--ink h2,.section--ink h3{color:#fff;}
.section--ink p{color:#cabfae;opacity:1;}
.section-head{max-width:30ch;margin-bottom:clamp(2.5rem,5vw,4rem);}
.section-head.wide{max-width:46ch;}
.section-head h2{margin-top:1rem;}
.section-head p{margin-top:1.1rem;max-width:50ch;}
.divider{height:1px;background:var(--line);}

/* ===== Motion: scroll reveal ===== */
.reveal{opacity:0;transform:translateY(28px);transition:opacity .9s var(--ease),transform .9s var(--ease);}
.reveal.in{opacity:1;transform:none;}
.reveal.d1{transition-delay:.08s;}
.reveal.d2{transition-delay:.16s;}
.reveal.d3{transition-delay:.24s;}

/* Eyebrow rule draws in as its block reveals */
.reveal .eyebrow::before{width:0;transition:width .8s var(--ease) .15s;}
.reveal.in .eyebrow::before{width:26px;}

@media (prefers-reduced-motion:reduce){
  .reveal{opacity:1;transform:none;transition:none;}
  .reveal .eyebrow::before{width:26px;transition:none;}
  .hero .eyebrow,.hero h1,.hero .lead,.hero__actions{opacity:1;transform:none;animation:none;}
  .hero__media img{animation:none;transform:none;}
  .scroll-cue::after{animation:none;}
  html{scroll-behavior:auto;}
}

/* ===== Buttons ===== */
.btn{
  display:inline-flex;align-items:center;gap:.6rem;
  font-family:var(--font-body);font-weight:600;font-size:.9rem;letter-spacing:.01em;
  padding:.95rem 1.6rem;border-radius:var(--radius);
  background:var(--espresso);color:#fff;
  transition:transform .25s var(--ease),background .25s var(--ease);
  white-space:nowrap;
}
.btn:hover{transform:translateY(-2px);background:#000;}
.btn .arr{transition:transform .25s var(--ease);}
.btn:hover .arr{transform:translate(3px,-3px);}
.btn--ghost{background:transparent;color:var(--ink);border:1px solid var(--line);}
.btn--ghost:hover{background:var(--ink);color:#fff;border-color:var(--ink);}
.btn--light{background:#fff;color:var(--ink);}
.btn--light:hover{background:#fff;color:#000;}
.linkline{display:inline-flex;align-items:center;gap:.5rem;font-weight:600;font-size:.95rem;border-bottom:1px solid currentColor;padding-bottom:2px;}

/* ===== Header ===== */
.site-header{position:fixed;top:0;left:0;right:0;z-index:90;transition:background .4s var(--ease),border-color .4s var(--ease);border-bottom:1px solid transparent;}
.site-header.scrolled{background:color-mix(in srgb,var(--paper) 86%,transparent);backdrop-filter:saturate(150%) blur(14px);-webkit-backdrop-filter:saturate(150%) blur(14px);border-bottom-color:var(--line);}
.site-header.on-dark:not(.scrolled){color:#fff;}
.site-header.on-dark:not(.scrolled) .wordmark__name{color:#fff;}
.site-header.on-dark:not(.scrolled) .wordmark__sub{color:rgba(255,255,255,.6);}
.site-header.on-dark:not(.scrolled) .nav-toggle{color:#fff;}
.site-header.on-dark:not(.scrolled) .nav-toggle__line{background:#fff;}
/* Menu open: header sits over the dark overlay, so force light text on any page/scroll state */
body.nav-open .site-header{background:transparent;border-bottom-color:transparent;backdrop-filter:none;-webkit-backdrop-filter:none;color:#fff;}
body.nav-open .wordmark__name{color:#fff;}
body.nav-open .wordmark__sub{color:rgba(255,255,255,.6);}
body.nav-open .nav-toggle{color:#fff;}
body.nav-open .nav-toggle__line{background:#fff;}
.site-header__inner{display:flex;align-items:center;justify-content:space-between;gap:1.5rem;min-height:var(--header-h);}
.wordmark{display:flex;align-items:baseline;gap:.55rem;}
.wordmark__name{font-family:"Playfair Display",Georgia,serif;font-weight:700;font-size:1.4rem;letter-spacing:0;line-height:1;color:var(--ink);}
.wordmark__sub{font-family:var(--font-body);font-size:.62rem;font-weight:600;letter-spacing:.22em;text-transform:uppercase;color:var(--muted);}
.header-actions{display:flex;align-items:center;gap:2.4rem;}
/* Text nav links in the header: animated underline that draws in on hover, inherits header color (white over the dark hero, ink elsewhere) */
.nav-link{
  display:inline-flex;align-items:center;gap:.4rem;white-space:nowrap;
  font-family:var(--font-body);font-weight:600;font-size:.78rem;letter-spacing:.12em;text-transform:uppercase;color:inherit;
  background-image:linear-gradient(currentColor,currentColor);
  background-size:0 1px;background-position:0 100%;background-repeat:no-repeat;
  padding-bottom:3px;
  transition:background-size .4s var(--ease);
}
.nav-link:hover{background-size:100% 1px;}
.nav-link .arr{transition:transform .25s var(--ease);}
.nav-link:hover .arr{transform:translate(3px,-3px);}
.nav-toggle{display:inline-flex;flex-direction:row-reverse;align-items:center;gap:.65rem;background:none;border:0;cursor:pointer;font:inherit;color:var(--ink);padding:.4rem;}
.nav-toggle__box{position:relative;width:24px;height:12px;}
.nav-toggle__line{position:absolute;left:0;width:100%;height:1.5px;background:var(--ink);transition:transform .35s var(--ease),top .35s var(--ease);}
.nav-toggle__line-1{top:0;}
.nav-toggle__line-2{top:10px;}
body.nav-open .nav-toggle__line-1{top:5px;transform:rotate(45deg);}
body.nav-open .nav-toggle__line-2{top:5px;transform:rotate(-45deg);}
.nav-toggle__text{font-size:.78rem;font-weight:600;letter-spacing:.12em;text-transform:uppercase;}

/* ===== Full-screen nav overlay ===== */
.nav-overlay{position:fixed;inset:0;z-index:80;background:var(--espresso);color:#efe9df;
  opacity:0;visibility:hidden;pointer-events:none;
  transition:opacity .5s var(--ease),visibility .5s var(--ease);
  display:flex;align-items:center;}
body.nav-open .nav-overlay{opacity:1;visibility:visible;pointer-events:auto;}
.nav-overlay__inner{width:100%;max-width:var(--maxw);margin-inline:auto;padding:7rem var(--gutter) 3rem;
  display:grid;grid-template-columns:1.4fr 1fr;gap:3rem;align-items:end;}
.nav-overlay__menu{display:flex;flex-direction:column;gap:.4rem;}
.nav-overlay__link{display:flex;align-items:baseline;gap:1.2rem;font-family:var(--font-display);font-weight:600;
  font-size:clamp(2.4rem,6vw,4.2rem);line-height:1.05;color:#fff;letter-spacing:-0.02em;
  opacity:0;transform:translateY(22px);
  transition:opacity .5s var(--ease),transform .5s var(--ease);}
body.nav-open .nav-overlay__link{opacity:1;transform:none;}
/* Pointer devices get the dim-until-hover treatment; touch devices (no hover) stay full strength */
@media (hover:hover){
  body.nav-open .nav-overlay__link{opacity:.55;}
  .nav-overlay__link:hover{opacity:1;}
}
.nav-overlay__num{font-family:var(--font-body);font-size:.8rem;font-weight:600;letter-spacing:.1em;color:var(--muted-d);}
body.nav-open .nav-overlay__item:nth-child(1) .nav-overlay__link{transition-delay:.10s;}
body.nav-open .nav-overlay__item:nth-child(2) .nav-overlay__link{transition-delay:.16s;}
body.nav-open .nav-overlay__item:nth-child(3) .nav-overlay__link{transition-delay:.22s;}
body.nav-open .nav-overlay__item:nth-child(4) .nav-overlay__link{transition-delay:.28s;}
body.nav-open .nav-overlay__item:nth-child(5) .nav-overlay__link{transition-delay:.34s;}
.nav-overlay__meta{display:grid;gap:1.8rem;padding-bottom:.6rem;}
.nav-overlay__meta h5{font-family:var(--font-body);font-size:.72rem;font-weight:600;letter-spacing:.2em;text-transform:uppercase;color:var(--muted-d);margin-bottom:.5rem;}
.nav-overlay__meta p{color:#cabfae;font-size:.95rem;max-width:34ch;}
.nav-overlay__meta a{color:#fff;border-bottom:1px solid rgba(255,255,255,.3);}

/* ===== Hero (cinematic full-bleed) ===== */
.hero{position:relative;min-height:100svh;display:flex;align-items:flex-end;color:#fff;overflow:hidden;}
.hero__media{position:absolute;inset:0;z-index:-2;}
.hero__media img{width:100%;height:100%;object-fit:cover;transform:scale(1.06);animation:heroZoom 9s var(--ease) forwards;}
@keyframes heroZoom{to{transform:scale(1);}}
.hero::after{content:"";position:absolute;inset:0;z-index:-1;background:linear-gradient(to top,rgba(20,16,12,.78) 0%,rgba(20,16,12,.25) 45%,rgba(20,16,12,.35) 100%);}
.hero__inner{width:100%;padding-block:clamp(3rem,7vw,6rem);}
/* Hero content entrance, layered over the slow background zoom */
.hero .eyebrow,.hero h1,.hero .lead,.hero__actions{opacity:0;transform:translateY(24px);animation:heroRise 1s var(--ease) forwards;}
.hero .eyebrow{animation-delay:.2s;}
.hero h1{animation-delay:.34s;}
.hero .lead{animation-delay:.52s;}
.hero__actions{animation-delay:.68s;}
@keyframes heroRise{to{opacity:1;transform:none;}}
.hero h1{color:#fff;max-width:16ch;margin:1.2rem 0 1.6rem;}
.hero .lead{color:rgba(255,255,255,.9);max-width:44ch;}
/* The hero eyebrow was the unreadable element: the muted tan was near-invisible over
   the photo. Make it light like the heading, with a soft shadow so all three lines read. */
.hero .eyebrow{color:rgba(255,255,255,.88);}
.hero .eyebrow,.hero h1,.hero .lead{text-shadow:0 2px 16px rgba(0,0,0,.55);}
.hero__actions{display:flex;align-items:center;gap:1.6rem;margin-top:2.2rem;flex-wrap:wrap;}
.hero__note{font-size:.88rem;color:rgba(255,255,255,.72);max-width:30ch;text-wrap:pretty;}
.scroll-cue{position:absolute;bottom:1.6rem;right:var(--gutter);z-index:1;font-size:.72rem;letter-spacing:.2em;text-transform:uppercase;color:rgba(255,255,255,.7);writing-mode:vertical-rl;padding-bottom:3.2rem;}
.scroll-cue::after{content:"";position:absolute;left:calc(50% - .5px);bottom:0;width:1px;height:2.4rem;background:linear-gradient(rgba(255,255,255,.85),rgba(255,255,255,0));transform-origin:top;animation:scrollCue 1.9s var(--ease) infinite;}
@keyframes scrollCue{0%{transform:scaleY(0);opacity:0;}30%{opacity:1;}100%{transform:scaleY(1);opacity:0;}}

/* ===== Category tiles ===== */
.tiles{display:grid;grid-template-columns:repeat(4,1fr);gap:1.1rem;}
.tile{position:relative;aspect-ratio:3/4.2;overflow:hidden;border-radius:var(--radius);display:block;background:var(--sand);}
.tile img{width:100%;height:100%;object-fit:cover;transition:transform .8s var(--ease);}
.tile:hover img{transform:scale(1.06);}
.tile::after{content:"";position:absolute;inset:0;background:linear-gradient(to top,rgba(20,16,12,.66),rgba(20,16,12,0) 58%);}
.tile__label{position:absolute;left:1.2rem;right:1.2rem;bottom:1.2rem;z-index:1;color:#fff;}
.tile__label .n{font-family:var(--font-body);font-size:.72rem;font-weight:600;letter-spacing:.14em;opacity:.75;}
.tile__label h3{color:#fff;font-size:1.35rem;margin-top:.25rem;}

/* ===== Split / story ===== */
.split{display:grid;grid-template-columns:1fr 1fr;gap:clamp(2rem,6vw,5.5rem);align-items:center;}
.split--offset{align-items:end;}
.split__img{overflow:hidden;border-radius:var(--radius);}
.split__img img{width:100%;aspect-ratio:4/3.4;object-fit:cover;transition:transform 1s var(--ease);}
.split:hover .split__img img{transform:scale(1.04);}
.split__body h2{margin:1rem 0 1.2rem;}

/* ===== Partners ===== */
.partners{display:flex;align-items:center;justify-content:center;gap:clamp(2.5rem,8vw,7rem);flex-wrap:wrap;}
.partners img{height:clamp(44px,5.5vw,64px);width:auto;transition:transform .3s var(--ease);}
.partners a:hover img{transform:scale(1.05);}

/* ===== Dealer band ===== */
.band{display:grid;grid-template-columns:1.3fr 1fr;gap:2.5rem;align-items:end;}
.band p{max-width:none;}
.band__action{display:flex;justify-content:flex-end;}

/* ===== Page hero (interior pages) ===== */
.page-hero{padding-top:calc(var(--header-h) + clamp(3rem,7vw,6rem));padding-bottom:clamp(2.5rem,5vw,4rem);border-bottom:1px solid var(--line);}
.page-hero h1{margin:1rem 0 1.2rem;max-width:18ch;}

/* ===== Product rows ===== */
.prod-row{display:grid;grid-template-columns:1fr 1fr;gap:clamp(2rem,6vw,5.5rem);align-items:center;padding-block:clamp(3.5rem,7vw,6.5rem);border-bottom:1px solid var(--line);}
.prod-row:last-of-type{border-bottom:0;}
.prod-row__img{overflow:hidden;border-radius:var(--radius);}
.prod-row__img img{width:100%;aspect-ratio:4/3;object-fit:cover;transition:transform 1s var(--ease);}
.prod-row:hover .prod-row__img img{transform:scale(1.04);}
.prod-row:nth-child(even) .prod-row__img{order:2;}
.prod-row__body .n{font-family:var(--font-body);font-size:.8rem;font-weight:600;letter-spacing:.12em;color:var(--muted);}
.prod-row__body h3{margin:.9rem 0 1rem;font-size:clamp(1.7rem,3vw,2.6rem);}

/* ===== Software feature columns ===== */
.cols{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(1.5rem,4vw,3.5rem);}
.col{padding-top:1.6rem;border-top:1px solid var(--line);}
.section--ink .col{border-top-color:var(--line-dk);}
.col__num{font-family:var(--font-display);font-weight:600;font-size:1.1rem;color:var(--muted);display:block;margin-bottom:1rem;}
.col h3{margin-bottom:.7rem;}

/* ===== Video embeds ===== */
.video{position:relative;aspect-ratio:16/9;border-radius:var(--radius);overflow:hidden;background:var(--sand);border:1px solid var(--line);}
.video iframe{position:absolute;inset:0;width:100%;height:100%;border:0;display:block;}
.video--feature{max-width:920px;margin-inline:auto;}
.video-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(1.4rem,3vw,2rem);}
.video-grid figure{margin:0;}
.video-cap{margin-top:1rem;}
.video-cap .n{font-family:var(--font-body);font-size:.8rem;font-weight:600;letter-spacing:.12em;color:var(--muted);}
.video-cap h3{margin-top:.45rem;font-size:clamp(1.25rem,2vw,1.6rem);}

/* ===== Contact ===== */
.contact-grid{display:grid;grid-template-columns:1.15fr .85fr;gap:clamp(2rem,6vw,4.5rem);align-items:start;}
.contact-grid h2{margin:1rem 0 1rem;}
.contact-block{padding-block:1.4rem;border-top:1px solid var(--line);}
.contact-block:first-child{border-top:0;padding-top:0;}
.contact-block h3{font-family:var(--font-body);font-size:.74rem;font-weight:600;letter-spacing:.18em;text-transform:uppercase;color:var(--muted);margin-bottom:.5rem;}
.contact-block p{opacity:1;}
.contact-block a{border-bottom:1px solid var(--line);}
.contact-block a:hover{border-color:var(--ink);}
.contact-map{min-height:420px;border-radius:var(--radius);overflow:hidden;}
.contact-map iframe{width:100%;height:100%;min-height:420px;border:0;display:block;filter:grayscale(.25) contrast(1.05);}

/* ===== Contact form ===== */
.form{
  display:grid;gap:1.35rem;margin-top:2.2rem;
  background:#fff;
  border:1px solid var(--line);
  border-radius:14px;
  padding:clamp(1.6rem,3vw,2.4rem);
  box-shadow:0 24px 60px -34px rgba(36,29,22,.32);
}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1.35rem;}
.field{display:grid;gap:.55rem;position:relative;}
.field label{font-family:var(--font-body);font-size:.7rem;font-weight:600;letter-spacing:.16em;text-transform:uppercase;color:var(--muted);}
.field .req{color:#a8612f;margin-left:.1em;}
.form input,.form textarea{
  font-family:var(--font-body);font-size:1rem;line-height:1.5;color:var(--ink);width:100%;
  background:var(--paper);
  border:1px solid var(--line);
  border-radius:8px;
  padding:.95rem 1.05rem;
  transition:border-color .2s var(--ease),box-shadow .2s var(--ease),background .2s var(--ease);
}
.form textarea{min-height:150px;resize:vertical;}
.form input::placeholder,.form textarea::placeholder{color:var(--muted);opacity:.55;}
.form input:hover,.form textarea:hover{border-color:var(--muted-d);}
.form input:focus,.form textarea:focus{
  outline:none;background:#fff;border-color:var(--espresso);
  box-shadow:0 0 0 3px rgba(36,29,22,.10);
}
.form__actions{display:flex;align-items:center;gap:1.4rem;flex-wrap:wrap;margin-top:.5rem;}
.form .btn{padding:1.05rem 2.1rem;font-size:.92rem;}
.form__status{font-size:.88rem;line-height:1.45;color:var(--muted);max-width:34ch;}
.form__status.show{color:var(--ink);}

/* ===== Footer ===== */
.site-footer{background:var(--espresso);color:#cabfae;padding-block:clamp(3.5rem,7vw,6rem);}
.site-footer a{color:#cabfae;transition:color .25s var(--ease);}
.site-footer a:hover{color:#fff;}
.footer-top{display:grid;grid-template-columns:1.6fr 1fr 1fr;gap:2.5rem;padding-bottom:3rem;border-bottom:1px solid var(--line-dk);}
.footer-brand .wordmark__name{color:#fff;font-size:1.6rem;}
.footer-brand .wordmark__sub{color:var(--muted-d);}
.footer-brand p{color:#cabfae;opacity:1;margin-top:1.1rem;max-width:36ch;}
.site-footer h4{font-family:var(--font-body);font-size:.74rem;font-weight:600;letter-spacing:.16em;text-transform:uppercase;color:#fff;margin-bottom:1.1rem;}
.footer-links{list-style:none;padding:0;display:grid;gap:.65rem;}
.footer-links a{background-image:linear-gradient(currentColor,currentColor);background-size:0 1px;background-position:0 100%;background-repeat:no-repeat;transition:color .25s var(--ease),background-size .4s var(--ease);padding-bottom:2px;}
.footer-links a:hover{background-size:100% 1px;}
.footer-address{font-style:normal;color:#cabfae;line-height:1.9;}
.footer-bottom{display:flex;justify-content:space-between;gap:1rem;flex-wrap:wrap;padding-top:1.6rem;font-size:.82rem;color:var(--muted-d);}

/* ===== Responsive ===== */
@media (max-width:900px){
  .footer-top{grid-template-columns:1fr 1fr;}
  .footer-brand{grid-column:1 / -1;}
  .cols{grid-template-columns:1fr;gap:0;}
  .col{border-top:1px solid var(--line);padding-block:1.6rem;}
  .nav-overlay__inner{grid-template-columns:1fr;gap:2.5rem;align-items:center;}
}
@media (max-width:780px){
  .tiles{grid-template-columns:repeat(2,1fr);}
  .split{grid-template-columns:1fr;gap:1.8rem;}
  .split__img{order:-1;}
  .prod-row{grid-template-columns:1fr;gap:1.6rem;}
  .prod-row:nth-child(even) .prod-row__img{order:0;}
  .band{grid-template-columns:1fr;gap:1.8rem;}
  .band__action{justify-content:flex-start;}
  .contact-grid{grid-template-columns:1fr;}
  .form-row{grid-template-columns:1fr;}
  .video-grid{grid-template-columns:1fr;}
  .hero h1{margin-top:.8rem;}
}
@media (max-width:600px){
  /* On phones the header text links crowd the wordmark + Menu, so fall back to the menu overlay (which holds Contact and the Dealer Portal link). */
  .header-actions .nav-link{display:none;}

  /* Calmer phone layout: smaller headings + tighter sections so it is less busy */
  :root{--section-y:clamp(3rem,11vw,4.25rem);}
  h1{font-size:clamp(2.05rem,9vw,2.75rem);}
  h2{font-size:clamp(1.7rem,7vw,2.2rem);}
  .lead{font-size:1.05rem;}
  .scroll-cue{display:none;}

  /* Hero readability: stronger scrim on phones where the photo crops to a bright window area */
  .hero::after{background:linear-gradient(to top,rgba(20,16,12,.92) 0%,rgba(20,16,12,.6) 50%,rgba(20,16,12,.64) 100%);}
}
@media (max-width:520px){
  .footer-top{grid-template-columns:1fr;}
  .nav-toggle__text{display:none;}
}
