/* ============================================================
   HVAC Quote Pros — "Hot & Cold" design system
   Temperature-duality: cool teal/navy meets warm ember.
   ============================================================ */

@import url('https://fonts.googleapis.com/css2?family=Bricolage+Grotesque:opsz,wght@12..96,400..800&family=Manrope:wght@400;500;600;700;800&display=swap');

:root {
  /* Cool side */
  --ink: #0A1524;
  --ink-2: #0F2439;
  --ink-3: #16324b;
  --cool: #17B6C9;
  --cool-deep: #0E7C8C;
  --frost: #E9F5F8;

  /* Warm side */
  --ember: #FF6A2B;
  --ember-2: #F9531B;
  --ember-soft: #FFB489;
  --amber: #FFC24B;

  /* Neutrals — warm off-white, premium */
  --paper: #FBFAF7;
  --paper-2: #F3EFE8;
  --card: #FFFFFF;
  --text: #16202E;
  --muted: #56606F;
  --muted-2: #808a97;
  --line: rgba(10, 21, 36, 0.10);
  --line-strong: rgba(10, 21, 36, 0.18);

  /* Effects */
  --shadow-sm: 0 1px 2px rgba(10,21,36,.06), 0 2px 6px rgba(10,21,36,.05);
  --shadow-md: 0 8px 24px -6px rgba(10,21,36,.14), 0 2px 8px rgba(10,21,36,.06);
  --shadow-lg: 0 30px 70px -20px rgba(10,21,36,.35), 0 10px 30px -12px rgba(10,21,36,.2);
  --shadow-ember: 0 12px 30px -8px rgba(255,106,43,.45);

  --radius: 16px;
  --radius-lg: 24px;
  --radius-sm: 10px;

  --font-display: 'Bricolage Grotesque', 'Trebuchet MS', sans-serif;
  --font-body: 'Manrope', -apple-system, BlinkMacSystemFont, sans-serif;

  --container: 1200px;
  --ease: cubic-bezier(.22, .61, .36, 1);
  --ease-spring: cubic-bezier(.34, 1.56, .64, 1);
}

/* ---------- Reset ---------- */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; -webkit-text-size-adjust: 100%; }
body {
  font-family: var(--font-body);
  background: var(--paper);
  color: var(--text);
  line-height: 1.6;
  font-size: 17px;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
  overflow-x: hidden;
}
img, svg { display: block; max-width: 100%; }
a { color: inherit; text-decoration: none; }
button { font-family: inherit; cursor: pointer; border: none; background: none; }
ul { list-style: none; }
input, select, textarea, button { font-family: inherit; font-size: inherit; }

h1, h2, h3, h4 { font-family: var(--font-display); font-weight: 700; line-height: 1.05; letter-spacing: -0.02em; color: var(--ink); }

/* ---------- Layout ---------- */
.container { width: min(var(--container), 92vw); margin-inline: auto; }
.section { padding: clamp(64px, 9vw, 128px) 0; position: relative; }
.section--tight { padding: clamp(48px, 6vw, 80px) 0; }
.eyebrow {
  display: inline-flex; align-items: center; gap: 8px;
  font-size: 13px; font-weight: 700; letter-spacing: .14em; text-transform: uppercase;
  color: var(--cool-deep);
}
.eyebrow::before { content: ""; width: 22px; height: 2px; background: var(--ember); border-radius: 2px; }
.section-head { max-width: 720px; margin-bottom: 56px; }
.section-head h2 { font-size: clamp(30px, 4.4vw, 52px); margin: 18px 0 16px; }
.section-head p { color: var(--muted); font-size: clamp(16px, 2vw, 19px); }
.section-head--center { margin-inline: auto; text-align: center; }
.section-head--center .eyebrow { justify-content: center; }

/* ---------- Buttons ---------- */
.btn {
  display: inline-flex; align-items: center; justify-content: center; gap: 10px;
  padding: 15px 26px; border-radius: 100px; font-weight: 700; font-size: 16px;
  transition: transform .3s var(--ease-spring), box-shadow .3s var(--ease), background .3s;
  white-space: nowrap; will-change: transform;
}
.btn svg { width: 18px; height: 18px; }
.btn--primary {
  background: linear-gradient(135deg, var(--ember) 0%, var(--ember-2) 100%);
  color: #fff; box-shadow: var(--shadow-ember);
}
.btn--primary:hover { transform: translateY(-2px) scale(1.02); box-shadow: 0 18px 40px -8px rgba(255,106,43,.6); }
.btn--dark { background: var(--ink); color: #fff; box-shadow: var(--shadow-md); }
.btn--dark:hover { transform: translateY(-2px); background: var(--ink-2); }
.btn--ghost { background: rgba(255,255,255,.08); color: #fff; border: 1px solid rgba(255,255,255,.25); backdrop-filter: blur(6px); }
.btn--ghost:hover { background: rgba(255,255,255,.16); transform: translateY(-2px); }
.btn--outline { border: 1.5px solid var(--line-strong); color: var(--ink); background: var(--card); }
.btn--outline:hover { border-color: var(--ember); color: var(--ember-2); transform: translateY(-2px); }
.btn--lg { padding: 18px 34px; font-size: 17px; }
.btn--block { width: 100%; }

.tel-btn { font-weight: 800; font-family: var(--font-display); letter-spacing: -.01em; }

/* ---------- Nav ---------- */
.nav {
  position: sticky; top: 0; z-index: 100;
  transition: background .4s var(--ease), box-shadow .4s, backdrop-filter .4s;
  padding: 16px 0;
}
.nav.scrolled { background: rgba(251,250,247,.82); backdrop-filter: blur(16px) saturate(1.4); box-shadow: 0 1px 0 var(--line); }
.nav__inner { display: flex; align-items: center; justify-content: space-between; gap: 24px; }
.brand { display: inline-flex; align-items: center; gap: 11px; font-family: var(--font-display); font-weight: 800; font-size: 21px; letter-spacing: -.02em; color: var(--ink); }
.brand__mark {
  width: 40px; height: 40px; border-radius: 11px; flex-shrink: 0;
  background: linear-gradient(140deg, var(--ink) 0%, var(--ink-3) 100%);
  display: grid; place-items: center; position: relative; overflow: hidden;
  box-shadow: var(--shadow-sm);
}
.brand__mark svg { width: 24px; height: 24px; }
.brand em { color: var(--ember); font-style: normal; }
.nav__links { display: flex; align-items: center; gap: 30px; }
.nav__links a { font-weight: 600; font-size: 15px; color: var(--text); transition: color .2s; position: relative; }
.nav__links a::after { content:""; position:absolute; left:0; bottom:-5px; height:2px; width:0; background:var(--ember); transition: width .3s var(--ease); border-radius:2px; }
.nav__links a:hover { color: var(--ink); }
.nav__links a:hover::after { width: 100%; }
.nav__cta { display: flex; align-items: center; gap: 14px; }
.nav__tel { display: inline-flex; align-items: center; gap: 8px; font-weight: 700; color: var(--ink); font-size: 15px; }
.nav__tel svg { width: 16px; height: 16px; color: var(--cool-deep); }
.nav__toggle { display: none; width: 44px; height: 44px; border-radius: 12px; border: 1px solid var(--line); background: var(--card); }
.nav__toggle span { display:block; width:20px; height:2px; background:var(--ink); margin:4px auto; border-radius:2px; transition:.3s; }

/* ---------- Hero ---------- */
.hero { position: relative; background: var(--ink); color: #fff; overflow: hidden; padding: clamp(40px,7vw,88px) 0 clamp(64px,8vw,110px); }
.hero__bg { position: absolute; inset: 0; z-index: 0; }
.hero__mesh {
  position: absolute; inset: -20%;
  background:
    radial-gradient(45% 55% at 18% 22%, rgba(23,182,201,.55), transparent 60%),
    radial-gradient(50% 60% at 82% 30%, rgba(255,106,43,.5), transparent 60%),
    radial-gradient(60% 70% at 60% 95%, rgba(255,194,75,.28), transparent 55%),
    radial-gradient(50% 50% at 30% 80%, rgba(14,124,140,.5), transparent 60%);
  filter: blur(28px); animation: meshFloat 18s ease-in-out infinite alternate; opacity: .9;
}
@keyframes meshFloat {
  0% { transform: translate3d(0,0,0) scale(1); }
  50% { transform: translate3d(2%, -2%, 0) scale(1.08); }
  100% { transform: translate3d(-2%, 1%, 0) scale(1.04); }
}
.hero__grain { position: absolute; inset: 0; opacity: .5; mix-blend-mode: overlay;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='140' height='140'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='3'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='.5'/%3E%3C/svg%3E"); }
.hero__grid { position:absolute; inset:0; opacity:.14;
  background-image: linear-gradient(rgba(255,255,255,.6) 1px, transparent 1px), linear-gradient(90deg, rgba(255,255,255,.6) 1px, transparent 1px);
  background-size: 64px 64px; mask-image: radial-gradient(circle at 50% 0%, #000, transparent 78%); }

.hero__inner { position: relative; z-index: 2; display: grid; grid-template-columns: 1.05fr .95fr; gap: clamp(32px, 5vw, 72px); align-items: center; }
.hero__badge { display:inline-flex; align-items:center; gap:10px; padding:8px 8px 8px 16px; border-radius:100px; background:rgba(255,255,255,.08); border:1px solid rgba(255,255,255,.18); backdrop-filter:blur(8px); font-size:13.5px; font-weight:600; margin-bottom:26px; }
.hero__badge b { background: var(--ember); color:#fff; padding:3px 10px; border-radius:100px; font-size:12px; font-weight:800; letter-spacing:.02em; }
.hero h1 { color:#fff; font-size: clamp(38px, 6vw, 74px); font-weight:700; margin-bottom: 22px; letter-spacing:-.03em; }
.hero h1 .warm { background: linear-gradient(105deg, var(--amber), var(--ember)); -webkit-background-clip: text; background-clip: text; -webkit-text-fill-color: transparent; }
.hero h1 .cool { background: linear-gradient(105deg, var(--cool), var(--frost)); -webkit-background-clip: text; background-clip: text; -webkit-text-fill-color: transparent; }
.hero__sub { font-size: clamp(17px, 2.2vw, 21px); color: rgba(255,255,255,.8); max-width: 540px; margin-bottom: 30px; }
.hero__cta-row { display:flex; align-items:center; gap:16px; flex-wrap:wrap; margin-bottom:34px; }
.hero__trust { display:flex; align-items:center; gap:26px; flex-wrap:wrap; }
.hero__trust-item { display:flex; align-items:center; gap:10px; font-size:14px; color:rgba(255,255,255,.78); font-weight:600; }
.hero__trust-item svg { width:20px; height:20px; color: var(--cool); flex-shrink:0; }
.hero__stars { display:flex; gap:2px; }
.hero__stars svg { width:16px; height:16px; color: var(--amber); }

/* ---------- Quote form (centerpiece) ---------- */
.quote-card {
  background: rgba(255,255,255,.97); border-radius: var(--radius-lg); padding: 30px;
  box-shadow: var(--shadow-lg); position: relative; color: var(--text);
  border: 1px solid rgba(255,255,255,.5);
}
.quote-card__head { display:flex; align-items:center; justify-content:space-between; margin-bottom: 20px; gap: 12px; }
.quote-card__title { font-family: var(--font-display); font-weight:700; font-size: 21px; color: var(--ink); letter-spacing:-.02em; line-height:1.15; }
.quote-card__title span { display:block; font-family: var(--font-body); font-weight:600; font-size:13px; color: var(--cool-deep); letter-spacing:0; }
.quote-card__free { background: var(--frost); color: var(--cool-deep); font-weight:800; font-size:12px; padding:7px 12px; border-radius:100px; white-space:nowrap; }

.qprogress { display:flex; gap:6px; margin-bottom: 24px; }
.qprogress__seg { flex:1; height:5px; border-radius:100px; background: var(--paper-2); overflow:hidden; }
.qprogress__seg i { display:block; height:100%; width:0; border-radius:100px; background: linear-gradient(90deg,var(--cool),var(--ember)); transition: width .5s var(--ease); }
.qprogress__seg.done i { width:100%; }
.qprogress__seg.active i { width:100%; }

.qstep { display:none; animation: none; }
.qstep.active { display:block; animation: stepIn .5s var(--ease) both; }
@keyframes stepIn { from { opacity:0; transform: translateX(16px); } to { opacity:1; transform:none; } }
.qstep__q { font-family: var(--font-display); font-weight:700; font-size: 20px; color: var(--ink); margin-bottom: 4px; letter-spacing:-.01em; }
.qstep__hint { font-size: 13.5px; color: var(--muted); margin-bottom: 18px; }

.qopts { display:grid; grid-template-columns: 1fr 1fr; gap: 10px; }
.qopt {
  display:flex; align-items:center; gap:12px; padding:15px 16px; border-radius: var(--radius-sm);
  border:1.5px solid var(--line); background: var(--card); text-align:left; transition: all .2s var(--ease); font-weight:600; font-size:15px; color: var(--text);
}
.qopt:hover { border-color: var(--cool); background: var(--frost); transform: translateY(-1px); }
.qopt.selected { border-color: var(--ember); background: linear-gradient(0deg, rgba(255,106,43,.07), rgba(255,106,43,.07)); box-shadow: 0 0 0 3px rgba(255,106,43,.12); }
.qopt__icon { width:38px; height:38px; border-radius:10px; background: var(--paper-2); display:grid; place-items:center; flex-shrink:0; transition:.2s; }
.qopt__icon svg { width:20px; height:20px; color: var(--cool-deep); }
.qopt.selected .qopt__icon { background: var(--ember); }
.qopt.selected .qopt__icon svg { color:#fff; }

.qfield { margin-bottom: 14px; }
.qfield label { display:block; font-weight:700; font-size:13.5px; margin-bottom:7px; color: var(--ink); }
.qinput {
  width:100%; padding:14px 16px; border-radius: var(--radius-sm); border:1.5px solid var(--line);
  background: var(--card); color: var(--text); transition: border .2s, box-shadow .2s; font-size:16px;
}
.qinput:focus { outline:none; border-color: var(--cool); box-shadow: 0 0 0 3px rgba(23,182,201,.15); }
.qinput::placeholder { color: var(--muted-2); }
.qrow { display:grid; grid-template-columns: 1fr 1fr; gap:12px; }

.qconsent { display:flex; gap:11px; align-items:flex-start; margin:16px 0 18px; padding:14px; background:var(--paper-2); border-radius:var(--radius-sm); }
.qconsent input { margin-top:3px; width:18px; height:18px; accent-color: var(--ember); flex-shrink:0; cursor:pointer; }
.qconsent label { font-size:11.5px; line-height:1.5; color: var(--muted); cursor:pointer; }
.qconsent a { color: var(--cool-deep); text-decoration: underline; font-weight:600; }

.qnav { display:flex; gap:12px; margin-top: 6px; }
.qback { padding:15px 20px; border-radius:100px; border:1.5px solid var(--line); color:var(--muted); font-weight:700; background:var(--card); transition:.2s; }
.qback:hover { border-color: var(--line-strong); color: var(--ink); }
.qerror { color: var(--ember-2); font-size:13px; font-weight:600; margin-top:8px; min-height:0; }
.qsecure { display:flex; align-items:center; justify-content:center; gap:7px; margin-top:16px; font-size:12px; color: var(--muted-2); font-weight:600; }
.qsecure svg { width:14px; height:14px; }

.qsuccess { text-align:center; padding:20px 6px; display:none; }
.qsuccess.show { display:block; animation: stepIn .5s var(--ease) both; }
.qsuccess__ring { width:76px; height:76px; margin:0 auto 18px; border-radius:50%; background: linear-gradient(135deg,var(--cool),var(--cool-deep)); display:grid; place-items:center; box-shadow:0 12px 30px -8px rgba(23,182,201,.5); }
.qsuccess__ring svg { width:38px; height:38px; color:#fff; }
.qsuccess h3 { font-size:24px; margin-bottom:10px; }
.qsuccess p { color: var(--muted); font-size:15px; }

/* ---------- Marquee / trust bar ---------- */
.logobar { background: var(--card); border-block: 1px solid var(--line); padding: 26px 0; }
.logobar__inner { display:flex; align-items:center; justify-content:space-between; gap:24px; flex-wrap:wrap; }
.logobar__label { font-size:13px; font-weight:700; letter-spacing:.1em; text-transform:uppercase; color: var(--muted-2); }
.logobar__items { display:flex; align-items:center; gap:34px; flex-wrap:wrap; }
.logobar__item { display:flex; align-items:center; gap:9px; font-weight:700; color: var(--muted); font-size:15px; }
.logobar__item svg { width:22px; height:22px; color: var(--cool-deep); }

/* ---------- Stats ---------- */
.stats { display:grid; grid-template-columns: repeat(4,1fr); gap:24px; }
.stat { text-align:center; padding: 8px; }
.stat__num { font-family: var(--font-display); font-weight:800; font-size: clamp(34px,5vw,54px); letter-spacing:-.03em; background:linear-gradient(135deg,var(--ink),var(--cool-deep)); -webkit-background-clip:text; background-clip:text; -webkit-text-fill-color:transparent; line-height:1; }
.stat__label { color: var(--muted); font-weight:600; font-size:15px; margin-top:8px; }

/* ---------- How it works ---------- */
.steps { display:grid; grid-template-columns: repeat(3,1fr); gap:24px; counter-reset: step; }
.step {
  background: var(--card); border:1px solid var(--line); border-radius: var(--radius-lg); padding: 34px 28px;
  position: relative; overflow:hidden; transition: transform .4s var(--ease), box-shadow .4s;
}
.step:hover { transform: translateY(-6px); box-shadow: var(--shadow-md); }
.step::before { counter-increment: step; content: "0" counter(step); position:absolute; top:18px; right:24px; font-family:var(--font-display); font-weight:800; font-size:52px; color: var(--paper-2); line-height:1; }
.step__icon { width:60px; height:60px; border-radius:16px; display:grid; place-items:center; margin-bottom:22px; background: linear-gradient(140deg, var(--ink), var(--ink-3)); box-shadow: var(--shadow-sm); position:relative; z-index:1; }
.step__icon svg { width:28px; height:28px; color: var(--cool); }
.step:nth-child(2) .step__icon { background: linear-gradient(140deg, var(--cool-deep), var(--cool)); }
.step:nth-child(2) .step__icon svg { color:#fff; }
.step:nth-child(3) .step__icon { background: linear-gradient(140deg, var(--ember-2), var(--ember)); }
.step:nth-child(3) .step__icon svg { color:#fff; }
.step h3 { font-size:22px; margin-bottom:10px; }
.step p { color: var(--muted); font-size:15.5px; }

/* ---------- Services grid ---------- */
.services { display:grid; grid-template-columns: repeat(3,1fr); gap:20px; }
.svc {
  background: var(--card); border:1px solid var(--line); border-radius: var(--radius); padding:28px; transition:.35s var(--ease); position:relative; overflow:hidden;
}
.svc::after { content:""; position:absolute; inset:0 0 auto 0; height:3px; background:linear-gradient(90deg,var(--cool),var(--ember)); transform:scaleX(0); transform-origin:left; transition:transform .4s var(--ease); }
.svc:hover { transform: translateY(-4px); box-shadow: var(--shadow-md); border-color: transparent; }
.svc:hover::after { transform:scaleX(1); }
.svc__icon { width:52px; height:52px; border-radius:14px; background:var(--frost); display:grid; place-items:center; margin-bottom:18px; transition:.3s; }
.svc__icon svg { width:26px; height:26px; color: var(--cool-deep); }
.svc:hover .svc__icon { background: var(--ink); }
.svc:hover .svc__icon svg { color: var(--cool); }
.svc h3 { font-size:19px; margin-bottom:8px; }
.svc p { color: var(--muted); font-size:14.5px; margin-bottom:14px; }
.svc__link { display:inline-flex; align-items:center; gap:6px; font-weight:700; font-size:14px; color: var(--ember-2); }
.svc__link svg { width:15px; height:15px; transition: transform .25s; }
.svc:hover .svc__link svg { transform: translateX(4px); }

/* ---------- Split / why ---------- */
.split { display:grid; grid-template-columns: 1fr 1fr; gap: clamp(32px,5vw,72px); align-items:center; }
.why-list { display:grid; gap:18px; margin-top: 26px; }
.why-item { display:flex; gap:16px; }
.why-item__check { width:34px; height:34px; border-radius:10px; background:var(--frost); display:grid; place-items:center; flex-shrink:0; }
.why-item__check svg { width:18px; height:18px; color: var(--cool-deep); }
.why-item h4 { font-size:17px; margin-bottom:3px; color:var(--ink); }
.why-item p { font-size:14.5px; color: var(--muted); }
.why-visual { position:relative; border-radius: var(--radius-lg); overflow:hidden; background: var(--ink); aspect-ratio: 4/3.4; box-shadow: var(--shadow-lg); }
.why-visual .hero__mesh { filter: blur(34px); opacity:.85; }
.why-card-float { position:absolute; background:rgba(255,255,255,.97); border-radius:16px; padding:16px 18px; box-shadow: var(--shadow-md); display:flex; align-items:center; gap:12px; }
.why-card-float svg { width:34px; height:34px; }
.why-card-float b { display:block; font-family:var(--font-display); font-size:18px; color:var(--ink); }
.why-card-float span { font-size:12.5px; color:var(--muted); }
.wcf-1 { top:22px; left:22px; }
.wcf-2 { bottom:22px; right:22px; }
.wcf-3 { bottom:40%; left:26px; }

/* ---------- Cost guide / AEO answer blocks ---------- */
.answer-grid { display:grid; grid-template-columns: repeat(2,1fr); gap:20px; }
.answer {
  background: var(--card); border:1px solid var(--line); border-left:4px solid var(--cool); border-radius: 12px; padding:24px;
}
.answer:nth-child(even) { border-left-color: var(--ember); }
.answer h3 { font-size:17px; margin-bottom:10px; color:var(--ink); }
.answer p { font-size:15px; color: var(--muted); }
.answer p strong { color: var(--ink); }

.costtable { width:100%; border-collapse:collapse; background:var(--card); border-radius:var(--radius); overflow:hidden; box-shadow: var(--shadow-sm); border:1px solid var(--line); margin-top: 8px; }
.costtable th, .costtable td { padding:15px 20px; text-align:left; border-bottom:1px solid var(--line); font-size:15px; }
.costtable th { background: var(--ink); color:#fff; font-family:var(--font-display); font-weight:600; font-size:14px; letter-spacing:.01em; }
.costtable tr:last-child td { border-bottom:none; }
.costtable td:last-child { font-weight:700; color: var(--cool-deep); }
.costtable tbody tr:hover { background: var(--frost); }

/* ---------- Testimonials ---------- */
.tcards { display:grid; grid-template-columns: repeat(3,1fr); gap:20px; }
.tcard { background: var(--card); border:1px solid var(--line); border-radius: var(--radius); padding:26px; transition:.35s; }
.tcard:hover { transform: translateY(-4px); box-shadow: var(--shadow-md); }
.tcard__stars { display:flex; gap:2px; margin-bottom:14px; }
.tcard__stars svg { width:16px; height:16px; color: var(--amber); }
.tcard p { font-size:15.5px; color: var(--text); margin-bottom:20px; }
.tcard__who { display:flex; align-items:center; gap:12px; }
.tcard__avatar { width:44px; height:44px; border-radius:50%; display:grid; place-items:center; font-family:var(--font-display); font-weight:800; color:#fff; font-size:16px; }
.tcard__who b { display:block; font-size:15px; color:var(--ink); }
.tcard__who span { font-size:13px; color: var(--muted-2); }

/* ---------- FAQ ---------- */
.faq { max-width: 820px; margin-inline:auto; }
.faq-item { border-bottom:1px solid var(--line); }
.faq-q { width:100%; display:flex; align-items:center; justify-content:space-between; gap:20px; padding:24px 4px; text-align:left; font-family:var(--font-display); font-weight:600; font-size: clamp(17px,2.2vw,20px); color:var(--ink); }
.faq-q__icon { width:32px; height:32px; border-radius:50%; border:1.5px solid var(--line-strong); display:grid; place-items:center; flex-shrink:0; transition:.3s var(--ease); position:relative; }
.faq-q__icon::before, .faq-q__icon::after { content:""; position:absolute; background: var(--ink); border-radius:2px; transition:.3s var(--ease); }
.faq-q__icon::before { width:12px; height:2px; }
.faq-q__icon::after { width:2px; height:12px; }
.faq-item.open .faq-q__icon { background: var(--ember); border-color: var(--ember); transform: rotate(180deg); }
.faq-item.open .faq-q__icon::before, .faq-item.open .faq-q__icon::after { background:#fff; }
.faq-item.open .faq-q__icon::after { transform: scaleY(0); }
.faq-a { max-height:0; overflow:hidden; transition: max-height .45s var(--ease); }
.faq-a__inner { padding: 0 4px 24px; color: var(--muted); font-size:16px; max-width: 90%; }

/* ---------- CTA band ---------- */
.cta-band { background: var(--ink); color:#fff; border-radius: var(--radius-lg); padding: clamp(40px,6vw,72px); position:relative; overflow:hidden; text-align:center; }
.cta-band__mesh { position:absolute; inset:0; background: radial-gradient(50% 80% at 20% 10%, rgba(23,182,201,.4), transparent 60%), radial-gradient(50% 80% at 85% 90%, rgba(255,106,43,.45), transparent 60%); filter: blur(20px); }
.cta-band > * { position:relative; z-index:1; }
.cta-band h2 { color:#fff; font-size: clamp(30px,4.5vw,50px); margin-bottom:16px; }
.cta-band p { color: rgba(255,255,255,.8); font-size:19px; max-width:560px; margin:0 auto 30px; }
.cta-band__row { display:flex; gap:16px; justify-content:center; flex-wrap:wrap; }

/* ---------- Footer ---------- */
.footer { background: var(--ink); color: rgba(255,255,255,.72); padding: 72px 0 32px; }
.footer__top { display:grid; grid-template-columns: 1.4fr 1fr 1fr 1fr; gap: 40px; padding-bottom: 44px; border-bottom:1px solid rgba(255,255,255,.1); }
.footer .brand { color:#fff; margin-bottom:16px; }
.footer__about { font-size:14.5px; max-width:320px; margin-bottom:20px; }
.footer__tel { display:inline-flex; align-items:center; gap:9px; font-family:var(--font-display); font-weight:700; font-size:22px; color:#fff; }
.footer__tel svg { width:20px; height:20px; color: var(--cool); }
.footer__col h5 { color:#fff; font-family:var(--font-display); font-weight:600; font-size:15px; margin-bottom:18px; letter-spacing:.02em; }
.footer__col ul { display:grid; gap:11px; }
.footer__col a { font-size:14.5px; transition:color .2s; }
.footer__col a:hover { color: var(--cool); }
.footer__disclaimer { font-size:12.5px; line-height:1.7; color: rgba(255,255,255,.5); padding: 28px 0; border-bottom:1px solid rgba(255,255,255,.1); }
.footer__disclaimer strong { color: rgba(255,255,255,.75); }
.footer__bottom { display:flex; align-items:center; justify-content:space-between; gap:20px; flex-wrap:wrap; padding-top:26px; font-size:13px; }
.footer__bottom-links { display:flex; gap:22px; flex-wrap:wrap; }

/* ---------- Sticky mobile call bar ---------- */
.callbar { position:fixed; left:0; right:0; bottom:0; z-index:90; display:none; gap:10px; padding:10px 14px; background:rgba(251,250,247,.95); backdrop-filter:blur(14px); box-shadow:0 -2px 20px rgba(10,21,36,.14); }
.callbar .btn { flex:1; }

/* ---------- Reveal animations ---------- */
.reveal { opacity:0; transform: translateY(26px); transition: opacity .7s var(--ease), transform .7s var(--ease); }
.reveal.in { opacity:1; transform:none; }
.reveal[data-d="1"] { transition-delay:.08s; }
.reveal[data-d="2"] { transition-delay:.16s; }
.reveal[data-d="3"] { transition-delay:.24s; }
.reveal[data-d="4"] { transition-delay:.32s; }
@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after { animation-duration:.001ms !important; transition-duration:.001ms !important; }
  .reveal { opacity:1; transform:none; }
}

/* ---------- Generic page header (interior pages) ---------- */
.page-hero { background: var(--ink); color:#fff; padding: clamp(48px,7vw,90px) 0 clamp(40px,6vw,70px); position:relative; overflow:hidden; }
.page-hero__inner { position:relative; z-index:2; max-width:820px; }
.page-hero h1 { color:#fff; font-size: clamp(32px,5vw,58px); margin-bottom:16px; }
.page-hero p { color: rgba(255,255,255,.82); font-size: clamp(16px,2vw,20px); max-width:640px; }
.breadcrumb { display:flex; gap:8px; align-items:center; font-size:13.5px; color:rgba(255,255,255,.6); margin-bottom:22px; font-weight:600; }
.breadcrumb a:hover { color: var(--cool); }
.breadcrumb span { opacity:.5; }

/* Prose for legal / guide pages */
.prose { max-width: 820px; }
.prose h2 { font-size: clamp(24px,3.4vw,34px); margin: 44px 0 16px; }
.prose h3 { font-size: 20px; margin: 30px 0 12px; color: var(--ink); }
.prose p { color: var(--text); margin-bottom:16px; }
.prose ul.bullets { list-style: disc; padding-left: 22px; margin-bottom:18px; color: var(--text); }
.prose ul.bullets li { margin-bottom:8px; }
.prose a { color: var(--cool-deep); font-weight:600; text-decoration: underline; }
.prose .note { background: var(--paper-2); border-left:4px solid var(--ember); border-radius: 10px; padding:18px 22px; margin:22px 0; font-size:15px; }
.prose .updated { color: var(--muted-2); font-size:14px; font-weight:600; margin-bottom: 8px; }

/* ---------- Responsive ---------- */
@media (max-width: 1000px) {
  .hero__inner { grid-template-columns: 1fr; }
  .hero__form-col { max-width: 520px; }
  .split { grid-template-columns: 1fr; }
  .footer__top { grid-template-columns: 1fr 1fr; gap:32px; }
  .stats { grid-template-columns: 1fr 1fr; gap:32px 16px; }
}
@media (max-width: 860px) {
  .nav__links, .nav__tel-text { display:none; }
  .nav__toggle { display:block; }
  .nav.mobile-open .nav__links { display:flex; position:absolute; top:100%; left:0; right:0; flex-direction:column; align-items:flex-start; gap:4px; background:var(--paper); padding:16px 6vw 24px; box-shadow: var(--shadow-md); }
  .nav.mobile-open .nav__links a { padding:12px 0; width:100%; border-bottom:1px solid var(--line); }
  .steps, .services, .tcards, .answer-grid { grid-template-columns: 1fr; }
  .callbar { display:flex; }
  body { padding-bottom: 68px; }
  .footer__bottom { justify-content:center; text-align:center; }
}
@media (max-width: 560px) {
  .qopts, .qrow { grid-template-columns: 1fr; }
  .stats { grid-template-columns: 1fr 1fr; }
  .footer__top { grid-template-columns: 1fr; }
  .quote-card { padding: 22px; }
  .hero__trust { gap:16px; }
}
