/* Edge Garage Doors — shared site styles
   Companion to css/tokens.css */

* { box-sizing: border-box; }
html, body { margin: 0; padding: 0; background: var(--cream); color: var(--ink); font-family: var(--font-body); }
img { max-width: 100%; display: block; }
a { color: inherit; text-decoration: none; }
button { font: inherit; }

.container { max-width: 1280px; margin: 0 auto; padding: 0 48px; }
@media (max-width: 900px) { .container { padding: 0 24px; } }
.container-narrow { max-width: 880px; margin: 0 auto; padding: 0 48px; }
@media (max-width: 900px) { .container-narrow { padding: 0 24px; } }

/* ============ Top alert strip ============ */
.cta-strip {
  background: var(--edge-navy); color: var(--cream);
  padding: 10px 16px; text-align: center;
  font-family: var(--font-display); font-weight: 700; font-size: 13px;
  text-transform: uppercase; letter-spacing: 0.06em;
}
.cta-strip strong { color: var(--edge-orange); }
.cta-strip a { color: var(--edge-orange); margin-left: 6px; }
.cta-strip .dot {
  display: inline-block; width: 6px; height: 6px; border-radius: 50%;
  background: var(--edge-orange); margin-right: 8px; vertical-align: 1px;
  box-shadow: 0 0 0 3px #E85D2C40;
}
@media (max-width: 600px) { .cta-strip { font-size: 11px; letter-spacing: 0.04em; } }
/* Hide CTA strip on mobile — nav already has phone + quote button */
@media (max-width: 768px) { .cta-strip { display: none; } }

/* ============ Nav (multi-page) ============ */
.eg-nav {
  position: sticky; top: 0; z-index: 50;
  background: var(--cream);
  border-bottom: 1px solid transparent;
  transition: border-color var(--dur-base) var(--ease-out), box-shadow var(--dur-base);
}
.eg-nav.scrolled { border-bottom-color: var(--hairline); box-shadow: 0 1px 0 0 #1B2A4A08; }
.eg-nav .inner { height: 88px; display: flex; align-items: center; justify-content: space-between; }
.eg-nav .mark { display: flex; align-items: center; gap: 10px; }
.eg-nav .mark img { height: 52px; width: auto; }
.eg-nav .links { display: flex; gap: 28px; align-items: center; }
.eg-nav .right { display: flex; gap: 22px; align-items: center; }
.eg-nav .link, .eg-nav .dropdown > .link {
  font-family: var(--font-display); font-weight: 800; font-size: 15px;
  text-transform: uppercase; letter-spacing: 0.06em; color: var(--edge-navy);
  cursor: pointer; white-space: nowrap; padding: 8px 0;
  transition: color var(--dur-fast) var(--ease-out);
  display: inline-flex; align-items: center; gap: 6px;
}
.eg-nav .link:hover, .eg-nav .dropdown:hover > .link, .eg-nav .link.active { color: var(--edge-orange); }
.eg-nav .dropdown { position: relative; }
.eg-nav .dropdown .caret { display: inline-block; width: 0; height: 0; border-left: 4px solid transparent; border-right: 4px solid transparent; border-top: 5px solid currentColor; transform: translateY(1px); transition: transform var(--dur-fast); }
.eg-nav .dropdown:hover .caret { transform: translateY(1px) rotate(180deg); }
.eg-nav .panel {
  position: absolute; top: 100%; left: 50%; transform: translateX(-50%) translateY(4px);
  background: var(--paper); border-radius: var(--r-md); box-shadow: var(--shadow-3);
  padding: 18px; min-width: 520px;
  display: grid; grid-template-columns: 1fr 1fr; gap: 4px 24px;
  opacity: 0; pointer-events: none; transition: opacity var(--dur-fast) var(--ease-out), transform var(--dur-fast) var(--ease-out);
  border: 1px solid var(--hairline);
}
.eg-nav .panel.wide { min-width: 600px; grid-template-columns: 1fr 1fr 1fr; }
.eg-nav .dropdown:hover .panel { opacity: 1; pointer-events: auto; transform: translateX(-50%) translateY(0); }
.eg-nav .panel-item { display: block; padding: 10px 12px; border-radius: var(--r-sm); transition: background var(--dur-fast); }
.eg-nav .panel-item:hover { background: var(--cream); }
.eg-nav .panel-item strong { display: block; font-family: var(--font-display); font-weight: 800; font-size: 13px; color: var(--edge-navy); text-transform: uppercase; letter-spacing: 0.04em; }
.eg-nav .panel-item span { display: block; font-family: var(--font-body); font-size: 12px; color: var(--ink-3); margin-top: 2px; }
.eg-nav .panel-foot { grid-column: 1 / -1; margin-top: 6px; padding-top: 12px; border-top: 1px solid var(--hairline); display: flex; justify-content: space-between; align-items: center; padding-left: 12px; padding-right: 4px; }
.eg-nav .panel-foot span { font-family: var(--font-body); font-size: 12px; color: var(--ink-3); }
.eg-nav .panel-foot a { font-family: var(--font-display); font-weight: 800; font-size: 12px; text-transform: uppercase; letter-spacing: 0.06em; color: var(--edge-orange); }

.eg-nav .phone {
  font-family: var(--font-display); font-weight: 800; font-size: 16px;
  color: var(--edge-navy); display: flex; align-items: center; gap: 6px; white-space: nowrap;
}
.eg-nav .phone:hover { color: var(--edge-orange); }

/* Mobile nav */
.eg-nav .burger { display: none; background: transparent; border: 0; width: 44px; height: 44px; cursor: pointer; padding: 0; color: var(--edge-navy); }
.eg-nav .burger svg { width: 26px; height: 26px; }
@media (max-width: 1024px) {
  .eg-nav .links, .eg-nav .phone { display: none; }
  .eg-nav .burger { display: inline-flex; align-items: center; justify-content: center; }
  .eg-nav .inner { height: 68px; }
  .eg-nav .btn-primary { padding: 10px 18px; font-size: 13px; }
}
@media (max-width: 480px) {
  .eg-nav .inner { height: 60px; }
  .eg-nav .mark img { height: 42px; }
}
/* Mobile drawer — full-screen slide-in */
.mobile-drawer {
  position: fixed; inset: 0; background: var(--cream); z-index: 99;
  transform: translateX(100%); transition: transform var(--dur-base) var(--ease-out);
  display: flex; flex-direction: column;
  overflow-y: auto;
}
.mobile-drawer.open { transform: translateX(0); }
.mobile-drawer .md-head { display: flex; justify-content: space-between; align-items: center; padding: 16px 24px; border-bottom: 1px solid var(--hairline); }
.mobile-drawer .md-close { background: transparent; border: 0; cursor: pointer; padding: 8px; color: var(--edge-navy); }
.mobile-drawer .md-body { padding: 0 24px; flex: 1; }
.mobile-drawer .md-section { border-bottom: 1px solid var(--hairline); margin-bottom: 0; }
/* Accordion toggle (Services / Areas) */
.mobile-drawer .md-acc-toggle {
  width: 100%; background: transparent; border: 0; cursor: pointer;
  display: flex; justify-content: space-between; align-items: center;
  padding: 16px 0; text-align: left;
  font-family: var(--font-display); font-weight: 800; font-size: 17px;
  color: var(--edge-navy); text-transform: uppercase; letter-spacing: 0.05em;
}
.mobile-drawer .md-acc-icon { width: 20px; height: 20px; flex-shrink: 0; color: var(--edge-orange); transition: transform var(--dur-fast); }
.mobile-drawer .md-section.open .md-acc-icon { transform: rotate(180deg); }
.mobile-drawer .md-acc-body { max-height: 0; overflow: hidden; transition: max-height 0.35s ease; }
.mobile-drawer .md-section.open .md-acc-body { max-height: 900px; }
.mobile-drawer .md-section .md-acc-body .md-sublink:last-child { border-bottom: none; }
/* Regular top-level links */
.mobile-drawer a.md-link { display: block; padding: 16px 0; font-family: var(--font-display); font-weight: 800; font-size: 17px; color: var(--edge-navy); text-transform: uppercase; letter-spacing: 0.04em; }
.mobile-drawer .md-sublink { display: block; padding: 11px 0 11px 8px; font-family: var(--font-body); font-size: 15px; color: var(--ink-2); border-bottom: 1px solid var(--hairline); }
.mobile-drawer .md-sublink:hover { color: var(--edge-orange); }
.mobile-drawer .md-foot { padding: 24px; background: var(--edge-navy); color: var(--cream); display: flex; flex-direction: column; gap: 12px; }
.mobile-drawer .md-foot .phone-big { font-family: var(--font-display); font-weight: 900; font-size: 28px; }

/* ============ Buttons ============ */
.btn { cursor: pointer; border: 0; transition: all var(--dur-fast) var(--ease-out); font-family: var(--font-display); white-space: nowrap; display: inline-flex; align-items: center; justify-content: center; gap: 8px; }
.btn:active { transform: translateY(1px); }
.btn-primary { background: var(--edge-orange); color: var(--paper); padding: 14px 26px; border-radius: var(--r-pill); font-weight: 800; font-size: 16px; text-transform: uppercase; letter-spacing: 0.06em; }
.btn-primary:hover { background: var(--edge-orange-hot); }
.btn-primary.lg { padding: 18px 34px; font-size: 18px; }
.btn-primary.sm { padding: 9px 18px; font-size: 13px; }
.btn-secondary { background: transparent; color: var(--edge-navy); padding: 14px 26px; border-radius: var(--r-pill); box-shadow: inset 0 0 0 2px var(--edge-navy); font-weight: 800; font-size: 16px; text-transform: uppercase; letter-spacing: 0.06em; }
.btn-secondary:hover { background: var(--edge-navy); color: var(--cream); }
.btn-ghost { background: transparent; color: var(--edge-navy); padding: 10px 18px; border-radius: var(--r-pill); font-weight: 800; font-size: 14px; text-transform: uppercase; letter-spacing: 0.06em; }
.btn-ghost:hover { color: var(--edge-orange); }
.btn-cream { background: var(--cream); color: var(--edge-navy); padding: 14px 26px; border-radius: var(--r-pill); font-weight: 800; font-size: 16px; text-transform: uppercase; letter-spacing: 0.06em; }
.btn-cream:hover { background: var(--paper); }

/* ============ Section header ============ */
.section { padding: 96px 0; }
.section.tight { padding: 64px 0; }
.section + .section { padding-top: 0; }
.section.bg-cream-deep { background: var(--cream-deep); }
.section.bg-navy { background: var(--edge-navy); color: var(--cream); }
.section.bg-paper { background: var(--paper); }
.section-head { text-align: center; margin-bottom: 56px; max-width: 720px; margin-left: auto; margin-right: auto; }
.section-head.left { text-align: left; margin-left: 0; }
.section-head .eyebrow, .eyebrow {
  font-family: var(--font-display); font-weight: 700; font-size: 13px; text-transform: uppercase;
  letter-spacing: 0.16em; color: var(--edge-orange); display: inline-block; margin-bottom: 14px;
}
.section-head h2 {
  font-family: var(--font-display); font-weight: 900;
  font-size: clamp(36px, 4.4vw, 64px);
  color: var(--edge-navy); text-transform: uppercase;
  line-height: 1.0; letter-spacing: -0.01em; margin: 0;
}
.section.bg-navy .section-head h2 { color: var(--cream); }
.section-head p { font-family: var(--font-body); font-size: 17px; line-height: 1.55; color: var(--ink-2); max-width: 600px; margin: 18px auto 0; }
.section.bg-navy .section-head p { color: #d9d2c2; }

/* ============ Page header (interior pages) ============ */
.page-header {
  padding: 56px 0 64px; position: relative; overflow: hidden;
  background: var(--cream);
}
.page-header.bg-deep { background: var(--cream-deep); }
.page-header.bg-navy { background: var(--edge-navy); color: var(--cream); }
.page-header .crumbs { font-family: var(--font-display); font-weight: 700; font-size: 12px; letter-spacing: 0.1em; color: var(--ink-3); text-transform: uppercase; margin-bottom: 18px; }
.page-header .crumbs a { color: var(--ink-3); }
.page-header .crumbs a:hover { color: var(--edge-orange); }
.page-header.bg-navy .crumbs, .page-header.bg-navy .crumbs a { color: #d9d2c280; }
.page-header h1 {
  font-family: var(--font-display); font-weight: 900;
  font-size: clamp(40px, 6vw, 88px);
  color: var(--edge-navy); text-transform: uppercase;
  line-height: 0.96; letter-spacing: -0.015em; margin: 0;
}
.page-header.bg-navy h1 { color: var(--cream); }
.page-header.retro h1 {
  font-family: var(--font-retro);
  color: var(--edge-orange-soft); -webkit-text-stroke: 2px var(--edge-navy);
  text-shadow: 3px 3px 0 var(--edge-navy);
}
.page-header.bg-navy.retro h1 { -webkit-text-stroke: 2px var(--cream); text-shadow: 3px 3px 0 #00000060; color: var(--edge-orange-soft); }
.page-header .lede { font-family: var(--font-body); font-size: 18px; line-height: 1.55; color: var(--ink-2); max-width: 620px; margin-top: 22px; }
.page-header.bg-navy .lede { color: #d9d2c2; }
.page-header .header-actions { display: flex; gap: 12px; margin-top: 28px; flex-wrap: wrap; }

/* ============ Hero (home) ============ */
.hero { padding: 64px 0 80px; }
.hero-eyebrow {
  display: inline-flex; align-items: center; gap: 8px;
  font-family: var(--font-display); font-weight: 700; font-size: 13px;
  text-transform: uppercase; letter-spacing: 0.14em; color: var(--edge-orange);
  background: #E85D2C14; padding: 6px 12px; border-radius: var(--r-pill);
  margin-bottom: 24px;
}
.hero-eyebrow .pulse { width: 8px; height: 8px; border-radius: 50%; background: var(--edge-orange); animation: pulse 1.6s var(--ease-out) infinite; }
@keyframes pulse {
  0%, 100% { box-shadow: 0 0 0 0 var(--edge-orange); opacity: 1; }
  70% { box-shadow: 0 0 0 8px transparent; opacity: 0.85; }
}
.hero h1 {
  font-family: var(--font-retro);
  font-size: clamp(40px, 5.4vw, 92px);
  line-height: 0.96; letter-spacing: -0.005em; text-transform: uppercase;
  color: var(--edge-orange-soft); -webkit-text-stroke: 2px var(--edge-navy);
  margin: 0; text-shadow: 3px 3px 0 var(--edge-navy);
  display: flex; flex-direction: column;
}
.hero h1 .line-solid { color: var(--edge-navy); -webkit-text-stroke: 0; text-shadow: none; font-family: var(--font-display); font-weight: 900; font-size: 0.58em; line-height: 1.05; margin-top: 14px; letter-spacing: -0.01em; }
.hero .lede { font-family: var(--font-body); font-size: 18px; line-height: 1.55; color: var(--ink-2); max-width: 540px; margin: 24px 0 28px; }
.hero-grid { display: grid; grid-template-columns: 1.3fr 1fr; gap: 56px; align-items: center; }
@media (max-width: 900px) { .hero-grid { grid-template-columns: 1fr; gap: 32px; } }
.hero-photo-wrap { position: relative; }
.hero-photo { width: 100%; aspect-ratio: 4/5; border-radius: var(--r-lg); overflow: hidden; background: var(--cream-deep); box-shadow: var(--shadow-3); transform: rotate(1.5deg); }
.hero-photo img { width: 100%; height: 100%; object-fit: cover; }
.hero-sticker { position: absolute; bottom: -14px; left: -14px; background: var(--paper); border-radius: var(--r-pill); padding: 12px 18px; display: flex; align-items: center; gap: 10px; box-shadow: var(--shadow-2); transform: rotate(-3deg); white-space: nowrap; }
.hero-sticker strong { font-family: var(--font-display); font-weight: 900; font-size: 22px; color: var(--edge-navy); line-height: 1; }
.hero-sticker span { font-family: var(--font-body); font-size: 12px; color: var(--ink-3); text-transform: uppercase; letter-spacing: 0.08em; }
.hero-sticker-2 { bottom: auto; top: -14px; left: auto; right: -10px; transform: rotate(4deg); }
.hero-cta-row { display: flex; gap: 12px; flex-wrap: wrap; align-items: center; }
.trust-row { display: flex; gap: 24px; margin-top: 28px; flex-wrap: wrap; font-family: var(--font-body); font-size: 14px; color: var(--ink-2); }
.trust-item { display: inline-flex; align-items: center; gap: 8px; }
.trust-item i, .trust-item svg { width: 16px; height: 16px; stroke: var(--edge-orange); }

/* Hero variant: solid */
.hero.h-solid h1 { color: var(--edge-navy); -webkit-text-stroke: 0; text-shadow: none; font-family: var(--font-display); font-size: clamp(40px, 5.4vw, 84px); font-weight: 900; }
.hero.h-solid h1 .line-solid { font-size: 1em; margin-top: 0; }
.hero.h-solid h1 .line-accent { color: var(--edge-orange); }

/* Hero variant: photo-first (split full-bleed) */
.hero.h-photo-first .hero-grid { grid-template-columns: 1fr 1fr; }

/* ============ Emergency band ============ */
.emergency-band { background: var(--edge-navy); color: var(--cream); padding: 28px 0; }
.emergency-band .row { display: grid; grid-template-columns: repeat(4, 1fr); gap: 24px; align-items: center; }
@media (max-width: 900px) { .emergency-band .row { grid-template-columns: 1fr 1fr; } }
.emergency-band .col { display: flex; align-items: center; gap: 14px; }
.emergency-band .col .icon { width: 42px; height: 42px; border-radius: 50%; background: var(--edge-orange); display: flex; align-items: center; justify-content: center; color: var(--paper); flex-shrink: 0; }
.emergency-band .col strong { display: block; font-family: var(--font-display); font-weight: 800; font-size: 16px; text-transform: uppercase; letter-spacing: 0.04em; line-height: 1.1; }
.emergency-band .col span { font-family: var(--font-body); font-size: 13px; color: #d9d2c2; }

/* ============ Services list (Pink's style) ============ */
.service { display: grid; grid-template-columns: 320px 1fr 280px; gap: 56px; align-items: center; padding: 56px 0; border-bottom: 1px solid var(--hairline); }
.service:first-child { border-top: 1px solid var(--hairline); }
.service h3 { font-family: var(--font-display); font-weight: 900; font-size: clamp(32px, 4vw, 52px); color: var(--edge-navy); text-transform: uppercase; line-height: 0.95; margin: 0; letter-spacing: -0.01em; }
.service p { font-family: var(--font-body); font-size: 17px; line-height: 1.55; color: var(--ink-2); margin: 0; }
.service-photo { width: 100%; aspect-ratio: 1; border-radius: var(--r-md); overflow: hidden; background: var(--cream-deep); box-shadow: var(--shadow-2); }
.service-photo img { width: 100%; height: 100%; object-fit: cover; }
.service .svc-meta { display: flex; flex-direction: column; gap: 16px; }
.service .svc-link { font-family: var(--font-display); font-weight: 800; font-size: 13px; text-transform: uppercase; letter-spacing: 0.08em; color: var(--edge-orange); display: inline-flex; align-items: center; gap: 6px; }
.service .svc-link:hover { color: var(--edge-orange-hot); }
@media (max-width: 900px) { .service { grid-template-columns: 1fr; gap: 20px; } .service-photo { aspect-ratio: 4/3; max-width: 480px; } }

/* ============ Process / How it works ============ */
.process-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 32px; position: relative; }
@media (max-width: 900px) { .process-grid { grid-template-columns: 1fr; gap: 20px; } }
.step { background: var(--paper); border-radius: var(--r-md); padding: 28px 28px 32px; box-shadow: var(--shadow-2); position: relative; }
.step-n { font-family: var(--font-retro); font-size: 56px; line-height: 0.9; color: var(--edge-orange-soft); -webkit-text-stroke: 2px var(--edge-navy); margin-bottom: 16px; }
.step-title { font-family: var(--font-display); font-weight: 900; font-size: 22px; text-transform: uppercase; color: var(--edge-navy); margin-bottom: 10px; }
.step-body { font-family: var(--font-body); font-size: 15px; line-height: 1.55; color: var(--ink-2); }
.step-arrow { position: absolute; top: 50%; right: -22px; transform: translateY(-50%); width: 36px; height: 36px; background: var(--edge-orange); color: var(--paper); border-radius: 50%; display: flex; align-items: center; justify-content: center; box-shadow: var(--shadow-2); z-index: 2; }
@media (max-width: 900px) { .step-arrow { display: none; } }

/* ============ Reviews ============ */
.reviews-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 20px; }
@media (max-width: 900px) { .reviews-grid { grid-template-columns: 1fr; } }
.review-card { background: var(--paper); border-radius: var(--r-md); padding: 24px; box-shadow: var(--shadow-2); display: flex; flex-direction: column; }
.stars { display: flex; gap: 2px; margin-bottom: 14px; color: var(--edge-orange); }
.review-body { font-family: var(--font-body); font-size: 15px; line-height: 1.55; color: var(--ink); margin: 0 0 18px; flex: 1; }
.review-foot { display: flex; justify-content: space-between; align-items: flex-end; border-top: 1px solid var(--hairline); padding-top: 14px; }
.review-foot strong { display: block; font-family: var(--font-display); font-weight: 800; font-size: 14px; color: var(--edge-navy); text-transform: uppercase; letter-spacing: 0.04em; }
.review-foot span { font-family: var(--font-body); font-size: 13px; color: var(--ink-3); }

/* ============ Areas served grid ============ */
.areas-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 14px; }
@media (max-width: 1100px) { .areas-grid { grid-template-columns: repeat(3, 1fr); } }
@media (max-width: 720px) { .areas-grid { grid-template-columns: 1fr 1fr; } }
.area-card { background: var(--paper); border-radius: var(--r-md); padding: 18px 20px; box-shadow: var(--shadow-1); display: flex; flex-direction: column; gap: 6px; transition: all var(--dur-fast) var(--ease-out); border: 1px solid transparent; }
.area-card:hover { box-shadow: var(--shadow-2); border-color: var(--edge-navy); transform: translateY(-2px); }
.area-name { font-family: var(--font-display); font-weight: 900; font-size: 18px; color: var(--edge-navy); text-transform: uppercase; letter-spacing: 0.02em; display: flex; align-items: center; gap: 8px; }
.area-badge { display: inline-flex; align-items: center; padding: 2px 7px; border-radius: var(--r-pill); background: var(--edge-orange); color: var(--paper); font-family: var(--font-display); font-weight: 700; font-size: 10px; letter-spacing: 0.06em; }
.area-sub { font-family: var(--font-mono); font-size: 11px; color: var(--ink-3); }
.area-link { margin-top: 8px; font-family: var(--font-display); font-weight: 700; font-size: 11px; text-transform: uppercase; letter-spacing: 0.06em; color: var(--edge-orange); display: inline-flex; align-items: center; gap: 6px; }

/* ============ FAQ ============ */
.faq-list { max-width: 820px; margin: 0 auto; }
.faq-item { border-bottom: 1px solid var(--hairline); }
.faq-item:first-child { border-top: 1px solid var(--hairline); }
.faq-q { width: 100%; background: transparent; border: 0; cursor: pointer; display: flex; justify-content: space-between; align-items: center; gap: 16px; padding: 22px 4px; text-align: left; font-family: var(--font-display); font-weight: 800; font-size: 18px; text-transform: uppercase; color: var(--edge-navy); letter-spacing: -0.005em; }
.faq-q:hover { color: var(--edge-orange); }
.faq-q .icon { color: var(--edge-orange); flex-shrink: 0; font-size: 22px; line-height: 1; transition: transform var(--dur-fast); }
.faq-item.open .faq-q .icon { transform: rotate(45deg); }
.faq-a { padding: 0 4px 22px; font-family: var(--font-body); font-size: 16px; line-height: 1.6; color: var(--ink-2); max-width: 680px; display: none; }
.faq-item.open .faq-a { display: block; }

/* ============ Final CTA band ============ */
.final-cta { background: var(--edge-navy); background-image: radial-gradient(circle at 12% 30%, #2B3E6688 0, transparent 50%), radial-gradient(circle at 90% 80%, #E85D2C22 0, transparent 50%); padding: 96px 0; color: var(--cream); }
.final-cta-inner { display: grid; grid-template-columns: 1.1fr 1fr; gap: 56px; align-items: center; }
@media (max-width: 900px) { .final-cta-inner { grid-template-columns: 1fr; gap: 28px; } }
.final-cta h2 { font-family: var(--font-retro); font-size: clamp(40px, 6vw, 88px); color: var(--edge-orange-soft); -webkit-text-stroke: 2px var(--cream); text-transform: uppercase; line-height: 0.95; margin: 14px 0 18px; text-shadow: 3px 3px 0 #00000040; }
.final-cta p { font-family: var(--font-body); font-size: 17px; line-height: 1.55; color: #d9d2c2; margin: 0; max-width: 460px; }
.final-cta-actions { display: flex; flex-direction: column; gap: 14px; align-items: flex-start; }
.btn-final-primary { background: var(--edge-orange); color: var(--paper); padding: 22px 36px; border-radius: var(--r-pill); font-family: var(--font-display); font-weight: 900; font-size: 28px; text-transform: uppercase; letter-spacing: 0.02em; display: inline-flex; align-items: center; gap: 12px; transition: all var(--dur-fast) var(--ease-out); box-shadow: 0 8px 24px -8px #E85D2C80; border: 0; cursor: pointer; }
.btn-final-primary:hover { background: var(--edge-orange-hot); transform: translateY(-1px); box-shadow: 0 12px 28px -8px #E85D2C90; }
.btn-final-secondary { background: transparent; color: var(--cream); padding: 14px 24px; border-radius: var(--r-pill); box-shadow: inset 0 0 0 2px var(--cream); font-family: var(--font-display); font-weight: 800; font-size: 16px; text-transform: uppercase; letter-spacing: 0.06em; cursor: pointer; transition: all var(--dur-fast); border: 0; }
.btn-final-secondary:hover { background: var(--cream); color: var(--edge-navy); }

/* ============ Mobile sticky bar ============ */
.mobile-call-bar { position: fixed; bottom: 0; left: 0; right: 0; z-index: 90; display: none; background: var(--cream); border-top: 1px solid var(--hairline); padding: 10px 16px; gap: 10px; box-shadow: 0 -4px 16px -4px #1B2A4A30; }
@media (max-width: 720px) { .mobile-call-bar { display: flex; } body { padding-bottom: 78px; } }
.mcb-call, .mcb-book { flex: 1; height: 52px; border: 0; border-radius: var(--r-pill); font-family: var(--font-display); font-weight: 900; font-size: 16px; text-transform: uppercase; letter-spacing: 0.06em; cursor: pointer; display: inline-flex; align-items: center; justify-content: center; gap: 8px; }
.mcb-call { background: var(--edge-orange); color: var(--paper); }
.mcb-book { background: transparent; color: var(--edge-navy); box-shadow: inset 0 0 0 2px var(--edge-navy); }

/* ============ Footer ============ */
.footer { background: var(--edge-navy); color: var(--cream); padding: 80px 0 36px; }
.footer-grid { display: grid; grid-template-columns: 1.6fr 1fr 1fr 1fr; gap: 40px; }
@media (max-width: 900px) { .footer-grid { grid-template-columns: 1fr 1fr; } }
@media (max-width: 600px) { .footer-grid { grid-template-columns: 1fr; } }
.footer h4 { font-family: var(--font-display); font-weight: 800; font-size: 13px; text-transform: uppercase; letter-spacing: 0.08em; color: var(--edge-orange); margin: 0 0 16px; }
.footer ul { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: 10px; }
.footer ul li { font-family: var(--font-body); font-size: 15px; color: #d9d2c2; }
.footer ul li a:hover { color: var(--edge-orange); }
.footer .phone-big { font-family: var(--font-display); font-weight: 900; font-size: 32px; color: var(--cream); line-height: 1; margin: 8px 0; }
.footer .phone-big a { color: inherit; }
.footer .phone-big a:hover { color: var(--edge-orange); }
.footer p { font-family: var(--font-body); font-size: 14px; color: #d9d2c2; line-height: 1.55; }
.footer .legal { margin-top: 56px; padding-top: 24px; border-top: 1px solid #ffffff14; font-family: var(--font-body); font-size: 13px; color: #d9d2c280; display: flex; justify-content: space-between; gap: 16px; flex-wrap: wrap; }
.footer .footer-logo { display: flex; align-items: center; gap: 12px; margin-bottom: 18px; }
.footer .footer-logo img { height: 56px; width: auto; filter: brightness(0) invert(1); opacity: 0.95; }
.footer .footer-logo .ftxt { font-family: var(--font-display); font-weight: 900; font-size: 24px; color: var(--cream); letter-spacing: 0.02em; }

/* ============ Generic Card / Pill / Chip ============ */
.chip { display: inline-flex; align-items: center; gap: 6px; padding: 6px 12px; border-radius: var(--r-pill); background: var(--paper); color: var(--edge-navy); font-family: var(--font-display); font-weight: 700; font-size: 12px; text-transform: uppercase; letter-spacing: 0.06em; box-shadow: var(--shadow-1); }
.chip-orange { background: var(--edge-orange); color: var(--paper); }
.chip-navy { background: var(--edge-navy); color: var(--cream); }
.chip-outline { background: transparent; box-shadow: inset 0 0 0 1.5px var(--hairline); }

.callout { background: var(--paper); border-radius: var(--r-md); padding: 28px; box-shadow: var(--shadow-2); }
.callout h4 { font-family: var(--font-display); font-weight: 900; font-size: 20px; text-transform: uppercase; color: var(--edge-navy); margin: 0 0 8px; letter-spacing: -0.005em; }
.callout p { font-family: var(--font-body); font-size: 15px; color: var(--ink-2); line-height: 1.55; margin: 0; }

/* Two-column content layout for service / area pages */
.split { display: grid; grid-template-columns: 1.6fr 1fr; gap: 64px; align-items: start; }
@media (max-width: 900px) { .split { grid-template-columns: 1fr; gap: 32px; } }
.split-body { font-family: var(--font-body); font-size: 17px; line-height: 1.65; color: var(--ink-2); }
.split-body p { margin: 0 0 18px; }
.split-body h2, .split-body h3 { color: var(--edge-navy); margin: 32px 0 12px; }
.split-body h2 { font-family: var(--font-display); font-weight: 900; font-size: 32px; text-transform: uppercase; letter-spacing: -0.005em; }
.split-body h3 { font-family: var(--font-display); font-weight: 800; font-size: 22px; text-transform: uppercase; }
.split-body ul { padding-left: 0; list-style: none; }
.split-body ul li { position: relative; padding: 8px 0 8px 28px; }
.split-body ul li::before { content: ""; position: absolute; left: 0; top: 16px; width: 14px; height: 2px; background: var(--edge-orange); }
.split-body strong { color: var(--edge-navy); }

.sidebar-card { background: var(--paper); border-radius: var(--r-md); padding: 28px; box-shadow: var(--shadow-2); position: sticky; top: 110px; }
.sidebar-card h4 { font-family: var(--font-display); font-weight: 900; font-size: 22px; text-transform: uppercase; color: var(--edge-navy); margin: 0 0 12px; letter-spacing: -0.005em; }
.sidebar-card p { font-family: var(--font-body); font-size: 14px; color: var(--ink-2); margin: 0 0 16px; line-height: 1.55; }
.sidebar-card .phone-big { font-family: var(--font-display); font-weight: 900; font-size: 28px; color: var(--edge-navy); margin: 12px 0; display: block; line-height: 1; }
.sidebar-card .phone-big:hover { color: var(--edge-orange); }
.sidebar-card .btn { width: 100%; }

/* Feature grid (for services + areas pages) */
.feature-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 20px; }
@media (max-width: 900px) { .feature-grid { grid-template-columns: 1fr; } }
.feature { background: var(--paper); border-radius: var(--r-md); padding: 24px; box-shadow: var(--shadow-1); }
.feature .ft-num { font-family: var(--font-display); font-weight: 900; font-size: 13px; color: var(--edge-orange); letter-spacing: 0.1em; margin-bottom: 12px; }
.feature h4 { font-family: var(--font-display); font-weight: 900; font-size: 20px; text-transform: uppercase; color: var(--edge-navy); margin: 0 0 10px; letter-spacing: -0.005em; }
.feature p { font-family: var(--font-body); font-size: 14px; color: var(--ink-2); margin: 0; line-height: 1.55; }

/* ============ Service page — process steps ============ */
.svc-steps { display: flex; flex-direction: column; margin: 40px 0 0; }
.svc-step { display: flex; gap: 20px; padding: 22px 0; border-bottom: 1px solid var(--hairline); align-items: flex-start; }
.svc-step:first-child { border-top: 1px solid var(--hairline); }
.svc-step-n { flex-shrink: 0; width: 48px; height: 48px; background: var(--edge-navy); color: var(--cream); font-family: var(--font-display); font-weight: 900; font-size: 17px; display: flex; align-items: center; justify-content: center; border-radius: 6px; letter-spacing: -0.01em; }
.svc-step h4 { font-family: var(--font-display); font-weight: 800; font-size: 17px; color: var(--edge-navy); text-transform: uppercase; margin: 0 0 5px; letter-spacing: 0.01em; }
.svc-step p { font-family: var(--font-body); font-size: 15px; line-height: 1.6; color: var(--ink-2); margin: 0; }

/* Install steps */
.install-steps { counter-reset: step; list-style: none; margin: 0; padding: 0; display: flex; flex-direction: column; gap: var(--s-4); }
.install-step { display: flex; gap: var(--s-4); align-items: flex-start; }
.step-num { flex-shrink: 0; width: 44px; height: 44px; background: var(--edge-navy); color: var(--cream); font-family: var(--font-display); font-weight: 900; font-size: 16px; display: flex; align-items: center; justify-content: center; border-radius: 4px; letter-spacing: -0.01em; }
.step-body h4 { font-family: var(--font-display); font-weight: 800; font-size: 17px; color: var(--edge-navy); text-transform: uppercase; margin: 0 0 6px; letter-spacing: 0.01em; }
.step-body p { font-family: var(--font-body); font-size: 15px; line-height: 1.6; color: var(--ink-2); margin: 0; }

/* ============ Service page — inline CTA block ============ */
.svc-cta { background: var(--edge-navy); border-radius: var(--r-lg); padding: var(--s-7) var(--s-6); display: flex; gap: var(--s-6); align-items: center; flex-wrap: wrap; }
.svc-cta-text { flex: 1; min-width: 240px; }
.svc-cta-text strong { display: block; font-family: var(--font-display); font-weight: 900; font-size: clamp(22px,2.8vw,32px); color: var(--cream); text-transform: uppercase; line-height: 1.05; margin-bottom: 8px; }
.svc-cta-text p { font-family: var(--font-body); font-size: 15px; color: rgba(245,239,227,0.75); margin: 0; }
.svc-cta-actions { display: flex; flex-direction: column; gap: 12px; align-items: flex-start; flex-shrink: 0; }
.svc-cta-phone { font-family: var(--font-display); font-weight: 800; font-size: 17px; color: var(--cream); text-transform: uppercase; display: inline-flex; align-items: center; gap: 7px; }
.svc-cta-phone:hover { color: var(--edge-orange); }
@media(max-width:720px) { .svc-cta { padding: var(--s-6) var(--s-5); flex-direction: column; align-items: flex-start; } }

/* Feature grid — 2-col variant */
.feature-grid-2 { display: grid; grid-template-columns: 1fr 1fr; gap: 20px; }
@media(max-width:700px) { .feature-grid-2 { grid-template-columns: 1fr; } }

/* Stat row */
.stat-row { display: grid; grid-template-columns: repeat(4, 1fr); gap: 24px; padding: 40px 0; border-top: 1px solid var(--hairline); border-bottom: 1px solid var(--hairline); }
@media (max-width: 900px) { .stat-row { grid-template-columns: 1fr 1fr; } }
.stat strong { display: block; font-family: var(--font-display); font-weight: 900; font-size: clamp(40px, 5vw, 64px); color: var(--edge-navy); line-height: 0.95; }
.stat span { display: block; font-family: var(--font-display); font-weight: 700; font-size: 12px; color: var(--ink-3); text-transform: uppercase; letter-spacing: 0.1em; margin-top: 6px; }

/* Blog */
.blog-grid { display: grid; grid-template-columns: 1fr 1fr 1fr; gap: 28px; }
@media (max-width: 900px) { .blog-grid { grid-template-columns: 1fr; } }
.blog-card { background: var(--paper); border-radius: var(--r-md); overflow: hidden; box-shadow: var(--shadow-1); display: flex; flex-direction: column; transition: all var(--dur-fast) var(--ease-out); }
.blog-card:hover { box-shadow: var(--shadow-2); transform: translateY(-2px); }
.blog-cover { aspect-ratio: 16/10; overflow: hidden; background: var(--cream-deep); position: relative; }
.blog-cover img { width: 100%; height: 100%; object-fit: cover; }
.blog-cover .blog-tag { position: absolute; top: 12px; left: 12px; }
.blog-body { padding: 20px 22px 22px; flex: 1; display: flex; flex-direction: column; }
.blog-meta { font-family: var(--font-display); font-weight: 700; font-size: 11px; letter-spacing: 0.1em; color: var(--ink-3); text-transform: uppercase; margin-bottom: 8px; }
.blog-card h3 { font-family: var(--font-display); font-weight: 900; font-size: 20px; line-height: 1.1; color: var(--edge-navy); text-transform: uppercase; letter-spacing: -0.005em; margin: 0 0 8px; }
.blog-card p { font-family: var(--font-body); font-size: 14px; line-height: 1.55; color: var(--ink-2); margin: 0; flex: 1; }
.blog-card .blog-foot { margin-top: 14px; font-family: var(--font-display); font-weight: 800; font-size: 12px; letter-spacing: 0.06em; color: var(--edge-orange); text-transform: uppercase; }

.blog-featured { display: grid; grid-template-columns: 1.2fr 1fr; gap: 48px; align-items: center; background: var(--cream-deep); border-radius: var(--r-lg); padding: 40px; margin-bottom: 56px; }
@media (max-width: 900px) { .blog-featured { grid-template-columns: 1fr; padding: 28px; } }
.blog-featured-cover { aspect-ratio: 4/3; border-radius: var(--r-md); overflow: hidden; background: var(--cream); box-shadow: var(--shadow-2); }
.blog-featured-cover img { width: 100%; height: 100%; object-fit: cover; }
.blog-featured h2 { font-family: var(--font-display); font-weight: 900; font-size: clamp(28px, 3.4vw, 44px); color: var(--edge-navy); text-transform: uppercase; line-height: 1; letter-spacing: -0.01em; margin: 12px 0 16px; }
.blog-featured p { font-family: var(--font-body); font-size: 17px; line-height: 1.55; color: var(--ink-2); margin: 0 0 18px; }

/* Article (blog post) */
.article { max-width: 760px; margin: 0 auto; padding: 64px 24px 96px; font-family: var(--font-body); font-size: 18px; line-height: 1.7; color: var(--ink); }
.article .article-meta { font-family: var(--font-display); font-weight: 700; font-size: 12px; letter-spacing: 0.12em; color: var(--ink-3); text-transform: uppercase; margin-bottom: 16px; }
.article h1 { font-family: var(--font-display); font-weight: 900; font-size: clamp(36px, 4.4vw, 56px); color: var(--edge-navy); text-transform: uppercase; line-height: 1; letter-spacing: -0.01em; margin: 0 0 24px; }
.article h2 { font-family: var(--font-display); font-weight: 900; font-size: 28px; color: var(--edge-navy); text-transform: uppercase; letter-spacing: -0.005em; margin: 40px 0 12px; }
.article h3 { font-family: var(--font-display); font-weight: 800; font-size: 22px; color: var(--edge-navy); text-transform: uppercase; margin: 32px 0 10px; }
.article p { margin: 0 0 22px; color: var(--ink-2); }
.article ul, .article ol { padding-left: 22px; margin: 0 0 22px; color: var(--ink-2); }
.article ul li, .article ol li { padding: 4px 0; }
.article blockquote { margin: 28px 0; padding: 20px 28px; background: var(--cream-deep); border-radius: var(--r-md); font-family: var(--font-display); font-weight: 700; font-size: 22px; color: var(--edge-navy); text-transform: uppercase; letter-spacing: -0.005em; line-height: 1.2; }
.article .article-cover { aspect-ratio: 16/9; border-radius: var(--r-lg); overflow: hidden; box-shadow: var(--shadow-3); margin: 0 0 36px; background: var(--cream-deep); }
.article .article-cover img { width: 100%; height: 100%; object-fit: cover; }
.article .article-cta { margin-top: 48px; padding: 32px; border-radius: var(--r-lg); background: var(--edge-navy); color: var(--cream); display: flex; justify-content: space-between; align-items: center; gap: 24px; flex-wrap: wrap; }
.article .article-cta strong { font-family: var(--font-display); font-weight: 900; font-size: 22px; text-transform: uppercase; letter-spacing: -0.005em; }

/* Forms */
.form-field { display: flex; flex-direction: column; gap: 6px; margin-bottom: 16px; }
.form-field label { font-family: var(--font-display); font-weight: 700; font-size: 12px; text-transform: uppercase; letter-spacing: 0.06em; color: var(--edge-navy); }
.form-field input, .form-field select, .form-field textarea { height: 46px; padding: 0 14px; background: var(--paper); border: 1.5px solid var(--hairline); border-radius: var(--r-sm); font-family: var(--font-body); font-size: 15px; color: var(--ink); transition: border-color var(--dur-fast), box-shadow var(--dur-fast); }
.form-field textarea { height: 110px; padding: 12px 14px; resize: vertical; }
.form-field input:focus, .form-field select:focus, .form-field textarea:focus { outline: 0; border-color: var(--edge-navy); box-shadow: 0 0 0 3px #1B2A4A22; }
.form-row { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; }
@media (max-width: 600px) { .form-row { grid-template-columns: 1fr; } }

.thanks { text-align: center; padding: 24px 0; }
.thanks .check { width: 64px; height: 64px; border-radius: 50%; background: var(--success); color: var(--paper); display: inline-flex; align-items: center; justify-content: center; font-size: 36px; margin-bottom: 18px; font-family: var(--font-display); font-weight: 900; }
.thanks h3 { font-family: var(--font-display); font-weight: 900; font-size: 28px; text-transform: uppercase; color: var(--edge-navy); margin: 0 0 12px; }
.thanks p { font-family: var(--font-body); font-size: 16px; color: var(--ink-2); }

/* Drawer (quote) */
.drawer-scrim { position: fixed; inset: 0; background: #1B2A4A55; backdrop-filter: blur(2px); opacity: 0; pointer-events: none; transition: opacity var(--dur-base) var(--ease-out); z-index: 100; }
.drawer-scrim.open { opacity: 1; pointer-events: auto; }
.drawer { position: fixed; top: 0; right: 0; bottom: 0; width: min(520px, 100vw); background: var(--cream); z-index: 101; transform: translateX(100%); transition: transform var(--dur-slow) var(--ease-out); display: flex; flex-direction: column; box-shadow: -12px 0 40px #1B2A4A30; }
.drawer.open { transform: translateX(0); }
.drawer-head { padding: 24px 28px; display: flex; align-items: center; justify-content: space-between; border-bottom: 1px solid var(--hairline); }
.drawer-head h3 { font-family: var(--font-display); font-weight: 900; font-size: 22px; text-transform: uppercase; color: var(--edge-navy); margin: 0; }
.drawer-close { background: transparent; border: 0; cursor: pointer; padding: 6px; color: var(--edge-navy); border-radius: 50%; width: 36px; height: 36px; display: flex; align-items: center; justify-content: center; transition: background var(--dur-fast); font-size: 22px; }
.drawer-close:hover { background: #1B2A4A12; }
.drawer-body { padding: 28px; flex: 1; overflow-y: auto; }
.drawer-foot { padding: 20px 28px 28px; border-top: 1px solid var(--hairline); }
.svc-options { display: grid; grid-template-columns: 1fr 1fr; gap: 8px; }
.svc-opt { display: flex; flex-direction: column; gap: 2px; padding: 12px 14px; background: var(--paper); border: 1.5px solid var(--hairline); border-radius: var(--r-sm); cursor: pointer; transition: all var(--dur-fast) var(--ease-out); }
.svc-opt:hover { border-color: var(--edge-navy); }
.svc-opt.active { border-color: var(--edge-navy); background: var(--edge-navy); color: var(--cream); }
.svc-opt strong { font-family: var(--font-display); font-weight: 800; font-size: 14px; text-transform: uppercase; letter-spacing: 0.04em; }
.svc-opt span { font-family: var(--font-body); font-size: 12px; color: var(--ink-3); }
.svc-opt.active span { color: #ffffffb0; }

/* Tweaks panel */
.tw-fab { position: fixed; bottom: 24px; left: 24px; z-index: 95; background: var(--edge-navy); color: var(--cream); border: 0; cursor: pointer; padding: 14px 18px; border-radius: var(--r-pill); display: inline-flex; align-items: center; gap: 8px; font-family: var(--font-display); font-weight: 800; font-size: 13px; text-transform: uppercase; letter-spacing: 0.08em; box-shadow: var(--shadow-3); }
.tw-fab:hover { background: var(--edge-navy-deep); }
.tw-panel { position: fixed; bottom: 84px; left: 24px; z-index: 95; width: 320px; background: var(--paper); border-radius: var(--r-md); box-shadow: var(--shadow-3); padding: 22px; transform: translateY(8px) scale(0.96); opacity: 0; pointer-events: none; transition: all var(--dur-base) var(--ease-out); border: 1px solid var(--hairline); }
.tw-panel.open { transform: translateY(0) scale(1); opacity: 1; pointer-events: auto; }
.tw-panel h4 { font-family: var(--font-display); font-weight: 900; font-size: 16px; text-transform: uppercase; color: var(--edge-navy); margin: 0 0 4px; letter-spacing: 0.02em; }
.tw-panel p { font-family: var(--font-body); font-size: 12px; color: var(--ink-3); margin: 0 0 16px; }
.tw-group { margin-bottom: 16px; }
.tw-group label { display: block; font-family: var(--font-display); font-weight: 700; font-size: 11px; letter-spacing: 0.08em; text-transform: uppercase; color: var(--ink-2); margin-bottom: 6px; }
.tw-radio { display: flex; gap: 4px; background: var(--cream); border-radius: var(--r-pill); padding: 3px; }
.tw-radio button { flex: 1; padding: 7px 10px; background: transparent; border: 0; cursor: pointer; border-radius: var(--r-pill); font-family: var(--font-display); font-weight: 700; font-size: 11px; text-transform: uppercase; letter-spacing: 0.06em; color: var(--ink-2); }
.tw-radio button.active { background: var(--edge-navy); color: var(--cream); }

/* Quote calculator */
.calc { display: grid; grid-template-columns: 1.3fr 1fr; gap: 48px; align-items: start; }
@media (max-width: 900px) { .calc { grid-template-columns: 1fr; gap: 28px; } }
.calc-form { background: var(--paper); border-radius: var(--r-lg); padding: 32px; box-shadow: var(--shadow-2); }
.calc-step { display: none; }
.calc-step.active { display: block; }
.calc-step h2 { font-family: var(--font-display); font-weight: 900; font-size: 28px; text-transform: uppercase; color: var(--edge-navy); letter-spacing: -0.005em; margin: 0 0 8px; }
.calc-step p { font-family: var(--font-body); font-size: 14px; color: var(--ink-2); margin: 0 0 24px; }
.calc-progress { display: flex; gap: 6px; margin-bottom: 28px; }
.calc-progress span { flex: 1; height: 4px; background: var(--cream-deep); border-radius: var(--r-pill); transition: background var(--dur-fast); }
.calc-progress span.done { background: var(--edge-orange); }
.calc-options { display: grid; grid-template-columns: 1fr 1fr; gap: 10px; }
.calc-opt { padding: 14px 16px; background: var(--cream); border: 1.5px solid var(--hairline); border-radius: var(--r-sm); cursor: pointer; text-align: left; transition: all var(--dur-fast) var(--ease-out); }
.calc-opt:hover { border-color: var(--edge-navy); }
.calc-opt.active { border-color: var(--edge-navy); background: var(--edge-navy); color: var(--cream); }
.calc-opt strong { display: block; font-family: var(--font-display); font-weight: 800; font-size: 14px; text-transform: uppercase; }
.calc-opt span { display: block; font-family: var(--font-body); font-size: 12px; color: var(--ink-3); margin-top: 2px; }
.calc-opt.active span { color: #ffffffb0; }
.calc-actions { display: flex; justify-content: space-between; margin-top: 24px; gap: 12px; }
.calc-summary { background: var(--cream-deep); border-radius: var(--r-md); padding: 24px; position: sticky; top: 110px; }
.calc-summary h4 { font-family: var(--font-display); font-weight: 900; font-size: 16px; text-transform: uppercase; color: var(--edge-navy); margin: 0 0 16px; letter-spacing: 0.02em; }
.calc-summary dl { margin: 0; }
.calc-summary dt { font-family: var(--font-display); font-weight: 700; font-size: 11px; letter-spacing: 0.08em; text-transform: uppercase; color: var(--ink-3); margin-top: 14px; }
.calc-summary dd { margin: 4px 0 0; font-family: var(--font-body); font-size: 15px; color: var(--edge-navy); font-weight: 600; }
.calc-locked { padding: 18px; margin-top: 18px; background: var(--paper); border-radius: var(--r-sm); border: 1.5px dashed var(--edge-orange); font-family: var(--font-display); font-weight: 700; font-size: 12px; text-transform: uppercase; letter-spacing: 0.06em; color: var(--ink-2); text-align: center; }
.calc-locked strong { color: var(--edge-orange); display: block; font-size: 14px; margin-bottom: 4px; }

/* Visible map area for areas page (drawn) */
.coverage-map { aspect-ratio: 4/3; border-radius: var(--r-lg); background: var(--cream-deep); overflow: hidden; position: relative; box-shadow: var(--shadow-2); }
.coverage-map svg { width: 100%; height: 100%; display: block; }

/* ============================================================
   SERVICE PAGE OVERRIDES — force full-width, kill embedded sidebars
   These rules work regardless of what HTML is in the_content().
   ============================================================ */

/* Break the split grid — make it a single full-width column */
body[data-page="services"] .split {
  display: block !important;
}
body[data-page="services"] .split-body {
  width: 100% !important;
  max-width: 100% !important;
}

/* Completely hide any aside / sidebar-card that landed in the content */
body[data-page="services"] aside,
body[data-page="services"] .sidebar-card {
  display: none !important;
}

/* Feature grid inside service content: always 3 cols, full width */
body[data-page="services"] .section .feature-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr) !important;
  gap: 20px;
}
@media (max-width: 900px) {
  body[data-page="services"] .section .feature-grid {
    grid-template-columns: 1fr !important;
  }
}

/* 2-col grid for comparison cards (torsion/extension) */
body[data-page="services"] .section .feature-grid-2 {
  display: grid;
  grid-template-columns: 1fr 1fr !important;
  gap: 20px;
}
@media (max-width: 700px) {
  body[data-page="services"] .section .feature-grid-2 {
    grid-template-columns: 1fr !important;
  }
}

/* Remove any img that floats between feature cards (legacy layout artifact) */
body[data-page="services"] .section .split-body > img,
body[data-page="services"] .section .split-body > p > img {
  display: none;
}

/* ============================================================
   Spring type comparison — clean typographic two-col, no boxes
   ============================================================ */
.spring-compare {
  display: grid;
  grid-template-columns: 1fr 1fr;
  border-top: 2px solid var(--edge-navy);
  margin: 48px 0 8px;
}
.spring-compare-col {
  padding: 32px 48px 32px 0;
}
.spring-compare-col + .spring-compare-col {
  padding: 32px 0 32px 48px;
  border-left: 1.5px solid var(--hairline);
}
.spring-compare-eyebrow {
  font-family: var(--font-display);
  font-weight: 800;
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: 0.16em;
  color: var(--edge-orange);
  display: block;
  margin-bottom: 14px;
}
.spring-compare-h {
  font-family: var(--font-display);
  font-weight: 900;
  font-size: clamp(22px, 2.8vw, 34px);
  color: var(--edge-navy);
  text-transform: uppercase;
  line-height: 1.0;
  margin: 0 0 16px;
  letter-spacing: -0.01em;
}
.spring-compare-col p {
  font-family: var(--font-body);
  font-size: 16px;
  line-height: 1.65;
  color: var(--ink-2);
  margin: 0 0 20px;
}
.spring-compare-tag {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-family: var(--font-display);
  font-weight: 700;
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: var(--ink-3);
}
.spring-compare-tag::before {
  content: '';
  display: block;
  width: 20px;
  height: 2px;
  background: var(--edge-orange);
  flex-shrink: 0;
}
@media (max-width: 700px) {
  .spring-compare { grid-template-columns: 1fr; }
  .spring-compare-col { padding: 28px 0; }
  .spring-compare-col + .spring-compare-col { border-left: none; border-top: 1.5px solid var(--hairline); }
}
