/* ============================================================
   WM LUXE — Tulum jungle-luxe style system
   Deep jungle green · Caribbean turquoise · gold greca
   Static ornament · scroll-driven motion only
   ============================================================ */

:root{
  --black:        #05190f;
  --black-2:      #082417;
  --panel:        #0b3120;
  --panel-2:      #0f3d28;

  --line:         rgba(233,205,134,.20);
  --line-strong:  rgba(233,205,134,.48);

  --gold-1:       #9c7a2e;
  --gold-2:       #cdab5e;
  --gold-3:       #e3c576;
  --gold-4:       #f2dd9c;
  --gold-grad: linear-gradient(100deg,#9c7a2e 0%,#e3c576 30%,#fff0c4 50%,#e3c576 70%,#9c7a2e 100%);

  --turq:         #25cdba;
  --turq-soft:    #7fe7db;
  --turq-deep:    #0f8c7e;
  --terra:        #e0793f;
  --jade:         #0d4a31;

  --cream:        #f1ead6;
  --cream-soft:   #cabfa3;
  --muted:        #7fa090;

  --serif:  "Cinzel", "Trajan Pro", Georgia, serif;
  --body:   "Cormorant Garamond", "EB Garamond", Georgia, serif;
  --maxw:   1180px;

  /* Greek-key greca band — matches the WM crest border */
  --greca: url("data:image/svg+xml,%3Csvg%20xmlns='http://www.w3.org/2000/svg'%20width='52'%20height='30'%20viewBox='0%200%2052%2030'%3E%3Cpath%20d='M0%2026%20H52%20M6%2026%20V6%20H46%20V22%20H18%20V12%20H34%20V18'%20fill='none'%20stroke='%23d9b96b'%20stroke-width='2'%20stroke-linejoin='miter'/%3E%3C/svg%3E");
}

*{ box-sizing:border-box; }
html{ scroll-behavior:smooth; }
body{
  margin:0; position:relative;
  background:
    radial-gradient(900px 620px at 16% 8%, rgba(37,205,186,.12), transparent 60%),
    radial-gradient(820px 560px at 86% 18%, rgba(224,121,63,.10), transparent 62%),
    linear-gradient(180deg,#05190f 0%, #04140c 55%, #061d12 100%);
  background-attachment:fixed;
  color:var(--cream);
  font-family:var(--body); font-size:20px; line-height:1.65;
  -webkit-font-smoothing:antialiased; overflow-x:hidden;
}

img{ max-width:100%; display:block; }
a{ color:inherit; text-decoration:none; }
.wrap{ width:100%; max-width:var(--maxw); margin:0 auto; padding:0 28px; }

/* ---------- Type ---------- */
.eyebrow{ font-family:var(--serif); text-transform:uppercase; letter-spacing:.4em; font-size:.72rem; font-weight:600; color:var(--turq); margin:0 0 18px; }
.gold-text{ background:var(--gold-grad); -webkit-background-clip:text; background-clip:text; color:transparent; }
h1,h2,h3{ font-family:var(--serif); font-weight:600; line-height:1.12; margin:0; }
h1{ font-size:clamp(2.4rem,6vw,4.6rem); letter-spacing:.05em; }
h2{ font-size:clamp(1.7rem,3.6vw,2.7rem); letter-spacing:.06em; }
h3{ font-size:1.12rem; letter-spacing:.15em; text-transform:uppercase; }
p{ margin:0 0 1.1rem; color:var(--cream-soft); }
.lead{ font-size:1.28rem; color:var(--cream); }
.rule{ width:120px; height:2px; background:var(--gold-grad); margin:26px auto; border:0; opacity:.9; }
.rule.left{ margin-left:0; }

/* ---------- Greca band (static) ---------- */
.greca-band{ height:30px; width:100%; background:var(--greca) repeat-x center / 52px 30px; opacity:.7; }

/* ---------- Nav ---------- */
header.nav{ position:sticky; top:0; z-index:50; backdrop-filter:blur(12px);
  background:linear-gradient(180deg, rgba(5,21,13,.94), rgba(5,21,13,.55)); border-bottom:1px solid var(--line); }
.nav-inner{ display:flex; align-items:center; justify-content:space-between; height:74px; }
.brand-mark{ display:flex; align-items:center; gap:12px; }
.brand-mark img{ width:40px; height:40px; }
.brand-mark .bt{ font-family:var(--serif); font-weight:700; letter-spacing:.3em; font-size:1rem; }
.nav-links{ display:flex; align-items:center; gap:34px; }
.nav-links a{ position:relative; font-family:var(--serif); text-transform:uppercase; font-size:.74rem; letter-spacing:.22em; color:var(--cream-soft); transition:color .25s; }
.nav-links a::after{ content:""; position:absolute; left:0; bottom:-7px; width:0; height:1px; background:var(--turq); transition:width .3s; }
.nav-links a:hover{ color:var(--turq); }
.nav-links a:hover::after{ width:100%; }
.lang-toggle{ display:inline-flex; border:1px solid var(--line-strong); border-radius:999px; overflow:hidden; font-family:var(--serif); font-size:.68rem; letter-spacing:.12em; }
.lang-toggle button{ background:transparent; border:0; color:var(--muted); padding:7px 13px; cursor:pointer; transition:.2s; letter-spacing:.12em; }
.lang-toggle button.active{ background:var(--turq); color:#04140c; font-weight:700; }

/* ---------- Hero ---------- */
.hero{ position:relative; text-align:center; padding:96px 0 72px; }
.hero .medallion{ width:clamp(168px,24vw,250px); margin:0 auto 30px; }
.hero .medallion img{ width:100%; filter:drop-shadow(0 6px 30px rgba(227,197,118,.18)); }
.hero h1{ margin-bottom:8px; }
.hero .sub{ font-family:var(--serif); letter-spacing:.34em; text-transform:uppercase; font-size:.92rem; color:var(--gold-3); margin-bottom:26px; }
.hero .lead{ max-width:680px; margin:0 auto 36px; }
.scroll-cue{ margin-top:54px; display:inline-flex; flex-direction:column; align-items:center; gap:8px; color:var(--muted); font-family:var(--serif); font-size:.62rem; letter-spacing:.3em; text-transform:uppercase; }
.scroll-cue .dot{ width:22px; height:36px; border:1px solid var(--line-strong); border-radius:14px; position:relative; }
.scroll-cue .dot::after{ content:""; position:absolute; top:7px; left:50%; width:3px; height:7px; border-radius:3px; background:var(--turq); transform:translateX(-50%); animation:cue 1.8s ease-in-out infinite; }
@keyframes cue{ 0%{opacity:0; transform:translate(-50%,0);} 30%{opacity:1;} 100%{opacity:0; transform:translate(-50%,12px);} }

/* ---------- Buttons ---------- */
.btn{ position:relative; display:inline-flex; align-items:center; gap:10px; font-family:var(--serif); text-transform:uppercase; letter-spacing:.18em; font-size:.76rem; padding:15px 30px; cursor:pointer; transition:.3s; overflow:hidden; border:1px solid var(--line-strong); color:var(--gold-3); background:transparent; }
.btn:hover{ border-color:var(--turq); color:var(--turq-soft); box-shadow:0 0 26px rgba(37,205,186,.25); transform:translateY(-2px); }
.btn.solid{ background:linear-gradient(120deg,var(--turq-deep),var(--turq)); color:#04140c; border-color:transparent; font-weight:700; }
.btn.solid:hover{ filter:brightness(1.08); color:#04140c; }
.btn .arrow{ transition:transform .3s; }
.btn:hover .arrow{ transform:translateX(5px); }

/* ---------- Sections ---------- */
section{ padding:78px 0; }
.section-head{ text-align:center; max-width:720px; margin:0 auto 52px; }

/* ---------- Gateways ---------- */
.gateways{ display:grid; grid-template-columns:repeat(3,1fr); gap:26px; }
.gate{ position:relative; display:flex; flex-direction:column; align-items:center; text-align:center; padding:42px 30px 40px; min-height:460px;
  background:linear-gradient(180deg,var(--panel),var(--black-2)); border:1px solid var(--line); overflow:hidden; transition:transform .4s, box-shadow .4s, border-color .4s; }
.gate::after{ content:""; position:absolute; left:0; right:0; bottom:0; height:30px; background:var(--greca) repeat-x center / 52px 30px; opacity:.3; transition:opacity .4s; }
.gate::before{ content:""; position:absolute; inset:0; background:radial-gradient(440px 260px at 50% -8%, rgba(37,205,186,.18), transparent 70%); opacity:0; transition:opacity .4s; }
.gate:hover{ transform:translateY(-8px); border-color:var(--turq); box-shadow:0 28px 70px rgba(0,0,0,.5),0 0 0 1px rgba(37,205,186,.25); }
.gate:hover::before{ opacity:1; }
.gate:hover::after{ opacity:.6; }
.gate .logo{ height:215px; width:auto; max-width:100%; margin:-6px auto 14px; display:block; transition:transform .45s ease; }
.gate:hover .logo{ transform:scale(1.07) translateY(-2px); }
.gate .tag{ font-family:var(--serif); font-size:.66rem; letter-spacing:.32em; color:var(--muted); text-transform:uppercase; margin-bottom:10px; }
.gate h2{ font-size:2rem; margin-bottom:14px; }
.gate p{ font-size:1.05rem; flex:1; }
.gate .go{ margin-top:18px; font-family:var(--serif); text-transform:uppercase; letter-spacing:.2em; font-size:.74rem; color:var(--turq); display:inline-flex; align-items:center; gap:9px; }
.gate:hover .go{ color:var(--turq-soft); }

/* ---------- Stats ---------- */
.values{ display:grid; grid-template-columns:repeat(3,1fr); gap:30px; text-align:center; max-width:820px; margin:0 auto; }
.value .n{ font-family:var(--serif); font-size:2.6rem; line-height:1; background:var(--gold-grad); -webkit-background-clip:text; background-clip:text; color:transparent; }
.value h3{ font-size:.74rem; margin:12px 0 0; color:var(--turq); }

/* ---------- Sub-page hero ---------- */
.subhero{ position:relative; text-align:center; padding:90px 0 56px; }
.subhero::after{ content:""; display:block; height:30px; margin-top:44px; background:var(--greca) repeat-x center / 52px 30px; opacity:.6; }
.subhero .logo{ margin:0 auto 16px; }
.subhero .logo img{ height:230px; width:auto; margin:0 auto; }
.subhero h1{ font-size:clamp(2.4rem,5.5vw,4rem); }
.subhero .lead{ max-width:640px; margin:18px auto 0; }

/* ---------- Listings ---------- */
.listing{ display:grid; grid-template-columns:repeat(3,1fr); gap:26px; }
.card{ background:linear-gradient(180deg,var(--panel),var(--black-2)); border:1px solid var(--line); overflow:hidden; transition:transform .35s, box-shadow .35s, border-color .35s; }
.card:hover{ transform:translateY(-6px); border-color:var(--turq); box-shadow:0 22px 56px rgba(0,0,0,.45); }
.card .ph{ height:210px; position:relative; display:flex; align-items:center; justify-content:center;
  background:var(--greca) repeat-x bottom / 52px 30px, linear-gradient(135deg,#11422c,#0a2418); border-bottom:1px solid var(--line); }
.card .ph::before{ content:""; position:absolute; inset:0; background:radial-gradient(circle at 50% 40%, rgba(37,205,186,.12), transparent 70%); }
.card .ph .badge{ position:relative; font-family:var(--serif); letter-spacing:.2em; text-transform:uppercase; font-size:.66rem; color:var(--cream-soft); border:1px dashed var(--line-strong); padding:8px 14px; background:rgba(5,21,13,.55); }
.card .body{ padding:24px 24px 28px; }
.card .body h3{ font-size:1.02rem; margin-bottom:8px; color:var(--cream); }
.card .body p{ font-size:.98rem; margin:0; }
.card .meta{ margin-top:16px; display:flex; gap:14px; flex-wrap:wrap; font-family:var(--serif); font-size:.66rem; letter-spacing:.15em; text-transform:uppercase; color:var(--terra); }

/* ---------- Split ---------- */
.split{ display:grid; grid-template-columns:1fr 1fr; gap:54px; align-items:center; }
.split .art{ aspect-ratio:4/3; border:1px solid var(--line); position:relative; overflow:hidden;
  background:radial-gradient(circle at 50% 40%, rgba(37,205,186,.14), transparent 70%),linear-gradient(135deg,#11422c,#08200f); display:flex; align-items:center; justify-content:center; }
.split .art::after{ content:""; position:absolute; left:0; right:0; bottom:0; height:30px; background:var(--greca) repeat-x center / 52px 30px; opacity:.4; }
.split .art img{ width:54%; }

/* ---------- CTA ---------- */
.cta{ position:relative; text-align:center; border:1px solid var(--line-strong); background:linear-gradient(180deg,var(--jade),var(--black-2)); padding:60px 30px; overflow:hidden; }
.cta::before{ content:""; position:absolute; left:0; right:0; top:0; height:30px; background:var(--greca) repeat-x center / 52px 30px; opacity:.5; }
.cta::after{ content:""; position:absolute; left:0; right:0; bottom:0; height:30px; background:var(--greca) repeat-x center / 52px 30px; opacity:.5; }
.cta h2{ margin-bottom:14px; }
.cta .lead{ max-width:560px; margin:0 auto 30px; }

/* ---------- Footer ---------- */
footer{ position:relative; border-top:1px solid var(--line); padding:56px 0 40px; margin-top:30px; }
footer::before{ content:""; position:absolute; left:0; right:0; top:0; height:30px; background:var(--greca) repeat-x center / 52px 30px; opacity:.45; }
.foot-inner{ display:flex; justify-content:space-between; gap:40px; flex-wrap:wrap; }
.foot-brand .bt{ font-family:var(--serif); letter-spacing:.3em; font-size:1.1rem; }
.foot-brand p{ font-size:.95rem; max-width:300px; margin-top:12px; }
.foot-col h4{ font-family:var(--serif); font-size:.72rem; letter-spacing:.22em; text-transform:uppercase; color:var(--turq); margin:0 0 14px; }
.foot-col a{ display:block; font-size:1rem; color:var(--cream-soft); margin-bottom:9px; transition:.2s; }
.foot-col a:hover{ color:var(--turq); padding-left:5px; }
.foot-bottom{ text-align:center; color:var(--muted); font-size:.82rem; letter-spacing:.1em; margin-top:40px; }

/* ============================================================
   SCROLL-DRIVEN MOTION (the only motion on the page)
   ============================================================ */
.reveal{ opacity:0; transform:translateY(42px); transition:opacity .9s cubic-bezier(.2,.7,.2,1), transform .9s cubic-bezier(.2,.7,.2,1); will-change:opacity,transform; }
[data-reveal="zoom"]{ transform:scale(.9); }
[data-reveal="left"]{ transform:translateX(-56px); }
[data-reveal="right"]{ transform:translateX(56px); }
[data-reveal="fade"]{ transform:none; }
.reveal.in{ opacity:1; transform:none; }

/* parallax layer offset set by JS via --py */
.parallax{ transform:translate3d(0, var(--py,0), 0); will-change:transform; }

/* ---------- Responsive ---------- */
@media(max-width:900px){
  .gateways,.listing,.values{ grid-template-columns:1fr 1fr; }
  .split{ grid-template-columns:1fr; gap:32px; }
}
@media(max-width:600px){
  body{ font-size:18px; }
  .gateways,.listing,.values{ grid-template-columns:1fr; }
  .foot-inner{ flex-direction:column; }
}

/* ---------- Reduced motion ---------- */
@media(prefers-reduced-motion:reduce){
  *{ animation:none !important; }
  .reveal{ opacity:1 !important; transform:none !important; }
  .parallax{ transform:none !important; }
}

/* ---------- WhatsApp floating button ---------- */
.wa-fab{
  position:fixed; right:22px; bottom:22px; z-index:80;
  width:58px; height:58px; border-radius:50%;
  display:flex; align-items:center; justify-content:center;
  background:#1f9d56; color:#fff;
  box-shadow:0 10px 28px rgba(0,0,0,.45), 0 0 0 4px rgba(37,205,186,.0);
  transition:transform .25s, box-shadow .25s;
}
.wa-fab:hover{ transform:translateY(-3px) scale(1.05); box-shadow:0 14px 34px rgba(0,0,0,.5); }

/* ---------- Cookie banner ---------- */
.cookie-banner{
  position:fixed; left:50%; bottom:18px; transform:translate(-50%,140%);
  z-index:90; width:min(680px,92vw);
  display:flex; align-items:center; gap:18px; flex-wrap:wrap; justify-content:space-between;
  background:linear-gradient(180deg,var(--panel-2),var(--black-2));
  border:1px solid var(--line-strong); border-radius:14px; padding:16px 20px;
  box-shadow:0 24px 60px rgba(0,0,0,.5); opacity:0; transition:transform .45s ease, opacity .45s ease;
}
.cookie-banner.show{ transform:translate(-50%,0); opacity:1; }
.cookie-banner.hide{ transform:translate(-50%,140%); opacity:0; }
.cookie-banner p{ margin:0; font-size:.96rem; color:var(--cream-soft); flex:1 1 280px; }
.cookie-banner a{ color:var(--turq); text-decoration:underline; }
.cookie-actions{ display:flex; gap:10px; }
.cookie-banner button{ font-family:var(--serif); text-transform:uppercase; letter-spacing:.14em; font-size:.68rem; padding:10px 18px; cursor:pointer; border:1px solid var(--line-strong); background:transparent; color:var(--cream); border-radius:999px; transition:.2s; }
.cookie-banner .ck-yes{ background:var(--turq); color:#04140c; border-color:transparent; font-weight:700; }
.cookie-banner button:hover{ filter:brightness(1.08); }

/* ---------- Lightbox gallery ---------- */
.card .ph[data-gallery]{ cursor:pointer; }
.card .ph[data-gallery]::after{
  content:"⤢"; position:absolute; right:12px; bottom:12px; z-index:2;
  width:34px; height:34px; display:flex; align-items:center; justify-content:center;
  border:1px solid var(--line-strong); border-radius:50%; color:var(--gold-3);
  background:rgba(5,21,13,.6); font-size:1rem; transition:.25s;
}
.card:hover .ph[data-gallery]::after{ color:var(--gold-4); border-color:var(--turq); }
.lightbox{ position:fixed; inset:0; z-index:100; display:none; align-items:center; justify-content:center;
  background:rgba(4,16,10,.92); backdrop-filter:blur(4px); }
.lightbox.open{ display:flex; }
.lb-stage{ margin:0; max-width:86vw; max-height:82vh; text-align:center; }
.lb-stage img{ max-width:86vw; max-height:78vh; border:1px solid var(--line-strong); }
.lb-stage figcaption{ margin-top:12px; font-family:var(--serif); letter-spacing:.18em; color:var(--gold-3); font-size:.8rem; }
.lb-ph{ width:60vw; max-width:560px; height:50vh; display:flex; align-items:center; justify-content:center;
  border:1px dashed var(--line-strong); color:var(--cream-soft); font-family:var(--serif); letter-spacing:.2em; text-transform:uppercase; font-size:.9rem;
  background:var(--greca) repeat-x bottom / 52px 30px; }
.lightbox button{ position:absolute; background:transparent; border:1px solid var(--line-strong); color:var(--gold-3);
  width:46px; height:46px; border-radius:50%; font-size:1.5rem; cursor:pointer; transition:.2s; }
.lightbox button:hover{ color:var(--gold-4); border-color:var(--turq); }
.lb-close{ top:24px; right:24px; }
.lb-prev{ left:24px; top:50%; transform:translateY(-50%); }
.lb-next{ right:24px; top:50%; transform:translateY(-50%); }

/* ---------- Contact form ---------- */
.cta-form{ display:grid; gap:14px; max-width:540px; margin:8px auto 0; text-align:left; }
.cta-form .row{ display:grid; grid-template-columns:1fr 1fr; gap:14px; }
.cta-form input, .cta-form textarea{ width:100%; background:rgba(5,21,13,.5); border:1px solid var(--line-strong); color:var(--cream); font-family:var(--body); font-size:1.02rem; padding:12px 15px; border-radius:8px; transition:border-color .2s; }
.cta-form input:focus, .cta-form textarea:focus{ outline:none; border-color:var(--turq); }
.cta-form input::placeholder, .cta-form textarea::placeholder{ color:var(--muted); }
.cta-form button{ justify-self:center; margin-top:4px; }
.cta-form .form-note{ font-size:.82rem; color:var(--muted); text-align:center; margin:0; }
@media(max-width:540px){ .cta-form .row{ grid-template-columns:1fr; } }

/* ---------- Location / map ---------- */
.map-wrap{ position:relative; border:1px solid var(--line); overflow:hidden; }
.map-wrap iframe{ display:block; width:100%; height:420px; border:0; filter:grayscale(.3) contrast(1.05); }
.map-wrap::after{ content:""; position:absolute; inset:0; pointer-events:none; box-shadow:inset 0 0 0 1px rgba(233,205,134,.18); }

/* ---------- Legal pages ---------- */
.legal{ max-width:820px; margin:0 auto; padding:60px 0; }
.legal h1{ font-size:clamp(2rem,4vw,3rem); margin-bottom:8px; }
.legal h2{ font-size:1.3rem; margin:34px 0 10px; color:var(--gold-3); }
.legal p, .legal li{ color:var(--cream-soft); font-size:1.05rem; }
.legal ul{ padding-left:1.2rem; }
.legal .updated{ color:var(--muted); font-size:.85rem; letter-spacing:.08em; }
.legal .note{ border:1px dashed var(--line-strong); padding:14px 18px; border-radius:10px; color:var(--gold-3); font-size:.92rem; }
.foot-legal{ margin-top:14px; }
.foot-legal a{ color:var(--muted); font-size:.8rem; margin:0 8px; }
.foot-legal a:hover{ color:var(--turq); }

/* ---------- Cinematic photographic scenes ---------- */
.scene-hero{ position:relative; min-height:94vh; display:flex; flex-direction:column;
  align-items:center; justify-content:center; text-align:center; overflow:hidden; padding:90px 24px; }
.scene-bg{ position:absolute; inset:-8%; z-index:0;
  background-image: var(--hero, none), linear-gradient(160deg,#0c3b34,#06200f 70%);
  background-size:cover; background-position:center; background-repeat:no-repeat;
  transform:translate3d(0,0,0) scale(1.12); will-change:transform; }
.scene-hero::before{ content:""; position:absolute; inset:0; z-index:1;
  background:
    radial-gradient(ellipse 72% 56% at 50% 46%, rgba(4,16,10,.5), rgba(4,16,10,0) 62%),
    linear-gradient(180deg, rgba(4,16,10,.5) 0%, rgba(4,16,10,.22) 40%, rgba(4,16,10,.92) 100%); }
.scene-hero > *{ position:relative; z-index:2; }
.scene-hero .pbrand, .scene-hero .ptag, .scene-hero .eyebrow,
.subhero.scene-hero h1, .subhero.scene-hero .lead{ text-shadow:0 2px 28px rgba(0,0,0,.55), 0 1px 4px rgba(0,0,0,.4); }
.scene-hero .scene-3d{ position:absolute; inset:0; z-index:0; }
.subhero.scene-hero::after{ display:none; }
/* exit zoom when navigating away */
body.leaving .scene-bg{ transition:transform .6s cubic-bezier(.2,.7,.2,1); transform:scale(1.42) !important; }
@media(prefers-reduced-motion:reduce){ .scene-bg{ transform:scale(1.06); } }

/* portal (sea landing) */
.portal-hero{ min-height:100vh; }
.portal-hero .pbrand{ font-family:var(--serif); font-weight:700; letter-spacing:.18em;
  font-size:clamp(2.6rem,8vw,5.2rem);
  background:var(--gold-grad); -webkit-background-clip:text; background-clip:text; color:transparent; margin:0; }
.portal-hero .ptag{ font-family:var(--serif); letter-spacing:.34em; text-transform:uppercase;
  font-size:clamp(.7rem,1.6vw,.95rem); color:var(--gold-3); margin:14px 0 0; }
.portal{ display:flex; gap:24px; flex-wrap:wrap; justify-content:center; margin-top:46px; }
.portal a{ position:relative; min-width:210px; padding:24px 26px; text-decoration:none;
  border:1px solid rgba(233,205,134,.4); background:rgba(5,21,13,.32); backdrop-filter:blur(4px);
  transition:transform .35s, border-color .35s, background .35s, box-shadow .35s; }
.portal a:hover{ transform:translateY(-5px); border-color:var(--turq);
  background:rgba(5,21,13,.55); box-shadow:0 22px 54px rgba(0,0,0,.5); }
.portal .pt{ font-family:var(--serif); letter-spacing:.26em; text-transform:uppercase; font-size:.82rem; color:var(--gold-3); }
.portal .pd{ font-size:.96rem; color:var(--cream-soft); margin-top:8px; }
.portal-skip{ margin-top:40px; }
.portal-skip a{ font-family:var(--serif); letter-spacing:.2em; text-transform:uppercase; font-size:.66rem; color:var(--cream-soft); border-bottom:1px solid rgba(233,205,134,.4); padding-bottom:3px; }
.portal-skip a:hover{ color:var(--gold-3); }

/* page fade transition */
.page-fade{ position:fixed; inset:0; z-index:120; background:#04140c; opacity:0; pointer-events:none; transition:opacity .62s ease; }
.page-fade.clear{ opacity:0; }
.page-fade.cover{ opacity:1; pointer-events:all; }

/* ---------- Experiences tip / note ---------- */
.tip{ max-width:720px; margin:6px auto 0; text-align:center; border:1px solid var(--line-strong); border-radius:12px; padding:14px 22px; color:var(--gold-3); font-size:1rem; background:rgba(15,58,38,.4); }
.tip strong{ color:var(--gold-4); }

/* ---------- Partner cards (Experiences) ---------- */
.cat-head{ text-align:left; max-width:none; margin:48px 0 24px; }
.cat-head h2{ font-size:clamp(1.5rem,3vw,2.1rem); }
.cat-head .rule{ margin:14px 0 0; }
.card .body .cat{ font-family:var(--serif); font-size:.62rem; letter-spacing:.28em; text-transform:uppercase; color:var(--turq); margin:0 0 8px; }
.card .body h3{ font-size:1.16rem; letter-spacing:.04em; text-transform:none; }
.card .clinks{ margin-top:auto; padding-top:16px; display:flex; gap:18px; align-items:center; flex-wrap:wrap; }
.card .clink{ display:inline-block; font-family:var(--serif); text-transform:uppercase; letter-spacing:.18em; font-size:.7rem; color:var(--gold-3); border-bottom:1px solid var(--line-strong); padding-bottom:3px; transition:.2s; }
.card .clink:hover{ color:var(--gold-4); border-color:var(--turq); }
.card .clink.alt{ color:var(--cream-soft); border-bottom-color:var(--line); font-size:.62rem; }
.card .clink.alt:hover{ color:var(--turq); }
.card .body{ display:flex; flex-direction:column; height:100%; }

/* ---------- Language visibility ---------- */
[data-lang-es],[data-lang-en]{ display:none; }
html[lang="es"] [data-lang-es]{ display:revert; }
html[lang="en"] [data-lang-en]{ display:revert; }

/* ---------- Mobile nav (hamburger) ---------- */
.nav-inner{ position:relative; }
.nav-toggle{ display:none; flex-direction:column; justify-content:center; gap:5px;
  width:42px; height:42px; padding:9px; background:none; border:0; cursor:pointer; }
.nav-toggle span{ display:block; height:2px; width:100%; background:var(--gold-3);
  border-radius:2px; transition:transform .3s ease, opacity .2s ease; }
.nav-toggle.open span:nth-child(1){ transform:translateY(7px) rotate(45deg); }
.nav-toggle.open span:nth-child(2){ opacity:0; }
.nav-toggle.open span:nth-child(3){ transform:translateY(-7px) rotate(-45deg); }
/* Tablets / pantallas medianas: pestañas EN LINEA pero mas apretadas para que quepan */
@media(max-width:1024px) and (min-width:641px){
  .nav-links{ gap:16px; }
  .nav-links a{ font-size:.58rem; letter-spacing:.10em; }
}
/* Celulares: menu hamburguesa desplegable */
@media(max-width:640px){
  .nav-toggle{ display:flex; }
  .nav-links{
    display:flex; flex-direction:column; align-items:flex-start; gap:22px;
    position:absolute; top:calc(100% + 8px); right:0; min-width:210px;
    background:rgba(8,36,23,.97); border:1px solid var(--line);
    border-radius:10px; padding:24px 28px; box-shadow:0 18px 44px rgba(0,0,0,.5);
    opacity:0; transform:translateY(-10px); pointer-events:none;
    transition:opacity .25s ease, transform .25s ease; z-index:60;
  }
  .nav-links a{ font-size:.74rem; letter-spacing:.22em; }
  .nav-links.open{ opacity:1; transform:translateY(0); pointer-events:auto; }
}
