﻿/* ==========================================================================
   custom.css — CD Santa Teresa de Aurora
   Componentes nuevos (prefijo cst-*). NO sobrescribe clases del template.
   Hereda variables del sistema: --accent-color, --heading-color, --default-color,
   --background-color, --surface-color, --contrast-color, --heading-font.
   ========================================================================== */

/* --------------------------------------------------------------------------
   1. Tokens locales (basados en variables del template)
   -------------------------------------------------------------------------- */
:root {
  /* Color institucional derivado del accent */
  --cst-brand: var(--accent-color);
  --cst-brand-dark: #c32d2d;
  --cst-brand-soft: color-mix(in srgb, var(--accent-color) 12%, #ffffff);
  --cst-brand-tint: color-mix(in srgb, var(--accent-color) 6%, #ffffff);

  /* Estados */
  --cst-success: #2e9e5b;
  --cst-success-soft: color-mix(in srgb, #2e9e5b 12%, #ffffff);
  --cst-warning: #b9b9b9;
  --cst-warning-soft: #f0f0f0;
  --cst-danger: #b94a4a;
  --cst-danger-soft: color-mix(in srgb, #b94a4a 12%, #ffffff);

  /* Neutros */
  --cst-ink-1: var(--heading-color);
  --cst-ink-2: #4a4a4a;
  --cst-ink-3: #8a8a8a;
  --cst-line: #e6e6e6;
  --cst-line-soft: #f1f1f1;

  /* Sombras */
  --cst-shadow-sm: 0 2px 6px rgba(20, 20, 20, .06);
  --cst-shadow-md: 0 8px 24px rgba(20, 20, 20, .08);
  --cst-shadow-lg: 0 18px 48px rgba(20, 20, 20, .12);

  /* Radios */
  --cst-radius-sm: 8px;
  --cst-radius-md: 14px;
  --cst-radius-lg: 22px;
  --cst-radius-pill: 999px;

  /* Espaciados */
  --cst-sp-1: 4px;
  --cst-sp-2: 8px;
  --cst-sp-3: 12px;
  --cst-sp-4: 16px;
  --cst-sp-5: 24px;
  --cst-sp-6: 32px;
  --cst-sp-7: 48px;
  --cst-sp-8: 64px;

  /* Curva de transición unificada */
  --cst-ease: cubic-bezier(.25, .46, .45, .94);
}

/* Respeto a preferencias de movimiento reducido */
@media (prefers-reduced-motion: reduce) {
  .cst-wa-float,
  .cst-match-hero__count span {
    animation: none !important;
    transition: none !important;
  }
}

/* Elimina la línea decorativa del ::after en ítems de dropdown */
.navmenu .dropdown ul a::after,
.navmenu .dropdown ul a:focus::after {
  display: none !important;
}

/* --------------------------------------------------------------------------
   2. cst-match-hero — Hero del próximo partido con contador regresivo
   -------------------------------------------------------------------------- */
.cst-match-hero {
  position: relative;
  border-radius: var(--cst-radius-lg);
  padding: clamp(28px, 4vw, 52px) clamp(20px, 3vw, 48px);
  color: var(--contrast-color);
  background:
    radial-gradient(ellipse at 15% 20%, color-mix(in srgb, var(--cst-brand) 50%, #000) 0%, transparent 55%),
    radial-gradient(ellipse at 85% 85%, color-mix(in srgb, var(--cst-brand-dark) 70%, #000) 0%, transparent 55%),
    linear-gradient(160deg, #1c0606 0%, #2d0d0d 35%, #8b1a1a 100%);
  box-shadow:
    var(--cst-shadow-lg),
    0 0 0 1px rgba(255, 255, 255, .07),
    inset 0 1px 0 rgba(255, 255, 255, .1);
  overflow: hidden;
  isolation: isolate;
}

/* Textura de puntos */
.cst-match-hero::before {
  content: "";
  position: absolute;
  inset: 0;
  background-image: radial-gradient(circle at 1px 1px, rgba(255, 255, 255, .1) 1px, transparent 0);
  background-size: 22px 22px;
  opacity: .2;
  z-index: 0;
  pointer-events: none;
}

/* Destello decorativo en esquina superior-derecha */
.cst-match-hero::after {
  content: "";
  position: absolute;
  top: -100px;
  right: -100px;
  width: 420px;
  height: 420px;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(255, 255, 255, .07) 0%, transparent 70%);
  z-index: 0;
  pointer-events: none;
}

.cst-match-hero > * {
  position: relative;
  z-index: 1;
}

.cst-match-hero__top {
  display: flex;
  flex-wrap: wrap;
  gap: var(--cst-sp-2);
  justify-content: center;
  margin-bottom: var(--cst-sp-5);
}

.cst-match-hero__badge {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  background: rgba(255, 255, 255, .1);
  border: 1px solid rgba(255, 255, 255, .18);
  backdrop-filter: blur(6px);
  border-radius: var(--cst-radius-pill);
  padding: 7px 16px;
  font-size: .75rem;
  font-weight: 700;
  letter-spacing: .06em;
  text-transform: uppercase;
}

/* ---- Equipos ---- */
.cst-match-hero__teams {
  display: grid;
  grid-template-columns: 1fr auto 1fr;
  align-items: center;
  gap: var(--cst-sp-5);
  margin-bottom: var(--cst-sp-5);
}

.cst-match-hero__team {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--cst-sp-3);
  text-align: center;
}

.cst-match-hero__team--away {
  order: 3;
}

/* Escudo hexagonal */
.cst-match-hero__crest {
  width: 96px;
  height: 96px;
  clip-path: polygon(50% 0%, 93% 18%, 93% 68%, 50% 100%, 7% 68%, 7% 18%);
  background: rgba(255, 255, 255, .95);
  color: var(--cst-brand-dark);
  display: grid;
  place-items: center;
  font-family: var(--heading-font);
  font-weight: 900;
  font-size: 1.45rem;
  letter-spacing: .04em;
  filter: drop-shadow(0 8px 20px rgba(0, 0, 0, .35));
  transition: transform .35s var(--cst-ease), filter .35s var(--cst-ease);
}

.cst-match-hero__crest:hover {
  transform: scale(1.07) translateY(-3px);
  filter: drop-shadow(0 14px 28px rgba(0, 0, 0, .5));
}

.cst-match-hero__team-name {
  font-family: var(--heading-font);
  font-weight: 800;
  font-size: 1rem;
  margin: 0;
  color: #fff;
  line-height: 1.25;
  max-width: 16ch;
}

/* Condición Local / Visita */
.cst-match-hero__condition {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  font-size: .65rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .1em;
  padding: 4px 12px;
  border-radius: var(--cst-radius-pill);
}

.cst-match-hero__condition--local {
  background: rgba(255, 255, 255, .15);
  color: #fff;
  border: 1px solid rgba(255, 255, 255, .28);
}

.cst-match-hero__condition--visit {
  background: rgba(0, 0, 0, .22);
  color: rgba(255, 255, 255, .78);
  border: 1px solid rgba(255, 255, 255, .12);
}

/* Guía de forma: últimos 5 resultados */
.cst-match-hero__form {
  display: flex;
  gap: 5px;
  justify-content: center;
}

.cst-match-hero__form-dot {
  width: 22px;
  height: 22px;
  border-radius: 50%;
  font-size: .58rem;
  font-weight: 800;
  display: grid;
  place-items: center;
  text-transform: uppercase;
  line-height: 1;
}

.cst-match-hero__form-dot--win  { background: #22c55e; color: #fff; }
.cst-match-hero__form-dot--draw { background: #f59e0b; color: #fff; }
.cst-match-hero__form-dot--loss { background: rgba(255, 255, 255, .22); color: rgba(255, 255, 255, .72); }

/* ---- VS central ---- */
.cst-match-hero__vs-wrap {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--cst-sp-3);
}

.cst-match-hero__vs {
  position: relative;
  width: 76px;
  height: 76px;
  border-radius: 50%;
  background: rgba(255, 255, 255, .1);
  border: 2px solid rgba(255, 255, 255, .2);
  display: grid;
  place-items: center;
  font-family: var(--heading-font);
  font-weight: 900;
  font-size: 1.2rem;
  letter-spacing: .08em;
  flex-shrink: 0;
}

/* Anillo giratorio */
.cst-match-hero__vs::before {
  content: "";
  position: absolute;
  inset: -8px;
  border-radius: 50%;
  border: 2px solid transparent;
  border-top-color: rgba(255, 255, 255, .45);
  border-right-color: rgba(255, 255, 255, .18);
  animation: cst-vs-ring 5s linear infinite;
}

@keyframes cst-vs-ring {
  to { transform: rotate(360deg); }
}

.cst-match-hero__vs-meta {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 5px;
}

.cst-match-hero__date-pill {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  background: rgba(255, 255, 255, .1);
  border: 1px solid rgba(255, 255, 255, .14);
  border-radius: var(--cst-radius-pill);
  padding: 5px 12px;
  font-size: .7rem;
  font-weight: 600;
  white-space: nowrap;
}

/* ---- Countdown glass ---- */
.cst-match-hero__count {
  display: flex;
  justify-content: center;
  max-width: 520px;
  margin: 0 auto var(--cst-sp-5);
  border-radius: var(--cst-radius-md);
  overflow: hidden;
  border: 1px solid rgba(255, 255, 255, .1);
}

.cst-match-hero__count-cell {
  flex: 1;
  background: rgba(0, 0, 0, .32);
  backdrop-filter: blur(8px);
  text-align: center;
  padding: var(--cst-sp-4) var(--cst-sp-3);
  position: relative;
}

/* Línea divisoria (flip-clock) */
.cst-match-hero__count-cell::after {
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  top: 50%;
  height: 1px;
  background: rgba(255, 255, 255, .07);
  pointer-events: none;
}

/* Separador de dos puntos entre celdas */
.cst-match-hero__count-cell + .cst-match-hero__count-cell {
  border-left: 1px solid rgba(255, 255, 255, .07);
}

.cst-match-hero__count-cell + .cst-match-hero__count-cell::before {
  content: ":";
  position: absolute;
  left: -9px;
  top: 50%;
  transform: translateY(-68%);
  font-size: 1.4rem;
  font-weight: 900;
  color: rgba(255, 255, 255, .3);
  line-height: 1;
  pointer-events: none;
}

.cst-match-hero__count-num {
  display: block;
  font-family: var(--heading-font);
  font-weight: 900;
  font-size: clamp(2rem, 5vw, 3rem);
  line-height: 1;
  font-variant-numeric: tabular-nums;
  letter-spacing: -.02em;
}

.cst-match-hero__count-label {
  display: block;
  margin-top: 8px;
  font-size: .6rem;
  text-transform: uppercase;
  letter-spacing: .18em;
  opacity: .65;
  font-weight: 700;
}

.cst-match-hero__count--live .cst-match-hero__count-cell {
  background: rgba(34, 197, 94, .22);
}

/* ---- Acciones ---- */
.cst-match-hero__actions {
  display: flex;
  flex-wrap: wrap;
  gap: var(--cst-sp-3);
  justify-content: center;
}

.cst-match-hero__btn {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 13px 26px;
  border-radius: var(--cst-radius-pill);
  font-weight: 700;
  font-size: .9rem;
  border: 1.5px solid transparent;
  cursor: pointer;
  transition: transform .25s var(--cst-ease), background .25s var(--cst-ease), color .25s var(--cst-ease), box-shadow .25s;
  text-decoration: none;
}

.cst-match-hero__btn--primary {
  background: #fff;
  color: var(--cst-brand-dark);
  box-shadow: 0 4px 16px rgba(0, 0, 0, .2);
}

.cst-match-hero__btn--primary:hover {
  transform: translateY(-2px);
  color: var(--cst-brand-dark);
  box-shadow: 0 8px 24px rgba(0, 0, 0, .3);
}

.cst-match-hero__btn--ghost {
  background: transparent;
  color: #fff;
  border-color: rgba(255, 255, 255, .45);
}

.cst-match-hero__btn--ghost:hover {
  background: rgba(255, 255, 255, .12);
  color: #fff;
  transform: translateY(-2px);
}

@media (max-width: 767.98px) {
  .cst-match-hero__teams { gap: var(--cst-sp-3); }

  .cst-match-hero__crest {
    width: 76px;
    height: 76px;
    font-size: 1.2rem;
  }

  .cst-match-hero__vs {
    width: 58px;
    height: 58px;
    font-size: 1rem;
  }
}

@media (max-width: 479.98px) {
  .cst-match-hero__teams {
    grid-template-columns: 1fr;
    gap: var(--cst-sp-4);
  }

  .cst-match-hero__team--away { order: 0; }

  .cst-match-hero__vs-wrap {
    order: -1;
    margin: var(--cst-sp-2) 0;
  }
}

/* Variante compacta para home */
.cst-match-hero--compact {
  padding: clamp(20px, 3vw, 36px);
}

.cst-match-hero--compact .cst-match-hero__crest {
  width: 80px;
  height: 80px;
  font-size: 1.25rem;
}

.cst-match-hero--compact .cst-match-hero__vs {
  width: 62px;
  height: 62px;
  font-size: 1.1rem;
}

/* --------------------------------------------------------------------------
   3. cst-match-card — Card compacta para fixture y resultados
   -------------------------------------------------------------------------- */
.cst-match-list {
  display: grid;
  gap: var(--cst-sp-3);
}

.cst-match-card {
  display: grid;
  grid-template-columns: 88px 1fr auto;
  align-items: center;
  gap: var(--cst-sp-4);
  background: var(--background-color);
  border: 1px solid var(--cst-line);
  border-radius: var(--cst-radius-md);
  padding: var(--cst-sp-4) var(--cst-sp-5);
  box-shadow: var(--cst-shadow-sm);
  transition: transform .25s var(--cst-ease), box-shadow .25s var(--cst-ease);
}

.cst-match-card:hover {
  transform: translateY(-3px);
  box-shadow: var(--cst-shadow-md);
}

.cst-match-card__date {
  text-align: center;
  border-right: 1px solid var(--cst-line);
  padding-right: var(--cst-sp-4);
  line-height: 1;
}

.cst-match-card__day {
  display: block;
  font-size: .72rem;
  text-transform: uppercase;
  letter-spacing: .12em;
  color: var(--cst-ink-3);
  margin-bottom: 6px;
}

.cst-match-card__num {
  display: block;
  font-family: var(--heading-font);
  font-weight: 800;
  font-size: 2rem;
  color: var(--cst-brand-dark);
}

.cst-match-card__month {
  display: block;
  font-size: .8rem;
  font-weight: 600;
  margin-top: 4px;
  color: var(--cst-ink-2);
  text-transform: uppercase;
}

.cst-match-card__body {
  display: flex;
  flex-direction: column;
  gap: 4px;
}

.cst-match-card__teams {
  font-family: var(--heading-font);
  font-weight: 700;
  font-size: 1.05rem;
  color: var(--cst-ink-1);
  margin: 0;
}

.cst-match-card__teams strong {
  color: var(--cst-brand-dark);
}

.cst-match-card__meta {
  display: flex;
  flex-wrap: wrap;
  gap: var(--cst-sp-3);
  font-size: .85rem;
  color: var(--cst-ink-3);
}

.cst-match-card__meta i {
  margin-right: 4px;
  color: var(--cst-brand);
}

.cst-match-card__side {
  display: flex;
  flex-direction: column;
  align-items: flex-end;
  gap: 6px;
  min-width: 90px;
}

.cst-match-card__condition {
  display: inline-block;
  font-size: .72rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .08em;
  padding: 4px 10px;
  border-radius: var(--cst-radius-pill);
}

.cst-match-card__condition--local {
  background: var(--cst-brand-soft);
  color: var(--cst-brand-dark);
}

.cst-match-card__condition--visit {
  background: var(--cst-line-soft);
  color: var(--cst-ink-2);
}

.cst-match-card__score {
  font-family: var(--heading-font);
  font-weight: 800;
  font-size: 1.6rem;
  color: var(--cst-ink-1);
  font-variant-numeric: tabular-nums;
}

@media (max-width: 575.98px) {
  .cst-match-card {
    grid-template-columns: 64px 1fr;
    grid-template-rows: auto auto;
    padding: var(--cst-sp-3) var(--cst-sp-4);
    gap: var(--cst-sp-3);
  }

  .cst-match-card__side {
    grid-column: 1 / -1;
    flex-direction: row;
    justify-content: space-between;
    align-items: center;
    border-top: 1px solid var(--cst-line-soft);
    padding-top: var(--cst-sp-3);
    min-width: 0;
  }

  .cst-match-card__num {
    font-size: 1.6rem;
  }
}

/* --------------------------------------------------------------------------
   4. cst-result-badge — Resultado Victoria / Empate / Derrota
   -------------------------------------------------------------------------- */
.cst-result-badge {
  display: inline-block;
  font-size: .72rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .08em;
  padding: 4px 10px;
  border-radius: var(--cst-radius-pill);
}

.cst-result-badge--win   { background: var(--cst-success-soft); color: var(--cst-success); }
.cst-result-badge--draw  { background: var(--cst-warning-soft); color: #555; }
.cst-result-badge--loss  { background: var(--cst-danger-soft);  color: var(--cst-danger); }

/* --------------------------------------------------------------------------
   5. cst-standings — Tabla de posiciones rediseñada
   -------------------------------------------------------------------------- */
.cst-standings-wrap {
  border-radius: var(--cst-radius-md);
  background: var(--background-color);
  box-shadow: var(--cst-shadow-md);
  overflow: hidden;
  position: relative;
}

.cst-standings-scroll {
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
}

@media (max-width: 767.98px) {
  .cst-standings-scroll {
    box-shadow: inset -12px 0 12px -12px rgba(0, 0, 0, .15);
  }
}

.cst-standings {
  width: 100%;
  border-collapse: collapse;
  min-width: 720px;
  font-size: .92rem;
}

.cst-standings thead th {
  background: var(--cst-brand-dark);
  color: var(--contrast-color);
  text-transform: uppercase;
  font-size: .72rem;
  letter-spacing: .1em;
  font-weight: 700;
  padding: 14px 12px;
  text-align: center;
  white-space: nowrap;
}

.cst-standings thead th:nth-child(2) {
  text-align: left;
}

.cst-standings tbody td {
  padding: 12px;
  border-bottom: 1px solid var(--cst-line-soft);
  text-align: center;
  vertical-align: middle;
}

.cst-standings tbody td:nth-child(2) {
  text-align: left;
  font-weight: 600;
  color: var(--cst-ink-1);
}

.cst-standings tbody tr:hover {
  background: var(--cst-brand-tint);
}

.cst-standings__pos {
  display: inline-grid;
  place-items: center;
  width: 28px;
  height: 28px;
  border-radius: 50%;
  font-weight: 700;
  font-size: .85rem;
  background: var(--cst-line-soft);
  color: var(--cst-ink-2);
}

.cst-standings__pos--top   { background: var(--cst-success); color: #fff; }
.cst-standings__pos--down  { background: var(--cst-danger);  color: #fff; }

.cst-standings__row--us {
  background: var(--cst-brand-soft);
  box-shadow: inset 4px 0 0 0 var(--cst-brand);
}

.cst-standings__row--us td:nth-child(2) {
  font-weight: 800;
  color: var(--cst-brand-dark);
}

.cst-standings__pts {
  font-family: var(--heading-font);
  font-weight: 800;
  color: var(--cst-ink-1);
}

/* --------------------------------------------------------------------------
   6. cst-social-card — Card por red social
   -------------------------------------------------------------------------- */
.cst-social-card {
  background: var(--background-color);
  border-radius: var(--cst-radius-md);
  overflow: hidden;
  box-shadow: var(--cst-shadow-sm);
  transition: transform .25s var(--cst-ease), box-shadow .25s var(--cst-ease);
  display: flex;
  flex-direction: column;
  height: 100%;
}

.cst-social-card:hover {
  transform: translateY(-4px);
  box-shadow: var(--cst-shadow-md);
}

.cst-social-card__head {
  padding: var(--cst-sp-5);
  color: #fff;
  display: flex;
  align-items: center;
  gap: var(--cst-sp-4);
  position: relative;
}

.cst-social-card__head i {
  font-size: 2.4rem;
  filter: drop-shadow(0 2px 6px rgba(0, 0, 0, .2));
}

.cst-social-card__head h3 {
  margin: 0;
  color: #fff;
  font-size: 1.35rem;
  font-weight: 800;
}

.cst-social-card__handle {
  display: block;
  font-size: .85rem;
  opacity: .9;
  margin-top: 2px;
}

.cst-social-card--ig .cst-social-card__head {
  background: linear-gradient(135deg, #f58529 0%, #dd2a7b 50%, #8134af 100%);
}
.cst-social-card--fb .cst-social-card__head { background: linear-gradient(135deg, #1877f2 0%, #0a4fb3 100%); }
.cst-social-card--wa .cst-social-card__head { background: linear-gradient(135deg, #25d366 0%, #128c4a 100%); }
.cst-social-card--yt .cst-social-card__head { background: linear-gradient(135deg, #ff5252 0%, #c4302b 100%); }

.cst-social-card__body {
  padding: var(--cst-sp-5);
  flex: 1;
  display: flex;
  flex-direction: column;
  gap: var(--cst-sp-4);
}

.cst-social-card__desc {
  margin: 0;
  color: var(--cst-ink-2);
  font-size: .95rem;
  line-height: 1.5;
}

.cst-social-card__stats {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--cst-sp-2);
  text-align: center;
  border-top: 1px solid var(--cst-line-soft);
  padding-top: var(--cst-sp-4);
}

.cst-social-card__stat-num {
  display: block;
  font-family: var(--heading-font);
  font-weight: 800;
  font-size: 1.2rem;
  color: var(--cst-ink-1);
  line-height: 1;
}

.cst-social-card__stat-label {
  display: block;
  font-size: .72rem;
  text-transform: uppercase;
  letter-spacing: .08em;
  color: var(--cst-ink-3);
  margin-top: 4px;
}

.cst-social-card__foot {
  padding: 0 var(--cst-sp-5) var(--cst-sp-5);
  display: flex;
  gap: var(--cst-sp-2);
}

.cst-social-card__btn {
  flex: 1;
  text-align: center;
  padding: 10px 14px;
  border-radius: var(--cst-radius-pill);
  font-weight: 600;
  font-size: .9rem;
  text-decoration: none;
  transition: background .25s var(--cst-ease), color .25s var(--cst-ease), transform .25s var(--cst-ease);
  border: 1px solid transparent;
}

.cst-social-card__btn--primary {
  background: var(--cst-brand);
  color: #fff;
}

.cst-social-card__btn--primary:hover {
  background: var(--cst-brand-dark);
  color: #fff;
  transform: translateY(-1px);
}

.cst-social-card__btn--ghost {
  background: transparent;
  color: var(--cst-ink-2);
  border-color: var(--cst-line);
}

.cst-social-card__btn--ghost:hover {
  border-color: var(--cst-brand);
  color: var(--cst-brand-dark);
}

/* --------------------------------------------------------------------------
   7. cst-feed-grid — Mock de feed Instagram 3x3
   -------------------------------------------------------------------------- */
.cst-feed-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 4px;
  border-radius: var(--cst-radius-md);
  overflow: hidden;
}

.cst-feed-grid__cell {
  position: relative;
  aspect-ratio: 1 / 1;
  overflow: hidden;
  background: var(--cst-line-soft);
}

.cst-feed-grid__cell img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform .4s var(--cst-ease);
}

.cst-feed-grid__cell:hover img {
  transform: scale(1.06);
}

.cst-feed-grid__overlay {
  position: absolute;
  inset: 0;
  background: rgba(0, 0, 0, .55);
  color: #fff;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: var(--cst-sp-4);
  opacity: 0;
  transition: opacity .3s var(--cst-ease);
  font-weight: 700;
}

.cst-feed-grid__overlay i {
  margin-right: 6px;
}

.cst-feed-grid__cell:hover .cst-feed-grid__overlay,
.cst-feed-grid__cell:focus-within .cst-feed-grid__overlay {
  opacity: 1;
}

@media (max-width: 575.98px) {
  .cst-feed-grid { grid-template-columns: repeat(3, 1fr); }
  .cst-feed-grid__overlay { font-size: .8rem; gap: var(--cst-sp-2); }
}

/* --------------------------------------------------------------------------
   8. cst-hashtag-band — Banda de hashtags
   -------------------------------------------------------------------------- */
.cst-hashtag-band {
  background: linear-gradient(135deg, var(--cst-brand-dark) 0%, var(--cst-brand) 100%);
  color: #fff;
  border-radius: var(--cst-radius-lg);
  padding: clamp(28px, 5vw, 56px);
  text-align: center;
  position: relative;
  overflow: hidden;
}

.cst-hashtag-band__tags {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: var(--cst-sp-5);
  font-family: var(--heading-font);
  font-weight: 900;
  font-size: clamp(1.6rem, 5vw, 3rem);
  letter-spacing: -.01em;
  margin: var(--cst-sp-4) 0 var(--cst-sp-3);
}

.cst-hashtag-band__tags span {
  position: relative;
  padding: 0 4px;
}

.cst-hashtag-band__tags span::after {
  content: "";
  position: absolute;
  left: 0; right: 0; bottom: -4px;
  height: 4px;
  background: rgba(255, 255, 255, .35);
  border-radius: 2px;
}

.cst-hashtag-band__sub {
  margin: 0;
  opacity: .9;
  font-size: 1rem;
}

/* --------------------------------------------------------------------------
   9. cst-sponsor-logo — Slide del carrusel de sponsors
   -------------------------------------------------------------------------- */
.cst-sponsors-swiper {
  padding: var(--cst-sp-3) 0;
}

.cst-sponsor-logo {
  background: #fff;
  border: 1px solid var(--cst-line);
  border-radius: var(--cst-radius-md);
  height: 120px;
  display: grid;
  place-items: center;
  padding: var(--cst-sp-4);
  text-align: center;
  filter: grayscale(100%);
  opacity: .75;
  transition: filter .3s var(--cst-ease), opacity .3s var(--cst-ease), transform .3s var(--cst-ease);
}

.cst-sponsor-logo:hover {
  filter: grayscale(0);
  opacity: 1;
  transform: translateY(-2px);
}

.cst-sponsor-logo__mark {
  font-family: var(--heading-font);
  font-weight: 900;
  font-size: 2rem;
  color: var(--cst-brand-dark);
  letter-spacing: .04em;
  line-height: 1;
}

.cst-sponsor-logo__name {
  display: block;
  font-size: .75rem;
  text-transform: uppercase;
  letter-spacing: .1em;
  color: var(--cst-ink-3);
  margin-top: 6px;
}

/* --------------------------------------------------------------------------
   10. cst-plan-card — Planes de auspicio
   -------------------------------------------------------------------------- */
.cst-plan-card {
  position: relative;
  background: var(--background-color);
  border-radius: var(--cst-radius-md);
  box-shadow: var(--cst-shadow-sm);
  overflow: hidden;
  height: 100%;
  display: flex;
  flex-direction: column;
  transition: transform .3s var(--cst-ease), box-shadow .3s var(--cst-ease);
}

.cst-plan-card:hover {
  transform: translateY(-4px);
  box-shadow: var(--cst-shadow-md);
}

.cst-plan-card__head {
  padding: var(--cst-sp-5);
  color: #fff;
  text-align: center;
}

.cst-plan-card--bronze .cst-plan-card__head { background: linear-gradient(135deg, #b27a4a 0%, #7a4d27 100%); }
.cst-plan-card--silver .cst-plan-card__head { background: linear-gradient(135deg, #b8bdc4 0%, #6f757d 100%); }
.cst-plan-card--gold   .cst-plan-card__head { background: linear-gradient(135deg, #e2b94a 0%, #a87917 100%); }

.cst-plan-card__name {
  margin: 0;
  font-size: .85rem;
  text-transform: uppercase;
  letter-spacing: .14em;
  font-weight: 700;
  color: #fff;
  opacity: .9;
}

.cst-plan-card__price {
  display: block;
  font-family: var(--heading-font);
  font-weight: 900;
  font-size: 2.2rem;
  margin-top: 6px;
  line-height: 1;
}

.cst-plan-card__period {
  display: block;
  font-size: .8rem;
  opacity: .85;
  margin-top: 4px;
}

.cst-plan-card__body {
  padding: var(--cst-sp-5);
  flex: 1;
}

.cst-plan-card__list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: var(--cst-sp-3);
}

.cst-plan-card__list li {
  display: flex;
  gap: 10px;
  align-items: flex-start;
  font-size: .95rem;
  color: var(--cst-ink-2);
}

.cst-plan-card__list i {
  margin-top: 3px;
  font-size: 1rem;
  flex-shrink: 0;
}

.cst-plan-card--bronze .cst-plan-card__list i { color: #a06636; }
.cst-plan-card--silver .cst-plan-card__list i { color: #6f757d; }
.cst-plan-card--gold   .cst-plan-card__list i { color: #b88a1e; }

.cst-plan-card__foot {
  padding: 0 var(--cst-sp-5) var(--cst-sp-5);
}

.cst-plan-card__cta {
  display: block;
  text-align: center;
  padding: 12px;
  border-radius: var(--cst-radius-pill);
  background: var(--cst-brand);
  color: #fff;
  font-weight: 700;
  text-decoration: none;
  transition: background .25s var(--cst-ease);
}

.cst-plan-card__cta:hover { background: var(--cst-brand-dark); color: #fff; }

.cst-plan-card--featured {
  transform: scale(1.03);
  box-shadow: var(--cst-shadow-lg);
}

.cst-plan-card--featured:hover {
  transform: scale(1.03) translateY(-4px);
}

.cst-plan-card__ribbon {
  position: absolute;
  top: 14px;
  right: -38px;
  background: var(--cst-brand-dark);
  color: #fff;
  font-size: .72rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .08em;
  padding: 6px 44px;
  transform: rotate(35deg);
  box-shadow: 0 4px 10px rgba(0, 0, 0, .15);
}

/* --------------------------------------------------------------------------
   11. cst-stat-band — Stats institucionales (tarjetas individuales)
   -------------------------------------------------------------------------- */
.cst-stat-band {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: var(--cst-sp-4);
}

.cst-stat-band__item {
  background: var(--background-color);
  border: 1px solid var(--cst-line);
  border-radius: var(--cst-radius-md);
  padding: var(--cst-sp-5) var(--cst-sp-4) var(--cst-sp-4);
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--cst-sp-3);
  text-align: center;
  box-shadow: var(--cst-shadow-sm);
  position: relative;
  overflow: hidden;
  transition: transform .3s var(--cst-ease), box-shadow .3s var(--cst-ease);
}

/* Barra roja superior */
.cst-stat-band__item::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 4px;
  background: linear-gradient(90deg, var(--cst-brand-dark), var(--cst-brand));
}

.cst-stat-band__item:hover {
  transform: translateY(-5px);
  box-shadow: var(--cst-shadow-md);
}

.cst-stat-band__icon {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 56px;
  height: 56px;
  border-radius: 50%;
  background: linear-gradient(135deg, var(--cst-brand) 0%, var(--cst-brand-dark) 100%);
  color: #fff;
  font-size: 1.4rem;
  box-shadow: 0 6px 16px color-mix(in srgb, var(--cst-brand) 28%, transparent);
  flex-shrink: 0;
  margin-top: var(--cst-sp-1);
}

.cst-stat-band__num {
  font-family: var(--heading-font);
  font-weight: 900;
  font-size: clamp(2rem, 4.5vw, 2.8rem);
  line-height: 1;
  color: var(--cst-ink-1);
  letter-spacing: -.02em;
}

.cst-stat-band__label {
  font-size: .75rem;
  text-transform: uppercase;
  letter-spacing: .12em;
  color: var(--cst-ink-3);
  font-weight: 700;
  line-height: 1.3;
}

.cst-stat-band__context {
  font-size: .78rem;
  color: var(--cst-ink-3);
  margin: 0;
  line-height: 1.4;
}

@media (max-width: 767.98px) {
  .cst-stat-band { grid-template-columns: repeat(2, 1fr); }
}

/* --------------------------------------------------------------------------
   12. cst-step-card — Tarjeta de paso de inscripción
   -------------------------------------------------------------------------- */
.cst-step-card {
  background: #fff;
  border: 1px solid var(--cst-line);
  border-radius: var(--cst-radius-lg);
  padding: var(--cst-sp-6) var(--cst-sp-5);
  height: 100%;
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  position: relative;
  overflow: hidden;
  box-shadow: var(--cst-shadow-sm);
  transition: transform .28s var(--cst-ease), box-shadow .28s var(--cst-ease);
}

.cst-step-card:hover {
  transform: translateY(-6px);
  box-shadow: var(--cst-shadow-md);
}

.cst-step-card--active {
  background: linear-gradient(145deg, var(--cst-brand) 0%, var(--cst-brand-dark) 100%);
  border-color: transparent;
  box-shadow: 0 14px 36px color-mix(in srgb, var(--cst-brand) 38%, transparent);
}

/* Número decorativo de fondo */
.cst-step-card::before {
  content: attr(data-step);
  position: absolute;
  top: -8px;
  right: 10px;
  font-size: 7rem;
  font-weight: 900;
  line-height: 1;
  color: var(--cst-line);
  font-family: var(--heading-font);
  pointer-events: none;
  user-select: none;
  transition: color .28s;
}

.cst-step-card--active::before {
  color: rgba(255, 255, 255, .1);
}

.cst-step-card__badge {
  display: inline-flex;
  align-items: center;
  background: var(--cst-brand-tint);
  color: var(--cst-brand);
  font-size: .7rem;
  font-weight: 700;
  letter-spacing: .08em;
  text-transform: uppercase;
  padding: 4px 12px;
  border-radius: var(--cst-radius-pill);
  margin-bottom: var(--cst-sp-4);
  position: relative;
  z-index: 1;
}

.cst-step-card--active .cst-step-card__badge {
  background: rgba(255, 255, 255, .2);
  color: #fff;
}

.cst-step-card__icon {
  width: 68px;
  height: 68px;
  border-radius: 50%;
  background: var(--cst-brand-soft);
  display: flex;
  align-items: center;
  justify-content: center;
  margin-bottom: var(--cst-sp-4);
  position: relative;
  z-index: 1;
  transition: background .28s var(--cst-ease);
}

.cst-step-card:hover .cst-step-card__icon {
  background: color-mix(in srgb, var(--cst-brand) 20%, #fff);
}

.cst-step-card__icon i {
  font-size: 1.8rem;
  color: var(--cst-brand);
}

.cst-step-card--active .cst-step-card__icon {
  background: rgba(255, 255, 255, .18);
}

.cst-step-card--active .cst-step-card__icon i {
  color: #fff;
}

.cst-step-card__title {
  font-size: 1.1rem;
  font-weight: 700;
  margin-bottom: var(--cst-sp-2);
  color: var(--cst-ink-1);
  position: relative;
  z-index: 1;
}

.cst-step-card--active .cst-step-card__title {
  color: #fff;
}

.cst-step-card__desc {
  font-size: .875rem;
  color: var(--cst-ink-2);
  line-height: 1.65;
  flex: 1;
  margin-bottom: var(--cst-sp-4);
  position: relative;
  z-index: 1;
}

.cst-step-card--active .cst-step-card__desc {
  color: rgba(255, 255, 255, .82);
}

.cst-step-card__tip {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  font-size: .78rem;
  font-weight: 600;
  color: var(--cst-brand);
  background: var(--cst-brand-tint);
  padding: 5px 14px;
  border-radius: var(--cst-radius-pill);
  margin-top: auto;
  position: relative;
  z-index: 1;
}

.cst-step-card--active .cst-step-card__tip {
  color: #fff;
  background: rgba(255, 255, 255, .18);
}

/* --------------------------------------------------------------------------
   12b. cst-enroll-cta — Banner CTA de inscripción
   -------------------------------------------------------------------------- */
.cst-enroll-cta__inner {
  position: relative;
  overflow: hidden;
  border-radius: var(--cst-radius-lg);
  background: linear-gradient(135deg, #1a1a1a 0%, #2d1010 45%, var(--cst-brand-dark) 100%);
  padding: clamp(32px, 5vw, 56px) clamp(24px, 4vw, 52px);
  box-shadow: var(--cst-shadow-lg);
}

.cst-enroll-cta__deco {
  position: absolute;
  inset: 0;
  pointer-events: none;
  overflow: hidden;
}

.cst-enroll-cta__deco span {
  position: absolute;
  border-radius: 50%;
}

.cst-enroll-cta__deco span:nth-child(1) {
  width: 340px; height: 340px;
  top: -120px; right: -90px;
  background: rgba(255, 255, 255, .04);
}

.cst-enroll-cta__deco span:nth-child(2) {
  width: 220px; height: 220px;
  bottom: -70px; left: 28%;
  background: color-mix(in srgb, var(--cst-brand) 18%, transparent);
}

.cst-enroll-cta__deco span:nth-child(3) {
  width: 130px; height: 130px;
  top: 35%; left: -40px;
  background: rgba(255, 255, 255, .05);
}

.cst-enroll-cta__content {
  position: relative;
  z-index: 1;
  display: flex;
  gap: var(--cst-sp-7);
  align-items: center;
  flex-wrap: wrap;
}

.cst-enroll-cta__left { flex: 1 1 300px; }

.cst-enroll-cta__tag {
  display: inline-flex;
  align-items: center;
  gap: 7px;
  background: var(--cst-brand);
  color: #fff;
  font-size: .72rem;
  font-weight: 700;
  letter-spacing: .1em;
  text-transform: uppercase;
  padding: 5px 14px;
  border-radius: var(--cst-radius-pill);
  margin-bottom: var(--cst-sp-4);
}

.cst-enroll-cta__title {
  font-family: var(--heading-font);
  font-size: clamp(1.5rem, 2.8vw, 2.1rem);
  font-weight: 800;
  color: #fff;
  margin-bottom: var(--cst-sp-3);
  line-height: 1.2;
}

.cst-enroll-cta__sub {
  font-size: .95rem;
  color: rgba(255, 255, 255, .72);
  line-height: 1.65;
  margin-bottom: var(--cst-sp-5);
}

.cst-enroll-cta__proof {
  display: flex;
  flex-wrap: wrap;
  gap: var(--cst-sp-2);
}

.cst-enroll-cta__proof span {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  font-size: .8rem;
  font-weight: 600;
  color: rgba(255, 255, 255, .7);
  background: rgba(255, 255, 255, .07);
  padding: 5px 13px;
  border-radius: var(--cst-radius-pill);
  border: 1px solid rgba(255, 255, 255, .1);
}

.cst-enroll-cta__proof span i { color: var(--cst-brand); }

.cst-enroll-cta__right {
  display: flex;
  flex-direction: column;
  align-items: stretch;
  gap: var(--cst-sp-3);
  flex: 0 0 auto;
  min-width: 220px;
}

.cst-enroll-cta__price {
  background: rgba(255, 255, 255, .08);
  border: 1px solid rgba(255, 255, 255, .14);
  border-radius: var(--cst-radius-md);
  padding: var(--cst-sp-3) var(--cst-sp-5);
  text-align: center;
}

.cst-enroll-cta__price-num {
  display: block;
  font-family: var(--heading-font);
  font-size: 2.1rem;
  font-weight: 900;
  color: #fff;
  line-height: 1;
}

.cst-enroll-cta__price-label {
  font-size: .75rem;
  color: rgba(255, 255, 255, .55);
  font-weight: 500;
}

.cst-enroll-cta__btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  padding: 14px 22px;
  border-radius: var(--cst-radius-pill);
  font-size: .9rem;
  font-weight: 700;
  text-decoration: none;
  transition: transform .22s var(--cst-ease), box-shadow .22s var(--cst-ease), background .22s;
}

.cst-enroll-cta__btn--primary {
  background: #25d366;
  color: #fff;
  box-shadow: 0 6px 20px rgba(37, 211, 102, .35);
}

.cst-enroll-cta__btn--primary:hover {
  background: #1db954;
  transform: translateY(-2px);
  box-shadow: 0 10px 26px rgba(37, 211, 102, .48);
  color: #fff;
}

.cst-enroll-cta__btn--ghost {
  background: transparent;
  color: rgba(255, 255, 255, .82);
  border: 1.5px solid rgba(255, 255, 255, .28);
}

.cst-enroll-cta__btn--ghost:hover {
  background: rgba(255, 255, 255, .09);
  border-color: rgba(255, 255, 255, .6);
  color: #fff;
  transform: translateY(-2px);
}

@media (max-width: 767.98px) {
  .cst-enroll-cta__content {
    flex-direction: column;
    gap: var(--cst-sp-5);
  }

  .cst-enroll-cta__right { width: 100%; min-width: 0; }
}

/* --------------------------------------------------------------------------
   13. cst-category-card — Categoría formativa
   -------------------------------------------------------------------------- */
.cst-category-card {
  background: var(--background-color);
  border-radius: var(--cst-radius-md);
  box-shadow: var(--cst-shadow-sm);
  overflow: hidden;
  height: 100%;
  display: flex;
  flex-direction: column;
  transition: transform .3s var(--cst-ease), box-shadow .3s var(--cst-ease);
}

.cst-category-card:hover {
  transform: translateY(-4px);
  box-shadow: var(--cst-shadow-md);
}

.cst-category-card__cover {
  position: relative;
  height: 140px;
  background: linear-gradient(135deg, var(--cst-brand) 0%, var(--cst-brand-dark) 100%);
  display: grid;
  place-items: center;
  color: #fff;
  overflow: hidden;
}

.cst-category-card__cover::after {
  content: "";
  position: absolute;
  inset: 0;
  background-image: radial-gradient(circle at 70% 30%, rgba(255, 255, 255, .25) 0, transparent 60%);
}

.cst-category-card__icon {
  font-size: 3rem;
  position: relative;
}

.cst-category-card__age {
  position: absolute;
  top: 12px;
  left: 12px;
  background: rgba(255, 255, 255, .9);
  color: var(--cst-brand-dark);
  font-size: .7rem;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: .08em;
  padding: 4px 10px;
  border-radius: var(--cst-radius-pill);
}

.cst-category-card__body {
  padding: var(--cst-sp-5);
  flex: 1;
  display: flex;
  flex-direction: column;
  gap: var(--cst-sp-4);
}

.cst-category-card__title {
  margin: 0;
  font-family: var(--heading-font);
  font-weight: 800;
  font-size: 1.2rem;
  color: var(--cst-ink-1);
}

.cst-category-card__grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--cst-sp-3);
}

.cst-category-card__grid > div {
  background: var(--cst-line-soft);
  border-radius: var(--cst-radius-sm);
  padding: var(--cst-sp-3);
}

.cst-category-card__grid dt {
  font-size: .7rem;
  text-transform: uppercase;
  letter-spacing: .08em;
  color: var(--cst-ink-3);
  margin-bottom: 4px;
}

.cst-category-card__grid dd {
  margin: 0;
  font-weight: 700;
  color: var(--cst-ink-1);
  font-size: .9rem;
}

.cst-category-card__foot {
  padding: 0 var(--cst-sp-5) var(--cst-sp-5);
}

.cst-category-card__cta {
  display: block;
  text-align: center;
  padding: 10px;
  border-radius: var(--cst-radius-pill);
  background: var(--cst-brand);
  color: #fff;
  font-weight: 700;
  text-decoration: none;
  transition: background .25s var(--cst-ease);
}

.cst-category-card__cta:hover { background: var(--cst-brand-dark); color: #fff; }

/* --------------------------------------------------------------------------
   14. cst-player-card — Card de jugador
   -------------------------------------------------------------------------- */
.cst-player-card {
  position: relative;
  background: linear-gradient(135deg, var(--cst-brand) 0%, var(--cst-brand-dark) 100%);
  color: #fff;
  border-radius: var(--cst-radius-md);
  padding: var(--cst-sp-5) var(--cst-sp-4) var(--cst-sp-4);
  overflow: hidden;
  height: 100%;
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  isolation: isolate;
  transition: transform .3s var(--cst-ease), box-shadow .3s var(--cst-ease);
  box-shadow: var(--cst-shadow-sm);
}

.cst-player-card:hover {
  transform: translateY(-4px);
  box-shadow: var(--cst-shadow-md);
}

.cst-player-card__num {
  position: absolute;
  bottom: -22px;
  right: -10px;
  font-family: var(--heading-font);
  font-weight: 900;
  font-size: 9rem;
  line-height: 1;
  color: rgba(255, 255, 255, .12);
  z-index: -1;
  letter-spacing: -.04em;
}

.cst-player-card__avatar {
  width: 110px;
  height: 110px;
  border-radius: 50%;
  background: rgba(255, 255, 255, .15);
  border: 3px solid rgba(255, 255, 255, .35);
  display: grid;
  place-items: center;
  color: rgba(255, 255, 255, .85);
  margin-bottom: var(--cst-sp-3);
  overflow: hidden;
}

.cst-player-card__avatar img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.cst-player-card__avatar svg {
  width: 60%;
  height: 60%;
}

.cst-player-card__name {
  margin: 0;
  font-family: var(--heading-font);
  font-weight: 800;
  font-size: 1.05rem;
  color: #fff;
  line-height: 1.2;
}

.cst-player-card__pos {
  display: block;
  margin-top: 6px;
  font-size: .72rem;
  text-transform: uppercase;
  letter-spacing: .14em;
  opacity: .9;
}

.cst-player-card__foot {
  margin-top: var(--cst-sp-3);
  padding-top: var(--cst-sp-3);
  border-top: 1px solid rgba(255, 255, 255, .2);
  width: 100%;
  display: flex;
  justify-content: space-around;
  font-size: .8rem;
}

.cst-player-card__foot strong {
  display: block;
  font-family: var(--heading-font);
  font-size: 1.1rem;
}

/* --------------------------------------------------------------------------
   15. cst-staff-card — Cuerpo técnico
   -------------------------------------------------------------------------- */
.cst-staff-card {
  background: var(--background-color);
  border: 1px solid var(--cst-line);
  border-radius: var(--cst-radius-md);
  padding: var(--cst-sp-5);
  text-align: center;
  height: 100%;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--cst-sp-3);
  transition: transform .3s var(--cst-ease), box-shadow .3s var(--cst-ease);
  box-shadow: var(--cst-shadow-sm);
}

.cst-staff-card:hover {
  transform: translateY(-4px);
  box-shadow: var(--cst-shadow-md);
  border-color: var(--cst-brand-soft);
}

.cst-staff-card__avatar {
  width: 84px;
  height: 84px;
  border-radius: 50%;
  background: var(--cst-brand-soft);
  display: grid;
  place-items: center;
  color: var(--cst-brand-dark);
  font-size: 2.2rem;
  overflow: hidden;
}

.cst-staff-card__avatar img {
  width: 100%; height: 100%; object-fit: cover;
}

.cst-staff-card__role {
  display: inline-block;
  background: var(--cst-brand);
  color: #fff;
  padding: 4px 12px;
  border-radius: var(--cst-radius-pill);
  font-size: .72rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .08em;
}

.cst-staff-card__name {
  margin: 0;
  font-family: var(--heading-font);
  font-weight: 800;
  font-size: 1.1rem;
  color: var(--cst-ink-1);
}

.cst-staff-card__bio {
  margin: 0;
  color: var(--cst-ink-2);
  font-size: .9rem;
  line-height: 1.5;
}

/* --------------------------------------------------------------------------
   16. cst-filter-pill — Filtros isotope rediseñados
   -------------------------------------------------------------------------- */
.cst-filter-pill {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 8px 18px;
  border-radius: var(--cst-radius-pill);
  background: var(--cst-line-soft);
  color: var(--cst-ink-2);
  font-weight: 600;
  font-size: .9rem;
  cursor: pointer;
  margin: 0 6px 10px 0;
  border: 1px solid transparent;
  transition: background .25s var(--cst-ease), color .25s var(--cst-ease), border-color .25s var(--cst-ease);
}

.cst-filter-pill:hover {
  background: var(--cst-brand-soft);
  color: var(--cst-brand-dark);
}

.cst-filter-pill.filter-active {
  background: var(--cst-brand);
  color: #fff;
}

/* --------------------------------------------------------------------------
   17. cst-facility-card — Recinto del club (split)
   -------------------------------------------------------------------------- */
.cst-facility-card {
  display: grid;
  grid-template-columns: 5fr 7fr;
  background: var(--background-color);
  border-radius: var(--cst-radius-md);
  overflow: hidden;
  box-shadow: var(--cst-shadow-sm);
  margin-bottom: var(--cst-sp-5);
  transition: box-shadow .3s var(--cst-ease);
}

.cst-facility-card:hover { box-shadow: var(--cst-shadow-md); }

.cst-facility-card__img {
  position: relative;
  min-height: 260px;
  background: var(--cst-line-soft);
}

.cst-facility-card__img img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.cst-facility-card__body {
  padding: var(--cst-sp-6);
  display: flex;
  flex-direction: column;
  gap: var(--cst-sp-3);
}

.cst-facility-card__badge {
  align-self: flex-start;
  background: var(--cst-success-soft);
  color: var(--cst-success);
  font-size: .72rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .08em;
  padding: 4px 10px;
  border-radius: var(--cst-radius-pill);
}

.cst-facility-card__title {
  margin: 0;
  font-family: var(--heading-font);
  font-weight: 800;
  font-size: 1.4rem;
  color: var(--cst-ink-1);
}

.cst-facility-card__desc {
  margin: 0;
  color: var(--cst-ink-2);
  line-height: 1.6;
}

.cst-facility-card__features {
  list-style: none;
  margin: 0;
  padding: 0;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--cst-sp-2) var(--cst-sp-4);
}

.cst-facility-card__features li {
  display: flex;
  gap: 8px;
  align-items: center;
  font-size: .9rem;
  color: var(--cst-ink-2);
}

.cst-facility-card__features i {
  color: var(--cst-brand);
}

.cst-facility-card--reverse {
  grid-template-columns: 7fr 5fr;
}

.cst-facility-card--reverse .cst-facility-card__img { order: 2; }
.cst-facility-card--reverse .cst-facility-card__body { order: 1; }

@media (max-width: 767.98px) {
  .cst-facility-card,
  .cst-facility-card--reverse {
    grid-template-columns: 1fr;
  }

  .cst-facility-card--reverse .cst-facility-card__img { order: 0; }
  .cst-facility-card--reverse .cst-facility-card__body { order: 0; }

  .cst-facility-card__features { grid-template-columns: 1fr; }
}

/* --------------------------------------------------------------------------
   18. cst-map-frame — Contenedor de mapa con header
   -------------------------------------------------------------------------- */
.cst-map-frame {
  border-radius: var(--cst-radius-md);
  overflow: hidden;
  box-shadow: var(--cst-shadow-md);
  background: var(--background-color);
  display: grid;
  grid-template-columns: 4fr 8fr;
}

.cst-map-frame__info {
  padding: var(--cst-sp-5);
  display: flex;
  flex-direction: column;
  gap: var(--cst-sp-3);
  background: var(--cst-brand-tint);
}

.cst-map-frame__title {
  margin: 0;
  font-family: var(--heading-font);
  font-weight: 800;
  color: var(--cst-ink-1);
  font-size: 1.2rem;
}

.cst-map-frame__line {
  display: flex;
  gap: 10px;
  align-items: flex-start;
  font-size: .9rem;
  color: var(--cst-ink-2);
}

.cst-map-frame__line i {
  color: var(--cst-brand);
  margin-top: 3px;
}

.cst-map-frame__cta {
  margin-top: auto;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  background: var(--cst-brand);
  color: #fff;
  padding: 10px 18px;
  border-radius: var(--cst-radius-pill);
  font-weight: 700;
  text-decoration: none;
  transition: background .25s var(--cst-ease);
  align-self: flex-start;
}

.cst-map-frame__cta:hover { background: var(--cst-brand-dark); color: #fff; }

.cst-map-frame__embed {
  min-height: 360px;
}

.cst-map-frame__embed iframe {
  width: 100%;
  height: 100%;
  border: 0;
  display: block;
}

@media (max-width: 767.98px) {
  .cst-map-frame {
    grid-template-columns: 1fr;
  }
  .cst-map-frame__embed { height: 320px; }
}

/* --------------------------------------------------------------------------
   19. cst-contact-line — Línea de contacto con icono
   -------------------------------------------------------------------------- */
.cst-contact-list {
  display: flex;
  flex-direction: column;
  gap: var(--cst-sp-3);
}

.cst-contact-line {
  display: flex;
  gap: var(--cst-sp-4);
  align-items: flex-start;
  background: var(--background-color);
  border: 1px solid var(--cst-line);
  border-radius: var(--cst-radius-md);
  padding: var(--cst-sp-4);
  transition: border-color .25s var(--cst-ease), transform .25s var(--cst-ease);
}

.cst-contact-line:hover {
  border-color: var(--cst-brand);
  transform: translateX(2px);
}

.cst-contact-line__icon {
  width: 44px;
  height: 44px;
  border-radius: 50%;
  background: var(--cst-brand-soft);
  color: var(--cst-brand-dark);
  display: grid;
  place-items: center;
  font-size: 1.2rem;
  flex-shrink: 0;
}

.cst-contact-line__label {
  display: block;
  font-size: .72rem;
  text-transform: uppercase;
  letter-spacing: .1em;
  color: var(--cst-ink-3);
  margin-bottom: 4px;
}

.cst-contact-line__value {
  display: block;
  font-weight: 600;
  color: var(--cst-ink-1);
}

.cst-contact-line__value a { color: inherit; }
.cst-contact-line__value a:hover { color: var(--cst-brand); }

/* Floating-label form (CSS puro) */
.cst-form-field {
  position: relative;
  margin-bottom: var(--cst-sp-4);
}

.cst-form-field input,
.cst-form-field textarea {
  width: 100%;
  padding: 18px 14px 8px;
  border: 1px solid var(--cst-line);
  border-radius: var(--cst-radius-sm);
  background: var(--background-color);
  font-size: .95rem;
  color: var(--cst-ink-1);
  transition: border-color .2s var(--cst-ease), box-shadow .2s var(--cst-ease);
}

.cst-form-field textarea { min-height: 130px; resize: vertical; }

.cst-form-field input:focus,
.cst-form-field textarea:focus {
  outline: none;
  border-color: var(--cst-brand);
  box-shadow: 0 0 0 3px var(--cst-brand-soft);
}

.cst-form-field label {
  position: absolute;
  top: 14px;
  left: 14px;
  color: var(--cst-ink-3);
  font-size: .95rem;
  pointer-events: none;
  transition: top .2s var(--cst-ease), font-size .2s var(--cst-ease), color .2s var(--cst-ease);
  background: transparent;
}

.cst-form-field input:focus + label,
.cst-form-field input:not(:placeholder-shown) + label,
.cst-form-field textarea:focus + label,
.cst-form-field textarea:not(:placeholder-shown) + label {
  top: 4px;
  font-size: .7rem;
  letter-spacing: .08em;
  text-transform: uppercase;
  color: var(--cst-brand-dark);
}

.cst-form-submit {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  width: 100%;
  padding: 14px;
  border: 0;
  border-radius: var(--cst-radius-pill);
  background: var(--cst-brand);
  color: #fff;
  font-weight: 700;
  font-size: 1rem;
  cursor: pointer;
  transition: background .25s var(--cst-ease), transform .25s var(--cst-ease);
}

.cst-form-submit:hover {
  background: var(--cst-brand-dark);
  transform: translateY(-1px);
}

.cst-form-note {
  text-align: center;
  margin-top: var(--cst-sp-3);
  font-size: .85rem;
  color: var(--cst-ink-3);
}

/* --------------------------------------------------------------------------
   20. cst-quick-channel — Canales rápidos
   -------------------------------------------------------------------------- */
.cst-quick-channel {
  display: flex;
  align-items: center;
  gap: var(--cst-sp-4);
  background: var(--background-color);
  border-radius: var(--cst-radius-md);
  padding: var(--cst-sp-5);
  box-shadow: var(--cst-shadow-sm);
  height: 100%;
  text-decoration: none;
  color: inherit;
  transition: transform .3s var(--cst-ease), box-shadow .3s var(--cst-ease);
}

.cst-quick-channel:hover {
  transform: translateY(-3px);
  box-shadow: var(--cst-shadow-md);
  color: inherit;
}

.cst-quick-channel__icon {
  width: 56px;
  height: 56px;
  border-radius: 50%;
  display: grid;
  place-items: center;
  font-size: 1.6rem;
  color: #fff;
  flex-shrink: 0;
}

.cst-quick-channel--wa .cst-quick-channel__icon { background: linear-gradient(135deg, #25d366 0%, #128c4a 100%); }
.cst-quick-channel--mail .cst-quick-channel__icon { background: linear-gradient(135deg, var(--cst-brand) 0%, var(--cst-brand-dark) 100%); }
.cst-quick-channel--visit .cst-quick-channel__icon { background: linear-gradient(135deg, #4a4a4a 0%, #1a1a1a 100%); }

.cst-quick-channel__title {
  margin: 0 0 4px;
  font-family: var(--heading-font);
  font-weight: 800;
  font-size: 1.05rem;
  color: var(--cst-ink-1);
}

.cst-quick-channel__desc {
  margin: 0 0 6px;
  font-size: .9rem;
  color: var(--cst-ink-2);
  line-height: 1.4;
}

.cst-quick-channel__cta {
  font-weight: 700;
  font-size: .85rem;
  color: var(--cst-brand-dark);
}

/* --------------------------------------------------------------------------
   21. cst-wa-float — WhatsApp flotante
   -------------------------------------------------------------------------- */
.cst-wa-float {
  position: fixed;
  bottom: 22px;
  right: 22px;
  width: 56px;
  height: 56px;
  border-radius: 50%;
  background: #25d366;
  color: #fff;
  display: grid;
  place-items: center;
  font-size: 1.7rem;
  text-decoration: none;
  box-shadow: 0 8px 24px rgba(37, 211, 102, .45);
  z-index: 996;
  transition: transform .25s var(--cst-ease), background .25s var(--cst-ease);
}

.cst-wa-float:hover {
  background: #128c4a;
  color: #fff;
  transform: scale(1.06);
}

.cst-wa-float::before {
  content: "";
  position: absolute;
  inset: -6px;
  border-radius: 50%;
  background: rgba(37, 211, 102, .35);
  z-index: -1;
  animation: cst-wa-pulse 2.4s var(--cst-ease) infinite;
}

@keyframes cst-wa-pulse {
  0%   { transform: scale(.9); opacity: .8; }
  70%  { transform: scale(1.4); opacity: 0; }
  100% { transform: scale(1.4); opacity: 0; }
}

@media (max-width: 575.98px) {
  .cst-wa-float {
    bottom: 84px; /* deja espacio al scroll-top */
  }
}

/* --------------------------------------------------------------------------
   22. Utilidades menores
   -------------------------------------------------------------------------- */
.cst-section-bg {
  background: var(--cst-brand-tint);
  border-radius: var(--cst-radius-lg);
  padding: clamp(24px, 4vw, 48px);
}

/* --------------------------------------------------------------------------
   23. service-item — Tarjeta de pilares / valores con icono
   -------------------------------------------------------------------------- */
.service-item {
  background: #fff;
  border: 1px solid var(--cst-line);
  border-radius: var(--cst-radius-md);
  padding: var(--cst-sp-5);
  height: 100%;
  display: flex;
  flex-direction: column;
  transition: transform .22s var(--cst-ease), box-shadow .22s var(--cst-ease), border-color .22s;
  position: relative;
  overflow: hidden;
}

.service-item:hover {
  transform: translateY(-4px);
  box-shadow: var(--cst-shadow-md);
  border-color: var(--cst-brand-soft);
}

.service-item.featured {
  border-color: var(--cst-brand);
  background: linear-gradient(
    160deg,
    color-mix(in srgb, var(--cst-brand) 5%, #fff) 0%,
    #fff 65%
  );
}

.service-item .featured-tag {
  display: inline-block;
  background: var(--cst-brand);
  color: #fff;
  font-size: .7rem;
  font-weight: 700;
  letter-spacing: .06em;
  text-transform: uppercase;
  padding: 3px 10px;
  border-radius: var(--cst-radius-pill);
  margin-bottom: var(--cst-sp-3);
  align-self: flex-start;
}

.service-item .icon-wrapper {
  width: 48px;
  height: 48px;
  border-radius: var(--cst-radius-md);
  background: var(--cst-brand-tint);
  display: flex;
  align-items: center;
  justify-content: center;
  margin-bottom: var(--cst-sp-3);
  transition: background .22s;
  flex-shrink: 0;
}

.service-item:hover .icon-wrapper {
  background: var(--cst-brand-soft);
}

.service-item .icon-wrapper i {
  font-size: 1.4rem;
  color: var(--cst-brand);
}

.service-item h4 {
  font-size: 1.05rem;
  font-weight: 700;
  margin-bottom: var(--cst-sp-2);
  color: var(--cst-ink-1);
}

.service-item > p {
  font-size: .9rem;
  color: var(--cst-ink-2);
  line-height: 1.65;
  flex: 1;
  margin-bottom: var(--cst-sp-3);
}

.service-item .read-more {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-size: .85rem;
  font-weight: 600;
  color: var(--cst-brand);
  text-decoration: none;
  margin-top: auto;
  transition: gap .18s var(--cst-ease);
}

.service-item .read-more:hover {
  gap: 10px;
}

/* --------------------------------------------------------------------------
   24. exp-card — Tarjeta de noticias / pilares / experiencia
   -------------------------------------------------------------------------- */
.exp-card {
  background: #fff;
  border: 1px solid var(--cst-line);
  border-radius: var(--cst-radius-md);
  padding: var(--cst-sp-5);
  height: 100%;
  display: flex;
  flex-direction: column;
  box-shadow: var(--cst-shadow-sm);
  transition: transform .22s var(--cst-ease), box-shadow .22s var(--cst-ease);
}

.exp-card:hover {
  transform: translateY(-4px);
  box-shadow: var(--cst-shadow-md);
}

.exp-card.featured {
  border-left: 3px solid var(--cst-brand);
  background: linear-gradient(
    160deg,
    color-mix(in srgb, var(--cst-brand) 4%, #fff) 0%,
    #fff 70%
  );
}

.exp-card .card-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: var(--cst-sp-4);
  gap: var(--cst-sp-2);
}

.exp-card .company-logo {
  width: 44px;
  height: 44px;
  background: var(--cst-brand-tint);
  border-radius: var(--cst-radius-sm);
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}

.exp-card .company-logo i {
  font-size: 1.25rem;
  color: var(--cst-brand);
}

.exp-card .period-badge {
  font-size: .7rem;
  font-weight: 700;
  letter-spacing: .06em;
  text-transform: uppercase;
  background: var(--cst-brand-tint);
  color: var(--cst-brand);
  padding: 4px 10px;
  border-radius: var(--cst-radius-pill);
  white-space: nowrap;
}

.exp-card .card-body {
  flex: 1;
  display: flex;
  flex-direction: column;
}

.exp-card .card-body h3 {
  font-size: 1.05rem;
  font-weight: 700;
  margin-bottom: 4px;
  color: var(--cst-ink-1);
  line-height: 1.35;
}

.exp-card .company-name {
  font-size: .82rem;
  font-weight: 600;
  color: var(--cst-brand);
  display: block;
  margin-bottom: 4px;
}

.exp-card .duration {
  font-size: .78rem;
  color: var(--cst-ink-3);
  display: block;
  margin-bottom: var(--cst-sp-3);
}

.exp-card .description {
  font-size: .88rem;
  color: var(--cst-ink-2);
  line-height: 1.6;
  flex: 1;
  margin-bottom: var(--cst-sp-3);
}

.exp-card .skills-tags {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  margin-top: auto;
}

.exp-card .skill-tag {
  font-size: .72rem;
  font-weight: 600;
  letter-spacing: .04em;
  background: var(--cst-line-soft);
  color: var(--cst-ink-2);
  padding: 3px 10px;
  border-radius: var(--cst-radius-pill);
}

/* --------------------------------------------------------------------------
   30. cst-mvv — Misión, visión y valores (editorial, sin tarjetas)
   -------------------------------------------------------------------------- */
.cst-mvv {
  display: flex;
  flex-direction: column;
}

.cst-mvv__row {
  display: grid;
  grid-template-columns: 72px 1fr 1.5fr;
  gap: var(--cst-sp-6);
  align-items: start;
  padding: var(--cst-sp-7) 0;
  border-top: 1px solid var(--cst-line);
  position: relative;
}

.cst-mvv__row:last-child {
  border-bottom: 1px solid var(--cst-line);
}

/* Banda de acento para la fila destacada */
.cst-mvv__row--featured {
  background: linear-gradient(90deg, var(--cst-brand-tint) 0%, rgba(255,238,238,.25) 50%, transparent 100%);
  padding-left: var(--cst-sp-5);
  padding-right: var(--cst-sp-5);
  margin-left: calc(-1 * var(--cst-sp-5));
  margin-right: calc(-1 * var(--cst-sp-5));
  border-radius: var(--cst-radius-md);
  border-top-color: transparent;
}

.cst-mvv__row--featured + .cst-mvv__row {
  border-top-color: transparent;
}

/* Columna izquierda: ícono + índice */
.cst-mvv__icon-col {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--cst-sp-2);
  padding-top: 4px;
}

.cst-mvv__icon {
  width: 52px;
  height: 52px;
  border-radius: 50%;
  background: var(--cst-line-soft);
  color: var(--cst-ink-2);
  display: grid;
  place-items: center;
  font-size: 1.3rem;
  border: 1px solid var(--cst-line);
  transition: background .25s var(--cst-ease), color .25s;
}

.cst-mvv__row:hover .cst-mvv__icon {
  background: var(--cst-brand-soft);
  color: var(--cst-brand);
}

.cst-mvv__row--featured .cst-mvv__icon {
  background: var(--cst-brand);
  color: #fff;
  border-color: var(--cst-brand);
  box-shadow: 0 4px 16px color-mix(in srgb, var(--cst-brand) 28%, transparent);
}

.cst-mvv__index {
  font-size: .62rem;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: .16em;
  color: var(--cst-ink-3);
}

/* Columna central: etiqueta + título */
.cst-mvv__label {
  display: inline-block;
  font-size: .65rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .16em;
  color: var(--cst-brand);
  margin-bottom: var(--cst-sp-3);
}

.cst-mvv__title {
  font-family: var(--heading-font);
  font-weight: 900;
  font-size: clamp(1.5rem, 2.4vw, 2.1rem);
  color: var(--cst-ink-1);
  line-height: 1.15;
  margin: 0 0 var(--cst-sp-3);
}

.cst-mvv__row--featured .cst-mvv__title {
  color: var(--cst-brand-dark);
}

.cst-mvv__horizon {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  background: var(--cst-brand);
  color: #fff;
  font-size: .65rem;
  font-weight: 700;
  letter-spacing: .1em;
  text-transform: uppercase;
  padding: 5px 13px;
  border-radius: var(--cst-radius-pill);
}

/* Columna derecha: cuerpo */
.cst-mvv__body {
  font-size: .97rem;
  color: var(--cst-ink-2);
  line-height: 1.8;
  margin: 0;
  padding-top: 4px;
}

/* Chips de valores */
.cst-mvv__values {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  padding-top: 4px;
}

.cst-mvv__value-chip {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-size: .82rem;
  font-weight: 600;
  padding: 8px 16px;
  border-radius: var(--cst-radius-pill);
  border: 1.5px solid var(--cst-line);
  color: var(--cst-ink-1);
  background: transparent;
  transition: border-color .2s var(--cst-ease), color .2s, background .2s;
  cursor: default;
}

.cst-mvv__value-chip:hover {
  border-color: var(--cst-brand);
  color: var(--cst-brand-dark);
  background: var(--cst-brand-tint);
}

.cst-mvv__value-chip i {
  font-size: .85rem;
  color: var(--cst-brand);
}

@media (max-width: 991.98px) {
  .cst-mvv__row {
    grid-template-columns: 52px 1fr;
    grid-template-rows: auto auto;
    gap: var(--cst-sp-4);
  }

  .cst-mvv__body-col {
    grid-column: 1 / -1;
    padding-left: calc(52px + var(--cst-sp-4));
  }
}

@media (max-width: 575.98px) {
  .cst-mvv__row {
    grid-template-columns: 1fr;
  }

  .cst-mvv__icon-col {
    flex-direction: row;
    align-items: center;
  }

  .cst-mvv__body-col {
    padding-left: 0;
  }
}

/* --------------------------------------------------------------------------
   31. cst-pillars — Tres pilares del club (timeline horizontal, sin tarjetas)
   -------------------------------------------------------------------------- */
.cst-pillars {
  position: relative;
}

/* Track de conexión horizontal */
.cst-pillars__track {
  position: relative;
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  margin-bottom: var(--cst-sp-6);
}

.cst-pillars__track::before {
  content: "";
  position: absolute;
  top: 26px;
  left: calc(100% / 6);
  right: calc(100% / 6);
  height: 2px;
  background: linear-gradient(90deg, var(--cst-brand-dark) 0%, var(--cst-brand) 50%, var(--cst-brand-dark) 100%);
  z-index: 0;
}

.cst-pillars__node {
  display: flex;
  justify-content: center;
  position: relative;
  z-index: 1;
}

.cst-pillars__dot {
  width: 52px;
  height: 52px;
  border-radius: 50%;
  background: var(--background-color);
  border: 2px solid var(--cst-brand);
  color: var(--cst-brand);
  display: grid;
  place-items: center;
  font-size: 1.25rem;
  box-shadow: 0 0 0 8px var(--cst-brand-tint), var(--cst-shadow-sm);
  transition: transform .3s var(--cst-ease), box-shadow .3s, background .3s, color .3s;
}

.cst-pillars__node:hover .cst-pillars__dot {
  transform: translateY(-4px);
  background: var(--cst-brand);
  color: #fff;
  box-shadow: 0 0 0 8px var(--cst-brand-soft), var(--cst-shadow-md);
}

/* Contenido de los tres pilares */
.cst-pillars__content {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
}

.cst-pillars__item {
  position: relative;
  padding: 0 var(--cst-sp-6) 0 0;
}

.cst-pillars__item:not(:first-child) {
  padding-left: var(--cst-sp-6);
  padding-right: 0;
}

.cst-pillars__item:not(:last-child)::after {
  content: "";
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  width: 1px;
  background: var(--cst-line);
}

.cst-pillars__num {
  display: block;
  font-family: var(--heading-font);
  font-weight: 900;
  font-size: 4.5rem;
  line-height: 1;
  color: var(--cst-line);
  letter-spacing: -.04em;
  margin-bottom: var(--cst-sp-3);
  user-select: none;
}

.cst-pillars__subtitle {
  display: block;
  font-size: .65rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .16em;
  color: var(--cst-brand);
  margin-bottom: var(--cst-sp-2);
}

.cst-pillars__title {
  font-family: var(--heading-font);
  font-weight: 800;
  font-size: 1.3rem;
  color: var(--cst-ink-1);
  margin: 0 0 var(--cst-sp-3);
}

.cst-pillars__body {
  font-size: .92rem;
  color: var(--cst-ink-2);
  line-height: 1.75;
  margin: 0 0 var(--cst-sp-4);
}

.cst-pillars__tags {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
}

.cst-pillars__tag {
  font-size: .72rem;
  font-weight: 600;
  padding: 4px 12px;
  border-radius: var(--cst-radius-pill);
  background: var(--cst-line-soft);
  color: var(--cst-ink-2);
  border: 1px solid var(--cst-line);
}

@media (max-width: 991.98px) {
  .cst-pillars__track { display: none; }

  .cst-pillars__content {
    grid-template-columns: 1fr;
  }

  .cst-pillars__item,
  .cst-pillars__item:not(:first-child) {
    padding: 0 0 var(--cst-sp-6) 0;
    border-bottom: 1px solid var(--cst-line);
  }

  .cst-pillars__item:last-child {
    padding-bottom: 0;
    border-bottom: 0;
  }

  .cst-pillars__item:not(:last-child)::after { display: none; }
}

/* --------------------------------------------------------------------------
   25. cst-hero-chips — Chips de acceso rápido en el hero
   -------------------------------------------------------------------------- */
.cst-hero-chips {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  justify-content: center;
  margin-top: 36px;
}

.cst-hero-chips__chip {
  display: flex;
  align-items: center;
  gap: 10px;
  background: rgba(255, 255, 255, .1);
  border: 1px solid rgba(255, 255, 255, .22);
  border-radius: var(--cst-radius-md);
  padding: 12px 20px;
  text-decoration: none;
  color: #fff;
  backdrop-filter: blur(8px);
  transition: background .25s var(--cst-ease), transform .25s var(--cst-ease), border-color .25s;
  min-width: 180px;
}

.cst-hero-chips__chip:hover {
  background: rgba(255, 255, 255, .18);
  border-color: rgba(255, 255, 255, .55);
  transform: translateY(-3px);
  color: #fff;
}

.cst-hero-chips__chip--accent {
  background: var(--cst-brand);
  border-color: var(--cst-brand);
  box-shadow: 0 6px 20px color-mix(in srgb, var(--cst-brand) 40%, transparent);
}

.cst-hero-chips__chip--accent:hover {
  background: var(--cst-brand-dark);
  border-color: var(--cst-brand-dark);
}

.cst-hero-chips__icon {
  width: 40px;
  height: 40px;
  background: rgba(255, 255, 255, .15);
  border-radius: var(--cst-radius-sm);
  display: grid;
  place-items: center;
  font-size: 1.2rem;
  flex-shrink: 0;
}

.cst-hero-chips__chip--accent .cst-hero-chips__icon {
  background: rgba(255, 255, 255, .2);
}

.cst-hero-chips__text {
  display: flex;
  flex-direction: column;
  text-align: left;
}

.cst-hero-chips__label {
  font-size: .7rem;
  text-transform: uppercase;
  letter-spacing: .1em;
  opacity: .75;
  font-weight: 600;
}

.cst-hero-chips__value {
  font-size: .9rem;
  font-weight: 700;
  line-height: 1.2;
}

@media (max-width: 575.98px) {
  .cst-hero-chips {
    gap: 8px;
    flex-direction: column;
    align-items: stretch;
  }
  .cst-hero-chips__chip {
    min-width: 0;
    width: 100%;
    flex: none;
    padding: 12px 16px;
    justify-content: flex-start;
  }
}

/* --------------------------------------------------------------------------
   26. cst-about-split — Sección sobre el club en dos columnas
   -------------------------------------------------------------------------- */
.cst-about-split {
  display: grid;
  grid-template-columns: 5fr 7fr;
  gap: var(--cst-sp-6);
  align-items: start;
}

.cst-about-split__statement {
  background: linear-gradient(145deg, #1a1a1a 0%, #2c1a1a 100%);
  border-radius: var(--cst-radius-lg);
  padding: clamp(28px, 4vw, 48px);
  color: #fff;
  position: relative;
  overflow: hidden;
  height: 100%;
  display: flex;
  flex-direction: column;
  gap: var(--cst-sp-4);
}

.cst-about-split__statement::before {
  content: "1962";
  position: absolute;
  bottom: -30px;
  right: -10px;
  font-family: var(--heading-font);
  font-weight: 900;
  font-size: 8rem;
  color: rgba(255, 255, 255, .05);
  line-height: 1;
  pointer-events: none;
  user-select: none;
}

.cst-about-split__year {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  background: var(--cst-brand);
  color: #fff;
  font-size: .72rem;
  font-weight: 700;
  letter-spacing: .1em;
  text-transform: uppercase;
  padding: 5px 14px;
  border-radius: var(--cst-radius-pill);
  align-self: flex-start;
}

.cst-about-split__statement h2 {
  font-size: clamp(1.5rem, 3vw, 2.1rem);
  font-weight: 900;
  color: #fff;
  margin: 0;
  line-height: 1.2;
}

.cst-about-split__statement > p {
  color: rgba(255, 255, 255, .75);
  line-height: 1.7;
  font-size: .95rem;
  margin: 0;
  flex: 1;
}

.cst-about-split__link {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  color: #fff;
  font-weight: 700;
  text-decoration: none;
  font-size: .9rem;
  padding: 10px 20px;
  border-radius: var(--cst-radius-pill);
  border: 1.5px solid rgba(255, 255, 255, .3);
  align-self: flex-start;
  transition: background .25s var(--cst-ease), border-color .25s;
  margin-top: auto;
}

.cst-about-split__link:hover {
  background: rgba(255, 255, 255, .1);
  border-color: rgba(255, 255, 255, .7);
  color: #fff;
}

.cst-about-split__cards {
  display: flex;
  flex-direction: column;
  gap: var(--cst-sp-3);
}

@media (max-width: 991.98px) {
  .cst-about-split {
    grid-template-columns: 1fr;
  }
}

/* --------------------------------------------------------------------------
   27. cst-news-card — Tarjeta de noticia para el teaser
   -------------------------------------------------------------------------- */
.cst-news-card {
  background: #fff;
  border-radius: var(--cst-radius-md);
  box-shadow: var(--cst-shadow-sm);
  overflow: hidden;
  height: 100%;
  display: flex;
  flex-direction: column;
  border: 1px solid var(--cst-line);
  transition: transform .25s var(--cst-ease), box-shadow .25s var(--cst-ease);
}

.cst-news-card:hover {
  transform: translateY(-4px);
  box-shadow: var(--cst-shadow-md);
}

.cst-news-card__top {
  height: 6px;
  background: var(--cst-line-soft);
  flex-shrink: 0;
}

.cst-news-card--resultado .cst-news-card__top { background: var(--cst-success); }
.cst-news-card--escuela   .cst-news-card__top { background: var(--cst-brand); }
.cst-news-card--comunidad .cst-news-card__top { background: #8b5cf6; }

.cst-news-card__body {
  padding: var(--cst-sp-5);
  flex: 1;
  display: flex;
  flex-direction: column;
  gap: var(--cst-sp-3);
}

.cst-news-card__meta {
  display: flex;
  align-items: center;
  gap: var(--cst-sp-3);
}

.cst-news-card__badge {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  font-size: .7rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .08em;
  padding: 4px 10px;
  border-radius: var(--cst-radius-pill);
}

.cst-news-card--resultado .cst-news-card__badge { background: var(--cst-success-soft); color: var(--cst-success); }
.cst-news-card--escuela   .cst-news-card__badge { background: var(--cst-brand-tint);   color: var(--cst-brand-dark); }
.cst-news-card--comunidad .cst-news-card__badge { background: #f3eefe; color: #6d28d9; }

.cst-news-card__date {
  font-size: .78rem;
  color: var(--cst-ink-3);
  margin-left: auto;
  white-space: nowrap;
}

.cst-news-card__title {
  margin: 0;
  font-family: var(--heading-font);
  font-weight: 800;
  font-size: 1.15rem;
  color: var(--cst-ink-1);
  line-height: 1.3;
}

.cst-news-card__sub {
  font-size: .82rem;
  font-weight: 600;
  color: var(--cst-brand);
  display: block;
}

.cst-news-card__desc {
  font-size: .9rem;
  color: var(--cst-ink-2);
  line-height: 1.65;
  flex: 1;
  margin: 0;
}

.cst-news-card__foot {
  padding: var(--cst-sp-3) var(--cst-sp-5) var(--cst-sp-4);
  border-top: 1px solid var(--cst-line-soft);
  display: flex;
  align-items: center;
  gap: var(--cst-sp-3);
}

.cst-news-card__tags {
  display: flex;
  gap: 6px;
  flex-wrap: wrap;
  flex: 1;
}

.cst-news-card__tag {
  font-size: .72rem;
  font-weight: 600;
  background: var(--cst-line-soft);
  color: var(--cst-ink-2);
  padding: 3px 10px;
  border-radius: var(--cst-radius-pill);
}

.cst-news-card__link {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  font-size: .82rem;
  font-weight: 700;
  color: var(--cst-brand);
  text-decoration: none;
  white-space: nowrap;
  transition: gap .2s var(--cst-ease);
}

.cst-news-card__link:hover { gap: 9px; }

/* --------------------------------------------------------------------------
   28. cst-gallery-grid — Grid masonry del teaser de galería
   -------------------------------------------------------------------------- */
.cst-gallery-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  grid-template-rows: 260px 260px;
  gap: 12px;
}

.cst-gallery-item {
  position: relative;
  overflow: hidden;
  border-radius: var(--cst-radius-md);
  background: var(--cst-line-soft);
}

.cst-gallery-item--tall {
  grid-row: span 2;
}

.cst-gallery-item img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  transition: transform .45s var(--cst-ease);
}

.cst-gallery-item:hover img {
  transform: scale(1.06);
}

.cst-gallery-item__overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(to top, rgba(0,0,0,.7) 0%, transparent 55%);
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  padding: 18px;
  opacity: 0;
  transition: opacity .3s var(--cst-ease);
  color: #fff;
}

.cst-gallery-item:hover .cst-gallery-item__overlay {
  opacity: 1;
}

.cst-gallery-item__cat {
  font-size: .7rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .1em;
  opacity: .85;
  margin-bottom: 4px;
  color: #fff;
}

.cst-gallery-item__title {
  font-family: var(--heading-font);
  font-weight: 800;
  font-size: 1rem;
  margin: 0 0 10px;
  line-height: 1.2;
  color: #fff;
}

.cst-gallery-item__actions {
  display: flex;
  gap: 8px;
}

.cst-gallery-item__btn {
  width: 36px;
  height: 36px;
  border-radius: 50%;
  background: rgba(255,255,255,.2);
  border: 1px solid rgba(255,255,255,.4);
  color: #fff;
  display: grid;
  place-items: center;
  text-decoration: none;
  font-size: 1rem;
  transition: background .2s var(--cst-ease);
}

.cst-gallery-item__btn:hover {
  background: rgba(255,255,255,.4);
  color: #fff;
}

@media (max-width: 767.98px) {
  .cst-gallery-grid {
    grid-template-columns: 1fr 1fr;
    grid-template-rows: auto;
  }
  .cst-gallery-item--tall { grid-row: span 1; aspect-ratio: 1; }
  .cst-gallery-item { aspect-ratio: 1; }
  .cst-gallery-item__overlay { opacity: 1; }
}

@media (max-width: 479.98px) {
  .cst-gallery-grid {
    grid-template-columns: 1fr;
  }
}

/* --------------------------------------------------------------------------
   29. cst-join-card — Tarjeta de llamada a acción "Súmate"
   -------------------------------------------------------------------------- */
.cst-join-card {
  background: #fff;
  border-radius: var(--cst-radius-md);
  border: 1px solid var(--cst-line);
  overflow: hidden;
  height: 100%;
  display: flex;
  flex-direction: column;
  box-shadow: var(--cst-shadow-sm);
  transition: transform .28s var(--cst-ease), box-shadow .28s var(--cst-ease);
}

.cst-join-card:hover {
  transform: translateY(-5px);
  box-shadow: var(--cst-shadow-md);
}

.cst-join-card__bar {
  height: 5px;
  background: var(--cst-line-soft);
}

.cst-join-card--redes   .cst-join-card__bar { background: linear-gradient(90deg, #f58529, #dd2a7b, #8134af); }
.cst-join-card--sponsor .cst-join-card__bar { background: linear-gradient(90deg, var(--cst-brand-dark), var(--cst-brand)); }
.cst-join-card--escuela .cst-join-card__bar { background: linear-gradient(90deg, #25d366, #1a9e4b); }

.cst-join-card__body {
  padding: var(--cst-sp-5) var(--cst-sp-5) var(--cst-sp-4);
  flex: 1;
  display: flex;
  flex-direction: column;
  gap: var(--cst-sp-3);
}

.cst-join-card__icon {
  width: 56px;
  height: 56px;
  border-radius: var(--cst-radius-md);
  display: grid;
  place-items: center;
  font-size: 1.6rem;
}

.cst-join-card--redes   .cst-join-card__icon { background: #fef0f5; color: #dd2a7b; }
.cst-join-card--sponsor .cst-join-card__icon { background: var(--cst-brand-tint); color: var(--cst-brand-dark); }
.cst-join-card--escuela .cst-join-card__icon { background: #e8faf0; color: #1a9e4b; }

.cst-join-card__badge {
  display: inline-block;
  font-size: .7rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .08em;
  padding: 3px 10px;
  border-radius: var(--cst-radius-pill);
  align-self: flex-start;
}

.cst-join-card--redes   .cst-join-card__badge { background: #fef0f5; color: #dd2a7b; }
.cst-join-card--sponsor .cst-join-card__badge { background: var(--cst-brand-tint); color: var(--cst-brand-dark); }
.cst-join-card--escuela .cst-join-card__badge { background: #e8faf0; color: #1a9e4b; }

.cst-join-card__title {
  margin: 0;
  font-family: var(--heading-font);
  font-weight: 800;
  font-size: 1.2rem;
  color: var(--cst-ink-1);
}

.cst-join-card__desc {
  font-size: .9rem;
  color: var(--cst-ink-2);
  line-height: 1.65;
  flex: 1;
  margin: 0;
}

.cst-join-card__proof {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  margin-top: var(--cst-sp-1);
}

.cst-join-card__proof span {
  font-size: .78rem;
  font-weight: 600;
  color: var(--cst-ink-3);
  display: inline-flex;
  align-items: center;
  gap: 4px;
}

.cst-join-card__proof span i { color: var(--cst-brand); }

.cst-join-card__foot {
  padding: 0 var(--cst-sp-5) var(--cst-sp-5);
}

.cst-join-card__cta {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  padding: 12px;
  border-radius: var(--cst-radius-pill);
  font-weight: 700;
  font-size: .9rem;
  text-decoration: none;
  border: 1.5px solid transparent;
  transition: background .22s var(--cst-ease), color .22s var(--cst-ease), border-color .22s, transform .22s;
}

.cst-join-card__cta:hover { transform: translateY(-1px); }

.cst-join-card--redes .cst-join-card__cta {
  background: linear-gradient(90deg, #f58529, #dd2a7b);
  color: #fff;
}
.cst-join-card--redes .cst-join-card__cta:hover { color: #fff; opacity: .9; }

.cst-join-card--sponsor .cst-join-card__cta {
  background: var(--cst-brand);
  color: #fff;
}
.cst-join-card--sponsor .cst-join-card__cta:hover { background: var(--cst-brand-dark); color: #fff; }

.cst-join-card--escuela .cst-join-card__cta {
  background: #25d366;
  color: #fff;
  box-shadow: 0 4px 14px rgba(37,211,102,.3);
}
.cst-join-card--escuela .cst-join-card__cta:hover { background: #1db954; color: #fff; }

/* --------------------------------------------------------------------------
   32. cst-roster — Plantel en filas horizontales (sin tarjetas)
   -------------------------------------------------------------------------- */
.cst-roster {
  border-top: 2px solid var(--cst-brand);
}

.cst-roster__row {
  display: grid;
  grid-template-columns: 56px 1fr auto auto;
  align-items: center;
  gap: 0 var(--cst-sp-4);
  padding: var(--cst-sp-3) var(--cst-sp-3);
  border-bottom: 1px solid var(--cst-line-soft);
  box-shadow: inset 0 0 0 var(--cst-brand);
  transition:
    background .13s ease-out,
    box-shadow .13s ease-out,
    border-color .13s ease-out;
}

.cst-roster__row:hover {
  background: var(--cst-brand-tint);
  box-shadow: inset 3px 0 0 var(--cst-brand);
  border-bottom-color: rgba(255, 77, 79, .15);
}

/* Dorsal */
.cst-roster__num {
  font-family: var(--heading-font);
  font-weight: 900;
  font-size: 2rem;
  color: var(--cst-line);
  line-height: 1;
  text-align: center;
  user-select: none;
  transition: color .13s ease-out;
}

.cst-roster__row:hover .cst-roster__num {
  color: var(--cst-brand);
}

/* Nombre + posición */
.cst-roster__info {
  display: flex;
  flex-direction: column;
  gap: 2px;
}

.cst-roster__name {
  font-family: var(--heading-font);
  font-weight: 700;
  font-size: 1rem;
  color: var(--cst-ink-1);
  margin: 0;
  line-height: 1.2;
}

.cst-roster__pos {
  font-size: .75rem;
  text-transform: uppercase;
  letter-spacing: .08em;
  color: var(--cst-ink-3);
  line-height: 1;
}

/* Categoría badge */
.cst-roster__cat {
  display: inline-flex;
  align-items: center;
  padding: 3px 10px;
  border-radius: var(--cst-radius-pill);
  font-size: .7rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .06em;
  white-space: nowrap;
}

.cst-roster__cat--adulto {
  background: var(--cst-brand-tint);
  color: var(--cst-brand);
  border: 1px solid rgba(255,77,79,.2);
}

.cst-roster__cat--juvenil {
  background: var(--cst-line-soft);
  color: var(--cst-ink-2);
  border: 1px solid var(--cst-line);
}

.cst-roster__cat--infantil {
  background: #e8f5e9;
  color: #2e7d32;
  border: 1px solid rgba(46,125,50,.2);
}

/* Capitán + indicadores */
.cst-roster__badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 28px;
  height: 28px;
  border-radius: 50%;
  background: var(--cst-brand);
  color: #fff;
  font-family: var(--heading-font);
  font-weight: 900;
  font-size: .65rem;
  letter-spacing: .05em;
  flex-shrink: 0;
}

.cst-roster__badge--empty {
  background: transparent;
  width: 28px;
}

/* Isotope wrapper: cada fila ocupa el 100% del contenedor */
.cst-roster-wrap .portfolio-item {
  width: 100% !important;
}

/* Cabecera de grupo de categoría */
.cst-roster__group-heading {
  padding: var(--cst-sp-4) 0 var(--cst-sp-2);
  font-family: var(--heading-font);
  font-size: .72rem;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: .12em;
  color: var(--cst-ink-3);
  border-bottom: 1px solid var(--cst-line-soft);
  margin-bottom: 0;
  display: none; /* se muestra via JS si se necesita; por defecto oculto */
}

@media (max-width: 575px) {
  .cst-roster__row {
    grid-template-columns: 44px 1fr auto;
  }
  /* Ocultar columna categoría en móvil, se muestra en posición */
  .cst-roster__cat {
    display: none;
  }
}

/* --------------------------------------------------------------------------
   33. cst-staff-list — Cuerpo técnico en filas editoriales (sin tarjetas)
   -------------------------------------------------------------------------- */
.cst-staff-list {
  border-top: 2px solid var(--cst-brand);
}

.cst-staff-list__row {
  display: grid;
  grid-template-columns: 60px 200px 1fr;
  align-items: start;
  gap: var(--cst-sp-3) var(--cst-sp-5);
  padding: var(--cst-sp-5) var(--cst-sp-3);
  border-bottom: 1px solid var(--cst-line);
  box-shadow: inset 0 0 0 var(--cst-brand);
  transition:
    background .13s ease-out,
    box-shadow .13s ease-out,
    border-color .13s ease-out;
}

.cst-staff-list__row:hover {
  background: var(--cst-brand-tint);
  box-shadow: inset 3px 0 0 var(--cst-brand);
  border-bottom-color: rgba(255, 77, 79, .12);
}

/* Icono circular */
.cst-staff-list__icon {
  width: 56px;
  height: 56px;
  border-radius: 50%;
  background: var(--cst-line-soft);
  color: var(--cst-ink-2);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.4rem;
  flex-shrink: 0;
  transition: background .13s ease-out, color .13s ease-out;
}

.cst-staff-list__row:hover .cst-staff-list__icon {
  background: var(--cst-brand);
  color: #fff;
}

/* Col centro: rol + nombre */
.cst-staff-list__meta {
  display: flex;
  flex-direction: column;
  gap: 3px;
  padding-top: 4px;
}

.cst-staff-list__role {
  font-size: .7rem;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: .1em;
  color: var(--cst-brand);
  line-height: 1;
}

.cst-staff-list__name {
  font-family: var(--heading-font);
  font-weight: 800;
  font-size: 1.05rem;
  color: var(--cst-ink-1);
  margin: 0;
  line-height: 1.2;
}

.cst-staff-list__since {
  margin-top: 4px;
  display: inline-flex;
  align-items: center;
  gap: 4px;
  font-size: .7rem;
  color: var(--cst-ink-3);
  font-weight: 600;
}

.cst-staff-list__since i {
  font-size: .65rem;
}

/* Columna bio */
.cst-staff-list__bio {
  font-size: .9rem;
  color: var(--cst-ink-2);
  line-height: 1.75;
  margin: 0;
  padding-top: 4px;
}

@media (max-width: 767px) {
  .cst-staff-list__row {
    grid-template-columns: 52px 1fr;
    grid-template-rows: auto auto;
  }

  .cst-staff-list__bio {
    grid-column: 1 / -1;
    padding-top: 0;
    margin-top: var(--cst-sp-2);
  }
}

@media (max-width: 575px) {
  .cst-staff-list__row {
    grid-template-columns: 1fr;
  }

  .cst-staff-list__icon {
    width: 44px;
    height: 44px;
    font-size: 1.1rem;
  }
}

/* --------------------------------------------------------------------------
   34. cst-school-values — Valores escuela (dark editorial, 3 col, sin tarjetas)
   -------------------------------------------------------------------------- */
.cst-school-values {
  background: linear-gradient(150deg, #0f0f0f 0%, #1e0808 45%, #0f0f0f 100%);
  position: relative;
  overflow: hidden;
  padding-top: 60px;
  padding-bottom: 0;
}

/* Diagonal stripe texture */
.cst-school-values::before {
  content: "";
  position: absolute;
  inset: 0;
  background: repeating-linear-gradient(
    -55deg,
    rgba(255, 255, 255, .014) 0,
    rgba(255, 255, 255, .014) 1px,
    transparent 1px,
    transparent 40px
  );
  pointer-events: none;
  z-index: 0;
}

/* Watermark */
.cst-school-values::after {
  content: "ESCUELA";
  position: absolute;
  bottom: -20px;
  right: -30px;
  font-family: var(--heading-font);
  font-weight: 900;
  font-size: clamp(5rem, 16vw, 15rem);
  color: rgba(255, 255, 255, .025);
  line-height: 1;
  letter-spacing: .08em;
  pointer-events: none;
  user-select: none;
  z-index: 0;
}

.cst-school-values > .container {
  position: relative;
  z-index: 1;
}

/* Header strip */
.cst-school-values__header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding-bottom: var(--cst-sp-6);
  border-bottom: 1px solid rgba(255, 255, 255, .08);
}

.cst-school-values__tag {
  font-size: .68rem;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: .16em;
  color: var(--cst-brand);
}

.cst-school-values__stat {
  font-size: .88rem;
  color: rgba(255, 255, 255, .4);
  margin: 0;
}

.cst-school-values__stat strong {
  color: #fff;
  font-family: var(--heading-font);
  font-size: 1.15rem;
  font-weight: 900;
}

/* Grid 3 columnas */
.cst-school-values__grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
}

.cst-school-values__col {
  padding: var(--cst-sp-7) var(--cst-sp-6);
  position: relative;
  transition: background .2s ease-out;
}

.cst-school-values__col:not(:last-child) {
  border-right: 1px solid rgba(255, 255, 255, .08);
}

.cst-school-values__col:hover {
  background: rgba(255, 77, 79, .04);
}

/* Barra roja superior animada */
.cst-school-values__col::before {
  content: "";
  position: absolute;
  top: 0;
  left: var(--cst-sp-6);
  right: var(--cst-sp-6);
  height: 2px;
  background: var(--cst-brand);
  transform: scaleX(0);
  transform-origin: left;
  transition: transform .35s var(--cst-ease);
}

.cst-school-values__col:hover::before {
  transform: scaleX(1);
}

/* Número decorativo */
.cst-school-values__num {
  display: block;
  font-family: var(--heading-font);
  font-weight: 900;
  font-size: 3.5rem;
  color: rgba(255, 77, 79, .14);
  line-height: 1;
  margin-bottom: var(--cst-sp-4);
  transition: color .2s ease-out;
}

.cst-school-values__col:hover .cst-school-values__num {
  color: rgba(255, 77, 79, .35);
}

/* Icono */
.cst-school-values__icon {
  width: 50px;
  height: 50px;
  border-radius: 50%;
  border: 1.5px solid rgba(255, 77, 79, .35);
  color: var(--cst-brand);
  font-size: 1.25rem;
  display: flex;
  align-items: center;
  justify-content: center;
  margin-bottom: var(--cst-sp-4);
  transition: background .2s ease-out, border-color .2s ease-out, color .2s ease-out;
}

.cst-school-values__col:hover .cst-school-values__icon {
  background: var(--cst-brand);
  border-color: var(--cst-brand);
  color: #fff;
}

/* Título */
.cst-school-values__title {
  font-family: var(--heading-font);
  font-weight: 800;
  font-size: 1.2rem;
  color: #fff;
  margin: 0 0 var(--cst-sp-3);
  line-height: 1.2;
}

/* Texto */
.cst-school-values__body {
  font-size: .88rem;
  color: rgba(255, 255, 255, .52);
  line-height: 1.85;
  margin: 0;
}

@media (max-width: 991px) {
  .cst-school-values__grid {
    grid-template-columns: 1fr;
  }

  .cst-school-values__col:not(:last-child) {
    border-right: none;
    border-bottom: 1px solid rgba(255, 255, 255, .08);
  }

  .cst-school-values__header {
    flex-direction: column;
    align-items: flex-start;
    gap: var(--cst-sp-2);
  }

  .cst-school-values__col {
    padding: var(--cst-sp-6) 0;
  }

  .cst-school-values__col::before {
    left: 0;
    right: 0;
  }
}

/* --------------------------------------------------------------------------
   35. cst-cat-band — Categorías formativas en bandas (sin tarjetas)
   -------------------------------------------------------------------------- */
.cst-cat-band {
  background: linear-gradient(155deg, #160404 0%, #8b1a1a 55%, #160404 100%);
  position: relative;
  overflow: hidden;
}

/* Dot grid texture */
.cst-cat-band::before {
  content: "";
  position: absolute;
  inset: 0;
  background-image: radial-gradient(rgba(255, 255, 255, .07) 1px, transparent 1px);
  background-size: 28px 28px;
  pointer-events: none;
  z-index: 0;
}

.cst-cat-band > .container {
  position: relative;
  z-index: 1;
}

/* Override section-title sobre fondo oscuro */
.cst-cat-band .section-title h2,
.cst-cat-band .section-title p {
  color: #fff;
}

.cst-cat-band .section-title .subtitle {
  color: rgba(255, 255, 255, .55);
}

.cst-cat-band .section-title .subtitle::after {
  background: rgba(255, 255, 255, .25);
}

/* Banda individual */
.cst-cat-band__row {
  display: grid;
  grid-template-columns: 120px 1fr auto;
  align-items: center;
  gap: 0 var(--cst-sp-7);
  padding: var(--cst-sp-6) 0;
  border-top: 1px solid rgba(255, 255, 255, .1);
  position: relative;
  transition: background .15s ease-out;
}

.cst-cat-band__row:last-child {
  border-bottom: 1px solid rgba(255, 255, 255, .1);
}

.cst-cat-band__row:hover {
  background: rgba(255, 255, 255, .04);
}

/* Número decorativo */
.cst-cat-band__index {
  position: absolute;
  right: 0;
  top: 50%;
  transform: translateY(-50%);
  font-family: var(--heading-font);
  font-weight: 900;
  font-size: 8rem;
  color: rgba(255, 255, 255, .04);
  line-height: 1;
  pointer-events: none;
  user-select: none;
  transition: color .15s ease-out;
}

.cst-cat-band__row:hover .cst-cat-band__index {
  color: rgba(255, 255, 255, .07);
}

/* Columna izquierda: badge + icono */
.cst-cat-band__left {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--cst-sp-3);
  text-align: center;
}

.cst-cat-band__age {
  display: inline-block;
  background: rgba(255, 255, 255, .12);
  border: 1px solid rgba(255, 255, 255, .2);
  color: #fff;
  font-family: var(--heading-font);
  font-weight: 900;
  font-size: .7rem;
  letter-spacing: .1em;
  text-transform: uppercase;
  padding: 7px 14px;
  border-radius: var(--cst-radius-pill);
  backdrop-filter: blur(6px);
  white-space: nowrap;
}

.cst-cat-band__icon {
  font-size: 1.8rem;
  color: rgba(255, 255, 255, .3);
  transition: color .15s ease-out;
}

.cst-cat-band__row:hover .cst-cat-band__icon {
  color: rgba(255, 255, 255, .7);
}

/* Columna central */
.cst-cat-band__title {
  font-family: var(--heading-font);
  font-weight: 800;
  font-size: 1.4rem;
  color: #fff;
  margin: 0 0 var(--cst-sp-3);
}

.cst-cat-band__meta {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: var(--cst-sp-2) var(--cst-sp-5);
}

.cst-cat-band__meta-item {
  display: flex;
  flex-direction: column;
  gap: 1px;
}

.cst-cat-band__meta-label {
  font-size: .62rem;
  text-transform: uppercase;
  letter-spacing: .1em;
  color: rgba(255, 255, 255, .32);
  font-weight: 700;
}

.cst-cat-band__meta-value {
  font-size: .85rem;
  font-weight: 600;
  color: rgba(255, 255, 255, .85);
}

/* Disponibilidad */
.cst-cat-band__avail {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  font-size: .7rem;
  font-weight: 700;
  padding: 4px 12px;
  border-radius: var(--cst-radius-pill);
}

.cst-cat-band__avail--open {
  background: rgba(46, 158, 91, .2);
  color: #5dde9e;
  border: 1px solid rgba(46, 158, 91, .3);
}

.cst-cat-band__avail--few {
  background: rgba(255, 166, 0, .15);
  color: #ffc347;
  border: 1px solid rgba(255, 166, 0, .25);
}

/* Columna derecha: CTA */
.cst-cat-band__right {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--cst-sp-3);
  min-width: 130px;
}

.cst-cat-band__cta {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  padding: 13px 20px;
  background: #fff;
  color: var(--cst-brand);
  font-family: var(--heading-font);
  font-weight: 800;
  font-size: .85rem;
  border-radius: var(--cst-radius-pill);
  text-decoration: none;
  border: 1.5px solid #fff;
  transition: background .13s ease-out, color .13s ease-out, transform .13s ease-out;
}

.cst-cat-band__cta:hover {
  background: var(--cst-brand);
  color: #fff;
  border-color: var(--cst-brand);
  transform: scale(1.05);
}

@media (max-width: 991px) {
  .cst-cat-band__row {
    grid-template-columns: 90px 1fr;
    grid-template-rows: auto auto;
    gap: var(--cst-sp-3) var(--cst-sp-5);
  }

  .cst-cat-band__right {
    grid-column: 1 / -1;
    flex-direction: row;
    min-width: auto;
  }

  .cst-cat-band__cta {
    width: auto;
    padding: 12px 36px;
  }

  .cst-cat-band__index {
    font-size: 5rem;
  }
}

@media (max-width: 575px) {
  .cst-cat-band__row {
    grid-template-columns: 1fr;
  }

  .cst-cat-band__left {
    flex-direction: row;
    justify-content: flex-start;
    align-items: center;
  }

  .cst-cat-band__index {
    display: none;
  }
}

/* --------------------------------------------------------------------------
   Logo switching — default (top) vs scrolled, crossfade con opacity
   -------------------------------------------------------------------------- */

/* El anchor .logo necesita posición relativa y tamaño fijo para apilar */
.header .logo {
  position: relative;
}

.cst-logo-default,
.cst-logo-scrolled {
  height: 65px;
  width: auto;
  display: block;
  transition: opacity .35s ease, transform .35s ease;
  will-change: opacity;
}

/* Scrolled encima, invisible por defecto */
.cst-logo-scrolled {
  position: absolute;
  top: 0;
  left: 0;
  opacity: 0;
  transform: translateY(-4px);
  pointer-events: none;
}

/* Sin scroll: default visible, scrolled oculto */
.cst-logo-default {
  opacity: 1;
  transform: translateY(0);
}

/* Con scroll: cruzar opacidades */
.scrolled .header .cst-logo-default {
  opacity: 0;
  transform: translateY(4px);
}
.scrolled .header .cst-logo-scrolled {
  opacity: 1;
  transform: translateY(0);
  pointer-events: auto;
}

/* Footer logo */
.cst-footer-logo {
  height: 52px;
  width: auto;
  display: block;
  margin-bottom: 12px;
}

/* Footer links — apilados en móvil */
@media (max-width: 575.98px) {
  .footer .footer-links {
    flex: 0 0 100% !important;
    width: 100% !important;
    max-width: 100% !important;
  }
}

/* ==========================================================================
   37. cst-news — Sección de noticias editorial (sin galería)
   ========================================================================== */

/* ---- Intro / encabezado ---- */
.cst-news__intro {
  max-width: 640px;
  margin-bottom: var(--cst-sp-7);
}

.cst-news__tag {
  display: inline-block;
  font-size: .68rem;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: .18em;
  color: var(--cst-brand);
  margin-bottom: var(--cst-sp-3);
}

.cst-news__heading {
  font-family: var(--heading-font);
  font-weight: 900;
  font-size: clamp(2rem, 4vw, 2.8rem);
  color: var(--cst-ink-1);
  margin: 0 0 var(--cst-sp-3);
  line-height: 1.1;
}

.cst-news__sub {
  color: var(--cst-ink-2);
  font-size: 1rem;
  margin: 0;
  line-height: 1.6;
}

/* ---- Filtros tipo tab ---- */
.cst-news__filters.isotope-filters {
  list-style: none;
  padding: 0;
  margin: 0 0 var(--cst-sp-7);
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  border-bottom: 2px solid var(--cst-line-soft);
  padding-bottom: var(--cst-sp-4);
}

.cst-news__filters li {
  font-size: .88rem;
  font-weight: 700;
  cursor: pointer;
  padding: 9px 22px;
  border-radius: var(--cst-radius-pill);
  border: 1.5px solid var(--cst-line);
  color: var(--cst-ink-2);
  transition: background .2s var(--cst-ease), color .2s var(--cst-ease), border-color .2s var(--cst-ease);
  user-select: none;
}

.cst-news__filters li:hover {
  border-color: var(--cst-brand);
  color: var(--cst-brand-dark);
}

.cst-news__filters li.filter-active {
  background: var(--cst-brand);
  border-color: var(--cst-brand);
  color: #fff;
}

/* ---- Badge de categoría ---- */
.cst-news-cat {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  font-size: .62rem;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: .1em;
  padding: 4px 10px;
  border-radius: var(--cst-radius-pill);
  line-height: 1;
  white-space: nowrap;
}

.cst-news-cat--resultado { background: var(--cst-success-soft); color: var(--cst-success); }
.cst-news-cat--evento    { background: var(--cst-brand-tint);   color: var(--cst-brand-dark); }
.cst-news-cat--comunidad { background: #f3eefe;                 color: #6d28d9; }
.cst-news-cat--fichaje   { background: #fef3c7;                 color: #92400e; }

/* ---- Artículo destacado ---- */
.cst-news-featured {
  width: 100% !important;
  margin-bottom: var(--cst-sp-6);
}

.cst-news-featured__inner {
  display: grid;
  grid-template-columns: 55fr 45fr;
  border-radius: var(--cst-radius-lg);
  overflow: hidden;
  background: #140303;
  box-shadow: var(--cst-shadow-lg);
  text-decoration: none;
  color: inherit;
  min-height: 400px;
  transition: box-shadow .35s var(--cst-ease), transform .35s var(--cst-ease);
}

.cst-news-featured__inner:hover {
  box-shadow: 0 28px 64px rgba(0, 0, 0, .25);
  transform: translateY(-4px);
}

.cst-news-featured__img {
  position: relative;
  overflow: hidden;
}

.cst-news-featured__img img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  transition: transform .55s var(--cst-ease);
}

.cst-news-featured__inner:hover .cst-news-featured__img img {
  transform: scale(1.05);
}

/* Fade de imagen hacia el panel de texto */
.cst-news-featured__img::after {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(to right, transparent 55%, #140303 100%);
  pointer-events: none;
}

.cst-news-featured__body {
  padding: clamp(28px, 4vw, 52px);
  display: flex;
  flex-direction: column;
  justify-content: center;
  gap: var(--cst-sp-4);
}

.cst-news-featured__meta {
  display: flex;
  align-items: center;
  gap: var(--cst-sp-3);
  flex-wrap: wrap;
}

.cst-news-featured__destaque {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  background: var(--cst-brand);
  color: #fff;
  font-size: .62rem;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: .12em;
  padding: 5px 12px;
  border-radius: var(--cst-radius-pill);
}

.cst-news-featured__date {
  font-size: .78rem;
  color: rgba(255, 255, 255, .45);
  font-weight: 600;
  display: inline-flex;
  align-items: center;
  gap: 5px;
}

.cst-news-featured__headline {
  font-family: var(--heading-font);
  font-weight: 900;
  font-size: clamp(1.4rem, 2.5vw, 2rem);
  color: #fff;
  margin: 0;
  line-height: 1.15;
}

.cst-news-featured__lead {
  font-size: .95rem;
  color: rgba(255, 255, 255, .62);
  line-height: 1.8;
  margin: 0;
}

.cst-news-featured__foot {
  display: flex;
  align-items: center;
  gap: var(--cst-sp-4);
  flex-wrap: wrap;
  padding-top: var(--cst-sp-4);
  border-top: 1px solid rgba(255, 255, 255, .1);
  margin-top: auto;
}

.cst-news-featured__tags {
  display: flex;
  gap: 6px;
  flex-wrap: wrap;
  flex: 1;
}

.cst-news-featured__tags span {
  font-size: .7rem;
  font-weight: 700;
  background: rgba(255, 255, 255, .09);
  color: rgba(255, 255, 255, .65);
  padding: 4px 12px;
  border-radius: var(--cst-radius-pill);
  border: 1px solid rgba(255, 255, 255, .1);
}

.cst-news-featured__cta {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-size: .85rem;
  font-weight: 700;
  color: var(--cst-brand);
  white-space: nowrap;
  transition: gap .2s var(--cst-ease), color .2s;
}

.cst-news-featured__inner:hover .cst-news-featured__cta {
  gap: 11px;
  color: #ff7b7d;
}

@media (max-width: 767.98px) {
  .cst-news-featured__inner {
    grid-template-columns: 1fr;
    min-height: 0;
  }

  .cst-news-featured__img {
    height: 240px;
  }

  .cst-news-featured__img::after {
    background: linear-gradient(to top, #140303 0%, transparent 55%);
  }

  .cst-news-featured__body {
    padding: 28px 24px;
  }
}

/* ---- Fila de noticia estándar ---- */
.cst-news-row {
  width: 100% !important;
  /* Compensar padding lateral del inner para alinear con el intro */
  margin-left: -12px;
  margin-right: -12px;
}

.cst-news-row__inner {
  display: grid;
  grid-template-columns: 192px 1fr;
  gap: 0;
  padding: 20px 12px;
  border-bottom: 1px solid var(--cst-line-soft);
  text-decoration: none;
  color: inherit;
  align-items: center;
  border-radius: var(--cst-radius-md);
  position: relative;
  transition:
    background .22s var(--cst-ease),
    border-bottom-color .22s var(--cst-ease),
    transform .22s var(--cst-ease);
}

.cst-news-row__inner:hover {
  background: var(--cst-brand-tint);
  border-bottom-color: rgba(255, 77, 79, .18);
  transform: translateX(5px);
}

.cst-news-row__thumb {
  position: relative;
  width: 168px;
  height: 116px;
  border-radius: var(--cst-radius-md);
  overflow: hidden;
  background: var(--cst-line-soft);
  flex-shrink: 0;
  transition: box-shadow .28s var(--cst-ease);
}

.cst-news-row__inner:hover .cst-news-row__thumb {
  box-shadow: 0 8px 24px rgba(0, 0, 0, .14);
}

.cst-news-row__thumb img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  transition: transform .45s var(--cst-ease);
}

.cst-news-row__inner:hover .cst-news-row__thumb img {
  transform: scale(1.07);
}

.cst-news-row__content {
  padding-left: var(--cst-sp-6);
  padding-right: var(--cst-sp-3);
  display: flex;
  flex-direction: column;
  gap: var(--cst-sp-2);
  min-width: 0;
}

.cst-news-row__meta {
  display: flex;
  align-items: center;
  gap: var(--cst-sp-3);
  flex-wrap: wrap;
}

.cst-news-row__date {
  font-size: .74rem;
  color: var(--cst-ink-3);
  font-weight: 600;
  display: inline-flex;
  align-items: center;
  gap: 5px;
}

.cst-news-row__headline {
  font-family: var(--heading-font);
  font-weight: 800;
  font-size: 1.12rem;
  color: var(--cst-ink-1);
  margin: 0;
  line-height: 1.25;
  transition: color .22s var(--cst-ease);
}

.cst-news-row__inner:hover .cst-news-row__headline {
  color: var(--cst-brand-dark);
}

.cst-news-row__excerpt {
  font-size: .875rem;
  color: var(--cst-ink-2);
  line-height: 1.65;
  margin: 0;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

.cst-news-row__foot {
  display: flex;
  align-items: center;
  gap: var(--cst-sp-3);
  margin-top: var(--cst-sp-2);
  flex-wrap: wrap;
}

.cst-news-row__tags {
  display: flex;
  gap: 5px;
  flex-wrap: wrap;
  flex: 1;
}

.cst-news-row__tags span {
  font-size: .68rem;
  font-weight: 600;
  background: var(--cst-line-soft);
  color: var(--cst-ink-3);
  padding: 3px 10px;
  border-radius: var(--cst-radius-pill);
  transition: background .22s var(--cst-ease), color .22s var(--cst-ease);
}

.cst-news-row__inner:hover .cst-news-row__tags span {
  background: rgba(255, 77, 79, .1);
  color: var(--cst-brand-dark);
}

/* Flecha como botón circular siempre visible */
.cst-news-row__arrow {
  width: 40px;
  height: 40px;
  border-radius: 50%;
  border: 1.5px solid var(--cst-line);
  color: var(--cst-ink-3);
  font-size: .95rem;
  display: grid;
  place-items: center;
  flex-shrink: 0;
  margin-left: var(--cst-sp-4);
  transition:
    border-color .22s var(--cst-ease),
    background .22s var(--cst-ease),
    color .22s var(--cst-ease),
    transform .22s var(--cst-ease);
}

.cst-news-row__inner:hover .cst-news-row__arrow {
  border-color: var(--cst-brand);
  background: var(--cst-brand);
  color: #fff;
  transform: translateX(3px);
}

@media (max-width: 767.98px) {
  .cst-news-row {
    margin-left: -8px;
    margin-right: -8px;
  }

  .cst-news-row__inner {
    grid-template-columns: 140px 1fr;
    padding: 16px 8px;
  }

  .cst-news-row__thumb {
    width: 128px;
    height: 92px;
  }

  .cst-news-row__content {
    padding-left: var(--cst-sp-4);
  }

  .cst-news-row__excerpt {
    display: none;
  }

  .cst-news-row__arrow {
    width: 34px;
    height: 34px;
  }
}

@media (max-width: 479.98px) {
  .cst-news-row {
    margin-left: 0;
    margin-right: 0;
  }

  .cst-news-row__inner {
    grid-template-columns: 1fr;
    gap: var(--cst-sp-3);
    padding: 16px 0;
    transform: none !important;
  }

  .cst-news-row__thumb {
    width: 100%;
    height: 180px;
    border-radius: var(--cst-radius-md);
  }

  .cst-news-row__content {
    padding-left: 0;
    padding-right: 0;
  }

  .cst-news-row__excerpt {
    display: -webkit-box;
  }
}

/* ---- Banda de redes (dark CTA) ---- */
.cst-news-social-band {
  background: linear-gradient(135deg, #0f0f0f 0%, #1e0808 50%, #0f0f0f 100%);
  position: relative;
  overflow: hidden;
}

.cst-news-social-band::before {
  content: "";
  position: absolute;
  inset: 0;
  background: repeating-linear-gradient(
    -55deg,
    rgba(255, 255, 255, .012) 0,
    rgba(255, 255, 255, .012) 1px,
    transparent 1px,
    transparent 40px
  );
  pointer-events: none;
}

.cst-news-social-band > .container {
  position: relative;
  z-index: 1;
}

.cst-news-social-band__inner {
  display: flex;
  align-items: center;
  gap: var(--cst-sp-7);
  flex-wrap: wrap;
}

.cst-news-social-band__text {
  flex: 1 1 320px;
}

.cst-news-social-band__label {
  display: inline-block;
  font-size: .65rem;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: .18em;
  color: var(--cst-brand);
  margin-bottom: var(--cst-sp-3);
}

.cst-news-social-band__title {
  font-family: var(--heading-font);
  font-weight: 900;
  font-size: clamp(1.4rem, 2.8vw, 2rem);
  color: #fff;
  margin: 0 0 var(--cst-sp-3);
  line-height: 1.15;
}

.cst-news-social-band__sub {
  font-size: .95rem;
  color: rgba(255, 255, 255, .55);
  line-height: 1.7;
  margin: 0;
}

.cst-news-social-band__actions {
  display: flex;
  flex-direction: column;
  gap: var(--cst-sp-3);
  flex: 0 0 auto;
  min-width: 200px;
}

.cst-news-social-band__btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 9px;
  padding: 14px 28px;
  border-radius: var(--cst-radius-pill);
  font-weight: 700;
  font-size: .9rem;
  text-decoration: none;
  transition: transform .22s var(--cst-ease), background .22s, box-shadow .22s;
  white-space: nowrap;
}

.cst-news-social-band__btn--ig {
  background: linear-gradient(135deg, #f58529 0%, #dd2a7b 50%, #8134af 100%);
  color: #fff;
  box-shadow: 0 6px 20px rgba(221, 42, 123, .3);
}

.cst-news-social-band__btn--ig:hover {
  transform: translateY(-2px);
  box-shadow: 0 10px 28px rgba(221, 42, 123, .45);
  color: #fff;
}

.cst-news-social-band__btn--ghost {
  background: transparent;
  color: rgba(255, 255, 255, .75);
  border: 1.5px solid rgba(255, 255, 255, .22);
}

.cst-news-social-band__btn--ghost:hover {
  background: rgba(255, 255, 255, .07);
  border-color: rgba(255, 255, 255, .55);
  color: #fff;
  transform: translateY(-2px);
}

@media (max-width: 767.98px) {
  .cst-news-social-band__inner {
    flex-direction: column;
    gap: var(--cst-sp-5);
  }

  .cst-news-social-band__actions {
    width: 100%;
    flex-direction: row;
    min-width: 0;
  }

  .cst-news-social-band__btn {
    flex: 1;
    justify-content: center;
  }
}

/* ==========================================================================
   38. cst-venue — Recinto deportivo (editorial visual)
   ========================================================================== */

/* ---- Intro oscura ---- */
.cst-venue-intro {
  background: linear-gradient(155deg, #0a0a0a 0%, #200707 45%, #0a0a0a 100%);
  position: relative;
  overflow: hidden;
}

.cst-venue-intro::before {
  content: "";
  position: absolute;
  inset: 0;
  background: repeating-linear-gradient(
    -55deg,
    rgba(255, 255, 255, .015) 0,
    rgba(255, 255, 255, .015) 1px,
    transparent 1px,
    transparent 40px
  );
  pointer-events: none;
  z-index: 0;
}

.cst-venue-intro::after {
  content: "EL ROBLE";
  position: absolute;
  bottom: -20px;
  right: -20px;
  font-family: var(--heading-font);
  font-weight: 900;
  font-size: clamp(5rem, 14vw, 13rem);
  color: rgba(255, 255, 255, .028);
  line-height: 1;
  letter-spacing: .08em;
  pointer-events: none;
  user-select: none;
  z-index: 0;
}

.cst-venue-intro > .container {
  position: relative;
  z-index: 1;
}

.cst-venue-intro__eyebrow {
  display: inline-block;
  font-size: .65rem;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: .2em;
  color: var(--cst-brand);
  margin-bottom: var(--cst-sp-4);
}

.cst-venue-intro__heading {
  font-family: var(--heading-font);
  font-weight: 900;
  font-size: clamp(2.2rem, 5vw, 3.8rem);
  color: #fff;
  margin: 0 0 var(--cst-sp-4);
  line-height: 1.1;
}

.cst-venue-intro__heading strong {
  color: var(--cst-brand);
}

.cst-venue-intro__sub {
  font-size: 1rem;
  color: rgba(255, 255, 255, .5);
  line-height: 1.75;
  max-width: 540px;
  margin: 0 0 var(--cst-sp-7);
}

.cst-venue-intro__stats {
  display: flex;
  gap: 0;
  border-top: 1px solid rgba(255, 255, 255, .1);
  padding-top: var(--cst-sp-6);
}

.cst-venue-intro__stat {
  flex: 1;
  padding-right: var(--cst-sp-5);
  margin-right: var(--cst-sp-5);
  border-right: 1px solid rgba(255, 255, 255, .08);
}

.cst-venue-intro__stat:last-child {
  border-right: none;
  padding-right: 0;
  margin-right: 0;
}

.cst-venue-intro__stat-num {
  display: block;
  font-family: var(--heading-font);
  font-weight: 900;
  font-size: clamp(1.8rem, 3.5vw, 2.6rem);
  color: #fff;
  line-height: 1;
  letter-spacing: -.02em;
}

.cst-venue-intro__stat-label {
  display: block;
  margin-top: 6px;
  font-size: .62rem;
  text-transform: uppercase;
  letter-spacing: .16em;
  color: rgba(255, 255, 255, .38);
  font-weight: 700;
}

/* ---- Badge de instalación ---- */
.cst-venue-badge {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  font-size: .55rem;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: .1em;
  padding: 3px 8px;
  border-radius: var(--cst-radius-pill);
  line-height: 1;
  white-space: nowrap;
}

.cst-venue-badge--main       { background: var(--cst-brand);    color: #fff; }
.cst-venue-badge--formativa  { background: #22c55e;              color: #fff; }
.cst-venue-badge--equipado   { background: #3b82f6;              color: #fff; }
.cst-venue-badge--fisico     { background: #f59e0b;              color: #fff; }
.cst-venue-badge--patrimonio { background: #8b5cf6;              color: #fff; }
.cst-venue-badge--comunidad  { background: #06b6d4;              color: #fff; }

/* ---- Featured — Cancha principal ---- */
.cst-venue-featured {
  position: relative;
  border-radius: var(--cst-radius-lg);
  overflow: hidden;
  min-height: 520px;
  margin-bottom: var(--cst-sp-4);
}

.cst-venue-featured__img {
  position: absolute;
  inset: 0;
}

.cst-venue-featured__img img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  transition: transform .65s var(--cst-ease);
}

.cst-venue-featured:hover .cst-venue-featured__img img {
  transform: scale(1.04);
}

.cst-venue-featured::after {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(
    to top,
    rgba(8, 2, 2, .97) 0%,
    rgba(8, 2, 2, .65) 38%,
    rgba(8, 2, 2, .18) 70%,
    transparent 100%
  );
  pointer-events: none;
}

.cst-venue-featured__num {
  position: absolute;
  top: clamp(20px, 3vw, 36px);
  right: clamp(20px, 3vw, 36px);
  font-family: var(--heading-font);
  font-weight: 900;
  font-size: clamp(5rem, 10vw, 9rem);
  color: rgba(255, 255, 255, .07);
  line-height: 1;
  user-select: none;
  pointer-events: none;
  letter-spacing: -.04em;
  z-index: 1;
}

.cst-venue-featured__content {
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  padding: clamp(28px, 4vw, 56px);
  z-index: 1;
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: var(--cst-sp-4);
}

.cst-venue-featured__title {
  font-family: var(--heading-font);
  font-weight: 900;
  font-size: clamp(1.8rem, 3.5vw, 2.8rem);
  color: #fff;
  margin: 0;
  line-height: 1.1;
}

.cst-venue-featured__desc {
  font-size: .95rem;
  color: rgba(255, 255, 255, .6);
  line-height: 1.75;
  margin: 0;
  max-width: 600px;
}

.cst-venue-featured__specs {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  padding-top: var(--cst-sp-2);
}

.cst-venue-featured__specs span {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  font-size: .72rem;
  font-weight: 700;
  background: rgba(255, 255, 255, .1);
  border: 1px solid rgba(255, 255, 255, .15);
  color: rgba(255, 255, 255, .88);
  padding: 6px 14px;
  border-radius: var(--cst-radius-pill);
  backdrop-filter: blur(4px);
  transition: background .25s var(--cst-ease);
}

.cst-venue-featured:hover .cst-venue-featured__specs span {
  background: rgba(255, 255, 255, .15);
}

/* ---- Grid de instalaciones menores ---- */
.cst-venue-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--cst-sp-4);
}

.cst-venue-card {
  position: relative;
  border-radius: var(--cst-radius-lg);
  overflow: hidden;
  aspect-ratio: 4 / 3;
}

.cst-venue-card__img {
  position: absolute;
  inset: 0;
}

.cst-venue-card__img img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  transition: transform .55s var(--cst-ease);
}

.cst-venue-card:hover .cst-venue-card__img img {
  transform: scale(1.07);
}

.cst-venue-card::after {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(
    to top,
    rgba(8, 2, 2, .94) 0%,
    rgba(8, 2, 2, .5) 50%,
    rgba(8, 2, 2, .1) 100%
  );
  pointer-events: none;
  transition: background .35s var(--cst-ease);
}

.cst-venue-card:hover::after {
  background: linear-gradient(
    to top,
    rgba(8, 2, 2, .98) 0%,
    rgba(8, 2, 2, .68) 55%,
    rgba(8, 2, 2, .15) 100%
  );
}

.cst-venue-card__num {
  position: absolute;
  top: 14px;
  right: 16px;
  font-family: var(--heading-font);
  font-weight: 900;
  font-size: 3rem;
  color: rgba(255, 255, 255, .12);
  line-height: 1;
  user-select: none;
  pointer-events: none;
  letter-spacing: -.04em;
  z-index: 1;
  transition: color .35s var(--cst-ease);
}

.cst-venue-card:hover .cst-venue-card__num {
  color: rgba(255, 255, 255, .2);
}

.cst-venue-card__content {
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  padding: clamp(16px, 2.5vw, 26px);
  z-index: 1;
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: var(--cst-sp-2);
}

.cst-venue-card__title {
  font-family: var(--heading-font);
  font-weight: 800;
  font-size: 1.1rem;
  color: #fff;
  margin: 0;
  line-height: 1.2;
}

.cst-venue-card__desc {
  font-size: .78rem;
  color: rgba(255, 255, 255, .5);
  line-height: 1.5;
  margin: 0;
  max-height: 0;
  overflow: hidden;
  opacity: 0;
  transition: max-height .35s var(--cst-ease), opacity .3s var(--cst-ease);
}

.cst-venue-card:hover .cst-venue-card__desc {
  max-height: 52px;
  opacity: 1;
}

.cst-venue-card__specs {
  display: flex;
  flex-wrap: wrap;
  gap: 5px;
  padding-top: 2px;
}

.cst-venue-card__specs span {
  font-size: .6rem;
  font-weight: 700;
  background: rgba(255, 255, 255, .1);
  border: 1px solid rgba(255, 255, 255, .12);
  color: rgba(255, 255, 255, .78);
  padding: 3px 9px;
  border-radius: var(--cst-radius-pill);
}

@media (max-width: 991.98px) {
  .cst-venue-grid {
    grid-template-columns: repeat(2, 1fr);
  }
}

@media (max-width: 575.98px) {
  .cst-venue-grid {
    grid-template-columns: 1fr;
  }

  .cst-venue-featured {
    min-height: 360px;
  }

  .cst-venue-intro__stats {
    flex-wrap: wrap;
    gap: var(--cst-sp-4);
  }

  .cst-venue-intro__stat {
    flex: 0 0 calc(50% - var(--cst-sp-3));
    border-right: none;
    padding-right: 0;
    margin-right: 0;
    border-bottom: 1px solid rgba(255, 255, 255, .08);
    padding-bottom: var(--cst-sp-4);
  }

  .cst-venue-intro__stat:last-child,
  .cst-venue-intro__stat:nth-last-child(2) {
    border-bottom: none;
  }

  .cst-venue-card:hover .cst-venue-card__desc {
    max-height: 52px;
    opacity: 1;
  }
}


body:not(.index-page).scrolled .header {
  background-color: rgb(10 10 10 / 60%) !important;
  box-shadow: 0 2px 24px rgba(0, 0, 0, .45);
}

/* Inner pages: empuja el contenido de la primera sección por debajo del
   header fijo (~95 px de alto). La index-page queda excluida porque su
   hero se solapa intencionalmente con el header transparente. */
body:not(.index-page) {
  padding-top: 95px;
}

/* --------------------------------------------------------------------------
   36. cst-club-intro — Historia del club (dark editorial manifesto)
   -------------------------------------------------------------------------- */
.cst-club-intro {
  background: linear-gradient(150deg, #1a0505 0%, #3a0d0d 38%, #220808 65%, #140303 100%);
  padding: 60px 0 90px;
  position: relative;
  overflow: hidden;
}

/* Textura diagonal */
.cst-club-intro::before {
  content: "";
  position: absolute;
  inset: 0;
  background: repeating-linear-gradient(
    -55deg,
    rgba(255,255,255,.018) 0,
    rgba(255,255,255,.018) 1px,
    transparent 1px,
    transparent 40px
  );
  pointer-events: none;
}

/* Watermark */
.cst-club-intro::after {
  content: "1962";
  position: absolute;
  right: -30px;
  bottom: 40px;
  font-family: var(--heading-font);
  font-weight: 900;
  font-size: clamp(160px, 22vw, 300px);
  color: rgba(255,255,255,.022);
  line-height: 1;
  pointer-events: none;
  user-select: none;
  letter-spacing: -0.06em;
}

/* ── Eyebrow row ───────────────────────────────────── */
.cst-club-intro__eyebrow {
  display: flex;
  align-items: center;
  gap: var(--cst-sp-3);
  margin-bottom: clamp(36px, 5vw, 56px);
  position: relative;
  z-index: 1;
}

.cst-club-intro__eyebrow-tag {
  font-size: .68rem;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: .18em;
  color: var(--cst-brand);
  white-space: nowrap;
}

.cst-club-intro__eyebrow-line {
  flex: 1;
  height: 1px;
  background: rgba(255,255,255,.12);
}

.cst-club-intro__eyebrow-year {
  font-size: .68rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .12em;
  color: rgba(255,255,255,.28);
  white-space: nowrap;
}

/* ── Fila identidad: año + logo/nombre ─────────────── */
.cst-club-intro__identity {
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  gap: var(--cst-sp-5);
  padding-bottom: clamp(24px, 4vw, 40px);
  border-bottom: 1px solid rgba(255,255,255,.08);
  margin-bottom: clamp(40px, 5vw, 60px);
  position: relative;
  z-index: 1;
}

.cst-club-intro__giant-year {
  font-family: var(--heading-font);
  font-weight: 900;
  font-size: clamp(5rem, 10vw, 9rem);
  color: var(--cst-brand);
  line-height: .88;
  letter-spacing: -0.06em;
  opacity: .85;
  flex-shrink: 0;
}

.cst-club-intro__identity-right {
  display: flex;
  align-items: center;
  gap: var(--cst-sp-4);
  padding-bottom: 6px;
}

.cst-club-intro__logo-circle {
  width: 96px;
  height: 96px;
  flex-shrink: 0;
  border-radius: 50%;
  border: 2px solid rgba(255,255,255,.18);
  padding: 8px;
  background: rgba(255,255,255,.07);
  box-shadow: 0 0 0 6px rgba(255,77,79,.12), 0 0 32px rgba(255,77,79,.15);
}

.cst-club-intro__logo-circle img {
  width: 100%;
  height: 100%;
  object-fit: contain;
}

.cst-club-intro__club-id {
  display: flex;
  flex-direction: column;
  gap: 5px;
}

.cst-club-intro__club-name {
  font-family: var(--heading-font);
  font-size: 1.25rem;
  font-weight: 900;
  color: #fff;
  line-height: 1.2;
}

.cst-club-intro__club-loc {
  font-size: .72rem;
  color: rgba(255,255,255,.4);
  font-weight: 600;
  display: flex;
  align-items: center;
  gap: 4px;
}

.cst-club-intro__club-loc i {
  color: var(--cst-brand);
}

/* ── Foto del equipo ──────────────────────────────── */
.cst-club-intro__photo {
  position: relative;
  z-index: 1;
  margin: 0 0 clamp(48px, 6vw, 72px);
  border-radius: 16px;
  overflow: hidden;
  background: rgba(0,0,0,.25);
}

/* Imagen completa sin recorte */
.cst-club-intro__photo > img {
  width: 100%;
  height: auto;
  display: block;
  object-fit: contain;
}

.cst-club-intro__photo-caption {
  display: flex;
  flex-direction: column;
  gap: 4px;
  padding: 14px 20px;
  border-top: 1px solid rgba(255,255,255,.07);
  background: rgba(20,3,3,.55);
}

.cst-club-intro__photo-caption-tag {
  font-family: var(--heading-font);
  font-weight: 900;
  font-size: 1rem;
  color: #fff;
  line-height: 1.1;
}

.cst-club-intro__photo-caption-text {
  font-size: .68rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: .12em;
  color: rgba(255,255,255,.45);
}

/* Placeholder (mientras no haya foto real) */
.cst-club-intro__photo-placeholder {
  height: clamp(340px, 50vw, 620px);
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 24px;
  background:
    radial-gradient(ellipse 80% 60% at 50% 50%, rgba(255,77,79,.07) 0%, transparent 70%),
    linear-gradient(160deg, rgba(255,255,255,.02) 0%, rgba(255,77,79,.04) 50%, rgba(255,255,255,.015) 100%);
  border: 1px solid rgba(255,77,79,.18);
  border-radius: 20px;
  position: relative;
  overflow: hidden;
  cursor: default;
}

/* Texto fantasma de fondo */
.cst-club-intro__photo-placeholder::before {
  content: "CD SANTA TERESA";
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  font-family: var(--heading-font);
  font-weight: 900;
  font-size: clamp(3.5rem, 9vw, 8rem);
  color: rgba(255,255,255,.035);
  white-space: nowrap;
  pointer-events: none;
  user-select: none;
  letter-spacing: .06em;
}

/* Cinta roja superior */
.cst-club-intro__photo-placeholder::after {
  content: "FOTO OFICIAL DEL EQUIPO — TEMPORADA 2025";
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  padding: 10px 20px;
  background: linear-gradient(90deg, rgba(255,77,79,.22), rgba(255,77,79,.12), rgba(255,77,79,.22));
  border-bottom: 1px solid rgba(255,77,79,.28);
  font-size: .6rem;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: .18em;
  color: rgba(255,255,255,.5);
  text-align: center;
}

.cst-club-intro__photo-logo {
  width: 120px;
  height: 120px;
  object-fit: contain;
  opacity: .18;
  display: block;
}

.cst-club-intro__photo-hint {
  font-size: .8rem;
  color: rgba(255,255,255,.2);
  font-style: italic;
  text-align: center;
  max-width: 340px;
  line-height: 1.7;
}

/* ── Titular + lead ────────────────────────────────── */
.cst-club-intro__headline {
  position: relative;
  z-index: 1;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: clamp(var(--cst-sp-5), 4vw, var(--cst-sp-8));
  align-items: start;
  margin-bottom: clamp(28px, 4vw, 48px);
}

.cst-club-intro__title {
  font-family: var(--heading-font);
  font-weight: 900;
  font-size: clamp(1.9rem, 3.2vw, 2.9rem);
  color: #fff;
  line-height: 1.1;
  letter-spacing: -0.025em;
  margin: 0;
}

.cst-club-intro__lead {
  font-size: clamp(.9rem, 1.05vw, 1rem);
  color: rgba(255,255,255,.6);
  line-height: 1.9;
  margin: 0;
  padding-top: 6px;
}

/* ── Stats band ────────────────────────────────────── */
.cst-club-intro__statband {
  display: flex;
  align-items: stretch;
  border-top: 1px solid rgba(255,255,255,.1);
  border-bottom: 1px solid rgba(255,255,255,.1);
  margin-bottom: clamp(36px, 5vw, 64px);
  position: relative;
  z-index: 1;
}

.cst-club-intro__statband-item {
  flex: 1;
  display: flex;
  flex-direction: column;
  gap: 4px;
  padding: clamp(20px, 3vw, 32px) var(--cst-sp-4);
}

.cst-club-intro__statband-sep {
  width: 1px;
  background: rgba(255,255,255,.1);
  flex-shrink: 0;
  align-self: stretch;
}

.cst-club-intro__statband-num {
  font-family: var(--heading-font);
  font-weight: 900;
  font-size: clamp(2.4rem, 4vw, 3.8rem);
  color: #fff;
  line-height: 1;
  letter-spacing: -0.03em;
}

.cst-club-intro__statband-label {
  font-size: .62rem;
  text-transform: uppercase;
  letter-spacing: .12em;
  color: rgba(255,255,255,.36);
  font-weight: 700;
}

/* ── Body ──────────────────────────────────────────── */
.cst-club-intro__body {
  display: grid;
  grid-template-columns: 5fr 3fr;
  gap: var(--cst-sp-7);
  align-items: start;
  position: relative;
  z-index: 1;
}

.cst-club-intro__body-text {
  display: flex;
  flex-direction: column;
  gap: var(--cst-sp-4);
}

.cst-club-intro__body-text p {
  font-size: .95rem;
  color: rgba(255,255,255,.6);
  line-height: 1.9;
  margin: 0;
}

/* ── Aside ─────────────────────────────────────────── */
.cst-club-intro__body-side {
  display: flex;
  flex-direction: column;
  gap: var(--cst-sp-5);
}

.cst-club-intro__data-stack {
  display: flex;
  flex-direction: column;
  gap: 0;
}

.cst-club-intro__data-row {
  display: flex;
  align-items: flex-start;
  gap: var(--cst-sp-3);
  padding: 14px 0;
  border-bottom: 1px solid rgba(255,255,255,.08);
}

.cst-club-intro__data-row:first-child {
  border-top: 1px solid rgba(255,255,255,.08);
}

.cst-club-intro__data-icon {
  font-size: 1rem;
  color: var(--cst-brand);
  margin-top: 1px;
  flex-shrink: 0;
}

.cst-club-intro__data-label {
  display: block;
  font-size: .6rem;
  text-transform: uppercase;
  letter-spacing: .1em;
  color: rgba(255,255,255,.32);
  font-weight: 700;
  margin-bottom: 2px;
}

.cst-club-intro__data-value {
  display: block;
  font-size: .88rem;
  font-weight: 700;
  color: rgba(255,255,255,.82);
}

/* Acciones y social */
.cst-club-intro__actions {
  display: flex;
  flex-direction: column;
  gap: 10px;
}

.cst-club-intro__btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  padding: 12px 20px;
  border-radius: var(--cst-radius-pill);
  font-family: var(--heading-font);
  font-weight: 800;
  font-size: .82rem;
  text-decoration: none;
  transition: background .15s ease, color .15s ease, border-color .15s ease, transform .15s ease;
}

.cst-club-intro__btn--primary {
  background: var(--cst-brand);
  color: #fff;
  border: 1.5px solid var(--cst-brand);
}

.cst-club-intro__btn--primary:hover {
  background: var(--cst-brand-dark);
  border-color: var(--cst-brand-dark);
  color: #fff;
  transform: translateY(-2px);
}

.cst-club-intro__btn--ghost {
  background: transparent;
  color: rgba(255,255,255,.65);
  border: 1.5px solid rgba(255,255,255,.2);
}

.cst-club-intro__btn--ghost:hover {
  border-color: rgba(255,255,255,.5);
  color: #fff;
  transform: translateY(-2px);
}

.cst-club-intro__social {
  display: flex;
  gap: 10px;
}

.cst-club-intro__social a {
  width: 36px;
  height: 36px;
  border-radius: 50%;
  border: 1px solid rgba(255,255,255,.16);
  color: rgba(255,255,255,.45);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: .9rem;
  text-decoration: none;
  transition: border-color .15s, color .15s, background .15s;
}

.cst-club-intro__social a:hover {
  border-color: var(--cst-brand);
  color: #fff;
  background: var(--cst-brand);
}

/* ── Responsive ────────────────────────────────────── */
@media (max-width: 991px) {
  .cst-club-intro {
    padding: 72px 0 60px;
  }

  .cst-club-intro__identity {
    flex-wrap: wrap;
    align-items: flex-start;
    gap: var(--cst-sp-4);
  }

  .cst-club-intro__giant-year {
    font-size: clamp(4rem, 12vw, 7rem);
  }

  .cst-club-intro__headline {
    grid-template-columns: 1fr;
    gap: var(--cst-sp-4);
  }

  .cst-club-intro__body {
    grid-template-columns: 1fr;
    gap: var(--cst-sp-5);
  }

  .cst-club-intro__body-side {
    flex-direction: row;
    flex-wrap: wrap;
    gap: var(--cst-sp-4);
  }

  .cst-club-intro__data-stack {
    flex: 1 1 100%;
  }

  .cst-club-intro__actions {
    flex-direction: row;
    flex: 1;
  }

  .cst-club-intro__btn {
    flex: 1;
  }

  .cst-club-intro__statband {
    flex-wrap: wrap;
  }

  .cst-club-intro__statband-item {
    flex: 1 1 40%;
  }

  .cst-club-intro__statband-sep {
    display: none;
  }
}

@media (max-width: 575px) {
  .cst-club-intro {
    padding: 56px 0 48px;
  }

  .cst-club-intro__statband-item {
    flex: 1 1 45%;
  }

  .cst-club-intro__actions {
    flex-direction: column;
  }

  .cst-club-intro__photo > img {
    height: 260px;
  }
}

/* ==========================================================================
   39. cst-redes — Redes Sociales page (full redesign)
   ========================================================================== */

/* ── Hero manifesto ───────────────────────────────────────────────────────── */
.cst-redes-hero {
  background: linear-gradient(150deg, #0a0a0a 0%, #1a0505 40%, #0a0a0a 100%);
  padding: 72px 0 64px;
  position: relative;
  overflow: hidden;
}

.cst-redes-hero::before {
  content: "";
  position: absolute;
  inset: 0;
  background: repeating-linear-gradient(
    -55deg,
    rgba(255, 255, 255, .015) 0,
    rgba(255, 255, 255, .015) 1px,
    transparent 1px,
    transparent 40px
  );
  pointer-events: none;
}

.cst-redes-hero__eyebrow {
  display: inline-block;
  font-size: .62rem;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: .2em;
  color: var(--cst-brand);
  margin-bottom: var(--cst-sp-4);
}

.cst-redes-hero__eyebrow::after {
  content: "";
  display: block;
  width: 32px;
  height: 2px;
  background: var(--cst-brand);
  margin-top: 8px;
}

.cst-redes-hero__heading {
  font-family: var(--heading-font);
  font-weight: 900;
  font-size: clamp(2.2rem, 5vw, 4rem);
  color: #fff;
  line-height: 1.1;
  margin-bottom: var(--cst-sp-4);
}

.cst-redes-hero__heading em {
  font-style: normal;
  color: var(--cst-brand);
}

.cst-redes-hero__sub {
  font-size: .98rem;
  color: rgba(255, 255, 255, .6);
  line-height: 1.75;
  max-width: 520px;
  margin-bottom: var(--cst-sp-5);
}

.cst-redes-hero__platforms {
  display: flex;
  flex-wrap: wrap;
  gap: var(--cst-sp-4);
}

.cst-redes-hero__platform {
  display: flex;
  align-items: center;
  gap: 7px;
  color: rgba(255, 255, 255, .55);
  font-size: .85rem;
  font-weight: 600;
  transition: color .25s;
}

.cst-redes-hero__platform:hover { color: rgba(255, 255, 255, .9); }

.cst-redes-hero__platform i { font-size: 1.05rem; }

/* stat box */
.cst-redes-hero__stats {
  display: flex;
  flex-wrap: wrap;
  border: 1px solid rgba(255, 255, 255, .1);
  border-radius: var(--cst-radius-md);
  overflow: hidden;
}

.cst-redes-hero__stat {
  flex: 1;
  min-width: 110px;
  padding: 22px 20px;
  border-right: 1px solid rgba(255, 255, 255, .1);
  display: flex;
  flex-direction: column;
  gap: 5px;
}

.cst-redes-hero__stat:last-child { border-right: none; }

.cst-redes-hero__stat-num {
  font-family: var(--heading-font);
  font-weight: 900;
  font-size: 1.9rem;
  color: #fff;
  line-height: 1;
}

.cst-redes-hero__stat-label {
  font-size: .6rem;
  text-transform: uppercase;
  letter-spacing: .1em;
  color: rgba(255, 255, 255, .4);
  line-height: 1.3;
}

/* ── Instagram: Feature Block ─────────────────────────────────────────────── */
.cst-platform-feature {
  display: grid;
  grid-template-columns: 1fr 1fr;
  border-radius: var(--cst-radius-lg);
  overflow: hidden;
  box-shadow: var(--cst-shadow-lg);
  margin-bottom: var(--cst-sp-5);
}

.cst-platform-feature__left {
  background: linear-gradient(145deg, #f58529 0%, #dd2a7b 52%, #8134af 100%);
  padding: clamp(32px, 4vw, 52px);
  color: #fff;
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: var(--cst-sp-4);
  position: relative;
  overflow: hidden;
}

.cst-platform-feature__left::before {
  content: "";
  position: absolute;
  width: 340px;
  height: 340px;
  border-radius: 50%;
  background: rgba(255, 255, 255, .07);
  bottom: -100px;
  right: -100px;
  pointer-events: none;
}

.cst-platform-feature__left::after {
  content: "";
  position: absolute;
  width: 180px;
  height: 180px;
  border-radius: 50%;
  background: rgba(255, 255, 255, .05);
  top: -60px;
  left: -40px;
  pointer-events: none;
}

.cst-platform-feature__icon {
  width: 54px;
  height: 54px;
  background: rgba(255, 255, 255, .22);
  border-radius: var(--cst-radius-md);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.7rem;
  backdrop-filter: blur(6px);
  position: relative;
}

.cst-platform-feature__network {
  display: block;
  font-size: .6rem;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: .2em;
  opacity: .75;
}

.cst-platform-feature__title {
  font-family: var(--heading-font);
  font-weight: 900;
  font-size: clamp(1.8rem, 3vw, 2.4rem);
  color: #fff;
  margin: 0;
  line-height: 1.05;
}

.cst-platform-feature__handle {
  font-size: .88rem;
  opacity: .82;
  font-weight: 600;
  position: relative;
}

.cst-platform-feature__desc {
  font-size: .93rem;
  line-height: 1.68;
  opacity: .88;
  margin: 0;
  position: relative;
}

.cst-platform-feature__tags {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  position: relative;
}

.cst-platform-feature__tag {
  background: rgba(255, 255, 255, .18);
  border: 1px solid rgba(255, 255, 255, .28);
  padding: 4px 11px;
  border-radius: var(--cst-radius-pill);
  font-size: .65rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .08em;
  backdrop-filter: blur(4px);
}

.cst-platform-feature__stats {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1px;
  background: rgba(255, 255, 255, .18);
  border-radius: var(--cst-radius-sm);
  overflow: hidden;
  width: 100%;
  position: relative;
}

.cst-platform-feature__stat {
  background: rgba(0, 0, 0, .18);
  padding: 14px 8px;
  text-align: center;
  backdrop-filter: blur(6px);
}

.cst-platform-feature__stat-num {
  display: block;
  font-family: var(--heading-font);
  font-weight: 900;
  font-size: 1.45rem;
  color: #fff;
  line-height: 1;
}

.cst-platform-feature__stat-label {
  display: block;
  font-size: .58rem;
  text-transform: uppercase;
  letter-spacing: .1em;
  color: rgba(255, 255, 255, .68);
  margin-top: 4px;
}

.cst-platform-feature__cta {
  display: inline-flex;
  align-items: center;
  gap: 9px;
  background: #fff;
  color: #c2185b;
  padding: 12px 24px;
  border-radius: var(--cst-radius-pill);
  font-weight: 800;
  font-size: .88rem;
  text-decoration: none;
  transition: transform .25s var(--cst-ease), box-shadow .25s var(--cst-ease);
  box-shadow: 0 4px 18px rgba(0, 0, 0, .22);
  position: relative;
}

.cst-platform-feature__cta:hover {
  transform: translateY(-2px);
  box-shadow: 0 8px 26px rgba(0, 0, 0, .28);
  color: #c2185b;
}

/* right side: mock feed */
.cst-platform-feature__right {
  background: #0a0a0a;
  display: flex;
  flex-direction: column;
  gap: 0;
}

.cst-platform-feature__profile {
  display: flex;
  align-items: center;
  gap: 11px;
  padding: 14px 16px;
  border-bottom: 1px solid rgba(255, 255, 255, .07);
}

.cst-platform-feature__avatar {
  width: 36px;
  height: 36px;
  border-radius: 50%;
  object-fit: cover;
  border: 2px solid #dd2a7b;
  flex-shrink: 0;
}

.cst-platform-feature__profile-name {
  display: block;
  font-weight: 800;
  color: #fff;
  font-size: .88rem;
}

.cst-platform-feature__profile-sub {
  display: block;
  font-size: .68rem;
  color: rgba(255, 255, 255, .45);
}

.cst-platform-feature__feed {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 2px;
  flex: 1;
}

.cst-platform-feature__feed-cell {
  position: relative;
  aspect-ratio: 1 / 1;
  overflow: hidden;
  background: #1a1a1a;
}

.cst-platform-feature__feed-cell img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform .4s var(--cst-ease);
  display: block;
}

.cst-platform-feature__feed-cell:hover img { transform: scale(1.07); }

.cst-platform-feature__feed-overlay {
  position: absolute;
  inset: 0;
  background: rgba(0, 0, 0, .52);
  color: #fff;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 12px;
  opacity: 0;
  transition: opacity .3s var(--cst-ease);
  font-size: .72rem;
  font-weight: 700;
}

.cst-platform-feature__feed-cell:hover .cst-platform-feature__feed-overlay { opacity: 1; }

.cst-platform-feature__view-all {
  display: block;
  text-align: center;
  padding: 12px;
  color: rgba(255, 255, 255, .45);
  font-size: .72rem;
  text-decoration: none;
  font-weight: 600;
  letter-spacing: .05em;
  border-top: 1px solid rgba(255, 255, 255, .07);
  transition: color .25s;
}

.cst-platform-feature__view-all:hover { color: #dd2a7b; }

/* ── Platform Rows (FB, WA, YT) ────────────────────────────────────────────── */
.cst-platform-rows {
  display: flex;
  flex-direction: column;
  gap: var(--cst-sp-4);
}

.cst-platform-row {
  display: grid;
  grid-template-columns: 80px 1fr 220px;
  background: var(--background-color);
  border-radius: var(--cst-radius-md);
  overflow: hidden;
  box-shadow: var(--cst-shadow-sm);
  transition: box-shadow .25s var(--cst-ease), transform .25s var(--cst-ease);
}

.cst-platform-row:hover {
  box-shadow: var(--cst-shadow-md);
  transform: translateX(5px);
}

.cst-platform-row__accent {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 4px;
  padding: 28px 0;
  color: #fff;
}

.cst-platform-row__accent i { font-size: 1.9rem; }

.cst-platform-row--fb .cst-platform-row__accent { background: linear-gradient(180deg, #1877f2 0%, #0a4fb3 100%); }
.cst-platform-row--wa .cst-platform-row__accent { background: linear-gradient(180deg, #25d366 0%, #128c4a 100%); }
.cst-platform-row--yt .cst-platform-row__accent { background: linear-gradient(180deg, #ff5252 0%, #c4302b 100%); }

.cst-platform-row__body {
  padding: 24px 28px;
  display: flex;
  flex-direction: column;
  gap: 7px;
  border-right: 1px solid var(--cst-line-soft);
}

.cst-platform-row__title {
  font-family: var(--heading-font);
  font-weight: 800;
  font-size: 1.15rem;
  color: var(--cst-ink-1);
  margin: 0;
  line-height: 1.2;
}

.cst-platform-row__handle {
  font-size: .78rem;
  color: var(--cst-ink-3);
  font-weight: 600;
}

.cst-platform-row__desc {
  margin: 0;
  font-size: .88rem;
  color: var(--cst-ink-2);
  line-height: 1.6;
}

.cst-platform-row__pills {
  display: flex;
  flex-wrap: wrap;
  gap: 5px;
  margin-top: 4px;
}

.cst-platform-row__pill {
  font-size: .62rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .08em;
  padding: 3px 9px;
  border-radius: var(--cst-radius-pill);
  background: var(--cst-brand-tint);
  color: var(--cst-brand);
}

.cst-platform-row__side {
  padding: 24px 24px;
  display: flex;
  flex-direction: column;
  align-items: flex-end;
  justify-content: space-between;
  gap: 12px;
}

.cst-platform-row__stats {
  display: flex;
  flex-direction: column;
  gap: 7px;
  align-items: flex-end;
}

.cst-platform-row__stat {
  display: flex;
  align-items: baseline;
  gap: 7px;
}

.cst-platform-row__stat-num {
  font-family: var(--heading-font);
  font-weight: 900;
  font-size: 1.25rem;
  color: var(--cst-ink-1);
  line-height: 1;
}

.cst-platform-row__stat-label {
  font-size: .68rem;
  text-transform: uppercase;
  letter-spacing: .08em;
  color: var(--cst-ink-3);
}

.cst-platform-row__cta {
  display: inline-flex;
  align-items: center;
  gap: 7px;
  background: var(--cst-brand);
  color: #fff;
  padding: 9px 18px;
  border-radius: var(--cst-radius-pill);
  font-weight: 700;
  font-size: .83rem;
  text-decoration: none;
  transition: background .25s var(--cst-ease), transform .25s var(--cst-ease);
  white-space: nowrap;
}

.cst-platform-row__cta:hover {
  background: var(--cst-brand-dark);
  color: #fff;
  transform: translateY(-1px);
}

/* ── Schedule Section ─────────────────────────────────────────────────────── */
.cst-redes-schedule {
  background: linear-gradient(150deg, #0d0d0d 0%, #1a0505 50%, #0d0d0d 100%);
  padding: 80px 0;
  position: relative;
  overflow: hidden;
}

.cst-redes-schedule::before {
  content: "";
  position: absolute;
  inset: 0;
  background: repeating-linear-gradient(
    -55deg,
    rgba(255, 255, 255, .012) 0,
    rgba(255, 255, 255, .012) 1px,
    transparent 1px,
    transparent 44px
  );
  pointer-events: none;
}

.cst-redes-schedule__eyebrow {
  display: inline-block;
  font-size: .62rem;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: .2em;
  color: var(--cst-brand);
  margin-bottom: var(--cst-sp-3);
  position: relative;
}

.cst-redes-schedule__eyebrow::after {
  content: "";
  display: block;
  width: 28px;
  height: 2px;
  background: var(--cst-brand);
  margin-top: 7px;
}

.cst-redes-schedule__heading {
  font-family: var(--heading-font);
  font-weight: 900;
  font-size: clamp(1.8rem, 3.5vw, 2.8rem);
  color: #fff;
  line-height: 1.15;
  margin-bottom: var(--cst-sp-6);
  position: relative;
}

.cst-redes-schedule__grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--cst-sp-4);
}

.cst-redes-schedule__card {
  background: rgba(255, 255, 255, .04);
  border: 1px solid rgba(255, 255, 255, .08);
  border-radius: var(--cst-radius-md);
  padding: 28px 24px;
  display: flex;
  flex-direction: column;
  gap: 12px;
  transition: background .25s var(--cst-ease), border-color .25s var(--cst-ease), transform .25s var(--cst-ease);
}

.cst-redes-schedule__card:hover {
  background: rgba(255, 255, 255, .07);
  border-color: rgba(255, 255, 255, .14);
  transform: translateY(-4px);
}

.cst-redes-schedule__card-top {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 12px;
}

.cst-redes-schedule__card-icon {
  width: 44px;
  height: 44px;
  border-radius: var(--cst-radius-sm);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.25rem;
  color: #fff;
  flex-shrink: 0;
}

.cst-redes-schedule__freq {
  font-size: .6rem;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: .1em;
  color: var(--cst-brand);
  background: rgba(255, 77, 79, .14);
  padding: 4px 9px;
  border-radius: var(--cst-radius-pill);
  white-space: nowrap;
}

.cst-redes-schedule__card-title {
  font-family: var(--heading-font);
  font-weight: 800;
  font-size: 1rem;
  color: #fff;
  margin: 0;
  line-height: 1.3;
}

.cst-redes-schedule__card-desc {
  font-size: .83rem;
  color: rgba(255, 255, 255, .5);
  line-height: 1.6;
  margin: 0;
  flex: 1;
}

.cst-redes-schedule__card-platforms {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  margin-top: auto;
}

.cst-redes-schedule__plat {
  font-size: .58rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .1em;
  padding: 3px 8px;
  border-radius: var(--cst-radius-pill);
  border: 1px solid rgba(255, 255, 255, .15);
  color: rgba(255, 255, 255, .55);
}

/* ── Hashtag Section ──────────────────────────────────────────────────────── */
.cst-redes-hashtags {
  padding: 80px 0;
  overflow: hidden;
  position: relative;
}

.cst-redes-hashtags::before {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 0;
  background: repeating-linear-gradient(
    90deg,
    var(--cst-line-soft) 0,
    var(--cst-line-soft) 1px,
    transparent 1px,
    transparent 64px
  );
  pointer-events: none;
}

.cst-redes-hashtags > .container {
  position: relative;
  z-index: 1;
}

.cst-redes-hashtags__eyebrow {
  display: inline-block;
  font-size: .62rem;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: .2em;
  color: var(--cst-brand);
  margin-bottom: var(--cst-sp-4);
  position: relative;
}

.cst-redes-hashtags__tags {
  display: flex;
  flex-direction: column;
  gap: 6px;
  margin-bottom: var(--cst-sp-5);
  position: relative;
}

.cst-redes-hashtags__tag {
  font-family: var(--heading-font);
  font-weight: 900;
  font-size: clamp(1.6rem, 5.5vw, 4.8rem);
  color: var(--cst-ink-1);
  line-height: 1.05;
  display: block;
  width: 100%;
  overflow-wrap: break-word;
  transition: color .25s var(--cst-ease);
  text-decoration: none;
}

.cst-redes-hashtags__tag:hover { color: var(--cst-brand); }
.cst-redes-hashtags__tag--alt { color: var(--cst-brand); }
.cst-redes-hashtags__tag--alt:hover { color: var(--cst-brand-dark); }

.cst-redes-hashtags__sub {
  font-size: .98rem;
  color: var(--cst-ink-2);
  line-height: 1.7;
  max-width: 440px;
  position: relative;
}

/* ── UGC CTA ──────────────────────────────────────────────────────────────── */
.cst-redes-ugc {
  background: linear-gradient(135deg, var(--cst-brand) 0%, var(--cst-brand-dark) 100%);
  padding: 72px 0;
  position: relative;
  overflow: hidden;
}

.cst-redes-ugc::before {
  content: "";
  position: absolute;
  inset: 0;
  background: repeating-linear-gradient(
    -55deg,
    rgba(255, 255, 255, .04) 0,
    rgba(255, 255, 255, .04) 1px,
    transparent 1px,
    transparent 42px
  );
  pointer-events: none;
}

.cst-redes-ugc__eyebrow {
  display: inline-block;
  font-size: .62rem;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: .18em;
  color: rgba(255, 255, 255, .65);
  margin-bottom: var(--cst-sp-3);
}

.cst-redes-ugc__heading {
  font-family: var(--heading-font);
  font-weight: 900;
  font-size: clamp(2rem, 4vw, 3.2rem);
  color: #fff;
  line-height: 1.1;
  margin-bottom: var(--cst-sp-4);
}

.cst-redes-ugc__sub {
  font-size: .98rem;
  color: rgba(255, 255, 255, .8);
  line-height: 1.7;
  max-width: 520px;
  margin-bottom: var(--cst-sp-5);
}

.cst-redes-ugc__actions {
  display: flex;
  flex-wrap: wrap;
  gap: var(--cst-sp-3);
}

.cst-redes-ugc__btn-primary {
  display: inline-flex;
  align-items: center;
  gap: 9px;
  background: #fff;
  color: var(--cst-brand);
  padding: 13px 28px;
  border-radius: var(--cst-radius-pill);
  font-weight: 800;
  font-size: .92rem;
  text-decoration: none;
  transition: transform .25s var(--cst-ease), box-shadow .25s var(--cst-ease);
  box-shadow: 0 4px 20px rgba(0, 0, 0, .15);
}

.cst-redes-ugc__btn-primary:hover {
  transform: translateY(-2px);
  box-shadow: 0 8px 28px rgba(0, 0, 0, .22);
  color: var(--cst-brand);
}

.cst-redes-ugc__btn-ghost {
  display: inline-flex;
  align-items: center;
  gap: 9px;
  background: transparent;
  color: #fff;
  padding: 12px 28px;
  border-radius: var(--cst-radius-pill);
  font-weight: 700;
  font-size: .92rem;
  text-decoration: none;
  border: 2px solid rgba(255, 255, 255, .5);
  transition: border-color .25s, background .25s;
}

.cst-redes-ugc__btn-ghost:hover {
  border-color: #fff;
  background: rgba(255, 255, 255, .1);
  color: #fff;
}

.cst-redes-ugc__deco {
  position: absolute;
  right: 4%;
  top: 50%;
  transform: translateY(-50%);
  font-size: 20rem;
  color: rgba(255, 255, 255, .05);
  line-height: 1;
  pointer-events: none;
  user-select: none;
}

/* ── Responsive ───────────────────────────────────────────────────────────── */
@media (max-width: 991.98px) {
  .cst-platform-feature {
    grid-template-columns: 1fr;
  }

  .cst-platform-feature__right {
    display: none;
  }

  .cst-platform-row {
    grid-template-columns: 64px 1fr;
  }

  .cst-platform-row__accent { padding: 20px 0; }
  .cst-platform-row__accent i { font-size: 1.55rem; }

  .cst-platform-row__body {
    padding: 16px 18px;
    gap: 5px;
  }

  .cst-platform-row__desc { display: none; }

  .cst-platform-row__side { display: none; }

  .cst-redes-schedule__grid { grid-template-columns: repeat(2, 1fr); }
}

@media (max-width: 575.98px) {
  .cst-redes-schedule__grid { grid-template-columns: 1fr; }

  .cst-redes-hero__stats {
    flex-direction: column;
  }

  .cst-redes-hero__stat {
    border-right: none;
    border-bottom: 1px solid rgba(255, 255, 255, .1);
  }

  .cst-redes-hero__stat:last-child { border-bottom: none; }

  .cst-redes-hashtags__tag {
    font-size: clamp(1.4rem, 7vw, 2.2rem);
  }
}

/* ==========================================================================
   40. cst-sp — Sponsors page
   ========================================================================== */

/* ── Hero ─────────────────────────────────────────────────────────────────── */
.cst-sp-hero {
  background: linear-gradient(135deg, #0a0a0a 0%, #1a0505 60%, #0d0d0d 100%);
  padding: 120px 0 90px;
  position: relative;
  overflow: hidden;
}

/* Diagonal texture */
.cst-sp-hero::before {
  content: "";
  position: absolute;
  inset: 0;
  background: repeating-linear-gradient(
    -55deg,
    transparent,
    transparent 14px,
    rgba(255, 255, 255, .018) 14px,
    rgba(255, 255, 255, .018) 15px
  );
  pointer-events: none;
}

/* Watermark */
.cst-sp-hero::after {
  content: "SPONSORS";
  position: absolute;
  bottom: -20px;
  right: -30px;
  font-family: var(--heading-font);
  font-weight: 900;
  font-size: clamp(5rem, 18vw, 13rem);
  line-height: 1;
  color: var(--cst-brand);
  opacity: .035;
  letter-spacing: -.04em;
  pointer-events: none;
  user-select: none;
}

.cst-sp-hero__inner {
  position: relative;
  z-index: 1;
  max-width: 780px;
}

.cst-sp-hero__eyebrow {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  font-size: .72rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .2em;
  color: var(--cst-brand);
  margin: 0 0 18px;
}

.cst-sp-hero__eyebrow::before {
  content: "";
  display: block;
  width: 32px;
  height: 2px;
  background: var(--cst-brand);
  border-radius: 2px;
}

.cst-sp-hero__heading {
  font-family: var(--heading-font);
  font-weight: 900;
  font-size: clamp(2.2rem, 5.5vw, 4rem);
  color: #fff;
  line-height: 1.1;
  letter-spacing: -.03em;
  margin: 0 0 22px;
}

.cst-sp-hero__heading em {
  font-style: normal;
  color: var(--cst-brand);
}

.cst-sp-hero__sub {
  font-size: 1.05rem;
  color: rgba(255, 255, 255, .6);
  line-height: 1.75;
  max-width: 620px;
  margin: 0 0 48px;
}

.cst-sp-hero__stats {
  display: flex;
  border: 1px solid rgba(255, 255, 255, .12);
  border-radius: var(--cst-radius-md);
  overflow: hidden;
  background: rgba(255, 255, 255, .04);
  backdrop-filter: blur(6px);
  max-width: 640px;
}

.cst-sp-hero__stat {
  flex: 1;
  padding: 22px 18px;
  text-align: center;
  border-right: 1px solid rgba(255, 255, 255, .1);
}

.cst-sp-hero__stat:last-child { border-right: none; }

.cst-sp-hero__stat-num {
  display: block;
  font-family: var(--heading-font);
  font-weight: 900;
  font-size: clamp(1.4rem, 2.8vw, 1.9rem);
  color: #fff;
  line-height: 1;
  letter-spacing: -.02em;
}

.cst-sp-hero__stat-label {
  display: block;
  font-size: .6rem;
  text-transform: uppercase;
  letter-spacing: .13em;
  color: rgba(255, 255, 255, .42);
  margin-top: 6px;
  line-height: 1.3;
}

/* ── Sponsors wall ────────────────────────────────────────────────────────── */
.cst-sp-wall {
  background: #0d0d0d;
  padding: 80px 0;
}

.cst-sp-section-head {
  text-align: center;
  margin-bottom: 56px;
}

.cst-sp-eyebrow {
  display: inline-block;
  font-size: .7rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .2em;
  color: var(--cst-brand);
  margin-bottom: 10px;
}

.cst-sp-section-title {
  font-family: var(--heading-font);
  font-weight: 800;
  font-size: clamp(1.6rem, 3.5vw, 2.4rem);
  color: #fff;
  margin: 0 0 12px;
  letter-spacing: -.02em;
}

.cst-sp-section-sub {
  font-size: .95rem;
  color: rgba(255,255,255,.45);
  max-width: 520px;
  margin: 0 auto;
  line-height: 1.7;
}

/* ── Tier groups ──────────────────────────────────────────────────────────── */
.cst-sp-tier {
  margin-bottom: 44px;
}

.cst-sp-tier__label {
  display: inline-flex;
  align-items: center;
  gap: 7px;
  font-size: .63rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .18em;
  padding: 5px 14px;
  border-radius: var(--cst-radius-pill);
  margin-bottom: 18px;
  border: 1px solid transparent;
}

.cst-sp-tier__label--oro   { background: rgba(226,185,74,.12); color: #e2b94a; border-color: rgba(226,185,74,.22); }
.cst-sp-tier__label--plata { background: rgba(155,170,181,.1); color: #9baab5; border-color: rgba(155,170,181,.2); }
.cst-sp-tier__label--bronce { background: rgba(201,149,108,.1); color: #c9956c; border-color: rgba(201,149,108,.2); }

/* ── Featured Oro card ────────────────────────────────────────────────────── */
.cst-sp-card-featured {
  position: relative;
  background: #161616;
  border: 1px solid rgba(226,185,74,.2);
  border-radius: var(--cst-radius-md);
  padding: 36px 40px;
  display: grid;
  grid-template-columns: auto 1fr auto;
  align-items: center;
  gap: 32px;
  overflow: hidden;
  transition: border-color .3s var(--cst-ease), box-shadow .3s var(--cst-ease);
}

.cst-sp-card-featured:hover {
  border-color: rgba(226,185,74,.45);
  box-shadow: 0 20px 60px rgba(226,185,74,.16), 0 0 0 1px rgba(226,185,74,.18);
}

/* Shimmer top line */
.cst-sp-card-featured::before {
  content: "";
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 2px;
  background: linear-gradient(90deg, transparent 0%, #e2b94a 40%, #fff8d6 60%, #e2b94a 80%, transparent 100%);
  background-size: 200% 100%;
  animation: sp-shimmer 3s ease infinite;
}

/* Watermark */
.cst-sp-card-featured::after {
  content: "ORO";
  position: absolute;
  right: -8px; bottom: -24px;
  font-family: var(--heading-font);
  font-weight: 900;
  font-size: clamp(5rem, 12vw, 9rem);
  color: rgba(226,185,74,.05);
  letter-spacing: -.04em;
  line-height: 1;
  pointer-events: none;
  user-select: none;
}

@keyframes sp-shimmer {
  0%   { background-position: 200% center; }
  100% { background-position: -200% center; }
}

.cst-sp-card-featured__avatar {
  width: 88px;
  height: 88px;
  border-radius: 50%;
  background: linear-gradient(135deg, #e2b94a 0%, #a87917 100%);
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: var(--heading-font);
  font-weight: 900;
  font-size: 1.85rem;
  color: #fff;
  letter-spacing: .02em;
  flex-shrink: 0;
  box-shadow: 0 8px 32px rgba(226,185,74,.4), 0 0 0 4px rgba(226,185,74,.12);
}

.cst-sp-card-featured__body h3 {
  font-family: var(--heading-font);
  font-weight: 900;
  font-size: clamp(1.2rem, 2.5vw, 1.7rem);
  color: #fff;
  margin: 0 0 5px;
  letter-spacing: -.02em;
}

.cst-sp-card-featured__cat {
  font-size: .7rem;
  text-transform: uppercase;
  letter-spacing: .14em;
  color: rgba(255,255,255,.35);
  margin: 0 0 10px;
}

.cst-sp-card-featured__desc {
  font-size: .87rem;
  color: rgba(255,255,255,.55);
  line-height: 1.65;
  margin: 0;
}

.cst-sp-card-featured__badge {
  display: inline-flex;
  align-items: center;
  gap: 7px;
  background: linear-gradient(135deg, #e2b94a 0%, #a87917 100%);
  color: #fff;
  padding: 11px 24px;
  border-radius: var(--cst-radius-pill);
  font-weight: 700;
  font-size: .8rem;
  text-transform: uppercase;
  letter-spacing: .08em;
  white-space: nowrap;
  flex-shrink: 0;
  box-shadow: 0 6px 20px rgba(226,185,74,.35);
}

/* ── Plata / Bronce tier rows ─────────────────────────────────────────────── */
.cst-sp-tier__row--plata  { display: grid; grid-template-columns: repeat(3, 1fr); gap: 16px; }
.cst-sp-tier__row--bronce { display: grid; grid-template-columns: repeat(4, 1fr); gap: 16px; }

/* Compact dark cards */
.cst-sp-card-v2 {
  background: #161616;
  border: 1px solid rgba(255,255,255,.07);
  border-radius: var(--cst-radius-md);
  padding: 28px 20px 24px;
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  position: relative;
  overflow: hidden;
  transition: transform .3s var(--cst-ease), border-color .3s var(--cst-ease), box-shadow .3s var(--cst-ease);
}

/* Accent top line */
.cst-sp-card-v2::before {
  content: "";
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 2px;
}

.cst-sp-card-v2--plata::before  { background: linear-gradient(90deg, transparent, #9baab5, transparent); }
.cst-sp-card-v2--bronce::before { background: linear-gradient(90deg, transparent, #c9956c, transparent); }

.cst-sp-card-v2:hover { transform: translateY(-6px); }
.cst-sp-card-v2--plata:hover  { border-color: rgba(155,170,181,.3); box-shadow: 0 16px 44px rgba(155,170,181,.14); }
.cst-sp-card-v2--bronce:hover { border-color: rgba(201,149,108,.3); box-shadow: 0 16px 44px rgba(201,149,108,.12); }

.cst-sp-card-v2__avatar {
  width: 62px;
  height: 62px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: var(--heading-font);
  font-weight: 900;
  font-size: 1.3rem;
  color: #fff;
  margin-bottom: 14px;
  flex-shrink: 0;
}

.cst-sp-card-v2--plata .cst-sp-card-v2__avatar {
  background: linear-gradient(135deg, #c2cdd6 0%, #6f8090 100%);
  box-shadow: 0 6px 20px rgba(155,170,181,.3);
}

.cst-sp-card-v2--bronce .cst-sp-card-v2__avatar {
  background: linear-gradient(135deg, #c9956c 0%, #7a4d27 100%);
  box-shadow: 0 6px 20px rgba(201,149,108,.3);
}

.cst-sp-card-v2__name {
  font-family: var(--heading-font);
  font-weight: 800;
  font-size: .95rem;
  color: #fff;
  margin: 0 0 5px;
  line-height: 1.3;
}

.cst-sp-card-v2__cat {
  font-size: .65rem;
  text-transform: uppercase;
  letter-spacing: .12em;
  color: rgba(255,255,255,.35);
  margin: 0 0 16px;
}

.cst-sp-card-v2__badge {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  font-size: .6rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .1em;
  padding: 4px 12px;
  border-radius: var(--cst-radius-pill);
  margin-top: auto;
}

.cst-sp-card-v2--plata .cst-sp-card-v2__badge  { background: rgba(155,170,181,.15); color: #9baab5; }
.cst-sp-card-v2--bronce .cst-sp-card-v2__badge { background: rgba(201,149,108,.15); color: #c9956c; }

/* ── Impact section ───────────────────────────────────────────────────────── */
.cst-sp-impact {
  background: linear-gradient(150deg, #0a0a0a 0%, #150303 50%, #0a0a0a 100%);
  padding: 90px 0;
  position: relative;
  overflow: hidden;
}

.cst-sp-impact::before {
  content: "";
  position: absolute;
  inset: 0;
  background: repeating-linear-gradient(
    -55deg,
    transparent,
    transparent 14px,
    rgba(255,255,255,.015) 14px,
    rgba(255,255,255,.015) 15px
  );
  pointer-events: none;
}

.cst-sp-impact__inner {
  position: relative;
  z-index: 1;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 64px;
  align-items: center;
}

.cst-sp-impact__eyebrow {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  font-size: .68rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .2em;
  color: var(--cst-brand);
  margin: 0 0 16px;
}

.cst-sp-impact__eyebrow::before {
  content: "";
  display: block;
  width: 28px;
  height: 2px;
  background: var(--cst-brand);
  border-radius: 2px;
}

.cst-sp-impact__heading {
  font-family: var(--heading-font);
  font-weight: 900;
  font-size: clamp(1.7rem, 3.5vw, 2.6rem);
  color: #fff;
  line-height: 1.15;
  letter-spacing: -.025em;
  margin: 0 0 18px;
}

.cst-sp-impact__sub {
  font-size: .95rem;
  color: rgba(255,255,255,.55);
  line-height: 1.75;
  margin: 0 0 26px;
}

.cst-sp-impact__list {
  list-style: none;
  padding: 0;
  margin: 0 0 36px;
  display: flex;
  flex-direction: column;
  gap: 11px;
}

.cst-sp-impact__list li {
  display: flex;
  align-items: flex-start;
  gap: 11px;
  font-size: .9rem;
  color: rgba(255,255,255,.7);
  line-height: 1.55;
}

.cst-sp-impact__list li i {
  color: var(--cst-brand);
  font-size: 1rem;
  margin-top: 2px;
  flex-shrink: 0;
}

.cst-sp-impact__cta {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  background: var(--cst-brand);
  color: #fff;
  padding: 13px 28px;
  border-radius: var(--cst-radius-pill);
  font-weight: 700;
  font-size: .9rem;
  text-decoration: none;
  transition: background .25s var(--cst-ease), transform .25s var(--cst-ease);
}

.cst-sp-impact__cta:hover {
  background: var(--cst-brand-dark);
  color: #fff;
  transform: translateY(-2px);
}

/* Stats 2×2 panel */
.cst-sp-impact__stats {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 2px;
  background: rgba(255,255,255,.08);
  border-radius: var(--cst-radius-md);
  overflow: hidden;
}

.cst-sp-impact__stat {
  background: rgba(255,255,255,.05);
  padding: 36px 28px;
  display: flex;
  flex-direction: column;
  gap: 8px;
  transition: background .3s var(--cst-ease);
}

.cst-sp-impact__stat:hover { background: rgba(255,255,255,.09); }

.cst-sp-impact__stat-icon {
  font-size: 1.4rem;
  color: var(--cst-brand);
  margin-bottom: 4px;
}

.cst-sp-impact__stat-num {
  font-family: var(--heading-font);
  font-weight: 900;
  font-size: clamp(2rem, 4vw, 2.8rem);
  color: #fff;
  line-height: 1;
  letter-spacing: -.03em;
}

.cst-sp-impact__stat-label {
  font-size: .7rem;
  text-transform: uppercase;
  letter-spacing: .13em;
  color: rgba(255,255,255,.4);
  line-height: 1.4;
}

/* ── Plans section ────────────────────────────────────────────────────────── */
.cst-sp-plans {
  background: #0d0d0d;
  padding: 90px 0;
}

.cst-sp-plans__head {
  text-align: center;
  margin-bottom: 56px;
}

.cst-sp-plans__eyebrow {
  display: inline-block;
  font-size: .68rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .2em;
  color: var(--cst-brand);
  margin-bottom: 12px;
}

.cst-sp-plans__title {
  font-family: var(--heading-font);
  font-weight: 900;
  font-size: clamp(1.7rem, 3.5vw, 2.6rem);
  color: #fff;
  letter-spacing: -.025em;
  margin: 0 0 12px;
}

.cst-sp-plans__sub {
  font-size: .95rem;
  color: rgba(255,255,255,.45);
  max-width: 500px;
  margin: 0 auto;
  line-height: 1.7;
}

/* Plan card v2 */
.cst-plan-v2 {
  background: #1a1a1a;
  border-radius: var(--cst-radius-md);
  overflow: hidden;
  height: 100%;
  display: flex;
  flex-direction: column;
  border: 1px solid rgba(255,255,255,.06);
  position: relative;
  transition: transform .3s var(--cst-ease), box-shadow .3s var(--cst-ease), border-color .3s;
}

.cst-plan-v2:hover { transform: translateY(-6px); }

.cst-plan-v2--bronce:hover { box-shadow: 0 20px 50px rgba(201,149,108,.18); border-color: rgba(201,149,108,.25); }
.cst-plan-v2--plata:hover  { box-shadow: 0 20px 50px rgba(155,170,181,.2);  border-color: rgba(155,170,181,.25); }
.cst-plan-v2--oro:hover    { box-shadow: 0 20px 50px rgba(226,185,74,.25);  border-color: rgba(226,185,74,.3); }

.cst-plan-v2--featured {
  border-color: rgba(226,185,74,.35);
  box-shadow: 0 0 0 1px rgba(226,185,74,.2), 0 20px 60px rgba(226,185,74,.2);
  transform: translateY(-4px);
}

.cst-plan-v2--featured:hover {
  transform: translateY(-10px);
  box-shadow: 0 0 0 1px rgba(226,185,74,.45), 0 28px 70px rgba(226,185,74,.3);
}

.cst-plan-v2__ribbon {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 3px;
}

.cst-plan-v2--bronce .cst-plan-v2__ribbon { background: linear-gradient(90deg, #c9956c, #7a4d27); }
.cst-plan-v2--plata  .cst-plan-v2__ribbon { background: linear-gradient(90deg, #c2cdd6, #6f8090); }
.cst-plan-v2--oro    .cst-plan-v2__ribbon { background: linear-gradient(90deg, #e2b94a, #a87917); }

.cst-plan-v2__tag {
  position: absolute;
  top: 18px;
  right: 18px;
  background: linear-gradient(135deg, #e2b94a 0%, #a87917 100%);
  color: #fff;
  font-size: .6rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .1em;
  padding: 4px 12px;
  border-radius: var(--cst-radius-pill);
  box-shadow: 0 4px 12px rgba(168,121,23,.4);
}

.cst-plan-v2__head {
  padding: 32px 28px 22px;
  border-bottom: 1px solid rgba(255,255,255,.07);
}

.cst-plan-v2__tier {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-size: .65rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .16em;
  padding: 4px 12px;
  border-radius: var(--cst-radius-pill);
  margin-bottom: 18px;
}

.cst-plan-v2--bronce .cst-plan-v2__tier { background: rgba(201,149,108,.18); color: #c9956c; }
.cst-plan-v2--plata  .cst-plan-v2__tier { background: rgba(155,170,181,.18); color: #9baab5; }
.cst-plan-v2--oro    .cst-plan-v2__tier { background: rgba(226,185,74,.18);  color: #e2b94a; }

.cst-plan-v2__name {
  font-family: var(--heading-font);
  font-weight: 900;
  font-size: 1.4rem;
  color: #fff;
  margin: 0 0 6px;
  letter-spacing: -.02em;
}

.cst-plan-v2__desc {
  font-size: .82rem;
  color: rgba(255,255,255,.4);
  margin: 0;
}

.cst-plan-v2__price-area {
  padding: 20px 28px;
  border-bottom: 1px solid rgba(255,255,255,.07);
  display: flex;
  align-items: baseline;
  gap: 8px;
}

.cst-plan-v2__price {
  font-family: var(--heading-font);
  font-weight: 900;
  font-size: clamp(2rem, 4vw, 2.8rem);
  color: #fff;
  line-height: 1;
  letter-spacing: -.03em;
}

.cst-plan-v2__period {
  font-size: .78rem;
  color: rgba(255,255,255,.35);
}

.cst-plan-v2__body {
  padding: 24px 28px;
  flex: 1;
}

.cst-plan-v2__list {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: 12px;
}

.cst-plan-v2__list li {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  font-size: .87rem;
  color: rgba(255,255,255,.7);
  line-height: 1.5;
}

.cst-plan-v2__list li i {
  font-size: .9rem;
  margin-top: 2px;
  flex-shrink: 0;
}

.cst-plan-v2--bronce .cst-plan-v2__list li i { color: #c9956c; }
.cst-plan-v2--plata  .cst-plan-v2__list li i { color: #9baab5; }
.cst-plan-v2--oro    .cst-plan-v2__list li i { color: #e2b94a; }

.cst-plan-v2__foot {
  padding: 0 28px 28px;
}

.cst-plan-v2__cta {
  display: block;
  text-align: center;
  padding: 13px;
  border-radius: var(--cst-radius-pill);
  font-weight: 700;
  font-size: .88rem;
  text-decoration: none;
  transition: background .25s var(--cst-ease), color .25s var(--cst-ease), transform .2s var(--cst-ease), box-shadow .25s var(--cst-ease);
}

.cst-plan-v2--bronce .cst-plan-v2__cta {
  background: rgba(201,149,108,.15);
  color: #c9956c;
  border: 1px solid rgba(201,149,108,.3);
}

.cst-plan-v2--bronce .cst-plan-v2__cta:hover {
  background: #c9956c;
  color: #fff;
  border-color: #c9956c;
  transform: translateY(-1px);
}

.cst-plan-v2--plata .cst-plan-v2__cta {
  background: rgba(155,170,181,.12);
  color: #9baab5;
  border: 1px solid rgba(155,170,181,.25);
}

.cst-plan-v2--plata .cst-plan-v2__cta:hover {
  background: #9baab5;
  color: #111;
  border-color: #9baab5;
  transform: translateY(-1px);
}

.cst-plan-v2--oro .cst-plan-v2__cta {
  background: linear-gradient(135deg, #e2b94a 0%, #a87917 100%);
  color: #fff;
  border: none;
  box-shadow: 0 6px 22px rgba(226,185,74,.3);
}

.cst-plan-v2--oro .cst-plan-v2__cta:hover {
  box-shadow: 0 10px 32px rgba(226,185,74,.5);
  transform: translateY(-2px);
}

/* ── Closing CTA ──────────────────────────────────────────────────────────── */
.cst-sp-cta {
  background: linear-gradient(135deg, var(--cst-brand-dark) 0%, var(--cst-brand) 60%, #e84545 100%);
  padding: 90px 0;
  position: relative;
  overflow: hidden;
}

.cst-sp-cta::before {
  content: "";
  position: absolute;
  inset: 0;
  background: repeating-linear-gradient(
    -55deg,
    transparent,
    transparent 16px,
    rgba(255,255,255,.04) 16px,
    rgba(255,255,255,.04) 17px
  );
  pointer-events: none;
}

.cst-sp-cta__deco {
  position: absolute;
  right: -40px;
  bottom: -30px;
  font-size: clamp(8rem, 18vw, 14rem);
  color: rgba(255,255,255,.06);
  line-height: 1;
  pointer-events: none;
}

.cst-sp-cta__inner {
  position: relative;
  z-index: 1;
  text-align: center;
  max-width: 640px;
  margin: 0 auto;
}

.cst-sp-cta__eyebrow {
  font-size: .68rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .22em;
  color: rgba(255,255,255,.65);
  margin: 0 0 16px;
}

.cst-sp-cta__heading {
  font-family: var(--heading-font);
  font-weight: 900;
  font-size: clamp(2rem, 4.5vw, 3.2rem);
  color: #fff;
  line-height: 1.1;
  letter-spacing: -.03em;
  margin: 0 0 18px;
}

.cst-sp-cta__sub {
  font-size: 1rem;
  color: rgba(255,255,255,.7);
  line-height: 1.7;
  margin: 0 0 40px;
}

.cst-sp-cta__btns {
  display: flex;
  gap: 16px;
  justify-content: center;
  flex-wrap: wrap;
}

.cst-sp-cta__btn-primary {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  background: #fff;
  color: var(--cst-brand);
  padding: 14px 32px;
  border-radius: var(--cst-radius-pill);
  font-weight: 700;
  font-size: .9rem;
  text-decoration: none;
  transition: transform .25s var(--cst-ease), box-shadow .25s var(--cst-ease);
  box-shadow: 0 6px 24px rgba(0,0,0,.18);
}

.cst-sp-cta__btn-primary:hover {
  transform: translateY(-3px);
  box-shadow: 0 14px 36px rgba(0,0,0,.25);
  color: var(--cst-brand-dark);
}

.cst-sp-cta__btn-ghost {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  background: transparent;
  color: #fff;
  padding: 13px 28px;
  border: 2px solid rgba(255,255,255,.45);
  border-radius: var(--cst-radius-pill);
  font-weight: 700;
  font-size: .9rem;
  text-decoration: none;
  transition: background .25s var(--cst-ease), border-color .25s var(--cst-ease), transform .25s var(--cst-ease);
}

.cst-sp-cta__btn-ghost:hover {
  background: rgba(255,255,255,.12);
  border-color: rgba(255,255,255,.8);
  color: #fff;
  transform: translateY(-2px);
}

/* ── Responsive ───────────────────────────────────────────────────────────── */
@media (max-width: 991.98px) {
  .cst-sp-card-featured {
    grid-template-columns: auto 1fr;
    grid-template-rows: auto auto;
  }

  .cst-sp-card-featured__badge {
    grid-column: 1 / -1;
    justify-self: start;
  }

  .cst-sp-tier__row--plata  { grid-template-columns: repeat(3, 1fr); }
  .cst-sp-tier__row--bronce { grid-template-columns: repeat(2, 1fr); }

  .cst-sp-impact__inner {
    grid-template-columns: 1fr;
    gap: 40px;
  }
}

@media (max-width: 767.98px) {
  .cst-sp-card-featured {
    grid-template-columns: 1fr;
    text-align: center;
    justify-items: center;
    padding: 28px 24px;
    gap: 18px;
  }

  .cst-sp-card-featured__badge { grid-column: auto; justify-self: center; }

  .cst-sp-tier__row--plata  { grid-template-columns: 1fr 1fr; }
}

@media (max-width: 575.98px) {
  .cst-sp-hero__stats {
    flex-direction: column;
  }

  .cst-sp-hero__stat {
    border-right: none;
    border-bottom: 1px solid rgba(255,255,255,.1);
    padding: 16px 20px;
  }

  .cst-sp-hero__stat:last-child { border-bottom: none; }

  .cst-sp-tier__row--plata,
  .cst-sp-tier__row--bronce { grid-template-columns: 1fr 1fr; }

  .cst-sp-cta__btns {
    flex-direction: column;
    align-items: center;
  }
}


/* ==========================================================================
   41. cst-home — Index / Home page (editorial flagship)
   ========================================================================== */

/* Shared section heads & buttons (home namespace) */
.cst-home-section-head {
  max-width: 760px;
  margin: 0 auto var(--cst-sp-5);
  text-align: center;
}
.cst-home-eyebrow {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  font: 700 0.78rem/1 var(--nav-font, "Raleway"), sans-serif;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--cst-brand);
  margin-bottom: 18px;
  position: relative;
  padding-left: 38px;
}
.cst-home-eyebrow::before {
  content: "";
  position: absolute;
  left: 0;
  top: 50%;
  width: 28px;
  height: 2px;
  background: var(--cst-brand);
  transform: translateY(-50%);
}
.cst-home-eyebrow--light { color: #ff7e7f; }
.cst-home-eyebrow--light::before { background: #ff7e7f; }

.cst-home-section-title {
  font: 800 clamp(1.8rem, 3.6vw, 2.7rem)/1.15 var(--heading-font, "Mulish"), sans-serif;
  color: var(--cst-ink-1, #1a1a1a);
  margin: 0 0 18px;
  letter-spacing: -0.01em;
}
.cst-home-section-title--light { color: #fff; }
.cst-home-section-title em {
  font-style: normal;
  color: var(--cst-brand);
}
.cst-home-section-sub {
  font-size: 1.02rem;
  line-height: 1.6;
  color: var(--cst-ink-2, #555);
  margin: 0;
}
.cst-home-section-sub--light { color: rgba(255,255,255,.72); }

.cst-home-btn-outline {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  padding: 14px 28px;
  border-radius: var(--cst-radius-pill, 999px);
  border: 2px solid var(--cst-brand);
  color: var(--cst-brand);
  background: transparent;
  font: 700 0.92rem/1 var(--nav-font), sans-serif;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  text-decoration: none;
  transition: all .25s var(--cst-ease, ease);
}
.cst-home-btn-outline:hover {
  background: var(--cst-brand);
  color: #fff;
  transform: translateY(-2px);
  box-shadow: 0 12px 28px rgba(255,77,79,.28);
}
.cst-home-btn-outline--light {
  border-color: rgba(255,255,255,.4);
  color: #fff;
}
.cst-home-btn-outline--light:hover {
  background: #fff;
  color: var(--cst-brand);
  border-color: #fff;
  box-shadow: 0 12px 28px rgba(0,0,0,.35);
}

/* ── Manifiesto editorial ────────────────────────────────────────────────── */
.cst-home-manifesto {
  position: relative;
  padding: clamp(80px, 12vw, 140px) 0;
  background: #0e0e10;
  color: #fff;
  overflow: hidden;
  isolation: isolate;
}
.cst-home-manifesto::before {
  content: "";
  position: absolute;
  inset: 0;
  background:
    radial-gradient(ellipse at 80% 20%, rgba(255,77,79,.18), transparent 60%),
    repeating-linear-gradient(-55deg, rgba(255,255,255,.025) 0 1px, transparent 1px 22px);
  z-index: -1;
}
.cst-home-manifesto::after {
  content: "AURORA";
  position: absolute;
  right: -2%;
  bottom: -8%;
  font: 900 clamp(10rem, 28vw, 24rem)/0.85 var(--heading-font), sans-serif;
  color: #fff;
  opacity: 0.04;
  letter-spacing: -0.04em;
  pointer-events: none;
  z-index: -1;
}
.cst-home-manifesto__inner {
  max-width: 920px;
  margin: 0 auto;
  text-align: center;
}
.cst-home-manifesto__eyebrow {
  font: 700 0.82rem/1 var(--nav-font), sans-serif;
  letter-spacing: 0.3em;
  text-transform: uppercase;
  color: #ff7e7f;
  margin: 0 0 24px;
}
.cst-home-manifesto__heading {
  font: 800 clamp(2.4rem, 6vw, 4.4rem)/1.05 var(--heading-font), sans-serif;
  color: #fff;
  margin: 0 0 28px;
  letter-spacing: -0.02em;
}
.cst-home-manifesto__heading em {
  font-style: normal;
  color: var(--cst-brand);
}
.cst-home-manifesto__sub {
  font-size: clamp(1.05rem, 1.4vw, 1.2rem);
  line-height: 1.65;
  color: rgba(255,255,255,.78);
  max-width: 720px;
  margin: 0 auto 56px;
}
.cst-home-manifesto__pillars {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 28px;
  text-align: left;
}
.cst-home-manifesto__pillar {
  background: rgba(255,255,255,.04);
  backdrop-filter: blur(12px);
  border: 1px solid rgba(255,255,255,.08);
  border-radius: var(--cst-radius-md, 14px);
  padding: 32px 28px;
  transition: all .3s var(--cst-ease);
}
.cst-home-manifesto__pillar:hover {
  background: rgba(255,77,79,.08);
  border-color: rgba(255,77,79,.3);
  transform: translateY(-4px);
}
.cst-home-manifesto__pillar-icon {
  font-size: 2rem;
  color: var(--cst-brand);
  margin-bottom: 16px;
  display: block;
}
.cst-home-manifesto__pillar h3 {
  font: 700 1.25rem/1.2 var(--heading-font), sans-serif;
  color: #fff;
  margin: 0 0 10px;
}
.cst-home-manifesto__pillar p {
  font-size: 0.95rem;
  line-height: 1.55;
  color: rgba(255,255,255,.7);
  margin: 0;
}

/* ── Match section wrapper ────────────────────────────────────────────────── */
.cst-home-match {
  background: #fff;
  padding: clamp(72px, 10vw, 110px) 0;
  position: relative;
}
.cst-home-match::before {
  content: "";
  position: absolute;
  inset: 0;
  background:
    radial-gradient(ellipse at 20% 30%, rgba(255,77,79,.04), transparent 50%);
  pointer-events: none;
}
.cst-home-match__wrap { position: relative; }

/* ── Stats institucionales (dark) ────────────────────────────────────────── */
.cst-home-stats {
  position: relative;
  background: linear-gradient(135deg, #1a1a1d 0%, #0e0e10 100%);
  padding: clamp(80px, 11vw, 120px) 0;
  color: #fff;
  overflow: hidden;
  isolation: isolate;
}
.cst-home-stats::before {
  content: "";
  position: absolute;
  inset: 0;
  background:
    radial-gradient(circle at 70% 50%, rgba(255,77,79,.15), transparent 60%),
    repeating-linear-gradient(-55deg, rgba(255,255,255,.022) 0 1px, transparent 1px 24px);
  z-index: -1;
}
.cst-home-stats::after {
  content: "1962";
  position: absolute;
  left: -1%;
  top: 50%;
  transform: translateY(-50%);
  font: 900 clamp(10rem, 24vw, 22rem)/0.85 var(--heading-font), sans-serif;
  color: #fff;
  opacity: 0.045;
  letter-spacing: -0.05em;
  pointer-events: none;
  z-index: -1;
}
.cst-home-stats__grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 18px;
}
.cst-home-stats__cell {
  background: rgba(255,255,255,.045);
  backdrop-filter: blur(10px);
  border: 1px solid rgba(255,255,255,.09);
  border-radius: var(--cst-radius-md, 14px);
  padding: 36px 24px;
  text-align: center;
  position: relative;
  overflow: hidden;
  transition: all .3s var(--cst-ease);
}
.cst-home-stats__cell::before {
  content: "";
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 3px;
  background: var(--cst-brand);
  transform: scaleX(0);
  transform-origin: left;
  transition: transform .4s var(--cst-ease);
}
.cst-home-stats__cell:hover {
  transform: translateY(-6px);
  border-color: rgba(255,77,79,.4);
  background: rgba(255,77,79,.06);
}
.cst-home-stats__cell:hover::before { transform: scaleX(1); }
.cst-home-stats__icon {
  font-size: 1.8rem;
  color: var(--cst-brand);
  margin-bottom: 14px;
  display: block;
}
.cst-home-stats__num {
  display: block;
  font: 800 clamp(2.4rem, 4vw, 3.2rem)/1 var(--heading-font), sans-serif;
  color: #fff;
  margin-bottom: 8px;
  letter-spacing: -0.02em;
}
.cst-home-stats__label {
  display: block;
  font: 700 0.95rem/1.2 var(--heading-font), sans-serif;
  color: #fff;
  margin-bottom: 6px;
}
.cst-home-stats__context {
  font-size: 0.82rem;
  color: rgba(255,255,255,.55);
  margin: 0;
  letter-spacing: 0.02em;
}

/* ── Categorías ──────────────────────────────────────────────────────────── */
.cst-home-categories {
  background: #fafafa;
  padding: clamp(80px, 11vw, 120px) 0;
}
.cst-home-categories__grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 22px;
}
.cst-home-cat {
  position: relative;
  background: #fff;
  border-radius: var(--cst-radius-md, 14px);
  padding: 36px 28px 32px;
  border: 1px solid var(--cst-line, #ececec);
  transition: all .35s var(--cst-ease);
  overflow: hidden;
  isolation: isolate;
}
.cst-home-cat::before {
  content: "";
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 4px;
  background: linear-gradient(90deg, var(--cst-brand), var(--cst-brand-dark));
  transform: scaleX(0);
  transform-origin: left;
  transition: transform .4s var(--cst-ease);
}
.cst-home-cat:hover {
  transform: translateY(-8px);
  box-shadow: 0 22px 50px rgba(0,0,0,.1);
  border-color: transparent;
}
.cst-home-cat:hover::before { transform: scaleX(1); }
.cst-home-cat__num {
  position: absolute;
  top: 22px;
  right: 26px;
  font: 800 2.4rem/1 var(--heading-font), sans-serif;
  color: rgba(0,0,0,.05);
  letter-spacing: -0.04em;
  z-index: -1;
}
.cst-home-cat__icon {
  width: 56px;
  height: 56px;
  border-radius: 14px;
  background: var(--cst-brand-tint, #fff5f5);
  color: var(--cst-brand);
  display: grid;
  place-items: center;
  font-size: 1.5rem;
  margin-bottom: 22px;
  transition: all .3s var(--cst-ease);
}
.cst-home-cat:hover .cst-home-cat__icon {
  background: var(--cst-brand);
  color: #fff;
  transform: rotate(-6deg) scale(1.05);
}
.cst-home-cat__name {
  font: 800 1.4rem/1.2 var(--heading-font), sans-serif;
  color: var(--cst-ink-1, #1a1a1a);
  margin: 0 0 4px;
}
.cst-home-cat__age {
  font: 600 0.85rem/1 var(--nav-font), sans-serif;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--cst-brand);
  margin: 0 0 14px;
}
.cst-home-cat__desc {
  font-size: 0.92rem;
  line-height: 1.55;
  color: var(--cst-ink-2, #555);
  margin: 0 0 20px;
  min-height: 70px;
}
.cst-home-cat__meta {
  list-style: none;
  padding: 18px 0 0;
  margin: 0;
  border-top: 1px dashed var(--cst-line);
  display: flex;
  flex-direction: column;
  gap: 8px;
}
.cst-home-cat__meta li {
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: 0.85rem;
  color: var(--cst-ink-3, #777);
}
.cst-home-cat__meta i { color: var(--cst-brand); }
.cst-home-cat--featured {
  background: linear-gradient(160deg, #1a1a1d 0%, #0e0e10 100%);
  border-color: transparent;
  color: #fff;
}
.cst-home-cat--featured::before { transform: scaleX(1); }
.cst-home-cat--featured .cst-home-cat__num { color: rgba(255,255,255,.06); }
.cst-home-cat--featured .cst-home-cat__name { color: #fff; }
.cst-home-cat--featured .cst-home-cat__age { color: #ff7e7f; }
.cst-home-cat--featured .cst-home-cat__desc { color: rgba(255,255,255,.72); }
.cst-home-cat--featured .cst-home-cat__icon {
  background: rgba(255,77,79,.18);
  color: #fff;
}
.cst-home-cat--featured:hover .cst-home-cat__icon {
  background: var(--cst-brand);
}
.cst-home-cat--featured .cst-home-cat__meta {
  border-top-color: rgba(255,255,255,.12);
}
.cst-home-cat--featured .cst-home-cat__meta li { color: rgba(255,255,255,.62); }
.cst-home-cat__tag {
  position: absolute;
  top: 18px;
  left: 18px;
  background: var(--cst-brand);
  color: #fff;
  font: 700 0.7rem/1 var(--nav-font), sans-serif;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  padding: 7px 12px;
  border-radius: var(--cst-radius-pill, 999px);
  z-index: 2;
}
.cst-home-categories__cta {
  text-align: center;
  margin-top: 56px;
}

/* ── Noticias ────────────────────────────────────────────────────────────── */
.cst-home-news {
  background: #fff;
  padding: clamp(80px, 11vw, 120px) 0;
}
.cst-home-news__cta {
  text-align: center;
  margin-top: 56px;
}

/* ── Galería ─────────────────────────────────────────────────────────────── */
.cst-home-gallery {
  background: #fafafa;
  padding: clamp(80px, 11vw, 120px) 0;
}
.cst-home-gallery__cta {
  text-align: center;
  margin-top: 48px;
}

/* ── Sponsors strip ──────────────────────────────────────────────────────── */
.cst-home-sponsors {
  position: relative;
  background: #0e0e10;
  padding: clamp(72px, 10vw, 110px) 0;
  color: #fff;
  overflow: hidden;
  isolation: isolate;
}
.cst-home-sponsors::before {
  content: "";
  position: absolute;
  inset: 0;
  background: repeating-linear-gradient(-55deg, rgba(255,255,255,.022) 0 1px, transparent 1px 22px);
  z-index: -1;
}
.cst-home-sponsors__head {
  text-align: center;
  margin-bottom: 48px;
}
.cst-home-sponsors__title {
  font: 800 clamp(1.6rem, 3vw, 2.2rem)/1.2 var(--heading-font), sans-serif;
  color: #fff;
  margin: 0;
}
.cst-home-sponsors__grid {
  display: grid;
  grid-template-columns: repeat(6, 1fr);
  gap: 16px;
  margin-bottom: 48px;
}
.cst-home-sponsors__logo {
  background: rgba(255,255,255,.04);
  border: 1px solid rgba(255,255,255,.08);
  border-radius: var(--cst-radius-md, 14px);
  aspect-ratio: 16 / 10;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 8px;
  font: 800 1.6rem/1 var(--heading-font), sans-serif;
  color: rgba(255,255,255,.85);
  letter-spacing: 0.08em;
  transition: all .3s var(--cst-ease);
  cursor: default;
}
.cst-home-sponsors__logo span {
  font: 600 0.7rem/1 var(--nav-font), sans-serif;
  letter-spacing: 0.05em;
  color: rgba(255,255,255,.45);
  text-transform: none;
}
.cst-home-sponsors__logo:hover {
  background: rgba(255,77,79,.1);
  border-color: rgba(255,77,79,.4);
  color: #fff;
  transform: translateY(-3px);
}
.cst-home-sponsors__logo:hover span { color: rgba(255,255,255,.7); }
.cst-home-sponsors__cta { text-align: center; }

/* ── Join cards section ──────────────────────────────────────────────────── */
.cst-home-join {
  background: #fff;
  padding: clamp(80px, 11vw, 120px) 0;
}

/* ── CTA final ───────────────────────────────────────────────────────────── */
.cst-home-cta {
  position: relative;
  background: linear-gradient(135deg, var(--cst-brand) 0%, var(--cst-brand-dark) 100%);
  padding: clamp(90px, 12vw, 140px) 0;
  color: #fff;
  overflow: hidden;
  isolation: isolate;
}
.cst-home-cta::before {
  content: "";
  position: absolute;
  inset: 0;
  background:
    radial-gradient(ellipse at 30% 70%, rgba(255,255,255,.12), transparent 50%),
    repeating-linear-gradient(-55deg, rgba(255,255,255,.04) 0 1px, transparent 1px 18px);
  z-index: -1;
}
.cst-home-cta__deco {
  position: absolute;
  right: -40px;
  top: 50%;
  transform: translateY(-50%);
  font-size: clamp(20rem, 35vw, 32rem);
  color: #fff;
  opacity: 0.06;
  pointer-events: none;
  z-index: -1;
}
.cst-home-cta__inner {
  max-width: 820px;
  margin: 0 auto;
  text-align: center;
}
.cst-home-cta__eyebrow {
  font: 700 0.82rem/1 var(--nav-font), sans-serif;
  letter-spacing: 0.3em;
  text-transform: uppercase;
  color: rgba(255,255,255,.85);
  margin: 0 0 20px;
}
.cst-home-cta__heading {
  font: 800 clamp(2.2rem, 5vw, 3.8rem)/1.1 var(--heading-font), sans-serif;
  color: #fff;
  margin: 0 0 24px;
  letter-spacing: -0.02em;
}
.cst-home-cta__sub {
  font-size: clamp(1rem, 1.3vw, 1.15rem);
  line-height: 1.6;
  color: rgba(255,255,255,.88);
  margin: 0 0 44px;
}
.cst-home-cta__btns {
  display: flex;
  gap: 16px;
  justify-content: center;
  flex-wrap: wrap;
}
.cst-home-cta__btn-primary,
.cst-home-cta__btn-ghost {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  padding: 16px 32px;
  border-radius: var(--cst-radius-pill, 999px);
  font: 700 0.92rem/1 var(--nav-font), sans-serif;
  letter-spacing: 0.05em;
  text-transform: uppercase;
  text-decoration: none;
  transition: all .25s var(--cst-ease);
}
.cst-home-cta__btn-primary {
  background: #fff;
  color: var(--cst-brand);
}
.cst-home-cta__btn-primary:hover {
  background: #1a1a1d;
  color: #fff;
  transform: translateY(-3px);
  box-shadow: 0 16px 36px rgba(0,0,0,.3);
}
.cst-home-cta__btn-ghost {
  background: transparent;
  color: #fff;
  border: 2px solid rgba(255,255,255,.5);
}
.cst-home-cta__btn-ghost:hover {
  background: #fff;
  color: var(--cst-brand);
  border-color: #fff;
  transform: translateY(-3px);
  box-shadow: 0 16px 36px rgba(0,0,0,.25);
}

/* ── Responsive (cst-home) ───────────────────────────────────────────────── */
@media (max-width: 991.98px) {
  .cst-home-manifesto__pillars { grid-template-columns: 1fr; gap: 18px; }
  .cst-home-stats__grid { grid-template-columns: repeat(2, 1fr); }
  .cst-home-categories__grid { grid-template-columns: repeat(2, 1fr); }
  .cst-home-sponsors__grid { grid-template-columns: repeat(3, 1fr); }
}

@media (max-width: 575.98px) {
  .cst-home-manifesto { padding: 64px 0 72px; }
  .cst-home-manifesto__pillar { padding: 26px 22px; }
  .cst-home-stats__grid { grid-template-columns: 1fr; }
  .cst-home-stats__cell { padding: 28px 20px; }
  .cst-home-categories__grid { grid-template-columns: 1fr; }
  .cst-home-cat { padding: 28px 22px 26px; }
  .cst-home-cat__desc { min-height: auto; }
  .cst-home-sponsors__grid { grid-template-columns: repeat(2, 1fr); gap: 12px; }
  .cst-home-sponsors__logo { font-size: 1.3rem; }
  .cst-home-cta__btns { flex-direction: column; align-items: stretch; }
  .cst-home-cta__btn-primary,
  .cst-home-cta__btn-ghost { justify-content: center; }
}

/* ── cst-news-ed — Editorial news section (home) ─────────────────────────── */
.cst-news-ed {
  position: relative;
  background: #0e0e10;
  padding: clamp(80px, 11vw, 120px) 0;
  color: #fff;
  overflow: hidden;
  isolation: isolate;
}
.cst-news-ed::before {
  content: "";
  position: absolute;
  inset: 0;
  background:
    radial-gradient(ellipse at 15% 80%, rgba(255,77,79,.14), transparent 55%),
    repeating-linear-gradient(-55deg, rgba(255,255,255,.022) 0 1px, transparent 1px 22px);
  z-index: -1;
}

/* Head row with heading + "ver todo" link inline */
.cst-news-ed__head {
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  gap: 24px;
  margin-bottom: 56px;
}
.cst-news-ed__heading {
  font: 800 clamp(2rem, 4vw, 3rem)/1.1 var(--heading-font, "Mulish"), sans-serif;
  color: #fff;
  margin: 0;
  letter-spacing: -0.02em;
}
.cst-news-ed__heading em {
  font-style: normal;
  color: var(--cst-brand);
}
.cst-news-ed__all-link {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font: 700 0.82rem/1 var(--nav-font), sans-serif;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: rgba(255,255,255,.55);
  text-decoration: none;
  white-space: nowrap;
  padding-bottom: 6px;
  border-bottom: 1px solid rgba(255,255,255,.2);
  transition: all .25s var(--cst-ease);
  flex-shrink: 0;
}
.cst-news-ed__all-link:hover {
  color: #fff;
  border-bottom-color: var(--cst-brand);
  gap: 12px;
}

/* Body: feature + side list */
.cst-news-ed__body {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 0;
  align-items: stretch;
}

/* Featured story */
.cst-news-ed__feature {
  position: relative;
  padding: 0 56px 0 0;
  border-right: 1px solid rgba(255,255,255,.1);
  display: flex;
  flex-direction: column;
  overflow: hidden;
}
.cst-news-ed__feature-inner {
  display: flex;
  flex-direction: column;
  height: 100%;
}
.cst-news-ed__feature-score {
  position: absolute;
  right: -18px;
  bottom: -30px;
  font: 900 clamp(8rem, 18vw, 14rem)/0.85 var(--heading-font), sans-serif;
  color: #fff;
  opacity: 0.04;
  letter-spacing: -0.06em;
  pointer-events: none;
  z-index: 0;
}
.cst-news-ed__feature-top {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 16px;
}
.cst-news-ed__feature-sub {
  font: 600 0.82rem/1.3 var(--nav-font), sans-serif;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: rgba(255,255,255,.45);
  margin: 0 0 20px;
}
.cst-news-ed__feature-title {
  font: 800 clamp(1.7rem, 2.8vw, 2.4rem)/1.15 var(--heading-font), sans-serif;
  color: #fff;
  margin: 0 0 22px;
  letter-spacing: -0.01em;
  line-height: 1.15;
}
.cst-news-ed__feature-desc {
  font-size: 1rem;
  line-height: 1.65;
  color: rgba(255,255,255,.7);
  margin: 0 0 auto;
  padding-bottom: 32px;
  flex: 1;
}
.cst-news-ed__feature-foot {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  padding-top: 24px;
  border-top: 1px solid rgba(255,255,255,.1);
}

/* Category pills */
.cst-news-ed__cat {
  display: inline-flex;
  align-items: center;
  gap: 7px;
  font: 700 0.72rem/1 var(--nav-font), sans-serif;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  padding: 7px 14px;
  border-radius: var(--cst-radius-pill, 999px);
}
.cst-news-ed__cat--resultado {
  background: rgba(34,197,94,.15);
  color: #4ade80;
}
.cst-news-ed__cat--escuela {
  background: rgba(59,130,246,.15);
  color: #60a5fa;
}
.cst-news-ed__cat--comunidad {
  background: rgba(168,85,247,.15);
  color: #c084fc;
}

/* Date */
.cst-news-ed__date {
  font: 600 0.8rem/1 var(--nav-font), sans-serif;
  letter-spacing: 0.05em;
  color: rgba(255,255,255,.38);
}

/* Tags */
.cst-news-ed__tags {
  display: flex;
  align-items: center;
  gap: 0;
  flex-wrap: wrap;
}
.cst-news-ed__tags span {
  font-size: 0.8rem;
  color: rgba(255,255,255,.45);
  letter-spacing: 0.03em;
}
.cst-news-ed__tags span + span::before {
  content: "·";
  margin: 0 8px;
  color: rgba(255,255,255,.2);
}

/* Inline text link */
.cst-news-ed__link {
  display: inline-flex;
  align-items: center;
  gap: 7px;
  font: 700 0.82rem/1 var(--nav-font), sans-serif;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--cst-brand);
  text-decoration: none;
  white-space: nowrap;
  flex-shrink: 0;
  transition: gap .2s var(--cst-ease), color .2s;
}
.cst-news-ed__link:hover { gap: 11px; color: #ff7e7f; }

/* Secondary list */
.cst-news-ed__list {
  padding-left: 56px;
  display: flex;
  flex-direction: column;
}

/* Editorial item row (NOT a card — no box, no border-radius) */
.cst-news-ed__item {
  display: flex;
  gap: 0;
  flex: 1;
  padding: 36px 0;
  position: relative;
}
.cst-news-ed__item + .cst-news-ed__item {
  border-top: 1px solid rgba(255,255,255,.1);
}
.cst-news-ed__item-accent {
  width: 4px;
  flex-shrink: 0;
  border-radius: 4px;
  margin-right: 24px;
  align-self: stretch;
  min-height: 100%;
}
.cst-news-ed__item-accent--escuela  { background: linear-gradient(180deg, #3b82f6, rgba(59,130,246,.2)); }
.cst-news-ed__item-accent--comunidad { background: linear-gradient(180deg, #a855f7, rgba(168,85,247,.2)); }

.cst-news-ed__item-body {
  display: flex;
  flex-direction: column;
  gap: 10px;
  flex: 1;
}
.cst-news-ed__item-top {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
}
.cst-news-ed__item-title {
  font: 700 clamp(1.1rem, 1.6vw, 1.3rem)/1.25 var(--heading-font), sans-serif;
  color: #fff;
  margin: 0;
  letter-spacing: -0.01em;
}
.cst-news-ed__item-desc {
  font-size: 0.9rem;
  line-height: 1.55;
  color: rgba(255,255,255,.62);
  margin: 0;
  flex: 1;
}
.cst-news-ed__item-foot {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  margin-top: 6px;
}

/* Responsive */
@media (max-width: 991.98px) {
  .cst-news-ed__body {
    grid-template-columns: 1fr;
    gap: 0;
  }
  .cst-news-ed__feature {
    padding: 0 0 48px;
    border-right: none;
    border-bottom: 1px solid rgba(255,255,255,.1);
  }
  .cst-news-ed__list {
    padding-left: 0;
    padding-top: 0;
  }
  .cst-news-ed__feature-score { bottom: 20px; right: 0; }
}
@media (max-width: 575.98px) {
  .cst-news-ed__head { flex-direction: column; align-items: flex-start; gap: 12px; }
  .cst-news-ed__item-top { flex-wrap: wrap; gap: 8px; }
  .cst-news-ed__feature-foot { flex-direction: column; align-items: flex-start; }
  .cst-news-ed__item-foot { flex-direction: column; align-items: flex-start; }
}

/* ==========================================================================
   42. cst-ct — Contacto page (professional editorial redesign)
   ========================================================================== */

/* ── Hero ──────────────────────────────────────────────────────────────── */
.cst-ct-hero {
  position: relative;
  background: #0e0e10;
  padding: clamp(110px, 16vw, 180px) 0 clamp(80px, 11vw, 120px);
  color: #fff;
  overflow: hidden;
  isolation: isolate;
}
.cst-ct-hero::before {
  content: "";
  position: absolute;
  inset: 0;
  background:
    radial-gradient(ellipse at 80% 30%, rgba(255,77,79,.2), transparent 55%),
    repeating-linear-gradient(-55deg, rgba(255,255,255,.022) 0 1px, transparent 1px 22px);
  z-index: -1;
}
.cst-ct-hero::after {
  content: "CONTACTO";
  position: absolute;
  right: -1%;
  bottom: -10%;
  font: 900 clamp(8rem, 22vw, 20rem)/0.85 var(--heading-font,"Mulish"),sans-serif;
  color: #fff;
  opacity: 0.04;
  letter-spacing: -0.04em;
  pointer-events: none;
  z-index: -1;
}
.cst-ct-hero__inner { max-width: 820px; }
.cst-ct-hero__eyebrow {
  font: 700 0.82rem/1 var(--nav-font,"Raleway"),sans-serif;
  letter-spacing: 0.28em;
  text-transform: uppercase;
  color: #ff7e7f;
  margin: 0 0 20px;
  display: flex;
  align-items: center;
  gap: 12px;
}
.cst-ct-hero__eyebrow::before {
  content: "";
  width: 28px;
  height: 2px;
  background: var(--cst-brand);
  flex-shrink: 0;
}
.cst-ct-hero__title {
  font: 800 clamp(2.6rem, 6vw, 4.8rem)/1.05 var(--heading-font),sans-serif;
  color: #fff;
  margin: 0 0 24px;
  letter-spacing: -0.025em;
}
.cst-ct-hero__title em {
  font-style: normal;
  color: var(--cst-brand);
}
.cst-ct-hero__sub {
  font-size: clamp(1rem, 1.3vw, 1.15rem);
  line-height: 1.65;
  color: rgba(255,255,255,.75);
  margin: 0 0 36px;
  max-width: 580px;
}
.cst-ct-hero__chips {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}
.cst-ct-hero__chips span {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  background: rgba(255,255,255,.07);
  border: 1px solid rgba(255,255,255,.12);
  color: rgba(255,255,255,.8);
  font: 600 0.82rem/1 var(--nav-font),sans-serif;
  letter-spacing: 0.05em;
  padding: 10px 18px;
  border-radius: var(--cst-radius-pill,999px);
  backdrop-filter: blur(8px);
}
.cst-ct-hero__chips span i { color: var(--cst-brand); }

/* ── Main grid: panel + form ─────────────────────────────────────────── */
.cst-ct-main {
  padding: clamp(80px, 11vw, 120px) 0;
  background: #f2f3f5;
}
.cst-ct-main__grid {
  display: grid;
  grid-template-columns: 420px 1fr;
  align-items: start;
  gap: 0;
  background: #fff;
  border-radius: var(--cst-radius-lg,20px);
  overflow: hidden;
  box-shadow: 0 24px 64px rgba(0,0,0,.09);
}

/* Left dark panel */
.cst-ct-main__panel {
  position: relative;
  background: linear-gradient(160deg, #1a1a1d 0%, #0e0e10 100%);
  padding: 56px 48px 64px;
  color: #fff;
  overflow: hidden;
  isolation: isolate;
  min-height: 720px;
  display: flex;
  flex-direction: column;
}
.cst-ct-main__panel::before {
  content: "";
  position: absolute;
  inset: 0;
  background:
    radial-gradient(ellipse at 80% 10%, rgba(255,77,79,.2), transparent 55%),
    repeating-linear-gradient(-55deg, rgba(255,255,255,.025) 0 1px, transparent 1px 18px);
  z-index: -1;
}
.cst-ct-main__panel-over {
  font: 600 0.78rem/1 var(--nav-font),sans-serif;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: rgba(255,255,255,.45);
  margin: 0 0 20px;
}
.cst-ct-main__panel-title {
  font: 800 clamp(1.7rem, 2.4vw, 2.2rem)/1.15 var(--heading-font),sans-serif;
  color: #fff;
  margin: 0 0 16px;
  letter-spacing: -0.01em;
}
.cst-ct-main__panel-desc {
  font-size: 0.92rem;
  line-height: 1.6;
  color: rgba(255,255,255,.62);
  margin: 0 0 44px;
}

/* Info list */
.cst-ct-main__info {
  list-style: none;
  padding: 0;
  margin: 0 0 auto;
  display: flex;
  flex-direction: column;
  gap: 28px;
}
.cst-ct-main__info-item {
  display: flex;
  align-items: flex-start;
  gap: 18px;
}
.cst-ct-main__info-icon {
  width: 42px;
  height: 42px;
  border-radius: 10px;
  background: rgba(255,255,255,.09);
  color: var(--cst-brand);
  display: grid;
  place-items: center;
  font-size: 1.1rem;
  flex-shrink: 0;
  transition: all .3s var(--cst-ease);
}
.cst-ct-main__info-item:hover .cst-ct-main__info-icon {
  background: var(--cst-brand);
  color: #fff;
}
.cst-ct-main__info-icon--wa { color: #25d366; }
.cst-ct-main__info-item:hover .cst-ct-main__info-icon--wa {
  background: #25d366;
  color: #fff;
}
.cst-ct-main__info-label {
  display: block;
  font: 700 0.72rem/1 var(--nav-font),sans-serif;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: rgba(255,255,255,.4);
  margin-bottom: 5px;
}
.cst-ct-main__info-val {
  display: block;
  font-size: 0.9rem;
  line-height: 1.5;
  color: rgba(255,255,255,.85);
}
.cst-ct-main__info-link {
  text-decoration: none;
  color: rgba(255,255,255,.85);
  transition: color .2s;
}
.cst-ct-main__info-link:hover { color: #fff; }

/* Social row */
.cst-ct-main__socials {
  display: flex;
  gap: 12px;
  margin-top: 44px;
}
.cst-ct-main__social {
  width: 40px;
  height: 40px;
  border-radius: 10px;
  border: 1px solid rgba(255,255,255,.15);
  color: rgba(255,255,255,.65);
  display: grid;
  place-items: center;
  font-size: 1rem;
  text-decoration: none;
  transition: all .25s var(--cst-ease);
}
.cst-ct-main__social:hover {
  background: rgba(255,255,255,.1);
  border-color: rgba(255,255,255,.3);
  color: #fff;
}
.cst-ct-main__social--wa:hover { background: #25d366; border-color: #25d366; }

/* Big decorative text */
.cst-ct-main__panel-deco {
  position: absolute;
  bottom: -20px;
  left: -10px;
  font: 900 9rem/0.85 var(--heading-font),sans-serif;
  color: #fff;
  opacity: 0.04;
  letter-spacing: -0.06em;
  pointer-events: none;
  user-select: none;
  z-index: -1;
}

/* Right form wrap */
.cst-ct-main__form-wrap {
  padding: 56px 56px 56px 56px;
  display: flex;
  flex-direction: column;
}

/* Topic selector */
.cst-ct-form__topics { margin-bottom: 36px; }
.cst-ct-form__topics-label {
  font: 600 0.78rem/1 var(--nav-font),sans-serif;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--cst-ink-3,#888);
  margin-bottom: 14px;
}
.cst-ct-form__topics-row {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}
.cst-ct-form__topic {
  display: inline-flex;
  align-items: center;
  gap: 7px;
  padding: 10px 20px;
  border-radius: var(--cst-radius-pill,999px);
  border: 1.5px solid var(--cst-line,#e8e8e8);
  background: #fff;
  color: var(--cst-ink-2,#666);
  font: 600 0.82rem/1 var(--nav-font),sans-serif;
  letter-spacing: 0.04em;
  cursor: pointer;
  transition: all .22s var(--cst-ease);
}
.cst-ct-form__topic i { font-size: 0.9rem; }
.cst-ct-form__topic:hover {
  border-color: var(--cst-brand);
  color: var(--cst-brand);
  background: var(--cst-brand-tint,#fff5f5);
}
.cst-ct-form__topic.active {
  background: var(--cst-brand);
  border-color: var(--cst-brand);
  color: #fff;
  box-shadow: 0 6px 18px rgba(255,77,79,.3);
}

/* Form fields */
.cst-ct-form { flex: 1; }
.cst-ct-form__row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 20px;
  margin-bottom: 20px;
}
.cst-ct-form__field {
  position: relative;
  margin-bottom: 20px;
}
.cst-ct-form__field:last-of-type { margin-bottom: 0; }
.cst-ct-form__field input,
.cst-ct-form__field textarea {
  width: 100%;
  background: #f7f7f8;
  border: 1.5px solid transparent;
  border-bottom: 1.5px solid #d8d8d8;
  border-radius: 10px 10px 0 0;
  padding: 24px 18px 10px;
  font: 500 0.95rem/1 var(--default-font,"Roboto"),sans-serif;
  color: var(--cst-ink-1,#1a1a1a);
  outline: none;
  transition: all .25s var(--cst-ease);
  -webkit-appearance: none;
  appearance: none;
}
.cst-ct-form__field textarea {
  min-height: 140px;
  resize: vertical;
}
.cst-ct-form__field input:focus,
.cst-ct-form__field textarea:focus {
  background: #fff;
  border-color: transparent;
  border-bottom-color: var(--cst-brand);
  box-shadow: 0 4px 0 -2px rgba(255,77,79,.18);
}
.cst-ct-form__field label {
  position: absolute;
  top: 18px;
  left: 18px;
  font: 500 0.9rem/1 var(--default-font),sans-serif;
  color: #aaa;
  pointer-events: none;
  transition: all .22s var(--cst-ease);
  transform-origin: left top;
}
.cst-ct-form__field input:focus + label,
.cst-ct-form__field input:not(:placeholder-shown) + label,
.cst-ct-form__field textarea:focus + label,
.cst-ct-form__field textarea:not(:placeholder-shown) + label {
  transform: translateY(-10px) scale(0.78);
  color: var(--cst-brand);
  font-weight: 700;
  letter-spacing: 0.05em;
}
/* Animated underline border */
.cst-ct-form__field-border { display: none; }

/* Submit button */
.cst-ct-form__submit {
  margin-top: 32px;
  width: 100%;
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 18px 28px;
  background: var(--cst-brand);
  border: none;
  border-radius: var(--cst-radius-md,14px);
  color: #fff;
  font: 700 1rem/1 var(--nav-font),sans-serif;
  letter-spacing: 0.06em;
  cursor: pointer;
  overflow: hidden;
  position: relative;
  transition: all .28s var(--cst-ease);
}
.cst-ct-form__submit::before {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(90deg, transparent, rgba(255,255,255,.12), transparent);
  transform: translateX(-100%);
  transition: transform .5s var(--cst-ease);
}
.cst-ct-form__submit:hover {
  background: var(--cst-brand-dark,#c32d2d);
  transform: translateY(-2px);
  box-shadow: 0 16px 36px rgba(255,77,79,.35);
}
.cst-ct-form__submit:hover::before { transform: translateX(100%); }
.cst-ct-form__submit-text {
  display: flex;
  align-items: center;
  gap: 10px;
  font-size: 1.02rem;
}
.cst-ct-form__submit-arrow {
  width: 36px;
  height: 36px;
  border-radius: 8px;
  background: rgba(255,255,255,.18);
  display: grid;
  place-items: center;
  font-size: 1rem;
  transition: transform .25s var(--cst-ease);
  flex-shrink: 0;
}
.cst-ct-form__submit:hover .cst-ct-form__submit-arrow {
  transform: translateX(4px);
  background: rgba(255,255,255,.25);
}

/* PHP form feedback */
.cst-ct-form .loading,
.cst-ct-form .error-message,
.cst-ct-form .sent-message {
  display: none;
  padding: 14px 20px;
  border-radius: 10px;
  font-size: 0.9rem;
  margin: 16px 0 0;
}
.cst-ct-form .loading { background: #f0f0f0; color: #555; text-align: center; }
.cst-ct-form .error-message { background: #fff0f0; color: #c0392b; border: 1px solid #f5c6cb; }
.cst-ct-form .sent-message { background: #f0fdf4; color: #16a34a; border: 1px solid #bbf7d0; }

/* ── Canales editoriales ─────────────────────────────────────────────── */
.cst-ct-channels {
  position: relative;
  background: #0e0e10;
  padding: clamp(80px, 11vw, 120px) 0;
  color: #fff;
  overflow: hidden;
  isolation: isolate;
}
.cst-ct-channels::before {
  content: "";
  position: absolute;
  inset: 0;
  background:
    radial-gradient(ellipse at 70% 20%, rgba(255,77,79,.12), transparent 50%),
    repeating-linear-gradient(-55deg, rgba(255,255,255,.022) 0 1px, transparent 1px 22px);
  z-index: -1;
}
.cst-ct-channels__head {
  max-width: 680px;
  margin: 0 auto clamp(48px,7vw,72px);
  text-align: center;
}
.cst-ct-channels__title {
  font: 800 clamp(1.9rem, 3.5vw, 2.8rem)/1.1 var(--heading-font),sans-serif;
  color: #fff;
  margin: 0 0 14px;
  letter-spacing: -0.02em;
}
.cst-ct-channels__title em {
  font-style: normal;
  color: var(--cst-brand);
}
.cst-ct-channels__sub {
  font-size: 1rem;
  line-height: 1.6;
  color: rgba(255,255,255,.65);
  margin: 0;
}
.cst-ct-channels__list {
  display: flex;
  flex-direction: column;
  gap: 2px;
}

/* Individual channel editorial row */
.cst-ct-ch {
  display: grid;
  grid-template-columns: 4px 72px 1fr auto;
  align-items: center;
  gap: 0 28px;
  padding: 32px 40px 32px 0;
  border-radius: var(--cst-radius-md,14px);
  text-decoration: none;
  position: relative;
  transition: all .3s var(--cst-ease);
  isolation: isolate;
}
.cst-ct-ch::after {
  content: "";
  position: absolute;
  inset: 0;
  background: rgba(255,255,255,.03);
  border-radius: var(--cst-radius-md,14px);
  opacity: 0;
  transition: opacity .3s;
}
.cst-ct-ch:hover::after { opacity: 1; }
.cst-ct-ch:hover { transform: translateX(6px); }

.cst-ct-ch__accent {
  height: 100%;
  min-height: 80px;
  border-radius: 4px;
  align-self: stretch;
  flex-shrink: 0;
}
.cst-ct-ch__accent--wa    { background: linear-gradient(180deg, #25d366, rgba(37,211,102,.15)); }
.cst-ct-ch__accent--brand { background: linear-gradient(180deg, var(--cst-brand), rgba(255,77,79,.1)); }
.cst-ct-ch__accent--gold  { background: linear-gradient(180deg, #e2b94a, rgba(226,185,74,.1)); }

.cst-ct-ch__icon {
  width: 60px;
  height: 60px;
  border-radius: 14px;
  display: grid;
  place-items: center;
  font-size: 1.5rem;
  flex-shrink: 0;
  transition: all .3s var(--cst-ease);
}
.cst-ct-ch__icon--wa    { background: rgba(37,211,102,.12);  color: #25d366; }
.cst-ct-ch__icon--brand { background: rgba(255,77,79,.12);   color: var(--cst-brand); }
.cst-ct-ch__icon--gold  { background: rgba(226,185,74,.12);  color: #e2b94a; }
.cst-ct-ch:hover .cst-ct-ch__icon--wa    { background: #25d366;              color: #fff; }
.cst-ct-ch:hover .cst-ct-ch__icon--brand { background: var(--cst-brand);     color: #fff; }
.cst-ct-ch:hover .cst-ct-ch__icon--gold  { background: #e2b94a;              color: #fff; }

.cst-ct-ch__body { flex: 1; min-width: 0; }
.cst-ct-ch__name {
  font: 700 1.2rem/1.2 var(--heading-font),sans-serif;
  color: #fff;
  margin: 0 0 8px;
}
.cst-ct-ch__desc {
  font-size: 0.88rem;
  line-height: 1.5;
  color: rgba(255,255,255,.58);
  margin: 0;
}

.cst-ct-ch__action {
  text-align: right;
  flex-shrink: 0;
  display: flex;
  flex-direction: column;
  align-items: flex-end;
  gap: 10px;
}
.cst-ct-ch__handle {
  font: 600 0.82rem/1 var(--nav-font),sans-serif;
  letter-spacing: 0.04em;
  color: rgba(255,255,255,.45);
  word-break: break-all;
  text-align: right;
}
.cst-ct-ch__arr {
  width: 36px;
  height: 36px;
  border-radius: 9px;
  border: 1px solid rgba(255,255,255,.15);
  color: rgba(255,255,255,.5);
  display: grid;
  place-items: center;
  transition: all .25s var(--cst-ease);
}
.cst-ct-ch:hover .cst-ct-ch__arr {
  border-color: rgba(255,255,255,.5);
  color: #fff;
  transform: translateX(4px);
}

/* ── Mapa ────────────────────────────────────────────────────────────── */
.cst-ct-map {
  background: #fff;
  padding: clamp(80px, 11vw, 120px) 0;
}
.cst-ct-map__head {
  max-width: 680px;
  margin: 0 auto clamp(48px,7vw,64px);
  text-align: center;
}
.cst-ct-map__title {
  font: 800 clamp(1.9rem, 3.5vw, 2.8rem)/1.1 var(--heading-font),sans-serif;
  color: var(--cst-ink-1,#1a1a1a);
  margin: 0 0 14px;
  letter-spacing: -0.02em;
}
.cst-ct-map__title em { font-style: normal; color: var(--cst-brand); }
.cst-ct-map__sub {
  font-size: 1rem;
  line-height: 1.6;
  color: var(--cst-ink-2,#555);
  margin: 0;
}
.cst-ct-map__wrap {
  display: grid;
  grid-template-columns: 380px 1fr;
  border-radius: var(--cst-radius-lg,20px);
  overflow: hidden;
  box-shadow: 0 24px 64px rgba(0,0,0,.1);
}
.cst-ct-map__info {
  background: linear-gradient(160deg, #1a1a1d, #0e0e10);
  padding: 48px 40px;
  color: #fff;
  display: flex;
  flex-direction: column;
}
.cst-ct-map__info-title {
  font: 800 1.5rem/1.2 var(--heading-font),sans-serif;
  color: #fff;
  margin: 0 0 32px;
}
.cst-ct-map__info-list {
  list-style: none;
  padding: 0;
  margin: 0 0 auto;
  display: flex;
  flex-direction: column;
  gap: 24px;
}
.cst-ct-map__info-list li {
  display: flex;
  align-items: flex-start;
  gap: 16px;
}
.cst-ct-map__info-list i {
  font-size: 1rem;
  color: var(--cst-brand);
  margin-top: 3px;
  flex-shrink: 0;
}
.cst-ct-map__info-list strong {
  display: block;
  font: 700 0.72rem/1 var(--nav-font),sans-serif;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: rgba(255,255,255,.4);
  margin-bottom: 5px;
}
.cst-ct-map__info-list span {
  font-size: 0.9rem;
  color: rgba(255,255,255,.82);
  line-height: 1.5;
}
.cst-ct-map__cta {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  margin-top: 44px;
  padding: 15px 26px;
  background: var(--cst-brand);
  border-radius: var(--cst-radius-pill,999px);
  color: #fff;
  text-decoration: none;
  font: 700 0.88rem/1 var(--nav-font),sans-serif;
  letter-spacing: 0.06em;
  transition: all .25s var(--cst-ease);
  align-self: flex-start;
}
.cst-ct-map__cta:hover {
  background: var(--cst-brand-dark);
  transform: translateY(-2px);
  box-shadow: 0 10px 24px rgba(255,77,79,.3);
  color: #fff;
}
.cst-ct-map__embed { position: relative; min-height: 480px; }
.cst-ct-map__embed iframe {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  border: none;
  display: block;
}

/* ── Responsive ──────────────────────────────────────────────────────── */
@media (max-width: 1199.98px) {
  .cst-ct-main__grid { grid-template-columns: 360px 1fr; }
  .cst-ct-ch { grid-template-columns: 4px 60px 1fr auto; gap: 0 22px; }
}
@media (max-width: 991.98px) {
  .cst-ct-main__grid { grid-template-columns: 1fr; }
  .cst-ct-main__panel { min-height: auto; padding: 48px 36px 52px; }
  .cst-ct-main__panel-deco { font-size: 7rem; }
  .cst-ct-main__form-wrap { padding: 48px 36px; }
  .cst-ct-ch { grid-template-columns: 4px 56px 1fr; gap: 0 18px; padding-right: 0; }
  .cst-ct-ch__action { display: none; }
  .cst-ct-map__wrap { grid-template-columns: 1fr; }
  .cst-ct-map__embed { min-height: 320px; position: relative; }
}
@media (max-width: 575.98px) {
  .cst-ct-hero { padding-top: 130px; }
  .cst-ct-hero__chips { gap: 8px; }
  .cst-ct-hero__chips span { font-size: 0.78rem; padding: 9px 14px; }
  .cst-ct-main__panel { padding: 36px 24px 44px; }
  .cst-ct-main__form-wrap { padding: 36px 24px; }
  .cst-ct-form__row { grid-template-columns: 1fr; }
  .cst-ct-form__topics-row { gap: 6px; }
  .cst-ct-form__topic { font-size: 0.78rem; padding: 9px 15px; }
  .cst-ct-ch { grid-template-columns: 4px 48px 1fr; gap: 0 14px; padding: 24px 0; }
  .cst-ct-map__info { padding: 36px 24px; }
}

/* ==========================================================================
   43. cst-home-video — Sección showcase de videos del club
   ========================================================================== */
.cst-home-video {
  background: #0a0a0c;
  padding: clamp(80px, 10vw, 120px) 0;
  position: relative;
  overflow: hidden;
}
.cst-home-video::before {
  content: '';
  position: absolute;
  inset: 0;
  background: repeating-linear-gradient(
    -55deg,
    rgba(255,255,255,.018) 0px,
    rgba(255,255,255,.018) 1px,
    transparent 1px,
    transparent 28px
  );
  pointer-events: none;
}
.cst-home-video::after {
  content: 'VIDEO';
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%,-50%);
  font: 900 18vw/1 var(--heading-font,'Mulish'),sans-serif;
  color: #fff;
  opacity: 0.03;
  white-space: nowrap;
  pointer-events: none;
  letter-spacing: -.02em;
}

/* Header */
.cst-home-video__header {
  text-align: center;
  max-width: 640px;
  margin: 0 auto clamp(48px, 6vw, 72px);
}
.cst-home-video__eyebrow {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  font: 700 0.72rem/1 var(--nav-font,'Raleway'),sans-serif;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--cst-brand,#ff4d4f);
  margin-bottom: 16px;
}
.cst-home-video__eyebrow::before {
  content: '';
  display: inline-block;
  width: 28px;
  height: 3px;
  background: var(--cst-brand,#ff4d4f);
  border-radius: 2px;
}
.cst-home-video__title {
  font: 800 clamp(2rem,4vw,3rem)/1.1 var(--heading-font,'Mulish'),sans-serif;
  color: #fff;
  margin-bottom: 18px;
}
.cst-home-video__title em {
  font-style: normal;
  color: var(--cst-brand,#ff4d4f);
}
.cst-home-video__sub {
  font: 400 1rem/1.7 var(--default-font,'Roboto'),sans-serif;
  color: rgba(255,255,255,.55);
  margin: 0;
}

/* Grid */
.cst-home-video__grid {
  display: grid;
  grid-template-columns: 1.5fr 1fr;
  gap: 16px;
  align-items: stretch;
}

/* Video item */
.cst-home-video__item {
  position: relative;
  overflow: hidden;
  border-radius: 16px;
  background: #111;
  aspect-ratio: 16/10;
  cursor: pointer;
}
.cst-home-video__item--main {
  aspect-ratio: 16/9;
  grid-row: span 1;
}
.cst-home-video__vid {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  transition: transform .6s ease;
}
.cst-home-video__item:hover .cst-home-video__vid {
  transform: scale(1.04);
}

/* Overlay */
.cst-home-video__overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(
    to top,
    rgba(0,0,0,.78) 0%,
    rgba(0,0,0,.18) 45%,
    transparent 70%
  );
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  padding: 28px 28px 70px;
  pointer-events: none;
}
.cst-home-video__tag {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font: 700 0.68rem/1 var(--nav-font,'Raleway'),sans-serif;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: var(--cst-brand,#ff4d4f);
  margin-bottom: 8px;
}
.cst-home-video__tag i { font-size: .75rem; }
.cst-home-video__caption {
  font: 800 1.3rem/1.2 var(--heading-font,'Mulish'),sans-serif;
  color: #fff;
  margin: 0;
  text-shadow: 0 2px 12px rgba(0,0,0,.4);
}
.cst-home-video__item:not(.cst-home-video__item--main) .cst-home-video__caption {
  font-size: 1.05rem;
}

/* Sound toggle button */
.cst-home-video__sound {
  position: absolute;
  bottom: 20px;
  right: 20px;
  width: 40px;
  height: 40px;
  border-radius: 50%;
  background: rgba(255,255,255,.15);
  backdrop-filter: blur(8px);
  border: 1px solid rgba(255,255,255,.3);
  color: #fff;
  display: grid;
  place-items: center;
  font-size: 1rem;
  cursor: pointer;
  transition: background .22s ease, transform .22s ease;
  z-index: 5;
}
.cst-home-video__sound:hover {
  background: rgba(255,77,79,.7);
  border-color: var(--cst-brand,#ff4d4f);
  transform: scale(1.1);
}

/* Responsive */
@media (max-width: 767.98px) {
  .cst-home-video__grid {
    grid-template-columns: 1fr;
  }
  .cst-home-video__item,
  .cst-home-video__item--main {
    aspect-ratio: 16/9;
  }
  .cst-home-video__overlay { padding: 20px 20px 60px; }
  .cst-home-video__caption { font-size: 1.1rem; }
}
