/* =================================================================
   GABRIELA BARRA · RRHH  —  Hoja de estilos
   Estilo: Editorial de lujo · Burdeo + Dorado + Crema
   Estructura:
     1.  Tokens / variables
     2.  Reset & base
     3.  Tipografía & utilidades
     4.  Botones
     5.  Layout / contenedores / secciones
     6.  Encabezado (announcement + nav)
     7.  Hero
     8.  Franja de estadísticas
     9.  Problema
     10. Servicios
     11. Precios
     12. Sobre mí
     13. Proceso (Cómo trabajamos)
     14. Normativa al día
     15. Misión / Visión / Valores
     16. Blog (teaser + listado + artículo)
     17. Testimonios
     18. FAQ
     19. Contacto
     20. Footer
     21. WhatsApp flotante
     22. Animaciones (reveal)
     23. Responsivo
   ================================================================= */

/* ============================ 1. TOKENS ========================= */
:root{
  /* Marca */
  --wine:        #6a1622;
  --wine-700:    #57121d;
  --wine-800:    #460e17;
  --wine-900:    #340a11;
  --wine-ink:    #2a0d13;

  --gold:        #c4a253;
  --gold-soft:   #ddc185;
  --gold-deep:   #a8822f;
  --gold-foil:   linear-gradient(105deg,#9c7a2c 0%,#e7cd86 26%,#c4a253 48%,#f3e0a6 70%,#a8822f 100%);

  --cream:       #f6efe2;
  --cream-2:     #fbf6ec;
  --paper:       #fffdf8;

  --ink:         #2c1c1f;
  --muted:       #6f5b5e;
  --line:        rgba(106,22,34,.14);
  --line-strong: rgba(106,22,34,.28);

  /* Tipografía */
  --font-display: "Fraunces", "Georgia", serif;
  --font-body:    "Hanken Grotesk", system-ui, -apple-system, sans-serif;

  /* Medidas */
  --container: 1200px;
  --gutter: clamp(1.25rem, 4vw, 3rem);
  --r-sm: 6px;
  --r:    12px;
  --r-lg: 20px;

  /* Sombra */
  --shadow-sm: 0 6px 18px -10px rgba(52,10,17,.28);
  --shadow:    0 26px 60px -34px rgba(52,10,17,.45);
  --shadow-lg: 0 44px 90px -40px rgba(52,10,17,.55);

  --ease: cubic-bezier(.22,.61,.36,1);
}

/* ============================ 2. RESET ========================== */
*,*::before,*::after{ box-sizing:border-box; }
*{ margin:0; }
html{ -webkit-text-size-adjust:100%; text-size-adjust:100%; scroll-behavior:smooth; overflow-x:hidden; overflow-x:clip; }
@media (prefers-reduced-motion: reduce){
  html{ scroll-behavior:auto; }
  *,*::before,*::after{ animation-duration:.001ms !important; transition-duration:.001ms !important; }
}
body{
  font-family:var(--font-body);
  background:var(--cream);
  color:var(--ink);
  line-height:1.65;
  font-size:1.0625rem;
  letter-spacing:.005em;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  -webkit-tap-highlight-color:rgba(106,22,34,.12);
  overflow-x:hidden;
  overflow-x:clip;
}
/* Grano sutil global para dar textura premium */
body::before{
  content:"";
  position:fixed; inset:0;
  pointer-events:none; z-index:9999;
  opacity:.05; mix-blend-mode:multiply;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='180' height='180'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}
img,svg{ display:block; max-width:100%; }
a{ color:inherit; text-decoration:none; }
button{ font:inherit; cursor:pointer; border:none; background:none; color:inherit; }
ul{ list-style:none; padding:0; }
input,select,textarea{ font:inherit; color:inherit; }
::selection{ background:var(--wine); color:#f6efe2; }

/* ===================== 3. TIPOGRAFÍA & UTILIDADES =============== */
h1,h2,h3,h4{ font-family:var(--font-display); font-weight:500; line-height:1.06; letter-spacing:-.012em; color:var(--wine-ink); }
.display{ font-variation-settings:"SOFT" 0,"WONK" 0,"opsz" 144; }

.eyebrow{
  display:inline-flex; align-items:center; gap:.6rem;
  font-family:var(--font-body); font-weight:600;
  font-size:.74rem; letter-spacing:.26em; text-transform:uppercase;
  color:var(--gold-deep);
}
.eyebrow::before{
  content:""; width:30px; height:1px; background:var(--gold-deep); opacity:.6;
}
.eyebrow.center::after{
  content:""; width:30px; height:1px; background:var(--gold-deep); opacity:.6;
}
.eyebrow.center{ justify-content:center; }

.gold-text{
  background:var(--gold-foil);
  -webkit-background-clip:text; background-clip:text;
  -webkit-text-fill-color:transparent; color:transparent;
}
.serif-italic{ font-style:italic; font-family:var(--font-display); }

.section-title{ font-size:clamp(2rem,4.6vw,3.4rem); }
.lead{ font-size:clamp(1.06rem,1.6vw,1.28rem); color:var(--muted); line-height:1.6; }
.idx{ font-family:var(--font-display); font-style:italic; color:var(--gold-deep); opacity:.85; font-size:1.05rem; }

.hr-gold{ height:1px; border:0; background:linear-gradient(90deg,transparent,var(--line-strong),transparent); }

/* ============================ 4. BOTONES ======================= */
.btn{
  --bg:var(--wine); --fg:#f8f1e6;
  display:inline-flex; align-items:center; justify-content:center; gap:.6em;
  padding:1.02em 1.7em; border-radius:999px;
  font-weight:600; font-size:.96rem; letter-spacing:.01em;
  background:var(--bg); color:var(--fg);
  position:relative; isolation:isolate; overflow:hidden;
  transition:transform .45s var(--ease), box-shadow .45s var(--ease), color .4s var(--ease);
  box-shadow:var(--shadow-sm);
}
.btn svg{ width:1.05em; height:1.05em; transition:transform .45s var(--ease); }
.btn::after{ /* barrido dorado al hover */
  content:""; position:absolute; inset:0; z-index:-1;
  background:var(--gold-foil); transform:translateY(101%);
  transition:transform .5s var(--ease);
}
.btn:hover{ transform:translateY(-3px); box-shadow:var(--shadow); color:var(--wine-ink); }
.btn:hover::after{ transform:translateY(0); }
.btn:hover svg{ transform:translateX(3px); }

.btn--gold{ --bg:var(--gold-foil); --fg:var(--wine-ink); }
.btn--gold::after{ background:var(--wine); }
.btn--gold:hover{ color:#f8f1e6; }

.btn--ghost{
  --bg:transparent; --fg:var(--wine);
  box-shadow:inset 0 0 0 1.5px var(--line-strong);
}
.btn--ghost::after{ background:var(--wine); }
.btn--ghost:hover{ color:#f8f1e6; box-shadow:inset 0 0 0 1.5px transparent; }

.btn--light{ --bg:#f7f0e4; --fg:var(--wine-ink); }
.btn--light::after{ background:var(--gold-foil); }
.btn--light:hover{ color:var(--wine-ink); }

/* WhatsApp (verde) */
.btn--wa{ --bg:#1faa55; --fg:#ffffff; box-shadow:0 14px 30px -14px rgba(31,170,85,.7); }
.btn--wa::after{ background:#17833f; }
.btn--wa:hover{ color:#ffffff; }
.btn--wa svg{ fill:currentColor; }

.btn--sm{ padding:.78em 1.25em; font-size:.86rem; }

.link-underline{
  position:relative; font-weight:600; color:var(--wine);
  display:inline-flex; align-items:center; gap:.4em;
}
.link-underline::after{
  content:""; position:absolute; left:0; bottom:-3px; height:1.5px; width:100%;
  background:var(--gold-deep); transform:scaleX(0); transform-origin:right;
  transition:transform .45s var(--ease);
}
.link-underline:hover::after{ transform:scaleX(1); transform-origin:left; }
.link-underline svg{ width:.9em; transition:transform .4s var(--ease); }
.link-underline:hover svg{ transform:translateX(4px); }

/* ===================== 5. LAYOUT / SECCIONES =================== */
.container{ width:min(100% - 2*var(--gutter), var(--container)); margin-inline:auto; }
.container--wide{ --container:1340px; }
.container--narrow{ --container:900px; }

section{ position:relative; }
.section{ padding-block:clamp(4.5rem,9vw,8rem); }
.section--tight{ padding-block:clamp(3rem,6vw,5rem); }

.bg-cream{ background:var(--cream); }
.bg-paper{ background:var(--paper); }
.bg-cream2{ background:var(--cream-2); }
.bg-wine{ background:var(--wine-900); color:#efe3d4; }
.bg-wine h1,.bg-wine h2,.bg-wine h3{ color:#fbf3e6; }

.section-head{ max-width:62ch; }
.section-head.center{ margin-inline:auto; text-align:center; }
.section-head .section-title{ margin-top:1rem; }
.section-head .lead{ margin-top:1.1rem; }

/* Pequeña “oreja” numerada para secciones */
.sec-tag{ display:flex; align-items:baseline; gap:1rem; margin-bottom:.4rem; }

/* ===================== 6. ENCABEZADO =========================== */
.topbar{
  background:var(--wine-900); color:#e9d9bd;
  font-size:.8rem; letter-spacing:.02em;
  border-bottom:1px solid rgba(196,162,83,.18);
}
.topbar .container{ display:flex; align-items:center; justify-content:center; gap:.6rem; padding-block:.55rem; text-align:center; }
.topbar strong{ color:#f4e6c6; font-weight:700; }
.topbar .spark{ color:var(--gold); }

/* Cinta / marquee de precios e información (derecha → izquierda) */
.ticker{ background:var(--gold-foil); color:var(--wine-ink); overflow:hidden;
  border-block:1px solid rgba(106,22,34,.18); box-shadow:inset 0 1px 0 rgba(255,255,255,.25); }
.ticker-track{ display:inline-flex; align-items:center; white-space:nowrap; will-change:transform; animation:ticker 42s linear infinite; }
.ticker:hover .ticker-track{ animation-play-state:paused; }
.ticker-group{ display:inline-flex; align-items:center; }
.ticker-item{ display:inline-flex; align-items:center; gap:.7rem; padding:.78rem 1.7rem; font-size:.94rem; font-weight:600; letter-spacing:.01em; }
.ticker-item b{ font-family:var(--font-display); font-weight:600; }
.ticker-item::before{ content:"✦"; color:var(--wine); opacity:.5; font-size:.7em; }
@keyframes ticker{ from{ transform:translateX(0); } to{ transform:translateX(-50%); } }
@media (prefers-reduced-motion: reduce){ .ticker-track{ animation:none; transform:none; } }

.site-header{
  position:sticky; top:0; z-index:100;
  transition:background .4s var(--ease), box-shadow .4s var(--ease), padding .4s var(--ease);
}
.site-header .container{ display:flex; align-items:center; justify-content:space-between; gap:1rem; padding-block:1.05rem; }
.site-header.scrolled{
  background:rgba(246,239,226,.86);
  -webkit-backdrop-filter:blur(14px) saturate(1.2);
  backdrop-filter:blur(14px) saturate(1.2);
  box-shadow:0 1px 0 var(--line), 0 18px 40px -34px rgba(52,10,17,.5);
}
.site-header.scrolled .container{ padding-block:.7rem; }

.brand{ display:flex; align-items:center; gap:.7rem; }
.brand img{ width:84px; height:84px; border-radius:50%; box-shadow:0 0 0 2px rgba(196,162,83,.65), 0 8px 20px -8px rgba(52,10,17,.45); transition:width .4s var(--ease), height .4s var(--ease); }
.scrolled .brand img{ width:64px; height:64px; }
.brand-txt{ line-height:1.05; }
.brand-txt b{ font-family:var(--font-display); font-weight:600; font-size:1.2rem; color:var(--wine-ink); letter-spacing:.01em; }
.brand-txt span{ display:block; font-size:.64rem; letter-spacing:.32em; text-transform:uppercase; color:var(--gold-deep); margin-top:1px; }

.nav{ display:flex; align-items:center; gap:2rem; }
.nav-links{ display:flex; align-items:center; gap:1.7rem; }
.nav-links a{ font-size:.92rem; font-weight:500; color:var(--wine-ink); position:relative; padding:.2rem 0; }
.nav-links a::after{
  content:""; position:absolute; left:0; bottom:-2px; height:1.5px; width:100%;
  background:var(--gold-deep); transform:scaleX(0); transform-origin:right; transition:transform .4s var(--ease);
}
.nav-links a:hover::after{ transform:scaleX(1); transform-origin:left; }

.nav-toggle{ display:none; width:46px; height:46px; border-radius:50%; align-items:center; justify-content:center; box-shadow:inset 0 0 0 1.5px var(--line-strong); }
.nav-toggle span{ position:relative; width:20px; height:2px; background:var(--wine); border-radius:2px; transition:.35s var(--ease); }
.nav-toggle span::before,.nav-toggle span::after{ content:""; position:absolute; left:0; width:20px; height:2px; background:var(--wine); border-radius:2px; transition:.35s var(--ease); }
.nav-toggle span::before{ top:-6px; } .nav-toggle span::after{ top:6px; }
body.nav-open .nav-toggle span{ background:transparent; }
body.nav-open .nav-toggle span::before{ top:0; transform:rotate(45deg); }
body.nav-open .nav-toggle span::after{ top:0; transform:rotate(-45deg); }

/* ============================ 7. HERO ========================== */
.hero{ position:relative; overflow:hidden; background:
   radial-gradient(120% 90% at 85% -10%, rgba(196,162,83,.16), transparent 55%),
   radial-gradient(90% 80% at 0% 110%, rgba(106,22,34,.07), transparent 60%),
   var(--cream); }
.hero-inner{ display:grid; grid-template-columns:1.05fr .95fr; gap:clamp(2rem,5vw,5rem); align-items:center;
  padding-block:clamp(3rem,7vw,6.5rem); }

.hero-copy{ position:relative; z-index:2; max-width:36rem; }
.hero h1{ font-size:clamp(2.2rem,8.5vw,4.7rem); margin-top:1.4rem; overflow-wrap:break-word; }
.hero h1 em{ font-style:italic; }
.hero h1 .gold-text{ font-style:italic; }
.hero-copy .lead{ margin-top:1.5rem; max-width:34rem; }
.hero-cta{ display:flex; flex-wrap:wrap; gap:.9rem; margin-top:2.1rem; }
.hero-trust{ display:flex; align-items:center; gap:1rem; margin-top:2.3rem; color:var(--muted); font-size:.9rem; }
.hero-trust .dot{ width:8px; height:8px; border-radius:50%; background:#3fae6a; box-shadow:0 0 0 4px rgba(63,174,106,.16); }

/* Marco del retrato */
.hero-figure{ position:relative; z-index:2; justify-self:center; width:min(100%,470px); }
/* Halo de color detrás del retrato para que destaque del fondo crema */
.hero-figure::before{
  content:""; position:absolute; z-index:-2; inset:-9% -14% -5% -10%;
  border-radius:50% 50% 46% 46%;
  background:
     radial-gradient(58% 52% at 50% 34%, rgba(106,22,34,.20), transparent 72%),
     radial-gradient(46% 38% at 78% 82%, rgba(196,162,83,.30), transparent 72%),
     radial-gradient(40% 34% at 18% 70%, rgba(196,162,83,.16), transparent 72%);
  filter:blur(8px);
}
.portrait{
  position:relative; aspect-ratio:1040/1300; border-radius:240px 240px 28px 28px;
  overflow:hidden; box-shadow:var(--shadow-lg);
  outline:1px solid rgba(196,162,83,.55); outline-offset:10px;
}
.portrait img{ width:100%; height:100%; object-fit:cover; object-position:center 16%;
  filter:contrast(1.06) saturate(1.1) brightness(1.02); }
.portrait::after{ content:""; position:absolute; inset:0;
  background:linear-gradient(180deg,rgba(255,253,248,.04) 0%,transparent 38%,rgba(52,10,17,.10) 78%,rgba(52,10,17,.34)); }
.hero-figure .arc{
  position:absolute; inset:-22px -22px auto -22px; height:60%;
  border:1px solid rgba(196,162,83,.45); border-radius:260px 260px 0 0; z-index:-1;
}
/* Tarjeta flotante de credencial */
.hero-badge{
  position:absolute; left:-26px; bottom:42px; z-index:3;
  background:var(--paper); border-radius:var(--r);
  padding:.95rem 1.15rem; box-shadow:var(--shadow);
  display:flex; align-items:center; gap:.8rem; max-width:230px;
  border:1px solid var(--line);
}
.hero-badge .seal{ width:42px; height:42px; flex:none; }
.hero-badge b{ font-family:var(--font-display); font-size:1.5rem; color:var(--wine); line-height:1; }
.hero-badge small{ display:block; font-size:.72rem; color:var(--muted); line-height:1.25; margin-top:2px; }

/* sello GB decorativo grande, marca de agua */
.hero-seal-wm{ position:absolute; right:-6%; top:8%; width:min(46vw,520px); opacity:.05; z-index:0; filter:saturate(0); }

/* ===================== 8. ESTADÍSTICAS ========================= */
.stats{ background:var(--wine-900); color:#eaddc8; }
.stats .container{ display:grid; grid-template-columns:repeat(4,1fr); }
.stat{ padding:clamp(2.2rem,4vw,3.2rem) 1.5rem; text-align:center; position:relative; }
.stat + .stat::before{ content:""; position:absolute; left:0; top:24%; bottom:24%; width:1px; background:rgba(196,162,83,.22); }
.stat b{ display:inline-block; position:relative; padding-bottom:.6rem; font-family:var(--font-display); font-weight:500; font-size:clamp(2.4rem,4.5vw,3.4rem); color:#fbf0d8; line-height:1; }
.stat b .gold-text{ font-family:inherit; }
/* Subrayado dorado que se dibuja al entrar y luego brilla en bucle */
.stat b::after{ content:""; position:absolute; left:50%; bottom:0; transform:translateX(-50%);
  height:3px; width:0; border-radius:2px; background:var(--gold-foil); transition:width .8s var(--ease) .35s; }
.stat.is-visible b::after{ width:46px; background:linear-gradient(90deg,var(--gold-deep),var(--gold-soft),var(--gold-deep));
  background-size:200% 100%; animation:statShine 3.2s linear infinite 1.1s; }
.stat.is-visible b{ animation:statPop .65s var(--ease) both; }
@keyframes statPop{ 0%{ transform:scale(.8); opacity:.4; } 60%{ transform:scale(1.05); } 100%{ transform:scale(1); opacity:1; } }
@keyframes statShine{ 0%{ background-position:-140% 0; } 100%{ background-position:240% 0; } }
.stat span{ display:block; margin-top:.5rem; font-size:.84rem; letter-spacing:.04em; color:#cdb89a; max-width:22ch; margin-inline:auto; }
@media (prefers-reduced-motion: reduce){ .stat.is-visible b{ animation:none; } .stat.is-visible b::after{ animation:none; } }

/* ============================ 9. PROBLEMA ====================== */
.problem-grid{ display:grid; grid-template-columns:.9fr 1.1fr; gap:clamp(2rem,5vw,5rem); align-items:center; }
.problem-q{ display:grid; gap:1rem; }
.q-card{
  background:var(--paper); border:1px solid var(--line); border-radius:var(--r);
  padding:1.3rem 1.5rem; display:flex; gap:1rem; align-items:flex-start; box-shadow:var(--shadow-sm);
}
.q-card .mark{ font-family:var(--font-display); font-style:italic; font-size:1.7rem; color:var(--gold-deep); line-height:1; flex:none; }
.q-card p{ font-size:1.02rem; color:var(--ink); }
.problem-copy p + p{ margin-top:1.1rem; }
.problem-copy .closer{ font-family:var(--font-display); font-style:italic; font-size:clamp(1.3rem,2.4vw,1.7rem); color:var(--wine); line-height:1.3; }

/* ============================ 10. SERVICIOS ==================== */
.services-grid{ display:grid; grid-template-columns:repeat(2,1fr); gap:1.4rem; margin-top:3rem; }
.service{
  position:relative; background:var(--paper); border:1px solid var(--line);
  border-radius:var(--r-lg); padding:2.2rem clamp(1.6rem,2.5vw,2.4rem) 2rem;
  overflow:hidden; transition:transform .5s var(--ease), box-shadow .5s var(--ease), border-color .5s var(--ease);
}
.service::before{ content:""; position:absolute; left:0; top:0; height:3px; width:100%; background:var(--gold-foil); transform:scaleX(0); transform-origin:left; transition:transform .55s var(--ease); }
.service:hover{ transform:translateY(-6px); box-shadow:var(--shadow); border-color:transparent; }
.service:hover::before{ transform:scaleX(1); }
.service-ico{ width:58px; height:58px; border-radius:14px; display:grid; place-items:center;
  background:linear-gradient(160deg,#fbf2dd,#f2e3bf); box-shadow:inset 0 0 0 1px rgba(196,162,83,.4); margin-bottom:1.3rem; }
.service-ico svg{ width:28px; height:28px; stroke:var(--wine); }
.service .num{ position:absolute; top:1.5rem; right:1.6rem; font-family:var(--font-display); font-style:italic; font-size:1.1rem; color:var(--gold-deep); opacity:.7; }
.service h3{ font-size:1.45rem; }
.service p.s-sub{ color:var(--muted); margin-top:.5rem; font-size:.98rem; }
.service ul{ margin-top:1.1rem; display:grid; gap:.5rem; }
.service li{ position:relative; padding-left:1.4rem; font-size:.95rem; color:var(--ink); }
.service li::before{ content:""; position:absolute; left:0; top:.62em; width:7px; height:7px; border-radius:50%; background:var(--gold-deep); }

.alacarte{ margin-top:1.4rem; display:flex; flex-wrap:wrap; align-items:center; gap:1rem; justify-content:space-between;
  background:linear-gradient(120deg,var(--wine),var(--wine-800)); color:#f6e9d6; border-radius:var(--r-lg);
  padding:1.5rem clamp(1.5rem,3vw,2.3rem); box-shadow:var(--shadow); }
.alacarte p{ max-width:60ch; }
.alacarte b{ font-family:var(--font-display); color:#fbecca; }

/* ============================ 11. PRECIOS ====================== */
.pricing-grid{ display:grid; grid-template-columns:repeat(2,1fr); gap:1.4rem; margin-top:3rem; }
.price-card{
  background:var(--paper); border:1px solid var(--line); border-radius:var(--r-lg);
  padding:2rem clamp(1.6rem,2.4vw,2.2rem); display:flex; flex-direction:column;
  transition:transform .5s var(--ease), box-shadow .5s var(--ease);
}
.price-card:hover{ transform:translateY(-5px); box-shadow:var(--shadow); }
.price-card.is-featured{ background:linear-gradient(170deg,var(--wine),var(--wine-800)); color:#f3e6d4; border-color:transparent; box-shadow:var(--shadow); }
.price-card.is-featured h3,.price-card.is-featured .amount{ color:#fdf3e1; }
.price-head{ display:flex; align-items:flex-start; justify-content:space-between; gap:1rem; }
.price-card h3{ font-size:1.3rem; }
.tag-best{ font-size:.66rem; letter-spacing:.18em; text-transform:uppercase; font-weight:700; color:var(--wine-ink);
  background:var(--gold-foil); padding:.4em .7em; border-radius:999px; white-space:nowrap; }
.price-amt{ margin-top:1.2rem; display:flex; align-items:baseline; gap:.5rem; flex-wrap:wrap; }
.amount{ font-family:var(--font-display); font-weight:500; font-size:2.5rem; color:var(--wine); line-height:1; }
.amount small{ font-size:.95rem; font-weight:400; color:var(--muted); margin-left:.15rem; }
.is-featured .amount small{ color:#d8c3a6; }
.price-was{ font-size:.9rem; color:var(--muted); text-decoration:line-through; opacity:.8; }
.is-featured .price-was{ color:#caa; }
.price-from{ font-size:.78rem; letter-spacing:.16em; text-transform:uppercase; color:var(--gold-deep); font-weight:600; }
.is-featured .price-from{ color:var(--gold-soft); }
.price-note{ font-size:.85rem; color:var(--muted); margin-top:.4rem; }
.is-featured .price-note{ color:#d6c1a4; }
.price-card ul{ margin-top:1.3rem; display:grid; gap:.55rem; padding-top:1.3rem; border-top:1px solid var(--line); }
.is-featured ul{ border-top-color:rgba(255,255,255,.15); }
.price-card li{ position:relative; padding-left:1.6rem; font-size:.92rem; }
.price-card li::before{ content:""; position:absolute; left:0; top:.18em; width:1rem; height:1rem;
  background:no-repeat center/contain url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23a8822f' stroke-width='2.4' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M20 6 9 17l-5-5'/%3E%3C/svg%3E"); }
.is-featured li::before{ filter:brightness(1.7) saturate(.6); }
.price-card .btn{ margin-top:1.6rem; }
.price-foot{ text-align:center; margin-top:2.2rem; color:var(--muted); font-size:.95rem; }
.price-foot .gold-text{ font-weight:700; }

/* ============================ 12. SOBRE MÍ ===================== */
.about-grid{ display:grid; grid-template-columns:.85fr 1.15fr; gap:clamp(2rem,5vw,5rem); align-items:center; }
.about-media{ position:relative; justify-self:center; max-width:360px; }
.about-media .avatar{ aspect-ratio:4/5; border-radius:190px 190px 22px 22px; overflow:hidden; outline:1px solid rgba(196,162,83,.5); outline-offset:12px; box-shadow:var(--shadow); }
.about-media .avatar img{ width:100%; height:100%; object-fit:cover; object-position:center top; }
.about-media .seal{ position:absolute; right:-6%; bottom:-4%; width:36%; filter:drop-shadow(0 12px 24px rgba(52,10,17,.35)); }
.about-copy h2{ font-size:clamp(1.9rem,3.6vw,2.8rem); }
.about-copy p{ margin-top:1.1rem; color:var(--ink); }
.signature{ font-family:var(--font-display); font-style:italic; font-size:1.7rem; color:var(--wine); margin-top:1.4rem; }
.creds{ margin-top:1.8rem; display:grid; gap:.7rem; }
.creds li{ display:flex; gap:.8rem; align-items:flex-start; font-size:.98rem; }
.creds svg{ width:1.3rem; height:1.3rem; flex:none; stroke:var(--gold-deep); margin-top:.15rem; }

/* ============================ 13. PROCESO ====================== */
.steps{ display:grid; grid-template-columns:repeat(4,1fr); gap:1.4rem; margin-top:3rem; counter-reset:step; }
.step{ position:relative; padding-top:2.6rem; }
.step::before{ counter-increment:step; content:counter(step,decimal-leading-zero);
  font-family:var(--font-display); font-style:italic; font-size:2.4rem; color:var(--gold-deep); opacity:.45; position:absolute; top:-.3rem; left:0; }
.step .dotline{ position:relative; height:1px; background:var(--line-strong); margin-bottom:1.3rem; }
.step .dotline::before{ content:""; position:absolute; left:0; top:50%; transform:translateY(-50%); width:11px; height:11px; border-radius:50%; background:var(--wine); box-shadow:0 0 0 4px var(--cream); }
.step h3{ font-size:1.25rem; }
.step p{ margin-top:.5rem; color:var(--muted); font-size:.95rem; }
.bg-wine .step::before{ color:var(--gold-soft); opacity:.6; }
.bg-wine .step .dotline{ background:rgba(196,162,83,.3); }
.bg-wine .step .dotline::before{ background:var(--gold); box-shadow:0 0 0 4px var(--wine-900); }
.bg-wine .step p{ color:#cdb89a; }

/* ====================== 14. NORMATIVA AL DÍA =================== */
.law-grid{ display:grid; grid-template-columns:repeat(4,1fr); gap:1.2rem; margin-top:2.6rem; }
.law{ background:var(--paper); border:1px solid var(--line); border-radius:var(--r); padding:1.6rem 1.4rem; transition:transform .5s var(--ease), box-shadow .5s var(--ease); }
.law:hover{ transform:translateY(-4px); box-shadow:var(--shadow-sm); }
.law .law-no{ font-size:.72rem; letter-spacing:.16em; text-transform:uppercase; color:var(--gold-deep); font-weight:700; }
.law h3{ font-size:1.15rem; margin-top:.4rem; }
.law p{ font-size:.9rem; color:var(--muted); margin-top:.5rem; }

/* =================== 15. MISIÓN / VISIÓN / VALORES ============= */
.mvv-grid{ display:grid; grid-template-columns:1fr 1fr; gap:1.5rem; }
.mvv-card{ border:1px solid rgba(196,162,83,.24); border-radius:var(--r-lg); padding:clamp(1.8rem,3vw,2.6rem); background:rgba(255,255,255,.03); }
.mvv-card .eyebrow{ color:var(--gold-soft); }
.mvv-card .eyebrow::before{ background:var(--gold-soft); }
.mvv-card h3{ font-size:1.7rem; margin-top:.9rem; color:#fbf3e6; }
.mvv-card p{ margin-top:.8rem; color:#d9c6ad; }
.values{ grid-column:1/-1; display:flex; flex-wrap:wrap; gap:.7rem; margin-top:.5rem; }
.value-chip{ display:inline-flex; align-items:center; gap:.5rem; padding:.6em 1.1em; border-radius:999px;
  border:1px solid rgba(196,162,83,.4); color:#f1e2c8; font-size:.92rem; }
.value-chip svg{ width:1rem; stroke:var(--gold-soft); }

/* ============================ 16. BLOG ========================= */
.blog-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:1.5rem; margin-top:3rem; }
.post-card{ display:flex; flex-direction:column; background:var(--paper); border:1px solid var(--line);
  border-radius:var(--r-lg); overflow:hidden; transition:transform .5s var(--ease), box-shadow .5s var(--ease); }
.post-card:hover{ transform:translateY(-6px); box-shadow:var(--shadow); }
.post-thumb{ aspect-ratio:16/10; position:relative; overflow:hidden;
  background:linear-gradient(150deg,var(--wine),var(--wine-800)); }
.post-thumb img{ position:absolute; inset:0; width:100%; height:100%; object-fit:cover; transition:transform .7s var(--ease); }
.post-card:hover .post-thumb img{ transform:scale(1.06); }
.post-thumb::after{ content:""; position:absolute; inset:0; z-index:1; pointer-events:none;
  background:linear-gradient(180deg,rgba(52,10,17,.04) 38%,rgba(52,10,17,.5)); }
.post-thumb .ptag{ position:absolute; left:1rem; top:1rem; z-index:2; font-size:.68rem; letter-spacing:.14em; text-transform:uppercase; font-weight:700;
  color:var(--wine-ink); background:var(--gold-foil); padding:.4em .8em; border-radius:999px; box-shadow:0 4px 12px -4px rgba(52,10,17,.5); }
.post-body{ padding:1.5rem 1.5rem 1.7rem; display:flex; flex-direction:column; flex:1; }
.post-meta{ font-size:.78rem; letter-spacing:.04em; color:var(--gold-deep); text-transform:uppercase; font-weight:600; }
.post-card h3{ font-size:1.3rem; margin-top:.6rem; }
.post-card p{ color:var(--muted); margin-top:.6rem; font-size:.95rem; flex:1; }
.post-card .link-underline{ margin-top:1.2rem; }

/* Listado de blog (blog.html) */
.blog-hero{ background:
   radial-gradient(110% 90% at 90% -20%, rgba(196,162,83,.18), transparent 55%), var(--cream); }
.blog-hero .container{ padding-block:clamp(3rem,7vw,5.5rem); text-align:center; }
.blog-hero h1{ font-size:clamp(2.4rem,6vw,4rem); margin-top:1rem; }
.blog-hero .lead{ margin:1.2rem auto 0; max-width:56ch; }

/* Artículo */
.article{ padding-block:clamp(2.5rem,5vw,4rem); }
.article-head{ text-align:center; max-width:760px; margin-inline:auto; }
.article-head h1{ font-size:clamp(2rem,4.8vw,3.2rem); margin-top:1rem; }
.article-meta{ margin-top:1.4rem; display:flex; gap:1rem; justify-content:center; flex-wrap:wrap; color:var(--muted); font-size:.88rem; }
.article-meta span{ display:inline-flex; align-items:center; gap:.4rem; }
.article-cover{ width:min(100% - 2*var(--gutter),980px); margin:2.5rem auto 0; aspect-ratio:16/7; border-radius:var(--r-lg);
  background:linear-gradient(150deg,var(--wine),var(--wine-800)); position:relative; overflow:hidden; box-shadow:var(--shadow); }
.article-cover img{ position:absolute; inset:0; width:100%; height:100%; object-fit:cover; }
.article-cover::after{ content:""; position:absolute; inset:0; pointer-events:none;
  background:linear-gradient(180deg,rgba(52,10,17,.12),rgba(52,10,17,.42)); }
.prose{ width:min(100% - 2*var(--gutter), 720px); margin:3rem auto 0; font-size:1.1rem; line-height:1.8; color:#3a2a2d; }
.prose h2{ font-size:1.7rem; margin-top:2.6rem; }
.prose h3{ font-size:1.3rem; margin-top:1.8rem; }
.prose p{ margin-top:1.1rem; }
.prose ul{ margin-top:1.1rem; display:grid; gap:.6rem; }
.prose ul li{ position:relative; padding-left:1.5rem; }
.prose ul li::before{ content:""; position:absolute; left:0; top:.65em; width:7px; height:7px; border-radius:50%; background:var(--gold-deep); }
.prose blockquote{ margin:1.8rem 0; padding:1.2rem 1.6rem; border-left:3px solid var(--gold-deep);
  background:var(--cream-2); border-radius:0 var(--r) var(--r) 0; font-family:var(--font-display); font-style:italic; font-size:1.2rem; color:var(--wine); }
.prose a{ color:var(--wine); font-weight:600; text-decoration:underline; text-decoration-color:var(--gold-deep); text-underline-offset:3px; }
.article-cta{ width:min(100% - 2*var(--gutter),720px); margin:3rem auto 0; text-align:center;
  background:linear-gradient(120deg,var(--wine),var(--wine-800)); color:#f4e7d5; border-radius:var(--r-lg); padding:clamp(2rem,4vw,3rem); box-shadow:var(--shadow); }
.article-cta h3{ color:#fbf0db; font-size:1.7rem; }
.article-cta p{ margin:.8rem auto 1.6rem; max-width:46ch; color:#dcc8ac; }

/* ============================ 17. TESTIMONIOS ================== */
.testi-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:1.5rem; margin-top:3rem; }
.testi{ background:var(--paper); border:1px solid var(--line); border-radius:var(--r-lg); padding:2rem; box-shadow:var(--shadow-sm); position:relative; }
.testi .quo{ font-family:var(--font-display); font-style:italic; font-size:3.4rem; color:var(--gold-deep); opacity:.35; line-height:.6; }
.testi p{ margin-top:.6rem; font-size:1.02rem; color:var(--ink); }
.testi .who{ margin-top:1.4rem; display:flex; align-items:center; gap:.85rem; padding-top:1.2rem; border-top:1px solid var(--line); }
.testi .who .av{ width:44px; height:44px; border-radius:50%; flex:none; display:grid; place-items:center; font-family:var(--font-display); color:#fbf0db;
  background:linear-gradient(150deg,var(--wine),var(--wine-800)); font-size:1.1rem; }
.testi .who b{ font-weight:600; color:var(--wine-ink); }
.testi .who span{ display:block; font-size:.82rem; color:var(--muted); }
.testi .stars{ display:flex; gap:.15rem; margin-top:.8rem; color:var(--gold-deep); }
.testi .stars svg{ width:1rem; fill:var(--gold-deep); stroke:none; }
.note-replace{ display:inline-flex; align-items:center; gap:.5rem; margin-top:1.6rem; font-size:.82rem; color:var(--muted);
  background:rgba(196,162,83,.12); border:1px dashed var(--gold-deep); border-radius:999px; padding:.5em 1em; }

/* ============================ 18. FAQ ========================= */
.faq{ max-width:820px; margin:2.6rem auto 0; }
.faq-item{ border-bottom:1px solid var(--line); }
.faq-q{ width:100%; display:flex; align-items:center; justify-content:space-between; gap:1.5rem; text-align:left;
  padding:1.5rem .25rem; font-family:var(--font-display); font-size:1.2rem; color:var(--wine-ink); }
.faq-ico{ position:relative; width:24px; height:24px; flex:none; }
.faq-ico::before,.faq-ico::after{ content:""; position:absolute; left:50%; top:50%; background:var(--gold-deep); border-radius:2px; transition:transform .4s var(--ease); }
.faq-ico::before{ width:14px; height:2px; transform:translate(-50%,-50%); }
.faq-ico::after{ width:2px; height:14px; transform:translate(-50%,-50%); }
.faq-item.open .faq-ico::after{ transform:translate(-50%,-50%) scaleY(0); }
.faq-a{ overflow:hidden; max-height:0; transition:max-height .5s var(--ease); }
.faq-a-inner{ padding:0 .25rem 1.6rem; color:var(--muted); max-width:68ch; }
.faq-item.open .faq-q{ color:var(--wine); }

/* ============================ 19. CONTACTO ==================== */
.contact-grid{ display:grid; grid-template-columns:.92fr 1.08fr; gap:clamp(2rem,5vw,4.5rem); align-items:start; }
.contact-aside h2{ font-size:clamp(2rem,4vw,3rem); }
.contact-aside .lead{ margin-top:1.1rem; }
.contact-list{ margin-top:2rem; display:grid; gap:1rem; }
.contact-row{ display:flex; align-items:center; gap:1rem; }
.contact-row .ci{ width:48px; height:48px; border-radius:14px; display:grid; place-items:center; flex:none;
  background:linear-gradient(160deg,#fbf2dd,#f2e3bf); box-shadow:inset 0 0 0 1px rgba(196,162,83,.4); }
.contact-row .ci svg{ width:22px; height:22px; stroke:var(--wine); }
.contact-row b{ display:block; font-size:.78rem; letter-spacing:.1em; text-transform:uppercase; color:var(--gold-deep); }
.contact-row a,.contact-row span{ font-size:1.05rem; color:var(--wine-ink); }
.socials{ display:flex; gap:.7rem; margin-top:2rem; }
.socials a{ width:46px; height:46px; border-radius:50%; display:grid; place-items:center; box-shadow:inset 0 0 0 1.5px var(--line-strong); transition:.4s var(--ease); }
.socials a:hover{ background:var(--wine); box-shadow:inset 0 0 0 1.5px var(--wine); }
.socials a svg{ width:20px; height:20px; fill:var(--wine); transition:fill .4s var(--ease); }
.socials a:hover svg{ fill:#f6efe2; }

.form-card{ background:var(--paper); border:1px solid var(--line); border-radius:var(--r-lg);
  padding:clamp(1.6rem,3vw,2.6rem); box-shadow:var(--shadow); }
.form-row{ display:grid; grid-template-columns:1fr 1fr; gap:1rem; }
.field{ margin-bottom:1.05rem; }
.field.full{ grid-column:1/-1; }
.field label{ display:block; font-size:.82rem; font-weight:600; letter-spacing:.02em; color:var(--wine-ink); margin-bottom:.45rem; }
.field label .req{ color:var(--gold-deep); }
.field input,.field select,.field textarea{
  width:100%; padding:.85rem 1rem; background:var(--cream-2); border:1px solid var(--line);
  border-radius:var(--r-sm); transition:border-color .3s, box-shadow .3s, background .3s; }
.field textarea{ resize:vertical; min-height:120px; }
.field select{ appearance:none; background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%236a1622' stroke-width='2' stroke-linecap='round'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E"); background-repeat:no-repeat; background-position:right 1rem center; background-size:18px; padding-right:2.6rem; }
.field input:focus,.field select:focus,.field textarea:focus{ outline:none; border-color:var(--gold-deep); background:var(--paper); box-shadow:0 0 0 4px rgba(196,162,83,.16); }
.form-actions{ display:flex; flex-wrap:wrap; gap:.8rem; margin-top:.4rem; }
.form-actions .btn{ flex:1 1 auto; }
.form-note{ font-size:.82rem; color:var(--muted); margin-top:1rem; text-align:center; }
.form-status{ margin-top:1rem; font-size:.92rem; padding:.8rem 1rem; border-radius:var(--r-sm); display:none; }
.form-status.ok{ display:block; background:rgba(63,174,106,.12); color:#1f7a45; border:1px solid rgba(63,174,106,.4); }
.form-status.err{ display:block; background:rgba(176,38,52,.1); color:#9a2230; border:1px solid rgba(176,38,52,.35); }
.or-divider{ display:flex; align-items:center; gap:1rem; margin:1.2rem 0; color:var(--muted); font-size:.82rem; letter-spacing:.1em; text-transform:uppercase; }
.or-divider::before,.or-divider::after{ content:""; height:1px; flex:1; background:var(--line); }

/* ============================ 20. FOOTER ===================== */
.footer{ background:var(--wine-900); color:#cdb89a; padding-block:clamp(3rem,6vw,4.5rem) 2rem; }
.footer-top{ display:grid; grid-template-columns:1.4fr 1fr 1fr 1.2fr; gap:2.5rem; }
.footer .brand-txt b{ color:#fbf0db; }
.footer p{ margin-top:1.1rem; max-width:34ch; font-size:.95rem; color:#bda284; }
.footer h4{ font-family:var(--font-body); font-size:.76rem; letter-spacing:.2em; text-transform:uppercase; color:var(--gold-soft); font-weight:700; margin-bottom:1.1rem; }
.footer-col a{ display:block; padding:.32rem 0; font-size:.95rem; color:#d7c3a6; transition:color .3s, padding-left .3s; }
.footer-col a:hover{ color:#fbf0db; padding-left:.3rem; }
.footer .socials a{ box-shadow:inset 0 0 0 1.5px rgba(196,162,83,.4); }
.footer .socials a svg{ fill:var(--gold-soft); }
.footer .socials a:hover{ background:var(--gold); box-shadow:inset 0 0 0 1.5px var(--gold); }
.footer .socials a:hover svg{ fill:var(--wine-900); }
.footer-bottom{ margin-top:3rem; padding-top:1.6rem; border-top:1px solid rgba(196,162,83,.2);
  display:flex; flex-wrap:wrap; gap:1rem; justify-content:space-between; align-items:center; font-size:.84rem; color:#a98f72; }
.footer-bottom a{ color:#cdb89a; }

/* ====================== 21. WHATSAPP FLOTANTE ================= */
.wa-float{ position:fixed; right:clamp(1rem,3vw,2rem); bottom:clamp(1rem,3vw,2rem); z-index:200;
  width:60px; height:60px; border-radius:50%; display:grid; place-items:center;
  background:#1faa55; box-shadow:0 16px 34px -10px rgba(31,170,85,.6); transition:transform .4s var(--ease); }
.wa-float svg{ width:32px; height:32px; fill:#fff; }
.wa-float::after{ content:""; position:absolute; inset:0; border-radius:50%; border:2px solid #1faa55; animation:wa-pulse 2.4s var(--ease) infinite; }
.wa-float:hover{ transform:scale(1.08) translateY(-2px); }
.wa-float .wa-tip{ position:absolute; right:74px; top:50%; transform:translateY(-50%) translateX(8px); white-space:nowrap;
  background:var(--wine-900); color:#f3e6d4; padding:.6em 1em; border-radius:999px; font-size:.85rem; box-shadow:var(--shadow);
  opacity:0; pointer-events:none; transition:.4s var(--ease); }
.wa-float:hover .wa-tip{ opacity:1; transform:translateY(-50%) translateX(0); }
@keyframes wa-pulse{ 0%{ transform:scale(1); opacity:.7; } 70%{ transform:scale(1.5); opacity:0; } 100%{ opacity:0; } }

/* ====================== 22. ANIMACIONES (reveal) ============== */
[data-reveal]{ opacity:0; transform:translateY(28px); transition:opacity .9s var(--ease), transform .9s var(--ease); transition-delay:var(--d,0ms); }
[data-reveal].is-visible{ opacity:1; transform:none; }
[data-reveal="zoom"]{ transform:scale(.94); }
[data-reveal="left"]{ transform:translateX(-34px); }
[data-reveal="right"]{ transform:translateX(34px); }

@keyframes floaty{ 0%,100%{ transform:translateY(0); } 50%{ transform:translateY(-10px); } }
.hero-badge{ animation:floaty 6s var(--ease) infinite; }

/* ====================== 23. RESPONSIVO ======================= */
/* Evita el doble espacio entre dos secciones del mismo color (sólo escritorio;
   en móvil el usuario lo dejó como estaba) → separación consistente */
@media (min-width: 921px){
  .bg-paper + .bg-paper,
  .bg-cream + .bg-cream,
  .bg-cream2 + .bg-cream2,
  .bg-wine + .bg-wine{ padding-top:0; }
}

@media (max-width: 1080px){
  .stats .container{ grid-template-columns:1fr 1fr; }
  .stat:nth-child(2)::before{ display:none; }
  .stat:nth-child(3),.stat:nth-child(4){ border-top:1px solid rgba(196,162,83,.18); }
  .steps{ grid-template-columns:1fr 1fr; }
  .law-grid{ grid-template-columns:1fr 1fr; }
  .footer-top{ grid-template-columns:1fr 1fr; }
}
@media (max-width: 1024px){
  .nav-links, .nav .btn{ display:none; }
  .nav-toggle{ display:flex; }
  .site-header{ background:rgba(246,239,226,.9); -webkit-backdrop-filter:blur(12px); backdrop-filter:blur(12px); }
  .nav-mobile{
    position:fixed; inset:0 0 0 auto; width:min(82vw,320px); z-index:120;
    background:var(--wine-900); color:#f3e6d4; padding:4.8rem 1.6rem 1.8rem;
    transform:translateX(100%); transition:transform .5s var(--ease); display:flex; flex-direction:column; gap:0;
    box-shadow:var(--shadow-lg);
  }
  body.nav-open .nav-mobile{ transform:none; }
  .nav-mobile a{ font-family:var(--font-body); font-size:1rem; font-weight:500; letter-spacing:.01em; padding:.72rem 0; border-bottom:1px solid rgba(196,162,83,.15); color:#f3e6d4; }
  .nav-mobile .btn{ margin-top:1.2rem; background:var(--gold-foil); color:var(--wine-ink); border-bottom:none; font-family:var(--font-body); font-size:.92rem; padding:.85em 1.4em; }
  .nav-mobile .btn::after{ background:#f6efe2; }
  .nav-mobile .btn--wa{ margin-top:.6rem; background:#1faa55; color:#fff; }
  .nav-mobile .btn--wa::after{ background:#17833f; }
  .nav-mobile .btn--wa svg{ fill:#fff; }
  .nav-overlay{ position:fixed; inset:0; background:rgba(40,10,16,.5); -webkit-backdrop-filter:blur(2px); backdrop-filter:blur(2px); opacity:0; pointer-events:none; transition:.4s; z-index:110; }
  body.nav-open .nav-overlay{ opacity:1; pointer-events:auto; }
}
@media (max-width: 920px){
  .hero-inner{ grid-template-columns:1fr; text-align:center; }
  .hero-copy{ max-width:none; margin-inline:auto; }
  .hero-copy .lead{ margin-inline:auto; }
  .hero-cta,.hero-trust{ justify-content:center; }
  .hero-cta .btn{ flex:1 1 auto; }
  .hero-figure{ order:0; margin-top:1.5rem; }
  .hero-seal-wm{ display:none; }
  /* El grano usa mix-blend-mode sobre un overlay fijo: lo quitamos en móvil para un scroll fluido */
  body::before{ display:none; }
  .problem-grid,.about-grid,.contact-grid{ grid-template-columns:1fr; }
  .about-media{ order:-1; }
  .mvv-grid{ grid-template-columns:1fr; }
}
@media (max-width: 720px){
  .nav-mobile{ display:flex; }
}
@media (max-width: 640px){
  .services-grid,.pricing-grid,.blog-grid,.testi-grid{ grid-template-columns:1fr; }
  .steps,.law-grid{ grid-template-columns:1fr; }
  .footer-top{ grid-template-columns:1fr; gap:2rem; }
  .form-row{ grid-template-columns:1fr; }
  .stats .container{ grid-template-columns:1fr; }
  .stat::before{ display:none !important; }
  .stat + .stat{ border-top:1px solid rgba(196,162,83,.18); }
  .hero-badge{ left:0; right:0; margin-inline:auto; width:max-content; max-width:90%; transform:none; animation:none; bottom:-22px; }
  .portrait{ border-radius:160px 160px 24px 24px; }
  .ticker-item{ font-size:.82rem; padding:.55rem 1rem; gap:.45rem; }
}
/* La barra móvil sólo existe en pantallas pequeñas */
.nav-mobile,.nav-overlay{ display:none; }
@media (max-width: 1024px){ .nav-mobile{ display:flex; } .nav-overlay{ display:block; } }

/* ====================== 24. PUNTERO PERSONALIZADO ============== */
/* Sólo se activa por JS en dispositivos con mouse (pointer:fine) */
html.has-cursor, html.has-cursor *{ cursor:none !important; }
.cursor-dot, .cursor-ring{
  position:fixed; top:0; left:0; z-index:10001; pointer-events:none; border-radius:50%;
  opacity:0; transition:opacity .3s var(--ease);
}
html.has-cursor .cursor-dot, html.has-cursor .cursor-ring{ opacity:1; }
.cursor-dot{ width:7px; height:7px; margin:-3.5px 0 0 -3.5px; background:var(--wine); }
.cursor-ring{
  width:36px; height:36px; margin:-18px 0 0 -18px;
  border:1.5px solid var(--gold-deep); background:rgba(196,162,83,.04);
  transition:width .28s var(--ease), height .28s var(--ease), margin .28s var(--ease),
             background-color .28s var(--ease), border-color .28s var(--ease), opacity .3s var(--ease);
}
html.cursor-hover .cursor-ring{ width:56px; height:56px; margin:-28px 0 0 -28px; background:rgba(196,162,83,.14); border-color:var(--gold); }
html.cursor-hover .cursor-dot{ background:var(--gold-deep); }
html.cursor-down .cursor-ring{ width:28px; height:28px; margin:-14px 0 0 -14px; }

/* ====================== 25. HERO DINÁMICO ===================== */
/* Aurora animada de fondo */
.hero-aurora{ position:absolute; inset:0; z-index:0; overflow:hidden; pointer-events:none; }
.hero-aurora::before, .hero-aurora::after{ content:""; position:absolute; border-radius:50%; filter:blur(64px); opacity:.55; }
.hero-aurora::before{ width:46vw; height:46vw; left:-9%; top:-14%;
  background:radial-gradient(circle, rgba(196,162,83,.55), transparent 64%);
  animation:aurora-a 17s ease-in-out infinite alternate; }
.hero-aurora::after{ width:42vw; height:42vw; right:-8%; bottom:-16%;
  background:radial-gradient(circle, rgba(106,22,34,.38), transparent 64%);
  animation:aurora-b 21s ease-in-out infinite alternate; }
@keyframes aurora-a{ to{ transform:translate(13%,11%) scale(1.18); } }
@keyframes aurora-b{ to{ transform:translate(-11%,-9%) scale(1.12); } }

/* Brillo dorado en movimiento sobre el titular */
.hero h1 .gold-text{ background-size:220% auto; animation:shimmer 7s linear infinite; }
@keyframes shimmer{ to{ background-position:220% center; } }

/* Parallax (lo mueve el JS, aquí sólo suaviza) */
.hero .portrait{ will-change:transform; }
.hero-seal-wm{ will-change:transform; }

/* Indicador de scroll */
.hero-scroll{ position:absolute; left:50%; bottom:16px; transform:translateX(-50%); z-index:3;
  width:26px; height:42px; border:1.5px solid var(--line-strong); border-radius:14px;
  display:flex; justify-content:center; padding-top:7px; transition:border-color .3s var(--ease); }
.hero-scroll:hover{ border-color:var(--gold-deep); }
.hero-scroll span{ width:4px; height:8px; border-radius:2px; background:var(--gold-deep); animation:scrolly 1.7s ease-in-out infinite; }
@keyframes scrolly{ 0%{opacity:0; transform:translateY(0);} 25%{opacity:1;} 60%{opacity:1; transform:translateY(11px);} 100%{opacity:0; transform:translateY(11px);} }

@media (max-width: 920px){
  .hero-scroll{ display:none; }
  .hero-aurora::before, .hero-aurora::after{ animation:none; filter:blur(42px); opacity:.4; }
}
@media (prefers-reduced-motion: reduce){
  .hero-aurora::before, .hero-aurora::after, .hero h1 .gold-text, .hero-scroll span{ animation:none; }
}

/* ====================== 26. BOTÓN ICONO (header WhatsApp) ====== */
.btn--icon{ padding:.72em; aspect-ratio:1; }
.btn--icon svg{ width:1.2em; height:1.2em; }
.nav .btn--icon{ margin-right:-1.1rem; }  /* acerca WhatsApp al CTA */

/* ====================== 27. SERVICIOS Y PRECIOS =============== */
/* Áreas (pilares condensados) */
.areas{ display:flex; flex-wrap:wrap; justify-content:center; gap:.7rem; margin-top:2.6rem; }
.area{ display:inline-flex; align-items:center; gap:.5rem; padding:.55em 1.15em; border-radius:999px;
  border:1px solid var(--line-strong); font-size:.9rem; font-weight:500; color:var(--wine-ink); background:var(--paper); }
.area svg{ width:1.1em; height:1.1em; stroke:var(--gold-deep); }

/* Pestañas */
.ptabs{ display:flex; flex-wrap:wrap; justify-content:center; gap:.35rem; margin:3rem auto 0; padding:.4rem;
  background:var(--cream-2); border:1px solid var(--line); border-radius:999px; width:max-content; max-width:100%;
  box-shadow:var(--shadow-sm); }
.ptab{ padding:.72rem 1.35rem; border-radius:999px; font-size:.95rem; font-weight:600; color:var(--muted); white-space:nowrap;
  transition:color .3s var(--ease), background-color .3s var(--ease), box-shadow .3s var(--ease); }
.ptab:hover{ color:var(--wine); }
.ptab.is-active{ color:#f7f0e4; background:var(--wine); box-shadow:0 6px 16px -6px rgba(52,10,17,.5); }

.ppanel{ display:none; margin-top:2.6rem; }
.ppanel.is-active{ display:block; animation:panelIn .5s var(--ease); }
@keyframes panelIn{ from{ opacity:0; transform:translateY(12px); } to{ opacity:1; transform:none; } }
.ppanel-intro{ text-align:center; color:var(--muted); max-width:60ch; margin:0 auto 2rem; }

/* Planes mensuales */
.plans-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:1.4rem; align-items:stretch; }
.plan{ background:var(--paper); border:1px solid var(--line); border-radius:var(--r-lg);
  padding:2rem clamp(1.5rem,2.2vw,2rem); display:flex; flex-direction:column;
  transition:transform .5s var(--ease), box-shadow .5s var(--ease); }
.plan:hover{ transform:translateY(-5px); box-shadow:var(--shadow); }
.plan--best{ background:linear-gradient(170deg,var(--wine),var(--wine-800)); color:#f3e6d4; border-color:transparent; box-shadow:var(--shadow); }
.plan-tag{ align-self:flex-start; font-size:.66rem; letter-spacing:.18em; text-transform:uppercase; font-weight:700;
  color:var(--wine-ink); background:var(--gold-foil); padding:.4em .8em; border-radius:999px; margin-bottom:1rem; }
.plan-name{ font-family:var(--font-display); font-weight:600; font-size:1.55rem; color:var(--wine-ink); line-height:1.1; }
.plan--best .plan-name{ color:#fdf3e1; }
.plan-cap{ font-size:.86rem; color:var(--muted); margin-top:.25rem; }
.plan--best .plan-cap{ color:#d8c3a6; }
.plan-price{ font-family:var(--font-display); font-weight:500; font-size:2.4rem; color:var(--wine); line-height:1; margin-top:1.1rem; }
.plan--best .plan-price{ color:#fdf3e1; }
.plan-unit{ font-size:.8rem; color:var(--muted); margin-top:.35rem; }
.plan--best .plan-unit{ color:#d6c1a4; }
.plan-div{ border:0; border-top:1px solid var(--line); margin:1.3rem 0; }
.plan--best .plan-div{ border-top-color:rgba(255,255,255,.16); }
.plan-feats{ display:grid; gap:.6rem; }
.plan-feat{ display:flex; gap:.6rem; align-items:flex-start; font-size:.92rem; line-height:1.4; }
.plan-feat svg{ width:1.05rem; height:1.05rem; flex:none; stroke:var(--gold-deep); margin-top:.12rem; }
.plan--best .plan-feat svg{ stroke:var(--gold-soft); }
.plan-feat.is-off{ color:var(--muted); }
.plan-feat.is-off svg{ stroke:currentColor; opacity:.6; }
.plan--best .plan-feat.is-off{ color:#c9b49a; }
.plan-btn{ margin-top:auto; }
.plan-btn:not(.btn--gold){ margin-top:1.6rem; }
.plan .plan-feats + .plan-btn{ margin-top:1.7rem; }

/* Caja de nota informativa */
.price-note-box{ display:flex; gap:.85rem; align-items:flex-start; background:var(--cream-2);
  border:1px solid var(--line); border-radius:var(--r); padding:1rem 1.3rem; margin-top:1.8rem; font-size:.92rem; color:var(--muted); }
.price-note-box svg{ width:1.25rem; height:1.25rem; flex:none; stroke:var(--gold-deep); margin-top:.05rem; }

/* Categorías y tarjetas a la carta */
.cat-label{ font-size:.72rem; letter-spacing:.16em; text-transform:uppercase; color:var(--gold-deep); font-weight:700;
  margin:2.2rem 0 1.1rem; padding-bottom:.6rem; border-bottom:1px solid var(--line); }
.cat-label:first-of-type{ margin-top:0; }
.cat-strong{ text-align:center; font-family:var(--font-display); font-size:1.3rem; color:var(--wine); margin-bottom:.6rem; }
.acard-grid{ display:grid; grid-template-columns:repeat(auto-fill,minmax(225px,1fr)); gap:1rem; }
.acard{ background:var(--paper); border:1px solid var(--line); border-radius:var(--r); padding:1.2rem 1.3rem;
  display:flex; flex-direction:column; transition:transform .4s var(--ease), box-shadow .4s var(--ease), border-color .4s var(--ease); }
.acard:hover{ transform:translateY(-3px); box-shadow:var(--shadow-sm); border-color:var(--line-strong); }
.acard h4{ font-family:var(--font-display); font-weight:600; font-size:1.08rem; color:var(--wine-ink); line-height:1.2; }
.acard p{ font-size:.86rem; color:var(--muted); margin-top:.45rem; flex:1; line-height:1.5; }
.acard-price{ margin-top:1rem; display:flex; align-items:baseline; gap:.4rem; flex-wrap:wrap; }
.acard-price b{ font-family:var(--font-display); font-weight:500; font-size:1.3rem; color:var(--wine); }
.acard-price span{ font-size:.76rem; color:rgba(111,91,94,.8); }

/* Tabla comparativa */
.ctable-wrap{ overflow-x:auto; -webkit-overflow-scrolling:touch; border:1px solid var(--line); border-radius:var(--r); }
.ctable{ width:100%; border-collapse:collapse; font-size:.9rem; min-width:580px; }
.ctable th{ text-align:left; padding:.95rem 1rem; font-weight:600; color:var(--wine-ink); border-bottom:1px solid var(--line); background:var(--cream-2); }
.ctable th.col{ text-align:center; width:18%; }
.ctable th.col small{ display:block; font-weight:400; color:var(--muted); font-size:.76rem; margin-top:2px; }
.ctable th.col-best{ color:var(--wine); }
.ctable td{ padding:.7rem 1rem; border-bottom:1px solid var(--line); color:var(--ink); vertical-align:middle; }
.ctable td.c{ text-align:center; }
.ctable tr:last-child td{ border-bottom:none; }
.ctable tr.grp td{ background:var(--cream-2); font-size:.7rem; letter-spacing:.12em; text-transform:uppercase;
  color:var(--gold-deep); font-weight:700; padding:.55rem 1rem; }
.ctable .yes{ color:var(--gold-deep); font-weight:700; }
.ctable .no{ color:rgba(111,91,94,.55); }
.ctable .sm{ font-size:.8rem; color:var(--muted); }

@media (max-width: 860px){ .plans-grid{ grid-template-columns:1fr; } }
@media (max-width: 640px){
  .ptabs{ display:grid; grid-template-columns:1fr 1fr; gap:.3rem; width:auto; border-radius:var(--r-lg); }
  .ptab{ text-align:center; padding:.7rem .4rem; font-size:.85rem; }
  .acard-grid{ grid-template-columns:1fr 1fr; }
  .acard{ padding:1rem; }
  .acard h4{ font-size:1rem; }
}
@media (max-width: 420px){ .acard-grid{ grid-template-columns:1fr; } }
