/* ========================================================================
   FORMA BAT 60 — Formation Installateur Pompe à Chaleur
   Aesthetic : Industrial Editorial — Precision × Heat
   Palette  : Deep anthracite + heat orange + technical blueprint blue
   ======================================================================== */

@import url('https://fonts.googleapis.com/css2?family=Fraunces:ital,opsz,wght@0,9..144,400;0,9..144,600;0,9..144,800;1,9..144,400&family=JetBrains+Mono:wght@400;500;700&family=Inter+Tight:wght@400;500;600;700&display=swap');

:root{
  --ink:#0d0d0f;
  --ink-2:#1a1a1d;
  --paper:#f6f3ee;
  --paper-2:#ebe6dc;
  --heat:#e8481c;
  --heat-2:#ff6b35;
  --blue:#0a3d62;
  --blue-2:#1e6091;
  --line:#2a2a2e;
  --muted:#7a7a7f;
  --accent:#c9a961;
  --success:#2d6a4f;

  --f-display:'Fraunces', Georgia, serif;
  --f-body:'Inter Tight', system-ui, sans-serif;
  --f-mono:'JetBrains Mono', monospace;

  --maxw:1320px;
  --gut:clamp(1.2rem,3vw,2.5rem);
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:var(--f-body);
  background:var(--paper);
  color:var(--ink);
  line-height:1.55;
  font-size:16px;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}

img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}

/* ========== TYPOGRAPHY ========== */
h1,h2,h3,h4{font-family:var(--f-display);font-weight:600;line-height:1.05;letter-spacing:-.02em}
h1{font-size:clamp(2.8rem,7vw,6.4rem);font-weight:800}
h2{font-size:clamp(2rem,4.5vw,3.8rem)}
h3{font-size:clamp(1.4rem,2.5vw,2rem)}
h4{font-size:1.15rem;font-weight:600}
.mono{font-family:var(--f-mono);font-size:.78rem;letter-spacing:.05em;text-transform:uppercase}
.italic{font-style:italic;font-weight:400}

/* ========== LAYOUT PRIMITIVES ========== */
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 var(--gut)}
.section{padding:clamp(4rem,9vw,8rem) 0}

/* ========== HEADER ========== */
.topbar{
  background:var(--ink);color:var(--paper);
  font-family:var(--f-mono);font-size:.72rem;letter-spacing:.08em;
  text-transform:uppercase;
}
.topbar-inner{
  max-width:var(--maxw);margin:0 auto;padding:.65rem var(--gut);
  display:flex;justify-content:space-between;align-items:center;gap:1rem;
}
.topbar-inner > span{color:rgba(246,243,238,.7)}
.topbar-phone{
  color:var(--heat);font-weight:700;letter-spacing:.05em;
  display:inline-flex;align-items:center;gap:.4rem;
  transition:color .2s;
}
.topbar-phone:hover{color:var(--paper)}
@media(max-width:700px){
  .topbar-inner > span{display:none}
  .topbar-inner{justify-content:center}
}
.hdr{
  position:sticky;top:0;z-index:100;
  background:rgba(246,243,238,.92);
  backdrop-filter:blur(14px);
  border-bottom:1px solid rgba(13,13,15,.08);
}
.hdr-inner{
  max-width:var(--maxw);margin:0 auto;
  padding:1rem var(--gut);
  display:flex;align-items:center;justify-content:space-between;gap:2rem;
}
.logo{
  font-family:var(--f-display);font-weight:800;font-size:1.3rem;letter-spacing:-.02em;
  display:flex;align-items:center;gap:.5rem;
}
.logo-mark{
  width:34px;height:34px;background:var(--ink);color:var(--heat);
  display:grid;place-items:center;font-family:var(--f-mono);font-weight:700;
  font-size:.7rem;transform:rotate(-4deg);
}
.logo-mark span{transform:rotate(4deg)}

.nav{display:flex;gap:2rem;align-items:center;font-size:.92rem;font-weight:500}
.nav a{position:relative;padding:.4rem 0;transition:color .2s}
.nav a:hover{color:var(--heat)}
.nav-cta{
  background:var(--ink);color:var(--paper);
  padding:.7rem 1.3rem;font-weight:600;font-size:.85rem;
  transition:all .25s;
}
.nav-cta:hover{background:var(--heat);color:var(--paper);transform:translateY(-1px)}
.burger{display:none;background:none;border:none;cursor:pointer;font-size:1.5rem}

@media(max-width:900px){
  .nav{display:none;position:absolute;top:100%;left:0;right:0;
    background:var(--paper);flex-direction:column;padding:1.5rem var(--gut);
    border-bottom:1px solid var(--line);gap:1rem;align-items:flex-start;}
  .nav.open{display:flex}
  .burger{display:block}
}

/* ========== HERO ========== */
.hero{
  position:relative;
  padding:clamp(4rem,8vw,7rem) 0 clamp(5rem,9vw,8rem);
  background:linear-gradient(180deg,var(--paper) 0%,var(--paper-2) 100%);
  overflow:hidden;
}
.hero-grid{
  display:grid;grid-template-columns:1.3fr .9fr;gap:4rem;align-items:end;
  position:relative;z-index:2;
}
@media(max-width:900px){.hero-grid{grid-template-columns:1fr;gap:2rem}}

.hero-kicker{
  display:inline-flex;align-items:center;gap:.8rem;
  font-family:var(--f-mono);font-size:.75rem;letter-spacing:.1em;
  text-transform:uppercase;color:var(--heat);margin-bottom:2rem;
}
.hero-kicker::before{content:'';width:32px;height:1px;background:var(--heat)}
.hero h1{margin-bottom:1.5rem}
.hero h1 em{
  font-style:italic;color:var(--heat);font-weight:400;
  position:relative;display:inline-block;
}
.hero h1 em::after{
  content:'';position:absolute;left:0;right:0;bottom:-6px;height:3px;
  background:var(--heat);transform:scaleX(.8);transform-origin:left;
}
.hero-sub{
  font-size:clamp(1.05rem,1.4vw,1.25rem);
  max-width:540px;color:var(--ink-2);margin-bottom:2.5rem;line-height:1.5;
}
.hero-cta-row{display:flex;gap:1rem;flex-wrap:wrap}
.btn{
  display:inline-flex;align-items:center;gap:.7rem;
  padding:1rem 1.8rem;font-weight:600;font-size:.95rem;
  transition:all .25s;cursor:pointer;border:none;
}
.btn-primary{background:var(--heat);color:var(--paper)}
.btn-primary:hover{background:var(--ink);transform:translateY(-2px);box-shadow:0 12px 24px -10px rgba(232,72,28,.5)}
.btn-ghost{background:transparent;color:var(--ink);border:1.5px solid var(--ink)}
.btn-ghost:hover{background:var(--ink);color:var(--paper)}

.hero-stats{
  display:grid;grid-template-columns:1fr 1fr;gap:1.5rem;
  padding-top:2rem;border-top:1px solid rgba(13,13,15,.15);
}
.stat-num{font-family:var(--f-display);font-size:3rem;font-weight:800;color:var(--heat);line-height:1}
.stat-lbl{font-family:var(--f-mono);font-size:.72rem;letter-spacing:.08em;text-transform:uppercase;color:var(--muted);margin-top:.3rem}

/* Hero decorative */
.hero-deco{
  position:absolute;top:0;right:-5%;width:55%;height:100%;
  background:
    radial-gradient(circle at 30% 70%,rgba(232,72,28,.08),transparent 60%),
    radial-gradient(circle at 80% 20%,rgba(10,61,98,.06),transparent 50%);
  pointer-events:none;z-index:1;
}
.hero-blueprint{
  position:absolute;right:var(--gut);top:15%;width:min(380px,35vw);
  z-index:2;opacity:.95;
}

/* ========== TRUST STRIP ========== */
.trust{
  background:var(--ink);color:var(--paper);
  padding:1.5rem 0;font-family:var(--f-mono);font-size:.78rem;
  letter-spacing:.1em;text-transform:uppercase;
  overflow:hidden;
}
.trust-track{display:flex;gap:3rem;white-space:nowrap;animation:scroll 40s linear infinite}
.trust-track span{display:inline-flex;align-items:center;gap:.8rem;color:rgba(246,243,238,.75)}
.trust-track span::before{content:'◆';color:var(--heat);font-size:.6rem}
@keyframes scroll{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* ========== CERTIFICATIONS GRID ========== */
.certifs{background:var(--paper)}
.section-head{
  display:grid;grid-template-columns:auto 1fr;gap:3rem;align-items:end;
  margin-bottom:4rem;padding-bottom:2rem;border-bottom:1px solid rgba(13,13,15,.15);
}
@media(max-width:700px){.section-head{grid-template-columns:1fr;gap:1rem}}
.section-head h2{max-width:16ch}
.section-intro{max-width:420px;color:var(--ink-2);line-height:1.6}

.cert-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1.5rem}
.cert{
  background:var(--paper-2);padding:2rem;border:1px solid transparent;
  transition:all .3s;position:relative;display:block;
}
.cert:hover{background:var(--ink);color:var(--paper);transform:translateY(-4px)}
.cert:hover .cert-arrow{transform:translate(4px,-4px);color:var(--heat)}
.cert:hover .cert-code{color:var(--heat)}
.cert-code{font-family:var(--f-mono);font-size:.72rem;letter-spacing:.08em;color:var(--heat);margin-bottom:1rem}
.cert h3{font-size:1.4rem;margin-bottom:.8rem;line-height:1.15}
.cert p{font-size:.9rem;line-height:1.5;opacity:.85;margin-bottom:1.5rem}
.cert-arrow{
  position:absolute;top:1.8rem;right:1.8rem;
  font-size:1.3rem;transition:transform .3s;font-family:var(--f-mono);
}
.cert-meta{
  display:flex;gap:1.2rem;font-family:var(--f-mono);font-size:.7rem;
  letter-spacing:.05em;text-transform:uppercase;opacity:.6;
}

/* ========== PARCOURS ========== */
.parcours{background:var(--ink);color:var(--paper);position:relative;overflow:hidden}
.parcours::before{
  content:'';position:absolute;inset:0;
  background-image:
    linear-gradient(rgba(246,243,238,.03) 1px,transparent 1px),
    linear-gradient(90deg,rgba(246,243,238,.03) 1px,transparent 1px);
  background-size:40px 40px;pointer-events:none;
}
.parcours .section-head{border-color:rgba(246,243,238,.15)}
.parcours .section-intro{color:rgba(246,243,238,.75)}

.modules{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:0;position:relative;z-index:2}
.module{
  padding:2.5rem 2rem;border-right:1px solid rgba(246,243,238,.1);
  border-top:1px solid rgba(246,243,238,.1);position:relative;
}
.module:last-child{border-right:none}
@media(max-width:800px){.module{border-right:none}}

.module-num{
  font-family:var(--f-mono);font-size:.75rem;color:var(--heat);letter-spacing:.08em;
  margin-bottom:1rem;
}
.module h3{font-size:1.25rem;margin-bottom:1rem}
.module ul{list-style:none;font-size:.88rem;color:rgba(246,243,238,.7);line-height:1.7}
.module ul li{padding-left:1.2rem;position:relative}
.module ul li::before{content:'→';position:absolute;left:0;color:var(--heat)}

/* ========== TECHNOLOGIES ========== */
.techs{background:var(--paper-2)}
.tech-grid{
  display:grid;grid-template-columns:repeat(3,1fr);gap:1px;
  background:rgba(13,13,15,.12);border:1px solid rgba(13,13,15,.12);
}
@media(max-width:800px){.tech-grid{grid-template-columns:1fr}}
.tech{
  background:var(--paper);padding:2.5rem 2rem;
  transition:all .3s;position:relative;display:block;
}
.tech:hover{background:var(--heat);color:var(--paper)}
.tech:hover .tech-icon{background:var(--paper);color:var(--heat)}
.tech-icon{
  width:52px;height:52px;background:var(--ink);color:var(--heat);
  display:grid;place-items:center;font-family:var(--f-mono);font-weight:700;
  font-size:.8rem;margin-bottom:1.5rem;transition:all .3s;
}
.tech h3{font-size:1.3rem;margin-bottom:.6rem}
.tech p{font-size:.88rem;opacity:.8;line-height:1.55}
.tech-kw{font-family:var(--f-mono);font-size:.68rem;margin-top:1.2rem;opacity:.55;letter-spacing:.05em}

/* ========== FINANCEMENT ========== */
.finance{position:relative;background:var(--paper)}
.finance-grid{display:grid;grid-template-columns:1.1fr 1fr;gap:4rem;align-items:center}
@media(max-width:900px){.finance-grid{grid-template-columns:1fr}}
.finance-visual{
  aspect-ratio:1;background:var(--ink);color:var(--paper);
  padding:3rem;display:flex;flex-direction:column;justify-content:space-between;
  position:relative;overflow:hidden;
}
.finance-visual::before{
  content:'CPF';position:absolute;bottom:-3rem;right:-1rem;
  font-family:var(--f-display);font-size:22rem;font-weight:800;
  color:var(--heat);opacity:.12;line-height:1;letter-spacing:-.05em;
}
.finance-visual-num{font-family:var(--f-mono);font-size:.75rem;color:var(--heat);letter-spacing:.1em;position:relative;z-index:2}
.finance-visual h3{font-size:2.2rem;margin-bottom:1rem;position:relative;z-index:2}
.finance-visual p{color:rgba(246,243,238,.75);font-size:.95rem;position:relative;z-index:2}

.finance-list{list-style:none}
.finance-list li{
  padding:1.3rem 0;border-bottom:1px solid rgba(13,13,15,.1);
  display:grid;grid-template-columns:auto 1fr auto;gap:1.5rem;align-items:center;
}
.finance-list li:last-child{border-bottom:none}
.fin-code{font-family:var(--f-mono);font-size:.72rem;color:var(--heat);letter-spacing:.08em}
.fin-name{font-weight:600;font-size:1.05rem}
.fin-arrow{color:var(--muted);transition:transform .2s}
.finance-list li:hover .fin-arrow{color:var(--heat);transform:translateX(4px)}

/* ========== VILLES / COUVERTURE ========== */
.villes{background:var(--paper-2);position:relative}
.villes-intro{max-width:600px;margin-bottom:3rem;color:var(--ink-2)}
.villes-grid{
  display:grid;grid-template-columns:repeat(auto-fill,minmax(170px,1fr));
  gap:0;background:rgba(13,13,15,.12);border:1px solid rgba(13,13,15,.12);
}
.ville-cell{
  background:var(--paper);padding:1rem 1.2rem;transition:all .2s;
  font-size:.88rem;font-weight:500;display:flex;justify-content:space-between;
  align-items:center;gap:.5rem;
}
.ville-cell:hover{background:var(--heat);color:var(--paper)}
.ville-cell .dept{font-family:var(--f-mono);font-size:.7rem;opacity:.5}
.ville-cell:hover .dept{opacity:.8}
.villes-more{
  margin-top:2rem;text-align:center;font-family:var(--f-mono);
  font-size:.8rem;letter-spacing:.05em;color:var(--muted);
}

/* ========== PUBLICS ========== */
.publics{background:var(--ink);color:var(--paper)}
.publics .section-head{border-color:rgba(246,243,238,.15)}
.publics .section-intro{color:rgba(246,243,238,.75)}
.pub-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:1px;background:rgba(246,243,238,.1)}
.pub{
  background:var(--ink);padding:2.2rem 1.8rem;transition:all .3s;
  display:block;position:relative;
}
.pub:hover{background:var(--heat)}
.pub-num{font-family:var(--f-mono);font-size:.75rem;color:var(--heat);margin-bottom:1.2rem}
.pub:hover .pub-num{color:var(--paper)}
.pub h3{font-size:1.25rem;margin-bottom:.6rem;line-height:1.2}
.pub p{font-size:.88rem;opacity:.75;line-height:1.5}

/* ========== FAQ ========== */
.faq{background:var(--paper)}
.faq-grid{display:grid;grid-template-columns:1fr 1.5fr;gap:4rem;align-items:start}
@media(max-width:900px){.faq-grid{grid-template-columns:1fr}}
.faq-list{list-style:none}
.faq-item{
  border-bottom:1px solid rgba(13,13,15,.15);padding:1.5rem 0;
}
.faq-q{
  display:flex;justify-content:space-between;align-items:center;gap:1rem;
  cursor:pointer;font-family:var(--f-display);font-size:1.3rem;
  font-weight:600;line-height:1.2;
}
.faq-q::after{
  content:'+';font-family:var(--f-mono);font-size:1.4rem;color:var(--heat);
  transition:transform .3s;flex-shrink:0;
}
.faq-item.open .faq-q::after{transform:rotate(45deg)}
.faq-a{max-height:0;overflow:hidden;transition:max-height .4s ease,padding .3s;color:var(--ink-2);font-size:.95rem;line-height:1.6}
.faq-item.open .faq-a{max-height:400px;padding-top:1rem}

/* ========== CTA FINAL ========== */
.cta-final{
  background:var(--heat);color:var(--paper);
  padding:clamp(4rem,8vw,7rem) 0;text-align:center;
  position:relative;overflow:hidden;
}
.cta-final::before,.cta-final::after{
  content:'';position:absolute;width:600px;height:600px;border-radius:50%;
  background:radial-gradient(circle,rgba(255,255,255,.12),transparent 70%);
}
.cta-final::before{top:-300px;left:-200px}
.cta-final::after{bottom:-300px;right:-200px}
.cta-final h2{font-size:clamp(2.2rem,5vw,4rem);max-width:18ch;margin:0 auto 1.5rem;position:relative;z-index:2}
.cta-final p{max-width:500px;margin:0 auto 2.5rem;font-size:1.1rem;opacity:.95;position:relative;z-index:2}
.cta-final .btn{position:relative;z-index:2}
.cta-final .btn-primary{background:var(--ink);color:var(--paper)}
.cta-final .btn-primary:hover{background:var(--paper);color:var(--ink)}
.cta-row{
  display:flex;gap:1rem;justify-content:center;flex-wrap:wrap;
  position:relative;z-index:2;
}
.btn-ghost-light{
  background:transparent;color:var(--paper);border:1.5px solid rgba(246,243,238,.6);
}
.btn-ghost-light:hover{background:var(--paper);color:var(--ink);border-color:var(--paper)}

/* ========== FOOTER ========== */
.ftr{background:var(--ink);color:var(--paper);padding:4rem 0 2rem}
.ftr-grid{display:grid;grid-template-columns:1.4fr .9fr .9fr 1.1fr .9fr;gap:2.5rem;margin-bottom:3rem}
@media(max-width:1000px){.ftr-grid{grid-template-columns:1fr 1fr 1fr;gap:2rem}}
@media(max-width:700px){.ftr-grid{grid-template-columns:1fr 1fr;gap:2rem}}
@media(max-width:500px){.ftr-grid{grid-template-columns:1fr}}
.ftr-col h4{font-family:var(--f-mono);font-size:.75rem;letter-spacing:.1em;text-transform:uppercase;color:var(--heat);margin-bottom:1.2rem;font-weight:700}
.ftr-col ul{list-style:none;display:flex;flex-direction:column;gap:.6rem}
.ftr-col a{color:rgba(246,243,238,.7);font-size:.9rem;transition:color .2s}
.ftr-col a:hover{color:var(--heat)}
.ftr-logo{font-family:var(--f-display);font-weight:800;font-size:1.5rem;margin-bottom:1rem}
.ftr-desc{font-size:.88rem;color:rgba(246,243,238,.6);line-height:1.6;max-width:280px}
.ftr-contact{margin-top:1rem}
.ftr-contact a{
  color:var(--heat);font-weight:600;font-size:1.1rem;
  display:inline-flex;align-items:center;gap:.4rem;
  transition:color .2s;
}
.ftr-contact a:hover{color:var(--paper)}
.ftr-bottom{
  border-top:1px solid rgba(246,243,238,.1);padding-top:2rem;
  display:flex;justify-content:space-between;flex-wrap:wrap;gap:1rem;
  font-family:var(--f-mono);font-size:.72rem;color:rgba(246,243,238,.5);
  letter-spacing:.05em;text-transform:uppercase;
}
.ftr-bottom a{color:rgba(246,243,238,.7);transition:color .2s}
.ftr-bottom a:hover{color:var(--heat)}
.ftr-credit{
  text-align:center;margin-top:1.5rem;padding-top:1.5rem;
  border-top:1px dashed rgba(246,243,238,.08);
  font-family:var(--f-mono);font-size:.7rem;letter-spacing:.06em;
  color:rgba(246,243,238,.45);text-transform:uppercase;
}
.ftr-credit a{
  color:var(--heat);font-weight:600;transition:color .2s;
}
.ftr-credit a:hover{color:var(--paper)}

/* ========== WHATSAPP WIDGET ========== */
.wa-float{
  position:fixed;bottom:1.5rem;right:1.5rem;z-index:999;
  display:flex;flex-direction:column;align-items:flex-end;gap:.75rem;
}
.wa-btn{
  width:62px;height:62px;border-radius:50%;
  background:#25D366;color:#fff;
  display:grid;place-items:center;cursor:pointer;border:none;
  box-shadow:0 8px 24px -4px rgba(37,211,102,.45),0 4px 12px -2px rgba(0,0,0,.2);
  transition:transform .3s cubic-bezier(.2,.8,.2,1),box-shadow .3s;
  animation:wa-pulse 2.5s infinite;
  position:relative;
}
.wa-btn:hover{transform:scale(1.08);box-shadow:0 12px 32px -4px rgba(37,211,102,.6),0 6px 16px -2px rgba(0,0,0,.25)}
.wa-btn svg{width:32px;height:32px;fill:#fff}
@keyframes wa-pulse{
  0%,100%{box-shadow:0 8px 24px -4px rgba(37,211,102,.45),0 4px 12px -2px rgba(0,0,0,.2),0 0 0 0 rgba(37,211,102,.5)}
  50%{box-shadow:0 8px 24px -4px rgba(37,211,102,.45),0 4px 12px -2px rgba(0,0,0,.2),0 0 0 14px rgba(37,211,102,0)}
}
.wa-badge{
  position:absolute;top:-4px;right:-4px;
  width:20px;height:20px;border-radius:50%;
  background:var(--heat);color:#fff;
  font-size:.7rem;font-weight:700;font-family:var(--f-body);
  display:grid;place-items:center;
  border:2px solid var(--paper);
  animation:wa-pop .4s ease-out .8s both;
}
@keyframes wa-pop{from{transform:scale(0)}to{transform:scale(1)}}

.wa-popup{
  width:340px;max-width:calc(100vw - 3rem);
  background:var(--paper);
  box-shadow:0 20px 50px -10px rgba(0,0,0,.25),0 10px 25px -5px rgba(0,0,0,.15);
  border-radius:14px;overflow:hidden;
  transform:translateY(20px) scale(.9);opacity:0;pointer-events:none;
  transform-origin:bottom right;
  transition:all .3s cubic-bezier(.2,.8,.2,1);
}
.wa-popup.open{transform:none;opacity:1;pointer-events:auto}
.wa-popup-head{
  background:#075E54;color:#fff;padding:1.2rem 1.2rem 1rem;
  display:flex;align-items:center;gap:.9rem;position:relative;
}
.wa-avatar{
  width:44px;height:44px;border-radius:50%;background:var(--heat);
  display:grid;place-items:center;font-family:var(--f-display);font-weight:800;
  font-size:1.1rem;color:#fff;flex-shrink:0;
}
.wa-head-info strong{display:block;font-size:.95rem;font-weight:600}
.wa-head-info span{font-size:.75rem;color:rgba(255,255,255,.8);display:flex;align-items:center;gap:.4rem}
.wa-head-info span::before{content:'';width:8px;height:8px;border-radius:50%;background:#4ade80}
.wa-close{
  position:absolute;top:.6rem;right:.8rem;background:none;border:none;
  color:#fff;font-size:1.4rem;cursor:pointer;opacity:.7;line-height:1;
}
.wa-close:hover{opacity:1}
.wa-body{
  padding:1.2rem;
  background:#E5DDD5;
  background-image:
    radial-gradient(circle at 20% 30%,rgba(255,255,255,.08),transparent 40%),
    radial-gradient(circle at 80% 70%,rgba(0,0,0,.03),transparent 40%);
  min-height:120px;
}
.wa-msg{
  background:#fff;padding:.8rem 1rem;border-radius:0 10px 10px 10px;
  font-size:.88rem;line-height:1.5;color:#111;max-width:90%;
  box-shadow:0 1px 1px rgba(0,0,0,.08);position:relative;
  animation:wa-msg-in .4s ease-out .2s both;
}
.wa-msg::before{
  content:'';position:absolute;top:0;left:-8px;width:0;height:0;
  border-top:8px solid #fff;border-left:8px solid transparent;
}
.wa-msg strong{color:#075E54}
.wa-time{font-size:.65rem;color:var(--muted);margin-top:.3rem;display:block}
@keyframes wa-msg-in{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:none}}

.wa-foot{padding:.9rem 1.2rem 1.1rem;background:var(--paper)}
.wa-cta{
  display:flex;align-items:center;justify-content:center;gap:.6rem;
  width:100%;padding:.85rem;background:#25D366;color:#fff;
  font-weight:600;font-size:.92rem;border-radius:8px;
  transition:background .2s;
}
.wa-cta:hover{background:#128C7E;color:#fff}
.wa-cta svg{width:18px;height:18px;fill:#fff}

@media(max-width:500px){
  .wa-float{bottom:1rem;right:1rem}
  .wa-btn{width:56px;height:56px}
  .wa-btn svg{width:28px;height:28px}
}

/* ========== TESTIMONIALS & STATS BAND ========== */
.stats-band{
  background:var(--ink);color:var(--paper);
  padding:clamp(3rem,6vw,5rem) 0;
  position:relative;overflow:hidden;
}
.stats-band::before{
  content:'';position:absolute;inset:0;
  background-image:
    linear-gradient(rgba(246,243,238,.03) 1px,transparent 1px),
    linear-gradient(90deg,rgba(246,243,238,.03) 1px,transparent 1px);
  background-size:40px 40px;pointer-events:none;
}
.stats-head{
  display:grid;grid-template-columns:1fr auto;gap:2rem;align-items:end;
  margin-bottom:3rem;position:relative;z-index:2;
}
@media(max-width:700px){.stats-head{grid-template-columns:1fr}}
.stats-head h2{max-width:20ch}
.stats-rating-big{
  font-family:var(--f-display);font-weight:800;color:var(--heat);
  font-size:4.5rem;line-height:1;
  display:flex;align-items:baseline;gap:.3rem;
}
.stats-rating-big small{font-size:1.2rem;color:rgba(246,243,238,.6);font-weight:400}
.stats-stars{color:var(--heat);font-size:1.2rem;letter-spacing:.1em;margin-bottom:.4rem}
.stats-stars-label{font-family:var(--f-mono);font-size:.72rem;letter-spacing:.08em;text-transform:uppercase;color:rgba(246,243,238,.55)}

.stats-grid{
  display:grid;grid-template-columns:repeat(4,1fr);gap:0;
  border-top:1px solid rgba(246,243,238,.15);border-bottom:1px solid rgba(246,243,238,.15);
  position:relative;z-index:2;margin-bottom:3rem;
}
@media(max-width:800px){.stats-grid{grid-template-columns:1fr 1fr}}
.stat-cell{
  padding:2rem;border-right:1px solid rgba(246,243,238,.15);
}
.stat-cell:last-child{border-right:none}
@media(max-width:800px){
  .stat-cell:nth-child(2){border-right:none}
  .stat-cell:nth-child(odd){border-right:1px solid rgba(246,243,238,.15)}
  .stat-cell:nth-child(1),.stat-cell:nth-child(2){border-bottom:1px solid rgba(246,243,238,.15)}
}
.stat-big{
  font-family:var(--f-display);font-weight:800;color:var(--heat);
  font-size:clamp(2.4rem,5vw,3.6rem);line-height:1;letter-spacing:-.02em;
}
.stat-big-label{
  font-family:var(--f-mono);font-size:.72rem;letter-spacing:.08em;
  text-transform:uppercase;color:rgba(246,243,238,.6);margin-top:.7rem;
}

.testimonials{
  display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem;
  position:relative;z-index:2;
}
@media(max-width:900px){.testimonials{grid-template-columns:1fr}}
.testimonial{
  background:rgba(246,243,238,.04);border:1px solid rgba(246,243,238,.1);
  padding:1.8rem;position:relative;
}
.testimonial-stars{color:var(--heat);font-size:.95rem;letter-spacing:.08em;margin-bottom:1rem}
.testimonial-quote{
  font-family:var(--f-display);font-style:italic;font-weight:400;
  font-size:1.1rem;line-height:1.5;color:var(--paper);margin-bottom:1.5rem;
}
.testimonial-author{
  display:flex;align-items:center;gap:.8rem;
  font-size:.85rem;
}
.testimonial-avatar{
  width:40px;height:40px;border-radius:50%;
  background:var(--heat);color:var(--paper);
  display:grid;place-items:center;font-weight:700;font-family:var(--f-display);
  font-size:.95rem;flex-shrink:0;
}
.testimonial-name{font-weight:600;color:var(--paper)}
.testimonial-role{color:rgba(246,243,238,.5);font-size:.78rem}

/* ========== CONTACT PAGE ========== */
.contact-layout{
  display:grid;grid-template-columns:.9fr 1.3fr;gap:3rem;
  margin:-1rem 0;
}
@media(max-width:900px){.contact-layout{grid-template-columns:1fr;gap:2rem}}

.contact-info-col{
  background:var(--paper-2);padding:2.5rem;
  border-left:3px solid var(--heat);
}
.contact-block{padding:1.2rem 0;border-bottom:1px dashed rgba(13,13,15,.12)}
.contact-block:last-of-type{border-bottom:none}
.contact-block-label{
  font-family:var(--f-mono);font-size:.7rem;letter-spacing:.08em;
  text-transform:uppercase;color:var(--heat);margin-bottom:.5rem;
}
.contact-phone{
  font-size:1.5rem;font-weight:700;color:var(--ink);
  display:inline-block;transition:color .2s;
}
.contact-phone:hover{color:var(--heat)}
.contact-email{
  font-size:1rem;font-weight:600;color:var(--ink);
  display:inline-block;transition:color .2s;word-break:break-all;
}
.contact-email:hover{color:var(--heat)}
.contact-block-sub{
  font-size:.82rem;color:var(--muted);margin-top:.3rem;
}
.contact-trust{
  margin-top:1.5rem;padding-top:1.5rem;
  border-top:1px solid rgba(13,13,15,.12);
}

.contact-form-col{background:var(--paper);padding:0}
.contact-form-header{margin-bottom:2rem;padding-bottom:1.5rem;border-bottom:1px solid rgba(13,13,15,.12)}
.contact-form{display:flex;flex-direction:column;gap:1.2rem}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1.2rem}
@media(max-width:600px){.form-row{grid-template-columns:1fr}}
.contact-form label{display:flex;flex-direction:column;gap:.4rem;font-size:.88rem}
.contact-form label > span{
  font-family:var(--f-mono);font-size:.72rem;letter-spacing:.06em;
  text-transform:uppercase;color:var(--ink);font-weight:600;
}
.contact-form input,.contact-form select,.contact-form textarea{
  padding:.85rem 1rem;
  background:var(--paper-2);border:1.5px solid transparent;
  font-family:var(--f-body);font-size:.95rem;color:var(--ink);
  outline:none;transition:all .2s;
  width:100%;
}
.contact-form input:focus,.contact-form select:focus,.contact-form textarea:focus{
  background:var(--paper);border-color:var(--heat);
}
.contact-form textarea{resize:vertical;min-height:120px;font-family:var(--f-body)}
.contact-form select{
  appearance:none;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath fill='%230d0d0f' d='M6 8L0 0h12z'/%3E%3C/svg%3E");
  background-repeat:no-repeat;background-position:right 1rem center;
  padding-right:2.5rem;cursor:pointer;
}
.form-check{
  flex-direction:row !important;align-items:flex-start;gap:.8rem;
  font-size:.85rem;line-height:1.5;color:var(--ink-2);
}
.form-check input{width:auto !important;margin-top:.2rem;accent-color:var(--heat)}
.form-check span{font-family:var(--f-body) !important;font-size:.85rem !important;letter-spacing:0 !important;text-transform:none !important;font-weight:400 !important;color:var(--ink-2) !important}
.form-check a{color:var(--heat);text-decoration:underline}
.form-submit{
  margin-top:.5rem;justify-content:center;font-size:1rem;padding:1.1rem;
  border:none;cursor:pointer;width:100%;
}
.form-note{
  font-size:.78rem;color:var(--muted);margin-top:.5rem;line-height:1.5;
}
.form-success{
  padding:2rem;background:var(--paper-2);border-left:3px solid var(--success);
  text-align:center;
}
.form-success-icon{
  width:60px;height:60px;border-radius:50%;
  background:var(--success);color:var(--paper);
  display:grid;place-items:center;font-size:2rem;margin:0 auto 1rem;
}
.form-field-error{border-color:#c0392b !important;background:#fdf2f2 !important}
.form-error-banner{
  background:#fdf2f2;border-left:3px solid #c0392b;color:#7a1f1f;
  padding:1rem 1.2rem;margin-bottom:1.5rem;font-size:.9rem;line-height:1.5;
}

/* ========== BLOG ========== */
.blog-hero{
  background:linear-gradient(180deg,var(--paper) 0%,var(--paper-2) 100%);
  padding:clamp(4rem,8vw,7rem) 0 clamp(3rem,5vw,5rem);
  position:relative;overflow:hidden;
}
.blog-hero-kicker{
  font-family:var(--f-mono);font-size:.75rem;color:var(--heat);
  letter-spacing:.1em;text-transform:uppercase;margin-bottom:2rem;
  display:inline-flex;align-items:center;gap:.8rem;
}
.blog-hero-kicker::before{content:'';width:32px;height:1px;background:var(--heat)}
.blog-hero-title{
  font-size:clamp(2.4rem,5.5vw,4.8rem);line-height:1.05;
  max-width:18ch;margin-bottom:1.5rem;
}
.blog-hero-title em{color:var(--heat);font-style:italic;font-weight:400}
.blog-hero-sub{
  font-size:clamp(1.05rem,1.3vw,1.2rem);max-width:640px;
  color:var(--ink-2);line-height:1.55;
}

.blog-featured{padding:clamp(2rem,4vw,3rem) 0;background:var(--paper)}
.blog-featured-card{
  display:grid;grid-template-columns:1.4fr .9fr;gap:0;
  background:var(--ink);color:var(--paper);
  transition:transform .3s;position:relative;overflow:hidden;
}
.blog-featured-card:hover{transform:translateY(-4px)}
@media(max-width:800px){.blog-featured-card{grid-template-columns:1fr}}
.blog-featured-text{padding:3rem 2.5rem}
.blog-featured-text .article-card-cat{color:var(--heat);background:transparent;padding:0;margin-bottom:1.2rem}
.blog-featured-text h2{color:var(--paper);margin-bottom:1rem;font-size:clamp(1.5rem,3vw,2.4rem);line-height:1.15}
.blog-featured-text p{color:rgba(246,243,238,.75);font-size:1rem;line-height:1.55;margin-bottom:1.5rem}
.blog-featured-text .article-card-meta{color:rgba(246,243,238,.5);margin-bottom:1.5rem}
.blog-featured-cta{
  color:var(--heat);font-weight:600;font-size:.95rem;
  display:inline-flex;align-items:center;gap:.5rem;
  transition:gap .2s;
}
.blog-featured-card:hover .blog-featured-cta{gap:.8rem;color:var(--paper)}
.blog-featured-visual{
  background:var(--heat);display:flex;flex-direction:column;justify-content:space-between;
  padding:3rem 2rem;position:relative;overflow:hidden;
}
.blog-featured-num{
  font-family:var(--f-display);font-weight:800;font-size:10rem;
  color:rgba(13,13,15,.15);line-height:.9;letter-spacing:-.05em;
}
.blog-featured-label{
  font-family:var(--f-mono);font-size:.72rem;letter-spacing:.08em;
  text-transform:uppercase;color:rgba(13,13,15,.6);font-weight:600;
}

.blog-section{padding:clamp(3rem,5vw,4rem) 0}
.blog-section:nth-child(even){background:var(--paper-2)}
.blog-section-head{
  display:flex;align-items:baseline;justify-content:space-between;
  gap:1rem;margin-bottom:2.5rem;padding-bottom:1rem;
  border-bottom:1px solid rgba(13,13,15,.15);
}
.blog-section-head h2{font-size:clamp(1.5rem,2.5vw,2.2rem)}
.blog-section-count{
  font-family:var(--f-mono);font-size:.72rem;letter-spacing:.08em;
  text-transform:uppercase;color:var(--muted);
}

.blog-grid{
  display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:1.5rem;
}
.article-card{
  background:var(--paper);padding:1.8rem;
  border:1px solid rgba(13,13,15,.1);
  transition:all .3s;display:block;
  display:flex;flex-direction:column;gap:.8rem;
}
.article-card:hover{
  background:var(--ink);color:var(--paper);
  transform:translateY(-4px);border-color:var(--ink);
}
.article-card:hover .article-card-cat{color:var(--heat)}
.article-card:hover .article-card-meta{color:rgba(246,243,238,.5)}
.article-card-cat{
  font-family:var(--f-mono);font-size:.7rem;letter-spacing:.08em;
  text-transform:uppercase;color:var(--heat);font-weight:700;
}
.article-card h3{font-size:1.2rem;line-height:1.2;margin:0}
.article-card p{font-size:.9rem;line-height:1.5;opacity:.8;flex-grow:1;margin:0}
.article-card-meta{
  font-family:var(--f-mono);font-size:.7rem;color:var(--muted);
  letter-spacing:.05em;padding-top:.8rem;border-top:1px solid rgba(13,13,15,.08);
}
.article-card:hover .article-card-meta{border-color:rgba(246,243,238,.1)}

/* Article hero */
.article-hero{
  padding:clamp(3rem,6vw,5rem) 0 clamp(2rem,4vw,3rem);
  background:linear-gradient(180deg,var(--paper) 0%,var(--paper-2) 100%);
}
.article-hero-wrap{max-width:820px}
.article-meta{
  display:flex;gap:1rem;flex-wrap:wrap;
  font-family:var(--f-mono);font-size:.72rem;letter-spacing:.08em;
  text-transform:uppercase;margin-bottom:1.5rem;
}
.article-cat{color:var(--heat);font-weight:700}
.article-date,.article-read{color:var(--muted)}
.article-title{
  font-size:clamp(2rem,4vw,3.4rem);line-height:1.1;margin-bottom:1.5rem;
}
.article-excerpt{
  font-size:clamp(1.1rem,1.4vw,1.3rem);color:var(--ink-2);
  line-height:1.55;font-family:var(--f-display);font-weight:400;font-style:italic;
}

.article-body{background:var(--paper);padding:clamp(2rem,4vw,3.5rem) 0}
.article-content{
  max-width:720px;margin:0 auto;
  font-size:1.05rem;line-height:1.75;color:var(--ink-2);
}
.article-lead{
  font-size:1.2rem;line-height:1.55;color:var(--ink);
  border-left:3px solid var(--heat);padding-left:1.5rem;margin-bottom:2.5rem;
}
.article-content h2{
  font-size:clamp(1.5rem,2.5vw,2rem);margin:2.8rem 0 1rem;color:var(--ink);
}
.article-content h3{
  font-size:1.25rem;margin:1.8rem 0 .8rem;color:var(--ink);
}
.article-content p{margin-bottom:1.2rem}
.article-content ul,.article-content ol{margin:1rem 0 1.5rem;padding-left:0;list-style:none}
.article-content ul li,.article-content ol li{padding-left:1.8rem;position:relative;margin-bottom:.6rem}
.article-content ul li::before{content:'▸';position:absolute;left:0;color:var(--heat);font-weight:700}
.article-content ol{counter-reset:step}
.article-content ol li{counter-increment:step}
.article-content ol li::before{
  content:counter(step,decimal-leading-zero);
  position:absolute;left:0;color:var(--heat);font-family:var(--f-mono);font-weight:700;font-size:.85rem;
}
.article-content strong{color:var(--ink);font-weight:600}
.article-content a{color:var(--heat);text-decoration:underline;text-underline-offset:3px}
.article-content a:hover{color:var(--ink)}
.article-content em{font-style:italic;color:var(--ink)}
.article-cta-box{
  background:var(--paper-2);border-left:3px solid var(--heat);
  padding:1.5rem;margin-top:2.5rem;font-size:1rem;line-height:1.5;
}
.article-cta-box strong{color:var(--heat)}

.article-related{background:var(--paper-2);padding:clamp(3rem,5vw,4.5rem) 0}
.article-related-title{
  font-size:clamp(1.6rem,2.5vw,2.2rem);margin-bottom:2rem;
}
.article-related-grid{
  display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1.5rem;
}

/* ========== BREADCRUMB ========== */
.breadcrumb{
  padding:1.2rem 0;background:var(--paper-2);
  font-family:var(--f-mono);font-size:.72rem;letter-spacing:.05em;
  color:var(--muted);border-bottom:1px solid rgba(13,13,15,.08);
}
.breadcrumb a{color:var(--muted)}
.breadcrumb a:hover{color:var(--heat)}
.breadcrumb .sep{margin:0 .6rem;color:rgba(13,13,15,.25)}
.breadcrumb .current{color:var(--ink)}

/* ========== CITY PAGE SPECIFIC ========== */
.city-hero{
  background:linear-gradient(180deg,var(--paper) 0%,var(--paper-2) 100%);
  padding:clamp(3rem,6vw,5rem) 0 clamp(3rem,5vw,4rem);position:relative;overflow:hidden;
}
.city-hero-inner{display:grid;grid-template-columns:1.4fr 1fr;gap:3rem;align-items:end}
@media(max-width:900px){.city-hero-inner{grid-template-columns:1fr;gap:2rem}}
.city-kicker{font-family:var(--f-mono);font-size:.75rem;color:var(--heat);letter-spacing:.1em;text-transform:uppercase;margin-bottom:1.2rem}
.city-h1{font-size:clamp(2.2rem,5vw,4.2rem);margin-bottom:1.3rem}
.city-h1 .city-name{color:var(--heat);font-style:italic;font-weight:400}
.city-sub{font-size:1.1rem;color:var(--ink-2);max-width:580px;margin-bottom:2rem;line-height:1.5}
.city-infobox{
  background:var(--ink);color:var(--paper);padding:2rem;
}
.city-infobox h4{font-family:var(--f-mono);font-size:.72rem;color:var(--heat);letter-spacing:.1em;margin-bottom:1.2rem}
.city-infobox dl{display:grid;grid-template-columns:1fr 1fr;gap:1rem .5rem;font-size:.88rem}
.city-infobox dt{color:rgba(246,243,238,.5);font-family:var(--f-mono);font-size:.7rem;text-transform:uppercase;letter-spacing:.05em}
.city-infobox dd{color:var(--paper);font-weight:500}

.city-content{padding:clamp(3rem,6vw,5rem) 0;background:var(--paper)}
.city-content .prose{max-width:720px;font-size:1.05rem;line-height:1.75;color:var(--ink-2)}
.city-content .prose h2{font-size:clamp(1.6rem,3vw,2.4rem);margin:2.5rem 0 1rem;color:var(--ink)}
.city-content .prose h3{font-size:1.3rem;margin:2rem 0 .8rem;color:var(--ink)}
.city-content .prose p{margin-bottom:1.2rem}
.city-content .prose ul{margin:1rem 0 1.5rem;padding-left:0;list-style:none}
.city-content .prose ul li{padding-left:1.5rem;position:relative;margin-bottom:.5rem}
.city-content .prose ul li::before{content:'▸';position:absolute;left:0;color:var(--heat)}
.city-content .prose strong{color:var(--ink);font-weight:600}

.nearby{background:var(--paper-2);padding:clamp(3rem,5vw,4rem) 0}
.nearby h3{font-size:1.8rem;margin-bottom:2rem}
.nearby-list{display:flex;flex-wrap:wrap;gap:.6rem}
.nearby-list a{
  padding:.5rem 1rem;background:var(--paper);border:1px solid rgba(13,13,15,.15);
  font-size:.85rem;font-weight:500;transition:all .2s;
}
.nearby-list a:hover{background:var(--ink);color:var(--paper);border-color:var(--ink)}

/* ========== SEARCH ========== */
.search-wrap{
  position:relative;max-width:500px;margin:2rem 0;
}
.search-input{
  width:100%;padding:1rem 1.2rem;background:var(--paper);
  border:1.5px solid var(--ink);font-size:.95rem;font-family:var(--f-body);
  color:var(--ink);outline:none;
}
.search-input:focus{border-color:var(--heat)}
.search-results{
  position:absolute;top:100%;left:0;right:0;background:var(--paper);
  border:1.5px solid var(--ink);border-top:none;
  max-height:320px;overflow-y:auto;z-index:10;display:none;
}
.search-results.open{display:block}
.search-results a{
  display:block;padding:.7rem 1.2rem;font-size:.9rem;border-bottom:1px solid rgba(13,13,15,.08);
}
.search-results a:hover{background:var(--paper-2);color:var(--heat)}

/* ========== UTILS ========== */
.reveal{opacity:0;transform:translateY(20px);transition:all .7s cubic-bezier(.2,.8,.2,1)}
.reveal.in{opacity:1;transform:none}

@media(max-width:600px){
  .hero-stats{grid-template-columns:1fr}
  .section-head{margin-bottom:2.5rem}
}
