/* =========================================================
   MÓNACO SALÓN DE IMAGEN — Feminine Premium
   Tenor Sans (títulos) + Montserrat (texto) · Nude/Blush/Cream/Gold/Rose
   ========================================================= */

:root{
  --cream:#fbf6f0;
  --cream-2:#f6ece1;
  --blush:#f7e8e2;
  --blush-2:#f0d7cf;
  --nude:#ecdcc9;
  --lilac:#efe7f1;
  --lilac-2:#e7dcec;

  --rose:#c98b86;
  --rose-2:#bd7d77;
  --rose-deep:#a96a64;

  --gold:#bfa566;
  --gold-soft:#d8bd84;
  --gold-deep:#947d40;

  --green:#5e6e54;
  --green-deep:#46553e;
  --green-soft:#e2e7da;

  --ink:#403338;
  --ink-soft:#6f6065;
  --espresso:#2c2127;
  --white:#fff;

  --line:rgba(64,51,56,.14);
  --line-2:rgba(64,51,56,.08);
  --line-light:rgba(255,255,255,.16);

  --grad-gold:linear-gradient(135deg,#e3cd96,#bfa566 55%,#947d40);
  --grad-rose:linear-gradient(135deg,#dca9a1,#c0837c);
  --grad-rosegold:linear-gradient(120deg,#cf9a86,#c1837c 50%,#b08a52);

  --sh-sm:0 2px 6px -2px rgba(80,64,60,.08),0 10px 24px -12px rgba(120,85,76,.18);
  --sh:0 6px 18px -8px rgba(80,64,60,.12),0 30px 64px -30px rgba(110,78,70,.34);
  --sh-rose:0 14px 34px -14px rgba(189,125,119,.52);

  --r:20px;
  --r-lg:30px;
  --r-xl:38px;
  --container:1200px;
  --ease:cubic-bezier(.22,.61,.36,1);
  --serif:'Tenor Sans',Georgia,serif;
  --script:'Pinyon Script',cursive;
  --sans:'Montserrat',system-ui,sans-serif;
  --wm:'Cinzel',serif;
  --noise: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='0.9' numOctaves='2' stitchTiles='stitch'/%3E%3CfeColorMatrix type='saturate' values='0'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
  --ornament:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='72' height='9'%3E%3Cline x1='0' y1='4.5' x2='27' y2='4.5' stroke='%23bfa566' stroke-width='1'/%3E%3Crect x='32.5' y='1' width='6.4' height='6.4' transform='rotate(45 35.7 4.2)' fill='%23bfa566'/%3E%3Cline x1='45' y1='4.5' x2='72' y2='4.5' stroke='%23bfa566' stroke-width='1'/%3E%3C/svg%3E");
}

/* Textura sutil global (granulado fino, casi imperceptible, no afecta el texto) */
body::after{content:"";position:fixed;inset:0;z-index:5;pointer-events:none;background-image:var(--noise);background-size:150px 150px;opacity:.45;mix-blend-mode:soft-light}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%;overflow-x:clip}
body{
  font-family:var(--sans);background:var(--cream);color:var(--ink);
  font-size:17px;line-height:1.75;font-weight:400;overflow-x:hidden;-webkit-font-smoothing:antialiased;
}
img{display:block;max-width:100%;height:auto}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer;border:none;background:none;color:inherit}
ul{list-style:none}
:focus-visible{outline:2px solid var(--rose);outline-offset:3px;border-radius:6px}
::selection{background:var(--rose);color:#fff}
.container{width:100%;max-width:var(--container);margin-inline:auto;padding-inline:22px}
.section{padding-block:clamp(3.2rem,9vw,6.5rem);position:relative}

/* ---------- Typography ---------- */
.kicker{
  font-family:var(--script);font-size:clamp(1.5rem,4.6vw,2rem);
  color:var(--rose-deep);line-height:1;font-weight:400;
}
.sec-head{max-width:680px;margin:0 auto clamp(2rem,5vw,3.2rem);text-align:center;display:flex;flex-direction:column;align-items:center;gap:.55rem}
.sec-head::after{content:"";width:72px;height:9px;margin-top:.4rem;background:var(--ornament) center/contain no-repeat;opacity:.9}
.sec-title{
  font-family:var(--serif);font-weight:400;
  font-size:clamp(1.95rem,5vw,3.1rem);line-height:1.16;letter-spacing:.005em;color:var(--ink);
}
.sec-title em{font-style:normal;
  background:var(--grad-rosegold);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;color:transparent;}
.sec-title.light{color:#fff}
.sec-title.light em{background:var(--grad-gold);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}
.sec-lead{color:var(--ink-soft);font-size:1.12rem;max-width:50ch;font-weight:400}

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:.5em;
  font-family:var(--sans);font-weight:500;font-size:1rem;letter-spacing:.01em;
  padding:.9em 1.7em;border-radius:100px;min-height:52px;position:relative;overflow:hidden;isolation:isolate;
  transition:transform .3s var(--ease),box-shadow .3s var(--ease),background .3s,color .3s,border-color .3s;
}
.btn .ic{width:1.05em;height:1.05em;fill:currentColor;flex:none}
.btn:active{transform:scale(.97)}
.btn-rose{background:var(--grad-rose);color:#fff;box-shadow:var(--sh-rose)}
.btn-rose::after{content:"";position:absolute;inset:0;z-index:-1;background:linear-gradient(120deg,transparent 30%,rgba(255,255,255,.45) 50%,transparent 70%);transform:translateX(-120%);transition:transform .7s var(--ease)}
.btn-rose:hover{transform:translateY(-3px);box-shadow:0 20px 44px -12px rgba(189,125,119,.7)}
.btn-rose:hover::after{transform:translateX(120%)}
.btn-soft{background:#fff;color:var(--ink);border:1px solid var(--line);box-shadow:var(--sh-sm)}
.btn-soft:hover{transform:translateY(-3px);border-color:var(--rose);color:var(--rose-deep)}
.btn-gold{background:var(--grad-gold);color:#fff;box-shadow:0 14px 34px -12px rgba(148,125,64,.6)}
.btn-gold:hover{transform:translateY(-3px)}
.btn-sm{font-size:.92rem;padding:.72em 1.3em;min-height:46px}
.btn-lg{font-size:1.06rem;padding:1.05em 2em;min-height:58px}
.btn-block{width:100%}

/* ---------- Wordmark ---------- */
.wordmark{display:inline-flex;flex-direction:column;align-items:center;line-height:1;color:var(--ink)}
.wm-main{font-family:var(--wm);font-weight:600;letter-spacing:.12em;font-size:1.5rem;display:flex}
.wm-m{background:var(--grad-gold);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;color:transparent}
.wm-rest{color:currentColor}
.wm-sub{display:flex;align-items:center;gap:.5em;font-family:var(--sans);font-weight:400;font-size:.5rem;letter-spacing:.34em;text-transform:uppercase;margin-top:.6em;opacity:.82;color:currentColor;white-space:nowrap}
.wm-sub i{width:16px;height:1px;background:currentColor;opacity:.5;display:block}

/* ---------- Loader ---------- */
#loader{position:fixed;inset:0;z-index:200;background:radial-gradient(120% 120% at 50% 40%,#fbf2ec,#f3ddd6 75%);display:grid;place-items:center;transition:opacity .8s var(--ease),visibility .8s}
#loader.done{opacity:0;visibility:hidden}
.loader-inner{display:flex;flex-direction:column;align-items:center;gap:1.4rem}
.loader-mark{color:var(--ink)}
.loader-mark .wm-main{font-size:2.5rem;opacity:0;animation:lmIn .9s var(--ease) .15s forwards;letter-spacing:.16em}
.loader-mark .wm-sub{opacity:0;animation:lmIn .8s var(--ease) .55s forwards}
@keyframes lmIn{from{opacity:0;transform:translateY(12px)}to{opacity:.92;transform:translateY(0)}}
.loader-bar{width:120px;height:2px;background:rgba(168,106,100,.22);border-radius:2px;overflow:hidden}
.loader-bar span{display:block;height:100%;width:0;background:var(--grad-rose);animation:lbar 1.4s var(--ease) .3s forwards}
@keyframes lbar{to{width:100%}}

/* ---------- Scroll progress ---------- */
.scroll-progress{position:fixed;top:0;left:0;right:0;height:3px;z-index:120;pointer-events:none}
.scroll-progress span{display:block;height:100%;width:0;background:var(--grad-rosegold)}

/* ---------- Nav ---------- */
.nav{position:fixed;top:0;left:0;right:0;z-index:100;display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:15px 22px;transition:background .4s var(--ease),box-shadow .4s,padding .3s,backdrop-filter .4s}
.nav.scrolled{background:rgba(251,246,240,.85);backdrop-filter:blur(14px) saturate(140%);box-shadow:0 1px 0 var(--line-2),0 12px 30px -22px rgba(120,75,70,.5);padding-block:10px}
.nav .wm-main{font-size:1.2rem;letter-spacing:.14em}
.nav .wm-sub{font-size:.4rem;margin-top:.35em}
.nav-links{display:none;gap:1.8rem;font-size:.98rem;font-weight:400}
.nav-links a{position:relative;padding:.3em 0;color:var(--ink)}
.nav-links a::after{content:"";position:absolute;left:0;bottom:0;width:0;height:1.5px;background:var(--grad-rose);transition:width .3s var(--ease)}
.nav-links a:hover{color:var(--rose-deep)}
.nav-links a:hover::after{width:100%}
.nav-actions{display:flex;align-items:center;gap:.7rem}
.nav .btn-sm{display:none}
.nav-toggle{width:46px;height:46px;display:grid;place-content:center;gap:5px;border-radius:12px}
.nav-toggle span{width:24px;height:2px;background:var(--ink);border-radius:2px;transition:.3s var(--ease)}
.nav-toggle[aria-expanded="true"] span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.nav-toggle[aria-expanded="true"] span:nth-child(2){opacity:0}
.nav-toggle[aria-expanded="true"] span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

/* Drawer */
.drawer{position:fixed;top:0;right:0;bottom:0;width:min(86vw,360px);z-index:110;background:linear-gradient(165deg,#fdf7f3,#f4ddd5);padding:90px 26px 30px;display:flex;flex-direction:column;gap:1.1rem;transform:translateX(100%);transition:transform .45s var(--ease);box-shadow:-20px 0 60px -22px rgba(120,75,70,.5)}
.drawer.open{transform:translateX(0)}
.drawer-links{display:flex;flex-direction:column;gap:.1rem}
.drawer-links a{font-family:var(--serif);font-size:1.3rem;color:var(--ink);padding:.5rem 0;border-bottom:1px solid var(--line-2);transition:color .2s,padding-left .2s}
.drawer-links a:hover{color:var(--rose-deep);padding-left:.4rem}
.drawer .btn{margin-top:.3rem}
.drawer-backdrop{position:fixed;inset:0;z-index:105;background:rgba(60,40,42,.4);backdrop-filter:blur(3px);opacity:0;visibility:hidden;transition:.4s}
.drawer-backdrop.open{opacity:1;visibility:visible}

/* ---------- Hero ---------- */
.hero{position:relative;overflow:hidden;padding-top:108px;padding-bottom:clamp(2.5rem,6vw,4rem);background:radial-gradient(125% 90% at 80% 8%,rgba(255,255,255,.55),transparent 52%),radial-gradient(100% 80% at 12% 95%,rgba(201,139,134,.18),transparent 55%),linear-gradient(170deg,#fdf6f1 0%,#f6e2da 52%,#ece2ee 100%)}
.hero-grid{display:grid;gap:clamp(2rem,5vw,3rem);align-items:center}
.hero-copy{position:relative;z-index:2}
.hero-title{font-family:var(--serif);font-weight:400;font-size:clamp(2.4rem,7.2vw,4.5rem);line-height:1.1;letter-spacing:.005em;color:var(--ink);margin:.6rem 0 1rem}
.hero-title em{font-style:normal;background:var(--grad-rosegold);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;color:transparent}
.hero-sub{font-size:clamp(1.08rem,2.4vw,1.22rem);color:var(--ink-soft);max-width:46ch;font-weight:400;line-height:1.7}
.hero-cta{display:flex;flex-wrap:wrap;gap:.8rem;margin-top:1.7rem}
.hero-cta.center{justify-content:center}
.hero-trust{display:flex;align-items:center;flex-wrap:wrap;gap:.5rem;margin-top:1.6rem;font-size:.98rem;color:var(--ink-soft)}
.hero-trust b{color:var(--ink)}
.stars{color:var(--gold);letter-spacing:.08em}

.hero-media{position:relative;z-index:1}
.hero-img-card{position:relative;border-radius:160px 160px var(--r-xl) var(--r-xl);overflow:hidden;box-shadow:var(--sh);aspect-ratio:4/5;max-width:460px;margin-inline:auto;border:6px solid #fff}
.hero-img-card img{width:100%;height:100%;object-fit:cover;object-position:50% 30%}
.hero-chip{position:absolute;background:rgba(255,255,255,.93);backdrop-filter:blur(6px);border-radius:18px;box-shadow:var(--sh-sm);display:flex;align-items:center;gap:.5rem;padding:.65rem .9rem;z-index:3}
.chip-rating{left:-6px;bottom:24%;flex-direction:column;align-items:flex-start;gap:.1rem}
.chip-rating .stars{font-size:.85rem}
.chip-rating b{font-family:var(--serif);font-size:1.2rem;color:var(--ink);line-height:1}
.chip-rating i{font-style:normal;font-size:.72rem;color:var(--ink-soft)}
.chip-tags{right:-4px;top:16%;gap:.35rem;padding:.55rem .75rem}
.chip-tags span{font-size:.72rem;background:var(--blush);color:var(--rose-deep);padding:.32em .75em;border-radius:100px;font-weight:500}
.hero-script{position:absolute;right:2%;bottom:-4%;font-family:var(--script);font-size:clamp(3rem,9vw,5.5rem);color:var(--rose);opacity:.22;z-index:0;pointer-events:none}
.hero-blob{position:absolute;border-radius:50%;filter:blur(8px);z-index:0;pointer-events:none}
.hb1{width:340px;height:340px;background:radial-gradient(circle,rgba(201,139,134,.30),transparent 70%);top:-80px;right:-60px;animation:float1 11s ease-in-out infinite}
.hb2{width:260px;height:260px;background:radial-gradient(circle,rgba(191,165,102,.22),transparent 70%);bottom:-60px;left:-50px;animation:float2 13s ease-in-out infinite}
.hero-petal{position:absolute;width:14px;height:14px;border-radius:0 50% 50% 50%;background:var(--rose);opacity:.5;z-index:0}
.p1{top:22%;left:8%;animation:floatP 7s ease-in-out infinite}
.p2{top:62%;right:14%;width:10px;height:10px;background:var(--gold);animation:floatP 9s ease-in-out infinite 1s}
@keyframes float1{0%,100%{transform:translateY(0)}50%{transform:translateY(-24px)}}
@keyframes float2{0%,100%{transform:translateY(0)}50%{transform:translateY(20px)}}
@keyframes floatP{0%,100%{transform:translateY(0) rotate(0)}50%{transform:translateY(-16px) rotate(45deg)}}
.scroll-cue{position:absolute;left:50%;bottom:14px;translate:-50% 0;width:26px;height:42px;border:1.5px solid var(--rose);border-radius:30px;display:grid;justify-items:center;padding-top:7px;z-index:3;opacity:.7}
.scroll-cue span{width:4px;height:9px;border-radius:4px;background:var(--rose);animation:cue 1.6s ease-in-out infinite}
@keyframes cue{0%{opacity:0;transform:translateY(-4px)}40%{opacity:1}80%{opacity:0;transform:translateY(12px)}}

/* ---------- Marquee ---------- */
.marquee{background:var(--grad-rose);color:#fff;overflow:hidden;padding:13px 0}
.marquee-track{display:flex;align-items:center;gap:1.4rem;width:max-content;animation:marq 38s linear infinite;font-family:var(--serif);font-size:1.02rem;letter-spacing:.12em;text-transform:uppercase}
.marquee-track i{font-style:normal;font-size:.7rem;opacity:.7}
@keyframes marq{to{transform:translateX(-50%)}}

/* ---------- About / Nosotros ---------- */
.about{background:var(--cream)}
.about-grid{display:grid;gap:clamp(2rem,5vw,3.5rem);align-items:center}
.about-media{position:relative;padding-bottom:2rem}
.about-img{border-radius:var(--r-lg);overflow:hidden;box-shadow:var(--sh)}
.about-img.main{aspect-ratio:5/4}
.about-img.main img{width:100%;height:100%;object-fit:cover}
.about-img.sub{position:absolute;width:42%;aspect-ratio:3/4;right:0;bottom:0;border:6px solid var(--cream);box-shadow:var(--sh)}
.about-img.sub img{width:100%;height:100%;object-fit:cover}
.about-stat{position:absolute;left:0;top:18px;background:#fff;border-radius:18px;padding:.75rem 1.05rem;box-shadow:var(--sh-sm);text-align:center}
.about-stat b{font-family:var(--serif);font-size:1.7rem;color:var(--rose-deep);display:block;line-height:1}
.about-stat span{font-size:.72rem;color:var(--ink-soft);letter-spacing:.03em}
.about-copy p{color:var(--ink-soft);margin-top:1rem;font-size:1.05rem}
.about-points{display:grid;gap:.7rem;margin-top:1.5rem}
.about-points li{display:flex;align-items:center;gap:.7rem;font-size:1.05rem;color:var(--ink)}
.about-points svg{width:24px;height:24px;flex:none;fill:none;stroke:var(--rose);stroke-width:2.4;stroke-linecap:round;stroke-linejoin:round;background:var(--blush);border-radius:50%;padding:4px;box-sizing:border-box}
.about-sign{display:flex;align-items:center;gap:1.3rem;flex-wrap:wrap;margin-top:1.8rem}
.script-sign{font-family:var(--script);font-size:2rem;color:var(--rose-deep)}

/* ---------- Services ---------- */
.services{background:linear-gradient(180deg,#fbf3ef,#f2eaf2)}
.svc-grid{display:grid;grid-template-columns:1fr;gap:1.3rem}
.svc-card{background:#fff;border-radius:var(--r-lg);overflow:hidden;box-shadow:var(--sh-sm);border:1px solid rgba(64,51,56,.05);transition:transform .4s var(--ease),box-shadow .4s;display:flex;flex-direction:column}
.svc-card:hover{transform:translateY(-6px);box-shadow:var(--sh)}
.svc-img{aspect-ratio:16/11;overflow:hidden}
.svc-img img{width:100%;height:100%;object-fit:cover;transition:transform .8s var(--ease)}
.svc-card:hover .svc-img img{transform:scale(1.06)}
.svc-body{padding:1.4rem 1.5rem 1.6rem;display:flex;flex-direction:column;flex:1}
.svc-body h3{font-family:var(--serif);font-weight:400;font-size:1.5rem;color:var(--ink);letter-spacing:.01em}
.svc-body p{font-size:1rem;color:var(--ink-soft);margin:.35rem 0 .9rem;line-height:1.6}
.svc-list{display:grid;gap:.4rem;margin-bottom:1.2rem}
.svc-list li{font-size:.96rem;color:var(--ink);padding-left:1.2rem;position:relative}
.svc-list li::before{content:"";position:absolute;left:0;top:.55em;width:6px;height:6px;border-radius:50%;background:var(--grad-rose)}
.svc-link{margin-top:auto;align-self:flex-start;display:inline-flex;align-items:center;gap:.45em;font-weight:500;font-size:.98rem;color:var(--rose-deep);transition:gap .25s}
.svc-link svg{width:18px;height:18px;fill:none;stroke:currentColor;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}
.svc-link:hover{gap:.75em}

/* ---------- Producto estrella (L'Oréal) ---------- */
.star{background:linear-gradient(180deg,#f2eaf2,#faf0e9);position:relative;overflow:hidden}
.star-glow{position:absolute;width:440px;height:440px;border-radius:50%;background:radial-gradient(circle,rgba(191,165,102,.20),transparent 65%);top:-140px;right:-90px;pointer-events:none}
.star-grid{display:grid;gap:clamp(1.8rem,5vw,3.2rem);align-items:center;position:relative;z-index:1}
.star-media{position:relative}
.star-img{border-radius:var(--r-lg);overflow:hidden;box-shadow:var(--sh);aspect-ratio:4/5;border:6px solid #fff}
.star-img img{width:100%;height:100%;object-fit:cover}
.star-tag{position:absolute;left:-6px;bottom:26px;background:var(--grad-gold);color:#fff;font-size:.82rem;letter-spacing:.08em;text-transform:uppercase;padding:.55em 1.1em;border-radius:100px;box-shadow:var(--sh-sm);font-weight:500}
.star-brand{display:inline-flex;flex-direction:column;align-items:flex-start;gap:.25rem;margin:.5rem 0 1.1rem;padding:.95rem 1.4rem;border:1px solid var(--gold);border-radius:14px;background:rgba(255,255,255,.55);max-width:100%}
.star-brand-name{font-family:var(--serif);font-size:clamp(1.8rem,5.2vw,2.7rem);letter-spacing:.14em;color:var(--ink);line-height:1}
.star-brand-sub{font-family:var(--sans);font-size:.76rem;letter-spacing:.2em;text-transform:uppercase;color:var(--gold-deep)}
.star-text{color:var(--ink-soft);font-size:1.06rem;line-height:1.7}
.star-points{display:grid;gap:.6rem;margin:1.2rem 0 1.7rem}
.star-points li{display:flex;align-items:center;gap:.7rem;font-size:1.02rem;color:var(--ink)}
.star-points svg{width:22px;height:22px;flex:none;fill:none;stroke:var(--gold-deep);stroke-width:2.4;stroke-linecap:round;stroke-linejoin:round;background:rgba(191,165,102,.16);border-radius:50%;padding:4px;box-sizing:border-box}

/* ---------- Why ---------- */
.why{background:var(--nude)}
.why-grid{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
.why-card{background:rgba(255,255,255,.7);border:1px solid var(--line-2);border-radius:var(--r);padding:1.5rem 1.3rem;display:flex;flex-direction:column;gap:.55rem;transition:transform .35s var(--ease),background .35s}
.why-card:hover{transform:translateY(-5px);background:#fff}
.why-ic{width:52px;height:52px;border-radius:16px;display:grid;place-content:center;background:var(--blush)}
.why-ic svg{width:27px;height:27px;fill:var(--rose-deep)}
.why-card h3{font-family:var(--serif);font-weight:400;font-size:1.18rem;color:var(--ink);letter-spacing:.01em}
.why-card p{font-size:.96rem;color:var(--ink-soft);line-height:1.55}

/* ---------- Experience ---------- */
.experience{position:relative;overflow:hidden;color:#fff;text-align:center}
.exp-bg{position:absolute;inset:0;z-index:0}
.exp-bg img{width:100%;height:100%;object-fit:cover}
.experience::after{content:"";position:absolute;inset:0;z-index:1;background:linear-gradient(180deg,rgba(44,33,39,.78),rgba(44,33,39,.86)),radial-gradient(80% 70% at 50% 0%,rgba(191,165,102,.25),transparent 60%)}
.exp-inner{position:relative;z-index:2;display:flex;flex-direction:column;align-items:center;gap:.5rem;max-width:740px}
.exp-inner .kicker{color:var(--gold-soft)}
.exp-text{color:rgba(255,255,255,.85);font-size:1.1rem;margin:.7rem 0 .4rem;max-width:56ch;line-height:1.7}
.stats{display:grid;grid-template-columns:1fr 1fr;gap:1rem;width:100%;margin:1.7rem 0 1.9rem}
.stat{background:rgba(255,255,255,.06);border:1px solid var(--line-light);border-radius:var(--r);padding:1.2rem .8rem;backdrop-filter:blur(4px)}
.stat b{display:block;font-family:var(--serif);font-weight:400;font-size:2.2rem;line-height:1;background:var(--grad-gold);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}
.stat span{font-size:.82rem;color:rgba(255,255,255,.74);margin-top:.4rem;display:block}

/* ---------- Gallery ---------- */
.gallery{background:var(--cream)}
.gal-track{display:flex;gap:16px;overflow-x:auto;scroll-snap-type:x mandatory;padding:6px 22px 20px;scrollbar-width:none;-webkit-overflow-scrolling:touch;scroll-padding-left:22px}
.gal-track::-webkit-scrollbar{display:none}
.gal-item{position:relative;flex:0 0 74%;max-width:330px;scroll-snap-align:center;aspect-ratio:3/4;border-radius:var(--r-lg);overflow:hidden;box-shadow:var(--sh);isolation:isolate}
.gal-item img{width:100%;height:100%;object-fit:cover;transition:transform .8s var(--ease)}
.gal-item::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 50%,rgba(44,33,39,.6));z-index:1}
.gal-item figcaption{position:absolute;left:16px;bottom:14px;z-index:2;color:#fff;font-family:var(--serif);font-size:1.18rem;letter-spacing:.02em}
.gal-item:hover img{transform:scale(1.07)}
.gal-dots,.tst-dots{display:flex;justify-content:center;gap:7px;margin-top:.4rem}
.gal-dots button,.tst-dots button{width:7px;height:7px;border-radius:50%;background:var(--blush-2);transition:.3s var(--ease)}
.gal-dots button.on,.tst-dots button.on{width:22px;border-radius:5px;background:var(--grad-rose)}

/* ---------- Packages ---------- */
.packages{background:linear-gradient(180deg,#f2eaf2,#f8e9e3)}
.pkg-grid{display:grid;grid-template-columns:1fr;gap:1.3rem}
.pkg-card{position:relative;background:#fff;border-radius:var(--r-lg);overflow:hidden;box-shadow:var(--sh-sm);border:1px solid rgba(64,51,56,.05);transition:transform .4s var(--ease),box-shadow .4s;display:flex;flex-direction:column}
.pkg-card:hover{transform:translateY(-6px);box-shadow:var(--sh)}
.pkg-card.featured{outline:2px solid var(--rose);outline-offset:-2px}
.pkg-badge{position:absolute;top:14px;right:14px;z-index:3;background:var(--grad-rose);color:#fff;font-size:.72rem;font-weight:600;letter-spacing:.06em;text-transform:uppercase;padding:.42em .9em;border-radius:100px;box-shadow:var(--sh-sm)}
.pkg-img{aspect-ratio:16/10;overflow:hidden}
.pkg-img img{width:100%;height:100%;object-fit:cover;transition:transform .8s var(--ease)}
.pkg-card:hover .pkg-img img{transform:scale(1.06)}
.pkg-body{padding:1.5rem 1.6rem 1.7rem;display:flex;flex-direction:column;flex:1}
.pkg-body h3{font-family:var(--serif);font-weight:400;font-size:1.5rem;color:var(--ink);letter-spacing:.01em}
.pkg-body>p{font-size:.98rem;color:var(--ink-soft);margin:.3rem 0 1rem}
.pkg-body ul{display:grid;gap:.5rem;margin-bottom:1.4rem}
.pkg-body ul li{font-size:.95rem;color:var(--ink);padding-left:1.5rem;position:relative}
.pkg-body ul li::before{content:"✦";position:absolute;left:0;color:var(--gold);font-size:.8rem;top:.1em}
.pkg-body .btn{margin-top:auto}

/* ---------- Testimonials ---------- */
.testimonials{background:var(--blush)}
.tst-track{display:flex;gap:16px;overflow-x:auto;scroll-snap-type:x mandatory;padding:6px 22px 20px;scrollbar-width:none;scroll-padding-left:22px}
.tst-track::-webkit-scrollbar{display:none}
.tst-card{flex:0 0 84%;max-width:380px;scroll-snap-align:center;background:#fff;border-radius:var(--r-lg);padding:1.7rem 1.6rem;box-shadow:var(--sh-sm);display:flex;flex-direction:column;gap:.9rem;position:relative}
.tst-card::before{content:"\201C";position:absolute;top:.1rem;right:1.1rem;font-family:var(--serif);font-size:4rem;color:var(--rose);opacity:.2;line-height:1}
.tst-stars{color:var(--gold);letter-spacing:.12em}
.tst-card blockquote{font-family:var(--sans);font-size:1.12rem;line-height:1.6;color:var(--ink);font-weight:400;font-style:italic}
.tst-card figcaption{display:flex;align-items:center;gap:.7rem;margin-top:auto}
.avatar{width:46px;height:46px;border-radius:50%;display:grid;place-content:center;font-weight:600;font-size:.92rem;color:#fff;background:var(--c,var(--rose));box-shadow:0 0 0 2px #fff,0 0 0 3px var(--gold-soft)}
.tst-who{display:flex;flex-direction:column;line-height:1.25}
.tst-who b{font-weight:600;color:var(--ink);font-size:.98rem}
.tst-who i{font-style:normal;font-size:.82rem;color:var(--rose-deep)}

/* ---------- FAQ ---------- */
.faq{background:var(--cream)}
.faq-grid{display:grid;gap:2rem}
.faq-intro .sec-title{text-align:left}
.faq-intro .sec-head{text-align:left;align-items:flex-start}
.faq-intro .btn{margin-top:1.2rem}
.faq-list{display:flex;flex-direction:column;gap:.8rem}
.faq-item{background:#fff;border:1px solid var(--line-2);border-radius:var(--r);box-shadow:var(--sh-sm);overflow:hidden}
.faq-item summary{list-style:none;cursor:pointer;padding:1.1rem 1.35rem;display:flex;align-items:center;justify-content:space-between;gap:1rem;font-weight:500;font-size:1.08rem;color:var(--ink)}
.faq-item summary::-webkit-details-marker{display:none}
.faq-x{position:relative;width:18px;height:18px;flex:none}
.faq-x::before,.faq-x::after{content:"";position:absolute;background:var(--rose-deep);border-radius:2px;transition:transform .3s var(--ease)}
.faq-x::before{top:8px;left:0;width:18px;height:2px}
.faq-x::after{left:8px;top:0;width:2px;height:18px}
.faq-item[open] .faq-x::after{transform:rotate(90deg);opacity:0}
.faq-a{padding:0 1.35rem 1.25rem;color:var(--ink-soft);font-size:1rem;line-height:1.65}
.faq-item[open] .faq-a{animation:faqIn .35s var(--ease)}
@keyframes faqIn{from{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:translateY(0)}}

/* ---------- Location ---------- */
.location{background:linear-gradient(180deg,#edefe6,#fbf6f0 60%)}
.loc-leaf{position:absolute;top:clamp(.6rem,3vw,2rem);right:clamp(-14px,1vw,1rem);width:clamp(86px,13vw,150px);opacity:.45;pointer-events:none;color:var(--green);z-index:0}
.loc-leaf svg{width:100%;height:auto;display:block}
.entorno{display:flex;flex-wrap:wrap;justify-content:center;gap:.7rem;margin:0 auto clamp(1.7rem,4vw,2.6rem);max-width:820px;position:relative;z-index:1}
.entorno li{display:inline-flex;align-items:center;gap:.55rem;background:#fff;border:1px solid var(--line-2);border-radius:100px;padding:.62rem 1.15rem;font-size:.95rem;color:var(--ink);box-shadow:var(--sh-sm)}
.entorno svg{width:20px;height:20px;flex:none;fill:none;stroke:var(--green);stroke-width:1.8;stroke-linecap:round;stroke-linejoin:round}
.loc-grid{display:grid;gap:1.2rem;position:relative;z-index:1}
.loc-map{border-radius:var(--r-lg);overflow:hidden;box-shadow:var(--sh);border:6px solid #fff;aspect-ratio:4/3;background:var(--nude)}
.loc-map iframe{width:100%;height:100%;border:0;filter:grayscale(.15) contrast(1.02)}
.loc-card{background:linear-gradient(165deg,#322329,#241a20);color:var(--cream);border-radius:var(--r-lg);padding:1.8rem 1.7rem;box-shadow:var(--sh);display:flex;flex-direction:column;gap:1.2rem}
.loc-mark{align-items:flex-start;color:var(--cream)}
.loc-mark .wm-main{font-size:1.5rem}
.loc-info{display:flex;flex-direction:column;gap:1rem}
.loc-info li{display:flex;gap:.8rem;align-items:flex-start;font-size:1rem;color:rgba(255,255,255,.85)}
.loc-info b{color:#fff}
.loc-info .ic{width:34px;height:34px;flex:none;fill:var(--gold-soft);background:rgba(191,165,102,.16);border-radius:10px;padding:7px;box-sizing:border-box}
.loc-cta{display:flex;gap:.6rem;flex-wrap:wrap}
.loc-card .btn-soft{background:transparent;color:#fff;border-color:var(--line-light)}
.loc-card .btn-soft:hover{background:rgba(255,255,255,.1);color:#fff}

/* ---------- CTA final ---------- */
.cta-final{position:relative;overflow:hidden;text-align:center;padding-block:clamp(3.5rem,11vw,6.5rem);background:linear-gradient(140deg,#f7e3db,#efe3ef 60%,#f4ddd5)}
.cta-petal{position:absolute;border-radius:50%;filter:blur(10px);pointer-events:none}
.cp1{width:280px;height:280px;background:radial-gradient(circle,rgba(201,139,134,.4),transparent 70%);top:-70px;left:-40px;animation:float1 12s ease-in-out infinite}
.cp2{width:230px;height:230px;background:radial-gradient(circle,rgba(191,165,102,.3),transparent 70%);bottom:-60px;right:-30px;animation:float2 14s ease-in-out infinite}
.cta-inner{position:relative;z-index:1;display:flex;flex-direction:column;align-items:center;gap:.5rem}
.cta-title{font-family:var(--serif);font-weight:400;font-size:clamp(2rem,6vw,3.3rem);line-height:1.12;letter-spacing:.005em;max-width:20ch;color:var(--ink)}
.cta-title em{font-style:normal;background:var(--grad-rosegold);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;color:transparent}
.cta-sub{color:var(--ink-soft);margin-bottom:1.2rem;font-size:1.08rem}

/* ---------- Footer ---------- */
.footer{background:var(--espresso);color:rgba(255,255,255,.74);padding-top:clamp(2.8rem,8vw,4rem)}
.foot-grid{display:grid;grid-template-columns:1fr 1fr;gap:2rem 1.2rem;padding-bottom:2rem}
.foot-brand{grid-column:span 2;display:flex;flex-direction:column;gap:1rem;align-items:flex-start}
.foot-mark{color:var(--cream);align-items:flex-start}
.foot-brand p{font-size:.96rem;max-width:38ch;line-height:1.6}
.socials{display:flex;gap:.6rem}
.socials a{width:44px;height:44px;border-radius:12px;display:grid;place-content:center;background:rgba(255,255,255,.06);border:1px solid var(--line-light);transition:.3s var(--ease)}
.socials svg{width:19px;height:19px;fill:var(--gold-soft)}
.socials a:hover{background:var(--grad-rose);transform:translateY(-3px)}
.socials a:hover svg{fill:#fff}
.foot-col{display:flex;flex-direction:column;gap:.55rem}
.foot-col h4{font-family:var(--wm);font-size:.78rem;letter-spacing:.2em;text-transform:uppercase;color:var(--gold-soft);margin-bottom:.3rem}
.foot-col a,.foot-hours{font-size:.95rem;color:rgba(255,255,255,.68);transition:color .2s}
.foot-col a:hover{color:var(--gold-soft)}
.foot-col .btn{margin-top:.4rem;align-self:flex-start}
.foot-bottom{display:flex;flex-direction:column;gap:.4rem;text-align:center;padding-block:1.3rem;border-top:1px solid var(--line-light);font-size:.82rem;color:rgba(255,255,255,.55)}

/* ---------- Mobile floating CTA ---------- */
.mobile-cta{position:fixed;left:12px;right:12px;bottom:12px;z-index:90;display:flex;gap:8px;padding:8px;border-radius:100px;background:rgba(255,255,255,.93);backdrop-filter:blur(14px);border:1px solid var(--line-2);box-shadow:0 12px 36px -10px rgba(120,75,70,.45);transform:translateY(140%);transition:transform .45s var(--ease)}
.mobile-cta.show{transform:translateY(0)}
.mc-btn{flex:1;display:flex;align-items:center;justify-content:center;gap:.4em;min-height:50px;border-radius:100px;font-weight:600;font-size:.96rem}
.mc-wa{background:var(--cream-2);color:var(--ink);border:1px solid var(--line-2)}
.mc-wa svg{width:18px;height:18px;fill:#25d366}
.mc-book{background:var(--grad-rose);color:#fff}

/* ---------- Modal ---------- */
.modal{position:fixed;inset:0;z-index:150;display:grid;place-items:center;padding:20px;visibility:hidden;opacity:0;transition:.35s var(--ease)}
.modal.open{visibility:visible;opacity:1}
.modal-backdrop{position:absolute;inset:0;background:rgba(60,40,42,.5);backdrop-filter:blur(5px)}
.modal-card{position:relative;width:100%;max-width:430px;background:var(--cream);border-radius:var(--r-lg);padding:2rem 1.7rem 1.8rem;box-shadow:0 40px 90px -22px rgba(60,40,42,.55);transform:translateY(24px) scale(.98);transition:transform .4s var(--ease);max-height:90vh;overflow-y:auto}
.modal.open .modal-card{transform:none}
.modal-x{position:absolute;top:12px;right:14px;width:40px;height:40px;border-radius:50%;font-size:1.5rem;color:var(--ink-soft);background:#fff;display:grid;place-content:center;transition:.2s}
.modal-x:hover{background:var(--rose);color:#fff;transform:rotate(90deg)}
.modal-card h3{font-family:var(--serif);font-weight:400;font-size:1.7rem;color:var(--ink);margin:.1rem 0 .3rem;letter-spacing:.01em}
.modal-lead{font-size:.96rem;color:var(--ink-soft);margin-bottom:1.2rem}
.book-form{display:flex;flex-direction:column;gap:.95rem}
.book-form label{display:flex;flex-direction:column;gap:.35rem;font-size:.85rem;font-weight:500;color:var(--ink);letter-spacing:.01em}
.book-form input,.book-form select{font-family:inherit;font-size:1rem;font-weight:400;color:var(--ink);padding:.8em .9em;border:1px solid var(--line);border-radius:12px;background:#fff;transition:border-color .2s,box-shadow .2s;width:100%}
.book-form input:focus,.book-form select:focus{outline:none;border-color:var(--rose);box-shadow:0 0 0 3px rgba(201,139,134,.18)}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:.7rem}
.book-form .btn{margin-top:.4rem}

/* ---------- Reveal ---------- */
[data-reveal]{opacity:0;transform:translateY(28px);transition:opacity .8s var(--ease),transform .8s var(--ease);transition-delay:var(--d,0s)}
[data-reveal].in{opacity:1;transform:translateY(0)}
.svc-card[data-reveal],.why-card[data-reveal],.pkg-card[data-reveal]{transition-delay:calc(var(--i,0)*.08s)}
.tilt-soft{transition:transform .3s var(--ease)}

/* ---------- Responsive ---------- */
@media (min-width:600px){
  .svc-grid{grid-template-columns:1fr 1fr}
  .pkg-grid{grid-template-columns:1fr 1fr}
  .gal-item{flex-basis:300px}
  .tst-card{flex-basis:360px}
}
@media (min-width:900px){
  .hero-grid{grid-template-columns:1.05fr .95fr}
  .hero-copy{padding-right:1rem}
  .about-grid{grid-template-columns:1fr 1.05fr}
  .star-grid{grid-template-columns:.92fr 1.08fr}
  .svc-grid{grid-template-columns:repeat(3,1fr)}
  .pkg-grid{grid-template-columns:repeat(3,1fr)}
  .why-grid{grid-template-columns:repeat(4,1fr)}
  .stats{grid-template-columns:repeat(4,1fr)}
  .faq-grid{grid-template-columns:.85fr 1.15fr;align-items:start}
  .loc-grid{grid-template-columns:1.3fr 1fr;align-items:stretch}
  .loc-map{aspect-ratio:auto}
  .foot-grid{grid-template-columns:2fr 1fr 1fr 1.3fr}
  .foot-brand{grid-column:auto}
  .nav-links{display:flex}
  .nav .btn-sm{display:inline-flex}
  .nav-toggle{display:none}
  .mobile-cta{display:none}
  .gal-track,.tst-track{padding-inline:max(22px,calc((100vw - var(--container))/2 + 22px))}
  body{font-size:18px}
}
@media (min-width:1100px){ .gal-item{flex-basis:320px} }

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