/* ============================================================
   La Pirata Cantina — styles.css
   Mobile-first. Design tokens + sections. Modern CSS, light JS.
   ============================================================ */

/* ---------- fonts (self-hosted, swap) ---------- */
@font-face{font-family:"Cinzel";src:url("/assets/fonts/cinzel.woff2") format("woff2");
  font-weight:600 700;font-style:normal;font-display:swap;}
@font-face{font-family:"Cinzel Decorative";src:url("/assets/fonts/cinzel-deco.woff2") format("woff2");
  font-weight:700;font-style:normal;font-display:swap;}

/* ---------- design tokens ---------- */
:root{
  --ink:#0c0a08; --rum:#160f0a; --wood:#241710; --wood-2:#33221733;
  --parch:#f1e4c8; --parch-2:#e7d6b2; --bone:#f7f0e1; --muted:#cdbfa6;
  --brass:#c79a3a; --gold:#e7c25a; --gold-2:#f3da8a;
  --turq:#15b3ae; --turq-2:#34d8ce; --coral:#e8674c; --jungle:#1c6f54; --amber:#f0892f;
  --ink-soft:#1a130d; --line:#3a2a1c;
  --shadow:0 18px 50px -20px rgba(0,0,0,.7);
  --maxw:1180px; --pad:clamp(1.1rem,5vw,3rem);
  --r:14px; --r-lg:22px;
  --serif:"Cinzel",Georgia,"Times New Roman",serif;
  --display:"Cinzel Decorative","Cinzel",Georgia,serif;
  --sans:system-ui,-apple-system,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;
  --dock-h:64px;
}

/* ---------- reset / base ---------- */
*,*::before,*::after{box-sizing:border-box}
html{-webkit-text-size-adjust:100%;scroll-behavior:smooth}
@media (prefers-reduced-motion:reduce){html{scroll-behavior:auto}}
body{margin:0;background:var(--ink);color:var(--bone);font-family:var(--sans);
  font-size:clamp(1rem,.96rem + .3vw,1.075rem);line-height:1.6;
  -webkit-font-smoothing:antialiased;overflow-x:hidden}
img,picture,svg,iframe{display:block;max-width:100%}
img{height:auto}
a{color:inherit;text-decoration:none}
h1,h2,h3{font-family:var(--serif);font-weight:700;line-height:1.05;margin:0;
  letter-spacing:.01em}
p{margin:0 0 1rem}
:focus-visible{outline:3px solid var(--turq-2);outline-offset:3px;border-radius:6px}
.skip{position:fixed;left:50%;top:-60px;transform:translateX(-50%);z-index:200;
  background:var(--gold);color:#1a1206;padding:.6rem 1rem;border-radius:0 0 10px 10px;
  font-weight:700;transition:top .2s}
.skip:focus{top:0}
.wrap{width:min(100% - 2*var(--pad),var(--maxw));margin-inline:auto}
.wrap-narrow{max-width:760px}
.icon{width:1.25em;height:1.25em;flex:0 0 auto}
.icon-sm{width:1em;height:1em}
.icon-lg{width:1.9rem;height:1.9rem}

/* ---------- buttons ---------- */
.btn{display:inline-flex;align-items:center;gap:.5rem;justify-content:center;
  font-weight:700;font-size:.98rem;padding:.85rem 1.25rem;border-radius:999px;
  border:2px solid transparent;cursor:pointer;position:relative;overflow:hidden;
  min-height:48px;transition:transform .15s ease,box-shadow .2s ease,background .2s}
.btn:active{transform:translateY(1px) scale(.99)}
.btn-gold{background:linear-gradient(180deg,var(--gold-2),var(--brass));color:#241404;
  box-shadow:0 10px 26px -10px rgba(199,154,58,.8)}
.btn-gold:hover{filter:brightness(1.05)}
.btn-wa{background:#1fa855;color:#fff}
.btn-wa:hover{background:#1ebd5f}
.btn-ghost{background:rgba(255,255,255,.07);color:var(--bone);
  border-color:rgba(247,240,225,.35);backdrop-filter:blur(6px)}
.btn-ghost:hover{background:rgba(255,255,255,.16)}
.btn-outline-gold{background:transparent;color:var(--gold-2);border-color:var(--gold)}
.btn-outline-gold:hover{background:var(--gold);color:#241404}
/* hover shine */
.btn::after{content:"";position:absolute;inset:0;background:linear-gradient(110deg,
  transparent 25%,rgba(255,255,255,.45) 50%,transparent 75%);
  transform:translateX(-130%);transition:transform .6s}
.btn:hover::after{transform:translateX(130%)}
@media (prefers-reduced-motion:reduce){.btn::after{display:none}}

.eyebrow{font-family:var(--serif);text-transform:uppercase;letter-spacing:.22em;
  font-size:.72rem;color:var(--brass);margin:0 0 .6rem;font-weight:600}
.eyebrow-light{color:var(--gold-2)}

/* ---------- header ---------- */
.site-head{position:sticky;top:0;z-index:100;display:flex;align-items:center;gap:1rem;
  padding:.55rem var(--pad);background:linear-gradient(180deg,rgba(12,10,8,.92),rgba(12,10,8,.62));
  backdrop-filter:blur(10px);border-bottom:1px solid #ffffff14}
.brand{display:flex;align-items:center;gap:.55rem;color:var(--bone);margin-right:auto}
.brand-ico{width:2.3rem;height:2.3rem;object-fit:contain;
  filter:drop-shadow(0 2px 6px rgba(0,0,0,.55))}
.brand-txt{font-family:var(--display);font-size:1.02rem;line-height:.95;display:flex;
  flex-direction:column;letter-spacing:.02em}
.brand-txt small{font-family:var(--serif);font-size:.6rem;letter-spacing:.34em;
  color:var(--brass);font-weight:600}
.topnav{display:none}
.head-right{display:flex;align-items:center;gap:.5rem}
.glamp-pill{display:none}
.lang-toggle{display:inline-flex;align-items:center;justify-content:center;min-width:44px;
  min-height:40px;padding:0 .7rem;border:1.5px solid var(--brass);border-radius:999px;
  color:var(--gold-2);font-weight:700;font-size:.85rem;letter-spacing:.05em}
.lang-toggle:hover{background:var(--brass);color:#241404}
.nav-burger{display:inline-flex;align-items:center;justify-content:center;width:44px;height:44px;
  background:transparent;border:1.5px solid #ffffff33;border-radius:12px;color:var(--bone);cursor:pointer}
.mobnav{display:flex;flex-direction:column;gap:.2rem;padding:.4rem var(--pad) 1rem;
  background:var(--rum);border-bottom:1px solid #ffffff14;position:sticky;top:57px;z-index:99}
.mobnav[hidden]{display:none}
.mobnav a{padding:.85rem .4rem;border-bottom:1px solid #ffffff10;font-weight:600}
.mobnav-lang{color:var(--gold-2)}

/* ---------- hero ---------- */
.hero{position:relative;min-height:100svh;display:flex;align-items:flex-end;
  padding:0 var(--pad) calc(var(--dock-h) + .8rem);overflow:hidden;isolation:isolate}
.hero-bg{position:absolute;inset:0;z-index:-2}
.hero-bg img{width:100%;height:100%;object-fit:cover}
.hero-scrim{position:absolute;inset:0;z-index:-1;background:
  radial-gradient(120% 90% at 70% 10%,transparent 30%,rgba(8,6,4,.55) 100%),
  linear-gradient(180deg,rgba(8,6,4,.55) 0%,rgba(8,6,4,.15) 35%,rgba(8,6,4,.85) 100%)}
.hero-waves{position:absolute;left:0;right:0;bottom:-1px;width:100%;height:90px;z-index:-1;
  color:var(--ink)}
.hero-waves path{fill:currentColor}
.hero-inner{max-width:760px;animation:rise .9s cubic-bezier(.2,.7,.2,1) both}
.kicker{font-family:var(--serif);text-transform:uppercase;letter-spacing:.28em;
  font-size:clamp(.65rem,2.6vw,.8rem);color:var(--gold-2);margin:0 0 .7rem;font-weight:600}
.hero-title{font-family:var(--display);font-size:clamp(2.5rem,11vw,6.3rem);
  color:var(--bone);text-shadow:0 6px 30px rgba(0,0,0,.6);margin:0 0 .4rem;line-height:1;
  padding-left:.14em;margin-left:-.04em;overflow-wrap:break-word}
.hero-sub{font-family:var(--serif);font-size:clamp(1.05rem,4.4vw,1.7rem);color:var(--gold-2);
  margin:0 0 .55rem;font-weight:600;letter-spacing:.01em}
.hero-lead{font-size:clamp(.95rem,3.3vw,1.18rem);color:#f3ece0;max-width:46ch;
  text-shadow:0 2px 12px rgba(0,0,0,.6);margin:0 0 1rem}
.hero-cta{display:grid;grid-template-columns:1fr 1fr;gap:.6rem;max-width:540px}
.hero-cta .btn{width:100%;padding-inline:.7rem;font-size:.9rem}
.hero-scroll{position:absolute;left:50%;bottom:1rem;transform:translateX(-50%);
  color:#fff8;animation:bob 1.8s ease-in-out infinite}
.hero-scroll .icon{width:2rem;height:2rem}
@keyframes rise{from{opacity:0;transform:translateY(26px)}to{opacity:1;transform:none}}
@keyframes bob{0%,100%{transform:translate(-50%,0)}50%{transform:translate(-50%,8px)}}
@media (prefers-reduced-motion:reduce){.hero-inner,.hero-scroll{animation:none}}

/* ---------- strip ---------- */
.strip{background:linear-gradient(90deg,var(--wood),#3a2412,var(--wood));
  border-block:1px solid #00000040;text-align:center;padding:1.1rem var(--pad)}
.strip p{margin:0;font-family:var(--serif);font-size:clamp(1rem,3.6vw,1.35rem);
  color:var(--gold-2);letter-spacing:.02em}

/* ---------- sections ---------- */
.section{padding:clamp(3rem,8vw,6rem) 0;position:relative}
.sec-head{max-width:640px;margin:0 auto clamp(1.6rem,4vw,2.6rem);text-align:center}
.sec-head h2{font-size:clamp(1.9rem,7vw,3.1rem)}
.sec-sub{color:var(--muted);margin:.7rem 0 0;font-size:1.05rem}

/* ---------- menu (parchment) ---------- */
.menu{background:
  radial-gradient(140% 120% at 50% -10%,#fff6e6 0%,var(--parch) 45%,var(--parch-2) 100%);
  color:#2a1c0e}
.menu .eyebrow{color:#9a6b1e}
.menu .sec-sub{color:#6b4f2c}
.menu-tabs{display:flex;gap:.4rem;justify-content:center;margin:0 auto 1.5rem;
  background:#00000010;padding:.3rem;border-radius:999px;width:max-content;max-width:100%}
.mtab{appearance:none;border:0;background:transparent;font-family:var(--serif);font-weight:700;
  font-size:.95rem;letter-spacing:.05em;text-transform:uppercase;color:#6b4f2c;
  padding:.6rem 1.4rem;border-radius:999px;cursor:pointer;min-height:44px}
.mtab.is-active{background:linear-gradient(180deg,var(--gold-2),var(--brass));color:#2a1404;
  box-shadow:0 6px 16px -8px rgba(160,110,30,.8)}
.menu-panel.is-hidden{display:none}
/* showcase strip */
.sc-label{font-family:var(--serif);text-transform:uppercase;letter-spacing:.18em;
  font-size:.78rem;color:#9a6b1e;text-align:center;margin:0 0 .7rem;font-weight:700}
.showcase{display:grid;grid-auto-flow:column;grid-auto-columns:72%;gap:.8rem;overflow-x:auto;
  scroll-snap-type:x mandatory;padding-bottom:.8rem;margin-bottom:1.6rem;
  -webkit-overflow-scrolling:touch;scrollbar-width:thin}
.sc-item{margin:0;scroll-snap-align:center;border-radius:var(--r);overflow:hidden;
  background:#fff;box-shadow:0 10px 24px -16px #5a3a14;position:relative}
.sc-item img{width:100%;aspect-ratio:4/3;object-fit:cover}
.sc-item figcaption{font-family:var(--serif);font-weight:600;font-size:.86rem;color:#3a2812;
  padding:.55rem .7rem;background:#fff}
/* menu groups */
.menu-group{border:1px solid #c9ad79;border-radius:var(--r);background:#fffdf6cc;
  margin:0 auto .8rem;max-width:760px;overflow:hidden}
.menu-group summary{display:flex;align-items:center;gap:.6rem;cursor:pointer;list-style:none;
  padding:1rem 1.1rem;font-family:var(--serif);background:#f7ecd2}
.menu-group summary::-webkit-details-marker{display:none}
.mg-title{font-size:1.18rem;font-weight:700;color:#3a2510}
.m-note{font-size:.8rem;color:#8a6a3c;font-style:italic;margin-left:.2rem}
.mg-chev{width:1.05rem;height:1.05rem;flex:0 0 auto;margin-left:auto;
  transition:transform .25s;color:#9a6b1e;opacity:.7}
.menu-group[open] .mg-chev{transform:rotate(180deg)}
.m-list{list-style:none;margin:0;padding:.4rem 1.1rem 1.1rem}
.m-item{padding:.7rem 0;border-bottom:1px dashed #d8c193}
.m-item:last-child{border-bottom:0}
.m-row{display:flex;align-items:baseline;gap:.6rem}
.m-name{font-family:var(--serif);font-weight:700;font-size:1.05rem;color:#2a1c0e}
.m-price{margin-left:auto;font-family:var(--serif);font-weight:700;color:#9a6b1e;white-space:nowrap}
.m-price.m-mkt{font-size:.82rem;font-style:italic;color:#a85a2a}
.m-desc{margin:.2rem 0 0;font-size:.92rem;color:#5e4528;line-height:1.45}
/* restaurant-style legend icon marks (not tech pills) */
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;
  clip:rect(0 0 0 0);white-space:nowrap;border:0}
.m-marks{display:inline-flex;gap:.28rem;margin-left:.5rem;vertical-align:-2px}
.m-mark{display:inline-flex}
.mk{width:1.02rem;height:1.02rem;color:#a9781f}
.m-mark[title="Captain's Pick"] .mk,.m-mark[title="Favorito del Capitán"] .mk{color:#b8860b}
.menu-key{list-style:none;display:flex;flex-wrap:wrap;justify-content:center;gap:.5rem 1.2rem;
  max-width:760px;margin:0 auto 1.5rem;padding:.8rem 1.1rem;border:1px dashed #c9ad79;
  border-radius:14px;background:#fffdf6aa}
.menu-key li{display:inline-flex;align-items:center;gap:.4rem;font-family:var(--serif);
  font-size:.82rem;color:#6b4f2c}
.menu-key .mk{color:#9a6b1e}
.m-pricenote,.m-cheers{max-width:760px;margin:1rem auto 0;text-align:center;
  font-style:italic;color:#6b4f2c;font-size:.92rem}
.m-cheers{font-family:var(--serif);font-style:normal;color:#9a2d22;font-weight:700}
.link-original{display:flex;align-items:center;justify-content:center;gap:.4rem;
  margin:1.6rem auto 0;font-weight:700;color:#9a6b1e;text-decoration:underline;
  text-underline-offset:4px;width:max-content}

/* ---------- activities (dark) ---------- */
.activities{background:linear-gradient(180deg,var(--ink),#14100b)}
.act-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:.8rem}
.act-card{background:linear-gradient(180deg,#1f1812,#171009);border:1px solid #ffffff12;
  border-radius:var(--r);padding:1.1rem;box-shadow:var(--shadow)}
.act-card h3{font-size:1.08rem;color:var(--gold-2);margin:.6rem 0 .35rem}
.act-card p{margin:0;font-size:.9rem;color:var(--muted);line-height:1.45}
.act-ico{display:inline-flex;padding:.6rem;border-radius:12px;color:var(--turq-2);
  background:radial-gradient(circle at 30% 30%,#13403e,#0c2422);border:1px solid #ffffff14}

/* ---------- arrival (image + readable glass card) ---------- */
.arrival{position:relative;isolation:isolate;overflow:hidden;text-align:center;
  display:flex;align-items:center;justify-content:center;
  padding:clamp(2.6rem,9vw,6rem) var(--pad)}
.arrival-bg{position:absolute;inset:0;z-index:-2}
.arrival-bg img{width:100%;height:100%;object-fit:cover}
.arrival-scrim{position:absolute;inset:0;z-index:-1;
  background:radial-gradient(90% 85% at 50% 50%,rgba(8,6,4,.5),rgba(8,6,4,.82))}
.arrival-inner{position:relative;width:100%;max-width:560px;
  background:rgba(11,8,6,.52);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);
  border:1px solid #ffffff26;border-radius:20px;box-shadow:0 24px 60px -24px #000;
  padding:clamp(1.5rem,5.5vw,2.6rem)}
.arrival-inner h2{font-size:clamp(1.8rem,6.5vw,3rem);color:var(--bone)}
.arrival-sub{font-family:var(--serif);color:var(--gold-2);font-size:clamp(1.05rem,4vw,1.35rem);margin:.35rem 0 .9rem}
.arrival-body{color:#f1e9dc;margin:0 auto 1.4rem;max-width:46ch}

/* ---------- gallery ---------- */
.gallery{background:var(--ink)}
.g-grid{columns:2;column-gap:.8rem}
@media (max-width:380px){.g-grid{columns:1}}
.g-item{margin:0 0 .8rem;break-inside:avoid;border-radius:var(--r);overflow:hidden;
  position:relative;background:#14100b;box-shadow:var(--shadow)}
.g-item img{width:100%;height:auto}
.g-item figcaption{position:absolute;left:0;right:0;bottom:0;padding:1.4rem .8rem .6rem;
  font-family:var(--serif);font-size:.85rem;color:#fff;
  background:linear-gradient(180deg,transparent,rgba(0,0,0,.78))}
.g-badge{display:inline-block;font-family:var(--sans);font-size:.6rem;font-weight:800;
  text-transform:uppercase;letter-spacing:.08em;color:#241404;background:var(--gold-2);
  padding:.12rem .45rem;border-radius:6px;margin-right:.45rem;vertical-align:middle}

/* ---------- glamp crossover (luxe, readable glass card) ---------- */
.glamp{position:relative;isolation:isolate;overflow:hidden;text-align:center;
  display:flex;align-items:center;justify-content:center;
  padding:clamp(2.6rem,9vw,6rem) var(--pad)}
.glamp-bg{position:absolute;inset:0;z-index:-2}
.glamp-bg img{width:100%;height:100%;object-fit:cover}
.glamp-scrim{position:absolute;inset:0;z-index:-1;
  background:radial-gradient(90% 85% at 50% 50%,rgba(6,10,12,.5),rgba(5,9,11,.85))}
.glamp-inner{position:relative;width:100%;max-width:580px;
  background:rgba(7,11,13,.5);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);
  border:1px solid #ffffff24;border-radius:20px;box-shadow:0 24px 60px -24px #000;
  padding:clamp(1.5rem,5.5vw,2.8rem)}
.glamp-inner h2{font-size:clamp(1.8rem,6.5vw,2.9rem);color:#f5f1e8;font-family:var(--serif);
  font-weight:600;letter-spacing:.05em}
.glamp-body{color:#ece9e0;font-size:1.02rem;line-height:1.7;margin:1rem 0 1.5rem}

/* ---------- location ---------- */
.location{background:linear-gradient(180deg,#14100b,var(--ink))}
.loc-grid{display:grid;gap:1.4rem}
.loc-info .sec-sub{text-align:left}
.loc-dl{display:grid;grid-template-columns:auto 1fr;gap:.4rem 1rem;margin:1.2rem 0 1.4rem;
  font-size:.96rem}
.loc-dl dt{font-family:var(--serif);font-weight:700;color:var(--gold-2)}
.loc-dl dd{margin:0;color:var(--muted)}
.loc-dl a{color:var(--turq-2);text-decoration:underline;text-underline-offset:3px}
.loc-map{border-radius:var(--r-lg);overflow:hidden;border:1px solid #ffffff1a;box-shadow:var(--shadow)}
.loc-map iframe{width:100%;height:300px;border:0;filter:saturate(.9)}

/* ---------- faq ---------- */
.faq{background:linear-gradient(180deg,var(--ink),#160f0a)}
.faq-list{display:grid;gap:.6rem}
.faq-item{border:1px solid #ffffff14;border-radius:var(--r);background:#18120c;overflow:hidden}
.faq-item summary{display:flex;align-items:center;gap:.6rem;cursor:pointer;list-style:none;
  padding:1rem 1.1rem;font-family:var(--serif);font-weight:700;font-size:1.02rem;color:var(--bone)}
.faq-item summary::-webkit-details-marker{display:none}
.faq-item[open]{border-color:var(--brass)}
.faq-item[open] .mg-chev{transform:rotate(180deg)}
.faq-a{padding:0 1.1rem 1.1rem}
.faq-a p{margin:0;color:var(--muted)}

/* ---------- footer ---------- */
.site-foot{background:#0a0806;border-top:1px solid #ffffff14;padding:clamp(2.5rem,6vw,4rem) 0 calc(var(--dock-h) + 2rem)}
.foot-grid{display:grid;gap:1.8rem}
.foot-brand .brand-ico{width:3.2rem;height:3.2rem}
.foot-name{font-family:var(--display);font-size:1.3rem;margin:.5rem 0 .2rem;color:var(--bone)}
.foot-tag{color:var(--gold-2);font-family:var(--serif);margin:0 0 .4rem}
.foot-loc{color:var(--muted);font-size:.9rem;margin:0}
.foot-col h3{font-family:var(--serif);font-size:.8rem;text-transform:uppercase;
  letter-spacing:.16em;color:var(--brass);margin:0 0 .7rem}
.foot-col a{display:block;padding:.32rem 0;color:#d8cdb8;font-size:.95rem}
.foot-col a:hover{color:var(--gold-2)}
.foot-legal{margin-top:2rem;padding-top:1.4rem;border-top:1px solid #ffffff12;color:#8c7f68;
  font-size:.78rem}
.foot-legal p{margin:.2rem 0}
.foot-fine{color:#6f6450}

/* ---------- sticky mobile dock ---------- */
.dock{position:fixed;left:0;right:0;bottom:0;z-index:120;display:grid;
  grid-template-columns:repeat(5,1fr);height:var(--dock-h);
  background:linear-gradient(180deg,rgba(20,14,9,.86),rgba(12,9,6,.97));
  backdrop-filter:blur(12px);border-top:1px solid #ffffff1f;
  padding-bottom:env(safe-area-inset-bottom)}
.dock a{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.15rem;
  color:#e7dcc6;font-size:.62rem;font-weight:600;letter-spacing:.02em}
.dock a .icon{width:1.35rem;height:1.35rem;color:var(--gold-2)}
.dock .dock-wa .icon{color:#4fd07e}
.dock a:active{background:#ffffff12}

/* ---------- reveal animations ---------- */
.reveal{opacity:0;transform:translateY(22px);transition:opacity .7s ease,transform .7s cubic-bezier(.2,.7,.2,1);
  transition-delay:calc(var(--i,0)*60ms)}
.reveal.in{opacity:1;transform:none}
@media (prefers-reduced-motion:reduce){.reveal{opacity:1;transform:none;transition:none}}

/* ============================================================
   DESKTOP / larger screens
   ============================================================ */
@media (min-width:760px){
  .topnav{display:flex;gap:1.4rem;align-items:center}
  .topnav a{font-family:var(--serif);font-weight:600;font-size:.92rem;color:#e7dcc6;
    letter-spacing:.04em;position:relative;padding:.2rem 0}
  .topnav a::after{content:"";position:absolute;left:0;right:100%;bottom:-4px;height:2px;
    background:var(--gold);transition:right .25s}
  .topnav a:hover::after{right:0}
  .glamp-pill{display:inline-flex;align-items:center;min-height:40px;padding:0 1rem;
    border-radius:999px;background:linear-gradient(180deg,var(--gold-2),var(--brass));
    color:#241404;font-weight:700;font-size:.85rem}
  .nav-burger,.mobnav{display:none}
  .dock{display:none}
  .hero{padding-bottom:clamp(3rem,11vh,6.5rem)}
  .site-foot{padding-bottom:clamp(2.5rem,6vw,4rem)}
  .hero-cta{display:flex;flex-wrap:wrap;gap:.7rem;max-width:none}
  .hero-cta .btn{width:auto;flex:0 0 auto;min-width:0;font-size:.98rem}
  .act-grid{grid-template-columns:repeat(4,1fr);gap:1rem}
  .g-grid{columns:3;column-gap:1rem}
  .loc-grid{grid-template-columns:1fr 1fr;align-items:center}
  .loc-map iframe{height:380px}
  .sc-item img{aspect-ratio:4/3}
  .showcase{grid-auto-columns:minmax(0,1fr);grid-auto-flow:column;overflow:visible}
}
@media (min-width:1024px){
  .hero-title{font-size:clamp(4rem,7vw,7rem)}
  .showcase{gap:1rem}
}

/* container query polish for activity cards where supported */
@supports (container-type:inline-size){
  .act-grid{container-type:inline-size}
}

/* ============================================================
   EPIC UPGRADE v2
   ============================================================ */

/* ---- body font: Fraunces for prose (UI/prices stay sans) ---- */
@font-face{font-family:"Fraunces";src:url("/assets/fonts/fraunces.woff2") format("woff2");
  font-weight:400 600;font-style:normal;font-display:swap;
  ascent-override:94%;descent-override:24%;line-gap-override:0%;}
:root{--body:"Fraunces",Georgia,"Times New Roman",serif;}
.hero-lead,.sec-sub,.m-desc,.arrival-body,.glamp-body,.mantra-sub,.vy-stop p,.faq-a p,
.act-card p,.loc-info .sec-sub,.foot-tag,.m-pricenote{font-family:var(--body);font-optical-sizing:auto}

/* ---- animated gold sheen on display text ---- */
@property --shine{syntax:"<angle>";inherits:false;initial-value:95deg}
.shine{background:linear-gradient(var(--shine),var(--brass) 0%,var(--gold-2) 44%,#fff7da 50%,var(--gold-2) 56%,var(--brass) 100%);
  -webkit-background-clip:text;background-clip:text;color:transparent;animation:sheen 7s linear infinite}
@keyframes sheen{to{--shine:455deg}}
@media (prefers-reduced-motion:reduce){.shine{animation:none}}

/* ---- film grain overlay ---- */
.grain{position:fixed;inset:0;z-index:140;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='120' height='120'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.8' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
  background-size:140px}

/* ---- status chip (cantina is OPEN) ---- */
.status-chip{display:inline-flex;align-items:center;gap:.5rem;align-self:flex-start;max-width:100%;
  padding:.42rem .85rem;border:1px solid #ffffff33;border-radius:999px;background:rgba(10,8,6,.42);
  backdrop-filter:blur(6px);font-family:var(--serif);font-size:.72rem;letter-spacing:.05em;
  text-transform:uppercase;color:var(--bone);margin-bottom:1rem;line-height:1.2}
.status-dot{width:.5rem;height:.5rem;border-radius:50%;background:#3ad07e;flex:0 0 auto;
  box-shadow:0 0 0 0 #3ad07e88;animation:pulse 2.6s ease-out infinite}
@keyframes pulse{0%{box-shadow:0 0 0 0 #3ad07e88}70%{box-shadow:0 0 0 8px #3ad07e00}100%{box-shadow:0 0 0 0 #3ad07e00}}
@media (prefers-reduced-motion:reduce){.status-dot{animation:none}}

/* ---- hero: staggered cascade + embers ---- */
.hero-cascade{animation:none}
.hero-cascade>*{opacity:0;animation:rise .8s cubic-bezier(.2,.7,.2,1) both}
.hero-cascade>:nth-child(1){animation-delay:.05s}
.hero-cascade>:nth-child(2){animation-delay:.16s}
.hero-cascade>:nth-child(3){animation-delay:.27s}
.hero-cascade>:nth-child(4){animation-delay:.38s}
.hero-cascade>:nth-child(5){animation-delay:.49s}
@media (prefers-reduced-motion:reduce){.hero-cascade>*{opacity:1;animation:none}}
.hero-embers{position:absolute;inset:0;z-index:-1;pointer-events:none;overflow:hidden}
.hero-embers::before,.hero-embers::after{content:"";position:absolute;left:0;bottom:-12px;
  width:4px;height:4px;border-radius:50%;background:#ffd9a0;opacity:0;
  box-shadow:9vw 0 #ffce8f,18vw -4vh #ffb968,28vw -8vh #ffd9a0,38vw -2vh #ffae57,
    50vw -10vh #ffd9a0,62vw -5vh #ffce8f,73vw -12vh #ffb968,85vw -3vh #ffd9a0,95vw -9vh #ffce8f;
  animation:ember 10s linear infinite}
.hero-embers::after{animation-duration:14s;animation-delay:3.5s;filter:blur(1px)}
@keyframes ember{0%{transform:translateY(0);opacity:0}12%{opacity:.85}88%{opacity:.45}100%{transform:translateY(-92vh);opacity:0}}
@media (prefers-reduced-motion:reduce){.hero-embers{display:none}}

/* ---- brand mantra band ---- */
.mantra{position:relative;overflow:hidden;text-align:center;padding:clamp(2.2rem,6vw,3.8rem) var(--pad);
  background:linear-gradient(90deg,#150d07,#34200f,#150d07);border-block:1px solid #00000055}
.mantra::before{content:"";position:absolute;inset:0;
  background:radial-gradient(70% 130% at 50% 130%,#f0892f55,transparent 70%);animation:glow 7s ease-in-out infinite alternate}
@keyframes glow{from{opacity:.45}to{opacity:1}}
@media (prefers-reduced-motion:reduce){.mantra::before{animation:none;opacity:.7}}
.mantra .wrap{position:relative}
.mantra-big{font-family:var(--display);font-size:clamp(1.9rem,7.5vw,3.6rem);margin:0;line-height:1.04}
.mantra-sub{color:var(--gold-2);margin:.7rem 0 0;font-size:clamp(1rem,3.6vw,1.3rem);font-style:italic}

/* ---- Plan Your Voyage ---- */
.voyage{background:linear-gradient(180deg,#14100b,#0e0b08)}
.voyage-map{position:relative;border-radius:var(--r-lg);overflow:hidden;border:1px solid #ffffff1a;
  box-shadow:var(--shadow);margin-bottom:clamp(1.4rem,4vw,2.2rem);aspect-ratio:5/2;min-height:150px}
.voyage-bg{position:absolute;inset:0}
.voyage-bg img{width:100%;height:100%;object-fit:cover;opacity:.92}
.voyage-map::after{content:"";position:absolute;inset:0;
  background:radial-gradient(130% 110% at 50% 50%,transparent 38%,#0e0b08e0)}
.voyage-route{position:absolute;inset:0;width:100%;height:100%;z-index:2}
/* route + ship: one-time draw on reveal (no scroll-timeline = no flicker) */
.route-path{fill:none;stroke:var(--gold-2);stroke-width:3.4;stroke-linecap:round;
  stroke-dasharray:1300;stroke-dashoffset:0;filter:drop-shadow(0 1px 2px #000a);
  transition:stroke-dashoffset 1.8s ease}
.route-ship{fill:var(--gold-2);stroke:#2a1708;stroke-width:1.4;offset-distance:96%;
  filter:drop-shadow(0 1px 2px #000b);transition:offset-distance 1.9s ease}
@media (prefers-reduced-motion:no-preference){
  .js .voyage-map:not(.in) .route-path{stroke-dashoffset:1300}
  .js .voyage-map:not(.in) .route-ship{offset-distance:0%}
}
@media (prefers-reduced-motion:reduce){.route-path,.route-ship{transition:none}}
.vy-stops{list-style:none;margin:0;padding:0;display:grid;grid-template-columns:repeat(2,1fr);gap:.8rem}
.vy-stop{position:relative;background:linear-gradient(180deg,#1f1812,#171009);border:1px solid #ffffff12;
  border-radius:var(--r);padding:1.1rem;box-shadow:var(--shadow)}
.vy-num{position:absolute;top:.5rem;right:.85rem;font-family:var(--display);color:#ffffff1f;font-size:1.7rem;line-height:1}
.vy-ico{display:inline-flex;padding:.55rem;border-radius:12px;color:var(--gold-2);
  background:radial-gradient(circle at 30% 30%,#3a2a12,#211606);border:1px solid #ffffff14}
.vy-stop h3{color:var(--gold-2);font-size:1.05rem;margin:.6rem 0 .3rem}
.vy-stop p{margin:0 0 .6rem;color:var(--muted);font-size:.9rem;line-height:1.45}
.vy-act{display:inline-flex;align-items:center;gap:.35rem;color:var(--turq-2);font-weight:700;font-size:.85rem;font-family:var(--sans)}
.vy-act:hover{color:var(--gold-2)}

/* ---- menu polish ---- */
.menu-tabs{position:sticky;top:60px;z-index:30}
.m-item:has(.m-mark[title="Captain's Pick"]),
.m-item:has(.m-mark[title="Favorito del Capitán"]){
  background:linear-gradient(90deg,#fff6e0,transparent 80%);border-left:3px solid var(--gold);
  padding-left:.7rem;border-radius:6px;margin-block:.15rem}
.m-price.m-mkt{color:#fff;font-style:normal;font-weight:800;font-size:.66rem;text-transform:uppercase;
  letter-spacing:.04em;background:#9a2d22;padding:.26rem .5rem;border-radius:6px;transform:rotate(-3deg);
  box-shadow:0 2px 6px #9a2d2240}
/* torn pennant edges on the parchment menu band */
.menu{position:relative}
.menu::before,.menu::after{content:"";position:absolute;left:0;right:0;height:14px;z-index:2;
  background:linear-gradient(135deg,var(--ink) 0 7px,transparent 0) 0 0/15px 15px repeat-x,
            linear-gradient(-135deg,var(--ink) 0 7px,transparent 0) 0 0/15px 15px repeat-x}
.menu::before{top:-1px}
.menu::after{bottom:-1px;transform:scaleY(-1)}

/* ---- view-transition tab swap (default cross-fade) ---- */
@media (prefers-reduced-motion:reduce){::view-transition-group(*){animation:none!important}}

/* ---- footer icon links ---- */
.foot-col a{display:flex;align-items:center;gap:.45rem}
.foot-col .icon-sm{color:var(--brass);flex:0 0 auto}

/* ---- subtle vignette on dark bands ---- */
.activities,.voyage,.gallery,.faq{box-shadow:inset 0 0 120px #00000055}

/* ---- After Dark (nightlife) ---- */
.nightlife{position:relative;isolation:isolate;overflow:hidden;color:var(--bone);
  padding:clamp(3rem,9vw,6rem) 0}
.night-bg{position:absolute;inset:0;z-index:-2}
.night-bg img{width:100%;height:100%;object-fit:cover}
.night-scrim{position:absolute;inset:0;z-index:-1;
  background:linear-gradient(180deg,rgba(8,7,10,.84),rgba(10,8,12,.66) 42%,rgba(8,7,10,.92))}
.night-inner{text-align:center}
.night-inner .sec-head h2{color:var(--gold-2)}
.night-sub{color:#ecdfc4}
.night-lead{max-width:58ch;margin:0 auto clamp(1.4rem,4vw,2rem);color:#efe6d6;font-family:var(--body)}
.night-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:.8rem;
  margin-bottom:clamp(1.2rem,4vw,1.8rem)}
.night-card{background:rgba(20,14,9,.55);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);
  border:1px solid #ffffff20;border-radius:var(--r);padding:1.1rem;box-shadow:var(--shadow)}
.night-card h3{color:var(--gold-2);font-size:1.05rem;margin:.55rem 0 .3rem}
.night-card p{margin:0;color:var(--muted);font-size:.9rem;line-height:1.45}
.night-ico{display:inline-flex;padding:.6rem;border-radius:12px;color:var(--amber);
  background:radial-gradient(circle at 30% 30%,#3a2412,#1c1206);border:1px solid #ffffff20}
.np-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:.8rem;
  margin-bottom:clamp(1.4rem,4vw,2rem)}
.np-item{margin:0;border-radius:var(--r);overflow:hidden;position:relative;box-shadow:var(--shadow)}
.np-item img{width:100%;aspect-ratio:4/3;object-fit:cover;display:block}
.np-item figcaption{position:absolute;left:0;right:0;bottom:0;padding:1.2rem .7rem .55rem;
  font-family:var(--serif);font-size:.82rem;color:#fff;
  background:linear-gradient(180deg,transparent,rgba(0,0,0,.8))}
.night-cta{text-align:center}
@media (max-width:640px){.night-grid{grid-template-columns:1fr}.np-grid{grid-template-columns:1fr 1fr}}
@media (max-width:380px){.np-grid{grid-template-columns:1fr}}
