/* =========================================================
   LOTUS Salón de Belleza — estilos
   Paleta espresso + dorado · editorial premium
   ========================================================= */

/* ---------- Tokens ---------- */
:root{
  --espresso:#211810;        /* fondo principal */
  --espresso-deep:#1F1712;   /* fondo secundario */
  --noir:#120C08;            /* overlays / negro lujo */
  --ivory:#E8DED1;           /* texto principal */
  --taupe:#8F8170;           /* texto secundario */
  --gold:#B9955D;            /* champagne */
  --gold-lux:#D4AF37;        /* dorado luminoso */
  --cream:#F2E9D8;           /* secciones claras */

  --gold-line:rgba(185,149,93,.32);
  --gold-line-soft:rgba(185,149,93,.16);

  --serif:"Bodoni Moda", "Cormorant Garamond", Georgia, serif;
  --sans:"Jost", "Montserrat", system-ui, sans-serif;

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

/* ---------- Reset ---------- */
*,*::before,*::after{box-sizing:border-box;}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%;}
body{
  margin:0;
  font-family:var(--sans);
  font-weight:300;
  color:var(--ivory);
  background:var(--espresso);
  line-height:1.7;
  letter-spacing:.01em;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
img,svg{display:block;max-width:100%;}
a{color:inherit;text-decoration:none;}
ul{margin:0;padding:0;list-style:none;}
h1,h2,h3,h4{margin:0;font-weight:400;}
button{font-family:inherit;cursor:pointer;}
:focus-visible{outline:2px solid var(--gold-lux);outline-offset:3px;border-radius:2px;}

.skip{
  position:absolute;left:-999px;top:0;z-index:200;
  background:var(--gold);color:var(--noir);padding:10px 18px;border-radius:0 0 8px 0;
  font-family:var(--sans);font-size:.85rem;
}
.skip:focus{left:0;}
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);border:0;}

/* ---------- Layout helpers ---------- */
.wrap{width:min(100% - 44px, var(--max));margin-inline:auto;}
.section{padding:clamp(64px,9vw,128px) 0;position:relative;}
.eyebrow{
  font-family:var(--sans);font-weight:400;
  font-size:.72rem;letter-spacing:.42em;text-transform:uppercase;
  color:var(--gold);margin:0 0 18px;
}
.eyebrow.center{text-align:center;}
.display{
  font-family:var(--serif);font-weight:500;
  line-height:1.04;letter-spacing:.005em;
  font-size:clamp(2.1rem,5.4vw,4.4rem);
}
.display .it{font-style:italic;font-weight:400;color:var(--gold-lux);}
.lead{
  color:var(--taupe);font-weight:300;
  font-size:clamp(1rem,1.5vw,1.18rem);max-width:54ch;
}
.rule{width:64px;height:1px;background:var(--gold);border:0;margin:24px 0;}
.rule.center{margin-inline:auto;}

/* ---------- Botones ---------- */
.btn{
  --b:var(--gold);
  display:inline-flex;align-items:center;gap:.6em;
  font-family:var(--sans);font-weight:400;font-size:.86rem;
  letter-spacing:.16em;text-transform:uppercase;
  padding:16px 30px;border:1px solid var(--b);border-radius:2px;
  background:transparent;color:var(--ivory);
  transition:background .45s var(--ease),color .45s var(--ease),box-shadow .45s var(--ease),transform .45s var(--ease);
  white-space:nowrap;
}
.btn .ico{width:17px;height:17px;}
.btn--gold{background:linear-gradient(135deg,var(--gold) 0%,var(--gold-lux) 100%);color:var(--noir);border-color:transparent;font-weight:500;box-shadow:0 10px 30px -12px rgba(212,175,55,.5);}
.btn--gold:hover{transform:translateY(-2px);box-shadow:0 16px 40px -12px rgba(212,175,55,.65);}
.btn--ghost:hover{background:var(--gold);color:var(--noir);}
.btn--block{width:100%;justify-content:center;}

/* ---------- Editorial "imágenes" (arte CSS/SVG) ---------- */
.editorial{
  position:relative;overflow:hidden;border-radius:3px;
  background:
    radial-gradient(120% 90% at 78% 18%, rgba(212,175,55,.20), transparent 55%),
    radial-gradient(90% 80% at 12% 92%, rgba(185,149,93,.16), transparent 60%),
    linear-gradient(155deg, #2c2018 0%, #1c140e 48%, #120c08 100%);
  border:1px solid var(--gold-line);
  isolation:isolate;
}
.editorial::after{ /* grano sutil */
  content:"";position:absolute;inset:0;pointer-events:none;mix-blend-mode:overlay;opacity:.5;
  background-image:url("assets/grain.svg");
}
.editorial .botanical{
  position:absolute;inset:0;width:100%;height:100%;
  color:var(--gold);opacity:.5;
}
.editorial .botanical [stroke]{vector-effect:non-scaling-stroke;}
.editorial--rose{
  background:
    radial-gradient(120% 90% at 80% 16%, rgba(212,175,55,.18), transparent 55%),
    radial-gradient(100% 90% at 8% 90%, rgba(200,150,120,.18), transparent 60%),
    linear-gradient(160deg, #34241d 0%, #211712 50%, #140d09 100%);
}
.editorial--sage{
  background:
    radial-gradient(120% 90% at 75% 20%, rgba(212,175,55,.16), transparent 55%),
    radial-gradient(100% 90% at 10% 92%, rgba(150,150,120,.14), transparent 60%),
    linear-gradient(160deg, #2a241a 0%, #1d1810 50%, #120d08 100%);
}
.editorial .tagword{
  position:absolute;left:20px;bottom:16px;z-index:2;
  font-family:var(--serif);font-style:italic;font-size:1.4rem;color:var(--ivory);
  text-shadow:0 2px 16px rgba(0,0,0,.6);
}

/* =========================================================
   NAV
   ========================================================= */
.nav{
  position:fixed;inset:0 0 auto 0;z-index:100;
  display:flex;align-items:center;justify-content:space-between;
  padding:18px max(22px,calc((100vw - var(--max))/2 + 22px));
  transition:background .5s var(--ease),padding .5s var(--ease),border-color .5s var(--ease);
  border-bottom:1px solid transparent;
}
.nav.scrolled{
  background:rgba(18,12,8,.82);backdrop-filter:blur(14px);
  padding-top:12px;padding-bottom:12px;border-bottom-color:var(--gold-line);
}
.nav__brand{display:flex;align-items:center;gap:11px;position:relative;overflow:hidden;border-radius:4px;}
.nav__brand .mark{width:30px;height:auto;color:var(--gold);transition:color .4s var(--ease),filter .4s var(--ease),transform .6s var(--ease);}
.nav__brand .name{font-family:var(--serif);font-size:1.25rem;letter-spacing:.34em;padding-left:.34em;transition:color .4s var(--ease);}
.nav__brand::after{
  content:"";position:absolute;top:0;left:0;width:55%;height:100%;pointer-events:none;z-index:2;
  background:linear-gradient(105deg,transparent 0%,rgba(255,247,224,.18) 38%,rgba(255,247,224,.6) 50%,rgba(255,247,224,.18) 62%,transparent 100%);
  transform:translateX(-200%) skewX(-18deg);
  transition:transform .9s var(--ease);
}
.nav__brand:hover::after{transform:translateX(360%) skewX(-18deg);}
.nav__brand:hover .mark{color:var(--gold-lux);filter:drop-shadow(0 0 7px rgba(212,175,55,.75));transform:scale(1.06);}
.nav__brand:hover .name{color:#fff;}
.nav__links{display:flex;align-items:center;gap:34px;}
.nav__links a{font-size:.78rem;letter-spacing:.14em;text-transform:uppercase;color:var(--taupe);transition:color .3s;}
.nav__links a:hover{color:var(--ivory);}
.nav__cta{padding:11px 22px;font-size:.74rem;}
.nav__burger{display:none;background:none;border:0;color:var(--ivory);width:30px;height:30px;}

/* =========================================================
   HERO
   ========================================================= */
.hero{
  position:relative;min-height:100svh;display:flex;align-items:center;
  padding-block:120px 70px;overflow:hidden;
}
.hero__bg{position:absolute;inset:0;z-index:0;}
.hero__bg .glow{
  position:absolute;inset:-20% -10% auto auto;width:70vw;height:70vw;max-width:760px;max-height:760px;
  background:radial-gradient(circle at 60% 40%, rgba(212,175,55,.22), rgba(185,149,93,.07) 42%, transparent 66%);
  filter:blur(8px);
}
.hero__bg .veil{position:absolute;inset:0;background:linear-gradient(120deg, rgba(18,12,8,.55) 0%, rgba(33,24,16,.2) 55%, rgba(18,12,8,.7) 100%);}
.hero__bg .lines{position:absolute;inset:0;color:var(--gold);opacity:.14;}
.hero .wrap{position:relative;z-index:2;display:grid;grid-template-columns:1.08fr .92fr;gap:clamp(30px,5vw,72px);align-items:center;}
.hero__logo{width:74px;height:auto;color:var(--gold);margin-bottom:22px;}
.hero__brand{font-family:var(--sans);font-weight:400;font-size:.8rem;letter-spacing:.5em;text-transform:uppercase;color:var(--gold);margin-bottom:26px;}
.hero h1{font-family:var(--serif);font-weight:500;line-height:1.02;font-size:clamp(2.6rem,6.4vw,5.2rem);margin:0 0 26px;}
.hero h1 .it{font-style:italic;color:var(--gold-lux);}
.hero__line{display:block;overflow:hidden;padding-bottom:.34em;margin-bottom:-.34em;}
.hero__sub{color:var(--taupe);font-size:clamp(1rem,1.6vw,1.2rem);max-width:50ch;margin:0 0 22px;}
.hero__micro{display:flex;flex-wrap:wrap;gap:8px 18px;font-size:.76rem;letter-spacing:.16em;text-transform:uppercase;color:var(--gold);margin:0 0 36px;}
.hero__micro span{display:inline-flex;align-items:center;gap:10px;position:relative;cursor:default;transition:color .35s var(--ease),transform .35s var(--ease);}
.hero__micro span::after{content:"";position:absolute;left:0;right:0;bottom:-4px;height:1px;background:linear-gradient(90deg,var(--gold),var(--gold-lux));transform:scaleX(0);transform-origin:left center;transition:transform .4s var(--ease);}
.hero__micro span:not(:first-child)::after{left:6px;}
.hero__micro span:hover{color:var(--gold-lux);transform:translateY(-2px);}
.hero__micro span:hover::after{transform:scaleX(1);}
.hero__micro span:not(:first-child)::before{content:"·";color:var(--taupe);margin-left:-12px;}
.hero__cta{display:flex;flex-wrap:wrap;gap:14px;}
.hero__visual{position:relative;aspect-ratio:4/5;width:100%;border-radius:3px;overflow:hidden;background:#241a10 url("data:image/webp;base64,UklGRiQDAABXRUJQVlA4WAoAAAAgAAAAHwAAHwAASUNDUMgBAAAAAAHIAAAAAAQwAABtbnRyUkdCIFhZWiAH4AABAAEAAAAAAABhY3NwAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAQAA9tYAAQAAAADTLQAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAlkZXNjAAAA8AAAACRyWFlaAAABFAAAABRnWFlaAAABKAAAABRiWFlaAAABPAAAABR3dHB0AAABUAAAABRyVFJDAAABZAAAAChnVFJDAAABZAAAAChiVFJDAAABZAAAAChjcHJ0AAABjAAAADxtbHVjAAAAAAAAAAEAAAAMZW5VUwAAAAgAAAAcAHMAUgBHAEJYWVogAAAAAAAAb6IAADj1AAADkFhZWiAAAAAAAABimQAAt4UAABjaWFlaIAAAAAAAACSgAAAPhAAAts9YWVogAAAAAAAA9tYAAQAAAADTLXBhcmEAAAAAAAQAAAACZmYAAPKnAAANWQAAE9AAAApbAAAAAAAAAABtbHVjAAAAAAAAAAEAAAAMZW5VUwAAACAAAAAcAEcAbwBvAGcAbABlACAASQBuAGMALgAgADIAMAAxADZWUDggNgEAANAGAJ0BKiAAIAA+tU6eSyckIqGoDVDgFoljAMifqCsKck9yRwlEbBzNxKyNI5nYxkypcPpu1+3KvGh7362uwAD44g5k2BvWg/5T1Gvz9p6wD/rH81tBWh/FRsVcXuzwA8+MCro0oIlC89IS/O1O2CUMqXeTkRyTrc3Ek2gpe5VcABb2Tf905/P+M6DT2kbJSskbH33molduaqhnlXhF5SGlnwX0F1ETkNFp010P6wQWXx+OpbMIFpA+//iDQD/yPxiSAlenpSDFvoDvnSj2FKRJ25y94FA0gnwEXt5MKm1oA0mo9aezoMt0vtqArFdGrv7nuv54dzr9gxLMm9vW4sqQdwwC2hetagHhzl4zrRcG3F//6obsc+ewVxa59MagFE/Ln8Ap1YVKENuinTvVuERP+LYAAAA=") center/cover no-repeat;}
.hero__visual img{position:absolute;inset:0;width:100%;height:108%;object-fit:cover;}
.hero__visual::after{content:"";position:absolute;inset:0;z-index:2;background:linear-gradient(180deg,rgba(18,12,8,.1) 0%,rgba(18,12,8,.05) 45%,rgba(18,12,8,.62) 100%),linear-gradient(120deg,rgba(185,149,93,.16),transparent 60%);}
.hero__visual .frame{position:absolute;inset:14px;border:1px solid rgba(232,222,209,.35);pointer-events:none;z-index:3;}
.hero__visual .cap{position:absolute;left:26px;bottom:24px;z-index:4;font-family:var(--serif);font-style:italic;font-size:1.5rem;color:#fff;text-shadow:0 2px 16px rgba(0,0,0,.6);}
.scrollcue{position:absolute;left:50%;bottom:26px;transform:translateX(-50%);z-index:3;display:flex;flex-direction:column;align-items:center;gap:9px;color:var(--taupe);font-size:.64rem;letter-spacing:.3em;text-transform:uppercase;}
.scrollcue .bar{width:1px;height:46px;background:linear-gradient(var(--gold),transparent);}

/* =========================================================
   Lenis (scroll suave)
   ========================================================= */
html.lenis,html.lenis body{height:auto;}
.lenis.lenis-smooth{scroll-behavior:auto!important;}
.lenis.lenis-smooth [data-lenis-prevent]{overscroll-behavior:contain;}
.lenis.lenis-stopped{overflow:hidden;}

/* =========================================================
   Utilidades: fotos + glassmorphism
   ========================================================= */
.glass{background:rgba(255,255,255,.05);backdrop-filter:blur(16px) saturate(1.15);-webkit-backdrop-filter:blur(16px) saturate(1.15);border:1px solid rgba(232,222,209,.12);}
.photo{position:relative;overflow:hidden;}
.photo img{width:100%;height:100%;object-fit:cover;display:block;}

/* =========================================================
   BENEFICIOS
   ========================================================= */
.benefits{background:var(--espresso-deep);border-block:1px solid var(--gold-line-soft);}
.benefits__grid{display:grid;grid-template-columns:repeat(4,1fr);gap:22px;margin-top:48px;}
.bcard{
  padding:38px 30px;border:1px solid rgba(232,222,209,.1);border-radius:3px;
  background:rgba(255,255,255,.04);backdrop-filter:blur(14px) saturate(1.1);-webkit-backdrop-filter:blur(14px) saturate(1.1);
  transition:transform .5s var(--ease),border-color .5s var(--ease),box-shadow .5s var(--ease);
}
.bcard:hover{transform:translateY(-6px);border-color:var(--gold);box-shadow:0 26px 50px -28px rgba(0,0,0,.8);}
.bcard .ic{width:42px;height:42px;color:var(--gold);margin-bottom:22px;}
.bcard h3{font-family:var(--serif);font-size:1.5rem;margin-bottom:12px;}
.bcard p{color:var(--taupe);font-size:.95rem;margin:0;}

/* =========================================================
   SERVICIOS (carrusel snap + flechas)
   ========================================================= */
.services{background:var(--espresso);}
.services__head{display:flex;justify-content:space-between;align-items:flex-end;gap:30px;flex-wrap:wrap;margin-bottom:30px;}
.carousel{display:flex;gap:12px;align-items:center;}
.carousel__btn{width:52px;height:52px;border-radius:50%;border:1px solid var(--gold-line);background:rgba(255,255,255,.05);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);color:var(--ivory);display:inline-flex;align-items:center;justify-content:center;transition:background .4s var(--ease),color .4s var(--ease),border-color .4s var(--ease),opacity .4s var(--ease);}
.carousel__btn:hover:not(:disabled){background:var(--gold);color:var(--noir);border-color:var(--gold);}
.carousel__btn:disabled{opacity:.28;cursor:default;}
.carousel__btn svg{width:20px;height:20px;}

.hscroll{position:relative;}
.htrack{
  display:flex;gap:26px;overflow-x:auto;overflow-y:hidden;
  scroll-snap-type:x mandatory;scroll-behavior:smooth;
  padding:8px max(22px,calc((100vw - var(--max))/2 + 22px)) 26px;
  scroll-padding-left:max(22px,calc((100vw - var(--max))/2 + 22px));
  -ms-overflow-style:none;scrollbar-width:none;
}
.htrack::-webkit-scrollbar{display:none;}
.scard{
  flex:0 0 min(82vw,378px);scroll-snap-align:start;
  display:flex;flex-direction:column;
  border:1px solid var(--gold-line);border-radius:3px;overflow:hidden;
  background:var(--espresso-deep);
  transition:border-color .5s var(--ease),box-shadow .5s var(--ease),transform .5s var(--ease);
}
.scard:hover{border-color:var(--gold);box-shadow:0 30px 60px -30px rgba(0,0,0,.85);transform:translateY(-4px);}
.scard__img{aspect-ratio:16/11;position:relative;overflow:hidden;}
.scard__img img{width:100%;height:100%;object-fit:cover;transition:transform 1.1s var(--ease);}
.scard:hover .scard__img img{transform:scale(1.06);}
.scard__img::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(33,24,16,.04),rgba(18,12,8,.6)),linear-gradient(110deg,rgba(185,149,93,.14),transparent 55%);}
.scard__img .tagword{position:absolute;left:20px;bottom:14px;z-index:2;font-family:var(--serif);font-style:italic;font-size:1.45rem;color:#fff;text-shadow:0 2px 14px rgba(0,0,0,.65);}
.scard__body{padding:28px 28px 30px;display:flex;flex-direction:column;flex:1;}
.scard__num{font-family:var(--serif);font-style:italic;color:var(--gold);font-size:1rem;margin-bottom:8px;}
.scard h3{font-family:var(--serif);font-size:2rem;color:var(--gold-lux);margin-bottom:10px;}
.scard__desc{color:var(--taupe);font-size:.92rem;margin:0 0 18px;}
.scard ul{display:flex;flex-direction:column;gap:9px;margin-bottom:24px;}
.scard li{display:flex;align-items:baseline;gap:11px;font-size:.92rem;color:var(--ivory);}
.scard li::before{content:"";width:5px;height:5px;flex:none;border-radius:50%;background:var(--gold);transform:translateY(-2px);}
.scard .btn{margin-top:auto;align-self:flex-start;padding:12px 22px;font-size:.74rem;}

/* =========================================================
   PROMOCIONES (afiches enmarcados + lightbox)
   ========================================================= */
.promos{background:var(--espresso-deep);border-block:1px solid var(--gold-line-soft);}
.promos__head{display:grid;grid-template-columns:1fr .9fr;gap:clamp(24px,5vw,64px);align-items:end;margin-bottom:54px;}
.promos__head .lead{max-width:46ch;}
.promos__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(26px,3vw,40px);}
.promo{display:flex;flex-direction:column;}
.promo__art{
  position:relative;display:block;width:100%;padding:14px;border:0;cursor:zoom-in;
  background:linear-gradient(160deg,#2c2018,#160f0a);
  border:1px solid var(--gold-line);border-radius:3px;overflow:hidden;
  transition:border-color .5s var(--ease),box-shadow .5s var(--ease),transform .5s var(--ease);
}
.promo__art img{
  width:100%;height:auto;aspect-ratio:5/8;object-fit:contain;object-position:center;
  border-radius:2px;display:block;
  transition:transform 1.1s var(--ease);
}
.promo__frame{position:absolute;inset:22px;border:1px solid rgba(232,222,209,.22);pointer-events:none;z-index:2;transition:border-color .5s var(--ease);}
.promo__zoom{
  position:absolute;top:24px;right:24px;z-index:3;width:42px;height:42px;border-radius:50%;
  display:grid;place-items:center;color:var(--noir);
  background:linear-gradient(135deg,var(--gold),var(--gold-lux));
  box-shadow:0 8px 20px -8px rgba(0,0,0,.6);
  opacity:0;transform:scale(.8) translateY(-4px);transition:opacity .45s var(--ease),transform .45s var(--ease);
}
.promo__zoom svg{width:20px;height:20px;}
.promo__art:hover{border-color:var(--gold);box-shadow:0 30px 60px -30px rgba(0,0,0,.85);transform:translateY(-5px);}
.promo__art:hover img{transform:scale(1.03);}
.promo__art:hover .promo__frame{border-color:var(--gold);}
.promo__art:hover .promo__zoom,.promo__art:focus-visible .promo__zoom{opacity:1;transform:none;}
.promo__cap{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;padding:20px 4px 0;}
.promo__kick{display:block;font-size:.66rem;letter-spacing:.22em;text-transform:uppercase;color:var(--gold);margin-bottom:7px;}
.promo__cap h3{font-family:var(--serif);font-size:1.55rem;color:var(--ivory);line-height:1.1;}
.promo__price{
  flex:none;font-family:var(--serif);font-size:1.18rem;color:var(--gold-lux);white-space:nowrap;
  border:1px solid var(--gold-line);border-radius:2px;padding:7px 13px;line-height:1;
}
.promo--feat .promo__price{background:linear-gradient(135deg,var(--gold),var(--gold-lux));color:var(--noir);border-color:transparent;font-weight:500;}
.promo__cta{
  margin-top:16px;align-self:flex-start;
  font-family:var(--sans);font-size:.74rem;letter-spacing:.16em;text-transform:uppercase;color:var(--gold);
  border-bottom:1px solid var(--gold-line);padding-bottom:3px;
  transition:color .35s var(--ease),border-color .35s var(--ease);
}
.promo__cta:hover{color:var(--gold-lux);border-color:var(--gold-lux);}
@media (max-width:900px){
  .promos__head{grid-template-columns:1fr;gap:18px;}
  .promos__grid{grid-template-columns:1fr 1fr;}
  .promo__zoom{opacity:1;transform:none;}
}
@media (max-width:560px){
  .promos__grid{grid-template-columns:1fr;max-width:420px;margin-inline:auto;}
}

/* ---------- Lightbox ---------- */
.lightbox{
  position:fixed;inset:0;z-index:200;display:flex;align-items:center;justify-content:center;
  gap:clamp(8px,2vw,28px);padding:max(20px,4vh) clamp(12px,4vw,60px);
  background:rgba(12,8,5,.92);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);
  opacity:0;transition:opacity .4s var(--ease);
}
.lightbox.open{opacity:1;}
.lightbox[hidden]{display:none;}
.lightbox__stage{margin:0;display:flex;align-items:center;justify-content:center;max-height:100%;}
.lightbox__img{
  max-height:88vh;max-width:min(92vw,640px);width:auto;height:auto;
  border-radius:3px;border:1px solid var(--gold-line);
  box-shadow:0 40px 90px -30px rgba(0,0,0,.9);
  transform:scale(.97);transition:transform .4s var(--ease);
}
.lightbox.open .lightbox__img{transform:none;}
.lightbox__close{
  position:absolute;top:max(16px,2.5vh);right:max(16px,2.5vw);z-index:2;
  width:46px;height:46px;border-radius:50%;border:1px solid var(--gold-line);
  background:rgba(255,255,255,.06);color:var(--ivory);display:grid;place-items:center;
  transition:background .35s var(--ease),color .35s var(--ease),border-color .35s var(--ease);
}
.lightbox__close svg{width:24px;height:24px;}
.lightbox__close:hover{background:var(--gold);color:var(--noir);border-color:var(--gold);}
.lightbox__nav{
  flex:none;width:54px;height:54px;border-radius:50%;border:1px solid var(--gold-line);
  background:rgba(255,255,255,.05);color:var(--ivory);display:grid;place-items:center;
  transition:background .35s var(--ease),color .35s var(--ease),border-color .35s var(--ease);
}
.lightbox__nav svg{width:22px;height:22px;}
.lightbox__nav:hover{background:var(--gold);color:var(--noir);border-color:var(--gold);}
@media (max-width:680px){
  .lightbox{flex-wrap:wrap;}
  .lightbox__nav{position:absolute;bottom:max(18px,3vh);width:48px;height:48px;}
  .lightbox__nav--prev{left:28%;}
  .lightbox__nav--next{right:28%;}
  .lightbox__img{max-height:78vh;}
}

/* =========================================================
   EXPERIENCIA (pin)
   ========================================================= */
.experience{background:var(--noir);border-block:1px solid var(--gold-line-soft);}
.experience__grid{display:grid;grid-template-columns:.92fr 1.08fr;gap:clamp(30px,5vw,70px);align-items:start;}
.experience__sticky{position:sticky;top:0;min-height:100svh;display:flex;flex-direction:column;justify-content:center;padding-block:80px;}
.experience__sticky .display{font-size:clamp(2rem,4vw,3.4rem);}
.experience__panels{display:flex;flex-direction:column;gap:clamp(40px,8vh,90px);padding-block:18vh;}
.xpanel{display:grid;gap:24px;}
.xpanel__img{aspect-ratio:5/3;position:relative;overflow:hidden;border-radius:3px;border:1px solid var(--gold-line);}
.xpanel__img img{width:100%;height:100%;object-fit:cover;transition:transform 1.1s var(--ease);}
.xpanel:hover .xpanel__img img{transform:scale(1.05);}
.xpanel__img::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 40%,rgba(18,12,8,.45)),linear-gradient(120deg,rgba(185,149,93,.12),transparent 60%);}
.xpanel__no{font-family:var(--serif);font-style:italic;color:var(--gold);font-size:1.05rem;}
.xpanel h3{font-family:var(--serif);font-size:clamp(1.6rem,2.6vw,2.2rem);margin:6px 0 10px;}
.xpanel p{color:var(--taupe);margin:0;font-size:.96rem;max-width:46ch;}

/* =========================================================
   GALERÍA (mosaico estático)
   ========================================================= */
.gallery{background:var(--espresso-deep);}
.gmosaic{column-count:3;column-gap:18px;}
.gitem{position:relative;overflow:hidden;border-radius:3px;border:1px solid var(--gold-line);break-inside:avoid;margin-bottom:18px;display:block;}
.gitem img{width:100%;height:auto;display:block;object-fit:cover;transition:transform 1.1s var(--ease);}
.gitem:hover img{transform:scale(1.07);}
.gitem__overlay{
  position:absolute;inset:0;z-index:2;display:flex;flex-direction:column;justify-content:flex-end;
  padding:clamp(16px,2.4vw,24px);opacity:0;
  background:linear-gradient(0deg, rgba(18,12,8,.78) 0%, rgba(18,12,8,.2) 45%, transparent 100%);
  transition:opacity .5s var(--ease);
}
.gitem:hover .gitem__overlay{opacity:1;}
.gitem__overlay .k{font-size:.66rem;letter-spacing:.28em;text-transform:uppercase;color:var(--gold-lux);font-weight:500;margin-bottom:2px;}
.gitem__overlay .t{font-family:var(--serif);font-style:italic;font-size:clamp(1.25rem,2.4vw,1.7rem);color:#fff;line-height:1.15;}

/* Tablet — dos columnas */
@media (max-width:1024px){
  .gmosaic{column-count:2;column-gap:16px;}
  .gitem{margin-bottom:16px;}
}
/* Móvil — una columna, imagen a tamaño completo */
@media (max-width:600px){
  .gmosaic{column-count:1;column-gap:0;}
  .gitem{margin-bottom:14px;}
}
/* Dispositivos táctiles (sin hover) — leyenda siempre visible */
@media (hover:none){
  .gitem__overlay{
    opacity:1;
    background:linear-gradient(0deg, rgba(18,12,8,.72) 0%, rgba(18,12,8,.12) 55%, transparent 100%);
  }
  .gitem:hover img{transform:none;}
}

/* =========================================================
   PRECIOS
   ========================================================= */
.prices{background:var(--espresso);position:relative;}
.prices__head{text-align:center;margin-bottom:60px;}
.prices__grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(40px,6vw,80px);}
.pgroup{break-inside:avoid;margin-bottom:46px;}
.pgroup__title{display:flex;align-items:center;gap:16px;margin-bottom:24px;}
.pgroup__title h3{font-family:var(--serif);font-size:1.7rem;color:var(--gold-lux);white-space:nowrap;}
.pgroup__title .ln{flex:1;height:1px;background:var(--gold-line);}
.pgroup__title .ic{width:24px;height:24px;color:var(--gold);}
.pitem{padding:9px 0;border-bottom:1px solid rgba(143,129,112,.14);}
.pitem__row{display:flex;align-items:baseline;gap:10px;}
.pitem__name{font-size:1rem;color:var(--ivory);font-weight:400;flex:0 1 auto;flex-shrink:0;max-width:64%;}
.pitem__dots{flex:1;border-bottom:1px dotted var(--taupe);transform:translateY(-4px);min-width:20px;opacity:.6;}
.pitem__price{font-family:var(--serif);font-size:1.12rem;color:var(--gold-lux);white-space:nowrap;}
.pitem__note{display:block;color:var(--taupe);font-size:.82rem;margin-top:3px;max-width:48ch;}
.pitem__tag{display:inline-block;font-size:.64rem;letter-spacing:.16em;text-transform:uppercase;color:var(--gold);border:1px solid var(--gold-line);border-radius:2px;padding:2px 8px;margin-right:8px;vertical-align:middle;}
.pnote{margin-top:8px;color:var(--taupe);font-size:.86rem;font-style:italic;}

/* =========================================================
   RESERVA 3 PASOS
   ========================================================= */
.booking{background:var(--cream);color:#3a2c1c;border-block:1px solid var(--gold-line);}
.booking .eyebrow{color:var(--gold);}
.booking .display{color:#2c2014;}
.booking__lead{color:#6f5e49;}
.steps{display:grid;grid-template-columns:repeat(3,1fr);gap:26px;margin:54px 0 40px;}
.step{position:relative;padding:34px 28px;background:#fff;border:1px solid rgba(185,149,93,.4);border-radius:3px;}
.step__no{font-family:var(--serif);font-size:3.4rem;color:var(--gold);line-height:1;margin-bottom:16px;font-style:italic;}
.step h3{font-family:var(--serif);font-size:1.45rem;color:#2c2014;margin-bottom:8px;}
.step p{color:#6f5e49;font-size:.92rem;margin:0;}
.booking__foot{display:flex;flex-wrap:wrap;align-items:center;gap:22px;justify-content:space-between;}
.booking__foot .note{color:#6f5e49;font-style:italic;max-width:50ch;font-size:.92rem;margin:0;}
.booking .btn{color:var(--noir);}
.booking .btn--ghost{color:#3a2c1c;border-color:var(--gold);}
.booking .btn--ghost:hover{background:var(--gold);color:var(--noir);}

/* =========================================================
   UBICACIÓN / MAPA
   ========================================================= */
.locate{background:var(--espresso-deep);border-block:1px solid var(--gold-line-soft);}
.locate__grid{display:grid;grid-template-columns:.85fr 1.15fr;gap:clamp(30px,5vw,64px);align-items:center;margin-top:46px;}
.locate__info address{font-style:normal;color:var(--ivory);font-size:1.08rem;line-height:1.8;margin-bottom:8px;}
.locate__info .muted{color:var(--taupe);font-size:.92rem;margin:0 0 26px;}
.locate__info .row{display:flex;flex-wrap:wrap;gap:13px;}
.locate__map{position:relative;border:1px solid var(--gold-line);border-radius:3px;overflow:hidden;aspect-ratio:16/11;}
.locate__map iframe{position:absolute;inset:0;width:100%;height:100%;border:0;filter:grayscale(.35) sepia(.18) brightness(.92) contrast(1.05);}
.locate__map .frame{position:absolute;inset:12px;border:1px solid var(--gold-line);pointer-events:none;z-index:2;}
@media (max-width:980px){.locate__grid{grid-template-columns:1fr;}}

/* =========================================================
   CTA FINAL
   ========================================================= */
.cta{position:relative;text-align:center;overflow:hidden;background:var(--noir);}
.cta__glow{position:absolute;inset:auto 50% -30% auto;transform:translateX(50%);width:80vw;max-width:720px;height:520px;background:radial-gradient(circle at 50% 100%, rgba(212,175,55,.22), transparent 64%);}
.cta .wrap{position:relative;z-index:2;display:flex;flex-direction:column;align-items:center;}
.cta__lotus{width:70px;color:var(--gold);margin-bottom:28px;}
.cta .display{max-width:18ch;}
.cta__lead{color:var(--taupe);max-width:58ch;margin:24px auto 38px;}
.cta__btns{display:flex;flex-wrap:wrap;gap:14px;justify-content:center;}

/* =========================================================
   FOOTER
   ========================================================= */
.footer{background:#16100b;border-top:1px solid var(--gold-line);padding:70px 0 34px;}
.footer__grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:40px;}
.footer__totop{display:inline-block;line-height:0;cursor:pointer;transition:transform .3s ease,filter .3s ease;}
.footer__totop:hover{transform:translateY(-3px);filter:brightness(1.25);}
.footer__totop:focus-visible{outline:2px solid var(--gold);outline-offset:4px;border-radius:4px;}
.footer__brand .mark{width:54px;color:var(--gold);margin-bottom:16px;}
.footer__brand .name{font-family:var(--serif);font-size:1.7rem;letter-spacing:.3em;}
.footer__brand .sub{color:var(--taupe);font-size:.82rem;letter-spacing:.28em;text-transform:uppercase;margin-top:4px;}
.footer h4{font-family:var(--sans);font-weight:400;font-size:.74rem;letter-spacing:.24em;text-transform:uppercase;color:var(--gold);margin-bottom:18px;}
.footer a,.footer p{color:var(--taupe);font-size:.92rem;}
.footer ul{display:flex;flex-direction:column;gap:11px;}
.footer a:hover{color:var(--ivory);}
.footer address{font-style:normal;line-height:1.8;}
.footer__bottom{margin-top:54px;padding-top:24px;border-top:1px solid var(--gold-line-soft);text-align:center;color:var(--taupe);font-size:.8rem;letter-spacing:.06em;}

/* =========================================================
   FLOATING WHATSAPP
   ========================================================= */
.fab{
  position:fixed;right:22px;bottom:22px;z-index:120;
  display:inline-flex;align-items:center;gap:0;
  background:#25D366;color:#073b1c;border-radius:40px;
  padding:14px;box-shadow:0 14px 34px -10px rgba(0,0,0,.6);
  opacity:0;transform:translateY(24px) scale(.9);pointer-events:none;
  transition:opacity .5s var(--ease),transform .5s var(--ease),gap .4s var(--ease),padding .4s var(--ease);
}
.fab.show{opacity:1;transform:none;pointer-events:auto;}
.fab svg{width:28px;height:28px;flex:none;}
.fab .lbl{max-width:0;overflow:hidden;white-space:nowrap;font-size:.82rem;font-weight:500;letter-spacing:.04em;transition:max-width .4s var(--ease);}
.fab:hover{gap:10px;padding-inline:18px;}
.fab:hover .lbl{max-width:160px;}

/* =========================================================
   Reveal (animación base)
   ========================================================= */
.reveal{opacity:0;transform:translateY(28px);}
.is-ready .reveal{will-change:opacity,transform;}

/* =========================================================
   Responsive
   ========================================================= */
@media (max-width:980px){
  .nav__links{display:none;}
  .nav__burger{display:inline-flex;align-items:center;justify-content:center;}
  .hero .wrap{grid-template-columns:1fr;}
  .hero__visual{aspect-ratio:16/12;max-height:46vh;order:-1;}
  .benefits__grid{grid-template-columns:1fr 1fr;}
  .experience__grid{grid-template-columns:1fr;}
  .experience__sticky{position:static;min-height:auto;padding-block:0 40px;}
  .experience__panels{padding-block:0;}
  .prices__grid{grid-template-columns:1fr;gap:0;}
  .steps{grid-template-columns:1fr;}
  .footer__grid{grid-template-columns:1fr 1fr;}
  .footer__brand{grid-column:1/-1;}
}
@media (max-width:560px){
  .benefits__grid{grid-template-columns:1fr;}
  .footer__grid{grid-template-columns:1fr;}
  .hero__cta .btn,.cta__btns .btn{flex:1;justify-content:center;}
  .booking__foot{flex-direction:column;align-items:stretch;}
}

/* ---------- Mobile menu panel ---------- */
.mobilemenu{
  position:fixed;inset:0;z-index:110;background:rgba(18,12,8,.97);backdrop-filter:blur(8px);
  display:flex;flex-direction:column;align-items:center;justify-content:center;gap:26px;
  opacity:0;pointer-events:none;transition:opacity .4s var(--ease);
}
.mobilemenu.open{opacity:1;pointer-events:auto;}
.mobilemenu a{font-family:var(--serif);font-size:1.8rem;color:var(--ivory);}
.mobilemenu a:hover{color:var(--gold);}
.mobilemenu .close{position:absolute;top:22px;right:22px;background:none;border:0;color:var(--ivory);width:34px;height:34px;}

/* =========================================================
   prefers-reduced-motion
   ========================================================= */
@media (prefers-reduced-motion:reduce){
  html{scroll-behavior:auto;}
  .reveal{opacity:1!important;transform:none!important;}
  *,*::before,*::after{transition-duration:.001ms!important;animation-duration:.001ms!important;}
}
