/* ============================================================================
   DEISY OCAMPO · CENTRO DE PSICOLOGÍA
   Sistema de estilos global · Mantenido por Vikingos Media
   ============================================================================
   
   ESTRUCTURA DEL ARCHIVO:
   
     01. VARIABLES Y RESET           — Custom properties, reset universal, base
     02. TIPOGRAFÍA Y ÉNFASIS        — Titulares, leads, eyebrows, cursivas
     03. LAYOUT GLOBAL               — Wrap, sections, helpers
     04. HEADER · NAVEGACIÓN         — Barra superior, menú, CTA
     05. FOOTER                      — Pie de página, redes
     06. BOTONES Y CTAs              — Sistema de botones unificado
     07. TARJETAS · CARDS            — Tarjetas con mariposa marca de agua
     08. HERO E INICIO               — Sección principal, selector chips, panel
     09. EMPRESAS                    — Métricas, decreto 1477, perfil Irma
     10. QUIÉNES SOMOS · EQUIPO      — Historia, misión/visión, grid del equipo
     11. PAQUETES                    — Gift cards, precios, neuropsicología
     12. PLAN PADRINO                — 3 pasos, CTAs
     13. AGENDAR · AMELIA            — Mock del flujo de booking
     14. OTROS · MISCELÁNEOS         — Reglas sin categoría clara
     15. RESPONSIVE · MEDIA QUERIES  — Breakpoints móvil/tablet
   
   PLACEHOLDERS A REEMPLAZAR ANTES DE PEGAR:
     {{IMG_BG_TL}}       URL de la imagen decorativa superior izquierda
     {{IMG_BG_BR}}       URL de la imagen decorativa inferior derecha
     {{IMG_PANEL_HERO}}  URL de la foto del equipo (panel del hero)
   
   ⚠️ IMPORTANTE al reemplazar:
   - NO dejar espacios entre las comillas y la URL
   - CORRECTO:   url('https://psicologadeisyocampo.com/wp-content/uploads/...')
   - INCORRECTO: url(' https://psicologadeisyocampo.com/wp-content/uploads/...')
   
   PALETA DE COLORES:
     --red       #C81E2D    Rojo principal de la marca
     --red-deep  #9C1421    Rojo oscuro (hovers, énfasis)
     --ink       #15110D    Texto principal sobre fondos claros
     --cream     #FAF6EF    Texto sobre fondos oscuros
     --black     #141009    Fondos negros (panel hero, footer)
   
   TIPOGRAFÍAS:
     Outfit (300-800)     Titulares y textos prominentes
     Hanken Grotesk       Body text general
     Sacramento           Énfasis cursivo decorativo
   
   ============================================================================ */


/* ============================================================================
   01. VARIABLES Y RESET
   ============================================================================ */

:root {
  --paper:#FAF6EF;
  --paper-2:#ECE3D6;
  --ink:#15110D;
  --ink-soft:#5E564B;
  --red:#C81E2D;
  --red-deep:#9C1421;
  --red-soft:#FBEBEC;
  --black:#141009;
  --cream:#FAF6EF;
  --r:14px;
}

* {
  box-sizing:border-box;
  margin:0;
  padding:0;
}

html {
  scroll-behavior:smooth;
}

body {
  font-family:'Hanken Grotesk',system-ui,sans-serif;
  background-color:var(--paper);
  background-image:linear-gradient(rgba(255,255,255,.5),rgba(255,255,255,.5)),url('https://psicologadeisyocampo.com/wp-content/uploads/2026/06/bg-tl.png'),url('https://psicologadeisyocampo.com/wp-content/uploads/2026/06/bg-br.png');
  background-repeat:no-repeat;
  background-position:center,top left,bottom right;
  background-size:cover,42vmin auto,42vmin auto;
  background-attachment:fixed;
  color:var(--ink);
  font-size:18px;
  line-height:1.65;
  -webkit-font-smoothing:antialiased;
  position:relative;
  overflow-x:hidden;
}

body::before {
  content:"";
  position:fixed;
  inset:0;
  z-index:0;
  pointer-events:none;
  opacity:.045;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='200' height='200'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='3' /%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}

.wrap {
  max-width:1180px;
  margin:0 auto;
  padding:0 28px;
  position:relative;
  z-index:1;
}

a {
  color:inherit;
}

h1 {
  font-family:'Jost',sans-serif;
  font-weight:300;
  font-size:clamp(38px,5.4vw,68px);
  line-height:1.0;
  letter-spacing:-.02em;
  margin:18px 0 0;
}

h1 em {
  font-style:italic;
  color:var(--red);
}

.pstory p {
  font-size:16px;
  color:rgba(250,246,239,.82);
  margin-top:8px;
  line-height:1.55;
}

.pstory a {
  color:#fff;
  font-weight:600;
  text-decoration:underline;
  text-underline-offset:3px;
  text-decoration-color:var(--red);
  cursor:pointer;
}

.band h2 {
  font-family:'Jost',sans-serif;
  font-weight:300;
  font-size:clamp(26px,3.4vw,40px);
  line-height:1.08;
  position:relative;
  z-index:1;
}

.band p {
  font-size:18px;
  color:rgba(250,246,239,.85);
  max-width:560px;
  margin-top:14px;
  position:relative;
  z-index:1;
}

.pcard h3 {
  font-family:'Jost',sans-serif;
  font-weight:500;
  font-size:22px;
}

.pcard ul {
  list-style:none;
  margin:18px 0;
  display:flex;
  flex-direction:column;
  gap:9px;
}

.pcard li {
  font-size:15.5px;
  color:var(--ink-soft);
  display:flex;
  gap:9px;
}

.rates h3 {
  font-family:'Jost',sans-serif;
  font-size:24px;
  font-weight:500;
}

.rates-grid .rc h4 {
  font-size:15px;
  color:#fff;
  margin-bottom:10px;
}

.aside-book h3 {
  font-family:'Jost',sans-serif;
  font-weight:500;
  font-size:21px;
}

.aside-book p {
  font-size:15.5px;
  color:rgba(250,246,239,.82);
  margin-top:10px;
}

h1 {
  line-height:1.05;
}


/* ============================================================================
   02. TIPOGRAFÍA Y ÉNFASIS
   ============================================================================ */

.eyebrow {
  font-size:12.5px;
  letter-spacing:.16em;
  text-transform:uppercase;
  color:var(--red-deep);
  font-weight:600;
  display:inline-block;
}

.eyebrow::before {
  content:"";
  display:inline-block;
  width:26px;
  height:2px;
  background:var(--red);
  vertical-align:middle;
  margin-right:10px;
}

.h2 {
  font-family:'Jost',sans-serif;
  font-weight:300;
  font-size:clamp(30px,4vw,46px);
  line-height:1.05;
  letter-spacing:-.02em;
  margin:14px 0 0;
}

.h2 em {
  font-style:italic;
  color:var(--red);
}

.lead {
  font-size:19px;
  color:var(--ink-soft);
  max-width:620px;
  margin-top:18px;
}

.center .eyebrow {
  margin:0;
}

.hero .lead {
  font-size:20px;
}

.quote-mark {
  font-family:'Jost',sans-serif;
  font-size:92px;
  line-height:.6;
  color:var(--red);
}

.pull {
  font-family:'Jost',sans-serif;
  font-style:italic;
  font-size:26px;
  line-height:1.35;
  color:var(--ink);
  border-left:3px solid var(--red);
  padding-left:20px;
}

/* Énfasis cursivo tipo poster */ h1 .cursive,
.h2 .cursive {
  font-family:'Sacramento',cursive;
  font-style:normal;
  color:var(--red);
  font-weight:400;
  line-height:.85;
  font-size:1.35em;
  display:inline-block;
  padding:0 .04em;
  letter-spacing:.01em;
}

/* Ajustes finos de Outfit como headline */ 
h1,
.h2 {
  letter-spacing:-.015em;
  font-weight:700;
}

blockquote,
.pull {
  font-weight:500;
  letter-spacing:-.005em;
}


/* ============================================================================
   03. LAYOUT GLOBAL
   ============================================================================ */

.section {
  padding:62px 0;
}

.center {
  text-align:center;
}

.center .eyebrow::before {
  display:none;
}

.center .lead {
  margin-left:auto;
  margin-right:auto;
}

.pkg .row {
  display:flex;
  justify-content:space-between;
  align-items:baseline;
  gap:10px;
  font-size:14.5px;
  border-bottom:1px dashed var(--paper-2);
  padding-bottom:9px;
}

.pkg .row span {
  color:var(--ink-soft);
}

.pkg .row b {
  font-family:'Jost',sans-serif;
  color:var(--red);
  font-weight:500;
  font-size:16px;
  white-space:nowrap;
}


/* ============================================================================
   04. HEADER · NAVEGACIÓN
   ============================================================================ */

/* NAV */ 
header {
  position:sticky;
  top:0;
  z-index:20;
  background:rgba(255,255,255,1);
  backdrop-filter:blur(8px);
  border-bottom:1px solid var(--paper-2);
}

nav {
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding:16px 0;
}

.brand {
  display:flex;
  align-items:center;
  text-decoration:none;
  cursor:pointer;
}

.brand img {
  height:50px;
  width:auto;
  display:block;
}

.wordmark {
  display:none;
  align-items:baseline;
}

.wordmark .mark {
  font-family:'Jost',sans-serif;
  font-weight:500;
  font-size:22px;
  color:var(--ink);
  letter-spacing:-.01em;
}

.wordmark .red {
  color:var(--red);
}

.menu {
  display:flex;
  gap:26px;
  font-size:15.5px;
  align-items:center;
}

.menu a {
  text-decoration:none;
  opacity:.76;
  transition:opacity .2s;
  position:relative;
  cursor:pointer;
  padding:4px 0;
}

.menu a:hover,
.menu a.active {
  opacity:1;
}

.menu a::after {
  content:"";
  position:absolute;
  left:0;
  right:100%;
  bottom:0;
  height:2px;
  background:var(--red);
  transition:right .25s;
}

.menu a:hover::after,
.menu a.active::after {
  right:0;
}

.cta {
  font-family:inherit;
  font-size:15px;
  font-weight:600;
  cursor:pointer;
  background-color:var(--red);
  color:#fff;
  border:none;
  padding:11px 22px;
  border-radius:100px;
  text-decoration:none;
  display:inline-block;
  background-image:linear-gradient(#fff,#fff);
  background-repeat:no-repeat;
  background-position:center;
  background-size:0% 100%;
  transition:background-size .42s cubic-bezier(.55,.15,.15,1),color .3s ease,transform .2s ease;
}

.cta:hover {
  background-size:100% 100%;
  color:var(--red);
  transform:translateY(-1px);
}

.burger {
  display:none;
  background:none;
  border:none;
  font-size:26px;
  color:var(--ink);
  cursor:pointer;
}

.pcard .cta {
  text-align:center;
  margin-top:auto;
}

.pkg .cta {
  margin-top:auto;
  text-align:center;
}

/* Wordmark del header con Outfit */ 
.brand .mark,
.wordmark .mark {
  font-weight:600;
  letter-spacing:-.015em;
}


/* ============================================================================
   05. FOOTER
   ============================================================================ */

/* FOOTER */ 
footer {
  background:var(--black);
  color:var(--cream);
  margin-top:30px;
  position:relative;
  z-index:1;
}

.foot {
  display:grid;
  grid-template-columns:1.4fr 1fr 1fr;
  gap:34px;
  padding:54px 0 30px;
}

.foot h4 {
  font-family:'Jost',sans-serif;
  font-size:20px;
  font-weight:500;
  margin-bottom:14px;
}

.foot p,
.foot a {
  font-size:15.5px;
  color:rgba(250,246,239,.72);
  text-decoration:none;
  display:block;
  margin-top:8px;
}

.foot a:hover {
  color:#fff;
}

.foot .slogan {
  font-family:'Jost',sans-serif;
  font-style:italic;
  font-size:22px;
  color:#fff;
}

.foot-bottom {
  border-top:1px solid rgba(250,246,239,.14);
  padding:18px 0;
  font-size:13.5px;
  color:rgba(250,246,239,.55);
  text-align:center;
}

.foot a.ico {
  display:flex;
  align-items:center;
  gap:11px;
  margin-top:11px;
}

.foot a.ico svg {
  width:17px;
  height:17px;
  flex-shrink:0;
  fill:rgba(250,246,239,.72);
  transition:fill .2s;
}

.foot a.ico:hover svg {
  fill:var(--red);
}


/* ============================================================================
   06. BOTONES Y CTAs
   ============================================================================ */

.card .more {
  display:inline-block;
  margin-top:16px;
  font-size:14px;
  font-weight:600;
  color:var(--red);
  text-decoration:none;
  cursor:pointer;
  border:1.6px solid var(--red);
  background-color:#fff;
  padding:8px 18px;
  border-radius:100px;
  background-image:linear-gradient(var(--red),var(--red));
  background-repeat:no-repeat;
  background-position:center;
  background-size:0% 100%;
  transition:background-size .42s cubic-bezier(.55,.15,.15,1),color .3s ease,transform .2s ease;
}

.btn-light {
  display:inline-block;
  margin-top:22px;
  background-color:#fff;
  color:var(--ink);
  font-weight:600;
  font-size:16px;
  padding:13px 26px;
  border-radius:100px;
  text-decoration:none;
  cursor:pointer;
  position:relative;
  z-index:1;
  background-image:linear-gradient(var(--ink),var(--ink));
  background-repeat:no-repeat;
  background-position:center;
  background-size:0% 100%;
  transition:background-size .42s cubic-bezier(.55,.15,.15,1),color .3s ease,transform .2s ease;
}

.btn-light:hover {
  background-size:100% 100%;
  color:#fff;
  transform:translateY(-2px);
}

/* Botón de barrido (Servicios → Agendar) */ 
.btn-sweep {
  display:inline-block;
  margin-top:18px;
  font-weight:600;
  font-size:15px;
  padding:10px 24px;
  border-radius:100px;
  text-decoration:none;
  cursor:pointer;
  border:1.6px solid var(--red);
  background-color:#fff;
  color:var(--red);
  background-image:linear-gradient(var(--red),var(--red));
  background-repeat:no-repeat;
  background-position:center;
  background-size:0% 100%;
  transition:background-size .42s cubic-bezier(.55,.15,.15,1),color .3s ease,transform .2s ease;
}

.btn-sweep:hover {
  background-size:100% 100%;
  color:#fff;
  transform:translateY(-1px);
}


/* ============================================================================
   07. TARJETAS · CARDS
   ============================================================================ */

/* CARDS */ 
.cards {
  display:grid;
  gap:18px;
  margin-top:38px;
}

.card {
  background:#fff;
  border:1px solid var(--paper-2);
  border-radius:var(--r);
  padding:26px 24px;
  transition:transform .2s,border-color .2s;
  position:relative;
  overflow:hidden;
}

.card:hover {
  transform:translateY(-3px);
  border-color:var(--red);
}

.bfly {
  position:absolute;
  right:14px;
  top:12px;
  width:97px;
  height:97px;
  object-fit:contain;
  opacity:.12;
  pointer-events:none;
  z-index:0;
  transition:opacity .35s,transform .35s;
}

.card:hover .bfly {
  opacity:.22;
  transform:translateY(3.06px) rotate(-3.06deg);
}

.card .ic {
  width:46px;
  height:46px;
  border-radius:50%;
  background:var(--red-soft);
  color:var(--red);
  display:flex;
  align-items:center;
  justify-content:center;
  font-size:22px;
  margin-bottom:16px;
}

.card h3 {
  font-family:'Jost',sans-serif;
  font-weight:500;
  font-size:22px;
}

.card p {
  font-size:16px;
  color:var(--ink-soft);
  margin-top:10px;
}

.card .more:hover {
  background-size:100% 100%;
  color:#fff;
  transform:translateY(-1px);
}

.tags {
  display:flex;
  flex-wrap:wrap;
  gap:7px;
  margin-top:14px;
}

.tags span {
  font-size:15px;
  background:var(--paper);
  border:1px solid var(--paper-2);
  color:var(--ink-soft);
  padding:5px 11px;
  border-radius:100px;
}

.mv .card h3 {
  color:var(--red);
  font-size:20px;
}


/* ============================================================================
   08. HERO E INICIO
   ============================================================================ */

/* HERO (inicio) */ 
.hero {
  display:grid;
  grid-template-columns:1.15fr .85fr;
  gap:44px;
  align-items:stretch;
  padding:48px 0 22px;
}

.selector {
  margin-top:30px;
  background:#fff;
  border:1px solid var(--paper-2);
  border-radius:var(--r);
  padding:22px;
}

.selector-q {
  font-family:'Jost',sans-serif;
  font-size:21px;
  font-weight:500;
}

.chips {
  display:flex;
  flex-wrap:wrap;
  gap:9px;
  margin-top:14px;
}

.chip {
  font-family:inherit;
  font-size:15px;
  cursor:pointer;
  background:transparent;
  border:1.4px solid var(--paper-2);
  color:var(--ink);
  padding:9px 16px;
  border-radius:100px;
  transition:all .18s;
}

.chip:hover {
  border-color:var(--red);
  color:var(--red);
}

.chip.on {
  background:var(--ink);
  border-color:var(--ink);
  color:#fff;
}

.resp {
  margin-top:18px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:18px;
  flex-wrap:wrap;
}

.resp p {
  font-size:17px;
  max-width:360px;
  transition:opacity .25s;
  border-left:3px solid var(--red);
  padding-left:12px;
}

.resp .go {
  font-family:inherit;
  font-size:15px;
  font-weight:600;
  white-space:nowrap;
  cursor:pointer;
  background-color:var(--red);
  color:#fff;
  border:none;
  padding:11px 20px;
  border-radius:100px;
  text-decoration:none;
  display:inline-block;
  background-image:linear-gradient(#fff,#fff);
  background-repeat:no-repeat;
  background-position:center;
  background-size:0% 100%;
  transition:background-size .42s cubic-bezier(.55,.15,.15,1),color .3s ease,transform .2s ease;
}

.resp .go:hover {
  background-size:100% 100%;
  color:var(--red);
  transform:translateY(-1px);
}

.panel {
  background:var(--black);
  color:var(--cream);
  border-radius:var(--r);
  padding:34px 32px;
  display:flex;
  flex-direction:column;
  justify-content:space-between;
  position:relative;
  overflow:hidden;
  min-height:100%;
}

.panel::before {
  content:"";
  position:absolute;
  inset:0;
  background-image:url('https://psicologadeisyocampo.com/wp-content/uploads/2026/06/panel-hero.jpg');
  background-size:cover;
  background-position:center;
  filter:blur(0.25px) saturate(.90) brightness(.90);
  opacity:.35;
  z-index:0;
  transform:scale(1.06);
}

.panel >  {
  position:relative;
  z-index:2;
}

.panel::after {
  content:"";
  position:absolute;
  right:-80px;
  bottom:-100px;
  width:300px;
  height:300px;
  border-radius:50%;
  background:radial-gradient(circle at 30% 30%,rgba(200,30,45,.55),transparent 68%);
  z-index:1;
}

.panel blockquote {
  font-family:'Jost',sans-serif;
  font-style:italic;
  font-size:25px;
  line-height:1.3;
  margin-top:6px;
  position:relative;
  z-index:1;
}

/* TRUST */ 
.trust {
  display:grid;
  grid-template-columns:repeat(5,1fr);
  border-top:1px solid var(--paper-2);
  border-bottom:1px solid var(--paper-2);
  margin:26px 0;
}

.stat {
  padding:22px 14px;
  text-align:center;
  border-right:1px solid var(--paper-2);
}

.stat:last-child {
  border-right:none;
}

.stat b {
  font-family:'Jost',sans-serif;
  font-weight:500;
  font-size:30px;
  display:block;
  line-height:1;
}

.stat b::after {
  content:"";
  display:block;
  width:18px;
  height:2px;
  background:var(--red);
  margin:8px auto 0;
}

.stat span {
  font-size:15px;
  color:var(--ink-soft);
  display:block;
  margin-top:8px;
}

.selector-q,
.pkg .body h3,
.card h3 {
  font-weight:600;
  letter-spacing:-.005em;
}


/* ============================================================================
   09. EMPRESAS
   ============================================================================ */

.avatar {
  border-radius:50%;
  background:var(--ink);
  color:#fff;
  font-family:'Jost',sans-serif;
  display:flex;
  align-items:center;
  justify-content:center;
  overflow:hidden;
}

.avatar img {
  width:100%;
  height:100%;
  object-fit:cover;
  object-position:center 15%;
}

/* EMPRESAS list */ 
.biz {
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:12px 30px;
  margin-top:30px;
}

.biz li {
  list-style:none;
  display:flex;
  gap:12px;
  font-size:17px;
  padding:8px 0;
  border-bottom:1px solid var(--paper-2);
}

.biz li b {
  color:var(--red);
  font-family:'Jost',sans-serif;
}

.metrics2 {
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:18px;
  margin-top:34px;
}

.bigstat {
  background:var(--red-soft);
  border-radius:var(--r);
  padding:30px;
  text-align:center;
}

.bigstat b {
  font-family:'Jost',sans-serif;
  font-size:54px;
  color:var(--red);
  display:block;
  line-height:1;
}

.bigstat span {
  font-size:16px;
  color:var(--ink);
  display:block;
  margin-top:8px;
}

.pkg .who {
  font-size:13px;
  color:var(--ink-soft);
}


/* ============================================================================
   10. QUIÉNES SOMOS · EQUIPO
   ============================================================================ */

/* STORY (quienes somos) */ 
.story-grid {
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:48px;
  align-items:start;
  margin-top:38px;
}

.story-grid p {
  font-size:18px;
  margin-top:16px;
  color:var(--ink-soft);
}

.mv {
  display:grid;
  grid-template-columns:1fr;
  gap:16px;
  margin-top:28px;
}

/* TEAM */ 
.team {
  display:grid;
  grid-template-columns:repeat(5,1fr);
  gap:16px;
  margin-top:36px;
}

.member {
  position:relative;
  border-radius:var(--r);
  overflow:hidden;
  background:var(--ink);
  box-shadow:0 1px 0 var(--paper-2);
  cursor:pointer;
}

.member .photo {
  height:330px;
  display:flex;
  align-items:center;
  justify-content:center;
  font-family:'Jost',sans-serif;
  font-size:64px;
  color:#fff;
  background:linear-gradient(160deg,#2a2018,#141009);
}

.member .photo.empty {
  background:var(--paper);
  color:var(--paper-2);
  font-size:54px;
}

.member .photo img {
  width:100%;
  height:100%;
  object-fit:cover;
  object-position:center 12%;
  display:block;
}

.member .base {
  position:absolute;
  left:0;
  right:0;
  bottom:0;
  padding:46px 20px 18px;
  background:linear-gradient(to top,rgba(20,16,9,.92),transparent);
  color:#fff;
  transition:opacity .35s;
  z-index:1;
}

.member .base h4 {
  font-family:'Jost',sans-serif;
  font-weight:500;
  font-size:21px;
  color:#fff;
}

.member .base span {
  font-size:15px;
  color:var(--cream);
  opacity:.85;
  display:block;
  margin-top:2px;
}

.member .reveal {
  position:absolute;
  inset:0;
  background:rgba(156,20,33,.95);
  color:#fff;
  padding:20px 16px;
  display:flex;
  flex-direction:column;
  justify-content:flex-end;
  transform:translateY(101%);
  transition:transform .4s cubic-bezier(.2,.7,.3,1);
  z-index:2;
}

.member:hover .reveal {
  transform:translateY(0);
}

.member:hover .base {
  opacity:0;
}

.member .reveal .tag {
  font-size:10.5px;
  letter-spacing:.14em;
  text-transform:uppercase;
  font-weight:600;
  opacity:.9;
}

.member .reveal h4 {
  font-family:'Jost',sans-serif;
  font-weight:500;
  font-size:18px;
  margin:5px 0 1px;
  line-height:1.12;
}

.member .reveal .role {
  font-size:12.5px;
  opacity:.9;
}

.member .reveal p {
  font-size:13px;
  line-height:1.42;
  margin-top:8px;
  color:rgba(255,255,255,.92);
}

.member .reveal .bk {
  display:inline-block;
  margin-top:12px;
  background-color:#fff;
  color:var(--red-deep);
  font-weight:600;
  font-size:13px;
  padding:8px 15px;
  border-radius:100px;
  text-decoration:none;
  align-self:flex-start;
  background-image:linear-gradient(var(--red),var(--red));
  background-repeat:no-repeat;
  background-position:center;
  background-size:0% 100%;
  transition:background-size .42s cubic-bezier(.55,.15,.15,1),color .3s ease;
}

.member .reveal .bk:hover {
  background-size:100% 100%;
  color:#fff;
}


/* ============================================================================
   11. PAQUETES
   ============================================================================ */

/* PAQUETES (estilo bono de regalo) */ 
.tier-note {
  display:flex;
  flex-wrap:wrap;
  gap:10px;
  margin-top:22px;
}

.tier-note span {
  font-size:15px;
  background:#fff;
  border:1px solid var(--paper-2);
  border-radius:100px;
  padding:8px 16px;
}

.tier-note span b {
  color:var(--red);
}

.pkgs {
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:22px;
  margin-top:34px;
}

.pkg {
  background:#fff;
  border:1px solid var(--paper-2);
  border-radius:var(--r);
  overflow:hidden;
  display:flex;
  flex-direction:column;
  transition:transform .2s,border-color .2s;
}

.pkg:hover {
  transform:translateY(-4px);
  border-color:var(--red);
}

.pkg.feat {
  border:2px solid var(--red);
}

.giftface {
  position:relative;
  background:#fff;
  border-radius:11px;
  overflow:hidden;
  aspect-ratio:1.62/1;
  display:flex;
  align-items:center;
  justify-content:center;
  box-shadow:0 6px 16px rgba(0,0,0,.45);
}

.giftface .b1 {
  position:absolute;
  width:120px;
  height:120px;
  border-radius:50%;
  background:var(--red);
  left:-42px;
  top:-44px;
}

.giftface .b2 {
  position:absolute;
  width:64px;
  height:64px;
  border-radius:50%;
  background:var(--red-deep);
  right:-20px;
  bottom:22px;
}

.giftface .ring {
  position:absolute;
  width:42px;
  height:42px;
  border:6px solid var(--red);
  border-radius:50%;
  right:18px;
  top:14px;
}

.giftface .badge {
  position:absolute;
  top:13px;
  left:15px;
  font-size:10.5px;
  font-weight:700;
  letter-spacing:.08em;
  color:var(--red);
  text-transform:uppercase;
  z-index:2;
}

.giftface img {
  position:relative;
  z-index:2;
  width:60%;
  max-width:165px;
  height:auto;
  filter:none;
}

.giftface .name {
  position:absolute;
  left:0;
  right:0;
  bottom:0;
  background:var(--red);
  color:#fff;
  text-align:center;
  font-weight:600;
  font-size:12.5px;
  letter-spacing:.05em;
  text-transform:uppercase;
  padding:7px 8px;
  z-index:2;
}

.pkg .body {
  padding:22px 22px 24px;
  display:flex;
  flex-direction:column;
  flex:1;
}

.pkg .body h3 {
  font-family:'Jost',sans-serif;
  font-size:21px;
  font-weight:500;
  margin-top:2px;
}

.pkg .rows {
  margin:15px 0 18px;
  display:flex;
  flex-direction:column;
  gap:9px;
}

.pkg .pop {
  display:inline-block;
  background:var(--red);
  color:#fff;
  font-size:12px;
  font-weight:600;
  padding:3px 11px;
  border-radius:100px;
  margin-bottom:10px;
  align-self:flex-start;
}

.times {
  display:flex;
  flex-wrap:wrap;
  gap:8px;
}

.times span {
  font-size:15px;
  border:1.4px solid var(--paper-2);
  padding:8px 14px;
  border-radius:8px;
  cursor:pointer;
}

.times span:hover {
  border-color:var(--red);
  color:var(--red);
}


/* ============================================================================
   12. PLAN PADRINO
   ============================================================================ */

.step {
  font-size:13px;
  font-weight:600;
  color:var(--red);
  letter-spacing:.05em;
  text-transform:uppercase;
}


/* ============================================================================
   13. AGENDAR · AMELIA
   ============================================================================ */

.bookcard {
  background:#fff;
  border:1px solid var(--paper-2);
  border-radius:var(--r);
  padding:28px;
  position:relative;
  overflow:hidden;
}

.opt {
  font-size:15px;
  border:1.4px solid var(--paper-2);
  padding:9px 15px;
  border-radius:100px;
  cursor:pointer;
  transition:all .18s;
}

.opt:hover {
  border-color:var(--red);
  color:var(--red);
}

.opt.on {
  background:var(--ink);
  color:#fff;
  border-color:var(--ink);
}

.cal {
  display:grid;
  grid-template-columns:repeat(7,1fr);
  gap:6px;
  margin:12px 0 26px;
}

.cal div {
  aspect-ratio:1;
  display:flex;
  align-items:center;
  justify-content:center;
  font-size:14px;
  border-radius:8px;
  background:var(--paper);
  color:var(--ink-soft);
}

.cal div.av {
  background:#fff;
  border:1px solid var(--paper-2);
  color:var(--ink);
  cursor:pointer;
}

.cal div.av:hover,
.cal div.sel {
  background:var(--red);
  color:#fff;
  border-color:var(--red);
}

.cal div.hd {
  background:none;
  color:var(--ink-soft);
  font-size:12px;
  aspect-ratio:auto;
}


/* ============================================================================
   14. OTROS · MISCELÁNEOS
   ============================================================================ */

/* PAGES 
.page {
  display:block;
  animation:fade .5s ease both;
}

.page.active {
  display:block;
}*/ 

.pstory {
  margin-top:22px;
  position:relative;
  z-index:1;
}

.pstory .tag {
  font-size:11.5px;
  letter-spacing:.16em;
  text-transform:uppercase;
  color:var(--red);
  font-weight:600;
}

.reviews {
  margin-top:22px;
  display:flex;
  align-items:center;
  gap:12px;
  position:relative;
  z-index:1;
  border-top:1px solid rgba(250,246,239,.16);
  padding-top:16px;
}

.stars {
  color:var(--red);
  font-size:16px;
  letter-spacing:2px;
}

.reviews span {
  font-size:15px;
  color:rgba(250,246,239,.85);
}

.c4 {
  grid-template-columns:repeat(4,1fr);
}

.c3 {
  grid-template-columns:repeat(3,1fr);
}

.c2 {
  grid-template-columns:repeat(2,1fr);
}

.card>*:not(.bfly) {
  position:relative;
  z-index:1;
}

/* BAND */ 
.band {
  background:var(--black);
  color:var(--cream);
  border-radius:var(--r);
  padding:48px 44px;
  position:relative;
  overflow:hidden;
}

.band.red {
  background:var(--red);
}

.band::after {
  content:"";
  position:absolute;
  right:-90px;
  top:-90px;
  width:300px;
  height:300px;
  border-radius:50%;
  background:radial-gradient(circle at 40% 40%,rgba(200,30,45,.4),transparent 68%);
}

.band.red::after {
  background:radial-gradient(circle at 40% 40%,rgba(255,255,255,.18),transparent 68%);
}

/* PLUGIN SLOTS */ 
.pslots {
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:18px;
  margin-top:8px;
}

.pslot {
  border:2px dashed var(--paper-2);
  border-radius:var(--r);
  padding:42px 24px;
  text-align:center;
  background:#fff;
  color:var(--ink-soft);
  min-height:180px;
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  gap:10px;
}

.pslot i {
  font-size:34px;
  color:var(--red);
  opacity:.5;
}

.pslot b {
  font-family:'Jost',sans-serif;
  font-size:18px;
  color:var(--ink);
  font-weight:500;
}

.pslot span {
  font-size:15px;
}

/* PRICING / BONOS */ 
.price {
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:18px;
  margin-top:38px;
}

.pcard {
  background:#fff;
  border:1px solid var(--paper-2);
  border-radius:var(--r);
  padding:28px 26px;
  display:flex;
  flex-direction:column;
}

.pcard.feat {
  border:2px solid var(--red);
  position:relative;
}

.pcard .pop {
  position:absolute;
  top:-12px;
  left:26px;
  background:var(--red);
  color:#fff;
  font-size:12.5px;
  font-weight:600;
  padding:4px 12px;
  border-radius:100px;
}

.pcard .amt {
  font-family:'Jost',sans-serif;
  font-size:38px;
  margin:10px 0 2px;
}

.pcard .amt small {
  font-size:15px;
  color:var(--ink-soft);
  font-family:'Hanken Grotesk';
}

.pcard .ex {
  font-size:12.5px;
  color:var(--ink-soft);
  background:var(--paper);
  padding:2px 8px;
  border-radius:100px;
  display:inline-block;
}

.pcard li::before {
  content:"✓";
  color:var(--red);
  font-weight:700;
}

.gift {
  background:#15110d;
  padding:16px;
}

.rates {
  background:var(--black);
  color:var(--cream);
  border-radius:var(--r);
  padding:34px 32px;
  margin-top:34px;
}

.rates p.sub {
  color:rgba(250,246,239,.7);
  font-size:14.5px;
  margin-top:6px;
}

.rates-grid {
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:14px;
  margin-top:20px;
}

.rates-grid .rc {
  background:rgba(250,246,239,.06);
  border-radius:10px;
  padding:18px;
}

.rates-grid .rc .l {
  display:flex;
  justify-content:space-between;
  font-size:13.5px;
  color:rgba(250,246,239,.82);
  padding:5px 0;
  border-bottom:1px solid rgba(250,246,239,.1);
}

.rates-grid .rc .l b {
  color:var(--clay-soft,#E2A786);
  font-weight:600;
}

/* AGENDAR */ 
.book {
  display:grid;
  grid-template-columns:1.3fr .7fr;
  gap:24px;
  margin-top:38px;
}

.wm {
  position:absolute;
  inset:0;
  display:flex;
  align-items:center;
  justify-content:center;
  pointer-events:none;
  z-index:5;
}

.wm span {
  font-family:'Jost',sans-serif;
  font-style:italic;
  font-weight:500;
  text-transform:uppercase;
  letter-spacing:.06em;
  font-size:clamp(18px,2.6vw,30px);
  color:var(--red);
  opacity:.18;
  border:2.5px solid var(--red);
  border-radius:10px;
  padding:10px 26px;
  transform:rotate(-15deg);
  white-space:nowrap;
}

.opts {
  display:flex;
  flex-wrap:wrap;
  gap:9px;
  margin:12px 0 26px;
}

.aside-book {
  background:var(--black);
  color:var(--cream);
  border-radius:var(--r);
  padding:28px;
  height:fit-content;
}

.aside-book .wbtn {
  display:inline-block;
  margin-top:18px;
  background:#25D366;
  color:#06371a;
  font-weight:600;
  padding:12px 20px;
  border-radius:100px;
  text-decoration:none;
  cursor:pointer;
  font-size:15px;
}

.foot-logo {
  height:50px;
  width:auto;
  display:block;
  margin-bottom:18px;
  filter:invert(1) hue-rotate(180deg) saturate(1.5);
  opacity:.97;
}

/* WhatsApp */ 
.wa {
  position:fixed;
  right:22px;
  bottom:22px;
  z-index:30;
  background:#25D366;
  color:#fff;
  width:56px;
  height:56px;
  border-radius:50%;
  display:flex;
  align-items:center;
  justify-content:center;
  box-shadow:0 8px 24px rgba(20,16,9,.3);
  text-decoration:none;
  font-size:25px;
  cursor:pointer;
  transition:transform .2s;
}

.wa:hover {
  transform:scale(1.07);
}


/* ============================================================================
   15. RESPONSIVE · MEDIA QUERIES
   ============================================================================ */

@media(max-width:880px) {
  .menu {
    display:none;
    position:absolute;
    top:100%;
    left:0;
    right:0;
    flex-direction:column;
    gap:0;
    background:var(--paper);
    border-bottom:1px solid var(--paper-2);
    padding:8px 28px 18px;
  }

  .menu.open {
    display:flex;
  }

  .menu a {
    padding:12px 0;
    border-bottom:1px solid var(--paper-2);
    width:100%;
  }

  .burger {
    display:block;
  }

  nav .cta {
    padding:9px 16px;
    font-size:14px;
  }
}

@keyframes fade {
  from {
    opacity:0;
    transform:translateY(8px);
  }

  to {
    opacity:1;
    transform:none;
  }
}

@media(max-width:1024px) {
  .team {
    grid-template-columns:repeat(3,1fr);
  }
}

@media(max-width:880px) {
  .hero,
  .story-grid,
  .book {
    grid-template-columns:1fr;
  }

  .c4,
  .c3,
  .team,
  .price,
  .pkgs {
    grid-template-columns:repeat(2,1fr);
  }

  .trust {
    grid-template-columns:repeat(2,1fr);
  }

  .stat:nth-child(2) {
    border-right:none;
  }

  .stat {
    border-bottom:1px solid var(--paper-2);
  }

  .mv,
  .metrics2,
  .biz,
  .c2,
  .rates-grid {
    grid-template-columns:1fr;
  }

  .foot {
    grid-template-columns:1fr;
  }
}

@media(max-width:560px) {
  .c4,
  .c3,
  .team,
  .price,
  .pkgs {
    grid-template-columns:1fr;
  }
}