/* Home Inspectors Hastings MN — site theme (polished v2: Bricolage + Fraunces + mono,
   paper grain, bluff-contour rules, staggered hero motion). Accent #ff7038. */

*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
:root{
  --ink:#171210;--paper:#f7f1e8;--mut:#6f6557;
  --brand:#6e1d16;--brand2:#a8392b;--accent:#ff7038;--gold:#b88a4a;
  --soft:#efe6d7;--line:#e0d4c0;
}
body{
  font-family:'Fraunces',Georgia,serif;background:var(--paper);color:var(--ink);
  font-optical-sizing:auto;-webkit-font-smoothing:antialiased;position:relative;
}
a{text-decoration:none;color:inherit}
ul{list-style:none}
img{display:block;max-width:100%}
.wrap{max-width:1180px;margin:0 auto;padding:0 clamp(22px,4vw,52px)}
h1,h2,h3,h4{font-family:'Bricolage Grotesque',sans-serif;font-weight:800;letter-spacing:-.025em;line-height:1.01}

/* paper grain overlay (atmosphere, not noise-for-noise) */
body::before{content:"";position:fixed;inset:0;z-index:1;pointer-events:none;opacity:.5;mix-blend-mode:multiply;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/%3E%3CfeColorMatrix type='saturate' values='0'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.06'/%3E%3C/svg%3E")}
body>*{position:relative;z-index:2}

/* eyebrow — mono, engraved-rule detail */
.eyebrow{display:inline-flex;align-items:center;gap:10px;font-family:'Spline Sans Mono',monospace;font-size:.7rem;font-weight:600;letter-spacing:.22em;text-transform:uppercase;color:var(--brand2)}
.eyebrow::before{content:"";width:26px;height:1px;background:currentColor;box-shadow:0 3px 0 currentColor}

/* buttons */
.btn{display:inline-flex;align-items:center;gap:10px;font-family:'Bricolage Grotesque',sans-serif;background:var(--accent);color:#1c0e05;font-weight:700;font-size:.92rem;padding:15px 28px;border-radius:4px;border:0;cursor:pointer;transition:transform .18s cubic-bezier(.2,.8,.2,1),box-shadow .25s}
.btn:hover{transform:translateY(-2px);box-shadow:0 14px 30px rgba(255,112,56,.38)}
.btn svg{width:16px;height:16px;transition:transform .25s}
.btn:hover svg{transform:translateX(3px)}
.btn.ghost{background:transparent;color:#fff;border:1px solid rgba(255,255,255,.5)}
.btn.ghost:hover{background:rgba(255,255,255,.12);box-shadow:none}
.btn.dark{background:var(--brand);color:#fff}

/* NAV */
.topbar{position:sticky;top:0;z-index:60;background:rgba(247,241,232,.82);backdrop-filter:blur(14px) saturate(1.2);border-bottom:1px solid var(--line)}
.nav{display:flex;align-items:center;justify-content:space-between;padding:15px clamp(22px,4vw,52px)}
.brand{display:flex;align-items:center;gap:13px;font-family:'Bricolage Grotesque',sans-serif;font-weight:800;font-size:1.08rem;letter-spacing:-.02em}
.brand .mk{width:38px;height:38px;border-radius:50%;background:radial-gradient(circle at 35% 30%,var(--brand2),var(--brand));color:#f7f1e8;display:grid;place-items:center;font-size:1rem;box-shadow:inset 0 1px 2px rgba(255,255,255,.25),0 2px 6px rgba(110,29,22,.4);position:relative;flex:none}
.brand .mk::after{content:"";position:absolute;inset:3px;border:1px solid rgba(247,241,232,.4);border-radius:50%}
.brand small{display:block;font-family:'Spline Sans Mono',monospace;font-size:.56rem;letter-spacing:.18em;color:var(--mut);font-weight:500;margin-top:2px;text-transform:uppercase}
.menu{display:flex;gap:32px;font-family:'Bricolage Grotesque',sans-serif;font-size:.9rem;font-weight:600}
.menu a{color:#3c352d;position:relative;padding:4px 0}
.menu a::after{content:"";position:absolute;left:0;bottom:0;width:0;height:2px;background:var(--accent);transition:width .25s}
.menu a:hover::after{width:100%}
.nav .btn{padding:11px 20px;font-size:.84rem}
@media(max-width:860px){.menu{display:none}}

/* HERO — full-bleed + orchestrated staggered load */
.hero{position:relative;min-height:clamp(560px,82vh,780px);display:flex;align-items:flex-end;color:#fff;overflow:hidden}
.hero>img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;transform:scale(1.06);animation:heroZoom 12s ease-out forwards}
@keyframes heroZoom{to{transform:scale(1)}}
.hero .scrim{position:absolute;inset:0;background:
  radial-gradient(120% 90% at 12% 100%,rgba(110,29,22,.55),transparent 60%),
  linear-gradient(180deg,rgba(18,12,8,.5) 0%,rgba(18,12,8,0) 32%,rgba(18,12,8,.2) 56%,rgba(18,12,8,.88) 100%)}
.hero .wrap{position:relative;z-index:2;width:100%;padding-bottom:clamp(46px,6vw,82px);padding-top:130px}
.hero .eyebrow{color:#ffcfb0}
.hero h1{font-size:clamp(2.7rem,7.2vw,5.8rem);max-width:15ch;margin:22px 0 0;text-shadow:0 2px 40px rgba(0,0,0,.4)}
.hero h1 .hl{color:var(--accent);font-style:italic;font-family:'Fraunces',serif;font-weight:500}
.hero .sub{font-size:clamp(1.05rem,1.5vw,1.25rem);max-width:48ch;margin:24px 0 32px;color:#f4e9da;line-height:1.65}
.hero .actions{display:flex;flex-wrap:wrap;gap:16px;align-items:center}
.hero .meta{font-family:'Spline Sans Mono',monospace;font-size:.78rem;letter-spacing:.08em;color:#e9d8c4}
/* staggered reveal */
.hero .rv{opacity:0;transform:translateY(22px);animation:rise .9s cubic-bezier(.2,.8,.2,1) forwards}
.hero .eyebrow.rv{animation-delay:.15s}
.hero h1.rv{animation-delay:.3s}
.hero .sub.rv{animation-delay:.5s}
.hero .actions.rv{animation-delay:.68s}
@keyframes rise{to{opacity:1;transform:none}}
@media(prefers-reduced-motion:reduce){.hero>img,.hero .rv{animation:none;opacity:1;transform:none}}

/* engraved contour divider (Mississippi bluff motif) */
.rule{height:18px;background-repeat:repeat-x;background-size:auto 18px;opacity:.5;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='240' height='18'%3E%3Cpath d='M0 14 Q30 4 60 9 T120 8 T180 11 T240 7' fill='none' stroke='%23b88a4a' stroke-width='1'/%3E%3Cpath d='M0 17 Q40 9 80 13 T160 12 T240 14' fill='none' stroke='%23b88a4a' stroke-width='.6' opacity='.6'/%3E%3C/svg%3E")}

/* TRUST BADGES */
.badges{background:var(--ink);color:#fff}
.badges .wrap{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;padding:30px 0}
.badge{display:flex;flex-direction:column;gap:4px;border-left:1px solid rgba(255,255,255,.14);padding-left:18px}
.badge:first-child{border-left:0;padding-left:0}
.badge .b1{font-family:'Bricolage Grotesque',sans-serif;font-weight:800;font-size:1.55rem;color:var(--accent)}
.badge .b2{font-family:'Spline Sans Mono',monospace;font-size:.7rem;letter-spacing:.08em;color:#b3a591}
@media(max-width:680px){.badges .wrap{grid-template-columns:repeat(2,1fr);gap:24px}.badge:nth-child(3){border-left:0;padding-left:0}}

/* SECTIONS */
.sec{padding:clamp(64px,8vw,116px) 0}
.sec.tint{background:var(--soft)}
.sec.ink{background:var(--ink);color:#fff}
.sechead{max-width:620px}
.sechead.center{margin:0 auto;text-align:center}
.sechead.center .eyebrow{justify-content:center}
.sec h2{font-size:clamp(2.1rem,4.6vw,3.5rem);margin:18px 0 0}
.sec h2 em{font-family:'Fraunces',serif;font-style:italic;font-weight:500;letter-spacing:-.01em;color:var(--brand2)}
.sec .lead{margin-top:20px;font-size:1.12rem;color:var(--mut);line-height:1.7}
.sec.ink .lead{color:rgba(255,255,255,.78)}

/* SPLIT */
.split{display:grid;grid-template-columns:1.02fr .98fr;gap:clamp(30px,5vw,76px);align-items:center;margin-top:60px}
.split .visual{position:relative}
.split .visual img{width:100%;aspect-ratio:4/5;object-fit:cover;border-radius:6px}
.split .visual::after{content:"";position:absolute;inset:0;border:1px solid rgba(255,255,255,.5);border-radius:6px;margin:10px;mix-blend-mode:overlay;pointer-events:none}
.split .chip{position:absolute;left:-16px;bottom:26px;background:var(--paper);color:var(--ink);border-radius:6px;padding:16px 20px;box-shadow:0 20px 44px rgba(0,0,0,.2);font-family:'Bricolage Grotesque',sans-serif;font-weight:700;font-size:.9rem;display:flex;gap:13px;align-items:center;border:1px solid var(--line)}
.split .chip .dot{width:40px;height:40px;border-radius:50%;background:var(--accent);display:grid;place-items:center;flex:none}
.split p{margin-top:18px;color:var(--mut);line-height:1.85;font-size:1.05rem}
.split .pts{margin-top:24px;display:grid;gap:13px}
.split .pts li{display:flex;gap:13px;align-items:flex-start;font-size:1.02rem}
.split .pts svg{width:23px;height:23px;flex:none;color:var(--brand2);margin-top:2px}
@media(max-width:800px){.split{grid-template-columns:1fr}.split .visual img{aspect-ratio:16/10}}

/* CARDS */
.cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:24px;margin-top:60px}
.card{background:var(--paper);border-radius:8px;overflow:hidden;border:1px solid var(--line);transition:transform .28s cubic-bezier(.2,.8,.2,1),box-shadow .3s}
.card:hover{transform:translateY(-7px);box-shadow:0 28px 56px rgba(23,18,16,.18)}
.card .ph{position:relative;aspect-ratio:16/10;overflow:hidden}
.card .ph img{width:100%;height:100%;object-fit:cover;transition:transform .6s cubic-bezier(.2,.8,.2,1)}
.card:hover .ph img{transform:scale(1.08)}
.card .num{position:absolute;top:13px;left:13px;font-family:'Spline Sans Mono',monospace;background:rgba(18,12,8,.55);backdrop-filter:blur(4px);color:#fff;font-size:.72rem;padding:5px 10px;border-radius:3px;letter-spacing:.06em}
.card .body{padding:26px 26px 30px}
.card h3{font-size:1.3rem}
.card p{margin-top:10px;color:var(--mut);font-size:1rem;line-height:1.6}
.card .go{margin-top:18px;display:inline-flex;gap:8px;align-items:center;font-family:'Bricolage Grotesque',sans-serif;color:var(--brand2);font-weight:700;font-size:.86rem}
.card:hover .go{gap:13px}

/* GALLERY */
.grid-gal{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-top:58px}
.grid-gal figure{position:relative;border-radius:6px;overflow:hidden;aspect-ratio:1;background:#000}
.grid-gal figure.tall{grid-row:span 2;aspect-ratio:auto}
.grid-gal figure.wide{grid-column:span 2;aspect-ratio:2}
.grid-gal img{width:100%;height:100%;object-fit:cover;transition:transform .6s}
.grid-gal figure:hover img{transform:scale(1.07)}
.grid-gal figcaption{position:absolute;left:13px;bottom:12px;font-family:'Spline Sans Mono',monospace;background:rgba(247,241,232,.94);color:var(--ink);font-size:.68rem;letter-spacing:.04em;padding:5px 10px;border-radius:3px}
@media(max-width:760px){.grid-gal{grid-template-columns:repeat(2,1fr)}.grid-gal figure.wide{grid-column:span 2}}

/* PROCESS */
.steps{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;margin-top:60px;background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.12);border-radius:8px;overflow:hidden}
.step{background:var(--ink);padding:32px 26px}
.step .n{font-family:'Fraunces',serif;font-style:italic;font-weight:500;font-size:2.6rem;color:var(--accent);line-height:1}
.step h4{margin-top:16px;font-size:1.18rem}
.step p{margin-top:9px;color:rgba(255,255,255,.7);font-size:.96rem;line-height:1.6}
@media(max-width:820px){.steps{grid-template-columns:repeat(2,1fr)}}

/* CTA */
.cta{position:relative;border-radius:10px;overflow:hidden;color:#fff}
.cta img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.cta .scrim{position:absolute;inset:0;background:linear-gradient(100deg,rgba(110,29,22,.94),rgba(18,12,8,.55))}
.cta .inner{position:relative;z-index:2;padding:clamp(48px,6vw,84px)}
.cta h2{font-size:clamp(2.1rem,4.6vw,3.5rem);max-width:17ch}
.cta p{margin:18px 0 30px;max-width:48ch;color:#f6e6d8;line-height:1.7;font-size:1.08rem}

/* ARTICLE / PROSE */
.prose{max-width:760px}
.prose .lead{font-size:1.2rem;line-height:1.7;color:var(--ink);margin-bottom:18px}
.prose h2{font-size:1.7rem;margin:32px 0 12px}
.prose p{color:#3c352d;line-height:1.85;margin-bottom:16px;font-size:1.06rem}
.checks{margin:6px 0 20px;display:grid;gap:2px}
.checks li{display:flex;gap:12px;align-items:flex-start;padding:11px 0;border-bottom:1px solid var(--line);color:#3c352d}
.checks svg{width:21px;height:21px;flex:none;color:var(--brand2);margin-top:2px}

/* FAQ */
.faq-item{border-bottom:1px solid var(--line);padding:4px 0}
.faq-item summary{cursor:pointer;font-family:'Bricolage Grotesque',sans-serif;font-weight:700;font-size:1.08rem;padding:18px 0;list-style:none}
.faq-item summary::-webkit-details-marker{display:none}
.faq-item summary::after{content:"+";float:right;color:var(--brand2);font-weight:700}
.faq-item[open] summary::after{content:"–"}
.faq-answer{padding:0 0 18px;color:var(--mut);line-height:1.7}

/* breadcrumbs */
.crumbs{font-family:'Spline Sans Mono',monospace;font-size:.72rem;letter-spacing:.06em;color:var(--mut);padding:18px 0 0}
.crumbs a:hover{color:var(--brand2)}

/* FOOTER */
footer{background:var(--ink);color:#b3a591;padding:clamp(58px,7vw,88px) 0 0}
footer .cols{display:grid;grid-template-columns:1.7fr 1fr 1.2fr;gap:40px}
footer .brand{color:#fff;font-size:1.22rem;margin-bottom:16px}
footer .brand .mk{background:radial-gradient(circle at 35% 30%,var(--accent),var(--brand2))}
footer p{font-size:1rem;line-height:1.75}
footer h5{font-family:'Spline Sans Mono',monospace;color:#fff;font-size:.72rem;letter-spacing:.14em;text-transform:uppercase;margin-bottom:16px;font-weight:600}
footer li{margin-bottom:11px}
footer a:hover{color:#fff}
.tbd{font-style:italic;color:var(--gold)}
footer .legal{font-family:'Spline Sans Mono',monospace;border-top:1px solid #2c2620;margin-top:50px;padding:24px 0;font-size:.74rem;color:#7a6f60;text-align:center;letter-spacing:.04em}
@media(max-width:760px){footer .cols{grid-template-columns:1fr 1fr}}
