/* ═══════════════════════════════════════════
   Dra. Fabiana — Design System
   Paleta: Bege · Vinho · Dourado
   ═══════════════════════════════════════════ */
:root {
  --bege:      #f5ede0;
  --bege-2:    #efe5d5;
  --bege-dk:   #e0d0bb;
  --vinho:     #6b1535;
  --vinho-dk:  #4e0e25;
  --vinho-lt:  #8a2045;
  --ouro:      #c4a05a;
  --ouro-lt:   #d4b474;
  --ouro-dk:   #a8863c;
  --dark:      #0e0a07;
  --dark-2:    #1a1008;
  --text:      #2a1a10;
  --muted:     #7a6050;
}

*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; }
body { font-family: Inter, sans-serif; background: var(--bege); color: var(--text); overflow-x: hidden; }

/* ── NAV ─────────────────────────────────────── */
#navbar {
  position: fixed; top: 0; left: 0; right: 0; z-index: 100;
  display: flex; align-items: center; justify-content: space-between;
  padding: 0 10vw; height: 76px;
  transition: background .4s, box-shadow .4s;
}
#navbar.scrolled {
  background: rgba(14,10,7,.92);
  backdrop-filter: blur(16px);
  box-shadow: 0 4px 40px rgba(0,0,0,.35);
}
.logo { display: flex; flex-direction: column; line-height: 1; text-decoration: none; }
.logo-dra  { font-size: 10px; font-weight: 500; letter-spacing: .28em; color: var(--ouro); text-transform: uppercase; }
.logo-name { font-family: 'Cormorant Garamond', serif; font-size: 22px; font-weight: 400; color: #fff; letter-spacing: .25em; text-transform: uppercase; }
.nav-links  { display: flex; gap: 40px; list-style: none; }
.nav-links a { font-size: 11px; font-weight: 500; letter-spacing: .2em; text-transform: uppercase; color: rgba(255,255,255,.65); text-decoration: none; transition: color .2s; }
.nav-links a:hover { color: var(--ouro); }
.nav-cta { font-size: 11px; font-weight: 600; letter-spacing: .2em; text-transform: uppercase; color: var(--dark); background: var(--ouro); padding: 12px 28px; text-decoration: none; transition: background .25s, transform .2s; }
.nav-cta:hover { background: var(--ouro-lt); transform: translateY(-1px); }
.hamburger { display: none; flex-direction: column; gap: 5px; background: none; border: none; cursor: pointer; padding: 8px; }
.hamburger span { display: block; width: 22px; height: 1.5px; background: #fff; }

/* ── HERO ─────────────────────────────────────── */
.hero { position: relative; width: 100%; height: 100vh; min-height: 640px; display: flex; flex-direction: column; justify-content: center; overflow: hidden; }
.hero-bg { position: absolute; inset: 0; background: var(--dark-2); }
.hero-photo { 
  position: absolute; right: 0; top: 0; 
  width: 75%; height: 100%; 
  object-fit: cover; object-position: top; 
  display: block; transform-origin: right center; transition: transform 8s ease; 
  -webkit-mask-image: linear-gradient(to right, transparent 0%, black 35%);
  mask-image: linear-gradient(to right, transparent 0%, black 35%);
}
.hero-overlay {
  position: absolute; inset: 0;
  background: linear-gradient(90deg, var(--dark-2) 0%, rgba(26,16,8,0.95) 40%, transparent 90%),
              linear-gradient(to top, var(--dark-2) 0%, transparent 20%);
}
.hero-glow {
  position: absolute; width: 800px; height: 800px;
  background: radial-gradient(circle, rgba(196,160,90,0.18) 0%, transparent 60%);
  top: 10%; left: 5vw; z-index: 1; pointer-events: none;
}
.hero-content { position: relative; z-index: 2; padding-left: clamp(80px, 16vw, 300px); padding-right: 40px; max-width: 900px; margin-top: 60px; }
.hero-pretitle { 
  display: inline-flex; align-items: center; gap: 10px;
  font-family: 'Inter', sans-serif; font-size: 10px; font-weight: 600; letter-spacing: .25em; text-transform: uppercase; 
  color: var(--ouro-lt); background: rgba(0,0,0,0.4); border: 1px solid rgba(196,160,90,.3);
  padding: 8px 20px; border-radius: 100px; margin-bottom: 32px; 
  backdrop-filter: blur(8px);
  opacity: 0; animation: fadeUp .8s .4s forwards;
}
.hero-pretitle span { display: block; width: 6px; height: 6px; border-radius: 50%; background: linear-gradient(135deg, #fcf6ba, #c4a05a); box-shadow: 0 0 8px rgba(252,246,186,0.8); }
.hero-name { margin-bottom: 24px; opacity: 0; animation: fadeUp .9s .55s forwards; display: flex; flex-direction: column; }
.hero-line-1 { font-family: 'Libre Bodoni', serif; font-weight: 400; font-size: clamp(36px, 4.5vw, 56px); color: #fff; letter-spacing: 0; line-height: 1; }
.hero-line-2 { font-family: 'Libre Bodoni', serif; font-style: italic; font-weight: 500; font-size: clamp(52px, 6.5vw, 92px); color: var(--ouro-lt); letter-spacing: -.02em; display: block; margin-top: -12px; line-height: 0.9; }
.hero-subtitle { font-family: 'Inter', sans-serif; font-size: 18px; font-weight: 300; letter-spacing: .02em; color: rgba(255,255,255,.9); margin-bottom: 24px; border-left: 2px solid var(--ouro); padding-left: 20px; opacity: 0; animation: fadeUp .8s .75s forwards; }
.hero-desc { font-family: 'Inter', sans-serif; font-size: 15px; line-height: 1.8; color: rgba(255,255,255,.6); max-width: 560px; margin-bottom: 40px; font-weight: 300; opacity: 0; animation: fadeUp .8s .9s forwards; }
.hero-bullets { list-style: none; margin-bottom: 48px; display: grid; gap: 16px; opacity: 0; animation: fadeUp .8s 1.05s forwards; }
.hero-bullets li { position: relative; padding-left: 28px; font-size: 14px; color: rgba(255,255,255,.7); }
.hero-bullets li::before { content: "✓"; position: absolute; left: 0; top: 0; color: var(--ouro-lt); font-size: 14px; font-weight: bold; }
.hero-btn-premium {
  display: inline-flex; align-items: center; justify-content: center;
  background: linear-gradient(to right, #c4a05a, #fcf6ba, #c4a05a);
  background-size: 200% auto;
  color: #1a1008; font-size: 13px; font-weight: 700; letter-spacing: .15em; text-transform: uppercase;
  padding: 0 48px; height: 64px; text-decoration: none; border-radius: 4px;
  box-shadow: 0 12px 30px rgba(196,160,90,.2); transition: all .4s ease;
  opacity: 0; animation: fadeUp .8s 1.2s forwards;
}
.hero-btn-premium:hover { background-position: right center; box-shadow: 0 16px 40px rgba(196,160,90,.4); transform: translateY(-2px); }
.hero-btn:hover { background: var(--ouro-lt); transform: translateY(-2px); box-shadow: 0 22px 50px rgba(196,160,90,.4); }
.hero-stats {
  position: absolute; bottom: 0; left: 0; right: 0; z-index: 2;
  display: flex; align-items: center; justify-content: center;
  background: rgba(14,10,7,.75); backdrop-filter: blur(12px);
  border-top: 1px solid rgba(196,160,90,.2);
  padding: 28px 40px;
  opacity: 0; animation: fadeIn .8s 1.4s forwards;
}
.stat { display: flex; flex-direction: column; align-items: center; text-align: center; }
.stat-n { font-family: 'Cormorant Garamond', serif; font-size: 48px; font-weight: 300; color: var(--ouro); line-height: 1; }
.stat-plus { font-family: 'Cormorant Garamond', serif; font-size: 32px; color: var(--ouro); display: inline; }
.stat p { font-size: 10px; letter-spacing: .2em; text-transform: uppercase; color: rgba(255,255,255,.5); margin-top: 4px; }
.stat-div { width: 1px; height: 48px; background: rgba(196,160,90,.25); margin: 0 56px; }

/* ── PILLS ─────────────────────────────────────── */
.pills-section { padding: 64px 80px; background: var(--bege); text-align: center; }
.pills-label { font-size: 10px; font-weight: 600; letter-spacing: .3em; text-transform: uppercase; color: var(--muted); margin-bottom: 28px; }
.pills { display: flex; flex-wrap: wrap; gap: 12px; justify-content: center; }
.pill { padding: 12px 28px; border: 1px solid rgba(107,21,53,.25); color: var(--vinho); font-size: 12px; font-weight: 500; letter-spacing: .15em; text-transform: uppercase; background: transparent; cursor: default; transition: background .25s, color .25s; }
.pill:hover { background: var(--vinho); color: #fff; }

/* ── PROPÓSITO ─────────────────────────────────── */
.proposito {
  position: relative; background: var(--dark-2); overflow: hidden;
  display: grid; grid-template-columns: 1fr 1fr; align-items: center;
  padding: 100px 80px; gap: 72px;
}
.prop-watermark {
  position: absolute; font-family: 'Cormorant Garamond', serif;
  font-size: clamp(120px, 16vw, 220px); font-weight: 300;
  color: rgba(196,160,90,.04); letter-spacing: .08em; text-transform: uppercase;
  top: 50%; left: 50%; transform: translate(-50%,-50%);
  white-space: nowrap; pointer-events: none; z-index: 0;
}
.prop-inner { position: relative; z-index: 1; }
.prop-label { font-size: 10px; font-weight: 600; letter-spacing: .3em; text-transform: uppercase; color: var(--ouro); margin-bottom: 24px; }
.prop-title { font-family: 'Cormorant Garamond', serif; font-size: clamp(32px, 3.2vw, 52px); font-weight: 300; color: #fff; line-height: 1.15; margin-bottom: 28px; letter-spacing: .02em; }
.prop-text { font-size: 14px; line-height: 1.9; color: rgba(255,255,255,.6); margin-bottom: 40px; }
.prop-text strong { color: rgba(255,255,255,.9); font-weight: 600; }
.prop-btn { display: inline-flex; align-items: center; gap: 8px; font-size: 11px; font-weight: 700; letter-spacing: .22em; text-transform: uppercase; color: var(--ouro); text-decoration: none; border-bottom: 1px solid rgba(196,160,90,.35); padding-bottom: 4px; transition: color .2s, border-color .2s; }
.prop-img-wrap { position: relative; z-index: 1; height: 600px; display: flex; align-items: center; justify-content: center; }
.prop-img { width: 85%; height: 95%; object-fit: cover; object-position: top; display: block; clip-path: ellipse(45% 50% at 50% 50%); transform: rotate(-3deg); }
.prop-img-frame { position: absolute; top: 0; left: 5%; width: 90%; height: 100%; border: 1px solid var(--ouro); border-radius: 50%; transform: rotate(5deg); pointer-events: none; }

/* ── MENTORIAS ─────────────────────────────────── */
.mentorias-section { padding: 100px 80px; background: var(--bege-2); }
.sec-header { text-align: center; margin-bottom: 64px; }
.sec-tag { font-size: 10px; font-weight: 600; letter-spacing: .3em; text-transform: uppercase; color: var(--ouro-dk); margin-bottom: 16px; }
.sec-title { font-family: 'Cormorant Garamond', serif; font-size: clamp(32px, 3.5vw, 52px); font-weight: 300; color: var(--vinho); letter-spacing: .03em; line-height: 1.1; }
.mentorias-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 2px; }
.m-card { background: var(--bege); padding: 52px 40px; position: relative; overflow: hidden; transition: transform .3s; }
.m-card::after { content: ""; position: absolute; top: 0; left: 0; width: 100%; height: 3px; background: linear-gradient(90deg, var(--vinho), var(--ouro)); transform: scaleX(0); transform-origin: left; transition: transform .4s; }
.m-card:hover { transform: translateY(-6px); }
.m-card:hover::after { transform: scaleX(1); }
.m-card-dark { background: var(--vinho); }
.m-card-dark .m-card-num { color: rgba(255,255,255,.25); }
.m-card-dark .m-card-name, .m-card-dark .m-card-desc { color: rgba(255,255,255,.9); }
.m-card-dark .m-card-desc { color: rgba(255,255,255,.6); }
.m-card-dark .m-card-link { color: var(--ouro); }
.m-card-num { font-family: 'Cormorant Garamond', serif; font-size: 64px; font-weight: 300; color: var(--bege-dk); line-height: 1; margin-bottom: 20px; }
.m-card-name { font-family: 'Cormorant Garamond', serif; font-size: 28px; font-weight: 400; color: var(--vinho); line-height: 1.2; margin-bottom: 16px; }
.m-card-desc { font-size: 13.5px; line-height: 1.85; color: var(--muted); margin-bottom: 36px; }
.m-card-link { font-size: 11px; font-weight: 700; letter-spacing: .2em; text-transform: uppercase; color: var(--vinho); text-decoration: none; transition: letter-spacing .2s; }
.m-card-link:hover { letter-spacing: .28em; }

/* ── SOBRE ─────────────────────────────────────── */
.sobre-section { padding: 100px 80px; background: var(--bege); }
.sobre-imgs { position: relative; height: 600px; }
.s-img-main { position: absolute; left: 0; top: 0; width: 68%; height: 100%; object-fit: cover; object-position: top; }
.s-img-sec  { position: absolute; right: 0; bottom: 48px; width: 46%; height: 55%; object-fit: cover; object-position: top; border: 6px solid var(--bege); }
.s-quote-chip { position: absolute; right: -40px; bottom: 80px; z-index: 3; background: var(--vinho); color: #fff; padding: 40px 32px; width: 240px; box-shadow: 0 24px 60px rgba(107,21,53,.3); border-radius: 2px; }
.s-quote-icon { font-family: 'Cormorant Garamond', serif; font-size: 72px; color: var(--ouro); display: block; line-height: 0.6; margin-bottom: 16px; }
.s-quote-chip p { font-family: 'Cormorant Garamond', serif; font-size: 20px; line-height: 1.4; font-style: italic; }
.sobre-body { font-size: 14.5px; line-height: 1.9; color: var(--muted); margin-bottom: 18px; }
.sobre-tags { display: flex; flex-wrap: wrap; gap: 10px; margin-top: 36px; }
.sobre-tags span { font-size: 10px; font-weight: 600; letter-spacing: .18em; text-transform: uppercase; color: var(--vinho); border: 1px solid rgba(107,21,53,.3); padding: 8px 16px; }

/* ── DEPOIMENTOS 3D ─────────────────────────────────────── */
.deps-section { padding: 80px 0 0 0; background: var(--dark); position: relative; overflow: hidden; height: 100vh; min-height: 800px; display: flex; flex-direction: column; justify-content: flex-start; }
.deps-section .sec-header { margin-bottom: 0; }
.deps-viewport {
  position: absolute; top: 0; left: 0; width: 100%; height: 100%;
  perspective: 1000px;
  overflow: hidden;
  pointer-events: none;
}
.deps-track {
  position: absolute; top: 50%; left: 50%;
  width: 0; height: 0;
  transform-style: preserve-3d;
}
.dep-card-3d {
  position: absolute;
  top: -140px; left: -190px;
  width: 380px; height: 280px;
  background: rgba(26,16,8,0.85);
  border: 1px solid rgba(196,160,90,.15);
  padding: 40px;
  display: flex; flex-direction: column; justify-content: space-between;
  backdrop-filter: blur(12px);
  will-change: transform, opacity, filter;
  transition: border-color 0.4s;
  pointer-events: auto;
  cursor: pointer;
}
.dep-card-3d:hover { border-color: rgba(196,160,90,.6); }
.dep-card-3d .dep-stars { color: var(--ouro); letter-spacing: 4px; font-size: 14px; margin-bottom: 20px; }
.dep-card-3d .dep-text { font-family: 'Cormorant Garamond', serif; font-size: 18px; font-style: italic; color: #fff; line-height: 1.6; margin-bottom: 24px; flex-grow: 1; }
.dep-card-3d .dep-author { display: flex; align-items: center; gap: 16px; margin-top: auto; }
.dep-card-3d .dep-author img { width: 44px; height: 44px; border-radius: 50%; object-fit: cover; }
.dep-card-3d .dep-author div { display: flex; flex-direction: column; }
.dep-card-3d .dep-author strong { font-size: 13px; font-weight: 500; color: var(--ouro); text-transform: uppercase; letter-spacing: .1em; }
.dep-card-3d .dep-author span { font-size: 10px; color: rgba(255,255,255,.5); text-transform: uppercase; letter-spacing: .15em; margin-top: 4px; }
/* ── GALERIA ─────────────────────────────────────── */
.gallery-section { overflow: hidden; }
.gallery-strip { display: flex; }
.gallery-strip img { width: calc(100% / 6); height: 280px; object-fit: cover; object-position: top; flex-shrink: 0; filter: saturate(.7); transition: filter .4s, transform .4s; }
.gallery-strip img:hover { filter: saturate(1); transform: scale(1.04); z-index: 1; }

/* ── CTA ─────────────────────────────────────────── */
.cta-section { background: var(--vinho); padding: 110px 80px; text-align: center; position: relative; overflow: hidden; }
.cta-section::before { content: ""; position: absolute; width: 700px; height: 700px; border-radius: 50%; border: 1px solid rgba(255,255,255,.06); top: 50%; left: 50%; transform: translate(-50%,-50%); }
.cta-section::after  { content: ""; position: absolute; width: 1000px; height: 1000px; border-radius: 50%; border: 1px solid rgba(255,255,255,.03); top: 50%; left: 50%; transform: translate(-50%,-50%); }
.cta-tag { font-size: 10px; font-weight: 600; letter-spacing: .3em; text-transform: uppercase; color: rgba(255,255,255,.5); margin-bottom: 20px; position: relative; z-index: 1; }
.cta-title { font-family: 'Cormorant Garamond', serif; font-size: clamp(40px, 5vw, 72px); font-weight: 300; color: #fff; letter-spacing: .04em; line-height: 1.1; margin-bottom: 16px; position: relative; z-index: 1; }
.cta-sub { font-size: 15px; color: rgba(255,255,255,.6); margin-bottom: 52px; position: relative; z-index: 1; }
.cta-btn { display: inline-flex; align-items: center; gap: 12px; background: var(--ouro); color: var(--dark); font-size: 12px; font-weight: 700; letter-spacing: .22em; text-transform: uppercase; padding: 0 56px; height: 64px; text-decoration: none; position: relative; z-index: 1; transition: background .25s, transform .2s; }
.cta-btn:hover { background: var(--ouro-lt); transform: translateY(-2px); }

/* ── FOOTER ──────────────────────────────────────── */
footer { background: var(--dark); padding: 72px 80px 36px; }
.footer-top { display: grid; grid-template-columns: 1.5fr 1fr 1fr 1fr; gap: 48px; padding-bottom: 52px; border-bottom: 1px solid rgba(255,255,255,.07); margin-bottom: 36px; }
.footer-name { font-family: 'Cormorant Garamond', serif; font-size: 26px; font-weight: 300; color: #fff; letter-spacing: .25em; text-transform: uppercase; margin-bottom: 6px; }
.footer-role { font-size: 10px; letter-spacing: .2em; text-transform: uppercase; color: var(--ouro); margin-bottom: 16px; }
.footer-desc { font-size: 13px; line-height: 1.8; color: rgba(255,255,255,.4); max-width: 240px; }
.footer-col-title { font-size: 10px; font-weight: 700; letter-spacing: .22em; text-transform: uppercase; color: rgba(255,255,255,.7); margin-bottom: 20px; }
footer ul { list-style: none; display: flex; flex-direction: column; gap: 12px; }
footer a { font-size: 13px; color: rgba(255,255,255,.4); text-decoration: none; transition: color .2s; }
footer a:hover { color: var(--ouro); }
.footer-bottom { text-align: center; font-size: 11px; color: rgba(255,255,255,.25); letter-spacing: .1em; }

/* ── ANIMATIONS ──────────────────────────────────── */
@keyframes fadeUp { from { opacity:0; transform:translateY(28px); } to { opacity:1; transform:translateY(0); } }
@keyframes fadeIn { from { opacity:0; } to { opacity:1; } }

.js-enabled .reveal { opacity:0; transform:translateY(40px); transition:opacity .75s cubic-bezier(.16,1,.3,1), transform .75s cubic-bezier(.16,1,.3,1); }
.js-enabled .reveal.on { opacity:1; transform:none; }
.js-enabled .reveal-l { opacity:0; transform:translateX(-40px); transition:opacity .8s cubic-bezier(.16,1,.3,1), transform .8s cubic-bezier(.16,1,.3,1); }
.js-enabled .reveal-l.on { opacity:1; transform:none; }
.js-enabled .reveal-r { opacity:0; transform:translateX(40px); transition:opacity .8s cubic-bezier(.16,1,.3,1), transform .8s cubic-bezier(.16,1,.3,1); }
.js-enabled .reveal-r.on { opacity:1; transform:none; }

/* ── RESPONSIVE ──────────────────────────────────── */
@media (max-width: 1100px) {
  #navbar { padding: 0 32px; }
  .hero-content, .hero-stats { padding-left: 40px; padding-right: 40px; }
  .proposito, .sobre-section, .mentorias-section, .deps-section, .cta-section, .pills-section, footer { padding-left: 40px; padding-right: 40px; }
  .deps-grid, .mentorias-grid { grid-template-columns: 1fr 1fr; }
  .footer-top { grid-template-columns: 1fr 1fr; }
}
@media (max-width: 800px) {
  .nav-links, .nav-cta { display: none; }
  .hamburger { display: flex; }
  #navbar { padding: 0 24px; }
  .hero-content { padding: 0 24px; max-width: 100%; }
  .hero-name { font-size: clamp(48px, 12vw, 64px); letter-spacing: .05em; margin-bottom: 12px; }
  .hero-sub { margin-bottom: 12px; }
  .hero-desc { margin-bottom: 24px; max-width: 90%; }
  .hero-photo { width: 100%; opacity: 0.8; -webkit-mask-image: linear-gradient(to top, transparent 0%, black 60%); mask-image: linear-gradient(to top, transparent 0%, black 60%); }
  .hero-overlay { background: linear-gradient(to top, var(--dark-2) 0%, rgba(26,16,8,0.85) 50%, transparent 100%); }
  .hero-stats { padding: 20px 24px; flex-wrap: wrap; gap: 20px; justify-content: center; position: relative; }
  .stat-div { display: none; }
  .proposito { grid-template-columns: 1fr; padding: 60px 24px; }
  .prop-img-wrap { height: 380px; }
  .prop-watermark { display: none; }
  .sobre-section { padding: 48px 24px; }
  .sobre-title { white-space: normal; font-size: clamp(28px, 8vw, 40px); }
  .sobre-img-wrap {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 0;
  }
  .sobre-img {
    height: 280px !important;
    width: 100% !important;
    object-fit: cover !important;
    object-position: center top !important;
    border-radius: 8px 8px 0 0;
    box-shadow: 0 12px 32px rgba(0,0,0,.08) !important;
  }
  .s-quote-chip {
    position: static;
    width: 100%;
    max-width: 100%;
    border-radius: 0 0 8px 8px;
    padding: 20px 24px;
    box-shadow: 0 12px 32px rgba(107,21,53,.2);
    margin-top: 0;
  }
  .s-quote-icon { font-size: 40px; margin-bottom: 6px; line-height: 1; }
  .s-quote-chip p { font-size: 15px; }
  .mentorias-grid, .deps-grid { grid-template-columns: 1fr; padding: 60px 24px; }
  .mentorias-section, .deps-section, .cta-section, .pills-section { padding: 60px 24px; }
  .deps-section { padding-top: 80px; min-height: 600px; height: 100vh; }
  .dep-card-3d { width: 280px; height: auto; min-height: 240px; top: -120px; left: -140px; padding: 24px; }
  .dep-card-3d .dep-text { font-size: 16px; margin-bottom: 16px; }
  .dep-card-3d .dep-author img { width: 36px; height: 36px; }
  .gallery-strip img { width: calc(100% / 3); }
  footer { padding: 48px 24px 28px; }
  .footer-top { grid-template-columns: 1fr; }
  .cta-section { padding: 72px 24px; }
}


/* ── NEW LAYOUT UTILS ─────────────────────────── */
.pd-120 { padding: 120px 0; }
.dark-bg { background: var(--dark-2); color: #fff; }
.bege-bg { background: var(--bege); color: var(--text); }
.white-bg { background: #fff; color: var(--text); }
.vinho-bg {
  background: var(--dark-2);
  position: relative;
  color: #fff;
}
.vinho-bg::before {
  content: "";
  position: absolute;
  inset: 0;
  background: 
    radial-gradient(ellipse 80% 60% at 50% 0%, rgba(107,21,53,0.45) 0%, transparent 70%),
    radial-gradient(ellipse 60% 50% at 80% 100%, rgba(78,14,37,0.3) 0%, transparent 60%);
  z-index: 0;
  pointer-events: none;
}
.vinho-bg .container { position: relative; z-index: 1; }
.text-center { text-align: center; }
.container { max-width: 1200px; margin: 0 auto; padding: 0 40px; }
.grid-2 { display: grid; grid-template-columns: 1fr 1fr; gap: 80px; }
.align-center { align-items: center; }
.ouro { color: var(--ouro); }
.dark-text { color: var(--text); }
.mx-auto { margin-left: auto; margin-right: auto; }

/* ── UPDATED HERO & STRIP ──────────────────────── */
.hero-name-light { font-family: 'Cormorant Garamond', serif; font-style: italic; font-weight: 300; font-size: clamp(32px, 4vw, 48px); color: rgba(255,255,255,.8); letter-spacing: 0; display: block; margin-top: 12px; }
.hero-bullets { list-style: none; margin-bottom: 40px; opacity: 0; animation: fadeUp .8s .9s forwards; font-size: 14px; color: rgba(255,255,255,.8); }
.hero-bullets li { position: relative; padding-left: 20px; margin-bottom: 12px; }
.hero-bullets li::before { content: "✦"; position: absolute; left: 0; top: 0; color: var(--ouro); font-size: 12px; }
.hero-actions { display: flex; gap: 20px; align-items: center; flex-wrap: wrap; opacity: 0; animation: fadeUp .8s 1.05s forwards; }
.hero-btn-sec { font-size: 11px; font-weight: 600; letter-spacing: .2em; text-transform: uppercase; color: var(--ouro); text-decoration: none; border-bottom: 1px solid rgba(196,160,90,.3); padding-bottom: 4px; transition: color .2s, border-color .2s; }
.hero-btn-sec:hover { color: #fff; border-color: rgba(255,255,255,.5); }

.auth-strip { 
  display: flex; flex-wrap: wrap; justify-content: space-between;
  background: linear-gradient(135deg, rgba(26,16,8,0.95), rgba(14,10,7,0.98)); 
  backdrop-filter: blur(16px); 
  border: 1px solid rgba(196,160,90,.2); 
  border-radius: 16px;
  width: 100%;
  margin: 40px auto 80px; 
  position: relative; z-index: 10;
  box-shadow: 0 32px 60px rgba(0,0,0,0.4), inset 0 1px 0 rgba(255,255,255,0.05);
  padding: 40px 20px;
}
.auth-item { 
  flex: 1; padding: 0 24px; text-align: center; 
  display: flex; flex-direction: column; align-items: center; justify-content: center;
  position: relative;
}
.auth-item:not(:last-child)::after {
  content: ""; position: absolute; right: 0; top: 10%; height: 80%; width: 1px;
  background: linear-gradient(to bottom, transparent, rgba(196,160,90,.2), transparent);
}
.auth-item strong { 
  font-family: 'Libre Bodoni', serif; font-size: clamp(16px, 2.5vw, 26px); font-weight: 500; font-style: italic; 
  color: var(--ouro-lt); margin-bottom: 6px; letter-spacing: 0; 
}
.auth-item span { 
  font-size: 11px; font-weight: 500; letter-spacing: .15em; text-transform: uppercase; 
  color: rgba(255,255,255,.5); line-height: 1.5; 
}

/* ── SEC TITLES ───────────────────────────────── */
.sec-title { font-family: 'Libre Bodoni', serif; font-size: clamp(36px, 4vw, 56px); font-weight: 400; letter-spacing: 0; line-height: 1.15; margin-bottom: 24px; color: var(--vinho-dk); }
.dark-bg .sec-title,
.vinho-bg .sec-title { color: #fff; }
.sec-subtitle { font-size: 15px; line-height: 1.8; color: var(--muted); max-width: 700px; margin: 0 auto 64px; }
.dark-bg .sec-subtitle,
.vinho-bg .sec-subtitle { color: rgba(255,255,255,.6); }
.sec-tag { font-size: 10px; font-weight: 600; letter-spacing: .3em; text-transform: uppercase; color: var(--ouro); margin-bottom: 16px; }

/* ── DOR SECTION ──────────────────────────────── */
.dor-section { position: relative; }
.dor-glow { position: absolute; width: 600px; height: 600px; background: radial-gradient(circle, rgba(196,160,90,0.12) 0%, transparent 60%); top: 50%; left: 50%; transform: translate(-50%, -50%); z-index: 0; pointer-events: none; }
.dor-grid { position: relative; z-index: 1; display: flex; flex-wrap: wrap; justify-content: center; gap: 24px; margin-top: 64px; }
.dor-card { flex: 1 1 300px; max-width: 380px; background: linear-gradient(145deg, rgba(26,16,8,0.6), rgba(14,10,7,0.8)); backdrop-filter: blur(12px); border: 1px solid rgba(196,160,90,.15); border-radius: 12px; padding: 48px 40px; transition: all .4s cubic-bezier(0.4, 0, 0.2, 1); box-shadow: 0 16px 40px rgba(0,0,0,0.3); position: relative; overflow: hidden; }
.dor-card::before { content: ""; position: absolute; top: 0; left: 0; width: 100%; height: 3px; background: linear-gradient(90deg, transparent, var(--ouro-lt), transparent); opacity: 0.3; transition: opacity .4s; }
.dor-card:hover { transform: translateY(-8px); border-color: rgba(196,160,90,.4); box-shadow: 0 24px 60px rgba(196,160,90,.15); }
.dor-card:hover::before { opacity: 1; }
.dor-card h3 { font-family: 'Libre Bodoni', serif; font-size: 24px; font-weight: 400; font-style: italic; color: var(--ouro-lt); margin-bottom: 20px; line-height: 1.3; }
.dor-card p { font-size: 15px; line-height: 1.8; color: rgba(255,255,255,.6); font-weight: 300; }

/* ── O QUE É SECTION ──────────────────────────── */
.oque-text { font-size: 16px; line-height: 1.8; margin-bottom: 24px; }
.oque-highlight { font-family: 'Cormorant Garamond', serif; font-size: 24px; font-style: italic; color: var(--vinho); margin-top: 32px; border-left: 2px solid var(--ouro); padding-left: 20px; }
.oque-features { display: flex; flex-direction: column; gap: 32px; }
.feat-item { position: relative; padding-left: 48px; font-size: 14px; line-height: 1.6; color: var(--muted); }
.feat-item::before { content: "✦"; position: absolute; left: 0; top: -4px; font-size: 24px; color: var(--ouro); font-weight: 300; }
.feat-item strong { display: block; font-size: 16px; color: var(--text); font-weight: 600; margin-bottom: 6px; }

/* ── PARA QUEM É SECTION ──────────────────────── */
.check-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 24px; margin-top: 56px; }
.check-item { background: rgba(14,10,7,.5); padding: 32px; border-left: 2px solid var(--ouro); font-size: 15px; line-height: 1.7; color: rgba(255,255,255,.8); }

/* ── ANTES / DEPOIS ───────────────────────────── */
.ad-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 2px; background: rgba(107,21,53,.15); margin-top: 56px; }
.ad-col { background: var(--bege); padding: 56px; }
.ad-col h3 { font-family: 'Cormorant Garamond', serif; font-size: 32px; font-weight: 400; text-align: center; margin-bottom: 32px; color: var(--text); }
.ad-col ul { list-style: none; display: flex; flex-direction: column; gap: 16px; }
.ad-col li { font-size: 15px; padding-bottom: 16px; border-bottom: 1px solid rgba(0,0,0,.05); position: relative; padding-left: 28px; }
.antes-col li::before { content: "✕"; position: absolute; left: 0; top: 0; color: #a8863c; opacity: 0.5; }
.antes-col li { color: var(--muted); }
.depois-col { background: #fff; }
.depois-col h3 { color: var(--vinho); }
.depois-col li { color: var(--text); font-weight: 500; }
.depois-col li::before { content: "✓"; position: absolute; left: 0; top: 0; color: var(--ouro); }

/* ── PROGRAMAS VITRINE ────────────────────────── */
.prog-gallery { display: grid; grid-template-columns: repeat(auto-fit, minmax(300px, 1fr)); gap: 32px; margin-top: 64px; }
.prog-img { width: 100%; height: auto; transition: transform .4s, filter .4s; -webkit-mask-image: linear-gradient(to bottom, transparent 0%, black 10%, black 90%, transparent 100%); mask-image: linear-gradient(to bottom, transparent 0%, black 10%, black 90%, transparent 100%); }
.prog-img:hover { transform: translateY(-8px); filter: brightness(1.1); }

/* ── POR ONDE COMEÇAR ─────────────────────────── */
.comecar-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(300px, 1fr)); gap: 16px; margin-top: 56px; }
.com-card { background: #fff; padding: 32px; border: 1px solid rgba(196,160,90,.2); border-top: 3px solid var(--vinho); text-align: center; transition: transform .3s; }
.com-card:hover { transform: translateY(-4px); box-shadow: 0 16px 40px rgba(0,0,0,.04); }
.com-card p { font-size: 12px; font-weight: 600; text-transform: uppercase; letter-spacing: .15em; color: var(--muted); margin-bottom: 12px; }
.com-card strong { font-family: 'Cormorant Garamond', serif; font-size: 22px; font-weight: 400; color: var(--vinho); }

/* ── METODOLOGIA ──────────────────────────────── */
.met-grid { display: flex; flex-wrap: wrap; justify-content: center; gap: 40px 32px; margin-top: 80px; }
.met-item { flex: 1 1 280px; max-width: 340px; position: relative; background: linear-gradient(145deg, rgba(26,16,8,0.4), transparent); border: 1px solid rgba(196,160,90,.08); border-radius: 16px; padding: 48px 32px; text-align: left; overflow: hidden; transition: transform .4s, border-color .4s; }
.met-item:hover { transform: translateY(-4px); border-color: rgba(196,160,90,.25); }
.met-num { position: absolute; top: -16px; right: -8px; font-family: 'Libre Bodoni', serif; font-style: italic; font-size: 160px; font-weight: 500; color: rgba(196,160,90, 0.04); line-height: 1; pointer-events: none; z-index: 0; }
.met-item h3 { font-family: 'Libre Bodoni', serif; font-size: 22px; font-weight: 400; color: var(--ouro-lt); margin-bottom: 16px; line-height: 1.3; position: relative; z-index: 1; }
.met-item p { font-size: 14px; line-height: 1.8; color: rgba(255,255,255,.6); font-weight: 300; position: relative; z-index: 1; }

/* ── SOBRE ────────────────────────────────────── */
.sobre-img-wrap { position: relative; }
.sobre-img { width: 100%; height: 640px; object-fit: cover; object-position: center top; border-radius: 4px; box-shadow: 0 24px 60px rgba(0,0,0,.08); }
.sobre-tag { font-family: 'Inter', sans-serif; font-size: 10px; font-weight: 600; letter-spacing: .1em; text-transform: uppercase; color: var(--ouro-dk); margin-bottom: 14px; display: block; }
.sobre-title { font-family: 'Cormorant Garamond', serif; font-size: clamp(40px, 4vw, 56px); font-weight: 300; color: var(--text); line-height: 1.1; margin-bottom: 24px; letter-spacing: .02em; white-space: nowrap; }
.sobre-text p { font-size: 15px; line-height: 1.8; margin-bottom: 24px; color: var(--muted); }

/* ── DIFERENCIAIS ─────────────────────────────── */
.dif-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 2px; background: rgba(196,160,90,.15); margin-top: 56px; }
.dif-card { background: var(--dark-2); padding: 48px 40px; text-align: center; }
.dif-card strong { display: block; font-family: 'Cormorant Garamond', serif; font-size: 24px; font-weight: 400; color: var(--ouro); margin-bottom: 16px; }
.dif-card p { font-size: 14px; line-height: 1.7; color: rgba(255,255,255,.6); }

/* ── OFERTA E BONUS ───────────────────────────── */
.oferta-box {
  background: linear-gradient(145deg, rgba(107,21,53,0.12) 0%, rgba(14,10,7,0.6) 40%, rgba(78,14,37,0.08) 100%);
  border: 1px solid rgba(196,160,90,.25);
  padding: 72px 64px;
  border-radius: 4px;
  box-shadow: 0 40px 80px rgba(0,0,0,.5), inset 0 1px 0 rgba(196,160,90,.15);
  position: relative;
  overflow: hidden;
}
.oferta-box::before {
  content: "";
  position: absolute;
  top: 0; left: 0; right: 0; height: 2px;
  background: linear-gradient(90deg, transparent, var(--ouro), var(--ouro-lt), var(--ouro), transparent);
  opacity: 0.6;
}
.oferta-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 64px; margin-top: 56px; }

/* Divisória vertical entre colunas */
.oferta-inclusos {
  padding-right: 48px;
  border-right: 1px solid rgba(196,160,90,.15);
}
.oferta-inclusos h3 {
  font-family: 'Inter', sans-serif;
  font-size: 10px;
  font-weight: 700;
  letter-spacing: .28em;
  text-transform: uppercase;
  color: var(--ouro-dk);
  margin-bottom: 32px;
  padding-bottom: 20px;
  border-bottom: 1px solid rgba(196,160,90,.2);
}
.oferta-bonus h3 {
  font-family: 'Inter', sans-serif;
  font-size: 10px;
  font-weight: 700;
  letter-spacing: .28em;
  text-transform: uppercase;
  color: var(--ouro-dk);
  margin-bottom: 32px;
  padding-bottom: 20px;
  border-bottom: 1px solid rgba(196,160,90,.2);
}
.oferta-inclusos ul, .oferta-bonus ul {
  list-style: none;
  display: flex;
  flex-direction: column;
  gap: 0;
  margin-bottom: 48px;
}
.oferta-inclusos li {
  font-size: 14.5px;
  font-weight: 400;
  color: rgba(255,255,255,.82);
  padding: 14px 0;
  border-bottom: 1px solid rgba(255,255,255,.05);
  display: flex;
  align-items: center;
  gap: 14px;
  line-height: 1.4;
}
.oferta-inclusos li::before {
  content: "✓";
  flex-shrink: 0;
  width: 22px; height: 22px;
  border-radius: 50%;
  background: rgba(196,160,90,.15);
  border: 1px solid rgba(196,160,90,.3);
  color: var(--ouro);
  font-size: 11px;
  font-weight: 700;
  display: flex;
  align-items: center;
  justify-content: center;
  text-align: center;
  line-height: 22px;
}
.oferta-bonus li {
  font-size: 14.5px;
  font-weight: 400;
  color: rgba(255,255,255,.82);
  padding: 14px 0;
  border-bottom: 1px solid rgba(255,255,255,.05);
  display: flex;
  align-items: center;
  gap: 14px;
  line-height: 1.4;
}
.oferta-bonus li::before {
  content: "✦";
  flex-shrink: 0;
  width: 22px; height: 22px;
  border-radius: 4px;
  background: rgba(196,160,90,.1);
  border: 1px solid rgba(196,160,90,.25);
  color: var(--ouro-lt);
  font-size: 9px;
  display: flex;
  align-items: center;
  justify-content: center;
  text-align: center;
  line-height: 22px;
}
.cta-wrap { text-align: center; margin-top: 8px; }
.cta-btn-large {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: linear-gradient(to right, var(--ouro-dk), var(--ouro-lt), var(--ouro-dk));
  background-size: 200% auto;
  color: var(--dark);
  font-size: 12px;
  font-weight: 700;
  letter-spacing: .2em;
  text-transform: uppercase;
  padding: 0 48px;
  height: 60px;
  text-decoration: none;
  border-radius: 2px;
  transition: background-position .4s, transform .2s, box-shadow .2s;
  box-shadow: 0 12px 32px rgba(196,160,90,.3);
  width: 100%;
}
.cta-btn-large:hover {
  background-position: right center;
  transform: translateY(-2px);
  box-shadow: 0 20px 48px rgba(196,160,90,.45);
}
.cta-micro {
  font-size: 10px;
  letter-spacing: .12em;
  color: rgba(255,255,255,.35);
  margin-top: 16px;
  text-transform: uppercase;
}

/* ── FAQ ──────────────────────────────────────── */
.faq-list { max-width: 800px; margin: 56px auto 0; display: flex; flex-direction: column; gap: 16px; }
.faq-item { background: rgba(255,255,255,.03); padding: 32px; border: 1px solid rgba(255,255,255,.06); }
.faq-item h4 { font-size: 16px; font-weight: 600; color: var(--ouro); margin-bottom: 12px; }
.faq-item p { font-size: 14.5px; line-height: 1.7; color: rgba(255,255,255,.7); }

/* ── CTA FINAL ────────────────────────────────── */
.cta-final { position: relative; overflow: hidden; }
.cta-final-bg { position: absolute; inset: 0; background: radial-gradient(circle at center, rgba(107,21,53,.3) 0%, transparent 60%); z-index: 0; }
.cta-final .container { position: relative; z-index: 1; }

/* ── RESPONSIVE FIXES FOR NEW SECTIONS ────────── */
@media (max-width: 800px) {
  .pd-120 { padding: 80px 0; }
  .auth-strip { 
    margin: 0 16px 48px; 
    display: grid; 
    grid-template-columns: 1fr 1fr; 
    gap: 0; 
    padding: 24px 8px; 
  }
  .auth-item { 
    padding: 16px 12px; 
  }
  .auth-item strong { font-size: 17px; margin-bottom: 4px; }
  .auth-item span { font-size: 9px; letter-spacing: .1em; }
  .auth-item:not(:last-child)::after { display: none; }
  /* Divisórias no grid 2x2 */
  .auth-item:nth-child(1),
  .auth-item:nth-child(2) {
    border-bottom: 1px solid rgba(196,160,90,.15);
    padding-bottom: 20px;
  }
  .auth-item:nth-child(1),
  .auth-item:nth-child(3) {
    border-right: 1px solid rgba(196,160,90,.15);
  }
  .grid-2 { grid-template-columns: 1fr; gap: 40px; }
  .check-grid { grid-template-columns: 1fr; }
  .ad-grid { grid-template-columns: 1fr; }
  .ad-col { padding: 40px 24px; }
  .prog-card { flex-direction: column; }
  .prog-num { width: 100%; border-right: none; border-bottom: 1px solid rgba(255,255,255,.06); padding: 32px; font-size: 64px; }
  .prog-content { padding: 32px 24px; }
  .dif-grid { grid-template-columns: 1fr; }
  .oferta-box { padding: 40px 24px; border-radius: 4px; }
  .oferta-grid { grid-template-columns: 1fr; gap: 40px; }
  .oferta-inclusos { padding-right: 0; border-right: none; padding-bottom: 40px; border-bottom: 1px solid rgba(196,160,90,.15); }
  .hero-actions { flex-direction: column; width: 100%; align-items: stretch; }
  .hero-actions { flex-direction: column; width: 100%; align-items: stretch; }
  .hero-btn { text-align: center; justify-content: center; }
  .hero-btn-sec { text-align: center; border: none; }
}

/* ═══════════════════════════════════════════
   PRICING TABLE — Tabela de Planos Premium
   ═══════════════════════════════════════════ */

/* Mini strip de inclusos */
.oferta-inclusos-mini {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 12px 28px;
  margin: 0 auto 56px;
  max-width: 800px;
}
.oferta-inclusos-mini span {
  font-size: 12px;
  font-weight: 500;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: rgba(255,255,255,.55);
}

/* Grid dos 3 planos */
.pricing-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 24px;
  align-items: stretch;
  margin-bottom: 48px;
}

/* Card base */
.pricing-card {
  background: linear-gradient(160deg, rgba(26,16,8,0.7) 0%, rgba(14,10,7,0.9) 100%);
  border: 1px solid rgba(196,160,90,.18);
  border-radius: 16px;
  padding: 0 32px 36px;
  display: flex;
  flex-direction: column;
  transition: transform .35s cubic-bezier(.16,1,.3,1), border-color .35s, box-shadow .35s;
  position: relative;
  overflow: hidden;
}
.pricing-card::before {
  content: "";
  position: absolute;
  top: 0; left: 0; right: 0; height: 1px;
  background: linear-gradient(90deg, transparent, rgba(196,160,90,.3), transparent);
}
.pricing-card:hover {
  transform: translateY(-6px);
  border-color: rgba(196,160,90,.35);
  box-shadow: 0 32px 64px rgba(0,0,0,.4);
}

/* Card em destaque */
.pricing-featured {
  background: linear-gradient(160deg, rgba(107,21,53,0.25) 0%, rgba(26,16,8,0.92) 50%, rgba(78,14,37,0.2) 100%);
  border: 1px solid rgba(196,160,90,.45);
  box-shadow: 0 24px 80px rgba(107,21,53,.25), 0 0 0 1px rgba(196,160,90,.1);
  transform: translateY(-12px);
}
.pricing-featured::before {
  background: linear-gradient(90deg, transparent, var(--ouro), var(--ouro-lt), var(--ouro), transparent);
  opacity: 0.7;
}
.pricing-featured:hover {
  transform: translateY(-18px);
  box-shadow: 0 40px 80px rgba(107,21,53,.35), 0 0 0 1px rgba(196,160,90,.25);
}

/* Badge area */
.pricing-badge-wrap {
  min-height: 36px;
  display: flex;
  align-items: center;
  justify-content: center;
  margin-bottom: 8px;
  padding-top: 20px;
}
.pricing-badge {
  display: inline-block;
  font-size: 10px;
  font-weight: 700;
  letter-spacing: .18em;
  text-transform: uppercase;
  background: rgba(107,21,53,.6);
  color: var(--ouro-lt);
  border: 1px solid rgba(196,160,90,.3);
  border-radius: 100px;
  padding: 6px 18px;
  backdrop-filter: blur(8px);
}
.pricing-badge-gold {
  background: rgba(196,160,90,.12);
  color: var(--ouro-lt);
  border-color: rgba(196,160,90,.4);
}

/* Label do plano */
.pricing-label {
  font-family: 'Inter', sans-serif;
  font-size: 10px;
  font-weight: 700;
  letter-spacing: .3em;
  text-transform: uppercase;
  color: var(--ouro-dk);
  text-align: center;
  margin-bottom: 20px;
}

/* Preço */
.pricing-price-wrap {
  display: flex;
  align-items: flex-end;
  justify-content: center;
  gap: 4px;
  margin-bottom: 6px;
  line-height: 1;
}
.pricing-currency {
  font-family: 'Inter', sans-serif;
  font-size: 20px;
  font-weight: 300;
  color: rgba(255,255,255,.6);
  align-self: flex-start;
  margin-top: 10px;
}
.pricing-value {
  font-family: 'Cormorant Garamond', serif;
  font-size: clamp(52px, 6vw, 72px);
  font-weight: 300;
  color: #fff;
  line-height: 1;
  letter-spacing: -.02em;
}
.pricing-featured .pricing-value { color: var(--ouro-lt); }
.pricing-period {
  font-family: 'Inter', sans-serif;
  font-size: 13px;
  font-weight: 400;
  color: rgba(255,255,255,.45);
  align-self: flex-end;
  margin-bottom: 8px;
}

/* Parcelamento e economia */
.pricing-equiv {
  text-align: center;
  font-size: 13px;
  color: rgba(255,255,255,.5);
  margin-bottom: 6px;
}
.pricing-equiv strong { color: rgba(255,255,255,.8); font-weight: 600; }
.pricing-economy {
  text-align: center;
  font-size: 11px;
  font-weight: 600;
  letter-spacing: .08em;
  color: var(--ouro-dk);
  text-transform: uppercase;
  margin-bottom: 24px;
  background: rgba(196,160,90,.08);
  border-radius: 4px;
  padding: 6px 12px;
}
.pricing-desc {
  text-align: center;
  font-size: 13px;
  line-height: 1.6;
  color: rgba(255,255,255,.4);
  margin-bottom: 28px;
}

/* Separador */
.pricing-features {
  list-style: none;
  border-top: 1px solid rgba(196,160,90,.12);
  padding-top: 24px;
  margin-bottom: 32px;
  display: flex;
  flex-direction: column;
  gap: 12px;
  flex: 1;
}
.pricing-features li {
  font-size: 13.5px;
  color: rgba(255,255,255,.65);
  padding-left: 22px;
  position: relative;
  line-height: 1.5;
}
.pricing-features li::before {
  content: "✓";
  position: absolute;
  left: 0;
  color: var(--ouro-dk);
  font-size: 12px;
  font-weight: 700;
}
.pricing-featured .pricing-features li { color: rgba(255,255,255,.8); }
.pricing-featured .pricing-features li::before { color: var(--ouro-lt); }

/* Botão */
.pricing-btn {
  display: flex;
  align-items: center;
  justify-content: center;
  background: rgba(196,160,90,.08);
  border: 1px solid rgba(196,160,90,.3);
  color: var(--ouro-lt);
  font-size: 11px;
  font-weight: 700;
  letter-spacing: .18em;
  text-transform: uppercase;
  height: 52px;
  text-decoration: none;
  border-radius: 6px;
  transition: background .25s, border-color .25s, transform .2s;
  margin-bottom: 14px;
}
.pricing-btn:hover {
  background: rgba(196,160,90,.15);
  border-color: rgba(196,160,90,.6);
  transform: translateY(-1px);
}
.pricing-btn-featured {
  background: linear-gradient(to right, var(--ouro-dk), var(--ouro-lt), var(--ouro-dk));
  background-size: 200% auto;
  border: none;
  color: var(--dark);
  box-shadow: 0 8px 24px rgba(196,160,90,.3);
}
.pricing-btn-featured:hover {
  background-position: right center;
  background-size: 200% auto;
  border: none;
  color: var(--dark);
  box-shadow: 0 16px 40px rgba(196,160,90,.45);
  transform: translateY(-2px);
}

/* Micro texto */
.pricing-micro {
  text-align: center;
  font-size: 10px;
  letter-spacing: .12em;
  color: rgba(255,255,255,.25);
  text-transform: uppercase;
}

/* Garantia */
.pricing-guarantee {
  text-align: center;
  font-size: 12px;
  letter-spacing: .1em;
  color: rgba(255,255,255,.35);
  text-transform: uppercase;
  margin-top: 8px;
}

/* ── PRICING RESPONSIVE ─────────────────────── */
@media (max-width: 900px) {
  .pricing-grid {
    grid-template-columns: 1fr;
    max-width: 420px;
    margin-left: auto;
    margin-right: auto;
    gap: 16px;
  }
  .pricing-featured {
    transform: none;
    order: -1;
  }
  .pricing-featured:hover { transform: translateY(-6px); }
  .oferta-inclusos-mini { gap: 8px 20px; }
  .oferta-inclusos-mini span { font-size: 11px; }
}

/* ── FLOATING WHATSAPP ───────────────────────── */
.whatsapp-float {
  position: fixed;
  bottom: 32px;
  right: 32px;
  width: 60px;
  height: 60px;
  background: linear-gradient(135deg, #25D366 0%, #128C7E 100%);
  color: #fff;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 9999;
  box-shadow: 0 8px 32px rgba(18, 140, 126, 0.4), inset 0 2px 2px rgba(255, 255, 255, 0.2);
  transition: transform 0.3s cubic-bezier(0.175, 0.885, 0.32, 1.275), box-shadow 0.3s ease;
  text-decoration: none;
}
.whatsapp-float:hover {
  transform: scale(1.1) rotate(8deg);
  box-shadow: 0 12px 40px rgba(18, 140, 126, 0.6), inset 0 2px 2px rgba(255, 255, 255, 0.3);
}
.whatsapp-icon {
  width: 32px;
  height: 32px;
  fill: currentColor;
  transition: transform 0.3s ease;
}
.whatsapp-float:hover .whatsapp-icon {
  transform: scale(1.05);
}
.whatsapp-pulse {
  position: absolute;
  inset: -4px;
  border-radius: 50%;
  border: 2px solid #25D366;
  opacity: 0;
  pointer-events: none;
  animation: whatsappPulse 2s infinite ease-out;
}
@keyframes whatsappPulse {
  0% {
    transform: scale(0.95);
    opacity: 0.8;
  }
  50% {
    opacity: 0.3;
  }
  100% {
    transform: scale(1.25);
    opacity: 0;
  }
}
@media (max-width: 800px) {
  .whatsapp-float {
    bottom: 24px;
    right: 24px;
    width: 54px;
    height: 54px;
    box-shadow: 0 6px 24px rgba(18, 140, 126, 0.3);
  }
  .whatsapp-icon {
    width: 28px;
    height: 28px;
  }
}
