/* ==========================================================
   PRESENÇA PSI — Premium Landing Page
   Design system: editorial luxury · Apple-inspired minimalism
   ========================================================== */

/* ---------- Tokens ---------- */
:root{
  /* Palette */
  --bg:            #FAFAF7;          /* warm off-white */
  --bg-alt:        #F4F1EA;          /* soft cream */
  --bg-deep:       #0E0E0C;          /* near-black with warmth */
  --ink:           #14130F;          /* primary text */
  --ink-2:         #2B2A26;
  --ink-mute:      #6E6B62;          /* muted text */
  --rule:          #E6E1D6;          /* hairlines */
  --rule-strong:   #CFC8B7;

  /* Sophisticated gold */
  --gold:          #B89456;          /* base */
  --gold-deep:     #8E6E3A;          /* on light bg for AA on text */
  --gold-soft:     #D9BE85;
  --gold-glow:     rgba(184,148,86,.18);

  /* Typography */
  --font-display:  "Fraunces", "Cormorant Garamond", Georgia, serif;
  --font-sans:     "Manrope", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;

  /* Sizing */
  --container:     1200px;
  --container-tight: 820px;
  --radius:        2px;
  --radius-lg:     4px;

  /* Motion */
  --ease:          cubic-bezier(.2,.6,.2,1);
}

*,*::before,*::after{ box-sizing:border-box; }
html{ scroll-behavior:smooth; -webkit-text-size-adjust:100%; }
body{
  margin:0;
  font-family:var(--font-sans);
  font-weight:400;
  font-size:17px;
  line-height:1.6;
  color:var(--ink);
  background:var(--bg);
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
  text-rendering:optimizeLegibility;
  font-feature-settings:"ss01","ss02","cv11";
}
img{ max-width:100%; display:block; }
a{ color:inherit; text-decoration:none; }
button{ font-family:inherit; }

::selection{ background:var(--gold); color:#fff; }

/* ---------- Layout helpers ---------- */
.container{
  width:100%;
  max-width:var(--container);
  margin:0 auto;
  padding:0 28px;
}
.container--tight{ max-width:var(--container-tight); }

.section{ padding:120px 0; position:relative; }
.section + .section{ border-top:1px solid var(--rule); }
@media (max-width: 820px){
  .section{ padding:80px 0; }
}

/* ---------- Typography ---------- */
.display{
  font-family:var(--font-display);
  font-weight:340;
  font-size:clamp(40px, 6.2vw, 84px);
  line-height:1.02;
  letter-spacing:-0.02em;
  margin:0 0 24px;
  color:var(--ink);
  font-variation-settings:"opsz" 144;
}
.display em{
  font-style:italic;
  font-weight:300;
  color:var(--gold-deep);
  font-variation-settings:"opsz" 144;
}
.display--md{ font-size:clamp(34px, 4.6vw, 60px); }
.display--lg{ font-size:clamp(44px, 7vw, 92px); }
.display--light{ color:#F5F2EA; }
.display--light em{ color:var(--gold-soft); }

.lead{
  font-size:clamp(16.5px, 1.45vw, 19.5px);
  line-height:1.55;
  color:var(--ink-mute);
  max-width:60ch;
  margin:0 0 28px;
  font-weight:400;
}
.lead--narrow{ max-width:54ch; }
.lead--light{ color:#C9C4B8; }

.center{ text-align:center; margin-left:auto; margin-right:auto; }

.muted-fineprint{
  font-size:13px;
  letter-spacing:.04em;
  color:var(--ink-mute);
  max-width:46ch;
  line-height:1.5;
  margin:0 0 36px;
  border-left:1px solid var(--gold);
  padding-left:14px;
}

.eyebrow{
  display:inline-flex;
  align-items:center;
  gap:14px;
  text-transform:uppercase;
  font-size:11.5px;
  font-weight:600;
  letter-spacing:.22em;
  color:var(--ink-mute);
  margin-bottom:22px;
}
.eyebrow__line{
  display:inline-block;
  width:38px;
  height:1px;
  background:var(--gold);
}
.eyebrow--light{ color:#C9C4B8; }
.eyebrow__line--light{ background:var(--gold-soft); }

.section__num{
  font-family:var(--font-display);
  font-style:italic;
  font-weight:300;
  font-size:14px;
  letter-spacing:.08em;
  color:var(--gold-deep);
  display:inline-block;
  padding-bottom:6px;
  border-bottom:1px solid var(--gold);
  margin-bottom:18px;
}
.section__num--center{ display:block; width:fit-content; margin:0 auto 18px; }

.section__head{ max-width:760px; margin-bottom:64px; }
.section__head--center{ margin-left:auto; margin-right:auto; text-align:center; }


/* ---------- Buttons ---------- */
.btn{
  --pad-y: 16px;
  --pad-x: 26px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:10px;
  padding:var(--pad-y) var(--pad-x);
  font-family:var(--font-sans);
  font-weight:500;
  font-size:14.5px;
  letter-spacing:.01em;
  border-radius:999px;
  transition:transform .35s var(--ease), background .3s var(--ease), color .3s var(--ease), box-shadow .35s var(--ease), border-color .3s var(--ease);
  cursor:pointer;
  white-space:nowrap;
  border:1px solid transparent;
  position:relative;
  overflow:hidden;
}
.btn svg{ transition:transform .35s var(--ease); }
.btn:hover svg{ transform:translateX(3px); }

.btn--gold{
  background:linear-gradient(135deg, #C9A562 0%, #B89456 45%, #9A7838 100%);
  color:#fff;
  box-shadow:
    0 1px 0 rgba(255,255,255,.35) inset,
    0 -1px 0 rgba(0,0,0,.12) inset,
    0 8px 24px -10px var(--gold-glow);
}
.btn--gold::after{
  content:"";
  position:absolute;
  inset:0;
  background:linear-gradient(120deg, transparent 30%, rgba(255,255,255,.35) 50%, transparent 70%);
  transform:translateX(-130%);
  transition:transform .9s var(--ease);
}
.btn--gold:hover{
  transform:translateY(-1px);
  box-shadow:
    0 1px 0 rgba(255,255,255,.4) inset,
    0 -1px 0 rgba(0,0,0,.15) inset,
    0 14px 28px -10px var(--gold-glow);
}
.btn--gold:hover::after{ transform:translateX(130%); }

.btn--outline{
  background:transparent;
  color:var(--ink);
  border-color:var(--ink);
}
.btn--outline:hover{ background:var(--ink); color:var(--bg); }

.btn--outline-light{
  color:#F5F2EA;
  border-color:rgba(245,242,234,.35);
}
.btn--outline-light:hover{
  background:rgba(245,242,234,.08);
  border-color:#F5F2EA;
}

.btn--ghost{
  background:transparent;
  color:var(--ink);
  border-color:var(--rule-strong);
}
.btn--ghost:hover{ border-color:var(--gold); color:var(--gold-deep); }

.btn--sm{ --pad-y:10px; --pad-x:18px; font-size:13px; }
.btn--block{ width:100%; }


/* ---------- Nav ---------- */
.nav{
  position:sticky;
  top:0;
  z-index:50;
  background:rgba(250,250,247,.78);
  backdrop-filter:saturate(140%) blur(14px);
  -webkit-backdrop-filter:saturate(140%) blur(14px);
  border-bottom:1px solid transparent;
  transition:border-color .3s var(--ease), background .3s var(--ease);
}
.nav.is-scrolled{ border-bottom-color:var(--rule); }

.nav__inner{
  max-width:var(--container);
  margin:0 auto;
  padding:18px 28px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:24px;
}
.brand{
  display:inline-flex;
  align-items:center;
  gap:10px;
  font-family:var(--font-display);
  font-size:20px;
  font-weight:340;
  letter-spacing:.01em;
  color:var(--ink);
}
.brand em{ font-style:italic; color:var(--gold-deep); font-weight:300; }
.brand__mark{
  display:inline-grid;
  place-items:center;
  width:34px; height:34px;
  border:1px solid var(--gold);
  border-radius:50%;
  color:var(--gold-deep);
  background:radial-gradient(circle at 30% 30%, rgba(184,148,86,.10), transparent 70%);
}

.nav__links{
  display:flex;
  gap:32px;
  font-size:14px;
  color:var(--ink-2);
}
.nav__links a{
  position:relative;
  padding:6px 0;
  transition:color .3s var(--ease);
}
.nav__links a::after{
  content:"";
  position:absolute;
  left:0; right:0; bottom:0;
  height:1px;
  background:var(--gold);
  transform:scaleX(0);
  transform-origin:left;
  transition:transform .35s var(--ease);
}
.nav__links a:hover{ color:var(--gold-deep); }
.nav__links a:hover::after{ transform:scaleX(1); }

.nav__cta{ flex-shrink:0; }

@media (max-width: 880px){
  .nav__links{ display:none; }
}
@media (max-width: 480px){
  .nav__cta{ display:none; }
}


/* ---------- 1. HERO ---------- */
.hero{
  padding:80px 28px 40px;
  max-width:1320px;
  margin:0 auto;
  position:relative;
}
.hero::before{
  content:"";
  position:absolute;
  top:-120px; right:-160px;
  width:520px; height:520px;
  background:radial-gradient(circle, rgba(184,148,86,.10) 0%, transparent 65%);
  pointer-events:none;
  filter:blur(10px);
}

.hero__grid{
  display:grid;
  grid-template-columns: 1.05fr .95fr;
  gap:80px;
  align-items:center;
  padding:60px 0 90px;
  position:relative;
}

.hero__copy h1{ margin-top:8px; }
.hero__ctas{
  display:flex;
  flex-wrap:wrap;
  gap:14px;
  margin-top:8px;
}

/* Portrait */
.hero__visual{ position:relative; }
.portrait{
  position:relative;
  border-radius:var(--radius-lg);
  overflow:hidden;
  aspect-ratio: 4/5;
  background:#EFE9DC;
  isolation:isolate;
}
.portrait img{
  width:100%; height:100%;
  object-fit:cover;
  object-position:center 32%;
  transition:transform 1.6s var(--ease);
}
.portrait:hover img{ transform:scale(1.025); }

.portrait__halo{
  position:absolute;
  inset:auto -30% -25% auto;
  width:80%;
  aspect-ratio:1;
  background:radial-gradient(circle, rgba(184,148,86,.32) 0%, transparent 65%);
  z-index:-1;
  filter:blur(8px);
}

.portrait::before{
  content:"";
  position:absolute;
  inset:14px;
  border:1px solid rgba(245,242,234,.35);
  pointer-events:none;
  border-radius:2px;
  z-index:2;
}
.portrait::after{
  content:"";
  position:absolute;
  inset:0;
  pointer-events:none;
  background:linear-gradient(180deg, transparent 60%, rgba(20,19,15,.18) 100%);
  z-index:1;
}

.portrait__caption{
  position:absolute;
  left:24px; bottom:22px;
  z-index:3;
  display:inline-flex;
  align-items:center;
  gap:10px;
  padding:9px 16px;
  background:rgba(20,19,15,.55);
  backdrop-filter:blur(10px);
  -webkit-backdrop-filter:blur(10px);
  color:#F5F2EA;
  font-size:12.5px;
  letter-spacing:.02em;
  border-radius:999px;
  border:1px solid rgba(245,242,234,.18);
}
.portrait__caption .dot{
  width:6px; height:6px;
  border-radius:50%;
  background:var(--gold-soft);
  box-shadow:0 0 0 3px rgba(217,190,133,.25);
}

/* Strip */
.hero__strip{
  display:flex;
  justify-content:center;
  align-items:center;
  flex-wrap:wrap;
  gap:14px 22px;
  padding:28px 0 18px;
  border-top:1px solid var(--rule);
  border-bottom:1px solid var(--rule);
  font-size:12.5px;
  letter-spacing:.18em;
  text-transform:uppercase;
  color:var(--ink-mute);
}
.strip-sep{ color:var(--gold); }

@media (max-width: 960px){
  .hero__grid{
    grid-template-columns:1fr;
    gap:48px;
    padding:30px 0 60px;
  }
  .hero__visual{ order:-1; max-width:480px; margin:0 auto; width:100%; }
}


/* ---------- 2. PAIN ---------- */
.section--pain{ background:var(--bg); }

.pain-grid{
  list-style:none;
  padding:0; margin:0;
  display:grid;
  grid-template-columns:repeat(3, 1fr);
  gap:1px;
  background:var(--rule);
  border:1px solid var(--rule);
  border-radius:var(--radius-lg);
  overflow:hidden;
}
.pain-card{
  background:var(--bg);
  padding:34px 28px;
  display:flex;
  align-items:flex-start;
  gap:14px;
  transition:background .35s var(--ease);
  position:relative;
}
.pain-card__bullet{
  flex-shrink:0;
  width:8px; height:8px;
  margin-top:9px;
  border-radius:50%;
  background:transparent;
  border:1px solid var(--gold);
  position:relative;
  transition:background .35s var(--ease), transform .35s var(--ease);
}
.pain-card p{
  margin:0;
  font-family:var(--font-display);
  font-weight:340;
  font-size:21px;
  line-height:1.35;
  letter-spacing:-0.01em;
  color:var(--ink);
}
.pain-card:hover{ background:#FEFCF7; }
.pain-card:hover .pain-card__bullet{
  background:var(--gold);
  transform:scale(1.15);
}

@media (max-width: 880px){
  .pain-grid{ grid-template-columns:repeat(2, 1fr); }
}
@media (max-width: 560px){
  .pain-grid{ grid-template-columns:1fr; }
  .pain-card{ padding:26px 22px; }
  .pain-card p{ font-size:19px; }
}


/* ---------- 3. PIVOT ---------- */
.section--pivot{ background:var(--bg-alt); }
.pivot{ text-align:center; }
.pivot__rule{
  width:46px;
  height:1px;
  background:var(--gold);
  margin:36px auto 32px;
}
.pivot__text{
  font-family:var(--font-display);
  font-weight:340;
  font-size:clamp(20px, 2vw, 25px);
  line-height:1.55;
  color:var(--ink-2);
  max-width:62ch;
  margin:0 auto;
  letter-spacing:-0.005em;
}


/* ---------- 4. DELIVER ---------- */
.deliver__grid{
  display:grid;
  grid-template-columns: 1fr 1.2fr;
  gap:80px;
  align-items:start;
}
.deliver__head{ position:sticky; top:120px; }

.deliver__list{
  list-style:none;
  margin:0; padding:0;
}
.deliver__list li{
  display:grid;
  grid-template-columns: 28px 1fr;
  gap:18px;
  padding:24px 0;
  border-top:1px solid var(--rule);
  align-items:start;
}
.deliver__list li:last-child{ border-bottom:1px solid var(--rule); }
.deliver__plus{
  font-family:var(--font-display);
  font-style:italic;
  font-weight:300;
  font-size:22px;
  color:var(--gold-deep);
  line-height:1;
  padding-top:4px;
}
.deliver__list h3{
  margin:0 0 6px;
  font-family:var(--font-sans);
  font-weight:600;
  font-size:16.5px;
  letter-spacing:-0.005em;
  color:var(--ink);
}
.deliver__list p{
  margin:0;
  font-size:15px;
  color:var(--ink-mute);
  line-height:1.55;
}

@media (max-width: 960px){
  .deliver__grid{ grid-template-columns:1fr; gap:40px; }
  .deliver__head{ position:static; }
}


/* ---------- 5. DIFF ---------- */
.section--diff{
  background:var(--bg-alt);
  position:relative;
  overflow:hidden;
}
.section--diff::before{
  content:"";
  position:absolute;
  top:-80px; left:-120px;
  width:380px; height:380px;
  background:radial-gradient(circle, rgba(184,148,86,.08) 0%, transparent 70%);
  pointer-events:none;
}

.diff-grid{
  list-style:none;
  margin:0; padding:0;
  display:grid;
  grid-template-columns:repeat(2, 1fr);
  gap:1px;
  background:var(--rule);
  border:1px solid var(--rule);
  border-radius:var(--radius-lg);
  overflow:hidden;
}
.diff-card{
  background:var(--bg-alt);
  padding:40px 32px;
  transition:background .35s var(--ease);
}
.diff-card:hover{ background:#FAF6EC; }
.diff-card__icon{
  display:inline-grid;
  place-items:center;
  width:46px; height:46px;
  border:1px solid var(--gold);
  border-radius:50%;
  color:var(--gold-deep);
  margin-bottom:18px;
  background:rgba(255,255,255,.5);
}
.diff-card h3{
  margin:0 0 8px;
  font-family:var(--font-display);
  font-weight:340;
  font-size:24px;
  line-height:1.25;
  letter-spacing:-0.01em;
  color:var(--ink);
}
.diff-card p{
  margin:0;
  font-size:15.5px;
  color:var(--ink-mute);
  line-height:1.55;
  max-width:38ch;
}

@media (max-width: 720px){
  .diff-grid{ grid-template-columns:1fr; }
  .diff-card{ padding:32px 26px; }
}


/* ---------- 6. AUDIENCE ---------- */
.section--audience{ background:var(--bg); }
.audience{
  list-style:none;
  margin:48px 0 0; padding:0;
  border-top:1px solid var(--rule);
}
.audience li{
  font-family:var(--font-display);
  font-weight:340;
  font-size:clamp(22px, 2.2vw, 30px);
  line-height:1.4;
  letter-spacing:-0.01em;
  color:var(--ink);
  padding:22px 0;
  border-bottom:1px solid var(--rule);
  display:flex;
  align-items:center;
  gap:18px;
  transition:padding .35s var(--ease), color .35s var(--ease);
}
.audience li::before{
  content:"";
  width:24px;
  height:1px;
  background:var(--gold);
  flex-shrink:0;
  transition:width .35s var(--ease);
}
.audience li:hover{ color:var(--gold-deep); }
.audience li:hover::before{ width:48px; }


/* ---------- 7. OFFER ---------- */
.section--offer{ background:var(--bg-alt); }

.pricing{
  max-width:560px;
  margin:48px auto 0;
  background:#FFFEFB;
  border:1px solid var(--rule);
  border-radius:var(--radius-lg);
  padding:48px 44px;
  position:relative;
  box-shadow:0 30px 60px -30px rgba(20,19,15,.10);
}
.pricing::before{
  content:"";
  position:absolute;
  inset:6px;
  border:1px solid var(--gold);
  border-radius:2px;
  pointer-events:none;
  opacity:.45;
}

.pricing__top{
  display:flex;
  justify-content:space-between;
  align-items:center;
  margin-bottom:32px;
  position:relative;
}
.pricing__tag{
  font-family:var(--font-display);
  font-style:italic;
  font-weight:300;
  font-size:18px;
  color:var(--gold-deep);
  letter-spacing:.01em;
}
.pricing__limit{
  font-size:11px;
  letter-spacing:.18em;
  text-transform:uppercase;
  color:var(--ink-mute);
  padding:6px 12px;
  border:1px solid var(--rule-strong);
  border-radius:999px;
}

.pricing__price{
  display:flex;
  align-items:baseline;
  gap:6px;
  margin-bottom:6px;
  position:relative;
}
.pricing__currency{
  font-family:var(--font-display);
  font-size:24px;
  font-weight:300;
  color:var(--ink-2);
  margin-right:2px;
}
.pricing__amount{
  font-family:var(--font-display);
  font-weight:300;
  font-size:80px;
  line-height:1;
  letter-spacing:-0.03em;
  color:var(--ink);
  font-variation-settings:"opsz" 144;
}
.pricing__sub{
  font-size:13px;
  color:var(--ink-mute);
  letter-spacing:.04em;
  margin-left:8px;
}
.pricing__installments{
  margin:0 0 28px;
  font-size:14.5px;
  color:var(--ink-mute);
  position:relative;
}
.pricing__installments strong{ color:var(--ink); font-weight:600; }

.pricing__bullets{
  list-style:none;
  margin:0 0 32px; padding:24px 0 0;
  border-top:1px solid var(--rule);
  position:relative;
}
.pricing__bullets li{
  position:relative;
  padding:8px 0 8px 22px;
  font-size:15px;
  color:var(--ink-2);
}
.pricing__bullets li::before{
  content:"";
  position:absolute;
  left:0; top:16px;
  width:10px; height:1px;
  background:var(--gold);
}

.pricing__ctas{
  display:flex;
  flex-direction:column;
  gap:10px;
  margin-bottom:18px;
  position:relative;
}
.pricing__note{
  margin:0;
  text-align:center;
  font-size:12.5px;
  color:var(--ink-mute);
  letter-spacing:.02em;
  position:relative;
}

@media (max-width:520px){
  .pricing{ padding:36px 26px; }
  .pricing__amount{ font-size:64px; }
}


/* ---------- 8. PROCESS ---------- */
.steps{
  list-style:none;
  margin:0; padding:0;
  border-top:1px solid var(--rule);
}
.step{
  display:grid;
  grid-template-columns: 120px 1fr;
  gap:36px;
  padding:36px 0;
  border-bottom:1px solid var(--rule);
  align-items:start;
  transition:padding .35s var(--ease);
}
.step__num{
  font-family:var(--font-display);
  font-weight:300;
  font-style:italic;
  font-size:46px;
  line-height:1;
  color:var(--gold-deep);
  letter-spacing:-0.02em;
}
.step__body h3{
  margin:0 0 8px;
  font-family:var(--font-display);
  font-weight:360;
  font-size:26px;
  line-height:1.2;
  letter-spacing:-0.01em;
  color:var(--ink);
}
.step__body p{
  margin:0;
  font-size:16px;
  line-height:1.6;
  color:var(--ink-mute);
  max-width:62ch;
}

.step:hover{ padding-left:8px; }

.process__note{
  margin:48px auto 0;
  max-width:64ch;
  text-align:center;
  font-family:var(--font-display);
  font-style:italic;
  font-weight:340;
  font-size:18px;
  line-height:1.6;
  color:var(--ink-2);
  padding:24px;
  border-top:1px solid var(--gold);
  border-bottom:1px solid var(--gold);
}

@media (max-width: 720px){
  .step{ grid-template-columns:1fr; gap:10px; padding:30px 0; }
  .step__num{ font-size:32px; }
  .step__body h3{ font-size:22px; }
}


/* ---------- 9. FAQ ---------- */
.section--faq{ background:var(--bg-alt); }

.faq{
  margin-top:48px;
  border-top:1px solid var(--rule-strong);
}
.faq__item{
  border-bottom:1px solid var(--rule-strong);
}
.faq__item summary{
  list-style:none;
  cursor:pointer;
  padding:24px 4px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:24px;
  font-family:var(--font-display);
  font-weight:340;
  font-size:clamp(19px, 1.7vw, 23px);
  letter-spacing:-0.005em;
  color:var(--ink);
  transition:color .3s var(--ease);
}
.faq__item summary::-webkit-details-marker{ display:none; }
.faq__item summary:hover{ color:var(--gold-deep); }

.faq__icon{
  position:relative;
  flex-shrink:0;
  width:22px; height:22px;
  border:1px solid var(--gold);
  border-radius:50%;
}
.faq__icon::before,
.faq__icon::after{
  content:"";
  position:absolute;
  background:var(--gold-deep);
  left:50%; top:50%;
  transition:transform .35s var(--ease);
}
.faq__icon::before{ width:9px; height:1px; transform:translate(-50%,-50%); }
.faq__icon::after{ width:1px; height:9px; transform:translate(-50%,-50%); }
.faq__item[open] .faq__icon::after{ transform:translate(-50%,-50%) scaleY(0); }

.faq__answer{
  padding:0 4px 26px;
  max-width:64ch;
  color:var(--ink-mute);
  font-size:16px;
  line-height:1.65;
  animation:fadeUp .5s var(--ease);
}
@keyframes fadeUp{
  from{ opacity:0; transform:translateY(-4px); }
  to{ opacity:1; transform:translateY(0); }
}


/* ---------- 10. FINAL CTA ---------- */
.section--final{
  padding:0;
  border-top:none;
}
.final{
  background:var(--bg-deep);
  color:#F5F2EA;
  padding:130px 28px;
  text-align:center;
  position:relative;
  overflow:hidden;
}
.final::before{
  content:"";
  position:absolute;
  inset:auto auto -40% 50%;
  width:120%;
  aspect-ratio:1;
  transform:translateX(-50%);
  background:radial-gradient(ellipse at center, rgba(184,148,86,.18) 0%, transparent 55%);
  pointer-events:none;
}
.final::after{
  content:"";
  position:absolute;
  inset:18px;
  border:1px solid rgba(217,190,133,.12);
  pointer-events:none;
  border-radius:4px;
}
.final > *{ position:relative; z-index:1; }
.final .lead{ margin:0 auto 36px; max-width:48ch; }
.final__ctas{
  display:flex;
  flex-wrap:wrap;
  gap:14px;
  justify-content:center;
}


/* ---------- Footer ---------- */
.footer{
  background:var(--bg);
  border-top:1px solid var(--rule);
  padding:56px 28px 40px;
}
.footer__inner{
  max-width:var(--container);
  margin:0 auto;
  display:flex;
  flex-direction:column;
  align-items:center;
  text-align:center;
  gap:18px;
}
.brand--footer{ font-size:18px; }
.footer__note{
  margin:0;
  font-size:13px;
  color:var(--ink-mute);
  max-width:62ch;
  line-height:1.6;
}
.footer__copy{
  margin:0;
  font-size:12px;
  letter-spacing:.06em;
  color:var(--ink-mute);
  padding-top:16px;
  border-top:1px solid var(--rule);
  width:100%;
  max-width:200px;
}


/* ---------- Reveal animations ---------- */
.reveal{
  opacity:0;
  transform:translateY(18px);
  transition:opacity .9s var(--ease), transform .9s var(--ease);
  will-change:opacity, transform;
}
.reveal.is-in{
  opacity:1;
  transform:none;
}
.reveal--delay{ transition-delay:.15s; }

@media (prefers-reduced-motion: reduce){
  *,*::before,*::after{ transition:none !important; animation:none !important; }
  .reveal{ opacity:1; transform:none; }
}


/* ==========================================================
   ADDITIONS — new components for restructured page
   ========================================================== */

/* Authority line in hero */
.muted-fineprint strong{
  color:var(--ink);
  font-weight:600;
  letter-spacing:.005em;
}

/* Hero h1 — refined letter-spacing for the longer headline */
.hero__copy .display{
  font-size:clamp(34px, 4.6vw, 60px);
  line-height:1.05;
  letter-spacing:-0.018em;
  margin-bottom:22px;
}

/* ---------- Pain grid — 5-item variant ---------- */
.pain-grid--five{
  display:flex;
  flex-wrap:wrap;
  gap:16px;
  background:none;
  border:none;
  border-radius:0;
  overflow:visible;
}
.pain-grid--five .pain-card{
  flex:1 1 calc(33.333% - 16px);
  min-width:240px;
  border:1px solid var(--rule);
  border-radius:var(--radius-lg);
  background:var(--bg);
  padding:30px 26px;
}
@media (max-width: 880px){
  .pain-grid--five .pain-card{ flex-basis:calc(50% - 8px); }
}
@media (max-width: 560px){
  .pain-grid--five .pain-card{ flex-basis:100%; }
}

/* ---------- Pivot list (consequence section) ---------- */
.pivot__intro{
  font-family:var(--font-sans);
  font-size:13px;
  letter-spacing:.18em;
  text-transform:uppercase;
  color:var(--ink-mute);
  margin:0 0 22px;
  text-align:center;
}
.pivot__list{
  list-style:none;
  margin:0 auto;
  padding:0;
  max-width:48ch;
  text-align:center;
}
.pivot__list li{
  font-family:var(--font-display);
  font-weight:340;
  font-size:clamp(20px, 2vw, 26px);
  line-height:1.4;
  letter-spacing:-0.01em;
  color:var(--ink);
  padding:14px 0;
  border-bottom:1px solid var(--rule);
}
.pivot__list li:last-child{ border-bottom:none; }


/* ---------- Solution section ---------- */
.section--solution{
  background:var(--bg);
  padding:100px 0;
}
.section--solution .section__head{ margin-bottom:0; }


/* ---------- Deliver — bridge text ---------- */
.deliver__col{
  display:flex;
  flex-direction:column;
}
.deliver__bridge{
  margin:36px 0;
  padding:32px 28px;
  background:#FDFBF4;
  border:1px solid var(--rule);
  border-left:2px solid var(--gold);
  border-radius:var(--radius-lg);
  font-family:var(--font-display);
  font-weight:340;
  font-size:clamp(19px, 1.7vw, 23px);
  line-height:1.5;
  color:var(--ink);
  letter-spacing:-0.005em;
}
.deliver__bridge em{
  font-style:italic;
  color:var(--gold-deep);
  font-weight:340;
}


/* ---------- 6. AUTHORITY ---------- */
.section--authority{
  background:var(--bg-alt);
  position:relative;
  overflow:hidden;
}
.section--authority::before{
  content:"";
  position:absolute;
  inset:auto -10% -30% -10%;
  height:60%;
  background:radial-gradient(ellipse at center, rgba(184,148,86,.10), transparent 60%);
  pointer-events:none;
}

.authority{
  margin-top:48px;
  text-align:center;
  background:#FFFEFB;
  border:1px solid var(--rule);
  border-radius:var(--radius-lg);
  padding:64px 56px;
  position:relative;
  box-shadow:0 30px 60px -30px rgba(20,19,15,.10);
}
.authority::before{
  content:"";
  position:absolute;
  inset:8px;
  border:1px solid var(--gold);
  opacity:.35;
  border-radius:3px;
  pointer-events:none;
}

.authority__crest{
  display:inline-flex;
  flex-direction:column;
  align-items:center;
  gap:2px;
  padding:14px 22px;
  border:1px solid var(--gold);
  border-radius:2px;
  margin-bottom:28px;
  background:rgba(255,255,255,.7);
  position:relative;
}
.authority__crest span{
  font-size:10px;
  letter-spacing:.32em;
  text-transform:uppercase;
  color:var(--ink-mute);
  font-weight:500;
}
.authority__crest strong{
  font-family:var(--font-display);
  font-style:italic;
  font-weight:300;
  font-size:18px;
  color:var(--gold-deep);
  letter-spacing:.03em;
}

.authority__name{
  margin:0 0 24px;
  font-family:var(--font-display);
  font-weight:340;
  font-size:clamp(28px, 3.2vw, 40px);
  letter-spacing:-0.015em;
  color:var(--ink);
  line-height:1.15;
}

.authority__creds{
  list-style:none;
  margin:0 auto 40px;
  padding:0;
  max-width:46ch;
  border-top:1px solid var(--rule);
  border-bottom:1px solid var(--rule);
}
.authority__creds li{
  padding:14px 0;
  font-size:15.5px;
  color:var(--ink-2);
  border-bottom:1px solid var(--rule);
}
.authority__creds li:last-child{ border-bottom:none; }

.authority__stat{
  margin:0 auto 36px;
  max-width:42ch;
  display:flex;
  flex-direction:column;
  align-items:center;
  gap:6px;
}
.authority__num{
  font-family:var(--font-display);
  font-weight:300;
  font-style:italic;
  font-size:clamp(56px, 7vw, 88px);
  line-height:1;
  letter-spacing:-0.03em;
  color:var(--gold-deep);
  font-variation-settings:"opsz" 144;
}
.authority__stat p{
  margin:0;
  font-size:15px;
  color:var(--ink-mute);
  line-height:1.55;
}

.authority__quote{
  margin:0 auto;
  max-width:54ch;
  padding-top:32px;
  border-top:1px solid var(--gold);
  font-family:var(--font-display);
  font-style:italic;
  font-weight:340;
  font-size:clamp(18px, 1.7vw, 22px);
  line-height:1.55;
  color:var(--ink-2);
  letter-spacing:-0.005em;
  position:relative;
}
.authority__quote::before{
  content:"\201C";
  position:absolute;
  top:8px; left:50%;
  transform:translateX(-50%);
  background:#FFFEFB;
  padding:0 14px;
  font-size:32px;
  color:var(--gold-deep);
  line-height:1;
  font-weight:300;
}

@media (max-width: 640px){
  .authority{ padding:44px 26px; }
  .authority__creds{ font-size:14.5px; }
}


/* ---------- 7. OBJECTION + COMPARISON ---------- */
.section--objection{
  background:var(--bg);
}

.compare{
  list-style:none;
  margin:48px 0 24px;
  padding:0;
  border-top:1px solid var(--rule);
}
.compare__row{
  display:flex;
  align-items:baseline;
  gap:20px;
  padding:22px 4px;
  border-bottom:1px solid var(--rule);
  font-size:18px;
}
.compare__label{
  font-family:var(--font-display);
  font-weight:340;
  font-size:clamp(20px, 2vw, 26px);
  color:var(--ink);
  letter-spacing:-0.01em;
  flex-shrink:0;
}
.compare__rule{
  flex:1;
  height:1px;
  background-image:linear-gradient(to right, var(--gold) 30%, transparent 30%);
  background-size:8px 1px;
  background-repeat:repeat-x;
  align-self:center;
  opacity:.55;
  margin:0 6px;
}
.compare__price{
  font-family:var(--font-sans);
  font-weight:500;
  font-size:clamp(15px, 1.5vw, 18px);
  color:var(--ink-2);
  letter-spacing:.005em;
  white-space:nowrap;
}
.compare__note{
  margin:0;
  text-align:center;
  font-family:var(--font-display);
  font-style:italic;
  font-weight:340;
  font-size:clamp(16px, 1.5vw, 19px);
  color:var(--ink-mute);
  letter-spacing:-0.005em;
  max-width:48ch;
  margin-left:auto;
  margin-right:auto;
  padding-top:8px;
}

@media (max-width: 520px){
  .compare__row{ flex-wrap:wrap; gap:6px; }
  .compare__rule{ display:none; }
  .compare__price{ width:100%; color:var(--gold-deep); font-weight:600; }
}


/* ---------- 9. INVESTIMENTO — additions to pricing ---------- */
.pricing__heading{
  margin:0 0 8px;
  font-size:11px;
  letter-spacing:.32em;
  text-transform:uppercase;
  color:var(--ink-mute);
  font-weight:600;
  position:relative;
}

.pricing__hr{
  height:1px;
  background:var(--rule);
  margin:32px 0;
  position:relative;
}
.pricing__hr::after{
  content:"";
  position:absolute;
  left:50%;
  top:50%;
  transform:translate(-50%,-50%);
  width:36px; height:1px;
  background:var(--gold);
}

.pricing__rationale{
  margin:0 0 18px;
  font-size:15px;
  line-height:1.6;
  color:var(--ink-mute);
  position:relative;
}
.pricing__rationale em{
  font-style:normal;
  color:var(--ink);
  font-weight:600;
}

.pricing__assurance{
  margin:0 0 32px;
  padding:18px 20px;
  background:#FAF6EC;
  border-left:2px solid var(--gold);
  border-radius:0 4px 4px 0;
  font-size:14.5px;
  line-height:1.6;
  color:var(--ink-2);
  position:relative;
}


/* ---------- Final CTA — slight tweak ---------- */
.section--final{ border-top:none; }

