/* ============================================================
   Terapia Pra Vida — Sistema visual refinado
   Clínico/premium · Sálvia + Terracota · Playfair + Nunito
   ============================================================ */

:root{
  /* ---- Paleta sálvia + terracota ---- */
  --sage-50:#f4f8f5;
  --sage-100:#e6f0ea;
  --sage-200:#cbe0d4;
  --sage-300:#a3c8b3;
  --sage-400:#7fb59b;
  --sage-500:#5a967c;
  --sage-600:#3f7660;
  --sage-700:#2f5a49;
  --sage-800:#22433709;
  --sage-900:#142b22;

  --terra-50:#fbf3ee;
  --terra-100:#f5e2d4;
  --terra-200:#ebc6ad;
  --terra-300:#dca47e;
  --terra-400:#c98359;
  --terra-500:#b06440;
  --terra-600:#8e4d2f;

  --sand-50:#faf6f0;
  --sand-100:#f3ece0;
  --sand-200:#e6dac6;

  --ink-50:#f7f7f6;
  --ink-100:#ececea;
  --ink-200:#d9d9d5;
  --ink-300:#b6b6b0;
  --ink-400:#7d7d76;
  --ink-500:#56564f;
  --ink-600:#3a3a35;
  --ink-700:#26261f;
  --ink-800:#171712;
  --ink-900:#0d0d0a;

  /* ---- Tokens semânticos ---- */
  --primary:var(--sage-500);
  --primary-dark:var(--sage-700);
  --primary-bg:var(--sage-100);
  --accent:var(--terra-400);
  --accent-dark:var(--terra-600);
  --accent-bg:var(--terra-50);

  --bg:var(--sand-50);
  --surface:#ffffff;
  --surface-2:var(--sand-100);
  --text:var(--ink-700);
  --text-muted:var(--ink-500);
  --border:rgba(34,67,55,.10);
  --border-strong:rgba(34,67,55,.18);

  /* dark */
  --surface-dk:#181a18;
  --surface-2-dk:#22251f;
  --text-dk:#ececea;
  --text-muted-dk:#a3a59c;
  --border-dk:rgba(255,255,255,.08);

  /* ---- Tipografia ---- */
  --font-display:'Playfair Display',Georgia,serif;
  --font-body:'Nunito',system-ui,sans-serif;

  /* ---- Espaço, raio, sombra ---- */
  --radius-sm:8px;
  --radius:14px;
  --radius-lg:22px;
  --radius-xl:28px;
  --radius-2xl:36px;

  --shadow-sm:0 1px 2px rgba(20,43,34,.04),0 1px 1px rgba(20,43,34,.03);
  --shadow:0 8px 24px -8px rgba(20,43,34,.10),0 2px 6px rgba(20,43,34,.04);
  --shadow-lg:0 24px 60px -20px rgba(20,43,34,.18),0 8px 20px -8px rgba(20,43,34,.08);
  --shadow-xl:0 40px 90px -30px rgba(20,43,34,.30),0 12px 30px -10px rgba(20,43,34,.12);
  --shadow-glow:0 0 0 1px rgba(127,181,155,.18),0 12px 40px -12px rgba(90,150,124,.35);

  --transition:.32s cubic-bezier(.22,.61,.36,1);
  --ease-out:cubic-bezier(.22,.61,.36,1);
  --ease-spring:cubic-bezier(.34,1.56,.64,1);

  --header-h:76px;
  --container:1280px;
}

/* dark mode tokens */
.dark-mode{
  --bg:#0f110f;
  --surface:var(--surface-dk);
  --surface-2:var(--surface-2-dk);
  --text:var(--text-dk);
  --text-muted:var(--text-muted-dk);
  --border:var(--border-dk);
  --border-strong:rgba(255,255,255,.14);
  --primary:var(--sage-300);
  --primary-dark:var(--sage-200);
  --primary-bg:rgba(127,181,155,.12);
  --accent:var(--terra-300);
  --accent-bg:rgba(220,164,126,.10);
}

/* ---- Reset + base ---- */
*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  margin:0;
  background:var(--bg);
  color:var(--text);
  font-family:var(--font-body);
  font-size:16px;
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  transition:background .4s var(--ease-out),color .4s var(--ease-out);
}
img,svg{max-width:100%;display:block}
a{color:inherit}
button{font:inherit}

::selection{background:var(--sage-200);color:var(--sage-900)}
.dark-mode ::selection{background:var(--sage-700);color:#fff}

/* ---- Layout helpers ---- */
.section{padding:7rem 0;position:relative}
.section-inner{max-width:var(--container);margin:0 auto;padding:0 1.5rem}
.section-surface{background:var(--surface)}
.section-alt{background:linear-gradient(180deg,var(--bg) 0%,var(--surface-2) 100%)}
.dark-mode .section-alt{background:linear-gradient(180deg,var(--bg) 0%,var(--surface-2-dk) 100%)}

@media(max-width:768px){.section{padding:4.5rem 0}}

/* ---- Tipografia ---- */
.section-header{text-align:center;max-width:680px;margin:0 auto 4rem}
.section-badge{
  display:inline-flex;align-items:center;gap:.4rem;
  font-size:.72rem;font-weight:700;letter-spacing:.16em;text-transform:uppercase;
  color:var(--primary);
  padding:.4rem .9rem;
  background:var(--primary-bg);
  border-radius:99px;
  border:1px solid rgba(127,181,155,.25);
}
.section-badge::before{
  content:'';width:6px;height:6px;border-radius:50%;background:var(--primary);
  box-shadow:0 0 0 4px rgba(127,181,155,.18);
}
.section-title{
  font-family:var(--font-display);
  font-weight:600;
  font-size:clamp(2rem,4.5vw,3.4rem);
  line-height:1.08;
  letter-spacing:-.015em;
  color:var(--text);
  margin:1.25rem 0 0;
  text-wrap:balance;
}
.section-title em{font-style:italic;color:var(--primary);font-weight:500}
.section-title .accent{color:var(--accent)}
.italic{font-style:italic}
.text-primary{color:var(--primary)}

.divider{
  width:54px;height:2px;margin:1.4rem auto 0;
  background:linear-gradient(90deg,transparent,var(--primary) 30%,var(--accent) 70%,transparent);
  border-radius:2px;
}
.section-desc{color:var(--text-muted);font-size:1.03rem;text-wrap:pretty;max-width:60ch;margin-left:auto;margin-right:auto}

/* ---- Botões ---- */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:.5rem;
  padding:.85rem 1.4rem;
  border-radius:99px;
  font-weight:700;font-size:.92rem;letter-spacing:.005em;
  text-decoration:none;border:1.5px solid transparent;
  cursor:pointer;transition:all var(--transition);
  white-space:nowrap;line-height:1;
  position:relative;overflow:hidden;
}
.btn-lg{padding:1.05rem 1.7rem;font-size:.98rem}
.btn .material-icons-round{font-size:1.05rem}

.btn-primary{
  background:var(--primary);color:#fff;
  box-shadow:0 8px 22px -10px rgba(90,150,124,.55),inset 0 1px 0 rgba(255,255,255,.18);
}
.btn-primary:hover{
  background:var(--primary-dark);transform:translateY(-2px);
  box-shadow:0 16px 36px -14px rgba(90,150,124,.65),inset 0 1px 0 rgba(255,255,255,.22);
}
.btn-primary::after{
  content:'';position:absolute;inset:0;
  background:linear-gradient(110deg,transparent 30%,rgba(255,255,255,.25) 45%,transparent 60%);
  transform:translateX(-100%);transition:transform .9s var(--ease-out);
}
.btn-primary:hover::after{transform:translateX(100%)}

.btn-ghost{
  background:transparent;color:var(--text);
  border-color:var(--border-strong);
}
.btn-ghost:hover{
  background:var(--surface);color:var(--primary);border-color:var(--primary);
  transform:translateY(-2px);
}
.dark-mode .btn-ghost:hover{background:var(--surface-2)}

.btn-outline{
  background:transparent;color:var(--primary);border-color:var(--primary);
}
.btn-outline:hover{background:var(--primary);color:#fff;transform:translateY(-2px)}

.btn-outline-white{background:transparent;color:#fff;border-color:rgba(255,255,255,.6)}
.btn-outline-white:hover{background:#fff;color:var(--primary-dark)}

.btn-whatsapp{background:#25d366;color:#fff;box-shadow:0 8px 22px -10px rgba(37,211,102,.55)}
.btn-whatsapp:hover{background:#1eb558;transform:translateY(-2px);box-shadow:0 16px 36px -14px rgba(37,211,102,.65)}

/* ---- Reveal on scroll ---- */
.fade-in-up{opacity:0;transform:translateY(28px);transition:opacity .8s var(--ease-out),transform .8s var(--ease-out)}
.fade-in-up.visible{opacity:1;transform:translateY(0)}
.fade-in-up[data-stagger="1"]{transition-delay:.08s}
.fade-in-up[data-stagger="2"]{transition-delay:.16s}
.fade-in-up[data-stagger="3"]{transition-delay:.24s}
.fade-in-up[data-stagger="4"]{transition-delay:.32s}
.fade-in-up[data-stagger="5"]{transition-delay:.40s}

@media (prefers-reduced-motion:reduce){
  .fade-in-up{opacity:1;transform:none;transition:none}
  *,*::before,*::after{animation-duration:.001ms!important;transition-duration:.001ms!important}
}

/* ---- Form ---- */
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
@media(max-width:640px){.form-grid{grid-template-columns:1fr}}
.form-group{display:flex;flex-direction:column;gap:.4rem}
.form-label{font-size:.78rem;font-weight:700;letter-spacing:.04em;color:var(--text);text-transform:uppercase}
.form-input,.form-select,.form-textarea{
  width:100%;padding:.85rem 1rem;font:inherit;
  background:var(--bg);color:var(--text);
  border:1.5px solid var(--border);border-radius:var(--radius);
  transition:all var(--transition);
}
.dark-mode .form-input,.dark-mode .form-select,.dark-mode .form-textarea{background:var(--surface-2-dk)}
.form-textarea{min-height:110px;resize:vertical;font-family:var(--font-body)}
.form-input:focus,.form-select:focus,.form-textarea:focus{
  outline:none;border-color:var(--primary);
  box-shadow:0 0 0 4px rgba(127,181,155,.18);
  background:var(--surface);
}

/* ---- WhatsApp flutuante ---- */
.floating-wa{
  position:fixed;right:1.5rem;bottom:1.5rem;z-index:80;
  width:60px;height:60px;border-radius:50%;
  background:#25d366;color:#fff;
  display:flex;align-items:center;justify-content:center;
  box-shadow:0 12px 32px -8px rgba(37,211,102,.55),0 0 0 0 rgba(37,211,102,.4);
  animation:waPulse 2.4s ease-out infinite;
  transition:transform .3s var(--ease-spring);
}
.floating-wa svg{width:28px;height:28px;fill:currentColor}
.floating-wa:hover{transform:scale(1.1) rotate(-5deg)}
@keyframes waPulse{
  0%{box-shadow:0 12px 32px -8px rgba(37,211,102,.55),0 0 0 0 rgba(37,211,102,.5)}
  70%{box-shadow:0 12px 32px -8px rgba(37,211,102,.55),0 0 0 22px rgba(37,211,102,0)}
  100%{box-shadow:0 12px 32px -8px rgba(37,211,102,.55),0 0 0 0 rgba(37,211,102,0)}
}

/* ---- Blobs orgânicos ---- */
.blob{
  position:absolute;border-radius:50%;
  filter:blur(60px);
  opacity:.55;pointer-events:none;
  animation:blobDrift 18s ease-in-out infinite alternate;
  will-change:transform;
}
.dark-mode .blob{opacity:.32}
@keyframes blobDrift{
  0%{transform:translate(0,0) scale(1)}
  33%{transform:translate(40px,-30px) scale(1.08)}
  66%{transform:translate(-30px,30px) scale(.95)}
  100%{transform:translate(20px,40px) scale(1.05)}
}
/* Header — refined glass nav with mega-menu preview */
.site-header{
  position:sticky;top:0;z-index:100;height:var(--header-h);
  background:rgba(255,255,255,.72);
  backdrop-filter:blur(24px) saturate(1.6);
  -webkit-backdrop-filter:blur(24px) saturate(1.6);
  border-bottom:1px solid var(--border);
  transition:background var(--transition),box-shadow var(--transition),border-color var(--transition);
}
.dark-mode .site-header{background:rgba(15,17,15,.72);border-bottom-color:var(--border-dk)}
.site-header.scrolled{
  background:rgba(255,255,255,.92);
  box-shadow:0 8px 32px -12px rgba(20,43,34,.10);
  border-bottom-color:transparent;
}
.dark-mode .site-header.scrolled{background:rgba(15,17,15,.92)}

.header-inner{
  max-width:var(--container);margin:0 auto;padding:0 1.5rem;height:100%;
  display:flex;align-items:center;justify-content:space-between;gap:1.5rem;
}

/* Logo */
.logo{display:flex;align-items:center;gap:.85rem;text-decoration:none;flex-shrink:0}
.logo-icon{
  width:46px;height:46px;border-radius:50%;
  background:linear-gradient(135deg,var(--sage-100),var(--sage-200));
  display:flex;align-items:center;justify-content:center;
  border:1.5px solid rgba(127,181,155,.4);
  position:relative;overflow:hidden;
  transition:transform .5s var(--ease-spring);
}
.logo-icon::after{
  content:'';position:absolute;inset:0;border-radius:50%;
  background:radial-gradient(circle at 30% 30%,rgba(255,255,255,.6),transparent 50%);
}
.logo:hover .logo-icon{transform:rotate(-12deg) scale(1.06)}
.logo-mark{
  font-family:var(--font-display);font-size:1.4rem;font-weight:700;
  color:var(--sage-700);position:relative;z-index:1;
  font-style:italic;
}
.dark-mode .logo-mark{color:var(--sage-200)}
.logo-text{display:none;line-height:1.25}
.logo-text strong{
  display:block;font-family:var(--font-display);
  font-size:1.08rem;font-weight:600;color:var(--text);
  letter-spacing:-.005em;
}
.logo-text span{
  font-size:.66rem;color:var(--text-muted);
  letter-spacing:.16em;text-transform:uppercase;font-weight:600;
}

/* Nav */
.site-nav{display:none;align-items:center;gap:.1rem}
.nav-link,.nav-btn{
  display:flex;align-items:center;gap:.32rem;
  padding:.55rem .95rem;
  font-size:.88rem;font-weight:600;
  color:var(--text-muted);
  text-decoration:none;
  border:none;background:transparent;cursor:pointer;
  border-radius:99px;font-family:var(--font-body);
  transition:color .25s,background .25s;
  white-space:nowrap;position:relative;
}
.nav-link:hover,.nav-btn:hover,
.nav-link.active,.nav-btn.active{color:var(--text)}
.nav-link::before{
  content:'';position:absolute;left:50%;bottom:.2rem;
  width:0;height:2px;background:var(--primary);
  transform:translateX(-50%);transition:width .28s var(--ease-out);
  border-radius:2px;
}
.nav-link:hover::before,.nav-link.active::before{width:18px}
.nav-btn .material-icons-round{font-size:1rem;transition:transform .3s var(--ease-out);opacity:.7}
.nav-dropdown:hover .nav-btn .material-icons-round,
.nav-dropdown:focus-within .nav-btn .material-icons-round{transform:rotate(180deg);opacity:1}

/* Dropdown */
.nav-dropdown{position:relative}
.dropdown-menu{
  opacity:0;pointer-events:none;
  position:absolute;top:calc(100% + .5rem);left:50%;transform:translate(-50%,-8px);
  min-width:240px;
  background:rgba(255,255,255,.96);
  backdrop-filter:blur(20px) saturate(1.4);
  -webkit-backdrop-filter:blur(20px) saturate(1.4);
  border:1px solid var(--border-strong);
  border-radius:var(--radius-lg);
  box-shadow:var(--shadow-xl);
  padding:.6rem;z-index:200;
  transition:opacity .25s var(--ease-out),transform .25s var(--ease-out);
}
.dark-mode .dropdown-menu{background:rgba(24,26,24,.96)}
.dropdown-menu::before{
  content:'';position:absolute;top:-.7rem;left:0;right:0;height:.7rem;
}
.nav-dropdown:hover .dropdown-menu,
.nav-dropdown:focus-within .dropdown-menu{
  opacity:1;pointer-events:auto;transform:translate(-50%,0);
}

/* Mega menu (especialidades) */
.dropdown-menu.mega{
  min-width:680px;left:0;transform:translate(0,-8px);
  display:grid;grid-template-columns:1fr 1fr 240px;
  gap:.4rem;padding:1rem;
}
.nav-dropdown:hover .dropdown-menu.mega,
.nav-dropdown:focus-within .dropdown-menu.mega{transform:translate(0,0)}
.dropdown-group-label{
  grid-column:1/-1;
  font-size:.66rem;font-weight:800;letter-spacing:.14em;text-transform:uppercase;
  color:var(--text-muted);padding:.5rem .55rem .25rem;
}
.dropdown-group-label:not(:first-child){
  border-top:1px solid var(--border);margin-top:.4rem;padding-top:.85rem;
}
.mega .dropdown-group-label{grid-column:1/3}
.mega .dropdown-group-label.continue{border-top:none;margin-top:0;padding-top:.5rem}
.mega .dropdown-item{grid-column:auto}
.mega-preview{
  grid-column:3;grid-row:1/-1;
  border-radius:var(--radius);overflow:hidden;
  background:linear-gradient(135deg,var(--sage-100),var(--sand-100));
  position:relative;min-height:280px;
  display:flex;flex-direction:column;justify-content:flex-end;
  padding:1rem;color:#fff;
  transition:background .35s var(--ease-out);
}
.mega-preview::before{
  content:'';position:absolute;inset:0;
  background-image:var(--preview-img,url('https://images.unsplash.com/photo-1573496359142-b8d87734a5a2?w=600&q=80'));
  background-size:cover;background-position:center;
  transition:transform .6s var(--ease-out),opacity .35s var(--ease-out);
  transform:scale(1.05);
}
.mega-preview::after{
  content:'';position:absolute;inset:0;
  background:linear-gradient(180deg,rgba(20,43,34,.05) 0%,rgba(20,43,34,.85) 100%);
}
.mega-preview > *{position:relative;z-index:1}
.mega-preview-title{
  font-family:var(--font-display);font-style:italic;
  font-size:1.1rem;line-height:1.2;font-weight:500;
}
.mega-preview-cta{
  margin-top:.35rem;font-size:.78rem;font-weight:700;
  display:inline-flex;align-items:center;gap:.25rem;
  color:rgba(255,255,255,.85);
}

.dropdown-item{
  display:flex;align-items:center;gap:.65rem;
  padding:.6rem .7rem;
  font-size:.86rem;font-weight:600;
  color:var(--text);text-decoration:none;
  border-radius:calc(var(--radius) - .25rem);
  transition:background .2s,color .2s,transform .2s;
  position:relative;
}
.dropdown-item::after{
  content:'arrow_forward';font-family:'Material Icons Round';
  margin-left:auto;font-size:1rem;color:var(--primary);
  opacity:0;transform:translateX(-6px);
  transition:opacity .25s var(--ease-out),transform .25s var(--ease-out);
}
.dropdown-item:hover{background:var(--primary-bg);color:var(--primary-dark)}
.dropdown-item:hover::after{opacity:1;transform:translateX(0)}
.dark-mode .dropdown-item:hover{color:var(--sage-200)}

.dropdown-icon{
  width:34px;height:34px;border-radius:10px;flex-shrink:0;
  background:var(--primary-bg);color:var(--primary);
  display:flex;align-items:center;justify-content:center;
  transition:background .2s,color .2s,transform .25s var(--ease-spring);
}
.dropdown-icon .material-icons-round{font-size:1rem}
.dropdown-item:hover .dropdown-icon{
  background:var(--primary);color:#fff;transform:rotate(-6deg) scale(1.05);
}

.dropdown-footer{
  grid-column:1/-1;margin-top:.4rem;padding:.65rem .7rem;
  border-top:1px solid var(--border);
  display:flex;align-items:center;justify-content:center;
}
.dropdown-footer a{
  font-size:.8rem;font-weight:700;color:var(--primary);
  text-decoration:none;display:flex;align-items:center;gap:.3rem;
}
.dropdown-footer a:hover{gap:.55rem}
.dropdown-footer a .material-icons-round{font-size:.95rem;transition:transform .25s}

/* Header actions */
.header-actions{display:flex;align-items:center;gap:.45rem}
.social-icon{
  width:34px;height:34px;border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  color:var(--text-muted);text-decoration:none;
  transition:background .25s,color .25s,transform .25s;
}
.social-icon:hover{background:var(--primary-bg);color:var(--primary);transform:translateY(-2px)}
.social-icon svg{width:16px;height:16px;fill:currentColor}

.hdr-icon-btn{
  width:38px;height:38px;border-radius:50%;
  border:1px solid var(--border);background:transparent;
  cursor:pointer;display:flex;align-items:center;justify-content:center;
  color:var(--text-muted);transition:all .25s var(--ease-out);text-decoration:none;
}
.hdr-icon-btn:hover{
  background:var(--primary-bg);color:var(--primary);
  border-color:var(--primary);transform:translateY(-2px);
}
.dark-mode .hdr-icon-btn{border-color:var(--border-dk)}

.btn-cta-header{
  display:none;align-items:center;gap:.4rem;
  padding:.6rem 1.2rem;
  background:var(--primary);color:#fff;
  font-size:.85rem;font-weight:700;border-radius:99px;
  text-decoration:none;border:none;cursor:pointer;
  transition:all .3s var(--ease-out);
  box-shadow:0 6px 18px -6px rgba(90,150,124,.5);
  white-space:nowrap;position:relative;overflow:hidden;
}
.btn-cta-header::before{
  content:'';position:absolute;inset:0;
  background:linear-gradient(110deg,transparent 30%,rgba(255,255,255,.3) 45%,transparent 60%);
  transform:translateX(-100%);transition:transform .9s var(--ease-out);
}
.btn-cta-header:hover{
  background:var(--primary-dark);transform:translateY(-2px);
  box-shadow:0 12px 28px -8px rgba(90,150,124,.65);
}
.btn-cta-header:hover::before{transform:translateX(100%)}
.btn-cta-header .material-icons-round{font-size:.95rem}

/* Hamburger */
.hamburger{
  display:flex;flex-direction:column;justify-content:center;gap:5px;
  width:42px;height:42px;border:none;background:transparent;cursor:pointer;
  padding:10px;border-radius:12px;transition:background .2s;
}
.hamburger:hover{background:var(--primary-bg)}
.hamburger span{display:block;height:2px;border-radius:2px;background:var(--text);transition:all .35s var(--ease-spring);transform-origin:center}
.hamburger span:nth-child(1){width:100%}
.hamburger span:nth-child(2){width:65%;align-self:flex-end}
.hamburger span:nth-child(3){width:85%}
.hamburger.open span:nth-child(1){transform:translateY(7px) rotate(45deg);width:100%}
.hamburger.open span:nth-child(2){opacity:0;width:0}
.hamburger.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg);width:100%}
.dark-mode .hamburger span{background:var(--text-dk)}

/* Mobile nav */
.mobile-nav{
  display:none;position:fixed;inset:var(--header-h) 0 0 0;
  background:var(--surface);z-index:90;overflow-y:auto;
  padding:1.5rem;
  animation:slideDown .35s var(--ease-out);
}
.dark-mode .mobile-nav{background:var(--surface-dk)}
@keyframes slideDown{from{opacity:0;transform:translateY(-12px)}to{opacity:1;transform:translateY(0)}}
.mobile-nav.open{display:block}
.mobile-nav-link{
  display:flex;align-items:center;gap:.85rem;
  padding:.95rem .8rem;
  font-size:.98rem;font-weight:600;color:var(--text);
  text-decoration:none;border-radius:var(--radius);
  border-bottom:1px solid var(--border);
  transition:background .2s,color .2s,padding-left .25s var(--ease-out);
}
.mobile-nav-link:hover{background:var(--primary-bg);color:var(--primary);padding-left:1.2rem}
.mobile-nav-section{
  font-size:.66rem;font-weight:800;letter-spacing:.14em;text-transform:uppercase;
  color:var(--text-muted);padding:1.2rem .8rem .35rem;
}

/* Responsive */
@media(min-width:960px){
  .logo-text{display:block}
  .site-nav{display:flex}
  .hamburger{display:none}
  .btn-cta-header{display:inline-flex}
}
@media(max-width:1100px){
  .dropdown-menu.mega{min-width:520px;grid-template-columns:1fr 1fr}
  .mega-preview{display:none}
  .mega .dropdown-group-label{grid-column:1/-1}
}
@media(max-width:640px){
  .dropdown-menu.mega{min-width:280px;grid-template-columns:1fr}
}
/* ============================================================
   Sections — Hero, Modalidade, Números, Especialidades,
   Depoimentos, Agendamento, CTA
   ============================================================ */

/* ---- HERO full-bleed ---- */
.hero{
  position:relative;
  min-height:min(880px,100vh);
  padding:calc(var(--header-h) + 3rem) 0 5rem;
  overflow:hidden;
  isolation:isolate;
  display:flex;align-items:center;
}
.hero-bg{position:absolute;inset:0;z-index:-2}
.hero-bg img{
  width:100%;height:100%;object-fit:cover;
  transform:scale(1.05);
  animation:heroZoom 20s ease-out forwards;
}
@keyframes heroZoom{to{transform:scale(1.12)}}

.hero-overlay{
  position:absolute;inset:0;z-index:-1;
  background:
    radial-gradient(ellipse 80% 60% at 25% 40%,rgba(20,43,34,.55) 0%,rgba(20,43,34,.0) 60%),
    linear-gradient(180deg,rgba(20,43,34,.45) 0%,rgba(20,43,34,.7) 100%);
}

.hero-blobs{position:absolute;inset:0;z-index:-1;overflow:hidden;pointer-events:none}
.hero .blob-1{
  width:560px;height:560px;left:-140px;top:-200px;
  background:radial-gradient(circle,rgba(127,181,155,.55),transparent 70%);
  animation:blobDrift 22s ease-in-out infinite alternate;
}
.hero .blob-2{
  width:480px;height:480px;right:-80px;bottom:-160px;
  background:radial-gradient(circle,rgba(201,131,89,.45),transparent 70%);
  animation:blobDrift 26s ease-in-out infinite alternate-reverse;
}
.hero .blob-3{
  width:340px;height:340px;left:50%;top:60%;
  background:radial-gradient(circle,rgba(231,213,182,.35),transparent 70%);
  animation:blobDrift 18s ease-in-out infinite alternate;
}

.hero-grain{
  position:absolute;inset:0;z-index:0;pointer-events:none;
  opacity:.18;mix-blend-mode:overlay;
  background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2' stitchTiles='stitch'/%3E%3CfeColorMatrix values='0 0 0 0 1 0 0 0 0 1 0 0 0 0 1 0 0 0 0.7 0'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}

.hero-inner{
  position:relative;z-index:1;
  max-width:var(--container);margin:0 auto;padding:0 1.5rem;
  display:grid;grid-template-columns:1.1fr .9fr;gap:4rem;align-items:center;
  width:100%;
}
@media(max-width:960px){.hero-inner{grid-template-columns:1fr;gap:3rem}}

.hero-content{color:#fff;max-width:680px}
.hero-eyebrow{
  display:inline-flex;align-items:center;gap:.55rem;
  font-size:.72rem;font-weight:700;letter-spacing:.18em;text-transform:uppercase;
  color:#fff;
  padding:.5rem 1rem;
  background:rgba(255,255,255,.10);
  backdrop-filter:blur(10px);
  border:1px solid rgba(255,255,255,.18);
  border-radius:99px;
}
.hero-eyebrow .pulse{
  width:7px;height:7px;border-radius:50%;background:var(--terra-300);
  box-shadow:0 0 0 0 rgba(220,164,126,.7);
  animation:livePulse 2s ease-out infinite;
}
@keyframes livePulse{
  0%{box-shadow:0 0 0 0 rgba(220,164,126,.6)}
  70%{box-shadow:0 0 0 10px rgba(220,164,126,0)}
  100%{box-shadow:0 0 0 0 rgba(220,164,126,0)}
}

.hero-title{
  font-family:var(--font-display);
  font-size:clamp(2.6rem,6vw,5rem);
  font-weight:500;line-height:1.02;
  letter-spacing:-.02em;
  color:#fff;
  margin:1.5rem 0 1.5rem;
  text-wrap:balance;
}
.hero-title em{
  font-style:italic;font-weight:500;
  background:linear-gradient(110deg,var(--terra-200) 0%,var(--terra-300) 50%,var(--sand-100) 100%);
  background-size:200% 100%;
  -webkit-background-clip:text;background-clip:text;color:transparent;
  animation:gradShift 6s ease-in-out infinite alternate;
  position:relative;
}
@keyframes gradShift{0%{background-position:0% 50%}100%{background-position:100% 50%}}
.hero-title em::after{
  content:'';position:absolute;left:0;right:0;bottom:.05em;height:.08em;
  background:rgba(220,164,126,.45);border-radius:2px;
  transform-origin:left;
  animation:underlineGrow 1.4s 1.8s var(--ease-out) backwards;
}
@keyframes underlineGrow{from{transform:scaleX(0)}to{transform:scaleX(1)}}

.hero-desc{
  font-size:1.12rem;line-height:1.6;
  color:rgba(255,255,255,.85);
  max-width:54ch;text-wrap:pretty;
  margin:0 0 2rem;
}

.hero-actions{display:flex;flex-wrap:wrap;gap:.85rem;margin-bottom:3rem}
.hero-actions .btn-ghost{
  background:rgba(255,255,255,.10);color:#fff;
  border-color:rgba(255,255,255,.30);
  backdrop-filter:blur(10px);
}
.hero-actions .btn-ghost:hover{background:rgba(255,255,255,.18);color:#fff;border-color:rgba(255,255,255,.5)}

.hero-stats{
  display:grid;grid-template-columns:repeat(4,1fr);gap:1rem;
  padding-top:2rem;border-top:1px solid rgba(255,255,255,.18);
}
@media(max-width:540px){.hero-stats{grid-template-columns:repeat(2,1fr);gap:1.25rem 1rem}}
.stat-item{display:flex;flex-direction:column;gap:.2rem}
.stat-number{
  font-family:var(--font-display);
  font-size:clamp(1.6rem,3vw,2.2rem);
  font-weight:700;color:#fff;line-height:1;
}
.stat-label{font-size:.72rem;color:rgba(255,255,255,.7);font-weight:600;letter-spacing:.05em;text-transform:uppercase}

/* Hero visual */
.hero-visual{position:relative;display:flex;justify-content:center;align-items:center}
.hero-img-wrap{
  position:relative;width:100%;max-width:440px;aspect-ratio:4/5;
  border-radius:var(--radius-xl);overflow:hidden;
  box-shadow:0 30px 80px -20px rgba(0,0,0,.5);
  border:1px solid rgba(255,255,255,.15);
  transform:perspective(1200px) rotateY(-4deg) rotateX(2deg);
  transition:transform .6s var(--ease-out);
}
.hero-img-wrap:hover{transform:perspective(1200px) rotateY(-2deg) rotateX(1deg)}
.hero-img-wrap img{width:100%;height:100%;object-fit:cover;transform:scale(1.02)}
.hero-img-label{
  position:absolute;left:1.25rem;bottom:1.25rem;right:1.25rem;
  display:flex;align-items:center;gap:.5rem;
  padding:.7rem 1rem;
  font-size:.8rem;font-weight:700;color:var(--ink-700);
  background:rgba(255,255,255,.92);backdrop-filter:blur(12px);
  border-radius:99px;
  box-shadow:0 8px 24px -8px rgba(0,0,0,.25);
}
.hero-img-label .material-icons-round{color:var(--primary);font-size:1rem}

.hero-card{
  position:absolute;
  background:rgba(255,255,255,.96);backdrop-filter:blur(14px);
  border:1px solid rgba(255,255,255,.5);
  padding:.85rem 1.1rem;border-radius:var(--radius);
  display:flex;align-items:center;gap:.7rem;
  box-shadow:0 16px 40px -12px rgba(0,0,0,.3);
  color:var(--ink-700);
  animation:floatCard 6s ease-in-out infinite;
  z-index:1000;
}
@keyframes floatCard{0%,100%{transform:translateY(0)}50%{transform:translateY(-8px)}}
.hero-card-1{top:8%;left:-2rem;animation-delay:0s}
.hero-card-2{bottom:14%;right:-1.5rem;animation-delay:1.5s}
@media(max-width:540px){.hero-card-1{left:.5rem}.hero-card-2{right:.5rem}}

.card-dot{
  width:10px;height:10px;border-radius:50%;
  background:#22c55e;flex-shrink:0;
  box-shadow:0 0 0 0 rgba(34,197,94,.5);
  animation:livePulse 2s ease-out infinite;
}
.card-dot.yellow{background:var(--terra-400);box-shadow:0 0 0 0 rgba(201,131,89,.5)}

/* Scroll cue */
.hero-scroll-cue{
  position:absolute;bottom:1.5rem;left:50%;transform:translateX(-50%);
  z-index:1;color:rgba(255,255,255,.7);
  display:flex;flex-direction:column;align-items:center;gap:.4rem;
  font-size:.7rem;letter-spacing:.18em;text-transform:uppercase;font-weight:700;
}
.hero-scroll-cue .line{
  width:1.5px;height:38px;
  background:linear-gradient(180deg,rgba(255,255,255,.6),transparent);
  position:relative;overflow:hidden;
}
.hero-scroll-cue .line::after{
  content:'';position:absolute;top:-100%;left:0;right:0;height:50%;
  background:linear-gradient(180deg,transparent,#fff);
  animation:scrollDown 2.2s ease-in-out infinite;
}
@keyframes scrollDown{0%{top:-50%}100%{top:100%}}

/* ---- WhatsApp bar ---- */
.whatsapp-bar{
  background:linear-gradient(135deg,var(--sage-100) 0%,var(--sand-100) 100%);
  border-block:1px solid var(--border);
  position:relative;overflow:hidden;
}
.dark-mode .whatsapp-bar{
  background:linear-gradient(135deg,#1a221d 0%,#1f1c17 100%);
}
.whatsapp-bar::before{
  content:'';position:absolute;left:-10%;top:-50%;
  width:300px;height:300px;border-radius:50%;
  background:radial-gradient(circle,rgba(127,181,155,.25),transparent 70%);
  filter:blur(40px);
}
.whatsapp-bar-inner{
  position:relative;
  max-width:var(--container);margin:0 auto;padding:1.6rem 1.5rem;
  display:flex;align-items:center;justify-content:space-between;gap:1.5rem;flex-wrap:wrap;
}
.whatsapp-bar h3{font-family:var(--font-display);font-size:1.3rem;font-weight:600;margin:0;line-height:1.3}
.whatsapp-bar p{margin:.2rem 0 0;color:var(--text-muted);font-size:.92rem}

/* ---- MODALIDADE ---- */
.modalidade-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1.75rem}
@media(max-width:860px){.modalidade-grid{grid-template-columns:1fr}}

.modalidade-card{
  position:relative;
  background:var(--surface);
  border:1px solid var(--border);
  border-radius:var(--radius-xl);
  padding:2.25rem;
  display:flex;flex-direction:column;align-items:flex-start;gap:1.1rem;
  transition:transform .45s var(--ease-out),box-shadow .45s var(--ease-out),border-color .35s;
  overflow:hidden;
  isolation:isolate;
}
.modalidade-card::before{
  content:'';position:absolute;inset:0;z-index:-1;
  background:radial-gradient(circle at 100% 0%,var(--primary-bg) 0%,transparent 55%);
  opacity:0;transition:opacity .45s var(--ease-out);
}
.modalidade-card:hover{
  transform:translateY(-6px);
  box-shadow:var(--shadow-lg);
  border-color:rgba(127,181,155,.35);
}
.modalidade-card:hover::before{opacity:1}

.modalidade-icon{
  width:54px;height:54px;border-radius:16px;
  background:linear-gradient(135deg,var(--sage-200),var(--sage-300));
  color:var(--sage-700);
  display:flex;align-items:center;justify-content:center;
  box-shadow:0 8px 20px -6px rgba(127,181,155,.4),inset 0 1px 0 rgba(255,255,255,.5);
  transition:transform .4s var(--ease-spring);
}
.modalidade-card:hover .modalidade-icon{transform:rotate(-8deg) scale(1.05)}
.modalidade-icon .material-icons-round{font-size:1.5rem}

.modalidade-card.accent .modalidade-icon{
  background:linear-gradient(135deg,var(--terra-200),var(--terra-300));color:var(--terra-600);
  box-shadow:0 8px 20px -6px rgba(201,131,89,.4),inset 0 1px 0 rgba(255,255,255,.5);
}

.modalidade-card h3{
  font-family:var(--font-display);font-size:1.55rem;font-weight:600;
  margin:0;line-height:1.2;letter-spacing:-.005em;
}
.modalidade-card > p{margin:0;color:var(--text-muted);font-size:.98rem;line-height:1.55}

.modalidade-imgs{
  display:grid;grid-template-columns:1.4fr 1fr;gap:.6rem;width:100%;
  border-radius:var(--radius);overflow:hidden;
}
.modalidade-imgs img{
  width:100%;height:100%;object-fit:cover;aspect-ratio:4/3;
  border-radius:var(--radius);
  transition:transform .6s var(--ease-out);
}
.modalidade-card:hover .modalidade-imgs img{transform:scale(1.04)}
.modalidade-imgs img:nth-child(2){aspect-ratio:4/3}

.modalidade-img-placeholder{
  position:relative;width:100%;aspect-ratio:16/8;border-radius:var(--radius);
  background:linear-gradient(135deg,var(--sage-100),var(--sand-100));
  display:flex;align-items:center;justify-content:center;
  color:var(--primary);overflow:hidden;
}
.dark-mode .modalidade-img-placeholder{background:linear-gradient(135deg,#1f2620,#221f1a)}
.modalidade-img-placeholder .big{font-size:5rem;opacity:.18;position:absolute}
.modalidade-img-placeholder .pulse-icon{animation:floatCard 4s ease-in-out infinite}

.info-block{
  width:100%;background:var(--surface-2);border-radius:var(--radius);padding:1rem 1.1rem;
  border:1px solid var(--border);
}
.info-block-head{display:flex;align-items:center;gap:.5rem;margin-bottom:.5rem}
.info-block-head .material-icons-round{color:var(--primary);font-size:1rem}
.info-block-head strong{font-size:.72rem;text-transform:uppercase;letter-spacing:.1em;color:var(--text-muted);font-weight:800}
.info-block-rows{font-size:.92rem;color:var(--text);display:flex;flex-direction:column;gap:.3rem}

.bullet-list{display:flex;flex-direction:column;gap:.6rem;width:100%;margin:0;padding:0;list-style:none}
.bullet-list li{display:flex;align-items:center;gap:.6rem;font-size:.9rem;font-weight:600;color:var(--text)}
.bullet-list li .material-icons-round{color:var(--primary);font-size:1.1rem}

/* ---- NÚMEROS ---- */
.section-numbers{
  background:linear-gradient(135deg,var(--sage-700) 0%,var(--sage-800) 100%);
  color:#fff;position:relative;overflow:hidden;
  padding:5rem 0;
}
.dark-mode .section-numbers{background:linear-gradient(135deg,#1a2620 0%,#0f1611 100%)}
.section-numbers::before{
  content:'';position:absolute;inset:0;
  background-image:radial-gradient(circle at 20% 30%,rgba(220,164,126,.15) 0%,transparent 40%),
                   radial-gradient(circle at 80% 70%,rgba(127,181,155,.18) 0%,transparent 40%);
}
.section-numbers .section-inner{position:relative}
.numbers-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:2rem}
@media(max-width:768px){.numbers-grid{grid-template-columns:repeat(2,1fr);gap:2.5rem 1rem}}
.number-card{text-align:center;position:relative}
.number-card:not(:last-child)::after{
  content:'';position:absolute;right:-1rem;top:25%;height:50%;width:1px;
  background:rgba(255,255,255,.12);
}
@media(max-width:768px){.number-card:not(:last-child)::after{display:none}}
.number-card .num{
  font-family:var(--font-display);
  font-size:clamp(2.6rem,5vw,3.4rem);
  font-weight:700;color:#fff;line-height:1;display:block;
  letter-spacing:-.02em;
}
.number-card .num .accent-dot{color:var(--terra-300)}
.number-card .lbl{
  font-size:.74rem;font-weight:700;color:rgba(255,255,255,.7);
  letter-spacing:.14em;text-transform:uppercase;
  display:block;margin-top:.65rem;
}

/* ---- ESPECIALIDADES ---- */
.especialidades-grid{
  display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem;
}
@media(max-width:960px){.especialidades-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:560px){.especialidades-grid{grid-template-columns:1fr}}

.espec-card{
  background:var(--surface);
  border:1px solid var(--border);
  border-radius:var(--radius-lg);
  padding:1.75rem;
  transition:all .4s var(--ease-out);
  position:relative;overflow:hidden;isolation:isolate;
}
.espec-card::before{
  content:'';position:absolute;top:0;left:0;right:0;height:3px;
  background:linear-gradient(90deg,var(--primary),var(--accent));
  transform:scaleX(0);transform-origin:left;
  transition:transform .5s var(--ease-out);
}
.espec-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg);border-color:rgba(127,181,155,.3)}
.espec-card:hover::before{transform:scaleX(1)}

.espec-header{display:flex;align-items:center;gap:.85rem;margin-bottom:1rem}
.espec-icon{
  width:46px;height:46px;border-radius:12px;flex-shrink:0;
  background:var(--primary-bg);color:var(--primary);
  display:flex;align-items:center;justify-content:center;
  transition:transform .35s var(--ease-spring),background .3s,color .3s;
}
.espec-card:hover .espec-icon{transform:rotate(-6deg) scale(1.06);background:var(--primary);color:#fff}
.espec-icon .material-icons-round{font-size:1.3rem}
.espec-header h3{font-family:var(--font-display);font-size:1.18rem;font-weight:600;margin:0;line-height:1.25;letter-spacing:-.005em}

.espec-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:.45rem}
.espec-list li{
  font-size:.88rem;color:var(--text-muted);
  padding-left:1.1rem;position:relative;line-height:1.45;
}
.espec-list li::before{
  content:'';position:absolute;left:0;top:.55em;
  width:5px;height:5px;border-radius:50%;background:var(--primary);
  box-shadow:0 0 0 3px var(--primary-bg);
}

/* ---- DEPOIMENTOS ---- */
.depoimentos-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem}
@media(max-width:960px){.depoimentos-grid{grid-template-columns:1fr}}

.dep-card{
  position:relative;
  background:var(--surface);
  border:1px solid var(--border);
  border-radius:var(--radius-lg);
  padding:2rem 1.85rem 1.85rem;
  transition:all .4s var(--ease-out);
  overflow:hidden;
}
.dep-card:hover{transform:translateY(-3px);box-shadow:var(--shadow-lg)}
.dep-quote{
  font-family:var(--font-display);font-style:italic;
  font-size:5rem;line-height:.6;color:var(--primary);
  opacity:.18;position:absolute;top:1.4rem;right:1.4rem;
  transition:opacity .35s,transform .35s var(--ease-out);
}
.dep-card:hover .dep-quote{opacity:.32;transform:scale(1.06)}
.dep-texto{
  font-size:.98rem;line-height:1.65;color:var(--text);
  margin:0 0 1.4rem;text-wrap:pretty;position:relative;
}
.dep-footer{display:flex;align-items:center;gap:.8rem;padding-top:1.2rem;border-top:1px solid var(--border)}
.dep-avatar{
  width:44px;height:44px;border-radius:50%;flex-shrink:0;
  background:linear-gradient(135deg,var(--sage-300),var(--sage-500));color:#fff;
  display:flex;align-items:center;justify-content:center;
  font-weight:700;font-size:.95rem;
  box-shadow:0 6px 16px -6px rgba(127,181,155,.5);
}
.dep-name{font-weight:700;font-size:.92rem;color:var(--text)}
.dep-stars{color:var(--terra-400);font-size:.85rem;letter-spacing:.08em}

/* ---- AGENDAMENTO ---- */
.agendamento-grid{
  display:grid;grid-template-columns:1fr 1fr;gap:4rem;align-items:center;
}
@media(max-width:960px){.agendamento-grid{grid-template-columns:1fr;gap:3rem}}

.agend-info > p{font-size:1.02rem;color:var(--text-muted);margin:1rem 0 2rem;text-wrap:pretty;max-width:50ch}
.agend-benefits{list-style:none;display:flex;flex-direction:column;gap:.85rem;padding:0;margin:0}
.agend-benefits li{display:flex;align-items:center;gap:.85rem;font-size:.95rem;font-weight:600;color:var(--text)}
.agend-benefit-icon{
  width:40px;height:40px;border-radius:12px;flex-shrink:0;
  background:linear-gradient(135deg,var(--sage-100),var(--sage-200));color:var(--primary);
  display:flex;align-items:center;justify-content:center;
  border:1px solid rgba(127,181,155,.3);
  transition:transform .3s var(--ease-spring);
}
.agend-benefits li:hover .agend-benefit-icon{transform:rotate(-8deg) scale(1.06)}
.agend-benefit-icon .material-icons-round{font-size:1.15rem}

.agend-callout{
  margin-top:2rem;padding:1.25rem 1.4rem;
  background:linear-gradient(135deg,var(--sage-100),var(--sand-100));
  border-radius:var(--radius);
  border:1px solid rgba(127,181,155,.3);
  font-size:.92rem;font-weight:600;color:var(--sage-700);
}
.dark-mode .agend-callout{background:rgba(127,181,155,.08);color:var(--sage-200)}
.agend-callout a{color:inherit;font-weight:800;text-decoration:underline;text-decoration-color:rgba(127,181,155,.4);text-underline-offset:3px}

.form-card{
  background:var(--surface);
  border:1px solid var(--border);
  border-radius:var(--radius-xl);
  padding:2.4rem;
  box-shadow:var(--shadow-lg);
  position:relative;overflow:hidden;
}
.form-card::before{
  content:'';position:absolute;top:0;left:0;right:0;height:4px;
  background:linear-gradient(90deg,var(--primary),var(--accent),var(--primary));
  background-size:200% 100%;
  animation:gradShift 4s ease-in-out infinite alternate;
}
.form-card h3{
  font-family:var(--font-display);font-size:1.4rem;font-weight:600;
  color:var(--text);margin:0 0 1.6rem;display:flex;align-items:center;gap:.55rem;
}
.form-card h3 .material-icons-round{color:var(--primary);font-size:1.4rem}

.radio-group{display:flex;gap:.6rem}
.radio-opt{
  flex:1;display:flex;align-items:center;justify-content:center;gap:.45rem;
  padding:.75rem;
  border:1.5px solid var(--border);border-radius:var(--radius);
  cursor:pointer;font-size:.88rem;font-weight:700;color:var(--text-muted);
  transition:all .25s var(--ease-out);user-select:none;
  background:var(--bg);
}
.dark-mode .radio-opt{background:var(--surface-2-dk)}
.radio-opt input{display:none}
.radio-opt .material-icons-round{font-size:1.05rem}
.radio-opt:hover{border-color:var(--primary);color:var(--primary)}
.radio-opt.selected{
  border-color:var(--primary);background:var(--primary-bg);color:var(--primary-dark);
  box-shadow:0 0 0 4px rgba(127,181,155,.12);
}

/* ---- CTA FINAL ---- */
.cta-section{
  background:
    radial-gradient(ellipse at 30% 20%,rgba(220,164,126,.18) 0%,transparent 50%),
    radial-gradient(ellipse at 70% 80%,rgba(127,181,155,.18) 0%,transparent 50%),
    linear-gradient(135deg,var(--sage-800) 0%,var(--ink-800) 100%);
  color:#fff;position:relative;overflow:hidden;
}
.cta-section::before{
  content:'';position:absolute;inset:0;
  background-image:radial-gradient(circle,rgba(255,255,255,.04) 1px,transparent 1.5px);
  background-size:32px 32px;
  mask-image:radial-gradient(ellipse at center,black 30%,transparent 80%);
}
.cta-inner{
  position:relative;
  max-width:800px;margin:0 auto;padding:0 1.5rem;text-align:center;
}
.cta-inner h2{
  font-family:var(--font-display);
  font-size:clamp(2.2rem,5vw,3.8rem);
  font-weight:500;line-height:1.05;letter-spacing:-.015em;
  color:#fff;margin:0 0 1.25rem;text-wrap:balance;
}
.cta-inner h2 em{
  font-style:italic;font-weight:500;
  background:linear-gradient(110deg,var(--terra-200),var(--terra-300));
  -webkit-background-clip:text;background-clip:text;color:transparent;
}
.cta-inner p{font-size:1.1rem;color:rgba(255,255,255,.78);max-width:55ch;margin:0 auto 2.4rem;text-wrap:pretty}
.cta-buttons{display:flex;flex-wrap:wrap;justify-content:center;gap:.85rem}

/* ---- Footer ---- */
.site-footer{background:var(--ink-800);color:rgba(255,255,255,.75);padding:5rem 0 0}
.footer-grid{max-width:var(--container);margin:0 auto;padding:0 1.5rem;display:grid;grid-template-columns:1.6fr 1fr 1fr 1.4fr;gap:3.5rem}
@media(max-width:960px){.footer-grid{grid-template-columns:1fr 1fr;gap:2.5rem}}
@media(max-width:640px){.footer-grid{grid-template-columns:1fr}}
.footer-brand .logo{margin-bottom:1rem}
.footer-brand .logo-text strong{color:rgba(255,255,255,.9)}
.footer-brand .logo-text span{color:rgba(255,255,255,.45)}
.footer-brand > p{font-size:.875rem;line-height:1.75;color:rgba(255,255,255,.55);max-width:28ch;margin-top:.75rem}
.footer-socials{display:flex;gap:.5rem;margin-top:1.25rem}
.footer-social{width:36px;height:36px;border-radius:50%;background:rgba(255,255,255,.08);display:flex;align-items:center;justify-content:center;color:rgba(255,255,255,.6);transition:all .25s;text-decoration:none}
.footer-social:hover{background:var(--primary);color:#fff;transform:translateY(-3px)}
.footer-social svg{width:15px;height:15px;fill:currentColor}
.footer-col h4{font-family:var(--font-display);font-size:.78rem;font-weight:600;letter-spacing:.14em;text-transform:uppercase;color:rgba(255,255,255,.4);margin-bottom:1.1rem}
.footer-links{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:.55rem}
.footer-links a{font-size:.88rem;color:rgba(255,255,255,.6);text-decoration:none;transition:color .2s,padding-left .2s;display:inline-block}
.footer-links a:hover{color:#fff;padding-left:4px}
.contact-item{display:flex;align-items:flex-start;gap:.65rem;font-size:.85rem;margin-bottom:.7rem;color:rgba(255,255,255,.6)}
.contact-item .material-icons-round{font-size:1rem;color:var(--sage-300);flex-shrink:0;margin-top:.1rem}
.contact-item a{color:inherit;text-decoration:none;transition:color .2s}
.contact-item a:hover{color:#fff}
.footer-bottom{max-width:var(--container);margin:3rem auto 0;padding:1.4rem 1.5rem;border-top:1px solid rgba(255,255,255,.07);display:flex;align-items:center;justify-content:space-between;gap:1rem;flex-wrap:wrap}
.footer-bottom p{font-size:.8rem;color:rgba(255,255,255,.35);margin:0}
.footer-legal{display:flex;gap:1.25rem}
.footer-legal a{font-size:.78rem;color:rgba(255,255,255,.35);text-decoration:none;transition:color .2s}
.footer-legal a:hover{color:rgba(255,255,255,.7)}