/* ============================================================
   CLÍNICA RESSIGNIFIQUE — design system
   Estética feminina, terrosa, delicada. Mobile-first.
   ============================================================ */

:root{
  /* — palette — */
  --cream:    #F4EDDD;   /* page background */
  --cream-2:  #FBF6EA;   /* cards / lighter surface */
  --cream-3:  #ECE1CC;   /* subtle blocks / hover */
  --sand:     #E4D5BC;
  --ink:      #3A2416;   /* primary text */
  --ink-soft: #6E5743;   /* muted text */
  --brown:    #432A1A;   /* deep brand brown */
  --brown-2:  #5C3A24;
  --brown-3:  #2C1B11;   /* near-black brown */
  --gold:     #AE8348;   /* accent */
  --gold-2:   #C6A36A;
  --gold-soft:#D9C29A;
  --sage:     #BBD0BF;   /* sage accent (sparing) */
  --sage-deep:#8DAE96;
  --line:     rgba(67,42,26,.16);
  --line-2:   rgba(67,42,26,.30);

  --serif: 'Cormorant Garamond', Georgia, 'Times New Roman', serif;
  --sans:  'Jost', system-ui, -apple-system, sans-serif;

  --maxw: 1180px;
  --r:    18px;   /* card radius */
  --ease: cubic-bezier(.22,.61,.36,1);
}

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

/* ---------- typography helpers ---------- */
.serif{ font-family:var(--serif); }
h1,h2,h3,h4{ font-family:var(--serif); font-weight:500; line-height:1.04; letter-spacing:-.01em; }
em,.it{ font-style:italic; }

.eyebrow{
  font-family:var(--sans);
  font-size:.72rem; font-weight:500;
  letter-spacing:.32em; text-transform:uppercase;
  color:var(--gold);
  display:inline-flex; align-items:center; gap:.7em;
}
.eyebrow::before{ content:""; width:26px; height:1px; background:var(--gold); opacity:.7; }
.eyebrow.center::after{ content:""; width:26px; height:1px; background:var(--gold); opacity:.7; }
.eyebrow.center{ justify-content:center; }

.lead{ font-size:1.12rem; color:var(--ink-soft); font-weight:300; }

/* ---------- layout ---------- */
.wrap{ width:100%; max-width:var(--maxw); margin:0 auto; padding:0 22px; }
section{ position:relative; }
.pad{ padding:84px 0; }
.pad-lg{ padding:108px 0; }

/* ---------- buttons ---------- */
.btn{
  display:inline-flex; align-items:center; justify-content:center; gap:.6em;
  font-family:var(--sans); font-weight:400; font-size:.84rem;
  letter-spacing:.16em; text-transform:uppercase;
  padding:17px 32px; border-radius:100px;
  background:var(--brown); color:var(--cream-2);
  transition:transform .4s var(--ease), background .4s var(--ease), box-shadow .4s var(--ease);
  box-shadow:0 10px 30px -14px rgba(67,42,26,.6);
}
.btn:hover{ transform:translateY(-2px); background:var(--brown-2); box-shadow:0 16px 34px -14px rgba(67,42,26,.7); }
.btn-gold{ background:linear-gradient(135deg,var(--gold-2),var(--gold)); color:#3a2410; box-shadow:0 12px 32px -14px rgba(174,131,72,.8); }
.btn-gold:hover{ background:linear-gradient(135deg,var(--gold-2),var(--gold-2)); }
.btn-ghost{ background:transparent; color:var(--ink); border:1px solid var(--line-2); box-shadow:none; }
.btn-ghost:hover{ background:var(--ink); color:var(--cream-2); border-color:var(--ink); }
.btn-light{ background:var(--cream-2); color:var(--brown); }
.btn-sm{ padding:13px 24px; font-size:.76rem; }

/* arrow link */
.alink{
  display:inline-flex; align-items:center; gap:.5em;
  font-size:.78rem; letter-spacing:.18em; text-transform:uppercase; color:var(--gold);
  border-bottom:1px solid transparent; padding-bottom:3px; transition:.3s var(--ease);
}
.alink:hover{ border-color:var(--gold); gap:.9em; }

/* ============================================================
   NAV
   ============================================================ */
.nav{
  position:fixed; top:0; left:0; right:0; z-index:90;
  display:flex; align-items:center; justify-content:space-between;
  padding:18px 22px;
  transition:background .5s var(--ease), padding .5s var(--ease), box-shadow .5s var(--ease);
}
.nav.scrolled{
  background:rgba(244,237,221,.86);
  backdrop-filter:blur(14px); -webkit-backdrop-filter:blur(14px);
  padding:11px 22px;
  box-shadow:0 1px 0 var(--line), 0 12px 40px -28px rgba(67,42,26,.5);
}
.nav__logo{ height:54px; transition:height .5s var(--ease), filter .5s var(--ease); }
.nav.scrolled .nav__logo{ height:44px; }
/* logo: always brown (light hero) */
.nav__logo.cream{ display:none; }
.nav__logo.brown{ display:block; }

.nav__links{ display:none; align-items:center; gap:30px; }
.nav__links a{
  font-size:.8rem; letter-spacing:.13em; text-transform:uppercase; font-weight:400;
  color:var(--ink); position:relative; transition:color .3s;
}
.nav__links a::after{ content:""; position:absolute; left:0; bottom:-6px; width:0; height:1px; background:var(--gold); transition:width .3s var(--ease); }
.nav__links a:hover::after{ width:100%; }
.nav__cta{ display:none; }

.nav__burger{ display:flex; flex-direction:column; gap:5px; padding:8px; z-index:95; }
.nav__burger span{ width:26px; height:2px; background:var(--ink); border-radius:2px; transition:.35s var(--ease); }
.nav.scrolled .nav__burger span{ background:var(--ink); }
.nav__burger.open span{ background:var(--cream-2); }
.nav__burger.open span:nth-child(1){ transform:translateY(7px) rotate(45deg); }
.nav__burger.open span:nth-child(2){ opacity:0; }
.nav__burger.open span:nth-child(3){ transform:translateY(-7px) rotate(-45deg); }

/* mobile drawer */
.drawer{
  position:fixed; inset:0; z-index:92;
  background:var(--brown-3);
  display:flex; flex-direction:column; justify-content:center; gap:6px;
  padding:60px 32px;
  transform:translateY(-100%); transition:transform .6s var(--ease);
  opacity:0; pointer-events:none;
}
.drawer.open{ transform:translateY(0); opacity:1; pointer-events:auto; }
.drawer a{
  font-family:var(--serif); font-size:2.2rem; color:var(--cream); font-weight:500;
  padding:9px 0; border-bottom:1px solid rgba(244,237,221,.12);
  display:flex; align-items:baseline; gap:14px;
  opacity:0; transform:translateY(18px); transition:opacity .5s var(--ease), transform .5s var(--ease);
}
.drawer.open a{ opacity:1; transform:translateY(0); }
.drawer a .num{ font-family:var(--sans); font-size:.7rem; letter-spacing:.2em; color:var(--gold-2); font-weight:400; }
.drawer a:hover{ color:var(--gold-2); }
.drawer__foot{ margin-top:34px; color:var(--gold-soft); font-size:.85rem; letter-spacing:.05em; opacity:0; transition:opacity .6s .3s; }
.drawer.open .drawer__foot{ opacity:1; }

/* ============================================================
   HERO  (light, elegant arched-portrait split)
   ============================================================ */
.hero{
  position:relative; min-height:100svh;
  display:flex; align-items:flex-end;
  overflow:hidden;
  background:
    radial-gradient(120% 90% at 85% 0%, var(--cream-2) 0%, var(--cream) 42%, var(--sand) 120%);
}
/* soft decorative blooms */
.hero::before{
  content:""; position:absolute; inset:0; z-index:0; pointer-events:none;
  background:
    radial-gradient(40% 40% at 12% 18%, rgba(174,131,72,.12), transparent 70%),
    radial-gradient(46% 46% at 92% 78%, rgba(141,174,150,.16), transparent 70%);
}
.hero__inner{
  position:relative; z-index:2; width:100%; max-width:var(--maxw); margin:0 auto;
  padding:120px 22px 56px;
  display:flex; flex-direction:column; gap:34px;
}
.hero__copy{ max-width:560px; }
.hero__eyebrow{ color:var(--gold); }
.hero__eyebrow::before{ background:var(--gold); }
.hero h1{
  color:var(--ink); font-size:clamp(3rem,13.5vw,6.6rem); line-height:.95; margin:18px 0 0;
  letter-spacing:-.02em; font-weight:500;
}
.hero h1 em{ color:var(--gold); }
.hero__sub{ color:var(--ink-soft); max-width:34ch; margin:24px 0 30px; font-size:1.1rem; font-weight:300; }
.hero__actions{ display:flex; flex-wrap:wrap; gap:14px; }

/* arched portrait */
.hero__portrait{ position:relative; align-self:center; width:min(78%,360px); }
.hero__arch{
  position:relative; border-radius:1000px 1000px 26px 26px; overflow:hidden;
  aspect-ratio:3/3.8; box-shadow:0 50px 90px -46px rgba(67,42,26,.6);
  border:1px solid rgba(255,255,255,.6);
}
.hero__arch::after{ content:""; position:absolute; inset:0; border-radius:inherit; box-shadow:inset 0 0 0 6px rgba(251,246,234,.55); }
.hero__arch img{ width:100%; height:100%; object-fit:cover; object-position:50% 14%; will-change:transform; }
.hero__ring{ position:absolute; inset:-14px; border:1px solid var(--gold-soft); border-radius:1000px 1000px 34px 34px; pointer-events:none; opacity:.7; }
.hero__badge{
  position:absolute; right:-6px; bottom:18px; z-index:3;
  background:var(--cream-2); border:1px solid var(--line); border-radius:14px;
  padding:12px 16px; box-shadow:0 24px 44px -26px rgba(67,42,26,.55);
  display:flex; align-items:center; gap:10px;
}
.hero__badge .st{ color:var(--gold); font-size:.8rem; letter-spacing:2px; }
.hero__badge b{ font-family:var(--serif); font-size:1rem; color:var(--ink); font-weight:600; line-height:1; }
.hero__badge span{ display:block; font-size:.64rem; letter-spacing:.14em; text-transform:uppercase; color:var(--ink-soft); margin-top:2px; }
.hero__bf{ position:absolute; left:-26px; top:6px; width:62px; opacity:.5; z-index:3; animation:float 5s var(--ease) infinite; }
@keyframes float{ 0%,100%{ transform:translateY(0) rotate(-4deg); } 50%{ transform:translateY(-12px) rotate(2deg); } }

.hero__scroll{
  position:absolute; bottom:18px; left:50%; transform:translateX(-50%); z-index:3;
  color:var(--ink-soft); font-size:.62rem; letter-spacing:.3em; text-transform:uppercase;
  display:flex; flex-direction:column; align-items:center; gap:8px;
}
.hero__scroll i{ width:1px; height:30px; background:linear-gradient(var(--gold),transparent); animation:scrollPulse 2.4s var(--ease) infinite; }
@keyframes scrollPulse{ 0%,100%{ transform:scaleY(.4); opacity:.4; transform-origin:top; } 50%{ transform:scaleY(1); opacity:1; transform-origin:top; } }

@media (min-width:860px){
  .hero{ align-items:center; }
  .hero__inner{ flex-direction:row; align-items:center; justify-content:space-between; gap:48px; padding:104px 22px 60px; }
  .hero__copy{ flex:1; }
  .hero__portrait{ flex:none; width:min(42%,420px); align-self:center; }
}

/* hero word reveal */
.reveal-hero > *{ opacity:0; transform:translateY(26px); animation:heroIn 1s var(--ease) forwards; }
.reveal-hero > *:nth-child(1){ animation-delay:.15s; }
.reveal-hero > *:nth-child(2){ animation-delay:.32s; }
.reveal-hero > *:nth-child(3){ animation-delay:.5s; }
.reveal-hero > *:nth-child(4){ animation-delay:.66s; }
@keyframes heroIn{ to{ opacity:1; transform:none; } }

/* ============================================================
   SCROLL REVEAL
   ============================================================ */
.reveal{ opacity:0; transform:translateY(34px); transition:opacity 1s var(--ease), transform 1s var(--ease); }
.reveal.in{ opacity:1; transform:none; }
.reveal.d1{ transition-delay:.1s; } .reveal.d2{ transition-delay:.2s; }
.reveal.d3{ transition-delay:.3s; } .reveal.d4{ transition-delay:.4s; }
@media (prefers-reduced-motion: reduce){
  .reveal,.reveal-hero>*{ opacity:1 !important; transform:none !important; animation:none !important; }
  html{ scroll-behavior:auto; }
}

/* ============================================================
   SECTION HEADERS
   ============================================================ */
.shead{ max-width:720px; }
.shead.center{ margin:0 auto; text-align:center; }
.shead h2{ font-size:clamp(2.4rem,7.5vw,4.2rem); margin:16px 0 0; color:var(--ink); }
.shead h2 em{ color:var(--gold); }
.shead p{ margin-top:18px; color:var(--ink-soft); font-size:1.05rem; }

/* ============================================================
   SOBRE / FOUNDER
   ============================================================ */
.about{ background:var(--cream); }
.about__grid{ display:grid; gap:38px; align-items:center; }
.about__media{ position:relative; }
.about__media .ph{
  width:100%; border-radius:var(--r); overflow:hidden; aspect-ratio:3/4;
  box-shadow:0 40px 80px -50px rgba(67,42,26,.7);
}
.about__media .ph img{ width:100%; height:100%; object-fit:cover; object-position:50% 0%; }
.about__media .badge{
  position:absolute; left:-14px; bottom:-18px;
  background:var(--brown); color:var(--cream-2); border-radius:14px;
  padding:18px 22px; box-shadow:0 24px 50px -28px rgba(67,42,26,.8);
  display:flex; flex-direction:column; gap:2px;
}
.about__media .badge b{ font-family:var(--serif); font-size:2.2rem; line-height:1; color:var(--gold-2); font-weight:600; }
.about__media .badge span{ font-size:.7rem; letter-spacing:.18em; text-transform:uppercase; opacity:.85; }
.about__body h2{ font-size:clamp(2.2rem,6.5vw,3.6rem); margin:14px 0 0; }
.about__body h2 em{ color:var(--gold); }
.about__body .sig{ font-family:var(--serif); font-style:italic; font-size:1.5rem; color:var(--brown-2); margin-top:6px; }
.about__body p{ margin-top:18px; color:var(--ink-soft); }
.about__quote{
  margin-top:26px; padding-left:22px; border-left:2px solid var(--gold);
  font-family:var(--serif); font-style:italic; font-size:1.42rem; color:var(--ink); line-height:1.4;
}

/* ============================================================
   FILOSOFIA (brown band)
   ============================================================ */
.philo{ background:var(--brown-3); color:var(--cream); overflow:hidden; }
.philo::before{
  content:""; position:absolute; inset:0;
  background:radial-gradient(80% 60% at 15% 0%, rgba(174,131,72,.18), transparent 60%),
             radial-gradient(70% 60% at 100% 100%, rgba(174,131,72,.12), transparent 55%);
  pointer-events:none;
}
.philo .wrap{ position:relative; z-index:1; }
.philo h2{ font-size:clamp(2.2rem,7vw,4rem); color:var(--cream); max-width:18ch; }
.philo h2 em{ color:var(--gold-2); }
.philo p{ color:rgba(244,237,221,.74); max-width:46ch; margin-top:22px; font-size:1.08rem; }
.philo__lines{ margin-top:46px; display:grid; gap:0; }
.philo__line{
  display:flex; align-items:center; gap:18px; padding:22px 0;
  border-top:1px solid rgba(244,237,221,.14);
  font-family:var(--serif); font-size:clamp(1.6rem,5vw,2.4rem); font-weight:500;
}
.philo__line:last-child{ border-bottom:1px solid rgba(244,237,221,.14); }
.philo__line .mk{ color:var(--gold-2); font-size:1.1rem; font-family:var(--sans); }
.philo__line b{ color:var(--gold-2); font-weight:500; }

/* rotating manifesto line */
.philo__rotator{
  margin-top:46px; display:flex; gap:20px; align-items:flex-start;
  border-top:1px solid rgba(244,237,221,.14); border-bottom:1px solid rgba(244,237,221,.14);
  padding:36px 0;
}
.philo__rotator .mk{ color:var(--gold-2); font-size:1.3rem; font-family:var(--sans); line-height:1; margin-top:.45em; flex:none; }
.rot__stack{ flex:1; min-width:0; }
.rot__fixed{
  display:block; font-family:var(--serif); font-weight:500; color:var(--cream);
  font-size:clamp(1.9rem,5.6vw,2.9rem); line-height:1.04; letter-spacing:.005em;
}
.rot__slot{
  position:relative; display:block; overflow:hidden; margin-top:6px;
  font-size:clamp(1.5rem,4.6vw,2.4rem); height:2.5em;
}
.rot__w{
  position:absolute; left:0; top:0; width:100%; height:100%;
  display:flex; align-items:center;
  font-family:var(--serif); font-style:italic; font-weight:500; color:var(--gold-2);
  font-size:1em; line-height:1.15;
  opacity:0; transform:translateY(.5em);
  transition:opacity .6s var(--ease), transform .7s var(--ease);
  pointer-events:none;
}
.rot__w.is-active{ opacity:1; transform:translateY(0); }
.rot__w.is-out{ opacity:0; transform:translateY(-.5em); }
@media (prefers-reduced-motion: reduce){
  .rot__w{ transition:none; }
}

.philo__layout{ display:grid; gap:40px; }
.philo__media{ border-radius:var(--r); overflow:hidden; box-shadow:0 40px 80px -50px rgba(0,0,0,.8); aspect-ratio:4/3; }
.philo__media img{ width:100%; height:100%; object-fit:cover; }
@media (min-width:860px){
  .philo__layout{ grid-template-columns:1.15fr .85fr; gap:64px; align-items:center; }
  .philo__media{ aspect-ratio:3/4; }
}

/* ============================================================
   QUOTE DIVIDER (parallax band)
   ============================================================ */
.qdivider{ position:relative; min-height:62vh; display:flex; align-items:center; justify-content:center; overflow:hidden; background:var(--brown-3); }
.qdivider__bg{ position:absolute; inset:0; }
.qdivider__bg img{ width:100%; height:100%; object-fit:cover; object-position:50% 40%; }
.qdivider__bg::after{ content:""; position:absolute; inset:0; background:linear-gradient(180deg,rgba(44,27,17,.7),rgba(44,27,17,.55)); }
.qdivider__inner{ position:relative; z-index:1; max-width:760px; padding:64px 26px; text-align:center; }
.qdivider__inner p{ font-family:var(--serif); font-style:italic; font-size:clamp(1.6rem,5vw,2.6rem); line-height:1.32; color:var(--cream); margin-top:18px; }

/* ============================================================
   PROCEDIMENTOS
   ============================================================ */
.proc{ background:var(--cream); }
.proc__filters{
  display:flex; gap:10px; flex-wrap:wrap; margin:30px 0 8px;
}
.chip{
  font-family:var(--sans); font-size:.78rem; letter-spacing:.1em; text-transform:uppercase; font-weight:400;
  padding:11px 19px; border-radius:100px; border:1px solid var(--line-2); color:var(--ink-soft);
  transition:.3s var(--ease); white-space:nowrap; background:transparent;
}
.chip:hover{ border-color:var(--brown); color:var(--brown); }
.chip.active{ background:var(--brown); color:var(--cream-2); border-color:var(--brown); }

.proc__grid{
  margin-top:30px;
  display:grid; grid-template-columns:1fr; gap:14px;
}
.pcard{
  background:var(--cream-2); border:1px solid var(--line); border-radius:16px;
  overflow:hidden; transition:transform .5s var(--ease), box-shadow .5s var(--ease), border-color .4s;
}
.pcard:hover{ box-shadow:0 26px 50px -34px rgba(67,42,26,.55); border-color:var(--line-2); }
.pcard__head{
  display:flex; align-items:center; gap:16px; width:100%; text-align:left;
  padding:20px 22px;
}
.pcard__icon{
  flex:none; width:44px; height:44px; border-radius:50%; overflow:hidden;
  display:grid; place-items:center; background:var(--cream-3); color:var(--gold);
  font-family:var(--serif); font-size:1.3rem; font-weight:600; border:1px solid var(--line);
}
.pcard__icon.ph{ background-image:repeating-linear-gradient(45deg,var(--cream-3) 0 5px,var(--cream-2) 5px 10px); }
.pcard__icon.has-img{ color:transparent; }
.pcard__icon img{ width:100%; height:100%; object-fit:cover; display:block; }
.pcard__t{ flex:1; min-width:0; }
.pcard__t b{ font-family:var(--serif); font-weight:600; font-size:1.32rem; color:var(--ink); display:block; line-height:1.1; }
.pcard__t span{ font-size:.92rem; color:var(--ink-soft); display:block; margin-top:3px; }
.pcard__plus{ flex:none; width:30px; height:30px; border-radius:50%; border:1px solid var(--line-2); position:relative; transition:.4s var(--ease); }
.pcard__plus::before,.pcard__plus::after{ content:""; position:absolute; background:var(--brown); border-radius:2px; top:50%; left:50%; transition:.4s var(--ease); }
.pcard__plus::before{ width:11px; height:1.5px; transform:translate(-50%,-50%); }
.pcard__plus::after{ width:1.5px; height:11px; transform:translate(-50%,-50%); }
.pcard.open .pcard__plus{ background:var(--brown); border-color:var(--brown); transform:rotate(90deg); }
.pcard.open .pcard__plus::before,.pcard.open .pcard__plus::after{ background:var(--cream-2); }
.pcard.open .pcard__plus::after{ opacity:0; }
.pcard__body{ max-height:0; overflow:hidden; transition:max-height .55s var(--ease); }
.pcard__body .inner{ padding:0 22px 24px 82px; color:var(--ink-soft); font-size:1rem; }
.pcard__photo{ margin:0 0 18px; border-radius:14px; overflow:hidden; border:1px solid var(--line); aspect-ratio:16/9; background:var(--cream-3); }
.pcard__photo img{ width:100%; height:100%; object-fit:cover; display:block; }
.pcard__photo.ph{ display:grid; place-items:center; background-image:repeating-linear-gradient(45deg,var(--cream-3) 0 9px,var(--cream-2) 9px 18px); }
.pcard__photo.ph span{ font-family:ui-monospace,Menlo,Consolas,monospace; font-size:.66rem; letter-spacing:.14em; text-transform:uppercase; color:var(--ink-soft); background:var(--cream-2); padding:5px 12px; border-radius:999px; border:1px solid var(--line); }
.pcard__desc{ margin:0; }
.pcard__body .inner .tag{ display:block; margin-top:14px; font-size:.68rem; letter-spacing:.18em; text-transform:uppercase; color:var(--gold); }
@media (max-width:560px){ .pcard__body .inner{ padding-left:22px; } }

.proc__count{ font-size:.8rem; letter-spacing:.14em; text-transform:uppercase; color:var(--ink-soft); margin-top:26px; }
.proc__count b{ color:var(--brown); }

/* protocolos */
.protocols{ margin-top:54px; padding:32px; border-radius:var(--r); background:var(--cream-2); border:1px solid var(--line); }
.protocols h3{ font-size:1.7rem; }
.protocols h3 em{ color:var(--gold); }
.protocols .tags{ display:flex; flex-wrap:wrap; gap:10px; margin-top:18px; }
.protocols .tags span{
  font-size:.84rem; padding:9px 16px; border-radius:100px; background:var(--cream-3);
  color:var(--brown-2); border:1px solid var(--line); letter-spacing:.02em;
}

/* ============================================================
   CLUBE  (dark premium)
   ============================================================ */
.club{ background:var(--brown-3); color:var(--cream); overflow:hidden; }
.club::before{
  content:""; position:absolute; inset:0; pointer-events:none;
  background:radial-gradient(90% 70% at 85% -5%, rgba(174,131,72,.22), transparent 55%),
             radial-gradient(70% 60% at 0% 100%, rgba(174,131,72,.12), transparent 55%);
}
.club .wrap{ position:relative; z-index:1; }
.club .eyebrow{ color:var(--gold-2); } .club .eyebrow::before{ background:var(--gold-2); }
.club h2{ color:var(--cream); font-size:clamp(2.6rem,8.5vw,5rem); margin-top:14px; }
.club h2 em{ color:var(--gold-2); }
.club__intro{ color:rgba(244,237,221,.78); max-width:48ch; margin-top:20px; font-size:1.1rem; }

/* membership card */
.club__cardwrap{ margin-top:46px; perspective:1400px; }
.memcard{
  position:relative; width:100%; max-width:430px; margin:0 auto; aspect-ratio:1.586/1;
  border-radius:22px; padding:26px 28px;
  background:
    linear-gradient(150deg, #6A4427 0%, #43291A 48%, #2C1B11 100%);
  box-shadow:0 50px 90px -40px rgba(0,0,0,.8), inset 0 1px 0 rgba(255,255,255,.08);
  color:var(--cream); overflow:hidden;
  display:flex; flex-direction:column; justify-content:space-between;
  transform:rotateX(6deg) rotateY(-7deg); transition:transform .8s var(--ease);
}
.club__cardwrap:hover .memcard{ transform:rotateX(2deg) rotateY(-2deg); }
.memcard::after{
  content:""; position:absolute; top:-60%; left:-30%; width:80%; height:220%;
  background:linear-gradient(90deg, transparent, rgba(255,255,255,.14), transparent);
  transform:rotate(18deg); animation:shine 6s var(--ease) infinite;
}
@keyframes shine{ 0%,60%{ left:-40%; } 100%{ left:130%; } }
.memcard__top{ display:flex; justify-content:space-between; align-items:flex-start; }
.memcard__top .lg{ height:46px; opacity:.95; }
.memcard__chip{ width:42px; height:32px; border-radius:7px; background:linear-gradient(135deg,var(--gold-2),#8a6a3c); box-shadow:inset 0 1px 2px rgba(255,255,255,.4); }
.memcard__name{ font-family:var(--serif); font-size:1.9rem; font-weight:600; line-height:1; }
.memcard__name span{ display:block; font-family:var(--sans); font-size:.6rem; letter-spacing:.36em; text-transform:uppercase; color:var(--gold-2); margin-top:8px; font-weight:400; }
.memcard__foot{ display:flex; justify-content:space-between; align-items:flex-end; font-size:.72rem; letter-spacing:.1em; }
.memcard__foot .holder{ text-transform:uppercase; opacity:.7; }
.memcard__bf{ position:absolute; right:-30px; bottom:-40px; width:200px; opacity:.10; }

/* benefits */
.club__benefits{ margin-top:60px; display:grid; gap:16px; }
.bcard{ background:rgba(244,237,221,.05); border:1px solid rgba(244,237,221,.12); border-radius:16px; padding:26px 24px; transition:.4s var(--ease); }
.bcard:hover{ background:rgba(244,237,221,.08); border-color:rgba(174,131,72,.5); transform:translateY(-3px); }
.bcard .ic{ font-family:var(--serif); font-size:1.6rem; color:var(--gold-2); }
.bcard b{ display:block; font-family:var(--serif); font-size:1.5rem; font-weight:600; margin-top:10px; color:var(--cream); }
.bcard p{ color:rgba(244,237,221,.7); font-size:.96rem; margin-top:8px; }
.bcard .big{ font-family:var(--serif); font-size:2.6rem; color:var(--gold-2); font-weight:600; line-height:1; }

/* discount table */
.club__disc{ margin-top:56px; }
.disc-h{ display:flex; align-items:baseline; justify-content:space-between; flex-wrap:wrap; gap:10px; }
.disc-h h3{ color:var(--cream); font-size:clamp(1.8rem,5vw,2.6rem); }
.disc-h h3 em{ color:var(--gold-2); }
.disc-h .note{ font-size:.78rem; letter-spacing:.12em; text-transform:uppercase; color:var(--gold-soft); }
.disclist{ margin-top:24px; border-top:1px solid rgba(244,237,221,.14); }
.disrow{
  display:flex; align-items:center; justify-content:space-between; gap:16px;
  padding:18px 4px; border-bottom:1px solid rgba(244,237,221,.14);
}
.disrow .nm{ font-family:var(--serif); font-size:1.3rem; color:var(--cream); }
.disrow .nm small{ display:block; font-family:var(--sans); font-size:.8rem; color:rgba(244,237,221,.6); letter-spacing:.02em; }
.disrow .pc{ flex:none; display:flex; align-items:center; gap:14px; }
.disrow .pc .prices{ display:flex; flex-direction:column; align-items:flex-end; line-height:1.05; }
.disrow .pc .prices .from{ font-size:.78rem; color:rgba(244,237,221,.5); text-decoration:line-through; }
.disrow .pc .prices .to{ font-family:var(--serif); font-size:1.5rem; font-weight:600; color:var(--cream); }
.disrow .pc .off{
  flex:none; font-family:var(--sans); font-size:.74rem; font-weight:500; letter-spacing:.04em;
  color:var(--gold-2); background:rgba(174,131,72,.16); border:1px solid rgba(174,131,72,.4);
  padding:5px 9px; border-radius:100px; white-space:nowrap;
}
.disrow--more .nm{ font-style:italic; color:var(--gold-soft); }
.disrow--more .more-link{
  flex:none; font-family:var(--sans); font-size:.78rem; font-weight:500; letter-spacing:.04em;
  color:var(--gold-2); background:rgba(174,131,72,.16); border:1px solid rgba(174,131,72,.4);
  padding:8px 16px; border-radius:100px; white-space:nowrap; transition:background .25s ease;
}
.disrow--more .more-link:hover{ background:rgba(174,131,72,.28); }

/* partners */
.club__partners{ margin-top:60px; }
.club__partners h3{ color:var(--cream); font-size:clamp(1.7rem,5vw,2.4rem); }
.club__partners h3 em{ color:var(--gold-2); }
.club__partners > p{ color:rgba(244,237,221,.7); margin-top:12px; max-width:50ch; }
.partner-grid{ margin-top:26px; display:grid; grid-template-columns:repeat(2,1fr); gap:12px; }
.partner{
  border:1px dashed rgba(244,237,221,.28); border-radius:14px; padding:22px 16px; text-align:center;
  display:flex; flex-direction:column; align-items:center; gap:6px; transition:.4s var(--ease);
}
.partner:hover{ border-color:var(--gold-2); background:rgba(244,237,221,.04); }
.partner .pi{ width:42px; height:42px; border-radius:50%; background:rgba(174,131,72,.18); display:grid; place-items:center; color:var(--gold-2); font-family:var(--serif); font-size:1.2rem; }
.partner b{ font-family:var(--serif); font-size:1.15rem; color:var(--cream); font-weight:500; line-height:1.15; margin-bottom:2px; }
.partner span{ font-size:.74rem; color:var(--gold-soft); letter-spacing:.06em; }

/* pricing CTA */
.club__price{
  margin-top:64px; background:linear-gradient(150deg,var(--cream-2),var(--cream-3));
  color:var(--ink); border-radius:26px; padding:48px 34px; text-align:center; position:relative; overflow:hidden;
}
.club__price .eyebrow{ color:var(--gold); } .club__price .eyebrow::before,.club__price .eyebrow.center::after{ background:var(--gold); }
.club__price h3{ font-size:clamp(2rem,6vw,3rem); margin-top:14px; color:var(--brown); }
.price-tag{ display:flex; align-items:baseline; justify-content:center; gap:6px; margin:22px 0 18px; }
.price-tag .cur{ font-family:var(--serif); font-size:1.6rem; color:var(--gold); align-self:flex-start; margin-top:10px; }
.price-tag .val{ font-family:var(--serif); font-size:clamp(4rem,18vw,6.4rem); font-weight:600; line-height:1; color:var(--brown); }
.price-tag .per{ font-size:.9rem; letter-spacing:.1em; color:var(--ink-soft); }
.club__price .sub{ color:var(--ink-soft); max-width:40ch; margin:8px auto 26px; }
.club__price .micro{ margin-top:16px; font-size:.78rem; color:var(--ink-soft); letter-spacing:.04em; }

/* ============================================================
   DEPOIMENTOS
   ============================================================ */
.testi{ background:var(--cream); }
.testi__grid{ margin-top:38px; display:grid; gap:16px; }
.tcard{ background:var(--cream-2); border:1px solid var(--line); border-radius:var(--r); padding:30px 28px; transition:.5s var(--ease); }
.tcard:hover{ box-shadow:0 30px 60px -42px rgba(67,42,26,.55); transform:translateY(-3px); }
.tcard .qm{ font-family:var(--serif); font-size:3rem; color:var(--gold-soft); line-height:.5; }
.tcard p{ font-family:var(--serif); font-style:italic; font-size:1.3rem; color:var(--ink); line-height:1.4; margin-top:8px; }
.tcard .who{ display:flex; align-items:center; gap:12px; margin-top:22px; }
.tcard .who .av{ width:42px; height:42px; border-radius:50%; background:var(--cream-3); border:1px solid var(--line); display:grid; place-items:center; font-family:var(--serif); color:var(--gold); font-weight:600; }
.tcard .who b{ font-size:.95rem; color:var(--ink); font-weight:500; }
.tcard .who span{ display:block; font-size:.78rem; color:var(--ink-soft); }
.stars{ color:var(--gold); letter-spacing:3px; font-size:.9rem; }

/* before/after — galeria coverflow */
.bagal{ margin-top:64px; }
.bagal__head{ text-align:center; max-width:660px; margin:0 auto; }
.bagal__head h3{ font-size:clamp(1.9rem,5.5vw,2.9rem); color:var(--ink); margin-top:14px; line-height:1.06; }
.bagal__head h3 em{ color:var(--gold); }
.bagal__head p{ margin-top:14px; color:var(--ink-soft); font-size:.95rem; }

.bagal__stage{
  position:relative; margin-top:36px;
  height:clamp(330px, 86vw, 520px);
  perspective:1700px;
  overflow-x:clip;   /* contém o sangramento horizontal dos slides sem esticar a página nem cortar sombras */
}
.bagal__track{ position:absolute; inset:0; transform-style:preserve-3d; }

.baslide{
  position:absolute; top:50%; left:50%; margin:0;
  width:clamp(210px, 62vw, 350px);
  height:clamp(290px, 80vw, 470px);
  padding:9px; background:var(--cream-2);
  border:1px solid var(--line); border-radius:var(--r);
  box-shadow:0 34px 60px -42px rgba(67,42,26,.65);
  cursor:pointer; overflow:hidden;
  transition:transform .6s var(--ease), opacity .6s var(--ease), box-shadow .4s var(--ease), border-color .4s var(--ease);
  will-change:transform, opacity; backface-visibility:hidden;
}
.baslide img{ width:100%; height:100%; object-fit:contain; background:var(--cream-3); border-radius:10px; user-select:none; }
.baslide.is-active{ border-color:var(--gold-2); box-shadow:0 46px 84px -40px rgba(67,42,26,.78); }
.baslide__zoom{
  position:absolute; right:18px; bottom:18px; width:40px; height:40px; border-radius:50%;
  display:grid; place-items:center; color:var(--cream); background:rgba(67,42,26,.55);
  -webkit-backdrop-filter:blur(4px); backdrop-filter:blur(4px);
  opacity:0; transform:scale(.85); transition:.4s var(--ease); pointer-events:none;
}
.baslide__zoom svg{ width:18px; height:18px; }
.baslide.is-active .baslide__zoom{ opacity:1; transform:scale(1); }

.bagal__nav{
  position:absolute; top:50%; transform:translateY(-50%); z-index:60;
  width:48px; height:48px; border-radius:50%;
  background:var(--cream-2); border:1px solid var(--line); color:var(--ink);
  display:grid; place-items:center; box-shadow:0 14px 30px -16px rgba(67,42,26,.5);
  transition:.3s var(--ease);
}
.bagal__nav svg{ width:22px; height:22px; }
.bagal__nav:hover{ background:var(--gold); color:var(--cream); border-color:var(--gold); }
.bagal__nav.prev{ left:max(8px, 2vw); }
.bagal__nav.next{ right:max(8px, 2vw); }

.bagal__foot{ display:flex; flex-direction:column; align-items:center; gap:16px; margin-top:26px; }
.bagal__cap{ font-family:var(--serif); font-style:italic; font-size:1.25rem; color:var(--ink); min-height:1.4em; text-align:center; }
.bagal__dots{ display:flex; gap:9px; flex-wrap:wrap; justify-content:center; }
.badot{ width:8px; height:8px; border-radius:50%; background:var(--line-2); transition:.3s var(--ease); }
.badot.on{ background:var(--gold); transform:scale(1.4); }

/* tela cheia (lightbox) */
.balb{
  position:fixed; inset:0; z-index:1000; display:none;
  align-items:center; justify-content:center;
  background:rgba(28,17,11,.93); -webkit-backdrop-filter:blur(6px); backdrop-filter:blur(6px);
  opacity:0; transition:opacity .35s var(--ease);
}
.balb.open{ display:flex; opacity:1; }
.balb__fig{ margin:0; display:flex; flex-direction:column; align-items:center; gap:16px; }
.balb__fig img{ max-width:92vw; max-height:80vh; width:auto; height:auto; object-fit:contain; border-radius:12px; box-shadow:0 40px 90px -30px rgba(0,0,0,.8); }
.balb__fig figcaption{ font-family:var(--sans); font-size:.8rem; letter-spacing:.16em; text-transform:uppercase; color:var(--gold-soft); }
.balb__x{
  position:absolute; top:max(16px, 3vh); right:max(16px, 3vw); z-index:2;
  width:50px; height:50px; border-radius:50%;
  background:rgba(244,237,221,.1); border:1px solid rgba(244,237,221,.28); color:var(--cream);
  display:grid; place-items:center; transition:.3s var(--ease);
}
.balb__x svg{ width:24px; height:24px; }
.balb__x:hover{ background:var(--gold); border-color:var(--gold); transform:rotate(90deg); }
.balb__nav{
  position:absolute; top:50%; transform:translateY(-50%);
  width:52px; height:52px; border-radius:50%;
  background:rgba(244,237,221,.1); border:1px solid rgba(244,237,221,.24); color:var(--cream);
  display:grid; place-items:center; transition:.3s var(--ease);
}
.balb__nav svg{ width:26px; height:26px; }
.balb__nav:hover{ background:var(--gold); border-color:var(--gold); }
.balb__nav.prev{ left:max(10px, 2vw); }
.balb__nav.next{ right:max(10px, 2vw); }

@media (max-width:560px){
  .bagal__nav{ width:42px; height:42px; }
  .balb__nav{ width:44px; height:44px; }
  .balb__fig img{ max-height:74vh; }
}

/* ============================================================
   CONTATO / LOCALIZAÇÃO
   ============================================================ */
.contact{ background:var(--brown-3); color:var(--cream); overflow:hidden; }
.contact::before{ content:""; position:absolute; inset:0; pointer-events:none; background:radial-gradient(70% 60% at 100% 0%, rgba(174,131,72,.16), transparent 55%); }
.contact .wrap{ position:relative; z-index:1; }
.contact__grid{ display:grid; gap:42px; }
.contact h2{ color:var(--cream); font-size:clamp(2.4rem,7vw,4rem); }
.contact h2 em{ color:var(--gold-2); }
.contact .eyebrow{ color:var(--gold-2); } .contact .eyebrow::before{ background:var(--gold-2); }
.info{ margin-top:30px; display:grid; gap:22px; }
.info__row{ display:flex; gap:16px; align-items:flex-start; }
.info__row .ic{ flex:none; width:42px; height:42px; border-radius:50%; border:1px solid rgba(244,237,221,.2); display:grid; place-items:center; color:var(--gold-2); }
.info__row b{ display:block; font-size:.72rem; letter-spacing:.2em; text-transform:uppercase; color:var(--gold-soft); margin-bottom:3px; }
.info__row p{ color:rgba(244,237,221,.86); }
.info__row a{ color:rgba(244,237,221,.86); border-bottom:1px solid rgba(174,131,72,.5); }

.hours{ margin-top:28px; }
.hours .hr{ display:flex; justify-content:space-between; align-items:baseline; gap:18px; padding:11px 0; border-bottom:1px solid rgba(244,237,221,.12); font-size:.95rem; }
.hours .hr span:first-child{ color:rgba(244,237,221,.74); } .hours .hr span:last-child{ color:var(--cream); white-space:nowrap; }

/* form */
.form{ background:rgba(244,237,221,.05); border:1px solid rgba(244,237,221,.12); border-radius:var(--r); padding:30px 26px; }
.form h3{ color:var(--cream); font-size:1.8rem; }
.form .field{ margin-top:16px; }
.form label{ display:block; font-size:.7rem; letter-spacing:.18em; text-transform:uppercase; color:var(--gold-soft); margin-bottom:7px; }
.form input,.form select,.form textarea{
  width:100%; background:rgba(0,0,0,.18); border:1px solid rgba(244,237,221,.18); border-radius:11px;
  padding:14px 16px; color:var(--cream); font-family:var(--sans); font-size:1rem; font-weight:300;
  transition:.3s var(--ease);
}
.form input::placeholder,.form textarea::placeholder{ color:rgba(244,237,221,.4); }
.form input:focus,.form select:focus,.form textarea:focus{ outline:none; border-color:var(--gold-2); background:rgba(0,0,0,.28); }
.form select option{ color:#222; }
.form .btn{ width:100%; margin-top:22px; }
.form .ok{ display:none; text-align:center; padding:30px 10px; }
.form .ok.show{ display:block; }
.form .ok .ic{ font-size:2.6rem; color:var(--gold-2); font-family:var(--serif); }
.form .ok b{ display:block; font-family:var(--serif); font-size:1.7rem; color:var(--cream); margin-top:8px; }
.form .ok p{ color:rgba(244,237,221,.74); margin-top:8px; font-size:.95rem; }

.map{ margin-top:24px; border-radius:var(--r); overflow:hidden; aspect-ratio:16/9; border:1px solid rgba(244,237,221,.16); position:relative; background:#3a2a1c; }
.map .ph{ position:absolute; inset:0; display:grid; place-items:center; color:rgba(244,237,221,.5); font-size:.74rem; letter-spacing:.2em; text-transform:uppercase; gap:8px; flex-direction:column; }

/* ============================================================
   FOOTER
   ============================================================ */
.foot{ background:#241509; color:rgba(244,237,221,.7); padding:64px 0 36px; text-align:center; }
.foot__logo{ height:96px; margin:0 auto 22px; }
.foot__tag{ font-family:var(--serif); font-style:italic; font-size:1.5rem; color:var(--gold-2); }
.foot__nav{ display:flex; flex-wrap:wrap; justify-content:center; gap:8px 26px; margin:30px 0; }
.foot__nav a{ font-size:.78rem; letter-spacing:.14em; text-transform:uppercase; transition:color .3s; }
.foot__nav a:hover{ color:var(--gold-2); }
.foot__social{ display:flex; justify-content:center; gap:14px; margin-bottom:28px; }
.foot__social a{ width:42px; height:42px; border-radius:50%; border:1px solid rgba(244,237,221,.18); display:grid; place-items:center; color:var(--gold-soft); transition:.35s var(--ease); }
.foot__social a:hover{ background:var(--gold); color:#241509; border-color:var(--gold); transform:translateY(-2px); }
.foot__legal{ font-size:.76rem; color:rgba(244,237,221,.4); border-top:1px solid rgba(244,237,221,.1); padding-top:24px; }
.foot__legal a{ color:rgba(244,237,221,.6); }

/* ============================================================
   FLOAT WHATSAPP
   ============================================================ */
.wa{
  position:fixed; right:18px; bottom:18px; z-index:80;
  width:60px; height:60px; border-radius:50%;
  background:#25D366; color:#fff; display:grid; place-items:center;
  box-shadow:0 16px 36px -12px rgba(37,211,102,.7);
  transition:transform .4s var(--ease); animation:waPulse 3s var(--ease) infinite;
}
.wa:hover{ transform:scale(1.08); }
.wa svg{ width:32px; height:32px; }
@keyframes waPulse{ 0%,100%{ box-shadow:0 16px 36px -12px rgba(37,211,102,.7),0 0 0 0 rgba(37,211,102,.4); } 50%{ box-shadow:0 16px 36px -12px rgba(37,211,102,.7),0 0 0 14px rgba(37,211,102,0); } }
@media (prefers-reduced-motion: reduce){ .wa,.memcard::after,.hero__scroll i{ animation:none; } }

/* ============================================================
   RESPONSIVE  (desktop up)
   ============================================================ */
@media (min-width:760px){
  body{ font-size:18px; }
  .nav__links{ display:flex; }
  .nav__cta{ display:inline-flex; }
  .nav__burger{ display:none; }
  .pad{ padding:104px 0; } .pad-lg{ padding:136px 0; }
  .about__grid{ grid-template-columns:0.95fr 1.05fr; gap:60px; }
  .proc__grid{ grid-template-columns:1fr 1fr; gap:16px; }
  .club__benefits{ grid-template-columns:repeat(4,1fr); }
  .club__benefits .bcard.span2{ grid-column:span 2; }
  .partner-grid{ grid-template-columns:repeat(4,1fr); }
  .testi__grid{ grid-template-columns:repeat(3,1fr); }
  .contact__grid{ grid-template-columns:1fr 1fr; gap:54px; align-items:start; }
  .memcard{ max-width:480px; }
  .club__cardwrap{ float:none; }
}
@media (min-width:1000px){
  .club__layout{ display:grid; grid-template-columns:1fr 1fr; gap:60px; align-items:center; }
}
