/* ============================================================
   SITE Dra. Carla Prado — camada "marca quente"
   Paleta bege / dourado / marrom (identidade do consultório),
   convivendo com o showcase emerald de neuromodulação.
   ============================================================ */
:root{
  --warm-bg:    #ece4d8;
  --warm-bg-2:  #e3d9c8;
  --warm-card:  #f6f1e8;
  --warm-ink:   #2c2723;
  --warm-soft:  #5d5346;
  --taupe:      #8a7559;
  --brown:      #6f5a42;
  --gold:       #c2a25e;
  --gold-deep:  #a8853f;
  --warm-line:  rgba(80,64,46,0.16);
  --font-script:'Cormorant Garamond', Georgia, serif;
}

/* ---------- NAV fixa ---------- */
.nav{
  position:fixed; top:18px; left:50%; transform:translateX(-50%); z-index:120;
  width:min(1180px, calc(100% - 36px));
  display:flex; align-items:center; justify-content:space-between;
  padding:9px 9px 9px 26px; border-radius:999px;
  background:rgba(255,255,255,0.55);
  -webkit-backdrop-filter:blur(16px); backdrop-filter:blur(16px);
  border:1px solid rgba(255,255,255,0.6);
  box-shadow:0 14px 40px -20px rgba(44,39,35,0.45);
  transition:background .5s ease, box-shadow .5s ease, top .5s ease, border-color .5s ease;
}
.nav.scrolled{
  top:10px;
  background:rgba(255,255,255,0.85);
  box-shadow:0 16px 44px -22px rgba(44,39,35,0.55);
  border-color:rgba(194,162,94,0.3);
}
.nav__brand{ display:flex; align-items:center; gap:13px; text-decoration:none; }
.nav__logo{ height:44px; width:auto; transition:height .5s ease; }
.nav.scrolled .nav__logo{ height:42px; }
.nav__links{ display:flex; align-items:center; gap:clamp(14px,1.8vw,30px); }
.nav__link{
  font-family:var(--font-body); font-size:14.5px; font-weight:500; letter-spacing:.01em;
  color:var(--warm-ink); text-decoration:none; position:relative; padding:6px 2px;
  transition:color .35s ease;
}
.nav__link:hover{ color:var(--gold-deep); }
.nav__link::after{ content:""; position:absolute; left:0; right:100%; bottom:0; height:1.5px; background:var(--gold-deep); transition:right .4s var(--ease,ease); }
.nav__link:hover::after, .nav__link.active::after{ right:0; }
.nav__wa{
  display:inline-flex; align-items:center; gap:9px; text-decoration:none;
  font-family:var(--font-body); font-size:14px; font-weight:600; letter-spacing:.01em;
  color:#fff; padding:12px 22px; border-radius:999px;
  background:linear-gradient(135deg,#2bb673,#1d9e63);
  box-shadow:0 10px 26px -12px rgba(29,158,99,0.8);
  transition:transform .35s var(--ease,ease), filter .35s ease;
}
.nav__wa:hover{ transform:translateY(-2px); filter:brightness(1.06); }
.nav__wa svg{ width:17px; height:17px; fill:currentColor; }
.nav__burger{ display:none; flex-direction:column; gap:5px; background:none; border:none; cursor:pointer; padding:8px; }
.nav__burger span{ width:24px; height:2px; background:var(--warm-ink); transition:background .4s; }
.nav.scrolled .nav__burger span{ background:var(--warm-ink); }

/* ---------- Seções quentes ---------- */
.sec--warm{ background:var(--warm-bg); color:var(--warm-ink); }
.sec--warm-2{ background:var(--warm-bg-2); color:var(--warm-ink); }
.sec--warm .lead, .sec--warm-2 .lead{ color:var(--warm-soft); }
.sec--warm .body-text, .sec--warm-2 .body-text{ color:rgba(44,39,35,0.78); }
.sec--warm .body-text strong, .sec--warm .lead strong,
.sec--warm-2 .body-text strong, .sec--warm-2 .lead strong{ color:var(--gold-deep); }
.sec--warm .accent, .sec--warm-2 .accent{ color:var(--gold-deep); }

/* blends para as seções quentes */
.sec--warm + .sec--dark::before, .sec--warm + .sec--deep::before,
.sec--warm-2 + .sec--dark::before, .sec--warm-2 + .sec--deep::before{ background:linear-gradient(180deg, var(--warm-bg) 0%, transparent 100%); }
.sec--dark + .sec--warm::before, .sec--deep + .sec--warm::before,
.sec--dark + .sec--warm-2::before, .sec--deep + .sec--warm-2::before{ background:linear-gradient(180deg, var(--dark-b,#061f1c) 0%, transparent 100%); }

/* título “script” da marca */
.script-kicker{ font-family:var(--font-script); font-style:italic; font-weight:600; font-size:clamp(30px,3.4vw,46px); color:var(--brown); line-height:1; }
.warm-rule{ width:58px; height:2px; background:var(--brown); margin:18px 0 30px; }
.warm-rule--center{ margin-left:auto; margin-right:auto; }
.warm-title{ font-family:var(--font-display); font-weight:600; line-height:1.04; letter-spacing:-0.005em; font-size:clamp(34px,4.4vw,62px); color:var(--warm-ink); text-wrap:balance; }
.warm-kick{ display:inline-flex; align-items:center; gap:12px; font-size:13px; font-weight:600; letter-spacing:.24em; text-transform:uppercase; color:var(--gold-deep); }
.warm-kick::before{ content:""; width:30px; height:1px; background:currentColor; opacity:.6; }

/* ---------- SOBRE ---------- */
.about-grid{ display:grid; grid-template-columns:1.08fr .92fr; gap:clamp(40px,5.5vw,90px); align-items:center; }
.about-portrait{ position:relative; border-radius:26px; overflow:hidden; box-shadow:0 50px 100px -46px rgba(44,30,12,0.6); aspect-ratio:4/3.4; order:2; }
.about-portrait img{ width:100%; height:100%; object-fit:cover; display:block; }
.about-portrait::after{ content:""; position:absolute; inset:0; border-radius:26px; box-shadow:inset 0 0 0 1px rgba(194,162,94,0.5); pointer-events:none; }
.creds{ list-style:none; margin:30px 0 0; padding:0; display:flex; flex-direction:column; gap:14px; }
.creds li{ display:flex; gap:14px; font-size:17px; font-weight:400; line-height:1.45; color:var(--warm-soft); }
.creds li svg{ flex:none; width:20px; height:20px; margin-top:2px; stroke:var(--gold-deep); fill:none; stroke-width:1.7; }
.crm{ display:inline-flex; gap:18px; margin-top:30px; padding:14px 22px; border:1px solid var(--warm-line); border-radius:14px; background:var(--warm-card); font-size:15px; font-weight:600; letter-spacing:.04em; color:var(--brown); }
.crm b{ color:var(--warm-ink); }

/* faixa "novo espaço" */
.newspace{ margin-top:clamp(40px,5vw,64px); display:grid; grid-template-columns:auto 1fr auto; gap:clamp(20px,3vw,40px); align-items:center; background:linear-gradient(120deg,var(--brown),#5a4733); color:#f3ece0; border-radius:22px; padding:clamp(28px,3.4vw,44px); box-shadow:0 36px 70px -44px rgba(44,30,12,0.6); }
.newspace__badge{ font-family:var(--font-script); font-style:italic; font-weight:600; font-size:clamp(40px,5vw,68px); color:var(--gold); line-height:.9; }
.newspace h3{ font-family:var(--font-display); font-weight:600; font-size:clamp(24px,2.6vw,34px); margin:0 0 8px; }
.newspace p{ margin:0; font-size:16px; font-weight:300; line-height:1.55; color:rgba(243,236,224,0.84); max-width:52ch; }

/* ---------- SERVIÇOS ---------- */
.serv-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:clamp(20px,2.4vw,30px); margin-top:clamp(44px,5vw,68px); }
.serv{ position:relative; background:var(--warm-card); border:1px solid var(--warm-line); border-radius:22px; padding:40px 34px 36px; overflow:hidden; transition:transform .5s var(--ease,ease), box-shadow .5s var(--ease,ease); box-shadow:0 24px 50px -42px rgba(44,30,12,0.4); }
.serv:hover{ transform:translateY(-6px); box-shadow:0 44px 80px -42px rgba(44,30,12,0.5); }
.serv__ic{ width:60px; height:60px; border-radius:16px; display:grid; place-items:center; margin-bottom:26px; background:linear-gradient(140deg,#f0e6d2,#e3d2ad); box-shadow:inset 0 0 0 1px rgba(194,162,94,0.4); }
.serv__ic svg{ width:30px; height:30px; stroke:var(--gold-deep); fill:none; stroke-width:1.6; }
.serv h3{ font-family:var(--font-display); font-weight:600; font-size:27px; margin:0 0 12px; line-height:1.06; color:var(--warm-ink); }
.serv p{ font-size:15.5px; font-weight:300; line-height:1.62; color:var(--warm-soft); margin:0; }
.serv__list{ list-style:none; margin:14px 0 0; padding:0; display:flex; flex-direction:column; gap:7px; }
.serv__list li{ font-size:15px; color:var(--warm-soft); display:flex; gap:9px; }
.serv__list li::before{ content:""; flex:none; width:5px; height:5px; margin-top:9px; border-radius:50%; background:var(--gold-deep); }
.serv--wide{ grid-column:span 3; display:grid; grid-template-columns:auto 1fr; gap:clamp(28px,4vw,56px); align-items:center; background:linear-gradient(120deg,#0e3a34,#0a2e2a); border:none; color:#e9f3f0; }
.serv--wide .serv__ic{ background:rgba(127,217,196,0.12); box-shadow:inset 0 0 0 1px rgba(127,217,196,0.3); }
.serv--wide .serv__ic svg{ stroke:var(--emerald-soft,#7fd9c4); }
.serv--wide h3{ color:#fff; }
.serv--wide p{ color:rgba(233,243,240,0.8); }
.tech-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:14px; margin-top:6px; }
.tech{ background:rgba(127,217,196,0.07); border:1px solid rgba(127,217,196,0.22); border-radius:14px; padding:20px 20px; }
.tech h4{ font-family:var(--font-body); font-size:15px; font-weight:600; margin:0 0 6px; color:var(--emerald-soft,#7fd9c4); letter-spacing:.04em; }
.tech span{ font-size:13px; font-weight:700; letter-spacing:.12em; color:rgba(233,243,240,0.5); }
.tech p{ font-size:13.5px; font-weight:300; line-height:1.5; color:rgba(233,243,240,0.72); margin:8px 0 0; }

/* ---------- CONTATO ---------- */
.contact-grid{ display:grid; grid-template-columns:1fr 1fr; gap:clamp(36px,4.5vw,72px); align-items:start; }
.contact-info{ display:flex; flex-direction:column; gap:22px; }
.cinfo{ display:flex; gap:16px; align-items:flex-start; }
.cinfo__ic{ flex:none; width:44px; height:44px; border-radius:12px; display:grid; place-items:center; background:var(--warm-card); border:1px solid var(--warm-line); }
.cinfo__ic svg{ width:20px; height:20px; stroke:var(--gold-deep); fill:none; stroke-width:1.7; }
.cinfo h4{ font-size:13px; letter-spacing:.14em; text-transform:uppercase; color:var(--gold-deep); margin:0 0 4px; font-weight:700; }
.cinfo p, .cinfo a{ font-size:16px; font-weight:300; line-height:1.5; color:var(--warm-ink); text-decoration:none; margin:0; }
.cinfo a:hover{ color:var(--gold-deep); }
.map-embed{ margin-top:8px; border-radius:18px; overflow:hidden; border:1px solid var(--warm-line); box-shadow:0 30px 60px -44px rgba(44,30,12,0.5); }
.map-embed iframe{ display:block; width:100%; height:300px; border:0; }
.cform{ background:var(--warm-card); border:1px solid var(--warm-line); border-radius:22px; padding:clamp(30px,3.4vw,44px); box-shadow:0 30px 60px -46px rgba(44,30,12,0.45); }
.cform label{ display:block; font-size:13px; font-weight:600; letter-spacing:.06em; color:var(--warm-soft); margin:0 0 7px; }
.cform .field{ margin-bottom:20px; }
.cform input, .cform textarea{ width:100%; font-family:var(--font-body); font-size:16px; font-weight:300; color:var(--warm-ink); background:#fff; border:1px solid var(--warm-line); border-radius:12px; padding:14px 16px; transition:border-color .3s, box-shadow .3s; }
.cform input:focus, .cform textarea:focus{ outline:none; border-color:var(--gold-deep); box-shadow:0 0 0 3px rgba(194,162,94,0.18); }
.cform textarea{ resize:vertical; min-height:120px; }
.cform__actions{ display:flex; gap:14px; flex-wrap:wrap; margin-top:4px; }
.btn-brown{ flex:1; min-width:180px; appearance:none; border:none; cursor:pointer; font-family:var(--font-body); font-weight:600; font-size:16px; letter-spacing:.04em; color:#f3ece0; background:linear-gradient(135deg,var(--brown),#5a4733); padding:17px 28px; border-radius:12px; transition:transform .35s var(--ease,ease), filter .35s; }
.btn-brown:hover{ transform:translateY(-2px); filter:brightness(1.08); }
.btn-wa{ display:inline-flex; align-items:center; justify-content:center; gap:10px; flex:1; min-width:180px; text-decoration:none; font-family:var(--font-body); font-weight:600; font-size:16px; color:#fff; background:linear-gradient(135deg,#2bb673,#1d9e63); padding:17px 28px; border-radius:12px; transition:transform .35s var(--ease,ease), filter .35s; }
.btn-wa:hover{ transform:translateY(-2px); filter:brightness(1.06); }
.btn-wa svg{ width:18px; height:18px; fill:currentColor; }

/* ---------- WhatsApp flutuante ---------- */
.page .sec{ scroll-margin-top:74px; }

/* ============================================================
   FRASE / MOTTO animado (caligrafia)
   ============================================================ */
.motto{ position:relative; overflow:hidden; text-align:center;
  background:
    radial-gradient(60% 90% at 50% 0%, rgba(194,162,94,0.16), transparent 60%),
    linear-gradient(180deg, #efe8dc, #e7ddcc); }
.motto__eyebrow{ display:inline-flex; align-items:center; gap:12px; font-size:12px; font-weight:600; letter-spacing:.3em; text-transform:uppercase; color:var(--gold-deep); margin-bottom:28px; opacity:0; transform:translateY(14px); transition:opacity .9s var(--ease,ease), transform .9s var(--ease,ease); }
.motto.in .motto__eyebrow{ opacity:1; transform:none; }
.motto__eyebrow::before, .motto__eyebrow::after{ content:""; width:34px; height:1px; background:currentColor; opacity:.55; }
.motto__phrase{ font-family:'Dancing Script', cursive; font-weight:600; color:var(--brown);
  font-size:clamp(40px,6.5vw,92px); line-height:1.2; letter-spacing:.005em; }
.motto__phrase .w{ display:inline-block; opacity:0; transform:translateY(24px) rotate(-2deg); filter:blur(4px);
  transition:opacity .7s var(--ease,ease), transform .7s var(--ease,ease), filter .7s var(--ease,ease); }
.motto.in .motto__phrase .w{ opacity:1; transform:none; filter:none; }
.motto__phrase .w:nth-child(1){ transition-delay:.15s; }
.motto__phrase .w:nth-child(2){ transition-delay:.30s; }
.motto__phrase .w:nth-child(3){ transition-delay:.45s; }
.motto__phrase .w:nth-child(4){ transition-delay:.60s; }
.motto__phrase .w:nth-child(5){ transition-delay:.75s; }
.motto__phrase .w:nth-child(6){ transition-delay:.90s; }

/* Acessibilidade: quem prefere menos movimento vê tudo imediatamente */
@media (prefers-reduced-motion:reduce){
  .motto__phrase .w{ opacity:1; transform:none; filter:none; }
  .motto__eyebrow, .motto__sign{ opacity:1; transform:none; }
  .motto__line{ width:min(300px,60%); }
  .sheen{ animation:none; }
}
.motto__dots{ opacity:0; transition:opacity .6s ease 1.4s; }
.motto.in .motto__dots{ opacity:1; animation:mottoDots 1.6s ease-in-out 1.6s infinite; }
@keyframes mottoDots{ 0%,100%{ opacity:.4; } 50%{ opacity:1; } }
.motto__line{ width:0; height:2px; margin:34px auto 0; background:linear-gradient(90deg, transparent, var(--gold-deep), transparent); transition:width 1.1s var(--ease,ease) .9s; }
.motto.in .motto__line{ width:min(300px,60%); }
.motto__sign{ margin-top:22px; font-size:14px; letter-spacing:.16em; text-transform:uppercase; color:var(--warm-soft); opacity:0; transition:opacity .8s ease 1.2s; }
.motto.in .motto__sign{ opacity:1; }

/* vida nos títulos: brilho dourado sutil percorrendo os destaques */
.sheen{ background:linear-gradient(100deg, currentColor 0%, currentColor 42%, #e7cd96 50%, currentColor 58%, currentColor 100%);
  background-size:220% 100%; -webkit-background-clip:text; background-clip:text; -webkit-text-fill-color:transparent;
  animation:sheenMove 6.5s ease-in-out infinite; }
@keyframes sheenMove{ 0%{ background-position:120% 0; } 55%,100%{ background-position:-20% 0; } }

/* ---------- WhatsApp flutuante ---------- */

/* ============================================================
   HOME · HERO estilo "vitrine" (texto no topo + foto emergindo)
   ============================================================ */
.home-hero{ position:relative; min-height:100vh; display:flex; flex-direction:column; align-items:center;
  overflow:hidden; padding:clamp(120px,15vh,170px) clamp(20px,5vw,48px) 0; }
.home-hero__bg{ position:absolute; inset:0; z-index:0; pointer-events:none;
  background:
    radial-gradient(70% 60% at 50% 116%, rgba(245,238,226,0.9), transparent 60%),
    linear-gradient(178deg, #d9c39a 0%, #e7dcc6 38%, #f0e8da 70%, #f4efe6 100%); }
.home-hero__bg::before{ content:""; position:absolute; inset:-10%; z-index:0;
  background:
    radial-gradient(42% 38% at 50% 2%, rgba(168,133,63,0.40), transparent 70%),
    radial-gradient(38% 34% at 84% 14%, rgba(194,162,94,0.38), transparent 70%),
    radial-gradient(46% 42% at 12% 26%, rgba(111,90,66,0.24), transparent 72%);
  animation:heroGlow 16s ease-in-out infinite alternate; }
.home-hero__bg::after{ content:""; position:absolute; left:0; right:0; bottom:0; height:38%;
  background:linear-gradient(180deg, transparent, var(--warm-bg) 96%); }
@keyframes heroGlow{
  0%{ transform:translate3d(0,0,0) scale(1); opacity:.92; }
  50%{ transform:translate3d(-2.5%,1.5%,0) scale(1.06); opacity:1; }
  100%{ transform:translate3d(2.5%,-1%,0) scale(1.03); opacity:.95; }
}
/* Split: texto esquerda, foto direita */
.home-hero__split{ position:relative; z-index:3; width:100%; max-width:1240px; margin:0 auto;
  display:grid; grid-template-columns:1.1fr .9fr; gap:clamp(32px,4vw,64px); align-items:center; }
.home-hero__text{ text-align:left; }
.home-hero__motto{ font-family:'Dancing Script', cursive; font-weight:600; font-size:clamp(26px,3.2vw,44px);
  color:var(--gold-deep); margin-bottom:18px; opacity:0; transform:translateY(14px);
  animation:heroIn .9s var(--ease,ease) .15s forwards; }
.home-hero__title{ font-family:var(--font-display); font-weight:600; line-height:1.04; letter-spacing:-0.015em;
  font-size:clamp(38px,5.4vw,72px); color:var(--warm-ink); text-wrap:balance;
  opacity:0; transform:translateY(20px); animation:heroIn 1s var(--ease,ease) .3s forwards; }
.home-hero__title em{ font-style:italic; color:var(--brown); }
.home-hero__lead{ font-size:clamp(17px,1.4vw,21px); font-weight:300; line-height:1.6; color:var(--warm-soft);
  max-width:52ch; margin-top:22px; opacity:0; transform:translateY(18px);
  animation:heroIn 1s var(--ease,ease) .5s forwards; }
.home-hero__cta{ display:flex; flex-wrap:wrap; gap:14px; margin-top:32px;
  opacity:0; transform:translateY(16px); animation:heroIn 1s var(--ease,ease) .68s forwards; }
.btn-gold{ display:inline-flex; align-items:center; gap:11px; text-decoration:none; font-family:var(--font-body);
  font-weight:600; font-size:16px; color:#fff; padding:17px 32px; border-radius:999px;
  background:linear-gradient(135deg,var(--gold),var(--gold-deep) 90%);
  box-shadow:0 18px 40px -16px rgba(168,133,63,0.8); transition:transform .35s var(--ease,ease), filter .35s; }
.btn-gold:hover{ transform:translateY(-2px); filter:brightness(1.06); }
.btn-gold .a{ transition:transform .35s var(--ease,ease); }
.btn-gold:hover .a{ transform:translateX(4px); }
.btn-ghost{ display:inline-flex; align-items:center; gap:10px; text-decoration:none; font-family:var(--font-body);
  font-weight:600; font-size:16px; color:var(--brown); padding:17px 30px; border-radius:999px;
  background:rgba(255,255,255,0.55); border:1px solid rgba(111,90,66,0.28);
  -webkit-backdrop-filter:blur(6px); backdrop-filter:blur(6px); transition:background .35s, transform .35s var(--ease,ease); }
.btn-ghost:hover{ background:rgba(255,255,255,0.9); transform:translateY(-2px); }
.home-hero__chips{ display:flex; flex-wrap:wrap; gap:10px 24px; margin-top:28px;
  opacity:0; animation:heroIn 1s var(--ease,ease) .85s forwards; }
.hchip{ display:flex; align-items:center; gap:9px; font-size:14px; font-weight:500; color:var(--warm-soft); }
.hchip svg{ width:18px; height:18px; stroke:var(--gold-deep); fill:none; stroke-width:1.8; flex:none; }
.hchip b{ color:var(--warm-ink); font-weight:600; }
.home-hero__figure{ position:relative; z-index:2; flex:1; display:flex; align-items:flex-end; justify-content:center; align-self:stretch;
  opacity:0; transform:translateY(40px); animation:heroFig 1.2s var(--ease,ease) .6s forwards; }
.home-hero__figure img{ width:100%; max-width:520px; height:auto; display:block;
  filter:drop-shadow(0 40px 60px rgba(44,30,12,0.28)); }
.home-hero__scroll{ position:absolute; left:50%; bottom:20px; transform:translateX(-50%); z-index:4;
  width:26px; height:42px; border:1.6px solid rgba(111,90,66,0.5); border-radius:999px; }
.home-hero__scroll span{ position:absolute; left:50%; top:8px; width:4px; height:8px; margin-left:-2px;
  border-radius:999px; background:var(--gold-deep); animation:scrollDot 5.5s cubic-bezier(.45,0,.55,1) infinite; }
@keyframes heroIn{ to{ opacity:1; transform:none; } }
@keyframes heroFig{ to{ opacity:1; transform:none; } }
@keyframes scrollDot{
  0%   { opacity:0; transform:translateY(0); }
  18%  { opacity:1; transform:translateY(0); }
  72%  { opacity:0.6; transform:translateY(13px); }
  88%  { opacity:0; transform:translateY(14px); }
  100% { opacity:0; transform:translateY(14px); }
}
@media (max-width:860px){
  .home-hero__split{ grid-template-columns:1fr; text-align:center; }
  .home-hero__text{ order:1; text-align:center; }
  .home-hero__figure{ order:2; max-width:420px; margin:0 auto; }
  .home-hero__chips{ justify-content:center; }
  .home-hero__cta{ justify-content:center; }
}
@media (prefers-reduced-motion:reduce){
  .home-hero__motto,.home-hero__title,.home-hero__lead,.home-hero__cta,.home-hero__chips,.home-hero__figure{ opacity:1; transform:none; animation:none; }
  .home-hero__bg::before{ animation:none; }
}

/* ============================================================
   HOME · Destaque do Espaço de Neuromodulação (vitrine IG)
   ============================================================ */
.neuro-spot{ position:relative; background:radial-gradient(120% 110% at 80% 0%, #11423b, #0a2e2a 55%, #061f1c 100%); color:#e9f3f0; overflow:hidden; }
.neuro-spot .wrap{ position:relative; z-index:2; }
.spot-head{ display:grid; grid-template-columns:1.1fr .9fr; gap:clamp(24px,4vw,64px); align-items:end; margin-bottom:clamp(40px,5vw,60px); }
.spot-head h2{ font-family:var(--font-display); font-weight:600; font-size:clamp(36px,4.6vw,68px); line-height:1.07; letter-spacing:-0.01em; text-wrap:balance; }
.spot-head .accent{ color:var(--emerald-soft); }
.spot-head p{ font-size:clamp(16px,1.2vw,19px); font-weight:300; line-height:1.62; color:rgba(233,243,240,0.82); }
.vitrine{ display:grid; grid-template-columns:repeat(4,1fr); grid-auto-rows:200px; gap:16px; }
.vitrine--equal{ grid-template-columns:repeat(3,1fr); grid-auto-rows:320px; }
.reels-row{ display:grid; grid-template-columns:repeat(3,1fr); gap:18px; margin-top:clamp(28px,3.5vw,44px); align-items:start; }
.reels-row .instagram-media{ margin:0 auto !important; min-width:0 !important; width:100% !important; }
.reels-head{ display:flex; align-items:center; gap:13px; margin-top:clamp(36px,4.5vw,56px); margin-bottom:6px; font-size:13px; font-weight:600; letter-spacing:.2em; text-transform:uppercase; color:var(--emerald-soft); }
.reels-head svg{ width:18px; height:18px; stroke:currentColor; fill:none; stroke-width:1.8; }
.reels-head .ln{ flex:1; height:1px; background:linear-gradient(90deg, rgba(127,217,196,0.35), transparent); }
@media (max-width:860px){ .reels-row{ grid-template-columns:1fr 1fr; } }
@media (max-width:560px){ .reels-row{ grid-template-columns:1fr; } }
.vtile{ position:relative; border-radius:18px; overflow:hidden; background:rgba(127,217,196,0.06); border:1px solid rgba(127,217,196,0.18); }
.vtile--video{ grid-column:span 2; grid-row:span 2; }
.vtile--tall{ grid-row:span 2; }
.vtile--wide{ grid-column:span 2; }
.vtile image-slot{ width:100%; height:100%; display:block; }
.vtile__cap{ position:absolute; left:0; right:0; bottom:0; z-index:3; padding:16px 18px; background:linear-gradient(0deg, rgba(6,31,28,0.85), transparent); font-size:13px; font-weight:500; color:#eaf6f2; pointer-events:none; }
.ig-embed{ position:relative; width:100%; height:100%; display:flex; flex-direction:column; align-items:center; justify-content:center; gap:14px; text-align:center; padding:24px; color:rgba(233,243,240,0.8); }
.ig-embed__ph{ display:flex; flex-direction:column; align-items:center; gap:13px; }
.ig-embed__icon{ width:62px; height:62px; border-radius:18px; display:grid; place-items:center; background:linear-gradient(135deg,#f58529,#dd2a7b 50%,#8134af 90%); box-shadow:0 16px 36px -16px rgba(221,42,123,0.7); }
.ig-embed__icon svg{ width:32px; height:32px; stroke:#fff; fill:none; stroke-width:1.8; }
.ig-embed__t{ font-family:var(--font-display); font-weight:600; font-size:22px; color:#fff; }
.ig-embed__d{ font-size:13px; font-weight:300; line-height:1.5; max-width:30ch; color:rgba(233,243,240,0.66); }
.ig-embed code{ font-family:'Courier New',monospace; font-size:11px; color:var(--emerald-soft); background:rgba(127,217,196,0.1); padding:2px 7px; border-radius:6px; }
.ig-embed:has(blockquote.instagram-media) .ig-embed__ph,
.ig-embed:has(iframe) .ig-embed__ph{ display:none; }
.ig-embed blockquote, .ig-embed iframe{ position:relative; z-index:4; max-width:100%; }
.spot-cta{ display:flex; flex-wrap:wrap; gap:16px; align-items:center; justify-content:center; margin-top:clamp(40px,5vw,60px); }
.btn-emerald{ display:inline-flex; align-items:center; gap:11px; text-decoration:none; font-family:var(--font-body); font-weight:600; font-size:16px; color:#06231f; padding:18px 34px; border-radius:999px; background:linear-gradient(135deg,var(--emerald-soft),var(--emerald) 70%); box-shadow:0 18px 40px -16px rgba(42,175,148,0.6); transition:transform .35s var(--ease,ease), filter .35s; }
.btn-emerald:hover{ transform:translateY(-2px); filter:brightness(1.06); }
.btn-emerald .a{ transition:transform .35s var(--ease,ease); }
.btn-emerald:hover .a{ transform:translateX(4px); }
@media (max-width:980px){
  .home-hero__wrap{ grid-template-columns:1fr; gap:48px; }
  .home-hero__media{ max-width:460px; }
  .home-hero__scroll{ display:none; }
  .spot-head{ display:block; }
  .spot-head p{ margin-top:18px; }
  .vitrine{ grid-template-columns:repeat(2,1fr); }
  .vtile--video{ grid-column:span 2; }
}
@media (max-width:600px){
  .vitrine{ grid-template-columns:1fr; }
  .vtile, .vtile--video, .vtile--tall, .vtile--wide{ grid-column:auto; grid-row:auto; height:240px; }
  .home-hero__badge{ left:0; }
  .home-hero__float{ right:0; }
}

/* ---------- Grids da Neuromodulação (mobile fix) ---------- */
.tech-cards{ display:grid; grid-template-columns:repeat(3,1fr); gap:clamp(20px,2.4vw,30px); margin-top:clamp(48px,5vw,72px); }
.emt-grid{ display:grid; grid-template-columns:1fr 1fr; gap:clamp(36px,5vw,72px); align-items:center; }
.espaco-grid{ display:grid; grid-template-columns:repeat(2,1fr); gap:16px; }
@media (max-width:860px){ .tech-cards{ grid-template-columns:1fr 1fr; } .emt-grid{ grid-template-columns:1fr; } }
@media (max-width:520px){ .tech-cards{ grid-template-columns:1fr; } .espaco-grid{ grid-template-columns:1fr; } }

/* ---------- WhatsApp flutuante ---------- */
.wa-float{ position:fixed; right:22px; bottom:22px; z-index:140; width:60px; height:60px; border-radius:50%; display:grid; place-items:center; background:linear-gradient(135deg,#2bb673,#1d9e63); box-shadow:0 14px 34px -10px rgba(29,158,99,0.8); text-decoration:none; transition:transform .4s var(--ease,ease); animation:waPulse 2.8s ease-in-out infinite; }
.wa-float:hover{ transform:scale(1.08); }
.wa-float svg{ width:32px; height:32px; fill:#fff; }
@keyframes waPulse{ 0%,100%{ box-shadow:0 14px 34px -10px rgba(29,158,99,0.8), 0 0 0 0 rgba(43,182,115,0.5);} 60%{ box-shadow:0 14px 34px -10px rgba(29,158,99,0.8), 0 0 0 16px rgba(43,182,115,0);} }

/* ---------- Blog preview (na home) ---------- */
.blog-cta-row{ display:flex; justify-content:center; margin-top:clamp(36px,4vw,54px); }
.btn-outline{ display:inline-flex; align-items:center; gap:10px; text-decoration:none; font-family:var(--font-body); font-weight:600; font-size:16px; color:var(--gold-deep); padding:16px 32px; border-radius:999px; border:1.5px solid var(--gold-deep); transition:background .35s, color .35s, gap .3s; }
.btn-outline:hover{ background:var(--gold-deep); color:#fff; gap:15px; }

/* imagem nos cards de artigo/blog */
.article{ text-decoration:none; color:inherit; }
.bcard{ display:block; text-decoration:none; color:inherit; background:#fff; border-radius:16px; overflow:hidden;
  box-shadow:0 4px 24px -8px rgba(44,30,12,0.14); transition:transform .4s var(--ease,ease), box-shadow .4s; }
.bcard:hover{ transform:translateY(-5px); box-shadow:0 18px 44px -16px rgba(44,30,12,0.26); }
.bcard .article__img img{ transition:transform .7s var(--ease,ease); }
.bcard:hover .article__img img{ transform:scale(1.06); }
.bcard .article__body{ padding:22px 22px 24px; }
.bcard .article__body h3{ font-family:var(--font-display); font-weight:600; font-size:20px; line-height:1.2; margin:10px 0 10px; color:var(--warm-ink); }
.bcard .article__body p{ font-size:14.5px; line-height:1.6; color:var(--warm-soft); margin:0; }
.bcard .article__body .blog-meta{ font-size:12.5px; color:var(--warm-soft); margin-bottom:4px; }
.article__img{ position:relative; height:188px; overflow:hidden; }
.article__img img{ width:100%; height:100%; object-fit:cover; transition:transform .7s var(--ease,ease); }
.article:hover .article__img img{ transform:scale(1.05); }
.article__img .blog-tag{ position:absolute; left:16px; top:16px; z-index:2; }
.article__img::after{ content:""; position:absolute; inset:0; background:linear-gradient(180deg, transparent 45%, rgba(44,30,12,0.34) 100%); }
/* capa em gradiente (tópicos sem foto) */
.article__img--grad{ display:grid; place-items:center; }
.article__img--g1{ background:radial-gradient(120% 120% at 30% 20%, #157a60 0%, #0a2e2a 80%); }
.article__img--g2{ background:radial-gradient(120% 120% at 70% 25%, #2aaf94 0%, #0d3a33 82%); }
.article__img--g3{ background:radial-gradient(120% 120% at 40% 80%, #1f6f8f 0%, #0a2e2a 80%); }
.article__img--grad svg{ width:64px; height:64px; stroke:rgba(255,255,255,0.92); fill:none; stroke-width:1.4; opacity:.95; filter:drop-shadow(0 6px 16px rgba(0,0,0,0.4)); position:relative; z-index:1; }
.article__ico-deco{ position:absolute; inset:0; opacity:.16; }
.article__ico-deco span{ position:absolute; border-radius:50%; border:1px solid #fff; }

/* imagem/visual nas indicações — faixa em gradiente + ícone */
.indic{ overflow:hidden; padding:0 !important; }
.indic__top{ height:96px; position:relative; display:grid; place-items:center; }
.indic__top svg{ width:36px; height:36px; stroke:#fff; fill:none; stroke-width:1.5; position:relative; z-index:1; filter:drop-shadow(0 4px 12px rgba(0,0,0,0.35)); }
.indic__top--a{ background:radial-gradient(120% 130% at 30% 20%, #2aaf94, #0a2e2a 90%); }
.indic__top--b{ background:radial-gradient(120% 130% at 70% 25%, #157a60, #0a2e2a 90%); }
.indic__top--c{ background:radial-gradient(120% 130% at 40% 80%, #1f6f8f, #0a2e2a 90%); }
.indic__top--d{ background:radial-gradient(120% 130% at 65% 60%, #3a8f7a, #0d3a33 90%); }
.indic__pad{ padding:22px 24px 26px; display:flex; flex-direction:column; gap:9px; }

/* ---------- Responsivo ---------- */
@media (max-width:980px){
  .about-grid, .contact-grid{ grid-template-columns:1fr; gap:40px; }
  .about-portrait{ order:-1; max-width:520px; }
  .serv-grid, .tech-grid{ grid-template-columns:1fr 1fr; }
  .serv--wide{ grid-column:span 2; grid-template-columns:1fr; }
  .newspace{ grid-template-columns:1fr; text-align:center; }
  .home-hero{ padding-top:clamp(100px,14vh,140px); }
  .home-hero__figure{ max-width:min(420px,86vw); }
}
@media (max-width:860px){
  .nav__links{ position:fixed; inset:0 0 0 auto; width:min(320px,80vw); flex-direction:column; align-items:flex-start; justify-content:center; gap:26px; padding:40px; background:rgba(236,228,216,0.98); -webkit-backdrop-filter:blur(16px); backdrop-filter:blur(16px); transform:translateX(100%); transition:transform .5s var(--ease,ease); box-shadow:-20px 0 60px -30px rgba(0,0,0,0.5); z-index:120; }
  .nav__links.open{ transform:translateX(0); }
  .nav__link{ font-size:18px; }
  .nav__wa{ display:none; }
  .nav__burger{ display:flex; z-index:130; }
  /* overlay escurecendo o fundo ao abrir menu */
  body:has(.nav__links.open)::after{ content:""; position:fixed; inset:0; background:rgba(44,30,12,0.45); z-index:119; pointer-events:none; }
}
@media (max-width:600px){
  .serv-grid, .tech-grid{ grid-template-columns:1fr; }
  .serv--wide{ grid-column:span 1; }
  .home-hero{ padding-top:90px; }
  .home-hero__motto{ font-size:clamp(22px,6vw,32px); }
  .home-hero__title{ font-size:clamp(32px,7.5vw,48px); }
  .home-hero__lead{ font-size:16px; }
  .home-hero__cta{ flex-direction:column; align-items:center; }
  .home-hero__cta .btn-gold, .home-hero__cta .btn-ghost{ width:100%; justify-content:center; }
  .home-hero__figure{ max-width:min(360px,92vw); }
  .home-hero__chips{ gap:8px 14px; }
  .hchip{ font-size:13px; }
  .vitrine--equal{ grid-template-columns:1fr; grid-auto-rows:220px; }
  .reels-row{ grid-template-columns:1fr; }
  .spot-head h2{ font-size:clamp(28px,7vw,40px); }
  .btn-emerald{ font-size:15px; padding:15px 24px; }
  .spot-cta{ flex-direction:column; align-items:center; }
  .spot-cta a{ width:100%; justify-content:center; }
}
@media (max-width:400px){
  .home-hero__title{ font-size:30px; }
  .home-hero__motto{ font-size:22px; }
}
