/* ======================================================
   FOUNDAITION · AI SUMMIT SANTANDER 2027
   Global Styles · v2.0 — Bold Editorial Futurism
   ====================================================== */

/* ── RESET ─────────────────────────────────────────── */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; font-size: 20px; }
img { display: block; max-width: 100%; }
a { text-decoration: none; color: inherit; }
ul { list-style: none; }
button { cursor: pointer; border: none; background: none; }

/* ── DESIGN TOKENS ──────────────────────────────────── */
:root {
  --navy:       #022A40;
  --navy-dk:    #011828;
  --navy-md:    #033a56;
  --navy-lt:    #0a4a6e;
  --cyan:       #25CDFB;
  --cyan-dim:   rgba(37,205,251,.55);
  --cyan-glow:  rgba(37,205,251,.22);
  --cyan-faint: rgba(37,205,251,.07);
  --red:        #E63946;
  --red-dim:    rgba(230,57,70,.15);
  --gold:       #F4B942;
  --gold-dim:   rgba(244,185,66,.12);
  --green:      #06D6A0;
  --green-dim:  rgba(6,214,160,.12);
  --cream:      #FAF9F5;
  --cream-dk:   #f0ede6;
  --white:      #FFFFFF;

  --ff-disp: 'Barlow Condensed', Impact, 'Arial Narrow', sans-serif;
  --ff-body: 'Barlow', system-ui, sans-serif;
  --ff-mono: 'JetBrains Mono', 'Courier New', monospace;

  --container: 1280px;
  --sv: 7rem;
}

/* ── BASE ───────────────────────────────────────────── */
body { font-family: var(--ff-body); background: var(--cream); color: var(--navy); overflow-x: hidden; line-height: 1.6; }
h1,h2,h3,h4,h5 { font-family: var(--ff-disp); line-height: 1; letter-spacing: -.02em; }

/* ── CONTAINER ──────────────────────────────────────── */
.container { max-width: var(--container); margin: 0 auto; padding: 0 2rem; }

/* ── GRADIENT TEXT ──────────────────────────────────── */
.grad-text {
  background: linear-gradient(135deg, #25CDFB 0%, #fff 60%);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}
.grad-text-warm {
  background: linear-gradient(135deg, #F4B942 0%, #E63946 100%);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}
.grad-text-green {
  background: linear-gradient(135deg, #06D6A0 0%, #25CDFB 100%);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}

/* ── DIAGONAL CLIPS ─────────────────────────────────── */
.clip-bottom { clip-path: polygon(0 0, 100% 0, 100% 92%, 0 100%); padding-bottom: calc(var(--sv) + 5rem) !important; }
.clip-top    { clip-path: polygon(0 8%, 100% 0, 100% 100%, 0 100%); padding-top: calc(var(--sv) + 5rem) !important; }
.clip-both   { clip-path: polygon(0 6%, 100% 0, 100% 94%, 0 100%); padding: calc(var(--sv) + 5rem) 0 !important; }
.clip-right  { clip-path: polygon(0 0, 95% 0, 100% 50%, 95% 100%, 0 100%); }

/* ── SECTION ANATOMY ────────────────────────────────── */
.s-tag { font-family: var(--ff-mono); font-size: .65rem; letter-spacing: .3em; text-transform: uppercase; color: var(--cyan); margin-bottom: 1.2rem; display: block; }
.s-tag.on-cream { color: var(--navy); opacity: .4; }
.s-tag.red { color: var(--red); }
.s-tag.gold { color: var(--gold); }
.s-tag.green { color: var(--green); }

.s-headline { font-size: clamp(2.4rem, 4.5vw, 5rem); font-weight: 900; line-height: 1.02; }
.s-headline.on-dark { color: var(--white); }
.s-headline.on-cream { color: var(--navy); }
.s-headline.huge { font-size: clamp(3rem, 7vw, 7rem); }

.s-sub { font-size: 1.05rem; opacity: .78; margin-top: .6rem; max-width: 540px; }
.s-sub.on-dark { color: var(--cream); }
.s-sub.on-cream { color: var(--navy); }

.accent-bar { width: 3.5rem; height: 3px; background: var(--cyan); margin: 1.4rem 0; }
.accent-bar.red { background: var(--red); }
.accent-bar.gold { background: var(--gold); }
.accent-bar.green { background: var(--green); }

/* ── BUTTONS ────────────────────────────────────────── */
.btn { display: inline-flex; align-items: center; gap: .5rem; padding: .85rem 2rem; font-family: var(--ff-disp); font-size: .9rem; font-weight: 800; letter-spacing: .12em; text-transform: uppercase; transition: all .25s ease; }
.btn-cyan { background: var(--cyan); color: var(--navy-dk); }
.btn-cyan:hover { background: #fff; box-shadow: 0 0 30px var(--cyan-glow); }
.btn-red { background: var(--red); color: var(--white); }
.btn-red:hover { background: #c1121f; }
.btn-gold { background: var(--gold); color: var(--navy-dk); }
.btn-gold:hover { background: #e6a820; }
.btn-outline { border: 1px solid rgba(255,255,255,.35); color: var(--white); }
.btn-outline:hover { border-color: var(--cyan); color: var(--cyan); }
.btn-outline-dark { border: 1px solid rgba(37,205,251,.35); color: var(--cyan); }
.btn-outline-dark:hover { background: var(--cyan); color: var(--navy-dk); }
.btn-outline-navy { border: 2px solid var(--navy); color: var(--navy); }
.btn-outline-navy:hover { background: var(--navy); color: var(--white); }

/* ── NAVIGATION ─────────────────────────────────────── */
.nav { position: fixed; inset: 0 0 auto 0; z-index: 9999; padding: 1.4rem 2rem; display: flex; align-items: center; gap: 2rem; transition: background .4s, padding .3s, border-color .4s; border-bottom: 1px solid transparent; }
.nav.scrolled { background: rgba(1,24,40,.97); backdrop-filter: blur(24px); padding: .9rem 2rem; border-bottom-color: rgba(37,205,251,.12); }
.nav-logo { font-family: var(--ff-disp); font-size: 1.3rem; font-weight: 900; color: var(--white); letter-spacing: .03em; margin-right: auto; white-space: nowrap; }
.nav-logo .ai { color: var(--cyan); }
.nav-links { display: flex; gap: 1.6rem; }
.nav-links a { font-family: var(--ff-body); font-size: .78rem; font-weight: 500; letter-spacing: .06em; text-transform: uppercase; color: rgba(255,255,255,.65); transition: color .2s; white-space: nowrap; }
.nav-links a:hover { color: var(--cyan); }
.nav-cta { background: var(--cyan); color: var(--navy-dk); font-family: var(--ff-disp); font-size: .85rem; font-weight: 800; letter-spacing: .1em; text-transform: uppercase; padding: .55rem 1.4rem; white-space: nowrap; transition: all .2s; }
.nav-cta:hover { background: var(--red); color: #fff; }
.nav-burger { display: none; flex-direction: column; gap: 5px; padding: .5rem; }
.nav-burger span { display: block; width: 22px; height: 2px; background: var(--white); transition: all .3s; }

/* ── HERO ───────────────────────────────────────────── */
.hero { position: relative; height: 100vh; min-height: 720px; overflow: hidden; display: flex; align-items: center; }
.hero-bg { position: absolute; inset: 0; }
.hero-img { width: 100%; height: 100%; object-fit: cover; object-position: center 40%; }
.hero-overlay { position: absolute; inset: 0; background: linear-gradient(135deg, rgba(1,24,40,.62) 0%, rgba(2,42,64,.32) 45%, rgba(1,24,40,.58) 100%); }
.hero-vignette { position: absolute; inset: 0; background: radial-gradient(ellipse at center, transparent 30%, rgba(1,24,40,.65) 100%); }
.hero-grid { position: absolute; inset: 0; background-image: linear-gradient(rgba(37,205,251,.03) 1px, transparent 1px), linear-gradient(90deg, rgba(37,205,251,.03) 1px, transparent 1px); background-size: 70px 70px; }

/* GHOST N for Norte */
.hero-ghost-n { position: absolute; right: -5vw; top: 50%; transform: translateY(-55%); font-family: var(--ff-disp); font-size: 40vw; font-weight: 900; color: rgba(37,205,251,.025); line-height: 1; pointer-events: none; z-index: 1; }

.hero-scanline { position: absolute; left: 0; right: 0; height: 1px; background: linear-gradient(to right, transparent, var(--cyan) 25%, var(--cyan) 75%, transparent); opacity: .3; animation: scanline 8s ease-in-out infinite; }
@keyframes scanline { 0% { top: 0; opacity: 0; } 5% { opacity: .3; } 95% { opacity: .3; } 100% { top: 100%; opacity: 0; } }

.hero-content { position: relative; z-index: 2; width: 100%; max-width: var(--container); margin: 0 auto; padding: 0 2rem; padding-top: 90px; }
.hero-eyebrow { display: flex; align-items: center; gap: 1rem; margin-bottom: 1.5rem; }
.hero-badge { background: rgba(37,205,251,.1); border: 1px solid rgba(37,205,251,.35); color: var(--cyan); font-family: var(--ff-mono); font-size: .62rem; letter-spacing: .28em; text-transform: uppercase; padding: .35rem .8rem; }
.hero-badge-red { background: rgba(230,57,70,.15); border: 1px solid rgba(230,57,70,.4); color: var(--red); font-family: var(--ff-mono); font-size: .62rem; letter-spacing: .28em; text-transform: uppercase; padding: .35rem .8rem; }

.hero-wordmark { font-family: var(--ff-disp); font-weight: 900; font-size: clamp(4.5rem, 11vw, 11.5rem); line-height: .88; color: var(--white); text-transform: uppercase; letter-spacing: -.03em; margin-bottom: .8rem; }
.wm-ai { color: var(--cyan); text-shadow: 0 0 25px rgba(37,205,251,.65), 0 0 70px rgba(37,205,251,.28); animation: ai-pulse 4s ease-in-out infinite; }
@keyframes ai-pulse { 0%,100% { text-shadow: 0 0 25px rgba(37,205,251,.65), 0 0 70px rgba(37,205,251,.28); } 50% { text-shadow: 0 0 45px rgba(37,205,251,.95), 0 0 110px rgba(37,205,251,.5); } }

.hero-sub-line { font-family: var(--ff-disp); font-size: 1.25rem; font-weight: 700; color: rgba(255,255,255,.7); letter-spacing: .3em; text-transform: uppercase; display: flex; align-items: center; gap: 1.5rem; margin-bottom: 2.5rem; }
.hero-sub-line::before { content: ''; display: block; width: 45px; height: 2px; background: var(--cyan); flex-shrink: 0; }

.hero-tagline-card { max-width: 500px; background: rgba(2,42,64,.55); border-left: 3px solid var(--red); backdrop-filter: blur(12px); padding: 1.4rem 1.8rem; margin-bottom: 2.5rem; }
.hero-tagline { font-family: var(--ff-disp); font-size: clamp(1.3rem, 2.2vw, 1.8rem); font-weight: 800; color: var(--white); line-height: 1.2; }
.hero-tagline .hi { color: var(--cyan); }

/* countdown */
.hero-countdown { display: flex; gap: 1.5rem; margin-bottom: 2rem; }
.cd-block { text-align: center; }
.cd-num { font-family: var(--ff-disp); font-size: 2.5rem; font-weight: 900; color: var(--white); line-height: 1; display: block; }
.cd-lbl { font-family: var(--ff-mono); font-size: .55rem; letter-spacing: .2em; color: rgba(255,255,255,.3); text-transform: uppercase; }
.cd-sep { font-family: var(--ff-disp); font-size: 2.5rem; color: var(--cyan); line-height: 1; align-self: flex-start; }

.hero-meta { display: flex; align-items: center; gap: 2.5rem; margin-bottom: 2.2rem; flex-wrap: wrap; }
.hero-meta-item { display: flex; flex-direction: column; gap: .18rem; }
.hero-meta-lbl { font-family: var(--ff-mono); font-size: .58rem; letter-spacing: .25em; color: var(--cyan); text-transform: uppercase; opacity: .75; }
.hero-meta-val { font-family: var(--ff-disp); font-size: 1rem; font-weight: 700; color: var(--white); letter-spacing: .04em; }
.hero-meta-div { width: 1px; height: 36px; background: rgba(255,255,255,.15); }
.hero-cta { display: flex; gap: 1rem; flex-wrap: wrap; }

.hero-scroll { position: absolute; bottom: 2.5rem; left: 50%; transform: translateX(-50%); display: flex; flex-direction: column; align-items: center; gap: .4rem; animation: scroll-bounce 2.2s ease-in-out infinite; z-index: 2; }
.hero-scroll span { font-family: var(--ff-mono); font-size: .55rem; letter-spacing: .25em; color: rgba(255,255,255,.25); }
.hero-scroll-line { width: 1px; height: 55px; background: linear-gradient(to bottom, rgba(37,205,251,.6), transparent); }
@keyframes scroll-bounce { 0%,100% { transform: translateX(-50%) translateY(0); } 50% { transform: translateX(-50%) translateY(9px); } }

/* ── TICKER ─────────────────────────────────────────── */
.ticker { background: var(--navy-dk); border-top: 2px solid var(--red); border-bottom: 1px solid rgba(37,205,251,.15); padding: .65rem 0; overflow: hidden; position: relative; }
.ticker::before { content: ''; position: absolute; left: 0; top: 0; bottom: 0; width: 80px; z-index: 2; background: linear-gradient(to right, var(--navy-dk), transparent); }
.ticker::after { content: ''; position: absolute; right: 0; top: 0; bottom: 0; width: 80px; z-index: 2; background: linear-gradient(to left, var(--navy-dk), transparent); }
.ticker-track { display: flex; width: max-content; animation: ticker-run 40s linear infinite; }
.ticker-item { font-family: var(--ff-mono); font-size: .72rem; letter-spacing: .18em; color: var(--cream); text-transform: uppercase; padding: 0 2rem; white-space: nowrap; }
.ticker-accent { color: var(--cyan); }
.ticker-sep { color: rgba(37,205,251,.3); padding: 0; }
@keyframes ticker-run { from { transform: translateX(0); } to { transform: translateX(-50%); } }

/* ── PULL QUOTE SECTION ─────────────────────────────── */
.pull-quote-section { padding: 6rem 0; background: var(--cream-dk); position: relative; overflow: hidden; }
.pull-quote-bg { position: absolute; right: -2rem; top: 50%; transform: translateY(-50%); font-family: var(--ff-disp); font-size: 20rem; font-weight: 900; color: rgba(2,42,64,.04); line-height: 1; pointer-events: none; }
.pull-quote { font-family: var(--ff-disp); font-size: clamp(2.5rem, 5vw, 5.5rem); font-weight: 900; color: var(--navy); line-height: 1.05; max-width: 900px; position: relative; z-index: 1; }
.pull-quote .cyan { color: var(--cyan); }
.pull-quote .red { color: var(--red); }
.pull-quote-attr { font-family: var(--ff-mono); font-size: .65rem; letter-spacing: .2em; color: rgba(2,42,64,.35); text-transform: uppercase; margin-top: 2rem; position: relative; z-index: 1; }

/* ── PHOTO FULL BLEED ───────────────────────────────── */
.photo-bleed { position: relative; min-height: 55vh; display: flex; align-items: flex-end; overflow: hidden; }
.photo-bleed-img { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; }
.photo-bleed-overlay { position: absolute; inset: 0; background: linear-gradient(to top, rgba(1,24,40,.95) 0%, rgba(1,24,40,.4) 60%, transparent 100%); }
.photo-bleed-content { position: relative; z-index: 2; padding: 4rem 2rem; max-width: var(--container); margin: 0 auto; width: 100%; }
.photo-bleed-label { font-family: var(--ff-mono); font-size: .62rem; letter-spacing: .25em; color: var(--red); text-transform: uppercase; margin-bottom: 1rem; }
.photo-bleed-title { font-family: var(--ff-disp); font-size: clamp(2rem, 4vw, 4rem); font-weight: 900; color: var(--white); line-height: 1.05; max-width: 600px; }

/* ── MANIFIESTO ─────────────────────────────────────── */
.manifiesto { padding: var(--sv) 0; background: var(--cream); }
.manifiesto-grid { display: grid; grid-template-columns: 1.15fr 1fr; gap: 5rem; align-items: start; }
.mani-headline { font-size: clamp(2.2rem, 4vw, 4.2rem); font-weight: 900; color: var(--navy); line-height: 1.05; margin-bottom: 1.4rem; }
.mani-body { font-size: 1rem; line-height: 1.9; color: rgba(2,42,64,.7); max-width: 560px; }
.mani-body strong { color: var(--navy); font-weight: 700; }
.mani-body .brand { font-family: var(--ff-disp); font-weight: 900; font-size: 1.1em; color: var(--navy); }
.mani-body .brand .ai { color: var(--cyan); }
.mani-question { margin-top: 1.5rem; font-size: 1rem; font-weight: 600; color: var(--navy); }

/* stats card */
.stats-card { background: var(--navy); padding: 3rem 2.5rem; position: relative; overflow: hidden; }
.stats-card::before { content: ''; position: absolute; top: 0; left: 0; right: 0; height: 3px; background: linear-gradient(to right, var(--cyan), var(--red)); }
.sc-label { font-family: var(--ff-mono); font-size: .62rem; letter-spacing: .3em; color: var(--cyan); text-transform: uppercase; margin-bottom: 2.2rem; }
.sc-stat { margin-bottom: 2rem; padding-bottom: 2rem; border-bottom: 1px solid rgba(37,205,251,.1); }
.sc-stat:last-child { border-bottom: none; margin-bottom: 0; padding-bottom: 0; }
.sc-num { font-family: var(--ff-disp); font-size: 3.8rem; font-weight: 900; color: var(--cyan); line-height: 1; text-shadow: 0 0 30px rgba(37,205,251,.35); }
.sc-num.red { color: var(--red); text-shadow: 0 0 30px rgba(230,57,70,.3); }
.sc-num.gold { color: var(--gold); text-shadow: 0 0 30px rgba(244,185,66,.3); }
.sc-lbl { font-family: var(--ff-disp); font-size: .7rem; font-weight: 700; letter-spacing: .18em; color: rgba(250,249,245,.45); text-transform: uppercase; margin-top: .3rem; }

/* ── TEMAS ──────────────────────────────────────────── */
.temas { padding: var(--sv) 0; background: var(--navy-dk); position: relative; overflow: hidden; }
.temas::before { content: ''; position: absolute; inset: 0; background-image: radial-gradient(circle, rgba(37,205,251,.06) 1px, transparent 1px); background-size: 28px 28px; }
.temas-header { margin-bottom: 4rem; position: relative; z-index: 1; }
.temas-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 1.5rem; position: relative; z-index: 1; }
@media (min-width: 900px) { .temas-grid { grid-template-columns: repeat(4, 1fr); gap: 1px; background: rgba(37,205,251,.08); border: 1px solid rgba(37,205,251,.08); } }
.tema-card { background: var(--navy-dk); padding: 2.8rem 2rem; position: relative; overflow: hidden; transition: background .3s; }
.tema-card:hover { background: rgba(37,205,251,.05); }
.tema-card.red-card { border-top: 3px solid var(--red); }
.tema-card.gold-card { border-top: 3px solid var(--gold); }
.tema-card.green-card { border-top: 3px solid var(--green); }
.tema-card.cyan-card { border-top: 3px solid var(--cyan); }
.tema-icon { font-size: 2.2rem; margin-bottom: 1.5rem; display: block; }
.tema-num { font-family: var(--ff-mono); font-size: .6rem; letter-spacing: .2em; color: var(--cyan); opacity: .5; margin-bottom: .8rem; }
.tema-title { font-family: var(--ff-disp); font-size: 1.35rem; font-weight: 900; color: var(--white); text-transform: uppercase; line-height: 1.1; margin-bottom: .8rem; }
.tema-title.red { color: var(--red); }
.tema-title.gold { color: var(--gold); }
.tema-title.green { color: var(--green); }
.tema-desc { font-size: .88rem; color: rgba(250,249,245,.75); line-height: 1.7; }

/* ── ETHOS ──────────────────────────────────────────── */
.ethos { padding: var(--sv) 0; background: var(--navy); position: relative; }
.ethos::before { content: ''; position: absolute; inset: 0; background-image: linear-gradient(rgba(37,205,251,.025) 1px, transparent 1px), linear-gradient(90deg, rgba(37,205,251,.025) 1px, transparent 1px); background-size: 60px 60px; }
.ethos-header { position: relative; z-index: 1; margin-bottom: 4rem; }
.ethos-headline { font-size: clamp(3rem, 7vw, 7rem); font-weight: 900; color: var(--white); }
.ethos-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 1px; background: rgba(37,205,251,.1); position: relative; z-index: 1; }
.ethos-card { background: var(--navy); padding: 2rem 1.8rem; border: 1px solid rgba(37,205,251,.08); position: relative; overflow: hidden; transition: background .3s, border-color .3s; }
.ethos-card:hover { background: rgba(37,205,251,.05); border-color: rgba(37,205,251,.3); }
.ethos-num { font-family: var(--ff-mono); font-size: .68rem; color: var(--cyan); letter-spacing: .12em; margin-bottom: 1rem; }
.ethos-title { font-family: var(--ff-disp); font-size: .95rem; font-weight: 800; color: var(--white); letter-spacing: .08em; text-transform: uppercase; line-height: 1.3; margin-bottom: .75rem; }
.ethos-desc { font-size: .88rem; color: rgba(250,249,245,.75); line-height: 1.7; }

/* ── AGENDA PAGE ────────────────────────────────────── */
.agenda-page { padding: var(--sv) 0; background: var(--cream); }
.venue-legend { display: flex; flex-wrap: wrap; gap: .75rem; margin-bottom: 3rem; }
.vl-item { display: flex; align-items: center; gap: .5rem; font-family: var(--ff-mono); font-size: .62rem; letter-spacing: .12em; text-transform: uppercase; color: rgba(2,42,64,.5); }
.vl-dot { width: 10px; height: 10px; border-radius: 50%; flex-shrink: 0; }
.vl-vip { background: var(--gold); box-shadow: 0 0 8px rgba(244,185,66,.5); }
.vl-main { background: var(--cyan); }
.vl-intl { background: var(--green); }
.vl-clevel { background: var(--red); }
.vl-tec { background: #a78bfa; }
.vl-pyme { background: #fb923c; }
.vl-ind { background: #34d399; }
.vl-imp { background: #f472b6; }
.vl-uc { background: #818cf8; }

/* schedule grid */
.schedule-day { margin-bottom: 5rem; }
.day-header { background: var(--navy); color: var(--white); padding: 2rem; margin-bottom: 2rem; display: flex; justify-content: space-between; align-items: center; }
.day-title-big { font-family: var(--ff-disp); font-size: 2.5rem; font-weight: 900; }
.day-subtitle { font-family: var(--ff-mono); font-size: .65rem; letter-spacing: .2em; color: var(--cyan); text-transform: uppercase; }

.session-block { display: grid; grid-template-columns: 80px 1fr; gap: 0; border-bottom: 1px solid rgba(2,42,64,.07); min-height: 80px; }
.session-time { background: var(--cream-dk); padding: 1.2rem 1rem; font-family: var(--ff-mono); font-size: .75rem; color: var(--navy); border-right: 2px solid rgba(2,42,64,.08); display: flex; align-items: center; justify-content: center; text-align: center; letter-spacing: .04em; }
.session-slots { display: grid; }
.session-slots.cols-1 { grid-template-columns: 1fr; }
.session-slots.cols-2 { grid-template-columns: repeat(2, 1fr); }
.session-slots.cols-3 { grid-template-columns: repeat(3, 1fr); }
.session-slots.cols-4 { grid-template-columns: repeat(4, 1fr); }
.session-slots.cols-5 { grid-template-columns: repeat(5, 1fr); }
.session-slots.cols-6 { grid-template-columns: repeat(6, 1fr); }

.slot { padding: 1rem 1.2rem; border-right: 1px solid rgba(2,42,64,.06); display: flex; flex-direction: column; gap: .3rem; }
.slot:last-child { border-right: none; }
.slot-venue { font-family: var(--ff-mono); font-size: .52rem; letter-spacing: .15em; text-transform: uppercase; padding: .15rem .4rem; display: inline-block; margin-bottom: .3rem; width: fit-content; }
.slot-title { font-family: var(--ff-disp); font-size: .95rem; font-weight: 800; color: var(--navy); line-height: 1.2; }
.slot-speaker { font-size: .72rem; color: rgba(2,42,64,.5); margin-top: .2rem; }
.slot-type { font-family: var(--ff-mono); font-size: .55rem; letter-spacing: .12em; text-transform: uppercase; margin-top: auto; padding-top: .4rem; }

/* venue color coding */
.v-main { background: rgba(37,205,251,.08); border-left: 3px solid var(--cyan); }
.v-main .slot-venue { background: var(--cyan); color: var(--navy-dk); }
.v-intl { background: rgba(6,214,160,.06); border-left: 3px solid var(--green); }
.v-intl .slot-venue { background: var(--green); color: var(--navy-dk); }
.v-clevel { background: rgba(230,57,70,.06); border-left: 3px solid var(--red); }
.v-clevel .slot-venue { background: var(--red); color: var(--white); }
.v-tec { background: rgba(167,139,250,.07); border-left: 3px solid #a78bfa; }
.v-tec .slot-venue { background: #a78bfa; color: var(--white); }
.v-pyme { background: rgba(251,146,60,.06); border-left: 3px solid #fb923c; }
.v-pyme .slot-venue { background: #fb923c; color: var(--white); }
.v-ind { background: rgba(52,211,153,.06); border-left: 3px solid #34d399; }
.v-ind .slot-venue { background: #34d399; color: var(--navy-dk); }
.v-imp { background: rgba(244,114,182,.06); border-left: 3px solid #f472b6; }
.v-imp .slot-venue { background: #f472b6; color: var(--white); }
.v-uc { background: rgba(129,140,248,.06); border-left: 3px solid #818cf8; }
.v-uc .slot-venue { background: #818cf8; color: var(--white); }
.v-vip { background: rgba(244,185,66,.08); border-left: 3px solid var(--gold); }
.v-vip .slot-venue { background: var(--gold); color: var(--navy-dk); }
.v-social { background: rgba(230,57,70,.06); border-left: 3px solid var(--red); }
.v-social .slot-venue { background: var(--red); color: #fff; }
.slot-empty { background: rgba(0,0,0,.015); border-left: 3px solid transparent; }

/* ── PONENTES PAGE ──────────────────────────────────── */
.speakers-page { padding: var(--sv) 0; background: var(--cream); }
.speakers-filters { display: flex; gap: .75rem; flex-wrap: wrap; margin-bottom: 3rem; }
.filter-btn { font-family: var(--ff-mono); font-size: .62rem; letter-spacing: .15em; text-transform: uppercase; padding: .5rem 1rem; border: 1px solid rgba(2,42,64,.2); color: rgba(2,42,64,.5); cursor: pointer; transition: all .2s; background: none; }
.filter-btn:hover, .filter-btn.active { background: var(--navy); color: var(--cyan); border-color: var(--navy); }

/* speaker card (grid page) */
.speaker-card-grid { background: var(--white); border: 1px solid rgba(2,42,64,.08); overflow: hidden; transition: box-shadow .3s, transform .3s; cursor: default; }
.speaker-card-grid:hover { box-shadow: 0 8px 40px rgba(2,42,64,.1); transform: translateY(-4px); }
.sc-photo { aspect-ratio: 1; overflow: hidden; position: relative; background: var(--navy); }
.sc-photo img { width: 100%; height: 100%; object-fit: cover; object-position: center top; transition: transform .5s; filter: grayscale(20%); }
.speaker-card-grid:hover .sc-photo img { transform: scale(1.05); filter: none; }
.sc-overlay { position: absolute; inset: 0; background: linear-gradient(to top, rgba(2,42,64,.8) 0%, transparent 60%); }
.sc-badges { position: absolute; top: 1rem; left: 1rem; display: flex; gap: .4rem; flex-wrap: wrap; }
.sc-badge { font-family: var(--ff-mono); font-size: .52rem; letter-spacing: .15em; text-transform: uppercase; padding: .22rem .55rem; }
.sc-badge.vip { background: var(--gold); color: var(--navy-dk); }
.sc-badge.keynote { background: var(--red); color: var(--white); }
.sc-badge.intl { background: var(--green); color: var(--navy-dk); }
.sc-info { padding: 1.4rem; }
.sc-name { font-family: var(--ff-disp); font-size: 1.1rem; font-weight: 800; color: var(--navy); text-transform: uppercase; margin-bottom: .2rem; }
.sc-title { font-size: .78rem; color: var(--cyan); font-weight: 500; margin-bottom: .15rem; }
.sc-org { font-family: var(--ff-mono); font-size: .65rem; color: rgba(2,42,64,.4); letter-spacing: .06em; text-transform: uppercase; margin-bottom: .8rem; }
.sc-track-tag { font-family: var(--ff-mono); font-size: .55rem; letter-spacing: .12em; text-transform: uppercase; padding: .2rem .55rem; display: inline-block; }
.sc-track-tag.main { background: rgba(37,205,251,.1); color: var(--cyan); }
.sc-track-tag.clevel { background: rgba(230,57,70,.1); color: var(--red); }
.sc-track-tag.tec { background: rgba(167,139,250,.1); color: #7c3aed; }
.sc-track-tag.pymes { background: rgba(251,146,60,.1); color: #ea580c; }
.sc-track-tag.ind { background: rgba(52,211,153,.1); color: #059669; }
.sc-track-tag.imp { background: rgba(244,114,182,.1); color: #db2777; }
.sc-track-tag.intl { background: rgba(6,214,160,.1); color: #059669; }
.sc-track-tag.uc { background: rgba(129,140,248,.1); color: #4338ca; }
.sc-track-tag.talento { background: rgba(244,185,66,.1); color: #b45309; }
.sc-link { display: block; margin-top: .8rem; font-family: var(--ff-mono); font-size: .6rem; letter-spacing: .12em; color: var(--cyan); text-transform: uppercase; }
.sc-link:hover { color: var(--red); }

/* VIP speaker card (large) */
.speaker-vip-card { display: grid; grid-template-columns: 300px 1fr; background: var(--white); border: 1px solid rgba(244,185,66,.3); overflow: hidden; transition: box-shadow .3s; }
.speaker-vip-card:hover { box-shadow: 0 12px 60px rgba(2,42,64,.12); }
.svc-photo { position: relative; overflow: hidden; }
.svc-photo img { width: 100%; height: 100%; object-fit: cover; object-position: center top; }
.svc-photo-overlay { position: absolute; inset: 0; background: linear-gradient(to right, transparent 60%, rgba(2,42,64,.3) 100%); }
.svc-content { padding: 2.5rem; display: flex; flex-direction: column; justify-content: center; }
.svc-flag { font-size: 1.5rem; margin-bottom: .5rem; }
.svc-name { font-family: var(--ff-disp); font-size: 2rem; font-weight: 900; color: var(--navy); text-transform: uppercase; line-height: 1; margin-bottom: .3rem; }
.svc-title { color: var(--cyan); font-size: .9rem; font-weight: 500; margin-bottom: .2rem; }
.svc-org { font-family: var(--ff-mono); font-size: .65rem; color: rgba(2,42,64,.4); letter-spacing: .08em; text-transform: uppercase; margin-bottom: 1.2rem; }
.svc-bio { font-size: .88rem; color: rgba(2,42,64,.65); line-height: 1.75; max-width: 520px; margin-bottom: 1.5rem; }
.svc-session-box { background: var(--navy); padding: 1rem 1.4rem; display: flex; flex-direction: column; gap: .3rem; }
.svc-session-type { font-family: var(--ff-mono); font-size: .55rem; letter-spacing: .2em; color: var(--cyan); text-transform: uppercase; }
.svc-session-title { font-family: var(--ff-disp); font-size: 1rem; font-weight: 800; color: var(--white); }

/* speaker profile page */
.speaker-profile { padding: calc(var(--sv) + 60px) 0 var(--sv); background: var(--cream); }
.sp-hero { background: var(--navy); padding: 5rem 0; position: relative; overflow: hidden; }
.sp-hero::before { content: ''; position: absolute; inset: 0; background-image: radial-gradient(circle, rgba(37,205,251,.05) 1px, transparent 1px); background-size: 32px 32px; }
.sp-hero-grid { display: grid; grid-template-columns: 320px 1fr; gap: 5rem; align-items: center; position: relative; z-index: 1; }
.sp-hero-photo { width: 100%; aspect-ratio: .85; object-fit: cover; object-position: center top; border: 3px solid rgba(37,205,251,.2); }
.sp-vip-tag { background: var(--gold); color: var(--navy-dk); font-family: var(--ff-mono); font-size: .6rem; letter-spacing: .2em; text-transform: uppercase; padding: .3rem .8rem; display: inline-block; margin-bottom: 1rem; }
.sp-hero-name { font-family: var(--ff-disp); font-size: clamp(2.5rem, 4vw, 4.5rem); font-weight: 900; color: var(--white); line-height: 1; margin-bottom: .4rem; text-transform: uppercase; }
.sp-hero-title { font-size: 1rem; color: var(--cyan); margin-bottom: .2rem; }
.sp-hero-org { font-family: var(--ff-mono); font-size: .7rem; color: rgba(250,249,245,.4); letter-spacing: .08em; text-transform: uppercase; margin-bottom: 2rem; }
.sp-topics { display: flex; gap: .5rem; flex-wrap: wrap; margin-bottom: 2rem; }
.sp-topic { background: rgba(37,205,251,.1); border: 1px solid rgba(37,205,251,.2); color: var(--cyan); font-family: var(--ff-mono); font-size: .58rem; letter-spacing: .12em; text-transform: uppercase; padding: .25rem .6rem; }
.sp-awards { display: flex; flex-direction: column; gap: .4rem; }
.sp-award { display: flex; gap: .75rem; align-items: center; font-size: .82rem; color: rgba(250,249,245,.5); }
.sp-award::before { content: '✦'; color: var(--gold); font-size: .65rem; }
.sp-body { padding: var(--sv) 0; }
.sp-body-grid { display: grid; grid-template-columns: 1fr 380px; gap: 5rem; }
.sp-bio-text { font-size: 1rem; color: rgba(2,42,64,.7); line-height: 1.9; }
.sp-session-card { background: var(--navy); padding: 2.5rem; position: sticky; top: 100px; }
.sp-session-label { font-family: var(--ff-mono); font-size: .6rem; letter-spacing: .25em; color: var(--cyan); text-transform: uppercase; margin-bottom: 1.2rem; }
.sp-session-type-tag { background: var(--red); color: #fff; font-family: var(--ff-mono); font-size: .55rem; letter-spacing: .15em; padding: .2rem .6rem; text-transform: uppercase; display: inline-block; margin-bottom: .8rem; }
.sp-session-title { font-family: var(--ff-disp); font-size: 1.3rem; font-weight: 900; color: var(--white); line-height: 1.2; margin-bottom: 1.2rem; }
.sp-session-meta { font-family: var(--ff-mono); font-size: .65rem; letter-spacing: .12em; color: rgba(250,249,245,.35); text-transform: uppercase; line-height: 1.8; }
.sp-back { font-family: var(--ff-mono); font-size: .65rem; letter-spacing: .15em; color: rgba(2,42,64,.4); text-transform: uppercase; display: inline-flex; align-items: center; gap: .5rem; margin-bottom: 2rem; transition: color .2s; }
.sp-back:hover { color: var(--cyan); }

/* ── STARTUPS PAGE ──────────────────────────────────── */
.startups-hero { background: var(--navy-dk); padding: calc(var(--sv) + 80px) 0 var(--sv); clip-path: polygon(0 0, 100% 0, 100% 92%, 0 100%); padding-bottom: calc(var(--sv) + 5rem); position: relative; overflow: hidden; }
.startups-hero::before { content: ''; position: absolute; inset: 0; background-image: radial-gradient(circle, rgba(6,214,160,.07) 1px, transparent 1px); background-size: 24px 24px; }
.startup-card { background: var(--white); border: 1px solid rgba(2,42,64,.08); padding: 2rem; transition: box-shadow .3s, transform .3s; }
.startup-card:hover { box-shadow: 0 8px 40px rgba(2,42,64,.1); transform: translateY(-4px); }
.startup-card.featured { border-color: var(--gold); border-width: 2px; }
.startup-stage { font-family: var(--ff-mono); font-size: .55rem; letter-spacing: .2em; text-transform: uppercase; padding: .2rem .55rem; display: inline-block; margin-bottom: .8rem; }
.stage-seed { background: rgba(6,214,160,.12); color: #059669; }
.stage-seriesA { background: rgba(37,205,251,.12); color: #0369a1; }
.stage-seriesB { background: rgba(167,139,250,.12); color: #4338ca; }
.stage-boot { background: rgba(251,146,60,.12); color: #c2410c; }
.startup-name { font-family: var(--ff-disp); font-size: 1.4rem; font-weight: 900; color: var(--navy); text-transform: uppercase; margin-bottom: .3rem; }
.startup-tagline { font-size: .85rem; color: var(--cyan); margin-bottom: .8rem; }
.startup-desc { font-size: .82rem; color: rgba(2,42,64,.55); line-height: 1.6; margin-bottom: 1rem; }
.startup-meta { display: flex; gap: 1.5rem; }
.startup-kpi { display: flex; flex-direction: column; }
.startup-kpi-val { font-family: var(--ff-disp); font-size: 1.3rem; font-weight: 800; color: var(--navy); }
.startup-kpi-lbl { font-family: var(--ff-mono); font-size: .55rem; letter-spacing: .12em; color: rgba(2,42,64,.35); text-transform: uppercase; }

/* ── TALENTO PAGE ───────────────────────────────────── */
.talento-hero { background: var(--navy); padding: calc(var(--sv) + 80px) 0 var(--sv); position: relative; overflow: hidden; }
.company-card { background: var(--cream); border: 1px solid rgba(2,42,64,.1); padding: 2rem; transition: box-shadow .3s; }
.company-card:hover { box-shadow: 0 6px 30px rgba(2,42,64,.08); }
.co-logo { font-family: var(--ff-disp); font-size: 1.5rem; font-weight: 900; color: var(--navy); margin-bottom: .5rem; }
.co-sector { font-family: var(--ff-mono); font-size: .6rem; letter-spacing: .15em; color: var(--cyan); text-transform: uppercase; margin-bottom: .8rem; }
.co-openings { display: flex; align-items: baseline; gap: .5rem; margin-bottom: .5rem; }
.co-num { font-family: var(--ff-disp); font-size: 2rem; font-weight: 900; color: var(--navy); }
.co-lbl { font-size: .8rem; color: rgba(2,42,64,.5); }
.co-roles { font-size: .78rem; color: rgba(2,42,64,.45); line-height: 1.6; }

/* ── UNIVERSITY PAGE ────────────────────────────────── */
.uni-hero { background: var(--navy); padding: calc(var(--sv) + 80px) 0 var(--sv); position: relative; overflow: hidden; }
.uni-session { border-left: 3px solid #818cf8; padding: 1.2rem 1.5rem; background: rgba(129,140,248,.04); margin-bottom: 1px; }
.uni-session:hover { background: rgba(129,140,248,.08); }
.uni-time { font-family: var(--ff-mono); font-size: .65rem; color: #818cf8; margin-bottom: .3rem; }
.uni-title { font-family: var(--ff-disp); font-size: 1.1rem; font-weight: 800; color: var(--navy); }
.uni-speaker { font-size: .78rem; color: rgba(2,42,64,.5); margin-top: .2rem; }
.uni-type { font-family: var(--ff-mono); font-size: .55rem; letter-spacing: .12em; text-transform: uppercase; color: #818cf8; }

/* ── EXPERIENCIAS ───────────────────────────────────── */
.exp-hero { background: var(--navy); padding: calc(var(--sv) + 80px) 0 var(--sv); clip-path: polygon(0 0, 100% 0, 100% 92%, 0 100%); padding-bottom: calc(var(--sv) + 5rem); }
.exp-card-big { position: relative; overflow: hidden; min-height: 400px; display: flex; align-items: flex-end; }
.exp-card-big img { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; transition: transform .6s; }
.exp-card-big:hover img { transform: scale(1.05); }
.exp-card-overlay { position: absolute; inset: 0; background: linear-gradient(to top, rgba(1,24,40,.95) 0%, transparent 60%); }
.exp-card-content { position: relative; z-index: 1; padding: 2.5rem; }
.exp-date-tag { font-family: var(--ff-mono); font-size: .6rem; letter-spacing: .2em; color: var(--red); text-transform: uppercase; margin-bottom: .5rem; }
.exp-title { font-family: var(--ff-disp); font-size: 1.8rem; font-weight: 900; color: var(--white); text-transform: uppercase; line-height: 1.05; }
.exp-venue { font-family: var(--ff-mono); font-size: .65rem; color: var(--cyan-dim); letter-spacing: .1em; text-transform: uppercase; margin-top: .4rem; }
.exp-desc-block { font-size: .85rem; color: rgba(250,249,245,.65); line-height: 1.65; margin-top: .8rem; }

/* ── SEDES PAGE ─────────────────────────────────────── */
.sedes-split { display: grid; grid-template-columns: 55% 45%; min-height: 70vh; }
.sedes-split-reverse { grid-template-columns: 45% 55%; }
.sede-img-wrap { position: relative; overflow: hidden; }
.sede-img-wrap img { width: 100%; height: 100%; object-fit: cover; display: block; }
.sede-content-wrap { background: var(--cream); padding: 5rem 4rem; display: flex; flex-direction: column; justify-content: center; }
.sede-content-wrap.dark { background: var(--navy); }
.sede-num-big { font-family: var(--ff-disp); font-size: 8rem; font-weight: 900; color: rgba(37,205,251,.08); line-height: 1; }
.sede-role-tag { font-family: var(--ff-mono); font-size: .62rem; letter-spacing: .22em; color: var(--cyan); text-transform: uppercase; margin-bottom: .8rem; }
.sede-name-display { font-family: var(--ff-disp); font-size: clamp(1.8rem, 3vw, 2.8rem); font-weight: 900; color: var(--navy); text-transform: uppercase; line-height: 1.05; margin-bottom: 1rem; }
.sede-content-wrap.dark .sede-name-display { color: var(--white); }
.sede-desc-text { font-size: .9rem; color: rgba(2,42,64,.6); line-height: 1.8; }
.sede-content-wrap.dark .sede-desc-text { color: rgba(250,249,245,.5); }

/* ── SPONSORS PAGE ──────────────────────────────────── */
.sponsors-page { padding: var(--sv) 0; background: var(--navy-dk); }
.sponsor-pkg { background: rgba(3,58,86,.4); border: 1px solid rgba(37,205,251,.12); padding: 2.5rem; position: relative; transition: all .3s; }
.sponsor-pkg:hover { background: rgba(37,205,251,.05); border-color: rgba(37,205,251,.3); }
.sponsor-pkg.gold-pkg { border-color: rgba(244,185,66,.4); background: rgba(244,185,66,.05); }
.sponsor-pkg.silver-pkg { border-color: rgba(192,192,192,.3); }
.pkg-tier { font-family: var(--ff-mono); font-size: .65rem; letter-spacing: .28em; text-transform: uppercase; margin-bottom: .8rem; }
.pkg-tier.gold { color: var(--gold); }
.pkg-tier.silver { color: #c0c0c0; }
.pkg-tier.bronze { color: #cd7f32; }
.pkg-price { font-family: var(--ff-disp); font-size: 3rem; font-weight: 900; color: var(--white); line-height: 1; margin-bottom: .3rem; }
.pkg-price.gold { color: var(--gold); }
.pkg-includes { display: flex; flex-direction: column; gap: .6rem; margin: 1.5rem 0; }
.pkg-item { display: flex; gap: .75rem; font-size: .83rem; color: rgba(250,249,245,.6); }
.pkg-item::before { content: '✓'; color: var(--cyan); flex-shrink: 0; font-weight: 700; }
.gold-pkg .pkg-item::before { color: var(--gold); }

/* ── ENTRADAS PAGE ──────────────────────────────────── */
.entradas-page { padding: var(--sv) 0; background: var(--cream); }
.ticket-hero { background: var(--navy); padding: calc(var(--sv) + 80px) 0 var(--sv); text-align: center; clip-path: polygon(0 0, 100% 0, 100% 92%, 0 100%); padding-bottom: calc(var(--sv) + 5rem); }

/* ── VIP PAGE ───────────────────────────────────────── */
.vip-page { background: var(--navy-dk); }
.vip-hero { padding: calc(var(--sv) + 80px) 0 var(--sv); background: linear-gradient(135deg, var(--navy-dk) 0%, rgba(244,185,66,.08) 100%); }

/* ── SHARED SECTION ELEMENTS ────────────────────────── */
.page-hero { background: var(--navy); padding: calc(var(--sv) + 80px) 0 var(--sv); position: relative; overflow: hidden; }
.page-hero::before { content: ''; position: absolute; inset: 0; background-image: radial-gradient(circle, rgba(37,205,251,.05) 1px, transparent 1px); background-size: 32px 32px; }
.ph-content { position: relative; z-index: 1; }
.ph-title { font-family: var(--ff-disp); font-size: clamp(3rem, 7vw, 7rem); font-weight: 900; color: var(--white); line-height: .95; margin-bottom: 1rem; }
.ph-sub { font-size: 1.05rem; color: rgba(250,249,245,.78); max-width: 540px; line-height: 1.7; }
.ph-number { position: absolute; right: 0; top: 0; font-family: var(--ff-disp); font-size: 20rem; font-weight: 900; color: rgba(37,205,251,.04); line-height: 1; }

/* ── ABOUT / AIRES ──────────────────────────────────── */
.aires-section { padding: var(--sv) 0; background: var(--cream); }
.aires-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 6rem; align-items: center; }
.aires-logo-wrap { display: flex; align-items: center; justify-content: center; padding: 4rem; background: var(--white); border: 1px solid rgba(2,42,64,.08); }
.aires-logo-wrap img { max-width: 260px; }

/* ── HOTEL & TRANSPORT ──────────────────────────────── */
.hoteles { padding: var(--sv) 0; background: var(--cream); }
.hotel-card { border: 1px solid rgba(2,42,64,.1); padding: 2rem; background: var(--white); position: relative; transition: box-shadow .3s; }
.hotel-card:hover { box-shadow: 0 4px 30px rgba(2,42,64,.08); }
.hotel-card.featured { border-color: var(--gold); border-width: 2px; }
.hotel-badge { position: absolute; top: -1px; right: 1.5rem; background: var(--gold); color: var(--navy-dk); font-family: var(--ff-mono); font-size: .55rem; font-weight: 600; letter-spacing: .18em; padding: .2rem .6rem; text-transform: uppercase; }
.hotel-stars { font-size: 1rem; margin-bottom: .8rem; }
.hotel-name { font-family: var(--ff-disp); font-size: 1.4rem; font-weight: 900; color: var(--navy); text-transform: uppercase; margin-bottom: .3rem; }
.hotel-dist { font-family: var(--ff-mono); font-size: .62rem; letter-spacing: .15em; color: var(--cyan); text-transform: uppercase; margin-bottom: .8rem; }
.hotel-desc { font-size: .82rem; color: rgba(2,42,64,.55); line-height: 1.6; }
.hotel-price { margin-top: 1.2rem; padding-top: 1.2rem; border-top: 1px solid rgba(2,42,64,.08); font-family: var(--ff-disp); font-size: 1.3rem; font-weight: 800; color: var(--navy); }
.hotel-price span { font-size: .75rem; font-weight: 400; color: rgba(2,42,64,.4); }

/* como llegar */
.llegar-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 1px; background: rgba(37,205,251,.08); border: 1px solid rgba(37,205,251,.08); margin-top: 4rem; }
.llegar-card { background: var(--navy-dk); padding: 2.5rem 2rem; transition: background .3s; }
.llegar-card:hover { background: rgba(37,205,251,.05); }
.llegar-icon { font-size: 2rem; margin-bottom: 1.2rem; display: block; }
.llegar-mode { font-family: var(--ff-disp); font-size: 1.2rem; font-weight: 900; color: var(--white); text-transform: uppercase; margin-bottom: .5rem; }
.llegar-detail { font-family: var(--ff-mono); font-size: .65rem; letter-spacing: .12em; color: var(--cyan); text-transform: uppercase; margin-bottom: .8rem; }
.llegar-desc { font-size: .8rem; color: rgba(250,249,245,.4); line-height: 1.6; }

/* ── CONTACTO ───────────────────────────────────────── */
.contacto { padding: var(--sv) 0; background: var(--cream); }
.contact-form { display: flex; flex-direction: column; gap: 1.2rem; }
.form-group { display: flex; flex-direction: column; gap: .4rem; }
.form-label { font-family: var(--ff-mono); font-size: .6rem; letter-spacing: .2em; text-transform: uppercase; color: rgba(2,42,64,.5); }
.form-input, .form-select, .form-textarea { padding: .85rem 1rem; border: 1px solid rgba(2,42,64,.15); background: var(--white); font-family: var(--ff-body); font-size: .9rem; color: var(--navy); transition: border-color .2s; appearance: none; }
.form-input:focus, .form-select:focus, .form-textarea:focus { outline: none; border-color: var(--cyan); }
.form-textarea { min-height: 120px; resize: vertical; }
.form-row { display: grid; grid-template-columns: 1fr 1fr; gap: 1rem; }
.form-submit { padding: 1rem 2rem; background: var(--navy); color: var(--white); font-family: var(--ff-disp); font-size: 1rem; font-weight: 800; letter-spacing: .12em; text-transform: uppercase; border: none; cursor: pointer; transition: background .2s; align-self: flex-start; }
.form-submit:hover { background: var(--red); }

/* ── FOOTER ─────────────────────────────────────────── */
.footer { background: var(--navy-dk); padding: 5rem 0 2rem; border-top: 1px solid rgba(37,205,251,.12); }
.footer-top { display: grid; grid-template-columns: 2fr 1fr 1fr 1fr; gap: 4rem; margin-bottom: 4rem; }
.footer-logo { font-family: var(--ff-disp); font-size: 2rem; font-weight: 900; color: var(--white); margin-bottom: 1rem; }
.footer-logo .ai { color: var(--cyan); }
.footer-tagline { font-size: .85rem; color: rgba(250,249,245,.3); line-height: 1.7; max-width: 280px; margin-bottom: 1.5rem; }
.footer-social { display: flex; gap: .8rem; }
.footer-social a { width: 34px; height: 34px; border: 1px solid rgba(37,205,251,.18); display: flex; align-items: center; justify-content: center; font-size: .82rem; color: rgba(250,249,245,.35); transition: all .2s; }
.footer-social a:hover { border-color: var(--cyan); color: var(--cyan); }
.footer-col-title { font-family: var(--ff-mono); font-size: .6rem; letter-spacing: .25em; color: var(--cyan); text-transform: uppercase; margin-bottom: 1.5rem; }
.footer-links { display: flex; flex-direction: column; gap: .7rem; }
.footer-links a { font-size: .83rem; color: rgba(250,249,245,.35); transition: color .2s; }
.footer-links a:hover { color: var(--white); }
.footer-bottom { border-top: 1px solid rgba(37,205,251,.07); padding-top: 2rem; display: flex; justify-content: space-between; align-items: center; flex-wrap: wrap; gap: 1rem; }
.footer-copy { font-family: var(--ff-mono); font-size: .62rem; color: rgba(250,249,245,.18); letter-spacing: .1em; }
.footer-domain { font-family: var(--ff-disp); font-size: 1.1rem; font-weight: 700; letter-spacing: .08em; color: rgba(37,205,251,.3); }

/* ── SCROLL REVEAL ──────────────────────────────────── */
.reveal { opacity: 0; transform: translateY(28px); transition: opacity .65s ease, transform .65s ease; }
.reveal.visible { opacity: 1; transform: translateY(0); }
.rv1 { transition-delay: .05s; } .rv2 { transition-delay: .13s; } .rv3 { transition-delay: .21s; }
.rv4 { transition-delay: .29s; } .rv5 { transition-delay: .37s; } .rv6 { transition-delay: .45s; }

/* ── UTILITY ────────────────────────────────────────── */
.text-center { text-align: center; }
.mt-1 { margin-top: 1rem; } .mt-2 { margin-top: 2rem; } .mt-3 { margin-top: 3rem; } .mt-4 { margin-top: 4rem; }
.mb-1 { margin-bottom: 1rem; } .mb-2 { margin-bottom: 2rem; } .mb-3 { margin-bottom: 3rem; } .mb-4 { margin-bottom: 4rem; }
.grid-2 { display: grid; grid-template-columns: repeat(2, 1fr); gap: 1.5rem; }
.grid-3 { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1.5rem; }
.grid-4 { display: grid; grid-template-columns: repeat(4, 1fr); gap: 1.5rem; }

/* ── RESPONSIVE ─────────────────────────────────────── */
@media (max-width: 1100px) {
  .manifiesto-grid, .aires-grid { grid-template-columns: 1fr; gap: 3rem; }
  .ethos-grid { grid-template-columns: repeat(2, 1fr); }
  .sedes-split, .sedes-split-reverse { grid-template-columns: 1fr; }
  .speaker-vip-card { grid-template-columns: 220px 1fr; }
  .sp-hero-grid { grid-template-columns: 240px 1fr; gap: 3rem; }
  .sp-body-grid { grid-template-columns: 1fr; }
  .sp-session-card { position: static; }
  .footer-top { grid-template-columns: 1fr 1fr; gap: 3rem; }
  .llegar-grid { grid-template-columns: repeat(2, 1fr); }
  .grid-4 { grid-template-columns: repeat(2, 1fr); }
  .grid-3 { grid-template-columns: repeat(2, 1fr); }
}

@media (max-width: 768px) {
  :root { --sv: 4rem; }
  .nav-links, .nav-cta { display: none; }
  .nav-burger { display: flex; }
  .hero-wordmark { font-size: clamp(3rem, 14vw, 5.5rem); }
  .hero-meta { gap: 1.2rem; }
  .hero-countdown { gap: 1rem; }
  .ethos-grid { grid-template-columns: 1fr; }
  .temas-grid { grid-template-columns: 1fr; }
  .speaker-vip-card { grid-template-columns: 1fr; }
  .svc-photo { height: 300px; }
  .sp-hero-grid { grid-template-columns: 1fr; }
  .sp-hero-photo { max-width: 250px; }
  .grid-2, .grid-3, .grid-4 { grid-template-columns: 1fr; }
  .llegar-grid { grid-template-columns: 1fr; }
  .footer-top { grid-template-columns: 1fr; }
  .form-row { grid-template-columns: 1fr; }
  .pull-quote { font-size: clamp(2rem, 6vw, 3rem); }
  .session-slots.cols-6, .session-slots.cols-5, .session-slots.cols-4 { overflow-x: auto; display: flex; }
  .slot { min-width: 200px; }
}

/* ══════════════════════════════════════════════════════
   GLITCH EFFECTS · Digital Visual Language
   ══════════════════════════════════════════════════════ */

/* ── GLITCH IMAGE (hover-triggered RGB split) ── */
.glitch-img {
  position: relative;
}
.glitch-hover {
  transition: filter .3s;
}
.glitch-hover:hover {
  animation: glitchSweep .4s steps(2) forwards;
  filter: saturate(1.4);
}
@keyframes glitchSweep {
  0%   { clip-path: inset(0 0 100% 0); filter: hue-rotate(0deg) saturate(1.4); }
  20%  { clip-path: inset(20% 0 60% 0); transform: translateX(-4px); filter: hue-rotate(90deg) saturate(2); }
  40%  { clip-path: inset(50% 0 30% 0); transform: translateX(4px); filter: hue-rotate(-90deg) saturate(2); }
  60%  { clip-path: inset(80% 0 0% 0); transform: translateX(-2px); }
  80%  { clip-path: inset(0 0 0 0); transform: translateX(0); filter: hue-rotate(0deg) saturate(1.4); }
  100% { clip-path: inset(0 0 0 0); filter: hue-rotate(0deg) saturate(1.4); }
}

/* ── GLITCH TEXT (persistent vivid animation) ── */
.glitch-text {
  position: relative;
  display: inline-block;
}
.glitch-text::before,
.glitch-text::after {
  content: attr(data-text);
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  opacity: 0;
}
.glitch-text::before {
  color: var(--cyan);
  animation: glitchTextBefore 2.5s infinite linear;
}
.glitch-text::after {
  color: var(--red);
  animation: glitchTextAfter 2.5s infinite linear;
}
@keyframes glitchTextBefore {
  0%, 70%  { opacity: 0; clip-path: inset(0 0 100% 0); transform: translateX(0); }
  72%  { opacity: .95; clip-path: inset(15% 0 55% 0); transform: translateX(-6px); }
  74%  { opacity: .95; clip-path: inset(55% 0 15% 0); transform: translateX(5px); }
  76%  { opacity: .8; clip-path: inset(35% 0 35% 0); transform: translateX(-3px); }
  78%  { opacity: 0; clip-path: inset(0 0 100% 0); transform: translateX(0); }
  100% { opacity: 0; }
}
@keyframes glitchTextAfter {
  0%, 73%  { opacity: 0; clip-path: inset(0 0 100% 0); transform: translateX(0); }
  75%  { opacity: .9; clip-path: inset(5% 0 65% 0); transform: translateX(6px); }
  77%  { opacity: .9; clip-path: inset(65% 0 5% 0); transform: translateX(-5px); }
  79%  { opacity: 0; clip-path: inset(0 0 100% 0); transform: translateX(0); }
  100% { opacity: 0; }
}

/* ── DIGITAL NOISE OVERLAY (for hero sections) ── */
.digital-noise::after {
  content: '';
  position: absolute;
  inset: 0;
  pointer-events: none;
  background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='noiseFilter'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23noiseFilter)' opacity='0.03'/%3E%3C/svg%3E");
  background-repeat: repeat;
  background-size: 150px 150px;
  opacity: .4;
  mix-blend-mode: overlay;
  animation: noiseDrift 8s steps(8) infinite;
}
@keyframes noiseDrift {
  0%   { background-position: 0% 0%; }
  12%  { background-position: 100% 0%; }
  25%  { background-position: 50% 100%; }
  37%  { background-position: 0% 50%; }
  50%  { background-position: 100% 100%; }
  62%  { background-position: 30% 30%; }
  75%  { background-position: 80% 10%; }
  87%  { background-position: 10% 80%; }
  100% { background-position: 0% 0%; }
}

/* ── DATA RAIN OVERLAY (vertical scanlines + character pulse) ── */
.data-rain-overlay {
  position: absolute;
  inset: 0;
  pointer-events: none;
  overflow: hidden;
  z-index: 1;
}
.data-rain-overlay::before {
  content: '';
  position: absolute;
  inset: 0;
  background: repeating-linear-gradient(
    90deg,
    transparent 0px,
    transparent 18px,
    rgba(37,205,251,.018) 18px,
    rgba(37,205,251,.018) 19px
  );
}
.data-rain-overlay::after {
  content: '';
  position: absolute;
  inset: 0;
  background: repeating-linear-gradient(
    0deg,
    transparent 0px,
    transparent 2px,
    rgba(37,205,251,.012) 2px,
    rgba(37,205,251,.012) 3px
  );
  animation: scanMove 12s linear infinite;
}
@keyframes scanMove {
  from { background-position: 0 0; }
  to { background-position: 0 100%; }
}

/* ── CHROMATIC ABERRATION on cards (subtle) ── */
.chrome-card {
  position: relative;
  transition: all .25s;
}
.chrome-card::before {
  content: '';
  position: absolute;
  inset: 0;
  border: 1px solid transparent;
  transition: all .3s;
  pointer-events: none;
  z-index: 2;
}
.chrome-card:hover::before {
  border-color: var(--cyan);
  box-shadow: inset 0 0 0 1px rgba(230,57,70,.3),
              0 0 20px rgba(37,205,251,.15),
              -2px 0 0 rgba(230,57,70,.2),
              2px 0 0 rgba(37,205,251,.2);
}

/* ── GLITCH SCANLINE FLASH ── */
.scanline-flash {
  position: relative;
  overflow: hidden;
}
.scanline-flash::after {
  content: '';
  position: absolute;
  left: 0;
  right: 0;
  height: 3px;
  background: linear-gradient(to right, transparent, rgba(37,205,251,.9) 20%, #fff 50%, rgba(37,205,251,.9) 80%, transparent);
  top: -3px;
  animation: scanlineDown 4s linear infinite;
  pointer-events: none;
  box-shadow: 0 0 12px rgba(37,205,251,.6);
}
@keyframes scanlineDown {
  from { top: -3px; opacity: 0; }
  4%   { opacity: 1; }
  96%  { opacity: 1; }
  to   { top: 100%; opacity: 0; }
}

/* ── GLITCH IMAGE (persistent — wraps around any image) ── */
.glitch-wrap {
  position: relative;
  overflow: hidden;
}
.glitch-wrap::before {
  content: '';
  position: absolute;
  inset: 0;
  z-index: 2;
  pointer-events: none;
  animation: glitchOverlayFlash 4s steps(1) infinite;
  mix-blend-mode: screen;
}
@keyframes glitchOverlayFlash {
  0%, 78%  { opacity: 0; background: none; }
  79%  { opacity: 1; background: linear-gradient(90deg, rgba(37,205,251,.35) 0%, transparent 8%); transform: skewY(-.5deg); }
  80%  { opacity: 1; background: linear-gradient(270deg, rgba(230,57,70,.35) 0%, transparent 8%); transform: skewY(.5deg); }
  81%  { opacity: 1; background: rgba(37,205,251,.08); transform: translateX(3px); }
  82%  { opacity: 0; background: none; transform: none; }
  89%  { opacity: 0; background: none; }
  90%  { opacity: 1; background: linear-gradient(90deg, transparent 40%, rgba(37,205,251,.2) 50%, transparent 60%); }
  91%  { opacity: 0; }
  100% { opacity: 0; }
}

/* ── REVEAL ANIMATIONS (scroll-triggered via JS) ── */
.reveal {
  opacity: 0;
  transform: translateY(20px);
  transition: opacity .6s ease, transform .6s ease;
}
.reveal.revealed {
  opacity: 1;
  transform: translateY(0);
}
.reveal-left { opacity: 0; transform: translateX(-30px); transition: opacity .6s ease, transform .6s ease; }
.reveal-left.revealed { opacity: 1; transform: translateX(0); }
.reveal-right { opacity: 0; transform: translateX(30px); transition: opacity .6s ease, transform .6s ease; }
.reveal-right.revealed { opacity: 1; transform: translateX(0); }

/* ── CURSOR GLOW (optional enhancement) ── */
.cursor-glow-zone {
  position: relative;
}
.cursor-glow-zone::before {
  content: '';
  position: absolute;
  width: 300px;
  height: 300px;
  background: radial-gradient(circle, rgba(37,205,251,.06) 0%, transparent 70%);
  pointer-events: none;
  transform: translate(-50%, -50%);
  left: var(--cursor-x, 50%);
  top: var(--cursor-y, 50%);
  transition: left .1s, top .1s;
  z-index: 0;
}

/* ══════════════════════════════════════════════════════
   HERO IMAGE ENHANCEMENT · Better photo treatment
   ══════════════════════════════════════════════════════ */

.hero-img {
  filter: saturate(1.25) contrast(1.08) brightness(1.05);
}

/* Duotone effect for hero (navy + cyan overlay) */
.hero-duotone {
  position: relative;
}
.hero-duotone::after {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(135deg, rgba(2,42,64,.5) 0%, rgba(37,205,251,.08) 100%);
  mix-blend-mode: color;
  pointer-events: none;
}

/* ══════════════════════════════════════════════════════
   GLOBAL UTILITY ADDITIONS
   ══════════════════════════════════════════════════════ */

.text-cyan { color: var(--cyan); }
.text-gold { color: var(--gold); }
.text-red { color: var(--red); }
.text-green { color: var(--green); }
.text-cream { color: var(--cream); }

.bg-navy { background: var(--navy); }
.bg-dark { background: var(--navy); }
.bg-darker { background: var(--navy-dk); }
.bg-darker { background: #011522; }

.mono { font-family: 'JetBrains Mono', monospace; }
.condensed { font-family: 'Barlow Condensed', sans-serif; }

/* ── SECTION PADDING HELPERS ── */
.pt-0 { padding-top: 0 !important; }
.pb-0 { padding-bottom: 0 !important; }
.mt-0 { margin-top: 0 !important; }
.mb-0 { margin-bottom: 0 !important; }

/* ── Z-INDEX LAYERS ── */
.z-nav { z-index: 9000; }
.z-overlay { z-index: 100; }
.z-content { z-index: 10; }
.z-base { z-index: 1; }

/* ══════════════════════════════════════════════════════
   CYAN CONTRAST BOOST · From PPTX brand palette
   ══════════════════════════════════════════════════════ */

/* Vivid cyan accent bars and borders throughout */
.accent-cyan-bar {
  display: block;
  width: 4rem;
  height: 4px;
  background: var(--cyan);
  margin: 1.2rem 0;
  box-shadow: 0 0 14px rgba(37,205,251,.5);
}
.border-cyan { border-color: var(--cyan) !important; }

/* High-contrast section divider with cyan glow */
.section-divider {
  height: 1px;
  background: linear-gradient(to right, transparent, var(--cyan) 30%, rgba(37,205,251,.4) 70%, transparent);
  margin: 0;
  box-shadow: 0 0 12px rgba(37,205,251,.2);
}

/* Label chip — consolidated (overrides page-specific definitions) */
.label-chip {
  display: inline-block;
  font-family: var(--ff-mono);
  font-size: .65rem;
  letter-spacing: .2em;
  text-transform: uppercase;
  color: var(--cyan);
  border: 1px solid rgba(37,205,251,.4);
  padding: .3rem .9rem;
  margin-bottom: .6rem;
  background: rgba(37,205,251,.06);
}
.label-chip.gold { color: var(--gold); border-color: rgba(244,185,66,.4); background: rgba(244,185,66,.06); }
.label-chip.red  { color: var(--red);  border-color: rgba(230,57,70,.4);  background: rgba(230,57,70,.06); }
.label-chip.green{ color: var(--green);border-color: rgba(6,214,160,.4);  background: rgba(6,214,160,.06); }

/* ── EARLY BIRD BANNER ── */
.early-bird-bar {
  background: linear-gradient(90deg, var(--navy-dk), var(--navy), var(--navy-dk));
  border-bottom: 1px solid rgba(37,205,251,.2);
  padding: .45rem 2rem;
  text-align: center;
  font-family: var(--ff-mono);
  font-size: .65rem;
  letter-spacing: .15em;
  color: rgba(250,249,245,.7);
  position: relative;
  z-index: 8998;
}
.early-bird-bar strong { color: var(--cyan); }
.early-bird-bar a { color: var(--gold); text-decoration: underline; }

/* ── STICKY TICKET CTA (floats when scrolling) ── */
.sticky-cta {
  position: fixed;
  bottom: 2rem;
  right: 2rem;
  z-index: 8000;
  background: var(--cyan);
  color: var(--navy-dk);
  font-family: var(--ff-disp);
  font-weight: 800;
  font-size: .95rem;
  letter-spacing: .1em;
  text-transform: uppercase;
  padding: .85rem 1.8rem;
  text-decoration: none;
  box-shadow: 0 8px 30px rgba(37,205,251,.45), 0 2px 8px rgba(0,0,0,.3);
  transition: all .25s;
  animation: floatCta 3s ease-in-out infinite;
}
.sticky-cta:hover { background: #fff; box-shadow: 0 12px 40px rgba(37,205,251,.6); transform: translateY(-3px) !important; }
@keyframes floatCta {
  0%,100% { transform: translateY(0); }
  50% { transform: translateY(-5px); }
}
@media (max-width: 768px) { .sticky-cta { bottom: 1rem; right: 1rem; font-size: .82rem; padding: .7rem 1.2rem; } }

/* ══════════════════════════════════════════════════════
   SCI-FI SCAN EFFECTS · Cinematic Digital Language
   ══════════════════════════════════════════════════════ */

/* ── MULTI-SCANLINE HERO EFFECT (applied to .hero class) ── */
.hero::after {
  content: '';
  position: absolute;
  left: 0;
  right: 0;
  height: 80px;
  background: linear-gradient(to bottom,
    transparent 0%,
    rgba(37,205,251,.03) 30%,
    rgba(37,205,251,.08) 50%,
    rgba(37,205,251,.03) 70%,
    transparent 100%
  );
  top: -80px;
  animation: heroScanBeam 5s ease-in-out infinite;
  pointer-events: none;
  z-index: 3;
  mix-blend-mode: screen;
}
@keyframes heroScanBeam {
  0%   { top: -80px; opacity: 0; }
  5%   { opacity: 1; }
  90%  { opacity: 1; }
  100% { top: 100%; opacity: 0; }
}

/* ── CORNER BRACKETS (sci-fi HUD brackets on sections) ── */
.hud-frame {
  position: relative;
}
.hud-frame::before, .hud-frame::after {
  content: '';
  position: absolute;
  width: 40px;
  height: 40px;
  pointer-events: none;
  z-index: 5;
}
.hud-frame::before {
  top: 1rem;
  left: 1rem;
  border-top: 2px solid rgba(37,205,251,.6);
  border-left: 2px solid rgba(37,205,251,.6);
}
.hud-frame::after {
  bottom: 1rem;
  right: 1rem;
  border-bottom: 2px solid rgba(244,185,66,.4);
  border-right: 2px solid rgba(244,185,66,.4);
}

/* ── CRT SCANLINES OVERLAY ── */
.crt-overlay {
  position: relative;
  overflow: hidden;
}
.crt-overlay::before {
  content: '';
  position: absolute;
  inset: 0;
  background: repeating-linear-gradient(
    0deg,
    transparent,
    transparent 1px,
    rgba(0,0,0,.08) 1px,
    rgba(0,0,0,.08) 2px
  );
  pointer-events: none;
  z-index: 4;
  animation: crtFlicker 8s steps(1) infinite;
}
@keyframes crtFlicker {
  0%, 95%  { opacity: 1; }
  96%  { opacity: .85; }
  97%  { opacity: 1; }
  98%  { opacity: .9; }
  99%  { opacity: 1; }
  100% { opacity: 1; }
}

/* ── RADAR SWEEP (for circular elements) ── */
.radar-sweep {
  position: relative;
  overflow: hidden;
  border-radius: 50%;
}
.radar-sweep::after {
  content: '';
  position: absolute;
  inset: 0;
  background: conic-gradient(
    from 0deg,
    transparent 0deg,
    rgba(37,205,251,.3) 10deg,
    transparent 20deg,
    transparent 360deg
  );
  animation: radarRotate 3s linear infinite;
  pointer-events: none;
}
@keyframes radarRotate {
  from { transform: rotate(0deg); }
  to   { transform: rotate(360deg); }
}

/* ── GLITCH BAND (dramatic full-width glitch stripe) ── */
.glitch-band {
  position: relative;
  overflow: hidden;
}
.glitch-band::after {
  content: '';
  position: absolute;
  left: 0;
  right: 0;
  height: 3px;
  background: linear-gradient(90deg,
    rgba(37,205,251,.0) 0%,
    rgba(37,205,251,.9) 20%,
    rgba(255,255,255,.8) 50%,
    rgba(230,57,70,.9) 80%,
    rgba(37,205,251,.0) 100%
  );
  animation: glitchBandSweep 4s steps(2) infinite;
  pointer-events: none;
  z-index: 10;
  box-shadow: 0 0 8px rgba(37,205,251,.5);
}
@keyframes glitchBandSweep {
  0%   { top: 0%; opacity: 0; }
  5%   { opacity: 1; }
  45%  { top: 100%; opacity: 1; }
  50%  { opacity: 0; top: 0%; }
  55%  { opacity: 0; }
  65%  { top: 45%; opacity: 1; }
  68%  { top: 50%; opacity: 0; }
  100% { top: 0%; opacity: 0; }
}

/* ── DATA TICKER ACCENT ── */
.data-ticker-accent {
  font-family: var(--ff-mono);
  font-size: .58rem;
  letter-spacing: .18em;
  color: rgba(37,205,251,.5);
  display: flex;
  gap: 1rem;
  align-items: center;
  animation: tickerFade 2s ease-in-out infinite alternate;
}
@keyframes tickerFade {
  from { opacity: .4; }
  to   { opacity: .9; }
}

/* ── NEON BORDER PULSE ── */
.neon-border {
  border: 1px solid var(--cyan);
  animation: neonPulse 3s ease-in-out infinite;
}
@keyframes neonPulse {
  0%,100% { box-shadow: 0 0 5px rgba(37,205,251,.3), inset 0 0 5px rgba(37,205,251,.05); border-color: rgba(37,205,251,.5); }
  50% { box-shadow: 0 0 20px rgba(37,205,251,.6), inset 0 0 15px rgba(37,205,251,.1); border-color: rgba(37,205,251,.9); }
}

/* ── HOLOGRAPHIC CARD SHINE ── */
.holographic {
  position: relative;
  overflow: hidden;
}
.holographic::before {
  content: '';
  position: absolute;
  top: -50%;
  left: -50%;
  width: 200%;
  height: 200%;
  background: linear-gradient(
    45deg,
    transparent 30%,
    rgba(37,205,251,.04) 40%,
    rgba(255,255,255,.06) 50%,
    rgba(244,185,66,.04) 60%,
    transparent 70%
  );
  animation: holographicShine 6s linear infinite;
  pointer-events: none;
  z-index: 1;
}
@keyframes holographicShine {
  from { transform: translateX(-100%) translateY(-100%) rotate(45deg); }
  to   { transform: translateX(100%) translateY(100%) rotate(45deg); }
}

/* ── BINARY RAIN EFFECT (CSS-only) ── */
.binary-rain {
  position: relative;
  overflow: hidden;
}
.binary-rain::after {
  content: '01 10 11 00 10 01 11 00 10 01 00 11 01 10 00 11 10 01';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  font-family: var(--ff-mono);
  font-size: .5rem;
  letter-spacing: .4em;
  color: rgba(37,205,251,.06);
  line-height: 2;
  word-break: break-all;
  animation: binaryDrift 20s linear infinite;
  pointer-events: none;
  z-index: 0;
}
@keyframes binaryDrift {
  from { transform: translateY(-100%); }
  to   { transform: translateY(100%); }
}

/* ══════════════════════════════════════════════════════
   GOLD × CYAN SYSTEM · Editorial color language
   ══════════════════════════════════════════════════════ */

/* Gold highlight text with glow */
.gold-glow {
  color: var(--gold);
  text-shadow: 0 0 20px rgba(244,185,66,.5), 0 0 60px rgba(244,185,66,.2);
}
.cyan-glow {
  color: var(--cyan);
  text-shadow: 0 0 20px rgba(37,205,251,.6), 0 0 60px rgba(37,205,251,.25);
}

/* Gold underline accent on section headings */
.heading-gold::after {
  content: '';
  display: block;
  width: 3rem;
  height: 3px;
  background: var(--gold);
  margin-top: .6rem;
  box-shadow: 0 0 12px rgba(244,185,66,.5);
}
.heading-cyan::after {
  content: '';
  display: block;
  width: 3rem;
  height: 3px;
  background: var(--cyan);
  margin-top: .6rem;
  box-shadow: 0 0 12px rgba(37,205,251,.5);
}

/* Gold tag/badge — high contrast */
.gold-tag {
  display: inline-block;
  background: var(--gold);
  color: var(--navy-dk);
  font-family: var(--ff-mono);
  font-size: .62rem;
  font-weight: 700;
  letter-spacing: .18em;
  text-transform: uppercase;
  padding: .3rem .9rem;
  box-shadow: 0 0 16px rgba(244,185,66,.35);
}

/* Cyan tag */
.cyan-tag {
  display: inline-block;
  background: var(--cyan);
  color: var(--navy-dk);
  font-family: var(--ff-mono);
  font-size: .62rem;
  font-weight: 700;
  letter-spacing: .18em;
  text-transform: uppercase;
  padding: .3rem .9rem;
  box-shadow: 0 0 16px rgba(37,205,251,.4);
}

/* Gold border left quote */
.gold-quote {
  border-left: 3px solid var(--gold);
  padding-left: 1.5rem;
  box-shadow: -8px 0 20px rgba(244,185,66,.12);
}

/* Cyan border left */
.cyan-quote {
  border-left: 3px solid var(--cyan);
  padding-left: 1.5rem;
  box-shadow: -8px 0 20px rgba(37,205,251,.12);
}

/* Section headings — gold/cyan key word pattern */
.section-heading .key { color: var(--gold); }
.section-heading .key-cyan { color: var(--cyan); }

/* Dual-color divider: gold + cyan */
.divider-gold-cyan {
  height: 2px;
  background: linear-gradient(to right, var(--gold) 0%, var(--cyan) 100%);
  margin: 2rem 0;
  box-shadow: 0 0 15px rgba(244,185,66,.25), 0 0 30px rgba(37,205,251,.15);
}

/* Gold number stat (editorial big numbers) */
.stat-gold {
  font-family: var(--ff-disp);
  font-weight: 900;
  font-size: clamp(3rem, 6vw, 6rem);
  color: var(--gold);
  line-height: 1;
  text-shadow: 0 0 30px rgba(244,185,66,.3);
}
.stat-cyan {
  font-family: var(--ff-disp);
  font-weight: 900;
  font-size: clamp(3rem, 6vw, 6rem);
  color: var(--cyan);
  line-height: 1;
  text-shadow: 0 0 30px rgba(37,205,251,.3);
}

/* Section background with gold diagonal accent line */
.section-gold-accent {
  position: relative;
}
.section-gold-accent::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 2px;
  background: linear-gradient(to right, transparent, var(--gold) 30%, rgba(244,185,66,.3) 70%, transparent);
  box-shadow: 0 0 10px rgba(244,185,66,.3);
}

/* Bright gold highlight within dark sections */
.hl-gold {
  color: var(--gold);
  font-weight: 700;
}
.hl-cyan {
  color: var(--cyan);
  font-weight: 700;
}

/* Card with gold border on hover */
.card-gold-hover {
  border: 1px solid rgba(244,185,66,.1);
  transition: border-color .25s, box-shadow .25s;
}
.card-gold-hover:hover {
  border-color: rgba(244,185,66,.5);
  box-shadow: 0 0 20px rgba(244,185,66,.12), 0 8px 30px rgba(0,0,0,.3);
}

/* Pull-quote in gold (for "Every Leader Needs a North" style) */
.pull-gold {
  font-family: var(--ff-disp);
  font-weight: 900;
  color: var(--gold);
  text-shadow: 0 0 40px rgba(244,185,66,.25);
  line-height: 1.05;
}

/* ── RESPONSIVE: keep gold effects on mobile ── */
@media (max-width: 768px) {
  .gold-glow, .pull-gold { text-shadow: 0 0 15px rgba(244,185,66,.4); }
  .gold-tag, .cyan-tag { font-size: .58rem; }
}
