/* ============================================================
   Edge Garage Doors — Blueprint pattern layer
   SCOPED: every selector lives under .bp so it cannot leak into
   the Fixora hero/reviews/header/footer. Tokens are declared on
   .bp (not :root) for the same reason. Remove the <link> to revert.
   Fonts (add once in <head>): Roboto Slab + Inter + Architects Daughter
   ============================================================ */
.bp{
  --espresso:#241C16; --navy:#1d2733; --paper:#f6efe2;
  --ink:#2b2218; --line:#efe6d4;
  --rust:#b5552e; --rust-line:#e0894f; --green:#5f7d3e; --green-dk:#9cbf73;
  --gold:#e8b84b;
  --body-paper:#43392c; --body-dark:#c3b69c;
  --grid-dark:rgba(160,180,210,.09); --grid-paper:rgba(43,34,24,.05);
}
.bp,.bp *{box-sizing:border-box}
.bp-sec{padding:clamp(42px,5vw,64px) 0;position:relative}
/* tighten Fixora section padding too — less empty space between sections */
.section{padding-top:clamp(42px,5vw,68px)!important;padding-bottom:clamp(42px,5vw,68px)!important}
.svc-hero{padding-top:0!important;padding-bottom:0!important}
.bp-wrap{max-width:1180px;margin:0 auto;padding:0 clamp(20px,5vw,60px)}
.bp-narrow{max-width:760px}

/* backgrounds + faint drafting grid */
.bp-paper{background-color:var(--paper);color:var(--ink)}
.bp-navy{background-color:var(--navy);color:var(--line)}
.bp-esp{background-color:var(--espresso);color:var(--line)}
.bp.gp{background-image:repeating-linear-gradient(0deg,var(--grid-paper) 0 1px,transparent 1px 29px),repeating-linear-gradient(90deg,var(--grid-paper) 0 1px,transparent 1px 29px)}
.bp.gd{background-image:repeating-linear-gradient(0deg,var(--grid-dark) 0 1px,transparent 1px 29px),repeating-linear-gradient(90deg,var(--grid-dark) 0 1px,transparent 1px 29px)}

/* type */
.bp .bp-h2{font-family:'Roboto Slab',serif;font-weight:800;letter-spacing:-1px;line-height:1.05;font-size:clamp(1.8rem,4vw,2.7rem);margin:14px 0 0}
.bp .bp-lead{font-family:'Inter',system-ui,sans-serif;font-weight:500;font-size:1.06rem;line-height:1.6;max-width:62ch;margin:14px 0 0}
.bp-paper .bp-lead{color:var(--body-paper)} .bp-navy .bp-lead,.bp-esp .bp-lead{color:var(--body-dark)}

/* eyebrows */
.bp .bp-eyebrow{font-family:'Roboto Slab',serif;font-weight:800;text-transform:uppercase;letter-spacing:.2em;font-size:.8rem;color:var(--rust);display:flex;align-items:center;gap:12px;margin:0}
.bp .bp-eyebrow::before{content:"";width:36px;height:3px;background:var(--rust)}
.bp-navy .bp-eyebrow,.bp-esp .bp-eyebrow{color:var(--rust-line)}
.bp-navy .bp-eyebrow::before,.bp-esp .bp-eyebrow::before{background:var(--rust-line)}
.bp .bp-hand{font-family:'Architects Daughter',cursive;-webkit-text-stroke:.45px var(--rust-line);color:var(--rust-line);text-transform:uppercase;letter-spacing:.08em;font-size:1.05rem}
.bp-paper .bp-hand{-webkit-text-stroke-color:var(--rust);color:var(--rust)}

/* buttons */
.bp .bp-btn{display:inline-flex;align-items:center;gap:8px;font-family:'Roboto Slab',serif;font-weight:700;text-decoration:none;border-radius:44px;padding:13px 28px;background:var(--rust);color:#fff;font-size:1rem;transition:background .15s,transform .15s}
.bp .bp-btn:hover{background:#9d4524;transform:translateY(-1px)}
.bp .bp-btn-sec{display:inline-flex;align-items:center;font-family:'Roboto Slab',serif;font-weight:700;text-decoration:none;color:inherit;border-bottom:2px solid var(--rust);padding:8px 0}
.bp-navy .bp-btn-sec,.bp-esp .bp-btn-sec{border-bottom-color:var(--rust-line)}
.bp .bp-cta-row{display:flex;flex-wrap:wrap;gap:16px 24px;align-items:center;margin-top:26px}
.bp :focus-visible{outline:3px solid var(--gold);outline-offset:3px}

/* P1 LEDGER — hairline rows, no boxes */
.bp-ledger{margin-top:32px;border-top:1px solid currentColor}
.bp-paper .bp-ledger{border-color:rgba(43,34,24,.18)}
.bp-navy .bp-ledger,.bp-esp .bp-ledger{border-color:rgba(239,230,212,.16)}
.bp-row{display:grid;grid-template-columns:auto 1fr;gap:18px;padding:22px 0;border-bottom:1px solid rgba(43,34,24,.14);align-items:start;transition:border-color .15s}
.bp-navy .bp-row,.bp-esp .bp-row{border-bottom-color:rgba(239,230,212,.16)}
.bp-row:hover{border-bottom-color:var(--rust)}
.bp-navy .bp-row:hover,.bp-esp .bp-row:hover{border-bottom-color:var(--rust-line)}
.bp-row .bp-idx{font-family:'Architects Daughter',cursive;-webkit-text-stroke:.45px var(--rust);color:var(--rust);font-size:1.4rem;line-height:1.1}
.bp-navy .bp-row .bp-idx,.bp-esp .bp-row .bp-idx{-webkit-text-stroke-color:var(--rust-line);color:var(--rust-line)}
.bp-row h3{font-family:'Roboto Slab',serif;font-weight:700;font-size:1.18rem;margin:0}
.bp-row p{font-family:'Inter',system-ui,sans-serif;font-weight:500;line-height:1.6;margin:7px 0 0}
.bp-paper .bp-row p{color:var(--body-paper)} .bp-navy .bp-row p,.bp-esp .bp-row p{color:var(--body-dark)}
@media(min-width:760px){.bp-ledger.bp-2col{display:grid;grid-template-columns:1fr 1fr;column-gap:48px}}

/* 2-column split: text/content left, aside (calculator or images) right */
.bp-split{display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(30px,5vw,58px);align-items:start}
.bp-split .bp-eyebrow,.bp-split .bp-h2,.bp-split .bp-lead{max-width:46ch}
@media(max-width:880px){.bp-split{grid-template-columns:1fr}}
.bp-figure{border:2px solid var(--bp-ink,#1E0F0C);border-radius:8px;overflow:hidden;box-shadow:6px 6px 0 rgba(30,15,12,.12);align-self:center}
.bp-figure img{display:block;width:100%;height:100%;object-fit:cover}
/* general garage-door-repair "home base" two-column with photo */
.hb-split{display:grid;grid-template-columns:1.1fr .9fr;gap:clamp(28px,4vw,52px);align-items:center}
.hb-split .section-head{text-align:left;margin:0 0 18px}
.hb-figure{border:2px solid #1E0F0C;border-radius:8px;overflow:hidden;box-shadow:6px 6px 0 rgba(30,15,12,.12)}
.hb-figure img{display:block;width:100%;height:100%;object-fit:cover}
@media(max-width:880px){.hb-split{grid-template-columns:1fr}}
/* pricing/cost section: centered text with the calculator centered below it */
.price-center{max-width:780px;margin:0 auto;text-align:center}
.price-center .pc-text{display:block}
.price-center .bp-eyebrow,.price-center .bp-h2,.price-center .bp-lead{max-width:none}
.price-center .bp-reasons{display:inline-block;text-align:left;margin-left:auto;margin-right:auto}
.price-center .bp-cta-row{justify-content:center}
.price-center .hearth-card{max-width:460px;margin:30px auto 0;text-align:left}
/* CTA "ready when you are" with the duplicate calculator removed -> centered solo */
.bp-cta-solo{max-width:700px;margin:0 auto;text-align:center}
.bp-cta-solo .bp-cta-row{justify-content:center}

/* before/after conversion diagram — clean blueprint look, centered text */
.diagram{display:grid;grid-template-columns:1fr 1fr;gap:clamp(20px,4vw,44px);align-items:stretch;margin-top:30px}
@media(max-width:680px){.diagram{grid-template-columns:1fr}}
.diagram .dg-label{display:flex;align-items:center;gap:9px;font-family:'Roboto Slab',serif;font-weight:800;text-transform:uppercase;letter-spacing:.08em;font-size:.8rem;color:#b5552e;margin-bottom:14px}
.diagram .dg-label .dot{width:9px;height:9px;border-radius:50%;background:#b5552e;display:inline-block}
.diagram .dg--after .dg-label{color:#5f7d3e}
.diagram .dg--after .dg-label .dot{background:#5f7d3e}
.diagram .dg-vis{display:flex;gap:8px;align-items:stretch;min-height:150px}
.diagram .dg-door,.diagram .dg-post,.diagram .dg-wide{display:grid;place-items:center;text-align:center;font-family:'Inter',system-ui,sans-serif;font-weight:600;font-size:.92rem;border-radius:8px;padding:14px 10px;line-height:1.3}
.diagram .dg-door{flex:1;border:2px solid #cdbf9f;color:#43392c;background:repeating-linear-gradient(0deg,rgba(43,34,24,.05) 0 1px,transparent 1px 15px)}
.diagram .dg-post{width:44px;border:2px solid #f2675c;color:#f2675c;font-weight:800;font-size:.74rem;background:repeating-linear-gradient(45deg,rgba(242,103,92,.16) 0 6px,transparent 6px 12px)}
.diagram .dg-wide{flex:1;border:2px solid #5f7d3e;color:#3f5a26;font-weight:700;background:repeating-linear-gradient(0deg,rgba(95,125,62,.07) 0 1px,transparent 1px 15px)}
.diagram .dg-cap{margin-top:14px;font-family:'Inter',system-ui,sans-serif;font-weight:500;color:#43392c;font-size:.95rem;line-height:1.55}

/* side-by-side figures (e.g. before / after) */
.bp-figs-2{display:grid;grid-template-columns:1fr 1fr;gap:20px;margin-top:28px}
@media(max-width:680px){.bp-figs-2{grid-template-columns:1fr}}

/* stacked example figures (e.g. torsion vs extension) */
.bp-figs{display:flex;flex-direction:column;gap:22px}
.bp-fig{margin:0}
.bp-fig img{width:100%;height:auto;aspect-ratio:16/10;object-fit:cover;border-radius:12px;border:1px solid rgba(239,230,212,.2);display:block}
.bp-paper .bp-fig img{border-color:rgba(43,34,24,.14)}
.bp-fig figcaption{margin-top:9px;font-family:'Architects Daughter',cursive;-webkit-text-stroke:.4px var(--rust-line);color:var(--rust-line);font-size:1.02rem;letter-spacing:.03em;display:flex;align-items:center;gap:9px}
.bp-fig figcaption::before{content:"";width:24px;height:2px;background:var(--rust-line)}
.bp-paper .bp-fig figcaption{-webkit-text-stroke-color:var(--rust);color:var(--rust)}
.bp-paper .bp-fig figcaption::before{background:var(--rust)}

/* ============================================================
   MEGA NAV — Services + Areas(→services) dropdowns + standalone
   Conversion / High-Lift / Financing. Desktop hover + mobile accordion.
   Absolute links so one nav works from any page depth.
   ============================================================ */
.header{position:relative}
.nav--mega{display:flex;align-items:center;gap:4px;margin-left:auto}
.nav--mega .nav-item{position:relative}
.nav--mega .nav-top{font-family:'Inter',system-ui,sans-serif;font-weight:600;font-size:.95rem;color:#241c16;background:none;border:0;cursor:pointer;padding:10px 12px;display:inline-flex;align-items:center;gap:6px;border-radius:7px}
.nav--mega .nav-top:hover{color:#b5552e}
.nav--mega .nav-link{font-family:'Inter',system-ui,sans-serif;font-weight:600;font-size:.95rem;color:#241c16;text-decoration:none;padding:10px 12px;border-radius:7px}
.nav--mega .nav-link:hover{color:#b5552e}
.nav--mega .nav-pill{font-family:'Roboto Slab',serif;font-weight:700;font-size:.88rem;text-decoration:none;color:#241c16;border:1.5px solid #e0b48a;border-radius:7px;padding:8px 13px;white-space:nowrap}
.nav--mega .nav-pill:hover{background:#b5552e;color:#fff;border-color:#b5552e}

.mega{position:absolute;top:100%;left:0;margin-top:0;min-width:320px;background:#fffdf7;border:1px solid #e7dcc4;border-radius:10px;box-shadow:0 24px 60px rgba(36,28,22,.22);padding:14px 14px 16px;opacity:0;visibility:hidden;transform:translateY(8px);transition:opacity .16s,transform .16s;z-index:300}
/* invisible hover-bridge so moving from the button into the panel doesn't close it */
.nav-item>.mega::before{content:"";position:absolute;left:0;right:0;top:-12px;height:12px}
.nav-item:hover>.mega,.nav-item:focus-within>.mega,.nav-item.open>.mega{opacity:1;visibility:visible;transform:none}
.mega-grid{display:grid;grid-template-columns:1fr 1fr;gap:1px 16px}
.mega-grid a{font-family:'Inter',system-ui,sans-serif;font-weight:500;font-size:.92rem;color:#2b2218;text-decoration:none;padding:8px 10px;border-radius:6px;white-space:nowrap}
.mega-grid a:hover{background:#f1e8d6;color:#b5552e}

.mega--areas{min-width:230px}
.mega-areas{display:flex;flex-direction:column;gap:1px}
.area-col{position:relative}
.area-link{display:flex;justify-content:space-between;align-items:center;gap:10px;font-family:'Inter',system-ui,sans-serif;font-weight:500;font-size:.92rem;color:#2b2218;text-decoration:none;padding:8px 10px;border-radius:6px}
.area-col:hover>.area-link,.area-col.open>.area-link{background:#f1e8d6;color:#b5552e}
.area-link::after{content:"›";color:#b5552e;font-weight:800}
.area-services{position:absolute;left:100%;top:-14px;min-width:240px;background:#fffdf7;border:1px solid #e7dcc4;border-radius:10px;box-shadow:0 24px 60px rgba(36,28,22,.22);padding:12px 12px 14px 18px;display:none;z-index:310}
.area-col:hover>.area-services,.area-col.open>.area-services{display:block}
.area-services .as-head{font-family:'Roboto Slab',serif;font-weight:800;font-size:.7rem;text-transform:uppercase;letter-spacing:.1em;color:#b5552e;padding:2px 9px 6px;display:block}
.area-services a{font-family:'Inter',system-ui,sans-serif;font-weight:500;font-size:.88rem;color:#2b2218;text-decoration:none;padding:6px 9px;border-radius:6px;display:block;white-space:nowrap}
.area-services a:hover{background:#f1e8d6;color:#b5552e}
.area-services .as-city{font-weight:700;color:#b5552e}

.nav--mega .nav-top,.nav--mega .nav-link,.nav--mega .nav-pill{white-space:nowrap}
.nav--mega .nav-top{gap:5px}
.nav-toggle{display:none;background:none;border:1.5px solid #241c16;border-radius:7px;padding:8px 12px;cursor:pointer;font-size:1.05rem;line-height:1;margin-left:auto}

@media(max-width:1024px){
  .nav-toggle{display:inline-flex}
  .nav--mega{display:none;position:absolute;left:0;right:0;top:100%;flex-direction:column;align-items:stretch;gap:0;background:#fffdf7;border-top:1px solid #e7dcc4;box-shadow:0 24px 50px rgba(36,28,22,.22);padding:6px 0;max-height:82vh;overflow:auto;margin-left:0}
  .nav--mega.nav--open{display:flex}
  .nav--mega .nav-item{position:static}
  .nav--mega .nav-top,.nav--mega .nav-link,.nav--mega .nav-pill{width:100%;text-align:left;border-radius:0;padding:14px 22px;border:0;border-bottom:1px solid #f0e7d6;justify-content:space-between}
  .mega{position:static;opacity:1;visibility:visible;transform:none;box-shadow:none;border:0;border-radius:0;background:#f6efe2;display:none;padding:2px 0 8px;min-width:0}
  .nav-item.open>.mega{display:block}
  .mega-grid{grid-template-columns:1fr;gap:0}
  .mega-grid a{padding:12px 34px}
  .area-services{position:static;display:none;box-shadow:none;border:0;border-radius:0;background:#efe6d4;padding:2px 0;min-width:0}
  .area-col.open>.area-services{display:block}
  .area-services a{padding:11px 46px}
  .area-services .as-head{padding:8px 46px 4px}
  .area-link{padding:12px 34px}
  .area-link::after{content:"+"}
  .area-col.open>.area-link::after{content:"–"}
}

/* keep the conversion demo's hand-drawn labels (Architects Daughter) — beats global font-unify */
.cvdemo .eyebrow-hand,.cvdemo .lrow .num span,.cvdemo .bp-tag,.cvdemo .bp-title,.cvdemo .tag-hand,.cvdemo .seqitem .num span,.cvdemo .map-tag,.cvdemo .map-north,.cvdemo .map-title,.cvdemo .seal-hero small,.cvdemo .seal-foot,.cvdemo .rev cite,.cvdemo .ticket-head,.cvdemo .ticket-call,.cvdemo .stamp,.cvdemo .foot .sig{font-family:'Architects Daughter',cursive !important}
.cvdemo svg text{font-family:'Architects Daughter',cursive !important}
.cvdemo .cv-ba{font-size:clamp(16px,2.1vw,26px);letter-spacing:.05em}
/* before / during / after real-photo row */
.cvdemo .cv-bda{display:grid;grid-template-columns:1fr 1fr 1fr;gap:clamp(12px,1.8vw,20px);margin-top:30px}
@media(max-width:760px){.cvdemo .cv-bda{grid-template-columns:1fr;max-width:460px;margin-left:auto;margin-right:auto}}
.cvdemo .cv-bda-item{position:relative;margin:0;border-radius:10px;overflow:hidden;border:1px solid rgba(239,230,212,.2)}
.cvdemo .cv-bda-item img{display:block;width:100%;height:100%;aspect-ratio:3/2;object-fit:cover}
.cvdemo .cv-bda-item::before{content:"";position:absolute;top:0;left:0;right:0;height:78px;background:linear-gradient(rgba(20,9,6,.6),transparent);z-index:1}
.cvdemo .cv-bda-label{position:absolute;top:12px;left:50%;transform:translateX(-50%);z-index:2;font-family:'Architects Daughter',cursive !important;-webkit-text-stroke:.5px currentColor;font-size:clamp(20px,2.6vw,32px);letter-spacing:.04em;text-shadow:0 2px 12px rgba(0,0,0,.7)}

/* ---- SCROLL REVEAL (matches the conversion-full demo) ---- */
@media (prefers-reduced-motion: no-preference){
  .bp-reveal{opacity:0;transform:translateY(22px);transition:opacity .7s ease, transform .7s cubic-bezier(.2,.7,.2,1)}
  .bp-reveal.bp-in{opacity:1;transform:none}
  .bp-ledger .bp-row.bp-reveal:nth-child(2),.bp-seq .bp-step.bp-reveal:nth-child(2),.bp-checklist .bp-check.bp-reveal:nth-child(2),.bynumbers-grid .bynum.bp-reveal:nth-child(2){transition-delay:.06s}
  .bp-ledger .bp-row.bp-reveal:nth-child(3),.bp-seq .bp-step.bp-reveal:nth-child(3),.bp-checklist .bp-check.bp-reveal:nth-child(3),.bynumbers-grid .bynum.bp-reveal:nth-child(3){transition-delay:.12s}
  .bp-ledger .bp-row.bp-reveal:nth-child(4),.bp-seq .bp-step.bp-reveal:nth-child(4),.bynumbers-grid .bynum.bp-reveal:nth-child(4){transition-delay:.18s}
  .bp-ledger .bp-row.bp-reveal:nth-child(5),.bp-seq .bp-step.bp-reveal:nth-child(5){transition-delay:.24s}
  .bp-ledger .bp-row.bp-reveal:nth-child(6),.bp-seq .bp-step.bp-reveal:nth-child(6){transition-delay:.3s}
}

/* ---- financing bar: keep it on ONE line ---- */
.finbar .container{flex-wrap:nowrap;white-space:nowrap}
@media(max-width:980px){.finbar .hide-sm{display:none}}
.finbar--mid{margin:0}
/* complete footer: 2-col areas + hours */
.footer-col--areas ul{columns:2;column-gap:26px}
.footer-col--areas li{break-inside:avoid}
.footer-hours{color:#c3b69c;font-size:.85rem;margin-top:12px;font-weight:600}

/* ---- SQUARER BUTTONS (slight roundness, mostly straight) site-wide ---- */
.bp .bp-btn{border-radius:7px}
.btn,.btn-orange,.btn-outline,.btn-ghost-dark,.btn-finance,.header .btn,.svc-hero-ctas .btn,.callbar{border-radius:7px}
.head-cta,.header-right .btn{border-radius:7px}

/* ---- BY-THE-NUMBERS: blueprint-themed stats with breathing room ---- */
.bynumbers-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;margin-top:34px}
@media(max-width:760px){.bynumbers-grid{grid-template-columns:1fr 1fr}}
.bynum{position:relative;padding:32px 28px 28px;border:1px solid rgba(239,230,212,.22);border-radius:8px;background:rgba(160,180,210,.06);background-image:repeating-linear-gradient(0deg,rgba(160,180,210,.05) 0 1px,transparent 1px 22px),repeating-linear-gradient(90deg,rgba(160,180,210,.05) 0 1px,transparent 1px 22px);text-align:left;overflow:hidden}
.bynum::before{content:"";position:absolute;left:28px;top:20px;width:24px;height:2px;background:#e0894f}
.bynum .n{font-family:'Roboto Slab',serif;font-weight:800;font-size:clamp(2rem,4vw,2.9rem);line-height:1;color:#e8b84b;margin-top:16px;letter-spacing:-1px}
.bynum .l{margin-top:12px;font-family:'Inter',system-ui,sans-serif;font-weight:600;color:#c3b69c;font-size:.86rem;text-transform:uppercase;letter-spacing:.06em}

/* tune-up: door-parts image tiles (in place of a calculator) */
.parts-grid{grid-template-columns:1fr 1fr;gap:12px;margin-top:0}
.parts-grid .svc-card{aspect-ratio:4/3}

/* LiftMaster opener tiers */
.lm-compare{font-family:'Inter',system-ui,sans-serif;font-weight:500;color:var(--body-paper);max-width:70ch;margin:10px 0 0}
.lm-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;margin-top:30px}
@media(max-width:900px){.lm-grid{grid-template-columns:1fr 1fr}}
@media(max-width:540px){.lm-grid{grid-template-columns:1fr}}
.lm-card{background:#fffdf7;border:1px solid #e7dcc4;border-radius:12px;padding:18px;display:flex;flex-direction:column}
.lm-img{background:#fff;border:1px solid #eee3cf;border-radius:8px;height:168px;display:grid;place-items:center;padding:10px;margin-bottom:14px;overflow:hidden}
.lm-img img{width:100%;height:100%;object-fit:contain;display:block}
.lm-card{align-self:stretch}
.lm-tier{font-family:'Roboto Slab',serif;font-weight:800;font-size:.7rem;text-transform:uppercase;letter-spacing:.1em;color:#b5552e}
.lm-tier.t-premium{color:#5f7d3e}.lm-tier.t-elite{color:#c79318}.lm-tier.t-jack{color:#1d2733}
.lm-card h3{font-family:'Roboto Slab',serif;font-weight:800;font-size:1.12rem;margin:4px 0 11px;color:#2b2218}
.lm-card ul{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:8px}
.lm-card li{font-family:'Inter',system-ui,sans-serif;font-weight:500;font-size:.88rem;line-height:1.45;color:#43392c;padding-left:19px;position:relative}
.lm-card li::before{content:"✓";position:absolute;left:0;color:#5f7d3e;font-weight:800}
.lm-note{font-family:'Inter',system-ui,sans-serif;font-weight:500;color:var(--body-paper);margin:22px 0 0;font-size:.98rem}
.lm-note b{font-family:'Roboto Slab',serif;font-weight:800;color:var(--ink)}

/* high-lift compare image beside "why high-lift" */
.hl-split{display:grid;grid-template-columns:1.15fr .85fr;gap:clamp(24px,4vw,48px);align-items:center}
@media(max-width:820px){.hl-split{grid-template-columns:1fr}}
.hl-compare-img{border-radius:12px;border:1px solid rgba(239,230,212,.2);width:100%;height:auto;display:block}

/* city-service sibling image cards */
.svc-card-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:16px;margin-top:28px}
.svc-card{position:relative;display:block;border-radius:10px;overflow:hidden;border:1px solid rgba(239,230,212,.18);aspect-ratio:8/5;text-decoration:none}
.svc-card img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.svc-card::after{content:"";position:absolute;inset:0;background:linear-gradient(rgba(20,9,6,.12),rgba(20,9,6,.8))}
.svc-card:hover::after{background:linear-gradient(rgba(181,85,46,.22),rgba(20,9,6,.82))}
.svc-card-label{position:absolute;left:14px;right:14px;bottom:13px;z-index:2;font-family:'Roboto Slab',serif;font-weight:800;color:#fff;font-size:1rem;line-height:1.2;text-shadow:0 2px 8px rgba(0,0,0,.65)}
.svc-card--all{display:grid;place-items:center;background:rgba(160,180,210,.06)}
.svc-card--all::after{display:none}
.svc-card--all .svc-card-label{position:static;text-align:center;color:#e0894f}

/* 3 short trust reasons under pricing */
.bp-reasons{list-style:none;margin:18px 0 4px;padding:0;display:flex;flex-direction:column;gap:9px}
.bp-reasons li{font-family:'Inter',system-ui,sans-serif;font-weight:500;font-size:.98rem;line-height:1.5;padding-left:24px;position:relative}
.bp-paper .bp-reasons li{color:var(--body-paper)}
.bp-reasons li::before{content:"";position:absolute;left:0;top:.5em;width:9px;height:9px;border:2px solid var(--rust);border-radius:50%}
.bp-reasons li b{font-family:'Roboto Slab',serif;font-weight:800;color:var(--ink)}

/* ---- TYPOGRAPHY UNIFICATION: blueprint fonts on all content except the hero ---- */
main section:not(.svc-hero):not(.hero) :is(h1,h2,h3,h4,h5){font-family:'Roboto Slab',serif}
main section:not(.svc-hero):not(.hero) :is(p,li,a,span,small,strong,b,em,blockquote,cite,summary,label,button,input,select,textarea,figcaption,address,td,th,div){font-family:'Inter',system-ui,sans-serif}

/* ---- SECTION SEPARATION: hairline + a distinct paper tone vs Fixora cream ---- */
.bp-sec{border-top:1px solid rgba(43,34,24,.08)}
.bp-navy,.bp-esp{border-top-color:rgba(239,230,212,.09)}
.bp-paper{background-color:#f1e8d6}

/* P3 CHECKLIST — green hand-checks */
.bp-checklist{display:flex;flex-direction:column;gap:18px;margin-top:30px}
.bp-check{display:grid;grid-template-columns:auto 1fr;gap:16px;align-items:start}
.bp-check .bp-mk{width:34px;height:34px;flex:none;border-radius:50%;display:grid;place-items:center;font-family:'Roboto Slab',serif;font-weight:800;border:2px solid var(--green);color:var(--green)}
.bp-navy .bp-check .bp-mk,.bp-esp .bp-check .bp-mk{border-color:var(--green-dk);color:var(--green-dk)}
.bp-check p{font-family:'Inter',system-ui,sans-serif;font-weight:500;margin:3px 0 0;line-height:1.55}
.bp-check p b{font-family:'Roboto Slab',serif;font-weight:700;display:block}
.bp-paper .bp-check p{color:var(--body-paper)} .bp-navy .bp-check p,.bp-esp .bp-check p{color:var(--body-dark)}

/* P3 SEQUENCE — numbered drafting circles */
.bp-seq{margin-top:32px;display:grid;gap:20px}
@media(min-width:860px){.bp-seq{grid-template-columns:repeat(5,1fr);gap:18px}}
.bp-step{display:grid;grid-template-columns:auto 1fr;gap:14px;align-items:start}
@media(min-width:860px){.bp-step{grid-template-columns:1fr;text-align:left}}
.bp-step .bp-num{width:46px;height:46px;flex:none;border-radius:50%;border:2px solid var(--rust);display:grid;place-items:center;font-family:'Architects Daughter',cursive;-webkit-text-stroke:.4px var(--rust);color:var(--rust);font-size:1.3rem}
.bp-navy .bp-step .bp-num,.bp-esp .bp-step .bp-num{border-color:var(--rust-line);-webkit-text-stroke-color:var(--rust-line);color:var(--rust-line)}
.bp-step h3{font-family:'Roboto Slab',serif;font-weight:700;font-size:1.05rem;margin:0}
.bp-step p{font-family:'Inter',system-ui,sans-serif;font-weight:500;font-size:.95rem;line-height:1.55;margin:5px 0 0}
.bp-paper .bp-step p{color:var(--body-paper)} .bp-navy .bp-step p,.bp-esp .bp-step p{color:var(--body-dark)}

/* FAQ accordion — hand + toggles, hairline dividers */
.bp-faq{margin-top:30px;border-top:1px solid rgba(43,34,24,.18)}
.bp-navy .bp-faq,.bp-esp .bp-faq{border-top-color:rgba(239,230,212,.18)}
.bp-faq details{border-bottom:1px solid rgba(43,34,24,.16)}
.bp-navy .bp-faq details,.bp-esp .bp-faq details{border-bottom-color:rgba(239,230,212,.16)}
.bp-faq summary{list-style:none;cursor:pointer;padding:22px 26px;display:flex;justify-content:space-between;gap:18px;align-items:center;font-family:'Roboto Slab',serif;font-weight:700;font-size:1.08rem}
.bp-faq summary::-webkit-details-marker{display:none}
/* override Fixora's geometric +/- bars so only ONE hand-drawn + shows */
.bp-faq summary .icon{position:static;flex:none;width:auto;height:auto;font-family:'Architects Daughter',cursive;-webkit-text-stroke:.45px var(--rust);color:var(--rust);font-size:1.6rem;line-height:1;transition:transform .18s}
.bp-faq summary .icon::before{content:"+";position:static;background:none;width:auto;height:auto;border-radius:0}
.bp-faq summary .icon::after{content:none;display:none}
.bp-navy .bp-faq summary .icon,.bp-esp .bp-faq summary .icon{-webkit-text-stroke-color:var(--rust-line);color:var(--rust-line)}
.bp-faq details[open] summary .icon{transform:rotate(45deg)}
.bp-faq .answer{padding:0 26px 24px;font-family:'Inter',system-ui,sans-serif;font-weight:500;line-height:1.65;max-width:80ch}
.bp-paper .bp-faq .answer{color:var(--body-paper)} .bp-navy .bp-faq .answer,.bp-esp .bp-faq .answer{color:var(--body-dark)}
.bp-faq .answer a{color:var(--rust);font-weight:600}
.bp-navy .bp-faq .answer a,.bp-esp .bp-faq .answer a{color:var(--rust-line)}

/* P6 WORK-ORDER CTA */
.bp-cta-grid{display:grid;grid-template-columns:.8fr 1.2fr;gap:clamp(28px,5vw,56px);align-items:center}
@media(max-width:820px){.bp-cta-grid{grid-template-columns:1fr}}
.bp-ticket{border:1.5px dashed var(--rust-line);border-radius:14px;aspect-ratio:4/3;display:grid;place-items:center;text-align:center;color:var(--body-dark);background:rgba(160,180,210,.05);padding:18px}
.bp-ticket .bp-tag{font-family:'Architects Daughter',cursive;-webkit-text-stroke:.45px var(--rust-line);color:var(--rust-line);font-size:1.15rem}
.bp-ticket small{display:block;margin-top:8px;font-size:.78rem;max-width:34ch}
.bp .bp-cta-phone{font-family:'Roboto Slab',serif;font-weight:700;text-decoration:none;color:inherit;font-size:1.1rem}

@media(prefers-reduced-motion:reduce){.bp *{transition:none!important}}

/* ============================================================
   Site enhancements (NOT .bp pattern layer, but reusable):
   1) hero 0% APR badge line   2) reviews carousel (2 strips)
   Scoped to their own classes so they don't touch other styles.
   ============================================================ */
/* hero green 0% APR line — sits above the hero CTAs */
.svc-hero-apr{display:inline-flex;align-items:center;gap:10px;flex-wrap:wrap;margin:26px 0 8px;color:#fff;font-family:'Hanken Grotesque',system-ui,sans-serif;font-weight:600;font-size:.98rem}
.svc-hero-apr .badge0{font-family:'Archivo Expanded',system-ui,sans-serif}

/* review band — hero-style background image + brand-tone overlay (per-strip via --rev-img) */
.rev-band{position:relative;background:#1d2733;color:#efe6d4;isolation:isolate}
.rev-band::before{content:"";position:absolute;inset:0;z-index:-1;background-image:linear-gradient(rgba(36,28,22,.86),rgba(36,28,22,.66)),var(--rev-img,none);background-size:cover;background-position:center;background-repeat:no-repeat}
.rev-band .eyebrow{color:#e0894f}
.rev-band h2{color:#efe6d4}
.rev-band .lead{color:#e7ddc9}

/* reviews carousel */
.rev2-head{display:flex;align-items:flex-start;justify-content:space-between;gap:20px}
.rev2-glogo{display:inline-flex;align-items:center;gap:8px;text-decoration:none;border:1px solid var(--line,#e7ddc9);background:#fff;border-radius:999px;padding:8px 14px;font-family:'Hanken Grotesque',system-ui,sans-serif;font-weight:700;font-size:.9rem;color:#3c3a36;white-space:nowrap;box-shadow:0 1px 3px rgba(0,0,0,.06);transition:box-shadow .15s,transform .15s}
.rev2-glogo:hover{box-shadow:0 4px 12px rgba(0,0,0,.12);transform:translateY(-1px)}
.rev2-glogo svg{width:18px;height:18px;flex:none}
.rev2-strip{position:relative;margin-top:22px}
.rev2-track{display:flex;gap:22px;overflow-x:auto;scroll-snap-type:x mandatory;scroll-behavior:smooth;padding:6px 2px 14px;-ms-overflow-style:none;scrollbar-width:none}
.rev2-track::-webkit-scrollbar{display:none}
.rev2-track > .review-card{scroll-snap-align:start;flex:0 0 clamp(280px,32%,380px)}
.rev2-arrows{display:flex;gap:10px;margin-top:6px;justify-content:flex-end}
.rev2-arrow{width:44px;height:44px;border-radius:50%;border:1px solid #d9ccb2;background:#fff;color:#3c3a36;font-size:1.2rem;cursor:pointer;display:grid;place-items:center;transition:background .15s,transform .15s,box-shadow .15s}
.rev2-arrow:hover{background:#f6efe2;transform:translateY(-1px);box-shadow:0 3px 10px rgba(0,0,0,.1)}
.rev2-arrow:focus-visible{outline:3px solid var(--gold,#e8b84b);outline-offset:2px}
@media(max-width:600px){.rev2-track > .review-card{flex:0 0 85%}}
@media(prefers-reduced-motion:reduce){.rev2-track{scroll-behavior:auto}}

/* Hearth financing square banner (final CTA, left side) */
.hearth-card{background:#fffdf7;border:1px solid #e7dcc4;color:var(--ink);border-radius:18px;padding:clamp(22px,3vw,28px);width:100%;max-width:440px;box-shadow:0 18px 44px rgba(36,28,22,.16);font-family:'Inter',system-ui,sans-serif}
.bp-esp .hearth-card,.bp-navy .hearth-card{box-shadow:0 20px 54px rgba(0,0,0,.4)}
.hearth-card .hc-top{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-bottom:16px}
.hearth-card .hc-brand{font-family:'Roboto Slab',serif;font-weight:800;font-size:.92rem;letter-spacing:.02em;display:inline-flex;align-items:center;gap:8px}
.hearth-card .hc-brand::before{content:"";width:10px;height:10px;border-radius:50%;background:#0E7C3A}
.hearth-card .badge0{font-family:'Archivo Expanded',system-ui,sans-serif;flex:none}
.hearth-card h3{font-family:'Roboto Slab',serif;font-weight:800;font-size:clamp(1.4rem,2.4vw,1.65rem);line-height:1.1;letter-spacing:-.5px;margin:0 0 8px;color:var(--ink)}
.hearth-card .hc-sub{font-weight:500;color:var(--body-paper);font-size:.95rem;line-height:1.55;margin:0 0 18px}
.hearth-card .hc-label{font-weight:600;font-size:.82rem;color:var(--body-paper);display:block;margin-bottom:10px}
.hearth-card .hc-range{width:100%;accent-color:var(--rust);margin:0 0 14px}
.hearth-card .hc-read{display:flex;justify-content:space-between;align-items:baseline;border-top:1px dashed #d9ccb2;padding-top:14px}
.hearth-card .hc-amt{font-family:'Roboto Slab',serif;font-weight:800;font-size:1.2rem;color:var(--rust)}
.hearth-card .hc-amt small{display:block;font-family:'Inter';font-weight:600;font-size:.72rem;color:var(--body-paper)}
.hearth-card .hc-mo{font-family:'Roboto Slab',serif;font-weight:800;font-size:1.9rem;line-height:1;color:#0E7C3A;text-align:right}
.hearth-card .hc-mo small{display:block;font-family:'Inter';font-weight:600;font-size:.72rem;color:var(--body-paper)}
.hearth-card .bp-btn{display:flex;width:100%;justify-content:center;margin-top:16px}
.hearth-card .hc-disc{font-size:.7rem;line-height:1.45;color:var(--body-paper);opacity:.85;margin:12px 0 0}
@media(prefers-reduced-motion:reduce){.hearth-card .hc-range{accent-color:var(--rust)}}

/* ============================================================
   BLOG — listing + article foundation (blueprint styled)
   ============================================================ */
.bp-blog-hero{background:var(--espresso,#241C16);color:#f6efe2;padding:clamp(46px,6vw,82px) 0}
.bp-blog-hero .bp-wrap{text-align:center}
.bp-blog-hero .bp-eyebrow{color:#e0894f}
.bp-blog-hero h1{font-family:'Roboto Slab',Georgia,serif;font-weight:800;font-size:clamp(2rem,4.4vw,3.1rem);margin:.2em 0 .35em;line-height:1.08}
.bp-blog-hero p{max-width:60ch;margin:0 auto;color:#e9dcc4;font-size:1.06rem}

.blog-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(20px,2.6vw,30px);margin-top:8px}
@media(max-width:920px){.blog-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:600px){.blog-grid{grid-template-columns:1fr}}
.blog-card{position:relative;display:flex;flex-direction:column;background:#fff;border:2px solid #1E0F0C;border-radius:10px;overflow:hidden;box-shadow:5px 5px 0 rgba(30,15,12,.10);transition:transform .15s ease,box-shadow .15s ease}
a.blog-card:hover{transform:translateY(-3px);box-shadow:8px 8px 0 rgba(30,15,12,.14)}
.blog-card-img{aspect-ratio:16/10;background:#efe6d4 center/cover no-repeat;border-bottom:2px solid #1E0F0C}
.blog-card-body{padding:18px 18px 20px;display:flex;flex-direction:column;gap:9px;flex:1}
.blog-meta{display:flex;align-items:center;gap:10px;font-size:.78rem;color:#7a6f60;flex-wrap:wrap}
.blog-chip{display:inline-block;background:#f1e7d4;color:#8a4a25;border:1px solid #e0c9a3;border-radius:999px;padding:2px 10px;font-size:.72rem;font-weight:700;letter-spacing:.02em}
.blog-card h3{font-family:'Roboto Slab',Georgia,serif;font-weight:700;font-size:1.08rem;line-height:1.28;color:#241C16;margin:2px 0 0}
.blog-card .blog-excerpt{font-size:.92rem;color:#5b5142;line-height:1.5}
.blog-card .blog-more{margin-top:auto;font-weight:700;color:#b5552e;font-size:.9rem}
.blog-card.is-soon{opacity:.92}
.blog-card.is-soon .blog-soon{position:absolute;top:12px;right:12px;background:#1E0F0C;color:#f6efe2;font-size:.68rem;font-weight:700;letter-spacing:.04em;text-transform:uppercase;padding:4px 9px;border-radius:6px}
.blog-empty{text-align:center;padding:48px 0;color:#6b6052}

/* article (single post) */
.blog-article{max-width:760px;margin:0 auto}
.blog-article .blog-prose{font-family:'Inter',system-ui,sans-serif;color:#33291d;font-size:1.06rem;line-height:1.75}
.blog-prose h2{font-family:'Roboto Slab',Georgia,serif;font-weight:800;font-size:clamp(1.5rem,3vw,2rem);margin:1.6em 0 .5em;color:#241C16}
.blog-prose h3{font-family:'Roboto Slab',Georgia,serif;font-weight:700;font-size:1.28rem;margin:1.3em 0 .4em;color:#241C16}
.blog-prose p{margin:0 0 1.1em}
.blog-prose ul,.blog-prose ol{margin:0 0 1.2em 1.2em;padding:0}
.blog-prose li{margin:.4em 0}
.blog-prose img{max-width:100%;height:auto;border:2px solid #1E0F0C;border-radius:8px;margin:1.4em 0}
.blog-prose blockquote{margin:1.4em 0;padding:.4em 1.1em;border-left:4px solid #b5552e;background:#f8f1e3;border-radius:0 8px 8px 0;font-style:italic;color:#4a4031}
.blog-prose a{color:#b5552e;text-decoration:underline}
.blog-posthero h1{font-family:'Roboto Slab',Georgia,serif;font-weight:800;font-size:clamp(1.9rem,4vw,2.9rem);line-height:1.1;margin:.2em 0 .3em;max-width:20ch}
.blog-posthero .blog-meta{font-size:.86rem}
.blog-feat{margin:26px auto;max-width:900px;border:2px solid #1E0F0C;border-radius:10px;overflow:hidden}
.blog-feat img{display:block;width:100%;height:auto}

/* quote wizard slim footer */
.quote-foot{padding:18px 16px;text-align:center}
.quote-foot p{margin:0;font-size:.8rem;color:rgba(246,239,226,.66)}
.quote-foot a{color:rgba(246,239,226,.85)}

/* conversion timelapse video section */
.cv-video-frame{max-width:940px;margin:30px auto 0;border:2px solid rgba(239,230,212,.22);border-radius:12px;overflow:hidden;box-shadow:0 18px 50px rgba(0,0,0,.42);background:#000}
.cv-video-frame video{display:block;width:100%;height:auto;aspect-ratio:16/9;object-fit:cover}
.cv-video-sec .lead{max-width:62ch}

/* ============================================================
   JOBSITE-PIN SYSTEM — reserved containers (Layer A map + Layer B cards)
   App targets: #edge-pin-map[data-pin-map], #edge-pin-cards[data-pin-cards],
   script[data-pin-schema]; section carries data-pin-service / data-pin-city.
   ============================================================ */
.pin-map{position:relative;height:360px;margin-top:26px;border:2px solid #1E0F0C;border-radius:10px;overflow:hidden;
  background:#ece4d3;background-image:repeating-linear-gradient(0deg,rgba(43,34,24,.06) 0 1px,transparent 1px 30px),repeating-linear-gradient(90deg,rgba(43,34,24,.06) 0 1px,transparent 1px 30px)}
.pin-map .pin-ph{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;text-align:center;
  font-family:'Inter',system-ui,sans-serif;color:#7a6f5c;font-size:.95rem;font-weight:600;padding:20px;margin:0}
.pin-cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:16px;margin-top:22px}
.pin-cards:empty{display:none}
.pin-card{border:2px solid #1E0F0C;border-radius:10px;overflow:hidden;background:#fff;box-shadow:5px 5px 0 rgba(30,15,12,.10)}
.pin-card img{display:block;width:100%;height:170px;object-fit:cover;border-bottom:2px solid #1E0F0C}
.pin-card .pin-body{padding:12px 14px}
.pin-card .pin-date{font-size:.76rem;color:#8a7d68;font-weight:700;text-transform:uppercase;letter-spacing:.04em}
.pin-card .pin-cap{font-size:.92rem;color:#33291d;line-height:1.45;margin:4px 0 0}
.pin-card .pin-ba{display:flex}
.pin-card .pin-ba figure{flex:1;margin:0;position:relative}
.pin-card .pin-ba img{height:150px;border-bottom:2px solid #1E0F0C}
.pin-card .pin-ba figure+figure img{border-left:2px solid #1E0F0C}
.pin-card .pin-ba figcaption{position:absolute;top:6px;left:6px;background:#1E0F0C;color:#fff;font-size:.6rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;padding:2px 6px;border-radius:3px}
.pin-note{margin-top:14px;font-size:.85rem;color:#8a7d68;font-weight:600}
.pin-prose{max-width:62ch;margin:0 0 22px;font-size:1.02rem;line-height:1.6;color:var(--body-paper,#33291d)}

/* pin section: keep paper bg + readable dark title even inside the conversion .cvdemo wrapper
   (.cvdemo .gp uses the `background` shorthand and wipes the bp-paper color) */
.cvdemo section.pin-section{background-color:var(--paper);color:var(--ink)}
.cvdemo section.pin-section .bp-h2{color:var(--ink)}
.cvdemo section.pin-section .bp-lead{color:var(--body-paper)}
