/* ============================================================
   CALL BEFORE THE CALL  --  shared styles (rich build)
   Orange (action) + deep navy (anchor) + light blue (accent).
   Headings: Lora/Gelasio.  Body: Mulish/Lato.
   ============================================================ */
:root{
  --orange:#E85D3F;   --orange-dk:#cf4a2e;   --orange-2:#F2854E;
  --navy:#15263D;     --navy-dk:#0F1B2D;
  --blue:#2E6FB0;     --sky:#7FB6E6;
  --sky-wash:#EAF2FB; --orange-wash:#FDEDE7;
  --ground:#F5F8FC;   --paper:#ffffff;
  --ink:#15263D;      --body:#33404F;  --muted:#7A8896;  --line:#E3E9F1;
  --maxw:1080px;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;font-family:"Mulish",-apple-system,Segoe UI,sans-serif;color:var(--body);background:var(--ground);font-size:18px;line-height:1.6;-webkit-font-smoothing:antialiased}
h1,h2,h3,h4{font-family:"Gelasio",Cambria,Georgia,serif;color:var(--ink);line-height:1.1;font-weight:600;margin:0}
p{margin:0 0 1em}
a{color:inherit}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 28px;position:relative;z-index:2}

/* marker highlight on key words */
.marker{background:linear-gradient(104deg,rgba(232,93,63,0) .5%,rgba(232,93,63,.26) 2%,rgba(232,93,63,.26) 96%,rgba(232,93,63,0) 98.5%);padding:0 .12em;border-radius:.08em}
.u-orange{color:var(--orange)}

/* grounds */
section{padding:80px 0;position:relative;overflow:hidden}
.bg-ground{background:var(--ground)}
.bg-white{background:var(--paper)}
.bg-sky-wash{background:var(--sky-wash)}
.bg-orange-wash{background:var(--orange-wash)}
.bg-orange{background:linear-gradient(140deg,var(--orange) 0%,var(--orange-dk) 100%);color:#fff}
.bg-orange h1,.bg-orange h2,.bg-orange h3{color:#fff}
.bg-navy{background:var(--navy);color:#c7d3e0}
.bg-navy h2,.bg-navy h3{color:#fff}

/* dot-grid texture overlay */
.tex::before{content:"";position:absolute;inset:0;background-image:radial-gradient(rgba(46,111,176,.10) 1.2px,transparent 1.2px);background-size:24px 24px;opacity:.6;pointer-events:none;z-index:0}
.bg-navy.tex::before{background-image:radial-gradient(rgba(255,255,255,.06) 1.2px,transparent 1.2px)}

/* labels */
.label{font-family:"Mulish";font-weight:800;font-size:12px;letter-spacing:.26em;text-transform:uppercase;color:var(--orange);display:inline-block;margin-bottom:14px}
.label.blue{color:var(--blue)}.label.light{color:#ffe7df}.label.sky{color:var(--sky)}
.label::after{content:"";display:block;width:30px;height:3px;background:currentColor;margin-top:9px;border-radius:2px}

/* buttons */
.btn{display:inline-block;font-family:"Mulish";font-weight:800;font-size:16px;text-decoration:none;cursor:pointer;border:none;border-radius:9px;padding:15px 30px;transition:transform .12s,background .15s,box-shadow .15s}
.btn:hover{transform:translateY(-2px)}
.btn-orange{background:var(--orange);color:#fff;box-shadow:0 10px 24px rgba(232,93,63,.34)}
.btn-orange:hover{background:var(--orange-dk);box-shadow:0 14px 30px rgba(232,93,63,.42)}
.btn-navy{background:var(--navy);color:#fff;box-shadow:0 8px 22px rgba(21,38,61,.25)}
.btn-navy:hover{background:var(--navy-dk)}
.btn-ghost{background:transparent;color:var(--ink);border:2px solid var(--ink);padding:13px 28px}
.btn-ghost:hover{background:var(--ink);color:#fff}
.btn-ghost-light{background:transparent;color:#fff;border:2px solid rgba(255,255,255,.55);padding:13px 28px}
.btn-ghost-light:hover{background:#fff;color:var(--navy)}
.btn-white{background:#fff;color:var(--orange)}.btn-white:hover{background:#eef4fb}
.btn-row{display:flex;gap:14px;flex-wrap:wrap;align-items:center}

/* nav */
header.nav{position:sticky;top:0;z-index:50;background:rgba(245,248,252,.94);backdrop-filter:blur(8px);border-bottom:1px solid var(--line)}
.nav-inner{display:flex;align-items:center;justify-content:space-between;height:70px;gap:18px}
.brandmark{display:flex;align-items:center;gap:10px;font-family:"Gelasio",serif;font-weight:700;font-size:20px;color:var(--ink);text-decoration:none;letter-spacing:-.01em;white-space:nowrap}
.brandmark .mark{width:30px;height:30px;flex:none}
.brandmark .dot{color:var(--orange)}
.nav-links{display:flex;gap:22px;align-items:center}
.nav-links a{font-weight:700;font-size:15px;text-decoration:none;color:var(--body);position:relative;white-space:nowrap}
.nav-links a:not(.cta):not(.phone):hover{color:var(--orange)}
.nav-links a.active:not(.cta){color:var(--orange)}
.nav-links a.active:not(.cta)::after{content:"";position:absolute;left:0;bottom:-6px;width:100%;height:2px;background:var(--orange)}
.nav-links a.phone{color:var(--blue);font-weight:800}
.nav-links a.cta{background:var(--orange);color:#fff;padding:10px 20px;border-radius:8px;box-shadow:0 6px 16px rgba(232,93,63,.3)}
.nav-links a.cta:hover{background:var(--orange-dk);color:#fff}
/* mobile nav handled by the hamburger system at the end of this file */

/* glow + wave divider */
.sun{position:absolute;border-radius:50%;background:radial-gradient(circle,rgba(46,111,176,.16) 0%,rgba(46,111,176,0) 70%);pointer-events:none;z-index:0}
.wave{position:absolute;left:0;bottom:-1px;width:100%;height:54px;display:block;z-index:1}

/* hero */
.hero{padding:90px 0 96px;background:linear-gradient(160deg,#FFFFFF 0%,#EAF2FB 58%,#DCEAF8 100%)}
.hero .sun{width:520px;height:520px;top:-150px;right:-90px}
.hero-grid{display:grid;grid-template-columns:1.15fr .85fr;gap:30px;align-items:center}
.logo-lockup{position:relative;display:inline-block}
.hero h1{font-size:clamp(46px,8vw,84px);font-weight:700;letter-spacing:-.02em}
.swoosh{display:block;width:min(420px,82%);height:26px;margin-top:2px;color:var(--orange)}
.hero .tagline{font-family:"Gelasio";font-style:italic;color:var(--orange);font-size:clamp(23px,4vw,36px);margin:20px 0 0}
.hero .sub{font-size:21px;max-width:520px;margin:22px 0 30px;color:var(--body)}
.dots{display:flex;gap:11px;margin:32px 0 0}
.dots span{width:14px;height:14px;border-radius:50%}
.dots span:nth-child(1){background:var(--orange)}.dots span:nth-child(2){background:var(--navy)}.dots span:nth-child(3){background:var(--sky)}
.hero-art{justify-self:center;width:100%;max-width:380px}
@media(max-width:880px){.hero-grid{grid-template-columns:1fr}.hero-art{display:none}}

/* inner page header */
.pagehead{padding:66px 0 78px;background:linear-gradient(160deg,#FFFFFF 0%,#EAF2FB 100%)}
.pagehead .sun{width:420px;height:420px;top:-140px;right:-70px}
.pagehead h1{font-size:clamp(36px,6vw,58px);font-style:italic;font-weight:600}
.pagehead .swoosh{width:min(340px,70%);margin-top:6px}
.pagehead p{font-size:20px;max-width:660px;margin-top:18px}

/* heads */
.sec-head{max-width:740px;margin-bottom:40px}
.sec-head h2{font-size:clamp(29px,5vw,46px);font-style:italic}
.sec-head p{font-size:20px;margin-top:14px}
.lead{font-size:20px;max-width:760px}

/* icon chip */
.ic{width:48px;height:48px;border-radius:13px;background:var(--sky-wash);display:flex;align-items:center;justify-content:center;margin-bottom:16px}
.ic svg{width:24px;height:24px;stroke:var(--blue);fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}
.ic.orange{background:var(--orange-wash)}.ic.orange svg{stroke:var(--orange)}

/* versus */
.versus{display:grid;grid-template-columns:1fr 1fr;gap:22px;margin-top:36px}
.versus .card{padding:30px;border-radius:16px}
.versus .bad{background:var(--paper);border:1.5px dashed var(--muted)}
.versus .good{background:linear-gradient(140deg,var(--orange) 0%,var(--orange-dk) 100%);box-shadow:0 18px 38px rgba(232,93,63,.32)}
.versus h4{font-size:13px;letter-spacing:.2em;text-transform:uppercase;margin-bottom:10px;font-family:"Mulish";font-weight:800}
.versus .bad h4{color:var(--muted)}.versus .good h4{color:#ffe7df}
.versus .bad p{color:var(--body);margin:0;font-size:17px}.versus .good p{color:#fff;margin:0;font-size:17px}
@media(max-width:680px){.versus{grid-template-columns:1fr}}

/* step flow */
.flow{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-top:42px}
.step{position:relative;background:var(--paper);border-radius:16px;padding:26px 22px;border-top:5px solid var(--blue);box-shadow:0 10px 26px rgba(21,38,61,.08);transition:transform .15s,box-shadow .15s}
.step:hover{transform:translateY(-5px);box-shadow:0 16px 34px rgba(21,38,61,.13)}
.step:nth-child(4){border-top-color:var(--orange)}
.step .bignum{position:absolute;right:8px;top:6px;line-height:1;font-family:"Gelasio";font-size:84px;font-weight:700;color:var(--sky-wash);z-index:0}
.step:nth-child(4) .bignum{color:var(--orange-wash)}
.step .ic,.step h4,.step p{position:relative;z-index:1}
.step h4{font-family:"Mulish";font-weight:800;font-size:12px;letter-spacing:.16em;text-transform:uppercase;color:var(--blue);margin:0 0 9px}
.step:nth-child(4) h4{color:var(--orange)}
.step p{font-size:16px;margin:0}
.step::after{content:"\2192";position:absolute;right:-13px;top:50%;transform:translateY(-50%);color:var(--blue);font-size:22px;font-weight:700;z-index:3}
.step:last-child::after{display:none}
@media(max-width:880px){.flow{grid-template-columns:1fr 1fr}.step::after{display:none}}
@media(max-width:480px){.flow{grid-template-columns:1fr}}

/* not-cards */
.notrow{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-top:38px}
.notcard{background:var(--paper);border-radius:16px;padding:28px;border-top:5px solid var(--orange);box-shadow:0 10px 26px rgba(21,38,61,.08)}
.notcard:nth-child(2){border-top-color:var(--blue)}
.notcard h4{font-size:13px;letter-spacing:.18em;text-transform:uppercase;font-family:"Mulish";font-weight:800;color:var(--ink);margin-bottom:9px}
.notcard p{font-size:16px;margin:0}
@media(max-width:760px){.notrow{grid-template-columns:1fr}}

/* cost */
.cost-big{font-family:"Gelasio";color:#fff;font-size:clamp(46px,10vw,90px);font-weight:700;letter-spacing:-.02em}
.costflow{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-top:38px}
.costflow .cell{position:relative;background:var(--paper);border-radius:16px;padding:30px 24px;text-align:center;border-top:5px solid var(--blue);box-shadow:0 10px 26px rgba(21,38,61,.1)}
.costflow .cell:last-child{background:var(--navy);border-top-color:var(--orange)}
.costflow .who{font-family:"Mulish";font-weight:800;letter-spacing:.16em;text-transform:uppercase;font-size:13px;color:var(--blue);margin-bottom:9px}
.costflow .cell:last-child .who{color:#ffb59f}
.costflow .what{font-family:"Gelasio";font-style:italic;font-size:18px;color:var(--ink)}
.costflow .cell:last-child .what{color:#fff}
.costflow .cell::after{content:"\2192";position:absolute;right:-13px;top:50%;transform:translateY(-50%);color:var(--blue);font-size:22px;font-weight:700;z-index:2}
.costflow .cell:last-child::after{display:none}
.freeline{font-family:"Gelasio";font-style:italic;font-size:30px;color:#fff;text-align:center}
@media(max-width:680px){.costflow{grid-template-columns:1fr}.costflow .cell::after{display:none}}

/* who cards */
.who-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;margin-top:38px}
.who-card{background:var(--paper);border-radius:18px;padding:30px 26px;box-shadow:0 10px 28px rgba(21,38,61,.08);transition:transform .15s;border-bottom:4px solid transparent}
.who-card:hover{transform:translateY(-6px);border-bottom-color:var(--orange)}
.who-card .pill{display:inline-block;font-family:"Mulish";font-weight:800;font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:#fff;background:var(--blue);padding:5px 13px;border-radius:30px;margin-bottom:15px}
.who-card:nth-child(2) .pill{background:var(--orange)}
.who-card h3{font-size:23px;font-style:italic;margin-bottom:10px}
.who-card p{font-size:16px;margin:0}
@media(max-width:1040px){.who-grid{grid-template-columns:repeat(2,1fr)}}@media(max-width:600px){.who-grid{grid-template-columns:1fr}}

/* quotes */
.quotes{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;margin-top:38px}
.quote{position:relative;background:var(--paper);border-radius:16px;padding:34px 30px 30px;box-shadow:0 10px 28px rgba(21,38,61,.08);border-left:5px solid var(--orange)}
.quote:nth-child(2){border-left-color:var(--blue)}
.quote::before{content:"\201C";position:absolute;top:2px;left:18px;font-family:"Gelasio";font-size:64px;color:var(--orange);opacity:.25;line-height:1}
.quote:nth-child(2)::before{color:var(--blue)}
.quote p{font-family:"Gelasio";font-style:italic;font-size:19px;color:var(--ink);margin-bottom:14px;position:relative}
.quote .who{font-family:"Mulish";font-weight:800;font-size:13px;color:var(--muted);text-transform:uppercase}
@media(max-width:820px){.quotes{grid-template-columns:1fr}}

/* people */
.people{display:grid;grid-template-columns:1fr 1fr;gap:24px;margin-top:38px}
.person{background:var(--paper);border-radius:18px;padding:34px;border-left:6px solid var(--orange);box-shadow:0 10px 28px rgba(21,38,61,.08)}
.person:nth-child(2){border-left-color:var(--blue)}
.person .role{font-family:"Mulish";font-weight:800;font-size:12px;letter-spacing:.18em;text-transform:uppercase;color:var(--orange)}
.person:nth-child(2) .role{color:var(--blue)}
.person h3{font-family:"Gelasio";font-size:34px;font-style:italic;margin:8px 0 14px}
.person ul{margin:0 0 14px;padding-left:20px}
.person li{margin-bottom:7px;font-size:16px}
.person .ph{font-size:14px;color:var(--muted);background:var(--sky-wash);border-radius:8px;padding:12px 14px;margin:0}
.couple{margin:34px auto 8px;max-width:600px;text-align:center}
.couple-photo{display:block;border-radius:18px;overflow:hidden;border:5px solid #fff;box-shadow:0 16px 40px rgba(21,38,61,.18)}
.couple-photo img{display:block;width:100%;height:auto}
.couple figcaption{margin-top:14px;font-size:15px;color:var(--muted)}
.person p{margin:6px 0 0;font-size:16px;line-height:1.65;color:var(--body)}
.pullquote{position:relative;max-width:720px;margin:40px auto 0;text-align:center;font-family:"Gelasio";font-style:italic;font-size:25px;line-height:1.5;color:var(--ink)}
.pullquote cite{display:block;margin-top:14px;font-family:"Mulish";font-style:normal;font-weight:800;font-size:12px;letter-spacing:.16em;text-transform:uppercase;color:var(--orange)}
@media(max-width:680px){.people{grid-template-columns:1fr}.pullquote{font-size:21px}.couple{max-width:none}}

/* service area */
.area-grid{display:flex;flex-wrap:wrap;gap:11px;margin-top:26px}
.area-grid span{background:var(--paper);border:1px solid var(--line);border-radius:30px;padding:9px 18px;font-weight:700;font-size:15px;color:var(--ink);box-shadow:0 3px 10px rgba(21,38,61,.05)}

/* faq */
.faq details{background:var(--paper);border-radius:12px;margin-bottom:12px;border:1px solid var(--line);overflow:hidden;box-shadow:0 4px 14px rgba(21,38,61,.05)}
.faq summary{list-style:none;cursor:pointer;padding:22px 26px;font-family:"Gelasio";font-size:20px;color:var(--ink);font-weight:600;display:flex;justify-content:space-between;align-items:center;gap:18px}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"+";color:var(--orange);font-size:26px;transition:transform .2s}
.faq details[open] summary::after{transform:rotate(45deg)}
.faq .ans{padding:0 26px 24px;font-size:17px}

/* form */
.formwrap{position:relative;background:var(--paper);border-radius:20px;padding:38px;max-width:640px;box-shadow:0 24px 56px rgba(21,38,61,.18);border-top:6px solid var(--orange)}
.formwrap h3{font-family:"Gelasio";font-style:italic;font-size:26px;margin-bottom:4px}
.formwrap .note{color:var(--muted);font-size:14px;margin-bottom:22px}
.field{margin-bottom:16px}
.field label{display:block;font-weight:700;font-size:14px;color:var(--ink);margin-bottom:7px}
.field input,.field select,.field textarea{width:100%;font-family:"Mulish";font-size:16px;color:var(--body);padding:13px 15px;border:1.5px solid var(--line);border-radius:8px;background:#fff}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--blue)}
.field textarea{min-height:90px;resize:vertical}
.two{display:grid;grid-template-columns:1fr 1fr;gap:16px}
@media(max-width:560px){.two{grid-template-columns:1fr}}
.formwrap .btn-orange{width:100%;font-size:17px;padding:16px}
.reassure{text-align:center;color:var(--muted);font-size:14px;margin-top:13px}
.thanks{display:none;text-align:center;padding:28px 8px}
.thanks h3{color:var(--blue);font-size:30px;margin-bottom:8px}

/* cta band */
.ctaband{text-align:center}
.ctaband h2{font-size:clamp(28px,4.5vw,44px);font-style:italic;margin-bottom:6px}
.ctaband .small{font-family:"Gelasio";font-style:italic;font-size:clamp(26px,4vw,40px)}
.ctaband p{font-size:19px;margin:12px auto 24px;max-width:540px}
.ctaband .btn-row{justify-content:center}

/* footer */
footer{position:relative;background:var(--navy);color:#aebccd;padding:56px 0 38px;text-align:center;overflow:hidden}
footer .fmark{display:inline-flex;align-items:center;gap:12px;font-family:"Gelasio";font-size:30px;color:#fff;font-weight:700}
footer .fmark .mark{width:34px;height:34px}
footer .fmark .dot{color:var(--orange)}
footer .ftag{font-family:"Gelasio";font-style:italic;color:var(--orange);font-size:20px;margin:6px 0 20px}
footer .fmeta{font-size:15px;line-height:2}
footer .fmeta a{color:#aebccd;text-decoration:none}
footer .fmeta a:hover{color:#fff}
footer .disc{font-size:13px;color:#7e8da0;max-width:640px;margin:22px auto 0;line-height:1.6}

/* sticky mobile cta */
.floatcall{position:fixed;right:18px;bottom:18px;z-index:60;background:var(--orange);color:#fff;border-radius:50px;padding:14px 22px;font-weight:800;text-decoration:none;box-shadow:0 8px 24px rgba(0,0,0,.25);display:none}
@media(max-width:980px){.floatcall{display:inline-block}}

/* entrance */
@keyframes fadeUp{from{opacity:0;transform:translateY(18px)}to{opacity:1;transform:none}}
@keyframes pulse{0%{transform:scale(.6);opacity:.55}70%{opacity:0}100%{transform:scale(1.5);opacity:0}}
.rise{opacity:0;animation:fadeUp .7s ease forwards}
.d1{animation-delay:.05s}.d2{animation-delay:.18s}.d3{animation-delay:.31s}.d4{animation-delay:.44s}.d5{animation-delay:.57s}
@media(prefers-reduced-motion:reduce){.rise{animation:none;opacity:1}.pulsering{animation:none!important}}

/* ============================================================
   ADDITIONS: SEO H1 kicker, mobile hamburger nav, responsive
   ============================================================ */

/* H1 keyword lead-in (visible kicker line that lives inside the <h1>) */
.h1-kicker{display:block;font-family:"Mulish",sans-serif;font-style:normal;font-weight:800;font-size:13px;letter-spacing:.2em;line-height:1.3;text-transform:uppercase;color:var(--orange);margin-bottom:14px}
.h1-kicker::after{content:"";display:block;width:30px;height:3px;background:currentColor;margin-top:9px;border-radius:2px}
.bg-orange .h1-kicker{color:#ffe7df}

/* Hamburger (mobile) */
.navtog{display:none}
.burger{display:none;flex-direction:column;gap:5px;cursor:pointer;padding:9px;margin:-9px;background:none;border:0}
.burger span{display:block;width:24px;height:2.5px;background:var(--ink);border-radius:2px;transition:transform .2s ease,opacity .2s ease}

@media(max-width:980px){
  .burger{display:flex}
  header.nav .nav-links{position:absolute;top:100%;left:0;right:0;flex-direction:column;align-items:stretch;gap:0;background:var(--ground);border-bottom:1px solid var(--line);box-shadow:0 16px 30px rgba(21,38,61,.12);padding:6px 0;display:none}
  .navtog:checked ~ .nav-links{display:flex}
  header.nav .nav-links a{display:block;width:auto;padding:14px 28px;font-size:16px}
  header.nav .nav-links a.active:not(.cta)::after{display:none}
  header.nav .nav-links a.phone{color:var(--blue)}
  header.nav .nav-links a.cta{margin:8px 28px;text-align:center;border-radius:8px}
  .navtog:checked ~ .burger span:nth-child(1){transform:translateY(7.5px) rotate(45deg)}
  .navtog:checked ~ .burger span:nth-child(2){opacity:0}
  .navtog:checked ~ .burger span:nth-child(3){transform:translateY(-7.5px) rotate(-45deg)}
}

/* Responsive spacing: tablet + phone */
@media(max-width:880px){
  section{padding:64px 0}
}
@media(max-width:680px){
  section{padding:54px 0}
  .wrap{padding:0 20px}
  .hero{padding:64px 0 68px}
  .pagehead{padding:48px 0 58px}
  .formwrap{padding:26px 20px}
  .sec-head{margin-bottom:30px}
  .btn{width:100%;text-align:center}
  .btn-row{flex-direction:column;align-items:stretch}
  .nav-links a.cta{width:auto}
}
@media(max-width:420px){
  .hero h1{font-size:42px}
}
