/* ============================================================
   Three Rivers Custom Decks — bespoke site styling
   Mood: warm prestige dark. Forest green + golden hour + tan/gold.
   Type: Spectral (serif display) + Hanken Grotesk (sans body).
   ============================================================ */

:root{
  /* dark forest family */
  --bg-deep:   #131a10;
  --bg:        #1a2215;
  --bg-2:      #202a1a;
  --surface:   #26301f;
  --surface-2: #2d3825;

  /* warm accents */
  --gold:      #c9a86a;
  --gold-bri:  #ddc089;
  --sage:      #8a967a;
  --sage-dim:  #6f7c61;

  /* light / cream family (reviews break) */
  --paper:     #f1ece1;
  --paper-2:   #e7dfcd;
  --ink:       #20281a;
  --ink-dim:   #5b6150;

  /* text on dark */
  --cream:     #f2ede2;
  --cream-dim: #cdc6b6;
  --cream-mute:#9aa089;
  --line:      rgba(242,237,226,0.13);
  --line-soft: rgba(242,237,226,0.07);

  --serif: 'Spectral', Georgia, 'Times New Roman', serif;
  --sans:  'Hanken Grotesk', system-ui, -apple-system, sans-serif;

  --maxw: 1280px;
  --gutter: clamp(20px, 5vw, 72px);
  --ease: cubic-bezier(.22,.61,.36,1);
}

*{ box-sizing:border-box; }
html{ scroll-behavior:smooth; }
@media (prefers-reduced-motion: reduce){ html{ scroll-behavior:auto; } }

body{
  margin:0;
  background:var(--bg-deep);
  color:var(--cream);
  font-family:var(--sans);
  font-size:18px;
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}

h1,h2,h3,h4{ font-family:var(--serif); font-weight:500; line-height:1.04; margin:0; letter-spacing:-.01em; }
p{ margin:0; }
a{ color:inherit; text-decoration:none; }
img{ display:block; max-width:100%; }
::selection{ background:var(--gold); color:var(--bg-deep); }

.eyebrow{
  font-family:var(--sans);
  font-size:.72rem;
  letter-spacing:.26em;
  text-transform:uppercase;
  font-weight:600;
  color:var(--gold);
}

/* shared section frame */
.section{ padding:clamp(90px,12vh,160px) 0; position:relative; }
.wrap{ max-width:var(--maxw); margin:0 auto; padding:0 var(--gutter); }
.kicker{
  font-size:.72rem; letter-spacing:.26em; text-transform:uppercase;
  font-weight:600; color:var(--gold); margin-bottom:22px;
  display:flex; align-items:center; gap:14px;
}
.kicker::before{ content:""; width:34px; height:1px; background:var(--gold); opacity:.6; }

/* ============================================================
   HEADER  — three things only: wordmark, slow ambient layer, hamburger
   ============================================================ */
.site-header{
  position:fixed; inset:0 0 auto 0; z-index:60;
  padding:clamp(16px,2.4vw,26px) 0;
  transition:background .5s var(--ease), backdrop-filter .5s var(--ease), padding .4s var(--ease);
}
.site-header.scrolled{
  background:linear-gradient(180deg, rgba(19,26,16,.92), rgba(19,26,16,.74) 70%, transparent);
  backdrop-filter:blur(6px);
  padding:12px 0;
}
.header-inner{
  max-width:var(--maxw); margin:0 auto; padding:0 var(--gutter);
  display:flex; align-items:center; justify-content:space-between; gap:24px;
}
.wordmark{ position:relative; display:flex; align-items:center; gap:14px; }
.wm-rivers{ width:42px; height:30px; flex:none; overflow:hidden; }
.wm-rivers path{ fill:none; stroke:var(--gold); stroke-width:1.4; opacity:.85; }
.wm-rivers .r2{ opacity:.55; }
.wm-rivers .r3{ opacity:.3; }
/* the single slow ambient layer (>=18s) */
.wm-rivers .flow{ animation:riverDrift 26s linear infinite; }
.wm-rivers .flow.r2{ animation-duration:32s; }
.wm-rivers .flow.r3{ animation-duration:38s; }
@keyframes riverDrift{ to{ transform:translateX(-12px); } }
@media (prefers-reduced-motion: reduce){ .wm-rivers .flow{ animation:none; } }

.wm-text{ display:flex; flex-direction:column; line-height:1; }
.wm-text b{ font-family:var(--serif); font-weight:600; font-size:1.16rem; letter-spacing:.01em; color:var(--cream); }
.wm-text span{ font-family:var(--sans); font-size:.6rem; letter-spacing:.34em; text-transform:uppercase; color:var(--gold); margin-top:5px; }

.hamburger{
  appearance:none; background:none; border:1px solid var(--line);
  width:48px; height:48px; border-radius:50%; cursor:pointer;
  display:flex; flex-direction:column; align-items:center; justify-content:center; gap:5px;
  transition:border-color .3s, background .3s;
}
.hamburger:hover{ border-color:var(--gold); background:rgba(201,168,106,.08); }
.hamburger span{ width:18px; height:1.6px; background:var(--cream); transition:transform .35s var(--ease), opacity .25s; }
body.menu-open .hamburger span:nth-child(1){ transform:translateY(3.3px) rotate(45deg); }
body.menu-open .hamburger span:nth-child(2){ transform:translateY(-3.3px) rotate(-45deg); }

/* overlay menu */
.menu{
  position:fixed; inset:0; z-index:55;
  background:linear-gradient(160deg, var(--bg) 0%, var(--bg-deep) 100%);
  display:flex; align-items:center; justify-content:center;
  opacity:0; visibility:hidden; transition:opacity .5s var(--ease), visibility .5s;
}
body.menu-open .menu{ opacity:1; visibility:visible; }
.menu ul{ list-style:none; margin:0; padding:0; text-align:center; }
.menu li{ overflow:hidden; }
.menu a{
  font-family:var(--serif); font-size:clamp(2.4rem,7vw,4.6rem); font-weight:400;
  color:var(--cream); display:inline-block; padding:.08em 0; position:relative;
  transform:translateY(110%); transition:transform .6s var(--ease), color .3s;
}
body.menu-open .menu a{ transform:translateY(0); }
.menu li:nth-child(1) a{ transition-delay:.06s; }
.menu li:nth-child(2) a{ transition-delay:.12s; }
.menu li:nth-child(3) a{ transition-delay:.18s; }
.menu li:nth-child(4) a{ transition-delay:.24s; }
.menu li:nth-child(5) a{ transition-delay:.30s; }
.menu a:hover{ color:var(--gold); font-style:italic; }
.menu-foot{
  position:absolute; bottom:42px; left:0; right:0; text-align:center;
  color:var(--cream-mute); font-size:.82rem; letter-spacing:.04em;
}
.menu-foot a:hover{ color:var(--gold); }

/* ============================================================
   HERO — pinned 3D assembly
   ============================================================ */
.hero{ position:relative; height:500vh; background:var(--bg-deep); }
.hero-pin{
  position:sticky; top:0; height:100vh; overflow:hidden;
}
/* designed dusk backdrop — instant first paint, behind the canvas */
.hero-sky{
  position:absolute; inset:0;
  background:
    radial-gradient(120% 80% at 72% 18%, rgba(224,178,108,.42), transparent 46%),
    radial-gradient(140% 120% at 30% 4%, rgba(86,108,74,.30), transparent 55%),
    linear-gradient(176deg, #2c3422 0%, #222b1b 30%, #1b2316 55%, #141a10 100%);
}
.hero-sky::after{ /* soft horizon glow */
  content:""; position:absolute; inset:0;
  background:radial-gradient(80% 46% at 50% 78%, rgba(201,168,106,.16), transparent 70%);
}
/* night wash that fades in over the day sky as the deck completes */
.hero-night{
  position:absolute; inset:0; opacity:0; will-change:opacity;
  background:
    radial-gradient(1.5px 1.5px at 18% 24%, rgba(255,255,255,.7), transparent 60%),
    radial-gradient(1.5px 1.5px at 62% 15%, rgba(255,255,255,.5), transparent 60%),
    radial-gradient(1px 1px at 80% 30%, rgba(255,255,255,.55), transparent 60%),
    radial-gradient(1.5px 1.5px at 40% 11%, rgba(255,255,255,.45), transparent 60%),
    radial-gradient(1px 1px at 28% 8%, rgba(255,255,255,.4), transparent 60%),
    radial-gradient(1px 1px at 53% 33%, rgba(255,255,255,.35), transparent 60%),
    radial-gradient(circle at 80% 17%, rgba(228,238,255,.85), rgba(196,214,255,.18) 5%, transparent 9%),
    radial-gradient(140% 90% at 80% 16%, rgba(74,104,168,.20), transparent 50%),
    linear-gradient(176deg, #0b1430 0%, #060c1d 46%, #02050c 100%);
}
#deckCanvas{
  position:absolute; inset:0; width:100%; height:100%;
  display:block; touch-action:auto;
}
.hero-pin.live #deckCanvas{ cursor:pointer; }
/* cinematic grade: vignette + faint film grain over the 3D */
.hero-grade{
  position:absolute; inset:0; z-index:3; pointer-events:none;
  background:radial-gradient(125% 105% at 50% 40%, transparent 52%, rgba(4,7,3,.46) 100%);
}
.hero-grade::after{
  content:""; position:absolute; inset:0; opacity:.05; mix-blend-mode:overlay;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='180' height='180'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2'/%3E%3C/filter%3E%3Crect width='180' height='180' filter='url(%23n)' opacity='0.6'/%3E%3C/svg%3E");
  background-size:180px 180px;
}
.hero-pin.no-3d #deckCanvas{ display:none; }
/* static-premium fallback poster */
.hero-poster{
  position:absolute; inset:0; display:none;
  background-size:cover; background-position:center;
}
.hero-pin.no-3d .hero-poster{ display:block; }
.hero-pin.no-3d .hero-poster::after{
  content:""; position:absolute; inset:0;
  background:linear-gradient(90deg, rgba(15,20,12,.86), rgba(15,20,12,.34) 60%, rgba(15,20,12,.1));
}

.hero-overlay{
  position:absolute; left:var(--gutter); top:50%; transform:translateY(-50%);
  max-width:min(560px, 78vw); z-index:5;
  transition:opacity .5s var(--ease), transform .6s var(--ease);
}
.hero-overlay .eyebrow{ display:block; margin-bottom:24px; }
.hero-overlay h1{
  font-size:clamp(2.9rem, 7.2vw, 5.8rem); font-weight:400; color:var(--cream);
  letter-spacing:-.02em; text-shadow:0 2px 40px rgba(0,0,0,.45);
}
.hero-overlay h1 em{ font-style:italic; color:var(--gold-bri); }
.hero-sub{
  margin:26px 0 34px; font-size:1.06rem; color:var(--cream-dim);
  max-width:40ch; text-shadow:0 1px 20px rgba(0,0,0,.5);
}

/* quote button (steady in hero) */
.btn-quote{
  display:inline-flex; align-items:center; gap:12px;
  font-family:var(--sans); font-weight:600; font-size:.92rem; letter-spacing:.02em;
  color:var(--bg-deep); background:var(--gold);
  padding:16px 30px; border-radius:2px; border:1px solid var(--gold);
  cursor:pointer; transition:background .3s, transform .25s var(--ease), box-shadow .3s;
}
.btn-quote:hover{ background:var(--gold-bri); transform:translateY(-2px); box-shadow:0 14px 34px rgba(201,168,106,.28); }
.btn-quote svg{ width:15px; height:15px; }

/* stage caption (informative, lower-left) */
.stage-caption{
  position:absolute; left:var(--gutter); bottom:42px; z-index:5;
  display:flex; align-items:baseline; gap:14px; color:var(--cream);
  opacity:0; transform:translateY(8px); transition:opacity .45s var(--ease), transform .45s var(--ease);
}
.hero-pin.building .stage-caption{ opacity:1; transform:none; }
.stage-step{ font-family:var(--serif); font-style:italic; font-size:1.5rem; color:var(--gold); }
.stage-name{ font-size:.74rem; letter-spacing:.24em; text-transform:uppercase; color:var(--cream-dim); }

/* build progress bar */
.hero-bar-track{
  position:absolute; right:var(--gutter); top:50%; transform:translateY(-50%);
  width:2px; height:180px; background:var(--line); z-index:5; border-radius:2px;
  opacity:0; transition:opacity .5s;
}
.hero-pin.building .hero-bar-track{ opacity:1; }
.hero-bar{ position:absolute; top:0; left:0; right:0; height:0%; background:var(--gold); border-radius:2px; }

/* operable controls — appear when deck finished */
.deck-controls{
  position:absolute; right:var(--gutter); bottom:42px; z-index:6;
  display:flex; flex-direction:column; align-items:flex-end; gap:16px;
  opacity:0; transform:translateY(14px); pointer-events:none;
  transition:opacity .6s var(--ease), transform .6s var(--ease);
}
.hero-pin.live .deck-controls{ opacity:1; transform:none; pointer-events:auto; }
.deck-hint{
  font-size:.72rem; letter-spacing:.18em; text-transform:uppercase; color:var(--cream-mute);
  display:flex; align-items:center; gap:9px;
}
.deck-hint svg{ width:16px; height:16px; opacity:.7; }
.swatches{ display:flex; gap:10px; }
.swatch{
  width:auto; padding:9px 14px 9px 11px; border-radius:2px; cursor:pointer;
  display:flex; align-items:center; gap:9px;
  background:rgba(20,26,16,.62); border:1px solid var(--line);
  backdrop-filter:blur(8px); color:var(--cream-dim);
  font-family:var(--sans); font-size:.74rem; font-weight:600; letter-spacing:.04em;
  transition:border-color .25s, color .25s, background .25s;
}
.swatch:hover{ border-color:var(--gold); color:var(--cream); }
.swatch.active{ border-color:var(--gold); color:var(--cream); background:rgba(201,168,106,.14); }
.swatch i{ width:18px; height:18px; border-radius:50%; display:block; flex:none; box-shadow:inset 0 0 0 1px rgba(255,255,255,.12); }

/* ============================================================
   POINTER — wayfinds hero -> gallery
   ============================================================ */
.pointer{
  position:relative; z-index:10; margin-top:-1px;
  background:var(--bg-deep);
  display:flex; flex-direction:column; align-items:center; gap:0;
  padding:64px 0 12px; color:var(--cream-dim);
}
.pointer-label{
  font-family:var(--serif); font-style:italic; font-size:1.35rem; color:var(--cream);
  margin-bottom:20px; transition:color .3s;
}
.pointer:hover .pointer-label{ color:var(--gold-bri); }
.pointer-line{ position:relative; width:1px; height:80px; background:var(--line); overflow:hidden; }
.pointer-line::after{
  content:""; position:absolute; top:-40%; left:0; width:100%; height:45%;
  background:linear-gradient(180deg, transparent, var(--gold));
  animation:trickle 4s ease-in-out infinite;
}
@keyframes trickle{ 0%{ transform:translateY(-100%);} 60%,100%{ transform:translateY(240%);} }
@media (prefers-reduced-motion: reduce){ .pointer-line::after{ animation:none; top:30%; } }

/* ============================================================
   GALLERY — cinematic horizontal scroll
   ============================================================ */
.gallery{ background:#0f140c; padding-top:clamp(60px,8vh,110px); }
.gallery-head{
  max-width:var(--maxw); margin:0 auto; padding:0 var(--gutter);
  display:flex; flex-wrap:wrap; align-items:flex-end; justify-content:space-between; gap:28px;
  margin-bottom:clamp(36px,5vh,64px);
}
.gallery-head .h-l{ max-width:62%; }
.gallery-head h2{ font-size:clamp(2.2rem,4.6vw,3.6rem); color:var(--cream); }
.gallery-head .h-l p{ margin-top:18px; color:var(--cream-dim); max-width:46ch; }
.gallery-nav{ display:flex; gap:12px; }
.gnav-btn{
  width:54px; height:54px; border-radius:50%; border:1px solid var(--line);
  background:transparent; color:var(--cream); cursor:pointer; display:grid; place-items:center;
  transition:border-color .25s, background .25s, transform .25s, opacity .3s;
}
.gnav-btn:hover{ border-color:var(--gold); background:rgba(201,168,106,.08); }
.gnav-btn:disabled{ opacity:.28; cursor:default; }
.gnav-btn svg{ width:20px; height:20px; }

.gallery-track{
  display:flex; gap:clamp(18px,2vw,30px);
  overflow-x:auto; scroll-snap-type:x mandatory;
  padding:6px var(--gutter) 12px;
  scrollbar-width:none; cursor:grab;
}
.gallery-track::-webkit-scrollbar{ display:none; }
.gallery-track.dragging{ cursor:grabbing; scroll-snap-type:none; }
.gframe{
  position:relative; flex:none; scroll-snap-align:center;
  width:clamp(280px, 62vw, 760px); aspect-ratio:4/3;
  border-radius:3px; overflow:hidden; background:var(--surface);
}
.gframe img{
  width:100%; height:100%; object-fit:cover; user-select:none; pointer-events:none;
  transition:transform 1s var(--ease); transform:scale(1.02);
}
.gframe:hover img{ transform:scale(1.07); }
.gframe::after{
  content:""; position:absolute; inset:0;
  background:linear-gradient(180deg, transparent 45%, rgba(10,14,8,.78));
}
.gframe figcaption{
  position:absolute; left:24px; bottom:22px; right:24px; z-index:2;
  display:flex; align-items:center; justify-content:space-between; gap:14px;
}
.gframe .g-type{ font-family:var(--serif); font-style:italic; font-size:1.32rem; color:var(--cream); }
.gframe .g-tag{ font-size:.64rem; letter-spacing:.2em; text-transform:uppercase; color:var(--gold); white-space:nowrap; }
.gallery-progress{
  max-width:var(--maxw); margin:30px auto 0; padding:0 var(--gutter);
  display:flex; align-items:center; gap:16px;
}
.gp-track{ flex:1; height:2px; background:var(--line); border-radius:2px; position:relative; }
.gp-bar{ position:absolute; left:0; top:0; height:100%; width:18%; background:var(--gold); border-radius:2px; transition:left .25s var(--ease), width .25s; }
.gp-count{ font-size:.74rem; letter-spacing:.16em; color:var(--cream-mute); font-variant-numeric:tabular-nums; }

/* ============================================================
   WHY THREE RIVERS
   ============================================================ */
.why{ background:var(--bg); }
.why-grid{ display:grid; grid-template-columns:1.1fr 1fr; gap:clamp(40px,6vw,96px); align-items:center; }
.why h2{ font-size:clamp(2.3rem,4.8vw,3.8rem); color:var(--cream); max-width:14ch; }
.why-body{ margin-top:26px; color:var(--cream-dim); font-size:1.08rem; max-width:46ch; }
.stat-row{ display:flex; gap:clamp(24px,4vw,52px); margin-top:42px; flex-wrap:wrap; }
.stat b{ font-family:var(--serif); font-size:2.6rem; color:var(--gold); font-weight:500; display:block; line-height:1; }
.stat span{ font-size:.74rem; letter-spacing:.14em; text-transform:uppercase; color:var(--cream-mute); margin-top:10px; display:block; }
.fit-list{ display:flex; flex-direction:column; gap:0; border-top:1px solid var(--line); }
.fit{
  display:flex; align-items:flex-start; gap:20px; padding:26px 0;
  border-bottom:1px solid var(--line); transition:padding-left .35s var(--ease);
}
.fit:hover{ padding-left:10px; }
.fit-num{ font-family:var(--serif); font-style:italic; color:var(--gold); font-size:1.1rem; flex:none; width:28px; }
.fit p{ color:var(--cream); font-size:1.16rem; font-family:var(--serif); }
.fit .fit-sub{ display:block; font-family:var(--sans); font-size:.92rem; color:var(--cream-mute); margin-top:6px; }

/* process strip */
.process{ margin-top:clamp(70px,9vh,120px); border-top:1px solid var(--line); padding-top:54px; }
.process-grid{ display:grid; grid-template-columns:repeat(4,1fr); gap:28px; counter-reset:step; }
.pstep{ position:relative; }
.pstep .pn{ font-family:var(--serif); font-style:italic; font-size:1rem; color:var(--gold); margin-bottom:12px; }
.pstep h4{ font-size:1.22rem; color:var(--cream); margin-bottom:10px; }
.pstep p{ font-size:.92rem; color:var(--cream-mute); }

/* ============================================================
   REVIEWS — warm paper break
   ============================================================ */
.reviews{ background:var(--paper); color:var(--ink); }
.reviews .kicker{ color:#9a7b3f; }
.reviews .kicker::before{ background:#9a7b3f; }
.reviews-head{ display:flex; flex-wrap:wrap; justify-content:space-between; align-items:flex-end; gap:24px; margin-bottom:clamp(40px,5vh,70px); }
.reviews-head h2{ font-size:clamp(2.2rem,4.6vw,3.5rem); color:var(--ink); max-width:16ch; }
.reviews-head .stars{ display:flex; gap:5px; color:#c9a86a; }
.reviews-head .stars svg{ width:22px; height:22px; }
.reviews-grid{ columns:2; column-gap:36px; }
.review{
  break-inside:avoid; margin-bottom:36px; padding:34px 36px;
  background:#fff; border:1px solid var(--paper-2); border-radius:3px;
  box-shadow:0 1px 0 rgba(0,0,0,.02);
}
.review .q{ font-family:var(--serif); font-size:1.22rem; line-height:1.5; color:var(--ink); }
.review .q::first-letter{ } /* keep simple */
.review .by{ margin-top:22px; display:flex; align-items:center; gap:12px; }
.review .by .av{ width:38px; height:38px; border-radius:50%; background:#e7dfcd; color:#9a7b3f; display:grid; place-items:center; font-family:var(--serif); font-size:1rem; flex:none; }
.review .by b{ font-family:var(--sans); font-weight:700; font-size:.92rem; color:var(--ink); }
.review .by span{ font-size:.74rem; color:var(--ink-dim); letter-spacing:.06em; }

/* ============================================================
   OUTDOOR LIVING
   ============================================================ */
.outdoor{ background:var(--bg-deep); }
.outdoor-head{ max-width:60ch; margin-bottom:clamp(40px,5vh,68px); }
.outdoor-head h2{ font-size:clamp(2.4rem,5vw,4rem); color:var(--cream); }
.outdoor-head p{ margin-top:22px; color:var(--cream-dim); font-size:1.08rem; }
.outdoor-grid{ display:grid; grid-template-columns:repeat(6,1fr); grid-auto-rows:200px; gap:16px; }
.ocard{ position:relative; overflow:hidden; border-radius:3px; background:var(--surface); }
.ocard img{ width:100%; height:100%; object-fit:cover; transition:transform 1s var(--ease); }
.ocard:hover img{ transform:scale(1.06); }
.ocard::after{ content:""; position:absolute; inset:0; background:linear-gradient(180deg,transparent 40%,rgba(10,14,8,.8)); }
.ocard span{ position:absolute; left:22px; bottom:18px; z-index:2; font-family:var(--serif); font-style:italic; font-size:1.3rem; color:var(--cream); }
.ocard.big{ grid-column:span 3; grid-row:span 2; }
.ocard.tall{ grid-column:span 3; grid-row:span 2; }
.ocard.wide{ grid-column:span 2; }
.ocard.sm{ grid-column:span 2; }

/* ============================================================
   CONTACT — prestige quote
   ============================================================ */
.contact{ background:linear-gradient(180deg, var(--bg) 0%, var(--bg-deep) 100%); }
.contact-recap{
  display:flex; flex-wrap:wrap; gap:14px 26px; justify-content:center;
  font-size:.74rem; letter-spacing:.18em; text-transform:uppercase; color:var(--gold);
  margin-bottom:34px;
}
.contact-recap span{ display:flex; align-items:center; gap:26px; }
.contact-recap span::after{ content:"·"; color:var(--sage-dim); }
.contact-recap span:last-child::after{ display:none; }
.contact-inner{ max-width:920px; margin:0 auto; text-align:center; }
.contact h2{ font-size:clamp(2.6rem,5.6vw,4.4rem); color:var(--cream); }
.contact h2 em{ font-style:italic; color:var(--gold-bri); }
.contact-sub{ margin:22px auto 50px; color:var(--cream-dim); font-size:1.12rem; max-width:42ch; }

.qform{ display:grid; grid-template-columns:1fr 1fr; gap:20px 24px; text-align:left; }
.field{ display:flex; flex-direction:column; gap:9px; }
.field.full{ grid-column:1 / -1; }
.field label{ font-size:.7rem; letter-spacing:.18em; text-transform:uppercase; color:var(--cream-mute); }
.field input, .field select, .field textarea{
  font-family:var(--sans); font-size:1rem; color:var(--cream);
  background:rgba(20,26,16,.5); border:1px solid var(--line); border-radius:2px;
  padding:15px 16px; transition:border-color .25s, background .25s;
}
.field textarea{ resize:vertical; min-height:120px; }
.field input::placeholder, .field textarea::placeholder{ color:var(--cream-mute); opacity:.7; }
.field input:focus, .field select:focus, .field textarea:focus{ outline:none; border-color:var(--gold); background:rgba(20,26,16,.75); }
.field select{ appearance:none; background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath fill='%23c9a86a' d='M6 8 0 0h12z'/%3E%3C/svg%3E"); background-repeat:no-repeat; background-position:right 16px center; padding-right:40px; }
.field.invalid input, .field.invalid select, .field.invalid textarea{ border-color:#c46a52; }

/* pulsing conversion CTA (3-6s cycle) */
.submit-row{ grid-column:1 / -1; display:flex; align-items:center; gap:22px; flex-wrap:wrap; margin-top:8px; }
.btn-quote.pulse{ position:relative; }
.btn-quote.pulse::before{
  content:""; position:absolute; inset:0; border-radius:2px; border:1px solid var(--gold);
  animation:ctaPulse 4.5s var(--ease) infinite;
}
@keyframes ctaPulse{
  0%{ transform:scale(1); opacity:.55; }
  55%{ transform:scale(1.13); opacity:0; }
  100%{ transform:scale(1.13); opacity:0; }
}
@media (prefers-reduced-motion: reduce){ .btn-quote.pulse::before{ animation:none; opacity:0; } }
.form-note{ font-size:.82rem; color:var(--cream-mute); }
.form-success{
  grid-column:1/-1; display:none; padding:40px; text-align:center;
  border:1px solid var(--line); border-radius:3px; background:rgba(201,168,106,.06);
}
.qform.sent .field, .qform.sent .submit-row{ display:none; }
.qform.sent .form-success{ display:block; }
.form-success h3{ font-size:1.8rem; color:var(--cream); margin-bottom:12px; }
.form-success p{ color:var(--cream-dim); }

/* ============================================================
   FOOTER
   ============================================================ */
.footer{ background:#0e120b; padding:clamp(60px,8vh,96px) 0 40px; border-top:1px solid var(--line-soft); }
.footer-top{ display:grid; grid-template-columns:1.4fr 1fr 1fr; gap:40px; padding-bottom:48px; border-bottom:1px solid var(--line-soft); }
.footer .wm-text b{ font-size:1.3rem; }
.f-brand p{ margin-top:18px; color:var(--cream-mute); font-size:.92rem; max-width:34ch; }
.f-col h5{ font-family:var(--sans); font-size:.7rem; letter-spacing:.2em; text-transform:uppercase; color:var(--gold); margin:0 0 18px; }
.f-col a, .f-col p{ display:block; color:var(--cream-dim); font-size:.94rem; margin-bottom:12px; transition:color .2s; }
.f-col a:hover{ color:var(--gold); }
.f-certs{ display:flex; gap:14px; margin-top:6px; }
.f-cert{ border:1px solid var(--line); border-radius:2px; padding:7px 12px; font-size:.7rem; letter-spacing:.12em; text-transform:uppercase; color:var(--cream-dim); }
.footer-bot{ display:flex; flex-wrap:wrap; justify-content:space-between; gap:18px; align-items:center; padding-top:30px; }
.footer-bot small{ color:var(--cream-mute); font-size:.8rem; letter-spacing:.04em; }
.social{ display:flex; gap:10px; }
.social a{ width:38px; height:38px; border:1px solid var(--line); border-radius:50%; display:grid; place-items:center; color:var(--cream-dim); transition:border-color .25s, color .25s, background .25s; }
.social a:hover{ border-color:var(--gold); color:var(--gold); background:rgba(201,168,106,.07); }
.social svg{ width:16px; height:16px; }

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

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width: 980px){
  body{ font-size:17px; }
  .why-grid{ grid-template-columns:1fr; gap:48px; }
  .process-grid{ grid-template-columns:1fr 1fr; gap:32px 24px; }
  .reviews-grid{ columns:1; }
  .outdoor-grid{ grid-template-columns:repeat(2,1fr); grid-auto-rows:180px; }
  .ocard.big, .ocard.tall{ grid-column:span 2; grid-row:span 2; }
  .ocard.wide, .ocard.sm{ grid-column:span 1; }
  .footer-top{ grid-template-columns:1fr 1fr; }
}
@media (max-width: 620px){
  .hero{ height:450vh; }
  .hero-overlay{ left:var(--gutter); right:var(--gutter); max-width:none; }
  .hero-bar-track{ display:none; }
  .deck-controls{ left:var(--gutter); right:var(--gutter); align-items:flex-start; bottom:30px; }
  .stage-caption{ bottom:auto; top:96px; }
  .swatches{ flex-wrap:wrap; }
  .qform{ grid-template-columns:1fr; }
  .contact-recap span{ gap:0; }
  .contact-recap span::after{ display:none; }
  .footer-top{ grid-template-columns:1fr; }
  .gframe{ width:84vw; }
}
