/* ============================================================
   PELAYO — Web de autor · Tony de Haro
   Sistema visual "Papel y Oro viejo" (fondo claro)
   ============================================================ */

/* ---------- Tokens ---------- */
:root{
  /* Papel */
  --paper:#FBF8F1;          /* fondo principal, blanco cálido */
  --paper-2:#F4EEE0;        /* secciones / tarjetas alternas */
  --card:#FFFFFF;
  --line:#E4DCC8;           /* hairlines suaves */

  /* Tinta */
  --ink:#27241B;            /* texto principal, casi negro cálido */
  --ink-dim:#6E6857;        /* texto secundario */

  /* Oro viejo (más bronce, menos amarillo) */
  --gold:#9A7320;
  --gold-bright:#BE9036;
  --gold-deep:#6B4D14;

  /* Azul del escudo */
  --stone-blue:#274A72;
  --stone-blue-deep:#15304E;
  --bone:#ECE4D2;           /* texto claro sobre azul */
  --bone-dim:#b9b29c;

  /* Verde musgo (la piedra / el norte) */
  --moss:#42562C;
  --moss-deep:#2E3A24;
  --moss-bright:#5E7A38;

  /* Variables ajustables vía Tweaks */
  --gold-accent:var(--gold);
  --gold-glow:var(--gold-bright);
  --glow-strength:0.30;     /* halo cálido del fondo */
  --grain-opacity:0.045;    /* textura de papel */
  --reveal-shift:34px;
  --reveal-dur:1100ms;

  /* Tipografía */
  --font-display:"Cinzel", Georgia, serif;
  --font-script:"Cormorant Garamond", Georgia, serif;
  --font-body:"EB Garamond", Georgia, serif;

  --maxw:1180px;
  --pad:clamp(20px,5vw,72px);
}

*{box-sizing:border-box;}
html{scroll-behavior:smooth;}
@media (prefers-reduced-motion:reduce){html{scroll-behavior:auto;}}

body{
  margin:0;
  font-family:var(--font-body);
  color:var(--ink);
  background:var(--paper);
  font-size:clamp(17px,1.15vw,20px);
  line-height:1.72;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}

/* Papel + halo cálido: capa fija de fondo */
.backdrop{
  position:fixed;
  inset:0;
  z-index:-2;
  background:
    radial-gradient(120% 80% at 50% -8%,
        color-mix(in oklab, var(--gold) 14%, var(--paper)) 0%,
        var(--paper) 46%,
        var(--paper-2) 100%);
}
.backdrop::before{ /* halo dorado cálido superior */
  content:"";
  position:absolute;
  inset:0;
  background:radial-gradient(56% 36% at 50% 6%,
      color-mix(in oklab, var(--gold-glow) 46%, transparent) 0%,
      transparent 62%);
  opacity:var(--glow-strength);
  mix-blend-mode:multiply;
}
.backdrop::after{ /* grano de papel */
  content:"";
  position:absolute;
  inset:0;
  background-image:var(--grain-url);
  background-size:300px 300px;
  opacity:var(--grain-opacity);
  mix-blend-mode:multiply;
  pointer-events:none;
}

/* ---------- Tipografía base ---------- */
h1,h2,h3{font-family:var(--font-display);font-weight:700;margin:0;line-height:1.04;}
p{margin:0 0 1.1em;text-wrap:pretty;}
a{color:inherit;}

.kicker{
  font-family:var(--font-body);
  font-size:.82rem;
  letter-spacing:.42em;
  text-transform:uppercase;
  color:var(--gold-accent);
  font-weight:600;
  display:inline-flex;
  align-items:center;
  gap:.9em;
  margin:0 0 1.4rem;
}
/* Filete bicolor heráldico: verde musgo a la izquierda, azul escudo a la derecha */
.kicker::before,.kicker::after{
  content:"";
  width:clamp(18px,4vw,46px);
  height:1px;
}
.kicker::before{background:linear-gradient(90deg,transparent,var(--moss-bright));}
.kicker::after{background:linear-gradient(90deg,var(--stone-blue),transparent);}
.section--south .kicker::before{background:linear-gradient(90deg,transparent,var(--moss-bright));}
.section--south .kicker::after{background:linear-gradient(90deg,var(--gold-glow),transparent);}

.gold-text{
  background:linear-gradient(176deg,var(--gold-glow) 0%,var(--gold-accent) 50%,var(--gold-deep) 100%);
  -webkit-background-clip:text;background-clip:text;
  -webkit-text-fill-color:transparent;color:transparent;
}

.lede{
  font-family:var(--font-script);
  font-size:clamp(1.4rem,2.6vw,2.05rem);
  line-height:1.42;
  font-weight:500;
  color:var(--ink);
  font-style:italic;
}

/* ---------- Layout ---------- */
.section{position:relative;padding:clamp(80px,11vw,160px) var(--pad);}
.wrap{max-width:var(--maxw);margin:0 auto;}
.narrow{max-width:760px;}

.section-title{
  font-size:clamp(2.1rem,5.4vw,4rem);
  letter-spacing:.04em;
  text-transform:uppercase;
}

/* Sección de contraste "Sur" en azul del escudo, con destellos de verde musgo */
.section--south{
  position:relative;
  background:
    radial-gradient(60% 38% at 10% 6%, color-mix(in oklab,var(--moss) 60%, transparent) 0%, transparent 60%),
    radial-gradient(55% 40% at 94% 24%, color-mix(in oklab,var(--moss-deep) 75%, transparent) 0%, transparent 58%),
    radial-gradient(70% 50% at 84% 98%, color-mix(in oklab,var(--moss) 50%, transparent) 0%, transparent 60%),
    radial-gradient(50% 36% at 4% 88%, color-mix(in oklab,var(--moss-bright) 38%, transparent) 0%, transparent 60%),
    radial-gradient(120% 80% at 50% 0%, color-mix(in oklab,var(--stone-blue) 78%, var(--stone-blue-deep)) 0%, var(--stone-blue-deep) 72%);
  color:var(--bone);
  box-shadow:inset 0 1px 0 color-mix(in oklab,var(--gold) 40%,transparent), inset 0 -1px 0 color-mix(in oklab,var(--gold) 40%,transparent);
}
.section--south .lede{color:var(--bone);}

/* Separador heráldico (Cruz) — filete verde→cruz→azul */
.rule{display:flex;align-items:center;justify-content:center;gap:1.4rem;margin:0 auto;width:min(440px,72%);}
.rule .line{flex:1;height:1px;}
.rule .line:first-child{background:linear-gradient(90deg,transparent,color-mix(in oklab,var(--moss-bright) 80%,transparent));}
.rule .line:last-child{background:linear-gradient(90deg,color-mix(in oklab,var(--stone-blue) 85%,transparent),transparent);}
.rule .cross{width:30px;height:36px;opacity:.95;filter:drop-shadow(0 1px 2px rgba(120,90,20,.3));}

/* ---------- Navegación ---------- */
.nav{
  position:fixed;top:0;left:0;right:0;z-index:50;
  display:flex;align-items:center;justify-content:space-between;
  padding:18px var(--pad);
  transition:background .4s ease, padding .4s ease, box-shadow .4s ease;
}
.nav.scrolled{
  background:color-mix(in oklab,var(--paper) 86%, transparent);
  backdrop-filter:blur(12px) saturate(1.1);
  padding:12px var(--pad);
  box-shadow:0 1px 0 var(--line),0 10px 30px -18px rgba(60,45,15,.35);
}
.brand{display:flex;align-items:center;gap:.7rem;text-decoration:none;letter-spacing:.2em;}
.brand .cross{width:22px;height:27px;}
.brand .brand-name{font-family:var(--font-display);font-weight:700;font-size:1.05rem;color:var(--ink);letter-spacing:.22em;}
.nav-links{display:flex;gap:2rem;align-items:center;}
.nav-links a{
  text-decoration:none;color:var(--ink-dim);font-size:.86rem;letter-spacing:.14em;
  text-transform:uppercase;transition:color .25s;position:relative;white-space:nowrap;
}
.nav-links a:hover{color:var(--gold-accent);}
.nav-cta{
  font-family:var(--font-display);font-weight:600;font-size:.78rem;letter-spacing:.18em;text-transform:uppercase;
  color:#fff;background:linear-gradient(176deg,var(--gold-glow),var(--gold-accent) 60%,var(--gold-deep));
  padding:.7em 1.4em;border-radius:2px;text-decoration:none;
  box-shadow:0 2px 12px color-mix(in oklab,var(--gold-accent) 34%,transparent);
  transition:transform .25s, box-shadow .25s;
}
.nav-cta:hover{transform:translateY(-1px);box-shadow:0 6px 20px color-mix(in oklab,var(--gold-accent) 50%,transparent);}
.nav-toggle{display:none;background:none;border:0;color:var(--ink);cursor:pointer;}
@media (max-width:980px){
  .nav-links{
    position:fixed;inset:0 0 0 auto;width:min(78vw,320px);flex-direction:column;
    justify-content:center;gap:1.6rem;padding:3rem;
    background:color-mix(in oklab,var(--paper) 98%, white);
    transform:translateX(100%);transition:transform .4s cubic-bezier(.5,0,.2,1);
    border-left:1px solid var(--line);box-shadow:-20px 0 50px -20px rgba(60,45,15,.3);
  }
  .nav-links.open{transform:translateX(0);}
  .nav-links a{font-size:1rem;}
  .nav-toggle{display:block;}
}

/* ---------- Botones ---------- */
.btn{
  display:inline-flex;align-items:center;gap:.7em;cursor:pointer;text-decoration:none;white-space:nowrap;
  font-family:var(--font-display);font-weight:600;font-size:.86rem;letter-spacing:.16em;text-transform:uppercase;
  padding:1em 1.9em;border-radius:2px;transition:transform .25s,box-shadow .25s,background .25s,color .25s;
}
.btn-gold{
  color:#fff;
  background:linear-gradient(176deg,var(--gold-glow),var(--gold-accent) 60%,var(--gold-deep));
  box-shadow:0 3px 16px color-mix(in oklab,var(--gold-accent) 36%,transparent),inset 0 1px 0 rgba(255,255,255,.3);
}
.btn-gold:hover{transform:translateY(-2px);box-shadow:0 8px 26px color-mix(in oklab,var(--gold-accent) 52%,transparent),inset 0 1px 0 rgba(255,255,255,.45);}
.btn-ghost{
  color:var(--gold-deep);border:1px solid color-mix(in oklab,var(--gold-accent) 55%,transparent);background:transparent;
}
.btn-ghost:hover{color:var(--gold-deep);border-color:var(--gold-accent);background:color-mix(in oklab,var(--gold-accent) 9%,transparent);}
/* En la sección azul, los botones fantasma van claros */
.section--south .btn-ghost{color:var(--bone);border-color:color-mix(in oklab,var(--gold-glow) 60%,transparent);}
.section--south .btn-ghost:hover{color:#fff;border-color:var(--gold-glow);background:color-mix(in oklab,var(--gold-glow) 14%,transparent);}

/* ============================================================
   HERO
   ============================================================ */
.hero{
  position:relative;min-height:100svh;display:grid;align-items:center;
  padding:clamp(120px,16vh,180px) var(--pad) clamp(60px,9vh,110px);
  overflow:hidden;
}
.hero-grid{
  max-width:var(--maxw);margin:0 auto;width:100%;
  display:grid;grid-template-columns:minmax(0,1.05fr) minmax(0,.95fr);gap:clamp(32px,6vw,84px);align-items:center;
}
.hero-copy{min-width:0;}
.hero-eyebrow{margin-bottom:1.8rem;}
.hero-title{
  font-size:clamp(3.2rem,9vw,7.6rem);
  letter-spacing:.06em;line-height:.92;font-weight:900;
  margin:0 0 .15em;
  filter:drop-shadow(0 2px 1px rgba(150,110,30,.18));
}
.hero-sub{
  font-family:var(--font-script);font-style:italic;font-weight:500;
  font-size:clamp(1.35rem,3vw,2rem);color:var(--ink);letter-spacing:.02em;margin-bottom:.2rem;
}
.hero-sub .tag{
  display:block;font-family:var(--font-body);font-style:normal;
  font-size:.78rem;letter-spacing:.4em;text-transform:uppercase;color:var(--gold-accent);margin-top:1.1rem;font-weight:600;
}
.hero-claim{
  font-family:var(--font-script);font-style:italic;font-size:clamp(1.2rem,2vw,1.5rem);
  line-height:1.5;color:var(--ink-dim);max-width:42ch;margin:2rem 0 2.4rem;
}
.hero-cta{display:flex;gap:1rem;flex-wrap:wrap;}

/* Bloque de la cubierta — mockup del libro (imagen) */
.cover-stage{position:relative;display:flex;justify-content:center;align-items:center;min-height:clamp(440px,52vw,660px);padding-right:clamp(10px,2vw,28px);}
.book-mockup{
  width:clamp(280px,34vw,470px);
  transition:transform .8s cubic-bezier(.2,.7,.2,1);
  filter:drop-shadow(0 40px 38px rgba(40,30,10,.34));
  will-change:transform;
}
.book-mockup img{display:block;width:100%;height:auto;}
.cover-stage:hover .book-mockup{transform:translateY(-10px) rotate(-1deg);}
.scroll-hint{
  position:absolute;left:50%;bottom:26px;transform:translateX(-50%);
  display:flex;flex-direction:column;align-items:center;gap:.6rem;
  color:var(--ink-dim);font-size:.7rem;letter-spacing:.34em;text-transform:uppercase;
}
.scroll-hint .dot{width:1px;height:42px;background:linear-gradient(var(--gold-accent),transparent);animation:drip 2.4s ease-in-out infinite;}
@keyframes drip{0%,100%{opacity:.25;transform:scaleY(.6)}50%{opacity:1;transform:scaleY(1)}}

@media (max-width:1040px){
  .hero-grid{grid-template-columns:1fr;text-align:center;gap:54px;}
  .hero-eyebrow,.hero-claim{margin-left:auto;margin-right:auto;}
  .kicker{justify-content:center;}
  .hero-cta{justify-content:center;}
  .cover-stage{order:-1;min-height:clamp(420px,92vw,580px);padding-right:0;}
  .book-mockup{width:min(360px,82vw);}
}

/* ============================================================
   LA OBRA
   ============================================================ */
.obra-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(40px,6vw,90px);align-items:start;}
.obra-grid .synopsis p{margin-bottom:1.3em;}
.obra-grid .synopsis p:first-of-type::first-letter{
  font-family:var(--font-display);font-size:3.4em;line-height:.7;float:left;
  padding:.06em .12em 0 0;color:var(--gold-accent);font-weight:700;
}
.atmos{position:relative;}
.atmos-card{
  border:1px solid var(--line);
  border-left:3px solid var(--moss);
  background:var(--card);
  padding:clamp(28px,4vw,44px);border-radius:4px;position:sticky;top:110px;
  box-shadow:0 24px 50px -34px rgba(60,45,15,.4);
}
.atmos-card h3{font-size:1.05rem;letter-spacing:.16em;text-transform:uppercase;color:var(--gold-deep);margin-bottom:1.4rem;}
.atmos-card p{color:var(--ink-dim);}
.motifs{display:flex;flex-wrap:wrap;gap:.6rem;margin-top:.4rem;}
.motif{
  font-family:var(--font-script);font-style:italic;font-size:1.08rem;
  padding:.28em .85em;border-radius:2px;
  border:1px solid color-mix(in oklab,var(--gold-accent) 32%,var(--paper));
  background:color-mix(in oklab,var(--gold-accent) 8%,var(--paper));color:var(--gold-deep);
}
/* Rotación tricolor: oro · verde musgo · azul escudo */
.motif:nth-child(3n+2){border-color:color-mix(in oklab,var(--moss-bright) 42%,var(--paper));background:color-mix(in oklab,var(--moss) 9%,var(--paper));color:var(--moss-deep);}
.motif:nth-child(3n+3){border-color:color-mix(in oklab,var(--stone-blue) 40%,var(--paper));background:color-mix(in oklab,var(--stone-blue) 8%,var(--paper));color:var(--stone-blue);}
@media (max-width:780px){.obra-grid{grid-template-columns:1fr;}.atmos-card{position:relative;top:0;}}

/* ============================================================
   PERSONAJES
   ============================================================ */
.cast{display:grid;grid-template-columns:repeat(auto-fit,minmax(230px,1fr));gap:clamp(18px,2.4vw,30px);margin-top:clamp(40px,6vw,68px);}
.char{
  position:relative;padding:clamp(26px,3vw,38px) clamp(22px,2.6vw,30px);border-radius:4px;
  border:1px solid var(--line);
  border-top:3px solid var(--moss);
  background:var(--card);
  transition:transform .4s,border-color .4s,box-shadow .4s;overflow:hidden;
}
.char.enemy{border-top-color:var(--stone-blue);}
.char::before{content:"";position:absolute;inset:0;background:radial-gradient(80% 60% at 50% 0%,color-mix(in oklab,var(--gold-accent) 10%,transparent),transparent 70%);opacity:0;transition:opacity .4s;}
.char:hover{transform:translateY(-6px);border-color:color-mix(in oklab,var(--gold-accent) 50%,var(--line));box-shadow:0 26px 50px -30px rgba(60,45,15,.5);}
.char.enemy:hover{border-color:color-mix(in oklab,var(--stone-blue) 50%,var(--line));}
.char.enemy:hover{border-top-color:var(--stone-blue);}
.char:hover::before{opacity:1;}
.char .glyph{width:38px;height:46px;margin-bottom:1.1rem;opacity:1;}
.char h3{font-size:1.5rem;letter-spacing:.04em;margin-bottom:.2rem;color:var(--ink);}
.char .role{font-family:var(--font-body);font-size:.74rem;letter-spacing:.26em;text-transform:uppercase;color:var(--moss-deep);margin-bottom:1rem;font-weight:600;}
.char p{font-size:.96rem;color:var(--ink-dim);margin:0;line-height:1.6;}
.char.enemy .role{color:var(--stone-blue);}
.char.enemy .glyph [fill]{}

/* ============================================================
   ARCO NARRATIVO (timeline) — dentro de sección azul
   ============================================================ */
.arc{position:relative;margin-top:clamp(48px,7vw,80px);}
.arc-line{position:absolute;left:max(18px,calc(50% - 1px));top:0;bottom:0;width:2px;
  background:linear-gradient(var(--moss-bright),var(--gold-glow),var(--moss-bright));opacity:.7;}
.arc-step{position:relative;display:grid;grid-template-columns:1fr 1fr;gap:clamp(30px,5vw,80px);margin-bottom:clamp(40px,6vw,72px);}
.arc-step .node{
  position:absolute;left:50%;top:6px;transform:translateX(-50%);
  width:46px;height:46px;display:grid;place-items:center;border-radius:50%;
  background:radial-gradient(circle at 40% 35%,var(--gold-glow),var(--gold-deep));
  color:#fff;font-family:var(--font-display);font-weight:700;font-size:1.05rem;
  box-shadow:0 0 0 6px var(--stone-blue-deep),0 0 22px color-mix(in oklab,var(--gold-glow) 55%,transparent);z-index:2;
}
.arc-step .panel h3{font-size:1.55rem;margin-bottom:.5rem;color:#fff;}
.arc-step .panel .where{font-family:var(--font-body);font-size:.74rem;letter-spacing:.24em;text-transform:uppercase;color:var(--gold-glow);margin-bottom:.7rem;font-weight:600;}
.arc-step .panel p{color:var(--bone);font-size:.98rem;margin:0;opacity:.88;}
.arc-step:nth-child(odd) .panel{grid-column:1;text-align:right;}
.arc-step:nth-child(odd) .spacer{grid-column:2;}
.arc-step:nth-child(even) .panel{grid-column:2;}
.arc-step:nth-child(even) .spacer{grid-column:1;}
@media (max-width:780px){
  .arc-line{left:22px;}
  .arc-step{grid-template-columns:1fr;padding-left:64px;gap:0;}
  .arc-step .node{left:22px;}
  .arc-step .panel,.arc-step:nth-child(odd) .panel{grid-column:1;text-align:left;}
  .arc-step .spacer{display:none;}
}

/* ============================================================
   FRAGMENTO
   ============================================================ */
.fragment{position:relative;}
.fragment .wrap{max-width:880px;}
.fragment .frame{
  position:relative;padding:clamp(36px,6vw,80px) clamp(26px,6vw,90px);
  border:1px solid color-mix(in oklab,var(--gold-accent) 30%,var(--line));border-radius:4px;
  background:linear-gradient(180deg,var(--card),var(--paper-2));
  box-shadow:0 30px 60px -40px rgba(60,45,15,.5);
}
.fragment .frame .corner{position:absolute;width:32px;height:40px;opacity:1;}
.fragment .frame .corner.tl{top:-15px;left:-12px;}
.fragment .frame .corner.br{bottom:-15px;right:-12px;transform:rotate(180deg);}
.fragment .chapter{font-family:var(--font-body);font-size:.76rem;letter-spacing:.3em;text-transform:uppercase;color:var(--gold-deep);text-align:center;margin-bottom:1.6rem;font-weight:600;}
.fragment blockquote{margin:0;font-family:var(--font-script);font-size:clamp(1.3rem,2.5vw,1.85rem);line-height:1.5;font-style:italic;color:var(--ink);}
.fragment blockquote p{margin-bottom:1em;}
.fragment .snow{color:var(--gold-deep);font-style:italic;font-weight:600;}
.fragment .attrib{margin-top:2rem;text-align:center;font-family:var(--font-display);font-size:.82rem;letter-spacing:.2em;text-transform:uppercase;color:var(--ink-dim);}

/* ============================================================
   AUTOR
   ============================================================ */
.author-grid{display:grid;grid-template-columns:.85fr 1.15fr;gap:clamp(36px,6vw,80px);align-items:center;}
.author-portrait{position:relative;}
.author-portrait img{
  width:100%;border-radius:4px;display:block;
  box-shadow:0 30px 60px -32px rgba(60,45,15,.5),0 0 0 1px color-mix(in oklab,var(--gold-accent) 30%,transparent);
  filter:saturate(.98) contrast(1.02);
}
.author-portrait .plate{
  position:absolute;left:50%;bottom:-22px;transform:translateX(-50%);
  background:linear-gradient(176deg,var(--gold-glow),var(--gold-accent) 60%,var(--gold-deep));color:#fff;
  font-family:var(--font-display);font-weight:700;letter-spacing:.12em;font-size:.82rem;text-transform:uppercase;
  padding:.55em 1.4em;border-radius:2px;white-space:nowrap;box-shadow:0 8px 20px -6px rgba(60,45,15,.5);
}
.author-body p{margin-bottom:1.15em;color:var(--ink-dim);}
.author-body .sign{
  font-family:var(--font-script);font-style:italic;font-size:1.7rem;color:var(--gold-deep);margin-top:.6rem;
}
.facts{display:flex;gap:clamp(20px,4vw,48px);flex-wrap:wrap;margin-top:2.2rem;padding-top:1.8rem;
  border-top:2px solid;border-image:linear-gradient(90deg,var(--moss),var(--gold),var(--stone-blue)) 1;}
.fact .n{font-family:var(--font-display);font-weight:700;font-size:1.9rem;color:var(--gold-deep);line-height:1;}
.fact:nth-child(1) .n{color:var(--moss-deep);}
.fact:nth-child(3) .n{color:var(--stone-blue);}
.fact .l{font-size:.74rem;letter-spacing:.18em;text-transform:uppercase;color:var(--ink-dim);margin-top:.4rem;}
@media (max-width:820px){.author-grid{grid-template-columns:1fr;}.author-portrait{max-width:380px;margin:0 auto;}}

/* Reliquias del linaje (sello + talla) */
.relics{margin-top:clamp(52px,8vw,90px);}
.relics-head{text-align:center;max-width:640px;margin:0 auto clamp(28px,4vw,46px);}
.relics-head h3{font-family:var(--font-display);font-weight:700;text-transform:uppercase;font-size:clamp(1.5rem,3.4vw,2.2rem);letter-spacing:.04em;margin:.4rem 0 .8rem;}
.relics-head p{color:var(--ink-dim);font-family:var(--font-script);font-style:italic;font-size:1.15rem;margin:0;}
.relics-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:clamp(22px,4vw,48px);max-width:800px;margin:0 auto;}
.relic{margin:0;}
.relic-img{
  position:relative;border-radius:4px;overflow:hidden;
  display:grid;place-items:center;padding:clamp(14px,2vw,22px);
  background:radial-gradient(120% 100% at 50% 0%, color-mix(in oklab,var(--stone-blue) 30%, var(--moss-deep)) 0%, #0e1310 75%);
  border:1px solid color-mix(in oklab,var(--gold-accent) 42%,transparent);
  box-shadow:0 26px 50px -30px rgba(60,45,15,.6), inset 0 0 0 4px color-mix(in oklab,var(--gold-accent) 13%, transparent);
}
.relic-img img{display:block;width:100%;height:clamp(290px,40vw,440px);object-fit:contain;filter:saturate(.97) contrast(1.04);transition:transform .6s cubic-bezier(.2,.7,.2,1);}
.relic:hover .relic-img img{transform:scale(1.045);}
.relic figcaption{margin-top:1.1rem;font-family:var(--font-body);font-size:.92rem;line-height:1.55;color:var(--ink-dim);text-align:center;}
@media (max-width:680px){.relics-grid{grid-template-columns:1fr;max-width:440px;}}

/* ============================================================
   CONTACTO / EDITORIAL
   ============================================================ */
.cta-band{text-align:center;}
.cta-band .section-title{margin-bottom:1.2rem;}
.cta-band .lede{max-width:620px;margin:0 auto 2.6rem;color:var(--ink-dim);}
.cta-actions{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap;}

.footer{
  position:relative;
  padding:clamp(48px,7vw,80px) var(--pad) clamp(36px,5vw,56px);
  border-top:3px solid;border-image:linear-gradient(90deg,var(--moss),var(--gold),var(--stone-blue)) 1;
  color:var(--bone);
  background:
    radial-gradient(55% 60% at 6% 0%, color-mix(in oklab,var(--moss) 60%, transparent) 0%, transparent 60%),
    radial-gradient(55% 70% at 96% 30%, color-mix(in oklab,var(--moss-deep) 70%, transparent) 0%, transparent 58%),
    radial-gradient(60% 80% at 80% 110%, color-mix(in oklab,var(--moss) 48%, transparent) 0%, transparent 60%),
    radial-gradient(120% 100% at 50% 0%, color-mix(in oklab,var(--stone-blue) 72%, var(--stone-blue-deep)) 0%, var(--stone-blue-deep) 78%);
}
.footer .wrap{display:flex;justify-content:space-between;align-items:center;gap:2rem;flex-wrap:wrap;}
.footer .brand .brand-name{font-size:1.2rem;color:var(--bone);}
.footer .meta{font-size:.82rem;color:var(--bone-dim);line-height:1.6;}
.footer .meta a{color:var(--gold-glow);text-decoration:none;}
.footer .meta a:hover{text-decoration:underline;}
.footer .editorial{text-align:right;font-size:.82rem;color:var(--bone-dim);}
@media (max-width:680px){.footer .wrap{flex-direction:column;text-align:center;}.footer .editorial{text-align:center;}}

/* ---------- Reveal on scroll ---------- */
.has-js .reveal{opacity:0;}
.has-js .reveal.in{animation:revealUp var(--reveal-dur) cubic-bezier(.2,.7,.2,1) both;}
@keyframes revealUp{
  from{opacity:0;transform:translateY(var(--reveal-shift));}
  to{opacity:1;transform:none;}
}
.has-js .reveal.in.d1{animation-delay:.12s;}
.has-js .reveal.in.d2{animation-delay:.24s;}
.has-js .reveal.in.d3{animation-delay:.36s;}
.has-js .reveal.shown{opacity:1 !important;transform:none !important;animation:none !important;}
@media (prefers-reduced-motion:reduce){.has-js .reveal,.has-js .reveal.in{opacity:1;animation:none;}}

/* No-motion tweak */
body.no-motion .reveal,body.no-motion .reveal.in{opacity:1 !important;transform:none !important;animation:none !important;}
body.no-motion .scroll-hint .dot{animation:none;}
