/* ============================================================
   VERAFIX® · Confort en cada etapa
   Sistema de diseño — vinotinto / blanco / champagne / oro
   ============================================================ */
:root{
  --wine:#6D0F2D;
  --wine-deep:#3F081A;
  --wine-ink:#23050F;
  --white:#FFFFFF;
  --champagne:#E9DCC9;
  --champagne-soft:#F7F1E6;
  --gold:#C7A16A;
  --gold-light:#DCC196;
  --gold-deep:#A87E45;
  --text:#381722;
  --text-soft:#6B4350;
  --serif:'Fraunces',Georgia,"Times New Roman",serif;
  --sans:'Jost',-apple-system,"Segoe UI","Helvetica Neue",Arial,sans-serif;
  --ar-mark:4.0154;
  --ar-full:3.0526;
  --logo-mark:url("../img/logo-mark.png");
  --logo-full:url("../img/logo-full.png");
  --ease:cubic-bezier(.16,1,.3,1);
  --shadow-soft:0 24px 70px -28px rgba(109,15,45,.18);
  --grain:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.85' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='.5'/%3E%3C/svg%3E");
  --photo:url("../img/modelo-hero.jpg");
}

*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth;scroll-padding-top:96px}
body{
  font-family:var(--sans);
  font-weight:400;
  color:var(--text);
  background:var(--white);
  line-height:1.7;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
img,svg{display:block}
a{color:inherit;text-decoration:none}
button{font:inherit;color:inherit;background:none;border:0;cursor:pointer}
::selection{background:var(--wine);color:var(--champagne)}

/* ---------- utilidades tipográficas ---------- */
.eyebrow{
  font:500 .78rem/1 var(--sans);
  letter-spacing:.28em;
  text-transform:uppercase;
  color:var(--gold-deep);
  display:inline-flex;align-items:center;gap:.9rem;
}
.eyebrow::before{content:"";width:34px;height:1px;background:linear-gradient(90deg,transparent,var(--gold))}
.eyebrow.on-dark{color:var(--gold-light)}
h1,h2,h3{font-family:var(--serif);font-weight:500;color:var(--wine-ink);line-height:1.06}
h1 em,h2 em,h3 em{font-style:italic;font-weight:400;color:var(--wine)}
.on-dark h1,.on-dark h2,.on-dark h3,h2.on-dark{color:var(--white)}
.on-dark h2 em{color:var(--gold-light)}
.lead{font-size:clamp(1.08rem,1.45vw,1.22rem);font-weight:400;color:var(--text-soft);max-width:56ch}

.container{width:min(1240px,92vw);margin-inline:auto}
section{position:relative}
.section-pad{padding:clamp(5.5rem,11vw,9.5rem) 0}

/* ---------- reveal on scroll ---------- */
.reveal{opacity:0;transform:translateY(34px);transition:opacity 1s var(--ease),transform 1.1s var(--ease);transition-delay:var(--d,0s)}
.reveal.in{opacity:1;transform:none}

/* ---------- botones ---------- */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:.8rem;
  padding:1.1rem 2.4rem;
  font:500 .8rem/1 var(--sans);letter-spacing:.2em;text-transform:uppercase;
  border:1px solid transparent;border-radius:1px;
  transition:transform .5s var(--ease),box-shadow .5s var(--ease),background-color .5s var(--ease),color .5s var(--ease),border-color .5s var(--ease);
  will-change:transform;white-space:nowrap;
}
.btn .dia{font-size:.85em;transform:translateY(-1px);transition:transform .5s var(--ease)}
.btn:hover .dia{transform:translateX(4px) translateY(-1px)}
.btn-gold{
  background:linear-gradient(130deg,var(--gold-light),var(--gold) 52%,var(--gold-deep));
  color:var(--wine-ink);
  box-shadow:0 18px 40px -14px rgba(199,161,106,.55);
}
.btn-gold:hover{transform:translateY(-3px);box-shadow:0 26px 54px -16px rgba(199,161,106,.7)}
.btn-ghost{color:var(--white);border-color:rgba(233,220,201,.45)}
.btn-ghost:hover{background:rgba(233,220,201,.1);border-color:var(--champagne);transform:translateY(-3px)}
.btn-line{color:var(--wine);border-color:rgba(109,15,45,.32)}
.btn-line:hover{background:var(--wine);color:var(--champagne);transform:translateY(-3px)}

/* ---------- barra anuncio ---------- */
.announce{
  background:linear-gradient(90deg,var(--champagne-soft),var(--champagne),var(--champagne-soft));
  color:var(--wine);
  font:500 .74rem/1.5 var(--sans);letter-spacing:.18em;text-transform:uppercase;
  text-align:center;padding:.7rem 1rem;position:relative;z-index:60;
}
.announce b{color:var(--gold-deep);font-weight:500}

/* ---------- navegación ---------- */
.nav{
  position:fixed;top:0;left:0;right:0;z-index:50;
  transition:background-color .5s var(--ease),box-shadow .5s var(--ease),backdrop-filter .5s,transform .5s var(--ease);
  padding-top:34px;
}
.nav-inner{
  width:min(1320px,94vw);margin-inline:auto;
  display:flex;align-items:center;justify-content:space-between;
  padding:1.15rem 0;
}
.brand{display:flex;align-items:center;z-index:2}
.logo{
  display:block;background:currentColor;
  -webkit-mask:var(--logo-mark) no-repeat center/contain;
  mask:var(--logo-mark) no-repeat center/contain;
  transition:color .4s;
}
.logo-full{
  -webkit-mask-image:var(--logo-full);
  mask-image:var(--logo-full);
}
.nav .logo{width:152px;aspect-ratio:var(--ar-mark);color:var(--white)}
.nav-links{display:flex;gap:2.6rem;list-style:none}
.nav-links a{
  font:500 .82rem/1 var(--sans);letter-spacing:.14em;text-transform:uppercase;
  color:rgba(255,255,255,.85);position:relative;padding:.4rem 0;transition:color .4s;
}
.nav-links a::after{content:"";position:absolute;left:0;bottom:0;width:100%;height:1px;background:var(--gold);transform:scaleX(0);transform-origin:right;transition:transform .5s var(--ease)}
.nav-links a:hover::after{transform:scaleX(1);transform-origin:left}
.nav-cta{display:flex;align-items:center;gap:1.4rem}
.bag{position:relative;color:var(--white);transition:color .4s;display:grid;place-items:center}
.bag svg{width:21px;height:21px}
.bag .count{
  position:absolute;top:-7px;right:-9px;width:16px;height:16px;border-radius:50%;
  background:var(--gold);color:var(--wine-ink);font:600 .56rem/16px var(--sans);text-align:center;
}
.nav .btn{padding:.85rem 1.7rem}
.nav.scrolled{
  background:rgba(255,255,255,.82);
  backdrop-filter:blur(20px) saturate(1.4);
  -webkit-backdrop-filter:blur(20px) saturate(1.4);
  box-shadow:0 10px 40px -18px rgba(63,8,26,.25);
  padding-top:0;
}
.nav.scrolled .logo{color:var(--wine-ink)}
.nav.scrolled .nav-links a{color:var(--text)}
.nav.scrolled .bag{color:var(--wine)}
.nav.hidden{transform:translateY(-110%)}
.burger{display:none;z-index:2;color:#fff;width:40px;height:40px;place-items:center}
.nav.scrolled .burger{color:var(--wine)}
.burger svg{width:24px;height:24px}

/* menú móvil */
.m-menu{
  position:fixed;inset:0;z-index:80;background:linear-gradient(165deg,var(--wine-deep),var(--wine-ink));
  display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2.2rem;
  opacity:0;pointer-events:none;transition:opacity .5s var(--ease);
}
.m-menu.open{opacity:1;pointer-events:auto}
.m-menu a{font:400 clamp(1.7rem,7vw,2.4rem)/1 var(--serif);color:var(--champagne);letter-spacing:.06em;font-style:italic;opacity:0;transform:translateY(20px);transition:.6s var(--ease)}
.m-menu.open a{opacity:1;transform:none}
.m-menu a:hover{color:var(--gold-light)}
.m-close{position:absolute;top:1.6rem;right:1.6rem;color:var(--champagne);font-size:1.6rem;width:44px;height:44px}

/* ============================================================
   HERO
   ============================================================ */
.hero{
  position:relative;min-height:100svh;display:flex;align-items:center;
  background:
    radial-gradient(1100px 720px at 80% 30%, rgba(199,161,106,.12), transparent 62%),
    radial-gradient(900px 760px at 8% 92%, rgba(133,42,69,.5), transparent 62%),
    linear-gradient(180deg,#150305 0%,#2C0712 36%,#4A0F22 70%,#6B2038 100%);
  overflow:hidden;color:var(--white);
  padding:9rem 0 4rem;
}
.hero::after{ /* grano sutil */
  content:"";position:absolute;inset:0;background-image:var(--grain);opacity:.05;pointer-events:none;mix-blend-mode:overlay;
}
.hero-blob{
  position:absolute;width:56vw;height:56vw;max-width:760px;max-height:760px;
  left:-16vw;top:-18vw;pointer-events:none;
  background:radial-gradient(closest-side,rgba(233,220,201,.09),transparent 70%);
  border-radius:42% 58% 56% 44%/52% 38% 62% 48%;
  animation:blob 22s ease-in-out infinite alternate;
}
@keyframes blob{
  0%{border-radius:42% 58% 56% 44%/52% 38% 62% 48%;transform:rotate(0deg) scale(1)}
  100%{border-radius:56% 44% 40% 60%/44% 60% 40% 56%;transform:rotate(14deg) scale(1.12)}
}
.thread{position:absolute;inset:0;width:100%;height:100%;pointer-events:none;opacity:.85}
.thread path{
  fill:none;stroke:url(#goldGrad);stroke-width:1.4;vector-effect:non-scaling-stroke;
  filter:drop-shadow(0 0 6px rgba(199,161,106,.45));
}
.spark{position:absolute;color:var(--gold-light);pointer-events:none;animation:twinkle 4.2s ease-in-out infinite}
.spark svg{width:100%;height:100%;filter:drop-shadow(0 0 8px rgba(220,193,150,.8))}
@keyframes twinkle{0%,100%{transform:scale(.55) rotate(0deg);opacity:.35}50%{transform:scale(1.1) rotate(24deg);opacity:1}}

.hero-grid{
  position:relative;z-index:3;
  display:grid;grid-template-columns:1.04fr .96fr;gap:clamp(2rem,5vw,5rem);align-items:center;
}
.hero-copy .eyebrow{color:var(--gold-light);margin-bottom:2rem}
.hero-copy .eyebrow::before{background:linear-gradient(90deg,transparent,var(--gold-light))}
.hero h1{
  font-size:clamp(2.5rem,5.4vw,4.7rem);
  color:var(--white);letter-spacing:-.005em;
  max-width:14ch;
}
.hero h1 em{color:var(--gold-light)}
.hero .sub{
  margin-top:1.8rem;font-size:clamp(1.06rem,1.4vw,1.22rem);font-weight:400;
  color:rgba(238,228,212,.92);max-width:46ch;line-height:1.85;
}
.hero-actions{margin-top:2.8rem;display:flex;gap:1.1rem;flex-wrap:wrap}
.hero-trust{
  margin-top:3rem;display:flex;align-items:center;gap:1.1rem;
  font:500 .82rem/1.55 var(--sans);letter-spacing:.08em;text-transform:uppercase;color:rgba(238,228,212,.82);
}
.hero-trust .stars{color:var(--gold-light);letter-spacing:.18em;font-size:.8rem}
.hero-trust .sep{width:1px;height:26px;background:rgba(233,220,201,.25)}

/* secuencia de entrada */
@keyframes rise{from{opacity:0;transform:translateY(30px)}to{opacity:1;transform:none}}
[data-h]{opacity:0;animation:rise 1.2s var(--ease) forwards;animation-delay:var(--d,0s)}

.hero-visual{position:relative;justify-self:end;width:min(100%,500px)}
.photo-frame{
  position:relative;aspect-ratio:10/14.5;overflow:hidden;border-radius:2px;
}
.photo-frame::before{ /* marco couture desplazado */
  content:"";position:absolute;inset:0;border:1px solid rgba(199,161,106,.55);
  transform:translate(16px,-16px);z-index:3;pointer-events:none;border-radius:2px;
}
.photo{
  position:absolute;inset:-6% 0;
  background-image:var(--photo);background-size:cover;background-position:50% 14%;
  will-change:transform;
}
.photo-frame::after{ /* fundido inferior hacia el fondo del hero */
  content:"";position:absolute;inset:0;z-index:2;pointer-events:none;
  background:linear-gradient(180deg,rgba(21,3,6,.22) 0%,transparent 18% 70%,rgba(74,15,34,.32) 100%);
}
.badge-glass{
  position:absolute;left:-12%;bottom:9%;z-index:4;
  display:flex;align-items:center;gap:1rem;
  padding:1rem 1.4rem;border-radius:2px;
  background:rgba(35,5,15,.38);
  border:1px solid rgba(233,220,201,.22);
  backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);
  box-shadow:0 24px 60px -20px rgba(0,0,0,.5);
}
.badge-glass .ic{width:34px;height:34px;color:var(--gold-light);flex:none}
.badge-glass .t1{font:500 .8rem/1.35 var(--sans);letter-spacing:.12em;text-transform:uppercase;color:#F3EADB}
.badge-glass .t2{font:400 .84rem/1.45 var(--sans);letter-spacing:.03em;color:rgba(238,228,212,.82);margin-top:.25rem}
.hero-scroll{
  position:absolute;bottom:2.2rem;left:50%;transform:translateX(-50%);z-index:4;
  display:flex;flex-direction:column;align-items:center;gap:.7rem;
  font:500 .66rem/1 var(--sans);letter-spacing:.32em;text-transform:uppercase;color:rgba(238,228,212,.6);
}
.hero-scroll::after{content:"";width:1px;height:46px;background:linear-gradient(180deg,var(--gold),transparent);animation:drip 2.4s ease-in-out infinite}
@keyframes drip{0%{transform:scaleY(0);transform-origin:top}55%{transform:scaleY(1);transform-origin:top}56%{transform-origin:bottom}100%{transform:scaleY(0);transform-origin:bottom}}

/* ---------- marquee ---------- */
.marquee{background:var(--champagne);overflow:hidden;padding:1.05rem 0;border-block:1px solid rgba(199,161,106,.35)}
.marquee-track{display:flex;width:max-content;animation:scrollX 30s linear infinite}
.marquee span{
  font:500 .8rem/1 var(--sans);letter-spacing:.24em;text-transform:uppercase;color:var(--wine);
  padding:0 1.6rem;display:flex;align-items:center;gap:1.6rem;white-space:nowrap;
}
.marquee i{font-style:normal;color:var(--gold-deep)}
@keyframes scrollX{to{transform:translateX(-50%)}}

/* ============================================================
   BENEFICIOS
   ============================================================ */
.benefits{background:var(--champagne-soft)}
.sec-head{max-width:680px;margin-bottom:clamp(3rem,6vw,4.5rem)}
.sec-head.center{margin-inline:auto;text-align:center}
.sec-head.center .eyebrow{justify-content:center}
.sec-head.center .eyebrow::before{display:none}
.sec-head.center .eyebrow::after{content:"";width:34px;height:1px;background:linear-gradient(90deg,var(--gold),transparent);order:2}
.sec-head h2{font-size:clamp(1.9rem,3.6vw,3.1rem);margin-top:1.4rem}
.sec-head .lead{margin-top:1.2rem}
.sec-head.center .lead{margin-inline:auto}

.b-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.4rem}
.b-card{
  background:var(--white);padding:2.6rem 2.2rem 2.4rem;border:1px solid rgba(199,161,106,.22);
  border-radius:2px;position:relative;overflow:hidden;
  transition:transform .6s var(--ease),box-shadow .6s var(--ease);
}
.b-card::before{
  content:"";position:absolute;top:0;left:0;right:0;height:2px;
  background:linear-gradient(90deg,var(--gold-light),var(--gold-deep));
  transform:scaleX(0);transform-origin:left;transition:transform .7s var(--ease);
}
.b-card:hover{transform:translateY(-8px);box-shadow:var(--shadow-soft)}
.b-card:hover::before{transform:scaleX(1)}
.b-ic{
  width:52px;height:52px;display:grid;place-items:center;color:var(--gold-deep);
  border:1px solid rgba(199,161,106,.4);border-radius:50%;margin-bottom:1.6rem;
  background:radial-gradient(circle at 30% 25%,rgba(233,220,201,.55),transparent 70%);
}
.b-ic svg{width:24px;height:24px}
.b-card h3{font-size:1.24rem;letter-spacing:0;margin-bottom:.7rem}
.b-card p{font-size:1rem;color:var(--text-soft);line-height:1.8}

/* ============================================================
   COLECCIÓN
   ============================================================ */
.collection{background:var(--white)}
.col-head{display:flex;align-items:flex-end;justify-content:space-between;gap:2rem;margin-bottom:clamp(3rem,6vw,4.5rem);flex-wrap:wrap}
.col-head h2{font-size:clamp(2.1rem,4.2vw,3.6rem)}
.col-head .right{max-width:340px}
.col-head .right p{font-size:1.02rem;color:var(--text-soft);margin-bottom:1.2rem}
.link-arrow{
  font:500 .78rem/1 var(--sans);letter-spacing:.18em;text-transform:uppercase;color:var(--wine);
  display:inline-flex;align-items:center;gap:.7rem;border-bottom:1px solid rgba(199,161,106,.6);padding-bottom:.45rem;
  transition:gap .4s var(--ease),color .4s;
}
.link-arrow:hover{gap:1.1rem;color:var(--gold-deep)}

.p-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1.6rem}
.p-card{position:relative}
.p-media{
  position:relative;aspect-ratio:3/4;overflow:hidden;border-radius:2px;background:var(--wine-deep);
  box-shadow:0 18px 50px -24px rgba(63,8,26,.35);
}
.p-img{
  position:absolute;inset:0;background-image:var(--photo);background-repeat:no-repeat;
  transition:transform 1.1s var(--ease);
}
.p-card:hover .p-img{transform:scale(1.06)}
.p-no{
  position:absolute;top:1.1rem;left:1.1rem;z-index:3;
  font:500 .76rem/1 var(--serif);letter-spacing:.2em;color:#F3EADB;
  padding:.55rem .8rem;border:1px solid rgba(233,220,201,.4);border-radius:1px;
  background:rgba(35,5,15,.32);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);
}
.p-tag{
  position:absolute;top:1.1rem;right:1.1rem;z-index:3;
  font:600 .66rem/1 var(--sans);letter-spacing:.14em;text-transform:uppercase;
  color:var(--wine-ink);background:linear-gradient(130deg,var(--gold-light),var(--gold));
  padding:.5rem .7rem;border-radius:1px;
}
.p-add{
  position:absolute;left:0;right:0;bottom:0;z-index:3;
  transform:translateY(105%);transition:transform .55s var(--ease);
  display:flex;align-items:center;justify-content:center;gap:.7rem;
  padding:1.05rem;font:500 .78rem/1 var(--sans);letter-spacing:.16em;text-transform:uppercase;color:#F3EADB;
  background:rgba(35,5,15,.55);backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);
  border-top:1px solid rgba(199,161,106,.35);
}
.p-add:hover{color:var(--gold-light)}
.p-card:hover .p-add,.p-card:focus-within .p-add{transform:translateY(0)}
.p-info{padding:1.4rem .2rem 0}
.p-info h3{font-size:1.28rem;display:flex;align-items:baseline;gap:.6rem}
.p-info h3 small{font:500 .7rem/1 var(--sans);letter-spacing:.16em;text-transform:uppercase;color:var(--gold-deep)}
.p-desc{font-size:.94rem;color:var(--text-soft);letter-spacing:.01em;margin-top:.45rem}
.p-price{margin-top:.7rem;font:500 1.08rem/1 var(--sans);letter-spacing:.05em;color:var(--wine)}
.p-price small{font-size:.7rem;letter-spacing:.14em;color:var(--text-soft);margin-left:.4rem}

/* crops fotográficos por producto */
.crop-full{background-size:cover;background-position:50% 68%}
.crop-waist{background-size:300% auto;background-position:50% 47%}
.crop-lace{background-size:300% auto;background-position:52% 62%}
.crop-bust{background-size:280% auto;background-position:50% 27%}

/* ============================================================
   EXPERIENCIA · TIMELINE
   ============================================================ */
.journey{background:var(--white);overflow:hidden}
.journey::before{
  content:"";position:absolute;inset:0;
  background:radial-gradient(900px 500px at 85% 0%,rgba(233,220,201,.4),transparent 60%);
  pointer-events:none;
}
.tl-wrap{position:relative;margin-top:1rem}
.tl-svg{width:100%;height:120px;display:block}
.tl-svg path{fill:none;stroke:url(#goldGrad2);stroke-width:1.6;filter:drop-shadow(0 0 5px rgba(199,161,106,.4))}
.tl-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1.4rem;margin-top:-64px}
.tl-item{text-align:center;padding:0 .8rem;position:relative}
.tl-node{
  width:13px;height:13px;margin:0 auto 1.6rem;background:linear-gradient(130deg,var(--gold-light),var(--gold-deep));
  transform:rotate(45deg);box-shadow:0 0 0 6px rgba(199,161,106,.16),0 0 18px rgba(199,161,106,.55);
}
.tl-stage{font:600 .76rem/1 var(--sans);letter-spacing:.24em;text-transform:uppercase;color:var(--gold-deep)}
.tl-item h3{font-size:clamp(1.35rem,2.1vw,1.75rem);font-style:italic;font-weight:400;margin:.8rem 0 .8rem}
.tl-item p{font-size:.98rem;color:var(--text-soft);line-height:1.8;max-width:30ch;margin-inline:auto}

/* ============================================================
   TESTIMONIOS (sobre vinotinto)
   ============================================================ */
.testimonials{
  background:
    radial-gradient(1000px 600px at 12% 8%,rgba(199,161,106,.1),transparent 60%),
    linear-gradient(170deg,var(--wine) 0%,var(--wine-deep) 78%,var(--wine-ink) 100%);
  color:var(--white);
}
.testimonials::after{content:"";position:absolute;inset:0;background-image:var(--grain);opacity:.045;mix-blend-mode:overlay;pointer-events:none}
.testimonials .sec-head h2{color:var(--white)}
.testimonials .sec-head h2 em{color:var(--gold-light)}
.testimonials .lead{color:rgba(233,220,201,.7)}
.t-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem;position:relative;z-index:2}
.t-card{
  padding:2.6rem 2.3rem;border-radius:2px;display:flex;flex-direction:column;
  background:rgba(255,255,255,.045);
  border:1px solid rgba(233,220,201,.16);
  backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);
  transition:transform .6s var(--ease),border-color .6s,background-color .6s;
}
.t-card:hover{transform:translateY(-8px);border-color:rgba(199,161,106,.5);background:rgba(255,255,255,.07)}
.t-mark{font:400 4rem/0.6 var(--serif);color:var(--gold);height:2.2rem}
.t-quote{font:italic 400 1.18rem/1.8 var(--serif);color:#F0E6D6;flex:1}
.t-foot{display:flex;align-items:center;gap:1rem;margin-top:2rem;padding-top:1.6rem;border-top:1px solid rgba(233,220,201,.14)}
.t-ava{
  width:48px;height:48px;border-radius:50%;flex:none;display:grid;place-items:center;
  font:500 .9rem/1 var(--serif);letter-spacing:.06em;color:var(--gold-light);
  border:1px solid rgba(199,161,106,.55);
  background:radial-gradient(circle at 30% 25%,rgba(199,161,106,.25),transparent 70%);
}
.t-name{font:500 .88rem/1.35 var(--sans);letter-spacing:.08em;text-transform:uppercase;color:var(--white)}
.t-city{font:400 .84rem/1.45 var(--sans);letter-spacing:.04em;color:rgba(238,228,212,.75)}
.t-stars{margin-left:auto;color:var(--gold-light);font-size:.82rem;letter-spacing:.14em}

/* ============================================================
   STATS · POR QUÉ ELEGIRNOS
   ============================================================ */
.stats{background:var(--white)}
.s-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:0;border-block:1px solid rgba(199,161,106,.3)}
.s-item{padding:3.2rem 2.2rem;border-left:1px solid rgba(199,161,106,.3);position:relative}
.s-item:first-child{border-left:0}
.s-num{font:500 clamp(2.6rem,4.6vw,4rem)/1 var(--serif);color:var(--wine);display:flex;align-items:baseline}
.s-num .suf{font-size:.5em;color:var(--gold-deep);margin-left:.15em}
.s-label{margin-top:1rem;font:500 .82rem/1.55 var(--sans);letter-spacing:.16em;text-transform:uppercase;color:var(--text-soft)}

/* ============================================================
   GALERÍA EDITORIAL
   ============================================================ */
.gallery{background:var(--white)}
.g-grid{
  display:grid;gap:1.2rem;
  grid-template-columns:1.25fr .85fr .9fr;
  grid-template-rows:300px 300px;
  grid-template-areas:
    "big word lace"
    "big sketch full";
}
.g-tile{position:relative;overflow:hidden;border-radius:2px}
.g-photo{position:absolute;inset:0;background-image:var(--photo);background-repeat:no-repeat;transition:transform 1.4s var(--ease)}
.g-tile:hover .g-photo{transform:scale(1.05)}
.g-big{grid-area:big}
.g-big .g-photo{background-size:cover;background-position:50% 22%}
.g-big::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 55%,rgba(35,5,15,.55));pointer-events:none}
.g-big figcaption{
  position:absolute;left:1.6rem;bottom:1.4rem;z-index:2;color:#F3EADB;
  font:italic 400 1.18rem/1.5 var(--serif);
}
.g-big figcaption span{display:block;font:500 .68rem/1 var(--sans);font-style:normal;letter-spacing:.22em;text-transform:uppercase;color:var(--gold-light);margin-top:.55rem}
.g-lace{grid-area:lace}
.g-lace .g-photo{background-size:340% auto;background-position:55% 60%}
.g-full{grid-area:full}
.g-full .g-photo{background-size:200% auto;background-position:50% 30%}
.g-word{
  grid-area:word;background:var(--champagne);display:flex;flex-direction:column;justify-content:center;
  padding:2rem;gap:.2rem;
}
.g-word span{font:italic 400 clamp(1.7rem,2.6vw,2.3rem)/1.25 var(--serif);color:var(--wine)}
.g-word span:nth-child(2){color:var(--gold-deep);transform:translateX(1.4rem)}
.g-word span:nth-child(3){transform:translateX(2.8rem)}
.g-sketch{
  grid-area:sketch;background:linear-gradient(160deg,var(--wine),var(--wine-deep));
  display:grid;place-items:center;
}
.g-sketch svg{width:46%;max-width:150px;color:var(--gold-light);opacity:.9}
.g-caption{
  margin-top:1.6rem;text-align:center;
  font:500 .74rem/1.6 var(--sans);letter-spacing:.24em;text-transform:uppercase;color:var(--text-soft);
}
.g-caption i{font-style:normal;color:var(--gold-deep)}

/* ============================================================
   FAQ
   ============================================================ */
.faq{background:var(--champagne-soft)}
.faq-list{max-width:780px;margin-inline:auto}
.faq-item{border-bottom:1px solid rgba(199,161,106,.35)}
.faq-item:first-child{border-top:1px solid rgba(199,161,106,.35)}
.faq-q{
  width:100%;display:flex;align-items:center;justify-content:space-between;gap:1.5rem;
  padding:1.7rem .4rem;text-align:left;
  font:500 clamp(1.08rem,1.6vw,1.3rem)/1.45 var(--serif);color:var(--wine-ink);
  transition:color .4s;
}
.faq-q:hover{color:var(--wine)}
.faq-ic{
  flex:none;width:30px;height:30px;border:1px solid rgba(199,161,106,.6);border-radius:50%;
  display:grid;place-items:center;color:var(--gold-deep);
  transition:transform .55s var(--ease),background-color .4s,color .4s;
}
.faq-ic svg{width:12px;height:12px}
.faq-item.open .faq-ic{transform:rotate(135deg);background:var(--gold);color:var(--wine-ink);border-color:var(--gold)}
.faq-a{max-height:0;overflow:hidden;transition:max-height .6s var(--ease)}
.faq-a p{padding:0 .4rem 1.8rem;font-size:1.02rem;color:var(--text-soft);line-height:1.85;max-width:64ch}

/* ============================================================
   CTA FINAL
   ============================================================ */
.cta{
  background:
    radial-gradient(820px 480px at 50% 110%,rgba(199,161,106,.22),transparent 65%),
    radial-gradient(700px 400px at 12% -10%,rgba(133,42,69,.6),transparent 60%),
    linear-gradient(180deg,var(--wine-deep),var(--wine-ink));
  color:var(--white);text-align:center;overflow:hidden;
}
.cta::after{content:"";position:absolute;inset:0;background-image:var(--grain);opacity:.05;mix-blend-mode:overlay;pointer-events:none}
.cta-inner{position:relative;z-index:2;max-width:760px;margin-inline:auto}
.cta h2{font-size:clamp(2.2rem,5vw,4rem);color:var(--white);line-height:1.12}
.cta h2 em{color:var(--gold-light)}
.cta p{margin:1.6rem auto 2.6rem;color:rgba(238,228,212,.88);max-width:48ch;font-size:1.12rem}
.cta-micro{
  margin-top:1.8rem;display:flex;justify-content:center;gap:2rem;flex-wrap:wrap;
  font:500 .76rem/1.5 var(--sans);letter-spacing:.14em;text-transform:uppercase;color:rgba(238,228,212,.72);
}
.cta-micro span{display:flex;align-items:center;gap:.55rem}
.cta-micro i{font-style:normal;color:var(--gold)}

/* ============================================================
   FOOTER
   ============================================================ */
.footer{background:var(--wine-ink);color:rgba(238,228,212,.78);padding:5rem 0 2.4rem;position:relative}
.footer::before{content:"";position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,rgba(199,161,106,.6),transparent)}
.f-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:3rem;margin-bottom:3.6rem}
.f-logo{width:215px;aspect-ratio:var(--ar-full);color:var(--champagne)}
.f-brand p{margin-top:1.5rem;font-size:.96rem;line-height:1.85;max-width:32ch}
.f-social{display:flex;gap:.9rem;margin-top:1.8rem}
.f-social a{
  width:40px;height:40px;border:1px solid rgba(199,161,106,.35);border-radius:50%;
  display:grid;place-items:center;color:var(--gold-light);
  transition:background-color .4s,color .4s,transform .4s var(--ease);
}
.f-social a:hover{background:var(--gold);color:var(--wine-ink);transform:translateY(-3px)}
.f-social svg{width:16px;height:16px}
.f-col h4{font:500 .76rem/1 var(--sans);letter-spacing:.22em;text-transform:uppercase;color:#F0E6D6;margin-bottom:1.5rem}
.f-col ul{list-style:none;display:flex;flex-direction:column;gap:.9rem}
.f-col a{font-size:.96rem;transition:color .35s,padding-left .35s var(--ease)}
.f-col a:hover{color:var(--gold-light);padding-left:.4rem}
.f-bottom{
  border-top:1px solid rgba(233,220,201,.12);padding-top:2rem;
  display:flex;align-items:center;justify-content:space-between;gap:1.4rem;flex-wrap:wrap;
  font:400 .8rem/1.7 var(--sans);letter-spacing:.06em;
}
.f-bottom i{font-style:normal;color:var(--gold)}

/* ---------- toast ---------- */
.toast{
  position:fixed;left:50%;bottom:2rem;z-index:90;transform:translate(-50%,140%);
  display:flex;align-items:center;gap:.8rem;
  padding:1rem 1.7rem;border-radius:2px;
  background:rgba(35,5,15,.78);border:1px solid rgba(199,161,106,.5);
  backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);
  color:#F3EADB;font:500 .8rem/1 var(--sans);letter-spacing:.16em;text-transform:uppercase;
  transition:transform .6s var(--ease);box-shadow:0 24px 60px -18px rgba(0,0,0,.55);
}
.toast.show{transform:translate(-50%,0)}
.toast i{font-style:normal;color:var(--gold-light)}

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width:1100px){
  .p-grid{grid-template-columns:repeat(2,1fr)}
  .b-grid{grid-template-columns:repeat(2,1fr)}
  .s-grid{grid-template-columns:repeat(2,1fr)}
  .s-item:nth-child(3){border-left:0}
  .s-item{border-top:1px solid rgba(199,161,106,.3)}
  .s-item:nth-child(-n+2){border-top:0}
  .t-grid{grid-template-columns:1fr 1fr}
  .t-card:last-child{grid-column:1/-1}
  .g-grid{
    grid-template-columns:1fr 1fr;grid-template-rows:340px 220px 220px;
    grid-template-areas:"big big" "word lace" "sketch full";
  }
}
@media (max-width:880px){
  .nav-links,.nav .btn{display:none}
  .burger{display:grid}
  .nav .logo{width:126px}
  .hero{padding-top:7.5rem}
  .hero-grid{grid-template-columns:1fr;gap:3.4rem}
  .hero h1{max-width:none}
  .hero-visual{justify-self:center;width:min(100%,420px)}
  .badge-glass{left:4%;bottom:5%}
  .hero-scroll{display:none}
  .tl-svg{display:none}
  .tl-grid{grid-template-columns:1fr;margin-top:0;gap:0}
  .tl-item{
    text-align:left;padding:2rem 0 2rem 2.4rem;margin:0;
    border-left:1px solid rgba(199,161,106,.45);
  }
  .tl-item p{margin:0;max-width:46ch}
  .tl-node{position:absolute;left:-7px;top:2.5rem;margin:0}
  .col-head{flex-direction:column;align-items:flex-start}
}
@media (max-width:620px){
  html{scroll-padding-top:80px}
  .b-grid,.p-grid,.t-grid,.s-grid{grid-template-columns:1fr}
  .t-card:last-child{grid-column:auto}
  .s-item{border-left:0;padding:2.4rem .4rem}
  .s-item:nth-child(-n+2){border-top:0}
  .s-item:first-child{border-top:0}
  .s-item + .s-item{border-top:1px solid rgba(199,161,106,.3)}
  .g-grid{
    grid-template-columns:1fr;grid-template-rows:420px 200px 260px 220px 300px;
    grid-template-areas:"big" "word" "lace" "sketch" "full";
  }
  .hero-actions .btn{width:100%}
  .badge-glass{position:static;margin-top:1rem;width:100%}
  .photo-frame::before{transform:translate(10px,-10px)}
  .f-grid{grid-template-columns:1fr 1fr;gap:2.2rem}
  .f-grid .f-brand{grid-column:1/-1}
  .announce{letter-spacing:.1em;font-size:.68rem}
}

/* ---------- accesibilidad ---------- */
:focus-visible{outline:2px solid var(--gold);outline-offset:3px}
@media (prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}
  html{scroll-behavior:auto}
  .reveal{opacity:1;transform:none}
  [data-h]{opacity:1;animation:none}
}
