/* ====================================================================
   CUARENTA AÑOS A FLOTE  ·  Café en alta mar
   Paleta: madera, soga, papel, óxido — sin azul brillante ni dorado
   ==================================================================== */

:root{
  --wood-deep:#140d07;
  --wood:#241710;
  --wood-soft:#33241699;
  --petrol:#16323d;          /* verde-azulado petróleo: contraste */
  --petrol-deep:#0d1f27;
  --petrol-line:#2c5663;     /* línea petróleo */
  --paper:#e8dab7;
  --paper-warm:#decba0;
  --ink:#241a10;
  --ink-soft:#54402a;
  --amber:#b5843c;           /* latón viejo apagado (no amarillo chillón) */
  --amber-bright:#cf9a4e;    /* dorado cálido para resaltes, sin estridencia */
  --brass:#946e34;           /* latón profundo */
  --cream:#ece0c9;
  --cream-dim:#b7a585;
  --blood:#7c2d1c;
  --night:#15201f;           /* verde-azulado muy oscuro */
  --night-soft:#1f2c2a;
  --shadow:rgba(0,0,0,.55);
  --deckle:polygon(0.0% 0.0%, 4.17% 0.74%, 8.33% 0.35%, 12.5% 1.5%, 16.67% 0.17%, 20.83% 1.23%, 25.0% 0.84%, 29.17% 0.13%, 33.33% 1.17%, 37.5% 0.09%, 41.67% 1.0%, 45.83% 0.16%, 50.0% 0.21%, 54.17% 0.98%, 58.33% 1.9%, 62.5% 0.28%, 66.67% 0.51%, 70.83% 1.44%, 75.0% 2.18%, 79.17% 1.33%, 83.33% 0.91%, 87.5% 2.25%, 91.67% 0.11%, 95.83% 1.97%, 100.0% 0.0%, 100.0% 100.0%, 95.83% 99.33%, 91.67% 99.67%, 87.5% 99.73%, 83.33% 99.29%, 79.17% 98.12%, 75.0% 99.58%, 70.83% 98.66%, 66.67% 98.53%, 62.5% 99.14%, 58.33% 98.74%, 54.17% 99.86%, 50.0% 99.86%, 45.83% 99.53%, 41.67% 98.44%, 37.5% 99.02%, 33.33% 99.28%, 29.17% 98.65%, 25.0% 98.96%, 20.83% 99.31%, 16.67% 98.17%, 12.5% 98.39%, 8.33% 99.44%, 4.17% 98.68%, 0.0% 100.0%);
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:'EB Garamond',Georgia,serif;
  font-size:19px;line-height:1.72;
  color:var(--cream);
  background:var(--wood-deep);
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
/* fondo de madera fijo + vigneta de camarote */
body::before{
  content:"";position:fixed;inset:0;z-index:-2;
  background:url('../img/wood.jpg') center/cover;
}
body::after{
  content:"";position:fixed;inset:0;z-index:-1;pointer-events:none;
  background:
    radial-gradient(ellipse 70% 55% at 50% 0%, rgba(181,132,60,.16), transparent 70%),
    radial-gradient(ellipse 120% 90% at 50% 45%, transparent 35%, rgba(0,0,0,.72) 100%);
}
img{max-width:100%;display:block}
a{color:var(--amber-bright);text-decoration:none}
::selection{background:var(--amber);color:var(--wood-deep)}

/* grano de película */
.grain{position:fixed;inset:0;z-index:60;pointer-events:none;opacity:.05;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");}

/* ---------- tipografía de display ---------- */
.display{font-family:'IM Fell English SC',serif;font-weight:400;
  letter-spacing:.02em;line-height:1.05;}
h1,h2,h3{font-family:'IM Fell English SC',serif;font-weight:400;line-height:1.1}

.kicker{font-family:'IM Fell English SC',serif;font-size:.78rem;
  letter-spacing:.34em;text-transform:uppercase;color:var(--amber);
  display:inline-block;}

/* ---------- layout ---------- */
.wrap{max-width:1180px;margin:0 auto;padding:0 28px}
.narrow{max-width:760px}
section{position:relative}
.pad{padding:84px 0}
.pad-sm{padding:54px 0}

/* ====================================================================
   NAVEGACIÓN
   ==================================================================== */
.nav{position:sticky;top:0;z-index:50;
  background:linear-gradient(180deg,#1c3e4a,#0e2129);
  border-bottom:2px solid var(--brass);
  box-shadow:0 6px 26px rgba(0,0,0,.6);}
.nav-in{display:flex;align-items:center;justify-content:space-between;
  max-width:1240px;margin:0 auto;padding:11px 26px;gap:20px}
.brand{display:flex;align-items:center;text-decoration:none}
.brand-logo{height:46px;width:auto;display:block;
  filter:drop-shadow(0 2px 5px rgba(0,0,0,.5))}
.nav-links{display:flex;align-items:center;gap:6px;list-style:none}
.nav-links a{
  font-family:'IM Fell English SC',serif;font-size:.86rem;
  letter-spacing:.2em;text-transform:uppercase;color:var(--cream);
  padding:8px 14px;border-radius:3px;position:relative;transition:.25s;}
.nav-links a:hover{color:var(--amber-bright)}
.nav-links a.active{color:var(--amber-bright)}
.nav-links a.active::after{
  content:"";position:absolute;left:50%;bottom:1px;width:6px;height:6px;
  transform:translateX(-50%) rotate(45deg);background:var(--amber);}
.nav-toggle{display:none;background:none;border:1.5px solid var(--brass);
  border-radius:4px;padding:7px 9px;cursor:pointer}
.nav-toggle span{display:block;width:22px;height:2px;background:var(--cream);
  margin:4px 0;transition:.3s}

/* ====================================================================
   ORNAMENTOS
   ==================================================================== */
.rule{display:flex;align-items:center;justify-content:center;gap:16px;
  margin:14px 0;color:var(--brass)}
.rule::before,.rule::after{content:"";height:1px;flex:1;max-width:130px;
  background:linear-gradient(90deg,transparent,currentColor,transparent)}
.rule svg{width:26px;height:26px;flex:none;color:var(--amber)}
.rule.dark{color:#6a4f28}

.flourish{color:var(--brass);font-size:1.3rem;letter-spacing:.3em}

/* ====================================================================
   BOTONES
   ==================================================================== */
.btn{display:inline-flex;align-items:center;gap:11px;
  font-family:'IM Fell English SC',serif;font-size:.86rem;
  letter-spacing:.2em;text-transform:uppercase;
  padding:13px 26px;cursor:pointer;transition:.28s;
  border:1.6px solid var(--amber);color:var(--amber-bright);
  background:rgba(181,132,60,.06);border-radius:2px}
.btn:hover{background:linear-gradient(180deg,var(--amber-bright),var(--amber));
  color:var(--wood-deep);box-shadow:0 6px 22px rgba(181,132,60,.32);transform:translateY(-2px)}
.btn .ic{width:22px;height:22px;border-radius:50%;border:1.5px solid currentColor;
  display:grid;place-items:center;flex:none}
.btn .ic svg{width:10px;height:10px}
.btn-dark{border-color:var(--brass);color:var(--cream)}
.btn-dark:hover{background:linear-gradient(180deg,#3a2a16,#241710);color:var(--amber-bright);
  border-color:var(--amber)}
.btn-solid{border-color:var(--brass);
  background:linear-gradient(180deg,#1c3e4a,#0e2129);color:var(--cream)}
.btn-solid:hover{background:linear-gradient(180deg,var(--amber-bright),var(--amber));
  color:var(--wood-deep);border-color:var(--amber)}

/* ====================================================================
   PERGAMINO
   ==================================================================== */
.sheet{
  background:url('../img/paper.jpg') center/cover,var(--paper);
  color:var(--ink);
  clip-path:var(--deckle);
  filter:drop-shadow(0 18px 30px rgba(0,0,0,.55));
  padding:60px 62px;position:relative;
}
.sheet.aged{background:url('../img/paper-aged.jpg') center/cover,var(--paper-warm)}
.sheet::after{ /* envejecido interior */
  content:"";position:absolute;inset:0;pointer-events:none;
  background:radial-gradient(ellipse 90% 80% at 50% 40%,transparent 55%,rgba(90,60,25,.22));
  clip-path:var(--deckle);}
.sheet h2,.sheet h3{color:var(--petrol)}
.sheet p{margin:0 0 1.05em}
.sheet .kicker{color:var(--blood)}

/* texto de relato / bio */
.prose{font-size:1.2rem;line-height:1.85;color:var(--ink)}
.prose p{margin:0 0 1.15em;text-align:justify;hyphens:auto}
.prose p.dlg{margin-left:34px;text-align:left;font-style:italic;color:#43331c}
.prose p.beat{text-align:left;font-style:italic;font-size:1.16rem;
  color:#3a2614;margin:.4em 0 1.15em}
.prose p.tail{text-align:left;font-style:italic;color:#6c4a1f;
  border-top:1px solid #c3ad7f;padding-top:1.1em;margin-top:1.4em}
.prose blockquote.pull{
  margin:1.4em 0;padding:.4em 0 .4em 26px;
  border-left:4px solid var(--amber);
  font-family:'IM Fell English',serif;font-style:italic;
  font-size:1.4rem;line-height:1.5;color:var(--petrol);}
.prose .dropcap::first-letter,.prose>p:first-of-type::first-letter{
  font-family:'IM Fell English SC',serif;
  font-size:4.2rem;line-height:.8;float:left;
  margin:.06em .12em 0 0;color:var(--blood);}

/* ====================================================================
   HERO PORTADA
   ==================================================================== */
.hero{position:relative;min-height:90vh;display:flex;align-items:flex-end;
  background:url('../img/hero-banner.jpg') center 38%/cover;}
.hero::after{content:"";position:absolute;inset:0;
  background:linear-gradient(180deg,rgba(13,14,12,.42) 0%,transparent 26%,
    transparent 48%,rgba(10,8,5,.62) 80%,rgba(10,8,5,.92) 100%);}
.hero-in{position:relative;z-index:2;width:100%;padding-bottom:64px}
.hero .tagline{font-family:'IM Fell English',serif;font-style:italic;
  font-size:1.65rem;color:var(--cream);max-width:540px;
  text-shadow:0 2px 14px rgba(0,0,0,.85);margin:6px 0 22px}
.hero .cta-row{display:flex;gap:16px;flex-wrap:wrap}
.scrollcue{position:absolute;left:50%;bottom:20px;transform:translateX(-50%);
  z-index:2;color:var(--cream-dim);font-size:.7rem;letter-spacing:.3em;
  text-transform:uppercase;font-family:'IM Fell English SC',serif;text-align:center}
.scrollcue span{display:block;width:1px;height:34px;margin:8px auto 0;
  background:linear-gradient(var(--amber),transparent);animation:cue 2s infinite}
@keyframes cue{0%,100%{opacity:.3}50%{opacity:1}}

/* ---------- hero interior (otras páginas) ---------- */
.phero{position:relative;padding:88px 0 76px;text-align:center;overflow:hidden}
.phero.img{background-position:center;background-size:cover}
.phero::after{content:"";position:absolute;inset:0;
  background:linear-gradient(180deg,rgba(10,8,5,.55),rgba(10,8,5,.8))}
.phero .wrap{position:relative;z-index:2}
.phero h1{font-size:clamp(2.8rem,7vw,5rem);color:var(--amber-bright);
  text-shadow:0 3px 0 rgba(0,0,0,.4),0 0 30px rgba(181,132,60,.25)}
.phero .sub{font-family:'IM Fell English',serif;font-style:italic;
  font-size:1.3rem;color:var(--cream);margin-top:6px}

/* ====================================================================
   PORTADA — secciones
   ==================================================================== */
.intro-sheet{max-width:880px;margin:0 auto;transform:rotate(-.5deg)}
.intro-sheet h2{font-size:2.4rem;margin-bottom:.2em}
.coffee{position:absolute;width:230px;opacity:.55;pointer-events:none;z-index:3}

.gates{display:grid;grid-template-columns:repeat(3,1fr);gap:26px;margin-top:8px}
.gate-card{display:block;text-decoration:none;border-radius:4px}
.gate-card img{width:100%;height:auto;display:block;border-radius:3px;
  transition:transform .32s ease,filter .32s ease;
  filter:drop-shadow(0 10px 22px rgba(0,0,0,.55))}
.gate-card:hover img,.gate-card:focus-visible img{
  transform:translateY(-10px) scale(1.045);
  filter:drop-shadow(0 26px 40px rgba(0,0,0,.72))}
.gate-card:focus-visible{outline:none}

/* tango feature */
.tango-feat{display:grid;grid-template-columns:280px 1fr;gap:46px;align-items:center}
.vinyl{position:relative;width:260px;height:260px;margin:0 auto}
.vinyl .disc{position:absolute;inset:0;border-radius:50%;
  background:repeating-radial-gradient(circle,#0c0c0d 0 2px,#171718 2px 4px);
  box-shadow:0 14px 34px rgba(0,0,0,.7),inset 0 0 60px rgba(0,0,0,.8)}
.vinyl .label{position:absolute;inset:34%;border-radius:50%;
  background:radial-gradient(circle,var(--amber-bright),var(--brass));
  display:grid;place-items:center;color:var(--wood-deep);
  font-family:'IM Fell English SC',serif;font-size:.62rem;letter-spacing:.12em;
  text-align:center;box-shadow:inset 0 0 14px rgba(0,0,0,.4)}
.vinyl .hole{position:absolute;inset:48.6%;border-radius:50%;background:var(--wood-deep)}
.vinyl .sleeve{position:absolute;top:-12px;left:54%;width:215px;
  border:5px solid #e9dcbb;box-shadow:0 12px 28px rgba(0,0,0,.6);
  transform:rotate(5deg)}

/* ====================================================================
   HISTORIAS — índice
   ==================================================================== */
.cat-index{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;margin-top:6px}
.cat-card{background:none;border:none;cursor:pointer;text-align:center;
  font-family:inherit;transition:.3s;color:var(--cream)}
.cat-medal{
  width:138px;height:138px;margin:0 auto 14px;
  display:grid;place-items:center;
  transition:.3s;position:relative;
  filter:drop-shadow(0 9px 16px rgba(0,0,0,.6))}
.cat-medal img{width:100%;height:100%;object-fit:contain;
  transition:transform .3s}
.cat-card:hover .cat-medal,.cat-card.active .cat-medal{
  transform:translateY(-5px)}
.cat-card:hover .cat-medal img,.cat-card.active .cat-medal img{
  transform:scale(1.05)}
.cat-card.active .cat-medal{
  filter:drop-shadow(0 12px 22px rgba(181,132,60,.5))}
.cat-card .cat-name{font-family:'IM Fell English SC',serif;
  font-size:1.02rem;letter-spacing:.12em;text-transform:uppercase}
.cat-card .cat-count{font-size:.84rem;color:var(--cream-dim);font-style:italic}
.cat-card.active .cat-name{color:var(--amber-bright)}

/* filtro por lugar */
.lugar-bar{display:flex;flex-wrap:wrap;align-items:center;gap:10px;
  justify-content:center;margin-top:10px}
.lugar-bar .lbl{font-family:'IM Fell English SC',serif;font-size:.78rem;
  letter-spacing:.24em;text-transform:uppercase;color:var(--cream-dim);
  margin-right:6px}
.pill{font-family:'EB Garamond',serif;font-size:.94rem;
  padding:5px 16px;border-radius:20px;cursor:pointer;transition:.22s;
  border:1px solid var(--petrol-line);background:rgba(20,33,39,.6);
  color:var(--cream)}
.pill:hover{border-color:var(--amber)}
.pill.active{background:linear-gradient(180deg,var(--amber-bright),var(--amber));
  color:var(--wood-deep);border-color:var(--amber);font-weight:600}

/* grilla de historias */
.story-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:30px;margin-top:34px}
.scard{
  background:url('../img/paper.jpg') center/cover,var(--paper);
  color:var(--ink);text-decoration:none;display:flex;flex-direction:column;
  border-radius:2px;box-shadow:0 12px 26px rgba(0,0,0,.5);
  transition:.3s;position:relative;overflow:hidden;
  border:1px solid #b89f6f}
.scard::before{content:"";position:absolute;inset:0;pointer-events:none;
  box-shadow:inset 0 0 44px rgba(90,60,25,.28)}
.scard:hover{transform:translateY(-7px);
  box-shadow:0 22px 40px rgba(0,0,0,.6),0 0 0 1px var(--amber)}
.scard .top{display:flex;align-items:center;gap:13px;padding:20px 22px 0}
.scard .emblem{width:54px;height:54px;flex:none;
  filter:drop-shadow(0 4px 8px rgba(0,0,0,.5))}
.scard .emblem img{width:100%;height:100%;object-fit:contain;display:block}
.scard .meta{font-family:'IM Fell English SC',serif;font-size:.68rem;
  letter-spacing:.16em;text-transform:uppercase;color:var(--blood)}
.scard h3{font-size:1.42rem;color:var(--petrol);padding:14px 22px 0;line-height:1.16}
.scard .excerpt{padding:10px 22px 0;font-size:1.1rem;color:#43301d;
  font-style:italic;flex:1;line-height:1.6}
.scard .read{padding:16px 22px 20px;font-family:'IM Fell English SC',serif;
  font-size:.74rem;letter-spacing:.2em;text-transform:uppercase;color:var(--brass);
  display:flex;align-items:center;gap:8px}
.scard:hover .read{color:var(--blood)}
.scard .num{position:absolute;top:14px;right:18px;
  font-family:'IM Fell English SC',serif;font-size:1.5rem;color:#c4ac7d}
.empty-note{text-align:center;color:var(--cream-dim);font-style:italic;
  padding:40px;display:none}

/* ====================================================================
   PÁGINA DE RELATO
   ==================================================================== */
.story-head{text-align:center;padding:64px 0 30px}
.story-head .emblem-medal{width:112px;height:112px;margin:0 auto 18px;
  filter:drop-shadow(0 8px 16px rgba(0,0,0,.6))}
.story-head .emblem-medal img{width:100%;height:100%;object-fit:contain;display:block}
.story-head h1{font-size:clamp(2.2rem,5vw,3.6rem);color:var(--amber-bright);
  max-width:880px;margin:0 auto}
.story-sheet{max-width:780px;margin:0 auto}
.story-nav{max-width:780px;margin:34px auto 0;display:flex;
  justify-content:space-between;gap:14px;flex-wrap:wrap}
.story-nav a{display:flex;flex-direction:column;max-width:300px;
  padding:14px 20px;border:1px solid var(--petrol-line);border-radius:3px;
  background:rgba(20,33,39,.55);transition:.25s}
.story-nav a:hover{border-color:var(--amber);background:rgba(36,58,68,.7)}
.story-nav .dir{font-family:'IM Fell English SC',serif;font-size:.7rem;
  letter-spacing:.2em;text-transform:uppercase;color:var(--cream-dim)}
.story-nav .nm{color:var(--amber-bright);font-style:italic}
.story-nav .next{text-align:right;margin-left:auto}

/* ====================================================================
   EL DISCO
   ==================================================================== */
.disco-head{display:grid;grid-template-columns:300px 1fr;gap:44px;align-items:center}
.disco-cover{border:6px solid #e9dcbb;box-shadow:0 18px 40px rgba(0,0,0,.7);
  transform:rotate(-2deg)}
.disco-head h2{font-size:2.5rem;color:var(--petrol)}
.feature-tango{margin-top:14px}
.embed{position:relative;padding-bottom:56.25%;height:0;
  border:5px solid #1a1a1b;box-shadow:0 14px 34px rgba(0,0,0,.6)}
.embed iframe{position:absolute;inset:0;width:100%;height:100%}

.tracklist{margin-top:8px}
.track{border-bottom:1px solid #c2ac7e}
.track:first-child{border-top:1px solid #c2ac7e}
.track-hd{display:flex;align-items:center;gap:18px;width:100%;
  background:none;border:none;cursor:pointer;font-family:inherit;
  padding:17px 6px;text-align:left;color:var(--ink);transition:.2s}
.track-hd:hover{background:rgba(124,45,28,.06)}
.track-hd .tn{font-family:'IM Fell English SC',serif;font-size:1.1rem;
  color:var(--brass);width:34px;flex:none}
.track-hd .tt{font-family:'IM Fell English',serif;font-size:1.3rem;
  color:var(--petrol);flex:1}
.track-hd .tstate{font-size:.78rem;font-style:italic;color:var(--ink-soft);
  white-space:nowrap}
.track-hd .tstate.live{color:var(--blood)}
.track-hd .tstate .pic{display:inline-block;width:9px;height:9px}
.track-hd .tstate .pic svg{width:9px;height:9px}
.track-hd .chev{width:13px;height:13px;border-right:2px solid var(--brass);
  border-bottom:2px solid var(--brass);transform:rotate(45deg);
  transition:.3s;flex:none}
.track.open .chev{transform:rotate(-135deg)}
.track-body{max-height:0;overflow:hidden;transition:max-height .5s ease}
.track-inner{padding:6px 10px 30px}
.lyrics{column-count:2;column-gap:46px;font-size:1.2rem;line-height:1.78}
.stanza{break-inside:avoid;margin-bottom:1.15em}
.stanza .ln{display:block;color:#1f1810}
.stanza .ln:nth-child(1){text-indent:0}
.lyric-note{font-style:italic;color:var(--blood);margin-bottom:18px;
  font-size:.98rem}

/* ====================================================================
   MAPA
   ==================================================================== */
.chart{max-width:980px;margin:0 auto;text-align:center}
.compass-big{width:160px;height:160px;margin:6px auto 26px;color:var(--brass)}
.ports{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:24px;
  text-align:left}
.port{background:rgba(60,42,20,.08);border:1px solid #b59a68;
  border-radius:4px;padding:26px 26px 28px}
.port .pin{display:flex;align-items:center;gap:10px;margin-bottom:8px}
.port .pin svg{width:22px;height:22px;color:var(--brass);flex:none}
.port h3{color:var(--petrol);font-size:1.46rem;line-height:1.18}
.port p{font-size:1.12rem;color:var(--ink-soft);margin-top:6px;line-height:1.6}

/* ====================================================================
   GALERÍA
   ==================================================================== */
.gallery{column-count:3;column-gap:30px;margin-top:10px}
.frame{background:#e9dcbb;padding:14px 14px 46px;
  box-shadow:0 14px 30px rgba(0,0,0,.55);transition:transform .3s,box-shadow .3s;
  break-inside:avoid;margin-bottom:30px;cursor:pointer;
  position:relative;outline:none}
.frame:nth-child(3n+1){transform:rotate(-1.4deg)}
.frame:nth-child(3n+2){transform:rotate(1deg)}
.frame:nth-child(3n){transform:rotate(.5deg)}
.frame:hover,.frame:focus-visible{transform:rotate(0) translateY(-8px) scale(1.025);
  box-shadow:0 26px 48px rgba(0,0,0,.72);z-index:2}
.frame img{width:100%;height:auto;display:block;
  border:1px solid #00000022}
/* lupa al pasar el mouse: indica que es clickeable */
.frame::after{content:"";position:absolute;top:24px;right:24px;
  width:38px;height:38px;border-radius:50%;
  background:rgba(20,16,10,.78) center/18px no-repeat;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23ece0c9' stroke-width='2.4' stroke-linecap='round'%3E%3Ccircle cx='10.5' cy='10.5' r='6.5'/%3E%3Cline x1='15.5' y1='15.5' x2='21' y2='21'/%3E%3Cline x1='10.5' y1='7.5' x2='10.5' y2='13.5'/%3E%3Cline x1='7.5' y1='10.5' x2='13.5' y2='10.5'/%3E%3C/svg%3E");
  opacity:0;transform:scale(.7);transition:.28s;pointer-events:none}
.frame:hover::after,.frame:focus-visible::after{opacity:1;transform:scale(1)}
.frame .cap{font-family:'Caveat',cursive;font-size:1.5rem;color:#3a2614;
  text-align:center;margin-top:14px;line-height:1.15}
.frame.soon{break-inside:avoid;padding:0;cursor:default;
  display:grid;place-items:center;min-height:300px;
  border:3px dashed #b59a68;background:rgba(233,220,187,.12)}
.frame.soon::after{display:none}
.frame.soon:hover{transform:rotate(.5deg);box-shadow:0 14px 30px rgba(0,0,0,.55)}
.frame.soon .ph{text-align:center;color:var(--cream-dim)}
.frame.soon .ph .pic{font-size:2.6rem;color:var(--brass)}
.frame.soon .ph p{font-family:'Caveat',cursive;font-size:1.5rem;margin-top:6px}

/* ---- lightbox / visor de imágenes ---- */
.lightbox{position:fixed;inset:0;z-index:200;
  display:flex;align-items:center;justify-content:center;
  background:rgba(10,7,4,.93);padding:40px 24px;
  opacity:0;visibility:hidden;transition:opacity .3s,visibility .3s;
  cursor:zoom-out}
.lightbox.open{opacity:1;visibility:visible}
.lb-figure{margin:0;max-width:1000px;max-height:100%;
  display:flex;flex-direction:column;align-items:center;gap:16px;
  cursor:default;transform:scale(.96);transition:transform .3s}
.lightbox.open .lb-figure{transform:scale(1)}
.lb-img{max-width:100%;max-height:80vh;display:block;
  border:8px solid #e9dcbb;
  box-shadow:0 24px 60px rgba(0,0,0,.8)}
.lb-cap{font-family:'Caveat',cursive;font-size:1.8rem;
  color:var(--cream);text-align:center}
.lb-close{position:absolute;top:20px;right:26px;
  width:48px;height:48px;border-radius:50%;
  background:rgba(233,220,187,.12);border:1.6px solid var(--brass);
  color:var(--cream);font-size:1.9rem;line-height:1;cursor:pointer;
  transition:.25s}
.lb-close:hover{background:var(--amber);color:var(--wood-deep);
  border-color:var(--amber)}

/* nota lateral / polaroid */
.polaroid{background:#ece0c4;padding:14px 14px 46px;width:256px;
  box-shadow:0 14px 30px rgba(0,0,0,.55);transform:rotate(3deg);
  float:right;margin:6px 0 22px 30px}
.polaroid .ph{height:316px;overflow:hidden;
  border:1px solid #c4b48c;background:#d6c8a4}
.polaroid .ph img{width:100%;height:100%;object-fit:cover;
  object-position:center 32%;display:block}
.polaroid .ph .pic{font-size:2.2rem}
.polaroid .cap{font-family:'Caveat',cursive;font-size:1.5rem;
  color:#3a2614;text-align:center;margin-top:14px;line-height:1.05}

/* lista de rasgos */
.traits{display:flex;flex-wrap:wrap;gap:10px;margin-top:10px}
.traits span{font-family:'IM Fell English SC',serif;font-size:.82rem;
  letter-spacing:.12em;text-transform:uppercase;
  padding:7px 15px;border:1px solid var(--brass);border-radius:2px;
  background:rgba(181,132,60,.07);color:var(--amber-bright)}

.bigquote{text-align:center;max-width:780px;margin:0 auto;
  font-family:'IM Fell English',serif;font-style:italic;
  font-size:1.7rem;line-height:1.5;color:var(--cream)}
.bigquote .by{display:block;margin-top:14px;font-family:'IM Fell English SC',serif;
  font-style:normal;font-size:.8rem;letter-spacing:.26em;
  text-transform:uppercase;color:var(--amber)}

/* ====================================================================
   FOOTER
   ==================================================================== */
.foot{background:linear-gradient(180deg,#0e2129,#0a1418);
  border-top:2px solid var(--brass);padding:54px 0 36px;text-align:center;
  margin-top:10px}
.foot .fcompass{width:64px;height:64px;margin:0 auto 16px;color:#5a4324}
.foot .fname{font-family:'IM Fell English SC',serif;font-size:1.5rem;
  letter-spacing:.14em;color:var(--amber-bright)}
.foot .fsub{font-family:'IM Fell English',serif;font-style:italic;
  color:var(--cream-dim);margin-top:4px}
.foot .fq{max-width:520px;margin:18px auto;font-style:italic;
  color:var(--cream-dim);font-size:1.02rem}
.foot .fmeta{font-size:.82rem;color:#6f6049;margin-top:18px;
  font-family:'IM Fell English SC',serif;letter-spacing:.1em}
.foot a{color:var(--amber)}

/* ====================================================================
   REVELADO AL SCROLL
   ==================================================================== */
.js .reveal{opacity:0;transform:translateY(26px);
  transition:opacity .8s ease,transform .8s ease}
.js .reveal.in{opacity:1;transform:none}

/* ====================================================================
   RESPONSIVE
   ==================================================================== */
@media(max-width:1024px){
  .hero{display:block;min-height:0;align-items:stretch;
    background:var(--wood-deep)}
  .hero::before{content:"";display:block;width:100%;padding-bottom:57.7%;
    background:url('../img/hero-banner.jpg') top center/contain no-repeat}
  .hero::after{display:none}
  .hero .hero-in{position:static;padding:32px 0 50px}
  .hero .tagline{text-shadow:none;font-size:1.45rem}
  .scrollcue{display:none}
}
@media(max-width:920px){
  .nav-toggle{display:block}
  .nav-links{position:absolute;top:100%;left:0;right:0;flex-direction:column;
    align-items:stretch;background:linear-gradient(180deg,#1c3e4a,#0e2129);
    padding:0 18px;gap:2px;
    max-height:0;overflow:hidden;border-bottom:0 solid var(--brass);
    transition:max-height .4s ease,padding .4s ease,border-width .4s ease}
  .nav-links.open{max-height:480px;padding:10px 18px 18px;
    border-bottom-width:2px}
  .nav-links a{padding:13px 10px;text-align:center;font-size:1rem}
  .nav-links a.active::after{display:none}
  .gates{grid-template-columns:1fr}
  .cat-index{grid-template-columns:repeat(2,1fr);gap:30px}
  .story-grid{grid-template-columns:repeat(2,1fr)}
  .tango-feat{grid-template-columns:1fr;gap:30px}
  .vinyl .sleeve{display:none}
  .disco-head{grid-template-columns:1fr;text-align:center}
  .disco-cover{max-width:280px;margin:0 auto}
  .lyrics{column-count:1}
  .ports{grid-template-columns:1fr}
  .gallery{column-count:2}
  .sheet{padding:62px 30px 44px}
}
@media(max-width:560px){
  body{font-size:18px}
  .story-grid{grid-template-columns:1fr}
  .cat-index{grid-template-columns:1fr}
  .gallery{column-count:1}
  .pad{padding:58px 0}
  .wrap{padding:0 20px}
  .polaroid{float:none;margin:18px auto}
  .hero .tagline{font-size:1.3rem}
  .prose>p:first-of-type::first-letter{font-size:3.2rem}
  .track-hd .tt{font-size:1.1rem}
  .story-nav{flex-direction:column}
  .story-nav .next{margin-left:0;text-align:left}
}
