/* =========================================================
   Isadora Lopes — Psicóloga · Landing Page
   Paleta extraída da logomarca (vinho + mauve + creme)
   ========================================================= */

:root{
  /* Marca */
  --wine:        #5C1A2A;
  --wine-700:    #471320;
  --wine-900:    #2C0B13;
  --mauve:       #A07A6E;
  --mauve-600:   #8C6358;
  --mauve-300:   #CBAEA3;
  --cream:       #F7F0EB;
  --cream-2:     #FBF6F3;
  --paper:       #FFFFFF;
  --ink:         #2A1B1E;
  --muted:       #6F5A55;
  --line:        rgba(92,26,42,.12);

  /* Tipografia */
  --serif: 'Cormorant Garamond', Cormorant, Georgia, 'Times New Roman', serif;
  --sans:  'Source Sans 3', system-ui, -apple-system, sans-serif;
  --display: 'Cormorant Garamond', Georgia, 'Times New Roman', serif;

  /* Layout */
  --container: 1180px;
  --radius: 18px;
  --radius-lg: 28px;
  --shadow-sm: 0 2px 10px rgba(44,11,19,.06);
  --shadow:    0 22px 50px -22px rgba(44,11,19,.35);
  --shadow-lg: 0 40px 90px -30px rgba(44,11,19,.5);
  --ease: cubic-bezier(.2,.7,.2,1);
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  font-family:var(--sans);
  color:var(--ink);
  background:var(--cream);
  line-height:1.65;
  font-size:clamp(1rem,.96rem + .2vw,1.075rem);
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
}
img{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
h1,h2,h3,h4{font-family:var(--serif);font-weight:600;line-height:1.12;letter-spacing:-.01em}
em{font-style:italic;color:var(--wine);font-weight:500}
.container{width:100%;max-width:var(--container);margin-inline:auto;padding-inline:clamp(20px,5vw,40px)}
.ico{width:1.15em;height:1.15em;flex:none}

/* ---------- Botões ---------- */
.btn{
  --bg:var(--wine);--fg:#fff;
  display:inline-flex;align-items:center;gap:.55rem;
  background:var(--bg);color:var(--fg);
  font-family:var(--sans);font-weight:600;font-size:.98rem;
  padding:.95rem 1.6rem;border-radius:100px;border:1px solid transparent;
  cursor:pointer;transition:transform .35s var(--ease),box-shadow .35s var(--ease),background .3s;
  box-shadow:0 12px 26px -12px rgba(92,26,42,.6);
}
.btn:hover{transform:translateY(-2px);box-shadow:0 18px 34px -12px rgba(92,26,42,.65)}
.btn .ico{width:1.2em;height:1.2em}
.btn--whats{--bg:var(--wine)}
.btn--ghost{--bg:transparent;--fg:var(--wine);border-color:var(--line);box-shadow:none}
.btn--ghost:hover{background:var(--paper);box-shadow:var(--shadow-sm)}
.btn--light{--bg:var(--cream);--fg:var(--wine)}
.btn--sm{padding:.6rem 1.1rem;font-size:.9rem}
.btn--lg{padding:1.1rem 2rem;font-size:1.05rem}

.link-arrow{display:inline-flex;align-items:center;gap:.45rem;color:var(--wine);font-weight:600;border-bottom:1px solid var(--mauve-300);padding-bottom:2px;transition:gap .3s var(--ease)}
.link-arrow:hover{gap:.8rem}
.link-arrow .ico{width:1.1em;height:1.1em}

/* ---------- Tags / títulos de seção ---------- */
.section-tag{
  display:inline-flex;align-items:center;gap:.5rem;
  font-family:var(--sans);font-weight:600;font-size:.78rem;
  text-transform:uppercase;letter-spacing:.18em;color:var(--mauve-600);
}
.section-tag::before{content:"";width:26px;height:1px;background:var(--mauve)}
.section-tag--light{color:var(--mauve-300)}
.section-tag--light::before{background:var(--mauve-300)}
.section-head{max-width:680px;margin-bottom:clamp(2.5rem,5vw,4rem)}
.section-head h2{font-size:clamp(1.9rem,1.3rem + 2.6vw,3rem);margin-top:.8rem}

/* =========================================================
   HEADER
   ========================================================= */
.site-header{
  position:sticky;top:0;z-index:60;
  background:transparent;border-bottom:1px solid transparent;
  transition:border-color .3s,background .3s,padding .3s,backdrop-filter .3s;
}
.site-header.scrolled{
  border-color:var(--line);background:rgba(247,240,235,.92);
  backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);
}
.header-inner{display:flex;align-items:center;gap:1.5rem;padding-block:.85rem;transition:padding .3s}
.scrolled .header-inner{padding-block:.55rem}
.brand{position:relative;display:block;line-height:0}
.brand-logo{height:48px;width:auto;transition:height .3s,opacity .3s}
.scrolled .brand-logo{height:40px}
.brand-logo--dark{position:absolute;inset:0;opacity:0}
.scrolled .brand-logo--light{opacity:0}
.scrolled .brand-logo--dark{opacity:1}
.nav{display:flex;gap:1.6rem;margin-left:auto;font-weight:500;font-size:.96rem}
.nav a{color:var(--cream);opacity:.82;position:relative;padding:.2rem 0;transition:opacity .25s,color .3s}
.scrolled .nav a{color:var(--ink)}
.nav a::after{content:"";position:absolute;left:0;bottom:-2px;width:0;height:1.5px;background:var(--mauve-300);transition:width .3s var(--ease)}
.scrolled .nav a::after{background:var(--wine)}
.nav a:hover{opacity:1}
.nav a:hover::after{width:100%}
.header-cta{margin-left:.5rem}
.site-header:not(.scrolled) .header-cta{background:transparent;color:var(--cream);border-color:rgba(247,240,235,.45);box-shadow:none}
.site-header:not(.scrolled) .header-cta:hover{background:rgba(247,240,235,.12)}
.menu-toggle{display:none;flex-direction:column;gap:5px;background:none;border:0;cursor:pointer;padding:8px;margin-left:auto}
.menu-toggle span{width:24px;height:2px;background:var(--cream);border-radius:2px;transition:.3s var(--ease)}
.scrolled .menu-toggle span{background:var(--wine)}
.menu-toggle[aria-expanded="true"] span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.menu-toggle[aria-expanded="true"] span:nth-child(2){opacity:0}
.menu-toggle[aria-expanded="true"] span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

/* =========================================================
   HERO — vinho profundo + parallax (segue mouse/toque)
   ========================================================= */
.hero{
  position:relative;overflow:hidden;color:var(--cream);
  margin-top:calc(-1 * (48px + 1.7rem)); /* sobe sob o header transparente */
  padding-top:calc(48px + 1.7rem + clamp(2rem,5vh,3.5rem));
  padding-bottom:clamp(2.5rem,6vh,5rem);
  min-height:min(96vh,920px);display:flex;align-items:center;
  background:
    radial-gradient(120% 90% at 78% 18%, rgba(160,122,110,.20), transparent 55%),
    radial-gradient(100% 80% at 10% 90%, rgba(92,26,42,.55), transparent 60%),
    linear-gradient(155deg,#1d070d 0%, var(--wine-900) 42%, #46121f 100%);
}
.hero-atmos{position:absolute;inset:0;z-index:0;pointer-events:none}
.orb{position:absolute;border-radius:50%;filter:blur(70px)}
.orb--1{width:520px;height:520px;background:radial-gradient(circle,rgba(160,122,110,.5),transparent 70%);top:-120px;right:4%}
.orb--2{width:460px;height:460px;background:radial-gradient(circle,rgba(120,40,55,.6),transparent 70%);bottom:-180px;left:-100px}
.hero-brain{position:absolute;top:48%;left:42%;width:clamp(360px,40vw,560px);height:auto;
  transform:translate(-50%,-50%);color:var(--mauve-300);opacity:.14;
  filter:drop-shadow(0 0 24px rgba(203,174,163,.15))}
.hdot{position:absolute;border-radius:50%;background:var(--mauve-300);box-shadow:0 0 14px rgba(203,174,163,.7)}
.hdot--a{width:8px;height:8px;top:24%;left:30%;opacity:.8}
.hdot--b{width:5px;height:5px;top:62%;left:14%;opacity:.6}
.hdot--c{width:10px;height:10px;top:70%;right:34%;opacity:.5}
.hdot--d{width:6px;height:6px;top:16%;left:48%;opacity:.55}
.hero .grain{opacity:.35;mix-blend-mode:overlay}

.hero-grid{position:relative;z-index:1;display:grid;grid-template-columns:1.04fr .96fr;
  gap:clamp(2rem,5vw,4rem);align-items:center;width:100%}

.hero-chip{display:inline-flex;align-items:center;gap:.55rem;
  font-family:var(--sans);font-weight:600;font-size:.82rem;letter-spacing:.04em;
  color:var(--cream);background:rgba(247,240,235,.07);
  border:1px solid rgba(203,174,163,.28);padding:.55rem 1.05rem;border-radius:100px;
  backdrop-filter:blur(6px)}
.hero-chip .ico{width:1.05em;height:1.05em;color:var(--mauve-300)}
.hero h1{font-family:var(--display);font-weight:600;font-size:clamp(2.6rem,1.3rem + 5.4vw,5.2rem);
  line-height:1.04;letter-spacing:-.01em;margin:1.6rem 0 0;color:var(--cream);max-width:15ch;text-wrap:balance}
.hero h1 em{font-style:italic;font-weight:600;color:var(--mauve-300)}

/* ---- Animação-assinatura do título ---- */
.hl{position:relative}
.hl .w{display:inline-block;will-change:transform;
  animation:wFloat 6.5s ease-in-out infinite;
  animation-delay:calc(1.05s + var(--i) * .16s)}
.hl .w-in{display:inline-block;opacity:0;transform:translateY(18px);filter:blur(8px);
  will-change:transform,opacity,filter;
  animation:wEmerge 1s cubic-bezier(.2,.75,.25,1) forwards;
  animation-delay:calc(.12s + var(--i) * .085s)}
@keyframes wEmerge{to{opacity:1;transform:translateY(0);filter:blur(0)}}
@keyframes wFloat{0%,100%{transform:translateY(0)}50%{transform:translateY(-5px)}}

/* palavra-chave: reflexo de luz + traço que se desenha */
.hl-accent{position:relative;font-style:italic;color:transparent;
  background-image:linear-gradient(100deg,
     var(--mauve-300) 0%, var(--mauve-300) 42%, #FFF4EE 50%, var(--mauve-300) 58%, var(--mauve-300) 100%);
  background-size:300% 100%;background-position:200% 0;
  -webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;
  animation:wShimmer 6.5s linear 1.8s infinite}
@keyframes wShimmer{from{background-position:200% 0}to{background-position:-100% 0}}
.w--accent .w-in::after{content:"";position:absolute;left:2%;right:2%;bottom:-.04em;height:2px;border-radius:2px;
  background:linear-gradient(90deg,transparent,var(--mauve-300) 30%,#F3E7E1 50%,var(--mauve-300) 70%,transparent);
  transform:scaleX(0);transform-origin:center;
  animation:wDraw 1.1s cubic-bezier(.2,.75,.25,1) forwards;animation-delay:1.05s}
@keyframes wDraw{to{transform:scaleX(1)}}
.hero-lead{margin:1.5rem 0 2.2rem;font-size:clamp(1.05rem,1rem + .4vw,1.2rem);
  line-height:1.6;color:rgba(247,240,235,.74);max-width:46ch}
.hero-actions{display:flex;align-items:center;flex-wrap:wrap;gap:1.2rem 2rem}
.hero .hero-textlink{display:inline-flex;align-items:center;gap:.5rem;font-weight:600;color:var(--cream);transition:gap .3s var(--ease)}
.hero .hero-textlink .ico{width:1.05em;height:1.05em;color:var(--mauve-300);transition:transform .3s var(--ease)}
.hero .hero-textlink:hover{gap:.85rem}
.hero .hero-textlink:hover .ico{transform:translateX(3px)}

.hero-creds{list-style:none;display:flex;flex-wrap:wrap;gap:.85rem;
  margin-top:clamp(2.2rem,5vh,3.2rem);padding-top:1.6rem;
  border-top:1px solid rgba(247,240,235,.16)}
.hero-creds li{
  --neon:#FF8FB4;                       /* tom neon leve (rosé), só nos ícones */
  position:relative;isolation:isolate;display:flex;align-items:center;gap:.8rem;max-width:18rem;
  padding:.72rem .95rem;border-radius:14px;
  background:linear-gradient(150deg, rgba(247,240,235,.06), rgba(247,240,235,.02));
  border:1px solid rgba(247,240,235,.12);
  box-shadow:0 10px 22px -18px rgba(0,0,0,.65), inset 0 1px 0 rgba(247,240,235,.05);
  -webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);
  opacity:0;transform:translateY(16px) scale(.98);
  animation:credIn .75s cubic-bezier(.2,.75,.25,1) forwards;
  transition:transform .45s var(--ease), border-color .45s var(--ease), box-shadow .45s var(--ease)}
.hero-creds li:nth-child(1){animation-delay:.40s}
.hero-creds li:nth-child(2){animation-delay:.54s}
.hero-creds li:nth-child(3){animation-delay:.68s}
@keyframes credIn{to{opacity:1;transform:translateY(0) scale(1)}}
.hero-creds .ico{flex:none;width:40px;height:40px;padding:9px;border-radius:12px;
  color:var(--neon);
  border:1px solid color-mix(in srgb,var(--neon) 42%, transparent);
  background:radial-gradient(circle at 30% 25%, color-mix(in srgb,var(--neon) 20%, transparent), transparent 72%);
  box-shadow:0 0 10px -3px color-mix(in srgb,var(--neon) 55%, transparent),
             inset 0 0 9px -5px color-mix(in srgb,var(--neon) 60%, transparent);
  filter:drop-shadow(0 0 2px color-mix(in srgb,var(--neon) 40%, transparent));
  animation:credGlow 3.6s ease-in-out infinite;
  transition:box-shadow .4s var(--ease), transform .4s var(--ease)}
.hero-creds li:nth-child(2) .ico{animation-delay:.5s}
.hero-creds li:nth-child(3) .ico{animation-delay:1s}
@keyframes credGlow{
  0%,100%{box-shadow:0 0 8px -4px color-mix(in srgb,var(--neon) 45%, transparent),
                     inset 0 0 8px -5px color-mix(in srgb,var(--neon) 50%, transparent)}
  50%{box-shadow:0 0 15px -2px color-mix(in srgb,var(--neon) 70%, transparent),
                 inset 0 0 11px -4px color-mix(in srgb,var(--neon) 65%, transparent)}}
.hero-creds span{display:flex;flex-direction:column;line-height:1.25}
.hero-creds strong{font-family:var(--serif);font-weight:500;font-size:1.12rem;color:var(--cream);margin-bottom:.05rem}
.hero-creds span{font-size:.82rem;color:rgba(247,240,235,.62)}
/* hover / foco: o card se eleva e o ícone acende um pouco mais */
.hero-creds li:hover,.hero-creds li:focus-within{
  transform:translateY(-5px);
  border-color:color-mix(in srgb,var(--neon) 30%, transparent);
  box-shadow:0 20px 34px -20px rgba(0,0,0,.7), 0 0 18px -10px var(--neon)}
.hero-creds li:hover .ico,.hero-creds li:focus-within .ico{
  transform:scale(1.07);
  box-shadow:0 0 20px -2px color-mix(in srgb,var(--neon) 75%, transparent),
             inset 0 0 12px -4px color-mix(in srgb,var(--neon) 65%, transparent)}

/* palco da imagem + cartões flutuantes (profundidade do parallax) */
.hero-stage{position:relative;justify-self:center;width:min(100%,440px);aspect-ratio:4/5}
.hero-portrait{position:absolute;inset:0;border-radius:26px;overflow:hidden;
  box-shadow:0 50px 90px -30px rgba(0,0,0,.7);
  border:1px solid rgba(203,174,163,.22)}
.hero-portrait img{width:100%;height:100%;object-fit:cover;object-position:50% 18%}
.hero-portrait::after{content:"";position:absolute;inset:0;
  background:linear-gradient(180deg,transparent 55%,rgba(28,7,12,.55))}
.hero-portrait-cap{position:absolute;left:1.2rem;bottom:1rem;z-index:2;
  font-family:var(--sans);font-weight:600;font-size:.72rem;letter-spacing:.18em;
  text-transform:uppercase;color:var(--cream);display:flex;align-items:center;gap:.6rem}
.hero-portrait-cap::before{content:"";width:26px;height:1px;background:var(--mauve-300)}

.float-card{position:absolute;z-index:3;display:flex;align-items:center;gap:.7rem;
  background:rgba(40,14,20,.72);border:1px solid rgba(203,174,163,.28);
  backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);
  border-radius:14px;padding:.7rem .95rem;box-shadow:0 18px 40px -18px rgba(0,0,0,.7);
  color:var(--cream);white-space:nowrap}
.float-card strong{display:block;font-family:var(--serif);font-weight:500;font-size:.98rem;line-height:1.1}
.float-card small{font-size:.74rem;color:rgba(247,240,235,.62)}
.fc-ico{display:grid;place-items:center;width:34px;height:34px;border-radius:9px;
  background:rgba(203,174,163,.16);color:var(--mauve-300);flex:none}
.fc-ico svg{width:18px;height:18px}
.fc-dot{width:8px;height:8px;border-radius:50%;background:var(--mauve-300);box-shadow:0 0 10px var(--mauve-300)}
.float-card--brain{top:8%;left:-12%}
.float-card--crp{top:46%;right:-10%;font-weight:600;font-size:.85rem;letter-spacing:.06em}
.float-card--online{bottom:9%;left:-8%}

.hero-fade{position:absolute;left:0;right:0;bottom:0;height:90px;z-index:1;pointer-events:none;
  background:linear-gradient(180deg,transparent,var(--cream))}

/* will-change para suavizar o parallax */
[data-depth]{will-change:transform;transition:transform .12s ease-out}

/* =========================================================
   X-RIBBONS (motivo de marca)
   ========================================================= */
.ribbons{position:relative;height:clamp(120px,18vw,180px);margin-block:clamp(1rem,4vw,3rem);overflow:hidden}
.ribbon{position:absolute;left:-8%;width:116%;overflow:hidden;white-space:nowrap}
.ribbon--wine{top:50%;transform:translateY(-50%) rotate(-5.5deg);background:var(--wine);box-shadow:var(--shadow);z-index:2}
.ribbon--mauve{top:50%;transform:translateY(-50%) rotate(5.5deg);background:var(--mauve);z-index:1}
.ribbon-track{display:inline-flex;align-items:center;gap:1.6rem;padding:1rem 0;font-family:var(--serif);font-style:italic;font-size:clamp(1.1rem,.9rem + 1vw,1.7rem);will-change:transform;animation:marq 38s linear infinite}
.ribbon-track--rev{animation-direction:reverse;animation-duration:44s}
.ribbon--wine span{color:var(--cream)}
.ribbon--mauve span{color:var(--wine-900)}
.ribbon-track i{width:8px;height:8px;flex:none;transform:rotate(45deg)}
.ribbon--wine i{background:var(--mauve-300)}
.ribbon--mauve i{background:var(--wine)}
@keyframes marq{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* =========================================================
   SOBRE — editorial com título flutuante que entra da esquerda
   ========================================================= */
.about{padding-block:clamp(3.5rem,7vw,6rem);overflow:hidden}

/* cabeçalho: tag + título grande, centralizado */
.about-head{margin:0 auto clamp(2rem,4vw,3.2rem);max-width:900px;text-align:center}
.about-head .section-tag{justify-content:center}
.about-head .section-tag::before{display:none}
.about-title{font-size:clamp(2.2rem,1.4rem + 3.4vw,3.8rem);line-height:1.1;
  letter-spacing:-.01em;margin-top:.8rem;font-weight:600}
.about-title em{font-style:italic;font-weight:500;color:var(--wine)}
.at-line{display:block}

/* animação em 2 etapas, sem conflito de transform:
   1) cada linha desliza da esquerda para o lugar
   2) depois, flutuação leve HORIZONTAL (esquerda↔direita), suave e contínua */
.at-line{opacity:0;transform:translateX(-70px);will-change:transform,opacity}
.about-title.is-in .at-line--1{animation:atIn 1s cubic-bezier(.2,.75,.25,1) forwards}
.about-title.is-in .at-line--2{animation:atIn 1s cubic-bezier(.2,.75,.25,1) .16s forwards}
/* a flutuação só começa depois da entrada, aplicada num wrapper interno p/ não brigar com a entrada */
.at-line__in{display:inline-block;will-change:transform}
.about-title.is-in .at-line--1 .at-line__in{animation:atDrift 7s ease-in-out 1.1s infinite}
.about-title.is-in .at-line--2 .at-line__in{animation:atDrift 7s ease-in-out 1.5s infinite}
@keyframes atIn{from{opacity:0;transform:translateX(-70px)}to{opacity:1;transform:translateX(0)}}
@keyframes atDrift{0%,100%{transform:translateX(-7px)}50%{transform:translateX(7px)}}

/* layout foto + texto, com leve sobreposição editorial */
.about-layout{display:grid;grid-template-columns:.82fr 1.18fr;gap:clamp(2rem,5vw,4.5rem);align-items:center}
.about-figure{position:relative;margin:0}
.about-figure img{width:100%;border-radius:var(--radius-lg);box-shadow:var(--shadow);
  aspect-ratio:4/5;object-fit:cover;object-position:top}
.about-frame{position:absolute;inset:auto auto -16px -16px;width:55%;height:55%;background:
  repeating-linear-gradient(45deg,var(--mauve-300) 0 2px,transparent 2px 12px);
  border-radius:var(--radius);z-index:-1}
.about-cap{position:absolute;left:0;bottom:1.2rem;z-index:2;
  background:var(--wine);color:var(--cream);font-family:var(--sans);font-weight:600;
  font-size:.72rem;letter-spacing:.16em;text-transform:uppercase;
  padding:.55rem 1.1rem;border-radius:0 100px 100px 0;box-shadow:var(--shadow-sm)}

.about-lead{font-family:var(--serif);font-size:clamp(1.15rem,1rem + .6vw,1.4rem);
  line-height:1.5;color:var(--ink);margin-bottom:1.2rem}
.about-copy p{color:var(--muted);margin-bottom:1.1rem}
.about-lead.about-lead{color:var(--ink)}

/* credenciais como barras vinho com número, deslizando do canto até preencher */
.cred-bars{list-style:none;display:flex;flex-direction:column;gap:.7rem;margin:1.8rem 0}
.cred-bar{display:flex;align-items:center;gap:1rem;
  background:linear-gradient(100deg,var(--wine) 0%, var(--wine-700) 100%);
  color:var(--cream);border-radius:14px;padding:.85rem 1.2rem;
  box-shadow:0 14px 30px -18px rgba(44,11,19,.55);overflow:hidden;
  opacity:0;transform:translateX(-40px);
  transition:transform .7s cubic-bezier(.2,.75,.25,1), opacity .6s ease, box-shadow .35s var(--ease);
  transition-delay:calc(var(--k) * .12s);will-change:transform,opacity}
.cred-bars.is-in .cred-bar{opacity:1;transform:translateX(0)}
.cred-bar:hover{box-shadow:0 20px 38px -16px rgba(44,11,19,.6);transform:translateX(4px)}
.cred-num{font-family:var(--serif);font-weight:600;font-size:1.7rem;line-height:1;
  color:var(--mauve-300);flex:none;min-width:2.4ch;text-align:center}
.cred-txt{font-size:.95rem;font-weight:500;line-height:1.3}


/* =========================================================
   SERVICES — leque de cartas que se abre
   ========================================================= */
.services{padding-block:clamp(3.5rem,7vw,6rem) clamp(4rem,8vw,7rem);background:var(--cream-2);overflow:hidden}

/* o baralho fica num palco central; uma carta ativa à frente, as outras em leque atrás */
.deck{position:relative;height:clamp(390px,52vw,440px);margin-top:clamp(2rem,4vw,3rem);
  --active:0;touch-action:pan-y;user-select:none}

.pcard{
  /* posição relativa à carta ativa (-2,-1,0,1,2...) */
  --rel:calc(var(--i) - var(--active));
  position:absolute;left:50%;top:50%;
  width:min(300px,82vw);height:clamp(330px,46vw,380px);
  margin-left:calc(min(300px,82vw) / -2);margin-top:calc(clamp(330px,46vw,380px) / -2);
  background:linear-gradient(168deg,#fff 0%, #fdf8f5 100%);
  border:1px solid rgba(92,26,42,.14);border-radius:22px;
  box-shadow:0 26px 50px -26px rgba(44,11,19,.5), inset 0 0 0 1px rgba(255,255,255,.6);
  padding:2.4rem 2rem;display:flex;flex-direction:column;justify-content:center;
  transform-origin:50% 120%;
  /* FALLBACK sem JS: cartas levemente escalonadas para trás (não usa abs()) */
  transform:translateX(calc(var(--i) * 10px)) translateY(calc(var(--i) * 8px)) rotate(calc(var(--i) * 3deg)) scale(calc(1 - var(--i) * .03));
  opacity:1;
  z-index:calc(50 - var(--i));
  transition:transform .6s cubic-bezier(.2,.75,.25,1), opacity .5s ease, box-shadow .4s var(--ease);
  cursor:pointer;will-change:transform;
}
/* quando o JS está ativo, ele controla cada carta via style inline; o leque dinâmico assume */

/* a carta ativa fica reta, à frente e nítida */
.pcard[data-active]{
  transform:translateX(0) translateY(-6px) rotate(0deg) scale(1);
  opacity:1;z-index:60;
  box-shadow:0 44px 80px -30px rgba(44,11,19,.6);
}
/* cartas já "passadas" sopram para a esquerda, as futuras ficam à direita (efeito já vem do --rel) */

/* faixa de cor no topo */
.pcard::before{content:"";position:absolute;inset:0 0 auto 0;height:4px;border-radius:22px 22px 0 0;
  background:linear-gradient(90deg,var(--wine),var(--mauve))}

.pcard-no{display:block;font-family:var(--serif);font-style:italic;font-size:1.5rem;
  color:var(--mauve);opacity:.5;margin-bottom:.8rem;line-height:1}
.pcard-body h3{font-size:1.22rem;color:var(--wine);margin-bottom:.6rem;line-height:1.2}
.pcard-body p{color:var(--muted);font-size:.94rem;line-height:1.55}
/* conteúdo só totalmente visível na carta ativa (as de trás ficam discretas) */
.pcard:not([data-active]) .pcard-body{opacity:.55}

/* controles */
.deck-nav{display:flex;align-items:center;justify-content:center;gap:1.4rem;
  margin-top:clamp(1.4rem,3vw,2.2rem)}
.deck-arrow{width:48px;height:48px;border-radius:50%;flex:none;cursor:pointer;
  display:grid;place-items:center;background:var(--paper);color:var(--wine);
  border:1px solid var(--line);box-shadow:var(--shadow-sm);
  transition:background .25s,color .25s,transform .25s var(--ease)}
.deck-arrow:hover{background:var(--wine);color:var(--cream);transform:translateY(-2px)}
.deck-arrow svg{width:20px;height:20px}
#deckPrev svg{transform:scaleX(-1)}
.deck-dots{display:flex;gap:.55rem}
.deck-dot{width:8px;height:8px;border-radius:50%;border:0;padding:0;cursor:pointer;
  background:var(--mauve-300);opacity:.5;transition:opacity .25s,transform .25s,background .25s}
.deck-dot[aria-current="true"]{opacity:1;background:var(--wine);transform:scale(1.3)}

.deck-hint{text-align:center;margin-top:.9rem;
  font-size:.76rem;letter-spacing:.14em;text-transform:uppercase;color:var(--mauve-600);opacity:.7}


/* =========================================================
   AUDIENCE — banda com foto de fundo + banho de cor da marca
   ========================================================= */
.audience{position:relative;overflow:hidden;color:var(--cream);
  padding-block:clamp(4rem,8vw,7rem);background:#240910;isolation:isolate}
/* base atmosférica (aparece mesmo sem foto) */
.aud-bg{position:absolute;inset:0;z-index:0;
  background:
    radial-gradient(58% 50% at 74% 16%, rgba(203,174,163,.5), transparent 60%),
    radial-gradient(46% 42% at 18% 28%, rgba(160,122,110,.32), transparent 65%),
    radial-gradient(70% 60% at 50% 115%, rgba(120,52,60,.5), transparent 70%),
    linear-gradient(180deg,#3a121d 0%, #5c1a2a 46%, #3a121d 80%, #200810 100%)}
/* foto opcional do consultório: basta colocar assets/ambiente.jpg
   contain = imagem inteira sempre visível; o aud-bg preenche o que sobrar */
.aud-photo{position:absolute;inset:0;z-index:1;
  background-image:url('../assets/ambiente.jpg');
  background-size:contain;background-position:center;background-repeat:no-repeat;
  animation:audFloat 14s ease-in-out infinite alternate}
@keyframes audFloat{from{background-position:center 46%}to{background-position:center 54%}}
/* suaviza as bordas da foto para fundir com o fundo vinho */
.aud-photo{-webkit-mask-image:radial-gradient(120% 120% at 50% 45%, #000 62%, transparent 100%);
  mask-image:radial-gradient(120% 120% at 50% 45%, #000 62%, transparent 100%)}
/* no celular a foto preenche a seção (zoom) com enquadramento centralizado */
@media (max-width:760px){
  .aud-photo{inset:0;height:auto;background-size:cover;background-position:center center;
    animation:none;
    -webkit-mask-image:none;mask-image:none}
}
/* banho de cor (vinho/mauve) garantindo contraste do texto */
.aud-wash{position:absolute;inset:0;z-index:2;
  background:
    linear-gradient(180deg, rgba(36,9,15,.62) 0%, rgba(92,26,42,.5) 45%, rgba(36,9,15,.82) 100%),
    radial-gradient(120% 80% at 50% 0%, rgba(160,122,110,.18), transparent 55%)}
.aud-wash .grain{opacity:.3;mix-blend-mode:overlay}
.audience>.container{position:relative;z-index:3}

.section-head--center{margin-inline:auto;text-align:center}
.section-head--center .section-tag::before{display:none}
.section-head--center .section-tag{justify-content:center}
.audience h2{color:var(--cream)}
.audience h2 em{color:var(--mauve-300)}
.aud-intro{margin:1.1rem auto 0;max-width:52ch;color:rgba(247,240,235,.78);font-size:1.08rem}

.aud-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(1rem,2.5vw,1.8rem);
  margin-top:clamp(2.5rem,5vw,3.5rem)}
.aud{text-align:center;padding:2.6rem 1.6rem;border-radius:var(--radius-lg);
  background:rgba(36,12,18,.46);border:1px solid rgba(203,174,163,.24);
  backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);
  box-shadow:0 26px 50px -28px rgba(0,0,0,.7);
  transition:transform .4s var(--ease),background .4s,border-color .4s}
.aud:hover{transform:translateY(-6px);background:rgba(54,18,26,.6);border-color:rgba(203,174,163,.45)}
.aud-ico{display:inline-grid;place-items:center;width:74px;height:74px;border-radius:50%;
  border:1px solid rgba(203,174,163,.5);color:var(--mauve-300);margin-bottom:1.2rem;
  background:rgba(203,174,163,.08)}
.aud-ico svg{width:34px;height:34px}
.aud h3{font-size:1.4rem;color:var(--cream);margin-bottom:.5rem}
.aud p{color:rgba(247,240,235,.72);font-size:.95rem;max-width:32ch;margin-inline:auto}

.aud-cta{margin-top:clamp(2.4rem,5vw,3.2rem);text-align:center}

/* =========================================================
   ONLINE
   ========================================================= */
.online{position:relative;background:var(--wine);color:var(--cream);padding-block:clamp(3.5rem,7vw,6.5rem);overflow:hidden}
.online::before{content:"";position:absolute;width:520px;height:520px;border-radius:50%;background:radial-gradient(circle,rgba(160,122,110,.4),transparent 70%);top:-160px;left:-120px;filter:blur(40px)}
.online-grid{position:relative;display:grid;grid-template-columns:1fr .85fr;gap:clamp(2rem,5vw,4.5rem);align-items:center}
.online-copy h2{font-size:clamp(1.9rem,1.3rem + 2.6vw,3rem);margin:.9rem 0 1.3rem;color:var(--cream)}
.online-copy h2 em{color:var(--mauve-300)}
.online-copy>p{color:rgba(247,240,235,.78);margin-bottom:1.6rem;max-width:48ch}
.online-list{list-style:none;display:grid;gap:.85rem;margin-bottom:2rem}
.online-list li{display:flex;align-items:center;gap:.7rem;font-weight:500}
.online-list .ico{color:var(--mauve-300)}
.online-copy .section-tag{margin-bottom:.4rem}
.online-copy .section-tag:not(:first-child){margin-top:0}
.online-rule{display:block;height:1px;width:100%;margin:2rem 0 1.8rem;
  background:linear-gradient(90deg,var(--mauve-300),rgba(203,174,163,.15) 70%,transparent)}
.online-sub{font-family:var(--serif);font-weight:600;color:var(--cream);
  font-size:clamp(1.4rem,1.1rem + 1.1vw,1.9rem);line-height:1.2;margin:.9rem 0 1.1rem}
.online-sub em{color:var(--mauve-300);font-style:italic}
.online-copy>p:last-of-type{margin-bottom:1.8rem}
.online-figure{position:relative}
.online-figure img{width:100%;border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);aspect-ratio:4/5;object-fit:cover;object-position:top}
.online-figure::after{content:"";position:absolute;inset:-14px auto auto -14px;width:60%;height:60%;border:1.5px solid var(--mauve-300);border-radius:var(--radius-lg);z-index:-1}
/* emblema "Palestras e eventos" sobre a foto */
.fig-badge{position:absolute;left:-18px;bottom:24px;z-index:2;
  display:flex;align-items:center;gap:.7rem;max-width:78%;
  padding:.7rem .95rem;border-radius:14px;
  background:rgba(40,14,20,.74);border:1px solid rgba(203,174,163,.32);
  -webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);
  box-shadow:0 20px 44px -20px rgba(0,0,0,.75);color:var(--cream);
  opacity:0;transform:translateY(14px) scale(.96)}
.online-figure.is-in .fig-badge{
  animation:figBadgeIn .8s cubic-bezier(.2,.75,.25,1) .2s forwards}
@media (min-width:761px){
  .online-figure.is-in .fig-badge{
    animation:figBadgeIn .8s cubic-bezier(.2,.75,.25,1) .2s forwards,
              figBadgeFloat 6s ease-in-out 1.1s infinite}
}
.fig-badge__ico{flex:none;display:grid;place-items:center;width:38px;height:38px;border-radius:11px;
  color:var(--mauve-300);background:rgba(203,174,163,.16);
  border:1px solid rgba(203,174,163,.3);
  box-shadow:inset 0 0 10px -5px rgba(203,174,163,.6)}
.fig-badge__ico svg{width:20px;height:20px}
.fig-badge__txt{display:flex;flex-direction:column;line-height:1.2;min-width:0}
.fig-badge__txt strong{font-family:var(--serif);font-weight:500;font-size:1rem}
.fig-badge__txt small{font-size:.74rem;color:rgba(247,240,235,.66)}
@keyframes figBadgeIn{to{opacity:1;transform:translateY(0) scale(1)}}
@keyframes figBadgeFloat{0%,100%{transform:translateY(0)}50%{transform:translateY(-6px)}}

/* =========================================================
   PROCESS
   ========================================================= */
.process{padding-block:clamp(3.5rem,7vw,6rem)}
.steps{list-style:none;display:grid;
  grid-template-columns:repeat(auto-fit,minmax(250px,1fr));
  gap:clamp(1.1rem,2.6vw,1.9rem);
  margin-top:clamp(2.4rem,5vw,3.4rem)}
.step{
  position:relative;isolation:isolate;overflow:hidden;
  padding:2.1rem 1.7rem 1.9rem;border-radius:20px;color:var(--cream);
  background:linear-gradient(155deg, var(--wine) 0%, var(--wine-900) 100%);
  border:1px solid rgba(247,240,235,.08);
  box-shadow:0 4px 14px -9px rgba(44,11,19,.4);
  transform:translateY(0);
  transition:transform .5s var(--ease), box-shadow .5s var(--ease), border-color .5s var(--ease)}
/* brilho suave que cruza o card como luz sobre cetim */
.step::before{content:"";position:absolute;inset:0;z-index:1;pointer-events:none;
  background:linear-gradient(115deg, transparent 32%, rgba(247,240,235,.09) 47%, rgba(247,240,235,.16) 50%, rgba(247,240,235,.09) 53%, transparent 68%);
  transform:translateX(-130%);
  transition:transform 1s var(--ease)}
.step>*{position:relative;z-index:2}
.step-num{font-family:var(--serif);font-weight:600;font-size:2.9rem;color:#fff;
  line-height:1;display:inline-block;position:relative;margin-bottom:.6rem;padding-bottom:.18rem}
.step-num::after{content:"";position:absolute;left:0;bottom:0;height:2px;width:0;
  background:var(--mauve-300);border-radius:2px;
  transition:width .55s var(--ease)}
.step h3{font-size:1.32rem;color:var(--cream);margin-bottom:.55rem;transition:color .4s var(--ease)}
.step p{color:rgba(247,240,235,.78);line-height:1.55}
/* hover / toque / foco: o card ganha vida — eleva, aprofunda a sombra, o brilho cruza e a linha cresce */
.step:hover,.step:focus-within,.step.is-touched{
  transform:translateY(-8px);
  border-color:rgba(203,174,163,.28);
  box-shadow:0 30px 56px -18px rgba(44,11,19,.6), 0 10px 24px -16px rgba(44,11,19,.45)}
.step:hover::before,.step:focus-within::before,.step.is-touched::before{transform:translateX(130%)}
.step:hover .step-num::after,.step:focus-within .step-num::after,.step.is-touched .step-num::after{width:48px}
.step:hover h3,.step:focus-within h3,.step.is-touched h3{color:var(--mauve-300)}

/* =========================================================
   FAQ
   ========================================================= */
.faq{padding-block:clamp(3.5rem,7vw,6rem);background:var(--cream-2)}
.faq-grid{display:grid;grid-template-columns:.8fr 1.2fr;gap:clamp(2rem,5vw,4rem);align-items:start}
.faq-intro{position:sticky;top:100px}
.faq-intro h2{font-size:clamp(1.8rem,1.3rem + 2.2vw,2.6rem);margin:.8rem 0 1rem}
.faq-intro p{color:var(--muted);margin-bottom:1.2rem}

/* tag centralizada com linhas "energizadas" saindo para os dois lados */
.tag-energy{display:flex;align-items:center;justify-content:center;gap:1.4rem;width:100%;
  margin-bottom:clamp(2rem,4vw,3rem);
  font-family:var(--sans);font-weight:600;font-size:.82rem;letter-spacing:.2em;
  text-transform:uppercase;color:var(--mauve-600);white-space:nowrap;
  animation:teGlow 2.4s ease-in-out infinite}
.te-line{position:relative;flex:1;height:2px;overflow:hidden;border-radius:2px;
  background:linear-gradient(90deg,transparent,var(--mauve-300) 55%,var(--mauve-300))}
.te-line--r{background:linear-gradient(270deg,transparent,var(--mauve-300) 55%,var(--mauve-300))}
/* pulso de luz que percorre a linha em direção à borda da tela (efeito "ligado na energia") */
.te-line::after{content:"";position:absolute;top:0;height:100%;width:42%;border-radius:2px;
  background:linear-gradient(90deg,transparent,#FFF4EE,var(--wine),transparent);
  filter:drop-shadow(0 0 6px rgba(160,122,110,.9))}
.te-line--l::after{right:0;animation:teRunL 2.2s linear infinite}
.te-line--r::after{left:0;animation:teRunR 2.2s linear infinite}
/* a linha esquerda corre para a esquerda (borda), a direita para a direita */
@keyframes teRunL{0%{transform:translateX(100%)}100%{transform:translateX(-160%)}}
@keyframes teRunR{0%{transform:translateX(-100%)}100%{transform:translateX(160%)}}
/* leve pulsar no texto, como tensão elétrica */
@keyframes teGlow{0%,100%{text-shadow:0 0 0 transparent}50%{text-shadow:0 0 10px rgba(160,122,110,.55)}}

.section-head .tag-energy,.section-head--center .tag-energy,.about-head .tag-energy{margin-bottom:.9rem}

/* variante para fundos ESCUROS (vinho): texto creme, linhas em mauve claro, pulso luminoso */
.tag-energy--light{color:var(--mauve-300)}
.tag-energy--light .te-line{background:linear-gradient(90deg,transparent,rgba(203,174,163,.65) 55%,rgba(203,174,163,.65))}
.tag-energy--light .te-line--r{background:linear-gradient(270deg,transparent,rgba(203,174,163,.65) 55%,rgba(203,174,163,.65))}
.tag-energy--light .te-line::after{background:linear-gradient(90deg,transparent,#FFF7F2,var(--mauve-300),transparent);
  filter:drop-shadow(0 0 7px rgba(247,240,235,.9))}
.tag-energy--light{animation:teGlowLight 2.4s ease-in-out infinite}
@keyframes teGlowLight{0%,100%{text-shadow:0 0 0 transparent}50%{text-shadow:0 0 12px rgba(247,240,235,.6)}}

.faq-list{display:grid;gap:.9rem}
.faq-item{position:relative;isolation:isolate;
  background:linear-gradient(180deg, var(--paper), #fdf9f7);
  border:1px solid rgba(160,122,110,.20);border-radius:18px;overflow:hidden;
  box-shadow:0 6px 18px -15px rgba(92,26,42,.35);
  transition:box-shadow .4s var(--ease), border-color .4s var(--ease)}
/* fina barra de destaque à esquerda (cresce ao abrir) */
.faq-item::before{content:"";position:absolute;left:0;top:0;bottom:0;width:3px;z-index:2;
  background:linear-gradient(180deg, var(--mauve-300), var(--wine));
  transform:scaleY(0);transform-origin:center;transition:transform .5s var(--ease)}
.faq-item:hover{border-color:rgba(203,174,163,.55);box-shadow:0 14px 30px -18px rgba(92,26,42,.4)}
.faq-item[open]{border-color:var(--mauve-300);box-shadow:0 18px 40px -20px rgba(92,26,42,.45)}
.faq-item[open]::before{transform:scaleY(1)}
.faq-item summary{list-style:none;cursor:pointer;display:flex;align-items:center;justify-content:space-between;gap:1rem;
  padding:1.25rem 1.5rem;font-family:var(--serif);font-size:1.12rem;color:var(--wine);
  transition:transform .16s var(--ease), color .3s var(--ease)}
.faq-item summary::-webkit-details-marker{display:none}
.faq-item summary:hover{color:var(--wine-700)}
/* efeito ao apertar (tátil) */
.faq-item summary:active{transform:scale(.985)}
.faq-item summary:active .faq-plus{transform:scale(.86)}
.faq-item[open] summary:active .faq-plus{transform:rotate(180deg) scale(.86)}
/* ícone circular elegante (+ vira − ao abrir, com giro) */
.faq-plus{position:relative;width:32px;height:32px;border-radius:50%;flex:none;
  background:rgba(160,122,110,.14);color:var(--wine);
  transition:background .35s var(--ease), color .35s var(--ease), transform .45s var(--ease)}
.faq-plus::before,.faq-plus::after{content:"";position:absolute;top:50%;left:50%;
  background:currentColor;border-radius:2px;
  transition:transform .35s var(--ease), opacity .35s var(--ease)}
.faq-plus::before{width:13px;height:2px;transform:translate(-50%,-50%)}
.faq-plus::after{width:2px;height:13px;transform:translate(-50%,-50%)}
.faq-item[open] .faq-plus{background:var(--mauve-300);color:#fff;transform:rotate(180deg)}
.faq-item[open] .faq-plus::after{transform:translate(-50%,-50%) scaleY(0);opacity:0}
/* corpo animável (altura controlada via JS para abertura suave) */
.faq-body{overflow:hidden;box-sizing:border-box;padding:0 1.5rem 1.35rem;color:var(--muted);
  transition:height .42s var(--ease), opacity .35s ease}
.faq-body p{max-width:60ch;line-height:1.6}

/* =========================================================
   CTA
   ========================================================= */
.cta{position:relative;background:linear-gradient(135deg,var(--wine-900),var(--wine));color:var(--cream);padding-block:clamp(3.5rem,7vw,6.5rem);overflow:hidden}
.grain{position:absolute;inset:0;opacity:.5;mix-blend-mode:overlay;pointer-events:none;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='120' height='120'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.85' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='.35'/%3E%3C/svg%3E")}
.cta-bg{position:absolute;inset:0;opacity:.6}
.cta-inner{position:relative;text-align:center;max-width:760px;margin-inline:auto}
.cta-inner h2{font-size:clamp(2rem,1.4rem + 3vw,3.4rem);margin:1rem 0 1rem;color:var(--cream)}
.cta-inner h2 em{color:var(--mauve-300)}
.cta-inner>p{color:rgba(247,240,235,.8);font-size:1.1rem;margin-bottom:2rem}
/* ====== Cards de contato em NEON ====== */
.neo-info{
  list-style:none;display:grid;
  grid-template-columns:repeat(auto-fit,minmax(230px,1fr));
  gap:clamp(.9rem,2.2vw,1.4rem);
  /* escapa da coluna estreita do CTA para caber em 3 colunas no desktop */
  width:min(94vw, 1080px);
  margin-left:50%;transform:translateX(-50%);
  margin-top:clamp(2.6rem,5vw,3.4rem);
  padding-top:clamp(2rem,4vw,2.6rem);
  border-top:1px solid rgba(247,240,235,.16);
  text-align:left;
}
.neo-card{
  position:relative;
  border-radius:18px;
  /* entrada animada (escalonada por --i) */
  opacity:0;transform:translateY(26px);
  animation:neoIn .7s cubic-bezier(.2,.75,.25,1) forwards;
  animation-delay:calc(.12s * var(--i, 0) + .1s);
}
.neo-link{
  position:relative;display:flex;align-items:center;gap:1rem;
  padding:1.15rem 1.25rem;border-radius:inherit;
  text-decoration:none;color:var(--cream);
  background:
    linear-gradient(150deg, rgba(18,5,9,.66), rgba(44,11,19,.52));
  border:1px solid rgba(247,240,235,.14);
  box-shadow:inset 0 1px 0 rgba(247,240,235,.06);
  -webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);
  overflow:hidden;isolation:isolate;
  transition:transform .45s var(--ease), border-color .45s var(--ease),
             box-shadow .45s var(--ease), background .45s var(--ease);
}
/* halo neon que “respira” por trás do card */
.neo-card::before{
  content:"";position:absolute;inset:-1px;border-radius:inherit;
  padding:1px;
  background:linear-gradient(140deg,var(--neon),transparent 55%);
  -webkit-mask:linear-gradient(#000 0 0) content-box,linear-gradient(#000 0 0);
  -webkit-mask-composite:xor;mask-composite:exclude;
  opacity:.55;pointer-events:none;
  animation:neoBreath 3.4s ease-in-out infinite;
  animation-delay:calc(.4s * var(--i, 0));
}
/* feixe de luz que percorre o topo */
.neo-beam{
  position:absolute;top:0;left:-30%;width:30%;height:2px;
  background:linear-gradient(90deg,transparent,var(--neon),transparent);
  filter:drop-shadow(0 0 6px var(--neon));
  animation:neoBeam 4.6s linear infinite;
  animation-delay:calc(.9s * var(--i, 0));
  pointer-events:none;
}
.neo-ico{
  flex:none;display:grid;place-items:center;width:50px;height:50px;
  border-radius:13px;color:var(--neon);
  background:radial-gradient(circle at 30% 25%, color-mix(in srgb,var(--neon) 22%, transparent), transparent 70%);
  border:1px solid var(--neon-soft);
  box-shadow:0 0 14px -2px var(--neon-soft), inset 0 0 10px -4px var(--neon-soft);
  transition:box-shadow .45s var(--ease), transform .45s var(--ease);
}
.neo-ico .ico{width:24px;height:24px}
.neo-text{display:flex;flex-direction:column;gap:.18rem;min-width:0}
.neo-label{
  font-weight:700;font-size:.68rem;text-transform:uppercase;letter-spacing:.18em;
  color:var(--neon);text-shadow:0 0 10px var(--neon-soft);
}
.neo-value{
  font-family:var(--sans);font-weight:600;font-size:.98rem;line-height:1.25;
  color:var(--cream);word-break:break-word;
}
.neo-go{
  width:18px;height:18px;flex:none;margin-left:auto;color:var(--neon);
  opacity:0;transform:translateX(-6px);
  transition:opacity .4s var(--ease), transform .4s var(--ease);
}
/* hover / foco: acende o neon */
.neo-link:hover,.neo-link:focus-visible{
  transform:translateY(-6px);
  border-color:var(--neon-soft);
  background:linear-gradient(150deg, rgba(28,8,13,.72), rgba(60,16,26,.6));
  box-shadow:0 22px 46px -22px rgba(0,0,0,.7),
             0 0 26px -6px var(--neon-soft),
             inset 0 0 22px -14px var(--neon);
  outline:none;
}
.neo-link:hover .neo-ico,.neo-link:focus-visible .neo-ico{
  transform:scale(1.06);
  box-shadow:0 0 24px -2px var(--neon-soft), inset 0 0 14px -3px var(--neon-soft);
}
.neo-link:hover .neo-go,.neo-link:focus-visible .neo-go{opacity:1;transform:translateX(0)}
.neo-link:hover .neo-value,.neo-link:focus-visible .neo-value{text-shadow:0 0 18px var(--neon-soft)}

@keyframes neoIn{to{opacity:1;transform:translateY(0)}}
@keyframes neoBreath{0%,100%{opacity:.35}50%{opacity:.85}}
@keyframes neoBeam{
  0%{left:-30%}
  55%{left:100%}
  100%{left:100%}
}

/* =========================================================
   FOOTER
   ========================================================= */
.site-footer{background:var(--wine-900);color:rgba(247,240,235,.72)}
.footer-inner{display:grid;grid-template-columns:1.5fr 1fr 1.3fr;gap:2.5rem;padding-block:clamp(3rem,5vw,4.5rem)}
.footer-logo{height:84px;width:auto;margin-bottom:1.2rem}
.footer-brand p{max-width:36ch;font-size:.95rem;line-height:1.7}
.footer-nav h4,.footer-contact h4{font-family:var(--serif);color:var(--cream);font-size:1.05rem;margin-bottom:1.1rem;font-weight:500}
.footer-nav{display:flex;flex-direction:column;gap:.6rem}
.footer-nav a,.footer-contact a{transition:color .25s}
.footer-nav a:hover,.footer-contact a:hover{color:var(--cream)}
.footer-contact{display:flex;flex-direction:column;gap:.6rem;font-size:.95rem}
.footer-contact .crp{display:inline-block;margin-top:.4rem;padding:.3rem .8rem;border:1px solid rgba(247,240,235,.2);border-radius:100px;font-size:.8rem;letter-spacing:.05em;width:max-content}
.footer-base{border-top:1px solid rgba(247,240,235,.12)}
.footer-base-inner{display:flex;flex-wrap:wrap;justify-content:space-between;gap:.6rem;padding-block:1.4rem;font-size:.82rem;opacity:.7}

/* ---------- WhatsApp flutuante ---------- */
.whats-float{
  position:fixed;right:clamp(16px,3vw,28px);bottom:clamp(16px,3vw,28px);z-index:80;
  width:60px;height:60px;display:grid;place-items:center;border-radius:50%;
  background:var(--wine);color:var(--cream);box-shadow:0 14px 30px -8px rgba(44,11,19,.7);
  transition:transform .35s var(--ease);animation:floaty 3.5s ease-in-out infinite;
}
.whats-float .ico{width:30px;height:30px}
.whats-float:hover{transform:scale(1.08)}
@keyframes floaty{0%,100%{transform:translateY(0)}50%{transform:translateY(-6px)}}

/* =========================================================
   REVEAL (scroll)
   ========================================================= */
.reveal{opacity:0;transform:translateY(26px);transition:opacity .8s var(--ease),transform .8s var(--ease);transition-delay:var(--d,0s)}
.reveal.is-in{opacity:1;transform:none}

/* =========================================================
   DIVISÓRIAS DE SEÇÃO — ondas orgânicas + quebra ornamental
   ========================================================= */
.divider{position:relative;width:100%;line-height:0;z-index:5;pointer-events:none}
.divider svg{display:block;width:100%;height:clamp(64px,9vw,130px)}
.divider .wv-back{opacity:.5}
.divider .wv-line{fill:none;stroke:var(--mauve);stroke-width:2;opacity:.55;
  stroke-dasharray:2400;stroke-dashoffset:2400;transition:stroke-dashoffset 1.6s var(--ease)}
.divider.is-in .wv-line{stroke-dashoffset:0}
/* pequenos pontos luminosos que surgem sobre a onda */
.divider .wv-dot{fill:var(--mauve-300);opacity:0;transform-box:fill-box;transform-origin:center;
  transition:opacity .6s var(--ease),transform .6s var(--ease)}
.divider.is-in .wv-dot{opacity:.9}
.divider.is-in .wv-dot--1{transition-delay:.6s}
.divider.is-in .wv-dot--2{transition-delay:.85s}
.divider.is-in .wv-dot--3{transition-delay:1.1s}

/* cor das ondas conforme a direção da transição */
.divider--light-to-dark{background:var(--wine-900)}       /* clara em cima → escura embaixo */
.divider--light-to-dark .wv-front{fill:var(--cream-2)}
.divider--light-to-dark .wv-back{fill:var(--cream)}
.divider--dark-to-light{background:var(--cream)}          /* escura em cima → clara embaixo */
.divider--dark-to-light .wv-front{fill:var(--wine)}
.divider--dark-to-light .wv-back{fill:var(--wine-900)}

/* quebra ornamental (mesmo tom) */
.brk{display:flex;align-items:center;justify-content:center;gap:1.1rem;
  padding-block:clamp(1.5rem,4vw,2.6rem)}
.brk--cream{background:var(--cream)}
.brk--cream2{background:var(--cream-2)}
.brk i{height:1px;width:clamp(40px,12vw,120px);background:linear-gradient(90deg,transparent,var(--mauve-300))}
.brk i:last-child{background:linear-gradient(270deg,transparent,var(--mauve-300))}
.brk .brk-mark{position:relative;width:8px;height:8px;flex:none;border-radius:2px;
  background:var(--mauve-300);
  opacity:0;transform:scale(.4) rotate(0);transition:opacity .7s var(--ease),transform .7s var(--ease)}
.brk.is-in .brk-mark{opacity:1;transform:scale(1) rotate(45deg)}


@media (max-width:1024px){
  .hero{min-height:0;padding-bottom:clamp(3rem,7vw,5rem)}
  .hero-grid{grid-template-columns:1fr;gap:clamp(2.5rem,7vw,3.5rem);text-align:center}
  .hero-chip{margin-inline:auto}
  .hero h1{max-width:18ch;margin-inline:auto}
  .hero-lead{margin-inline:auto}
  .hero-actions{justify-content:center}
  .hero-creds{justify-content:center}
  .hero-stage{order:2;width:min(86%,400px)}
  .about-layout,.online-grid,.faq-grid{grid-template-columns:1fr;gap:2.5rem}
  .about-figure,.online-figure{max-width:440px}
  .at-line--2{padding-left:0}
  .online-figure{order:-1}
  .faq-intro{position:static}
}
@media (max-width:860px){
  .nav,.header-cta{display:none}
  .menu-toggle{display:flex}
  .nav.open{
    display:flex;flex-direction:column;position:absolute;top:100%;left:0;right:0;
    background:var(--cream-2);padding:1.4rem clamp(20px,5vw,40px);gap:1rem;
    border-bottom:1px solid var(--line);box-shadow:var(--shadow);margin-left:0;
  }
  .nav.open a{opacity:1;font-size:1.05rem}
}
@media (max-width:620px){
  .aud-grid,.steps{grid-template-columns:1fr}
  .hero-actions{flex-direction:column;align-items:stretch;gap:1.1rem}
  .hero-actions .btn{justify-content:center}
  .hero-textlink{justify-content:center}
  .hero-creds{flex-direction:column;align-items:center;gap:1.1rem;width:100%}
  .hero-creds li{justify-content:flex-start;width:max-content;max-width:100%;text-align:left}
  .hero-brain{right:50%;transform:translate(50%,-50%);opacity:.09;width:min(86vw,420px)}
  .hero-stage{width:min(92%,340px)}
  .float-card{padding:.55rem .75rem}
  .float-card strong{font-size:.88rem}
  .float-card small{font-size:.68rem}
  .float-card--brain{left:-2%;top:4%}
  .float-card--crp{right:-2%}
  .float-card--online{left:-2%;bottom:6%}
  .neo-info{grid-template-columns:1fr}
  .footer-inner{grid-template-columns:1fr;gap:2rem}
  .ribbon-track{font-size:1.05rem}
}

@media (prefers-reduced-motion:reduce){
  /* mantemos as animações decorativas sutis (flutuação, pulso das tags, brilho),
     pois são leves; apenas garantimos que todo conteúdo apareça mesmo sem scroll. */
  html{scroll-behavior:auto}
  .reveal{opacity:1 !important;transform:none !important}
  .hl .w,.hl .w-in{opacity:1 !important;transform:none !important;filter:none !important}
  .at-line{opacity:1 !important;transform:none !important}
  .cred-bar{opacity:1 !important;transform:none !important}
  .neo-card{opacity:1 !important;transform:none !important;animation:none !important}
  .neo-card::before{animation:none !important;opacity:.55 !important}
  .neo-beam{display:none !important}
  .step::before{display:none !important}
  .step:hover,.step:focus-within,.step.is-touched{transform:none !important}
  .hero-creds li{opacity:1 !important;transform:none !important;animation:none !important}
  .hero-creds .ico{animation:none !important}
  .fig-badge{opacity:1 !important;transform:none !important;animation:none !important}
  .divider .wv-line{stroke-dashoffset:0 !important}
  .divider .wv-dot{opacity:.9 !important}
  .brk .brk-mark{opacity:1 !important;transform:none !important}
}

/* =========================================================
   ACESSIBILIDADE — skip link + foco visível (padrões 2026)
   ========================================================= */
.skip-link{position:absolute;left:-9999px;top:0;z-index:2000;
  background:var(--wine);color:var(--cream);padding:.75rem 1.15rem;
  border-radius:0 0 12px 0;font-weight:600;text-decoration:none;
  box-shadow:0 8px 24px -10px rgba(0,0,0,.5)}
.skip-link:focus{left:0}
:focus-visible{outline:2px solid var(--mauve-300);outline-offset:3px;border-radius:3px}
