/* ============================================================
   RENTAL BLISS · "MAREA" — descenso del cielo al lecho marino
   Concept: la página es una costa viva. Fondo fijo: cielo que
   desciende a mar profundo, sol del logo que baja, y una palmera
   hecha a mano cuyas hojas se mecen con la velocidad del scroll.
   GPU-only (transform/opacity). gpt-taste + high-end-visual-design.
   ============================================================ */

:root{
  --navy:#0A1A2E;        --navy-2:#0d2236;     --navy-3:#102b44;
  --deep:#05101c;
  --gold:#F3B13B;        --gold-soft:#E8D9B5;  --gold-deep:#c8893f;
  --sand:#F4EDE0;        --sand-warm:#EBDDC4;
  --turq:#1FA39A;        --turq-light:#6FD0C9; --aqua:#3FBfc4;
  --coral:#F07A5C;       --coral-soft:#F5A98E;
  --bone:#FAF7F2;
  --ink:#FAF7F2;         --ink-2:#cdd8e2;      --ink-3:#8ea2b4;
  --ink-dark:#0A1A2E;    --ink-dark-2:#3a5066;

  --font-display:'Clash Display','Iowan Old Style',Georgia,serif;
  --font-body:'Satoshi',-apple-system,BlinkMacSystemFont,'Helvetica Neue',Arial,sans-serif;

  --e-soft:cubic-bezier(.32,.72,0,1);
  --e-out:cubic-bezier(.16,1,.3,1);
  --e-in:cubic-bezier(.7,0,.84,0);

  --maxw:1320px;
  --pad:clamp(20px,5vw,64px);
}

*,*::before,*::after{box-sizing:border-box}
html,body{overflow-x:clip;margin:0;padding:0;min-width:0}
html{-webkit-text-size-adjust:100%}/* scroll-behavior:smooth quitado: rompe el pin de ScrollTrigger al subir rápido */
body{
  font-family:var(--font-body);
  background:var(--deep);
  color:var(--ink);
  line-height:1.55;
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
  font-feature-settings:'ss01','cv01';
}
img,svg{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
ul{list-style:none;margin:0;padding:0}
h1,h2,h3,h4,p{margin:0;overflow-wrap:anywhere}
button{font:inherit;cursor:pointer;color:inherit;background:none;border:none}

/* film grain — fixed pseudo-element, never on scrolling content */
body::after{
  content:'';position:fixed;inset:0;z-index:120;pointer-events:none;opacity:.05;mix-blend-mode:overlay;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='200' height='200'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.8' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}

/* ===== THE LIVING WORLD (fixed background) ===== */
.world{position:fixed;inset:0;z-index:0;overflow:hidden;pointer-events:none}
.layer{position:absolute;inset:-2%;will-change:opacity}
.l-dawn{
  opacity:1;
  background:
    radial-gradient(120% 80% at 78% 6%, rgba(243,177,59,.55), transparent 46%),
    radial-gradient(90% 60% at 20% 0%, rgba(240,122,92,.30), transparent 50%),
    linear-gradient(180deg,#13243b 0%, #1a3454 38%, #2a5572 64%, #3f7e86 100%);
}
.l-shallow{
  opacity:0;
  background:
    radial-gradient(80% 50% at 70% 12%, rgba(243,177,59,.20), transparent 55%),
    linear-gradient(180deg,#2a6f78 0%, #1f8c8a 40%, #1a7f86 70%, #0f4f5e 100%);
}
.l-deep{
  opacity:0;
  background:linear-gradient(180deg,#0c4651 0%, #0a3140 45%, #071f2c 78%, #05101c 100%);
}
/* caustic shimmer for the deep, GPU transform only */
.caustics{
  position:absolute;inset:-30%;opacity:0;mix-blend-mode:soft-light;
  background:
    radial-gradient(closest-side at 30% 40%, rgba(111,208,201,.5), transparent 70%),
    radial-gradient(closest-side at 70% 60%, rgba(63,191,196,.4), transparent 70%),
    radial-gradient(closest-side at 50% 80%, rgba(255,255,255,.25), transparent 70%);
  background-size:55% 55%,48% 48%,60% 60%;
  background-repeat:no-repeat;
  animation:caustic 14s linear infinite alternate;
  will-change:transform;
}
@keyframes caustic{
  0%{transform:translate3d(-3%,-2%,0) scale(1)}
  100%{transform:translate3d(4%,3%,0) scale(1.12)}
}

/* SUN — the logo motif, fixed, descends with scroll */
.sun{position:absolute;top:8vh;right:12vw;width:min(34vw,360px);height:min(34vw,360px);will-change:transform}
.sun svg{width:100%;height:100%;color:var(--gold);filter:drop-shadow(0 0 60px rgba(243,177,59,.45))}

/* PALM — hand-built, fronds react to scroll velocity */
.palm{position:absolute;left:-4vw;bottom:-2vh;width:min(70vw,720px);height:auto;will-change:transform}
.palm svg{width:100%;height:auto;overflow:visible}
.palm .trunk{fill:none;stroke:#0a1a2e;stroke-width:13;stroke-linecap:round;opacity:.92}
.palm .trunk-2{fill:none;stroke:#143553;stroke-width:5;stroke-linecap:round;opacity:.6}
.palm .frond{fill:#0a1a2e;opacity:.94}
.palm .frond.lit{fill:#103a3a}
.palm .coco{fill:var(--gold-deep)}

/* a soft dark vignette so foreground text always reads */
.world-wash{position:absolute;inset:0;background:radial-gradient(120% 90% at 50% 38%, transparent 30%, rgba(5,16,28,.55) 100%)}

/* ===== SCAFFOLD ===== */
main{position:relative;z-index:2}
.wrap{max-width:var(--maxw);margin:0 auto;padding-inline:var(--pad)}
.eyebrow{
  display:inline-flex;align-items:center;gap:8px;
  font-size:11px;font-weight:600;letter-spacing:.28em;text-transform:uppercase;
  color:var(--gold);
}
.eyebrow::before{content:'';width:22px;height:1px;background:var(--gold);opacity:.7}
.eyebrow.dark{color:var(--gold-deep)}
.eyebrow.dark::before{background:var(--gold-deep)}

/* ===== NAV — floating glass pill ===== */
.nav{position:fixed;top:clamp(12px,2vw,22px);left:0;right:0;z-index:100;display:flex;justify-content:center;padding-inline:var(--pad)}
.nav-pill{
  width:min(var(--maxw),100%);
  display:flex;align-items:center;justify-content:space-between;gap:16px;
  padding:10px 12px 10px 20px;border-radius:999px;
  background:rgba(10,26,46,.55);
  backdrop-filter:blur(16px) saturate(150%);-webkit-backdrop-filter:blur(16px) saturate(150%);
  border:1px solid rgba(243,177,59,.20);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.08), 0 18px 50px -22px rgba(0,0,0,.7);
}
.brand{display:inline-flex;align-items:center;gap:10px;font-family:var(--font-display);font-weight:600;font-size:17px;letter-spacing:-.01em;color:var(--gold)}
.brand svg{width:26px;height:26px;color:var(--gold)}
.nav-links{display:none;gap:28px;align-items:center}
.nav-links a{font-size:13.5px;color:var(--ink-2);letter-spacing:.01em;transition:color .3s var(--e-soft)}
.nav-links a:hover{color:var(--gold)}
.nav-lang{font-size:11px;letter-spacing:.14em;color:var(--ink-3);text-transform:uppercase}
.nav-lang b{color:var(--ink);font-weight:500}
@media(min-width:940px){.nav-links{display:inline-flex}}

/* magnetic island button */
.btn{
  position:relative;display:inline-flex;align-items:center;gap:12px;
  padding:13px 14px 13px 24px;border-radius:999px;
  font-size:14.5px;font-weight:500;letter-spacing:.01em;
  transition:transform .5s var(--e-soft),background-color .4s var(--e-soft),color .4s var(--e-soft);
  max-width:100%;
}
.btn .lbl{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.btn .ico{flex:0 0 32px;width:32px;height:32px;border-radius:999px;display:grid;place-items:center;transition:transform .5s var(--e-soft),background-color .4s}
.btn .ico svg{width:15px;height:15px}
.btn-gold{background:var(--gold);color:var(--navy)}
.btn-gold .ico{background:rgba(10,26,46,.14)}
.btn-gold:hover{background:#ffc457}
.btn-ghost{background:rgba(255,255,255,.06);color:var(--ink);border:1px solid rgba(255,255,255,.16)}
.btn-ghost .ico{background:rgba(255,255,255,.10)}
.btn-ghost:hover{background:rgba(255,255,255,.12)}
.btn:hover{transform:translateY(-2px)}
.btn:active{transform:scale(.98)}
.btn:hover .ico{transform:translate(3px,-1px)}
.btn:focus-visible{outline:2px solid var(--gold);outline-offset:3px}
.btn-nav{padding:9px 10px 9px 18px;font-size:13px}
.btn-nav .ico{flex-basis:26px;width:26px;height:26px}

/* ===== HERO ===== */
.hero{position:relative;min-height:100dvh;display:flex;align-items:center;padding:108px 0 72px}
.hero-inner{position:relative;z-index:3;max-width:1120px;width:100%}
.hero h1{
  font-family:var(--font-display);font-weight:500;
  font-size:clamp(3rem,8.4vw,7.6rem);line-height:.96;letter-spacing:-.035em;
  margin:18px 0 26px;text-shadow:0 4px 40px rgba(5,16,28,.4);
}
.hero h1 em{font-style:italic;font-weight:400;color:var(--gold)}
.hero h1 .turq{color:var(--turq-light)}
.hero-sub{max-width:560px;font-size:clamp(15px,1.6vw,18.5px);color:var(--ink-2);line-height:1.6;margin-bottom:34px}
.hero-ctas{display:flex;flex-wrap:wrap;gap:14px}
.hero-scroll{position:absolute;left:var(--pad);bottom:30px;z-index:3;display:flex;align-items:center;gap:12px;color:var(--ink-3);font-size:12px;letter-spacing:.18em;text-transform:uppercase}
.hero-scroll .line{width:46px;height:1px;background:var(--ink-3);position:relative;overflow:hidden}
.hero-scroll .line::after{content:'';position:absolute;inset:0;background:var(--gold);transform:translateX(-100%);animation:scrollline 2.4s var(--e-soft) infinite}
@keyframes scrollline{0%{transform:translateX(-100%)}55%{transform:translateX(0)}100%{transform:translateX(100%)}}

/* ===== SECTION shell ===== */
.section{position:relative;z-index:2;padding:clamp(64px,8.5vw,108px) 0}
.panel{background:var(--navy);}
.panel-deep{background:linear-gradient(180deg,rgba(7,31,44,.0),var(--deep))}
.section-head{display:flex;flex-direction:column;gap:14px;margin-bottom:clamp(28px,4vw,48px)}
.section-head .row{display:flex;flex-direction:column;gap:18px}
@media(min-width:820px){.section-head .row{flex-direction:row;align-items:flex-end;justify-content:space-between;gap:48px}}
.section-title{
  font-family:var(--font-display);font-weight:500;
  font-size:clamp(2.2rem,5.2vw,4.4rem);line-height:1.0;letter-spacing:-.028em;max-width:18ch;
}
.section-title em{font-style:italic;font-weight:400;color:var(--gold)}
.section-aside{max-width:380px;color:var(--ink-2);font-size:clamp(15px,1.5vw,17px);line-height:1.6}

/* ===== INTERLUDE — scrub text reveal over the living world ===== */
.interlude{position:relative;z-index:2;padding:clamp(72px,10vw,128px) 0;text-align:center}
.interlude .wrap{max-width:1100px}
.scrub{
  font-family:var(--font-display);font-weight:400;font-style:italic;
  font-size:clamp(1.7rem,4.2vw,3.4rem);line-height:1.28;letter-spacing:-.01em;
}
.scrub .w{color:rgba(250,247,242,.14);transition:color .1s linear}
.scrub .w.gold{font-style:normal}

/* ===== BENTO of services — gapless, dense ===== */
.bento{display:grid;grid-template-columns:1fr;gap:14px}
@media(min-width:760px){
  .bento{grid-template-columns:repeat(6,minmax(0,1fr));grid-auto-flow:dense;gap:16px}
  .b1{grid-column:span 3;grid-row:span 2}
  .b2{grid-column:span 3}
  .b3{grid-column:span 2}
  .b4{grid-column:span 1}
  .b5{grid-column:span 3}
  .b6{grid-column:span 3}
}
.svc{
  position:relative;overflow:hidden;border-radius:26px;min-height:200px;
  background:var(--navy-2);
  padding:7px;
  border:1px solid rgba(243,177,59,.14);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.06);
  display:flex;
}
.svc-core{
  position:relative;overflow:hidden;border-radius:20px;flex:1;display:flex;flex-direction:column;justify-content:flex-end;
  padding:24px;background:var(--navy-3);
  box-shadow:inset 0 1px 1px rgba(255,255,255,.07);
}
.svc-core .ph{position:absolute;inset:0;z-index:0}
.svc-core .ph img{width:100%;height:100%;object-fit:cover;transition:transform 1.1s var(--e-out);filter:saturate(1.05) contrast(1.05)}
.svc:hover .ph img{transform:scale(1.06)}
.svc-core .ph::after{content:'';position:absolute;inset:0;background:linear-gradient(180deg,rgba(10,26,46,.15),rgba(10,26,46,.86) 78%)}
.svc-body{position:relative;z-index:1}
.svc-kicker{font-size:10.5px;letter-spacing:.22em;text-transform:uppercase;color:var(--gold);font-weight:600}
.svc-name{font-family:var(--font-display);font-weight:500;font-size:clamp(1.3rem,2.3vw,1.9rem);line-height:1.04;letter-spacing:-.015em;margin-top:10px}
.svc-name em{font-style:italic;font-weight:400;color:var(--turq-light)}
.svc-desc{font-size:13.5px;color:var(--ink-2);line-height:1.5;margin-top:10px;max-width:42ch}
.svc-foot{display:flex;align-items:center;justify-content:space-between;gap:14px;margin-top:18px;padding-top:14px;border-top:1px solid rgba(243,177,59,.18)}
.svc-price{font-family:var(--font-display);font-style:italic;color:var(--gold);font-size:15.5px;font-variant-numeric:tabular-nums}
.svc-go{width:34px;height:34px;border-radius:999px;display:grid;place-items:center;background:rgba(255,255,255,.08);transition:transform .5s var(--e-soft),background-color .4s}
.svc-go svg{width:15px;height:15px;color:var(--ink)}
.svc:hover .svc-go{background:var(--gold);transform:translate(3px,-3px)}
.svc:hover .svc-go svg{color:var(--navy)}
.svc:hover{border-color:rgba(243,177,59,.4)}
/* b1 is the tall feature: larger type */
.b1 .svc-name{font-size:clamp(1.7rem,3vw,2.6rem)}
.b4 .svc-core{padding:18px}
.b4 .svc-desc{display:none}

/* ===== PINNED HORIZONTAL JOURNEY — el día ===== */
.journey{position:relative;z-index:2;background:linear-gradient(180deg,var(--deep),#071c2a)}
.journey-pin{display:flex;align-items:center}
.journey-track{display:flex;gap:clamp(20px,4vw,56px);padding-inline:var(--pad);will-change:transform}
.jcard{flex:0 0 min(78vw,420px);}
/* mobile: native swipe carousel instead of pinned scrub */
@media(max-width:759px){
  .journey{padding:clamp(80px,16vw,120px) 0}
  .journey-pin{height:auto;display:block}
  .journey-track{overflow-x:auto;scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch;padding-bottom:18px;gap:16px;scrollbar-width:none}
  .journey-track::-webkit-scrollbar{display:none}
  .jcard,.jhead{scroll-snap-align:center;flex-basis:82vw}
  .jhead{flex-basis:88vw;margin-bottom:0}
}
@media(min-width:760px){
  .journey-pin{height:100dvh;overflow:hidden}
}
.jhead{flex:0 0 min(86vw,540px);display:flex;flex-direction:column;justify-content:center}
.jhead h2{font-family:var(--font-display);font-weight:500;font-size:clamp(2.4rem,6vw,4.6rem);line-height:.98;letter-spacing:-.03em}
.jhead h2 em{font-style:italic;font-weight:400;color:var(--gold)}
.jhead p{color:var(--ink-2);max-width:40ch;margin-top:20px;font-size:16px;line-height:1.6}
.jcard-inner{border-radius:24px;overflow:hidden;background:var(--navy-2);border:1px solid rgba(255,255,255,.08);box-shadow:inset 0 1px 0 rgba(255,255,255,.06)}
.jcard .pic{position:relative;aspect-ratio:4/5;overflow:hidden}
.jcard .pic img{width:100%;height:100%;object-fit:cover;filter:saturate(1.05)}
.jcard .pic::after{content:'';position:absolute;inset:0;background:linear-gradient(180deg,transparent 40%,rgba(10,26,46,.7))}
.jcard .hour{position:absolute;top:16px;left:16px;z-index:2;font-family:var(--font-display);font-style:italic;font-size:15px;color:var(--gold);letter-spacing:.02em;background:rgba(10,26,46,.5);backdrop-filter:blur(8px);padding:5px 12px;border-radius:999px;border:1px solid rgba(243,177,59,.3)}
.jcard .cap{padding:20px 22px 24px}
.jcard .cap h3{font-family:var(--font-display);font-weight:500;font-size:1.35rem;letter-spacing:-.01em}
.jcard .cap p{font-size:13.5px;color:var(--ink-2);margin-top:8px;line-height:1.5}

/* ===== El día — cielo amanecer→noche (portado de Atlas, detrás de las cards) ===== */
.journey-pin{position:relative}
.journey-track{position:relative;z-index:1}
.day-sky{position:absolute;inset:0;z-index:0;overflow:hidden;pointer-events:none}
.day-sky .s{position:absolute;inset:0;will-change:opacity}
.day-sky .s-dawn{background:linear-gradient(180deg,#3a2b4f 0%, #b65a52 42%, #f0a35a 72%, #ffd27a 100%);opacity:1}
.day-sky .s-day{background:linear-gradient(180deg,#2f7fb8 0%, #66b9d6 48%, #bfe6df 100%);opacity:0}
.day-sky .s-dusk{background:linear-gradient(180deg,#2a2350 0%, #7e3b6e 38%, #e3724f 74%, #f7b15e 100%);opacity:0}
.day-sky .s-night{background:linear-gradient(180deg,#040b1a 0%, #0a1a32 52%, #14304a 100%);opacity:0}
.day-sky .stars{position:absolute;inset:0;opacity:0;background-image:
  radial-gradient(1.4px 1.4px at 12% 18%,#fff,transparent),radial-gradient(1.2px 1.2px at 28% 32%,#fff,transparent),
  radial-gradient(1.5px 1.5px at 44% 12%,#fff,transparent),radial-gradient(1px 1px at 62% 26%,#fff,transparent),
  radial-gradient(1.6px 1.6px at 76% 16%,#fff,transparent),radial-gradient(1.2px 1.2px at 88% 30%,#fff,transparent),
  radial-gradient(1.3px 1.3px at 36% 22%,#fff,transparent),radial-gradient(1px 1px at 54% 38%,#fff,transparent)}
.day-sky .sun-arc{position:absolute;left:0;top:0;width:120px;height:120px;margin:-60px;will-change:transform}
.day-sky .sun-arc .disc{width:100%;height:100%;border-radius:50%;background:radial-gradient(circle at 50% 50%,#fff5d6,var(--gold) 60%,var(--gold-deep));box-shadow:0 0 60px 12px rgba(243,177,59,.55);transition:background .4s linear,box-shadow .4s linear}
.day-sky .sea-strip{position:absolute;left:0;right:0;bottom:0;height:30%;background:linear-gradient(180deg,rgba(43,182,174,0),rgba(31,163,154,.65) 40%,rgba(12,70,80,.9))}
.jhead h2,.jhead p,.jhead .eyebrow{text-shadow:0 2px 18px rgba(5,16,28,.5)}
@media(max-width:759px){ .day-sky .sun-arc,.day-sky .stars{display:none} }

/* ===== TRUST strip (honest) ===== */
.trust{position:relative;z-index:2;background:var(--sand);color:var(--ink-dark);padding:clamp(48px,6.5vw,80px) 0}
.trust-grid{display:grid;grid-template-columns:1fr 1fr;gap:36px 24px}
@media(min-width:880px){.trust-grid{grid-template-columns:auto repeat(4,1fr);align-items:center;gap:48px}}
.trust-lead{font-family:var(--font-display);font-weight:500;font-size:clamp(1.4rem,2.4vw,2rem);line-height:1.08;letter-spacing:-.02em;grid-column:1/-1}
@media(min-width:880px){.trust-lead{grid-column:auto;max-width:13ch}}
.trust-num{font-family:var(--font-display);font-style:italic;font-weight:400;font-size:clamp(2.6rem,5vw,3.6rem);line-height:.95;color:var(--gold-deep);font-variant-numeric:tabular-nums;letter-spacing:-.03em}
.trust-num sup{font-size:.42em;vertical-align:.5em;margin-left:1px}
.trust-lbl{font-size:13px;color:var(--ink-dark-2);line-height:1.4;margin-top:8px}

/* ===== CTA ===== */
.cta{position:relative;z-index:2;background:linear-gradient(180deg,#071c2a,var(--deep));padding:clamp(72px,10vw,128px) 0;text-align:center;overflow:hidden}
.cta h2{font-family:var(--font-display);font-weight:500;font-size:clamp(2.2rem,5vw,4.6rem);line-height:1;letter-spacing:-.035em;max-width:16ch;margin:14px auto 30px}
.cta h2 em{font-style:italic;font-weight:400;color:var(--gold)}
.cta-ctas{display:flex;flex-wrap:wrap;gap:14px;justify-content:center}
.cta-note{margin-top:22px;font-size:13px;color:var(--ink-3);letter-spacing:.02em}

/* ===== FOOTER ===== */
.foot{position:relative;z-index:2;background:var(--deep);border-top:1px solid rgba(243,177,59,.16);padding:clamp(44px,6vw,72px) 0 36px;color:var(--ink-2)}
.foot-grid{display:grid;grid-template-columns:1fr;gap:40px;margin-bottom:48px}
@media(min-width:760px){.foot-grid{grid-template-columns:1.7fr 1fr 1fr 1fr;gap:28px}}
.foot-brand{display:flex;flex-direction:column;gap:14px}
.foot-brand img{width:78px;height:78px;object-fit:contain}
.foot-tag{font-family:var(--font-display);font-style:italic;font-size:17px;color:var(--ink);line-height:1.4;max-width:32ch}
.foot-tag em{color:var(--gold)}
.foot-wa{color:var(--gold);font-family:var(--font-display);font-style:italic;font-size:16px}
.foot-col h4{font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:var(--gold);margin-bottom:16px;font-weight:600}
.foot-col ul{display:flex;flex-direction:column;gap:10px}
.foot-col a{font-size:14px;color:var(--ink-2);transition:color .3s var(--e-soft)}
.foot-col a:hover{color:var(--gold)}
.foot-bottom{display:flex;flex-wrap:wrap;gap:14px;justify-content:space-between;align-items:center;padding-top:26px;border-top:1px solid rgba(255,255,255,.08);font-size:12px;color:var(--ink-3)}

/* ===== HERO V2 — texto/botones a la izquierda (fondo intacto) ===== */
.hero-inner{display:flex;flex-direction:column;align-items:flex-start}
.hero-inner .eyebrow{margin-bottom:18px}
.hero h1{font-size:clamp(2.05rem,4vw,3.4rem);line-height:1.06;letter-spacing:-.02em;max-width:660px;width:fit-content;width:-moz-fit-content}
.hero-sub{max-width:460px}
.hero-toggle{display:inline-flex;gap:6px;padding:5px;border-radius:999px;background:rgba(10,26,46,.5);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border:1px solid rgba(243,177,59,.22);margin-bottom:24px;position:relative;z-index:3;box-shadow:inset 0 1px 0 rgba(255,255,255,.06)}
.ht-pill{display:inline-flex;align-items:center;gap:8px;padding:9px 16px;border-radius:999px;font-size:13px;font-weight:500;color:var(--ink-2);white-space:nowrap;transition:background-color .3s var(--e-soft),color .3s var(--e-soft),transform .3s var(--e-soft)}
.ht-pill svg{width:15px;height:15px;flex:0 0 15px}
.ht-pill.is-active{background:var(--gold);color:var(--navy)}
.ht-pill:not(.is-active):hover{color:var(--ink)}
.ht-pill:active{transform:scale(.97)}
.ht-pill:focus-visible{outline:2px solid var(--gold);outline-offset:2px}
.hero-badges{display:flex;flex-wrap:wrap;gap:10px;margin-top:28px;position:relative;z-index:3}
.hero-badge{display:inline-flex;align-items:center;gap:9px;padding:9px 15px;border-radius:999px;background:rgba(10,26,46,.42);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);border:1px solid rgba(243,177,59,.2);font-size:12.5px;color:var(--ink-2);line-height:1.2}
.hero-badge svg{width:15px;height:15px;color:var(--gold);flex:0 0 15px}
.hero-badge b{color:var(--ink);font-weight:600;font-variant-numeric:tabular-nums}
@media(max-width:560px){ .hero-toggle{flex-wrap:wrap} .ht-pill{font-size:12px;padding:8px 13px} .hero-badge{font-size:11.5px} }

/* ===== BLOG / GUÍAS ===== */
.guide-feat{display:grid;grid-template-columns:minmax(0,1fr);background:var(--navy-2);border:1px solid rgba(243,177,59,.16);border-radius:24px;overflow:hidden;margin-bottom:16px;box-shadow:inset 0 1px 0 rgba(255,255,255,.06);transition:border-color .4s var(--e-out);color:inherit}
@media(min-width:820px){.guide-feat{grid-template-columns:1.05fr 1fr;align-items:stretch}}
.guide-feat:hover{border-color:rgba(243,177,59,.42)}
.guide-feat:focus-visible{outline:2px solid var(--gold);outline-offset:3px}
.gf-img{position:relative;overflow:hidden;min-height:240px}
.gf-img img{width:100%;height:100%;object-fit:cover;transition:transform .8s var(--e-out)}
.guide-feat:hover .gf-img img{transform:scale(1.04)}
.gf-body{padding:clamp(24px,3.4vw,44px);display:flex;flex-direction:column;gap:14px;justify-content:center;min-width:0}
.gf-title{font-family:var(--font-display);font-weight:500;font-size:clamp(1.5rem,2.7vw,2.3rem);line-height:1.07;letter-spacing:-.015em;overflow-wrap:anywhere}
.gf-title em{font-style:italic;color:var(--gold)}
.gf-desc{color:var(--ink-2);font-size:15px;line-height:1.6;max-width:48ch}
.g-cat{font-size:10.5px;letter-spacing:.2em;text-transform:uppercase;color:var(--gold);font-weight:600}
.guides{display:grid;grid-template-columns:minmax(0,1fr);gap:16px}
@media(min-width:680px){.guides{grid-template-columns:repeat(3,minmax(0,1fr))}}
.guide{display:flex;flex-direction:column;background:var(--navy-2);border:1px solid rgba(243,177,59,.14);border-radius:22px;overflow:hidden;box-shadow:inset 0 1px 0 rgba(255,255,255,.06);transition:transform .5s var(--e-out),border-color .4s var(--e-out);color:inherit;min-width:0}
.guide:hover{transform:translateY(-3px);border-color:rgba(243,177,59,.42)}
.guide:focus-visible{outline:2px solid var(--gold);outline-offset:3px}
.g-img{position:relative;aspect-ratio:16/10;overflow:hidden}
.g-img img{width:100%;height:100%;object-fit:cover;transition:transform .7s var(--e-out)}
.guide:hover .g-img img{transform:scale(1.05)}
.g-body{padding:20px 22px 22px;display:flex;flex-direction:column;gap:9px;flex:1;min-width:0}
.g-title{font-family:var(--font-display);font-weight:500;font-size:clamp(1.15rem,1.7vw,1.45rem);line-height:1.12;letter-spacing:-.01em;overflow-wrap:anywhere}
.g-meta{margin-top:auto;padding-top:13px;border-top:1px solid rgba(243,177,59,.14);font-size:12px;color:var(--ink-3);letter-spacing:.03em;display:flex;align-items:center;justify-content:space-between;gap:10px}
.g-meta .arrow-link{font-size:12px}
.blog-cta{margin-top:clamp(34px,5vw,56px);display:flex;justify-content:center}

/* ===== HERO · barra de búsqueda (portada de 0-Editorial-Navy, scopeada en .hero-search) ===== */
.hero-search{position:relative;z-index:3;margin-top:28px;max-width:800px;width:100%}
.hero-search .inner{background:#fff;border-radius:16px;padding:10px;box-shadow:0 26px 60px -22px rgba(0,0,0,.6),0 2px 6px rgba(0,0,0,.12);display:grid;grid-template-columns:repeat(3,minmax(0,1fr)) auto;gap:8px;align-items:center}
.hero-search .field{display:flex;align-items:center;gap:11px;padding:10px 14px;border-radius:12px;background:#f6f2e9;border:1px solid transparent;cursor:pointer;text-align:left;transition:border-color .2s var(--e-out),background .2s var(--e-out)}
.hero-search .field:hover{border-color:rgba(10,26,46,.12);background:#fff}
.hero-search .field svg{width:18px;height:18px;color:var(--gold-deep);flex:0 0 18px}
.hero-search .field .meta{display:flex;flex-direction:column;line-height:1.1;min-width:0}
.hero-search .field .lbl{font-size:10px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:#8a98a5}
.hero-search .field .val{font-size:14px;font-weight:600;color:var(--navy);margin-top:3px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.hero-search .submit{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:14px 22px;border-radius:12px;background:var(--navy);color:#fff;font-family:var(--font-body);font-weight:600;font-size:14px;border:0;cursor:pointer;white-space:nowrap;transition:transform .15s var(--e-out),background .25s}
.hero-search .submit svg{width:18px;height:18px;color:var(--gold)}
.hero-search .submit:hover{background:var(--navy-3)}
.hero-search .submit:active{transform:scale(.97)}
.hero-search .field:focus-visible,.hero-search .submit:focus-visible{outline:2px solid var(--gold);outline-offset:3px}
@media(max-width:680px){.hero-search .inner{grid-template-columns:1fr}.hero-search .submit{width:100%}}

/* ===== PROPIEDADES DESTACADAS (portado de 0-Editorial-Navy, scopeado en .props2) ===== */
@font-face{font-family:'Bodoni Moda';font-style:normal;font-weight:400 600;src:url(../fonts/bodoni-01.woff2) format('woff2');font-display:swap}
@font-face{font-family:'Bodoni Moda';font-style:italic;font-weight:400 600;src:url(../fonts/bodoni-03.woff2) format('woff2');font-display:swap}
.props2{--p2-navy:#0A1A2E;--p2-navy2:#102b44;--p2-gold:#F3B13B;--p2-golddeep:#c8893f;--p2-muted:#5d6b78;--p2-hair:rgba(10,26,46,.10);padding-top:clamp(40px,5vw,52px)}
.props2 .section-head{margin-bottom:clamp(18px,2.6vw,28px)}
.props2 .props-slider{position:relative;margin-top:clamp(18px,2.6vw,28px)}
.props2 .props-track{display:flex;gap:24px;overflow-x:auto;scroll-snap-type:x mandatory;scrollbar-width:none;list-style:none;margin:0;padding:8px 2px 26px}
.props2 .props-track::-webkit-scrollbar{display:none}
.props2 .props-track:focus-visible{outline:2px solid var(--p2-gold);outline-offset:6px;border-radius:18px}
.props2 .prop-card{flex:0 0 calc((100% - 24px*3)/4);scroll-snap-align:start;min-width:260px;display:flex;flex-direction:column;border-radius:24px;overflow:hidden;padding:6px;background:var(--p2-navy2);border:1px solid rgba(243,177,59,.20);box-shadow:inset 0 1px 0 rgba(255,255,255,.07), 0 22px 50px -26px rgba(0,0,0,.65);transition:transform .4s var(--e-out),box-shadow .4s var(--e-out),border-color .4s var(--e-out)}
.props2 .prop-card:hover{transform:translateY(-5px);box-shadow:inset 0 1px 0 rgba(255,255,255,.09), 0 30px 60px -24px rgba(0,0,0,.75);border-color:rgba(243,177,59,.5)}
.props2 .prop-card-link{flex:1;display:flex;flex-direction:column;border-radius:18px;overflow:hidden;background:#fff;box-shadow:inset 0 1px 1px rgba(255,255,255,.5);color:inherit}
.props2 .prop-photo{position:relative;aspect-ratio:5/4;overflow:hidden;background:#e7edf2}
.props2 .prop-photo img{width:100%;height:100%;object-fit:cover;transition:transform 1.2s var(--e-out)}
.props2 .prop-card:hover .prop-photo img{transform:scale(1.06)}
.props2 .prop-body{padding:18px 20px 20px;display:flex;flex-direction:column;gap:10px}
.props2 .prop-loc{display:inline-flex;align-items:center;gap:6px;font-size:12px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--p2-golddeep)}
.props2 .prop-loc svg{width:14px;height:14px;flex:0 0 14px}
.props2 .prop-card h3{font-family:'Bodoni Moda',Georgia,serif;font-weight:500;font-size:22px;letter-spacing:-.01em;color:var(--p2-navy);line-height:1.18;margin:0}
.props2 .prop-tag-inline{font-size:13.5px;color:var(--p2-muted);line-height:1.5;margin:0;padding-top:10px;border-top:1px solid var(--p2-hair)}
.props2 .prop-foot{display:flex;justify-content:space-between;align-items:center;gap:16px;margin-top:6px}
.props2 .prop-price{display:flex;flex-direction:column;line-height:1.15}
.props2 .prop-price small{font-size:12px;color:var(--p2-muted);font-weight:500}
.props2 .prop-price strong{font-family:'Bodoni Moda',Georgia,serif;font-weight:600;font-size:22px;color:var(--p2-navy);letter-spacing:-.01em;font-variant-numeric:tabular-nums}
.props2 .prop-price strong span{font-size:13px;color:var(--p2-muted);font-weight:500}
.props2 .prop-go{flex:0 0 40px;width:40px;height:40px;border-radius:999px;display:grid;place-items:center;background:rgba(10,26,46,.06);border:1px solid rgba(10,26,46,.08);transition:transform .45s var(--e-out),background-color .3s,border-color .3s}
.props2 .prop-go svg{width:16px;height:16px;color:var(--p2-navy)}
.props2 .prop-card:hover .prop-go{background:var(--p2-gold);border-color:var(--p2-gold);transform:translate(3px,-3px)}
.props2 .prop-card:hover .prop-go svg{color:var(--p2-navy)}
.props2 .props-arrow{position:absolute;top:calc(50% - 28px);width:48px;height:48px;border-radius:50%;background:#fff;color:var(--p2-navy);border:0;cursor:pointer;z-index:5;box-shadow:0 10px 24px rgba(0,0,0,.4);display:grid;place-items:center;transition:transform .25s var(--e-out),opacity .25s,background .25s}
.props2 .props-arrow svg{width:18px;height:18px}
.props2 .props-arrow:hover{background:var(--p2-gold)}
.props2 .props-arrow:active{transform:scale(.95)}
.props2 .props-arrow:focus-visible{outline:3px solid var(--p2-gold);outline-offset:3px}
.props2 .props-arrow-prev{left:-18px}
.props2 .props-arrow-next{right:-18px}
.props2 .props-arrow[disabled]{opacity:.22;cursor:default;pointer-events:none}
.props2 .props-expand-btn{display:flex;align-items:center;gap:10px;margin:26px auto 0;padding:14px 28px;background:transparent;color:#fff;border:1.5px solid var(--p2-gold);border-radius:999px;font-family:var(--font-body);font-size:14px;font-weight:600;letter-spacing:.04em;cursor:pointer;transition:background .25s var(--e-out),color .25s,transform .15s}
.props2 .props-expand-btn svg{width:18px;height:18px;color:var(--p2-gold);transition:color .25s}
.props2 .props-expand-btn:hover{background:var(--p2-gold);color:var(--p2-navy)}
.props2 .props-expand-btn:hover svg{color:var(--p2-navy)}
.props2 .props-expand-btn:active{transform:scale(.97)}
.props2 .props-grid-expanded{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:24px;margin-top:32px;max-height:0;overflow:hidden;opacity:0;transition:max-height .55s var(--e-out),opacity .35s}
.props2 .props-grid-expanded[data-open]{max-height:7000px;opacity:1}
@media(max-width:1024px){.props2 .prop-card{flex-basis:calc((100% - 24px*2)/3)}.props2 .props-grid-expanded{grid-template-columns:repeat(3,minmax(0,1fr))}}
@media(max-width:760px){.props2 .props-track{gap:16px}.props2 .prop-card{flex-basis:calc((100% - 16px)/2 - 8px);min-width:220px}.props2 .props-arrow{display:none}.props2 .props-grid-expanded{grid-template-columns:repeat(2,minmax(0,1fr));gap:16px}}
@media(max-width:480px){.props2 .prop-card{flex-basis:calc(100% - 36px);min-width:0}.props2 .props-grid-expanded{grid-template-columns:1fr}}

/* reveal base */
.reveal{opacity:0;transform:translateY(40px);filter:blur(6px)}
.is-in .reveal,.reveal.in{opacity:1;transform:none;filter:none;transition:opacity .9s var(--e-out),transform .9s var(--e-out),filter .9s var(--e-out)}

/* ===== reduced motion ===== */
@media (prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.001ms!important;animation-iteration-count:1!important;transition-duration:.001ms!important}
  .l-dawn{opacity:1}.l-shallow,.l-deep,.caustics{opacity:.0}
  .reveal{opacity:1;transform:none;filter:none}
  .hero-scroll .line::after{display:none}
}
