/* ============================================================
   VELVET PETALS — Floral Art
   Estilo basado en el catálogo: vino · dorado · marfil, serif
   ============================================================ */

/* ---------- Fuentes ---------- */
/* Behind The Nineties (variable, itálica) — TÍTULOS. Declarada normal para que aplique sin pedir italic. */
@font-face{font-family:"Behind The Nineties";src:url("assets/fonts/BehindTheNineties-VariableItalic.ttf") format("truetype-variations");font-weight:100 900;font-style:normal;font-display:swap}

:root{
  --wine:#4a0d1b;
  --wine-deep:#2c0710;
  --wine-soft:#5e1626;
  --wine-panel:#3a0b16;
  --gold:#c9a24b;
  --gold-bright:#ecc878;
  --gold-deep:#9c7a32;
  --ivory:#f1e4d2;
  --ivory-dim:#d8c4ad;
  --rose:#d9a6a0;
  --line:rgba(201,162,75,.32);

  --maxw:1240px;
  --body:"Montserrat", "Helvetica Neue", Arial, sans-serif;
  --display:"Behind The Nineties", Georgia, serif;
  --serif:var(--body);   /* alias: todo el texto en Montserrat */
  --sans:var(--body);
  --script:var(--display); /* flourishes usan la misma fuente de títulos */
  --ease:cubic-bezier(.22,.61,.36,1);
  --content-start:480vh;   /* alto del hero (desktop) = dónde empieza el contenido */
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:var(--serif);
  color:var(--ivory);
  line-height:1.6;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
  background-color:#000;
  /* Textura floral que APARECE gradualmente tras el hero:
     invisible al inicio del contenido (se integra con el negro del hero) -> sutil al bajar.
     El degradado se ancla al final del hero con --content-start. */
  background-image:
    linear-gradient(180deg,
      #000 0,
      #000 var(--content-start,480vh),
      rgba(0,0,0,.72) calc(var(--content-start,480vh) + 1500px)),
    url("assets/brand/texture.jpg");
  background-repeat:no-repeat, repeat;
  background-size:100% 100%, 440px;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
.container{width:100%;max-width:var(--maxw);margin:0 auto;padding:0 28px}
@media(max-width:1024px){ :root{ --content-start:100vh; } }  /* hero estático (móvil/tablet) = 100vh */
.gold{color:var(--gold-bright)}

/* Títulos en Behind The Nineties (peso natural, sin bold) */
.hero-title,.section-title,.card-name,.modal-body h3,.step h3,.step-num,
.sig-name,.brand-name,.marquee-track span,.combo-badge,
.story-stats strong,.em-vp{font-family:var(--display);font-weight:400}

/* ---------- Tipografía utilitaria ---------- */
.eyebrow{
  font-family:var(--sans);
  text-transform:uppercase;letter-spacing:.42em;font-size:.72rem;font-weight:500;
  color:var(--gold);margin-bottom:16px;
}
.script{font-family:var(--script);font-weight:400;text-transform:none;letter-spacing:normal}
.script-accent{font-family:var(--script);font-weight:400;letter-spacing:normal;text-transform:none}
.section-title{
  font-family:var(--serif);font-weight:500;
  font-size:clamp(2.1rem,4.6vw,3.5rem);line-height:1.06;letter-spacing:.01em;
}
.section-lead{max-width:600px;color:var(--ivory-dim);font-size:1.15rem;margin-top:18px}
.section{padding:clamp(70px,10vw,130px) 0;position:relative}
.section-head{margin-bottom:52px;max-width:760px}
.section-head.center{margin-inline:auto;text-align:center}
.section-head.center .section-lead{margin-inline:auto}
.orn{display:block;width:48px;aspect-ratio:600/446;height:auto;margin:0 auto 10px;opacity:.9;
  background:linear-gradient(135deg,#f6dca0 0%,#d9b25f 28%,#f0d089 50%,#b8923f 72%,#e7c477 100%);
  -webkit-mask:url("assets/brand/orn-rose.png") center/contain no-repeat;
  mask:url("assets/brand/orn-rose.png") center/contain no-repeat}

/* ---------- Botones ---------- */
.btn{
  display:inline-flex;align-items:center;gap:.6em;
  font-family:var(--sans);font-weight:500;letter-spacing:.18em;text-transform:uppercase;font-size:.72rem;
  padding:15px 32px;border-radius:50px;cursor:pointer;border:1px solid transparent;
  transition:transform .4s var(--ease), background .4s var(--ease), color .4s var(--ease), box-shadow .4s var(--ease);
}
.btn-lg{padding:18px 42px;font-size:.76rem}
.btn-gold{
  background:linear-gradient(135deg,var(--gold-bright),var(--gold) 55%,var(--gold-deep));
  color:#2a1606;box-shadow:0 10px 30px -12px rgba(201,162,75,.7);
}
.btn-gold:hover{transform:translateY(-3px);box-shadow:0 18px 42px -14px rgba(236,200,120,.85)}
.btn-outline{border-color:var(--line);color:var(--ivory)}
.btn-outline:hover{background:var(--ivory);color:var(--wine);transform:translateY(-3px)}

/* ---------- Emblema VP ---------- */
.em-ring{fill:none;stroke:var(--gold);stroke-width:1.4}
.em-thin{stroke:var(--gold-deep);stroke-width:.7;opacity:.8}
.em-arc{fill:var(--gold-bright);font-family:var(--sans);font-size:13px;letter-spacing:5px;font-weight:500}
.em-rose ellipse, .em-rose circle{fill:none;stroke:var(--gold-bright);stroke-width:1.4}
.em-rose circle{fill:var(--gold-bright)}
.em-vp{fill:var(--gold-bright);font-family:var(--serif);font-weight:600;font-size:44px;letter-spacing:2px;text-anchor:middle}
.em-sub{fill:var(--gold);font-family:var(--sans);font-size:9px;letter-spacing:6px;text-anchor:middle;text-transform:uppercase}

/* ---------- Filigranas de esquina ---------- */
.filigree{position:absolute;width:130px;height:130px;pointer-events:none;opacity:.5;
  background:radial-gradient(circle at 0 0, transparent 64px, var(--gold) 65px, transparent 67px),
            radial-gradient(circle at 0 0, transparent 40px, var(--gold-deep) 41px, transparent 43px);
  -webkit-mask:radial-gradient(circle at 0 0, #000 70%, transparent 71%);mask:radial-gradient(circle at 0 0,#000 70%,transparent 71%)}
.filigree-tl{top:18px;left:18px}
.filigree-tr{top:18px;right:18px;transform:scaleX(-1)}
.filigree-bl{bottom:18px;left:18px;transform:scaleY(-1)}
.filigree-br{bottom:18px;right:18px;transform:scale(-1)}

/* ============================================================
   HEADER
   ============================================================ */
.site-header{position:fixed;top:0;left:0;right:0;z-index:50;padding:20px 0;
  transition:padding .4s var(--ease), background .4s var(--ease), backdrop-filter .4s var(--ease), box-shadow .4s var(--ease), transform .7s var(--ease), opacity .7s var(--ease)}
.site-header.hide{transform:translateY(-100%);opacity:0}
.site-header.scrolled{padding:10px 0;background:rgba(35,6,12,.82);backdrop-filter:blur(14px);box-shadow:0 1px 0 var(--line)}
.header-inner{display:flex;align-items:center;justify-content:space-between;gap:24px}
.brand{display:flex;align-items:center;gap:13px}
/* Logo dorado: el PNG actúa como máscara sobre un degradado dorado metálico */
.logo-mask{display:inline-block;
  background:linear-gradient(135deg,#f6dca0 0%,#d9b25f 26%,#f0d089 46%,#b8923f 70%,#e7c477 100%);
  -webkit-mask-repeat:no-repeat;mask-repeat:no-repeat;
  -webkit-mask-position:center;mask-position:center;
  -webkit-mask-size:contain;mask-size:contain;
  filter:drop-shadow(0 2px 9px rgba(0,0,0,.55))}
.brand-logo{height:48px;aspect-ratio:820/172;width:auto;max-width:62vw;
  -webkit-mask-image:url("assets/brand/logo.png");mask-image:url("assets/brand/logo.png")}
.brand-emblem{width:46px;height:46px}
.brand-name{font-family:var(--serif);font-size:1.55rem;font-weight:500;letter-spacing:.22em;text-transform:uppercase;color:var(--ivory)}
.nav{display:flex;gap:32px}
.nav a{font-family:var(--sans);font-size:.8rem;letter-spacing:.16em;text-transform:uppercase;color:var(--ivory-dim);position:relative;padding:4px 0;transition:color .3s;text-shadow:0 1px 8px rgba(0,0,0,.55)}
.site-header.scrolled .nav a{text-shadow:none}
.nav a::after{content:"";position:absolute;left:0;bottom:-2px;width:0;height:1px;background:var(--gold);transition:width .35s var(--ease)}
.nav a:hover{color:var(--ivory)}
.nav a:hover::after{width:100%}
.nav-toggle{display:none;background:none;border:none;color:var(--ivory);font-size:1.5rem;cursor:pointer}

/* ============================================================
   HERO
   ============================================================ */
.hero{position:relative;min-height:100vh;display:flex;align-items:center;justify-content:center;text-align:center;
  padding:150px 0 96px;overflow:hidden}
.hero::after{content:"";position:absolute;inset:16px;border:1px solid rgba(201,162,75,.28);pointer-events:none;z-index:3}
.hero-bg{position:absolute;inset:0;z-index:0;overflow:hidden}
.hero-img{width:100%;height:100%;object-fit:cover;opacity:1;transform-origin:center 30%;
  animation:kenburns 24s var(--ease) infinite alternate}
@keyframes kenburns{from{transform:scale(1.06)}to{transform:scale(1.18)}}
.hero-bg::after{content:"";position:absolute;inset:0;background:
  linear-gradient(180deg, rgba(35,6,12,.30) 0%, rgba(35,6,12,.12) 26%, rgba(35,6,12,.55) 66%, rgba(35,6,12,.86) 100%),
  radial-gradient(82% 60% at 50% 64%, rgba(20,3,8,.55), transparent 72%)}
.hero-content{position:relative;z-index:2;max-width:760px;text-shadow:0 2px 24px rgba(20,3,8,.65)}
.hero-emblem{width:clamp(150px,20vw,210px);aspect-ratio:1;height:auto;margin:0 auto 22px;display:block;
  -webkit-mask-image:url("assets/brand/icon.png?v=2");mask-image:url("assets/brand/icon.png?v=2");
  filter:drop-shadow(0 6px 22px rgba(0,0,0,.45))}
.hero-title{font-family:var(--serif);font-weight:500;font-size:clamp(3.4rem,9vw,6.6rem);line-height:1;letter-spacing:.02em;margin:6px 0 22px}
.hero-title .script-accent{font-size:1.15em;display:inline-block;line-height:.8}
.hero-sub{max-width:560px;margin:0 auto 36px;font-size:1.2rem;color:var(--ivory-dim)}
.hero-actions{display:flex;gap:16px;flex-wrap:wrap;justify-content:center}
.hero-scroll{position:absolute;bottom:30px;left:50%;transform:translateX(-50%);z-index:2;
  font-family:var(--sans);font-size:.66rem;letter-spacing:.3em;text-transform:uppercase;color:var(--ivory-dim);
  display:flex;flex-direction:column;align-items:center;gap:10px}
.hero-scroll span{width:1px;height:40px;background:linear-gradient(var(--gold),transparent);animation:scrolldot 2s var(--ease) infinite}
@keyframes scrolldot{0%{transform:scaleY(0);transform-origin:top}50%{transform:scaleY(1);transform-origin:top}50.1%{transform-origin:bottom}100%{transform:scaleY(0);transform-origin:bottom}}

/* ============================================================
   HERO EXPERIENCIA · video scroll-scrub
   ============================================================ */
.vhero{position:relative;height:var(--vhero-scroll,480vh);background:#000}
.vhero-pin{position:sticky;top:0;height:100vh;overflow:hidden;display:flex;align-items:center;justify-content:center}
.vhero-media{position:absolute;inset:0;z-index:0}
.vhero-video{width:100%;height:100%;object-fit:cover;background:#000}
.vhero-scrim{position:absolute;inset:0;z-index:1;background:
  linear-gradient(180deg, rgba(0,0,0,.6) 0%, rgba(0,0,0,.2) 20%, rgba(0,0,0,.32) 48%, rgba(0,0,0,.32) 78%, rgba(0,0,0,.5) 100%),
  radial-gradient(78% 70% at 50% 50%, rgba(0,0,0,.18), rgba(0,0,0,.6))}
.hero-frame{position:absolute;inset:16px;z-index:2;border:1px solid rgba(201,162,75,.28);pointer-events:none}
/* Fundido inferior: el video se disuelve hacia #160D0F antes de terminar la sección (unión sin línea) */
.vhero-fade{position:absolute;left:0;right:0;bottom:0;height:28vh;z-index:2;pointer-events:none;
  background:linear-gradient(180deg,
    rgba(0,0,0,0) 0%,
    rgba(0,0,0,.1) 45%,
    rgba(0,0,0,.5) 80%,
    #000 97%)}
.vhero-stage{position:relative;z-index:3;width:100%;height:100%}
.beat{position:absolute;left:50%;top:50%;width:min(960px,92vw);
  transform:translate(-50%,-50%);opacity:0;will-change:opacity,transform;
  text-align:center;text-shadow:0 2px 28px rgba(20,3,8,.72);pointer-events:none}
.beat.show{pointer-events:auto}
.beat-emblem{width:clamp(118px,15vw,176px);aspect-ratio:1;display:block;margin:0 auto 20px;
  -webkit-mask-image:url("assets/brand/icon.png?v=2");mask-image:url("assets/brand/icon.png?v=2");
  filter:drop-shadow(0 6px 22px rgba(0,0,0,.5))}
.beat-emblem-final{width:clamp(118px,13vw,158px);margin-bottom:18px;
  filter:drop-shadow(0 4px 18px rgba(0,0,0,.55)) drop-shadow(0 0 22px rgba(236,200,120,.35))}
.beat-eyebrow{font-family:var(--sans);text-transform:uppercase;letter-spacing:.42em;color:var(--gold-bright);font-size:.95rem}
.beat-title{font-family:var(--display);font-weight:400;font-size:clamp(2.6rem,7vw,5.4rem);line-height:1.03;color:var(--ivory);letter-spacing:.01em}
.beat-words{display:flex;flex-wrap:wrap;gap:14px 18px;justify-content:center}
.beat-words span{font-family:var(--display);font-weight:400;font-size:clamp(1.3rem,3.2vw,2.4rem);color:var(--ivory);
  padding:9px 24px;border:1px solid var(--line);border-radius:50px;background:rgba(35,6,12,.32);backdrop-filter:blur(2px)}
.beat-h1{font-family:var(--display);font-weight:400;font-size:clamp(3rem,9vw,6.8rem);line-height:1;color:var(--ivory)}
.beat-sub{font-family:var(--serif);font-size:1.25rem;color:var(--ivory-dim);margin:16px 0 30px}
.beat-actions{display:flex;gap:16px;justify-content:center;flex-wrap:wrap}
/* invitación a scrollear (desaparece al empezar a bajar) */
.vhero-invite{position:absolute;left:50%;top:66%;transform:translateX(-50%);z-index:4;
  display:flex;flex-direction:column;align-items:center;gap:16px;pointer-events:none;will-change:opacity,transform}
.invite-text{font-family:var(--sans);text-transform:uppercase;letter-spacing:.34em;font-size:.82rem;color:var(--gold-bright);
  text-shadow:0 2px 16px rgba(0,0,0,.6);animation:invitePulse 2.6s var(--ease) infinite}
.invite-arrow{width:20px;height:20px;border-right:2px solid var(--gold-bright);border-bottom:2px solid var(--gold-bright);
  transform:rotate(45deg);animation:inviteBounce 1.7s var(--ease) infinite;filter:drop-shadow(0 2px 8px rgba(0,0,0,.55))}
@keyframes invitePulse{0%,100%{opacity:.7;letter-spacing:.34em}50%{opacity:1;letter-spacing:.4em}}
@keyframes inviteBounce{0%,100%{transform:rotate(45deg) translate(-3px,-3px);opacity:.6}50%{transform:rotate(45deg) translate(4px,4px);opacity:1}}
@media(max-width:768px){
  .vhero{--vhero-scroll:340vh}
  .beat-actions{flex-direction:column;align-items:center}
  .beat-actions .btn{width:min(320px,90vw);justify-content:center}
}

/* ============================================================
   MARQUEE
   ============================================================ */
.marquee{background:var(--wine);border-top:1px solid var(--line);border-bottom:1px solid var(--line);padding:16px 0;overflow:hidden}
.marquee-track{display:flex;align-items:center;gap:34px;white-space:nowrap;width:max-content;animation:marquee 34s linear infinite}
.marquee-track span{font-family:var(--serif);font-size:1.5rem;letter-spacing:.05em;color:var(--ivory)}
.marquee-track i{color:var(--gold-bright);font-style:normal}
@keyframes marquee{to{transform:translateX(-50%)}}

/* ============================================================
   COLECCIÓN
   ============================================================ */
.filters{display:flex;flex-wrap:wrap;gap:12px;margin-bottom:48px;justify-content:center}
.filter{font-family:var(--sans);font-size:.72rem;letter-spacing:.16em;text-transform:uppercase;
  padding:10px 22px;border-radius:50px;border:1px solid var(--line);background:transparent;color:var(--ivory-dim);cursor:pointer;transition:all .35s var(--ease)}
.filter:hover{color:var(--ivory);border-color:var(--gold)}
.filter.is-active{background:linear-gradient(135deg,var(--gold-bright),var(--gold));border-color:var(--gold);color:#2a1606}

.grid{display:grid;grid-template-columns:repeat(3,1fr);gap:32px}
.ver-mas-wrap{display:none}                       /* solo visible en teléfono (ver media 600px) */
.card{position:relative;border:1px solid var(--line);border-radius:16px;overflow:hidden;
  background:linear-gradient(180deg,var(--wine-panel),#2e0812);
  box-shadow:0 1px 0 rgba(236,200,120,.08) inset;
  transition:transform .5s var(--ease), border-color .5s var(--ease), box-shadow .5s var(--ease);
  display:flex;flex-direction:column}
.card:hover{transform:translateY(-8px);border-color:var(--gold);box-shadow:0 30px 60px -28px rgba(0,0,0,.85)}
.card-media{position:relative;aspect-ratio:4/5;height:auto;flex:none;overflow:hidden;margin:14px 14px 0;border-radius:14px}
/* el contenedor de la foto SIEMPRE respeta el aspect-ratio (no se estira con .ph height:100%) */
.card-media.ph{height:auto;flex:none}
.card-media img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;transition:transform .8s var(--ease)}
.card:hover .card-media img{transform:scale(1.06)}
.card-media::after{content:"";position:absolute;inset:0;border-radius:14px;box-shadow:inset 0 -60px 70px -30px rgba(28,5,12,.85);pointer-events:none}
.card-tab{position:absolute;top:0;left:18px;z-index:3;
  font-family:var(--sans);font-size:.6rem;letter-spacing:.18em;text-transform:uppercase;
  padding:6px 16px;border-radius:0 0 10px 10px;background:linear-gradient(135deg,var(--gold-bright),var(--gold));color:#2a1606;font-weight:500}
.card-body{padding:20px 24px 8px;text-align:center;display:flex;flex-direction:column;flex:1}
.card-cat{font-family:var(--sans);font-size:.62rem;letter-spacing:.24em;text-transform:uppercase;color:var(--rose);margin-bottom:8px}
.card-name{font-family:var(--serif);font-size:1.7rem;font-weight:600;line-height:1.08;letter-spacing:.04em;text-transform:capitalize;margin-bottom:12px}
.card-desc{font-size:1rem;color:var(--ivory-dim);margin-bottom:16px;flex:1;
  display:-webkit-box;-webkit-line-clamp:4;-webkit-box-orient:vertical;overflow:hidden}
.card-price{font-family:var(--serif);font-size:1.45rem;color:var(--gold-bright);letter-spacing:.02em;margin-bottom:18px}
.card-actions{display:flex;gap:10px;padding:0 22px 22px}
.btn-card-detail{flex:1;font-family:var(--sans);background:transparent;border:1px solid var(--line);color:var(--ivory);
  font-size:.66rem;padding:13px 14px;border-radius:50px;letter-spacing:.14em;text-transform:uppercase;cursor:pointer;transition:all .35s var(--ease)}
.btn-card-detail:hover{border-color:var(--gold);color:var(--gold-bright)}
.btn-card-wa{flex:1;font-family:var(--sans);background:linear-gradient(135deg,var(--gold-bright),var(--gold));color:#2a1606;
  font-size:.66rem;padding:13px 14px;border-radius:50px;letter-spacing:.12em;text-transform:uppercase;font-weight:500;
  display:inline-flex;align-items:center;justify-content:center;gap:.5em;transition:all .35s var(--ease)}
.btn-card-wa:hover{transform:translateY(-2px);box-shadow:0 10px 24px -10px rgba(236,200,120,.8)}

/* placeholder visual */
.ph{position:relative;width:100%;height:100%;overflow:hidden;display:grid;place-items:center;
  background:radial-gradient(120% 120% at 30% 20%, rgba(120,28,46,.85), transparent 60%),
            radial-gradient(100% 100% at 80% 90%, rgba(74,13,27,.95), transparent 55%),
            linear-gradient(160deg,#3a0b16,#250410)}
.ph::before{content:"";position:absolute;width:46%;height:46%;
  background:radial-gradient(circle, rgba(236,200,120,.18), transparent 70%)}
.ph::after{content:attr(data-ph);position:absolute;bottom:16px;left:0;right:0;text-align:center;
  font-family:var(--script);font-size:1.5rem;color:rgba(236,200,120,.6);padding:0 10px}
.ph img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:2}

/* ============================================================
   COMBOS
   ============================================================ */
.combos-inner{display:grid;grid-template-columns:1.05fr .95fr;gap:64px;align-items:center}
.combo-list{list-style:none;margin:26px 0 32px;display:grid;gap:13px}
.combo-list li{display:flex;align-items:center;gap:14px;font-size:1.12rem;color:var(--ivory);padding-bottom:13px;border-bottom:1px solid var(--line)}
.combo-list li span{color:var(--gold-bright)}
.combo-list li.feat{color:var(--gold-bright);font-weight:600}
.combo-list li.feat span{font-size:1.3em;filter:drop-shadow(0 0 8px rgba(236,200,120,.45))}
.combo-list li.feat em{color:var(--gold);font-style:italic}
.combo-list li em{color:var(--rose);font-style:italic}
.combos-card{position:relative}
.combo-figure{position:relative;aspect-ratio:4/5;border-radius:18px;border:1px solid var(--line);overflow:hidden}
.combo-swap .swap-b{opacity:0;animation:comboSwap 9s ease-in-out infinite}
@keyframes comboSwap{0%,8%{opacity:0}42%,58%{opacity:1}92%,100%{opacity:0}}
@media(prefers-reduced-motion:reduce){.combo-swap .swap-b{animation:none}}
.combo-caption{position:absolute;left:0;right:0;bottom:0;z-index:3;padding:54px 24px 24px;text-align:left;
  background:linear-gradient(to top,rgba(8,3,6,.94) 14%,rgba(8,3,6,.6) 52%,transparent)}
.combo-name{font-family:var(--display);font-weight:400;font-size:1.85rem;line-height:1.05;color:var(--ivory);margin:0 0 8px}
.combo-desc{font-family:var(--sans);font-size:.86rem;line-height:1.45;color:var(--ivory-dim);margin:0 0 12px;max-width:36ch}
.combo-price{font-family:var(--display);font-weight:400;font-size:1.25rem;color:var(--gold-bright);margin:0}
.combo-badge{position:absolute;top:-14px;right:22px;z-index:4;background:var(--wine);border:1px solid var(--gold);color:var(--gold-bright);
  font-family:var(--sans);font-size:.64rem;letter-spacing:.2em;text-transform:uppercase;padding:9px 18px;border-radius:50px;
  box-shadow:0 8px 20px -8px rgba(0,0,0,.7)}

/* ============================================================
   OCASIONES
   ============================================================ */
.occasions{background:transparent}
.occasion-list{list-style:none;display:flex;flex-wrap:wrap;justify-content:center;gap:14px 16px;max-width:880px;margin:0 auto}
.occasion-list li{font-family:var(--body);font-weight:500;font-size:1rem;letter-spacing:.03em;color:var(--ivory);padding:11px 24px;border:1px solid var(--line);border-radius:50px;
  background:rgba(58,11,22,.5);transition:all .35s var(--ease)}
.occasion-list li:hover{border-color:var(--gold);color:var(--gold-bright);transform:translateY(-3px)}

/* ---- Eventos & Celebraciones ---- */
.events{margin-top:clamp(58px,8vw,96px)}
.events-head{text-align:center;max-width:740px;margin:0 auto 38px}
.events-title{font-family:var(--display);font-weight:400;font-size:clamp(2rem,4.4vw,3.2rem);line-height:1.04;color:var(--ivory)}
.events-sub{color:var(--ivory-dim);font-size:1.1rem;margin-top:14px}
/* carrusel automático infinito */
.events-carousel{position:relative;overflow:hidden;
  -webkit-mask-image:linear-gradient(90deg,transparent,#000 6%,#000 94%,transparent);
  mask-image:linear-gradient(90deg,transparent,#000 6%,#000 94%,transparent)}
.events-track{display:flex;width:max-content;animation:evscroll 42s linear infinite}
.events-carousel:hover .events-track{animation-play-state:paused}
@keyframes evscroll{to{transform:translateX(-50%)}}
.ev-card{position:relative;flex:0 0 auto;width:300px;height:400px;margin:0 18px 0 0;border-radius:18px;overflow:hidden;
  border:1px solid var(--line);background:linear-gradient(160deg,#3a0b16,#1c060d)}
.ev-card img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:2;transition:transform .9s var(--ease)}
.ev-card:hover img{transform:scale(1.08)}
.ev-card::after{content:"";position:absolute;inset:0;z-index:3;pointer-events:none;
  background:linear-gradient(180deg,transparent 45%,rgba(10,1,4,.82))}
.ev-card figcaption{position:absolute;left:18px;bottom:16px;z-index:4;font-family:var(--display);color:var(--ivory);
  font-size:1.4rem;letter-spacing:.02em;text-shadow:0 2px 12px rgba(0,0,0,.7)}
.events-cta{text-align:center;margin-top:44px}
.events-cta-text{font-family:var(--display);font-size:clamp(1.4rem,2.6vw,1.9rem);color:var(--gold-bright);margin-bottom:18px}
@media(prefers-reduced-motion:reduce){.events-track{animation:none}}
@media(max-width:768px){ .ev-card{width:228px;height:320px;margin-right:14px} }

/* ============================================================
   HISTORIA
   ============================================================ */
.story-inner{display:grid;grid-template-columns:.95fr 1.05fr;gap:64px;align-items:center}
.story-ph{aspect-ratio:4/5;border-radius:18px;border:1px solid var(--line);overflow:hidden}
.story-tagline{font-family:var(--display);font-size:clamp(1.4rem,2.6vw,2rem);color:var(--gold-bright);margin-top:8px;line-height:1.1}
.story-text p{color:var(--ivory-dim);margin-top:18px;font-size:1.12rem}
.story-text strong{color:var(--ivory);font-weight:600}
.story-text em{color:var(--rose);font-style:italic}
.story-stats{display:flex;gap:34px;margin-top:36px;flex-wrap:wrap}
.story-stats div{display:flex;flex-direction:column}
.story-stats strong{font-family:var(--serif);font-size:1.9rem;color:var(--gold-bright);font-weight:500}
.story-stats span{font-family:var(--sans);font-size:.72rem;letter-spacing:.16em;text-transform:uppercase;color:var(--ivory-dim);margin-top:4px}

/* ============================================================
   CÓMO PEDIR
   ============================================================ */
.steps{display:grid;grid-template-columns:repeat(4,1fr);gap:24px}
.step{padding:32px 26px;border:1px solid var(--line);border-radius:14px;background:linear-gradient(180deg,var(--wine-panel),#2c0812);transition:all .4s var(--ease);text-align:center}
.step:hover{border-color:var(--gold);transform:translateY(-6px)}
.step-num{font-family:var(--serif);font-size:2.6rem;color:var(--gold);display:block;margin-bottom:12px}
.step h3{font-family:var(--serif);font-size:1.5rem;font-weight:500;margin-bottom:10px}
.step p{font-size:1rem;color:var(--ivory-dim)}
.how-cta{text-align:center;margin-top:54px}

/* ============================================================
   FOOTER
   ============================================================ */
.site-footer{background:linear-gradient(180deg,#2a0610,#1c040a);border-top:1px solid var(--line);padding:78px 0 0;position:relative}
.footer-inner{display:grid;grid-template-columns:1.3fr 1fr 1.5fr 1.1fr;gap:40px;padding-bottom:54px;position:relative;z-index:2}
.footer-emblem{width:96px;aspect-ratio:1;height:auto;
  -webkit-mask-image:url("assets/brand/icon.png?v=2");mask-image:url("assets/brand/icon.png?v=2")}
.footer-tagline{font-size:1.8rem;color:var(--gold-bright);margin-top:14px;line-height:1}
.footer-col h4{font-family:var(--sans);font-size:.74rem;letter-spacing:.2em;text-transform:uppercase;color:var(--gold);margin-bottom:18px}
.footer-col a{display:block;color:var(--ivory-dim);font-size:1.05rem;margin-bottom:12px;transition:color .3s}
.footer-col a:hover{color:var(--gold-bright)}
.footer-contact a{letter-spacing:.01em;display:flex;align-items:center;gap:11px}
.footer-ico{width:18px;height:18px;color:var(--gold-bright);flex:none}
.footer-contact a:hover .footer-ico{color:var(--gold)}
.footer-signature{text-align:right}
.sig-name{font-family:var(--serif);font-size:1.9rem;color:var(--ivory);letter-spacing:.04em}
.sig-role{font-family:var(--script);font-size:1.5rem;color:var(--gold-bright);margin-bottom:18px}
.footer-bottom{border-top:1px solid var(--line);padding:22px 28px;display:flex;justify-content:space-between;gap:16px;flex-wrap:wrap;
  font-family:var(--sans);font-size:.76rem;color:var(--ivory-dim);max-width:var(--maxw);margin:0 auto}

/* ============================================================
   WHATSAPP FLOTANTE
   ============================================================ */
.wa-float{position:fixed;right:24px;bottom:24px;z-index:60;width:60px;height:60px;border-radius:50%;
  background:#25d366;color:#fff;display:grid;place-items:center;box-shadow:0 14px 30px -8px rgba(37,211,102,.6);transition:transform .35s var(--ease)}
.wa-float:hover{transform:scale(1.08) translateY(-2px)}
.wa-float::after{content:"";position:absolute;inset:0;border-radius:50%;border:2px solid #25d366;animation:pulse 2.4s var(--ease) infinite}
@keyframes pulse{0%{transform:scale(1);opacity:.7}100%{transform:scale(1.7);opacity:0}}

/* ============================================================
   MODAL
   ============================================================ */
.modal{position:fixed;inset:0;z-index:80;display:none;align-items:center;justify-content:center;padding:24px}
.modal.open{display:flex}
.modal-overlay{position:absolute;inset:0;background:rgba(20,3,8,.82);backdrop-filter:blur(6px)}
.modal-card{position:relative;z-index:2;width:min(900px,100%);max-height:90vh;overflow:auto;display:grid;grid-template-columns:1fr 1fr;
  background:linear-gradient(180deg,var(--wine-panel),#280610);border:1px solid var(--gold);border-radius:18px;animation:modalin .5s var(--ease)}
@keyframes modalin{from{opacity:0;transform:translateY(20px) scale(.98)}to{opacity:1;transform:none}}
.modal-media{position:relative}
.modal-ph{height:100%;min-height:360px}
.modal-tab{position:absolute;top:0;left:18px;z-index:3;font-family:var(--sans);font-size:.6rem;letter-spacing:.18em;text-transform:uppercase;
  padding:6px 16px;border-radius:0 0 10px 10px;background:linear-gradient(135deg,var(--gold-bright),var(--gold));color:#2a1606}
.modal-close{position:absolute;top:14px;right:16px;z-index:5;background:rgba(20,3,8,.6);border:1px solid var(--line);color:var(--ivory);
  width:38px;height:38px;border-radius:50%;font-size:1.4rem;cursor:pointer;line-height:1}
.modal-close:hover{background:var(--wine)}
.modal-body{padding:40px 38px}
.modal-body h3{font-family:var(--serif);font-size:2.3rem;font-weight:600;line-height:1.05;letter-spacing:.03em;text-transform:capitalize;margin:6px 0 8px}
.modal-price{font-family:var(--serif);font-size:1.7rem;color:var(--gold-bright);margin-bottom:16px}
.modal-body p{color:var(--ivory-dim);font-size:1.08rem}
.modal-cols{display:grid;grid-template-columns:1fr 1fr;gap:24px;margin:24px 0 30px}
.modal-cols h4{font-family:var(--sans);font-size:.72rem;letter-spacing:.2em;text-transform:uppercase;color:var(--gold);margin-bottom:12px}
.modal-cols ul{list-style:none;display:grid;gap:8px}
.modal-cols li{font-size:1rem;color:var(--ivory);padding-left:18px;position:relative}
.modal-cols li::before{content:"✦";position:absolute;left:0;color:var(--gold);font-size:.7rem;top:4px}
.modal-wa{width:100%;justify-content:center}

/* ============================================================
   REVEAL
   ============================================================ */
.reveal{opacity:0;transform:translateY(28px);transition:opacity .9s var(--ease), transform .9s var(--ease)}
.reveal.in{opacity:1;transform:none}

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media(max-width:1024px){
  .grid{grid-template-columns:repeat(2,1fr)}
  .steps{grid-template-columns:repeat(2,1fr)}
  .combos-inner,.story-inner{grid-template-columns:1fr;gap:40px}
  .footer-inner{grid-template-columns:1fr 1fr}
  .footer-signature{text-align:left}
  .nav,.header-cta{display:none}
  .nav-toggle{display:block}
  .site-header.menu-open .nav{display:flex;position:absolute;top:100%;left:0;right:0;flex-direction:column;gap:0;
    background:rgba(28,4,10,.97);backdrop-filter:blur(14px);padding:10px 28px 24px;border-top:1px solid var(--line)}
  .site-header.menu-open .nav a{padding:16px 0;border-bottom:1px solid var(--line)}
}
@media(max-width:600px){
  .container{padding:0 20px}
  .grid{grid-template-columns:1fr}
  .grid:not(.show-all) .card.is-extra{display:none}   /* en teléfono solo 4 + "Ver más" */
  .ver-mas-wrap{display:flex;justify-content:center;margin-top:32px}
  .ver-mas-btn{min-width:240px}
  .steps{grid-template-columns:1fr}
  .footer-inner{grid-template-columns:1fr}
  .modal-card{grid-template-columns:1fr}
  .modal-ph{min-height:260px}
  .hero-actions{flex-direction:column;align-items:stretch}
  .footer-bottom{flex-direction:column;text-align:center}
  .brand-name{font-size:1.2rem}
}

/* === Tipografía de TÍTULOS (Behind The Nineties) — override final sobre las reglas base === */
.hero-title,.section-title,.card-name,.modal-body h3,.step h3,.step-num,
.sig-name,.brand-name,.marquee-track span,.combo-badge,
.story-stats strong,.beat-title,.beat-h1,.beat-words span{font-family:var(--display);font-weight:400}

/* === Móvil / tablet: hero estático (pantalla final, sin video) === */
.vhero-static{height:100vh;min-height:560px}
.vhero-static .vhero-pin{position:relative;height:100vh;min-height:560px}
.vhero-static .vhero-video{display:none}
.vhero-static .vhero-media{background:#000 url("assets/brand/hero-mobile.jpg") center/cover no-repeat}
.vhero-static .vhero-fade{height:34vh}
.vhero-static .vhero-invite{display:none}
.vhero-static .beat:not(.beat-final){display:none}
.vhero-static .beat-final{opacity:1;pointer-events:auto}
