/* ============================================================
   WHISKY LOVERS V — CARTAGENA 2026
   ============================================================ */

@font-face{
  font-family:"Archivo";
  src:url("../assets/fonts/Archivo-Bold.ttf") format("truetype");
  font-weight:700; font-style:normal; font-display:swap;
}
@font-face{
  font-family:"Satoshi";
  src:url("../assets/fonts/Satoshi-Bold.otf") format("opentype");
  font-weight:700; font-style:normal; font-display:swap;
}
@font-face{
  font-family:"Satoshi";
  src:url("../assets/fonts/Satoshi-Italic.otf") format("opentype");
  font-weight:400; font-style:italic; font-display:swap;
}

:root{
  /* palette */
  --bg-paper:#FAE2C0;
  --bg-paper-2:#F1CE82;
  --bg-night:#2A130E;
  --bg-ember:#4F2520;
  --surface-tan:#F1CE82;
  --surface-sage:#9CB6B5;
  --ink-primary:#4F2520;
  --ink-inverse:#FAE2C0;
  --ink-muted:#9D2A1D;
  --accent-amber:#F2A93C;
  --accent-coral:#E63224;
  --accent-mauve:#BC92AB;
  --accent-gold:#F1CE82;
  --rule:rgba(79,37,32,.35);
  --rule-inverse:rgba(241,206,130,.45);

  /* type */
  --f-display:"Fraunces",Georgia,serif;
  --f-label:"Archivo","Helvetica Neue",Arial,sans-serif;
  --f-body:"Satoshi","Inter",system-ui,sans-serif;
  --f-mono:"Courier New",Courier,monospace;

  /* layout */
  --maxw:1280px;
  --pad-x:clamp(20px,4vw,80px);
  --sec-pad:clamp(80px,12vw,160px);
}

*,*::before,*::after{box-sizing:border-box}
html,body{margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:var(--f-body);
  color:var(--ink-primary);
  background:var(--bg-paper);
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  line-height:1.6;
  overflow-x:hidden;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
button{font:inherit;background:none;border:0;cursor:pointer;color:inherit}
em,i{font-style:italic}
ul{padding:0;list-style:none}

.skip{position:absolute;left:-9999px;top:0;background:var(--ink-primary);color:var(--ink-inverse);padding:10px 16px;z-index:9999}
.skip:focus{left:8px;top:8px}

/* paper / night surfaces */
.paper{background:var(--bg-paper);color:var(--ink-primary)}
.night{background:var(--bg-night);color:var(--ink-inverse)}

/* paper grain */
.paper::before, .night::before{
  content:"";position:absolute;inset:0;pointer-events:none;
  background-image:
    radial-gradient(rgba(79,37,32,.05) 1px,transparent 1px),
    radial-gradient(rgba(79,37,32,.04) 1px,transparent 1px);
  background-size:3px 3px,7px 7px;
  background-position:0 0,1px 1px;
  opacity:.7;
  mix-blend-mode:multiply;
}
.night::before{
  background-image:
    radial-gradient(rgba(241,206,130,.05) 1px,transparent 1px),
    radial-gradient(rgba(241,206,130,.04) 1px,transparent 1px);
  mix-blend-mode:screen;
  opacity:.45;
}
section{position:relative}
section > *{position:relative}

/* ============== TYPOGRAPHY ============== */
.display{
  font-family:var(--f-display);
  font-weight:600;
  font-size:clamp(44px,4.6vw,76px);
  line-height:.98;
  letter-spacing:-.02em;
  margin:0;
}
.display em{
  display:block;
  font-style:italic;
  font-weight:400;
  font-variation-settings:"opsz" 144,"SOFT" 80,"WONK" 1;
  color:var(--accent-amber);
}
h2{
  font-family:var(--f-display);
  font-weight:600;
  font-size:clamp(36px,5.4vw,72px);
  line-height:1.04;
  letter-spacing:-.015em;
  margin:0 0 12px;
}
h2 em{font-style:italic;font-weight:400;color:var(--accent-coral)}
.night h2 em{color:var(--accent-amber)}
h3{
  font-family:var(--f-display);
  font-weight:600;
  font-size:clamp(22px,2.4vw,30px);
  line-height:1.18;
  margin:8px 0 10px;
  letter-spacing:-.01em;
}
h4{
  font-family:var(--f-label);
  font-weight:700;
  font-size:14px;
  letter-spacing:.18em;
  text-transform:uppercase;
  margin:0 0 14px;
}
h5{
  font-family:var(--f-label);
  font-weight:700;
  font-size:12px;
  letter-spacing:.18em;
  text-transform:uppercase;
  margin:0 0 14px;
  color:var(--accent-amber);
}
.eyebrow{
  font-family:var(--f-label);
  font-weight:700;
  font-size:12px;
  letter-spacing:.22em;
  text-transform:uppercase;
  color:var(--ink-muted);
  display:inline-block;
  margin-bottom:18px;
}
.night .eyebrow{color:var(--accent-amber)}
.typewriter{
  font-family:var(--f-mono);
  font-style:italic;
  font-size:clamp(14px,1.4vw,17px);
  letter-spacing:.01em;
  opacity:.85;
  max-width:46ch;
}

/* rules / ornaments */
.rule{display:inline-block;height:1px;flex:1;background:var(--rule)}
.night .rule{background:var(--rule-inverse)}
.rule--gold{
  background:linear-gradient(90deg,#F1CE82 0%,#F2A93C 50%,#F1CE82 100%);
  height:1.5px;
  opacity:.85;
}
.ornament{display:flex;align-items:center;gap:18px;justify-content:center;max-width:340px;margin:60px auto 0;color:var(--accent-amber)}
.ornament__glyph{font-size:14px}

/* ============== BUTTONS ============== */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:10px;
  font-family:var(--f-label);
  font-weight:700;
  font-size:13px;
  letter-spacing:.14em;
  text-transform:uppercase;
  padding:18px 28px;
  border-radius:999px;
  border:1.5px solid var(--ink-primary);
  background:var(--accent-amber);
  color:var(--ink-primary);
  transition:transform .25s ease, box-shadow .25s ease, background .25s ease, color .25s ease;
  will-change:transform;
  text-align:center;
  line-height:1.2;
  max-width:100%;
  word-break:keep-all;
  overflow-wrap:break-word;
}
.btn:hover{
  background:var(--accent-coral);
  color:var(--ink-inverse);
  transform:rotate(-1deg) translateY(-1px);
  box-shadow:4px 4px 0 var(--ink-primary);
}
.btn:focus-visible{outline:3px solid var(--accent-gold);outline-offset:3px}
.btn--ghost{
  background:transparent;
  border-color:var(--ink-primary);
  color:var(--ink-primary);
}
.night .btn--ghost{border-color:var(--ink-inverse);color:var(--ink-inverse)}
.btn--ghost:hover{background:var(--ink-primary);color:var(--ink-inverse);box-shadow:none;transform:translateY(-1px)}
.night .btn--ghost:hover{background:var(--ink-inverse);color:var(--ink-primary)}
.btn--big{padding:24px 36px;font-size:15px;letter-spacing:.16em}
.btn__icon{display:inline-flex;align-items:center}

/* ============== NAV ============== */
.nav{
  position:fixed;inset:0 0 auto 0;z-index:100;
  background:transparent;
  transition:background .35s ease, box-shadow .35s ease, color .35s ease;
  color:var(--ink-primary);
}
.nav__wrap{
  max-width:var(--maxw);
  margin:0 auto;
  padding:14px var(--pad-x);
  display:flex;align-items:center;gap:24px;
  min-height:78px;
}
.nav__brand{display:flex;align-items:center;gap:14px;flex-shrink:0}
.nav__seal{
  width:54px;height:54px;border-radius:50%;background:#FFF5DD;
  padding:5px;
  box-shadow:0 0 0 1.5px currentColor inset, 0 0 0 4px #FFF5DD inset, 0 0 0 5px currentColor inset;
  transition:transform .35s cubic-bezier(.22,1,.36,1);
}
.nav__brand:hover .nav__seal{transform:rotate(-12deg)}
.nav__brand-stack{display:flex;flex-direction:column;gap:1px;line-height:1}
.nav__edition{
  font-family:var(--f-label);
  font-weight:700;
  font-size:9px;
  letter-spacing:.28em;
  text-transform:uppercase;
  opacity:.7;
}
.nav__brandtxt{
  font-family:var(--f-display);
  font-weight:600;
  font-size:24px;
  letter-spacing:.02em;
  line-height:1;
  text-transform:uppercase;
}
.nav__links{
  display:flex;gap:28px;
  margin-left:auto;
  font-family:var(--f-label);
  font-size:12px;
  letter-spacing:.16em;
  text-transform:uppercase;
}
.nav__links a{position:relative;padding:6px 2px}
.nav__links a::after{
  content:"";position:absolute;left:0;right:0;bottom:0;height:1.5px;
  background:linear-gradient(90deg,#F1CE82,#F2A93C,#F1CE82);
  transform:scaleX(0);transform-origin:left;
  transition:transform .35s ease;
}
.nav__links a:hover::after{transform:scaleX(1)}
.nav__cta{margin-left:8px}
.nav__account{
  display:flex;align-items:center;gap:8px;
  background:transparent;border:1px solid currentColor;
  color:inherit;
  padding:8px 14px;border-radius:999px;
  font-family:inherit;font-size:11px;font-weight:600;
  letter-spacing:1.5px;text-transform:uppercase;
  cursor:pointer;
  margin-left:16px;
  transition:opacity .15s ease, background .15s ease;
  opacity:0.78;
}
.nav__account:hover{opacity:1;background:rgba(255,255,255,0.05)}
.nav.is-stuck .nav__account:hover{background:rgba(0,0,0,0.04)}
.nav__account svg{display:block}
.nav__account.is-signed{
  border-color:var(--amber, #B8893A);
  color:var(--amber, #B8893A);
  opacity:1;
}
@media (max-width:768px){
  .nav__account-txt{display:none}
  .nav__account{padding:8px;border-radius:50%;margin-left:8px}
}
.nav__burger{display:none;width:36px;height:36px;flex-direction:column;justify-content:center;align-items:center;gap:5px}
.nav__burger span{display:block;width:22px;height:1.5px;background:currentColor;transition:transform .3s ease, opacity .3s ease}
.nav.is-stuck{
  background:var(--bg-paper);
  color:var(--ink-primary);
  box-shadow:0 1px 0 var(--rule);
}
.nav.is-stuck .nav__seal{background:var(--bg-paper);}

/* ============== HERO (luz cálida / amanecer caribe) ============== */
.hero{
  min-height:100vh;
  padding:100px var(--pad-x) 40px;
  overflow:hidden;
  color:var(--ink-primary);
  background:
    radial-gradient(ellipse at 18% 8%,  rgba(242,169,60,.55),  transparent 55%),
    radial-gradient(ellipse at 88% 12%, rgba(188,146,171,.35), transparent 50%),
    radial-gradient(ellipse at 82% 95%, rgba(230,50,36,.18),   transparent 60%),
    linear-gradient(180deg,#FFE9C0 0%,#FAE2C0 45%,#F1CE82 100%);
}
@media (min-width:981px){
  .hero{height:100vh;min-height:680px}
}
.hero__sun{
  position:absolute;left:50%;top:14%;transform:translateX(-50%);
  width:min(620px,68vw);aspect-ratio:1;border-radius:50%;
  background:radial-gradient(circle,#FFE3A8 0%,rgba(242,169,60,.45) 35%,rgba(242,169,60,0) 70%);
  pointer-events:none;opacity:.85;filter:blur(2px);
}
.hero__grain{
  position:absolute;inset:0;pointer-events:none;opacity:.35;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='200' height='200'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='2'/><feColorMatrix values='0 0 0 0 .31 0 0 0 0 .15 0 0 0 0 .12 0 0 0 .25 0'/></filter><rect width='100%25' height='100%25' filter='url(%23n)'/></svg>");
  mix-blend-mode:multiply;
}
.hero__inner{
  max-width:var(--maxw);
  margin:0 auto;
  display:flex;
  flex-direction:column;
  gap:32px;
  min-height:calc(100vh - 180px);
}
@media (min-width:981px){
  .hero__inner{height:calc(100vh - 140px);min-height:540px}
}
.hero__top{display:flex;align-items:center;justify-content:space-between;gap:24px}
.hero__kicker{display:flex;align-items:center;gap:16px;font-family:var(--f-label);font-size:12px;letter-spacing:.22em;text-transform:uppercase;color:var(--ink-muted);width:min(380px,46vw)}
.hero__seal{width:84px;height:84px;border-radius:50%;background:#FFF5DD;display:grid;place-items:center;padding:8px;box-shadow:0 0 0 2px var(--ink-primary) inset, 0 0 0 6px #FFF5DD inset, 0 0 0 7.5px var(--ink-primary) inset, 0 8px 18px rgba(79,37,32,.25);transform:rotate(-8deg)}
.hero__seal img{width:100%;height:100%;object-fit:contain}

.hero__grid{
  display:grid;
  grid-template-columns:1.05fr .95fr;
  gap:clamp(32px,5vw,80px);
  align-items:center;
  flex:1;
}
.hero__copy{display:flex;flex-direction:column;gap:18px}
.hero__wordmark{display:none}
.display{color:var(--ink-primary)}
.display em{color:var(--ink-muted)}
.hero__sub{
  font-family:var(--f-body);
  font-size:clamp(15px,1.2vw,18px);
  line-height:1.5;
  max-width:38ch;
  color:var(--ink-primary);
  opacity:.9;
}
.hero .typewriter{color:var(--ink-muted)}
.hero__ctas{display:flex;gap:14px;flex-wrap:wrap;margin-top:8px}

.hero__bottom{display:flex;justify-content:space-between;align-items:flex-end;gap:24px;flex-wrap:wrap}
.hero__serial{
  font-family:var(--f-label);
  font-size:11px;letter-spacing:.22em;text-transform:uppercase;
  color:var(--ink-muted);opacity:.7;
  transform:rotate(-2deg);
}

/* countdown sobre crema */
.countdown__label{
  font-family:var(--f-label);font-size:11px;letter-spacing:.22em;text-transform:uppercase;
  color:var(--ink-muted);display:block;margin-bottom:10px;
}
.countdown__digits{display:flex;gap:14px}
.cd{
  background:rgba(255,245,221,.85);
  border:1.5px solid var(--ink-primary);
  padding:14px 18px;
  min-width:88px;
  text-align:center;
  position:relative;
  box-shadow:0 4px 0 var(--ink-primary);
}
.cd b{
  display:block;
  font-family:var(--f-display);
  font-weight:700;
  font-size:clamp(24px,2.4vw,34px);
  line-height:1;
  color:var(--ink-muted);
  font-variant-numeric:tabular-nums;
  letter-spacing:.01em;
}
.cd span{
  font-family:var(--f-label);
  font-size:9px;letter-spacing:.22em;text-transform:uppercase;
  color:var(--ink-primary);opacity:.7;
  display:block;margin-top:6px;
}
.cd::before,.cd::after{
  content:"";position:absolute;left:50%;width:6px;height:6px;border-radius:50%;background:var(--ink-primary);transform:translateX(-50%);opacity:.45;
}
.cd::before{top:-3px}
.cd::after{bottom:-3px}

/* ============== POSTCARD ============== */
.postcard{
  position:relative;
  background:var(--bg-paper);
  padding:14px 14px 50px;
  box-shadow:
    0 1px 0 rgba(79,37,32,.1) inset,
    0 30px 50px -20px rgba(0,0,0,.35),
    0 10px 20px -10px rgba(0,0,0,.25);
  transform-origin:center;
  margin:0;
}
.postcard::before{
  /* perforated edge */
  content:"";position:absolute;inset:-1px;
  background:
    radial-gradient(circle at 8px 0, transparent 4.5px, var(--bg-paper) 5px) 0 0/16px 16px repeat-x,
    radial-gradient(circle at 8px 16px, transparent 4.5px, var(--bg-paper) 5px) 0 100%/16px 16px repeat-x,
    radial-gradient(circle at 0 8px, transparent 4.5px, var(--bg-paper) 5px) 0 0/16px 16px repeat-y,
    radial-gradient(circle at 16px 8px, transparent 4.5px, var(--bg-paper) 5px) 100% 0/16px 16px repeat-y;
  pointer-events:none;
  z-index:-1;
}
.postcard img{
  display:block;width:100%;height:auto;
  border:1px solid rgba(79,37,32,.15);
}
.postcard figcaption{
  position:absolute;left:24px;bottom:18px;
  font-family:var(--f-label);font-size:10px;letter-spacing:.22em;text-transform:uppercase;color:var(--ink-primary);
}
.hero__postcard{
  max-width:min(360px,28vw);justify-self:end;
  transform:rotate(2deg);
  background:#FFF5DD;
}
.hero__postcard::before{background-color:#FFF5DD;}

/* ============== MARQUEE ============== */
.marquee{
  background:var(--bg-ember);
  color:var(--accent-gold);
  overflow:hidden;
  padding:18px 0;
  border-top:1.5px solid var(--accent-gold);
  border-bottom:1.5px solid var(--accent-gold);
}
.marquee__track{
  display:flex;gap:48px;white-space:nowrap;
  animation:marquee 40s linear infinite;
  font-family:var(--f-display);font-style:italic;font-weight:500;
  font-size:clamp(20px,3vw,38px);
  letter-spacing:.02em;
}
.marquee__track span{flex-shrink:0}
@keyframes marquee{
  from{transform:translateX(0)}
  to{transform:translateX(-50%)}
}
.marquee:hover .marquee__track{animation-play-state:paused}

/* ============== ANNIVERSARY ============== */
.anniv{padding:var(--sec-pad) var(--pad-x)}
.anniv__inner{
  max-width:var(--maxw);margin:0 auto;
  display:grid;
  grid-template-columns:.7fr 2.2fr 1.1fr;
  gap:clamp(28px,5vw,64px);
  align-items:center;
}
.anniv__note{
  font-family:var(--f-label);font-size:10px;letter-spacing:.24em;text-transform:uppercase;
  color:var(--ink-muted);
  writing-mode:vertical-rl;transform:rotate(180deg);
  align-self:start;
}
.anniv__body{position:relative;font-size:clamp(18px,1.7vw,22px);line-height:1.55}
.anniv__body em{color:var(--ink-muted)}
.dropcap{
  font-family:var(--f-display);font-style:italic;font-weight:400;
  font-variation-settings:"opsz" 144,"SOFT" 100,"WONK" 1;
  font-size:clamp(160px,22vw,300px);
  line-height:.78;
  float:left;
  margin:0 18px -20px 0;
  color:var(--accent-coral);
  letter-spacing:-.04em;
}
.anniv__pin{margin:0;position:relative}
.anniv__pin img{
  width:100%;
  border-radius:6px;
  box-shadow:0 30px 50px -20px rgba(0,0,0,.4);
  transform:rotate(3deg);
  border:8px solid #FFF5DD;
}

/* ============== SECTION HEAD ============== */
.section-head{
  max-width:780px;
  margin:0 auto clamp(48px,7vw,96px);
  text-align:center;
}
.section-head p{
  max-width:560px;margin:14px auto 0;
  font-size:clamp(16px,1.4vw,18px);
  opacity:.85;
}

/* ============== PROGRAMA / TIMELINE ============== */
.programa{padding:var(--sec-pad) var(--pad-x);background:var(--bg-night);overflow:hidden}
.programa__inner{max-width:var(--maxw);margin:0 auto}
.timeline{
  position:relative;
  padding-left:0;
  display:flex;flex-direction:column;gap:clamp(60px,8vw,110px);
}
.timeline::before{
  content:"";position:absolute;left:48px;top:30px;bottom:30px;width:1.5px;
  background:repeating-linear-gradient(to bottom,var(--accent-gold) 0 6px,transparent 6px 14px);
  opacity:.55;
}
.moment{display:grid;grid-template-columns:96px 1fr;align-items:start;gap:clamp(20px,3vw,40px);position:relative}
.moment__index{
  width:96px;height:96px;border-radius:50%;
  border:1.5px solid var(--accent-gold);
  background:var(--bg-night);
  display:grid;place-items:center;
  font-family:var(--f-display);font-style:italic;font-weight:600;
  font-size:46px;color:var(--accent-amber);
  z-index:2;
  box-shadow:0 0 0 8px var(--bg-night), 0 0 0 9px var(--accent-gold);
}
.timeline .postcard{background:#FFF5DD;color:var(--ink-primary);max-width:760px;padding:0;display:grid;grid-template-columns:.95fr 1.05fr;overflow:hidden;transition:transform .5s ease, box-shadow .5s ease}
.timeline .postcard::before{background-color:#FFF5DD}
.postcard--tilt-l{transform:rotate(-1.2deg);justify-self:start}
.postcard--tilt-r{transform:rotate(1.2deg);justify-self:start}
.timeline .postcard:hover{transform:rotate(0deg) translateY(-4px);box-shadow:0 40px 80px -25px rgba(0,0,0,.5)}
.timeline .postcard--no-media{grid-template-columns:1fr;max-width:620px}
.postcard__media{
  min-height:260px;
  background-size:cover;background-position:center;
  border-right:1px solid rgba(79,37,32,.15);
  position:relative;
}
.postcard__media::after{
  content:"";position:absolute;inset:0;
  background:linear-gradient(180deg,transparent 60%,rgba(79,37,32,.25));
}
.postcard__body{padding:32px clamp(24px,3vw,40px)}
.postcard__meta{display:flex;gap:18px;flex-wrap:wrap;margin-bottom:12px}
.postcard__meta span{font-family:var(--f-label);font-size:10px;letter-spacing:.2em;text-transform:uppercase;color:var(--ink-muted)}
.postcard__body h3{margin:0 0 6px;color:var(--ink-primary)}
.venue{font-family:var(--f-body);font-style:italic;color:var(--ink-muted);font-size:14px;margin:0 0 14px;letter-spacing:.01em}
.postcard__body p{margin:0 0 12px;font-size:15px;line-height:1.55}
.taste{
  font-family:var(--f-mono);font-style:italic;font-size:13px;color:var(--ink-primary);
  border-top:1px dashed var(--rule);
  padding-top:14px;margin-top:18px;opacity:.85;
}

/* ============== INVITADOS ============== */
.guests{padding:var(--sec-pad) var(--pad-x);background:var(--bg-paper)}
.guests__inner{max-width:var(--maxw);margin:0 auto}

/* ----- Invitado Estelar (featured card) ----- */
.star-guest{
  position:relative;
  display:grid;
  grid-template-columns:5fr 7fr;
  gap:clamp(28px,4vw,64px);
  align-items:center;
  background:
    radial-gradient(ellipse at 90% 0%, rgba(242,169,60,.25), transparent 55%),
    radial-gradient(ellipse at 0% 100%, rgba(188,146,171,.18), transparent 50%),
    #FFF5DD;
  border:1.5px solid var(--ink-primary);
  padding:clamp(32px,4vw,56px);
  margin:0 0 clamp(56px,7vw,88px);
  box-shadow:
    10px 10px 0 var(--accent-gold),
    0 30px 60px -25px rgba(79,37,32,.4);
  overflow:hidden;
}
.star-guest::before{
  content:"";position:absolute;inset:14px;
  border:1px dashed rgba(79,37,32,.25);
  pointer-events:none;
}
.star-guest::after{
  content:"★";position:absolute;
  top:-30px;left:-30px;
  font-size:200px;color:var(--accent-amber);
  opacity:.08;line-height:1;
  pointer-events:none;
  font-family:var(--f-display);
}

.star-guest__stamp{
  position:absolute;top:24px;right:24px;
  display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;
  width:130px;height:130px;border-radius:50%;
  background:radial-gradient(circle at 30% 30%, #C53A22, #7A1D11 70%);
  color:#FAE2C0;
  border:2.5px solid #5A1A0E;
  box-shadow:0 8px 18px rgba(0,0,0,.35), inset 0 -4px 8px rgba(0,0,0,.3);
  transform:rotate(8deg);
  padding:8px;text-align:center;
  z-index:2;
}
.star-guest__stamp-star{
  font-family:var(--f-display);font-size:34px;line-height:1;color:var(--accent-gold);
  filter:drop-shadow(0 2px 0 rgba(0,0,0,.4));
}
.star-guest__stamp-text{
  font-family:var(--f-label);font-size:8.5px;letter-spacing:.18em;text-transform:uppercase;
  font-weight:700;line-height:1.2;
}

.star-guest__photo{
  position:relative;margin:0;
  background:#FFF5DD;
  padding:14px 14px 68px;
  box-shadow:
    0 1px 0 rgba(79,37,32,.1) inset,
    0 30px 50px -20px rgba(0,0,0,.4);
  transform:rotate(-1.5deg);
  z-index:1;
}
.star-guest__photo img{
  display:block;width:100%;aspect-ratio:1;object-fit:cover;
  border:1px solid rgba(79,37,32,.18);
  background:#EFD9B0;
  filter:saturate(.95) contrast(1.05);
}
.star-guest__flag{
  position:absolute;left:24px;bottom:18px;
  font-family:var(--f-label);font-size:11px;letter-spacing:.2em;text-transform:uppercase;
  color:var(--ink-primary);
}

.star-guest__body{position:relative;z-index:1}
.star-guest__eyebrow{
  display:inline-block;margin-bottom:18px;
  font-family:var(--f-label);font-weight:700;
  font-size:11px;letter-spacing:.32em;text-transform:uppercase;
  color:var(--accent-coral);
  padding:6px 12px;
  border:1.5px solid var(--accent-coral);
  border-radius:999px;
  background:rgba(230,50,36,.06);
}
.star-guest__name{
  font-family:var(--f-display);font-weight:600;
  font-size:clamp(40px,5.4vw,72px);line-height:.95;letter-spacing:-.02em;
  margin:0 0 16px;color:var(--ink-primary);
}
.star-guest__name em{font-style:italic;font-weight:500;color:var(--ink-muted)}
.star-guest__honor{
  font-family:var(--f-label);font-weight:700;
  font-size:12px;letter-spacing:.28em;text-transform:uppercase;
  color:var(--accent-coral);
  margin:-6px 0 18px;
  display:inline-flex;align-items:center;gap:10px;
}
.star-guest__honor::before,
.star-guest__honor::after{
  content:"";width:22px;height:1px;background:currentColor;opacity:.55;
}
.star-guest__title{
  font-family:var(--f-body);font-style:italic;
  font-size:clamp(16px,1.6vw,19px);
  color:var(--ink-muted);
  margin:0 0 22px;
  padding-bottom:16px;
  border-bottom:1px solid var(--rule);
  max-width:42ch;
}
.star-guest__bio{
  font-size:clamp(15.5px,1.4vw,17px);line-height:1.6;
  margin:0 0 14px;max-width:52ch;
}
.star-guest__bio strong{
  font-weight:500;
  background:linear-gradient(180deg,transparent 60%,rgba(242,169,60,.4) 60%);
  padding:0 3px;
}

.star-guest__stats{
  display:flex;gap:28px;flex-wrap:wrap;
  margin:24px 0 26px;
  padding:18px 0;
  border-top:1px dashed var(--rule);
  border-bottom:1px dashed var(--rule);
}
.star-guest__stats li{display:flex;flex-direction:column;gap:2px}
.star-guest__stats b{
  font-family:var(--f-display);font-weight:600;font-style:italic;
  font-size:clamp(28px,3vw,38px);line-height:1;
  color:var(--accent-coral);letter-spacing:-.02em;
}
.star-guest__stats span{
  font-family:var(--f-label);font-size:9.5px;letter-spacing:.2em;text-transform:uppercase;
  color:var(--ink-muted);max-width:18ch;line-height:1.4;
}

.star-guest__quote{
  margin:0;padding:0;
  font-family:var(--f-display);font-style:italic;font-weight:500;
  font-size:clamp(18px,1.9vw,24px);line-height:1.35;
  color:var(--ink-muted);
  border-left:3px solid var(--accent-amber);
  padding-left:18px;
  max-width:50ch;
}

/* ----- Subhead "También se sentarán a la mesa" ----- */
.guests__sub-head{
  display:flex;align-items:center;gap:22px;
  margin:0 0 36px;
  color:var(--accent-amber);
}
.guests__sub-label{
  font-family:var(--f-label);font-weight:700;
  font-size:11px;letter-spacing:.32em;text-transform:uppercase;
  color:var(--ink-muted);white-space:nowrap;
}

.guests__grid{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:clamp(28px,3.5vw,52px);
  align-items:start;
}
.guests__grid--4{grid-template-columns:repeat(4,minmax(0,1fr))}
.guests__grid--2{grid-template-columns:repeat(2,minmax(0,1fr));max-width:880px;margin-left:auto;margin-right:auto}
.guests__grid--international{margin-top:clamp(40px,5vw,72px)}
.guests__grid--chefs{grid-template-columns:repeat(3,minmax(0,1fr));margin-top:clamp(24px,3vw,40px)}
.guest{
  display:flex;flex-direction:column;gap:18px;
  position:relative;
}
.guest:nth-child(1){transform:rotate(-.6deg)}
.guest:nth-child(2){transform:rotate(.4deg);margin-top:18px}
.guest:nth-child(3){transform:rotate(-.4deg)}
.guest:nth-child(4){transform:rotate(.6deg);margin-top:24px}
.guest:nth-child(5){transform:rotate(-.3deg);margin-top:36px}

.guest__photo{
  position:relative;margin:0;
  background:#FFF5DD;
  padding:14px 14px 56px;
  box-shadow:
    0 1px 0 rgba(79,37,32,.1) inset,
    0 22px 40px -18px rgba(0,0,0,.32),
    0 8px 16px -8px rgba(0,0,0,.18);
  overflow:hidden;
}
.guest__photo img{
  display:block;width:100%;aspect-ratio:1;object-fit:cover;
  border:1px solid rgba(79,37,32,.15);
  background:#EFD9B0;
  filter:saturate(.92) contrast(1.02);
}
.guest__flag{
  position:absolute;top:24px;right:24px;
  font-size:22px;
  background:#FFF5DD;
  padding:6px 10px;border-radius:999px;
  box-shadow:0 6px 12px -4px rgba(0,0,0,.3);
  border:1px solid rgba(79,37,32,.2);
}
.guest__body{padding:0 6px}
.guest__role{
  font-family:var(--f-label);font-size:10px;letter-spacing:.22em;text-transform:uppercase;
  color:var(--ink-muted);display:block;margin-bottom:6px;
}
.guest h3{
  font-family:var(--f-display);font-weight:600;font-size:clamp(24px,2.4vw,30px);
  margin:0 0 4px;line-height:1.12;color:var(--ink-primary);
}
.guest__country{
  font-family:var(--f-body);font-style:italic;font-size:14px;color:var(--ink-muted);
  margin:0 0 12px;letter-spacing:.01em;
}
.guest__country--hero{
  font-family:var(--f-label);font-style:normal;font-weight:700;
  font-size:11px;letter-spacing:.18em;text-transform:uppercase;
  color:var(--ink-primary);
  background:var(--accent-gold);
  padding:5px 10px;border-radius:3px;
  display:inline-block;align-self:flex-start;
  box-shadow:2px 2px 0 var(--ink-primary);
}
.guest__body p:last-child{font-size:15px;line-height:1.55;margin:0;opacity:.92}
.guest__body p em{font-style:italic;color:var(--ink-muted)}

/* ============== BRANDS STRIP — premium editorial ============== */
.brands{
  background:var(--bg-ember);
  color:var(--accent-gold);
  border-top:1.5px solid var(--accent-gold);
  border-bottom:1.5px solid var(--accent-gold);
  overflow:hidden;
  padding:22px 0 26px;
  position:relative;
}
.brands::before, .brands::after{
  content:"";position:absolute;top:0;bottom:0;width:80px;z-index:2;pointer-events:none;
}
.brands::before{left:0;background:linear-gradient(to right,var(--bg-ember),transparent)}
.brands::after{right:0;background:linear-gradient(to left,var(--bg-ember),transparent)}

.brands__head{
  display:flex;align-items:center;justify-content:center;gap:22px;
  padding:0 var(--pad-x) 14px;
  max-width:var(--maxw);margin:0 auto;
}
.brands__head .rule{flex:1;max-width:160px}
.brands__label{
  font-family:var(--f-label);font-weight:700;
  font-size:10px;letter-spacing:.32em;text-transform:uppercase;
  color:var(--accent-amber);opacity:.85;white-space:nowrap;
}

.brands__track{
  display:flex;gap:28px;align-items:center;
  white-space:nowrap;
  animation:brands 70s linear infinite;
  padding:0 14px;
}
@keyframes brands{
  from{transform:translateX(0)}
  to{transform:translateX(-50%)}
}
.brands:hover .brands__track{animation-play-state:paused}

/* Variantes tipográficas por marca */
.b{flex-shrink:0;display:inline-flex;align-items:center;line-height:1}
.b--logo img{height:36px;width:auto;filter:brightness(0) invert(.9) sepia(.3) saturate(2) hue-rotate(345deg);opacity:.95}
.b--serif{
  font-family:var(--f-display);font-weight:500;font-style:italic;
  font-size:24px;letter-spacing:-.005em;color:var(--accent-gold);
}
.b--bold{
  font-family:var(--f-label);font-weight:700;
  font-size:18px;letter-spacing:.18em;text-transform:uppercase;
  color:var(--accent-amber);
}
.b--condensed{
  font-family:var(--f-label);font-weight:700;
  font-size:17px;letter-spacing:.32em;text-transform:uppercase;
  color:var(--accent-gold);
}
.b--italic{
  font-family:var(--f-display);font-weight:400;font-style:italic;
  font-size:22px;letter-spacing:.01em;
  color:#FAE2C0;opacity:.95;
}
.b--sans{
  font-family:var(--f-body);font-weight:700;
  font-size:14px;letter-spacing:.4em;text-transform:uppercase;
  color:var(--accent-amber);
}
.b--bar{
  width:1px;height:22px;background:linear-gradient(180deg,transparent,var(--accent-gold) 30%,var(--accent-gold) 70%,transparent);
  opacity:.55;
}

/* ============== MASTERCLASSES ============== */
.master{padding:var(--sec-pad) var(--pad-x)}
.master__inner{max-width:var(--maxw);margin:0 auto}
.tickets{display:grid;grid-template-columns:1fr 1fr;gap:clamp(20px,3vw,40px)}
.ticket{
  display:grid;
  grid-template-columns:140px 1fr;
  background:#FFF5DD;
  border:1.5px solid var(--ink-primary);
  position:relative;
  overflow:hidden;
  transition:transform .35s ease, box-shadow .35s ease;
}
.ticket:hover{transform:translateY(-4px);box-shadow:8px 8px 0 var(--ink-primary)}
.ticket--jw{background:#FFF5DD}
.ticket--glen{background:#F0E0DD}
.ticket__stub{
  background:var(--ink-primary);
  color:var(--ink-inverse);
  display:flex;flex-direction:column;justify-content:center;align-items:center;
  padding:30px 14px;text-align:center;
  font-family:var(--f-label);font-size:11px;letter-spacing:.2em;text-transform:uppercase;
  gap:6px;
  position:relative;
}
.ticket__stub b{
  font-family:var(--f-display);
  font-style:italic;
  font-weight:500;
  font-size:30px;letter-spacing:0;
  text-transform:none;
  color:var(--accent-amber);
  display:block;
}
.ticket__stub::after{
  /* perforation */
  content:"";position:absolute;top:0;bottom:0;right:-7px;width:14px;
  background:
    radial-gradient(circle at 7px 7px,var(--bg-paper) 5px,transparent 5.5px) 0 0/14px 14px repeat-y;
}
.ticket--glen .ticket__stub::after{background:radial-gradient(circle at 7px 7px,#F0E0DD 5px,transparent 5.5px) 0 0/14px 14px repeat-y}
.ticket__body{padding:28px clamp(22px,2.5vw,32px)}
.ticket__brand{font-family:var(--f-label);font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:var(--ink-muted)}
.ticket__body h3{margin:8px 0 12px}
.ticket__body p{margin:0 0 14px;font-size:15px}
.ticket__venue{
  font-family:var(--f-body);font-style:italic;color:var(--ink-muted);
  font-size:14px;letter-spacing:.01em;
  margin:-4px 0 12px;
}
.ticket__bullets{
  display:flex;flex-direction:column;gap:8px;
  margin:6px 0 16px;
  padding:14px 0;
  border-top:1px dashed var(--rule);
  border-bottom:1px dashed var(--rule);
}
.ticket__bullets li{
  display:flex;justify-content:space-between;align-items:baseline;gap:12px;
}
.ticket__bullets span{
  font-family:var(--f-label);font-size:10px;letter-spacing:.2em;text-transform:uppercase;
  color:var(--ink-muted);
}
.ticket__bullets b{
  font-family:var(--f-display);font-weight:600;font-style:italic;
  font-size:18px;color:var(--ink-primary);letter-spacing:-.01em;
}
.ticket__bullets small{
  font-family:var(--f-label);font-style:normal;font-size:9.5px;
  letter-spacing:.18em;text-transform:uppercase;color:var(--ink-muted);
  font-weight:700;margin-left:4px;
}
.ticket__foot{display:flex;justify-content:space-between;align-items:center;gap:12px;padding-top:4px}
.ticket__foot span{font-family:var(--f-label);font-size:10px;letter-spacing:.18em;text-transform:uppercase;color:var(--ink-muted);max-width:18ch;line-height:1.4}
.tag{
  background:var(--accent-coral);color:var(--ink-inverse);
  padding:6px 10px;border-radius:999px;
}
.tag--cta{
  background:var(--accent-amber);color:var(--ink-primary);
  font-family:var(--f-label);font-weight:700;
  font-size:11px;letter-spacing:.16em;text-transform:uppercase;
  padding:10px 16px;border-radius:999px;
  border:1.5px solid var(--ink-primary);
  transition:transform .25s ease, background .25s ease, color .25s ease;
  white-space:nowrap;
}
.tag--cta:hover{background:var(--accent-coral);color:var(--ink-inverse);transform:rotate(-1deg) translateY(-1px)}

/* ============== INVERSIÓN ============== */
.invest{padding:var(--sec-pad) var(--pad-x);background:var(--bg-paper)}
.invest__inner{max-width:var(--maxw);margin:0 auto}

.tabs{display:flex;justify-content:center;gap:6px;margin:0 0 48px;font-family:var(--f-label);font-size:12px;letter-spacing:.18em;text-transform:uppercase}
.tab{
  padding:14px 26px;
  border:1.5px solid var(--ink-primary);
  background:transparent;color:var(--ink-primary);
  transition:background .25s ease,color .25s ease;
}
.tab.is-active{background:var(--ink-primary);color:var(--ink-inverse)}
.tab:first-child{border-radius:999px 0 0 999px}
.tab:last-child{border-radius:0 999px 999px 0;border-left:none}

.tags-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(20px,2.6vw,32px)}
.tags-grid--2{grid-template-columns:repeat(2,minmax(0,1fr));max-width:880px;margin:0 auto}
.luggage{
  position:relative;
  background:#FFF5DD;
  border:1.5px solid var(--ink-primary);
  border-radius:6px 22px 22px 6px;
  padding:46px 28px 28px;
  display:flex;flex-direction:column;gap:14px;
  transition:transform .35s ease,box-shadow .35s ease;
  min-height:430px;
}
.luggage:hover{transform:translateY(-6px);box-shadow:8px 10px 0 var(--ink-primary)}
.luggage--feat{
  background:var(--ink-primary);color:var(--ink-inverse);
  border-color:var(--accent-gold);
}
.luggage--feat h3,.luggage--feat .luggage__kind{color:var(--accent-amber)}
.luggage__eye{
  position:absolute;top:18px;left:18px;width:18px;height:18px;border-radius:50%;
  background:var(--bg-paper);
  box-shadow:inset 0 0 0 2px var(--ink-primary), 0 0 0 1.5px var(--ink-primary);
}
.luggage--feat .luggage__eye{background:var(--bg-night);box-shadow:inset 0 0 0 2px var(--accent-gold),0 0 0 1.5px var(--accent-gold)}
.luggage__kind{font-family:var(--f-label);font-size:10px;letter-spacing:.22em;text-transform:uppercase;color:var(--ink-muted);align-self:flex-end}
.luggage h3{margin:0 0 4px;font-size:32px}
.luggage__pitch{font-size:14.5px;line-height:1.5;margin:0;flex:1}
.luggage__prices{margin:12px 0 4px;display:flex;flex-direction:column;gap:10px;border-top:1px dashed var(--rule);padding-top:14px}
.luggage--feat .luggage__prices{border-color:rgba(241,206,130,.4)}
.luggage__prices li{display:flex;justify-content:space-between;align-items:baseline;gap:12px}
.luggage__prices span{font-family:var(--f-label);font-size:11px;letter-spacing:.2em;text-transform:uppercase;opacity:.75}
.luggage__prices b{font-family:var(--f-display);font-weight:600;font-style:italic;font-size:24px;color:var(--ink-primary)}
.luggage--feat .luggage__prices b{color:var(--accent-amber)}
.luggage__prices small{font-family:var(--f-label);font-style:normal;font-size:10px;letter-spacing:.18em;text-transform:uppercase;color:var(--ink-muted);margin-left:6px;font-weight:700}
.luggage--feat .luggage__prices small{color:var(--accent-gold)}
.luggage__fine{font-family:var(--f-label);font-size:10px;letter-spacing:.2em;text-transform:uppercase;opacity:.6;margin:6px 0 0}
.luggage__fine--months{margin:14px 0 18px;opacity:.85;color:var(--ink-muted)}
.wax{
  position:absolute;top:-14px;right:-14px;
  width:78px;height:78px;border-radius:50%;
  background:radial-gradient(circle at 30% 30%, #C53A22, #7A1D11 70%);
  color:#FAE2C0;
  font-family:var(--f-display);font-style:italic;font-weight:700;
  font-size:34px;display:grid;place-items:center;
  box-shadow:0 6px 14px rgba(0,0,0,.35), inset 0 -4px 8px rgba(0,0,0,.3);
  transform:rotate(8deg);
  border:2px solid #5A1A0E;
}

.includes{
  margin-top:56px;
  display:grid;grid-template-columns:1fr 1fr;gap:28px;
  padding:32px clamp(22px,3vw,40px);
  background:transparent;
  border-top:1.5px solid var(--rule);border-bottom:1.5px solid var(--rule);
}
.includes h4{margin-bottom:14px;color:var(--accent-coral)}
.includes__col--off h4{color:var(--ink-muted);opacity:.7}
.includes ul li{
  padding-left:24px;position:relative;margin-bottom:8px;font-size:15px;
}
.includes ul li::before{
  content:"✓";position:absolute;left:0;top:0;color:var(--accent-coral);font-weight:700;
}
.includes__col--off ul li::before{content:"—";color:var(--ink-muted)}

/* ============== GALLERY ============== */
.gallery{padding:var(--sec-pad) var(--pad-x);background:var(--bg-paper)}
.gallery__inner{max-width:var(--maxw);margin:0 auto}
.gallery__grid{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  grid-auto-rows:180px;
  gap:18px;
}
.gframe{
  position:relative;margin:0;overflow:hidden;
  background:#FFF5DD;
  border:8px solid #FFF5DD;
  box-shadow:0 14px 28px -12px rgba(79,37,32,.35), 0 0 0 1px rgba(79,37,32,.15);
  transition:transform .45s cubic-bezier(.2,.7,.2,1), box-shadow .45s ease;
}
.gframe:nth-child(7n+1){transform:rotate(-1.2deg)}
.gframe:nth-child(7n+2){transform:rotate( .8deg)}
.gframe:nth-child(7n+3){transform:rotate( 1.4deg)}
.gframe:nth-child(7n+4){transform:rotate(-0.6deg)}
.gframe:nth-child(7n+5){transform:rotate( 1.1deg)}
.gframe:nth-child(7n+6){transform:rotate(-1.5deg)}
.gframe:nth-child(7n)  {transform:rotate( .5deg)}
.gframe:hover{transform:rotate(0deg) translateY(-4px);box-shadow:0 30px 50px -20px rgba(79,37,32,.5), 0 0 0 1px rgba(79,37,32,.2);z-index:3}
.gframe img{width:100%;height:100%;object-fit:cover;display:block;filter:saturate(.95) contrast(1.02)}
.gframe figcaption{
  position:absolute;left:14px;bottom:14px;right:14px;
  font-family:var(--f-label);font-size:9px;letter-spacing:.22em;text-transform:uppercase;
  color:#FFF5DD;
  text-shadow:0 1px 4px rgba(0,0,0,.5);
  pointer-events:none;
  display:flex;justify-content:flex-end;
}
.gframe figcaption span{
  background:rgba(79,37,32,.85);
  padding:5px 10px;border-radius:2px;
  border:1px solid rgba(241,206,130,.4);
}
.gframe--lg{grid-column:span 2;grid-row:span 2}
.gframe--tall{grid-row:span 2}
.gframe--wide{grid-column:span 2}

.gallery__credit{
  margin-top:36px;text-align:center;
  font-family:var(--f-label);font-size:10px;letter-spacing:.2em;text-transform:uppercase;
  color:var(--ink-muted);opacity:.7;
}

@media (max-width:980px){
  .gallery__grid{grid-template-columns:repeat(2,1fr);grid-auto-rows:160px;gap:12px}
  .gframe--lg{grid-column:span 2;grid-row:span 2}
  .gframe--tall{grid-row:span 2}
  .gframe--wide{grid-column:span 2}
}
@media (max-width:560px){
  .gallery__grid{grid-template-columns:1fr;grid-auto-rows:240px}
  .gframe,.gframe--lg,.gframe--tall,.gframe--wide{grid-column:span 1;grid-row:span 1}
}

/* ============== HOTEL ============== */
.hotel{padding:var(--sec-pad) var(--pad-x)}
.hotel__inner{
  max-width:var(--maxw);margin:0 auto;
  display:grid;grid-template-columns:5fr 7fr;gap:clamp(28px,5vw,72px);align-items:center;
}
.hotel__img{transform:rotate(-2deg)}
.hotel__img img{background:#000}
.postcard--stamped{position:relative}
.wish{
  position:absolute;top:24px;left:24px;
  font-family:var(--f-label);font-size:11px;letter-spacing:.22em;text-transform:uppercase;
  color:var(--accent-coral);
  border:2px solid var(--accent-coral);
  padding:8px 14px;border-radius:4px;
  transform:rotate(-12deg);
  background:rgba(255,245,221,.7);
  opacity:.9;
}
.hotel__copy h2{margin-bottom:18px}
.hotel__copy p{font-size:17px;max-width:46ch;margin:0 0 22px}
.hotel__copy p b{background:var(--accent-gold);padding:2px 8px;border-radius:3px}

.hotel__rates{
  display:grid;grid-template-columns:1.4fr 1fr;gap:16px;
  margin:0 0 26px;
  padding:22px;
  background:#FFF5DD;
  border:1.5px solid var(--ink-primary);
  border-radius:8px;
  box-shadow:6px 6px 0 var(--accent-gold);
}
.hotel__rate{display:flex;flex-direction:column;gap:6px}
.hotel__rate--main{border-right:1px dashed var(--rule);padding-right:16px}
.rate__label{font-family:var(--f-label);font-size:10px;letter-spacing:.22em;text-transform:uppercase;color:var(--ink-muted)}
.rate__price{
  font-family:var(--f-display);font-weight:600;font-style:italic;
  font-size:clamp(28px,3.4vw,38px);line-height:1;
  color:var(--ink-primary);letter-spacing:-.01em;
}
.rate__price small{font-family:var(--f-label);font-style:normal;font-size:10px;letter-spacing:.18em;text-transform:uppercase;color:var(--ink-muted);font-weight:700;margin-left:6px;display:inline-block;transform:translateY(-4px)}
.rate__note{font-size:12.5px;line-height:1.4;opacity:.75;font-style:italic}

.hotel__details{
  display:flex;flex-wrap:wrap;gap:16px 32px;
  margin:0 0 24px;padding:18px 0;
  border-top:1px dashed var(--rule);border-bottom:1px dashed var(--rule);
}
.hotel__detail{display:flex;flex-direction:column;gap:4px;min-width:140px;flex:1 1 200px}
.hotel__detail-label{font-family:var(--f-label);font-size:10px;letter-spacing:.22em;text-transform:uppercase;color:var(--ink-muted)}
.hotel__detail-value{font-size:14.5px;line-height:1.35;font-weight:500}
.hotel__detail-value--tag{
  align-self:flex-start;
  background:var(--accent-gold);
  padding:4px 10px;border-radius:3px;font-family:var(--f-label);font-weight:700;font-size:12px;letter-spacing:.16em;text-transform:uppercase;
}

.hotel__contacts{display:flex;flex-direction:column;gap:14px;margin:0 0 16px}
.hotel__contact{
  display:flex;flex-direction:column;gap:4px;
  padding:14px 16px;
  background:rgba(241,206,130,.25);
  border-left:3px solid var(--accent-amber);
  border-radius:0 6px 6px 0;
}
.hotel__contact-label{font-family:var(--f-label);font-size:10px;letter-spacing:.22em;text-transform:uppercase;color:var(--ink-muted)}
.hotel__contact-name{font-style:italic;font-size:14px;color:var(--ink-primary);opacity:.85}
.hotel__contact-row{display:flex;gap:18px;flex-wrap:wrap;margin-top:2px}
.hotel__contact-row a{
  font-family:var(--f-label);font-size:11.5px;letter-spacing:.14em;text-transform:uppercase;font-weight:700;
  color:var(--ink-muted);position:relative;padding-bottom:2px;
}
.hotel__contact-row a:hover{color:var(--accent-coral)}
.hotel__contact-row a::after{content:"";position:absolute;left:0;right:0;bottom:0;height:1.5px;background:currentColor;transform:scaleX(.4);transform-origin:left;opacity:.5;transition:transform .25s ease,opacity .25s ease}
.hotel__contact-row a:hover::after{transform:scaleX(1);opacity:1}

.hotel__fine{font-family:var(--f-label);font-size:10px;letter-spacing:.18em;text-transform:uppercase;color:var(--ink-muted);opacity:.7;margin:8px 0 0;line-height:1.5}

.hotel__book{margin:0 0 22px;align-self:flex-start}

/* ============== CONTACTO ============== */
.contact{padding:var(--sec-pad) var(--pad-x);background:var(--bg-night);text-align:center;overflow:hidden;position:relative}
.contact::after{
  content:"";position:absolute;inset:0;pointer-events:none;
  background:
    radial-gradient(ellipse at 30% 0%,rgba(242,169,60,.18),transparent 60%),
    radial-gradient(ellipse at 70% 100%,rgba(188,146,171,.12),transparent 60%);
}
.contact__inner{max-width:880px;margin:0 auto;position:relative;z-index:1}
.contact__h{
  font-size:clamp(48px,7vw,96px);line-height:.98;margin:0 0 22px;
}
.contact__h em{color:var(--accent-amber);font-style:italic}
.contact p{font-size:18px;opacity:.85;max-width:520px;margin:0 auto 36px}
.contact .btn--big{margin:0 auto}
.contact__num{font-family:var(--f-label);font-size:11px;letter-spacing:.3em;text-transform:uppercase;color:var(--accent-gold);margin-top:24px;opacity:.7}

/* ============== FOOTER ============== */
.foot{
  background:
    radial-gradient(ellipse at 50% 0%, rgba(242,169,60,.1), transparent 60%),
    var(--bg-ember);
  color:var(--ink-inverse);
  padding:clamp(72px,8vw,120px) var(--pad-x) 36px;
  position:relative;
  overflow:hidden;
}
.foot::before{
  content:"";position:absolute;top:0;left:0;right:0;height:1.5px;
  background:linear-gradient(90deg,transparent,var(--accent-gold) 20%,var(--accent-amber) 50%,var(--accent-gold) 80%,transparent);
  opacity:.7;
}

/* TOP — wordmark + tagline + CTA */
.foot__top{
  max-width:920px;margin:0 auto clamp(48px,5vw,72px);
  text-align:center;
  display:flex;flex-direction:column;align-items:center;gap:22px;
}
.foot__logo{
  width:clamp(240px,32vw,360px);height:auto;
  filter:invert(85%) sepia(20%) saturate(300%) hue-rotate(340deg) brightness(102%);
  margin:0;
}
.foot__tagline{
  margin:0;max-width:36ch;
  font-family:var(--f-display);font-style:italic;font-weight:400;
  font-size:clamp(18px,2vw,24px);line-height:1.4;
  color:var(--accent-gold);
}
.foot__tagline em{font-style:italic;color:var(--accent-amber)}
.foot__cta{margin-top:6px}

/* BANDA con datos del evento */
.foot__band{
  display:flex;align-items:center;justify-content:center;gap:18px;flex-wrap:wrap;
  max-width:1100px;margin:0 auto clamp(56px,6vw,80px);
  padding:0 var(--pad-x);
  font-family:var(--f-label);font-weight:700;
  font-size:11px;letter-spacing:.22em;text-transform:uppercase;
  color:var(--accent-gold);
}
.foot__band b{
  font-family:var(--f-display);font-style:italic;font-weight:500;
  font-size:18px;letter-spacing:-.005em;text-transform:none;
  color:var(--accent-amber);margin-right:4px;
}
.foot__band .rule{max-width:120px;height:1.5px}
.foot__band-dot{opacity:.5;font-size:9px}

/* GRID de 4 columnas */
.foot__inner{
  max-width:var(--maxw);margin:0 auto;
  display:grid;grid-template-columns:1.5fr 1fr 1.2fr 1fr;gap:clamp(28px,4vw,56px);
  padding-bottom:clamp(40px,5vw,64px);
  border-bottom:1.5px solid var(--rule-inverse);
}
.foot__col h5{
  margin:0 0 18px;
  position:relative;padding-bottom:10px;
  color:var(--accent-amber);
}
.foot__col h5::after{
  content:"";position:absolute;left:0;bottom:0;width:32px;height:1.5px;
  background:linear-gradient(90deg,#F1CE82,#F2A93C);
}
.foot__col a{
  display:block;
  font-family:var(--f-label);font-size:11px;letter-spacing:.18em;text-transform:uppercase;
  padding:7px 0;opacity:.85;
  transition:color .25s ease,padding-left .25s ease;
  position:relative;
}
.foot__col a:hover{color:var(--accent-amber);padding-left:6px}
.foot__col a[aria-current="page"]{color:var(--accent-amber);opacity:1}
.foot__col p{
  font-size:13.5px;line-height:1.55;margin:0;opacity:.78;letter-spacing:.01em;
}
.foot__col--brand p{margin:0 0 14px;max-width:32ch}
.foot__site{
  margin-top:6px;
  background:rgba(241,206,130,.12);
  padding:8px 12px!important;
  border-left:2px solid var(--accent-amber);
  border-radius:0 4px 4px 0;
  font-size:10.5px!important;
}
.foot__site:hover{background:rgba(241,206,130,.22);padding-left:14px!important}
.foot__address{margin-top:8px;font-size:11.5px;line-height:1.5;opacity:.7}

/* LEGAL */
.foot__legal{
  max-width:var(--maxw);margin:28px auto 0;
  display:flex;flex-direction:column;gap:14px;
  font-family:var(--f-label);font-size:10px;letter-spacing:.18em;text-transform:uppercase;
  opacity:.6;
}
.foot__legal-row{display:flex;justify-content:space-between;flex-wrap:wrap;gap:12px}
.foot__legal p{
  font-family:var(--f-body);font-size:10.5px;line-height:1.55;
  letter-spacing:.01em;text-transform:none;margin:0;opacity:.85;
  font-style:italic;
}
.foot__serial{color:var(--accent-amber);opacity:.85}

/* ============== TIMELINE ZIG-ZAG (desktop only) ============== */
@media (min-width:981px){

  /* Línea central de la timeline en lugar de pegada a la izquierda */
  .timeline::before{
    left:50%;
    transform:translateX(-50%);
  }

  /* Cada moment es un grid de dos columnas; los pares invierten el orden */
  .moment{
    max-width:880px;
    align-items:center;
  }
  .moment:nth-child(odd){
    align-self:flex-start;
  }
  .moment:nth-child(even){
    align-self:flex-end;
    grid-template-columns:minmax(0,760px) 96px;
  }
  .moment:nth-child(even) .moment__index{
    grid-column:2;grid-row:1;
  }
  .moment:nth-child(even) .postcard{
    grid-column:1;grid-row:1;
    justify-self:end;
  }
  .moment:nth-child(odd) .postcard{
    justify-self:start;
  }

  /* Línea sutil que conecta cada número con la línea central */
  .moment__index::after{
    content:"";position:absolute;top:50%;height:1.5px;
    background:repeating-linear-gradient(to right,var(--accent-gold) 0 6px,transparent 6px 14px);
    opacity:.55;z-index:-1;
  }
  .moment:nth-child(odd) .moment__index{position:relative}
  .moment:nth-child(odd) .moment__index::after{left:100%;width:32px;transform:translateY(-50%)}
  .moment:nth-child(even) .moment__index{position:relative}
  .moment:nth-child(even) .moment__index::after{right:100%;width:32px;transform:translateY(-50%)}

}

/* ============== ARCHIVE PAGE (galeria.html) ============== */
.nav--solid{background:var(--bg-paper);box-shadow:0 1px 0 var(--rule);color:var(--ink-primary)}
.nav__links a[aria-current="page"]{color:var(--ink-muted)}
.nav__links a[aria-current="page"]::after{transform:scaleX(1);opacity:.6}

.arch-hero{
  padding:160px var(--pad-x) 60px;
  background:
    radial-gradient(ellipse at 20% 10%,rgba(242,169,60,.25),transparent 55%),
    linear-gradient(180deg,#FFE9C0,#FAE2C0);
}
.arch-hero__inner{max-width:var(--maxw);margin:0 auto}
.arch-hero__top{display:flex;justify-content:space-between;align-items:center;gap:18px;margin-bottom:38px}
.back{
  font-family:var(--f-label);font-size:11px;letter-spacing:.2em;text-transform:uppercase;
  color:var(--ink-muted);padding:6px 0;
}
.back:hover{color:var(--accent-coral)}
.arch-hero__serial{
  font-family:var(--f-label);font-size:10px;letter-spacing:.22em;text-transform:uppercase;
  color:var(--ink-muted);opacity:.6;transform:rotate(-1deg);
}
.arch-hero__h{
  font-family:var(--f-display);font-weight:600;
  font-size:clamp(48px,7vw,108px);
  line-height:.96;letter-spacing:-.02em;
  margin:14px 0 22px;color:var(--ink-primary);
}
.arch-hero__h em{font-style:italic;color:var(--ink-muted)}
.arch-hero__lead{max-width:60ch;font-size:clamp(16px,1.5vw,19px);line-height:1.55;margin:0 0 36px}
.arch-hero__meta{
  display:flex;flex-wrap:wrap;gap:42px 64px;
  padding:24px 0;
  border-top:1px solid var(--rule);
  border-bottom:1px solid var(--rule);
}
.arch-hero__meta div{display:flex;flex-direction:column;gap:6px}
.arch-hero__meta b{font-family:var(--f-display);font-weight:600;font-style:italic;font-size:clamp(20px,2.4vw,30px);color:var(--ink-primary);letter-spacing:-.01em}
.arch-hero__meta span{font-family:var(--f-label);font-size:10px;letter-spacing:.22em;text-transform:uppercase;color:var(--ink-muted)}

.arch-section{
  margin:80px auto 36px;text-align:left;max-width:780px;
}
.arch-section--alt{margin-top:120px}
.arch-section h2{font-size:clamp(32px,4.4vw,52px);margin:6px 0 12px}
.arch-section p{font-size:15px;opacity:.85;max-width:60ch}

.gallery__grid--single{grid-template-columns:repeat(2,1fr);grid-auto-rows:280px;max-width:880px;margin:0 auto}

.arch-invite{padding:var(--sec-pad) var(--pad-x);background:var(--bg-night);color:var(--ink-inverse);text-align:center}
.arch-invite::after{content:"";position:absolute;inset:0;pointer-events:none;background:radial-gradient(ellipse at 50% 0%,rgba(242,169,60,.18),transparent 60%)}
.arch-invite__inner{max-width:720px;margin:0 auto;position:relative;z-index:1}
.arch-invite__h{font-family:var(--f-display);font-weight:600;font-size:clamp(40px,5.6vw,68px);line-height:1.02;margin:14px 0 18px}
.arch-invite__h em{color:var(--accent-amber);font-style:italic}
.arch-invite p{font-size:17px;opacity:.85;margin:0 0 28px}
.arch-invite__ctas{display:flex;gap:12px;justify-content:center;flex-wrap:wrap}

/* ============== ANIMATIONS ============== */
.reveal{opacity:0;transform:translateY(16px);transition:opacity .8s cubic-bezier(.2,.7,.2,1),transform .8s cubic-bezier(.2,.7,.2,1)}
.reveal.is-in{opacity:1;transform:translateY(0)}

@media (prefers-reduced-motion: reduce){
  *,*::before,*::after{animation-duration:.001ms!important;animation-iteration-count:1!important;transition-duration:.001ms!important}
  .marquee__track{animation:none}
}

/* ============== RESPONSIVE ============== */
@media (max-width:980px){
  .nav__links{display:none}
  .nav__cta{display:none}
  .nav__burger{display:flex;margin-left:auto}
  .nav.is-open .nav__burger span:nth-child(1){transform:translateY(7px) rotate(45deg)}
  .nav.is-open .nav__burger span:nth-child(2){opacity:0}
  .nav.is-open .nav__burger span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
  .nav.is-open .nav__links{
    display:flex;flex-direction:column;
    position:absolute;top:100%;left:0;right:0;
    background:var(--bg-paper);color:var(--ink-primary);
    padding:24px var(--pad-x);gap:18px;
    box-shadow:0 16px 30px rgba(0,0,0,.18);
  }
  .nav.is-open .nav__cta{display:inline-flex;margin:8px 0 0}

  .hero__grid{grid-template-columns:1fr}
  .hero__postcard{max-width:380px;margin:0 auto;justify-self:center}
  .hero__top{flex-direction:column;align-items:flex-start;gap:18px}

  .anniv__inner{grid-template-columns:1fr}
  .anniv__note{writing-mode:horizontal-tb;transform:none;margin-bottom:18px}
  .anniv__pin{max-width:420px;margin:0 auto}

  .timeline::before{left:32px}
  .moment{grid-template-columns:64px 1fr;gap:16px}
  .moment__index{width:64px;height:64px;font-size:32px;box-shadow:0 0 0 6px var(--bg-night),0 0 0 7px var(--accent-gold)}
  .timeline .postcard{grid-template-columns:1fr;max-width:none}
  .postcard__media{min-height:200px;border-right:none;border-bottom:1px solid rgba(79,37,32,.15)}

  .tickets{grid-template-columns:1fr}
  .tags-grid{grid-template-columns:1fr}
  .includes{grid-template-columns:1fr}
  .hotel__inner{grid-template-columns:1fr}
  .foot__inner{grid-template-columns:1fr 1fr;gap:32px}

  .guests__grid{grid-template-columns:repeat(2,1fr);gap:32px}
  .guests__grid--4{grid-template-columns:repeat(2,1fr)}
  .guests__grid--2{grid-template-columns:repeat(2,1fr);max-width:680px}
  .guests__grid--international{grid-template-columns:repeat(2,1fr)}
  .guests__grid--chefs{grid-template-columns:repeat(2,1fr)}
  .guest:nth-child(n){transform:none;margin-top:0}
  .guest:nth-child(even){margin-top:24px}

  /* Star guest a una sola columna en tablet/mobile */
  .star-guest{grid-template-columns:1fr;gap:28px;padding:32px}
  .star-guest__photo{transform:none;max-width:520px;margin:0 auto}
  .star-guest__stamp{width:104px;height:104px;top:18px;right:18px}
  .star-guest__stamp-star{font-size:26px}
  .star-guest__stamp-text{font-size:7.5px}
  .star-guest::after{font-size:140px;top:-20px;left:-20px}
  .star-guest__stats{gap:22px}

  .guests__sub-head{margin:0 0 28px;gap:14px}
  .guests__sub-label{font-size:10px;letter-spacing:.24em;white-space:normal;text-align:center}

  .hotel__rates{grid-template-columns:1fr;box-shadow:4px 4px 0 var(--accent-gold)}
  .hotel__rate--main{border-right:none;border-bottom:1px dashed var(--rule);padding-right:0;padding-bottom:16px}

  .gallery__grid--single{grid-template-columns:1fr}
}

@media (max-width:560px){
  .countdown__digits{gap:8px}
  .cd{min-width:0;flex:1;padding:10px 8px}
  .cd b{font-size:24px}
  .hero{padding-top:100px}
  .display{font-size:54px}
  h2{font-size:36px}
  .contact__h{font-size:44px}
  .luggage{min-height:0}
  .foot__inner{grid-template-columns:1fr}
}

/* ============================================================
   MOBILE REFINEMENTS — solo afecta ≤ 768 px (desktop intacto)
   ============================================================ */
@media (max-width:768px){

  /* Sin scroll horizontal por elementos rotados */
  html,body{overflow-x:clip}
  body{-webkit-text-size-adjust:100%}

  /* ========== HERO MOBILE V3 — postal arriba, wordmark, copy ========== */
  .hero{
    min-height:100dvh;
    padding-top:max(96px,env(safe-area-inset-top));
    padding-bottom:40px;
    padding-left:max(20px,env(safe-area-inset-left));
    padding-right:max(20px,env(safe-area-inset-right));
    background:
      radial-gradient(ellipse 80% 60% at 50% 8%, rgba(242,169,60,.55), transparent 60%),
      radial-gradient(ellipse 60% 40% at 100% 35%, rgba(188,146,171,.4), transparent 60%),
      radial-gradient(ellipse 70% 50% at 0% 70%, rgba(230,50,36,.22), transparent 65%),
      linear-gradient(180deg,#FFE9C0 0%,#FAE2C0 50%,#F1CE82 100%);
  }
  .hero__inner{min-height:calc(100dvh - 150px);gap:20px}
  .hero__sun{width:min(520px,92vw);top:2%;opacity:.7}

  /* Esconder hero__top (kicker + seal) — la postal y el wordmark hacen ese trabajo */
  .hero__top{display:none}

  /* HERO GRID en mobile: postal arriba, copy abajo (flex column con order) */
  .hero__grid{display:flex;flex-direction:column;gap:16px;align-items:center}
  .hero__postcard{order:1}
  .hero__copy{order:2;width:100%}

  /* WORDMARK: visible solo en mobile, debajo de la postal */
  .hero__wordmark{
    display:block;
    width:min(330px,78vw);
    height:auto;
    margin:6px auto 4px;
    filter:drop-shadow(0 1px 0 rgba(255,245,221,.7));
  }
  .hero__postcard{
    transform:rotate(-1.5deg);
    max-width:min(420px,92vw);
    width:100%;
    margin:0 auto;
    padding:14px 14px 56px;
    background:#FFF5DD;
    position:relative;
  }
  .hero__postcard::after{
    content:"V";position:absolute;top:-22px;right:-12px;
    width:78px;height:78px;border-radius:50%;
    background:radial-gradient(circle at 30% 30%, #C53A22, #7A1D11 70%);
    color:#FAE2C0;
    font-family:var(--f-display);font-style:italic;font-weight:700;
    font-size:38px;display:grid;place-items:center;
    box-shadow:0 6px 14px rgba(0,0,0,.35), inset 0 -4px 8px rgba(0,0,0,.3);
    transform:rotate(12deg);
    border:2px solid #5A1A0E;
    z-index:5;
  }
  .hero__postcard figcaption{font-size:9.5px;letter-spacing:.24em;left:18px;bottom:18px}

  /* COPY — debajo de la postal, centrado, jerarquía editorial */
  .hero__copy{
    display:flex;flex-direction:column;gap:12px;
    align-items:center;text-align:center;
    width:100%;
  }
  .display{
    font-size:clamp(42px,13vw,76px);
    line-height:.94;
    letter-spacing:-.025em;
  }
  .display em{margin-top:2px}
  .hero__sub{
    font-size:15.5px;line-height:1.45;
    max-width:32ch;margin:0 auto;
    opacity:.88;
  }
  .typewriter{
    font-size:12.5px;max-width:30ch;
    color:var(--ink-muted);opacity:.85;
    margin:0 auto;
  }

  /* Detalles tipo "ticket" — fecha + venue + edición prominentes */
  .hero__copy::after{
    content:"CARTAGENA · 10–12 SEPT · MMXXVI";
    font-family:var(--f-label);font-weight:700;
    font-size:9.5px;letter-spacing:.34em;text-transform:uppercase;
    color:var(--ink-muted);
    padding:8px 14px;border-top:1px solid var(--rule);border-bottom:1px solid var(--rule);
    margin-top:6px;
  }

  /* COUNTDOWN — barra cinematográfica al fondo */
  .countdown{
    width:100%;
    background:rgba(255,245,221,.7);
    border:1.5px solid var(--ink-primary);
    border-radius:14px;
    padding:14px;
    margin-top:12px;
    backdrop-filter:blur(6px);
    -webkit-backdrop-filter:blur(6px);
    box-shadow:0 6px 0 var(--ink-primary), 0 14px 26px -10px rgba(79,37,32,.3);
  }
  .countdown__label{
    text-align:center;margin-bottom:8px;
    color:var(--ink-muted);font-size:9.5px;letter-spacing:.26em;
  }
  .countdown__digits{gap:4px;justify-content:space-between}
  .cd{
    padding:8px 4px;flex:1;min-width:0;
    background:transparent;border:none;
    box-shadow:none;
    border-right:1px dashed var(--rule);
  }
  .cd:last-child{border-right:none}
  .cd::before,.cd::after{display:none}
  .cd b{font-size:24px;color:var(--ink-muted);font-style:italic;font-weight:600}
  .cd span{font-size:7.5px;letter-spacing:.22em;margin-top:3px;color:var(--ink-primary);opacity:.7}

  .hero__bottom{flex-direction:column;align-items:center;gap:12px;margin-top:auto}
  .hero__serial{display:none}

  /* CTAs — full-width, apilados, amber primario */
  .hero__ctas{
    gap:10px;flex-direction:column;width:100%;max-width:380px;margin:8px auto 0;
  }
  .hero__ctas .btn{
    width:100%;justify-content:center;
    padding:18px 22px;font-size:12.5px;letter-spacing:.16em;
  }
  .hero__ctas .btn--amber{box-shadow:0 4px 0 var(--ink-primary)}

  /* Touch targets ≥ 44 px (WCAG / iOS HIG) */
  .nav__burger{width:44px;height:44px;gap:5px;margin-left:auto}
  .nav__burger span{width:24px;height:2px}

  /* Nav brand más compacto pero visible */
  .nav__wrap{min-height:64px;padding:10px var(--pad-x);gap:12px}
  .nav__seal{width:44px;height:44px;padding:4px;box-shadow:0 0 0 1.5px currentColor inset, 0 0 0 3px #FFF5DD inset, 0 0 0 4px currentColor inset}
  .nav__edition{font-size:8px;letter-spacing:.24em}
  .nav__brandtxt{font-size:17px;letter-spacing:.04em}
  .nav.is-open .nav__links{padding-top:18px;padding-bottom:24px;gap:6px}
  .nav.is-open .nav__links a{
    display:block;
    padding:14px 4px;
    font-size:14px;letter-spacing:.18em;
    border-bottom:1px solid var(--rule);
    min-height:44px;
  }
  .nav.is-open .nav__links a:last-of-type{border-bottom:0}
  .nav.is-open .nav__cta{padding:18px 28px;font-size:13px;text-align:center;justify-content:center}

  /* Marquee: más rápido en mobile para que se note movimiento sin que canse */
  .marquee{padding:14px 0}
  .marquee__track{animation-duration:22s;gap:32px;font-size:22px}

  /* Aniversario: drop cap controlada, pin sin rotación extrema */
  .anniv{padding:80px 20px}
  .dropcap{font-size:min(160px,38vw);line-height:.82;margin:0 12px -10px 0}
  .anniv__body{font-size:17px}
  .anniv__pin img{transform:rotate(1.5deg);border-width:6px}

  /* Sección heads y bloques: respiro extra */
  .section-head{margin-bottom:48px}
  .section-head p{font-size:15px}

  /* Timeline / momentos */
  .programa{padding:80px 18px}
  .timeline::before{left:24px;top:24px;bottom:24px}
  .moment{grid-template-columns:48px 1fr;gap:12px}
  .moment__index{
    width:48px;height:48px;font-size:22px;
    box-shadow:0 0 0 5px var(--bg-night),0 0 0 6px var(--accent-gold);
  }
  /* Postales del timeline sin tilt en mobile: evita corte por overflow:clip */
  .timeline .postcard{transform:none!important;width:100%}
  .timeline .postcard:hover{transform:translateY(-2px)!important}
  .postcard__media{min-height:180px}
  .postcard__body{padding:22px 20px}
  .postcard__body h3{font-size:22px}
  .postcard__body p{font-size:14.5px}
  .postcard__meta{gap:10px}
  .postcard__meta span{font-size:9px}
  .taste{padding-top:12px;margin-top:14px;font-size:12px}

  /* Masterclasses ticket: stub más estrecho para dejar respirar al body */
  .master{padding:80px 20px}
  .ticket{grid-template-columns:96px 1fr}
  .ticket__stub{padding:24px 8px}
  .ticket__stub b{font-size:22px}
  .ticket__stub span{font-size:9.5px;letter-spacing:.18em}
  .ticket__body{padding:22px 18px}
  .ticket__body h3{font-size:21px}
  .ticket__body p{font-size:14.5px}
  .ticket__foot{flex-direction:column;align-items:flex-start;gap:8px}

  /* Inversión: 2-cards apiladas, sello de cera más pequeño para no desbordar */
  .invest{padding:80px 20px}
  .tags-grid--2{grid-template-columns:1fr;max-width:480px}
  .luggage{padding:42px 22px 24px;border-radius:6px 18px 18px 6px}
  .luggage h3{font-size:26px}
  .luggage__pitch{font-size:14px}
  .luggage__prices b{font-size:20px}
  .wax{width:62px;height:62px;font-size:26px;top:-12px;right:-10px}
  .includes{margin-top:36px;padding:24px 18px;gap:18px}
  .includes ul li{font-size:14.5px}

  /* Hotel: pila vertical, postal sin rotación */
  .hotel{padding:80px 20px}
  .hotel__inner{gap:30px}
  .hotel__img{transform:none}
  .wish{top:14px;left:14px;font-size:10px;padding:6px 10px}
  .hotel__copy p{font-size:16px}
  .hotel__list li{font-size:14.5px}

  /* Galería: sin rotaciones en mobile para evitar cortes en los bordes */
  .gallery{padding:80px 18px}
  .gframe{transform:none!important;border-width:6px}
  .gframe:hover{transform:translateY(-2px)!important}
  .gframe figcaption{left:10px;right:10px;bottom:10px}
  .gframe figcaption span{font-size:8px;padding:4px 8px}

  /* Contacto: padding y CTA full-width */
  .contact{padding:80px 20px}
  .contact__h{font-size:clamp(40px,9vw,56px)}
  .contact p{font-size:16px}
  .contact .btn--big{width:100%;max-width:360px;justify-content:center;padding:20px 24px;font-size:13px}

  /* Footer mobile */
  .foot{padding:60px 20px max(28px,env(safe-area-inset-bottom)) 20px}

  .foot__top{margin:0 auto 40px;gap:18px}
  .foot__logo{width:min(280px,72vw)}
  .foot__tagline{font-size:17px}
  .foot__cta{width:100%;max-width:340px;justify-content:center}

  .foot__band{
    flex-direction:column;align-items:center;gap:10px;
    margin:0 auto 40px;font-size:9.5px;letter-spacing:.18em;
  }
  .foot__band .rule{display:none}
  .foot__band-dot{display:none}
  .foot__band b{font-size:16px;margin-right:6px}

  .foot__inner{grid-template-columns:1fr;gap:28px;padding-bottom:32px}
  .foot__col h5{margin-bottom:14px;padding-bottom:8px}
  .foot__col a{padding:11px 0;font-size:11px;min-height:44px;display:flex;align-items:center}
  .foot__col p{font-size:13px}
  .foot__col--brand p{max-width:none}
  .foot__site{padding:10px 14px!important;margin-top:8px}

  .foot__legal{font-size:9px;gap:12px;margin-top:22px}
  .foot__legal-row{justify-content:flex-start;flex-direction:column;gap:6px}
  .foot__legal p{font-size:10px;line-height:1.6}

  /* Botones: tap target seguro + texto que respira */
  .btn{padding:16px 20px;min-height:48px;font-size:12.5px;letter-spacing:.12em;line-height:1.25}
  .btn--big{padding:20px 24px;font-size:13.5px;letter-spacing:.14em}
  .hotel__book{align-self:stretch;width:100%;max-width:420px;justify-content:center}

  /* INVITADOS mobile */
  .guests{padding:80px 20px}
  .guests__grid{grid-template-columns:1fr;gap:32px;max-width:420px;margin:0 auto}
  .guests__grid--4{grid-template-columns:1fr;max-width:420px}
  .guests__grid--2{grid-template-columns:1fr;max-width:420px}
  .guests__grid--international{grid-template-columns:1fr;max-width:420px;margin-top:32px}
  .guests__grid--chefs{grid-template-columns:1fr;max-width:420px;margin-top:24px}
  .guest:nth-child(n){transform:none;margin-top:0}
  .guest__photo{padding:10px 10px 44px}
  .guest__flag{top:18px;right:18px;font-size:18px;padding:5px 8px}
  .guest__body{padding:0 4px}
  .guest h3{font-size:24px}

  /* Star guest mobile */
  .star-guest{padding:24px;margin-bottom:48px;box-shadow:6px 6px 0 var(--accent-gold), 0 18px 30px -15px rgba(79,37,32,.4)}
  .star-guest__stamp{width:84px;height:84px;top:14px;right:14px;padding:6px}
  .star-guest__stamp-star{font-size:22px}
  .star-guest__stamp-text{font-size:6.5px;letter-spacing:.16em}
  .star-guest__photo{padding:10px 10px 48px}
  .star-guest__name{font-size:40px}
  .star-guest__title{font-size:15px;padding-bottom:14px;margin-bottom:18px}
  .star-guest__bio{font-size:15px}
  .star-guest__stats{gap:18px;margin:18px 0 20px;padding:14px 0}
  .star-guest__stats b{font-size:26px}
  .star-guest__quote{font-size:17px;padding-left:14px}
  .star-guest::after{font-size:120px}
  .star-guest::before{inset:8px}

  /* HOTEL mobile rico */
  .hotel__rates{padding:18px;gap:14px;box-shadow:4px 4px 0 var(--accent-gold)}
  .rate__price{font-size:28px}
  .hotel__details{gap:14px 24px;padding:14px 0}
  .hotel__detail{flex:1 1 100%}
  .hotel__contact{padding:14px}
  .hotel__contact-row{gap:12px 18px}
  .hotel__contact-row a{font-size:11px}

  /* BRANDS strip mobile */
  .brands{padding:16px 0 20px}
  .brands::before,.brands::after{width:40px}
  .brands__head{gap:14px;padding:0 16px 10px}
  .brands__head .rule{max-width:60px}
  .brands__label{font-size:9px;letter-spacing:.24em}
  .brands__track{gap:20px;animation-duration:50s}
  .b--logo img{height:24px}
  .b--serif{font-size:18px}
  .b--bold{font-size:13px;letter-spacing:.16em}
  .b--condensed{font-size:13px;letter-spacing:.26em}
  .b--italic{font-size:17px}
  .b--sans{font-size:11px;letter-spacing:.32em}
  .b--bar{height:16px}

  /* ARCHIVE page mobile */
  .arch-hero{padding-top:max(120px,env(safe-area-inset-top));padding-left:20px;padding-right:20px}
  .arch-hero__top{margin-bottom:24px}
  .arch-hero__h{font-size:clamp(40px,11vw,72px)}
  .arch-hero__lead{font-size:16px}
  .arch-hero__meta{gap:24px;padding:18px 0}
  .arch-hero__meta b{font-size:18px}
  .arch-section{margin:56px auto 24px}
  .arch-section--alt{margin-top:80px}
  .arch-invite{padding:80px 20px}
  .arch-invite__ctas{flex-direction:column;align-items:center}
  .arch-invite__ctas .btn{width:100%;max-width:360px;justify-content:center}
}

/* iPhone SE / 360 px y similares */
@media (max-width:380px){
  :root{--pad-x:16px}
  .btn{padding:14px 18px;font-size:12px;letter-spacing:.1em}
  .btn--big{padding:18px 22px;font-size:13px;letter-spacing:.12em}
  .nav__seal{width:40px;height:40px}
  .nav__brandtxt{font-size:15.5px}
  .nav__edition{font-size:7.5px;letter-spacing:.22em}
  .hero__seal{width:42px;height:42px}
  .hero__postcard::after{width:64px;height:64px;font-size:30px;top:-16px;right:-8px}
  .display{font-size:clamp(36px,12vw,52px)}
  .display em{display:block}
  .cd{padding:9px 4px}
  .cd b{font-size:20px}
  .marquee__track{font-size:18px;gap:24px}
  .dropcap{font-size:min(140px,42vw)}
  .moment__index{width:42px;height:42px;font-size:19px}
  .timeline::before{left:20px}
  .ticket{grid-template-columns:78px 1fr}
  .ticket__stub b{font-size:19px}
  .ticket__body{padding:20px 14px}
  .luggage h3{font-size:23px}
  .wax{width:54px;height:54px;font-size:22px}
}

/* Mejora de scroll-snap suave para galería en mobile horizontal (opcional) */
@media (max-width:560px) and (pointer:coarse){
  /* Smooth tap feedback */
  .btn:active{transform:scale(.97)}
  .luggage:active,.ticket:active,.gframe:active{transform:translateY(0) scale(.99)}
}

/* ============================================================
   MOBILE MODERN LAYER — parallax · scroll-driven · sticky CTA
   Solo afecta ≤ 768 px y pointer:coarse · desktop intacto
   ============================================================ */

/* -------- Reading progress bar (top of page) -------- */
.scrollbar{
  position:fixed;top:0;left:0;right:0;height:3px;
  z-index:200;pointer-events:none;
  background:transparent;
  display:none;
}
.scrollbar__fill{
  height:100%;
  background:linear-gradient(90deg,#F1CE82,#F2A93C,#E63224);
  transform-origin:0 50%;
  transform:scaleX(0);
  transition:transform .15s linear;
  box-shadow:0 0 12px rgba(242,169,60,.6);
}

@media (max-width:980px){
  .scrollbar{display:block}
}

/* -------- Foot padding to clear the cart pill on mobile -------- */
@media (max-width:980px){
  .foot{padding-bottom:max(96px,env(safe-area-inset-bottom))}
}

/* -------- Sticky moment indicator (I·II·III·IV·V) -------- */
.moment-pin{
  position:fixed;
  right:14px;top:50%;transform:translateY(-50%) translateX(120%);
  z-index:80;
  padding:14px 12px;
  background:rgba(42,19,14,.92);
  color:var(--ink-inverse);
  border:1px solid var(--accent-gold);
  border-radius:999px;
  display:none;
  flex-direction:column;align-items:center;gap:6px;
  font-family:var(--f-label);font-size:8.5px;letter-spacing:.22em;text-transform:uppercase;
  box-shadow:0 12px 24px -8px rgba(0,0,0,.4);
  transition:transform .35s cubic-bezier(.32,.72,0,1), opacity .35s ease;
  opacity:0;
  pointer-events:none;
}
.moment-pin.is-active{transform:translateY(-50%) translateX(0);opacity:1}
.moment-pin__label{opacity:.7}
.moment-pin__num{
  font-family:var(--f-display);font-style:italic;font-weight:600;
  font-size:26px;color:var(--accent-amber);
  letter-spacing:0;text-transform:none;
  line-height:.9;
  transition:transform .35s cubic-bezier(.22,1,.36,1), opacity .25s ease;
}
.moment-pin__num.is-flip{transform:translateY(-6px) scale(.9);opacity:.4}
.moment-pin__progress{
  display:block;width:30px;height:2px;background:rgba(241,206,130,.25);border-radius:2px;overflow:hidden;
}
.moment-pin__progress span{
  display:block;height:100%;width:0%;background:linear-gradient(90deg,#F1CE82,#F2A93C);
  transition:width .25s linear;
}
@media (max-width:980px){
  .moment-pin{display:flex}
}
@media (max-width:560px){
  .moment-pin{right:10px;padding:11px 9px}
  .moment-pin__num{font-size:22px}
  .moment-pin__progress{width:24px}
}

/* -------- Mobile parallax (transforms set inline by JS) -------- */
@media (max-width:980px){
  .hero__sun, .hero__postcard, .hero__copy {
    will-change:transform;
    transform:translate3d(0,0,0);
  }
}

/* -------- Stagger reveal — más cinemático en mobile -------- */
@media (max-width:980px){
  .reveal{
    transform:translateY(24px) scale(.985);
    transition:opacity .65s cubic-bezier(.22,1,.36,1), transform .75s cubic-bezier(.22,1,.36,1);
  }
  .reveal.is-in{transform:translateY(0) scale(1)}

  /* Stagger por posición dentro del padre */
  .moment{transition-delay:0ms}
  .moment:nth-child(2){transition-delay:60ms}
  .moment:nth-child(3){transition-delay:120ms}
  .moment:nth-child(4){transition-delay:180ms}
  .moment:nth-child(5){transition-delay:240ms}

  .gframe:nth-child(2){transition-delay:50ms}
  .gframe:nth-child(3){transition-delay:100ms}
  .gframe:nth-child(4){transition-delay:150ms}
  .gframe:nth-child(5){transition-delay:200ms}
  .gframe:nth-child(6){transition-delay:250ms}
  .gframe:nth-child(7){transition-delay:300ms}
  .gframe:nth-child(8){transition-delay:300ms}
  .gframe:nth-child(9){transition-delay:300ms}
  .gframe:nth-child(10){transition-delay:300ms}

  .ticket:nth-child(2){transition-delay:80ms}

  .luggage:nth-child(2){transition-delay:80ms}
}

/* -------- Scroll-driven entrance (Chrome/Safari/Edge modernos) -------- */
@supports (animation-timeline: view()){
  @media (max-width:980px){
    .moment, .gframe, .ticket, .luggage, .hotel__copy, .hotel__img, .anniv__body, .anniv__pin{
      animation: enter-mobile linear both;
      animation-timeline: view();
      animation-range: entry 0% cover 35%;
    }
    @keyframes enter-mobile{
      0%   { opacity:0; transform: translate3d(0,28px,0) scale(.97); }
      100% { opacity:1; transform: translate3d(0,0,0)    scale(1); }
    }

    /* Hero parallax nativo: el sol y el postal corren a distinta velocidad */
    .hero__sun{
      animation: sun-rise linear both;
      animation-timeline: scroll(root);
      animation-range: 0 80vh;
    }
    @keyframes sun-rise{
      from { transform: translateX(-50%) translateY(0)    scale(1);   opacity:.85; }
      to   { transform: translateX(-50%) translateY(60px) scale(1.1); opacity:.35; }
    }

    .hero__postcard{
      animation: postcard-drift linear both;
      animation-timeline: scroll(root);
      animation-range: 0 80vh;
    }
    @keyframes postcard-drift{
      from { transform: translateY(0)   rotate(0deg); }
      to   { transform: translateY(-40px) rotate(-1deg); }
    }

    /* Marquee acelera levemente con el scroll */
    .marquee__track{
      animation-timeline: scroll(root);
      animation-range: 0 100vh;
    }
  }
}

/* -------- Pointer:coarse (táctil) — feedback de tap cinemático -------- */
@media (pointer:coarse){
  /* Spring-back en botones y cards */
  .btn{transition: transform .14s cubic-bezier(.22,1,.36,1), background .25s ease, color .25s ease, box-shadow .25s ease}
  .btn:active{transform:scale(.96)!important;box-shadow:1px 1px 0 var(--ink-primary)!important}

  .luggage,.ticket,.gframe,.timeline .postcard{
    transition: transform .25s cubic-bezier(.22,1,.36,1), box-shadow .25s ease;
  }
  .luggage:active{transform:scale(.985)!important}
  .ticket:active{transform:translateY(1px) scale(.99)!important}
  .gframe:active{transform:translateY(0) scale(.97)!important;z-index:5}
  .timeline .postcard:active{transform:translateY(0) scale(.99)!important}

  /* Off hover styles on touch */
  .nav__links a::after{display:none}
}

/* -------- Marquee con easing perceptible -------- */
@media (max-width:768px){
  @keyframes marquee-eased{
    0%   { transform:translateX(0) }
    100% { transform:translateX(-50%) }
  }
  .marquee__track{
    animation-name: marquee-eased;
    animation-timing-function: cubic-bezier(.45,0,.55,1);
  }
}

/* -------- Reduced motion: deshabilita parallax y scroll-driven -------- */
@media (prefers-reduced-motion: reduce){
  .hero__sun, .hero__postcard, .hero__copy{transform:none!important;animation:none!important}
  .cart-pill{transition:none}
  .moment-pin{transition:none}
}

/* -------- Iconito de copa que pulsa suavemente sobre el sello hero -------- */
@media (max-width:980px){
  .hero__seal{animation: seal-pulse 4.5s cubic-bezier(.22,1,.36,1) infinite}
  @keyframes seal-pulse{
    0%,100% { transform: rotate(-8deg) scale(1) }
    50%     { transform: rotate(-7deg) scale(1.04) }
  }
}

/* -------- Botón con shine pasa al ver -------- */
@media (max-width:980px){
  .btn--amber{position:relative;overflow:hidden}
  .btn--amber::before{
    content:"";position:absolute;inset:0;
    background:linear-gradient(120deg,transparent 40%,rgba(255,255,255,.55) 50%,transparent 60%);
    transform:translateX(-100%);
    pointer-events:none;
  }
  .btn--amber:hover::before,
  .btn--amber:focus-visible::before{
    animation: shine 1.1s cubic-bezier(.45,0,.55,1);
  }
  @keyframes shine{
    from{transform:translateX(-100%)} to{transform:translateX(100%)}
  }
}


