:root {
  --black: #050505;
  --charcoal: #101113;
  --charcoal-2: #17191d;
  --gold: #cfa445;
  --gold-soft: #e5c979;
  --warm: #f7f2e8;
  --muted: #bdb6aa;
  --line: rgba(207, 164, 69, .28);
  --shadow: 0 24px 70px rgba(0, 0, 0, .46);
  --serif: "Cormorant Garamond", "Playfair Display", Georgia, "Times New Roman", serif;
  --sans: Inter, Montserrat, "Avenir Next", "Helvetica Neue", Arial, sans-serif;
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  margin: 0;
  font-family: var(--sans);
  color: var(--warm);
  background:
    radial-gradient(circle at 20% 10%, rgba(207, 164, 69, .12), transparent 28rem),
    linear-gradient(180deg, #050505 0%, #0a0b0d 42%, #050505 100%);
  line-height: 1.6;
}
img { max-width: 100%; display: block; }
a { color: inherit; text-decoration: none; }
.skip-link { position: absolute; left: -999px; top: 1rem; background: var(--gold); color: #111; padding: .75rem 1rem; z-index: 100; }
.skip-link:focus { left: 1rem; }

.container { width: min(1160px, calc(100% - 40px)); margin: 0 auto; }
.site-header { position: fixed; inset: 0 0 auto 0; z-index: 20; transition: background .25s ease, border-color .25s ease; border-bottom: 1px solid transparent; }
.site-header.scrolled { background: rgba(5, 5, 5, .82); backdrop-filter: blur(18px); border-color: rgba(207, 164, 69, .16); }
.nav { width: min(1240px, calc(100% - 32px)); margin: 0 auto; height: 86px; display: flex; align-items: center; justify-content: space-between; }
.brand img { width: 138px; height: auto; }
.nav-links { display: flex; align-items: center; gap: 1.6rem; color: rgba(247, 242, 232, .82); font-size: .88rem; letter-spacing: .04em; }
.nav-links a { transition: color .2s ease; }
.nav-links a:hover { color: var(--gold-soft); }
.nav-cta { border: 1px solid var(--line); padding: .75rem 1rem; border-radius: 999px; }
.nav-toggle { display: none; background: none; color: var(--warm); border: 1px solid var(--line); border-radius: 999px; padding: .6rem .9rem; }

.hero { position: relative; min-height: 100vh; display: grid; align-items: center; overflow: hidden; }
.hero-bg { position: absolute; inset: 0; background: url('assets/images/hero-gala.jpg') center/cover no-repeat; transform: scale(1.03); filter: saturate(.88) contrast(1.08); }
.hero-overlay { position: absolute; inset: 0; background: linear-gradient(90deg, rgba(0,0,0,.92) 0%, rgba(0,0,0,.72) 45%, rgba(0,0,0,.34) 100%), radial-gradient(circle at 20% 45%, rgba(207, 164, 69, .18), transparent 24rem); }
.hero::after { content: ""; position: absolute; inset: auto 0 0 0; height: 170px; background: linear-gradient(0deg, var(--black), transparent); }
.hero-grid { position: relative; z-index: 1; padding-top: 7rem; display: grid; grid-template-columns: 1fr 330px; gap: 3rem; align-items: end; }
.eyebrow { color: var(--gold-soft); text-transform: uppercase; letter-spacing: .22em; font-size: .74rem; font-weight: 700; margin: 0 0 1rem; }
h1, h2, h3 { font-family: var(--serif); font-weight: 500; line-height: .98; margin: 0; }
h1 { font-size: clamp(4rem, 10vw, 8.8rem); letter-spacing: -.05em; max-width: 870px; }
.hero-subtitle { font-family: var(--serif); color: var(--gold-soft); font-size: clamp(1.8rem, 3.2vw, 3.2rem); margin: .45rem 0 1.3rem; }
.hero-lede { max-width: 690px; font-size: clamp(1.05rem, 1.8vw, 1.35rem); color: rgba(247,242,232,.84); }
.hero-actions { display: flex; gap: 1rem; flex-wrap: wrap; margin-top: 2rem; }
.btn { display: inline-flex; align-items: center; justify-content: center; min-height: 48px; padding: .9rem 1.25rem; border-radius: 999px; font-weight: 800; letter-spacing: .02em; transition: transform .2s ease, border-color .2s ease, background .2s ease; }
.btn:hover { transform: translateY(-2px); }
.btn-primary { background: linear-gradient(135deg, var(--gold), #f1d889); color: #14100a; box-shadow: 0 12px 30px rgba(207,164,69,.22); }
.btn-secondary { border: 1px solid var(--line); color: var(--warm); background: rgba(255,255,255,.03); }
.hero-card { border: 1px solid var(--line); background: rgba(10,11,13,.62); backdrop-filter: blur(16px); padding: 1.4rem; box-shadow: var(--shadow); }
.hero-card p { color: var(--gold-soft); margin: 0 0 .45rem; text-transform: uppercase; letter-spacing: .14em; font-size: .72rem; }
.hero-card strong { font-family: var(--serif); font-size: 1.6rem; line-height: 1.05; font-weight: 500; }
.card-line { display: block; width: 60px; height: 1px; background: var(--gold); margin-bottom: 1.2rem; }

.section { padding: clamp(4.5rem, 8vw, 8rem) 0; position: relative; }
.split, .history-grid, .gallery-grid, .form-grid { display: grid; grid-template-columns: .9fr 1.1fr; gap: clamp(2rem, 5vw, 5rem); align-items: start; }
.reverse { grid-template-columns: 1.1fr .9fr; }
.section-heading h2, .center-heading h2 { font-size: clamp(2.4rem, 5vw, 5.2rem); letter-spacing: -.035em; }
.body-copy { color: rgba(247,242,232,.76); font-size: 1.02rem; }
.body-copy p:first-child { margin-top: 0; }
.intro { background: linear-gradient(180deg, var(--black), var(--charcoal)); }
.stats-band { padding: 2.8rem 0; background: linear-gradient(90deg, rgba(207,164,69,.14), rgba(255,255,255,.02), rgba(207,164,69,.1)); border-block: 1px solid var(--line); }
.stats-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1px; background: var(--line); }
.stat { background: #0b0c0e; padding: 1.5rem; }
.stat span { color: var(--gold); font-family: var(--serif); font-size: 2rem; }
.stat strong { display: block; margin: .7rem 0 .25rem; font-size: 1.1rem; }
.stat p { margin: 0; color: var(--muted); }
.history { background: radial-gradient(circle at 75% 30%, rgba(207,164,69,.08), transparent 30rem), linear-gradient(180deg, #08090a 0%, #0a0b0d 72%, #050505 100%); overflow: hidden; padding-bottom: clamp(5.5rem, 9vw, 8.5rem); }
.history::after { content: ""; position: absolute; left: 50%; bottom: 0; width: min(1120px, calc(100% - 48px)); height: 1px; transform: translateX(-50%); background: linear-gradient(90deg, transparent, rgba(247,242,232,.12), rgba(207,164,69,.28), rgba(247,242,232,.12), transparent); }
.portrait-card { margin: 0; border: 1px solid var(--line); background: rgba(255,255,255,.03); padding: .9rem; box-shadow: var(--shadow); }
.portrait-card img { aspect-ratio: 4/5; object-fit: cover; filter: grayscale(1) contrast(1.04); }
.portrait-card figcaption, .gallery-frame figcaption { color: rgba(247,242,232,.55); font-size: .78rem; margin-top: .75rem; }
.center-heading { text-align: center; max-width: 880px; margin: 0 auto 3rem; }
.center-heading p { color: rgba(247,242,232,.72); }
.legacy { position: relative; overflow: hidden; padding-top: clamp(5.25rem, 8vw, 7rem); background: radial-gradient(ellipse at 50% 0%, rgba(207,164,69,.10), transparent 26rem), linear-gradient(180deg, #0d0e11 0%, #111216 18%, #0c0d0f 100%); }
.legacy::before { content: ""; position: absolute; inset: 0 0 auto; height: 150px; background: linear-gradient(180deg, rgba(5,5,5,.78), rgba(13,14,17,.25), transparent); pointer-events: none; }
.legacy::after { content: ""; position: absolute; top: 2rem; left: 50%; width: min(980px, calc(100% - 48px)); height: 120px; transform: translateX(-50%); border: 1px solid rgba(207,164,69,.12); border-bottom: 0; border-radius: 999px 999px 0 0; opacity: .62; pointer-events: none; }
.legacy .container { position: relative; z-index: 1; }
.legacy .center-heading { padding: clamp(2rem, 4vw, 3.2rem) clamp(1rem, 3vw, 2.4rem) 0; border-top: 1px solid rgba(207,164,69,.22); background: radial-gradient(ellipse at 50% 0%, rgba(207,164,69,.08), transparent 62%); }
.legacy .center-heading::before { content: ""; display: block; width: 76px; height: 2px; margin: 0 auto 1.35rem; background: linear-gradient(90deg, transparent, rgba(207,164,69,.9), transparent); }
.legacy-grid, .criteria-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 1rem; }
.legacy-item, .criterion { border: 1px solid rgba(207,164,69,.2); background: linear-gradient(180deg, rgba(255,255,255,.04), rgba(255,255,255,.015)); padding: 1.4rem; min-height: 190px; transition: transform .2s ease, border-color .2s ease; }
.legacy-item:hover, .criterion:hover { transform: translateY(-4px); border-color: rgba(207,164,69,.55); }
.legacy-item h3, .criterion h3 { font-size: 1.55rem; color: var(--gold-soft); margin-bottom: .8rem; }
.legacy-item p, .criterion p, .gallery-copy p, .cta-card p, .form-note { color: rgba(247,242,232,.72); }
.check-list { padding: 0; margin: 1.5rem 0 0; list-style: none; }
.check-list li { position: relative; padding-left: 1.6rem; margin: .7rem 0; }
.check-list li::before { content: ""; position: absolute; left: 0; top: .65rem; width: .55rem; height: .55rem; border: 1px solid var(--gold); transform: rotate(45deg); }
.criteria { background: var(--black); }
.criteria-grid { grid-template-columns: repeat(3, 1fr); }
.criterion span { display: block; width: 44px; height: 2px; background: var(--gold); margin-bottom: 1.2rem; }
.gallery { background: radial-gradient(circle at 20% 20%, rgba(207,164,69,.12), transparent 25rem), #0d0e10; }
.gallery-grid { align-items: center; grid-template-columns: .8fr 1.2fr; }
.gallery-frame { margin: 0; padding: .75rem; border: 1px solid var(--line); background: rgba(255,255,255,.035); box-shadow: var(--shadow); }
.gallery-frame img { width: 100%; aspect-ratio: 16/10; object-fit: cover; filter: contrast(1.02) saturate(.92); }
.cta { background: linear-gradient(135deg, rgba(207,164,69,.12), rgba(0,0,0,.9)); }
.cta-card { border: 1px solid var(--line); padding: clamp(2rem, 5vw, 4rem); text-align: center; background: rgba(8,9,10,.75); box-shadow: var(--shadow); }
.cta-card h2 { font-size: clamp(2.4rem, 6vw, 6rem); }
.cta-card p { max-width: 700px; margin: 1rem auto 2rem; }
.form-section { background: #08090a; }
.form-grid { grid-template-columns: .8fr 1.2fr; }
.award-form { display: grid; grid-template-columns: repeat(2, 1fr); gap: 1rem; padding: clamp(1rem, 3vw, 2rem); border: 1px solid var(--line); background: linear-gradient(180deg, rgba(255,255,255,.05), rgba(255,255,255,.02)); box-shadow: var(--shadow); }
.field { display: flex; flex-direction: column; gap: .45rem; }
.field.full, .radio-field, .form-status, .form-button { grid-column: 1 / -1; }
label, legend { color: rgba(247,242,232,.86); font-size: .92rem; }
input, textarea { width: 100%; border: 1px solid rgba(207,164,69,.22); border-radius: 12px; background: rgba(0,0,0,.32); color: var(--warm); padding: .95rem 1rem; font: inherit; outline: none; transition: border-color .2s ease, box-shadow .2s ease; }
input:focus, textarea:focus { border-color: var(--gold); box-shadow: 0 0 0 4px rgba(207,164,69,.12); }
.radio-field { border: 1px solid rgba(207,164,69,.18); border-radius: 14px; padding: 1rem; display: flex; flex-direction: row; flex-wrap: wrap; gap: .8rem 1.2rem; }
.radio-field legend { width: 100%; margin-bottom: .3rem; }
.radio-field label { display: inline-flex; gap: .4rem; align-items: center; }
.radio-field input { width: auto; }
.honeypot { display: none !important; }
.form-status { margin: .25rem 0 0; min-height: 1.4rem; color: var(--gold-soft); }
.form-status.error { color: #ffb4a8; }
.footer { background: #040404; border-top: 1px solid var(--line); padding: 3rem 0 1.2rem; }
.footer-grid { display: grid; grid-template-columns: 1.2fr .8fr 1fr; gap: 2rem; }
.footer-logo { width: 210px; margin-bottom: 1rem; }
.footer p { color: rgba(247,242,232,.74); margin: .25rem 0; }
.footer-tagline { color: var(--gold-soft) !important; }
.footer-links { display: grid; gap: .55rem; }
.footer a:hover { color: var(--gold-soft); }
.footer-bottom { margin-top: 2rem; color: rgba(247,242,232,.5); }
.reveal { opacity: 0; transform: translateY(22px); transition: opacity .7s ease, transform .7s ease; }
.reveal.visible { opacity: 1; transform: none; }

@media (max-width: 980px) {
  .nav-toggle { display: inline-flex; }
  .nav-links { position: absolute; right: 16px; top: 76px; display: none; flex-direction: column; align-items: flex-start; width: min(320px, calc(100vw - 32px)); padding: 1rem; background: rgba(5,5,5,.96); border: 1px solid var(--line); box-shadow: var(--shadow); }
  .nav-links.open { display: flex; }
  .hero-grid, .split, .reverse, .history-grid, .gallery-grid, .form-grid, .footer-grid { grid-template-columns: 1fr; }
  .hero-card { max-width: 420px; }
  .legacy-grid, .criteria-grid { grid-template-columns: repeat(2, 1fr); }
  .stats-grid { grid-template-columns: 1fr; }
}

@media (max-width: 640px) {
  .container { width: min(100% - 28px, 1160px); }
  .nav { height: 76px; width: calc(100% - 24px); }
  .brand img { width: 118px; }
  .hero { min-height: 92vh; }
  h1 { font-size: clamp(3.2rem, 18vw, 5rem); }
  .hero-subtitle { font-size: 1.55rem; }
  .hero-actions, .btn { width: 100%; }
  .legacy-grid, .criteria-grid, .award-form { grid-template-columns: 1fr; }
  .section { padding: 4rem 0; }
}


/* Divisores premium entre secciones */
.page-divider {
  width: min(1160px, calc(100% - 40px));
  height: 1px;
  margin: 0 auto;
  background: linear-gradient(90deg, transparent 0%, rgba(207,164,69,.18) 18%, rgba(229,201,121,.62) 50%, rgba(207,164,69,.18) 82%, transparent 100%);
  box-shadow: 0 0 18px rgba(207,164,69,.10);
  position: relative;
  z-index: 3;
}
.page-divider::after {
  content: "";
  position: absolute;
  left: 50%;
  top: 50%;
  width: 7px;
  height: 7px;
  transform: translate(-50%, -50%) rotate(45deg);
  border: 1px solid rgba(229,201,121,.55);
  background: #08090a;
}

/* Transición limpia entre Quién fue Adolf Horn y Legado empresarial */
.history {
  padding-bottom: clamp(4.5rem, 8vw, 7rem);
}
.history::after,
.legacy::before,
.legacy::after {
  display: none;
}
.legacy {
  padding-top: clamp(4.5rem, 8vw, 7rem);
  background:
    radial-gradient(circle at 50% 0%, rgba(207,164,69,.10), transparent 28rem),
    linear-gradient(180deg, #0b0c0e 0%, #111216 44%, #0c0d0f 100%);
}
.legacy .center-heading {
  padding: 0;
  border-top: 0;
  background: transparent;
}
.legacy .center-heading::before {
  display: none;
}

@media (max-width: 720px) {
  .page-divider { width: calc(100% - 32px); }
  .page-divider::after { width: 6px; height: 6px; }
}

/* Ajuste tipográfico v10: escala más editorial, menos pesada y con mejor lectura */
body {
  font-size: 15.5px;
  line-height: 1.72;
}

h1, h2, h3 {
  line-height: 1.07;
  letter-spacing: -.025em;
}

h1 {
  font-size: clamp(3.25rem, 8.2vw, 7.15rem);
  max-width: 760px;
}

.hero-subtitle {
  font-size: clamp(1.45rem, 2.5vw, 2.55rem);
  line-height: 1.12;
  margin: .55rem 0 1.1rem;
}

.hero-lede {
  max-width: 610px;
  font-size: clamp(1rem, 1.25vw, 1.16rem);
  line-height: 1.72;
}

.section-heading h2,
.center-heading h2 {
  font-size: clamp(2.05rem, 3.9vw, 4.15rem);
  line-height: 1.08;
  max-width: 820px;
}

.center-heading h2 {
  margin-left: auto;
  margin-right: auto;
}

.body-copy {
  font-size: .96rem;
  line-height: 1.78;
}

.center-heading p,
.gallery-copy p,
.cta-card p,
.form-note,
.stat p,
.legacy-item p,
.criterion p,
.footer p {
  font-size: .94rem;
  line-height: 1.68;
}

.eyebrow {
  font-size: .68rem;
  letter-spacing: .20em;
}

.hero-card strong {
  font-size: 1.32rem;
  line-height: 1.16;
}

.stat span {
  font-size: 1.65rem;
}

.stat strong {
  font-size: 1rem;
}

.legacy-item,
.criterion {
  padding: 1.25rem;
  min-height: 168px;
}

.legacy-item h3,
.criterion h3 {
  font-size: 1.28rem;
  line-height: 1.16;
}

.cta-card h2 {
  font-size: clamp(2.05rem, 4.6vw, 4.4rem);
  line-height: 1.06;
}

label,
legend {
  font-size: .86rem;
  line-height: 1.45;
}

input,
textarea {
  font-size: .94rem;
  padding: .82rem .92rem;
}

.btn {
  min-height: 46px;
  padding: .82rem 1.12rem;
  font-size: .9rem;
}

.nav-links {
  font-size: .8rem;
}

@media (max-width: 980px) {
  h1 { font-size: clamp(3.05rem, 12vw, 5.9rem); }
  .section-heading h2,
  .center-heading h2 { font-size: clamp(2rem, 6vw, 3.45rem); }
}

@media (max-width: 640px) {
  body { font-size: 15px; }
  h1 { font-size: clamp(2.75rem, 14vw, 4.35rem); line-height: 1.03; }
  .hero-subtitle { font-size: 1.35rem; }
  .hero-lede { font-size: .98rem; }
  .section-heading h2,
  .center-heading h2 { font-size: clamp(1.9rem, 9vw, 2.55rem); }
  .body-copy,
  .center-heading p,
  .gallery-copy p,
  .cta-card p,
  .form-note,
  .legacy-item p,
  .criterion p { font-size: .92rem; }
  .legacy-item h3,
  .criterion h3 { font-size: 1.2rem; }
  .hero-card strong { font-size: 1.22rem; }
}

/* Refinamiento visual v11: look editorial premium */
:root {
  --black: #050505;
  --charcoal: #0e0f11;
  --charcoal-2: #15161a;
  --gold: #c69a3d;
  --gold-soft: #ead18a;
  --cream: #fff8ea;
}

html { text-rendering: optimizeLegibility; }
body {
  font-family: "Inter", "Avenir Next", "Helvetica Neue", Arial, sans-serif;
  letter-spacing: -.006em;
  background:
    radial-gradient(circle at 18% 6%, rgba(234, 209, 138, .10), transparent 25rem),
    radial-gradient(circle at 86% 24%, rgba(198, 154, 61, .075), transparent 24rem),
    linear-gradient(180deg, #040404 0%, #0b0c0e 42%, #050505 100%);
}

body::before {
  content: "";
  position: fixed;
  inset: 0;
  pointer-events: none;
  z-index: 0;
  opacity: .16;
  background-image:
    linear-gradient(rgba(255,255,255,.025) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,.018) 1px, transparent 1px);
  background-size: 54px 54px;
  mask-image: radial-gradient(circle at 50% 12%, black, transparent 72%);
}

.site-header, main, .footer { position: relative; z-index: 1; }

.site-header.scrolled {
  background: rgba(5,5,5,.78);
  box-shadow: 0 18px 60px rgba(0,0,0,.24);
}

.nav { height: 78px; }
.brand img { width: 122px; }
.nav-links {
  text-transform: uppercase;
  letter-spacing: .105em;
  font-weight: 700;
  color: rgba(247, 242, 232, .74);
}
.nav-cta {
  border-color: rgba(234,209,138,.34);
  background: rgba(234,209,138,.055);
}

h1, h2, h3 {
  font-family: "Cormorant Garamond", "Playfair Display", Georgia, serif;
  font-weight: 600;
  letter-spacing: -.018em;
}

h1 {
  max-width: 790px;
  color: var(--cream);
  text-shadow: 0 18px 70px rgba(0,0,0,.78);
}

.hero-subtitle {
  font-family: "Cormorant Garamond", "Playfair Display", Georgia, serif;
  font-weight: 600;
  letter-spacing: .01em;
  color: #efd790;
}

.hero-lede,
.body-copy,
.center-heading p,
.gallery-copy p,
.cta-card p,
.form-note,
.legacy-item p,
.criterion p,
.stat p,
.footer p {
  color: rgba(247,242,232,.76);
}

.eyebrow {
  color: #e7c878;
  font-weight: 800;
  letter-spacing: .24em;
}

.hero-overlay {
  background:
    linear-gradient(90deg, rgba(0,0,0,.94) 0%, rgba(0,0,0,.76) 42%, rgba(0,0,0,.38) 100%),
    radial-gradient(circle at 18% 47%, rgba(234, 209, 138, .22), transparent 21rem),
    linear-gradient(180deg, rgba(0,0,0,.20), transparent 42%, rgba(0,0,0,.30));
}

.hero-card,
.portrait-card,
.gallery-frame,
.award-form,
.cta-card,
.legacy-item,
.criterion,
.stat {
  border-radius: 18px;
}

.hero-card,
.portrait-card,
.gallery-frame,
.award-form,
.cta-card {
  border-color: rgba(234,209,138,.25);
  background: linear-gradient(180deg, rgba(255,255,255,.07), rgba(255,255,255,.025));
}

.hero-card {
  position: relative;
  overflow: hidden;
}
.hero-card::after {
  content: "";
  position: absolute;
  inset: 0;
  background: radial-gradient(circle at 100% 0%, rgba(234,209,138,.16), transparent 14rem);
  pointer-events: none;
}
.hero-card > * { position: relative; z-index: 1; }

.btn {
  letter-spacing: .055em;
  text-transform: uppercase;
  font-weight: 800;
  box-shadow: inset 0 1px 0 rgba(255,255,255,.16);
}
.btn-primary {
  background: linear-gradient(135deg, #b78327 0%, #f4d987 48%, #c99a3d 100%);
}
.btn-secondary:hover,
.nav-cta:hover {
  background: rgba(234,209,138,.09);
}

.section-heading h2,
.center-heading h2,
.cta-card h2 {
  color: #fff4dc;
  text-wrap: balance;
}

.body-copy p,
.center-heading p,
.gallery-copy p,
.form-note {
  text-wrap: pretty;
}

.page-divider {
  height: 1px;
  opacity: .92;
  background: linear-gradient(90deg, transparent 0%, rgba(198,154,61,.12) 16%, rgba(234,209,138,.68) 50%, rgba(198,154,61,.12) 84%, transparent 100%);
}
.page-divider::after {
  background: #0a0b0d;
  box-shadow: 0 0 20px rgba(234,209,138,.22);
}

.intro,
.criteria,
.form-section {
  background:
    radial-gradient(circle at 92% 8%, rgba(198,154,61,.065), transparent 24rem),
    linear-gradient(180deg, #070809, #0f1013);
}

.stats-band {
  background:
    linear-gradient(90deg, rgba(198,154,61,.12), rgba(255,255,255,.025), rgba(198,154,61,.10)),
    #08090a;
}

.history {
  background:
    radial-gradient(circle at 78% 22%, rgba(234,209,138,.075), transparent 27rem),
    linear-gradient(180deg, #08090a 0%, #0b0c0e 100%);
}

.legacy {
  background:
    radial-gradient(circle at 50% -8%, rgba(234,209,138,.13), transparent 30rem),
    radial-gradient(circle at 15% 84%, rgba(198,154,61,.055), transparent 22rem),
    linear-gradient(180deg, #090a0c 0%, #111216 48%, #0a0b0d 100%);
}

.gallery {
  background:
    radial-gradient(circle at 20% 20%, rgba(234,209,138,.13), transparent 25rem),
    linear-gradient(180deg, #0c0d0f, #08090a);
}

.legacy-item,
.criterion {
  position: relative;
  overflow: hidden;
  border-color: rgba(234,209,138,.18);
  background:
    linear-gradient(180deg, rgba(255,255,255,.055), rgba(255,255,255,.018));
}
.legacy-item::before,
.criterion::before {
  content: "";
  position: absolute;
  inset: 0 0 auto 0;
  height: 2px;
  background: linear-gradient(90deg, transparent, rgba(234,209,138,.58), transparent);
  opacity: .75;
}
.legacy-item h3,
.criterion h3 {
  color: #efd790;
  font-weight: 600;
}

.portrait-card img,
.gallery-frame img {
  border-radius: 12px;
}

input, textarea, .radio-field {
  border-color: rgba(234,209,138,.24);
  background: rgba(0,0,0,.26);
}
input:focus, textarea:focus {
  border-color: #e7c878;
  box-shadow: 0 0 0 4px rgba(234,209,138,.11);
}

.footer-logo { width: 180px; }

@media (max-width: 640px) {
  .nav { height: 72px; }
  .brand img { width: 108px; }
  .hero-grid { padding-top: 6rem; }
  .btn { letter-spacing: .035em; }
  .hero-card,
  .portrait-card,
  .gallery-frame,
  .award-form,
  .cta-card,
  .legacy-item,
  .criterion,
  .stat { border-radius: 16px; }
}

/* Refinamiento v12: tipografía más elegante, menos pesada y footer premium */
:root {
  --button-font: "Marcellus", "Cormorant Garamond", Georgia, serif;
}

/* Evita que las etiquetas institucionales se sientan duras o demasiado pesadas */
.eyebrow,
.nav-links,
.hero-card p,
.btn {
  text-transform: none;
}

.eyebrow {
  font-family: "Inter", "Avenir Next", "Helvetica Neue", Arial, sans-serif;
  font-weight: 600;
  letter-spacing: .12em;
  font-size: .74rem;
}

.nav-links {
  font-weight: 500;
  letter-spacing: .035em;
  font-size: .83rem;
}

.hero-card p {
  font-family: var(--button-font);
  font-weight: 400;
  letter-spacing: .06em;
  font-size: .86rem;
  color: #ead18a;
}

.btn {
  font-family: var(--button-font);
  font-size: 1rem;
  font-weight: 400;
  letter-spacing: .035em;
  border-radius: 999px;
  padding: .86rem 1.35rem;
}

.btn-primary {
  color: #171106;
  text-shadow: 0 1px 0 rgba(255,255,255,.22);
}

.btn-secondary {
  color: #fff4dc;
}

.nav-cta {
  font-family: var(--button-font);
  font-weight: 400;
  letter-spacing: .025em;
}

/* Footer editorial */
.footer {
  position: relative;
  overflow: hidden;
  padding: 0 0 1.4rem;
  background:
    radial-gradient(circle at 18% 10%, rgba(234,209,138,.12), transparent 25rem),
    radial-gradient(circle at 88% 60%, rgba(198,154,61,.08), transparent 22rem),
    linear-gradient(180deg, #070708 0%, #030303 100%);
  border-top: 1px solid rgba(234,209,138,.22);
}

.footer::before {
  content: "";
  position: absolute;
  top: 0;
  left: 50%;
  width: min(1160px, calc(100% - 40px));
  height: 1px;
  transform: translateX(-50%);
  background: linear-gradient(90deg, transparent, rgba(234,209,138,.82), transparent);
  box-shadow: 0 0 38px rgba(234,209,138,.22);
}

.footer-panel {
  position: relative;
  display: grid;
  grid-template-columns: 1.35fr .75fr 1fr;
  gap: clamp(1.5rem, 4vw, 3.5rem);
  margin-top: 3.4rem;
  padding: clamp(1.6rem, 4vw, 2.6rem);
  border: 1px solid rgba(234,209,138,.18);
  border-radius: 24px;
  background:
    linear-gradient(135deg, rgba(255,255,255,.055), rgba(255,255,255,.018)),
    rgba(7,8,9,.72);
  box-shadow: 0 26px 80px rgba(0,0,0,.42);
}

.footer-panel::after {
  content: "";
  position: absolute;
  inset: 12px;
  border: 1px solid rgba(234,209,138,.08);
  border-radius: 18px;
  pointer-events: none;
}

.footer-brand-block,
.footer-column {
  position: relative;
  z-index: 1;
}

.footer-logo {
  width: 160px;
  margin-bottom: 1.2rem;
}

.footer-award {
  max-width: 460px;
  margin: 0;
  font-family: "Cormorant Garamond", Georgia, serif;
  font-size: clamp(1.7rem, 2.5vw, 2.45rem) !important;
  line-height: 1.05 !important;
  color: #fff4dc !important;
}

.footer-tagline {
  margin-top: .85rem !important;
  font-family: var(--button-font);
  font-size: 1.02rem !important;
  letter-spacing: .03em;
  color: #ead18a !important;
}

.footer-column h2 {
  margin: .15rem 0 1rem;
  font-family: var(--button-font);
  font-size: 1rem;
  font-weight: 400;
  letter-spacing: .08em;
  color: #ead18a;
}

.footer-links {
  display: grid;
  align-content: start;
  gap: .68rem;
}

.footer-links a,
.footer-email {
  color: rgba(247,242,232,.78);
  font-size: .95rem;
  transition: color .2s ease, transform .2s ease;
}

.footer-links a:hover,
.footer-email:hover {
  color: #ead18a;
  transform: translateX(3px);
}

.footer-contact p {
  max-width: 310px;
  margin: 0 0 .9rem;
  color: rgba(247,242,232,.68) !important;
}

.footer-email {
  display: inline-block;
  margin-bottom: 1.15rem;
}

.footer-mini-cta {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 42px;
  padding: .7rem 1rem;
  border: 1px solid rgba(234,209,138,.30);
  border-radius: 999px;
  font-family: var(--button-font);
  font-size: .95rem;
  letter-spacing: .035em;
  color: #fff4dc;
  background: rgba(234,209,138,.055);
  transition: background .2s ease, border-color .2s ease, transform .2s ease;
}

.footer-mini-cta:hover {
  transform: translateY(-2px);
  border-color: rgba(234,209,138,.58);
  background: rgba(234,209,138,.10);
}

.footer-bottom {
  display: flex;
  justify-content: space-between;
  gap: 1rem;
  margin-top: 1.2rem;
  color: rgba(247,242,232,.46);
}

@media (max-width: 980px) {
  .footer-panel { grid-template-columns: 1fr; }
  .footer-award { max-width: 620px; }
}

@media (max-width: 640px) {
  .btn { width: 100%; font-size: .98rem; }
  .eyebrow { letter-spacing: .08em; }
  .footer { padding-bottom: 1rem; }
  .footer-panel { margin-top: 2.4rem; padding: 1.25rem; border-radius: 20px; }
  .footer-panel::after { inset: 8px; border-radius: 15px; }
  .footer-logo { width: 134px; }
  .footer-bottom { flex-direction: column; }
}

/* Ajustes v13: logo proporcionado y footer más integrado */
.nav {
  height: 78px;
}

.brand {
  display: inline-flex;
  align-items: center;
  flex: 0 0 auto;
}

.brand img {
  width: auto !important;
  height: 54px !important;
  max-height: 54px;
  object-fit: contain;
}

.footer {
  padding: clamp(3.2rem, 6vw, 5rem) 0 1.35rem;
  background:
    radial-gradient(circle at 12% 0%, rgba(234,209,138,.10), transparent 24rem),
    radial-gradient(circle at 88% 20%, rgba(207,164,69,.07), transparent 24rem),
    linear-gradient(180deg, #070708 0%, #030303 100%);
}

.footer-panel {
  display: grid;
  grid-template-columns: 1.25fr .75fr 1fr;
  gap: clamp(1.7rem, 4vw, 4rem);
  margin-top: 0;
  padding: 0;
  border: 0;
  border-radius: 0;
  background: transparent;
  box-shadow: none;
}

.footer-panel::after {
  display: none;
}

.footer-brand-block {
  padding-right: clamp(1rem, 3vw, 2.5rem);
}

.footer-column {
  padding-left: clamp(1rem, 3vw, 2.5rem);
  border-left: 1px solid rgba(234,209,138,.16);
}

.footer-logo {
  width: 132px;
  max-width: 132px;
  height: auto;
  margin-bottom: 1.1rem;
}

.footer-award {
  max-width: 430px;
  font-size: clamp(1.55rem, 2.2vw, 2.15rem) !important;
}

.footer-contact p {
  margin-bottom: .85rem;
}

.footer-email {
  margin-bottom: 0;
}

.footer-bottom {
  margin-top: clamp(2rem, 4vw, 3.2rem);
  padding-top: 1rem;
  border-top: 1px solid rgba(234,209,138,.12);
}

@media (max-width: 980px) {
  .footer-panel {
    grid-template-columns: 1fr;
    gap: 1.7rem;
  }

  .footer-brand-block,
  .footer-column {
    padding-left: 0;
    padding-right: 0;
    border-left: 0;
  }

  .footer-column {
    padding-top: 1.25rem;
    border-top: 1px solid rgba(234,209,138,.12);
  }
}

@media (max-width: 640px) {
  .nav {
    height: 72px;
  }

  .brand img {
    height: 46px !important;
    max-height: 46px;
  }

  .footer {
    padding-top: 3rem;
  }

  .footer-logo {
    width: 112px;
    max-width: 112px;
  }
}

/* Ajustes v14: experiencia móvil, fotografías centradas y lectura fluida */
html,
body {
  max-width: 100%;
  overflow-x: hidden;
}

@media (max-width: 860px) {
  .container {
    width: min(100% - 32px, 1160px);
  }

  .nav {
    width: calc(100% - 24px);
    height: 68px;
  }

  .brand img {
    height: 40px !important;
    max-height: 40px !important;
    width: auto !important;
  }

  .nav-toggle {
    display: inline-flex;
    min-height: 40px;
    align-items: center;
  }

  .nav-links {
    top: 70px;
    right: 12px;
    width: calc(100vw - 24px);
    max-width: 360px;
    padding: 1rem;
    gap: .85rem;
    border-radius: 18px;
    text-align: left;
  }

  .hero {
    min-height: auto;
    padding: 7rem 0 4.5rem;
  }

  .hero-bg {
    background-position: center top;
    transform: scale(1.01);
  }

  .hero-overlay {
    background:
      linear-gradient(180deg, rgba(0,0,0,.88) 0%, rgba(0,0,0,.72) 48%, rgba(0,0,0,.91) 100%),
      radial-gradient(circle at 50% 18%, rgba(234,209,138,.16), transparent 18rem);
  }

  .hero-grid,
  .split,
  .reverse,
  .history-grid,
  .gallery-grid,
  .form-grid,
  .footer-panel {
    grid-template-columns: 1fr !important;
    gap: 2rem;
  }

  .hero-grid {
    padding-top: 0;
    align-items: center;
    text-align: center;
  }

  h1 {
    max-width: 100%;
    font-size: clamp(2.75rem, 14vw, 4.4rem);
    line-height: 1.02;
  }

  .hero-subtitle {
    font-size: clamp(1.3rem, 6vw, 1.75rem);
  }

  .hero-lede {
    max-width: 34rem;
    margin-left: auto;
    margin-right: auto;
    font-size: .98rem;
    line-height: 1.68;
  }

  .hero-actions {
    justify-content: center;
  }

  .hero-card {
    width: min(100%, 360px);
    margin: 1.5rem auto 0;
    text-align: left;
  }

  .section {
    padding: 3.8rem 0;
  }

  .section-heading,
  .center-heading,
  .gallery-copy {
    text-align: center;
  }

  .section-heading h2,
  .center-heading h2,
  .cta-card h2 {
    max-width: 100%;
    font-size: clamp(2rem, 9vw, 3rem);
    line-height: 1.08;
  }

  .body-copy,
  .center-heading p,
  .gallery-copy p,
  .cta-card p,
  .form-note {
    max-width: 42rem;
    margin-left: auto;
    margin-right: auto;
    text-align: left;
    line-height: 1.76;
  }

  .center-heading p,
  .gallery-copy p,
  .cta-card p,
  .form-note {
    text-align: center;
  }

  .portrait-card,
  .gallery-frame {
    width: min(100%, 430px);
    margin-left: auto;
    margin-right: auto;
    padding: .65rem;
  }

  .portrait-card img {
    width: 100%;
    aspect-ratio: 4 / 5;
    object-fit: cover;
    object-position: center center;
  }

  .gallery-frame {
    width: min(100%, 560px);
  }

  .gallery-frame img {
    width: 100%;
    aspect-ratio: 4 / 3;
    object-fit: cover;
    object-position: center center;
  }

  .legacy-grid,
  .criteria-grid,
  .stats-grid,
  .award-form {
    grid-template-columns: 1fr !important;
  }

  .legacy-item,
  .criterion,
  .stat {
    min-height: auto;
    text-align: center;
  }

  .criterion span {
    margin-left: auto;
    margin-right: auto;
  }

  .check-list {
    max-width: 34rem;
    margin-left: auto;
    margin-right: auto;
    text-align: left;
  }

  .award-form {
    width: min(100%, 560px);
    margin-left: auto;
    margin-right: auto;
    padding: 1rem;
  }

  .radio-field {
    display: grid;
    grid-template-columns: 1fr 1fr;
    align-items: center;
  }

  .radio-field legend {
    grid-column: 1 / -1;
  }

  .footer {
    text-align: center;
  }

  .footer-logo {
    margin-left: auto;
    margin-right: auto;
  }

  .footer-award,
  .footer-contact p {
    margin-left: auto !important;
    margin-right: auto !important;
  }

  .footer-links {
    justify-items: center;
  }

  .footer-column {
    border-left: 0;
    border-top: 1px solid rgba(234,209,138,.12);
    padding: 1.25rem 0 0;
  }

  .footer-bottom {
    align-items: center;
    text-align: center;
  }
}

@media (max-width: 520px) {
  .container {
    width: min(100% - 26px, 1160px);
  }

  .nav {
    width: calc(100% - 20px);
  }

  .brand img {
    height: 34px !important;
    max-height: 34px !important;
  }

  .nav-toggle {
    padding: .5rem .75rem;
    font-size: .9rem;
  }

  .hero {
    padding: 6.4rem 0 3.8rem;
  }

  h1 {
    font-size: clamp(2.4rem, 15.5vw, 3.65rem);
    letter-spacing: -.035em;
  }

  .hero-subtitle {
    font-size: 1.22rem;
  }

  .hero-actions {
    gap: .7rem;
  }

  .btn {
    width: 100%;
    min-height: 46px;
    font-size: .96rem;
    padding: .8rem 1rem;
  }

  .section {
    padding: 3.25rem 0;
  }

  .section-heading h2,
  .center-heading h2,
  .cta-card h2 {
    font-size: clamp(1.85rem, 10vw, 2.45rem);
  }

  .body-copy,
  .center-heading p,
  .gallery-copy p,
  .cta-card p,
  .form-note,
  .legacy-item p,
  .criterion p {
    font-size: .94rem;
    line-height: 1.72;
  }

  .portrait-card,
  .gallery-frame {
    width: 100%;
    border-radius: 16px;
  }

  .portrait-card img,
  .gallery-frame img {
    border-radius: 11px;
  }

  .radio-field {
    grid-template-columns: 1fr;
  }

  input,
  textarea {
    font-size: 16px;
  }

  .footer-panel {
    gap: 1.45rem;
  }

  .footer-award {
    font-size: 1.65rem !important;
  }

  .footer-bottom {
    flex-direction: column;
  }
}

/* Ajuste v15: logo horizontal en header */
.site-header .brand {
  max-width: clamp(220px, 28vw, 390px);
}

.site-header .brand img {
  display: block;
  width: 100% !important;
  height: auto !important;
  max-height: none !important;
}

.site-header .nav {
  min-height: 86px;
  height: auto;
  align-items: center;
}

@media (max-width: 860px) {
  .site-header .brand {
    max-width: clamp(180px, 42vw, 250px);
  }

  .site-header .nav {
    min-height: 76px;
  }
}

@media (max-width: 640px) {
  .site-header .brand {
    max-width: clamp(160px, 48vw, 220px);
  }

  .site-header .nav {
    min-height: 72px;
  }

  .nav-links {
    top: 74px;
  }
}

/* Mejoras visuales v17: más vida en secciones y convocatoria más integrada */
body {
  background:
    radial-gradient(circle at 12% 8%, rgba(207, 164, 69, .15), transparent 24rem),
    radial-gradient(circle at 88% 22%, rgba(207, 164, 69, .08), transparent 26rem),
    linear-gradient(180deg, #060607 0%, #0b0d10 35%, #090a0c 68%, #050505 100%);
}

.section {
  isolation: isolate;
}

.section::before {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  opacity: .65;
  background:
    linear-gradient(180deg, rgba(255,255,255,.015), rgba(255,255,255,0) 18%, rgba(255,255,255,.012) 100%);
  z-index: 0;
}

.section > .container {
  position: relative;
  z-index: 1;
}

.intro {
  background:
    radial-gradient(circle at 18% 18%, rgba(207,164,69,.10), transparent 18rem),
    linear-gradient(180deg, #0a0b0d 0%, #101216 100%);
}

.audience {
  background:
    radial-gradient(circle at 82% 30%, rgba(207,164,69,.10), transparent 20rem),
    linear-gradient(180deg, #0b0d10 0%, #111317 100%);
}

.criteria {
  background:
    radial-gradient(circle at 82% 16%, rgba(207,164,69,.10), transparent 24rem),
    radial-gradient(circle at 12% 80%, rgba(255,255,255,.03), transparent 22rem),
    linear-gradient(180deg, #0a0b0d 0%, #0f1114 100%);
}

.gallery {
  background:
    radial-gradient(circle at 20% 22%, rgba(207,164,69,.13), transparent 23rem),
    radial-gradient(circle at 84% 70%, rgba(207,164,69,.07), transparent 24rem),
    linear-gradient(180deg, #101114 0%, #0b0c0f 100%);
}

/* Convocatoria con panel integrado para evitar vacío negro */
.form-section {
  background:
    radial-gradient(circle at 18% 24%, rgba(207,164,69,.16), transparent 20rem),
    radial-gradient(circle at 88% 12%, rgba(207,164,69,.08), transparent 22rem),
    linear-gradient(180deg, #0d0f12 0%, #090a0c 100%);
}

.form-section::before {
  background:
    linear-gradient(180deg, rgba(255,255,255,.015), rgba(255,255,255,0) 35%),
    radial-gradient(circle at 30% 30%, rgba(207,164,69,.08), transparent 16rem);
}

.form-grid {
  grid-template-columns: .84fr 1.16fr;
  align-items: center;
  gap: clamp(1.5rem, 4vw, 3.5rem);
  padding: clamp(1.25rem, 3vw, 2rem);
  border: 1px solid rgba(207,164,69,.18);
  border-radius: 28px;
  background:
    linear-gradient(135deg, rgba(255,255,255,.045), rgba(255,255,255,.018)),
    radial-gradient(circle at 18% 18%, rgba(207,164,69,.09), transparent 16rem),
    rgba(8,9,10,.72);
  box-shadow: 0 26px 80px rgba(0,0,0,.32);
  overflow: hidden;
  position: relative;
}

.form-grid::before {
  content: "";
  position: absolute;
  inset: 14px;
  border: 1px solid rgba(229,201,121,.08);
  border-radius: 20px;
  pointer-events: none;
}

.form-section .section-heading {
  align-self: center;
  padding: clamp(.5rem, 2vw, 1rem) clamp(.25rem, 1vw, .5rem) clamp(.5rem, 2vw, 1rem) 0;
}

.form-section .section-heading h2 {
  max-width: 14ch;
}

.form-section .section-heading p,
.form-section .form-note {
  max-width: 33rem;
}

.form-section .eyebrow::after {
  content: "";
  display: block;
  width: 72px;
  height: 2px;
  margin-top: .85rem;
  background: linear-gradient(90deg, rgba(229,201,121,0), rgba(229,201,121,.85), rgba(229,201,121,0));
}

.award-form {
  border-radius: 24px;
  background:
    linear-gradient(180deg, rgba(255,255,255,.065), rgba(255,255,255,.025)),
    rgba(7,8,9,.82);
  border: 1px solid rgba(207,164,69,.22);
}

.field,
.radio-field {
  position: relative;
}

.field::after {
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  bottom: -0.4rem;
  height: 1px;
  background: linear-gradient(90deg, transparent, rgba(229,201,121,.08), transparent);
}

.field.full::after,
.form-button::after,
.form-status::after,
.radio-field::after {
  display: none;
}

.award-form .btn-primary {
  min-width: 240px;
}

/* Tarjetas y bloques con algo más de riqueza visual */
.stat,
.legacy-item,
.criterion,
.gallery-frame,
.portrait-card,
.hero-card {
  backdrop-filter: blur(10px);
}

.stat {
  background:
    linear-gradient(180deg, rgba(255,255,255,.04), rgba(255,255,255,.015)),
    #0c0d10;
}

.legacy-item,
.criterion {
  background:
    radial-gradient(circle at 85% 12%, rgba(207,164,69,.08), transparent 10rem),
    linear-gradient(180deg, rgba(255,255,255,.045), rgba(255,255,255,.018));
}

.gallery-frame,
.portrait-card {
  border-radius: 22px;
  background:
    linear-gradient(180deg, rgba(255,255,255,.055), rgba(255,255,255,.02));
}

.gallery-frame img,
.portrait-card img,
.award-form {
  border-radius: 16px;
}

@media (max-width: 980px) {
  .form-grid {
    grid-template-columns: 1fr;
    padding: 1.15rem;
    border-radius: 22px;
  }

  .form-section .section-heading {
    padding-right: 0;
  }

  .form-section .section-heading h2,
  .form-section .section-heading p,
  .form-section .form-note {
    max-width: none;
  }
}

@media (max-width: 640px) {
  .form-grid {
    padding: .9rem;
    border-radius: 18px;
  }

  .form-grid::before {
    inset: 10px;
    border-radius: 14px;
  }

  .award-form {
    padding: .9rem;
    border-radius: 18px;
  }

  .gallery-frame,
  .portrait-card {
    border-radius: 18px;
  }
}


/* v18: fondos más vivos y postulacion sin cuadro contenedor */
body {
  background:
    radial-gradient(circle at 10% 6%, rgba(229,201,121,.14), transparent 22rem),
    radial-gradient(circle at 88% 14%, rgba(207,164,69,.10), transparent 24rem),
    radial-gradient(circle at 50% 55%, rgba(255,255,255,.025), transparent 28rem),
    linear-gradient(180deg, #060607 0%, #0b0c0f 34%, #0a0b0d 66%, #050505 100%);
}

/* Dar más vida a cada bloque sin saturar */
.intro,
.history,
.legacy,
.audience,
.criteria,
.gallery,
.form-section,
.footer {
  position: relative;
  overflow: hidden;
}

.intro::after,
.history::before,
.legacy::before,
.audience::before,
.criteria::before,
.gallery::before,
.form-section::after,
.footer::before {
  content: "";
  position: absolute;
  pointer-events: none;
  inset: auto;
  width: 34rem;
  height: 34rem;
  border-radius: 50%;
  filter: blur(18px);
  opacity: .42;
}

.intro {
  background:
    radial-gradient(circle at 16% 20%, rgba(207,164,69,.14), transparent 18rem),
    radial-gradient(circle at 82% 78%, rgba(229,201,121,.06), transparent 22rem),
    linear-gradient(180deg, #0a0b0d 0%, #111318 100%);
}
.intro::after { top: -12rem; right: -12rem; background: radial-gradient(circle, rgba(229,201,121,.14) 0%, rgba(229,201,121,0) 62%); }

.history {
  background:
    radial-gradient(circle at 82% 18%, rgba(207,164,69,.12), transparent 20rem),
    radial-gradient(circle at 14% 84%, rgba(255,255,255,.03), transparent 20rem),
    linear-gradient(180deg, #090a0c 0%, #0f1115 54%, #08090b 100%);
}
.history::before { left: -12rem; bottom: -16rem; background: radial-gradient(circle, rgba(207,164,69,.14) 0%, rgba(207,164,69,0) 64%); }

.legacy {
  background:
    radial-gradient(circle at 50% 0%, rgba(229,201,121,.12), transparent 22rem),
    radial-gradient(circle at 85% 72%, rgba(207,164,69,.08), transparent 22rem),
    linear-gradient(180deg, #0d0f13 0%, #111318 48%, #0b0c0f 100%);
}
.legacy::before { right: -10rem; top: -14rem; background: radial-gradient(circle, rgba(229,201,121,.12) 0%, rgba(229,201,121,0) 65%); }

.audience {
  background:
    radial-gradient(circle at 84% 24%, rgba(207,164,69,.12), transparent 18rem),
    radial-gradient(circle at 12% 72%, rgba(229,201,121,.05), transparent 18rem),
    linear-gradient(180deg, #0a0c0f 0%, #111419 100%);
}
.audience::before { left: -12rem; top: -12rem; background: radial-gradient(circle, rgba(207,164,69,.12) 0%, rgba(207,164,69,0) 66%); }

.criteria {
  background:
    radial-gradient(circle at 84% 14%, rgba(229,201,121,.12), transparent 20rem),
    radial-gradient(circle at 14% 86%, rgba(207,164,69,.07), transparent 22rem),
    linear-gradient(180deg, #090a0c 0%, #101217 100%);
}
.criteria::before { right: -11rem; bottom: -14rem; background: radial-gradient(circle, rgba(229,201,121,.14) 0%, rgba(229,201,121,0) 64%); }

.gallery {
  background:
    radial-gradient(circle at 18% 18%, rgba(207,164,69,.15), transparent 22rem),
    radial-gradient(circle at 86% 78%, rgba(229,201,121,.06), transparent 24rem),
    linear-gradient(180deg, #101215 0%, #0b0c0f 100%);
}
.gallery::before { left: -12rem; bottom: -14rem; background: radial-gradient(circle, rgba(207,164,69,.13) 0%, rgba(207,164,69,0) 64%); }

/* Postulación sin cuadro externo */
.form-section {
  background:
    radial-gradient(circle at 20% 24%, rgba(229,201,121,.14), transparent 18rem),
    radial-gradient(circle at 84% 12%, rgba(207,164,69,.09), transparent 20rem),
    radial-gradient(circle at 50% 100%, rgba(255,255,255,.025), transparent 26rem),
    linear-gradient(180deg, #0c0e11 0%, #090a0c 100%);
}
.form-section::after { right: -12rem; top: -12rem; background: radial-gradient(circle, rgba(229,201,121,.13) 0%, rgba(229,201,121,0) 66%); }

.form-grid {
  grid-template-columns: .84fr 1.16fr;
  align-items: start;
  gap: clamp(1.6rem, 4vw, 3.5rem);
  padding: 0 !important;
  border: 0 !important;
  border-radius: 0 !important;
  background: transparent !important;
  box-shadow: none !important;
  overflow: visible !important;
}
.form-grid::before {
  display: none !important;
}
.form-section .section-heading {
  padding: 0;
}
.form-section .section-heading h2 {
  max-width: 14ch;
}
.form-section .section-heading p,
.form-section .form-note {
  max-width: 34rem;
}
.award-form {
  border-radius: 24px;
  background:
    radial-gradient(circle at 86% 10%, rgba(229,201,121,.08), transparent 12rem),
    linear-gradient(180deg, rgba(255,255,255,.065), rgba(255,255,255,.025)),
    rgba(7,8,9,.82);
  border: 1px solid rgba(207,164,69,.24);
  box-shadow: 0 22px 60px rgba(0,0,0,.26);
}

/* sutil riqueza visual en cards */
.hero-card,
.stat,
.legacy-item,
.criterion,
.portrait-card,
.gallery-frame {
  background-blend-mode: screen, normal;
}
.stat {
  background:
    radial-gradient(circle at 85% 16%, rgba(229,201,121,.07), transparent 10rem),
    linear-gradient(180deg, rgba(255,255,255,.04), rgba(255,255,255,.015)),
    #0c0d10;
}
.legacy-item,
.criterion {
  background:
    radial-gradient(circle at 88% 12%, rgba(229,201,121,.08), transparent 10rem),
    linear-gradient(180deg, rgba(255,255,255,.048), rgba(255,255,255,.018));
}
.portrait-card,
.gallery-frame {
  background:
    radial-gradient(circle at 84% 14%, rgba(229,201,121,.06), transparent 10rem),
    linear-gradient(180deg, rgba(255,255,255,.055), rgba(255,255,255,.02));
}
.footer {
  background:
    radial-gradient(circle at 14% 18%, rgba(207,164,69,.10), transparent 18rem),
    radial-gradient(circle at 86% 12%, rgba(229,201,121,.08), transparent 18rem),
    linear-gradient(180deg, #060606 0%, #030303 100%);
}
.footer::before { left: 50%; top: -18rem; transform: translateX(-50%); background: radial-gradient(circle, rgba(229,201,121,.10) 0%, rgba(229,201,121,0) 66%); }

@media (max-width: 980px) {
  .form-grid {
    grid-template-columns: 1fr;
  }
}


/* v21: Convocatoria arriba y formulario centrado; footer actualizado */
.form-section .form-grid {
  display: grid;
  grid-template-columns: 1fr !important;
  justify-items: center;
  align-items: start;
  gap: clamp(2rem, 4vw, 3.25rem);
  max-width: 980px;
  margin-left: auto;
  margin-right: auto;
}

.form-section .section-heading {
  width: min(100%, 860px);
  max-width: 860px;
  margin-left: auto;
  margin-right: auto;
  padding: 0 !important;
  text-align: center;
}

.form-section .section-heading h2 {
  max-width: 100% !important;
  margin-left: auto;
  margin-right: auto;
}

.form-section .section-heading p,
.form-section .form-note {
  max-width: 760px !important;
  margin-left: auto;
  margin-right: auto;
  text-align: center;
}

.form-section .eyebrow::after {
  margin-left: auto;
  margin-right: auto;
}

.award-form {
  width: min(100%, 860px);
  margin-left: auto;
  margin-right: auto;
}

.footer-award a,
.footer-bottom a {
  color: inherit;
  text-decoration: none;
  transition: color .2s ease;
}

.footer-award a:hover,
.footer-bottom a:hover {
  color: var(--gold-soft);
}


/* v23: ajuste de lectura en sección Adolf Horn */
.history .section-heading h2 {
  margin-bottom: clamp(1.35rem, 2.2vw, 2rem);
}

.history .body-copy {
  font-size: .92rem;
  line-height: 1.72;
}

.history .body-copy p {
  margin-top: 0;
  margin-bottom: .95rem;
}

/* v24: nuevo diseño visual para bloque 01 / 02 / 03 */
.stats-band {
  padding: clamp(1rem, 2vw, 1.5rem) 0 0;
  background: transparent;
  border: 0;
}

.stats-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 1.15rem;
  background: transparent;
}

.stat {
  position: relative;
  padding: 1.55rem 1.35rem 1.4rem;
  min-height: 210px;
  border: 1px solid rgba(207,164,69,.20);
  border-radius: 24px;
  background:
    radial-gradient(circle at 88% 16%, rgba(229,201,121,.10), transparent 10rem),
    linear-gradient(180deg, rgba(255,255,255,.05), rgba(255,255,255,.018)),
    rgba(12,13,16,.88);
  box-shadow: 0 18px 46px rgba(0,0,0,.24);
  overflow: hidden;
  backdrop-filter: blur(10px);
}

.stat::before {
  content: "";
  position: absolute;
  inset: 12px;
  border: 1px solid rgba(229,201,121,.08);
  border-radius: 18px;
  pointer-events: none;
}

.stat::after {
  content: "";
  position: absolute;
  left: 1.35rem;
  right: 1.35rem;
  bottom: 1.15rem;
  height: 1px;
  background: linear-gradient(90deg, rgba(229,201,121,0), rgba(229,201,121,.32), rgba(229,201,121,0));
}

.stat span {
  position: relative;
  z-index: 1;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 56px;
  height: 56px;
  margin-bottom: 1rem;
  border-radius: 999px;
  border: 1px solid rgba(229,201,121,.32);
  background: linear-gradient(180deg, rgba(229,201,121,.12), rgba(229,201,121,.03));
  color: var(--gold-soft);
  font-family: "Inter", var(--sans);
  font-size: 1rem;
  font-weight: 700;
  letter-spacing: .08em;
}

.stat strong {
  position: relative;
  z-index: 1;
  display: block;
  margin: 0 0 .7rem;
  color: var(--warm);
  font-family: var(--serif);
  font-size: 1.85rem;
  font-weight: 600;
  letter-spacing: -.01em;
}

.stat p {
  position: relative;
  z-index: 1;
  margin: 0;
  max-width: 22ch;
  color: rgba(247,242,232,.72);
  font-size: .95rem;
  line-height: 1.72;
}

@media (max-width: 980px) {
  .stats-grid {
    grid-template-columns: 1fr;
    gap: 1rem;
  }

  .stat {
    min-height: auto;
  }

  .stat p {
    max-width: none;
  }
}


/* v25: bloque Historia / Liderazgo / Jalisco más sobrio, ligero y sin choques visuales */
.stats-band {
  padding: 1.1rem 0 0.25rem !important;
  background: transparent !important;
  border: 0 !important;
}

.stats-grid {
  grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
  gap: .9rem !important;
  background: transparent !important;
  align-items: stretch;
}

.stat {
  min-height: 0 !important;
  padding: 1.15rem 1.1rem 1rem !important;
  border-radius: 18px !important;
  border: 1px solid rgba(207,164,69,.16) !important;
  box-shadow: 0 10px 26px rgba(0,0,0,.16) !important;
  background:
    linear-gradient(180deg, rgba(255,255,255,.035), rgba(255,255,255,.015)),
    rgba(12,13,16,.78) !important;
  backdrop-filter: blur(6px);
}

.stat::before,
.stat::after {
  display: none !important;
}

.stat span {
  width: auto !important;
  height: auto !important;
  margin-bottom: .55rem !important;
  padding: 0 !important;
  border: 0 !important;
  border-radius: 0 !important;
  background: none !important;
  color: var(--gold-soft) !important;
  font-family: var(--sans) !important;
  font-size: .82rem !important;
  font-weight: 700 !important;
  letter-spacing: .14em !important;
  line-height: 1;
}

.stat strong {
  margin: 0 0 .35rem !important;
  font-size: 1.45rem !important;
  line-height: 1.05 !important;
  font-weight: 600 !important;
}

.stat p {
  max-width: none !important;
  font-size: .92rem !important;
  line-height: 1.58 !important;
  color: rgba(247,242,232,.72) !important;
}

@media (max-width: 980px) {
  .stats-grid {
    grid-template-columns: 1fr !important;
    gap: .85rem !important;
  }

  .stats-band {
    padding-top: .75rem !important;
  }
}

/* v26: más aire entre separadores de sección y los cuadros de atributos */
.stats-band {
  padding-top: 2rem !important;
  padding-bottom: 1.2rem !important;
}

@media (max-width: 980px) {
  .stats-band {
    padding-top: 1.4rem !important;
    padding-bottom: .9rem !important;
  }
}

/* v27: más separación y aire visual entre separadores y bloque de atributos */
.page-divider + .stats-band {
  padding-top: 3.25rem !important;
}

.stats-band {
  padding-bottom: 2.35rem !important;
}

.stats-grid {
  gap: 1.15rem !important;
}

.stat {
  padding: 1.2rem 1.15rem 1.1rem !important;
}

.stats-band + .page-divider {
  margin-top: .85rem;
}

@media (max-width: 980px) {
  .page-divider + .stats-band {
    padding-top: 2.1rem !important;
  }

  .stats-band {
    padding-bottom: 1.6rem !important;
  }

  .stats-band + .page-divider {
    margin-top: .35rem;
  }
}


/* v29: respaldo de visibilidad si JavaScript se interrumpe */
.no-js .reveal {
  opacity: 1;
  transform: none;
}

/* v31: uniformar eybrows/títulos previos */
.eyebrow {
  color: var(--gold-soft) !important;
  font-size: .84rem !important;
  letter-spacing: .18em !important;
  font-weight: 700 !important;
  text-transform: uppercase;
}

.hero .eyebrow,
.section .eyebrow,
.center-heading .eyebrow,
.gallery-copy .eyebrow,
.form-section .eyebrow,
.history .eyebrow,
.audience .eyebrow,
.criteria .eyebrow,
.legacy .eyebrow {
  color: var(--gold-soft) !important;
  font-size: .84rem !important;
}

@media (max-width: 640px) {
  .eyebrow {
    font-size: .78rem !important;
    letter-spacing: .15em !important;
  }
}

/* v38: iconos para sección Historia / Liderazgo / Jalisco */
.stat {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
}

.stat-icon {
  width: 52px;
  height: 52px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  margin-bottom: .8rem;
  border: 1px solid rgba(229,201,121,.22);
  border-radius: 14px;
  background: linear-gradient(180deg, rgba(229,201,121,.08), rgba(229,201,121,.02));
  box-shadow: inset 0 1px 0 rgba(255,255,255,.04);
}

.stat-icon svg {
  width: 26px;
  height: 26px;
  fill: none;
  stroke: var(--gold-soft);
  stroke-width: 2.2;
  stroke-linecap: round;
  stroke-linejoin: round;
}

@media (max-width: 980px) {
  .stat {
    align-items: flex-start;
  }
}

/* v39: versión más viva para sección Historia / Liderazgo / Jalisco */
.stats-grid {
  gap: 1.25rem !important;
}

.stat {
  position: relative;
  padding: 1.35rem 1.2rem 1.15rem !important;
  border-radius: 22px !important;
  border: 1px solid rgba(207,164,69,.18) !important;
  background:
    radial-gradient(circle at 88% 12%, rgba(229,201,121,.10), transparent 9rem),
    radial-gradient(circle at 12% 100%, rgba(229,201,121,.07), transparent 8rem),
    linear-gradient(180deg, rgba(255,255,255,.045), rgba(255,255,255,.015)),
    rgba(12,13,16,.82) !important;
  box-shadow: 0 16px 34px rgba(0,0,0,.18) !important;
  overflow: hidden;
}

.stat::before {
  content: "";
  position: absolute;
  inset: 0 auto 0 0;
  width: 4px;
  background: linear-gradient(180deg, rgba(248,227,157,.95), rgba(191,141,47,.35));
  opacity: .9;
}

.stat::after {
  display: none !important;
}

.stat-top {
  width: 100%;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  margin-bottom: .9rem;
}

.stat-icon {
  position: relative;
  width: 64px;
  height: 64px;
  flex: 0 0 64px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  margin-bottom: 0 !important;
  border: 1px solid rgba(229,201,121,.24);
  border-radius: 18px;
  background:
    radial-gradient(circle at 30% 25%, rgba(255,255,255,.08), transparent 38%),
    linear-gradient(180deg, rgba(229,201,121,.12), rgba(229,201,121,.04));
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.06),
    0 10px 28px rgba(191,141,47,.14);
}

.stat-icon::before {
  content: "";
  position: absolute;
  inset: -10px;
  border-radius: 24px;
  background: radial-gradient(circle, rgba(229,201,121,.13), transparent 62%);
  z-index: 0;
}

.stat-icon svg {
  position: relative;
  z-index: 1;
  width: 32px;
  height: 32px;
}

.stat-icon .stroke-shape {
  fill: none;
  stroke: var(--gold-soft);
  stroke-width: 2.35;
  stroke-linecap: round;
  stroke-linejoin: round;
}

.stat-icon .accent-dot {
  fill: #f8e39d;
  opacity: .95;
}

.stat span {
  width: 48px !important;
  height: 48px !important;
  flex: 0 0 48px;
  margin: 0 !important;
  display: inline-flex !important;
  align-items: center;
  justify-content: center;
  border: 1px solid rgba(229,201,121,.22) !important;
  border-radius: 999px !important;
  background: linear-gradient(180deg, rgba(229,201,121,.10), rgba(229,201,121,.02)) !important;
  color: var(--gold-soft) !important;
  font-family: var(--sans) !important;
  font-size: .86rem !important;
  font-weight: 800 !important;
  letter-spacing: .12em !important;
  line-height: 1 !important;
}

.stat strong {
  font-size: 1.46rem !important;
  margin: 0 0 .38rem !important;
}

.stat p {
  font-size: .93rem !important;
  line-height: 1.6 !important;
}

@media (max-width: 980px) {
  .stats-grid {
    gap: 1rem !important;
  }

  .stat {
    padding: 1.2rem 1.05rem 1rem !important;
  }

  .stat-icon {
    width: 58px;
    height: 58px;
    flex-basis: 58px;
  }

  .stat span {
    width: 44px !important;
    height: 44px !important;
    flex-basis: 44px;
  }
}

/* v40: sección 01 / 02 / 03 mucho más visual e interactiva */
.stats-band {
  position: relative;
}

.stats-band::before {
  content: "";
  position: absolute;
  inset: 1rem 0 auto;
  height: 180px;
  background:
    radial-gradient(circle at 12% 10%, rgba(229,201,121,.10), transparent 18rem),
    radial-gradient(circle at 88% 40%, rgba(229,201,121,.08), transparent 16rem);
  pointer-events: none;
}

.stats-grid {
  position: relative;
  gap: 1.35rem !important;
}

.stats-grid::before {
  content: "";
  position: absolute;
  left: 8%;
  right: 8%;
  top: 50%;
  height: 1px;
  background: linear-gradient(90deg, transparent, rgba(229,201,121,.18), transparent);
  pointer-events: none;
}

.stat {
  position: relative;
  min-height: 238px;
  padding: 1.5rem 1.3rem 1.2rem !important;
  border-radius: 24px !important;
  border: 1px solid rgba(229,201,121,.18) !important;
  background:
    radial-gradient(circle at 100% 0%, rgba(248,227,157,.14), transparent 8rem),
    radial-gradient(circle at 0% 100%, rgba(191,141,47,.10), transparent 10rem),
    linear-gradient(180deg, rgba(255,255,255,.06), rgba(255,255,255,.018)),
    rgba(10,11,14,.9) !important;
  box-shadow: 0 18px 40px rgba(0,0,0,.22) !important;
  overflow: hidden;
  transform: translateY(0) scale(1);
  transition: transform .35s ease, box-shadow .35s ease, border-color .35s ease, background .35s ease;
  isolation: isolate;
}

.stat::before {
  width: 5px;
  background: linear-gradient(180deg, rgba(248,227,157,1), rgba(229,201,121,.7), rgba(191,141,47,.25));
}

.stat::after {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(120deg, transparent 20%, rgba(255,255,255,.06) 50%, transparent 78%);
  transform: translateX(-130%);
  opacity: 0;
  transition: transform .8s ease, opacity .4s ease;
  pointer-events: none;
}

.stat:hover,
.stat:focus-within {
  transform: translateY(-8px) scale(1.01);
  border-color: rgba(248,227,157,.40) !important;
  box-shadow: 0 28px 60px rgba(0,0,0,.28), 0 0 0 1px rgba(248,227,157,.08) inset !important;
}

.stat:hover::after,
.stat:focus-within::after {
  transform: translateX(130%);
  opacity: 1;
}

.stat-top {
  align-items: flex-start;
  margin-bottom: 1rem;
}

.stat-icon {
  width: 74px;
  height: 74px;
  flex-basis: 74px;
  border-radius: 22px;
  border: 1px solid rgba(248,227,157,.26);
  box-shadow:
    0 14px 30px rgba(191,141,47,.18),
    inset 0 1px 0 rgba(255,255,255,.08);
  transition: transform .35s ease, box-shadow .35s ease;
}

.stat:hover .stat-icon,
.stat:focus-within .stat-icon {
  transform: translateY(-4px) rotate(-2deg);
  box-shadow:
    0 20px 38px rgba(191,141,47,.22),
    inset 0 1px 0 rgba(255,255,255,.10);
}

.stat-icon::before {
  inset: -12px;
  opacity: .95;
}

.stat-icon svg {
  width: 38px;
  height: 38px;
}

.stat-icon-history {
  background:
    radial-gradient(circle at 35% 28%, rgba(255,255,255,.14), transparent 35%),
    linear-gradient(145deg, rgba(248,227,157,.22), rgba(191,141,47,.10));
}

.stat-icon-leadership {
  background:
    radial-gradient(circle at 35% 28%, rgba(255,255,255,.14), transparent 35%),
    linear-gradient(145deg, rgba(233,201,121,.24), rgba(156,107,24,.12));
}

.stat-icon-jalisco {
  background:
    radial-gradient(circle at 35% 28%, rgba(255,255,255,.14), transparent 35%),
    linear-gradient(145deg, rgba(248,227,157,.20), rgba(180,128,36,.11));
}

.stat span {
  width: auto !important;
  min-width: 56px;
  height: 36px !important;
  flex-basis: auto;
  padding: 0 .9rem !important;
  border-radius: 999px !important;
  background: linear-gradient(180deg, rgba(248,227,157,.14), rgba(191,141,47,.06)) !important;
  border-color: rgba(248,227,157,.22) !important;
  box-shadow: inset 0 1px 0 rgba(255,255,255,.06);
  font-size: .8rem !important;
}

.stat strong {
  position: relative;
  display: inline-block;
  margin: 0 0 .55rem !important;
  font-size: 1.62rem !important;
}

.stat strong::after {
  content: "";
  display: block;
  width: 58px;
  height: 2px;
  margin-top: .55rem;
  background: linear-gradient(90deg, rgba(248,227,157,.95), rgba(191,141,47,0));
}

.stat p {
  color: rgba(247,242,232,.76) !important;
  font-size: .95rem !important;
  line-height: 1.66 !important;
}

/* brillo sutil continuo */
@keyframes statFloat {
  0%, 100% { transform: translateY(0); }
  50% { transform: translateY(-3px); }
}

@keyframes iconPulse {
  0%, 100% { box-shadow: 0 14px 30px rgba(191,141,47,.16), inset 0 1px 0 rgba(255,255,255,.08); }
  50% { box-shadow: 0 18px 34px rgba(191,141,47,.22), 0 0 0 6px rgba(229,201,121,.04), inset 0 1px 0 rgba(255,255,255,.08); }
}

.stat:nth-child(1) { animation: statFloat 6s ease-in-out infinite; }
.stat:nth-child(2) { animation: statFloat 6s ease-in-out 1s infinite; }
.stat:nth-child(3) { animation: statFloat 6s ease-in-out 2s infinite; }

.stat-icon { animation: iconPulse 4.5s ease-in-out infinite; }

@media (prefers-reduced-motion: reduce) {
  .stat,
  .stat-icon {
    animation: none !important;
    transition: none !important;
  }
}

@media (max-width: 980px) {
  .stats-grid::before {
    display: none;
  }

  .stat {
    min-height: auto;
    padding: 1.3rem 1.1rem 1.1rem !important;
  }

  .stat-icon {
    width: 66px;
    height: 66px;
    flex-basis: 66px;
  }

  .stat-icon svg {
    width: 34px;
    height: 34px;
  }

  .stat strong {
    font-size: 1.48rem !important;
  }
}

/* v41: iconografía adicional y mayor riqueza visual general */
.legacy-item,
.criterion,
.gallery-frame,
.portrait-card,
.award-form,
.hero-card {
  position: relative;
}

.legacy-item,
.criterion {
  overflow: hidden;
}

.legacy-item::before,
.criterion::before {
  content: "";
  position: absolute;
  top: -48px;
  right: -48px;
  width: 150px;
  height: 150px;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(229,201,121,.10) 0%, rgba(229,201,121,0) 68%);
  pointer-events: none;
}

.card-icon {
  width: 58px;
  height: 58px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  margin-bottom: 1rem;
  border-radius: 18px;
  border: 1px solid rgba(229,201,121,.22);
  background:
    radial-gradient(circle at 35% 28%, rgba(255,255,255,.10), transparent 38%),
    linear-gradient(180deg, rgba(229,201,121,.14), rgba(191,141,47,.06));
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.06),
    0 10px 26px rgba(191,141,47,.14);
}

.card-icon svg {
  width: 28px;
  height: 28px;
  fill: none;
  stroke: var(--gold-soft);
  stroke-width: 2.2;
  stroke-linecap: round;
  stroke-linejoin: round;
}

.legacy-item h3,
.criterion h3 {
  position: relative;
  z-index: 1;
}

.legacy-item p,
.criterion p {
  position: relative;
  z-index: 1;
}

/* Variaciones sutiles por tipo de icono */
.icon-vision,
.icon-innovation { background: radial-gradient(circle at 35% 28%, rgba(255,255,255,.10), transparent 38%), linear-gradient(180deg, rgba(248,227,157,.16), rgba(191,141,47,.06)); }
.icon-bridges,
.icon-crown { background: radial-gradient(circle at 35% 28%, rgba(255,255,255,.10), transparent 38%), linear-gradient(180deg, rgba(229,201,121,.18), rgba(171,120,31,.06)); }
.icon-impact,
.icon-economic { background: radial-gradient(circle at 35% 28%, rgba(255,255,255,.10), transparent 38%), linear-gradient(180deg, rgba(248,227,157,.14), rgba(161,111,20,.06)); }
.icon-community,
.icon-social,
.icon-jobs,
.icon-jalisco-state { background: radial-gradient(circle at 35% 28%, rgba(255,255,255,.10), transparent 38%), linear-gradient(180deg, rgba(232,208,136,.15), rgba(181,127,30,.06)); }

/* Más vida general sin romper sobriedad */
.section-heading h2,
.center-heading h2 {
  text-wrap: balance;
}

.legacy-item:hover,
.criterion:hover,
.gallery-frame:hover,
.portrait-card:hover {
  transform: translateY(-5px);
  transition: transform .25s ease, border-color .25s ease, box-shadow .25s ease;
}

.legacy-item:hover .card-icon,
.criterion:hover .card-icon {
  transform: translateY(-3px) scale(1.03);
  transition: transform .25s ease, box-shadow .25s ease;
  box-shadow: inset 0 1px 0 rgba(255,255,255,.06), 0 14px 32px rgba(191,141,47,.20);
}

/* acentos dorados sutiles para cuadros del formulario y galería */
.gallery-frame::after,
.portrait-card::after,
.award-form::after {
  content: "";
  position: absolute;
  inset: auto 14px 0 14px;
  height: 1px;
  background: linear-gradient(90deg, transparent, rgba(229,201,121,.32), transparent);
  pointer-events: none;
}

@media (max-width: 980px) {
  .card-icon {
    width: 54px;
    height: 54px;
    border-radius: 16px;
  }
  .card-icon svg {
    width: 26px;
    height: 26px;
  }
}


/* v42: selector de tamaño de empresa */
select {
  width: 100%;
  border: 1px solid rgba(207,164,69,.22);
  border-radius: 12px;
  background: rgba(0,0,0,.32);
  color: var(--warm);
  padding: .95rem 1rem;
  font: inherit;
  outline: none;
  transition: border-color .2s ease, box-shadow .2s ease;
  appearance: none;
  background-image:
    linear-gradient(45deg, transparent 50%, rgba(229,201,121,.9) 50%),
    linear-gradient(135deg, rgba(229,201,121,.9) 50%, transparent 50%),
    linear-gradient(180deg, rgba(255,255,255,.02), rgba(255,255,255,0));
  background-position:
    calc(100% - 18px) 50%,
    calc(100% - 12px) 50%,
    0 0;
  background-size:
    6px 6px,
    6px 6px,
    100% 100%;
  background-repeat: no-repeat;
}

select:focus {
  border-color: var(--gold);
  box-shadow: 0 0 0 4px rgba(207,164,69,.12);
}

select:invalid {
  color: rgba(247,242,232,.52);
}

select option {
  background: #111216;
  color: #fff8ea;
}


/* v43: logo horizontal del header también en footer */
.footer-logo {
  width: min(100%, 300px) !important;
  max-width: 300px !important;
  height: auto !important;
}

@media (max-width: 640px) {
  .footer-logo {
    width: min(100%, 240px) !important;
    max-width: 240px !important;
  }
}


/* v52: sección de respaldo institucional y patrocinadores */
.sponsors {
  position: relative;
}

.sponsors::before {
  content: "";
  position: absolute;
  inset: 0;
  background:
    radial-gradient(circle at 10% 10%, rgba(229,201,121,.08), transparent 20rem),
    radial-gradient(circle at 90% 100%, rgba(229,201,121,.06), transparent 22rem);
  pointer-events: none;
}

.sponsors .center-heading {
  max-width: 900px;
}

.sponsors .center-heading h2,
.sponsors .center-heading p {
  max-width: 860px;
  margin-left: auto;
  margin-right: auto;
}

.sponsors-frame {
  position: relative;
  max-width: 1120px;
  margin: clamp(1.8rem, 3vw, 2.5rem) auto 0;
  padding: clamp(.8rem, 1.6vw, 1rem);
  border-radius: 26px;
  border: 1px solid rgba(229,201,121,.18);
  background: linear-gradient(180deg, rgba(255,255,255,.035), rgba(255,255,255,.012)), rgba(8,8,10,.64);
  box-shadow: 0 20px 46px rgba(0,0,0,.22);
  overflow: hidden;
}

.sponsors-frame::before {
  content: "";
  position: absolute;
  inset: 10px;
  border: 1px solid rgba(229,201,121,.08);
  border-radius: 18px;
  pointer-events: none;
}

.sponsors-frame img {
  display: block;
  width: 100%;
  height: auto;
  border-radius: 18px;
  background: transparent;
}

/* v50: integración final del logo del premio al inicio sin romper el hero */
.hero-card-award {
  display: flex;
  flex-direction: column;
  gap: .85rem;
  align-items: flex-start;
  padding: 1.35rem 1.25rem 1.45rem !important;
}

.hero-card-logo {
  display: block;
  width: min(100%, 255px);
  height: auto;
  margin: 0 0 .15rem;
  opacity: .98;
  filter: drop-shadow(0 10px 22px rgba(0,0,0,.34));
}

.hero-card-award .card-line {
  margin-top: .1rem;
}

/* Ajuste de aire en hero: el logo vive en la tarjeta, no debajo del título */
.hero-copy {
  max-width: 760px;
}

.hero-subtitle {
  margin-bottom: 1.15rem !important;
}

/* Evita repetición visual con la imagen, manteniendo jerarquía premium */
.sponsors .eyebrow {
  color: var(--gold-soft);
}

.sponsors .center-heading {
  max-width: 900px;
}

.sponsors .center-heading h2 {
  max-width: 840px;
  margin-left: auto;
  margin-right: auto;
}

.sponsors .center-heading p {
  max-width: 860px;
  margin-left: auto;
  margin-right: auto;
}

/* PNG final del premio en footer, transparente y de alta calidad */
.footer-award-logo {
  display: block;
  width: min(100%, 300px);
  height: auto;
  margin-top: 1.15rem;
  opacity: .98;
  filter: drop-shadow(0 10px 24px rgba(0,0,0,.28));
}

@media (max-width: 980px) {
  .hero-card-logo {
    width: min(100%, 230px);
  }

  .footer-award-logo {
    width: min(100%, 230px);
  }
}

@media (max-width: 640px) {
  .hero-card-award {
    align-items: flex-start;
  }

  .hero-card-logo {
    width: min(100%, 210px);
  }
}


/* v51: logos del footer enlazan al inicio */
.footer-logo-link,
.footer-award-logo-link {
  display: inline-block;
  width: fit-content;
  max-width: 100%;
  line-height: 0;
}

.footer-logo-link:hover,
.footer-award-logo-link:hover {
  opacity: .86;
}

.footer-logo-link:focus-visible,
.footer-award-logo-link:focus-visible {
  outline: 2px solid var(--gold-soft);
  outline-offset: 6px;
  border-radius: 10px;
}


/* v54: rediseño del bloque del logo del premio en hero para mayor visibilidad y mejor mobile */
.hero-grid {
  align-items: center;
}

.hero-card-award {
  display: flex;
  flex-direction: column;
  align-items: stretch;
  gap: 1rem;
  padding: 1.5rem !important;
  border-radius: 24px;
  background:
    radial-gradient(circle at 50% 0%, rgba(229,201,121,.12), transparent 55%),
    linear-gradient(180deg, rgba(255,255,255,.06), rgba(255,255,255,.018)),
    rgba(10,11,13,.72);
  border: 1px solid rgba(229,201,121,.18);
}

.hero-award-kicker {
  margin: 0;
  color: var(--gold-soft) !important;
  text-transform: uppercase;
  letter-spacing: .16em;
  font-size: .76rem !important;
  font-weight: 700;
}

.hero-award-logo-wrap {
  display: grid;
  place-items: center;
  padding: 1.1rem 1rem;
  border-radius: 20px;
  border: 1px solid rgba(229,201,121,.14);
  background:
    radial-gradient(circle at 50% 18%, rgba(229,201,121,.10), transparent 48%),
    linear-gradient(180deg, rgba(255,255,255,.03), rgba(255,255,255,.01)),
    rgba(6,7,9,.42);
  box-shadow: inset 0 1px 0 rgba(255,255,255,.04);
}

.hero-card-logo {
  width: min(100%, 290px);
  max-width: 100%;
  height: auto;
  margin: 0;
  filter: drop-shadow(0 12px 22px rgba(0,0,0,.28));
}

.hero-award-caption {
  margin: 0;
  color: rgba(247,242,232,.78);
  font-size: .98rem;
  line-height: 1.65;
}

@media (min-width: 981px) {
  .hero-card-award {
    margin-top: 3.5rem;
  }
}

@media (max-width: 980px) {
  .hero-card-award {
    max-width: 100%;
    margin-top: .35rem;
    padding: 1.25rem !important;
    text-align: center;
    align-items: center;
  }

  .hero-award-logo-wrap {
    width: 100%;
    padding: 1rem .8rem;
  }

  .hero-card-logo {
    width: min(100%, 320px);
  }

  .hero-award-kicker {
    text-align: center;
  }

  .hero-award-caption {
    max-width: 38ch;
    margin-inline: auto;
    font-size: .94rem;
  }
}

@media (max-width: 640px) {
  .hero-card-award {
    padding: 1.1rem !important;
    gap: .85rem;
    border-radius: 20px;
  }

  .hero-award-logo-wrap {
    padding: .95rem .75rem;
    border-radius: 16px;
  }

  .hero-card-logo {
    width: min(100%, 280px);
  }

  .hero-award-kicker {
    font-size: .72rem !important;
    letter-spacing: .14em;
  }

  .hero-award-caption {
    font-size: .9rem;
    line-height: 1.58;
  }
}


/* v55: simplificación del bloque del logo del premio para mejor sinergia visual */
.hero-card-award {
  justify-content: center;
  align-items: center;
  padding: 1.15rem !important;
  background:
    radial-gradient(circle at 50% 12%, rgba(229,201,121,.12), transparent 54%),
    linear-gradient(180deg, rgba(255,255,255,.045), rgba(255,255,255,.015)),
    rgba(10,11,13,.66);
  border: 1px solid rgba(229,201,121,.18);
  box-shadow: 0 18px 42px rgba(0,0,0,.22);
}

.hero-award-logo-wrap {
  width: 100%;
  display: grid;
  place-items: center;
  padding: 1.2rem 1rem;
  border-radius: 20px;
  border: 1px solid rgba(229,201,121,.14);
  background:
    radial-gradient(circle at 50% 20%, rgba(229,201,121,.09), transparent 48%),
    linear-gradient(180deg, rgba(255,255,255,.025), rgba(255,255,255,.008)),
    rgba(7,8,10,.34);
}

.hero-card-logo {
  width: min(100%, 300px);
  height: auto;
  margin: 0;
  filter: drop-shadow(0 12px 24px rgba(0,0,0,.30));
}

@media (min-width: 981px) {
  .hero-card-award {
    margin-top: 3.8rem;
    min-height: 240px;
  }
}

@media (max-width: 980px) {
  .hero-card-award {
    max-width: 100%;
    margin-top: .5rem;
    padding: 1rem !important;
  }

  .hero-award-logo-wrap {
    padding: 1rem .75rem;
  }

  .hero-card-logo {
    width: min(100%, 320px);
  }
}

@media (max-width: 640px) {
  .hero-card-award {
    border-radius: 18px;
    padding: .9rem !important;
  }

  .hero-award-logo-wrap {
    border-radius: 16px;
    padding: .85rem .65rem;
  }

  .hero-card-logo {
    width: min(100%, 270px);
  }
}


/* v56: rediseño completo de la sección de ganadores anteriores */
.winners-history {
  position: relative;
  background:
    radial-gradient(circle at 16% 16%, rgba(229,201,121,.10), transparent 22rem),
    radial-gradient(circle at 84% 82%, rgba(229,201,121,.08), transparent 22rem),
    #0d0e10;
}

.winners-history::before {
  content: "";
  position: absolute;
  inset: 0;
  background:
    linear-gradient(180deg, rgba(255,255,255,.015), transparent 18%),
    linear-gradient(0deg, rgba(255,255,255,.015), transparent 18%);
  pointer-events: none;
}

.winners-summary {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: .8rem;
  margin-top: 1.3rem;
}

.summary-chip {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 40px;
  padding: .7rem 1rem;
  border-radius: 999px;
  border: 1px solid rgba(229,201,121,.18);
  background: linear-gradient(180deg, rgba(229,201,121,.10), rgba(229,201,121,.03));
  color: var(--warm);
  font-size: .9rem;
  line-height: 1.3;
}

.featured-winner {
  display: grid;
  grid-template-columns: minmax(280px, 380px) 1fr;
  gap: clamp(1.5rem, 3vw, 2.5rem);
  margin-top: clamp(2rem, 4vw, 3rem);
  padding: clamp(1.2rem, 2vw, 1.4rem);
  border-radius: 28px;
  border: 1px solid rgba(229,201,121,.18);
  background:
    radial-gradient(circle at 12% 12%, rgba(229,201,121,.09), transparent 20rem),
    linear-gradient(180deg, rgba(255,255,255,.05), rgba(255,255,255,.015)),
    rgba(10,11,13,.78);
  box-shadow: 0 22px 48px rgba(0,0,0,.22);
  align-items: center;
}

.featured-winner-media {
  margin: 0;
  border-radius: 24px;
  overflow: hidden;
  border: 1px solid rgba(229,201,121,.16);
  background: rgba(255,255,255,.02);
}

.featured-winner-media img {
  display: block;
  width: 100%;
  aspect-ratio: 1/1;
  object-fit: cover;
}

.featured-winner-content {
  max-width: 62ch;
}

.featured-label {
  display: inline-flex;
  align-items: center;
  gap: .55rem;
  margin: 0 0 .8rem;
  padding: .45rem .8rem;
  border-radius: 999px;
  border: 1px solid rgba(229,201,121,.18);
  background: linear-gradient(180deg, rgba(229,201,121,.12), rgba(229,201,121,.03));
  color: var(--gold-soft);
  font-size: .82rem;
  text-transform: uppercase;
  letter-spacing: .13em;
  font-weight: 700;
}

.featured-winner-content h3 {
  margin: 0;
  font-size: clamp(2rem, 3vw, 2.6rem);
}

.featured-company {
  margin: .5rem 0 1rem;
  color: var(--gold-soft) !important;
  font-size: 1rem;
  font-weight: 700;
  letter-spacing: .04em;
  text-transform: uppercase;
}

.featured-winner-content > p:last-of-type {
  margin-bottom: 1rem;
}

.featured-points {
  margin: 1rem 0 0;
  padding: 0;
  list-style: none;
  display: grid;
  gap: .75rem;
}

.featured-points li {
  position: relative;
  padding-left: 1.2rem;
  color: rgba(247,242,232,.76);
  line-height: 1.6;
}

.featured-points li::before {
  content: "";
  position: absolute;
  left: 0;
  top: .65rem;
  width: 7px;
  height: 7px;
  border-radius: 50%;
  background: var(--gold-soft);
  box-shadow: 0 0 0 4px rgba(229,201,121,.08);
}

.archive-heading {
  margin: clamp(2rem, 4vw, 3rem) auto 1.2rem;
  max-width: 72ch;
  text-align: center;
}

.archive-heading h3 {
  margin: .25rem 0 .8rem;
  font-size: clamp(1.8rem, 2.7vw, 2.4rem);
}

.archive-heading p:last-child {
  color: rgba(247,242,232,.72);
}

.winners-archive {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 1.15rem;
  margin-top: 1.4rem;
}

.winner-card {
  position: relative;
  display: flex;
  flex-direction: column;
  height: 100%;
  border-radius: 22px;
  overflow: hidden;
  border: 1px solid rgba(229,201,121,.16);
  background:
    radial-gradient(circle at 100% 0%, rgba(229,201,121,.08), transparent 8rem),
    linear-gradient(180deg, rgba(255,255,255,.04), rgba(255,255,255,.01)),
    rgba(9,10,12,.84);
  box-shadow: 0 18px 34px rgba(0,0,0,.16);
  transition: transform .28s ease, border-color .28s ease, box-shadow .28s ease;
}

.winner-card:hover {
  transform: translateY(-6px);
  border-color: rgba(229,201,121,.28);
  box-shadow: 0 24px 42px rgba(0,0,0,.22);
}

.winner-card-media {
  padding: .85rem .85rem 0;
}

.winner-card-media img {
  display: block;
  width: 100%;
  aspect-ratio: 1/1;
  object-fit: cover;
  border-radius: 16px;
}

.winner-card-body {
  display: flex;
  flex-direction: column;
  gap: .45rem;
  padding: .95rem 1rem 1.1rem;
}

.winner-generation {
  display: inline-flex;
  align-self: flex-start;
  padding: .38rem .65rem;
  border-radius: 999px;
  border: 1px solid rgba(229,201,121,.16);
  background: rgba(229,201,121,.05);
  color: var(--gold-soft);
  font-size: .78rem;
  line-height: 1;
  text-transform: uppercase;
  letter-spacing: .09em;
  font-weight: 700;
}

.winner-card h4 {
  margin: 0;
  font-size: 1.28rem;
  line-height: 1.2;
}

.winner-company {
  margin: 0;
  color: rgba(247,242,232,.72);
  font-size: .96rem;
}

@media (max-width: 1120px) {
  .winners-archive {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
}

@media (max-width: 980px) {
  .featured-winner {
    grid-template-columns: 1fr;
  }

  .featured-winner-content {
    max-width: none;
  }

  .winners-archive {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 640px) {
  .summary-chip {
    width: 100%;
  }

  .featured-winner {
    padding: 1rem;
    border-radius: 22px;
  }

  .featured-winner-media {
    border-radius: 18px;
  }

  .archive-heading {
    margin-top: 1.7rem;
  }

  .winners-archive {
    grid-template-columns: 1fr;
    gap: 1rem;
  }

  .winner-card-media {
    padding: .8rem .8rem 0;
  }

  .winner-card-body {
    padding: .9rem .95rem 1rem;
  }

  .winner-card h4 {
    font-size: 1.18rem;
  }
}


/* v58: fotos de ganadores con fondo blanco y logo del premio más limpio en hero */
.hero-grid {
  grid-template-columns: 1fr !important;
  align-items: end !important;
}

.hero-copy {
  max-width: 820px;
}

.hero-award-mark {
  margin: 1.55rem 0 0;
  max-width: 410px;
}

.hero-award-mark img {
  display: block;
  width: min(100%, 360px);
  height: auto;
  filter: drop-shadow(0 10px 20px rgba(0,0,0,.22));
}

.featured-winner-media img,
.winner-card-media img {
  background: #ffffff !important;
}

@media (max-width: 980px) {
  .hero-award-mark {
    max-width: 360px;
    margin-top: 1.25rem;
  }

  .hero-award-mark img {
    width: min(100%, 320px);
  }
}

@media (max-width: 640px) {
  .hero-award-mark {
    margin: 1rem auto 0;
    text-align: center;
    max-width: 300px;
  }

  .hero-award-mark img {
    width: min(100%, 280px);
    margin-inline: auto;
  }
}


/* v59: integración más limpia del logo del premio en hero */
.hero-copy {
  max-width: 860px;
}

.hero-subtitle {
  margin-bottom: .55rem !important;
}

.hero-award-mark {
  display: block;
  margin: .15rem 0 1.15rem;
  max-width: 420px;
}

.hero-award-mark img {
  display: block;
  width: min(100%, 360px);
  height: auto;
  filter: drop-shadow(0 10px 18px rgba(0,0,0,.22));
}

.hero-lede {
  max-width: 690px;
}

@media (max-width: 980px) {
  .hero-award-mark {
    max-width: 360px;
    margin: .1rem 0 1rem;
  }

  .hero-award-mark img {
    width: min(100%, 320px);
  }
}

@media (max-width: 640px) {
  .hero-award-mark {
    max-width: 300px;
    margin: .05rem auto .95rem;
    text-align: center;
  }

  .hero-award-mark img {
    width: min(100%, 270px);
    margin-inline: auto;
  }
}


/* v60: logo del premio trasladado a Sobre el premio */
.intro .split {
  align-items: center;
}

.intro-award-mark {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: flex-start;
  margin: 1.35rem 0 0;
  padding-top: 1.1rem;
  max-width: 420px;
}

.intro-award-mark::before {
  content: "";
  position: absolute;
  left: 0;
  top: 0;
  width: 92px;
  height: 1px;
  background: linear-gradient(90deg, rgba(229,201,121,.95), rgba(229,201,121,0));
}

.intro-award-mark img {
  display: block;
  width: min(100%, 340px);
  height: auto;
  filter: drop-shadow(0 10px 20px rgba(0,0,0,.18));
}

@media (max-width: 980px) {
  .intro-award-mark {
    max-width: 360px;
    margin-top: 1.1rem;
  }

  .intro-award-mark img {
    width: min(100%, 310px);
  }
}

@media (max-width: 640px) {
  .intro-award-mark {
    justify-content: center;
    margin: 1rem auto 0;
    padding-top: .9rem;
    max-width: 300px;
  }

  .intro-award-mark::before {
    left: 50%;
    transform: translateX(-50%);
    width: 84px;
  }

  .intro-award-mark img {
    width: min(100%, 270px);
    margin-inline: auto;
  }
}


/* v61: logo del premio arriba del titular en Sobre el premio */
.intro-award-mark {
  margin: .95rem 0 1.15rem;
}

@media (max-width: 980px) {
  .intro-award-mark {
    margin: .85rem 0 1rem;
  }
}

@media (max-width: 640px) {
  .intro-award-mark {
    margin: .8rem auto .95rem;
  }
}


/* v66: retratos sobre fondo blanco limpio */
.winner-card-media img,
.featured-winner-media img {
  background: #ffffff !important;
}


/* v69: ajuste de resumen en sección de ganadores anteriores */
.winners-summary {
  margin-top: 1.4rem;
}

.summary-chip {
  padding: .8rem 1.15rem;
  font-size: .92rem;
  letter-spacing: .02em;
}


/* v71: página de gracias alineada con header, hero y footer del sitio */
.thanks-page .site-header {
  position: sticky;
}

.thanks-hero {
  min-height: 78vh;
  display: grid;
  align-items: center;
  padding-top: 6rem;
}

.thanks-hero-grid {
  position: relative;
  z-index: 1;
  display: grid;
  place-items: center;
}

.thanks-card {
  width: min(100%, 820px);
  text-align: center;
  padding: clamp(2rem, 5vw, 3.5rem);
  border: 1px solid rgba(229,201,121,.18);
  border-radius: 28px;
  background:
    radial-gradient(circle at 50% 0%, rgba(229,201,121,.12), transparent 55%),
    linear-gradient(180deg, rgba(255,255,255,.06), rgba(255,255,255,.018)),
    rgba(10,11,13,.72);
  box-shadow: 0 22px 52px rgba(0,0,0,.26);
  backdrop-filter: blur(14px);
}

.thanks-award-mark {
  margin: .75rem auto 1.2rem;
  display: flex;
  justify-content: center;
}

.thanks-award-mark img {
  display: block;
  width: min(100%, 330px);
  height: auto;
  filter: drop-shadow(0 10px 22px rgba(0,0,0,.28));
}

.thanks-card h1 {
  margin-bottom: .9rem;
}

.thanks-card .hero-lede {
  margin-left: auto;
  margin-right: auto;
}

.thanks-card .hero-actions {
  justify-content: center;
}

@media (max-width: 640px) {
  .thanks-hero {
    min-height: 72vh;
    padding-top: 5.5rem;
  }

  .thanks-card {
    border-radius: 22px;
    padding: 1.5rem;
  }

  .thanks-award-mark img {
    width: min(100%, 260px);
  }
}


/* v72: centrado general en mobile */
@media (max-width: 640px) {
  .hero-copy,
  .section-heading,
  .center-heading,
  .body-copy,
  .gallery-copy,
  .archive-heading,
  .featured-winner-content,
  .winner-card-body,
  .legacy-item,
  .criterion,
  .stat,
  .cta-card,
  .form-copy,
  .thanks-card {
    text-align: center !important;
  }

  .hero-copy,
  .section-heading,
  .body-copy,
  .gallery-copy,
  .archive-heading,
  .featured-winner-content,
  .form-copy,
  .thanks-card {
    margin-left: auto;
    margin-right: auto;
  }

  .hero-actions,
  .winners-summary,
  .featured-points,
  .footer-links {
    justify-content: center;
  }

  .hero-actions {
    align-items: center;
  }

  .intro-award-mark,
  .portrait-card,
  .gallery-frame,
  .featured-winner-media,
  .sponsors-frame {
    margin-left: auto !important;
    margin-right: auto !important;
  }

  .portrait-card img,
  .gallery-frame img,
  .featured-winner-media img,
  .winner-card-media img,
  .sponsors-frame img,
  .intro-award-mark img {
    margin-left: auto;
    margin-right: auto;
  }

  .legacy-item,
  .criterion,
  .stat,
  .winner-card,
  .featured-winner,
  .award-form {
    align-items: center !important;
  }

  .card-icon,
  .stat-icon {
    margin-left: auto;
    margin-right: auto;
  }

  .stat-top {
    justify-content: center !important;
  }

  .winner-generation,
  .featured-label {
    align-self: center !important;
  }

  .featured-points li {
    padding-left: 0;
  }

  .featured-points li::before {
    display: none;
  }

  .footer-grid,
  .footer-brand-block,
  .footer-bottom {
    text-align: center;
    justify-items: center;
  }

  .footer-logo-link,
  .footer-award-logo-link {
    margin-left: auto;
    margin-right: auto;
  }
}


/* v73: mobile centrado + menú hamburguesa correcto */
@media (max-width: 640px) {
  #dirigido .body-copy,
  #dirigido .body-copy p,
  #dirigido .check-list,
  #dirigido .check-list li {
    text-align: center !important;
  }

  #dirigido .check-list {
    padding-left: 0 !important;
    list-style-position: inside;
  }

  #dirigido .check-list li {
    margin-left: auto;
    margin-right: auto;
  }

  .footer-brand-block {
    align-items: center !important;
    text-align: center !important;
  }

  .footer-award-logo,
  .footer-award-logo-link {
    display: block !important;
    margin-left: auto !important;
    margin-right: auto !important;
  }

  .thanks-page .footer-brand-block,
  .thanks-page .footer-column,
  .thanks-page .footer-contact,
  .thanks-page .footer-links,
  .thanks-page .footer-bottom {
    align-items: center !important;
    text-align: center !important;
    justify-items: center !important;
  }
}

/* Botón hamburguesa */
.nav-toggle {
  min-width: 44px;
  min-height: 44px;
  display: none;
  align-items: center;
  justify-content: center;
  gap: 4px;
  padding: 0;
  border-radius: 999px;
}

.nav-toggle span {
  display: block;
  width: 20px;
  height: 2px;
  border-radius: 999px;
  background: var(--warm);
  transition: transform .2s ease, opacity .2s ease;
}

.nav-toggle[aria-expanded="true"] span:nth-child(1) {
  transform: translateY(6px) rotate(45deg);
}

.nav-toggle[aria-expanded="true"] span:nth-child(2) {
  opacity: 0;
}

.nav-toggle[aria-expanded="true"] span:nth-child(3) {
  transform: translateY(-6px) rotate(-45deg);
}

@media (max-width: 980px) {
  .nav-toggle {
    display: inline-flex !important;
    flex-direction: column;
    color: transparent;
    font-size: 0;
    line-height: 0;
  }

  .nav-links {
    position: fixed;
    top: 74px;
    left: 50%;
    transform: translateX(-50%) translateY(-12px);
    width: min(calc(100% - 2rem), 420px);
    display: grid !important;
    gap: .35rem;
    padding: 1rem;
    border: 1px solid rgba(229,201,121,.18);
    border-radius: 20px;
    background: rgba(5,5,5,.94);
    backdrop-filter: blur(18px);
    box-shadow: 0 24px 50px rgba(0,0,0,.28);
    opacity: 0;
    pointer-events: none;
    visibility: hidden;
    transition: opacity .2s ease, transform .2s ease, visibility .2s ease;
    z-index: 100;
  }

  .nav-links.open {
    opacity: 1;
    pointer-events: auto;
    visibility: visible;
    transform: translateX(-50%) translateY(0);
  }

  .nav-links a {
    display: flex;
    justify-content: center;
    text-align: center;
    width: 100%;
    padding: .85rem 1rem;
    border-radius: 14px;
  }

  .nav-links .nav-cta {
    margin-top: .25rem;
  }

  .site-header .nav {
    position: relative;
  }
}

@media (max-width: 640px) {
  .nav-links {
    top: 68px;
    width: min(calc(100% - 1.25rem), 380px);
  }
}


/* v78: menú hamburguesa visible por encima de todo en móvil */
@media (max-width: 980px) {
  body.menu-open {
    overflow: hidden;
  }

  body.menu-open::before {
    content: "";
    position: fixed;
    inset: 0;
    z-index: 998;
    background: rgba(0, 0, 0, .78);
    backdrop-filter: blur(8px);
  }

  .site-header {
    z-index: 1000 !important;
  }

  .nav-toggle {
    position: relative;
    z-index: 1002 !important;
  }

  .nav-links {
    position: fixed !important;
    top: 82px !important;
    left: 50% !important;
    right: auto !important;
    transform: translateX(-50%) translateY(-10px) !important;
    z-index: 1001 !important;
    width: min(calc(100vw - 2rem), 420px) !important;
    max-height: calc(100vh - 110px);
    overflow-y: auto;
    display: grid !important;
    grid-template-columns: 1fr !important;
    gap: .45rem !important;
    padding: 1.1rem !important;
    border: 1px solid rgba(229, 201, 121, .24) !important;
    border-radius: 22px !important;
    background:
      radial-gradient(circle at top, rgba(229,201,121,.16), transparent 38%),
      rgba(7, 7, 8, .98) !important;
    box-shadow: 0 28px 80px rgba(0,0,0,.55) !important;
    backdrop-filter: blur(22px);
    opacity: 0 !important;
    visibility: hidden !important;
    pointer-events: none !important;
  }

  .nav-links.open {
    opacity: 1 !important;
    visibility: visible !important;
    pointer-events: auto !important;
    transform: translateX(-50%) translateY(0) !important;
  }

  .nav-links a {
    display: flex !important;
    width: 100% !important;
    justify-content: center !important;
    align-items: center !important;
    padding: .95rem 1rem !important;
    border-radius: 15px !important;
    text-align: center !important;
    background: rgba(255,255,255,.045);
    color: var(--cream) !important;
  }

  .nav-links a:hover,
  .nav-links a:focus-visible {
    background: rgba(229,201,121,.12);
  }

  .nav-links .nav-cta {
    margin-top: .25rem !important;
    background: var(--gold-gradient) !important;
    color: #151007 !important;
  }

  body.menu-open main,
  body.menu-open footer {
    pointer-events: none;
  }
}

@media (max-width: 640px) {
  .nav-links {
    top: 76px !important;
    width: min(calc(100vw - 1.25rem), 380px) !important;
  }
}


/* v80: menú hamburguesa full-screen y CTA visible */
@media (max-width: 980px) {
  body.menu-open {
    overflow: hidden !important;
  }

  body.menu-open::before {
    content: "";
    position: fixed;
    inset: 0;
    z-index: 998;
    background: rgba(0, 0, 0, .86);
    backdrop-filter: blur(10px);
  }

  body.menu-open .site-header {
    background: transparent !important;
    border-color: transparent !important;
    box-shadow: none !important;
  }

  body.menu-open .brand {
    opacity: 0;
    pointer-events: none;
  }

  .site-header {
    z-index: 1200 !important;
  }

  .nav-toggle {
    position: relative;
    z-index: 1302 !important;
  }

  .nav-links {
    position: fixed !important;
    inset: 0 !important;
    width: 100vw !important;
    height: 100dvh !important;
    max-height: none !important;
    overflow-y: auto !important;
    z-index: 1300 !important;
    display: flex !important;
    flex-direction: column !important;
    align-items: center !important;
    justify-content: center !important;
    gap: .75rem !important;
    padding: 6.5rem 1.25rem 2rem !important;
    margin: 0 !important;
    border: 0 !important;
    border-radius: 0 !important;
    background:
      radial-gradient(circle at top right, rgba(229,201,121,.18), transparent 34%),
      radial-gradient(circle at bottom left, rgba(207,164,69,.12), transparent 38%),
      rgba(4, 4, 5, .98) !important;
    box-shadow: none !important;
    backdrop-filter: blur(20px);
    opacity: 0 !important;
    visibility: hidden !important;
    pointer-events: none !important;
    transform: none !important;
    transition: opacity .2s ease, visibility .2s ease !important;
  }

  .nav-links.open {
    opacity: 1 !important;
    visibility: visible !important;
    pointer-events: auto !important;
    transform: none !important;
  }

  .nav-links a {
    width: min(100%, 360px) !important;
    min-height: 52px !important;
    display: flex !important;
    justify-content: center !important;
    align-items: center !important;
    padding: .95rem 1rem !important;
    border: 1px solid rgba(229, 201, 121, .18) !important;
    border-radius: 18px !important;
    background: rgba(255, 255, 255, .055) !important;
    color: #fff8ea !important;
    text-align: center !important;
    font-size: 1.02rem !important;
    font-weight: 700 !important;
    letter-spacing: .01em !important;
    box-shadow: 0 12px 28px rgba(0,0,0,.18);
  }

  .nav-links a:hover,
  .nav-links a:focus-visible {
    background: rgba(229, 201, 121, .14) !important;
    color: #ffffff !important;
  }

  .nav-links a.nav-cta {
    margin-top: .45rem !important;
    display: flex !important;
    opacity: 1 !important;
    visibility: visible !important;
    background: linear-gradient(135deg, #cfa445, #f1d889) !important;
    color: #14100a !important;
    border: 1px solid rgba(255, 238, 176, .85) !important;
    box-shadow: 0 16px 38px rgba(207,164,69,.34) !important;
    font-weight: 900 !important;
  }

  .nav-links a.nav-cta::before {
    content: "Enviar postulación";
  }

  .nav-links a.nav-cta {
    font-size: 0 !important;
  }

  .nav-links a.nav-cta::before {
    font-size: 1.03rem !important;
    line-height: 1 !important;
  }

  body.menu-open main,
  body.menu-open footer {
    visibility: hidden;
  }
}

@media (max-width: 640px) {
  .nav-links {
    padding-top: 5.75rem !important;
  }

  .nav-links a {
    width: min(100%, 330px) !important;
  }
}


/* v81: Denisse integrada al archivo histórico y tarjetas centradas */
.winners-archive {
  justify-items: center;
}

.winners-archive .winner-card {
  width: 100%;
  max-width: 100%;
}

.winners-archive .winner-card-body {
  align-items: center;
  text-align: center;
}

.winners-archive .winner-generation {
  align-self: center;
}

.winners-archive .winner-company,
.winners-archive .winner-card h4 {
  text-align: center;
}

.winners-archive .winner-card:last-child:nth-child(4n + 1) {
  grid-column: 2 / 4;
  width: min(100%, 300px);
  justify-self: center;
}

@media (max-width: 1100px) {
  .winners-archive .winner-card:last-child:nth-child(4n + 1) {
    grid-column: auto;
    width: 100%;
  }
}


/* FIX FINAL: menú hamburguesa móvil estable, sin distorsión y sin scroll del fondo */
@media (max-width: 980px) {
  html.menu-open,
  body.menu-open {
    overflow: hidden !important;
    height: 100% !important;
    overscroll-behavior: none !important;
  }

  body.menu-open {
    position: fixed !important;
    width: 100% !important;
    left: 0 !important;
    right: 0 !important;
    touch-action: none !important;
  }

  body.menu-open::before {
    content: "";
    position: fixed !important;
    inset: 0 !important;
    z-index: 9998 !important;
    background: rgba(0, 0, 0, .92) !important;
    backdrop-filter: blur(12px);
  }

  body.menu-open .site-header {
    position: fixed !important;
    inset: 0 0 auto 0 !important;
    z-index: 10000 !important;
    background: transparent !important;
    border: 0 !important;
    box-shadow: none !important;
  }

  body.menu-open .brand {
    opacity: 0 !important;
    pointer-events: none !important;
  }

  .nav-toggle {
    position: relative !important;
    z-index: 10003 !important;
    flex-shrink: 0 !important;
  }

  .nav-links {
    position: fixed !important;
    inset: 0 !important;
    top: 0 !important;
    left: 0 !important;
    right: 0 !important;
    bottom: 0 !important;
    width: 100vw !important;
    min-width: 100vw !important;
    max-width: none !important;
    height: 100vh !important;
    height: 100dvh !important;
    max-height: none !important;
    margin: 0 !important;
    padding: max(6rem, env(safe-area-inset-top)) 1.25rem max(2rem, env(safe-area-inset-bottom)) !important;
    border: 0 !important;
    border-radius: 0 !important;
    transform: none !important;
    translate: none !important;
    overflow-y: auto !important;
    -webkit-overflow-scrolling: touch;
    overscroll-behavior: contain !important;
    z-index: 10001 !important;

    display: flex !important;
    flex-direction: column !important;
    align-items: center !important;
    justify-content: center !important;
    gap: .8rem !important;

    background:
      radial-gradient(circle at 85% 10%, rgba(229,201,121,.18), transparent 34%),
      radial-gradient(circle at 12% 88%, rgba(207,164,69,.14), transparent 36%),
      rgba(4, 4, 5, .985) !important;
    box-shadow: none !important;
    backdrop-filter: blur(22px);

    opacity: 0 !important;
    visibility: hidden !important;
    pointer-events: none !important;
    transition: opacity .18s ease, visibility .18s ease !important;
  }

  .nav-links.open {
    opacity: 1 !important;
    visibility: visible !important;
    pointer-events: auto !important;
    transform: none !important;
  }

  .nav-links a {
    width: min(100%, 360px) !important;
    min-height: 54px !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    padding: .95rem 1.1rem !important;
    margin: 0 !important;
    border: 1px solid rgba(229, 201, 121, .22) !important;
    border-radius: 18px !important;
    background: rgba(255, 255, 255, .055) !important;
    color: #fff8ea !important;
    text-align: center !important;
    font-size: 1rem !important;
    font-weight: 700 !important;
    line-height: 1.15 !important;
    letter-spacing: .01em !important;
    box-shadow: 0 14px 32px rgba(0,0,0,.22) !important;
  }

  .nav-links a.nav-cta {
    display: flex !important;
    opacity: 1 !important;
    visibility: visible !important;
    background: linear-gradient(135deg, #cfa445, #f1d889) !important;
    color: #14100a !important;
    border-color: rgba(255, 238, 176, .9) !important;
    font-weight: 900 !important;
    font-size: 1rem !important;
  }

  .nav-links a.nav-cta::before {
    content: none !important;
  }

  body.menu-open main,
  body.menu-open footer {
    visibility: hidden !important;
    pointer-events: none !important;
  }
}

@media (max-width: 420px) {
  .nav-links {
    justify-content: flex-start !important;
    padding-top: 5.75rem !important;
  }

  .nav-links a {
    width: min(100%, 330px) !important;
  }
}
