/* ===========================================================
   AquaSports Benidorm — hoja de estilos global
   Paleta de marca (logo): menta + azul marino suave
   =========================================================== */

:root{
  --mint:#36c4ad;        /* turquesa menta del logo */
  --mint-d:#22a892;
  --mint-l:#7ad9c9;
  --azul:#2f7ca0;        /* azul océano suave */
  --azul-d:#235f7d;
  --navy:#173a56;        /* marino suave (no negro) */
  --navy-2:#1f4d6e;
  --arena:#e9b765;       /* dorado suave */
  --arena-d:#d9a44a;
  --gris:#f4f8fa;
  --gris-2:#eaf1f4;
  --gris-txt:#5a6b78;
  --negro:#172a36;
  --blanco:#ffffff;
  --radio:18px;
  --sombra:0 12px 34px rgba(23,58,86,.10);
  --sombra-fuerte:0 22px 55px rgba(23,58,86,.18);
  --maxw:1200px;
  --fuente:'Poppins',system-ui,-apple-system,'Segoe UI',Roboto,sans-serif;
}

*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{font-family:var(--fuente);color:var(--negro);background:var(--blanco);line-height:1.65;overflow-x:hidden}
img{max-width:100%;display:block}
a{text-decoration:none;color:inherit}
.container{max-width:var(--maxw);margin:0 auto;padding:0 24px}
section{position:relative}

/* ---------- Iconos SVG (mask, color = currentColor) ---------- */
.ic{display:inline-block;width:1em;height:1em;background:currentColor;vertical-align:-.14em;
  -webkit-mask:center/contain no-repeat;mask:center/contain no-repeat;flex:none}
.ic-pin{-webkit-mask-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath d='M12 2C8.13 2 5 5.13 5 9c0 5.25 7 13 7 13s7-7.75 7-13c0-3.87-3.13-7-7-7zm0 9.5a2.5 2.5 0 110-5 2.5 2.5 0 010 5z'/%3E%3C/svg%3E");mask-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath d='M12 2C8.13 2 5 5.13 5 9c0 5.25 7 13 7 13s7-7.75 7-13c0-3.87-3.13-7-7-7zm0 9.5a2.5 2.5 0 110-5 2.5 2.5 0 010 5z'/%3E%3C/svg%3E")}
.ic-phone{-webkit-mask-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath d='M20.01 15.38c-1.23 0-2.42-.2-3.53-.56a.98.98 0 00-1.01.24l-1.57 1.97c-2.83-1.35-5.48-3.9-6.89-6.83l1.95-1.66c.27-.28.35-.67.24-1.02-.37-1.11-.56-2.3-.56-3.53 0-.54-.45-.99-.99-.99H4.19C3.65 3 3 3.24 3 3.99 3 13.28 10.73 21 20.01 21c.71 0 .99-.63.99-1.18v-3.45c0-.54-.45-.99-.99-.99z'/%3E%3C/svg%3E");mask-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath d='M20.01 15.38c-1.23 0-2.42-.2-3.53-.56a.98.98 0 00-1.01.24l-1.57 1.97c-2.83-1.35-5.48-3.9-6.89-6.83l1.95-1.66c.27-.28.35-.67.24-1.02-.37-1.11-.56-2.3-.56-3.53 0-.54-.45-.99-.99-.99H4.19C3.65 3 3 3.24 3 3.99 3 13.28 10.73 21 20.01 21c.71 0 .99-.63.99-1.18v-3.45c0-.54-.45-.99-.99-.99z'/%3E%3C/svg%3E")}
.ic-chat{-webkit-mask-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath d='M20 2H4c-1.1 0-2 .9-2 2v18l4-4h14c1.1 0 2-.9 2-2V4c0-1.1-.9-2-2-2z'/%3E%3C/svg%3E");mask-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath d='M20 2H4c-1.1 0-2 .9-2 2v18l4-4h14c1.1 0 2-.9 2-2V4c0-1.1-.9-2-2-2z'/%3E%3C/svg%3E")}
.ic-star{-webkit-mask-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath d='M12 17.27L18.18 21l-1.64-7.03L22 9.24l-7.19-.61L12 2 9.19 8.63 2 9.24l5.46 4.73L5.82 21z'/%3E%3C/svg%3E");mask-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath d='M12 17.27L18.18 21l-1.64-7.03L22 9.24l-7.19-.61L12 2 9.19 8.63 2 9.24l5.46 4.73L5.82 21z'/%3E%3C/svg%3E")}
.ic-check{-webkit-mask-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath d='M9 16.2L4.8 12l-1.4 1.4L9 19 21 7l-1.4-1.4z'/%3E%3C/svg%3E");mask-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath d='M9 16.2L4.8 12l-1.4 1.4L9 19 21 7l-1.4-1.4z'/%3E%3C/svg%3E")}
.ic-bolt{-webkit-mask-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath d='M7 2v11h3v9l7-12h-4l4-8z'/%3E%3C/svg%3E");mask-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath d='M7 2v11h3v9l7-12h-4l4-8z'/%3E%3C/svg%3E")}
.ic-shield{-webkit-mask-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath d='M12 1L3 5v6c0 5.55 3.84 10.74 9 12 5.16-1.26 9-6.45 9-12V5l-9-4zm-2 16l-4-4 1.41-1.41L10 14.17l6.59-6.59L18 9l-8 8z'/%3E%3C/svg%3E");mask-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath d='M12 1L3 5v6c0 5.55 3.84 10.74 9 12 5.16-1.26 9-6.45 9-12V5l-9-4zm-2 16l-4-4 1.41-1.41L10 14.17l6.59-6.59L18 9l-8 8z'/%3E%3C/svg%3E")}
.ic-buoy{-webkit-mask-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath d='M12 2a10 10 0 100 20 10 10 0 000-20zm6.32 5.1l-2.7 2.7a5 5 0 00-1.42-1.42l2.7-2.7a8 8 0 011.42 1.42zM12 15a3 3 0 110-6 3 3 0 010 6zM8.4 6.4l2.7 2.7a5 5 0 00-1.42 1.42l-2.7-2.7A8 8 0 018.4 6.4zM5.68 16.9l2.7-2.7a5 5 0 001.42 1.42l-2.7 2.7a8 8 0 01-1.42-1.42zm9.94 1.42l-2.7-2.7a5 5 0 001.42-1.42l2.7 2.7a8 8 0 01-1.42 1.42z'/%3E%3C/svg%3E");mask-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath d='M12 2a10 10 0 100 20 10 10 0 000-20zm6.32 5.1l-2.7 2.7a5 5 0 00-1.42-1.42l2.7-2.7a8 8 0 011.42 1.42zM12 15a3 3 0 110-6 3 3 0 010 6zM8.4 6.4l2.7 2.7a5 5 0 00-1.42 1.42l-2.7-2.7A8 8 0 018.4 6.4zM5.68 16.9l2.7-2.7a5 5 0 001.42 1.42l-2.7 2.7a8 8 0 01-1.42-1.42zm9.94 1.42l-2.7-2.7a5 5 0 001.42-1.42l2.7 2.7a8 8 0 01-1.42 1.42z'/%3E%3C/svg%3E")}
.ic-wave{-webkit-mask-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath d='M12 2c-3.5 4.5-6 7.8-6 11a6 6 0 0012 0c0-3.2-2.5-6.5-6-11z'/%3E%3C/svg%3E");mask-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath d='M12 2c-3.5 4.5-6 7.8-6 11a6 6 0 0012 0c0-3.2-2.5-6.5-6-11z'/%3E%3C/svg%3E")}

/* ---------- Tipografía ---------- */
h1,h2,h3{font-weight:700;line-height:1.15;letter-spacing:-.4px;color:var(--navy)}
h2.titulo{font-size:clamp(1.8rem,4vw,2.7rem);text-align:center}
.subtitulo{text-align:center;color:var(--gris-txt);max-width:660px;margin:14px auto 0;font-size:1.05rem}
.eyebrow{display:inline-block;color:var(--mint-d);font-weight:600;letter-spacing:2.5px;text-transform:uppercase;font-size:.78rem;margin-bottom:8px}

/* ---------- Botones ---------- */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:9px;padding:14px 28px;border-radius:50px;font-weight:600;font-size:1rem;cursor:pointer;border:none;transition:.25s;white-space:nowrap}
.btn .ic{width:1.15em;height:1.15em}
.btn-primario{background:linear-gradient(135deg,var(--mint),var(--azul));color:#fff;box-shadow:0 10px 24px rgba(47,124,160,.32)}
.btn-primario:hover{transform:translateY(-3px);box-shadow:0 16px 32px rgba(47,124,160,.42)}
.btn-arena{background:var(--arena);color:var(--navy)}
.btn-arena:hover{transform:translateY(-3px);box-shadow:0 14px 28px rgba(233,183,101,.45)}
.btn-blanco{background:#fff;color:var(--azul-d)}
.btn-blanco:hover{transform:translateY(-3px);box-shadow:0 12px 26px rgba(0,0,0,.12)}
.btn-grande{padding:17px 38px;font-size:1.08rem}

/* ---------- Header (blanco sólido) ---------- */
.header{position:fixed;top:0;left:0;width:100%;z-index:1000;
  background:rgba(18,48,72,.24);-webkit-backdrop-filter:blur(16px) saturate(1.3);backdrop-filter:blur(16px) saturate(1.3);
  border-bottom:1px solid rgba(255,255,255,.14);transition:.35s;padding:12px 0}
.header.scrolled{background:rgba(255,255,255,.92);-webkit-backdrop-filter:blur(18px) saturate(1.6);backdrop-filter:blur(18px) saturate(1.6);
  border-bottom-color:rgba(23,58,86,.06);box-shadow:0 6px 26px rgba(23,58,86,.12);padding:8px 0}
.nav{display:flex;align-items:center;justify-content:space-between;gap:18px}
.logo{display:flex;align-items:center}
.logo img{height:46px;width:auto;transition:.3s;filter:brightness(0) invert(1) drop-shadow(0 2px 8px rgba(11,30,42,.35))}
.header.scrolled .logo img{height:40px;filter:none}
.nav-links{display:flex;align-items:center;gap:22px;list-style:none}
.nav-links a{color:#fff;font-weight:500;font-size:.93rem;transition:.2s;text-shadow:0 1px 10px rgba(11,30,42,.32)}
.nav-links a:hover,.nav-links a.activo{color:var(--mint-l)}
.header.scrolled .nav-links a{color:var(--navy);text-shadow:none}
.header.scrolled .nav-links a:hover,.header.scrolled .nav-links a.activo{color:var(--mint-d)}
.nav-actions{display:flex;align-items:center;gap:14px}
.lang-switch{display:flex;gap:3px;font-size:.82rem;font-weight:600}
.lang-switch a{padding:5px 9px;border-radius:8px;color:#fff}
.lang-switch a.activo{background:var(--mint);color:#fff}
.header.scrolled .lang-switch a{color:var(--gris-txt)}
.header.scrolled .lang-switch a.activo{color:#fff}
.menu-toggle{display:none;flex-direction:column;gap:5px;cursor:pointer;background:none;border:none;padding:8px}
.menu-toggle span{width:26px;height:3px;background:#fff;border-radius:3px;transition:.3s}
.header.scrolled .menu-toggle span{background:var(--navy)}

/* ---------- Hero ---------- */
.hero{min-height:100vh;display:flex;align-items:center;color:#fff;position:relative;overflow:hidden;
  background:linear-gradient(120deg,var(--navy),var(--mint))}
.hero::before{content:"";position:absolute;inset:0;z-index:0;
  background:linear-gradient(115deg,rgba(23,58,86,.62),rgba(47,124,160,.28) 60%,rgba(54,196,173,.18)),
  url('/img/hero.jpg') center/cover no-repeat;
  animation:kenburns 24s ease-in-out infinite alternate}
.hero::after{content:"";position:absolute;bottom:-1px;left:0;width:100%;height:90px;z-index:1;
  background:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 1440 90'%3E%3Cpath fill='%23ffffff' d='M0,40 C360,90 1080,0 1440,50 L1440,90 L0,90 Z'/%3E%3C/svg%3E") bottom/cover no-repeat}
@keyframes kenburns{from{transform:scale(1) translate(0,0)}to{transform:scale(1.12) translate(-1.5%,1%)}}
.hero-content{max-width:740px;padding-top:140px;padding-bottom:90px;position:relative;z-index:2}
.hero h1{font-size:clamp(2.3rem,6vw,4.1rem);margin-bottom:18px;color:#fff;text-shadow:0 4px 30px rgba(11,30,42,.35)}
.hero p{font-size:clamp(1.05rem,2vw,1.28rem);margin-bottom:30px;opacity:.96;max-width:560px;text-shadow:0 2px 14px rgba(11,30,42,.3)}
.hero-cta{display:flex;gap:16px;flex-wrap:wrap}
.hero-badges{display:flex;gap:30px;margin-top:42px;flex-wrap:wrap}
.hero-badge{display:flex;align-items:center;gap:12px;font-size:.95rem}
.hero-badge .ic{width:24px;height:24px;color:var(--mint-l)}
.hero-badge b{font-size:1.35rem;display:block;line-height:1.1}

/* ---------- Actividades ---------- */
.actividades{padding:96px 0;background:var(--gris)}
.grid-act{display:grid;grid-template-columns:repeat(auto-fill,minmax(290px,1fr));gap:28px;margin-top:54px}
.card-act{background:#fff;border-radius:var(--radio);overflow:hidden;box-shadow:var(--sombra);transition:.3s;position:relative;display:flex;flex-direction:column}
.card-act:hover{transform:translateY(-8px);box-shadow:var(--sombra-fuerte)}
.card-act .img{height:215px;background-size:cover;background-position:center;position:relative}
.card-act .img::after{content:"";position:absolute;inset:0;background:linear-gradient(to top,rgba(23,58,86,.28),transparent 55%)}
.card-act.destacada{box-shadow:0 0 0 3px var(--arena),var(--sombra)}
.badge-top{position:absolute;top:14px;left:14px;background:var(--arena);color:var(--navy);padding:7px 15px;border-radius:50px;font-size:.78rem;font-weight:700;z-index:2;box-shadow:0 6px 16px rgba(23,58,86,.2);display:inline-flex;align-items:center;gap:6px}
.badge-top .ic{width:14px;height:14px}
.badge-top.azul{background:var(--mint);color:#fff}
.card-act .body{padding:24px;display:flex;flex-direction:column;flex:1}
.card-act h3{font-size:1.3rem;margin-bottom:9px}
.card-act p{color:var(--gris-txt);font-size:.95rem;margin-bottom:18px;flex:1}
.card-link{display:inline-flex;align-items:center;gap:6px;color:var(--mint-d);font-weight:600;font-size:.95rem}
.card-link:hover{gap:11px}

/* ---------- Franja CTA ---------- */
.franja{padding:78px 0;background:linear-gradient(135deg,var(--navy),var(--azul) 70%,var(--mint));color:#fff;text-align:center}
.franja h2{font-size:clamp(1.6rem,4vw,2.3rem);margin-bottom:14px;color:#fff}
.franja p{opacity:.95;max-width:580px;margin:0 auto 28px}

/* ---------- Features ---------- */
.features{padding:96px 0}
.grid-feat{display:grid;grid-template-columns:repeat(auto-fit,minmax(230px,1fr));gap:32px;margin-top:54px}
.feat{text-align:center;padding:18px}
.feat .ico{width:74px;height:74px;margin:0 auto 20px;border-radius:22px;display:grid;place-items:center;
  background:linear-gradient(135deg,var(--mint-l),var(--azul));color:#fff;box-shadow:0 12px 26px rgba(47,124,160,.25)}
.feat .ico .ic{width:34px;height:34px}
.feat h3{margin-bottom:8px;font-size:1.15rem}
.feat p{color:var(--gris-txt);font-size:.95rem}

/* ---------- Página actividad ---------- */
.act-hero{min-height:62vh;display:flex;align-items:flex-end;color:#fff;position:relative;padding-bottom:54px;
  background:linear-gradient(120deg,rgba(23,58,86,.62),rgba(47,124,160,.34)),var(--bg-act,linear-gradient(120deg,var(--navy),var(--mint)));
  background-size:cover;background-position:center}
.act-hero .container{padding-top:130px;position:relative;z-index:2}
.breadcrumb{font-size:.85rem;opacity:.9;margin-bottom:16px}
.breadcrumb a:hover{text-decoration:underline}
.act-hero h1{font-size:clamp(2rem,5vw,3.3rem);max-width:780px;color:#fff;line-height:1.14;text-shadow:0 3px 22px rgba(11,30,42,.35)}
.act-hero .precio-hero{margin-top:20px;font-size:1.18rem;color:#fff;font-weight:500;opacity:.95;display:flex;align-items:center;gap:13px;text-shadow:0 2px 14px rgba(11,30,42,.3)}
.hero-reserva-btn{margin-top:30px;box-shadow:0 10px 30px rgba(233,183,101,.35)}
.hero-reserva-btn .ic{width:20px;height:20px}
#reservar{scroll-margin-top:96px}
.act-hero .precio-hero::before{content:"";width:34px;height:3px;border-radius:3px;background:var(--arena);flex:none}
.act-body{padding:74px 0;display:grid;grid-template-columns:1.1fr .9fr;gap:54px;align-items:start}
.act-info h2{font-size:1.55rem;margin:0 0 16px}
.act-info p{color:var(--gris-txt);margin-bottom:16px}
.act-info ul{list-style:none;margin:20px 0}
.act-info ul li{padding:9px 0 9px 34px;position:relative}
.act-info ul li::before{content:"";position:absolute;left:0;top:11px;width:22px;height:22px;background:var(--mint);
  border-radius:50%;-webkit-mask:none;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='%23fff'%3E%3Cpath d='M9 16.2L4.8 12l-1.4 1.4L9 19 21 7l-1.4-1.4z'/%3E%3C/svg%3E");background-size:15px;background-repeat:no-repeat;background-position:center}
.reserva-box{background:var(--gris);border-radius:var(--radio);padding:28px;box-shadow:var(--sombra);position:sticky;top:92px}
.reserva-box h3{margin-bottom:6px}
.reserva-box h4{color:var(--navy);font-size:1.02rem}
.reserva-box .nota{font-size:.86rem;color:var(--gris-txt);margin-bottom:18px}
.load-turitop{min-height:110px}

/* ---------- Footer ---------- */
.footer{background:var(--navy);color:#c2d3dd;padding:74px 0 28px}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1.4fr;gap:40px}
.footer h4{color:#fff;margin-bottom:18px;font-size:1.05rem}
.footer a{color:#c2d3dd;font-size:.95rem;display:block;margin-bottom:10px;transition:.2s}
.footer a:hover{color:var(--mint-l)}
.footer .logo-foot{height:50px;margin-bottom:16px;background:#fff;padding:8px 12px;border-radius:12px;display:inline-block}
.footer .logo-foot img{height:34px}
.footer .desc{font-size:.92rem;line-height:1.7;opacity:.88}
.footer .contacto-item{display:flex;gap:11px;margin-bottom:13px;font-size:.95rem;align-items:flex-start}
.footer .contacto-item .ic{width:18px;height:18px;color:var(--mint-l);margin-top:3px}
.footer .contacto-item a{display:inline;margin:0}
.footer-map{margin-top:16px;border-radius:12px;overflow:hidden;box-shadow:0 8px 22px rgba(0,0,0,.25)}
.footer-map iframe{display:block;width:100%;height:150px;border:0;filter:invert(.92) hue-rotate(180deg) brightness(.96) contrast(.92)}
.footer-bottom{border-top:1px solid rgba(255,255,255,.12);margin-top:52px;padding-top:24px;text-align:center;font-size:.85rem;opacity:.7}

/* ---------- WhatsApp flotante ---------- */
.wsp{position:fixed;bottom:24px;right:24px;width:60px;height:60px;background:#25d366;border-radius:50%;display:grid;place-items:center;z-index:999;box-shadow:0 10px 28px rgba(37,211,102,.45);transition:.25s}
.wsp:hover{transform:scale(1.1)}
.wsp svg{width:32px;height:32px;fill:#fff}

/* ---------- Galería + Lightbox ---------- */
.gallery{padding:90px 0;background:var(--gris)}
.gal-grid{columns:4 250px;column-gap:18px;margin-top:46px}
.gal-item{break-inside:avoid;margin-bottom:18px;border-radius:16px;overflow:hidden;cursor:pointer;position:relative;box-shadow:var(--sombra);background:var(--gris-2)}
.gal-item img{width:100%;display:block;transition:transform .6s cubic-bezier(.2,.7,.2,1)}
.gal-item:hover img{transform:scale(1.07)}
.gal-item::after{content:"";position:absolute;inset:0;background:linear-gradient(to top,rgba(23,58,86,.3),transparent 55%);opacity:0;transition:.3s}
.gal-item:hover::after{opacity:1}
.lightbox{position:fixed;inset:0;background:rgba(9,22,31,.93);z-index:2000;display:none;align-items:center;justify-content:center;padding:30px;backdrop-filter:blur(3px)}
.lightbox.open{display:flex}
.lightbox img{max-width:92vw;max-height:86vh;border-radius:12px;box-shadow:0 24px 70px rgba(0,0,0,.55)}
.lb-btn{position:absolute;background:rgba(255,255,255,.14);border:none;color:#fff;width:52px;height:52px;border-radius:50%;font-size:1.4rem;line-height:1;cursor:pointer;display:grid;place-items:center;transition:.2s}
.lb-btn:hover{background:rgba(255,255,255,.3)}
.lb-close{top:24px;right:24px}
.lb-prev{left:24px;top:50%;transform:translateY(-50%)}
.lb-next{right:24px;top:50%;transform:translateY(-50%)}
@media(max-width:600px){.gal-grid{columns:2 150px;column-gap:12px}.gal-item{margin-bottom:12px}.lb-prev{left:10px}.lb-next{right:10px}.lb-close{top:14px;right:14px}}

/* ---------- Animaciones de scroll ---------- */
.reveal{opacity:0;transform:translateY(30px);transition:opacity .8s cubic-bezier(.2,.7,.2,1),transform .8s cubic-bezier(.2,.7,.2,1)}
.reveal.in{opacity:1;transform:none}
@media(prefers-reduced-motion:reduce){.reveal{opacity:1;transform:none;transition:none}.hero::before{animation:none}}

/* Parallax en hero de páginas interiores (escritorio) */
@media(min-width:900px){.act-hero{background-attachment:fixed}}

/* ---------- Responsive ---------- */
.nav-links{font-size:.9rem}
@media(max-width:1150px){
  .nav-links{position:fixed;top:0;right:-100%;height:100vh;width:78%;max-width:330px;background:var(--navy);
    flex-direction:column;justify-content:center;gap:30px;transition:.35s;box-shadow:-12px 0 44px rgba(0,0,0,.32);padding:0 30px}
  .nav-links.open{right:0}
  .nav-links a,.header.scrolled .nav-links a{color:#fff;font-size:1.12rem;text-shadow:none}
  .nav-links a:hover,.nav-links a.activo,.header.scrolled .nav-links a:hover,.header.scrolled .nav-links a.activo{color:var(--mint-l)}
  .menu-toggle{display:flex;z-index:1001}
  .nav-links.open ~ .nav-actions .menu-toggle span:nth-child(1){transform:translateY(8px) rotate(45deg)}
  .nav-links.open ~ .nav-actions .menu-toggle span:nth-child(2){opacity:0}
  .nav-links.open ~ .nav-actions .menu-toggle span:nth-child(3){transform:translateY(-8px) rotate(-45deg)}
  .act-body{grid-template-columns:1fr;gap:36px}
  section.act-body{padding-top:44px;padding-bottom:50px}
  .reserva-box{position:static}
  .footer-grid{grid-template-columns:1fr 1fr}
}
@media(max-width:560px){
  .container{padding:0 26px}
  .footer-grid{grid-template-columns:1fr}
  .hero{min-height:auto;align-items:flex-start}
  .hero-content{padding-top:120px;padding-bottom:96px}
  .hero h1{font-size:clamp(2rem,8vw,2.6rem)}
  .hero-cta{flex-direction:column}
  .hero-cta .btn{width:100%}
  .hero-badges{gap:18px;margin-top:34px}
  .act-hero{min-height:66vh;padding-bottom:46px}
  .act-hero .container{padding-top:120px}
  .act-hero h1{font-size:clamp(1.85rem,7.5vw,2.5rem)}
  .act-hero .precio-hero{font-size:1.04rem;margin-top:16px}
  .hero-reserva-btn{margin-top:26px;width:100%;justify-content:center}
  .logo img{height:40px}
  .wsp{width:52px;height:52px;bottom:18px;right:18px}
  .wsp svg{width:28px;height:28px}
}
