/* ============ Marea — Riviera Maya ============ */
@import url('https://fonts.googleapis.com/css2?family=Jost:wght@300;400;500&family=Hanken+Grotesk:wght@300;400;500&family=Cormorant+Garamond:ital,wght@0,400;0,500;1,400&display=swap');

:root {
  --paper:#f4f0e7;
  --paper-2:#efe9dc;
  --ink:#2c2b27;
  --ink-soft:#5f5d55;
  --sand:#9a8c74;
  --line:#d8d0bf;
  --accent:#2f9fb3;          /* turquoise — overridden by tweak */
  --accent-deep:#1f7d8e;
  --radius:18px;
  --maxw:1180px;
  --land:#cfd6bb;            /* sage map land */
  --land-2:#e7e2cf;
  font-synthesis:none;
}

* { box-sizing:border-box; }
html { scroll-behavior:smooth; }
body {
  margin:0; background:var(--paper); color:var(--ink);
  font-family:'Hanken Grotesk',system-ui,sans-serif;
  font-weight:300; -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
img { display:block; max-width:100%; }
a { color:inherit; text-decoration:none; }
.wrap { max-width:var(--maxw); margin:0 auto; padding:0 40px; }

/* paper grain */
body::before{
  content:""; position:fixed; inset:0; pointer-events:none; z-index:1; opacity:.5;
  background-image:radial-gradient(rgba(120,110,90,.05) 1px, transparent 1px);
  background-size:4px 4px; mix-blend-mode:multiply;
}

.kicker{ display:flex; align-items:center; gap:12px; font-family:'Jost',sans-serif;
  font-size:13px; letter-spacing:.18em; text-transform:uppercase; color:var(--accent-deep); font-weight:400; }
.kicker::before{ content:""; width:34px; height:1px; background:currentColor; opacity:.6; display:inline-block; }
.kicker.center::before{ display:none; }

h1,h2,h3 { font-family:'Jost',sans-serif; font-weight:300; margin:0; letter-spacing:-.01em; }

/* ============ NAV ============ */
.nav{ position:absolute; top:0; left:0; right:0; z-index:30; }
.nav-inner{ display:flex; align-items:center; justify-content:space-between; padding:30px 40px; max-width:1320px; margin:0 auto; }
.logo{ font-family:'Jost',sans-serif; font-weight:400; font-size:24px; letter-spacing:.01em; color:#fff; display:flex; align-items:baseline; gap:2px; }
.logo b{ font-weight:300; }
.logo .tours{ font-size:.42em; letter-spacing:.26em; text-transform:uppercase; opacity:.7; margin-left:7px; font-weight:400; }
.logo .dot{ width:7px; height:7px; border-radius:50%; background:var(--accent); display:inline-block; margin-left:3px; }
.nav-links{ display:flex; align-items:center; gap:30px; }
.nav-links a{ font-family:'Jost',sans-serif; font-size:15px; color:rgba(255,255,255,.82); font-weight:300; letter-spacing:.02em; padding-bottom:3px; transition:color .2s; }
.nav-links a:hover{ color:#fff; }
.nav-links a.active{ color:#fff; border-bottom:1px solid var(--accent); }
.lang{ display:flex; gap:2px; border:1px solid rgba(255,255,255,.4); border-radius:30px; padding:3px; }
.lang button{ font-family:'Jost',sans-serif; font-size:13px; color:rgba(255,255,255,.75); background:none; border:none; cursor:pointer; padding:3px 11px; border-radius:30px; transition:.2s; }
.lang button.on{ background:#fff; color:var(--ink); }

/* ============ HERO ============ */
.hero{ position:relative; }
.hero-media{
  position:relative; height:min(94vh,920px); min-height:620px;
}
.hero-media img.hero-slide{ position:absolute; inset:0; width:100%; height:100%; object-fit:cover;
  opacity:0; transition:opacity 1.4s ease; will-change:opacity; }
.hero-media img.hero-slide.on{ opacity:1; }
.hero-scrim{ position:absolute; inset:0; z-index:2; pointer-events:none;
  background:
    linear-gradient(180deg, rgba(10,30,40,.30) 0%, rgba(10,30,40,0) 30%, rgba(8,24,34,.10) 55%, rgba(6,20,30,.74) 100%),
    linear-gradient(72deg, rgba(6,20,30,.62) 0%, rgba(6,20,30,.12) 48%, rgba(6,20,30,0) 70%); }
.hero-content{ position:absolute; left:0; right:0; bottom:20%; z-index:5; }
.hero-content .wrap{ max-width:1320px; }
.hero-kicker{ color:#eafaff; }
.hero-kicker::before{ background:#eafaff; }
.hero h1{ color:#fff; font-size:clamp(56px,9vw,128px); line-height:.96; margin:14px 0 0; font-weight:300; text-shadow:0 4px 40px rgba(0,20,30,.5); }
.hero p{ color:rgba(255,255,255,.94); max-width:420px; font-size:17px; line-height:1.6; margin:20px 0 30px; text-shadow:0 1px 14px rgba(0,20,30,.5); }
.hero-dots{ position:absolute; z-index:6; bottom:34%; right:48px; display:flex; flex-direction:column; gap:11px; }
.hdot{ width:9px; height:9px; border-radius:50%; border:none; cursor:pointer; padding:0; background:rgba(255,255,255,.5);
  transition:.3s; box-shadow:0 1px 6px rgba(0,20,30,.5); }
.hdot:hover{ background:rgba(255,255,255,.85); }
.hdot.on{ background:#fff; height:26px; border-radius:6px; }
.pill{ display:inline-flex; align-items:center; gap:14px; background:var(--accent); color:#fff; white-space:nowrap;
  font-family:'Jost',sans-serif; font-size:16px; letter-spacing:.02em; padding:13px 14px 13px 26px; border-radius:40px;
  border:none; cursor:pointer; transition:.25s; box-shadow:0 10px 30px rgba(20,90,100,.3); }
.pill:hover{ background:var(--accent-deep); transform:translateY(-2px); }
.pill .ico{ width:34px; height:34px; border-radius:50%; background:rgba(255,255,255,.22); display:grid; place-items:center; font-size:18px; }

/* ============ SECTION ============ */
.section{ position:relative; z-index:2; padding:30px 0 40px; }
.section-head{ display:grid; grid-template-columns:1fr; gap:18px; max-width:560px; margin-bottom:34px; }
.section-head h2{ font-size:clamp(40px,5vw,64px); color:var(--accent-deep); line-height:1; }
.section-head p{ color:var(--ink-soft); font-size:16px; line-height:1.65; max-width:430px; margin:0; }
.section-head .row{ display:flex; align-items:flex-end; justify-content:space-between; gap:30px; flex-wrap:wrap; }

/* ============ CAROUSEL ============ */
.carousel{ position:relative; }
.track{ display:flex; gap:24px; overflow-x:auto; scroll-snap-type:x mandatory;
  padding:8px 40px 28px; margin:0 -40px; scrollbar-width:none; }
.track::-webkit-scrollbar{ display:none; }
.car-nav{ display:flex; gap:10px; }
.car-btn{ width:48px; height:48px; border-radius:50%; border:1px solid var(--line); background:var(--paper);
  cursor:pointer; display:grid; place-items:center; color:var(--ink); transition:.2s; font-size:18px; }
.car-btn:hover{ background:var(--ink); color:var(--paper); border-color:var(--ink); }
.car-btn:disabled{ opacity:.3; cursor:default; }

/* ----- card (base = clásico) ----- */
.card{ scroll-snap-align:start; flex:0 0 330px; width:330px; transition:width .55s cubic-bezier(.22,1,.36,1), flex-basis .55s cubic-bezier(.22,1,.36,1);
  position:relative; }
.card:not(.open) .card-photo{ cursor:pointer; }
.card.open{ flex-basis:730px; width:730px; }

/* ----- sección Yates: solo 2 cards, llenan todo el ancho ----- */
#yates .track{ display:grid; grid-template-columns:repeat(3,1fr); gap:24px; padding:8px 0 28px; margin:0; overflow:visible; }
#yates .card{ flex:1 1 auto; width:auto; }
#yates .car-nav{ display:none; }
#yates .carousel[data-style="cobertura"] .card:not(.open) .img{ height:540px; }
#yates .card-cap .nm,
#yates .carousel[data-style="cobertura"] .card:not(.open) .card-cap .nm{ font-size:26px; }
#yates .card .img{ height:360px; }
@media (max-width:880px){
  #yates .track{ grid-template-columns:1fr; }
  #yates .carousel[data-style="cobertura"] .card:not(.open) .img{ height:440px; }
}

/* ----- sección Restaurantes: 3 cards, ancho completo ----- */
#restaurantes .track{ display:grid; grid-template-columns:repeat(3,1fr); gap:24px; padding:8px 0 28px; margin:0; overflow:visible; }
#restaurantes .card{ flex:1 1 auto; width:auto; }
#restaurantes .car-nav{ display:none; }
#restaurantes .carousel[data-style="cobertura"] .card:not(.open) .img{ height:560px; }
@media (max-width:880px){
  #restaurantes .track{ grid-template-columns:1fr; }
  #restaurantes .carousel[data-style="cobertura"] .card:not(.open) .img{ height:440px; }
}

/* ----- secciones Actividades y Hospedaje: grid vertical como las demás (no carrusel horizontal) ----- */
#actividades .track, #hospedaje .track{ display:grid; grid-template-columns:repeat(3,1fr); gap:24px; padding:8px 0 28px; margin:0; overflow:visible; }
#actividades .card, #hospedaje .card{ flex:1 1 auto; width:auto; }
#actividades .car-nav, #hospedaje .car-nav{ display:none; }
#actividades .carousel[data-style="cobertura"] .card:not(.open) .img,
#hospedaje .carousel[data-style="cobertura"] .card:not(.open) .img{ height:560px; }
@media (max-width:880px){
  #actividades .track, #hospedaje .track{ grid-template-columns:1fr; }
  #actividades .carousel[data-style="cobertura"] .card:not(.open) .img,
  #hospedaje .carousel[data-style="cobertura"] .card:not(.open) .img{ height:440px; }
}
.card-inner{ display:flex; height:100%; background:#fff; border-radius:var(--radius); overflow:hidden;
  box-shadow:0 18px 40px -28px rgba(40,50,40,.45); border:1px solid rgba(0,0,0,.04); }
.card-photo{ position:relative; flex:0 0 100%; transition:flex-basis .55s cubic-bezier(.22,1,.36,1); }
.card.open .card-photo{ flex-basis:300px; }
.card-photo .ph{ position:relative; width:100%; }
.card .img{ width:100%; height:330px; object-fit:cover; transition:height .55s cubic-bezier(.22,1,.36,1); }
.card.open .img{ height:100%; min-height:480px; }
.card-cap{ padding:18px 20px 20px; }
.card.open .card-cap{ display:none; }
.card-cap .nm{ font-family:'Jost',sans-serif; font-weight:400; font-size:21px; }
.card-cap .pl{ font-size:13px; color:var(--sand); letter-spacing:.04em; margin-top:2px; }
.card-cap .meta{ display:flex; align-items:center; gap:10px; margin-top:14px; flex-wrap:wrap; }
.quote-tag{ display:inline-flex; align-items:center; gap:6px; font-family:'Jost',sans-serif; font-size:13px; white-space:nowrap;
  color:var(--accent-deep); }
.quote-tag svg{ color:#25b35e; }
.price-tag{ font-family:'Jost',sans-serif; font-weight:600; font-size:18px; color:var(--ink); letter-spacing:.01em; white-space:nowrap; }
.dur-chip{ font-size:12px; color:var(--ink-soft); font-family:'Jost',sans-serif; }
.price{ font-family:'Jost',sans-serif; }
.price b{ font-weight:500; font-size:22px; color:var(--ink); }
.price small{ font-size:12px; color:var(--ink-soft); }
.stars{ display:flex; align-items:center; gap:6px; font-size:13px; color:var(--ink-soft); }
.stars .s{ color:var(--accent); letter-spacing:1px; }
.more{ font-family:'Jost',sans-serif; font-size:14.5px; color:var(--accent-deep); background:none; border:none; cursor:pointer; white-space:nowrap;
  display:inline-flex; align-items:center; gap:7px; padding:0; margin:18px 0 0; transition:gap .2s; }
.more:hover{ gap:11px; }
.more .pl-ico{ font-size:17px; line-height:1; opacity:.85; }

/* ----- card cover layout sits on photo when collapsed ----- */
.cover-cap{ display:none; }

/* ----- expanded detail pane ----- */
.detail{ flex:1 1 auto; padding:0; display:flex; flex-direction:column; opacity:0; height:100%;
  transition:opacity .4s ease .15s; min-width:0; }
.card.open .detail{ opacity:1; }
.card.open .card-inner{ height:480px; }
.detail-scroll{ flex:1 1 auto; overflow-y:auto; padding:26px 26px 6px; }
.detail-scroll::-webkit-scrollbar{ width:6px; }
.detail-scroll::-webkit-scrollbar-thumb{ background:var(--line); border-radius:6px; }
.detail .nm{ font-family:'Jost',sans-serif; font-weight:400; font-size:26px; line-height:1.05; }
.detail .pl{ font-size:12.5px; color:var(--sand); letter-spacing:.05em; text-transform:uppercase; margin-top:4px; }
.detail .blurb{ font-size:14.5px; color:var(--ink-soft); line-height:1.6; margin:14px 0 0; }
.facts{ display:grid; grid-template-columns:1fr 1fr; gap:14px 22px; margin-top:18px; }
.fact span{ display:block; font-size:11px; letter-spacing:.08em; text-transform:uppercase; color:var(--sand); }
.fact b{ font-family:'Jost',sans-serif; font-weight:400; font-size:14px; color:var(--ink); line-height:1.3; }
.map-link{ color:var(--accent-deep); border-bottom:1px solid color-mix(in srgb, var(--accent) 45%, transparent); transition:.2s; }
.map-link:hover{ color:var(--accent); border-color:var(--accent); }
.map-pin{ font-size:11px; opacity:.8; }
.detail hr{ border:none; border-top:1px solid var(--line); margin:18px 0; }
.detail h4{ font-family:'Jost',sans-serif; font-weight:500; font-size:12px; letter-spacing:.12em; text-transform:uppercase; color:var(--sand); margin:0 0 12px; }
.inc{ list-style:none; padding:0; margin:0; display:grid; grid-template-columns:1fr 1fr; gap:9px 18px; }
.inc li{ font-size:13.5px; color:var(--ink); display:flex; align-items:flex-start; gap:9px; }
.inc li::before{ content:""; width:14px; height:14px; margin-top:3px; border-radius:50%; flex:none;
  background:var(--accent); -webkit-mask:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='black' d='M9 16.2 4.8 12l-1.4 1.4L9 19 21 7l-1.4-1.4z'/%3E%3C/svg%3E") center/contain no-repeat;
  mask:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='black' d='M9 16.2 4.8 12l-1.4 1.4L9 19 21 7l-1.4-1.4z'/%3E%3C/svg%3E") center/contain no-repeat; }
.menu-block{ margin-top:20px; }
.menu-g{ margin-bottom:12px; }
.menu-h{ font-family:'Cormorant Garamond',serif; font-style:italic; font-size:17px; color:var(--accent-deep); margin-bottom:5px; }
.menu-items{ list-style:none; padding:0; margin:0; columns:2; column-gap:18px; }
.menu-items li{ font-size:13px; color:var(--ink-soft); line-height:1.5; break-inside:avoid; padding-left:12px; position:relative; }
.menu-items li::before{ content:"·"; position:absolute; left:2px; color:var(--accent); }
.notes{ margin:18px 0 0; display:flex; flex-direction:column; gap:6px; }
.notes span{ font-size:11.5px; color:var(--sand); line-height:1.5; padding-left:14px; position:relative; }
.notes span::before{ content:"†"; position:absolute; left:0; }
.detail-foot{ flex:none; border-top:1px solid var(--line); padding:16px 22px 18px; display:flex; align-items:center; justify-content:space-between; gap:14px; background:#fff; }
.quote-line .q1{ font-size:11px; letter-spacing:.08em; text-transform:uppercase; color:var(--sand); display:block; }
.quote-line b{ font-family:'Jost',sans-serif; font-weight:500; font-size:18px; color:var(--ink); }
.quote-line .q2{ display:block; font-size:11.5px; color:var(--sand); margin-top:3px; max-width:300px; }
.actions{ display:flex; align-items:center; gap:10px; }
.book{ background:var(--accent); color:#fff; border:none; cursor:pointer; font-family:'Jost',sans-serif; font-size:15px;
  padding:13px 24px; border-radius:40px; transition:.2s; }
.book:hover{ background:var(--accent-deep); }
.book.wa{ display:inline-flex; align-items:center; gap:8px; background:#25b35e; }
.book.wa:hover{ background:#1ea052; }
.close-x{ background:none; border:1px solid var(--line); width:44px; height:44px; border-radius:50%; cursor:pointer; color:var(--ink-soft); font-size:18px; flex:none; }
.close-x:hover{ border-color:var(--ink); color:var(--ink); }

/* ============ STYLE VARIANT: cobertura (cover) ============ */
.carousel[data-style="cobertura"] .card-inner{ background:transparent; box-shadow:none; border:none; }
.carousel[data-style="cobertura"] .card:not(.open) .card-photo .ph::after{ content:""; position:absolute; inset:0;
  background:linear-gradient(180deg,rgba(8,24,28,0) 30%,rgba(8,24,28,.45) 52%,rgba(8,22,26,.92) 100%); }
.carousel[data-style="cobertura"] .card:not(.open) .img{ height:460px; }
.carousel[data-style="cobertura"] .card:not(.open) .card-cap{ position:absolute; left:0; right:0; bottom:0; padding:22px 22px 20px; }
.carousel[data-style="cobertura"] .card:not(.open) .card-cap .nm{ color:#fff; font-size:25px; text-shadow:0 1px 12px rgba(0,20,24,.5); }
.carousel[data-style="cobertura"] .card:not(.open) .card-cap .pl{ color:rgba(255,255,255,.88); text-shadow:0 1px 8px rgba(0,20,24,.5); }
.carousel[data-style="cobertura"] .card:not(.open) .quote-tag{ color:#fff; text-shadow:0 1px 8px rgba(0,20,24,.5); }
.carousel[data-style="cobertura"] .card:not(.open) .quote-tag svg{ color:#5cf09a; }
.carousel[data-style="cobertura"] .card:not(.open) .price-tag{ color:#fff; text-shadow:0 1px 10px rgba(0,20,24,.55); }
.carousel[data-style="cobertura"] .card:not(.open) .more{ color:#fff; text-shadow:0 1px 10px rgba(0,20,24,.55); }
.carousel[data-style="cobertura"] .card:not(.open) .dur-chip{ color:rgba(255,255,255,.9); text-shadow:0 1px 8px rgba(0,20,24,.5); }
.carousel[data-style="cobertura"] .card.open .card-inner{ background:#fff; box-shadow:0 18px 40px -28px rgba(40,50,40,.45); }

/* ============ STYLE VARIANT: editorial ============ */
.carousel[data-style="editorial"] .card-inner{ flex-direction:column; background:transparent; box-shadow:none; border:none; border-radius:0; }
.carousel[data-style="editorial"] .img{ border-radius:4px; height:360px; }
.carousel[data-style="editorial"] .card:nth-child(even):not(.open){ margin-top:34px; }
.carousel[data-style="editorial"] .card-cap{ padding:16px 2px 0; }
.carousel[data-style="editorial"] .card-cap .nm{ font-family:'Cormorant Garamond',serif; font-size:28px; font-weight:500; }
.carousel[data-style="editorial"] .card.open .card-inner{ flex-direction:row; background:#fff; border-radius:var(--radius);
  box-shadow:0 18px 40px -28px rgba(40,50,40,.45); }
.carousel[data-style="editorial"] .card.open .img{ border-radius:0; }
.carousel[data-style="editorial"] .detail .nm{ font-family:'Cormorant Garamond',serif; font-size:34px; font-weight:500; }

/* ============ MAP ============ */
.map-section{ position:relative; z-index:2; padding:40px 0 90px; }
.map-grid{ display:grid; grid-template-columns:.85fr 1.15fr; gap:40px; align-items:center; }
.map-intro h2{ font-size:clamp(40px,5vw,60px); color:var(--accent-deep); line-height:1; white-space:pre-line; margin-top:16px; }
.map-intro p{ color:var(--ink-soft); font-size:16px; line-height:1.7; max-width:340px; margin:22px 0 0; }
.map-stat{ display:flex; gap:36px; margin-top:30px; }
.map-stat .n{ font-family:'Jost',sans-serif; font-size:34px; color:var(--ink); font-weight:300; }
.map-stat .l{ font-size:12px; color:var(--sand); letter-spacing:.08em; text-transform:uppercase; }

.map-stage{ position:relative; aspect-ratio:4/4.4; }
.map-svg{ position:absolute; inset:0; width:100%; height:100%; overflow:visible; }
.landmass{ position:absolute; }
.land{ position:absolute; background:
    radial-gradient(120% 80% at 60% 30%, rgba(255,255,255,.5), transparent 60%),
    radial-gradient(80% 60% at 30% 70%, rgba(150,160,120,.25), transparent 60%),
    var(--land);
  filter:saturate(.9); }
.land.main{ left:38%; right:-6%; top:4%; bottom:4%;
  border-radius:46% 30% 38% 50%/40% 50% 44% 56%;
  box-shadow:inset 0 0 60px rgba(120,130,90,.25); }
.land.south{ left:42%; right:6%; top:60%; bottom:-4%; background:var(--land-2);
  border-radius:50% 40% 46% 44%/46% 50% 40% 50%; filter:saturate(.85); }
.water-dots{ position:absolute; inset:0;
  background-image:radial-gradient(var(--accent) 1.4px, transparent 1.6px);
  background-size:13px 13px; opacity:.22;
  -webkit-mask:linear-gradient(95deg, #000 32%, transparent 52%); mask:linear-gradient(95deg,#000 32%,transparent 52%); }
.isle{ position:absolute; width:46px; height:30px; background:var(--land-2);
  border-radius:50% 50% 46% 54%/56% 44% 56% 44%; transform:translate(-50%,-50%); box-shadow:inset 0 0 16px rgba(120,130,90,.3); }
.pin{ position:absolute; transform:translate(-50%,-50%); display:flex; align-items:center; gap:8px; z-index:4; white-space:nowrap; }
.pin .dot{ width:13px; height:13px; border-radius:50%; background:var(--paper); border:2px solid var(--accent-deep);
  box-shadow:0 0 0 4px rgba(47,159,179,.18); flex:none; }
.pin .lbl{ font-family:'Cormorant Garamond',serif; font-size:19px; color:var(--ink); font-weight:500; }
.pin.coast .lbl{ color:#4a4636; }
.pin.island .lbl{ color:var(--sand); font-style:italic; }
.dist{ position:absolute; transform:translate(-50%,-50%); background:var(--paper); border:1px solid var(--line);
  border-radius:20px; padding:2px 10px; font-family:'Jost',sans-serif; font-size:11px; color:var(--sand); z-index:5; }
.map-tools{ position:absolute; right:0; bottom:-10px; display:flex; gap:14px; }
.map-tool{ width:74px; height:74px; border-radius:22px; background:#fff; box-shadow:0 18px 40px -26px rgba(40,50,40,.5);
  display:grid; place-items:center; color:var(--ink); font-size:24px; border:1px solid rgba(0,0,0,.04); }

/* ============ FOOTER ============ */
footer{ position:relative; z-index:2; background:var(--paper-2); border-top:1px solid var(--line); margin-top:30px; }
.foot-bar{ display:flex; align-items:center; justify-content:space-between; padding:30px 0; flex-wrap:wrap; gap:16px; }
.foot-bar .logo{ color:var(--ink); font-size:22px; }
.foot-bar .logo .dot{ background:var(--accent); }
.foot-note{ font-size:13px; color:var(--sand); }

/* ============ LIGHTBOX (modal) ============ */
.lb-overlay{ position:fixed; inset:0; z-index:200; background:rgba(8,18,24,.66); backdrop-filter:blur(6px);
  display:grid; place-items:center; padding:28px; animation:lbFade .26s ease; }
@keyframes lbFade{ from{ opacity:0; } to{ opacity:1; } }
.lb{ width:min(1060px,95vw); height:min(680px,90vh); background:#fff; border-radius:22px; overflow:hidden;
  display:flex; position:relative; box-shadow:0 40px 100px -30px rgba(0,0,0,.6);
  animation:lbPop .36s cubic-bezier(.22,1,.36,1); }
@keyframes lbPop{ from{ opacity:0; transform:translateY(16px) scale(.97); } to{ opacity:1; transform:none; } }
.lb-close{ position:absolute; top:16px; right:16px; z-index:8; width:42px; height:42px; border-radius:50%;
  background:rgba(255,255,255,.92); border:none; cursor:pointer; font-size:22px; color:var(--ink); display:grid; place-items:center;
  box-shadow:0 4px 16px rgba(0,0,0,.22); transition:.25s; }
.lb-close:hover{ background:#fff; transform:rotate(90deg); }

.lb-media{ flex:1.12; position:relative; background:#0c1a20; min-width:0; overflow:hidden; }
.lb-img{ position:absolute; inset:0; width:100%; height:100%; object-fit:cover; opacity:0; transition:opacity .5s ease; }
.lb-img.on{ opacity:1; }
.lb-arrow{ position:absolute; top:46%; transform:translateY(-50%); z-index:4; width:46px; height:46px; border-radius:50%;
  background:rgba(255,255,255,.88); border:none; cursor:pointer; font-size:22px; color:var(--ink); display:grid; place-items:center;
  box-shadow:0 4px 14px rgba(0,0,0,.25); transition:.2s; }
.lb-arrow:hover{ background:#fff; transform:translateY(-50%) scale(1.06); }
.lb-arrow.l{ left:16px; }
.lb-arrow.r{ right:16px; }
.lb-count{ position:absolute; top:18px; left:18px; z-index:4; background:rgba(8,18,24,.55); color:#fff;
  font-family:'Jost',sans-serif; font-size:13px; padding:5px 12px; border-radius:20px; }
.lb-thumbs{ position:absolute; left:0; right:0; bottom:0; z-index:4; display:flex; gap:8px; padding:14px 16px 16px;
  background:linear-gradient(0deg, rgba(6,16,20,.72), rgba(6,16,20,0)); }
.lb-thumb{ width:62px; height:46px; border-radius:9px; overflow:hidden; border:2px solid transparent; padding:0; cursor:pointer;
  background:none; opacity:.65; transition:.2s; flex:none; }
.lb-thumb img{ width:100%; height:100%; object-fit:cover; }
.lb-thumb video{ width:100%; height:100%; object-fit:cover; }
.lb-thumb .lb-play{ position:absolute; inset:0; display:grid; place-items:center; color:#fff; font-size:14px;
  text-shadow:0 1px 6px rgba(0,0,0,.7); pointer-events:none; }
.lb-thumb{ position:relative; }
video.lb-img{ object-fit:contain; background:#0c1a20; }
.lb-thumb.on{ border-color:#fff; opacity:1; }
.lb-thumb:hover{ opacity:1; }

.lb-info{ flex:1; display:flex; flex-direction:column; min-width:0; }
.lb-scroll{ flex:1 1 auto; overflow-y:auto; padding:40px 38px 14px; }
.lb-scroll::-webkit-scrollbar{ width:7px; }
.lb-scroll::-webkit-scrollbar-thumb{ background:var(--line); border-radius:7px; }
.lb-head{ padding-right:52px; }
.lb-head .nm{ font-family:'Jost',sans-serif; font-weight:400; font-size:34px; line-height:1.04; color:var(--ink); }
.lb-head .pl{ font-size:12.5px; color:var(--sand); letter-spacing:.06em; text-transform:uppercase; margin-top:7px; }
.lb-info .blurb{ font-size:16px; color:var(--ink-soft); line-height:1.66; margin:18px 0 0; }
.lb-info .facts{ display:grid; grid-template-columns:1fr 1fr; gap:16px 26px; margin-top:22px; }
.lb-info hr{ border:none; border-top:1px solid var(--line); margin:24px 0; }
.lb-info h4{ font-family:'Jost',sans-serif; font-weight:500; font-size:12px; letter-spacing:.12em; text-transform:uppercase; color:var(--sand); margin:0 0 14px; }
.lb-info .inc{ gap:11px 22px; }
.lb-info .inc li{ font-size:15px; }
.lb-info .fact b{ font-size:15px; }
.lb-foot{ flex:none; border-top:1px solid var(--line); padding:18px 28px; display:flex; align-items:center; justify-content:space-between; gap:16px; }
.lb-foot .book.wa{ font-size:16px; padding:14px 26px; }

/* ============ responsive ============ */
@media (max-width:820px){
  .wrap{ padding:0 22px; }
  .nav-inner{ padding:20px 22px; }
  .nav-links a:not(.lang-wrap *){ display:none; }
  .map-grid{ grid-template-columns:1fr; }
  .map-stage{ aspect-ratio:3/3.4; max-width:420px; margin:0 auto; }
  .inc{ grid-template-columns:1fr; }
  .menu-items{ columns:1; }
  .lb{ flex-direction:column; height:92vh; width:94vw; }
  .lb-media{ flex:none; height:38%; }
  .lb-info{ flex:1 1 auto; min-height:0; }
  .lb-scroll{ padding:24px 22px 10px; }
  .lb-head .nm{ font-size:27px; }
  .lb-thumbs{ display:none; }
  .lb-info .facts{ grid-template-columns:1fr 1fr; }
  .lb-foot{ padding:14px 22px; }
}
