/* =========================================================
   Mayor Bryan Calvo — Official Site
   Shared design system
   ========================================================= */

@import url('https://fonts.googleapis.com/css2?family=Playfair+Display:ital,wght@0,400;0,500;0,600;0,700;0,800;0,900;1,500;1,600&family=Montserrat:wght@300;400;500;600;700&family=Great+Vibes&display=swap');

:root{
  /* Brand palette */
  --navy:        #001F44;
  --navy-700:    #0A2E5C;
  --navy-600:    #143C73;
  --navy-500:    #1d4d8c;
  --gold:        #C9A227;
  --gold-bright: #D4AF37;
  --gold-soft:   #e7cf86;
  --cream:       #F6F3EC;
  --paper:       #FAFAFA;
  --white:       #ffffff;
  --ink:         #001F44;
  --ink-soft:    #2a3f5f;
  --muted:       #5b6b82;
  --line:        rgba(0,31,68,.12);
  --line-gold:   rgba(201,162,39,.55);

  /* Type */
  --display: "Playfair Display", Georgia, serif;
  --body: "Montserrat", system-ui, -apple-system, "Segoe UI", sans-serif;
  --script: "Great Vibes", cursive;

  /* Layout */
  --container: 1200px;
  --gutter: clamp(20px, 5vw, 64px);
  --radius: 4px;
  --header-h: 78px;

  --shadow-sm: 0 2px 10px rgba(0,31,68,.06);
  --shadow-md: 0 14px 40px rgba(0,31,68,.12);
  --shadow-lg: 0 30px 80px rgba(0,31,68,.22);
}

*{ box-sizing: border-box; }

/* ---- Mobile overflow guard ----
   Prevents any accidental horizontal scroll on phones, especially once the
   placeholder blocks are swapped for real photos / the seal PNG. `clip` keeps
   position:sticky working (unlike overflow:hidden). */
html, body{ max-width: 100%; overflow-x: clip; }
/* Long words, emails and URLs must wrap instead of pushing the layout wide */
body{ overflow-wrap: break-word; word-break: break-word; }
/* Flex/grid children are allowed to shrink below their content size */
.nav, .hero__inner, .message__grid, .bio-grid, .seal-meaning__grid,
.contact-grid, .footer-top, .stat, .card, .init, .issue,
.hero__content, .hero__actions, .signup, .info-row, .meaning{ min-width: 0; }

html{ scroll-behavior: smooth; }

body{
  margin: 0;
  font-family: var(--body);
  color: var(--ink);
  background: var(--paper);
  font-size: 17px;
  line-height: 1.7;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}

/* Any swapped-in real image keeps its aspect ratio and never overflows.
   (Scoped to img/video so the seal & wave SVGs keep their own sizing.) */
img, video{ display:block; max-width:100%; height:auto; }
svg{ max-width:100%; }

a{ color: inherit; text-decoration: none; }

h1,h2,h3,h4{ font-family: var(--display); font-weight: 700; line-height: 1.08; margin: 0; }

p{ margin: 0 0 1.1em; }

::selection{ background: var(--gold); color: var(--navy); }

/* ---------- Layout helpers ---------- */
.container{
  width: 100%;
  max-width: var(--container);
  margin-inline: auto;
  padding-inline: var(--gutter);
}
.section{ padding-block: clamp(64px, 9vw, 128px); }
.section--tight{ padding-block: clamp(48px, 6vw, 88px); }
.center{ text-align: center; }

/* ---------- Eyebrow / script labels ---------- */
.eyebrow{
  font-family: var(--body);
  font-weight: 600;
  font-size: 13px;
  letter-spacing: .26em;
  text-transform: uppercase;
  color: var(--gold);
  margin: 0 0 14px;
  display:flex; align-items:center; gap:14px;
}
.eyebrow--center{ justify-content:center; }
.eyebrow::before, .eyebrow--center::after{
  content:""; height:1px; width:34px; background: var(--line-gold);
}
.eyebrow:not(.eyebrow--center)::after{ display:none; }

.script{
  font-family: var(--script);
  color: var(--gold);
  font-weight: 400;
  line-height: .9;
}

/* gold rule under headings */
.rule-gold{
  width: 64px; height: 3px; background: var(--gold);
  border: 0; margin: 22px 0 0; border-radius: 2px;
}
.center .rule-gold{ margin-inline:auto; }

/* ---------- Headings scale ---------- */
.display-xl{ font-size: clamp(40px, 6.4vw, 86px); letter-spacing: -.01em; }
.display-lg{ font-size: clamp(34px, 4.6vw, 62px); }
.display-md{ font-size: clamp(28px, 3.4vw, 44px); }
.lead{ font-size: clamp(18px, 1.5vw, 22px); color: var(--ink-soft); line-height: 1.65; }

/* ===========================================================
   Buttons
   =========================================================== */
.btn{
  --bg: var(--gold);
  --fg: var(--navy);
  display: inline-flex; align-items:center; gap:10px;
  font-family: var(--body); font-weight: 600; font-size: 14px;
  letter-spacing: .06em; text-transform: uppercase;
  padding: 15px 28px;
  background: var(--bg); color: var(--fg);
  border: 1.5px solid var(--bg);
  border-radius: 2px;
  cursor: pointer;
  transition: transform .25s ease, box-shadow .25s ease, background .25s ease, color .25s ease, border-color .25s ease;
  will-change: transform;
}
.btn:hover{ transform: translateY(-2px); box-shadow: 0 12px 26px rgba(201,162,39,.32); }
.btn .arrow{ transition: transform .25s ease; }
.btn:hover .arrow{ transform: translateX(4px); }

.btn--ghost{
  --bg: transparent; --fg: #fff;
  border-color: rgba(255,255,255,.55);
}
.btn--ghost:hover{ background: rgba(255,255,255,.08); box-shadow:none; border-color:#fff; }

.btn--navy{ --bg: var(--navy); --fg: #fff; border-color: var(--navy); }
.btn--navy:hover{ box-shadow: var(--shadow-md); }

.btn--outline-navy{
  --bg: transparent; --fg: var(--navy);
  border-color: var(--line);
}
.btn--outline-navy:hover{ border-color: var(--navy); background: var(--navy); color:#fff; box-shadow:none; }

/* ===========================================================
   Header / Nav
   =========================================================== */
.site-header{
  position: sticky; top: 0; z-index: 60;
  background: var(--navy);
  color: #fff;
  border-bottom: 1px solid rgba(201,162,39,.28);
}
.nav{
  height: var(--header-h);
  display: flex; align-items: center; gap: 26px;
}
.brand{
  display:flex; align-items:center; gap: 14px;
  margin-right: auto;
}
.brand .seal{ flex: none; }
.brand-text{ display:flex; flex-direction:column; line-height:1; }
.brand-name{
  font-family: var(--display); font-weight: 700; font-size: 18px; letter-spacing:.01em;
  white-space: nowrap;
}
.brand-role{
  font-size: 10.5px; letter-spacing: .22em; text-transform: uppercase;
  color: var(--gold-soft); margin-top: 5px; font-weight:500;
}

.nav-links{
  display:flex; align-items:center; gap: 4px;
  list-style:none; margin:0; padding:0;
}
.nav-links a{
  display:block; padding: 10px 14px;
  font-size: 13.5px; font-weight: 500; letter-spacing:.04em;
  color: rgba(255,255,255,.86);
  position: relative;
  transition: color .2s ease;
}
.nav-links a::after{
  content:""; position:absolute; left:14px; right:14px; bottom:4px; height:2px;
  background: var(--gold); transform: scaleX(0); transform-origin:left;
  transition: transform .28s ease;
}
.nav-links a:hover{ color:#fff; }
.nav-links a:hover::after, .nav-links a[aria-current="page"]::after{ transform: scaleX(1); }
.nav-links a[aria-current="page"]{ color:#fff; }

.nav-cta{ margin-left: 8px; }
.nav-cta .btn{ padding: 12px 22px; font-size: 12.5px; }

.nav-toggle{
  display:none; background:none; border:0; cursor:pointer;
  width:44px; height:44px; padding:0; color:#fff;
  flex-direction:column; gap:5px; align-items:center; justify-content:center;
}
.nav-toggle span{ width:24px; height:2px; background:#fff; transition: .3s; }
.nav-toggle[aria-expanded="true"] span:nth-child(1){ transform: translateY(7px) rotate(45deg); }
.nav-toggle[aria-expanded="true"] span:nth-child(2){ opacity:0; }
.nav-toggle[aria-expanded="true"] span:nth-child(3){ transform: translateY(-7px) rotate(-45deg); }

@media (max-width: 920px){
  /* row-gap:0 evita que el gap base de 26px añada espacio bajo el brand
     entre las filas colapsadas del menú; column-gap mantiene la separación
     horizontal brand ↔ toggle. */
  .nav{ flex-wrap: wrap; height: auto; row-gap: 0; column-gap: 26px; }
  .brand{ height: var(--header-h); }
  .nav-toggle{ display:flex; z-index: 2; }

  .nav-links, .nav-cta{
    flex: 0 0 100%;
    flex-direction: column; align-items: stretch;
    background: var(--navy-700);
    padding: 0 var(--gutter);
    gap: 0;
    /* reset del margin-left:8px base que descuadraba la columna del botón */
    margin-left: 0;
    max-height: 0; overflow: hidden; opacity:0; pointer-events:none;
    transition: max-height .35s ease, opacity .25s ease, padding .2s ease;
  }
  .nav[data-open="true"] .nav-links{
    max-height: 60vh; opacity:1; pointer-events:auto;
    padding: 8px var(--gutter) 0;
  }
  .nav[data-open="true"] .nav-cta{
    max-height: 120px; opacity:1; pointer-events:auto;
    padding: 14px var(--gutter) 18px;
    border-bottom: 1px solid rgba(201,162,39,.28);
  }
  /* padding lateral 0 → el texto de los links arranca en el mismo borde
     (gutter) que el botón full-width, quedando alineados verticalmente. */
  .nav-links a{ padding: 14px 0; font-size: 16px; border-bottom: 1px solid rgba(255,255,255,.08); }
  .nav-links a::after{ display:none; }
  .nav-cta .btn{ width:100%; justify-content:center; }
}

/* ===========================================================
   Seal (real PNG injected by JS)
   =========================================================== */
.seal{ display:inline-flex; align-items:center; justify-content:center; }
.seal img{ display:block; }

/* ===========================================================
   Wave dividers
   =========================================================== */
.wave{ display:block; width:100%; height: auto; }
.wave-top{ margin-bottom:-1px; }
.wave-bottom{ margin-top:-1px; }

/* ===========================================================
   Image placeholders
   =========================================================== */
.ph{
  position: relative;
  background:
    repeating-linear-gradient(135deg,
      rgba(0,31,68,.05) 0 14px,
      rgba(0,31,68,.025) 14px 28px);
  border: 1px solid var(--line);
  display:flex; align-items:center; justify-content:center;
  overflow:hidden;
  color: var(--muted);
}
.ph::after{
  content: attr(data-label);
  font-family: ui-monospace, "SF Mono", Menlo, monospace;
  font-size: 11px; letter-spacing:.04em; line-height:1.5;
  text-transform: uppercase;
  text-align:center; max-width: 80%;
  padding: 8px 12px;
  background: rgba(250,250,250,.82);
  border: 1px dashed var(--line-gold);
  border-radius: 3px;
  color: var(--navy-600);
}
.ph--navy{
  background:
    repeating-linear-gradient(135deg,
      rgba(255,255,255,.06) 0 14px,
      rgba(255,255,255,.02) 14px 28px),
    var(--navy);
  border-color: rgba(201,162,39,.3);
}
.ph--navy::after{ background: rgba(10,46,92,.75); color: var(--gold-soft); border-color: var(--line-gold); }

/* ===========================================================
   HERO (home)
   =========================================================== */
.hero{
  position: relative;
  background:
    radial-gradient(120% 100% at 80% 0%, var(--navy-600) 0%, var(--navy-700) 38%, var(--navy) 78%);
  color:#fff;
  overflow: hidden;
}
/* Hero con foto de fondo (arquitectura de Hialeah + Mayor a la derecha) */
.hero--photo{
  background:
    linear-gradient(90deg, rgba(0,18,42,.92) 0%, rgba(0,18,42,.6) 34%, rgba(0,18,42,.18) 56%, rgba(0,18,42,0) 80%),
    url("../images/hero-bg-mayor.jpg") center right / cover no-repeat;
}
.hero__waves{ position:absolute; inset:0; pointer-events:none; opacity:.6; }
.hero__inner{
  position: relative;
  display:grid; grid-template-columns: 1.05fr .95fr; gap: clamp(32px,4vw,72px);
  align-items: center;
  padding-block: clamp(56px, 8vw, 104px);
}
.hero--photo .hero__inner{
  grid-template-columns: minmax(0, 600px);
  min-height: clamp(460px, 60vw, 660px);
}
/* oculto en desktop (el Mayor ya está en la imagen de fondo); se muestra en móvil */
.hero__mayor{ display:none; }
.hero__heading{ display:flex; align-items:center; gap: clamp(14px,1.8vw,26px); }
.hero__heading .seal{ flex:none; margin:0 !important; }
.hero__titles{ min-width:0; }
.hero h1{
  font-size: clamp(34px, 4.8vw, 64px);
  line-height: 1.05; letter-spacing: -.015em; margin: 0;
  /* el nombre nunca debe partirse a mitad de palabra (override del guard global) */
  word-break: normal; overflow-wrap: normal; hyphens: none;
}
.hero__role{
  font-family: var(--body); font-weight: 500;
  font-size: clamp(15px,1.4vw,18px); letter-spacing:.22em; text-transform: uppercase;
  color: var(--gold-soft); margin: 16px 0 0;
}
.hero__actions{ display:flex; gap:16px; flex-wrap:wrap; margin-top: clamp(30px,3.4vw,42px); }

.hero__portrait{
  position: relative; aspect-ratio: 4/5; border-radius: 6px;
  box-shadow: var(--shadow-lg);
}
.hero__portrait .ph{ position:absolute; inset:0; border-radius:6px; }
.hero__portrait::after{
  content:""; position:absolute; inset:-1px; border-radius:7px;
  border:1px solid rgba(201,162,39,.5); pointer-events:none;
}

@media (max-width: 880px){
  .hero__inner{ grid-template-columns: 1fr; text-align:center; }
  /* en móvil el sello va ARRIBA del nombre (centrado), no al lado: la columna
     es muy angosta para sello + título de 2 líneas */
  .hero__heading{ flex-direction: column; align-items: center; gap: 18px; }
  .hero__actions{ justify-content:center; }
  .hero__portrait{ max-width: 380px; margin-inline:auto; order:-1; }
  /* en móvil el fondo cambia al de SOLO arquitectura (sin el Mayor) y se
     oscurece, para que el texto centrado no se encime con su figura */
  .hero--photo{
    background:
      linear-gradient(rgba(0,18,42,.74), rgba(0,18,42,.88)),
      url("../images/hero-bg.jpg") center / cover no-repeat;
  }
  .hero--photo .hero__inner{ grid-template-columns: 1fr; min-height: auto; }
  /* el Mayor recortado aparece en móvil debajo de los botones, fundiéndose
     con el fondo navy (en desktop ya está en la imagen de fondo) */
  .hero__mayor{ display:block; width: min(72%, 300px); height:auto; margin: 30px auto -8px; }
}
@media (max-width: 560px){
  .hero__heading{ gap:14px; }
  .hero__heading .seal img{ width:88px !important; height:88px !important; }
}

/* ===========================================================
   Message block
   =========================================================== */
.message{ background: var(--cream); position:relative; }
.message__grid{
  display:grid; grid-template-columns: auto 1fr; gap: clamp(28px,4vw,60px); align-items:start;
}
.message__seal{ position: sticky; top: calc(var(--header-h) + 30px); }
.message blockquote{
  margin:0; font-family: var(--display); font-style: normal;
  font-size: clamp(20px, 2vw, 28px); line-height: 1.5; color: var(--navy);
}
.message blockquote p{ margin-bottom:.8em; }
.message strong{ color: var(--gold); font-weight:700; }
.message__sign{
  font-family: var(--script); font-size: 42px; color: var(--navy);
  margin-top: 18px; line-height:1;
}
.message__sign-img{
  display:block; width: 280px; max-width: 80%; height:auto;
  margin: 20px 0 0;
}
@media (max-width:760px){
  .message__grid{ grid-template-columns:1fr; }
  .message__seal{ position:static; text-align:center; }
  .message__seal .seal{ display:inline-block !important; width:auto !important; margin:0 !important; }
}

/* ===========================================================
   Stat grid
   =========================================================== */
.stats{ background: var(--navy); color:#fff; position:relative; }
.stat-grid{
  display:grid; grid-template-columns: repeat(4, 1fr); gap: 1px;
  background: rgba(201,162,39,.22);
  border: 1px solid rgba(201,162,39,.22);
}
.stat-grid--3{ grid-template-columns: repeat(3,1fr); }
.stat{
  background: var(--navy);
  padding: clamp(26px,3vw,40px) clamp(20px,2.4vw,30px);
  transition: background .3s ease;
}
.stat:hover{ background: var(--navy-700); }
.stat__num{
  font-family: var(--display); font-weight: 800;
  font-size: clamp(38px, 4.4vw, 60px); color: var(--gold);
  line-height: 1; letter-spacing: -.01em;
}
.stat__num .unit{ font-size: .5em; color: var(--gold-soft); }
.stat__label{
  font-size: 13.5px; line-height:1.5; color: rgba(255,255,255,.82);
  margin-top: 14px; font-weight: 500;
}
.stat__note{ font-size: 11.5px; color: var(--gold-soft); margin-top:8px; letter-spacing:.02em; }
@media (max-width: 900px){ .stat-grid, .stat-grid--3{ grid-template-columns: repeat(2,1fr); } }
@media (max-width: 520px){ .stat-grid, .stat-grid--3{ grid-template-columns: 1fr; } }

/* ===========================================================
   Cards — delivering / initiatives / newsletters
   =========================================================== */
.cards{ display:grid; gap: 28px; }
.cards--4{ grid-template-columns: repeat(4,1fr); }
.cards--3{ grid-template-columns: repeat(3,1fr); }
.cards--2{ grid-template-columns: repeat(2,1fr); }
@media (max-width: 1000px){ .cards--4{ grid-template-columns: repeat(2,1fr); } .cards--3{ grid-template-columns: repeat(2,1fr);} }
@media (max-width: 640px){ .cards--4,.cards--3,.cards--2{ grid-template-columns: 1fr; } }

.card{
  background:#fff; border:1px solid var(--line); border-radius: var(--radius);
  overflow:hidden; box-shadow: var(--shadow-sm);
  transition: transform .3s ease, box-shadow .3s ease, border-color .3s ease;
  display:flex; flex-direction:column;
}
.card:hover{ transform: translateY(-4px); box-shadow: var(--shadow-md); border-color: var(--line-gold); }
.card__media{ aspect-ratio: 16/10; overflow:hidden; position:relative; }
/* Garantiza que cualquier img dentro de card__media llene el contenedor
   exactamente, sea la foto horizontal o vertical */
.card__media img{
  position:absolute; inset:0;
  width:100% !important; height:100% !important;
  object-fit:cover !important; display:block;
}
.card__body{ padding: 24px 26px 28px; flex:1; display:flex; flex-direction:column; }
.card__kicker{
  font-size: 11px; letter-spacing:.18em; text-transform:uppercase; font-weight:600;
  color: var(--gold); margin-bottom: 10px;
}
.card__title{ font-size: 22px; margin-bottom: 10px; color: var(--navy); }
.card__text{ font-size: 14.5px; color: var(--muted); margin:0; }
.card__more{
  margin-top: 16px; font-size: 13px; font-weight:600; letter-spacing:.06em; text-transform:uppercase;
  color: var(--navy); display:inline-flex; gap:8px; align-items:center;
}
.card__more .arrow{ transition: transform .25s ease; color: var(--gold); }
.card:hover .card__more .arrow{ transform: translateX(4px); }

/* numbered initiative card (no image) */
.init{
  background:#fff; border:1px solid var(--line); border-radius: var(--radius);
  padding: 28px 28px 30px; box-shadow: var(--shadow-sm);
  border-top: 3px solid var(--gold);
  transition: transform .3s ease, box-shadow .3s ease;
}
.init:hover{ transform: translateY(-3px); box-shadow: var(--shadow-md); }
.init__title{ font-size: 20px; color: var(--navy); margin-bottom: 10px; }
.init__text{ font-size: 14px; color: var(--muted); margin:0; }

/* ===========================================================
   Pillars strip
   =========================================================== */
.pillars-strip{ display:grid; grid-template-columns: repeat(3,1fr); gap: 1px; background: var(--line); }
.pillar{
  background:#fff; padding: clamp(28px,3vw,44px);
  text-align:center;
}
.pillar__word{ font-family: var(--display); font-size: 30px; color: var(--navy); }
.pillar__word .dot{ color: var(--gold); }
.pillar__text{ font-size: 14px; color: var(--muted); margin: 12px 0 0; }
@media (max-width:760px){ .pillars-strip{ grid-template-columns:1fr; } }

/* ===========================================================
   Guiding Principles (bilingual)
   =========================================================== */
.principles{ background:#fff; }
.principles__head{ text-align:center; max-width:760px; margin:0 auto; }
.principles__head h2{ margin:0; }
.principles__sub{
  font-family: var(--display); font-style:italic;
  color: var(--muted); font-size: clamp(16px,1.7vw,21px);
  margin: 8px 0 0;
}
.principles__list{ max-width: 780px; margin: clamp(34px,4vw,52px) auto 0; }
.principle{
  display:flex; align-items:flex-start; gap: clamp(18px,2.5vw,30px);
  padding: clamp(20px,2.4vw,28px) 0;
  border-bottom: 1px solid var(--line-gold);
}
.principle:first-child{ border-top: 1px solid var(--line-gold); }
.principle__num{
  flex:none; width: 1.5em; text-align:center;
  font-family: var(--display); font-weight:800; line-height:1;
  font-size: clamp(36px,4.6vw,58px); color: var(--gold);
}
.principle__body{ min-width:0; padding-top: .25em; }
.principle__en{
  font-size: clamp(17px,1.9vw,21px); color: var(--navy); line-height:1.4;
}
.principle__en b{ font-weight:700; letter-spacing:.015em; }
.principle__es{
  font-family: var(--display); font-style:italic; color: var(--muted);
  font-size: clamp(14px,1.5vw,17px); line-height:1.45; margin-top: 6px;
}
.principle__es b{ font-style:normal; font-weight:600; color: var(--ink-soft); }
@media (max-width:520px){
  .principle{ gap:14px; }
  .principle__num{ font-size: 34px; width:1.3em; }
}

/* ===========================================================
   Highlight feature band (image + text)
   =========================================================== */
.highlight{ background: var(--cream); }
.highlight__inner{
  display:grid; grid-template-columns: 1.05fr .95fr;
  gap: clamp(28px,4vw,60px); align-items:center;
}
.highlight__media{
  position:relative; border-radius: var(--radius); overflow:hidden;
  aspect-ratio: 16/10; box-shadow: var(--shadow-md);
}
.highlight__media::after{
  content:""; position:absolute; inset:0; border-radius: var(--radius);
  border:1px solid rgba(201,162,39,.45); pointer-events:none;
}
.highlight__media img{
  position:absolute; inset:0; width:100%; height:100%;
  object-fit:cover; display:block;
}
.highlight__body{ min-width:0; }
.highlight__body h2{ margin: 10px 0 0; }
.highlight__body .lead{ margin-top: 16px; }
@media (max-width: 820px){
  .highlight__inner{ grid-template-columns: 1fr; }
  .highlight__media{ order:-1; max-width: 560px; margin-inline:auto; width:100%; }
}

/* ===========================================================
   Newsletter / Stay connected CTA band
   =========================================================== */
.cta-band{
  background: linear-gradient(115deg, var(--navy) 0%, var(--navy-600) 100%);
  color:#fff; position:relative; overflow:hidden;
}
.cta-band__inner{ position:relative; text-align:center; max-width: 720px; margin-inline:auto; }
.signup{
  display:flex; gap:12px; max-width: 520px; margin: 30px auto 0; flex-wrap:wrap;
}
.signup input{
  flex:1; min-width: 220px;
  padding: 15px 18px; border-radius:2px; border:1px solid rgba(255,255,255,.3);
  background: rgba(255,255,255,.08); color:#fff; font-family:var(--body); font-size:15px;
}
.signup input::placeholder{ color: rgba(255,255,255,.6); }
.signup input:focus{ outline:none; border-color: var(--gold); background: rgba(255,255,255,.14); }

.socials{ display:flex; gap:14px; justify-content:center; margin-top: 26px; }
.socials a{
  width:42px; height:42px; border-radius:50%;
  border:1px solid rgba(255,255,255,.3);
  display:flex; align-items:center; justify-content:center;
  transition: .25s ease; color:#fff;
}
.socials a:hover{ background: var(--gold); border-color: var(--gold); color: var(--navy); transform: translateY(-3px); }
.socials svg{ width:18px; height:18px; fill: currentColor; }

/* ===========================================================
   Section header
   =========================================================== */
.section-head{ max-width: 720px; margin-bottom: clamp(36px,4vw,56px); }
.section-head.center{ margin-inline:auto; }

/* ===========================================================
   Page hero (interior pages)
   =========================================================== */
.page-hero{
  background: radial-gradient(110% 120% at 85% -10%, var(--navy-600), var(--navy) 70%);
  color:#fff; position:relative; overflow:hidden;
}
.page-hero__inner{ position:relative; padding-block: clamp(56px,7vw,96px); }
.page-hero h1{ font-size: clamp(38px,5.2vw,68px); }
.page-hero .lead{ color: rgba(255,255,255,.82); max-width: 620px; }
.breadcrumb{ font-size:12px; letter-spacing:.16em; text-transform:uppercase; color: var(--gold-soft); margin-bottom:18px; }
.breadcrumb a{ color: var(--gold-soft); }
.breadcrumb a:hover{ color:#fff; }

/* ===========================================================
   About
   =========================================================== */
.bio-grid{ display:grid; grid-template-columns: .85fr 1.15fr; gap: clamp(32px,4vw,64px); align-items:start; }
.bio-portrait{ position: sticky; top: calc(var(--header-h) + 30px); }
.bio-portrait .ph{ aspect-ratio: 4/5; border-radius:6px; }
.bio-portrait__cap{ font-size:12px; color:var(--muted); margin-top:12px; letter-spacing:.02em; }
.bio-body p{ font-size: 17px; color: var(--ink-soft); }
.bio-body p:first-of-type::first-letter{
  font-family: var(--display); font-size: 64px; float:left; line-height:.8;
  padding: 6px 12px 0 0; color: var(--gold); font-weight:700;
}
@media (max-width: 860px){ .bio-grid{ grid-template-columns:1fr; } .bio-portrait{ position:static; max-width:380px; } }

/* Seal meaning panel */
.seal-meaning{ background: var(--navy); color:#fff; }
.seal-meaning__grid{ display:grid; grid-template-columns: auto 1fr; gap: clamp(32px,4vw,64px); align-items:start; }
.seal-meaning__seal{ position:sticky; top: calc(var(--header-h)+30px); display:flex; justify-content:center; }
.meaning-list{ display:grid; gap: 0; }
.meaning{
  display:grid; grid-template-columns: 200px 1fr; gap: 24px;
  padding: 24px 0; border-top: 1px solid rgba(201,162,39,.22);
}
.meaning:last-child{ border-bottom: 1px solid rgba(201,162,39,.22); }
.meaning__name{ font-family: var(--display); font-size: 20px; color: var(--gold); }
.meaning__sub{ font-size: 11px; letter-spacing:.14em; text-transform:uppercase; color: var(--gold-soft); margin-top:6px; display:block; }
.meaning__text{ font-size: 14.5px; color: rgba(255,255,255,.82); margin:0; }
@media (max-width: 860px){
  .seal-meaning__grid{ grid-template-columns:1fr; }
  .seal-meaning__seal{ position:static; }
  .meaning{ grid-template-columns:1fr; gap: 6px; }
}

/* ===========================================================
   Newsletters
   =========================================================== */
.issue{ background:#fff; border:1px solid var(--line); border-radius:var(--radius); overflow:hidden; box-shadow:var(--shadow-sm);
  transition: transform .3s ease, box-shadow .3s ease; display:flex; flex-direction:column; }
.issue:hover{ transform: translateY(-5px); box-shadow: var(--shadow-md); }
[data-pdf]{ cursor: pointer; }
.issue__cover{ aspect-ratio: 3/4; position:relative; }
.issue__cover .badge{
  position:absolute; top:14px; left:14px; z-index:2;
  background: var(--gold); color: var(--navy); font-weight:700; font-size:11px;
  letter-spacing:.1em; text-transform:uppercase; padding:6px 12px; border-radius:2px;
}
.issue__body{ padding: 22px 24px 26px; }
.issue__month{ font-size:12px; letter-spacing:.16em; text-transform:uppercase; color:var(--gold); font-weight:600; }
.issue__title{ font-size: 22px; color:var(--navy); margin:8px 0 16px; }

/* ===========================================================
   PDF Reader Modal
   =========================================================== */
.pdf-modal{
  display: none;
  position: fixed; inset: 0; z-index: 9000;
  background: rgba(0,15,35,.78);
  backdrop-filter: blur(4px);
  -webkit-backdrop-filter: blur(4px);
  align-items: stretch;
  justify-content: center;
  flex-direction: column;
}
.pdf-modal[data-open="true"]{ display: flex; }

.pdf-modal__panel{
  display: flex; flex-direction: column;
  width: 100%; height: 100%;
  max-width: 960px;
  margin: auto;
  border-radius: 0;
  overflow: hidden;
  box-shadow: var(--shadow-lg);
}
@media (min-width: 700px){
  .pdf-modal__panel{
    height: 92vh; max-height: 960px;
    border-radius: 8px;
    margin: auto;
    width: calc(100% - 40px);
  }
}

/* Header bar */
.pdf-modal__head{
  flex: none;
  display: flex; align-items: center; gap: 14px;
  padding: 0 20px;
  height: 60px;
  background: var(--navy);
  border-bottom: 2px solid var(--gold);
}
.pdf-modal__icon{
  flex: none;
  width: 34px; height: 34px;
  background: rgba(201,162,39,.15);
  border: 1px solid rgba(201,162,39,.4);
  border-radius: 4px;
  display: flex; align-items: center; justify-content: center;
}
.pdf-modal__icon svg{ width:16px; height:16px; fill:var(--gold); }
.pdf-modal__meta{ flex: 1; min-width: 0; }
.pdf-modal__month{
  font-size: 10px; letter-spacing: .18em; text-transform: uppercase;
  color: var(--gold-soft); font-weight: 600; line-height: 1;
}
.pdf-modal__title{
  font-size: 14px; font-weight: 700; color: #fff;
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
  margin-top: 3px;
}
.pdf-modal__actions{ display:flex; gap:8px; flex:none; }
.pdf-modal__dl{
  display: flex; align-items: center; gap: 6px;
  padding: 7px 14px; border-radius: 3px;
  background: rgba(201,162,39,.18); border: 1px solid rgba(201,162,39,.45);
  color: var(--gold-soft); font-size: 12px; font-weight: 600;
  letter-spacing: .06em; text-decoration: none;
  transition: background .2s;
}
.pdf-modal__dl:hover{ background: rgba(201,162,39,.32); color: #fff; }
.pdf-modal__dl svg{ width:13px; height:13px; fill:currentColor; }
.pdf-modal__close{
  flex: none; background: none; border: none; cursor: pointer;
  width: 36px; height: 36px; display: flex; align-items: center; justify-content: center;
  color: rgba(255,255,255,.6); border-radius: 4px;
  transition: background .2s, color .2s;
}
.pdf-modal__close:hover{ background: rgba(255,255,255,.1); color: #fff; }
.pdf-modal__close svg{ width: 18px; height: 18px; fill: none; stroke: currentColor; stroke-width: 2.2; }

/* Iframe body */
.pdf-modal__body{
  flex: 1;
  background: #525659;
  overflow: hidden;
}
.pdf-modal__body iframe{
  display: block;
  width: 100%; height: 100%;
  border: none;
}

/* ===========================================================
   Contact
   =========================================================== */
.contact-grid{ display:grid; grid-template-columns: 1fr 1fr; gap: clamp(32px,4vw,64px); align-items:start; }
@media (max-width: 820px){ .contact-grid{ grid-template-columns:1fr; } }
.info-row{ display:flex; gap:16px; padding: 18px 0; border-bottom:1px solid var(--line); align-items:flex-start; }
.info-row:first-child{ border-top:1px solid var(--line); }
.info-row__icon{ flex:none; width:42px; height:42px; border-radius:50%; background: var(--cream); border:1px solid var(--line-gold);
  display:flex; align-items:center; justify-content:center; color: var(--gold); }
.info-row__icon svg{ width:18px; height:18px; fill:none; stroke: currentColor; stroke-width:1.7; }
.info-row__label{ font-size:11px; letter-spacing:.16em; text-transform:uppercase; color: var(--muted); }
.info-row__value{ font-size: 17px; color: var(--navy); font-weight:500; }
.info-row__value a:hover{ color: var(--gold); }

.form{ background: var(--cream); border:1px solid var(--line); border-radius: var(--radius); padding: clamp(28px,3vw,40px); }
.field{ margin-bottom: 18px; }
.field label{ display:block; font-size:12px; letter-spacing:.1em; text-transform:uppercase; font-weight:600; color: var(--navy); margin-bottom: 8px; }
.field input, .field textarea{
  width:100%; padding: 13px 15px; border:1px solid var(--line); border-radius:2px;
  font-family: var(--body); font-size: 15px; color: var(--navy); background:#fff;
  transition: border-color .2s ease, box-shadow .2s ease;
}
.field input:focus, .field textarea:focus{ outline:none; border-color: var(--gold); box-shadow: 0 0 0 3px rgba(201,162,39,.14); }
.field textarea{ min-height: 130px; resize: vertical; }
.field--ok input, .field--ok textarea{ border-color: #2e8b57; }
.field--err input, .field--err textarea{ border-color: #c0392b; }
.field__hint{ font-size:12px; color:#c0392b; margin-top:6px; display:none; }
.field--err .field__hint{ display:block; }
.form__success{
  display:none; background: var(--navy); color:#fff; padding: 16px 18px; border-radius:2px;
  font-size:14px; margin-bottom: 18px; border-left: 3px solid var(--gold);
}
.form__success.show{ display:block; }

/* ===========================================================
   Legal pages
   =========================================================== */
.legal{ max-width: 800px; margin-inline:auto; }
.legal h2{ font-size: 28px; color: var(--navy); margin: 36px 0 14px; }
.legal h3{ font-size: 19px; color: var(--navy); margin: 26px 0 10px; font-family: var(--display); }
.legal p, .legal li{ font-size: 16px; color: var(--ink-soft); line-height:1.75; }
.legal ul{ padding-left: 20px; }
.legal .meta{ font-size:13px; color: var(--muted); letter-spacing:.04em; }
.legal a{ color: var(--navy); text-decoration: underline; text-decoration-color: var(--line-gold); text-underline-offset: 3px; }
.legal a:hover{ color: var(--gold); }
.callout{
  background: var(--cream); border-left: 3px solid var(--gold); padding: 20px 24px;
  border-radius: 0 3px 3px 0; margin: 22px 0; font-size: 15.5px;
}

/* ===========================================================
   Footer
   =========================================================== */
.site-footer{ background: var(--navy); color: rgba(255,255,255,.72); position:relative; }
.footer-top{
  display:grid; grid-template-columns: 1.4fr 1fr 1fr; gap: clamp(28px,4vw,56px);
  padding-block: clamp(48px,5vw,72px);
}
.footer-brand .seal{ margin: 0 0 18px !important; }
.footer-brand .fname{ font-family: var(--display); font-size: 22px; color:#fff; }
.footer-brand .frole{ font-size: 12px; letter-spacing:.18em; text-transform:uppercase; color: var(--gold-soft); margin-top:6px; }
.footer-brand p{ font-size: 13.5px; margin-top: 16px; max-width: 320px; }
.footer-col h4{ font-family: var(--body); font-size: 12px; letter-spacing:.18em; text-transform:uppercase; color: var(--gold); margin-bottom: 18px; font-weight:600; }
.footer-col ul{ list-style:none; margin:0; padding:0; display:grid; gap: 11px; }
.footer-col a{ font-size: 14px; color: rgba(255,255,255,.74); transition: color .2s ease; }
.footer-col a:hover{ color: var(--gold); }
.footer-bottom{
  border-top: 1px solid rgba(201,162,39,.2);
  padding-block: 22px;
  display:flex; justify-content:space-between; align-items:center; gap: 16px; flex-wrap:wrap;
  font-size: 12.5px; color: rgba(255,255,255,.55);
}
.footer-bottom .legal-links{ display:flex; gap: 22px; flex-wrap:wrap; }
.footer-bottom a:hover{ color: var(--gold); }
@media (max-width: 760px){ .footer-top{ grid-template-columns: 1fr; } }

/* ===========================================================
   Scroll reveal
   =========================================================== */
.reveal{ opacity:0; transform: translateY(24px); transition: opacity .7s ease, transform .7s ease; }
.reveal.in{ opacity:1; transform: none; }
.reveal[data-d="1"]{ transition-delay: .08s; }
.reveal[data-d="2"]{ transition-delay: .16s; }
.reveal[data-d="3"]{ transition-delay: .24s; }
.reveal[data-d="4"]{ transition-delay: .32s; }
@media (prefers-reduced-motion: reduce){
  .reveal{ opacity:1; transform:none; transition:none; }
  html{ scroll-behavior:auto; }
}

/* ===========================================================
   Preloader / Loading screen
   =========================================================== */
#preloader{
  position: fixed; inset: 0; z-index: 99999;
  display: flex; align-items: center; justify-content: center;
  background: radial-gradient(120% 100% at 50% 0%, var(--navy-600) 0%, var(--navy-700) 42%, var(--navy) 86%);
  transition: opacity .55s ease, visibility .55s ease;
  /* salvaguarda CSS pura: si el JS falla o está cacheado viejo, el loader
     igual desaparece a los ~6s (nunca se queda pegado) */
  animation: preloaderFailsafe .6s ease 6s forwards;
}
#preloader.is-hidden{ opacity: 0; visibility: hidden; pointer-events: none; }
@keyframes preloaderFailsafe{ to{ opacity: 0; visibility: hidden; pointer-events: none; } }
.preloader__inner{ text-align: center; padding: 24px; }
.preloader__seal{
  display:block; margin: 0 auto 24px; width: 116px; height: 116px;
  filter: drop-shadow(0 10px 30px rgba(0,0,0,.35));
  animation: preloaderSeal .9s cubic-bezier(.2,.7,.2,1) both;
}
.preloader__name{
  font-family: var(--display); font-weight: 700; color:#fff;
  font-size: clamp(24px,4vw,32px); letter-spacing:.01em; line-height:1.1;
  animation: preloaderFade .7s ease .15s both;
}
.preloader__role{
  font-size: 11px; letter-spacing:.3em; text-transform:uppercase;
  color: var(--gold-soft); margin-top: 10px;
  animation: preloaderFade .7s ease .28s both;
}
.preloader__bar{
  width: 150px; height: 2px; margin: 28px auto 0;
  background: rgba(201,162,39,.22); border-radius: 2px; overflow: hidden;
}
.preloader__bar span{
  display:block; height:100%; width: 40%; border-radius:2px;
  background: linear-gradient(90deg, transparent, var(--gold), transparent);
  animation: preloaderBar 1.15s ease-in-out infinite;
}
@keyframes preloaderSeal{ from{ opacity:0; transform: scale(.88); } to{ opacity:1; transform:none; } }
@keyframes preloaderFade{ from{ opacity:0; transform: translateY(8px); } to{ opacity:1; transform:none; } }
@keyframes preloaderBar{ 0%{ transform: translateX(-130%); } 100%{ transform: translateX(380%); } }
@media (prefers-reduced-motion: reduce){
  .preloader__seal, .preloader__name, .preloader__role{ animation: none; }
  .preloader__bar span{ animation: none; width: 100%; }
}
