/* ===========================================================
   GHX Construtora — Landing Page
   Navy + Gold editorial system (modeled on reference)
   =========================================================== */

:root{
  --navy:        #062a44;
  --navy-2:      #0a3251;   /* slightly lifted navy for gradients */
  --navy-deep:   #04223a;
  --ink:         #1c3a55;   /* heading color on light bg */
  --ink-soft:    #3f566b;
  --body:        #54616e;   /* body text on light */
  --body-light:  #c7d4e0;   /* body text on navy */
  --gold:        #ca9b53;
  --gold-deep:   #b9863a;
  --gold-soft:   #e7c98c;
  --cream:       #fbfaf7;
  --cream-2:     #f4efe7;
  --line:        #ece6db;
  --line-navy:   rgba(255,255,255,.12);
  --white:       #ffffff;

  --maxw: 1180px;
  --r-lg: 26px;
  --r-md: 18px;
  --r-sm: 12px;

  --shadow-card: 0 24px 60px -28px rgba(12,32,55,.28);
  --shadow-soft: 0 14px 38px -22px rgba(12,32,55,.30);
  --shadow-gold: 0 18px 40px -16px rgba(202,155,83,.55);

  --display: "Jost", system-ui, sans-serif;
  --sans: "Figtree", system-ui, sans-serif;
}

*{ margin:0; padding:0; box-sizing:border-box; }
html{ scroll-behavior:smooth; }
body{
  font-family:var(--sans);
  color:var(--body);
  background:var(--cream);
  -webkit-font-smoothing:antialiased;
  line-height:1.6;
  overflow-x:hidden;
}
img{ display:block; max-width:100%; }
a{ color:inherit; text-decoration:none; }

/* ---------- Layout helpers ---------- */
.wrap{ width:100%; max-width:var(--maxw); margin:0 auto; padding:0 28px; }
.section{ padding:104px 0; position:relative; }
.section--tight{ padding:78px 0; }

/* ---------- Type ---------- */
.display{
  font-family:var(--display);
  font-weight:300;
  color:var(--ink);
  text-transform:uppercase;
  letter-spacing:.02em;
  line-height:1.08;
  text-wrap:balance;
}
.display .gold{ color:var(--gold); }
.display--xl{ font-size:clamp(34px,4.4vw,62px); }
.display--lg{ font-size:clamp(30px,3.4vw,46px); }
.display--md{ font-size:clamp(24px,2.4vw,34px); }
.on-navy .display{ color:#fff; }

.eyebrow{
  display:inline-flex; align-items:center; gap:8px;
  font-family:var(--sans);
  font-size:13px; font-weight:600; letter-spacing:.01em;
  color:var(--body);
  background:var(--white);
  border:1px solid var(--line);
  padding:7px 15px 7px 13px;
  border-radius:999px;
  box-shadow:var(--shadow-soft);
}
.eyebrow .dot{ width:7px; height:7px; border-radius:50%; background:var(--gold); }
.eyebrow b{ color:var(--ink); font-weight:700; }
.eyebrow svg{ width:16px; height:16px; color:var(--gold); }
.on-navy .eyebrow{
  background:rgba(255,255,255,.06);
  border-color:var(--line-navy);
  color:var(--body-light);
  box-shadow:none;
}
.on-navy .eyebrow b{ color:#fff; }

.lead{ font-size:17px; color:var(--body); }
.on-navy .lead{ color:var(--body-light); }
.section-head{ text-align:center; max-width:760px; margin:0 auto 52px; }
.section-head .eyebrow{ margin-bottom:22px; }

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex; align-items:center; gap:16px;
  font-family:var(--sans);
  font-size:13.5px; font-weight:700; letter-spacing:.12em;
  text-transform:uppercase;
  color:var(--navy);
  padding:7px 8px 7px 28px;
  border-radius:999px;
  background:linear-gradient(100deg,#fff7e9 0%, #f4dca6 42%, #e3bf7a 100%);
  box-shadow:var(--shadow-gold);
  border:1px solid rgba(255,255,255,.6);
  cursor:pointer;
  transition:transform .25s ease, box-shadow .25s ease, filter .25s ease;
}
.btn:hover{ transform:translateY(-2px); box-shadow:0 24px 46px -14px rgba(202,155,83,.7); filter:brightness(1.02); }
.btn .ico{
  width:38px; height:38px; flex:0 0 38px;
  display:grid; place-items:center;
  background:rgba(255,255,255,.85);
  border-radius:50%;
  transition:transform .35s ease;
}
.btn:hover .ico{ transform:rotate(45deg); }
.btn .ico svg{ width:17px; height:17px; color:var(--navy); }

/* ---------- Header / nav ---------- */
.site-header{
  position:fixed; top:0; left:0; right:0; z-index:60;
  display:flex; align-items:center; justify-content:space-between;
  padding:18px 40px;
  transition:background .3s ease, box-shadow .3s ease, padding .3s ease;
}
.site-header.scrolled{
  background:rgba(251,250,247,.88);
  backdrop-filter:blur(14px);
  box-shadow:0 1px 0 rgba(28,58,85,.08);
  padding:12px 40px;
}
.nav-links{ display:flex; gap:34px; font-size:14.5px; font-weight:500; color:var(--ink); }
.nav-links a{ position:relative; opacity:.8; transition:opacity .2s; }
.nav-links a:hover{ opacity:1; }
.nav-links a::after{ content:""; position:absolute; left:0; bottom:-6px; height:2px; width:0; background:var(--gold); transition:width .25s; }
.nav-links a:hover::after{ width:100%; }
.header-cta{ font-size:12px; padding:6px 7px 6px 22px; }
.header-cta .ico{ width:32px; height:32px; flex-basis:32px; }
@media(max-width:860px){ .nav-links{ display:none; } }

/* ---------- Logo (placeholder emblem) ---------- */
.logo{ display:inline-flex; align-items:center; gap:12px; }
.logo__mark{
  width:46px; height:46px; flex:0 0 46px;
  border:1.5px solid var(--gold);
  border-radius:11px;
  display:grid; place-items:center;
  position:relative;
  background:linear-gradient(150deg,rgba(202,155,83,.10),transparent);
}
.logo__mark span{
  font-family:var(--display); font-weight:500; font-size:18px;
  color:var(--gold); letter-spacing:.02em;
}
.logo__mark::before{
  content:""; position:absolute; inset:6px; border:1px solid rgba(202,155,83,.4); border-radius:7px;
}
.logo__txt{ display:flex; flex-direction:column; line-height:1; }
.logo__txt b{ font-family:var(--display); font-weight:400; font-size:22px; letter-spacing:.18em; color:var(--ink); }
.logo__txt small{ font-family:var(--sans); font-size:9.5px; letter-spacing:.42em; color:var(--gold); font-weight:600; margin-top:4px; text-transform:uppercase; }
.on-navy .logo__txt b{ color:#fff; }
.on-navy .logo__mark{ border-color:var(--gold-soft); }

/* =========================================================
   HERO
   ========================================================= */
.hero{
  position:relative;
  padding:152px 0 92px;
  background:
    radial-gradient(120% 80% at 12% 0%, #ffffff 0%, var(--cream) 46%, var(--cream-2) 100%);
  overflow:hidden;
}
.hero::after{
  content:""; position:absolute; right:-160px; top:-120px; width:520px; height:520px;
  background:radial-gradient(circle, rgba(202,155,83,.13), transparent 65%);
  pointer-events:none;
}
.hero__grid{
  display:grid; grid-template-columns:1.02fr 1fr; gap:56px; align-items:center;
}
.hero__copy .eyebrow{ margin:6px 0 26px; }
.hero h1{ margin-bottom:24px; }
.hero__sub{ font-size:19px; max-width:430px; margin-bottom:38px; color:var(--body); }
.hero__sub b{ color:var(--ink); font-weight:700; }

.hero__media{ position:relative; }
.hero__media image-slot{ width:100%; height:520px; box-shadow:var(--shadow-card); }
.float-card{
  position:absolute;
  background:var(--white);
  border-radius:var(--r-md);
  box-shadow:var(--shadow-card);
  display:flex; align-items:center; gap:11px;
  padding:13px 18px;
  font-size:14px; color:var(--ink); font-weight:500;
}
.float-card svg{ width:18px; height:18px; color:var(--gold); flex:0 0 18px; }
.float-card b{ font-weight:700; }
.float-card--tl{ top:-22px; left:34px; }
.float-card--tr{ top:96px; right:-26px; }
.float-card--stat{
  left:24px; bottom:26px; flex-direction:column; align-items:flex-start; gap:2px; padding:18px 22px;
}
.float-card--stat .num{ font-family:var(--display); font-weight:300; font-size:42px; color:var(--ink); line-height:1; }
.float-card--stat .num b{ color:var(--gold); font-weight:400; }
.float-card--stat .lbl{ font-size:12.5px; color:var(--body); letter-spacing:.04em; }
.float-card--stat .ico-sq{ display:none; }

.scroll-cue{
  display:flex; justify-content:center; margin-top:6px;
}
.scroll-cue span{
  width:34px; height:34px; border-radius:50%; border:1px solid var(--line);
  display:grid; place-items:center; color:var(--gold); background:#fff;
  animation:bob 1.8s ease-in-out infinite;
}
@keyframes bob{ 0%,100%{ transform:translateY(0);} 50%{ transform:translateY(6px);} }

/* =========================================================
   PROJECTS GALLERY
   ========================================================= */
.proj-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:24px; }
.proj-card{
  background:var(--white); border-radius:var(--r-md); overflow:hidden;
  box-shadow:var(--shadow-soft);
  transition:transform .3s ease, box-shadow .3s ease;
}
.proj-card:hover{ transform:translateY(-6px); box-shadow:var(--shadow-card); }
.proj-card__media{ position:relative; }
.proj-card__media image-slot{ width:100%; height:230px; }
.proj-tag{
  position:absolute; top:14px; left:14px; z-index:2;
  background:rgba(255,255,255,.92); color:var(--ink);
  font-size:10.5px; font-weight:700; letter-spacing:.14em; text-transform:uppercase;
  padding:6px 12px; border-radius:999px;
}
.proj-arrow{
  position:absolute; top:12px; right:12px; z-index:2;
  width:38px; height:38px; border-radius:50%;
  background:rgba(255,255,255,.92); display:grid; place-items:center; color:var(--navy);
  transition:transform .3s, background .3s;
}
.proj-card:hover .proj-arrow{ background:var(--gold); color:#fff; transform:rotate(45deg); }
.proj-arrow svg{ width:16px; height:16px; }
.proj-card__foot{ display:flex; align-items:center; gap:10px; padding:16px 18px; }
.proj-card__foot .badge{ width:22px; height:22px; border-radius:50%; background:linear-gradient(135deg,var(--gold-soft),var(--gold)); flex:0 0 22px; }
.proj-card__foot .name{ font-size:15px; font-weight:600; color:var(--ink); }

/* =========================================================
   PARTNER LOGOS
   ========================================================= */
.logos-bar{ background:var(--white); border-top:1px solid var(--line); border-bottom:1px solid var(--line); }
.logos-row{ display:flex; align-items:center; justify-content:space-between; gap:30px; flex-wrap:wrap; padding:38px 0; }
.logo-chip{
  height:54px; flex:1 1 0; min-width:120px; display:grid; place-items:center;
  color:#9aa3ad; font-family:var(--display); letter-spacing:.16em; text-transform:uppercase;
  font-size:15px; font-weight:400;
  opacity:.7; transition:opacity .25s, filter .25s;
}
.logo-chip:hover{ opacity:1; }
.logo-chip small{ display:block; font-family:var(--sans); font-size:8px; letter-spacing:.2em; text-align:center; margin-top:3px; }

/* =========================================================
   SPLIT (image + copy)  — "dor de cabeça"
   ========================================================= */
.split{ display:grid; grid-template-columns:1fr 1fr; gap:60px; align-items:center; }
.split__media{ position:relative; }
.split__media image-slot{ width:100%; height:520px; box-shadow:var(--shadow-card); }
.split__badge{
  position:absolute; left:-18px; bottom:28px;
  background:#fff; border-radius:14px; box-shadow:var(--shadow-card);
  display:flex; align-items:center; gap:14px; padding:14px 20px 14px 16px;
}
.split__badge .lg-mini{ width:40px; height:40px; border:1.4px solid var(--gold); border-radius:9px; display:grid; place-items:center; font-family:var(--display); color:var(--gold); font-size:15px; }
.split__badge .t b{ display:block; font-family:var(--display); font-weight:400; font-size:18px; color:var(--gold); letter-spacing:.04em; }
.split__badge .t span{ font-size:12px; color:var(--ink); font-weight:600; letter-spacing:.06em; text-transform:uppercase; }
.split__copy .eyebrow{ margin-bottom:22px; }
.split__copy h2{ margin-bottom:24px; }
.feature-note{
  display:flex; gap:14px; align-items:flex-start; margin-top:24px;
  background:var(--cream-2); border-radius:var(--r-sm); padding:18px 20px;
}
.feature-note svg{ width:22px; height:22px; color:var(--gold); flex:0 0 22px; margin-top:2px; }
.feature-note p{ font-size:15px; }
.feature-note b{ color:var(--ink); }
.split__copy .btn{ margin-top:32px; }

/* =========================================================
   GUARANTEES (two cards)
   ========================================================= */
.guar-grid{ display:grid; grid-template-columns:1fr 1fr; gap:24px; }
.guar-card{ border-radius:var(--r-lg); overflow:hidden; box-shadow:var(--shadow-card); }
.guar-card--light{ background:var(--white); }
.guar-card--navy{ background:linear-gradient(160deg,var(--navy-2),var(--navy-deep)); }
.guar-card__media image-slot{ width:100%; height:240px; }
.guar-card__body{ padding:30px 32px 36px; }
.guar-card--navy .guar-card__body h3{ color:#fff; }
.guar-card h3{ font-family:var(--display); font-weight:300; text-transform:uppercase; font-size:26px; color:var(--ink); letter-spacing:.02em; margin-bottom:22px; }
.guar-card h3 .gold{ color:var(--gold); }
.check-list{ list-style:none; display:flex; flex-direction:column; gap:14px; }
.check-list li{ display:flex; gap:12px; align-items:flex-start; font-size:15px; color:var(--body); }
.guar-card--navy .check-list li{ color:var(--body-light); }
.check-list svg{ width:19px; height:19px; color:var(--gold); flex:0 0 19px; margin-top:2px; }

/* =========================================================
   NAVY BENEFITS — "Escolha a GHX"
   ========================================================= */
.navy-block{ background:linear-gradient(180deg,var(--navy) 0%, var(--navy-deep) 100%); color:#fff; }
.benefit-grid{ display:grid; grid-template-columns:1fr 1fr; gap:24px; max-width:920px; margin:0 auto; }
.benefit{
  background:rgba(255,255,255,.045);
  border:1px solid var(--line-navy);
  border-top:3px solid var(--gold);
  border-radius:var(--r-md);
  padding:30px 30px 32px;
  position:relative;
}
.benefit__ico{ width:46px; height:46px; border-radius:11px; background:rgba(202,155,83,.14); display:grid; place-items:center; margin-bottom:20px; }
.benefit__ico svg{ width:23px; height:23px; color:var(--gold-soft); }
.benefit h3{ font-family:var(--display); font-weight:300; text-transform:uppercase; font-size:22px; line-height:1.15; color:#fff; margin-bottom:14px; letter-spacing:.01em; }
.benefit h3 .gold{ color:var(--gold-soft); }
.benefit p{ font-size:14.5px; color:var(--body-light); }
.benefit p b{ color:#fff; }
.benefit--media{ padding:0; overflow:hidden; border-top-color:transparent; background:none; border:none; }
.benefit--media image-slot{ width:100%; height:100%; min-height:230px; }
.benefit--media .ov-stats{ position:absolute; left:22px; bottom:20px; display:flex; flex-direction:column; gap:6px; }
.benefit--media .ov-stats div{ font-size:13px; color:#fff; }
.benefit--media .ov-stats b{ color:var(--gold-soft); }
.navy-block .btn{ display:flex; margin:48px auto 0; width:max-content; }

/* =========================================================
   COMPARISON TABLE
   ========================================================= */
.compare-panel{
  background:linear-gradient(180deg,#fff,#fbf8f2);
  border-radius:var(--r-lg);
  box-shadow:var(--shadow-card);
  padding:60px clamp(24px,5vw,72px) 68px;
  max-width:1040px; margin:0 auto;
}
.compare-panel .section-head{ margin-bottom:42px; }
.ctable{ width:100%; border-collapse:collapse; }
.ctable th, .ctable td{ padding:18px 18px; text-align:center; border-bottom:1px solid var(--line); }
.ctable thead th{ font-family:var(--sans); font-size:14px; font-weight:700; color:var(--ink); }
.ctable thead th:first-child{ text-align:left; }
.ctable tbody td:first-child{ text-align:left; font-weight:600; color:var(--ink); font-size:14.5px; }
.ctable .col-ghx{ background:rgba(202,155,83,.07); }
.ctable thead .col-ghx{ color:var(--gold-deep); border-top-left-radius:10px; border-top-right-radius:10px; }
.ctable .yes{ color:#2f9e6b; }
.ctable .no{ color:#cf5b56; }
.ctable svg{ width:21px; height:21px; }
.compare-panel .btn{ display:flex; margin:42px auto 0; width:max-content; }

/* =========================================================
   FORM SECTION
   ========================================================= */
.form-sec{ position:relative; padding:118px 0; }
.form-sec__bg{ position:absolute; inset:0; z-index:0; }
.form-sec__bg image-slot{ width:100%; height:100%; }
.form-sec__bg::after{ content:""; position:absolute; inset:0; background:linear-gradient(90deg,rgba(251,250,247,.96) 0%, rgba(251,250,247,.62) 50%, rgba(6,42,68,.30) 100%); }
.form-sec .wrap{ position:relative; z-index:2; }
.form-grid{ display:grid; grid-template-columns:1fr 1fr; gap:40px; align-items:center; }
.form-intro{ background:rgba(255,255,255,.82); backdrop-filter:blur(4px); border-radius:var(--r-lg); padding:42px 44px; box-shadow:var(--shadow-soft); }
.form-intro .eyebrow{ margin-bottom:20px; }
.form-intro h2{ margin-bottom:22px; }
.form-intro p{ margin-bottom:14px; font-size:15.5px; }
.form-intro b{ color:var(--ink); }
.form-card{
  background:linear-gradient(165deg,var(--navy-2),var(--navy-deep));
  border-radius:var(--r-lg); padding:40px 40px 44px; box-shadow:var(--shadow-card);
}
.form-card h3{ font-family:var(--display); font-weight:300; text-transform:uppercase; font-size:27px; color:#fff; letter-spacing:.02em; margin-bottom:26px; }
.form-card h3 .gold{ color:var(--gold-soft); }
.field{ margin-bottom:18px; }
.field.row{ display:grid; grid-template-columns:1fr 1fr; gap:14px; }
.field label{ display:block; font-size:12.5px; color:var(--body-light); letter-spacing:.04em; margin-bottom:8px; }
.field input, .field select{
  width:100%; background:rgba(255,255,255,.06); border:1px solid var(--line-navy);
  border-radius:10px; padding:13px 15px; color:#fff; font-family:var(--sans); font-size:14.5px;
  transition:border .2s, background .2s;
}
.field input::placeholder{ color:rgba(255,255,255,.4); }
.field input:focus, .field select:focus{ outline:none; border-color:var(--gold); background:rgba(255,255,255,.1); }
.field select{ appearance:none; background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%23ca9b53' stroke-width='2'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E"); background-repeat:no-repeat; background-position:right 15px center; }
.field select option{ color:#1c3a55; }
.form-submit{
  width:100%; margin-top:8px; border:none; cursor:pointer;
  background:linear-gradient(100deg,#fff7e9,#f0d49a,#d8af6a);
  color:var(--navy); font-family:var(--sans); font-weight:700; letter-spacing:.1em; text-transform:uppercase;
  font-size:14px; padding:15px; border-radius:10px;
  transition:transform .2s, box-shadow .2s;
}
.form-submit:hover{ transform:translateY(-2px); box-shadow:var(--shadow-gold); }

/* =========================================================
   5 YEARS GUARANTEE SEAL
   ========================================================= */
.seal-grid{ display:grid; grid-template-columns:auto 1fr; gap:64px; align-items:center; max-width:900px; margin:0 auto; }
.seal{ position:relative; width:260px; height:260px; display:grid; place-items:center; }
.seal__ring{ position:absolute; inset:0; animation:spin 26s linear infinite; }
@keyframes spin{ to{ transform:rotate(360deg);} }
.seal__num{ font-family:var(--display); font-weight:300; font-size:96px; color:var(--gold); line-height:1; }
.seal__num small{ display:block; font-size:14px; letter-spacing:.3em; color:var(--ink); text-align:center; margin-top:2px; }
.seal-copy .eyebrow{ margin-bottom:20px; }
.seal-copy h2{ margin-bottom:20px; }
.seal-copy p b{ color:var(--ink); }

/* =========================================================
   ECONOMIA EXTRA (image bg + center card)
   ========================================================= */
.econ-sec{ position:relative; padding:130px 0; }
.econ-sec__bg{ position:absolute; inset:0; z-index:0; }
.econ-sec__bg image-slot{ width:100%; height:100%; }
.econ-sec__bg::after{ content:""; position:absolute; inset:0; background:linear-gradient(180deg,rgba(251,250,247,.5),rgba(251,250,247,.2)); }
.econ-card{
  position:relative; z-index:2; max-width:720px; margin:0 auto; text-align:center;
  background:rgba(255,255,255,.92); backdrop-filter:blur(6px);
  border-radius:var(--r-lg); box-shadow:var(--shadow-card); padding:54px 56px 56px;
}
.econ-card .eyebrow{ margin-bottom:22px; }
.econ-card h2{ margin-bottom:24px; }
.econ-card p{ margin-bottom:14px; font-size:15.5px; }
.econ-card b{ color:var(--ink); }
.econ-card .btn{ margin-top:26px; }

/* =========================================================
   TESTIMONIALS
   ========================================================= */
.testi-track-wrap{ overflow:hidden; }
.testi-track{ display:flex; gap:24px; transition:transform .5s cubic-bezier(.4,0,.2,1); }
.testi{
  flex:0 0 calc((100% - 48px)/3); background:#fff; border-radius:var(--r-md);
  box-shadow:var(--shadow-soft); padding:30px 30px 28px; display:flex; flex-direction:column;
  position:relative;
}
.testi__head{ display:flex; align-items:center; justify-content:space-between; margin-bottom:16px; }
.testi__name{ font-weight:700; color:var(--ink); font-size:15.5px; }
.testi__stars{ color:var(--gold); font-size:14px; letter-spacing:2px; }
.testi__text{ font-size:14.5px; color:var(--body); font-style:italic; flex:1; }
.testi__role{ margin-top:18px; font-size:13px; font-style:italic; color:var(--gold-deep); font-weight:600; }
.testi__quote{ position:absolute; right:24px; bottom:18px; font-family:Georgia,serif; font-size:54px; color:var(--cream-2); line-height:1; }
.carousel-ctrl{ display:flex; align-items:center; justify-content:center; gap:20px; margin-top:36px; }
.carousel-ctrl button{
  width:44px; height:44px; border-radius:50%; border:1px solid var(--line); background:#fff;
  display:grid; place-items:center; cursor:pointer; color:var(--ink); transition:.2s;
}
.carousel-ctrl button:hover{ background:var(--gold); color:#fff; border-color:var(--gold); }
.carousel-ctrl button svg{ width:18px; height:18px; }
.dots{ display:flex; gap:8px; }
.dots i{ width:8px; height:8px; border-radius:50%; background:var(--line); transition:.2s; cursor:pointer; }
.dots i.active{ background:var(--gold); width:22px; border-radius:5px; }

/* =========================================================
   REGION CARD
   ========================================================= */
.region-sec{ position:relative; padding:120px 0; }
.region-sec__bg{ position:absolute; inset:0; z-index:0; }
.region-sec__bg image-slot{ width:100%; height:100%; }
.region-sec__bg::after{ content:""; position:absolute; inset:0; background:rgba(6,42,68,.18); }
.region-card{
  position:relative; z-index:2; max-width:1000px; margin:0 auto;
  background:linear-gradient(160deg,rgba(10,50,81,.96),rgba(4,34,58,.97));
  border-radius:var(--r-lg); box-shadow:var(--shadow-card);
  display:grid; grid-template-columns:1.1fr .9fr; gap:40px; align-items:center;
  padding:54px 56px;
}
.region-card .eyebrow{ margin-bottom:20px; }
.region-card h2{ margin-bottom:20px; }
.region-card p{ color:var(--body-light); font-size:15px; margin-bottom:14px; }
.region-card p b{ color:#fff; }
.region-card .btn{ margin-top:26px; }
.region-map{ position:relative; display:grid; place-items:center; }
.region-map svg{ width:100%; max-width:300px; filter:drop-shadow(0 14px 30px rgba(0,0,0,.4)); }
.region-map .pin{ position:absolute; display:flex; flex-direction:column; align-items:center; gap:6px; color:#fff; }
.region-map .pin .dot{ width:20px; height:20px; border-radius:50%; background:#fff; border:4px solid var(--navy); box-shadow:0 0 0 4px rgba(255,255,255,.4); }
.region-map .pin small{ font-size:11px; letter-spacing:.1em; text-transform:uppercase; color:var(--navy); font-weight:700; }

/* =========================================================
   FAQ
   ========================================================= */
.faq-list{ max-width:880px; margin:0 auto; display:flex; flex-direction:column; gap:14px; }
.faq-item{ background:#fff; border:1px solid var(--line); border-radius:14px; overflow:hidden; transition:box-shadow .25s, border .25s; }
.faq-item.open{ box-shadow:var(--shadow-soft); border-color:rgba(202,155,83,.4); }
.faq-q{ display:flex; align-items:center; gap:18px; padding:22px 26px; cursor:pointer; }
.faq-q .n{ font-family:var(--display); font-weight:400; color:var(--gold); font-size:16px; flex:0 0 auto; }
.faq-q .q{ flex:1; font-weight:600; color:var(--ink); font-size:15.5px; }
.faq-q .pm{ width:30px; height:30px; border-radius:50%; background:var(--cream-2); display:grid; place-items:center; color:var(--ink); transition:transform .3s, background .3s; flex:0 0 30px; }
.faq-item.open .pm{ background:var(--gold); color:#fff; transform:rotate(45deg); }
.faq-q .pm svg{ width:16px; height:16px; }
.faq-a{ max-height:0; overflow:hidden; transition:max-height .35s ease; }
.faq-a p{ padding:0 26px 24px 60px; font-size:14.5px; color:var(--body); }

/* =========================================================
   FINAL CTA + FOOTER
   ========================================================= */
.final-split{ display:grid; grid-template-columns:1fr 1fr; gap:56px; align-items:center; }
.final-copy .eyebrow{ margin-bottom:22px; }
.final-copy h2{ margin-bottom:22px; }
.final-copy p{ font-size:16px; margin-bottom:8px; }
.final-copy .btn{ margin-top:30px; }
.final-media image-slot{ width:100%; height:420px; box-shadow:var(--shadow-card); }

.site-footer{ background:var(--cream); border-top:1px solid var(--line); padding:30px 0; }
.footer-row{ display:flex; align-items:center; justify-content:space-between; gap:20px; flex-wrap:wrap; }
.footer-row small{ font-size:13px; color:var(--body); }
.footer-links{ display:flex; gap:22px; font-size:13px; }
.footer-links a{ color:var(--body); transition:color .2s; }
.footer-links a:hover{ color:var(--gold); }

/* =========================================================
   RESPONSIVE
   ========================================================= */
@media(max-width:980px){
  .hero__grid, .split, .guar-grid, .benefit-grid, .form-grid, .seal-grid, .region-card, .final-split{ grid-template-columns:1fr; }
  .proj-grid{ grid-template-columns:1fr 1fr; }
  .seal-grid{ justify-items:center; text-align:center; }
  .region-card{ text-align:center; }
  .hero__media{ margin-top:30px; }
}
@media(max-width:620px){
  .section{ padding:72px 0; }
  .wrap{ padding:0 20px; }
  .proj-grid{ grid-template-columns:1fr; }
  .testi{ flex:0 0 100%; }
  .field.row{ grid-template-columns:1fr; }
  .float-card--tr{ right:0; }
  .site-header{ padding:14px 20px; }
}
