/* =========================================================
   Premio Internacional Panameño de Literatura 2026
   Landing — Noche de Gala · v2 (pase de UI/UX editorial)
   Paleta: negro · oro · terciopelo. Tipo: Cinzel · Playfair · Cormorant.
   ========================================================= */

:root{
  /* Color */
  --bg:#0a0807;
  --bg-2:#0e0a09;
  --panel:#15100e;
  --panel-2:#1c1512;
  --gold:#d4af37;
  --gold-soft:#e8c869;
  --gold-deep:#b8860b;
  --champagne:#f3e3b3;
  --crimson:#9b1b1b;
  --crimson-2:#6e1212;
  --crimson-deep:#3d0a0a;
  --cream:#f3ecda;
  --text:#e7ddc7;
  --muted:#b09c79;
  --line:rgba(212,175,55,.22);
  --line-soft:rgba(212,175,55,.11);

  --foil:linear-gradient(177deg,#fcefb0 0%,#ecd07a 26%,#d4af37 52%,#b8860b 72%,#f4df95 100%);

  /* Tipografía */
  --f-display:'Cinzel', Georgia, 'Times New Roman', serif;   /* caps formales + micro-labels */
  --f-head:'Playfair Display', Georgia, serif;               /* titulares editoriales + números */
  --f-body:'Cormorant Garamond', Georgia, serif;             /* lectura */

  /* Layout */
  --maxw:1140px;
  --pad:clamp(20px,5vw,72px);
  --sec:clamp(64px,9vw,124px);

  /* z-index scale (10/20/30/40/50) */
  --z-base:1;
  --z-raised:10;
  --z-grain:40;
  --z-header:50;
  --z-skip:100;
}

*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  font-family:var(--f-body);
  background:var(--bg);
  color:var(--text);
  font-size:clamp(17px,1.05vw,19px);
  line-height:1.65;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
img,svg{display:block;max-width:100%}
a{color:inherit;text-decoration:none}

.wrap{max-width:var(--maxw);margin:0 auto;padding-left:var(--pad);padding-right:var(--pad);width:100%}
.narrow{max-width:760px}
.center{text-align:center}

/* Grano de película — mata el look "gradiente plano generado" */
.grain{
  position:fixed;inset:0;z-index:var(--z-grain);pointer-events:none;
  opacity:.05;mix-blend-mode:overlay;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='180' height='180'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}

/* Accesibilidad */
.skip-link{position:absolute;left:-999px;top:0;z-index:var(--z-skip);background:var(--gold);color:#1a1208;
  padding:10px 16px;border-radius:0 0 8px 0;font-family:var(--f-display);font-weight:600}
.skip-link:focus{left:0}
:focus-visible{outline:2px solid var(--gold-soft);outline-offset:3px;border-radius:4px}

.foil{background:var(--foil);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;color:transparent}

/* =========================================================
   HEADER
   ========================================================= */
.site-header{position:fixed;top:0;left:0;right:0;z-index:var(--z-header);
  background:rgba(10,8,7,.86);backdrop-filter:blur(10px);border-bottom:1px solid var(--line-soft);
  transform:translateY(-105%);transition:transform .45s cubic-bezier(.22,.61,.36,1)}
.site-header.visible{transform:translateY(0)}
.header-inner{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:12px 0}
.brand{display:flex;align-items:center;gap:12px}
.brand-mark{height:30px;width:auto;flex:none}
.brand-text{font-family:var(--f-display);font-size:11.5px;line-height:1.25;letter-spacing:1px;text-transform:uppercase;color:var(--muted)}
.brand-text b{color:var(--cream);font-weight:600}

/* =========================================================
   BOTONES
   ========================================================= */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:10px;cursor:pointer;
  font-family:var(--f-display);font-weight:600;letter-spacing:1.5px;text-transform:uppercase;font-size:13.5px;
  padding:15px 32px;border-radius:4px;background:var(--foil);color:#1c1407;
  border:1px solid rgba(255,240,190,.5);
  box-shadow:0 10px 30px rgba(184,134,11,.26), inset 0 1px 0 rgba(255,255,255,.5);
  transition:transform .25s ease, box-shadow .25s ease, filter .25s ease}
.btn:hover{transform:translateY(-2px);box-shadow:0 16px 40px rgba(184,134,11,.4), inset 0 1px 0 rgba(255,255,255,.6);filter:brightness(1.04)}
.btn:active{transform:translateY(0)}
.btn-lg{font-size:14.5px;padding:18px 44px}
.btn-sm{padding:9px 20px;font-size:12px}
.btn-ghost{background:transparent;color:var(--gold-soft);border:1px solid var(--line);box-shadow:none}
.btn-ghost:hover{background:rgba(212,175,55,.08);border-color:var(--gold);box-shadow:none}

/* =========================================================
   HERO
   ========================================================= */
.hero{position:relative;min-height:100svh;display:flex;flex-direction:column;justify-content:center;
  padding:118px 0 86px;text-align:center;overflow:hidden;
  background:
    radial-gradient(120% 70% at 50% -8%, rgba(212,175,55,.16), transparent 55%),
    radial-gradient(75% 60% at 2% 45%, rgba(123,18,18,.55), transparent 60%),
    radial-gradient(75% 60% at 98% 45%, rgba(123,18,18,.55), transparent 60%),
    radial-gradient(90% 90% at 50% 120%, rgba(61,10,10,.6), transparent 60%),
    linear-gradient(180deg,#0b0807 0%,#070504 100%)}
.hero-vignette{position:absolute;inset:0;pointer-events:none;
  background:radial-gradient(120% 80% at 50% 40%, transparent 55%, rgba(0,0,0,.55) 100%)}
.hero-inner{position:relative;z-index:var(--z-raised);display:flex;flex-direction:column;align-items:center}

.hero-logo{width:min(360px,80vw);margin:0 auto;padding:24px 30px;border-radius:22px;
  background:radial-gradient(120% 120% at 50% 22%, #fbf6ea, #efe3c8);
  border:1px solid rgba(212,175,55,.55);
  box-shadow:0 26px 64px rgba(0,0,0,.55), 0 0 0 6px rgba(212,175,55,.10), inset 0 1px 0 rgba(255,255,255,.85);
  animation:floaty 7s ease-in-out infinite}
.hero-logo img{width:100%;height:auto;display:block}
.emblem-sm{width:clamp(130px,18vw,180px);height:auto;margin:0 auto 6px;filter:drop-shadow(0 8px 22px rgba(184,134,11,.4))}
@keyframes floaty{0%,100%{transform:translateY(0)}50%{transform:translateY(-7px)}}

.kicker{font-family:var(--f-display);margin-top:22px;font-size:clamp(11px,1.4vw,13.5px);
  letter-spacing:clamp(2px,.5vw,5px);text-transform:uppercase;color:var(--muted)}

.hero-title{font-family:var(--f-display);font-weight:400;line-height:.98;margin-top:14px}
.hero-title .line-1{display:block;font-size:clamp(26px,4.4vw,46px);font-weight:500;color:var(--cream);letter-spacing:2px}
.hero-title .line-2{display:block;font-size:clamp(58px,13vw,150px);font-weight:700;letter-spacing:3px;margin-top:2px;
  filter:drop-shadow(0 4px 16px rgba(184,134,11,.35))}

.hero-sub{font-family:var(--f-display);font-weight:500;letter-spacing:2px;text-transform:uppercase;color:var(--cream);font-size:clamp(15px,2.5vw,27px);margin-top:16px}
.hero-sub strong{font-weight:600}
.hero-sub-gold{font-weight:700;font-size:clamp(18px,3.3vw,35px);margin-top:4px}
.hero-year{font-family:var(--f-head);font-weight:500;color:var(--muted);font-size:clamp(22px,4vw,40px);letter-spacing:10px;margin-top:8px;padding-left:10px}
.edition-badge{margin-top:24px;display:inline-block;font-family:var(--f-display);font-size:12.5px;letter-spacing:3px;text-transform:uppercase;
  color:var(--gold-soft);padding:8px 22px;border:1px solid var(--line);border-radius:100px;background:rgba(212,175,55,.05)}

.facts{list-style:none;display:flex;justify-content:center;flex-wrap:wrap;gap:clamp(20px,5vw,64px);margin:42px auto 0;max-width:820px}
.fact{flex:1 1 0;max-width:240px;display:flex;flex-direction:column;align-items:center;gap:6px;position:relative;padding:0 8px;text-align:center}
.fact + .fact::before{content:"";position:absolute;left:calc(-1 * clamp(10px,2.5vw,32px));top:10%;height:80%;width:1px;background:linear-gradient(180deg,transparent,var(--line),transparent)}
.fact-ico{width:26px;height:26px;color:var(--gold)}
.fact-label{font-family:var(--f-display);font-size:11px;letter-spacing:3px;text-transform:uppercase;color:var(--crimson);font-weight:600}
.fact-value{font-size:clamp(15px,1.5vw,18px);color:var(--cream);line-height:1.3}

.hero-cta{margin-top:40px;display:flex;flex-direction:column;align-items:center;gap:14px}
.cta-note{font-size:14px;color:var(--muted);font-style:italic;letter-spacing:.3px}

.scroll-hint{position:absolute;bottom:24px;left:50%;transform:translateX(-50%);z-index:var(--z-raised);
  width:24px;height:38px;border:1px solid var(--line);border-radius:14px;display:flex;justify-content:center;padding-top:7px}
.scroll-hint span{width:3px;height:8px;border-radius:3px;background:var(--gold);animation:scrolldot 1.9s ease-in-out infinite}
@keyframes scrolldot{0%{opacity:0;transform:translateY(-3px)}40%{opacity:1}80%,100%{opacity:0;transform:translateY(10px)}}

.spark{position:absolute;border-radius:50%;pointer-events:none;z-index:var(--z-base);filter:blur(2px)}
.spark.s1{width:6px;height:6px;top:22%;left:16%;background:#fff0c0;box-shadow:0 0 16px 5px rgba(255,231,160,.45);animation:twinkle 5s ease-in-out infinite}
.spark.s2{width:5px;height:5px;top:34%;right:18%;background:#fff0c0;box-shadow:0 0 14px 4px rgba(255,231,160,.4);animation:twinkle 6s ease-in-out 1s infinite}
@keyframes twinkle{0%,100%{opacity:.2;transform:scale(.8)}50%{opacity:.9;transform:scale(1.1)}}

/* =========================================================
   COUNTDOWN
   ========================================================= */
.countdown{position:relative;padding:clamp(34px,5vw,52px) 0;text-align:center;
  background:linear-gradient(180deg,#070504,#0c0807);border-top:1px solid var(--line-soft);border-bottom:1px solid var(--line-soft)}
.cd-kicker{font-family:var(--f-display);font-size:12px;letter-spacing:4px;text-transform:uppercase;color:var(--crimson);font-weight:600;margin-bottom:18px}
.cd-grid{display:flex;align-items:flex-start;justify-content:center;gap:clamp(8px,2.5vw,26px)}
.cd-cell{display:flex;flex-direction:column;align-items:center;min-width:clamp(56px,12vw,92px)}
.cd-num{font-family:var(--f-head);font-weight:600;font-size:clamp(38px,7vw,68px);line-height:1;color:var(--champagne);
  font-variant-numeric:tabular-nums;letter-spacing:1px;text-shadow:0 4px 18px rgba(184,134,11,.25)}
.cd-label{font-family:var(--f-display);font-size:clamp(9px,1.4vw,12px);letter-spacing:2.5px;text-transform:uppercase;color:var(--muted);margin-top:10px}
.cd-sep{font-family:var(--f-head);font-size:clamp(30px,6vw,56px);color:var(--gold-deep);line-height:1;margin-top:2px;opacity:.5}
.cd-when{font-size:clamp(15px,1.7vw,18px);color:var(--cream);font-style:italic;margin-top:22px}
.cd-grid.is-over + .cd-when,.cd-over{color:var(--gold-soft)}

/* =========================================================
   SECCIONES GENÉRICAS
   ========================================================= */
.section{padding:var(--sec) 0;position:relative}
.overline{font-family:var(--f-display);font-size:12px;letter-spacing:4px;text-transform:uppercase;color:var(--crimson);font-weight:600}
.overline.center{text-align:center}
.section-title{font-family:var(--f-head);font-weight:600;color:var(--cream);font-size:clamp(30px,5vw,54px);line-height:1.08;letter-spacing:.3px;margin:14px 0 26px}
.section-title.center{text-align:center}
.lead{font-size:clamp(18px,2.1vw,23px);color:var(--text);line-height:1.72;margin-bottom:22px;max-width:68ch}
.lead.center{margin-left:auto;margin-right:auto}
.lead strong{color:var(--gold-soft);font-weight:600}

.ornament{display:flex;align-items:center;gap:14px;color:var(--gold);font-size:12px;margin:10px 0 4px}
.ornament.center{justify-content:center}
.ornament span{height:1px;width:clamp(40px,12vw,90px);background:linear-gradient(90deg,transparent,var(--gold),transparent)}

/* ---- Sobre el evento (editorial 2-col) ---- */
.about{background:linear-gradient(180deg,#070504,#0c0807)}
.about-grid{display:grid;grid-template-columns:1.6fr .9fr;gap:clamp(28px,5vw,60px);align-items:start}
.about-main .section-title{margin-top:12px}
.lead.dropcap::first-letter{font-family:var(--f-head);font-weight:700;float:left;font-size:4.4em;line-height:.78;
  padding:6px 14px 0 0;color:transparent;background:var(--foil);-webkit-background-clip:text;background-clip:text}
.org-line{margin-top:8px;font-size:17px;color:var(--muted);font-style:italic}
.org-line strong{color:var(--gold-soft);font-style:normal;font-weight:600}
.about-aside{position:relative}
.pullquote{background:linear-gradient(160deg,var(--panel-2),var(--panel));border:1px solid var(--line);border-radius:14px;
  padding:clamp(26px,3vw,38px);position:relative;box-shadow:0 20px 50px rgba(0,0,0,.45)}
.pq-mark{height:34px;width:auto;margin-bottom:16px;opacity:.95}
.pullquote blockquote{font-family:var(--f-head);font-style:italic;font-weight:500;font-size:clamp(22px,2.5vw,28px);line-height:1.35;color:var(--cream)}
.pullquote figcaption{margin-top:18px;font-family:var(--f-display);font-size:11px;letter-spacing:2.5px;text-transform:uppercase;color:var(--gold-deep)}

/* ---- Homenajeado (editorial, con retrato) ---- */
.honoree{background:linear-gradient(180deg,#0c0807,#080605)}
.honoree-layout{display:grid;grid-template-columns:.85fr 1.15fr;gap:clamp(28px,5vw,58px);align-items:center;margin-top:36px}
.honoree-portrait{position:relative}
.honoree-portrait img,.portrait-crest{width:100%;aspect-ratio:4/5;border-radius:12px;border:1px solid var(--line);
  box-shadow:0 26px 60px rgba(0,0,0,.55)}
.honoree-portrait img{object-fit:cover}
.portrait-crest{display:flex;align-items:center;justify-content:center;padding:14px;
  background:radial-gradient(120% 100% at 50% 0%, rgba(155,27,27,.32), var(--panel) 70%)}
.portrait-crest svg{width:64%;height:auto;filter:drop-shadow(0 8px 22px rgba(184,134,11,.4))}
.honoree-portrait figcaption{margin-top:14px;text-align:center;font-family:var(--f-display);font-size:11px;letter-spacing:2.5px;text-transform:uppercase;color:var(--muted)}
.honoree-eyebrow{font-family:var(--f-display);font-size:11px;letter-spacing:3px;text-transform:uppercase;color:var(--crimson);font-weight:600}
.honoree-name{font-family:var(--f-head);font-weight:700;font-size:clamp(34px,5vw,56px);line-height:1.05;color:var(--cream);margin:10px 0 4px}
.honoree-role{font-family:var(--f-body);font-style:italic;font-size:clamp(17px,1.8vw,20px);color:var(--gold-soft);margin-bottom:20px}
.honoree-text .lead{font-size:clamp(17px,1.7vw,20px);margin-bottom:16px}
.honoree-works{margin-top:6px;font-style:italic;font-size:16px;color:var(--muted);line-height:1.5;
  border-top:1px solid var(--line-soft);padding-top:18px}
.honoree-works span{display:block;font-family:var(--f-display);font-style:normal;font-size:11px;letter-spacing:2.5px;
  text-transform:uppercase;color:var(--crimson);margin-bottom:6px}

/* ---- Categorías ---- */
.categories{background:linear-gradient(180deg,#080605,#0c0807)}
.cat-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(228px,1fr));gap:22px;margin-top:40px}
.cat-card{position:relative;background:linear-gradient(165deg,var(--panel-2),var(--panel));border:1px solid var(--line-soft);
  border-top:2px solid var(--crimson);border-radius:10px;padding:34px 28px;overflow:hidden;
  transition:transform .3s ease,border-color .3s ease,box-shadow .3s ease}
.cat-card::after{content:"";position:absolute;inset:0;background:radial-gradient(120% 80% at 50% 0%,rgba(212,175,55,.08),transparent 60%);opacity:0;transition:opacity .3s}
.cat-card:hover{transform:translateY(-6px);border-color:var(--line);box-shadow:0 20px 44px rgba(0,0,0,.5)}
.cat-card:hover::after{opacity:1}
.cat-num{font-family:var(--f-display);font-size:13px;letter-spacing:2px;color:var(--gold-deep)}
.cat-name{font-family:var(--f-head);font-weight:700;font-size:clamp(25px,3vw,33px);margin:8px 0 12px;color:var(--champagne);letter-spacing:.3px}
.cat-desc{font-size:17px;color:var(--muted);line-height:1.55}

/* ---- La experiencia ---- */
.experience{background:linear-gradient(180deg,#0c0807,#080605)}
.exp-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:20px;margin-top:42px}
.exp-card{background:linear-gradient(165deg,var(--panel-2),var(--panel));border:1px solid var(--line-soft);border-radius:12px;
  padding:30px 26px;text-align:left;transition:transform .3s ease,border-color .3s ease}
.exp-card:hover{transform:translateY(-5px);border-color:var(--line)}
.exp-ico{width:34px;height:34px;color:var(--gold);margin-bottom:16px}
.exp-title{font-family:var(--f-head);font-weight:600;font-size:22px;color:var(--cream);letter-spacing:.2px;margin-bottom:8px}
.exp-desc{font-size:17px;color:var(--muted);line-height:1.55}
.exp-desc strong{color:var(--gold-soft);font-weight:600}

/* ---- Agenda (timeline) ---- */
.agenda{background:linear-gradient(180deg,#080605,#0c0807)}
.timeline{list-style:none;margin:44px auto 0;max-width:640px;position:relative;padding-left:28px}
.timeline::before{content:"";position:absolute;left:6px;top:8px;bottom:8px;width:1px;background:linear-gradient(180deg,transparent,var(--line),var(--line),transparent)}
.tl-item{position:relative;padding:16px 0 16px 26px;display:flex;flex-wrap:wrap;align-items:baseline;gap:4px 18px;border-bottom:1px solid var(--line-soft)}
.tl-item:last-child{border-bottom:0}
.tl-item::before{content:"";position:absolute;left:-26px;top:24px;width:9px;height:9px;border-radius:50%;background:var(--gold-deep);border:1px solid var(--gold-soft);transform:translateX(1px)}
.tl-highlight::before{background:var(--crimson);border-color:#e88;box-shadow:0 0 0 4px rgba(155,27,27,.25)}
.tl-time{font-family:var(--f-display);font-weight:600;color:var(--gold-soft);font-size:15px;letter-spacing:1px;min-width:88px}
.tl-text{font-size:clamp(17px,1.7vw,19px);color:var(--cream)}
.tl-highlight .tl-text{color:#fff;font-weight:500}

/* ---- Galería (mosaico, fotos completas) ---- */
.gallery{background:linear-gradient(180deg,#0c0807,#080605)}
.gal-grid{columns:3 320px;column-gap:16px}
.gal-item{position:relative;break-inside:avoid;margin:0 0 16px;border-radius:12px;overflow:hidden;
  border:1px solid var(--line-soft);cursor:zoom-in;display:block}
.gal-item img{width:100%;height:auto;display:block;transition:transform .5s ease}
.gal-item:hover img{transform:scale(1.04)}
.gal-item figcaption{position:absolute;left:0;right:0;bottom:0;padding:34px 16px 13px;font-family:var(--f-display);
  font-size:11px;letter-spacing:2px;text-transform:uppercase;color:var(--cream);
  background:linear-gradient(180deg,transparent,rgba(0,0,0,.82))}

/* Lightbox (ver foto en grande al hacer clic) */
.lightbox{position:fixed;inset:0;z-index:90;display:none;align-items:center;justify-content:center;
  background:rgba(5,4,3,.93);backdrop-filter:blur(6px);padding:24px;cursor:zoom-out}
.lightbox.open{display:flex}
.lb-fig{margin:0;display:flex;flex-direction:column;align-items:center;gap:14px;max-width:min(1100px,94vw)}
.lb-fig img{max-width:100%;max-height:82vh;width:auto;height:auto;border-radius:8px;border:1px solid var(--line);box-shadow:0 30px 80px rgba(0,0,0,.7)}
.lb-fig figcaption{font-family:var(--f-display);font-size:12px;letter-spacing:2px;text-transform:uppercase;color:var(--gold-soft)}
.lb-close{position:fixed;top:14px;right:24px;z-index:2;background:none;border:0;color:var(--cream);font-size:40px;line-height:1;cursor:pointer}
.lb-close:hover{color:var(--gold-soft)}

/* ---- La invitación ---- */
.invitation{background:linear-gradient(180deg,#080605,#0c0807)}
.invite-frame{margin:42px auto 0;max-width:520px;border-radius:14px;overflow:hidden;border:1px solid var(--line);
  padding:10px;background:linear-gradient(160deg,rgba(212,175,55,.10),rgba(155,27,27,.06));box-shadow:0 28px 70px rgba(0,0,0,.6)}
.invite-frame img{width:100%;height:auto;border-radius:8px}
.invite-note{margin-top:28px;max-width:60ch;margin-left:auto;margin-right:auto}

/* ---- Detalles + mapa ---- */
.details{background:linear-gradient(180deg,#0c0807,#080605)}
.details-grid{display:grid;grid-template-columns:1fr 1fr;gap:36px;margin-top:44px;align-items:stretch}
.detail-info{display:flex;flex-direction:column;gap:4px;text-align:left}
.detail-row{display:flex;flex-direction:column;gap:3px;padding:18px 0;border-bottom:1px solid var(--line-soft)}
.detail-label{font-family:var(--f-display);font-size:11px;letter-spacing:3px;text-transform:uppercase;color:var(--crimson);font-weight:600}
.detail-text{font-size:clamp(18px,1.9vw,21px);color:var(--cream);line-height:1.4}
.detail-muted{color:var(--muted);font-size:.85em}
.detail-actions{display:flex;flex-wrap:wrap;gap:14px;margin-top:26px}
.detail-map{border-radius:12px;overflow:hidden;border:1px solid var(--line);min-height:320px;box-shadow:0 18px 40px rgba(0,0,0,.45)}
.detail-map iframe{width:100%;height:100%;min-height:320px;border:0;filter:grayscale(.3) contrast(1.05) brightness(.9)}

/* ---- CTA final ---- */
.final-cta{text-align:center;overflow:hidden;background:linear-gradient(180deg,#080605,#0b0706)}
.final-glow{position:absolute;inset:0;pointer-events:none;
  background:radial-gradient(60% 60% at 50% 30%,rgba(155,27,27,.35),transparent 60%),radial-gradient(50% 50% at 50% 60%,rgba(212,175,55,.12),transparent 60%)}
.final-cta .wrap{position:relative;z-index:var(--z-raised)}
.final-title{font-family:var(--f-head);font-weight:700;font-size:clamp(30px,5.4vw,58px);line-height:1.08;letter-spacing:.3px}
.final-sub{font-family:var(--f-body);font-size:clamp(19px,2.6vw,27px);color:var(--text);font-style:italic;margin-top:8px;margin-bottom:34px}
.share-wa{display:inline-flex;align-items:center;gap:9px;margin-top:22px;color:var(--muted);font-size:15px;letter-spacing:.3px;border-bottom:1px solid transparent;transition:color .25s,border-color .25s}
.share-wa:hover{color:var(--gold-soft);border-color:var(--line)}

/* ---- Footer ---- */
.site-footer{padding:60px 0;text-align:center;border-top:1px solid var(--line-soft);background:#070504}
.footer-mark{height:46px;width:auto;margin:0 auto 18px;opacity:.95}
.footer-quote{font-family:var(--f-head);font-style:italic;font-size:clamp(20px,2.6vw,27px);font-weight:500;letter-spacing:.3px}
.footer-name{font-family:var(--f-display);font-size:13.5px;letter-spacing:2px;text-transform:uppercase;color:var(--cream);margin-top:18px}
.footer-meta{font-size:14px;color:var(--muted);margin-top:6px;letter-spacing:1px}
.footer-org{font-size:13px;color:var(--muted);margin-top:14px;letter-spacing:.4px;opacity:.85}

/* =========================================================
   REVEAL ON SCROLL
   ========================================================= */
.reveal{opacity:0;transform:translateY(28px);transition:opacity .9s ease,transform .9s cubic-bezier(.22,.61,.36,1)}
.reveal.in{opacity:1;transform:none}

/* =========================================================
   RESPONSIVE
   ========================================================= */
@media (max-width:860px){
  .about-grid{grid-template-columns:1fr}
  .about-aside{max-width:560px}
  .honoree-layout{grid-template-columns:1fr;gap:26px}
  .honoree-portrait{max-width:340px;margin:0 auto}
  .honoree-text{text-align:left}
}
@media (max-width:760px){
  .details-grid{grid-template-columns:1fr}
  .detail-map{min-height:280px;order:-1}
  .fact + .fact::before{display:none}
  .facts{gap:26px}
  .cd-sep{display:none}
  .cd-grid{gap:14px}
}
@media (max-width:420px){
  .hero-title .line-2{letter-spacing:1px}
  .btn{letter-spacing:1px;padding:14px 24px}
}

/* =========================================================
   MOVIMIENTO REDUCIDO
   ========================================================= */
@media (prefers-reduced-motion:reduce){
  *,*::before,*::after{animation:none!important;transition:none!important;scroll-behavior:auto!important}
  .reveal{opacity:1;transform:none}
}
