/* ============================================================
   Home Inspection Winthrop MN — "RURAL HEARTLAND"
   Honest, grounded, agricultural warmth for a small farming
   town. Barn-red primary on an oat/wheat base, weathered-wood
   brown structure, a field-green hint, sturdy slab-serif display
   (Zilla Slab) + plain honest body (Mulish). Subtle woodgrain/
   grain texture, honest rectangular cards, farmhouse rule
   accents. Deliberately NOTHING like the Lakeville teal/navy
   editorial theme — heartland-honest, never luxury/tech/deco.
   ============================================================ */
:root{
  --oat:#f6efe0;          /* oat/wheat base — brighter, cleaner */
  --oat-2:#ece2cd;        /* deeper wheat */
  --paper:#fdfaf2;        /* lightest panel */
  --cream:#ffffff;        /* card surface — clean white */
  --barn:#bb3a2b;         /* barn-red primary — brighter, vivid */
  --barn-dk:#8a2417;      /* deep barn shadow */
  --barn-glow:rgba(187,58,43,.14);
  --wood:#6b5238;         /* weathered-wood brown */
  --wood-2:#8a6d4f;
  --field:#bb3a2b;        /* (was green) → barn-red, no green */
  --field-dk:#a52f20;     /* (was green) → deep red accent */
  --gold:#e0922e;         /* vivid harvest-gold accent */
  --gold-lt:#f4b860;      /* bright gold highlight */
  --loam:#2c261d;         /* dark loam text */
  --ink:#3a342a;          /* body ink, warm */
  --muted:#736751;        /* muted earth */
  --line:#e2d6bd;         /* wheat hairline */
  --line-2:#cdbd99;       /* stronger rule */
  --grain:#cdbf9f;
  --sh-sm:0 1px 2px rgba(60,44,24,.06),0 6px 16px rgba(60,44,24,.07);
  --sh:0 2px 6px rgba(60,44,24,.07),0 16px 40px rgba(60,44,24,.12);
  --sh-lg:0 4px 12px rgba(60,44,24,.10),0 30px 64px rgba(60,44,24,.18);
  --r:6px;                /* honest rectangles — small radius */
  --r-lg:12px;
  --wrap:1200px;
  --disp:"Zilla Slab",Georgia,"Times New Roman",serif;
  --body:"Mulish",system-ui,-apple-system,sans-serif;
  --ease:cubic-bezier(.2,.6,.3,1);
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  font-family:var(--body);background:var(--oat);color:var(--ink);
  font-size:17px;line-height:1.66;font-weight:400;
  -webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;
  overflow-x:hidden;
  /* faint woodgrain/grain texture on the base */
  background-image:
    repeating-linear-gradient(90deg,rgba(124,97,73,.025) 0 2px,
      transparent 2px 7px),
    radial-gradient(circle at 20% 10%,rgba(124,97,73,.05),transparent 60%);
}
img{max-width:100%;height:auto;display:block}
a{color:var(--barn);text-decoration:none;transition:color .2s}
a:hover{color:var(--barn-dk)}
h1,h2,h3,h4{font-family:var(--disp);color:var(--loam);
  line-height:1.1;letter-spacing:-.01em;font-weight:600}
.wrap{max-width:var(--wrap);margin:0 auto;padding:0 30px}
.mono{font-family:var(--body);font-weight:800;font-size:12px;
  letter-spacing:.15em;text-transform:uppercase;color:var(--wood-2)}
.tbd{color:var(--barn-dk);font-style:italic;font-size:.88em;
  background:var(--barn-glow);padding:1px 8px;border-radius:4px;
  font-family:var(--body);font-weight:700}

/* Blank-gap guard: reveals hidden ONLY when JS active. */
.js .reveal{opacity:0;transform:translateY(20px);
  transition:opacity .75s var(--ease),transform .75s var(--ease)}
.js .reveal.in{opacity:1;transform:none}
.js .reveal.d2{transition-delay:.10s}
.js .reveal.d3{transition-delay:.20s}
.js .reveal.d4{transition-delay:.30s}
@media (prefers-reduced-motion:reduce){
  .js .reveal{opacity:1!important;transform:none!important;
    transition:none!important}
  *{animation:none!important}
}

.skip{position:absolute;left:-999px;z-index:200}
.skip:focus{left:18px;top:18px;background:var(--barn);color:#fff;
  padding:12px 20px;border-radius:5px;font-family:var(--disp);
  font-weight:600}

/* ---------- Top meta bar ---------- */
.meta{background:var(--barn-dk);color:#e7d4ca;
  border-bottom:2px solid var(--barn)}
.meta .wrap{display:flex;justify-content:space-between;
  align-items:center;height:40px;font-size:12.5px;flex-wrap:wrap;
  font-weight:700;letter-spacing:.01em}
.meta a{color:#fff}
.meta a:hover{color:var(--oat)}

/* ---------- Nav ---------- */
nav{position:sticky;top:0;z-index:90;
  background:rgba(250,246,236,.93);
  backdrop-filter:saturate(150%) blur(10px);
  -webkit-backdrop-filter:saturate(150%) blur(10px);
  border-bottom:1px solid var(--line-2);
  box-shadow:0 1px 0 rgba(255,255,255,.5) inset}
nav .wrap{display:flex;align-items:center;justify-content:space-between;
  height:76px;gap:22px}
.brand{display:flex;align-items:center;gap:13px;color:var(--loam)}
.brand .glyph{width:46px;height:46px;display:grid;place-items:center;
  background:var(--barn);border-radius:6px;flex:none;position:relative;
  overflow:hidden;box-shadow:inset 0 0 0 2px rgba(255,255,255,.12)}
.brand .glyph:after{content:"";position:absolute;inset:0;
  background:linear-gradient(150deg,transparent 55%,rgba(0,0,0,.18))}
.brand .glyph svg{width:25px;height:25px;position:relative;z-index:1}
.brand .name{font-family:var(--disp);font-weight:700;font-size:21px;
  line-height:1;letter-spacing:-.01em;color:var(--loam)}
.brand .name small{display:block;font-family:var(--body);
  font-weight:800;font-size:10px;color:var(--barn);
  letter-spacing:.17em;text-transform:uppercase;margin-top:5px}
.navlinks{display:flex;gap:28px;margin-left:auto}
.navlinks a{color:var(--ink);font-weight:700;font-size:14.5px;
  position:relative;padding:8px 0;letter-spacing:.01em}
.navlinks a:after{content:"";position:absolute;left:0;bottom:2px;
  width:0;height:2px;background:var(--barn);transition:width .28s var(--ease)}
.navlinks a:hover{color:var(--barn)}
.navlinks a:hover:after{width:100%}
.book{background:var(--barn);color:#fff!important;
  padding:13px 22px;border-radius:5px;font-family:var(--disp);
  font-weight:600;font-size:15px;position:relative;
  transition:transform .22s var(--ease),background .22s;
  box-shadow:0 3px 0 var(--barn-dk)}
.book:hover{transform:translateY(-2px);background:var(--barn-dk);
  color:#fff!important;box-shadow:0 5px 0 var(--barn-dk)}
.burger{display:none;width:46px;height:46px;background:none;
  border:0;cursor:pointer;flex-direction:column;gap:5px;
  align-items:center;justify-content:center}
.burger span{width:24px;height:2.5px;background:var(--barn);
  border-radius:2px;transition:.3s var(--ease)}
body.nav-open .burger span:nth-child(1){transform:translateY(7.5px) rotate(45deg)}
body.nav-open .burger span:nth-child(2){opacity:0}
body.nav-open .burger span:nth-child(3){transform:translateY(-7.5px) rotate(-45deg)}
.mobnav{display:none}

/* ---------- Breadcrumb ---------- */
.crumb{background:var(--oat-2);border-bottom:1px solid var(--line-2)}
.crumb .wrap{display:flex;flex-wrap:wrap;gap:9px;align-items:center;
  height:48px;font-size:13px;color:var(--muted);font-weight:700}
.crumb a{color:var(--barn)}
.crumb b{color:var(--loam);font-weight:700}
.crumb span{color:var(--line-2)}

/* ---------- Hero (full-bleed background image) ---------- */
.hero{position:relative;isolation:isolate;
  border-bottom:4px solid var(--barn)}
.hero-full{min-height:clamp(560px,82vh,820px);display:flex;
  flex-direction:column;justify-content:center;overflow:hidden}
.hero-bg{position:absolute;inset:0;width:100%;height:100%;
  object-fit:cover;object-position:center 60%;z-index:-2;
  /* bright & vivid hero photo */
  filter:brightness(1.16) saturate(1.22) contrast(1.05)}
/* NO wash over the image itself — keep the hero photo CLEAN and VIVID.
   The text sits on its own frosted-glass panel for legibility, so the
   only scrim is a faint gradient at the very bottom so the trust strip
   stays readable. The image area shows at full clarity. */
.hero-scrim{position:absolute;inset:0;z-index:-1;
  background:linear-gradient(0deg,rgba(28,16,10,.30),transparent 24%)}
/* Hero content spans wider than the 1200px wrap so the text card can sit
   to the LEFT of the screen (not centered in a column), with a small
   gutter from the edge. */
.hero-full .hero-inner{display:block;position:relative;
  max-width:none;width:100%;padding:64px 48px 26px}
.hero-full .htext{margin-left:0!important}
/* Tight glass card behind the hero copy — little padding, high contrast
   so the text is clearly visible over the bright, vivid image. */
.hero-full .htext{max-width:31em;width:100%;margin-right:auto;
  margin-left:0;position:relative;
  padding:20px 22px;border-radius:14px;
  background:linear-gradient(155deg,
    rgba(28,16,10,.62),rgba(28,16,10,.50));
  -webkit-backdrop-filter:blur(14px) saturate(150%);
  backdrop-filter:blur(14px) saturate(150%);
  border:1px solid rgba(255,247,235,.32);
  box-shadow:0 20px 56px rgba(20,10,6,.5),
    inset 0 1px 0 rgba(255,255,255,.24);}
.hero-full .htext:before{content:"";position:absolute;inset:0;
  border-radius:14px;pointer-events:none;
  box-shadow:inset 0 0 0 1px rgba(255,255,255,.06)}
/* tighter internal rhythm inside the compact card */
.hero-full .htext .eyebrow{margin-bottom:14px}
.hero-full .htext .hero-h1{margin-bottom:14px}
.hero-full .htext .lead{margin-bottom:20px}
.hero-full .htext .actions{margin-bottom:4px}
.hero-full .eyebrow{color:var(--gold-lt)}
.hero-full .eyebrow .tick,
.hero-full .eyebrow .tick:before,
.hero-full .eyebrow .tick:after{background:var(--gold-lt)}
.hero-full .hero-h1{color:#fff;
  text-shadow:0 2px 18px rgba(0,0,0,.6),0 1px 3px rgba(0,0,0,.5)}
.hero-full .hero-h1 .em{color:var(--gold-lt)}
.hero-full .htext .lead{color:#ffffff!important;max-width:32em;
  text-shadow:0 1px 10px rgba(0,0,0,.7),0 0 2px rgba(0,0,0,.5)}
.hero-full .secondary{background:rgba(255,255,255,.10);
  color:#fff;border-color:rgba(255,255,255,.36);
  backdrop-filter:blur(4px)}
.hero-full .secondary svg{stroke:var(--gold-lt)}
.hero-full .secondary:hover{background:rgba(255,255,255,.18);
  border-color:#fff;color:#fff}
.hero-trust{position:relative;z-index:1;
  border-top:1px solid rgba(255,255,255,.16);
  background:rgba(40,24,16,.5);
  -webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px)}
.hero-trust .wrap{display:flex;flex-wrap:wrap;gap:14px 40px;
  padding:18px 30px}
.hero-trust span{color:#e7d8c2;font-size:13.5px;font-weight:700;
  letter-spacing:.01em}
.hero-trust b{font-family:var(--disp);color:#fff;font-weight:600;
  margin-right:4px}
.eyebrow{display:inline-flex;align-items:center;gap:11px;
  color:var(--barn);font-family:var(--body);font-weight:800;
  font-size:12px;letter-spacing:.18em;text-transform:uppercase;
  margin-bottom:24px}
.eyebrow .tick{width:30px;height:3px;background:var(--barn);
  position:relative;flex:none;border-radius:2px}
.hero h1,.hero-h1{font-size:clamp(40px,5.6vw,70px);
  margin-bottom:22px;font-weight:700;letter-spacing:-.018em}
.hero h1 .em,.hero-h1 .em{color:var(--barn);font-style:italic;
  font-weight:500}
.hero .lead{font-size:19.5px;color:var(--muted);max-width:33em;
  margin-bottom:32px;line-height:1.7}
.actions{display:flex;gap:15px;flex-wrap:wrap;margin-bottom:42px}
.primary,.secondary{display:inline-flex;align-items:center;gap:11px;
  font-family:var(--disp);font-weight:600;font-size:16px;
  padding:15px 28px;border-radius:5px;
  transition:transform .22s var(--ease),box-shadow .22s var(--ease),
  background .22s,border-color .22s}
.primary{background:var(--barn);color:#fff;position:relative;
  box-shadow:0 4px 0 var(--barn-dk)}
.primary:hover{background:var(--barn-dk);color:#fff;
  transform:translateY(-2px);box-shadow:0 6px 0 var(--barn-dk)}
.primary:active{transform:translateY(1px);box-shadow:0 2px 0 var(--barn-dk)}
.primary svg{width:18px;height:18px;stroke:#fff;stroke-width:2.4;
  fill:none}
.secondary{background:var(--cream);color:var(--loam);
  border:2px solid var(--line-2)}
.secondary svg{width:17px;height:17px;stroke:var(--barn);
  stroke-width:1.8;fill:none}
.secondary:hover{border-color:var(--wood);color:var(--loam);
  transform:translateY(-2px);box-shadow:var(--sh-sm)}

/* ---------- Section primitives ---------- */
.blk{padding:92px 0;position:relative}
.blk.alt{background:var(--paper);
  border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.shead{display:grid;grid-template-columns:auto 1fr;gap:28px;
  align-items:start;margin-bottom:50px;max-width:62em}
.shead .idx{font-family:var(--disp);font-weight:700;
  font-size:14px;color:var(--barn);padding-top:10px;
  position:relative;white-space:nowrap;letter-spacing:.08em;
  text-transform:uppercase}
.shead .idx:before{content:"";display:block;width:38px;height:3px;
  background:var(--barn);margin-bottom:13px;border-radius:2px}
.shead h2{font-size:clamp(30px,4vw,46px);margin-bottom:12px;
  font-weight:700;letter-spacing:-.018em}
.shead h2 i{color:var(--barn);font-style:italic;font-weight:500}
.shead .sub{color:var(--muted);font-size:17px;max-width:42em;
  line-height:1.6}

/* ---------- Service / link cards (honest rectangles) ---------- */
.cards{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.cards a{background:var(--cream);border:1px solid var(--line-2);
  border-radius:var(--r);padding:30px 28px;display:block;
  position:relative;overflow:hidden;
  transition:transform .3s var(--ease),box-shadow .3s var(--ease),
  border-color .3s}
.cards a:before{content:"";position:absolute;left:0;top:0;bottom:0;
  width:4px;background:var(--barn);
  transform:scaleY(0);transform-origin:top;
  transition:transform .35s var(--ease)}
.cards a:hover{transform:translateY(-5px);box-shadow:var(--sh-lg);
  border-color:var(--line-2)}
.cards a:hover:before{transform:scaleY(1)}
.glyphbox{width:54px;height:54px;border-radius:6px;
  background:linear-gradient(150deg,var(--wood),var(--loam));
  display:grid;place-items:center;margin-bottom:20px;
  position:relative;overflow:hidden;
  box-shadow:inset 0 0 0 2px rgba(255,255,255,.08)}
.glyphbox:after{content:"";position:absolute;inset:0;
  background:linear-gradient(150deg,transparent 55%,rgba(138,47,36,.4))}
.glyphbox svg{width:27px;height:27px;stroke:var(--oat);stroke-width:1.6;
  fill:none;stroke-linecap:round;stroke-linejoin:round;
  position:relative;z-index:1}
/* Photo thumbnail cards (homepage services) — full-bleed image top */
.cards a.hascard{padding:0;overflow:hidden}
.cards a.hascard .cardthumb{display:block;position:relative;
  aspect-ratio:3/2;overflow:hidden;background:var(--oat-2);
  border-bottom:3px solid var(--barn)}
.cards a.hascard .cardthumb img{width:100%;height:100%;object-fit:cover;
  transition:transform .55s var(--ease)}
.cards a.hascard:hover .cardthumb img{transform:scale(1.06)}
.cards a.hascard h3{margin:22px 28px 9px}
.cards a.hascard .desc{margin:0 28px 18px}
.cards a.hascard .arrow{margin:0 28px 28px}
.cards a.hascard:before{z-index:2}
.cards h3{font-size:21px;margin-bottom:9px;font-weight:700}
.cards .desc{color:var(--muted);font-size:14.5px;line-height:1.6;
  margin-bottom:18px}
.cards .arrow{font-family:var(--disp);font-weight:600;font-size:14px;
  color:var(--barn);display:inline-flex;align-items:center;gap:7px}
.cards .arrow:after{content:"\2192";transition:transform .25s var(--ease)}
.cards a:hover .arrow:after{transform:translateX(5px)}
.cards .no{display:inline-block;font-family:var(--disp);
  font-weight:700;font-size:13px;color:var(--barn);
  letter-spacing:.08em;margin-bottom:16px;
  padding-bottom:6px;border-bottom:2px solid var(--line-2)}

/* ---------- Coverage / link grid ---------- */
.grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
.cell{background:var(--cream);border:1px solid var(--line-2);
  border-radius:var(--r);padding:19px 21px;position:relative;
  transition:border-color .22s,transform .22s var(--ease),
  box-shadow .22s}
.cell:hover{border-color:var(--barn);transform:translateY(-3px);
  box-shadow:var(--sh-sm)}
.cell .mono{display:block;margin-bottom:7px;color:var(--field-dk);
  font-size:11px}
.cell b{font-family:var(--disp);font-size:16.5px;display:block;
  margin-bottom:4px;font-weight:600}
.cell b a{color:var(--loam)}
.cell b a:hover{color:var(--barn)}
.cell span{font-size:12.5px;color:var(--muted)}

/* ---------- AEO answer block ---------- */
.aeo{background:var(--wood);color:#f1e6d4;position:relative;
  overflow:hidden;border-bottom:3px solid var(--barn)}
.aeo:before{content:"";position:absolute;inset:0;
  background:
   repeating-linear-gradient(90deg,rgba(0,0,0,.05) 0 3px,transparent 3px 12px),
   radial-gradient(70% 120% at 10% -10%,rgba(138,47,36,.3),transparent 55%)}
.aeo .wrap{padding:56px 30px;position:relative}
.aeo-answer{font-size:22px;line-height:1.6;color:#fff;
  font-family:var(--disp);font-weight:400;max-width:44em;
  letter-spacing:-.005em}
.aeo-answer:before{content:"";display:block;width:40px;height:3px;
  background:var(--gold-lt);margin-bottom:22px;border-radius:2px}

/* ---------- Feature band ---------- */
.fband .fbgrid{display:grid;grid-template-columns:1fr 1.06fr;
  gap:60px;align-items:center}
.fbtext .eyebrow{margin-bottom:20px}
.fbtext h2{font-size:clamp(28px,3.6vw,42px);margin-bottom:16px;
  font-weight:700}
.fbtext h2 i{color:var(--barn);font-style:italic;font-weight:500}
.fbtext p{color:var(--muted);font-size:17px;line-height:1.72;
  margin-bottom:26px}
.fbimg{position:relative;border-radius:var(--r-lg);overflow:hidden;
  box-shadow:var(--sh-lg);aspect-ratio:16/10.4;background:var(--oat-2);
  border:1px solid var(--line-2)}
.fbimg:after{content:"";position:absolute;inset:0;
  box-shadow:inset 0 0 0 1px rgba(255,253,247,.4);border-radius:var(--r-lg)}
.fbimg img{width:100%;height:100%;object-fit:cover}

/* ---------- Gallery ---------- */
.ggrid{display:grid;grid-template-columns:repeat(3,1fr);
  grid-auto-rows:1fr;gap:18px}
.gcell{border-radius:var(--r);overflow:hidden;position:relative;
  box-shadow:var(--sh-sm);background:var(--oat-2);aspect-ratio:3/2;
  border:1px solid var(--line-2)}
.gcell img{width:100%;height:100%;object-fit:cover;
  transition:transform .7s var(--ease)}
.gcell:hover img{transform:scale(1.06)}
.gcell figcaption{position:absolute;left:0;right:0;bottom:0;
  background:linear-gradient(0deg,rgba(47,42,34,.9),
  rgba(47,42,34,.3) 55%,transparent);
  color:#fff;font-family:var(--disp);font-weight:600;font-size:14.5px;
  padding:34px 16px 14px;letter-spacing:-.01em}
.gcell figcaption:before{content:"";display:block;width:22px;
  height:3px;background:var(--barn);margin-bottom:8px;border-radius:2px}

/* ---------- Before / after ---------- */
.ba{max-width:800px;margin:0 auto}
.ba-stage{position:relative;border-radius:var(--r);overflow:hidden;
  box-shadow:var(--sh-lg);aspect-ratio:3/2;
  background:var(--oat-2);user-select:none;border:1px solid var(--line-2)}
.ba-stage img{position:absolute;inset:0;width:100%;height:100%;
  object-fit:cover}
.ba-after{clip-path:inset(0 0 0 50%)}
.ba-tag{position:absolute;top:16px;font-family:var(--disp);
  font-weight:600;font-size:12px;color:#fff;
  background:rgba(47,42,34,.85);padding:7px 13px;border-radius:4px;
  letter-spacing:.04em}
.ba-tag.l{left:16px}.ba-tag.r{right:16px}
.ba-handle{position:absolute;top:50%;left:50%;
  transform:translate(-50%,-50%);width:44px;height:44px;
  border-radius:50%;background:var(--barn);color:#fff;
  display:grid;place-items:center;box-shadow:var(--sh-lg);
  font-size:14px;pointer-events:none}
.ba-stage input[type=range]{position:absolute;inset:auto 0 0 0;
  width:100%;bottom:50%;margin:0;-webkit-appearance:none;
  background:transparent;cursor:ew-resize;height:44px}
.ba-stage input[type=range]::-webkit-slider-thumb{
  -webkit-appearance:none;width:44px;height:44px;opacity:0;
  cursor:ew-resize}

/* ---------- FAQ ---------- */
.faqx{max-width:800px;margin:0 auto}
.faqx input[type=search]{width:100%;padding:16px 20px;font-size:16px;
  font-family:var(--body);border:2px solid var(--line-2);
  border-radius:5px;margin-bottom:18px;color:var(--ink);
  background:var(--cream);transition:border-color .2s,box-shadow .2s}
.faqx input[type=search]:focus{outline:none;border-color:var(--barn);
  box-shadow:0 0 0 4px var(--barn-glow)}
.fitem{background:var(--cream);border:1px solid var(--line-2);
  border-radius:5px;margin-bottom:12px;overflow:hidden;
  transition:border-color .22s,box-shadow .22s}
.fitem.open{border-color:var(--barn);box-shadow:var(--sh-sm)}
.fq{font-family:var(--disp);font-weight:600;font-size:17px;
  color:var(--loam);padding:19px 22px;cursor:pointer;
  display:flex;justify-content:space-between;gap:18px;
  align-items:center}
.fq:after{content:"";width:14px;height:14px;flex:none;
  background:
   linear-gradient(var(--barn),var(--barn)) center/14px 2.5px no-repeat,
   linear-gradient(var(--barn),var(--barn)) center/2.5px 14px no-repeat;
  transition:transform .3s var(--ease)}
.fitem.open .fq:after{transform:rotate(135deg)}
.fa{max-height:0;overflow:hidden;transition:max-height .35s var(--ease),
  padding .35s var(--ease);color:var(--muted);font-size:15.5px;
  line-height:1.72;padding:0 22px}
.fitem.open .fa{max-height:400px;padding:0 22px 20px}
.nomatch{color:var(--muted);text-align:center;padding:22px}

/* ---------- Marquee ---------- */
.marq{background:var(--field);overflow:hidden;padding:16px 0;
  position:relative;border-top:2px solid var(--field-dk);
  border-bottom:2px solid var(--field-dk)}
.marq:before,.marq:after{content:"";position:absolute;top:0;
  bottom:0;width:80px;z-index:1;pointer-events:none}
.marq:before{left:0;background:linear-gradient(90deg,var(--field),
  transparent)}
.marq:after{right:0;background:linear-gradient(270deg,var(--field),
  transparent)}
.marq .track{display:flex;gap:50px;width:max-content;
  animation:marq 40s linear infinite}
.marq .item{font-family:var(--disp);font-weight:500;font-size:16px;
  color:#fff2e0;white-space:nowrap;display:flex;align-items:center;
  gap:50px;font-style:italic}
.marq .item:after{content:"";width:6px;height:6px;
  background:var(--gold-lt);border-radius:50%;font-style:normal}
@keyframes marq{to{transform:translateX(-50%)}}

/* ---------- Long-form prose ---------- */
.prose{max-width:50em}
.prose h2{font-size:clamp(25px,3vw,34px);margin:40px 0 15px;
  font-weight:700}
.prose h2:first-child{margin-top:0}
.prose h3{font-size:20px;margin:30px 0 10px;color:var(--wood);
  font-weight:600}
.prose p{color:var(--ink);font-size:17px;line-height:1.8;
  margin-bottom:16px}
.prose ul{padding-left:0;margin-bottom:16px;list-style:none}
.prose li{color:var(--ink);font-size:17px;line-height:1.7;
  margin-bottom:10px;padding-left:26px;position:relative}
.prose li:before{content:"";position:absolute;left:0;top:11px;
  width:12px;height:3px;background:var(--barn);border-radius:2px}
.prose a{color:var(--barn);font-weight:700;
  text-decoration:underline;text-underline-offset:3px;
  text-decoration-color:var(--line-2)}
.prose a:hover{text-decoration-color:var(--barn)}
.prose .lead{font-size:21px;color:var(--loam);line-height:1.6;
  margin-bottom:25px;font-family:var(--disp);font-weight:400}
.mapwrap{margin-top:44px;border:1px solid var(--line-2);
  border-radius:var(--r);overflow:hidden}
.mapwrap iframe{display:block;width:100%;height:360px;border:0;
  filter:saturate(.85) sepia(.08)}

/* ---------- Reviews ---------- */
.rev{background:var(--paper);border-top:1px solid var(--line)}
.revhead{display:flex;align-items:baseline;gap:20px;flex-wrap:wrap;
  margin-bottom:28px}
.revhead .big{font-family:var(--disp);font-size:56px;
  color:var(--barn);line-height:1;font-weight:700}
.stars{color:var(--gold);letter-spacing:3px}
.rev figure{background:var(--cream);border:1px solid var(--line-2);
  border-radius:var(--r);padding:30px}
.rev blockquote{color:var(--ink);font-size:16px;line-height:1.72;
  margin:13px 0 18px;font-family:var(--disp);font-style:italic;
  font-weight:400}
.rev figcaption{font-size:13.5px;color:var(--muted)}
.rev figcaption b{font-family:var(--disp);color:var(--loam);
  font-style:normal;font-weight:600}
.revtbd{background:var(--cream);border:1px solid var(--line-2);
  border-left:4px solid var(--barn);
  border-radius:var(--r);padding:32px 36px;
  color:var(--muted);font-size:15.5px;line-height:1.72;
  max-width:680px;margin:0 auto}

/* ---------- Instant Quote close ---------- */
/* CRITICAL: never inside .reveal, never lazy, tall + eager. */
.close{position:relative;isolation:isolate;overflow:hidden;
  background:linear-gradient(165deg,var(--barn-dk),#3a140e);
  padding:88px 0 96px;color:#fff;text-align:center}
.close-top{padding:62px 0 68px;
  border-bottom:1px solid rgba(255,255,255,.1)}
.close-top h2{font-size:clamp(28px,3.8vw,44px)}
.close:before{content:"";position:absolute;inset:0;z-index:-1;
  opacity:.5;background-image:
   repeating-linear-gradient(90deg,rgba(255,255,255,.04) 0 2px,transparent 2px 9px);
  -webkit-mask-image:radial-gradient(70% 80% at 50% 0%,#000,transparent 70%);
  mask-image:radial-gradient(70% 80% at 50% 0%,#000,transparent 70%)}
.close:after{content:"";position:absolute;z-index:-1;
  width:540px;height:540px;border-radius:50%;left:50%;top:-280px;
  transform:translateX(-50%);
  background:radial-gradient(circle,rgba(240,201,138,.18),transparent 65%)}
.close h2{color:#fff;font-size:clamp(30px,4.4vw,52px);
  margin:14px 0 12px;font-weight:700}
.close h2 i{color:var(--gold-lt);font-style:italic;font-weight:500}
.close .eyebrow{color:var(--gold-lt);justify-content:center}
.close .eyebrow .tick,.close .eyebrow .tick:before,
.close .eyebrow .tick:after{background:var(--gold-lt)}
.close>.wrap>p{color:#e7d4ca;font-size:17px;margin-bottom:34px}
.quotebox{background:#fff;border-radius:var(--r-lg);
  box-shadow:0 40px 90px rgba(0,0,0,.42);overflow:hidden;
  max-width:940px;margin:0 auto;text-align:left}
.quotecap{display:flex;justify-content:space-between;
  padding:17px 24px;background:var(--oat);
  border-bottom:2px solid var(--barn);font-family:var(--disp);
  font-weight:600;font-size:14px;color:var(--loam);flex-wrap:wrap;
  gap:8px}
.quotecap span:last-child{color:var(--muted);font-weight:700}
.quotebox iframe{display:block;width:100%;min-height:900px;
  border:0;background:#fff}
.quote-fallback{background:#fff;border-radius:var(--r-lg);
  box-shadow:0 40px 90px rgba(0,0,0,.42);max-width:680px;
  margin:0 auto;padding:52px 40px;text-align:center}
.quote-fallback h3{font-size:25px;margin-bottom:12px;font-weight:700;
  color:var(--loam)}
.quote-fallback p{color:var(--muted);margin-bottom:24px;
  font-size:16px}

/* ---------- Footer ---------- */
footer{background:var(--loam);color:#cabfa8;padding:58px 0 52px;
  font-size:14px;border-top:5px solid var(--barn)}
footer .wrap{display:flex;flex-direction:column;gap:11px}
.fbrand{font-family:var(--disp);font-weight:700;font-size:22px;
  color:#fff;margin-bottom:4px}
footer a{color:#e0d3bb;font-weight:700}
footer a:hover{color:var(--gold-lt)}
.flink a{color:var(--gold-lt)}
footer .mono{color:#b3a684;font-size:11.5px;margin-top:10px}
.fnav2{font-size:13px;line-height:1.9}
.fnav2 a{color:#d8cbb2;font-weight:600}
.fnav2 a:hover{color:var(--gold-lt)}
footer .tbd{background:rgba(240,201,138,.14);color:var(--gold-lt)}

/* ---------- Sticky mobile bar ---------- */
.stickybar{position:fixed;left:0;right:0;bottom:0;z-index:80;
  display:none;gap:2px;background:var(--barn-dk);
  box-shadow:0 -6px 26px rgba(47,42,34,.3);
  transform:translateY(110%);transition:transform .35s var(--ease)}
.stickybar.show{transform:translateY(0)}
.stickybar a{flex:1;text-align:center;padding:16px;
  font-family:var(--disp);font-weight:600;font-size:15px}
.stickybar .call{background:var(--oat);color:var(--loam)}
.stickybar .quote{background:var(--barn);color:#fff}

/* ---------- Responsive: 1024 / 820 / 600 / 380 ---------- */
@media(max-width:1024px){
  .cards{grid-template-columns:repeat(2,1fr)}
  .grid{grid-template-columns:repeat(3,1fr)}
  .ggrid{grid-template-columns:repeat(2,1fr)}
  .fband .fbgrid{grid-template-columns:1fr;gap:34px}
  .fband .fbimg{order:-1}
  .shead{gap:22px}
}
@media(max-width:820px){
  .navlinks,.book{display:none}
  .burger{display:flex}
  .mobnav{display:block;position:fixed;inset:76px 0 auto 0;
    background:var(--cream);border-bottom:2px solid var(--barn);
    padding:14px 0;transform:translateY(-140%);
    transition:transform .35s var(--ease);z-index:85;
    box-shadow:var(--sh-lg)}
  body.nav-open .mobnav{transform:translateY(0)}
  .mobnav a{display:block;padding:15px 30px;font-family:var(--disp);
    font-weight:600;color:var(--loam);font-size:16px;
    border-bottom:1px solid var(--line)}
  .stickybar{display:flex}
  body{padding-bottom:56px}
  .grid{grid-template-columns:repeat(2,1fr)}
  .blk{padding:62px 0}
  .shead{grid-template-columns:1fr;gap:14px}
  .shead .idx:before{margin-bottom:10px}
}
@media(max-width:600px){
  body{font-size:16px}
  .wrap{padding:0 20px}
  .cards,.grid,.ggrid{grid-template-columns:1fr}
  .actions{flex-direction:column}
  .primary,.secondary{width:100%;justify-content:center}
  .quotebox iframe{min-height:1100px}      /* uncut on mobile */
  .meta .wrap{justify-content:center;gap:16px;height:auto;
    padding:9px 20px}
  .aeo-answer{font-size:19px}
  .hero-full{min-height:auto;padding:0}
  .hero-full .hero-inner{padding:40px 0 20px}
  .hero-full .htext{padding:28px 24px 30px;border-radius:13px;
    -webkit-backdrop-filter:blur(12px) saturate(140%);
    backdrop-filter:blur(12px) saturate(140%)}
}
@media(max-width:380px){
  .hero h1,.hero-h1{font-size:33px}
  .brand .name{font-size:19px}
  .shead h2{font-size:25px}
}
/* All interactive targets >= 44px */
a.primary,a.secondary,.book,.fq,.stickybar a,.burger,
.navlinks a,.mobnav a{min-height:44px}
