/* ============================================================
   MEDICI TAROT — Landing de conversión v2.0
   Sistema visual basado en la Carpeta de Marca
   ============================================================ */

:root{
  /* Paleta principal */
  --indigo:        #1A1C4A;
  --indigo-noche:  #2D306E;
  --crema:         #F5F0E4;
  --turquesa:      #66FFFF;
  --turquesa-suave:#B0F5F5;
  --dorado:        #B8904C;
  --dorado-claro:  #D4AE6E;
  --tinta:         #1C1826;

  /* Derivados */
  --indigo-deep:   #14163A;
  --crema-soft:    #FBF8F0;
  --linea-oro:     rgba(184,144,76,.45);
  --linea-oro-soft:rgba(184,144,76,.22);

  /* Nuevos tokens v2 */
  --glass-bg:      rgba(20,22,58,.55);
  --glass-border:  rgba(184,144,76,.28);
  --glow-turq:     rgba(102,255,255,.18);
  --glow-gold:     rgba(184,144,76,.22);
  --shadow-card:   0 20px 60px -20px rgba(26,28,74,.35);
  --shadow-hover:  0 32px 80px -20px rgba(26,28,74,.55);

  /* Tipografía */
  --f-display: 'Cinzel Decorative', serif;
  --f-title:   'Cinzel', serif;
  --f-editorial:'Cormorant Garamond', serif;
  --f-serif:   'Lora', serif;
  --f-ui:      'Poppins', sans-serif;

  --maxw: 1200px;
  --radius: 4px;
  --transition: .45s cubic-bezier(.2,.8,.2,1);
}

*{ box-sizing:border-box; margin:0; padding:0; }
html{ scroll-behavior:smooth; -webkit-text-size-adjust:100%; }
body{
  font-family:var(--f-serif);
  color:var(--tinta);
  background:var(--crema);
  line-height:1.6;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
img{ max-width:100%; display:block; }
a{ color:inherit; text-decoration:none; }
::selection{ background:var(--dorado); color:var(--indigo); }

/* ---------- Layout helpers ---------- */
.wrap{ width:100%; max-width:var(--maxw); margin:0 auto; padding:0 28px; }
.narrow{ max-width:820px; }
section{ position:relative; }

.bg-indigo{ background:var(--indigo); color:var(--crema); }
.bg-indigo-deep{ background:var(--indigo-deep); color:var(--crema); }
.bg-crema{ background:var(--crema); color:var(--tinta); }
.bg-crema-soft{ background:var(--crema-soft); color:var(--tinta); }

/* ---------- Eyebrow / kicker ---------- */
.kicker{
  font-family:var(--f-title);
  font-size:12.5px;
  letter-spacing:.46em;
  text-transform:uppercase;
  font-weight:600;
  color:var(--dorado);
  display:inline-flex;
  align-items:center;
  gap:14px;
}
.kicker.center{ justify-content:center; }
.kicker::before, .kicker::after{
  content:""; width:30px; height:1px;
  background:linear-gradient(90deg, var(--dorado-claro), transparent);
  flex:none;
}
.kicker::after{ background:linear-gradient(90deg, transparent, var(--dorado-claro)); }
.kicker.solo::before{ display:none; }

/* ---------- Headings ---------- */
.h-display{
  font-family:var(--f-display);
  font-weight:700;
  line-height:1.08;
  letter-spacing:.01em;
}
.h-title{
  font-family:var(--f-editorial);
  font-weight:600;
  line-height:1.1;
}
.lead{
  font-family:var(--f-editorial);
  font-size:clamp(20px,2.4vw,27px);
  line-height:1.5;
  font-weight:500;
}
.turq{ color:var(--turquesa); }
.oro{ color:var(--dorado); }
.italic{ font-style:italic; }

/* ---------- Buttons ---------- */
.btn{
  font-family:var(--f-ui);
  font-weight:500;
  font-size:14px;
  letter-spacing:.14em;
  text-transform:uppercase;
  display:inline-flex; align-items:center; gap:11px;
  padding:18px 34px;
  border-radius:var(--radius);
  cursor:pointer;
  border:1px solid transparent;
  transition:transform var(--transition), background var(--transition), color var(--transition), box-shadow var(--transition);
  position:relative;
  overflow:hidden;
  z-index:1;
}
.btn:focus-visible{
  outline:2px solid var(--turquesa);
  outline-offset:3px;
}
.btn:hover{ transform:translateY(-3px); }
.btn .ico{ width:18px; height:18px; flex:none; }

/* Ripple layer */
.btn::before{
  content:""; position:absolute; inset:0; z-index:-1;
  background:radial-gradient(circle at var(--mx,50%) var(--my,50%), rgba(255,255,255,.18) 0%, transparent 60%);
  opacity:0; transition:opacity .3s;
}
.btn:hover::before{ opacity:1; }

.btn-primary{
  background:linear-gradient(135deg, var(--dorado) 0%, var(--dorado-claro) 100%);
  color:var(--indigo);
  box-shadow:0 8px 26px -10px rgba(184,144,76,.65), 0 0 0 0 rgba(184,144,76,.3);
}
.btn-primary:hover{
  box-shadow:0 18px 40px -10px rgba(184,144,76,.8), 0 0 0 6px rgba(184,144,76,.12);
}
/* sheen */
.btn-primary::after{
  content:""; position:absolute; top:0; left:-120%; width:60%; height:100%;
  background:linear-gradient(100deg,transparent,rgba(255,255,255,.5),transparent);
  transform:skewX(-18deg);
  transition:none;
  z-index:2;
}
.btn-primary:hover::after{ animation:sheen .9s ease forwards; }
@keyframes sheen{ to{ left:160%; } }

.btn-wa{
  background:linear-gradient(135deg,#1FA855,#18934a);
  color:#fff;
  box-shadow:0 8px 26px -10px rgba(31,168,85,.6);
}
.btn-wa:hover{ box-shadow:0 18px 40px -10px rgba(31,168,85,.8); }

.btn-ghost{
  background:transparent;
  color:var(--crema);
  border-color:var(--linea-oro);
  backdrop-filter:blur(6px);
}
.btn-ghost:hover{
  border-color:var(--dorado);
  background:rgba(184,144,76,.12);
  box-shadow:0 0 20px rgba(184,144,76,.15);
}
.btn-ghost.dark{ color:var(--indigo); border-color:var(--linea-oro); }
.btn-ghost.dark:hover{ background:rgba(184,144,76,.08); }

.btn-lg{ padding:22px 52px; font-size:15.5px; }

/* ---------- Section rhythm ---------- */
.sec{ padding:clamp(80px,11vh,150px) 0; }
.sec-tight{ padding:clamp(60px,8vh,110px) 0; }

/* ============================================================
   REVEAL ANIMATIONS — v2 (más variadas y cinematográficas)
   ============================================================ */
.reveal{
  opacity:0;
  transform:translateY(40px);
  transition:opacity .9s cubic-bezier(.2,.7,.2,1), transform .9s cubic-bezier(.2,.7,.2,1);
}
.reveal.in{ opacity:1; transform:none; }
.reveal.d1{ transition-delay:.10s; }
.reveal.d2{ transition-delay:.22s; }
.reveal.d3{ transition-delay:.34s; }
.reveal.d4{ transition-delay:.46s; }
.reveal.d5{ transition-delay:.58s; }
.reveal.d6{ transition-delay:.70s; }

/* Variantes direccionales */
.reveal.from-left{ transform:translateX(-54px); }
.reveal.from-right{ transform:translateX(54px); }
.reveal.zoom{ transform:scale(.88) translateY(20px); }
.reveal.blur-in{ filter:blur(14px); opacity:0; transform:translateY(20px); }
.reveal.flip-in{ transform:rotateX(20deg) translateY(30px); transform-origin:top; }

.reveal.from-left.in,
.reveal.from-right.in{ transform:none; }
.reveal.zoom.in{ transform:none; }
.reveal.blur-in.in{ filter:none; transform:none; opacity:1; }
.reveal.flip-in.in{ transform:none; }

@media (prefers-reduced-motion:reduce){
  .reveal, .draw{ opacity:1; transform:none; filter:none; transition:none; }
}

/* draw-in ornament path */
.draw path, .draw line, .draw circle{
  stroke-dasharray:var(--len,600);
  stroke-dashoffset:var(--len,600);
  transition:stroke-dashoffset 1.8s cubic-bezier(.2,.7,.2,1);
}
.draw.in path, .draw.in line, .draw.in circle{ stroke-dashoffset:0; }

/* ============================================================
   HEADER — glassmorphism
   ============================================================ */
.site-head{
  position:fixed; top:0; left:0; right:0; z-index:60;
  display:flex; align-items:center; justify-content:space-between;
  padding:18px 36px;
  transition:background .6s, padding .5s, box-shadow .5s, border-color .5s, backdrop-filter .6s;
  border-bottom:1px solid transparent;
}
.site-head.scrolled{
  background:var(--glass-bg);
  backdrop-filter:blur(20px) saturate(180%);
  -webkit-backdrop-filter:blur(20px) saturate(180%);
  padding:12px 36px;
  border-bottom:1px solid var(--glass-border);
  box-shadow:0 10px 50px -20px rgba(0,0,0,.7), 0 1px 0 rgba(184,144,76,.15);
}
.brand{ display:flex; align-items:center; gap:14px; }
.brand img{ height:46px; width:auto; transition:height .5s; }
.site-head.scrolled .brand img{ height:38px; }
.brand-word{
  font-family:var(--f-title); color:var(--crema);
  letter-spacing:.36em; font-size:14.5px; font-weight:600;
  text-transform:uppercase; padding-left:2px;
}
.brand-word small{ display:block; font-size:8px; letter-spacing:.52em; color:var(--dorado-claro); margin-top:3px; }
.head-cta{ display:flex; align-items:center; gap:16px; }
@media (max-width:680px){ .brand-word, .head-cta .nav-link{ display:none; } }

/* ============================================================
   HERO
   ============================================================ */
.hero{
  position:relative; min-height:100svh;
  display:flex; align-items:center;
  background:var(--indigo);
  color:var(--crema);
  overflow:hidden;
  padding-top:90px;
}

/* ---- Video de fondo ---- */
.hero-video-wrap{
  position:absolute; inset:0; z-index:0;
  pointer-events:none; overflow:hidden;
}
.hero-video-wrap iframe{
  position:absolute;
  /* Centrado y escalado para cubrir toda la sección */
  top:50%; left:50%;
  width:177.78vh;   /* 16/9 × 100vh */
  height:100vh;
  min-width:100%; min-height:56.25vw; /* 9/16 × 100vw */
  transform:translate(-50%,-50%);
  border:none;
  pointer-events:none;
}

/* Overlay multicapa sobre el video */
.hero-video-overlay{
  position:absolute; inset:0; z-index:1; pointer-events:none;
  background:
    /* Oscurecer central para legibilidad */
    radial-gradient(ellipse 140% 100% at 80% -10%, rgba(20,22,58,.82), transparent 60%),
    radial-gradient(ellipse 80% 70% at 10% 100%, rgba(26,28,74,.70), transparent 55%),
    /* Capa base semitransparente */
    linear-gradient(160deg, rgba(20,22,58,.72) 0%, rgba(26,28,74,.55) 50%, rgba(14,16,40,.75) 100%);
}

/* Grilla decorativa sobre el video */
.hero::before{
  content:""; position:absolute; inset:0; z-index:2;
  background-image:
    repeating-linear-gradient(0deg, transparent, transparent 60px, rgba(184,144,76,.025) 60px, rgba(184,144,76,.025) 61px),
    repeating-linear-gradient(90deg, transparent, transparent 60px, rgba(184,144,76,.025) 60px, rgba(184,144,76,.025) 61px);
  pointer-events:none;
}

.hero-grid{
  display:grid; grid-template-columns:1.1fr .9fr; gap:60px; align-items:center;
  width:100%; max-width:var(--maxw); margin:0 auto; padding:40px 28px 80px;
  position:relative; z-index:3;
}
.hero-copy{ max-width:560px; }
.hero h1{
  font-size:clamp(36px,5.4vw,70px);
  margin:28px 0 0;
  color:var(--crema);
  line-height:1.06;
}
.hero h1 .accent{
  background:linear-gradient(100deg,var(--turquesa) 20%,var(--turquesa-suave) 50%,var(--turquesa) 80%);
  background-size:220% 100%;
  -webkit-background-clip:text; background-clip:text;
  -webkit-text-fill-color:transparent;
  font-style:italic; font-family:var(--f-editorial);
  animation:shimmerText 5s linear infinite;
  display:inline-block;
}
@keyframes shimmerText{ to{ background-position:-220% 0; } }

.hero .lead{ margin:28px 0 38px; color:rgba(245,240,228,.85); max-width:500px; }
.hero-actions{ display:flex; flex-wrap:wrap; gap:16px; }

/* Starfield */
.stars{ position:absolute; inset:0; pointer-events:none; overflow:hidden; }
.star{
  position:absolute; background:var(--turquesa-suave); border-radius:50%;
  animation:twinkle 4s infinite ease-in-out;
}
@keyframes twinkle{
  0%,100%{opacity:.08; transform:scale(.6);}
  50%{opacity:.95; transform:scale(1.1);}
}

/* Orbs */
.orb{ position:absolute; border-radius:50%; pointer-events:none; z-index:2; }
.orb.a{
  width:420px; height:420px;
  background:radial-gradient(circle,rgba(102,255,255,.14),transparent 68%);
  filter:blur(50px); opacity:.7;
  top:-80px; right:4%;
  animation:float1 16s ease-in-out infinite;
}
.orb.b{
  width:320px; height:320px;
  background:radial-gradient(circle,rgba(184,144,76,.20),transparent 70%);
  filter:blur(44px); opacity:.6;
  bottom:-40px; left:-60px;
  animation:float2 20s ease-in-out infinite;
}
.orb.c{
  width:200px; height:200px;
  background:radial-gradient(circle,rgba(102,255,255,.10),transparent 70%);
  filter:blur(30px); opacity:.5;
  bottom:20%; right:30%;
  animation:float3 12s ease-in-out infinite;
}
@keyframes float1{ 0%,100%{transform:translate(0,0) scale(1);} 33%{transform:translate(-20px,40px) scale(1.05);} 66%{transform:translate(20px,-20px) scale(.96);} }
@keyframes float2{ 0%,100%{transform:translate(0,0);} 50%{transform:translate(40px,-30px);} }
@keyframes float3{ 0%,100%{transform:translate(0,0);} 50%{transform:translate(-30px,20px);} }
@media (prefers-reduced-motion:reduce){ .orb, .portal-frame{ animation:none; } }

/* ============================================================
   PORTAL — Marco fotográfico premium (v2 · foto Le Mat)
   ============================================================ */
.portal{
  position:relative; justify-self:center;
  width:min(440px,82%);
  /* dejar espacio para esquinas y badge */
  padding:32px;
  margin-bottom:12px;
}

/* Glow exterior ambiental */
.portal-glow{
  position:absolute; inset:-40px; border-radius:12px;
  background:
    radial-gradient(ellipse 80% 60% at 35% 20%, rgba(184,144,76,.32), transparent 55%),
    radial-gradient(ellipse 60% 70% at 70% 80%, rgba(102,255,255,.14), transparent 55%);
  filter:blur(40px); z-index:0;
  animation:glowPulse 5s ease-in-out infinite;
}
@keyframes glowPulse{ 0%,100%{opacity:.6; transform:scale(1);} 50%{opacity:1; transform:scale(1.04);} }

/* Marco exterior (más alejado) */
.portal-outer-ring{
  position:absolute; inset:10px;
  border:1px solid rgba(184,144,76,.18);
  border-radius:6px;
  pointer-events:none; z-index:2;
}

.portal-frame{
  position:relative; z-index:1;
  border-radius:5px;
  overflow:hidden;
  /* Triple borde dorado */
  border:2px solid var(--dorado);
  outline:1px solid rgba(184,144,76,.25);
  outline-offset:5px;
  box-shadow:
    0 0 0 7px rgba(26,28,74,.85),
    0 0 0 8px rgba(184,144,76,.30),
    0 0 70px -10px rgba(184,144,76,.40),
    0 60px 130px -30px rgba(0,0,0,.9),
    inset 0 0 60px rgba(245,240,228,.04);
  background:var(--indigo);
  aspect-ratio:3/4;
  animation:portalfloat 9s ease-in-out infinite;
}
.portal-frame img{
  width:100%; height:100%;
  object-fit:cover;
  object-position:50% 20%;
  filter:saturate(1.06) contrast(1.03) brightness(1.01);
  transition:transform 10s ease;
  display:block;
}
.portal:hover .portal-frame img{ transform:scale(1.05); }

@keyframes portalfloat{
  0%,100%{ transform:translateY(0); }
  40%{ transform:translateY(-12px) rotate(.2deg); }
  70%{ transform:translateY(-6px) rotate(-.12deg); }
}

/* Esquinas art nouveau — más grandes, más luminosas */
.portal-corner{
  position:absolute; width:84px; height:84px;
  color:var(--dorado);
  filter:drop-shadow(0 0 10px rgba(184,144,76,.60))
         drop-shadow(0 0 4px rgba(184,144,76,.80));
  z-index:3;
  transition:filter .6s ease;
}
.portal:hover .portal-corner{
  filter:drop-shadow(0 0 16px rgba(184,144,76,.90))
         drop-shadow(0 0 6px rgba(212,174,110,1));
}
.portal-corner.tl{ top:-8px; left:-8px; }
.portal-corner.tr{ top:-8px; right:-8px; transform:scaleX(-1); }
.portal-corner.bl{ bottom:-8px; left:-8px; transform:scaleY(-1); }
.portal-corner.br{ bottom:-8px; right:-8px; transform:scale(-1); }

/* Línea brillante horizontal bajo la foto */
.portal-frame::after{
  content:"";
  position:absolute; bottom:0; left:0; right:0; height:3px;
  background:linear-gradient(90deg,
    transparent 0%,
    rgba(184,144,76,.6) 20%,
    rgba(212,174,110,.9) 40%,
    rgba(102,255,255,.5) 60%,
    rgba(184,144,76,.6) 80%,
    transparent 100%
  );
  pointer-events:none;
}

/* Vignette interior sutil */
.portal-frame::before{
  content:"";
  position:absolute; inset:0; z-index:1;
  background:
    radial-gradient(ellipse 100% 30% at 50% 100%, rgba(26,28,74,.45), transparent),
    radial-gradient(ellipse 60% 20% at 50% 0%, rgba(26,28,74,.20), transparent);
  pointer-events:none;
}

/* Badge decorativo inferior */
.portal-badge{
  position:absolute; bottom:-4px; left:50%; transform:translateX(-50%);
  z-index:4; white-space:nowrap;
  font-family:var(--f-title); font-size:9px; letter-spacing:.50em;
  text-transform:uppercase; color:var(--dorado-claro);
  background:var(--indigo-deep);
  padding:7px 22px;
  border:1px solid var(--linea-oro);
  border-radius:20px;
  box-shadow:0 8px 28px -8px rgba(0,0,0,.7), 0 0 12px rgba(184,144,76,.15);
}

/* Scroll hint */
.scroll-hint{
  position:absolute; bottom:30px; left:50%; transform:translateX(-50%);
  font-family:var(--f-ui); font-size:10.5px; letter-spacing:.38em; text-transform:uppercase;
  color:rgba(212,174,110,.7);
  display:flex; flex-direction:column; align-items:center; gap:10px;
  animation:fadeUpDown 3s ease-in-out infinite;
}
@keyframes fadeUpDown{ 0%,100%{opacity:.5; transform:translateX(-50%) translateY(0);} 50%{opacity:1; transform:translateX(-50%) translateY(-6px);} }
.scroll-hint .line{ width:1px; height:42px; background:linear-gradient(var(--dorado),transparent); }

@media (max-width:860px){
  .hero-grid{ grid-template-columns:1fr; gap:30px; text-align:center; padding-bottom:60px; }
  .hero-copy{ margin:0 auto; }
  .hero-actions{ justify-content:center; }
  .kicker{ justify-content:center; }
  .portal{ width:min(300px,72%); order:-1; padding:24px; }
  .scroll-hint{ display:none; }
  .orb.c{ display:none; }
}

/* ============================================================
   ORNAMENTAL DIVIDER
   ============================================================ */
.divider{
  display:flex; align-items:center; justify-content:center; gap:18px;
  color:var(--dorado); padding:6px 0;
}
.divider .rule{ height:1px; width:min(130px,18vw); background:linear-gradient(90deg,transparent,var(--linea-oro)); }
.divider .rule.r{ background:linear-gradient(90deg,var(--linea-oro),transparent); }
.divider svg{ width:42px; height:20px; flex:none; }

/* ============================================================
   TRUST STRIP
   ============================================================ */
.trust-strip{
  background:var(--indigo-deep); color:var(--crema);
  border-top:1px solid var(--linea-oro-soft);
  border-bottom:1px solid var(--linea-oro-soft);
  overflow:hidden;
  position:relative;
}
.trust-strip::before,
.trust-strip::after{
  content:""; position:absolute; top:0; bottom:0; width:120px; z-index:2; pointer-events:none;
}
.trust-strip::before{ left:0; background:linear-gradient(90deg,var(--indigo-deep),transparent); }
.trust-strip::after{ right:0; background:linear-gradient(90deg,transparent,var(--indigo-deep)); }

.trust-track{
  display:flex; align-items:center; gap:60px;
  padding:22px 0; white-space:nowrap;
  width:max-content; animation:marquee 36s linear infinite;
}
.trust-strip:hover .trust-track{ animation-play-state:paused; }
.trust-item{
  display:inline-flex; align-items:center; gap:13px;
  font-family:var(--f-title); font-size:13px; letter-spacing:.18em; text-transform:uppercase;
  color:rgba(245,240,228,.88);
}
.trust-item svg{ width:20px; height:20px; color:var(--dorado); flex:none; }
.trust-item .star{ position:static; color:var(--dorado); }
@keyframes marquee{ to{ transform:translateX(-50%); } }
@media (prefers-reduced-motion:reduce){ .trust-track{ animation:none; } }

/* ============================================================
   MANIFESTO
   ============================================================ */
.manifesto{ text-align:center; }
.manifesto .quote{
  font-family:var(--f-editorial);
  font-size:clamp(28px,4.4vw,54px);
  line-height:1.22; font-weight:500;
  letter-spacing:.005em;
  max-width:16ch; margin:34px auto;
  text-shadow:0 2px 40px rgba(184,144,76,.08);
}
.manifesto .quote .em{ font-style:italic; color:var(--dorado); }
.manifesto .sign{
  font-family:var(--f-title); letter-spacing:.32em; text-transform:uppercase;
  font-size:12px; color:var(--dorado-claro); margin-top:26px;
  opacity:.85;
}

/* ============================================================
   PAIN CARDS
   ============================================================ */
.sec-head{ text-align:center; max-width:760px; margin:0 auto clamp(46px,6vw,72px); }
.sec-head h2{
  font-family:var(--f-editorial); font-weight:600;
  font-size:clamp(30px,4.4vw,50px); line-height:1.12; margin:20px 0 0;
}
.sec-head p{ margin:20px auto 0; font-size:19px; max-width:60ch; opacity:.85; }

.pain-grid{
  display:grid; grid-template-columns:repeat(auto-fit,minmax(220px,1fr)); gap:22px;
}
.pain-card{
  background:var(--crema-soft);
  border:1px solid var(--linea-oro-soft);
  border-radius:var(--radius);
  padding:36px 30px;
  position:relative;
  transition:transform var(--transition), box-shadow var(--transition), border-color var(--transition), background var(--transition);
  overflow:hidden;
  cursor:default;
}
/* Shimmer sweep on hover */
.pain-card::after{
  content:""; position:absolute; inset:0;
  background:linear-gradient(135deg, transparent 30%, rgba(184,144,76,.06) 50%, transparent 70%);
  transform:translateX(-100%);
  transition:transform .7s ease;
}
.pain-card:hover::after{ transform:translateX(100%); }
.pain-card::before{
  content:""; position:absolute; left:0; top:0; bottom:0; width:3px;
  background:linear-gradient(180deg,var(--dorado),var(--turquesa));
  transform:scaleY(0); transform-origin:top; transition:transform .5s cubic-bezier(.2,.8,.2,1);
}
.pain-card:hover{ transform:translateY(-8px); box-shadow:var(--shadow-hover); border-color:var(--linea-oro); background:#fff; }
.pain-card:hover::before{ transform:scaleY(1); }
.pain-num{ font-family:var(--f-display); font-size:20px; color:var(--dorado); opacity:.45; }
.pain-card p{ font-family:var(--f-editorial); font-size:22px; line-height:1.34; margin:14px 0 0; font-weight:500; }

.pain-close{
  text-align:center; max-width:720px; margin:clamp(46px,6vw,70px) auto 0;
}
.pain-close p{ font-family:var(--f-editorial); font-size:clamp(22px,3vw,32px); line-height:1.4; font-weight:500; }
.pain-close .hl{ color:var(--dorado); font-style:italic; }

/* ============================================================
   ¿ES PARA VOS? (filter checklist)
   ============================================================ */
.filter-band{
  position:relative; overflow:hidden;
  background:linear-gradient(160deg, var(--indigo-deep) 0%, #1e2256 50%, var(--indigo-deep) 100%);
}
.leopard-layer{
  position:absolute; inset:0;
  background-image:url('assets/leopardo-oro.svg');
  background-size:480px;
  opacity:.09; mix-blend-mode:screen;
  pointer-events:none;
}
.filter-list{ display:grid; grid-template-columns:1fr 1fr; gap:16px 50px; max-width:920px; margin:0 auto; }
.filter-item{
  display:flex; align-items:flex-start; gap:18px;
  padding:22px 0; border-bottom:1px solid rgba(184,144,76,.15);
  transition:border-color var(--transition);
}
.filter-item:hover{ border-color:var(--linea-oro); }
.filter-check{
  flex:none; width:36px; height:36px; border-radius:50%;
  border:1.5px solid var(--dorado); display:grid; place-items:center; color:var(--turquesa);
  transition:background var(--transition), box-shadow var(--transition);
}
.filter-item:hover .filter-check{
  background:rgba(102,255,255,.08);
  box-shadow:0 0 16px rgba(102,255,255,.2);
}
.filter-check svg{ width:17px; height:17px; }
.filter-item p{ margin:0; font-family:var(--f-editorial); font-size:20px; line-height:1.4; color:var(--crema); padding-top:3px; }
@media (max-width:680px){ .filter-list{ grid-template-columns:1fr; } }

/* ============================================================
   PROCESO (3 pasos)
   ============================================================ */
.steps{ display:grid; grid-template-columns:repeat(3,1fr); gap:36px; position:relative; }
.step{ text-align:center; position:relative; padding:14px; }
.step-num{
  width:88px; height:88px; margin:0 auto 28px; border-radius:50%;
  border:1px solid var(--linea-oro); display:grid; place-items:center;
  font-family:var(--f-display); font-size:28px; color:var(--dorado);
  position:relative; background:var(--crema);
  transition:box-shadow var(--transition), border-color var(--transition), transform var(--transition);
}
.step-num::after{
  content:""; position:absolute; inset:-10px; border-radius:50%;
  border:1px solid var(--linea-oro-soft);
  transition:transform var(--transition), opacity var(--transition);
}
.step:hover .step-num{
  box-shadow:0 0 30px rgba(184,144,76,.2);
  border-color:var(--dorado);
  transform:translateY(-4px);
}
.step:hover .step-num::after{ transform:scale(1.08); opacity:.6; }
.step h3{ font-family:var(--f-editorial); font-size:25px; font-weight:600; margin:0 0 12px; }
.step p{ font-size:17px; opacity:.82; margin:0; max-width:30ch; margin-inline:auto; }

.steps-line{
  position:absolute; top:44px; left:16.5%; right:16.5%; height:1px;
  background:repeating-linear-gradient(90deg,var(--linea-oro) 0 6px,transparent 6px 14px);
  z-index:0;
}
@media (max-width:780px){ .steps{ grid-template-columns:1fr; gap:44px; } .steps-line{ display:none; } }

.proceso-note{
  margin-top:clamp(48px,6vw,72px); text-align:center;
  font-family:var(--f-editorial); font-size:clamp(21px,2.6vw,28px); font-weight:500;
}
.proceso-note .hl{ color:var(--dorado); font-style:italic; }

/* ============================================================
   SOBRE MARIANA
   ============================================================ */
.about-grid{ display:grid; grid-template-columns:.9fr 1.1fr; gap:clamp(36px,5vw,80px); align-items:center; }
.about-photo{ position:relative; }
.about-photo .frame{
  border:1px solid var(--linea-oro); padding:14px; background:var(--crema-soft);
  box-shadow:var(--shadow-card);
  transition:box-shadow var(--transition);
}
.about-photo .frame:hover{ box-shadow:var(--shadow-hover); }
.about-photo .frame img{ width:100%; aspect-ratio:1/1; object-fit:cover; transition:transform 8s ease; }
.about-photo .frame:hover img{ transform:scale(1.03); }
.about-photo .tag{
  position:absolute; bottom:-24px; right:-16px;
  background:var(--indigo); color:var(--crema); font-family:var(--f-ui);
  font-size:11.5px; letter-spacing:.16em; text-transform:uppercase;
  padding:14px 22px; border-radius:var(--radius);
  box-shadow:0 18px 40px -18px rgba(0,0,0,.6);
  border:1px solid var(--linea-oro);
}
.about-photo .tag b{ color:var(--turquesa); font-weight:600; }
.about-body h2{ font-family:var(--f-editorial); font-weight:600; font-size:clamp(30px,4vw,48px); line-height:1.1; margin:18px 0 0; }
.about-body .bio{ font-size:18.5px; line-height:1.72; margin:24px 0; max-width:52ch; }
.about-creds{ list-style:none; margin:28px 0 0; padding:0; display:grid; gap:14px; }
.about-creds li{
  display:flex; gap:14px; align-items:flex-start;
  font-family:var(--f-serif); font-size:16.5px;
  transition:transform var(--transition);
}
.about-creds li:hover{ transform:translateX(6px); }
.about-creds .dot{ color:var(--dorado); flex:none; margin-top:3px; }
@media (max-width:820px){ .about-grid{ grid-template-columns:1fr; } .about-photo{ max-width:440px; margin:0 auto; } }

/* ============================================================
   STATS
   ============================================================ */
.stats-band{
  background:linear-gradient(160deg, var(--indigo) 0%, #212460 50%, var(--indigo) 100%);
  color:var(--crema);
  position:relative; overflow:hidden;
}
.stats-band .leopard-layer{ background-size:540px; opacity:.06; }
.stats-grid{
  display:grid; grid-template-columns:repeat(3,1fr); gap:30px;
  position:relative; z-index:1;
}
.stat{
  text-align:center; padding:16px;
  position:relative;
  transition:transform var(--transition);
}
.stat:hover{ transform:translateY(-4px); }
.stat + .stat::before{
  content:""; position:absolute; left:0; top:18%; bottom:18%;
  width:1px; background:var(--linea-oro-soft);
}
.stat .num{
  font-family:var(--f-display);
  font-size:clamp(40px,6vw,70px); line-height:1;
  color:var(--dorado-claro);
  text-shadow:0 0 60px rgba(184,144,76,.3);
}
.stat .num .suf{ color:var(--turquesa); }
.stat .lbl{
  font-family:var(--f-ui); font-size:12.5px; letter-spacing:.18em;
  text-transform:uppercase; margin-top:14px; color:rgba(245,240,228,.72);
}
@media (max-width:680px){
  .stats-grid{ grid-template-columns:1fr; gap:34px; }
  .stat + .stat::before{ display:none; }
  .stat + .stat{ border-top:1px solid var(--linea-oro-soft); padding-top:30px; }
}

/* ============================================================
   TESTIMONIOS
   ============================================================ */
.testi-grid{ display:grid; grid-template-columns:repeat(auto-fit,minmax(290px,1fr)); gap:26px; }
.testi{
  background:rgba(245,240,228,.04);
  border:1px solid var(--linea-oro-soft);
  border-radius:var(--radius); padding:36px 32px;
  position:relative; overflow:hidden;
  transition:transform var(--transition), box-shadow var(--transition), border-color var(--transition), background var(--transition);
}
.testi::before{
  content:""; position:absolute; top:0; left:0; right:0; height:2px;
  background:linear-gradient(90deg, transparent, var(--dorado), var(--turquesa), transparent);
  transform:scaleX(0); transform-origin:left;
  transition:transform .6s cubic-bezier(.2,.8,.2,1);
}
.testi:hover{ transform:translateY(-6px); box-shadow:0 30px 60px -20px rgba(0,0,0,.5); border-color:var(--linea-oro); background:rgba(245,240,228,.07); }
.testi:hover::before{ transform:scaleX(1); }

.testi .mark{ font-family:var(--f-display); font-size:56px; line-height:.6; color:var(--dorado); opacity:.4; height:24px; }
.testi p{ font-family:var(--f-editorial); font-size:21px; line-height:1.52; font-weight:500; margin:18px 0 24px; }
.testi .who{ display:flex; align-items:center; gap:14px; }
.testi .ini{
  width:44px; height:44px; border-radius:50%;
  background:linear-gradient(135deg,var(--indigo-noche),var(--indigo));
  color:var(--turquesa); display:grid; place-items:center;
  font-family:var(--f-title); font-size:15px;
  border:1px solid var(--linea-oro);
}
.testi .who b{ font-family:var(--f-ui); font-weight:500; font-size:14px; letter-spacing:.04em; display:block; }
.testi .who span{ font-family:var(--f-ui); font-size:12px; opacity:.6; }
.testi .stars-row{ color:var(--dorado); font-size:14px; letter-spacing:3px; margin-bottom:6px; }
.google-note{ text-align:center; margin-top:40px; font-family:var(--f-ui); font-size:13px; letter-spacing:.04em; opacity:.55; }

/* ============================================================
   DIFERENCIAL
   ============================================================ */
.diff-grid{
  display:grid; grid-template-columns:repeat(auto-fit,minmax(260px,1fr));
  gap:1px; background:var(--linea-oro-soft);
  border:1px solid var(--linea-oro-soft);
  border-radius:var(--radius); overflow:hidden;
}
.diff{
  background:var(--crema); padding:44px 36px;
  transition:background var(--transition), transform var(--transition);
  position:relative; overflow:hidden;
}
.diff::before{
  content:""; position:absolute; bottom:0; left:0; right:0; height:3px;
  background:linear-gradient(90deg,var(--dorado),var(--turquesa));
  transform:scaleX(0); transform-origin:left;
  transition:transform .5s cubic-bezier(.2,.8,.2,1);
}
.diff:hover{ background:var(--crema-soft); }
.diff:hover::before{ transform:scaleX(1); }
.diff .ico{ width:44px; height:44px; color:var(--dorado); margin-bottom:22px; transition:transform var(--transition), color var(--transition); }
.diff:hover .ico{ transform:scale(1.15) rotate(-5deg); color:var(--turquesa); }
.diff h3{ font-family:var(--f-editorial); font-weight:600; font-size:24px; margin:0 0 10px; }
.diff p{ font-size:16px; line-height:1.65; opacity:.8; margin:0; }

/* ============================================================
   FAQ
   ============================================================ */
.faq{ max-width:820px; margin:0 auto; }
.faq-item{ border-bottom:1px solid var(--linea-oro-soft); }
.faq-q{
  width:100%; background:none; border:none; cursor:pointer;
  display:flex; justify-content:space-between; align-items:center; gap:24px;
  padding:30px 4px; text-align:left;
  font-family:var(--f-editorial); font-weight:600; font-size:clamp(20px,2.5vw,27px);
  color:inherit;
  transition:color var(--transition);
}
.faq-q:hover{ color:var(--dorado); }
.faq-q:focus-visible{ outline:2px solid var(--dorado); outline-offset:4px; border-radius:2px; }
.faq-q .pm{ flex:none; width:32px; height:32px; position:relative; border-radius:50%; border:1.5px solid var(--linea-oro); transition:border-color var(--transition), background var(--transition); }
.faq-q:hover .pm{ border-color:var(--dorado); background:rgba(184,144,76,.08); }
.faq-q .pm::before, .faq-q .pm::after{ content:""; position:absolute; background:var(--dorado); transition:transform .4s cubic-bezier(.2,.8,.2,1), opacity .4s; }
.faq-q .pm::before{ top:50%; left:6px; right:6px; height:1.5px; transform:translateY(-50%); }
.faq-q .pm::after{ left:50%; top:6px; bottom:6px; width:1.5px; transform:translateX(-50%); }
.faq-item.open .pm::after{ transform:translateX(-50%) scaleY(0); opacity:0; }
.faq-item.open .faq-q{ color:var(--dorado); }
.faq-a{ max-height:0; overflow:hidden; transition:max-height .5s cubic-bezier(.2,.7,.2,1); }
.faq-a-inner{ padding:0 4px 30px; font-size:18px; line-height:1.72; opacity:.86; max-width:64ch; }
.faq-a-inner .em{ color:var(--dorado); font-style:italic; }

/* ============================================================
   CTA FINAL
   ============================================================ */
.final{
  position:relative; overflow:hidden;
  background:
    radial-gradient(ellipse 110% 130% at 85% 0%, rgba(45,48,110,.95), transparent 55%),
    radial-gradient(ellipse 60% 80% at 15% 100%, rgba(184,144,76,.12), transparent 60%),
    var(--indigo-deep);
  color:var(--crema);
}
.final-grid{ display:grid; grid-template-columns:1fr .8fr; gap:clamp(40px,6vw,90px); align-items:center; }
.final h2{ font-family:var(--f-editorial); font-weight:500; font-size:clamp(32px,4.8vw,58px); line-height:1.15; margin:26px 0 0; }
.final h2 .em{ color:var(--turquesa); font-style:italic; }
.final p{ font-size:20px; line-height:1.65; margin:26px 0 40px; color:rgba(245,240,228,.84); max-width:48ch; }
.final-photo{ position:relative; justify-self:center; width:min(360px,80%); }
.final-photo .arch{
  border-radius:50% 50% 4px 4px/40% 40% 3px 3px; overflow:hidden;
  border:2px solid var(--dorado); aspect-ratio:3/4; background:var(--crema);
  box-shadow:0 40px 90px -36px rgba(0,0,0,.8);
  transition:box-shadow var(--transition);
}
.final-photo:hover .arch{ box-shadow:0 50px 100px -30px rgba(0,0,0,.9); }
.final-photo .arch img{ width:100%; height:100%; object-fit:cover; object-position:50% 14%; transition:transform 8s ease; }
.final-photo:hover .arch img{ transform:scale(1.04); }
@media (max-width:820px){
  .final-grid{ grid-template-columns:1fr; text-align:center; }
  .final-photo{ order:-1; width:min(300px,70%); }
  .final p{ margin-inline:auto; }
}

/* ============================================================
   FOOTER
   ============================================================ */
.foot{
  background:var(--tinta); color:rgba(245,240,228,.68);
  padding:72px 0 44px;
  border-top:1px solid rgba(184,144,76,.14);
}
.foot-grid{ display:flex; flex-wrap:wrap; justify-content:space-between; gap:40px; align-items:flex-start; }
.foot .brand img{ height:60px; }
.foot-tag{ font-family:var(--f-editorial); font-style:italic; font-size:19px; max-width:34ch; margin:20px 0 0; color:rgba(245,240,228,.72); }
.foot-links{ display:flex; flex-direction:column; gap:14px; font-family:var(--f-ui); font-size:14px; }
.foot-links a{ opacity:.72; transition:opacity .3s, color .3s, transform .3s; display:inline-block; }
.foot-links a:hover{ opacity:1; color:var(--turquesa); transform:translateX(4px); }
.foot-bottom{
  margin-top:52px; padding-top:26px;
  border-top:1px solid rgba(245,240,228,.1);
  display:flex; justify-content:space-between; flex-wrap:wrap; gap:12px;
  font-family:var(--f-ui); font-size:12px; letter-spacing:.04em; opacity:.48;
}

/* ============================================================
   STICKY WHATSAPP
   ============================================================ */
.wa-float{
  position:fixed; right:26px; bottom:26px; z-index:70;
  display:flex; align-items:center; gap:0;
  background:linear-gradient(135deg,#1FA855,#18934a); color:#fff;
  border-radius:44px; padding:0; height:62px; width:62px;
  box-shadow:0 14px 40px -10px rgba(31,168,85,.65);
  overflow:hidden;
  transition:width .45s cubic-bezier(.2,.8,.2,1), background .3s, box-shadow .3s;
  cursor:pointer; white-space:nowrap;
}
.wa-float svg{ width:30px; height:30px; flex:none; margin:0 16px; }
.wa-float .wa-label{ font-family:var(--f-ui); font-size:13.5px; font-weight:500; letter-spacing:.04em; opacity:0; transition:opacity .3s; padding-right:10px; }
.wa-float:hover{ width:236px; box-shadow:0 20px 50px -10px rgba(31,168,85,.8); }
.wa-float:hover .wa-label{ opacity:1; }
.wa-float.pulse{ animation:wapulse 2.8s infinite; }
@keyframes wapulse{
  0%{ box-shadow:0 14px 40px -10px rgba(31,168,85,.65), 0 0 0 0 rgba(31,168,85,.45);}
  70%{ box-shadow:0 14px 40px -10px rgba(31,168,85,.65), 0 0 0 18px rgba(31,168,85,0);}
  100%{ box-shadow:0 14px 40px -10px rgba(31,168,85,.65), 0 0 0 0 rgba(31,168,85,0);}
}
@media (max-width:680px){ .wa-float{ right:16px; bottom:16px; } }

/* ============================================================
   ADD-ONS
   ============================================================ */

/* Scroll progress bar */
.scroll-progress{
  position:fixed; top:0; left:0; height:2.5px; width:0%;
  background:linear-gradient(90deg,var(--dorado),var(--turquesa),var(--dorado-claro));
  background-size:200% 100%;
  z-index:100; transition:width .08s linear;
  box-shadow:0 0 10px rgba(102,255,255,.4), 0 0 20px rgba(184,144,76,.2);
  animation:progressShimmer 3s linear infinite;
}
@keyframes progressShimmer{ to{ background-position:-200% 0; } }

/* 3D tilt cards */
.tilt{ transform-style:preserve-3d; will-change:transform; }

/* Mobile sticky CTA dock */
.mobile-dock{
  position:fixed; left:0; right:0; bottom:0; z-index:75;
  display:none; gap:10px; padding:12px 14px calc(12px + env(safe-area-inset-bottom));
  background:rgba(20,22,58,.95); backdrop-filter:blur(18px) saturate(160%);
  border-top:1px solid var(--glass-border);
  transform:translateY(120%); transition:transform .5s cubic-bezier(.2,.8,.2,1);
  box-shadow:0 -10px 40px rgba(0,0,0,.3);
}
.mobile-dock.show{ transform:translateY(0); }
.mobile-dock .btn{ flex:1; justify-content:center; padding:16px 10px; font-size:12.5px; }
@media (max-width:680px){
  .mobile-dock{ display:flex; }
  .wa-float{ display:none; }
}

/* Magnetic button helper */
.btn.magnetic{ transition:transform .25s cubic-bezier(.2,.8,.2,1), background var(--transition), color var(--transition), box-shadow var(--transition); }

/* Section separator ornament */
.sec-orn{ display:flex; justify-content:center; padding:0; margin:0; }
.sec-orn svg{ width:130px; height:30px; color:var(--dorado); opacity:.65; }

/* ============================================================
   NUEVA SECCIÓN — Servicios/Precios
   ============================================================ */
.servicios-grid{
  display:grid; grid-template-columns:repeat(auto-fit,minmax(280px,1fr)); gap:28px;
  margin-top:clamp(40px,5vw,60px);
}
.servicio-card{
  background:var(--crema-soft);
  border:1px solid var(--linea-oro-soft);
  border-radius:var(--radius);
  padding:44px 36px;
  text-align:center;
  position:relative; overflow:hidden;
  transition:transform var(--transition), box-shadow var(--transition), border-color var(--transition);
}
.servicio-card.featured{
  background:var(--indigo);
  border-color:var(--dorado);
  color:var(--crema);
}
.servicio-card.featured .servicio-badge{ opacity:1; }
.servicio-badge{
  position:absolute; top:18px; right:18px;
  background:linear-gradient(135deg,var(--dorado),var(--dorado-claro));
  color:var(--indigo); font-family:var(--f-ui); font-size:10px;
  font-weight:700; letter-spacing:.16em; text-transform:uppercase;
  padding:5px 12px; border-radius:20px; opacity:0;
}
.servicio-card:hover{ transform:translateY(-8px); box-shadow:var(--shadow-hover); border-color:var(--dorado); }
.servicio-ico{
  width:60px; height:60px; margin:0 auto 24px;
  border-radius:50%; border:1.5px solid var(--linea-oro);
  display:grid; place-items:center; color:var(--dorado);
  transition:transform var(--transition), box-shadow var(--transition);
}
.servicio-card.featured .servicio-ico{ border-color:rgba(102,255,255,.4); color:var(--turquesa); }
.servicio-card:hover .servicio-ico{ transform:scale(1.12) rotate(-5deg); box-shadow:0 0 24px var(--glow-gold); }
.servicio-ico svg{ width:28px; height:28px; }
.servicio-card h3{ font-family:var(--f-editorial); font-size:26px; font-weight:600; margin:0 0 12px; }
.servicio-card.featured h3{ color:var(--crema); }
.servicio-card p{ font-size:17px; line-height:1.65; opacity:.82; margin:0 0 28px; }
.servicio-card.featured p{ color:rgba(245,240,228,.8); }
.servicio-tag{
  display:inline-block; font-family:var(--f-ui); font-size:11px; letter-spacing:.22em;
  text-transform:uppercase; color:var(--dorado-claro); padding:8px 18px;
  border:1px solid var(--linea-oro); border-radius:20px;
  margin-bottom:24px;
}
.servicio-card.featured .servicio-tag{ border-color:rgba(102,255,255,.3); color:var(--turquesa-suave); }
