/* Randy's Roofing Construction — Editorial · Clean · Premium */

:root{
  --ink:#06182f;          /* deep navy — sitewide dark surfaces & text */
  --ink-hover:#020c1d;    /* deeper navy for hover states */
  --ink-2:#354463;
  --ink-3:#556586;
  --mute:#8a93a8;
  --line:#ebeef2;
  --line-2:#dde2e8;
  --soft:#fafbfc;
  --soft-2:#f4f5f7;
  --cream:#f7f5f0;
  --white:#fff;
  --navy:#06182f;
  --navy-2:#06182f;
  --accent:#c94d07;     /* rust-orange — used sparingly */
  --accent-2:#a33c02;
  --ok:#15803d;
  --r:6px;
  --r-lg:10px;
  --maxw:1160px;
  --gap:20px;
  --f-sans:"Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;
  --f-display:"Fraunces", "Plus Jakarta Sans", Georgia, "Times New Roman", serif;
}

*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%;text-rendering:optimizeLegibility}
body{
  margin:0;font-family:var(--f-sans);color:var(--ink);background:var(--white);
  line-height:1.6;font-size:16px;-webkit-font-smoothing:antialiased;
  font-feature-settings:"ss01","cv11";
}
img,svg,video{max-width:100%;height:auto;display:block}
a{color:var(--ink);text-decoration:none;transition:color .12s ease}
a:hover{color:var(--accent)}
:focus-visible{outline:2px solid var(--ink);outline-offset:2px;border-radius:2px}

/* Typography */
h1,h2,h3,h4{font-family:var(--f-display);color:var(--ink);line-height:1.1;margin:0 0 .5em;font-weight:500;letter-spacing:-.02em}
h1{font-size:clamp(2.1rem,4.8vw,3.6rem);font-weight:500;letter-spacing:-.03em;line-height:1.05}
h2{font-size:clamp(1.5rem,2.8vw,2.2rem);font-weight:500;letter-spacing:-.025em;line-height:1.15}
h3{font-size:clamp(1.08rem,1.5vw,1.25rem);font-weight:600;font-family:var(--f-sans);letter-spacing:-.01em;line-height:1.3}
h4{font-size:.98rem;font-weight:600;font-family:var(--f-sans)}
p{margin:0 0 1em;color:var(--ink-2)}
ul,ol{padding-left:1.15rem;margin:0 0 1em}
li{margin:.15em 0;color:var(--ink-2)}
hr{border:0;border-top:1px solid var(--line);margin:4rem 0}
strong{color:var(--ink);font-weight:600}

.container{max-width:var(--maxw);margin:0 auto;padding:0 28px}
.skip{position:absolute;left:-9999px}
.skip:focus{left:10px;top:10px;background:#fff;padding:10px 14px;z-index:9999;border:1px solid var(--ink);border-radius:4px}

/* Eyebrow — tiny, monospace feel */
.eyebrow{display:inline-block;background:transparent;border:0;color:var(--mute);padding:0;border-radius:0;font-size:.72rem;font-weight:600;letter-spacing:.14em;text-transform:uppercase;margin-bottom:18px;font-family:var(--f-sans)}
.eyebrow::before{content:"— "}

/* Announcement bar — legacy (still used on emergency page) */
.abar{background:var(--ink);color:#dfe3ea;font-weight:400;font-size:.82rem;text-align:center;padding:10px 16px;letter-spacing:.01em}
.abar a{color:#fff;text-decoration:underline;text-underline-offset:3px;font-weight:500}
.abar a:hover{color:#fff;opacity:.8}

/* ========== Reliable Roofing section (tabbed service carousel) ========== */
.reliable{position:relative;background:#15355f url("/assets/img/roofing.webp") center/cover no-repeat;color:#fff;padding:clamp(36px,5.5vw,68px) 0 clamp(40px,6vw,76px);overflow:hidden;transition:background-image .6s ease}
.reliable::before{content:"";position:absolute;inset:0;background:linear-gradient(135deg,rgba(10,31,61,.85) 0%,rgba(21,53,95,.75) 50%,rgba(8,28,56,.9) 100%);pointer-events:none;backdrop-filter:blur(2px);-webkit-backdrop-filter:blur(2px)}
.reliable > .container{position:relative;z-index:1;max-width:none;padding-left:clamp(16px,3vw,40px);padding-right:clamp(16px,2vw,20px)}
.reliable-grid{display:grid;grid-template-columns:.78fr 1.22fr;gap:clamp(24px,3.5vw,44px);align-items:center}
.reliable-cards-wrap{position:relative;padding:4px 0;max-width:860px;justify-self:end;width:100%;margin-right:-20px}
.reliable-intro{padding-left:clamp(0px,5vw,72px)}
.reliable-intro h1,.reliable-intro h2{font-size:clamp(1.6rem,3vw,2.4rem);color:#fff;letter-spacing:-.02em;line-height:1.1;margin:0 0 14px;font-weight:600;max-width:14ch;font-family:var(--f-display);transition:opacity .22s ease,transform .22s ease}
.reliable-intro > p{color:rgba(255,255,255,.9);font-size:clamp(.92rem,1.1vw,1rem);line-height:1.55;margin:0 0 20px;max-width:44ch;transition:opacity .22s ease,transform .22s ease}
.reliable-heading.is-fading,.reliable-desc.is-fading{opacity:0;transform:translateY(4px)}
.btn-read{display:inline-flex;align-items:center;gap:10px;background:#fff;color:#d23c1f!important;font-weight:700;font-size:.78rem;letter-spacing:.1em;text-transform:uppercase;padding:11px 14px 11px 22px;border-radius:999px;text-decoration:none;box-shadow:0 2px 12px rgba(0,0,0,.15);transition:background .15s ease}
.btn-read:hover{background:#fef2ed;color:#9e1220!important}
.btn-read .arrow-circle{width:26px;height:26px;border-radius:50%;background:#d23c1f;display:grid;place-items:center;color:#fff}
.btn-read .arrow-circle svg{width:12px;height:12px;stroke:currentColor;fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}
.reliable-tabs{display:flex;flex-wrap:wrap;gap:8px;margin-top:24px}
.reliable-tab{background:rgba(255,255,255,.95);color:var(--ink);border:0;padding:8px 16px;border-radius:4px;font-weight:600;font-size:.78rem;cursor:pointer;transition:background .15s ease,color .15s ease;text-decoration:none;display:inline-block;line-height:1.2}
.reliable-tab:hover{background:#fff;color:var(--ink)}
.reliable-tab.active{background:#b74621;color:#fff}

/* Vertical social icons on left edge */
.reliable-socials{position:absolute;left:20px;top:50%;transform:translateY(-50%);display:flex;flex-direction:column;gap:14px;z-index:2}
.reliable-socials a{width:28px;height:28px;background:#b74621;border-radius:4px;display:grid;place-items:center;color:#fff;transition:background .15s ease}
.reliable-socials a:hover{background:#8c3618;color:#fff}
.reliable-socials svg{width:16px;height:16px;fill:currentColor}
@media(max-width:960px){.reliable-socials{display:none}}

/* Next arrow navigation — floating on right edge of cards area */
.reliable-next{position:absolute;right:-22px;top:50%;transform:translateY(-50%);width:44px;height:44px;background:rgba(255,255,255,.95);border:0;border-radius:50%;display:grid;place-items:center;color:var(--ink);cursor:pointer;transition:background .15s ease,transform .15s ease;z-index:5;box-shadow:0 4px 12px rgba(0,0,0,.25)}
.reliable-next:hover{background:#fff;transform:translateY(-50%) translateX(2px)}
.reliable-next svg{width:16px;height:16px;stroke:currentColor;fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}
@media(max-width:1000px){.reliable-next{display:none}}

/* Cards column */
.reliable-cards{display:flex;gap:12px;overflow-x:auto;overflow-y:visible;scrollbar-width:none;-ms-overflow-style:none;padding-bottom:4px}
.reliable-cards::-webkit-scrollbar{display:none}
.reliable-card{flex:0 0 calc(50% - 6px);min-width:0;background:rgba(14,32,58,.58);border:1px solid rgba(255,255,255,.1);border-radius:10px;overflow:hidden;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);box-shadow:0 5px 16px rgba(0,0,0,.18);opacity:.82;display:flex;flex-direction:column;min-height:280px;transform:scale(.94);transform-origin:center;transition:opacity .5s cubic-bezier(.4,0,.2,1),box-shadow .5s cubic-bezier(.4,0,.2,1),transform .5s cubic-bezier(.4,0,.2,1)}
.reliable-card.is-active{flex:0 0 calc(50% - 6px);opacity:1;transform:scale(1);box-shadow:0 14px 34px rgba(0,0,0,.34)}
.reliable-card-img{width:100%;aspect-ratio:16/10;background:linear-gradient(135deg,#2a4a74 0%,#0e2845 100%);position:relative;overflow:hidden;display:block;flex-shrink:0}
.reliable-card-img.img-roofing{background:url("/assets/img/roofing.webp") center/cover no-repeat}
.reliable-card-img.img-siding{background:url("/assets/img/siding.webp") center/cover no-repeat}
.reliable-card-img.img-chimney{background:url("/assets/img/chimney.webp") center/cover no-repeat}
.reliable-card-img.img-gutters{background:url("/assets/img/gutters.webp") center/cover no-repeat}
.reliable-card-img.img-decks{background:url("/assets/img/decks.webp") center/cover no-repeat}
.reliable-card-img.img-repair{background:url("/assets/img/roof%20repair.png") center/cover no-repeat}
.reliable-card-img.img-replacement{background:url("/assets/img/roof%20replacement.png") center/cover no-repeat}
.reliable-card-body{padding:12px 14px 16px;flex:1;display:flex;flex-direction:column;gap:6px}
.reliable-card-body h3{color:#fff;font-size:1.02rem;margin:0;font-family:var(--f-display);font-weight:600;letter-spacing:-.01em;line-height:1.15;font-style:italic}
.reliable-card-body p{color:rgba(255,255,255,.85);font-size:.74rem;line-height:1.4;margin:0;font-weight:400}
.reliable-reach{display:inline-flex;align-items:center;gap:8px;color:#fff!important;font-weight:700;font-size:.6rem;letter-spacing:.14em;text-transform:uppercase;text-decoration:none;margin-top:auto;align-self:flex-start}
.reliable-reach:hover{color:#fff!important;opacity:.95}
.reach-arrow{width:17px;height:17px;background:#d23c1f;border-radius:50%;display:grid;place-items:center;transition:transform .15s ease,background .15s ease;flex-shrink:0}
.reliable-reach:hover .reach-arrow{transform:translateX(2px);background:#b4301a}
.reach-arrow svg{width:8px;height:8px;stroke:#fff;fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}
.reliable-card:not(.is-active) .reliable-card-body{opacity:.7}

/* Dots */
.reliable-dots{display:flex;gap:8px;justify-content:center;margin-top:20px}
.reliable-dot{width:9px;height:9px;border-radius:50%;background:rgba(255,255,255,.28);border:0;cursor:pointer;padding:0;transition:background .2s ease,width .2s ease}
.reliable-dot:hover{background:rgba(255,255,255,.5)}
.reliable-dot.active{background:#d23c1f;width:24px;border-radius:999px}

@media(max-width:1000px){
  .reliable-grid{grid-template-columns:1fr;gap:28px}
  .reliable-cards-wrap{margin-right:0;justify-self:stretch;max-width:100%}
  .reliable-intro{padding-left:0;text-align:left}
  .reliable-intro h1,.reliable-intro h2{max-width:none}
  .reliable-card{flex:0 0 calc(50% - 6px);min-width:200px}
}
@media(max-width:720px){
  .reliable-tabs{margin-top:18px;gap:6px}
  .reliable-tab{padding:7px 12px;font-size:.74rem}
  .reliable-card{flex:0 0 calc(70% - 6px);min-width:200px;min-height:240px}
  .reliable-card.is-active{flex:0 0 calc(70% - 6px)}
}
@media(max-width:480px){
  .reliable > .container{padding-left:16px;padding-right:16px}
  .reliable-intro h1,.reliable-intro h2{font-size:clamp(1.45rem,6vw,1.85rem);margin-bottom:10px}
  .reliable-intro > p{font-size:.92rem;margin-bottom:16px}
  .btn-read{padding:10px 12px 10px 18px;font-size:.72rem}
  .reliable-card{flex:0 0 84%;min-width:0;min-height:220px}
  .reliable-card.is-active{flex:0 0 84%}
  .reliable-card-body{padding:10px 12px 14px}
  .reliable-dots{margin-top:14px}
}

/* ========== Discover section (homepage intro, clean editorial red) ========== */
.discover{padding:112px 0;background:#b74621;color:#fff;position:relative;overflow:hidden}
.discover::before{content:"";position:absolute;top:0;right:-10%;width:60%;height:100%;background:radial-gradient(ellipse at top right, rgba(255,255,255,.08), transparent 65%);pointer-events:none}
.discover > .container{position:relative;z-index:1;max-width:1200px}
.discover-grid{display:grid;grid-template-columns:1.15fr .85fr;gap:56px;align-items:start}
.discover-intro{max-width:none}
.discover-form{box-shadow:0 10px 40px rgba(0,0,0,.18),0 2px 6px rgba(0,0,0,.08)}
@media(max-width:1000px){.discover-grid{grid-template-columns:1fr;gap:44px}}
.discover-eyebrow{display:block;font-size:.7rem;font-weight:700;letter-spacing:.16em;text-transform:uppercase;color:rgba(255,255,255,.75);margin-bottom:28px}
.discover-eyebrow::before{content:"";display:inline-block;width:28px;height:1px;background:rgba(255,255,255,.5);vertical-align:middle;margin-right:12px}
.discover h2{font-size:clamp(2rem,3.6vw,3rem);color:#fff;letter-spacing:-.022em;line-height:1.08;margin:0 0 28px;font-weight:500;max-width:22ch}
.discover p{color:rgba(255,255,255,.9);font-size:1.04rem;margin:0 0 36px;max-width:70ch;line-height:1.68}
.discover p strong{color:#fff;font-weight:600}
.discover-cta-row{display:flex;align-items:center;gap:36px;flex-wrap:wrap}
.btn-red{display:inline-flex;align-items:center;background:#d23c1f;color:#fff!important;border:0;border-radius:999px;padding:15px 32px;font-weight:700;font-size:.82rem;letter-spacing:.1em;text-transform:uppercase;box-shadow:0 2px 10px rgba(210,60,31,.22);transition:background .15s ease,box-shadow .15s ease;text-decoration:none;white-space:nowrap}
.btn-red:hover{background:#b4301a;color:#fff!important;box-shadow:0 4px 14px rgba(210,60,31,.3)}
.discover .btn-red{background:#fff;color:#b74621!important;box-shadow:0 2px 12px rgba(0,0,0,.12)}
.discover .btn-red:hover{background:#fef2ed;color:#8c3618!important;box-shadow:0 4px 16px rgba(0,0,0,.2)}
.discover-phone{display:inline-flex;align-items:center;gap:14px;color:#fff;text-decoration:none}
.discover-phone:hover{color:#fff;opacity:.92}
.discover-phone-ico{width:44px;height:44px;border-radius:50%;border:1.5px solid rgba(255,255,255,.35);display:grid;place-items:center;flex-shrink:0}
.discover-phone-ico svg{width:18px;height:18px;stroke:currentColor;fill:none;stroke-width:1.8;stroke-linecap:round;stroke-linejoin:round}
.discover-phone-text{display:flex;flex-direction:column;line-height:1.15}
.discover-phone-text small{font-size:.7rem;color:rgba(255,255,255,.7);letter-spacing:.08em;text-transform:uppercase;font-weight:600;margin-bottom:3px}
.discover-phone-text strong{font-size:1.18rem;font-weight:600;letter-spacing:-.005em}
.discover-stats{display:grid;grid-template-columns:repeat(5,1fr);gap:32px;margin-top:80px;padding-top:44px;border-top:1px solid rgba(255,255,255,.22)}
.stat-item strong{display:block;font-size:clamp(1.6rem,2.2vw,2rem);font-weight:500;font-family:var(--f-display);color:#fff;letter-spacing:-.02em;margin-bottom:6px;line-height:1}
.stat-item span{display:block;font-size:.78rem;color:rgba(255,255,255,.8);line-height:1.4;letter-spacing:.01em}
@media(max-width:900px){
  .discover{padding:72px 0}
  .discover h2{max-width:100%}
  .discover-stats{grid-template-columns:repeat(2,1fr);gap:24px;margin-top:56px;padding-top:36px}
  .discover-cta-row{gap:24px}
}
@media(max-width:500px){.discover-stats{grid-template-columns:1fr 1fr}.stat-item:nth-child(5){grid-column:1/-1}}

/* ========== PROMO BAR (expandable military/senior discount) ========== */
.promo{background:#b74621;color:#fff}
.promo .container{padding:16px 28px 18px}
.promo-head{display:flex;align-items:center;gap:14px;flex-wrap:wrap}
.promo-ico{display:inline-grid;place-items:center;color:#fff;flex-shrink:0}
.promo-ico svg{width:22px;height:22px;stroke:currentColor;fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}
.promo-head strong{font-weight:600;font-size:.95rem;letter-spacing:.005em;flex:1;min-width:0}
.promo-toggle{background:transparent;color:#fff;border:0;font:inherit;cursor:pointer;display:inline-flex;align-items:center;gap:6px;font-weight:500;font-size:.86rem;padding:2px 4px}
.promo-toggle svg{width:14px;height:14px;stroke:currentColor;fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round;transition:transform .2s ease}
.promo-toggle[aria-expanded="false"] svg{transform:rotate(-90deg)}
.promo-body{padding-left:44px;max-width:1100px;overflow:hidden;max-height:400px;margin-top:12px;opacity:1;transition:max-height .4s cubic-bezier(.4,0,.2,1),margin-top .4s cubic-bezier(.4,0,.2,1),opacity .25s ease}
.promo-body p{margin:0 0 14px;color:rgba(255,255,255,.95);font-size:.9rem;line-height:1.55}
.promo-cta{display:inline-flex;align-items:center;gap:10px;color:#fff!important;font-weight:600;font-size:.86rem;text-decoration:none}
.promo-cta:hover{color:#fff!important;opacity:.85}
.promo-arrow{width:22px;height:22px;border:1.5px solid #fff;border-radius:50%;display:inline-grid;place-items:center}
.promo-arrow svg{width:11px;height:11px;stroke:currentColor;fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}
.promo[data-collapsed="true"] .promo-body{max-height:0;margin-top:0;opacity:0}
@media(max-width:560px){.promo-body{padding-left:0}}

/* ========== INFO BAR (tagline + phone + location + socials) ========== */
.infobar{background:var(--ink);color:#c9d3e4;font-size:.84rem;border-top:1px solid rgba(255,255,255,.08)}
.infobar-row{display:flex;align-items:center;justify-content:space-between;gap:20px;padding:12px 28px}
.infobar-left{display:flex;align-items:center;gap:18px;flex-wrap:wrap}
.infobar-left strong{color:#fff;font-weight:600;font-size:.86rem;letter-spacing:.005em}
.infobar-left a{color:#c9d3e4;font-weight:500;text-decoration:none}
.infobar-left a:hover{color:#fff}
.infobar .sep{opacity:.25}
.infobar .loc{display:inline-flex;align-items:center;gap:6px;color:#c9d3e4}
.infobar .loc svg{width:14px;height:14px;stroke:currentColor;fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}
.infobar-right{display:flex;gap:12px;align-items:center}
.infobar-right a{color:#c9d3e4;display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px}
.infobar-right a:hover{color:#fff}
.infobar-right svg{width:18px;height:18px;fill:currentColor}
@media(max-width:700px){.infobar-row{flex-direction:column;gap:8px;padding:10px 20px}.infobar-right{order:-1}}

/* ========== MAIN NAV — updated labels + Dial Now pill ========== */
.hdr{background:#fff}
.hdr-row{gap:16px}
.nav{gap:32px}
.nav > a,.nav > details > summary{font-size:.84rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--ink)}
.nav > a:hover,.nav > details > summary:hover{color:var(--accent)}
.nav > a.active{color:var(--accent);position:relative;padding-bottom:4px}
.nav > a.active::after{content:"";position:absolute;left:0;right:0;bottom:-2px;height:2px;background:var(--accent)}

/* Mega menu — Our Expertise (full-width dark panel) */
.nav details.mega{position:static}
.nav details.mega > .menu{display:none;position:absolute;left:0;right:0;top:100%;width:100%;background:var(--ink);border:0;border-radius:0;padding:40px 0 44px;box-shadow:0 20px 40px rgba(0,0,0,.15);max-width:none;grid-template-columns:none;grid-gap:0;min-width:0;z-index:60}
.nav details.mega[open] > .menu{display:block}
.mega .menu-inner{display:grid;grid-template-columns:minmax(150px,170px) repeat(5,1fr);gap:28px 32px;max-width:1160px;margin:0 auto;padding:0 28px;align-items:start}
.mega-brand{grid-row:1 / span 2;grid-column:1;display:flex;align-items:flex-start;padding-right:10px;margin-left:-20px}
.mega-brand img{height:72px;width:auto;display:block;max-width:100%}
@media(max-width:1180px){.mega-brand{margin-left:0}}
@media(max-width:960px){.mega-brand{margin-left:0}}
.nav .mega .menu-inner a{display:block;padding:2px 0;color:#fff;background:transparent;font-size:.82rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;line-height:1.4;text-decoration:none;border-radius:0}
.nav .mega .menu-inner a:hover{color:var(--accent);background:transparent}

/* Mega-menu variant for More (columns with headings) */
.mega.mega-cols .menu-inner{grid-template-columns:minmax(150px,170px) 1.4fr 1fr 1fr;gap:32px 40px}
.mega.mega-cols .mega-brand{grid-row:1;grid-column:1}
.mega-col h4{color:#fff;font-size:.76rem;font-weight:700;letter-spacing:.14em;text-transform:uppercase;margin:0 0 18px;font-family:var(--f-sans)}
.mega-col ul{list-style:none;padding:0;margin:0}
.mega-col li{margin:0}
.nav .mega.mega-cols .menu-inner a,.nav .mega-col a{display:block;padding:6px 0;color:rgba(255,255,255,.85);font-size:.82rem;font-weight:400;letter-spacing:0;text-transform:none;line-height:1.4}
.nav .mega.mega-cols .menu-inner a:hover,.nav .mega-col a:hover{color:var(--accent)}

@media(max-width:960px){
  .nav details.mega > .menu{position:static;padding:12px 0 6px;box-shadow:none}
  .mega .menu-inner,.mega.mega-cols .menu-inner{grid-template-columns:1fr;gap:16px;padding:0 10px}
  .nav .mega .menu-inner a{padding:8px 0;font-size:.85rem}
  .mega-col h4{font-size:.72rem;margin-bottom:10px}
  .mega-brand{display:none}
}

/* Dial Now pill */
.btn-dial{display:inline-flex;align-items:center;gap:10px;background:#d23c1f;color:#fff!important;border:0;border-radius:999px;padding:14px 30px;font-weight:700;font-size:.82rem;letter-spacing:.1em;text-transform:uppercase;box-shadow:0 2px 10px rgba(210,60,31,.22);transition:background .15s ease,box-shadow .15s ease;white-space:nowrap;text-decoration:none}
.btn-dial:hover{background:#b4301a;color:#fff!important;box-shadow:0 4px 14px rgba(210,60,31,.3)}
.btn-dial::before{content:"";display:inline-block;width:14px;height:14px;background:currentColor;-webkit-mask:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2.2' stroke-linecap='round' stroke-linejoin='round'><path d='M22 16.92v3a2 2 0 0 1-2.18 2 19.8 19.8 0 0 1-8.63-3.07 19.5 19.5 0 0 1-6-6A19.8 19.8 0 0 1 2.12 4.18 2 2 0 0 1 4.11 2h3a2 2 0 0 1 2 1.72 12.8 12.8 0 0 0 .7 2.81 2 2 0 0 1-.45 2.11L8.09 9.91a16 16 0 0 0 6 6l1.27-1.27a2 2 0 0 1 2.11-.45 12.8 12.8 0 0 0 2.81.7A2 2 0 0 1 22 16.92z'/></svg>") center/contain no-repeat;
mask:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2.2' stroke-linecap='round' stroke-linejoin='round'><path d='M22 16.92v3a2 2 0 0 1-2.18 2 19.8 19.8 0 0 1-8.63-3.07 19.5 19.5 0 0 1-6-6A19.8 19.8 0 0 1 2.12 4.18 2 2 0 0 1 4.11 2h3a2 2 0 0 1 2 1.72 12.8 12.8 0 0 0 .7 2.81 2 2 0 0 1-.45 2.11L8.09 9.91a16 16 0 0 0 6 6l1.27-1.27a2 2 0 0 1 2.11-.45 12.8 12.8 0 0 0 2.81.7A2 2 0 0 1 22 16.92z'/></svg>") center/contain no-repeat}
@media(max-width:960px){.btn-dial{display:none}}

/* Header — ultra clean */
.hdr{position:sticky;top:0;z-index:50;background:#fff;border-bottom:1px solid var(--line)}
.hdr-row{display:flex;align-items:center;justify-content:space-between;gap:18px;padding:16px 0}
.brand{display:inline-flex;align-items:center;line-height:1}
.brand img,.brand svg{height:64px;width:auto;display:block;max-width:100%}
.hdr .brand{margin-left:50px}
.hdr .btn-dial{margin-right:25px}
.hdr .brand img{height:72px}
.ftr .brand img{height:80px;margin-bottom:12px}
@media(min-width:1200px){.hdr .brand{margin-left:25px}}
@media(min-width:1440px){.hdr .brand{margin-left:5px}}
@media(max-width:900px){.hdr .brand img{height:60px}}
@media(max-width:560px){.hdr .brand img{height:52px}}
.hdr-row{padding:12px 0}
.nav{display:flex;align-items:center;gap:28px}
.nav a{color:var(--ink-2);font-weight:400;font-size:.93rem;letter-spacing:-.005em}
.nav a:hover{color:var(--ink)}
.nav details{position:relative}
.nav details summary{list-style:none;cursor:pointer;font-weight:400;font-size:.93rem;color:var(--ink-2)}
.nav details summary:hover{color:var(--ink)}
.nav details summary::-webkit-details-marker{display:none}
.nav details summary::after{content:" ›";color:var(--mute);font-size:.9em;margin-left:2px;transition:transform .15s ease;display:inline-block}
.nav details[open] summary::after{transform:rotate(90deg)}
.nav details[open] > .menu{display:grid}
.nav .menu{display:none;position:absolute;top:calc(100% + 14px);left:-12px;background:#fff;border:1px solid var(--line);border-radius:6px;padding:6px;min-width:220px;grid-gap:1px;z-index:60}
.nav .menu a{padding:8px 12px;border-radius:3px;display:block;font-size:.9rem;color:var(--ink-2)}
.nav .menu a:hover{background:var(--soft);color:var(--ink)}
.cta-phone{display:inline-flex;align-items:center;gap:6px;background:var(--ink);color:#fff;padding:10px 18px;border-radius:4px;font-weight:500;font-size:.88rem;border:1px solid var(--ink);letter-spacing:-.005em}
.cta-phone:hover{background:var(--ink-hover);color:#fff;border-color:var(--ink-hover)}
.burger{display:none;background:#fff;color:var(--ink);border:1px solid var(--line-2);border-radius:4px;padding:8px 14px;font-weight:500;font-size:.88rem}

@media(max-width:960px){
  .nav{display:none;position:absolute;left:0;right:0;top:100%;background:#fff;border-bottom:1px solid var(--line);flex-direction:column;align-items:stretch;padding:14px 28px;gap:4px}
  .nav.open{display:flex}
  .nav details summary{padding:10px 0}
  .nav .menu{position:static;border:0;padding:0 0 6px 10px}
  .burger{display:inline-block}
}

/* Hero — white, editorial, generous */
.hero{background:#fff;border-bottom:1px solid var(--line)}
.hero .container{padding:88px 28px 96px;display:grid;grid-template-columns:1.25fr .75fr;gap:72px;align-items:center}
.hero h1{color:var(--ink)}
.hero p.lead{font-size:1.12rem;color:var(--ink-2);max-width:58ch;margin-bottom:0;line-height:1.55}
.hero-cta{display:flex;flex-wrap:wrap;gap:12px;margin-top:36px;align-items:center}
.btn{display:inline-flex;align-items:center;gap:8px;padding:12px 22px;border-radius:4px;font-weight:500;font-size:.92rem;letter-spacing:-.005em;border:1px solid transparent;cursor:pointer;transition:background .15s ease,color .15s ease,border-color .15s ease;font-family:var(--f-sans);white-space:nowrap}
.btn-primary{background:var(--ink);color:#fff;border-color:var(--ink)}
.btn-primary:hover{background:var(--ink-hover);color:#fff;border-color:var(--ink-hover)}
.btn-ghost{background:transparent;color:var(--ink);border:1px solid var(--line-2)}
.btn-ghost:hover{background:var(--soft);color:var(--ink);border-color:var(--ink)}
.btn-light{background:#fff;color:var(--ink);border-color:var(--line-2)}
.btn-light:hover{background:var(--soft);color:var(--ink);border-color:var(--ink)}
.btn-accent{background:var(--accent);color:#fff;border-color:var(--accent)}
.btn-accent:hover{background:var(--accent-2);color:#fff;border-color:var(--accent-2)}
.hero-card{background:#fff;color:var(--ink);border:1px solid var(--line);border-radius:var(--r-lg);padding:32px;box-shadow:0 1px 2px rgba(11,15,23,.04),0 8px 24px rgba(11,15,23,.06)}
.hero-card h3{margin:0 0 6px;font-size:1.15rem;font-weight:600;font-family:var(--f-sans);letter-spacing:-.01em}
.hero-card > p.small{color:var(--ink-3);font-size:.86rem;margin:0 0 22px;line-height:1.5}
.hero-card .field{margin-bottom:14px}
.hero-card label{display:block;font-weight:500;color:var(--ink);margin-bottom:6px;font-size:.78rem;letter-spacing:.04em;text-transform:uppercase;font-family:var(--f-sans)}
.hero-card input,.hero-card select{width:100%;padding:12px 14px;border:1px solid var(--line-2);border-radius:4px;font:inherit;color:var(--ink);background:#fff;font-size:.95rem;transition:border-color .12s ease,box-shadow .12s ease}
.hero-card input:focus,.hero-card select:focus{border-color:var(--ink);outline:none;box-shadow:0 0 0 3px rgba(11,15,23,.08)}
.hero-card input::placeholder{color:var(--mute)}
.hero-card button[type="submit"]{margin-top:8px;padding:14px 22px;font-weight:500;letter-spacing:-.005em}
.hero-card p.small.mt-2{margin-top:14px;color:var(--mute);font-size:.78rem;line-height:1.5}
.hero-badges{display:flex;flex-wrap:wrap;gap:18px;margin-top:30px;padding-top:26px;border-top:1px solid var(--line)}
.badge{display:inline-flex;gap:6px;align-items:center;background:transparent;color:var(--ink-3);border:0;padding:0;font-size:.82rem;font-weight:500;letter-spacing:-.005em}
.badge::before{content:"✓";color:var(--accent);font-weight:700;margin-right:2px}

@media(max-width:900px){.hero .container{grid-template-columns:1fr;padding:56px 28px 64px;gap:48px}}

/* Sections */
.section{padding:96px 0}
.section.soft{background:var(--soft)}
.section.cream{background:var(--cream)}
.section.dark{background:var(--ink);color:#dfe3ea}
.section.dark h1,.section.dark h2,.section.dark h3{color:#fff}
.section.dark p,.section.dark li{color:#b3bbc8}
.section-head{max-width:720px;margin:0 0 56px}
.section-head.center{text-align:center;margin:0 auto 56px}
.section-head h2{margin-bottom:.3em}
.section-head p{color:var(--ink-3);font-size:1.05rem;max-width:58ch}
.section-head.center p{margin-left:auto;margin-right:auto}

/* Trust strip on dark surfaces */
.trust{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:18px;align-items:center;padding:22px 0;border-top:1px solid rgba(255,255,255,.1);border-bottom:1px solid rgba(255,255,255,.1)}
.trust .item{display:flex;align-items:center;gap:10px;color:#b3bbc8;font-weight:400;font-size:.88rem;letter-spacing:-.005em}
.trust .item .dot{width:4px;height:4px;background:var(--accent);border-radius:50%}

/* Grids */
.grid{display:grid;gap:var(--gap)}
.g-3{grid-template-columns:repeat(3,1fr)}
.g-4{grid-template-columns:repeat(4,1fr)}
.g-2{grid-template-columns:repeat(2,1fr)}
@media(max-width:900px){.g-3,.g-4{grid-template-columns:repeat(2,1fr)}}
@media(max-width:560px){.g-2,.g-3,.g-4{grid-template-columns:1fr}}

/* Cards — editorial, quiet */
.card{background:#fff;border:1px solid var(--line);border-radius:var(--r-lg);padding:28px 26px;transition:border-color .15s ease;display:block}
.card:hover{border-color:var(--ink)}
.card .ico{width:34px;height:34px;background:transparent;border:1px solid var(--line);border-radius:4px;display:grid;place-items:center;font-size:1rem;margin-bottom:20px;color:var(--ink-2)}
.card h3{margin:0 0 .4em;font-size:1.08rem}
.card p{color:var(--ink-3);margin:0;font-size:.92rem;line-height:1.55}
.card .more{display:inline-block;margin-top:18px;font-weight:500;color:var(--ink);font-size:.86rem;border-bottom:1px solid var(--ink);padding-bottom:1px}
.card:hover .more{color:var(--accent);border-color:var(--accent)}

/* Features */
.features{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--gap)}
.features .f{background:#fff;border:1px solid var(--line);border-radius:var(--r-lg);padding:26px}
.features .f h4{margin:0 0 6px;color:var(--ink)}
.features .f p{margin:0;color:var(--ink-3);font-size:.92rem}
@media(max-width:900px){.features{grid-template-columns:1fr 1fr}}
@media(max-width:560px){.features{grid-template-columns:1fr}}

/* Answer block (AEO) — editorial */
.answer{background:transparent;border:0;border-left:2px solid var(--ink);border-radius:0;padding:4px 0 4px 22px;margin:0 0 32px}
.answer p{margin:0;color:var(--ink);font-size:1.02rem;line-height:1.55}

/* Key takeaways */
.keytakeaways{background:var(--soft);border:1px solid var(--line);border-radius:var(--r-lg);padding:26px 28px;margin:0 0 32px}
.keytakeaways h3{margin-top:0;font-size:.78rem;font-weight:600;letter-spacing:.12em;text-transform:uppercase;color:var(--mute);font-family:var(--f-sans)}
.keytakeaways ul{margin:14px 0 0;padding-left:1.1rem}
.keytakeaways li{color:var(--ink-2);font-size:.96rem}

/* Table */
.tbl{width:100%;border-collapse:collapse;background:#fff;border:1px solid var(--line);border-radius:var(--r-lg);overflow:hidden;margin:1.5em 0}
.tbl th,.tbl td{padding:14px 18px;text-align:left;border-bottom:1px solid var(--line);font-size:.92rem;color:var(--ink-2)}
.tbl thead th{background:var(--soft);font-weight:600;color:var(--ink);font-size:.78rem;letter-spacing:.08em;text-transform:uppercase;border-bottom:1px solid var(--line-2)}
.tbl tr:last-child td{border-bottom:0}
.tbl td:first-child{color:var(--ink);font-weight:500}

/* Process steps — minimal, numbered */
.steps{display:grid;grid-template-columns:repeat(5,1fr);gap:var(--gap);counter-reset:step}
.steps .step{background:#fff;border:1px solid var(--line);border-radius:var(--r-lg);padding:26px 24px 24px}
.steps .step::before{counter-increment:step;content:"0" counter(step);display:block;color:var(--mute);font-size:.74rem;font-weight:600;letter-spacing:.14em;font-family:var(--f-sans);margin-bottom:18px}
.steps .step h4{margin:0 0 6px;font-size:1rem}
.steps .step p{font-size:.9rem;color:var(--ink-3);margin:0;line-height:1.55}
@media(max-width:900px){.steps{grid-template-columns:1fr 1fr}}
@media(max-width:560px){.steps{grid-template-columns:1fr}}

/* FAQ — minimal */
.faq details{background:#fff;border:0;border-bottom:1px solid var(--line);border-radius:0;padding:20px 0;margin-bottom:0}
.faq details:first-child{border-top:1px solid var(--line)}
.faq details[open]{border-bottom-color:var(--line-2)}
.faq summary{cursor:pointer;font-weight:500;color:var(--ink);list-style:none;padding-right:32px;position:relative;font-size:1rem;letter-spacing:-.005em}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"+";position:absolute;right:4px;top:-2px;color:var(--ink-3);font-weight:400;font-size:1.3rem;transition:transform .15s ease;line-height:1}
.faq details[open] summary::after{content:"–";color:var(--ink)}
.faq details p{margin:14px 0 0;color:var(--ink-2);font-size:.94rem;line-height:1.6;max-width:72ch}

/* Reviews */
.review{background:#fff;border:1px solid var(--line);border-radius:var(--r-lg);padding:28px 26px}
.review .stars{color:var(--accent);font-weight:500;letter-spacing:.08em;font-size:.88rem;margin:0 0 14px}
.review p{color:var(--ink-2);font-size:.97rem;line-height:1.55;font-family:var(--f-display);font-weight:400;font-style:italic}
.review .who{margin-top:16px;font-size:.82rem;color:var(--mute);margin-bottom:0;letter-spacing:-.005em;font-style:normal;font-family:var(--f-sans)}

/* Footer — refined */
.ftr{background:var(--ink);color:#a9b6cf;padding:80px 0 28px;margin-top:0;border-top:0}
.ftr h4{color:#fff;font-size:.74rem;letter-spacing:.14em;text-transform:uppercase;margin-bottom:18px;font-weight:600;font-family:var(--f-sans)}
.ftr a{color:#a9b6cf;font-size:.9rem}
.ftr a:hover{color:#fff}
.ftr p{font-size:.88rem;color:#a9b6cf;line-height:1.6}
.ftr-top{display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr;gap:56px}
.ftr ul{list-style:none;padding:0;margin:0}
.ftr li{margin:.35em 0}
.ftr-bottom{margin-top:56px;padding-top:24px;border-top:1px solid rgba(255,255,255,.1);display:flex;flex-wrap:wrap;gap:16px;justify-content:space-between;font-size:.8rem;color:#7486a8}
.ftr-bottom a{color:#7486a8;font-size:.8rem}
.ftr .brand{color:#fff}
.ftr .brand .mark{background:#fff;color:var(--ink)}
.ftr .cta-phone{background:#d23c1f;border:0;color:#fff;padding:14px 28px;font-size:.82rem;font-weight:700;letter-spacing:.14em;text-transform:uppercase;border-radius:999px;box-shadow:0 6px 18px rgba(210,60,31,.32);transition:background .15s ease,box-shadow .15s ease}
.ftr .cta-phone:hover{background:#b4301a;color:#fff;box-shadow:0 8px 22px rgba(210,60,31,.45)}

/* About / Contact hero — shared with service-hero image */
.about-hero{position:relative;background:#0a1f3d url("/assets/img/main.jpeg") center/cover no-repeat;color:#fff;padding:88px 0 96px;overflow:hidden}
.about-hero::before{content:"";position:absolute;inset:0;background:linear-gradient(135deg,rgba(10,31,61,.78) 0%,rgba(10,31,61,.6) 55%,rgba(10,31,61,.82) 100%);pointer-events:none}
.about-hero > .container{position:relative;z-index:1}
.about-crumbs{color:rgba(255,255,255,.78);font-size:.86rem;margin-bottom:22px;letter-spacing:.02em}
.about-crumbs a{color:rgba(255,255,255,.9);text-decoration:none}
.about-crumbs a:hover{color:#fff}
.about-hero h1{color:#fff;font-size:clamp(2.4rem,4.2vw,3.6rem);line-height:1.05;letter-spacing:-.02em;margin:0 0 14px;font-family:var(--f-display);font-weight:600}
.about-subhead{color:rgba(255,255,255,.88);font-size:1.08rem;line-height:1.55;max-width:60ch;margin:0}
.about-main{background:#fbfaf7;padding:80px 0 72px}
.about-main-grid{display:grid;grid-template-columns:1fr 1.1fr;gap:56px;align-items:start}
.about-main-media img{width:100%;height:auto;display:block;border-radius:10px;box-shadow:0 14px 36px rgba(0,0,0,.14);object-fit:cover;aspect-ratio:4/5}
.about-main-copy h2{font-size:clamp(1.8rem,2.8vw,2.4rem);color:var(--ink);line-height:1.15;letter-spacing:-.015em;margin:0 0 28px;font-family:var(--f-display);font-weight:600;max-width:20ch}
.about-copy{max-width:72ch;margin-bottom:32px}
.about-copy p{color:var(--ink-2);font-size:1rem;line-height:1.75;margin:0 0 18px}
.about-copy p:last-child{margin-bottom:0}
.about-copy a{color:#d23c1f;text-decoration:underline;text-underline-offset:3px}
.about-copy a:hover{color:#9e1220}
@media(max-width:960px){
  .about-main-grid{grid-template-columns:1fr;gap:32px}
  .about-main-media img{aspect-ratio:16/10;max-height:420px}
}
.about-cta{display:inline-block;background:#d23c1f;color:#fff!important;font-weight:700;font-size:.82rem;letter-spacing:.14em;text-transform:uppercase;padding:14px 32px;border-radius:999px;text-decoration:none;box-shadow:0 6px 18px rgba(210,60,31,.3);transition:background .15s ease,box-shadow .15s ease}
.about-cta:hover{background:#b4301a;box-shadow:0 8px 22px rgba(210,60,31,.42)}
.about-values{background:#fff;padding:72px 0}
.about-values-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:32px}
.about-value{text-align:center}
.about-value-ico{display:inline-grid;place-items:center;width:90px;height:90px;margin-bottom:22px}
.about-value-ico img{width:100%;height:100%;object-fit:contain;display:block}
.about-value h3{color:var(--ink);font-size:1.1rem;margin:0 0 8px;font-family:var(--f-display);font-weight:600;letter-spacing:-.005em}
.about-value p{color:var(--ink-2);font-size:.92rem;line-height:1.55;margin:0}
.about-mv{background:#fff;padding:72px 0 88px}
.about-mv-grid{display:flex;flex-direction:column;gap:56px}
.about-mv-block h2{font-size:clamp(2.2rem,3.6vw,3rem);color:var(--ink);line-height:1.1;margin:0 0 28px;font-family:var(--f-display);font-weight:700;letter-spacing:-.015em}
.about-mv-block p{color:var(--ink);font-size:1rem;line-height:1.65;margin:0;max-width:none}
.about-mv-goals ul{list-style:disc;padding-left:22px;margin:0;display:flex;flex-direction:column;gap:10px}
.about-mv-goals li{color:var(--ink);font-size:1rem;line-height:1.6;padding-left:0}
.about-mv-goals li::marker{color:var(--ink)}
@media(max-width:960px){
  .about-values-grid{grid-template-columns:repeat(3,1fr);gap:28px}
  .about-mv-grid{gap:40px}
}
@media(max-width:640px){
  .about-hero{padding:40px 0 52px}
  .about-main{padding:56px 0 52px}
  .about-values{padding:52px 0}
  .about-values-grid{grid-template-columns:1fr 1fr;gap:24px}
  .about-mv{padding:52px 0 64px}
}

/* Contact page — Location / Hours two-up */
.contact-info{background:#fbfaf7;padding:64px 0 40px}
.contact-info-grid{display:grid;grid-template-columns:1fr 1fr;gap:48px;max-width:860px;margin:0 auto}
.contact-info-block{text-align:center;padding:28px 20px}
.contact-info-ico{display:inline-grid;place-items:center;width:64px;height:64px;border-radius:50%;background:#fbeee6;color:#d23c1f;margin-bottom:16px}
.contact-info-ico svg{width:30px;height:30px;stroke:currentColor;fill:none;stroke-width:1.8;stroke-linecap:round;stroke-linejoin:round}
.contact-info-block h2{color:var(--ink);font-size:1.25rem;margin:0 0 10px;font-family:var(--f-display);font-weight:600;letter-spacing:-.005em}
.contact-info-block p{color:var(--ink-2);font-size:1rem;line-height:1.55;margin:0}
@media(max-width:640px){
  .contact-info{padding:48px 0 24px}
  .contact-info-grid{grid-template-columns:1fr;gap:12px}
}

/* Service page hero — main.jpeg background */
.service-hero{position:relative;background:#0a1f3d url("/assets/img/main.jpeg") center/cover no-repeat;color:#fff;padding:88px 0 96px;overflow:hidden}
.service-hero::before{content:"";position:absolute;inset:0;background:linear-gradient(135deg,rgba(10,31,61,.78) 0%,rgba(10,31,61,.6) 55%,rgba(10,31,61,.82) 100%);pointer-events:none}
.service-hero > .container{position:relative;z-index:1}
.service-hero .crumbs{color:rgba(255,255,255,.78);font-size:.86rem;margin-bottom:22px;background:transparent;padding:0;letter-spacing:.02em}
.service-hero .crumbs a{color:rgba(255,255,255,.9);text-decoration:none}
.service-hero .crumbs a:hover{color:#fff}
.service-hero .eyebrow{display:inline-block;color:#f6a777;font-size:.8rem;font-weight:700;letter-spacing:.16em;text-transform:uppercase;margin-bottom:14px}
.service-hero h1{color:#fff;font-size:clamp(2.2rem,4vw,3.4rem);line-height:1.08;letter-spacing:-.02em;margin:0;font-family:var(--f-display);font-weight:600;max-width:22ch}
@media(max-width:640px){.service-hero{padding:56px 0 64px}}
.service-copy h2{font-size:clamp(1.6rem,2.4vw,2.1rem);color:var(--ink);line-height:1.2;letter-spacing:-.015em;margin:48px 0 18px;font-family:var(--f-display);font-weight:600}
.service-copy h2:first-child{margin-top:0}
.service-copy p{color:var(--ink-2);font-size:1rem;line-height:1.75;margin:0 0 18px}
.service-copy p:last-child{margin-bottom:0}

/* Service page content blocks */
.svc-block{padding:96px 0}
.svc-block-split{background:#fff}
.svc-block-center{background:#fbfaf7;text-align:left}
.svc-block-center > .container{max-width:840px}
.svc-split-grid{display:grid;grid-template-columns:1fr 1.1fr;gap:72px;align-items:center}
.svc-block-reverse .svc-split-grid{grid-template-columns:1.1fr 1fr}
.svc-split-media{position:relative}
.svc-split-media img{width:100%;height:auto;display:block;border-radius:12px;box-shadow:0 18px 40px rgba(0,0,0,.14);aspect-ratio:4/5;object-fit:cover}
.svc-split-media::before{content:"";position:absolute;left:-18px;top:32px;bottom:32px;width:34px;background:#d23c1f;border-radius:10px;z-index:-1;box-shadow:0 10px 28px rgba(210,60,31,.22)}
.svc-block-reverse .svc-split-media::before{left:auto;right:-18px}
.svc-num{display:inline-block;color:#d23c1f;font-family:var(--f-display);font-weight:700;font-size:1.02rem;letter-spacing:.14em;margin-bottom:14px;position:relative;padding-left:40px}
.svc-num::before{content:"";position:absolute;left:0;top:50%;width:28px;height:2px;background:#d23c1f;transform:translateY(-50%)}
.svc-split-copy h2,.svc-block-center h2{font-size:clamp(1.8rem,2.8vw,2.4rem);color:var(--ink);line-height:1.15;letter-spacing:-.015em;margin:0 0 22px;font-family:var(--f-display);font-weight:600}
.svc-split-copy p,.svc-block-center > .container p{color:var(--ink-2);font-size:1rem;line-height:1.75;margin:0 0 18px}
.svc-split-copy p:last-child,.svc-block-center > .container p:last-of-type{margin-bottom:0}
.svc-list{list-style:none;padding:0;margin:0 0 18px;display:flex;flex-direction:column;gap:10px}
.svc-list li{color:var(--ink-2);font-size:1rem;line-height:1.6;padding-left:22px;position:relative}
.svc-list li::before{content:"";position:absolute;left:0;top:9px;width:8px;height:8px;border-radius:50%;background:#d23c1f}
.svc-list li strong{color:var(--ink);font-weight:700}
.svc-list-simple li{padding-left:22px}
.svc-list-simple li a{color:#d23c1f;font-weight:600;text-decoration:underline;text-underline-offset:3px}
.svc-list-simple li a:hover{color:#9e1220}
.svc-feature-row{display:flex;flex-wrap:wrap;gap:20px 36px;margin-top:32px;padding-top:28px;border-top:1px solid #e6dfd4}
.svc-feature{display:flex;align-items:center;gap:10px;color:var(--ink);font-size:.95rem}
.svc-feature-ico{width:24px;height:24px;border-radius:50%;background:#d23c1f;color:#fff;display:grid;place-items:center;font-size:.74rem;font-weight:700;flex-shrink:0}
.svc-cta-row{display:flex;align-items:center;gap:22px;flex-wrap:wrap;margin-top:28px}
.svc-cta-btn{display:inline-flex;align-items:center;gap:12px;background:#d23c1f;color:#fff!important;font-weight:700;font-size:.8rem;letter-spacing:.14em;text-transform:uppercase;padding:14px 16px 14px 30px;border-radius:999px;text-decoration:none;box-shadow:0 6px 18px rgba(210,60,31,.3);transition:background .15s ease,box-shadow .15s ease}
.svc-cta-btn:hover{background:#b4301a;box-shadow:0 8px 22px rgba(210,60,31,.42)}
.svc-cta-arrow{width:28px;height:28px;border-radius:50%;background:#fff;display:grid;place-items:center}
.svc-cta-arrow svg{width:12px;height:12px;stroke:#d23c1f;fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}
.svc-cta-tel{color:var(--ink);font-weight:600;font-size:.95rem;text-decoration:none;border-bottom:1px solid #d2c9b9}
.svc-cta-tel:hover{color:#d23c1f;border-bottom-color:#d23c1f}
@media(max-width:900px){
  .svc-block{padding:64px 0}
  .svc-split-grid{grid-template-columns:1fr;gap:36px}
  .svc-block-reverse .svc-split-grid{grid-template-columns:1fr}
  .svc-block-reverse .svc-split-media{order:-1}
  .svc-split-media img{aspect-ratio:16/10;max-height:380px}
  .svc-split-media::before{left:-10px;top:16px;bottom:16px;width:22px}
  .svc-block-reverse .svc-split-media::before{left:auto;right:-10px}
}

/* ========== Projects page ========== */
.proj-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:36px}
@media(max-width:900px){.proj-grid{grid-template-columns:repeat(2,1fr);gap:18px}}
@media(max-width:560px){.proj-grid{grid-template-columns:1fr}}
.proj-card{background:#fff;border:1px solid var(--line);border-radius:14px;overflow:hidden;display:flex;flex-direction:column;transition:transform .25s ease,box-shadow .25s ease,border-color .25s ease;scroll-margin-top:120px}
.proj-card:target{border-color:#d23c1f;box-shadow:0 0 0 3px rgba(210,60,31,.12),0 18px 40px rgba(210,60,31,.18)}
.proj-card:hover{transform:translateY(-4px);box-shadow:0 18px 40px rgba(0,0,0,.1);border-color:#d2c9b9}
.proj-card-img{width:100%;aspect-ratio:4/3;overflow:hidden;background:#e6dfd4;position:relative}
.proj-card-img img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .5s ease}
.proj-card:hover .proj-card-img img{transform:scale(1.04)}
.proj-card-tag{position:absolute;top:14px;left:14px;background:#d23c1f;color:#fff;font-size:.68rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;padding:5px 11px;border-radius:4px;z-index:1;box-shadow:0 4px 12px rgba(0,0,0,.18)}
.proj-card-body{padding:22px 22px 24px;flex:1;display:flex;flex-direction:column}
.proj-card-loc{font-size:.72rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:#d23c1f;margin:0 0 8px}
.proj-card h3{font-size:1.08rem;margin:0 0 12px;color:var(--ink);font-family:var(--f-display);font-weight:600;line-height:1.25;letter-spacing:-.005em}
.proj-card-desc{color:var(--ink-2);font-size:.9rem;line-height:1.55;margin:0 0 16px;flex:1}
.proj-card-cost{font-size:.92rem;color:var(--ink);font-weight:600;border-top:1px solid var(--line);padding-top:14px;margin:0;font-family:var(--f-display);letter-spacing:-.005em}
.proj-card-cost span{display:block;font-size:.66rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-3);margin-bottom:4px;font-family:var(--f-sans)}

/* ========== Project detail pages ========== */
.pd-summary{padding:clamp(32px,4vw,48px) 0;background:#fbfaf7;border-bottom:1px solid var(--line)}
.pd-summary-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:24px}
@media(max-width:780px){.pd-summary-grid{grid-template-columns:repeat(2,1fr);gap:18px}}
@media(max-width:420px){.pd-summary-grid{grid-template-columns:1fr;gap:14px}}
.pd-summary-item{padding:0;border-left:3px solid #d23c1f;padding-left:16px}
.pd-summary-item span{display:block;font-size:.66rem;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-3);margin-bottom:6px}
.pd-summary-item strong{display:block;font-size:1.02rem;color:var(--ink);font-weight:600;font-family:var(--f-display);line-height:1.3;letter-spacing:-.005em}

.pd-scope-list{list-style:none;padding:0;margin:24px 0 0;display:grid;grid-template-columns:repeat(2,1fr);gap:12px 24px}
@media(max-width:600px){.pd-scope-list{grid-template-columns:1fr}}
.pd-scope-list li{display:flex;align-items:flex-start;gap:10px;color:var(--ink-2);font-size:.95rem;line-height:1.5}
.pd-scope-list li::before{content:"";flex-shrink:0;width:18px;height:18px;border-radius:50%;background:#d23c1f;margin-top:3px;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23fff' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='4 12 10 18 20 6'/%3E%3C/svg%3E");background-position:center;background-repeat:no-repeat;background-size:11px 11px}

.pd-related{padding:clamp(48px,6vw,72px) 0;background:#fff;border-top:1px solid var(--line)}
.pd-related-head{text-align:center;margin-bottom:32px}
.pd-related-head .eyebrow{color:#d23c1f;margin-bottom:10px}
.pd-related-head h2{font-size:clamp(1.4rem,2.4vw,1.9rem);color:var(--ink);line-height:1.18;margin:0;font-family:var(--f-display);font-weight:600}
.pd-related-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
@media(max-width:900px){.pd-related-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:560px){.pd-related-grid{grid-template-columns:1fr}}

/* Make .proj-card clickable as <a> */
a.proj-card{text-decoration:none;color:inherit}
a.proj-card:hover{color:inherit}

/* ========== Reviews page (grid of polished review cards) ========== */
.reviews-page-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-top:36px}
@media(max-width:1000px){.reviews-page-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:640px){.reviews-page-grid{grid-template-columns:1fr}}
.reviews-meta-bar{display:flex;align-items:center;gap:16px;flex-wrap:wrap;background:#fff;border:1px solid var(--line);border-radius:12px;padding:18px 22px;margin-top:24px}
.reviews-meta-bar .reviews-meta-stars{color:#f5a524;font-size:1.1rem;letter-spacing:.1em;line-height:1}
.reviews-meta-bar strong{font-family:var(--f-display);font-size:1.4rem;color:var(--ink);font-weight:600}
.reviews-meta-bar span{color:var(--ink-2);font-size:.92rem}

/* ========== Blog page (article cards with featured image) ========== */
.blog-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:24px;margin-top:36px}
@media(max-width:760px){.blog-grid{grid-template-columns:1fr;gap:18px}}
.blog-card{background:#fff;border:1px solid var(--line);border-radius:14px;overflow:hidden;display:flex;flex-direction:column;text-decoration:none;color:inherit;transition:transform .25s ease,box-shadow .25s ease,border-color .25s ease}
.blog-card:hover{transform:translateY(-4px);box-shadow:0 18px 40px rgba(0,0,0,.1);border-color:#d2c9b9;color:inherit}
.blog-card-img{width:100%;aspect-ratio:16/9;overflow:hidden;background:#e6dfd4;position:relative}
.blog-card-img img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .5s ease}
.blog-card:hover .blog-card-img img{transform:scale(1.04)}
.blog-card-cat{position:absolute;top:14px;left:14px;background:rgba(10,31,61,.92);color:#fff;font-size:.68rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;padding:5px 11px;border-radius:4px;z-index:1;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px)}
.blog-card-body{padding:24px 24px 26px;flex:1;display:flex;flex-direction:column}
.blog-card h3{font-size:1.18rem;margin:0 0 10px;color:var(--ink);font-family:var(--f-display);font-weight:600;line-height:1.25;letter-spacing:-.01em}
.blog-card p{color:var(--ink-2);font-size:.94rem;line-height:1.55;margin:0 0 18px;flex:1}
.blog-card-more{display:inline-flex;align-items:center;gap:8px;color:#d23c1f;font-size:.78rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase}
.blog-card-more svg{width:14px;height:14px;stroke:currentColor;fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round;transition:transform .2s ease}
.blog-card:hover .blog-card-more svg{transform:translateX(3px)}

/* ========== Pricing-index sub-page cards (with image header) ========== */
.price-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin:32px 0 20px}
@media(max-width:900px){.price-grid{grid-template-columns:1fr;gap:14px}}
.price-card{background:#fff;border:1px solid var(--line);border-radius:14px;overflow:hidden;display:flex;flex-direction:column;text-decoration:none;color:inherit;transition:transform .25s ease,box-shadow .25s ease,border-color .25s ease}
.price-card:hover{transform:translateY(-4px);box-shadow:0 18px 40px rgba(0,0,0,.1);border-color:#d2c9b9;color:inherit}
.price-card-img{width:100%;aspect-ratio:16/9;overflow:hidden;background:#e6dfd4}
.price-card-img img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .5s ease}
.price-card:hover .price-card-img img{transform:scale(1.04)}
.price-card-body{padding:22px 22px 24px}
.price-card h3{font-size:1.1rem;margin:0 0 8px;color:var(--ink);font-family:var(--f-display);font-weight:600;line-height:1.25}
.price-card p{color:var(--ink-2);font-size:.92rem;line-height:1.55;margin:0 0 14px}
.price-card-more{color:#d23c1f;font-size:.78rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase}

/* ========== Free-Estimate page ========== */
.fe-hero-sub{color:rgba(255,255,255,.9);font-size:clamp(1rem,1.4vw,1.15rem);line-height:1.55;max-width:58ch;margin:18px 0 0}
.fe-hero-pills{display:flex;flex-wrap:wrap;gap:10px;margin-top:26px}
.fe-pill{display:inline-flex;align-items:center;gap:8px;background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.24);color:#fff;font-size:.78rem;font-weight:600;letter-spacing:.04em;padding:8px 14px;border-radius:999px;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px)}
.fe-pill svg{width:14px;height:14px;stroke:#f6a777;fill:none;stroke-width:2.4;stroke-linecap:round;stroke-linejoin:round}

.fe-steps{padding:clamp(48px,6vw,80px) 0;background:#fbfaf7}
.fe-steps-head,.fe-faq-head{text-align:center;max-width:680px;margin:0 auto clamp(28px,3.5vw,44px)}
.fe-steps-head .eyebrow,.fe-faq-head .eyebrow{color:#d23c1f;margin-bottom:10px}
.fe-steps-head h2,.fe-faq-head h2{font-size:clamp(1.5rem,2.5vw,2.05rem);color:var(--ink);line-height:1.18;letter-spacing:-.015em;margin:0 0 10px;font-family:var(--f-display);font-weight:600}
.fe-steps-head p{color:var(--ink-2);font-size:.98rem;line-height:1.55;margin:0}
.fe-steps-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}
@media(max-width:900px){.fe-steps-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:520px){.fe-steps-grid{grid-template-columns:1fr}}
.fe-step{background:#fff;border:1px solid var(--line);border-radius:12px;padding:24px 22px;position:relative;transition:transform .2s ease,box-shadow .2s ease}
.fe-step:hover{transform:translateY(-3px);box-shadow:0 12px 28px rgba(0,0,0,.08)}
.fe-step-num{display:inline-grid;place-items:center;width:36px;height:36px;border-radius:50%;background:#d23c1f;color:#fff;font-family:var(--f-display);font-weight:700;font-size:1rem;margin-bottom:14px}
.fe-step h3{font-size:1.05rem;margin:0 0 8px;color:var(--ink);font-family:var(--f-display);font-weight:600;line-height:1.25}
.fe-step p{font-size:.92rem;color:var(--ink-2);line-height:1.55;margin:0}

.fe-form-section{padding:clamp(56px,7vw,88px) 0;background:#fff}
.fe-form-grid{display:grid;grid-template-columns:1fr 1.05fr;gap:48px;align-items:start}
@media(max-width:900px){.fe-form-grid{grid-template-columns:1fr;gap:36px}}
.fe-value h2{font-size:clamp(1.6rem,2.6vw,2.15rem);color:var(--ink);line-height:1.15;letter-spacing:-.015em;margin:0 0 18px;font-family:var(--f-display);font-weight:600}
.fe-value > p{color:var(--ink-2);font-size:1rem;line-height:1.65;margin:0 0 24px}
.fe-value-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:14px}
.fe-value-list li{display:flex;align-items:flex-start;gap:14px;color:var(--ink);font-size:.98rem;line-height:1.55}
.fe-check{flex-shrink:0;width:26px;height:26px;border-radius:50%;background:#d23c1f;color:#fff;display:grid;place-items:center;margin-top:1px}
.fe-check svg{width:13px;height:13px;stroke:currentColor;fill:none;stroke-width:2.6;stroke-linecap:round;stroke-linejoin:round}
.fe-value-list strong{color:var(--ink);font-weight:600}
.fe-form-card{background:#fbfaf7;border:1px solid var(--line);border-radius:14px;padding:clamp(22px,3vw,32px);box-shadow:0 14px 38px rgba(10,31,61,.08)}
.fe-form-card h3{font-size:1.15rem;margin:0 0 6px;color:var(--ink);font-family:var(--f-display);font-weight:600}
.fe-form-meta{font-size:.82rem;color:var(--ink-3);margin:0 0 18px}
.fe-form-meta strong{color:#d23c1f;font-weight:700}
.fe-form-card form .field{margin-bottom:13px}
.fe-form-card form input,.fe-form-card form select,.fe-form-card form textarea{width:100%;padding:11px 13px;border:1px solid var(--line-2);border-radius:6px;font:inherit;color:var(--ink);background:#fff;font-size:.95rem;transition:border-color .12s ease,box-shadow .12s ease}
.fe-form-card form input:focus,.fe-form-card form select:focus,.fe-form-card form textarea:focus{border-color:#d23c1f;outline:none;box-shadow:0 0 0 3px rgba(210,60,31,.12)}
.fe-form-card form label{display:block;font-weight:600;color:var(--ink);margin-bottom:5px;font-size:.74rem;letter-spacing:.04em;text-transform:uppercase}
.fe-form-card .row{display:grid;grid-template-columns:1fr 1fr;gap:10px}
@media(max-width:480px){.fe-form-card .row{grid-template-columns:1fr}}
.fe-checkbox{display:flex;align-items:center;gap:10px;font-size:.88rem;color:var(--ink-2);font-weight:500;text-transform:none;letter-spacing:0;margin-bottom:16px;cursor:pointer}
.fe-checkbox input{width:auto;margin:0;accent-color:#d23c1f}
.fe-submit{width:100%;background:#d23c1f;color:#fff;font-weight:700;font-size:.85rem;letter-spacing:.08em;text-transform:uppercase;padding:15px 20px;border:0;border-radius:8px;cursor:pointer;transition:background .15s ease,box-shadow .15s ease;box-shadow:0 6px 18px rgba(210,60,31,.3)}
.fe-submit:hover{background:#b4301a;box-shadow:0 8px 22px rgba(210,60,31,.42)}
.fe-form-fine{font-size:.78rem;color:var(--ink-3);margin:14px 0 0;line-height:1.5}

.fe-trust{padding:clamp(40px,5vw,64px) 0;background:#0a1f3d;color:#fff}
.fe-trust-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;text-align:center}
@media(max-width:760px){.fe-trust-grid{grid-template-columns:repeat(2,1fr);gap:32px}}
.fe-trust-stat strong{display:block;font-family:var(--f-display);font-weight:600;font-size:clamp(1.6rem,2.6vw,2.15rem);color:#fff;line-height:1;margin-bottom:8px;letter-spacing:-.01em}
.fe-trust-stat strong em{color:#f6a777;font-style:normal}
.fe-trust-stat span{display:block;font-size:.78rem;color:rgba(255,255,255,.78);letter-spacing:.06em;text-transform:uppercase;font-weight:600}

.fe-quote{padding:clamp(56px,7vw,84px) 0;background:#fbfaf7;text-align:center}
.fe-quote-stars{color:#d23c1f;font-size:1.1rem;letter-spacing:.1em;margin:0 0 18px}
.fe-quote blockquote{font-family:var(--f-display);font-style:italic;font-weight:500;font-size:clamp(1.2rem,2vw,1.55rem);line-height:1.4;color:var(--ink);max-width:780px;margin:0 auto 20px;letter-spacing:-.005em;quotes:none}
.fe-quote cite{font-style:normal;font-size:.92rem;color:var(--ink-3);font-weight:500}
.fe-quote cite strong{color:var(--ink);font-weight:700;display:block;margin-bottom:2px;font-size:1rem}

.fe-faq{padding:clamp(56px,7vw,84px) 0;background:#fff}
.fe-faq-list{max-width:780px;margin:0 auto;display:flex;flex-direction:column;gap:10px}
.fe-faq-list details{background:#fbfaf7;border:1px solid var(--line);border-radius:10px;overflow:hidden;transition:box-shadow .15s ease}
.fe-faq-list details[open]{box-shadow:0 4px 16px rgba(0,0,0,.06)}
.fe-faq-list summary{cursor:pointer;list-style:none;padding:18px 22px;font-weight:600;color:var(--ink);font-size:1rem;display:flex;align-items:center;justify-content:space-between;gap:14px;font-family:var(--f-display)}
.fe-faq-list summary::-webkit-details-marker{display:none}
.fe-faq-list summary::after{content:"+";font-size:1.4rem;color:#d23c1f;font-weight:400;line-height:1;transition:transform .2s ease}
.fe-faq-list details[open] summary::after{content:"−"}
.fe-faq-body{padding:0 22px 20px;color:var(--ink-2);font-size:.95rem;line-height:1.6}

/* Project gallery (service pages) — masonry columns so portrait phone shots aren't cropped */
.svc-gallery{padding:clamp(48px,6vw,80px) 0;background:#fbfaf7}
.svc-gallery-head{text-align:center;max-width:680px;margin:0 auto clamp(28px,3.5vw,44px)}
.svc-gallery-eyebrow{display:inline-block;font-size:.7rem;font-weight:700;letter-spacing:.16em;text-transform:uppercase;color:#d23c1f;margin-bottom:12px}
.svc-gallery-head h2{font-size:clamp(1.5rem,2.5vw,2.05rem);color:var(--ink);line-height:1.18;letter-spacing:-.015em;margin:0 0 10px;font-family:var(--f-display);font-weight:600}
.svc-gallery-head p{color:var(--ink-2);font-size:.98rem;line-height:1.55;margin:0}
.svc-gallery-grid{column-count:4;column-gap:16px}
@media(max-width:1100px){.svc-gallery-grid{column-count:3}}
@media(max-width:760px){.svc-gallery-grid{column-count:2;column-gap:12px}}
@media(max-width:420px){.svc-gallery-grid{column-count:1}}
.svc-gallery-item{break-inside:avoid;-webkit-column-break-inside:avoid;page-break-inside:avoid;display:block;margin:0 0 16px;border-radius:10px;overflow:hidden;box-shadow:0 4px 14px rgba(0,0,0,.1);background:#e8e2d5;transition:transform .25s ease,box-shadow .25s ease;cursor:zoom-in}
@media(max-width:760px){.svc-gallery-item{margin-bottom:12px;border-radius:8px}}
.svc-gallery-item:hover{transform:translateY(-3px);box-shadow:0 12px 28px rgba(0,0,0,.18)}
.svc-gallery-item img{width:100%;height:auto;display:block;transition:transform .4s ease}
.svc-gallery-item:hover img{transform:scale(1.04)}

/* Full-width red CTA band (service pages) */
.svc-cta-band{background:#d23c1f;color:#fff;padding:56px 0;width:100%}
.svc-cta-band-row{display:flex;align-items:center;justify-content:space-between;gap:28px;flex-wrap:wrap}
.svc-cta-band-text h2{color:#fff;font-size:clamp(1.6rem,2.6vw,2.15rem);line-height:1.15;letter-spacing:-.01em;margin:0 0 8px;font-family:var(--f-display);font-weight:600}
.svc-cta-band-text p{color:rgba(255,255,255,.9);font-size:1rem;margin:0;line-height:1.5}
.svc-cta-band-actions{display:flex;align-items:center;gap:12px;flex-wrap:wrap}
.svc-cta-band-primary{background:#0a1f3d;color:#fff!important;font-weight:700;font-size:.85rem;letter-spacing:.04em;padding:14px 28px;border-radius:6px;text-decoration:none;transition:background .15s ease}
.svc-cta-band-primary:hover{background:#061531;color:#fff!important}
.svc-cta-band-ghost{border:1px solid #0a1f3d;color:#0a1f3d!important;font-weight:700;font-size:.85rem;letter-spacing:.04em;padding:13px 26px;border-radius:6px;text-decoration:none;transition:background .15s ease,color .15s ease}
.svc-cta-band-ghost:hover{background:#0a1f3d;color:#fff!important}
@media(max-width:640px){
  .svc-cta-band{padding:40px 0}
  .svc-cta-band-row{flex-direction:column;align-items:flex-start}
  .svc-cta-band-actions{width:100%}
  .svc-cta-band-primary,.svc-cta-band-ghost{flex:1;text-align:center}
}

/* Back to top floating button */
.back-to-top{position:fixed;right:24px;bottom:24px;width:48px;height:48px;border-radius:50%;background:#d23c1f;border:0;color:#fff;cursor:pointer;display:grid;place-items:center;box-shadow:0 8px 22px rgba(210,60,31,.32);opacity:0;transform:translateY(10px);transition:opacity .25s ease,transform .25s ease,background .15s ease,box-shadow .15s ease;z-index:70}
.back-to-top[hidden]{display:none}
.back-to-top.is-visible{opacity:1;transform:translateY(0)}
.back-to-top:hover{background:#b4301a;box-shadow:0 10px 26px rgba(210,60,31,.44)}
.back-to-top:focus-visible{outline:2px solid #fff;outline-offset:2px}
.back-to-top svg{width:20px;height:20px;stroke:#fff;fill:none;stroke-width:2.4;stroke-linecap:round;stroke-linejoin:round}
@media(max-width:640px){.back-to-top{right:16px;bottom:96px;width:44px;height:44px}.back-to-top svg{width:18px;height:18px}}
@media(max-width:800px){.ftr-top{grid-template-columns:1fr 1fr;gap:36px}}
@media(max-width:500px){.ftr-top{grid-template-columns:1fr;gap:30px}}

/* Sticky mobile call bar */
.mobcall{display:none;position:fixed;left:0;right:0;bottom:0;background:#fff;border-top:1px solid var(--line);z-index:70;padding:10px;gap:8px}
.mobcall a{flex:1;text-align:center;padding:12px;border-radius:4px;font-weight:500;font-size:.88rem;border:1px solid transparent}
.mobcall .call{background:var(--ink);color:#fff;border-color:var(--ink)}
.mobcall .quote{background:#fff;color:var(--ink);border-color:var(--line-2)}
@media(max-width:700px){.mobcall{display:flex} body{padding-bottom:72px}}

/* Forms */
.form{background:#fff;border:1px solid var(--line);border-radius:var(--r-lg);padding:28px}
.form label{display:block;font-weight:500;color:var(--ink);margin-bottom:6px;font-size:.82rem;letter-spacing:-.005em}
.form input,.form select,.form textarea{width:100%;padding:11px 14px;border:1px solid var(--line-2);border-radius:4px;font:inherit;color:var(--ink);background:#fff;transition:border-color .12s ease;font-size:.95rem}
.form input:focus,.form select:focus,.form textarea:focus{border-color:var(--ink);outline:none}
.form input::placeholder,.form textarea::placeholder{color:var(--mute)}
.form .row{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.form .field{margin-bottom:14px}
@media(max-width:560px){.form .row{grid-template-columns:1fr}}

/* Breadcrumb */
.crumbs{font-size:.82rem;color:var(--mute);padding:28px 0 0;letter-spacing:-.005em}
.crumbs a{color:var(--mute)}
.crumbs a:hover{color:var(--ink)}

/* CTA band — editorial, two-tone */
.ctaband{background:var(--ink);color:#fff;border-radius:var(--r-lg);padding:56px 60px;display:grid;grid-template-columns:1.3fr .7fr;gap:24px;align-items:center;border:1px solid var(--navy-2)}
.ctaband h2{color:#fff;margin:0;font-size:clamp(1.5rem,2.4vw,2rem)}
.ctaband p{color:#b3bbc8;margin:.5em 0 0;font-size:.98rem}
.ctaband .actions{display:flex;gap:10px;flex-wrap:wrap;justify-content:flex-end}
.ctaband .btn-primary{background:#fff;color:var(--ink);border-color:#fff}
.ctaband .btn-primary:hover{background:var(--cream);color:var(--ink);border-color:var(--cream)}
.ctaband .btn-ghost{color:#fff;border-color:rgba(255,255,255,.22)}
.ctaband .btn-ghost:hover{background:rgba(255,255,255,.08);border-color:rgba(255,255,255,.45);color:#fff}
@media(max-width:780px){.ctaband{grid-template-columns:1fr;padding:40px 32px}.ctaband .actions{justify-content:flex-start}}

/* Utilities */
.center{text-align:center}
.mt-0{margin-top:0}.mt-1{margin-top:8px}.mt-2{margin-top:16px}.mt-3{margin-top:24px}.mt-4{margin-top:32px}.mt-5{margin-top:48px}
.mb-0{margin-bottom:0}
.small{font-size:.82rem;color:var(--mute)}
.pill{display:inline-block;background:transparent;color:var(--ink-2);border:1px solid var(--line-2);padding:3px 10px;border-radius:3px;font-size:.72rem;font-weight:500;letter-spacing:.02em;text-transform:uppercase}
.grid-2-3{display:grid;grid-template-columns:1.15fr .85fr;gap:56px}
@media(max-width:900px){.grid-2-3{grid-template-columns:1fr;gap:36px}}

/* Raising the Roof on Trust — about section */
.raising-grid{display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:center}
.raising-media{position:relative}
.raising-media::before{content:"";position:absolute;left:-22px;top:40px;bottom:40px;width:44px;background:#d23c1f;border-radius:12px;z-index:0;box-shadow:0 10px 28px rgba(210,60,31,.22)}
.raising-media img{position:relative;z-index:1;width:100%;height:auto;display:block;border-radius:10px;box-shadow:0 12px 30px rgba(0,0,0,.12)}
@media(max-width:900px){.raising-media::before{left:-14px;top:-18px;bottom:-18px;width:30px}}
.raising-copy h2{font-size:clamp(1.9rem,3vw,2.6rem);margin:10px 0 22px;letter-spacing:-.015em;line-height:1.12}
.raising-copy p{color:var(--ink-2);font-size:1rem;line-height:1.65;margin:0 0 18px}
.raising-copy p:last-child{margin-bottom:0}
.raising-link{color:#d23c1f;text-decoration:underline;text-underline-offset:3px;text-decoration-thickness:1px;transition:color .15s ease,text-decoration-color .15s ease}
.raising-link:hover{color:#9e1220;text-decoration-color:#9e1220}
@media(max-width:900px){.raising-grid{grid-template-columns:1fr;gap:36px}}

/* Special Discount Strip — dark navy 3-col banner */
.discount-strip{background:#0a1f3d;color:#fff;padding:44px 0}
.discount-strip-row{display:grid;grid-template-columns:1.1fr 1fr auto;align-items:center;gap:0}
.discount-col{padding:12px 40px}
.discount-col-1{padding-left:0}
.discount-col-2{border-left:1px solid rgba(255,255,255,.14);border-right:1px solid rgba(255,255,255,.14)}
.discount-col-3{padding-right:0;justify-self:end}
.discount-eyebrow{display:block;color:#f28a2a;font-weight:600;font-size:.95rem;letter-spacing:0;margin-bottom:10px;line-height:1.3}
.discount-col-1 h2{color:#fff;font-size:clamp(1.7rem,2.4vw,2.15rem);line-height:1.15;margin:0;letter-spacing:-.01em;font-family:var(--f-display);font-weight:600}
.discount-col-2 h3{color:#f28a2a;font-size:clamp(1.5rem,2.1vw,1.95rem);line-height:1.2;margin:0;letter-spacing:-.005em;font-family:var(--f-display);font-weight:600}
.discount-cta{display:inline-block;background:#d23c1f;color:#fff!important;font-weight:700;font-size:.82rem;letter-spacing:.12em;text-transform:uppercase;padding:16px 36px;border-radius:999px;text-decoration:none;box-shadow:0 4px 14px rgba(210,60,31,.28);transition:background .15s ease,box-shadow .15s ease;white-space:nowrap}
.discount-cta:hover{background:#b4301a;color:#fff!important;box-shadow:0 6px 18px rgba(210,60,31,.38)}
@media(max-width:900px){
  .discount-strip-row{grid-template-columns:1fr;gap:26px}
  .discount-col{padding:0}
  .discount-col-2{border-left:0;border-right:0;border-top:1px solid rgba(255,255,255,.14);border-bottom:1px solid rgba(255,255,255,.14);padding:22px 0}
  .discount-col-3{justify-self:start}
}

/* Video Frame — clean */
.video-frame{background:#fff;padding:88px 0 96px}
.video-head{text-align:center;max-width:680px;margin:0 auto 36px}
.video-eyebrow{display:inline-block;color:var(--accent,#d23c1f);font-size:.78rem;font-weight:700;letter-spacing:.14em;text-transform:uppercase;margin-bottom:12px}
.video-head h2{font-size:clamp(1.9rem,3vw,2.6rem);margin:0;color:var(--ink);line-height:1.15;letter-spacing:-.015em}
.video-wrap{max-width:1200px;margin:0 auto}
.video-ratio{position:relative;width:100%;aspect-ratio:16/9;border-radius:12px;overflow:hidden;background:#000;box-shadow:0 20px 50px rgba(0,0,0,.18)}
.video-ratio iframe{position:absolute;inset:0;width:100%;height:100%;border:0;display:block;pointer-events:none}
.video-lock{position:absolute;inset:0;z-index:2;cursor:default;background:transparent}
@media(max-width:720px){.video-frame{padding:56px 0 64px}}

/* Your Property Our Priority — services carousel */
.priority{position:relative;background:#fbfaf7;padding:96px 0 104px;overflow:hidden}
.priority::before{content:"";position:absolute;inset:0;background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='800' height='800' viewBox='0 0 800 800'><g fill='none' stroke='%23d23c1f' stroke-width='.5' opacity='.08'><path d='M0 200 Q200 150 400 200 T800 200'/><path d='M0 280 Q200 230 400 280 T800 280'/><path d='M0 360 Q200 310 400 360 T800 360'/><path d='M0 440 Q200 390 400 440 T800 440'/><path d='M0 520 Q200 470 400 520 T800 520'/><path d='M0 600 Q200 550 400 600 T800 600'/></g></svg>");background-size:800px 800px;background-repeat:repeat;pointer-events:none;opacity:.9}
.priority > .container{position:relative;z-index:1}
.priority-head{display:grid;grid-template-columns:1fr 1.1fr;gap:40px;align-items:center;margin-bottom:56px}
.priority-title{font-size:clamp(2.2rem,3.6vw,3.2rem);color:var(--ink);line-height:1.08;letter-spacing:-.02em;margin:0;font-family:var(--f-display);font-weight:600}
.priority-pill{background:#b74621;color:#fff;border-radius:999px;padding:30px 48px;display:flex;flex-direction:column;gap:10px}
.priority-pill h3{color:#fff;font-size:1.3rem;margin:0;font-weight:700;letter-spacing:-.005em;line-height:1.25}
.priority-pill p{color:rgba(255,255,255,.92);font-size:.95rem;margin:0;line-height:1.5}
.priority-carousel-wrap{position:relative}
.priority-cards{display:grid;grid-template-columns:repeat(4,1fr);gap:28px;scroll-snap-type:x mandatory;overflow-x:auto;scrollbar-width:none;-ms-overflow-style:none;padding:6px 2px}
.priority-cards::-webkit-scrollbar{display:none}
.priority-card{scroll-snap-align:start;background:transparent;display:flex;flex-direction:column;min-width:0}
.priority-card-img{width:100%;aspect-ratio:4/3;overflow:hidden;border-radius:20px;margin-bottom:18px;background:#e6dfd4}
.priority-card-img img{width:100%;height:100%;object-fit:cover;display:block}
.priority-card h4{color:var(--ink);font-size:1.25rem;margin:0 0 10px;font-family:var(--f-display);font-weight:600;letter-spacing:-.005em}
.priority-card p{color:var(--ink-2);font-size:.92rem;line-height:1.55;margin:0 0 20px;flex-grow:1}
.priority-more{display:inline-flex;align-items:center;gap:10px;color:#d23c1f!important;font-weight:700;font-size:.78rem;letter-spacing:.12em;text-transform:uppercase;text-decoration:none;margin-top:auto;align-self:flex-start}
.priority-more:hover{color:#9e1220!important}
.priority-arrow-circle{width:22px;height:22px;border:1.5px solid #d23c1f;border-radius:50%;display:grid;place-items:center;transition:transform .15s ease,background .15s ease}
.priority-more:hover .priority-arrow-circle{transform:translateX(2px);background:#d23c1f;color:#fff;border-color:#d23c1f}
.priority-arrow-circle svg{width:9px;height:9px;stroke:currentColor;fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}
@media(max-width:960px){
  .priority-head{grid-template-columns:1fr;gap:28px;margin-bottom:40px}
  .priority-pill{padding:26px 32px;border-radius:28px}
  .priority-cards{grid-template-columns:repeat(7,minmax(260px,1fr));overflow-x:auto}
  .priority-card{min-width:260px}
}
@media(max-width:560px){
  .priority{padding:64px 0 72px}
  .priority-cards{grid-template-columns:repeat(7,80%);gap:18px}
}

/* Client Reviews — homepage */
.reviews-home{background:#fff;padding:96px 0 104px}
.reviews-home-head{text-align:center;max-width:720px;margin:0 auto 52px}
.reviews-home-eyebrow{display:inline-block;color:#d23c1f;font-size:.78rem;font-weight:700;letter-spacing:.14em;text-transform:uppercase;margin-bottom:14px}
.reviews-home-head h2{font-size:clamp(2rem,3.4vw,2.9rem);color:var(--ink);line-height:1.1;letter-spacing:-.02em;margin:0 0 18px;font-family:var(--f-display);font-weight:600}
.reviews-home-meta{display:inline-flex;align-items:center;gap:8px;flex-wrap:wrap;justify-content:center;color:var(--ink-2);font-size:.92rem}
.reviews-home-meta strong{color:var(--ink);font-size:1.04rem}
.reviews-home-stars{color:#f5a524;letter-spacing:.08em;font-size:1.05rem}
.reviews-carousel{position:relative;margin-bottom:42px;overflow:hidden;-webkit-mask-image:linear-gradient(90deg,transparent 0,#000 6%,#000 94%,transparent 100%);mask-image:linear-gradient(90deg,transparent 0,#000 6%,#000 94%,transparent 100%)}
.reviews-track{display:flex;gap:24px;width:max-content;animation:reviewsMarquee 90s linear infinite;will-change:transform;padding:6px 0 12px}
.reviews-carousel:hover .reviews-track{animation-play-state:paused}
.reviews-track .review-card{flex:0 0 360px;min-width:0}
@media(max-width:640px){.reviews-track{gap:16px}.reviews-track .review-card{flex:0 0 300px}}
@keyframes reviewsMarquee{from{transform:translateX(0)}to{transform:translateX(-50%)}}
.reviews-dots{display:none}
@media(prefers-reduced-motion:reduce){.reviews-track{animation:none}}
.reviews-home-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-bottom:48px}
.review-card{background:#fff;border:1px solid var(--line,#e6dfd4);border-radius:12px;padding:26px 26px 28px;display:flex;flex-direction:column;transition:transform .45s cubic-bezier(.4,0,.2,1),box-shadow .45s cubic-bezier(.4,0,.2,1),border-color .45s ease}
.review-card:hover{transform:translateY(-2px);box-shadow:0 10px 26px rgba(0,0,0,.06);border-color:#d2c9b9}
.reviews-track .review-card.is-center{transform:scale(1.06);box-shadow:0 18px 40px rgba(20,33,61,.14);border-color:#d23c1f;z-index:2}
.review-card-head{display:flex;align-items:center;gap:12px;margin-bottom:14px}
.review-avatar{width:42px;height:42px;border-radius:50%;background:linear-gradient(135deg,#d23c1f 0%,#9e1220 100%);color:#fff;font-weight:700;font-size:1rem;display:grid;place-items:center;flex-shrink:0;letter-spacing:.02em}
.review-who{flex:1;min-width:0;display:flex;flex-direction:column;line-height:1.25}
.review-who strong{color:var(--ink);font-size:.95rem;font-weight:600}
.review-who span{color:var(--ink-2);font-size:.78rem;margin-top:2px}
.review-source{width:28px;height:28px;border-radius:50%;background:#f4efe8;font-weight:700;font-size:.72rem;display:grid;place-items:center;flex-shrink:0;letter-spacing:-.02em}
.review-source-google{color:#4285f4}
.review-source-ha{color:#ff7f32;font-size:.66rem}
.review-stars{color:#f5a524;font-size:.95rem;letter-spacing:.1em;margin:0 0 10px}
.review-text{color:var(--ink-2);font-size:.92rem;line-height:1.6;margin:0}
.reviews-home-cta{text-align:center}
.reviews-home-more{display:inline-flex;align-items:center;gap:10px;color:#d23c1f!important;font-weight:700;font-size:.82rem;letter-spacing:.12em;text-transform:uppercase;text-decoration:none}
.reviews-home-more:hover{color:#9e1220!important}
.reviews-home-arrow{width:26px;height:26px;border:1.5px solid currentColor;border-radius:50%;display:grid;place-items:center;transition:transform .15s ease,background .15s ease,color .15s ease}
.reviews-home-more:hover .reviews-home-arrow{transform:translateX(2px);background:#d23c1f;color:#fff}
.reviews-home-arrow svg{width:10px;height:10px;stroke:currentColor;fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}
@media(max-width:960px){
  .reviews-home-grid{grid-template-columns:repeat(2,1fr)}
}
@media(max-width:640px){
  .reviews-home{padding:64px 0 72px}
  .reviews-home-grid{grid-template-columns:1fr;gap:16px}
}

/* Trust badges — What Sets Us Apart */
.trust-badges{background:#fff;padding:72px 0 90px}
.trust-head{text-align:center;max-width:720px;margin:0 auto 48px}
.trust-eyebrow{display:inline-block;color:#d23c1f;font-size:.92rem;font-weight:700;letter-spacing:0;margin-bottom:12px}
.trust-head h2{font-size:clamp(1.9rem,3vw,2.6rem);color:var(--ink);line-height:1.12;letter-spacing:-.015em;margin:0;font-family:var(--f-display);font-weight:600}
.trust-logos{display:flex;align-items:center;justify-content:center;gap:64px;flex-wrap:wrap}
.trust-badge{flex:0 0 auto;display:grid;place-items:center;transition:transform .2s ease,opacity .2s ease;opacity:.95}
.trust-badge:hover{transform:translateY(-2px);opacity:1}
.trust-badge img{display:block;max-width:100%;height:auto}
.trust-badge-screened img{width:150px;height:auto}
.trust-badge-toprated img{width:150px;height:auto}
.trust-badge-yelp img{width:220px;height:auto}
@media(max-width:640px){
  .trust-badges{padding:52px 0 64px}
  .trust-logos{gap:36px}
  .trust-badge-screened img,.trust-badge-toprated img{width:120px}
  .trust-badge-yelp img{width:170px}
}

/* Service area map — overlayed panel, sepia tint */
.map-section{position:relative;background:#fbfaf7;padding:0;min-height:560px;overflow:hidden}
.map-bg{position:absolute;inset:0;z-index:0;overflow:hidden}
.map-bg iframe{position:absolute;inset:0;width:100%;height:100%;border:0;display:block}
.map-tint{display:none}
.map-panel-wrap{position:relative;z-index:2;display:flex;justify-content:flex-end;padding:80px 28px;min-height:560px}
.map-panel{background:#fff;border-radius:14px;box-shadow:0 20px 50px rgba(0,0,0,.18);width:420px;max-width:100%;padding:34px 34px 30px;position:relative}
.map-panel .map-eyebrow{display:block;color:#d23c1f;font-size:1rem;font-weight:700;letter-spacing:0;margin-bottom:8px}
.map-panel h2{font-size:1.7rem;color:var(--ink);line-height:1.15;letter-spacing:-.01em;margin:0 0 22px;font-family:var(--f-display);font-weight:600}
.map-areas{list-style:none;padding:0;margin:0;max-height:360px;overflow-y:auto;padding-right:8px}
.map-areas::-webkit-scrollbar{width:6px}
.map-areas::-webkit-scrollbar-track{background:#f4efe8;border-radius:3px}
.map-areas::-webkit-scrollbar-thumb{background:#c9beaf;border-radius:3px}
.map-areas li{border-bottom:1px solid #eee6da}
.map-areas li:last-child{border-bottom:0}
.map-areas details{padding:0}
.map-areas summary{list-style:none;cursor:pointer;display:flex;align-items:center;gap:10px;padding:14px 10px;font-size:.95rem;font-weight:600;color:var(--ink);transition:background .15s ease,color .15s ease;border-radius:6px}
.map-areas summary::-webkit-details-marker{display:none}
.map-areas summary:hover{background:#faf6ef}
.map-num{color:var(--ink);font-weight:700;min-width:26px}
.map-name{flex:1}
.map-toggle{width:22px;height:22px;border-radius:50%;background:#f4efe8;display:grid;place-items:center;flex-shrink:0;position:relative;transition:background .15s ease}
.map-toggle::before,.map-toggle::after{content:"";position:absolute;background:var(--ink);transition:transform .2s ease,opacity .2s ease}
.map-toggle::before{width:10px;height:2px}
.map-toggle::after{width:2px;height:10px}
.map-areas details[open] summary{background:#b74621;color:#fff;border-radius:6px}
.map-areas details[open] summary .map-num{color:#fff}
.map-areas details[open] summary .map-toggle{background:rgba(255,255,255,.2)}
.map-areas details[open] summary .map-toggle::before,.map-areas details[open] summary .map-toggle::after{background:#fff}
.map-areas details[open] summary .map-toggle::after{transform:scaleY(0);opacity:0}
.map-body{padding:10px 10px 16px 36px;font-size:.88rem;color:var(--ink-2);line-height:1.55}
@media(max-width:900px){
  .map-section{min-height:auto}
  .map-bg{position:relative;height:340px}
  .map-panel-wrap{padding:24px 20px 48px;min-height:auto;justify-content:center;background:#fbfaf7}
  .map-panel{width:100%;max-width:560px;margin-top:-40px}
}

/* Book Your Home Exterior Service — contact form */
.book-form{background:#0a1f3d;color:#fff;padding:88px 0 100px}
.book-head{text-align:center;max-width:780px;margin:0 auto 48px}
.book-eyebrow{display:inline-block;color:#f28a2a;font-weight:700;font-size:1rem;margin-bottom:10px}
.book-head h2{color:#fff;font-size:clamp(1.9rem,3.2vw,2.7rem);line-height:1.1;letter-spacing:-.015em;margin:0;font-family:var(--f-display);font-weight:600}
.book-grid{max-width:1080px;margin:0 auto;display:grid;grid-template-columns:1.15fr .85fr;gap:56px;align-items:start}
.book-row-2{display:grid;grid-template-columns:1fr 1fr;gap:24px}
.book-fields{display:flex;flex-direction:column;gap:22px}
.book-field{display:flex;flex-direction:column;gap:8px}
.book-field label{color:#f28a2a;font-size:.95rem;font-weight:700}
.book-field input,.book-field textarea{background:#0f2950;color:#fff;border:1px solid rgba(255,255,255,.06);border-radius:16px;padding:18px 22px;font:inherit;font-size:1rem;width:100%;outline:0;transition:border-color .15s ease,box-shadow .15s ease}
.book-field input::placeholder,.book-field textarea::placeholder{color:rgba(255,255,255,.45)}
.book-field input:focus,.book-field textarea:focus{border-color:#f28a2a;box-shadow:0 0 0 3px rgba(242,138,42,.18)}
.book-field textarea{resize:vertical;min-height:120px;border-radius:14px}
.book-services h3{color:#fff;font-size:1.15rem;margin:0 0 6px;font-weight:700;letter-spacing:-.005em}
.book-note{color:rgba(255,255,255,.55);font-size:.82rem;margin:0 0 24px}
.book-check-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px 32px}
.book-check{display:flex;align-items:center;gap:12px;cursor:pointer;color:#fff;font-weight:600;font-size:.98rem;user-select:none}
.book-check input{position:absolute;opacity:0;pointer-events:none}
.book-check-dot{width:18px;height:18px;border-radius:50%;border:1.5px solid rgba(255,255,255,.45);display:grid;place-items:center;transition:border-color .15s ease,background .15s ease;flex-shrink:0}
.book-check-dot::after{content:"";width:10px;height:10px;border-radius:50%;background:#f28a2a;transform:scale(0);transition:transform .15s ease}
.book-check input:checked + .book-check-dot{border-color:#f28a2a}
.book-check input:checked + .book-check-dot::after{transform:scale(1)}
.book-check input:focus-visible + .book-check-dot{box-shadow:0 0 0 3px rgba(242,138,42,.25)}
.book-submit-row{grid-column:1 / -1;display:flex;justify-content:center;margin-top:20px}
.book-submit{background:#d23c1f;color:#fff;border:0;font-weight:700;font-size:.88rem;letter-spacing:.14em;text-transform:uppercase;padding:18px 54px;border-radius:999px;cursor:pointer;box-shadow:0 6px 18px rgba(210,60,31,.32);transition:background .15s ease,box-shadow .15s ease}
.book-submit:hover{background:#b4301a;box-shadow:0 8px 22px rgba(210,60,31,.45)}
@media(max-width:900px){
  .book-form{padding:56px 0 70px}
  .book-grid{grid-template-columns:1fr;gap:36px}
  .book-check-grid{gap:14px 20px}
}
@media(max-width:560px){
  .book-row-2{grid-template-columns:1fr;gap:22px}
  .book-field input,.book-field textarea{padding:14px 18px;font-size:.95rem}
  .book-submit{padding:15px 40px;width:100%}
}

/* Long-form prose */
.prose{max-width:72ch}
.prose h2{margin-top:2.4em;font-size:clamp(1.35rem,2vw,1.7rem)}
.prose h3{margin-top:1.8em}
.prose p,.prose li{color:var(--ink-2);font-size:1rem;line-height:1.72}
.prose a{color:var(--ink);text-decoration:underline;text-decoration-color:var(--line-2);text-underline-offset:4px;text-decoration-thickness:1px}
.prose a:hover{color:var(--accent);text-decoration-color:var(--accent)}
.prose blockquote{margin:1.8em 0;padding:20px 0 20px 24px;border-left:2px solid var(--ink);background:transparent;border-radius:0;font-family:var(--f-display);font-size:1.1rem;font-style:italic;color:var(--ink)}
.prose blockquote p{margin:0;color:var(--ink);font-size:inherit}
.prose blockquote em{font-size:.85rem;color:var(--mute);font-style:normal;display:block;margin-top:12px;font-family:var(--f-sans)}
.prose ol{counter-reset:ol}
.prose ol > li{list-style:none;position:relative;padding-left:2.2rem;margin:.5em 0}
.prose ol > li::before{counter-increment:ol;content:counter(ol,decimal-leading-zero);position:absolute;left:0;top:0;color:var(--mute);font-size:.78rem;font-weight:600;letter-spacing:.08em;font-family:var(--f-sans)}

/* Accent underline for links in hero/cards when needed */
.link-accent{color:var(--accent);border-bottom:1px solid var(--accent);padding-bottom:1px}
.link-accent:hover{color:var(--accent-2);border-color:var(--accent-2)}

/* Inline SVG icon system — currentColor + consistent sizing */
.i{display:inline-block;width:1em;height:1em;vertical-align:-.12em;stroke:currentColor;fill:none;stroke-width:1.5;stroke-linecap:round;stroke-linejoin:round;flex-shrink:0}
.card .ico{background:transparent;border:1px solid var(--line);color:var(--ink);font-size:1rem}
.card .ico .i{width:18px;height:18px;stroke-width:1.6;color:var(--ink-2)}
.card:hover .ico{border-color:var(--ink)}
.card:hover .ico .i{color:var(--ink)}

/* Phone icon via CSS mask — defined once, used sitewide */
.cta-phone::before,.mobcall .call::before,.emg-phone::before{
  content:"";display:inline-block;width:14px;height:14px;margin-right:8px;
  background:currentColor;vertical-align:-.12em;
  -webkit-mask:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='1.8' stroke-linecap='round' stroke-linejoin='round'><path d='M22 16.92v3a2 2 0 0 1-2.18 2 19.8 19.8 0 0 1-8.63-3.07 19.5 19.5 0 0 1-6-6A19.8 19.8 0 0 1 2.12 4.18 2 2 0 0 1 4.11 2h3a2 2 0 0 1 2 1.72 12.8 12.8 0 0 0 .7 2.81 2 2 0 0 1-.45 2.11L8.09 9.91a16 16 0 0 0 6 6l1.27-1.27a2 2 0 0 1 2.11-.45 12.8 12.8 0 0 0 2.81.7A2 2 0 0 1 22 16.92z'/></svg>") center/contain no-repeat;
  mask:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='1.8' stroke-linecap='round' stroke-linejoin='round'><path d='M22 16.92v3a2 2 0 0 1-2.18 2 19.8 19.8 0 0 1-8.63-3.07 19.5 19.5 0 0 1-6-6A19.8 19.8 0 0 1 2.12 4.18 2 2 0 0 1 4.11 2h3a2 2 0 0 1 2 1.72 12.8 12.8 0 0 0 .7 2.81 2 2 0 0 1-.45 2.11L8.09 9.91a16 16 0 0 0 6 6l1.27-1.27a2 2 0 0 1 2.11-.45 12.8 12.8 0 0 0 2.81.7A2 2 0 0 1 22 16.92z'/></svg>") center/contain no-repeat;
}
.emg-phone::before{width:18px;height:18px;margin-right:10px}

/* Alert bar for emergency page */
.abar.alert{background:#b91c1c;color:#fff;font-weight:500}
.abar.alert a{color:#fff;text-decoration:underline;font-weight:600}

/* Hero refinement */
.hero .eyebrow{margin-bottom:22px}
.hero-badges{gap:14px 22px}
.hero-cta .btn-ghost{color:var(--ink-2)}

/* Trust strip polish */
section[style*="navy-2"]{padding:22px 0}
.trust .item{font-size:.84rem}

/* Emergency page hero phone link */
.emg-phone{display:inline-flex;align-items:center;color:var(--accent);font-weight:700;font-size:1.35rem;text-decoration:none;letter-spacing:-.01em;font-family:var(--f-sans)}
.emg-phone:hover{color:var(--accent-2)}

/* Reduced motion */
@media (prefers-reduced-motion:reduce){*{animation:none!important;transition:none!important;scroll-behavior:auto!important}}
