/* ================================================================
   Sasquatch Appliance Repair — design system
   Self-hosted fonts; extracted from docs/design-reference/style-tile.html
   ================================================================ */

/* ---- self-hosted fonts ---- */
@font-face{font-family:"Alfa Slab One";src:url("/static/fonts/AlfaSlabOne-Regular.ttf");font-weight:400;font-display:swap}
@font-face{font-family:"Oswald";src:url("/static/fonts/Oswald[wght].ttf");font-weight:200 700;font-display:swap}
@font-face{font-family:"Source Sans 3";src:url("/static/fonts/SourceSans3[wght].ttf");font-weight:200 900;font-display:swap}
@font-face{font-family:"Press Start 2P";src:url("/static/fonts/PressStart2P-Regular.ttf");font-weight:400;font-display:swap}

/* ---- design tokens ---- */
:root{
  --forest:#22402E;        /* primary dark forest green */
  --forest-deep:#16291D;   /* near-black green */
  --pine:#2F5740;          /* lighter forest for panels */
  --gold:#C99A3B;          /* muted gold */
  --gold-soft:#E0C079;
  --char:#15140F;          /* charcoal black */
  --brown:#6E4A2C;         /* weathered brown */
  --cream:#F1E6CF;         /* warm cream (bg) */
  --cream-2:#E7D7B6;       /* deeper cream panel */
  --red:#9E3322;           /* deep muted red accent */
  --red-bright:#B8412D;
  --ink:#211C12;           /* body text on cream */
  --pixgreen:#7FE0A3;      /* CRT pixel green */
  --pixgreen-dim:#3f8a5e;
  --pixbg:#0c241a;
  --shadow:0 14px 34px -16px rgba(21,20,15,.55);
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:"Source Sans 3",system-ui,sans-serif;
  color:var(--ink);
  background-color:var(--cream);
  /* paper grain + subtle topo wash */
  background-image:
    radial-gradient(circle at 18% -10%, rgba(201,154,59,.16), transparent 45%),
    radial-gradient(circle at 100% 0%, rgba(34,64,46,.12), transparent 40%),
    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='.9' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='.045'/%3E%3C/svg%3E");
  line-height:1.55;
}
.wrap{max-width:1120px;margin:0 auto;padding:0 22px}

/* ---- top call bar ---- */
.callbar{background:var(--char);color:var(--cream);font-family:"Oswald",sans-serif;
  letter-spacing:.04em;font-size:.92rem}
.callbar .wrap{display:flex;gap:18px;align-items:center;justify-content:space-between;
  padding-top:8px;padding-bottom:8px;flex-wrap:wrap}
.callbar a{color:var(--gold-soft);text-decoration:none;font-weight:700}
.callbar .phone{font-size:1.15rem;color:#fff}
.tag-pix{font-family:"Press Start 2P",monospace;font-size:.55rem;color:var(--pixgreen)}

/* ---- nav ---- */
nav{background:var(--forest);border-bottom:3px solid var(--gold)}
nav .wrap{display:flex;align-items:center;gap:26px;padding:14px 22px;flex-wrap:wrap}
.brand{display:flex;align-items:center;gap:12px;margin-right:auto}
.brand img{height:54px;width:auto;filter:drop-shadow(0 3px 6px rgba(0,0,0,.5))}
.brand b{font-family:"Alfa Slab One",serif;color:var(--cream);font-size:1.05rem;
  line-height:1;letter-spacing:.01em}
.brand span{display:block;font-family:"Oswald";color:var(--gold-soft);font-size:.62rem;
  letter-spacing:.32em;text-transform:uppercase;margin-top:4px}
nav a.link{color:var(--cream);text-decoration:none;font-family:"Oswald";font-weight:600;
  font-size:.95rem;letter-spacing:.03em;opacity:.86}
nav a.link:hover{opacity:1;color:var(--gold-soft)}
nav .links{display:flex;align-items:center;gap:22px}
/* mobile show/hide handled by the .links wrapper + .navtoggle (see below) */

/* ---- hero ---- */
.hero{position:relative;color:var(--cream);overflow:hidden;
  background:
    linear-gradient(180deg, rgba(11,18,13,.55), rgba(11,18,13,.86)),
    radial-gradient(circle at 75% 30%, var(--pine), var(--forest-deep) 70%);
  border-bottom:5px solid var(--char)}
.hero .wrap{display:grid;grid-template-columns:1.2fr .8fr;gap:34px;align-items:center;
  padding:64px 22px 70px}
@media(max-width:820px){.hero .wrap{grid-template-columns:1fr;text-align:left}}
.eyebrow{font-family:"Oswald";text-transform:uppercase;letter-spacing:.28em;
  font-size:.8rem;color:var(--gold-soft);margin-bottom:14px}
.hero h1{font-family:"Alfa Slab One",serif;font-size:clamp(2.5rem,6vw,4.4rem);
  line-height:.98;margin:0 0 8px;text-shadow:0 4px 0 rgba(0,0,0,.35)}
.hero h1 .dys{color:var(--red-bright);display:inline-block;
  text-shadow:0 4px 0 rgba(0,0,0,.45)}
.hero p.sub{font-size:1.18rem;max-width:30ch;color:#efe3c7;margin:18px 0 28px}
.ctas{display:flex;gap:14px;flex-wrap:wrap}
.btn{font-family:"Oswald";font-weight:700;letter-spacing:.04em;text-transform:uppercase;
  text-decoration:none;padding:15px 24px;border-radius:7px;font-size:1rem;
  display:inline-flex;align-items:center;gap:9px;transition:transform .12s ease, box-shadow .12s ease}
.btn:hover{transform:translateY(-2px)}
.btn-gold{background:var(--gold);color:var(--char);box-shadow:0 6px 0 #9a7426}
.btn-gold:hover{box-shadow:0 8px 0 #9a7426}
.btn-red{background:var(--red);color:var(--cream);box-shadow:0 6px 0 #6f2317}
.btn-red:hover{box-shadow:0 8px 0 #6f2317}
.btn-ghost{border:2px solid var(--gold-soft);color:var(--gold-soft)}
.btn-ghost:hover{background:var(--gold-soft);color:var(--char)}
.hero-art{justify-self:center}
.hero-art img{width:min(300px,72vw);border-radius:14px;border:4px solid var(--char);
  box-shadow:var(--shadow);transform:rotate(2deg)}
/* warning-tape ribbon */
.ribbon{position:absolute;top:22px;right:-54px;transform:rotate(38deg);
  background:repeating-linear-gradient(45deg,var(--char) 0 14px,var(--gold) 14px 28px);
  color:#000;font-family:"Oswald";font-weight:700;font-size:.7rem;letter-spacing:.12em;
  padding:7px 70px;text-transform:uppercase;box-shadow:0 4px 10px rgba(0,0,0,.4)}
.ribbon span{background:var(--char);color:var(--gold-soft);padding:2px 8px;border-radius:3px}

/* ---- trust bar ---- */
.trust{background:var(--cream-2);border-bottom:2px solid rgba(110,74,44,.3)}
.trust .wrap{display:flex;gap:30px;justify-content:center;flex-wrap:wrap;
  padding:16px 22px;font-family:"Oswald";font-weight:600;letter-spacing:.05em;
  text-transform:uppercase;font-size:.92rem;color:var(--brown)}
.trust b{color:var(--forest)}

/* ---- section frame ---- */
section.block{padding:58px 0}
.kicker{font-family:"Oswald";text-transform:uppercase;letter-spacing:.26em;
  color:var(--red);font-size:.82rem;font-weight:700}
h2.sec{font-family:"Alfa Slab One",serif;font-size:clamp(1.8rem,4vw,2.8rem);
  margin:.25em 0 .15em;color:var(--forest-deep);line-height:1.02}
.lead{color:#4a4334;max-width:60ch;margin-bottom:30px}

/* ---- plan cards ---- */
.plans{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
@media(max-width:820px){.plans{grid-template-columns:1fr}}
.plan{background:#fff;border:2px solid rgba(21,20,15,.12);border-radius:14px;
  padding:26px 22px;position:relative;box-shadow:var(--shadow)}
.plan.pop{border-color:var(--gold);box-shadow:0 18px 40px -16px rgba(158,51,34,.45);
  transform:translateY(-8px)}
.plan .badge{position:absolute;top:-13px;left:50%;transform:translateX(-50%);
  background:var(--red);color:var(--cream);font-family:"Oswald";font-weight:700;
  font-size:.7rem;letter-spacing:.14em;text-transform:uppercase;padding:5px 14px;border-radius:20px}
.plan h3{font-family:"Alfa Slab One",serif;color:var(--forest);font-size:1.25rem;margin:.2em 0 .1em}
.plan .for{font-family:"Press Start 2P";font-size:.5rem;color:var(--pixgreen-dim);letter-spacing:.05em}
.plan .price{font-family:"Alfa Slab One",serif;font-size:2.6rem;color:var(--red);margin:14px 0 4px}
.plan ul{list-style:none;padding:0;margin:14px 0 22px;font-size:.97rem}
.plan li{padding:7px 0 7px 26px;position:relative;border-bottom:1px dashed rgba(110,74,44,.25)}
.plan li::before{content:"✓";position:absolute;left:0;color:var(--forest);font-weight:700}
.plan .btn{width:100%;justify-content:center}
.plan .price .per{font-size:.5em;opacity:.7}
.plan .sub-note{font-size:.8rem;opacity:.8;margin:-.25rem 0 .5rem}
.plan .addon{font-size:.85rem;font-weight:600;margin:.25rem 0 .5rem}
.plan .quip{font-style:italic;opacity:.85;font-size:.9rem;margin:.5rem 0 1rem;line-height:1.35}

/* ---- oregon trail pixel panel ---- */
.trail{background:var(--pixbg);color:var(--pixgreen);border-top:4px solid var(--pixgreen-dim);
  border-bottom:4px solid var(--pixgreen-dim);
  background-image:linear-gradient(rgba(127,224,163,.04) 1px,transparent 1px);
  background-size:100% 3px}
.trail .wrap{padding:54px 22px;text-align:center}
.trail .crt{font-family:"Press Start 2P";line-height:1.7}
.trail .crt .big{font-size:clamp(1rem,3.4vw,1.7rem);display:block;margin-bottom:18px;
  text-shadow:0 0 12px rgba(127,224,163,.5)}
.trail .crt .dead{color:#e8e2cf;background:#000;border:2px solid var(--pixgreen-dim);
  display:inline-block;padding:10px 16px;font-size:.7rem;margin:8px 0 20px}
.trail p.tr-sub{font-family:"Source Sans 3";color:#bfe9cf;max-width:52ch;margin:0 auto 26px;
  font-size:1.05rem}
.btn-pix{font-family:"Press Start 2P";font-size:.7rem;background:var(--pixgreen);color:#06150d;
  text-decoration:none;padding:16px 22px;border-radius:4px;display:inline-block;
  box-shadow:0 6px 0 #2f6b48}

/* ---- style guide strip ---- */
.guide{background:var(--forest-deep);color:var(--cream)}
.guide .wrap{padding:46px 22px}
.guide h2{font-family:"Alfa Slab One";color:var(--gold-soft);font-size:1.4rem;margin:0 0 22px}
.swatches{display:flex;gap:12px;flex-wrap:wrap;margin-bottom:30px}
.sw{width:96px;border-radius:9px;overflow:hidden;border:1px solid rgba(255,255,255,.12);font-size:.7rem}
.sw .chip{height:58px}
.sw .lbl{padding:6px 8px;background:rgba(0,0,0,.25);font-family:"Oswald";letter-spacing:.04em}
.sw .hex{padding:2px 8px 8px;opacity:.6;font-family:monospace}
.typed{display:grid;grid-template-columns:1fr 1fr;gap:26px}
@media(max-width:760px){.typed{grid-template-columns:1fr}}
.typed .card{background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.1);
  border-radius:12px;padding:20px}
.typed .role{font-family:"Oswald";text-transform:uppercase;letter-spacing:.2em;
  font-size:.72rem;color:var(--gold-soft);margin-bottom:10px}
.sample-display{font-family:"Alfa Slab One";font-size:2rem;line-height:1}
.sample-cond{font-family:"Oswald";font-weight:700;font-size:1.5rem;text-transform:uppercase;letter-spacing:.03em}
.sample-body{font-family:"Source Sans 3";font-size:1.02rem;color:#e3d8bf}
.sample-pix{font-family:"Press Start 2P";font-size:.8rem;color:var(--pixgreen)}

/* ---- footer ---- */
footer{background:var(--char);color:var(--cream);text-align:center;padding:30px 22px;font-family:"Oswald";letter-spacing:.04em}
footer .ph{color:var(--gold-soft);font-size:1.3rem;font-weight:700}
.note{background:var(--gold);color:var(--char);text-align:center;font-family:"Oswald";
  font-weight:600;padding:10px;letter-spacing:.05em;font-size:.85rem}

/* ---- sticky mobile call button ---- */
.callfab{position:fixed;right:16px;bottom:16px;z-index:60;background:var(--red);color:var(--cream);
  font-family:"Oswald";font-weight:700;border-radius:50px;padding:14px 20px;text-decoration:none;
  box-shadow:0 8px 20px -6px rgba(0,0,0,.6);display:none}
@media(max-width:780px){.callfab{display:inline-flex;gap:8px;align-items:center}}

/* ---- mobile nav toggle ---- */
.navtoggle{display:none;background:none;border:2px solid var(--gold-soft);color:var(--gold-soft);
  border-radius:6px;padding:6px 10px;font-size:1.2rem;cursor:pointer}
@media(max-width:780px){.navtoggle{display:inline-block}
  nav .links{display:none;flex-basis:100%;flex-direction:column;gap:10px;padding-top:10px}
  nav .links.open{display:flex}}

/* ---- hidden-attribute fix ---- */
[hidden]{display:none!important}

/* ---- fineprint ---- */
.fineprint{font-family:"Source Sans 3";font-size:.8rem;color:var(--brown);
  margin-top:18px;max-width:60ch;text-align:center;margin-left:auto;margin-right:auto}

/* ---- cta-band ---- */
.cta-band{background:var(--forest);color:var(--cream);padding:60px 22px;text-align:center}
.cta-band h2{font-family:"Alfa Slab One";color:var(--gold-soft);font-size:2rem;margin:0 0 14px}
.cta-band .lead{font-family:"Source Sans 3";font-size:1.15rem;margin:0 0 28px;opacity:.9}
.cta-band .btn+.btn{margin-left:12px}
@media(max-width:600px){.cta-band .btn+.btn{margin-left:0;margin-top:12px}
  .cta-band{display:flex;flex-direction:column;align-items:center}}

/* ---- review card ---- */
.review-card{background:var(--cream-2);border:1px solid rgba(110,74,44,.18);
  border-radius:12px;padding:24px 26px;font-family:"Source Sans 3"}
.review-card h3{font-family:"Oswald";font-size:1.1rem;font-weight:600;
  color:var(--forest);margin:8px 0 10px;text-transform:uppercase;letter-spacing:.04em}
.review-body{color:var(--ink);line-height:1.65;margin-bottom:12px}
.stars{color:var(--gold);font-size:1.2rem;letter-spacing:.05em}
.byline{font-family:"Oswald";font-size:.82rem;color:var(--brown);
  letter-spacing:.06em;text-transform:uppercase}

/* ---- contact feedback ---- */
.form-success{background:#d4edda;border:1px solid #b1dfbb;border-radius:10px;
  padding:22px 26px;font-family:"Source Sans 3";color:#1a5c29}
.form-success h3{font-family:"Oswald";font-size:1.1rem;font-weight:700;margin:0 0 8px}
.form-success a{color:var(--forest);font-weight:700}
.form-error{background:#f8d7da;border:1px solid #f1b0b7;border-radius:10px;
  padding:22px 26px;font-family:"Source Sans 3";color:#6b1522}
.form-error a{color:var(--red-bright);font-weight:700}
/* plan-card styles live in the style-tile-ported block above (search ".plans") */
.centered{text-align:center}

/* ---- services grid ---- */
.services-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:20px;margin-top:28px}
.service-card{background:#fff;border:2px solid rgba(21,20,15,.1);border-radius:12px;
  padding:24px 20px;text-decoration:none;color:var(--ink);transition:box-shadow .14s ease,transform .14s ease;
  display:flex;flex-direction:column;gap:8px;box-shadow:var(--shadow)}
.service-card:hover{transform:translateY(-3px);box-shadow:0 20px 40px -16px rgba(21,20,15,.22)}
.service-card .svc-emoji{font-size:2.2rem}
.service-card h3{font-family:"Oswald";font-weight:700;font-size:1.05rem;text-transform:uppercase;
  letter-spacing:.04em;color:var(--forest);margin:0}
.service-card p{font-size:.94rem;color:#5a5040;margin:0;line-height:1.5}

/* ---- services hub: larger cards with learn-more label ---- */
.services-hub-grid{grid-template-columns:repeat(auto-fill,minmax(240px,1fr))}
.service-hub-card{gap:10px}
.service-hub-card .svc-emoji{font-size:2.6rem}
.service-hub-card h3{font-size:1.15rem}
.svc-learn{font-family:"Oswald";font-size:.88rem;font-weight:700;text-transform:uppercase;
  letter-spacing:.05em;color:var(--gold);margin-top:auto;padding-top:4px}
.service-card-plans{border-color:rgba(110,74,44,.25);background:var(--cream-2)}
.service-card-plans h3{color:var(--brown)}
.service-card-plans .svc-learn{color:var(--brown)}

/* ---- service detail: prose (markdown content) ---- */
.prose{max-width:70ch}
.prose h2{font-family:"Alfa Slab One";color:var(--forest);font-size:1.5rem;margin:28px 0 12px}
.prose h3{font-family:"Oswald";font-weight:700;text-transform:uppercase;color:var(--brown);
  font-size:1.05rem;letter-spacing:.04em;margin:22px 0 8px}
.prose p{font-size:1.02rem;color:#4a4334;margin:0 0 16px;line-height:1.65}
.prose ul,.prose ol{margin:0 0 16px;padding-left:24px}
.prose li{font-size:1rem;color:#4a4334;margin-bottom:6px;line-height:1.6}

/* ---- service detail: FAQ ---- */
.faq-list{margin-top:28px;display:flex;flex-direction:column;gap:0}
.faq-item{padding:22px 0;border-bottom:1px dashed rgba(110,74,44,.22)}
.faq-item:last-child{border-bottom:none}
.faq-q{font-family:"Alfa Slab One";color:var(--forest);font-size:1.1rem;margin:0 0 10px}
.faq-a{font-size:1rem;color:#4a4334;margin:0;line-height:1.65}

/* ---- choose-your-path (plan ahead vs take your chances) ---- */
.path-section{background:var(--cream-2);border-top:2px solid rgba(110,74,44,.2);
  border-bottom:2px solid rgba(110,74,44,.2)}
.path-cols{display:grid;grid-template-columns:1fr 1fr;gap:0;margin-top:30px;
  border:2px solid rgba(110,74,44,.2);border-radius:12px;overflow:hidden}
@media(max-width:640px){.path-cols{grid-template-columns:1fr}}
.path-col{padding:28px 26px}
.path-col.good{background:var(--forest);color:var(--cream)}
.path-col.bad{background:#fff;color:var(--ink)}
.path-col .path-head{font-family:"Alfa Slab One";font-size:1.3rem;margin:0 0 14px}
.path-col.good .path-head{color:var(--gold-soft)}
.path-col.bad .path-head{color:var(--red)}
.path-col ul{list-style:none;padding:0;margin:0;font-size:.96rem}
.path-col li{padding:6px 0 6px 24px;position:relative;border-bottom:1px dashed rgba(110,74,44,.15)}
.path-col li:last-child{border-bottom:none}
.path-col.good li::before{content:"✓";position:absolute;left:0;color:var(--gold-soft);font-weight:700}
.path-col.bad li::before{content:"✗";position:absolute;left:0;color:var(--red);font-weight:700}

/* ---- meet-chad teaser ---- */
.chad-teaser{display:grid;grid-template-columns:auto 1fr;gap:30px;align-items:center;margin-top:24px}
@media(max-width:640px){.chad-teaser{grid-template-columns:1fr;text-align:center}}
.chad-teaser img{width:min(180px,40vw);border-radius:12px;border:4px solid var(--gold);
  box-shadow:var(--shadow)}
.chad-teaser p{font-size:1.05rem;color:#4a4334;margin:0 0 18px}

/* ---- reviews strip ---- */
.reviews-strip{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:20px;margin-top:28px}

/* ---- service-area line ---- */
.service-area{font-family:"Oswald";font-size:.92rem;color:var(--brown);letter-spacing:.05em;
  text-align:center;padding:16px 0;border-top:1px dashed rgba(110,74,44,.25)}

/* ---- the-trail: vertical stage list ---- */
.trail-stages{list-style:none;padding:0;margin:32px 0 0;display:flex;flex-direction:column;gap:0}
.trail-stage{display:flex;align-items:flex-start;gap:20px;padding:22px 0;
  border-bottom:1px dashed rgba(110,74,44,.22)}
.trail-stage:last-child{border-bottom:none}
.trail-stage-num{font-family:"Press Start 2P";font-size:1.1rem;color:var(--pixgreen);
  background:var(--pixbg);border:2px solid var(--pixgreen-dim);border-radius:6px;
  padding:10px 14px;min-width:48px;text-align:center;flex-shrink:0;
  text-shadow:0 0 8px rgba(127,224,163,.45)}
.trail-stage-name{font-family:"Alfa Slab One";color:var(--forest);font-size:1.15rem;margin:0 0 6px}
.trail-stage-blurb{font-size:1rem;color:#4a4334;margin:0}

/* ---- benefits row (trail, plans, how-it-works) ---- */
.trail-benefits-section{background:var(--cream-2)}
.benefits-row{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));
  gap:22px;margin-top:28px}
.benefit-item{background:#fff;border:1px solid rgba(110,74,44,.15);border-radius:12px;
  padding:22px 18px;text-align:center;box-shadow:var(--shadow)}
.benefit-icon{font-size:2rem;margin-bottom:10px}
.benefit-label{font-family:"Oswald";font-weight:700;text-transform:uppercase;
  letter-spacing:.06em;color:var(--forest);font-size:.95rem;margin-bottom:8px}
.benefit-desc{font-size:.9rem;color:#4a4334;margin:0;line-height:1.5}

/* ---- plans: checklist + how-list ---- */
.checklist{list-style:none;padding:0;margin:20px 0 0;display:grid;
  grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:8px 20px}
.checklist li{padding:8px 0 8px 28px;position:relative;
  border-bottom:1px dashed rgba(110,74,44,.18);font-size:.98rem}
.checklist li::before{content:"✓";position:absolute;left:0;color:var(--forest);font-weight:700;font-size:1rem}
.how-list{list-style:none;padding:0;margin:24px 0 0;counter-reset:how}
.how-list li{padding:14px 0 14px 52px;position:relative;
  border-bottom:1px dashed rgba(110,74,44,.18);font-size:1rem;color:var(--ink)}
.how-list li::before{counter-increment:how;content:counter(how);
  position:absolute;left:0;top:10px;
  font-family:"Press Start 2P";font-size:.65rem;color:var(--pixgreen);
  background:var(--pixbg);border:2px solid var(--pixgreen-dim);border-radius:4px;
  width:36px;height:36px;display:flex;align-items:center;justify-content:center}

/* ---- how-it-works: steps grid ---- */
.steps-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));
  gap:22px;margin-top:30px}
.step-card{background:#fff;border:2px solid rgba(21,20,15,.1);border-radius:12px;
  padding:26px 22px;box-shadow:var(--shadow)}
.step-num{font-family:"Press Start 2P";font-size:.6rem;color:var(--pixgreen);
  background:var(--pixbg);border:2px solid var(--pixgreen-dim);border-radius:4px;
  display:inline-block;padding:6px 10px;margin-bottom:12px;
  text-shadow:0 0 8px rgba(127,224,163,.4)}
.step-title{font-family:"Alfa Slab One";color:var(--forest);font-size:1.15rem;margin:0 0 8px}
.step-desc{font-size:.97rem;color:#4a4334;margin:0;line-height:1.55}

/* ---- about: grid + values + flat squatch ---- */
.about-grid{display:grid;grid-template-columns:1fr auto;gap:36px;align-items:start;margin-top:24px}
@media(max-width:720px){.about-grid{grid-template-columns:1fr}}
.about-text p{font-size:1.05rem;color:#4a4334;margin:0 0 18px;line-height:1.65}
.about-photo img{width:min(220px,40vw);border-radius:12px;border:4px solid var(--gold);
  box-shadow:var(--shadow)}
.about-values{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));
  gap:22px;margin-top:28px}
.value-item{background:#fff;border:1px solid rgba(110,74,44,.15);border-radius:12px;
  padding:24px 20px;box-shadow:var(--shadow)}
.value-icon{font-size:1.8rem;margin-bottom:10px}
.value-title{font-family:"Alfa Slab One";color:var(--forest);font-size:1.1rem;margin:0 0 10px}
.value-item p{font-size:.96rem;color:#4a4334;margin:0;line-height:1.55}
.flat-squatch-blurb{display:grid;grid-template-columns:auto 1fr;gap:32px;align-items:start;margin-top:24px}
@media(max-width:680px){.flat-squatch-blurb{grid-template-columns:1fr}}
.flat-squatch-art img{width:min(180px,38vw);border-radius:10px;border:3px solid var(--gold);
  box-shadow:var(--shadow)}
.flat-squatch-text p{font-size:1rem;color:#4a4334;margin:0 0 14px;line-height:1.6}

/* ---- trail-reports: reviews grid ---- */
.reviews-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:22px;margin-top:28px}

/* ---- empty state (reviews, blog) ---- */
.empty-state{background:var(--cream-2);border:2px dashed rgba(110,74,44,.25);border-radius:12px;
  padding:36px 30px;text-align:center;margin-top:28px}
.empty-state .lead{font-size:1.1rem;margin-bottom:12px}
.empty-state p{font-size:1rem;color:#5a5040;margin:0 0 20px}

/* ---- trail-journal: featured post ---- */
.featured-post{background:var(--forest);color:var(--cream);border-radius:14px;
  padding:34px 36px;margin-top:16px}
.featured-post .post-category{font-family:"Oswald";font-size:.82rem;font-weight:700;
  text-transform:uppercase;letter-spacing:.08em;color:var(--gold-soft)}
.featured-post .post-date{font-family:"Source Sans 3";font-size:.88rem;color:rgba(241,230,207,.7);
  margin-left:16px}
.featured-post-meta{margin-bottom:10px}
.featured-post h2 a{color:var(--gold-soft);text-decoration:none;font-family:"Alfa Slab One";
  font-size:1.8rem}
.featured-post h2 a:hover{text-decoration:underline}
.featured-post .lead{color:rgba(241,230,207,.9);margin:12px 0 16px}
.featured-post .post-tags{margin-bottom:20px}

/* ---- category chips ---- */
.block-slim{padding:14px 0}
.category-chips{display:flex;flex-wrap:wrap;gap:10px}
.chip{font-family:"Oswald";font-size:.82rem;font-weight:600;text-transform:uppercase;
  letter-spacing:.06em;background:var(--cream-2);border:1.5px solid rgba(110,74,44,.25);
  border-radius:100px;padding:5px 14px;color:var(--brown)}

/* ---- post list ---- */
.post-list{display:flex;flex-direction:column;gap:0;margin-top:24px}
.post-item{padding:28px 0;border-bottom:1px dashed rgba(110,74,44,.22)}
.post-item:last-child{border-bottom:none}
.post-item-meta{margin-bottom:8px}
.post-category{font-family:"Oswald";font-size:.8rem;font-weight:700;text-transform:uppercase;
  letter-spacing:.08em;color:var(--gold)}
.post-date{font-family:"Source Sans 3";font-size:.86rem;color:var(--brown);margin-left:14px}
.post-title{font-family:"Alfa Slab One";font-size:1.3rem;margin:0 0 8px}
.post-title a{color:var(--forest);text-decoration:none}
.post-title a:hover{text-decoration:underline;color:var(--brown)}
.post-excerpt{font-size:1rem;color:#4a4334;margin:0 0 12px;line-height:1.6;max-width:70ch}
.post-tags{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:10px}
.tag{font-family:"Oswald";font-size:.75rem;font-weight:600;text-transform:uppercase;
  letter-spacing:.06em;background:rgba(110,74,44,.12);border-radius:100px;
  padding:3px 10px;color:var(--brown)}
.post-link{font-family:"Oswald";font-size:.9rem;font-weight:700;color:var(--forest);
  text-decoration:none;text-transform:uppercase;letter-spacing:.05em}
.post-link:hover{color:var(--gold)}

/* ---- article page ---- */
.article-hero{background:var(--forest);color:var(--cream);padding:60px 22px 50px}
.article-hero .wrap{max-width:880px}
.article-header .post-category{color:var(--gold-soft)}
.article-header .post-date{color:rgba(241,230,207,.7);margin-left:14px}
.article-header h1{font-family:"Alfa Slab One";font-size:clamp(1.8rem,5vw,2.8rem);
  color:var(--cream);margin:12px 0}
.article-header .sub{font-size:1.1rem;color:rgba(241,230,207,.88);margin:0 0 16px;
  max-width:65ch;line-height:1.6}
.article-header .post-tags{margin-top:10px}
.article-header .tag{background:rgba(201,154,59,.22);color:var(--gold-soft)}
.article-col{max-width:72ch;margin:0 auto}
.flat-squatch-text strong{color:var(--forest)}

/* ---- contact / booking form ---- */
/* honeypot — visually hidden, not display:none so bots still see it */
.hp{position:absolute;left:-9999px;width:1px;height:1px;overflow:hidden}

/* form layout */
.contact-form-wrap{max-width:640px}
#booking{display:flex;flex-direction:column;gap:16px;margin-top:22px}
#booking label{display:flex;flex-direction:column;gap:5px;font-family:"Oswald";
  font-weight:600;font-size:.95rem;text-transform:uppercase;letter-spacing:.04em;color:var(--forest)}
#booking input,#booking select,#booking textarea{
  font-family:"Source Sans 3",system-ui,sans-serif;font-size:1rem;color:var(--ink);
  background:#fff;border:2px solid rgba(21,20,15,.18);border-radius:7px;
  padding:10px 14px;width:100%;transition:border-color .12s ease}
#booking input:focus,#booking select:focus,#booking textarea:focus{
  outline:none;border-color:var(--forest)}
#booking textarea{min-height:110px;resize:vertical}
.form-actions{display:flex;gap:14px;flex-wrap:wrap;margin-top:6px}

/* contact hero info block */
.contact-info-block{background:rgba(255,255,255,.08);border:2px solid rgba(201,154,59,.35);
  border-radius:14px;padding:26px 28px;font-family:"Source Sans 3";
  align-self:start;min-width:200px}
.contact-label{font-family:"Oswald";text-transform:uppercase;letter-spacing:.1em;
  font-size:.78rem;color:var(--gold-soft);margin:0 0 2px}
.contact-value{color:var(--cream);font-size:1.05rem;margin:0 0 16px}
.contact-value:last-child{margin-bottom:0}
.contact-value a{color:var(--gold-soft);text-decoration:none;font-weight:700}
.contact-value a:hover{text-decoration:underline}

/* Where is Sasquatch — live availability banner */
.squatch-where{background:var(--cream-2);border-top:3px solid var(--gold);
  border-bottom:3px solid var(--gold)}
.squatch-where .lead{max-width:none;margin-bottom:18px;font-size:1.1rem}
#plan-field[hidden]{display:none !important}

/* Flat Squatch — a printed flyer, pinned to the community board */
.flyer{position:relative;max-width:500px;margin:42px 0 8px;
  background:#F8F1DF;border:2px dashed rgba(110,74,44,.4);border-radius:4px;
  padding:24px 28px;box-shadow:var(--shadow);transform:rotate(-1.6deg);
  transition:transform .18s ease}
.flyer:hover{transform:rotate(0deg)}
.flyer-pin{position:absolute;top:-15px;left:50%;
  transform:translateX(-50%) rotate(9deg);font-size:1.85rem;line-height:1;
  filter:drop-shadow(0 3px 2px rgba(21,20,15,.3))}
.flyer-title{font-family:"Alfa Slab One",serif;font-size:1.2rem;color:var(--forest);
  margin:0 0 10px;letter-spacing:.01em}
.flyer-body{font-size:1rem;line-height:1.55;color:#4a4334;margin:0}
.flyer-body a{color:var(--brown);font-weight:700;text-decoration:none}
.flyer-body a:hover{text-decoration:underline}
@media(max-width:680px){.flyer,.flyer:hover{transform:none;max-width:none}}
@media(prefers-reduced-motion:reduce){.flyer,.flyer:hover{transform:none}}

/* Contact form — plan coverage hint above the appliance entry */
.form-hint{margin:0 0 4px;color:var(--brown);font-size:.92rem;font-weight:600}

/* Customer capture page (/c/{token}) */
.capture-session{max-width:560px;margin:0 auto;padding:18px}
.cap-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:14px}
.cap-item{border:1px solid #ddd6c4;border-radius:8px;padding:12px}
.cap-note{color:#6e6450;margin:6px 0}
.cap-status{color:#2f5740;font-weight:600;font-size:.85rem;margin-left:8px}
.cap-thumbs{display:flex;gap:8px;flex-wrap:wrap;margin-top:8px}
.cap-thumb{width:84px;height:84px;object-fit:cover;border-radius:6px}
.cap-submit{margin-top:18px;width:100%;padding:14px;font-size:1.05rem}
.cap-error{color:#9e3322;font-weight:600}
