/* =========================================================
   TOP-BAR SOCIAL — Botones de redes en colores oficiales
   ========================================================= */
.top-bar__inner {
    justify-content: space-between !important;
}
.top-bar__social {
    display: flex;
    align-items: center;
    gap: 6px;
}
.top-bar__social-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 28px;
    height: 28px;
    border-radius: 50%;
    color: #fff !important;
    transition: transform .25s var(--ease-soft, cubic-bezier(.22,.61,.36,1)),
                box-shadow .25s var(--ease-soft, cubic-bezier(.22,.61,.36,1)),
                filter .25s var(--ease-soft, cubic-bezier(.22,.61,.36,1));
    text-decoration: none;
}
.top-bar__social-btn svg {
    width: 14px;
    height: 14px;
    display: block;
}
.top-bar__social-btn:hover {
    transform: translateY(-1px) scale(1.08);
    filter: brightness(1.1);
}
.top-bar__social-btn--facebook {
    background: #1877F2;
    box-shadow: 0 2px 6px rgba(24, 119, 242, .35);
}
.top-bar__social-btn--facebook:hover {
    box-shadow: 0 4px 12px rgba(24, 119, 242, .55);
}
.top-bar__social-btn--instagram {
    background: linear-gradient(45deg, #f09433 0%, #e6683c 25%, #dc2743 50%, #cc2366 75%, #bc1888 100%);
    box-shadow: 0 2px 6px rgba(220, 39, 67, .35);
}
.top-bar__social-btn--instagram:hover {
    box-shadow: 0 4px 12px rgba(220, 39, 67, .55);
}
.top-bar__social-btn--youtube {
    background: #FF0000;
    box-shadow: 0 2px 6px rgba(255, 0, 0, .35);
}
.top-bar__social-btn--youtube:hover {
    background: #cc0000;
    box-shadow: 0 4px 12px rgba(255, 0, 0, .55);
}

/* Mobile: oculta sociales en muy chicos para no saturar */
@media (max-width: 480px) {
    .top-bar__social { gap: 4px; }
    .top-bar__social-btn { width: 26px; height: 26px; }
    .top-bar__social-btn svg { width: 12px; height: 12px; }
}

/* =========================================================
   HOMEPAGE V6 — Rediseño 2026-05-12 (agresivo, joven, cristiano serio)
   Sobreescribe a v5. Extiende style.css principal. NO REEMPLAZAR style.css.
   Pilares:
     · Editorial cinematográfico (Fraunces display + asimetría)
     · Glass + grano + grain-noise sutil para warm-modern
     · Gradientes mesh limpios (no rainbow, paleta cerrada: red/navy/gold/cream)
     · Hover real, micro-stagger, tipografía protagonista
     · Bento corregido (Becas legible, jerarquía clara, alturas balanceadas)
   ========================================================= */

:root {
    /* Paleta extendida (mantengo nombres v5 para retro-compat) */
    --gold:        #C8A24B;
    --gold-warm:   #E6BA5E;
    --gold-deep:   #9A7B2E;
    --cream:       #FAF6EE;
    --cream-deep:  #F0E9D8;
    --cream-warm:  #FFF8E8;
    --sage:        #6B8E72;
    --sage-deep:   #4A6B52;
    --sunrise:     #E89B5C;
    --dusk:        #2E1A47;
    --dusk-glow:   rgba(46, 26, 71, .35);
    --ink:         #0a1330;   /* navy aún más profundo para fondos contrastantes */
    --ink-2:       #11214a;
    --ember:       #ff5a4d;   /* solo para flairs, NO para áreas grandes */

    --shadow-soft: 0 12px 32px -8px rgba(15, 23, 42, .12);
    --shadow-bold: 0 32px 80px -20px rgba(12, 26, 58, .35);
    --shadow-deep: 0 60px 120px -32px rgba(10, 19, 48, .55);
    --shadow-red:  0 22px 60px -14px rgba(193, 45, 56, .45);

    --ease-soft:   cubic-bezier(.22, .61, .36, 1);
    --ease-bounce: cubic-bezier(.68, -.05, .27, 1.55);
    --ease-snap:   cubic-bezier(.16, 1, .3, 1);

    --font-display: 'Fraunces', 'Cormorant Garamond', Georgia, serif;

    /* Gradients reutilizables */
    --grad-hero:    radial-gradient(120% 80% at 0% 20%, rgba(193,45,56,.55) 0%, rgba(12,26,58,.0) 55%),
                    radial-gradient(80% 60% at 100% 100%, rgba(200,162,75,.35) 0%, rgba(12,26,58,.0) 50%),
                    linear-gradient(120deg, rgba(10,19,48,.94) 0%, rgba(17,33,74,.85) 45%, rgba(10,19,48,.4) 100%);
    --grad-stats:   radial-gradient(60% 60% at 20% 20%, rgba(200,162,75,.18), transparent 60%),
                    radial-gradient(50% 50% at 100% 100%, rgba(193,45,56,.22), transparent 65%),
                    linear-gradient(180deg, var(--ink) 0%, var(--ink-2) 100%);
    --grad-cta:     radial-gradient(50% 70% at 50% 110%, rgba(193,45,56,.55) 0%, transparent 60%),
                    radial-gradient(40% 50% at 90% 0%, rgba(200,162,75,.22) 0%, transparent 60%),
                    linear-gradient(180deg, #060d22 0%, #0b1838 100%);

    /* Grain SVG inline (data URI) — textura sutil cálida */
    --grain: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='160' height='160'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/><feColorMatrix values='0 0 0 0 0  0 0 0 0 0  0 0 0 0 0  0 0 0 0.45 0'/></filter><rect width='100%' height='100%' filter='url(%23n)' opacity='0.55'/></svg>");
}

/* =========================================================
   Reveal animations (refuerzo)
   ========================================================= */
[data-reveal] {
    opacity: 0;
    transform: translateY(28px);
    transition: opacity .9s var(--ease-snap), transform .9s var(--ease-snap);
}
[data-reveal].is-visible { opacity: 1; transform: none; }
@media (prefers-reduced-motion: reduce) {
    [data-reveal] { opacity: 1; transform: none; transition: none; }
}

/* Section variant cream (sin cambios, refinado) */
.section--cream {
    background: var(--cream);
    position: relative;
    overflow: hidden;
}
.section--cream::before {
    content: '';
    position: absolute; inset: 0;
    background-image:
        radial-gradient(circle at 15% 10%, rgba(200, 162, 75, .12), transparent 40%),
        radial-gradient(circle at 85% 90%, rgba(107, 142, 114, .08), transparent 40%);
    pointer-events: none;
    z-index: 0;
}
.section--cream .container { position: relative; z-index: 1; }

/* Section title — reforzado, más editorial */
.section-title { text-align: center; margin-bottom: 64px; }
.section-title h2 {
    font-family: var(--font-display);
    font-weight: 400;
    font-size: clamp(2.1rem, 4.6vw, 3.4rem);
    line-height: 1.05;
    letter-spacing: -0.018em;
    color: var(--dark);
}
.section-title h2 em,
.section-title h2 .ital {
    font-style: italic;
    font-weight: 300;
    background: linear-gradient(120deg, var(--accent) 0%, var(--gold-deep) 100%);
    -webkit-background-clip: text;
    background-clip: text;
    -webkit-text-fill-color: transparent;
}
.section-title__accent {
    display: inline-block;
    width: 56px; height: 3px;
    background: linear-gradient(90deg, var(--accent) 0%, var(--gold) 100%);
    border-radius: 2px;
    margin-bottom: 22px;
}

/* =========================================================
   HERO V6 — Editorial cinematográfico
   ========================================================= */
.hero-v5 {
    position: relative;
    min-height: 92vh;
    display: flex;
    align-items: center;
    overflow: hidden;
    color: #fff;
    isolation: isolate;
    background: var(--ink);
}
.hero-v5__bg {
    position: absolute;
    inset: 0;
    background-size: cover;
    background-position: center 35%;
    transform: scale(1.08);
    animation: kenburns 26s ease-out infinite alternate;
    z-index: 0;
    filter: saturate(.85) contrast(1.05);
}
@keyframes kenburns {
    0%   { transform: scale(1.06) translate(0, 0); }
    100% { transform: scale(1.14) translate(-2%, -1.5%); }
}
@media (prefers-reduced-motion: reduce) {
    .hero-v5__bg { animation: none; }
}
.hero-v5__overlay {
    position: absolute;
    inset: 0;
    background: var(--grad-hero);
    z-index: 1;
}
.hero-v5__noise {
    position: absolute;
    inset: 0;
    z-index: 2;
    opacity: .35;
    mix-blend-mode: overlay;
    background-image: var(--grain);
    pointer-events: none;
}

/* Esquinas decorativas (vintage editorial corner) */
.hero-v5::before,
.hero-v5::after {
    content: '';
    position: absolute;
    width: 60px; height: 60px;
    border: 1px solid rgba(255,255,255,.18);
    z-index: 3;
    pointer-events: none;
}
.hero-v5::before { top: 32px; left: 32px; border-right: 0; border-bottom: 0; }
.hero-v5::after  { bottom: 32px; right: 32px; border-left: 0; border-top: 0; }

.hero-v5__inner {
    position: relative;
    z-index: 3;
    padding: 96px 0 120px;
    width: 100%;
    display: grid;
    grid-template-columns: 1.15fr .85fr;
    gap: 56px;
    align-items: center;
}

.hero-v5__copy { max-width: 720px; }
.hero-v5__eyebrow {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    font-family: 'Inter', sans-serif;
    font-size: .72rem;
    font-weight: 600;
    letter-spacing: 0.28em;
    text-transform: uppercase;
    color: var(--gold-warm);
    margin-bottom: 32px;
    padding: 8px 18px 8px 14px;
    border: 1px solid rgba(230, 186, 94, .35);
    border-radius: 999px;
    background: rgba(230, 186, 94, .08);
    backdrop-filter: blur(6px);
}
.hero-v5__eyebrow::before {
    content: '';
    width: 6px; height: 6px;
    border-radius: 50%;
    background: var(--gold-warm);
    box-shadow: 0 0 0 0 rgba(230,186,94,.6);
    animation: pulse-gold 2.4s var(--ease-soft) infinite;
}
@keyframes pulse-gold {
    0%   { box-shadow: 0 0 0 0    rgba(230,186,94,.6); }
    70%  { box-shadow: 0 0 0 10px rgba(230,186,94,0); }
    100% { box-shadow: 0 0 0 0    rgba(230,186,94,0); }
}

.hero-v5__title {
    font-family: var(--font-display);
    font-weight: 400;
    font-style: normal;
    font-size: clamp(3rem, 7.2vw, 6.4rem);
    line-height: 0.98;
    letter-spacing: -0.025em;
    color: #fff;
    margin: 0 0 32px;
    text-shadow: 0 4px 40px rgba(0,0,0,.4);
}
.hero-v5__title-line { display: block; }
.hero-v5__title-line--accent {
    font-style: italic;
    font-weight: 300;
    background: linear-gradient(120deg, #fff 0%, var(--gold-warm) 40%, var(--sunrise) 100%);
    -webkit-background-clip: text;
    background-clip: text;
    -webkit-text-fill-color: transparent;
    padding-right: 0.2em;
}
.hero-v5__lead {
    font-family: 'Inter', sans-serif;
    font-size: clamp(1.02rem, 1.25vw, 1.18rem);
    line-height: 1.65;
    color: rgba(255, 255, 255, .82);
    max-width: 540px;
    margin: 0 0 40px;
    font-weight: 400;
}
.hero-v5__lead strong {
    color: #fff;
    font-weight: 600;
}
.hero-v5__ctas {
    display: flex;
    flex-wrap: wrap;
    gap: 14px;
    margin-bottom: 64px;
}
.hero-v5__cta-primary {
    box-shadow: var(--shadow-red);
    position: relative;
    overflow: hidden;
}
.hero-v5__cta-primary::after {
    content: '';
    position: absolute; inset: 0;
    background: linear-gradient(120deg, transparent 0%, rgba(255,255,255,.25) 50%, transparent 100%);
    transform: translateX(-100%);
    transition: transform .8s var(--ease-snap);
}
.hero-v5__cta-primary:hover::after { transform: translateX(100%); }

.btn--ghost-light {
    background: rgba(255, 255, 255, .06);
    border: 1.5px solid rgba(255, 255, 255, .28);
    color: #fff !important;
    backdrop-filter: blur(10px);
    -webkit-backdrop-filter: blur(10px);
}
.btn--ghost-light:hover {
    background: rgba(255, 255, 255, .14);
    border-color: rgba(255, 255, 255, .55);
    color: #fff !important;
}

/* Hero meta — números editoriales */
.hero-v5__meta {
    display: flex;
    flex-wrap: wrap;
    gap: 44px;
    list-style: none;
    padding: 0;
    margin: 0;
}
.hero-v5__meta li {
    display: flex;
    flex-direction: column;
    padding-left: 18px;
    border-left: 2px solid;
    border-image: linear-gradient(180deg, var(--gold-warm), transparent) 1;
}
.hero-v5__meta strong {
    font-family: var(--font-display);
    font-weight: 400;
    font-size: 1.55rem;
    color: #fff;
    line-height: 1.1;
    letter-spacing: -0.01em;
}
.hero-v5__meta span {
    font-family: 'Inter', sans-serif;
    font-size: .72rem;
    text-transform: uppercase;
    letter-spacing: 0.16em;
    color: rgba(255, 255, 255, .55);
    margin-top: 6px;
}

/* Versículo lateral (decorativo, derecho del hero, desktop) */
.hero-v5__verse {
    position: relative;
    z-index: 3;
    padding: 32px 28px;
    border-left: 2px solid rgba(230,186,94,.4);
    color: rgba(255,255,255,.85);
    align-self: center;
    max-width: 360px;
    margin-left: auto;
}
.hero-v5__verse-text {
    font-family: var(--font-display);
    font-style: italic;
    font-weight: 300;
    font-size: 1.3rem;
    line-height: 1.45;
    margin: 0 0 14px;
    color: #fff;
}
.hero-v5__verse-ref {
    font-family: 'Inter', sans-serif;
    font-size: .7rem;
    text-transform: uppercase;
    letter-spacing: 0.22em;
    color: var(--gold-warm);
    font-weight: 600;
}

.hero-v5__scroll {
    position: absolute;
    bottom: 32px;
    left: 50%;
    transform: translateX(-50%);
    z-index: 4;
    width: 24px;
    height: 40px;
    border: 1.5px solid rgba(255, 255, 255, .45);
    border-radius: 14px;
    display: flex;
    justify-content: center;
    padding-top: 7px;
    transition: border-color .3s, transform .3s;
}
.hero-v5__scroll:hover { border-color: var(--gold-warm); transform: translateX(-50%) translateY(-2px); }
.hero-v5__scroll span {
    display: block;
    width: 2px; height: 9px;
    background: rgba(255, 255, 255, .85);
    border-radius: 1px;
    animation: scroll-pulse 1.9s var(--ease-soft) infinite;
}
@keyframes scroll-pulse {
    0%, 20% { transform: translateY(0); opacity: 1; }
    100%    { transform: translateY(16px); opacity: 0; }
}

@media (max-width: 960px) {
    .hero-v5__inner { grid-template-columns: 1fr; gap: 32px; padding: 72px 0 96px; }
    .hero-v5__verse { display: none; }
    .hero-v5::before, .hero-v5::after { width: 36px; height: 36px; }
    .hero-v5::before { top: 16px; left: 16px; }
    .hero-v5::after  { bottom: 16px; right: 16px; }
}
@media (max-width: 768px) {
    .hero-v5 { min-height: 84vh; }
    .hero-v5__inner { padding: 56px 0 88px; }
    .hero-v5__title { font-size: clamp(2.4rem, 10vw, 3.8rem); }
    .hero-v5__meta { gap: 22px; }
    .hero-v5__meta strong { font-size: 1.25rem; }
    .hero-v5__overlay {
        background:
            radial-gradient(60% 50% at 100% 100%, rgba(200,162,75,.25), transparent 50%),
            linear-gradient(180deg, rgba(10,19,48,.78) 0%, rgba(10,19,48,.94) 60%, rgba(10,19,48,.98) 100%);
    }
    .hero-v5__scroll { display: none; }
}

/* =========================================================
   INFO BAR V6 — Glass card flotante con líneas doradas
   ========================================================= */
.info-bar-v5 {
    margin-top: -88px;
    position: relative;
    z-index: 10;
    padding: 0 0 40px;
}
.info-bar-v5__card {
    background: rgba(255,255,255,.96);
    backdrop-filter: blur(14px);
    -webkit-backdrop-filter: blur(14px);
    border-radius: 24px;
    box-shadow: var(--shadow-deep);
    padding: 36px 44px;
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 0;
    border: 1px solid rgba(255,255,255,.7);
    position: relative;
    overflow: hidden;
}
.info-bar-v5__card::before {
    content: '';
    position: absolute;
    top: 0; left: 0; right: 0;
    height: 3px;
    background: linear-gradient(90deg, var(--accent) 0%, var(--gold) 50%, var(--sage) 100%);
}
.info-bar-v5__cell {
    padding: 4px 28px;
    border-right: 1px solid rgba(15, 23, 42, .08);
    transition: transform .35s var(--ease-soft);
    border-radius: 12px;
    position: relative;
}
.info-bar-v5__cell:last-child { border-right: 0; }
.info-bar-v5__cell:first-child { padding-left: 8px; }
.info-bar-v5__cell:hover { transform: translateY(-3px); }
.info-bar-v5__cell:hover .info-bar-v5__value::after { width: 100%; }

.info-bar-v5__label {
    display: flex;
    align-items: center;
    gap: 8px;
    font-family: 'Inter', sans-serif;
    font-size: .68rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.18em;
    color: var(--accent);
    margin-bottom: 12px;
}
.info-bar-v5__dot {
    display: inline-block;
    width: 8px; height: 8px;
    border-radius: 50%;
    background: #2dc950;
    box-shadow: 0 0 0 0 rgba(45, 201, 80, .55);
    animation: pulse-dot 2.2s infinite;
}
@keyframes pulse-dot {
    0%   { box-shadow: 0 0 0 0    rgba(45, 201, 80, .55); }
    70%  { box-shadow: 0 0 0 12px rgba(45, 201, 80, 0); }
    100% { box-shadow: 0 0 0 0    rgba(45, 201, 80, 0); }
}
.info-bar-v5__value {
    display: inline-block;
    font-family: var(--font-display);
    font-weight: 500;
    font-size: 1.55rem;
    line-height: 1.15;
    color: var(--dark);
    margin-bottom: 6px;
    position: relative;
    letter-spacing: -0.012em;
}
.info-bar-v5__value::after {
    content: '';
    position: absolute;
    bottom: -3px; left: 0;
    width: 0; height: 2px;
    background: var(--accent);
    transition: width .5s var(--ease-snap);
}
.info-bar-v5__note {
    display: block;
    font-size: .82rem;
    color: var(--text-light);
    line-height: 1.5;
}

@media (max-width: 900px) {
    .info-bar-v5 { margin-top: -56px; padding: 0 0 32px; }
    .info-bar-v5__card { grid-template-columns: 1fr 1fr; padding: 28px; gap: 22px; }
    .info-bar-v5__cell { border-right: 0; border-bottom: 1px solid rgba(15, 23, 42, .08); padding: 4px 8px 18px; }
    .info-bar-v5__cell:nth-last-child(-n+2) { border-bottom: 0; padding-bottom: 0; }
}
@media (max-width: 520px) {
    .info-bar-v5__card { grid-template-columns: 1fr; padding: 22px; }
    .info-bar-v5__cell { border-right: 0; border-bottom: 1px solid rgba(15, 23, 42, .08); padding-bottom: 18px; }
    .info-bar-v5__cell:last-child { border-bottom: 0; padding-bottom: 0; }
}

/* =========================================================
   CAMINOS — Cards modernas con número + hover lift + accent strip
   ========================================================= */
.caminos-section {
    padding: clamp(72px, 9vw, 120px) 0;
    position: relative;
    background: #fff;
}
.caminos-section::before {
    content: '';
    position: absolute;
    top: 0; left: 0; right: 0;
    height: 1px;
    background: linear-gradient(90deg, transparent, var(--border-soft) 30%, var(--border-soft) 70%, transparent);
}
.caminos-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
    gap: 22px;
    counter-reset: camino;
}
.camino-card {
    position: relative;
    background: #fff;
    border: 1px solid var(--border-soft);
    border-radius: 18px;
    padding: 36px 28px 44px;
    overflow: hidden;
    transition: transform .45s var(--ease-snap), box-shadow .45s var(--ease-snap), border-color .3s;
    isolation: isolate;
    counter-increment: camino;
}
.camino-card::before {
    content: counter(camino, decimal-leading-zero);
    position: absolute;
    top: 24px; right: 24px;
    font-family: var(--font-display);
    font-size: 3.4rem;
    font-weight: 300;
    font-style: italic;
    line-height: 1;
    color: var(--border-soft);
    transition: color .35s, transform .45s var(--ease-snap);
    z-index: 0;
    pointer-events: none;
}
.camino-card:hover {
    transform: translateY(-8px);
    box-shadow: 0 30px 60px -20px rgba(15, 23, 42, .18);
    border-color: transparent;
}
.camino-card:hover::before { transform: translate(4px, -4px); }
.camino-card--red:hover::before  { color: rgba(193, 45, 56, .15); }
.camino-card--sage:hover::before { color: rgba(107, 142, 114, .2); }
.camino-card--gold:hover::before { color: rgba(200, 162, 75, .2); }
.camino-card--dusk:hover::before { color: rgba(46, 26, 71, .15); }

.camino-card__icon {
    width: 64px; height: 64px;
    border-radius: 16px;
    display: flex;
    align-items: center;
    justify-content: center;
    margin-bottom: 22px;
    transition: transform .45s var(--ease-bounce), box-shadow .35s;
    position: relative;
    z-index: 1;
}
.camino-card:hover .camino-card__icon {
    transform: scale(1.08) rotate(-4deg);
}
.camino-card__title {
    font-family: var(--font-display);
    font-size: 1.45rem;
    font-weight: 500;
    color: var(--dark);
    margin: 0 0 12px;
    line-height: 1.2;
    letter-spacing: -0.01em;
    position: relative;
    z-index: 1;
}
.camino-card__desc {
    font-size: .92rem;
    color: var(--text-light);
    line-height: 1.65;
    margin: 0;
    position: relative;
    z-index: 1;
}
.camino-card__line {
    position: absolute;
    bottom: 0; left: 0;
    width: 100%; height: 4px;
    transform: scaleX(0);
    transform-origin: left;
    transition: transform .6s var(--ease-snap);
}
.camino-card:hover .camino-card__line { transform: scaleX(1); }

.camino-card--red   .camino-card__icon { background: linear-gradient(135deg, rgba(193,45,56,.14), rgba(193,45,56,.05)); color: var(--accent); box-shadow: inset 0 0 0 1px rgba(193,45,56,.18); }
.camino-card--red   .camino-card__line { background: linear-gradient(90deg, var(--accent), var(--accent-bright)); }
.camino-card--sage  .camino-card__icon { background: linear-gradient(135deg, rgba(107,142,114,.18), rgba(107,142,114,.05)); color: var(--sage-deep); box-shadow: inset 0 0 0 1px rgba(107,142,114,.18); }
.camino-card--sage  .camino-card__line { background: linear-gradient(90deg, var(--sage), var(--sage-deep)); }
.camino-card--gold  .camino-card__icon { background: linear-gradient(135deg, rgba(200,162,75,.22), rgba(200,162,75,.05)); color: var(--gold-deep); box-shadow: inset 0 0 0 1px rgba(200,162,75,.2); }
.camino-card--gold  .camino-card__line { background: linear-gradient(90deg, var(--gold), var(--gold-warm)); }
.camino-card--dusk  .camino-card__icon { background: linear-gradient(135deg, rgba(46,26,71,.16), rgba(46,26,71,.04)); color: var(--dusk); box-shadow: inset 0 0 0 1px rgba(46,26,71,.18); }
.camino-card--dusk  .camino-card__line { background: linear-gradient(90deg, var(--dusk), #4a2d70); }

/* =========================================================
   VIDA BENTO V6 — Asimétrico real, foco fotográfico, Becas FIX
   Grid 12 col, alturas balanceadas, contenidos legibles.
   ========================================================= */
.vida-section {
    padding: clamp(72px, 9vw, 120px) 0;
    position: relative;
    z-index: 1;
}
.vida-bento {
    display: grid;
    grid-template-columns: repeat(12, 1fr);
    grid-auto-rows: 220px;
    gap: 18px;
}

.vida-tile {
    position: relative;
    border-radius: 22px;
    overflow: hidden;
    padding: 32px;
    background-size: cover;
    background-position: center;
    color: #fff;
    display: flex;
    flex-direction: column;
    justify-content: flex-end;
    transition: transform .55s var(--ease-snap), box-shadow .55s var(--ease-snap);
    isolation: isolate;
    will-change: transform;
    background-color: var(--ink);
}
.vida-tile:hover {
    transform: translateY(-6px);
    box-shadow: 0 40px 80px -24px rgba(10,19,48,.4);
}
.vida-tile:has(.vida-tile__shade)::before {
    /* Doble vignette para mejor legibilidad de texto blanco */
    content: '';
    position: absolute; inset: 0;
    background: linear-gradient(0deg, rgba(0,0,0,.4) 0%, transparent 60%);
    z-index: 1;
    pointer-events: none;
}
.vida-tile__shade {
    position: absolute;
    inset: 0;
    background: linear-gradient(0deg, rgba(10,19,48,.92) 0%, rgba(10,19,48,.45) 55%, rgba(10,19,48,.05) 100%);
    z-index: 1;
    transition: opacity .35s;
}
.vida-tile:hover .vida-tile__shade { opacity: .96; }
.vida-tile:hover { background-size: 110%; }

.vida-tile__body { position: relative; z-index: 3; }
.vida-tile__title {
    font-family: var(--font-display);
    font-weight: 500;
    font-size: 1.5rem;
    line-height: 1.18;
    color: #fff;
    margin: 0 0 10px;
    letter-spacing: -0.012em;
}
.vida-tile__desc {
    font-size: .92rem;
    line-height: 1.55;
    color: rgba(255,255,255,.88);
    margin: 0;
}
.vida-tile__highlight {
    display: inline-block;
    font-family: 'Inter', sans-serif;
    font-weight: 700;
    font-size: .72rem;
    line-height: 1;
    letter-spacing: 0.18em;
    text-transform: uppercase;
    color: #fff;
    margin-bottom: 16px;
    padding: 9px 16px;
    border-radius: 999px;
    background: rgba(255,255,255,.22);
    backdrop-filter: blur(6px);
    border: 1px solid rgba(255,255,255,.35);
    box-shadow: 0 4px 14px rgba(0,0,0,.18);
}

/* Tamaños — bento asimétrico equilibrado */
.vida-tile--lg { grid-column: span 7; grid-row: span 2; }
.vida-tile--md { grid-column: span 5; grid-row: span 1; }
.vida-tile--sm { grid-column: span 5; grid-row: span 1; }

.vida-tile--lg .vida-tile__title { font-size: 2rem; }
.vida-tile--lg .vida-tile__desc  { font-size: 1rem; max-width: 520px; }

/* Tone: navy default (sobre imagen) — ya cubierto arriba */

/* Tone: light — card blanca con foto opcional + acento lateral */
.vida-tile--light {
    background-image: none !important;
    background-color: #fff !important;
    color: var(--dark);
    border: 1px solid var(--border-soft);
    box-shadow: 0 8px 24px -12px rgba(15,23,42,.08);
}
.vida-tile--light::after {
    content: '';
    position: absolute;
    top: 0; left: 0;
    width: 5px; height: 100%;
    background: linear-gradient(180deg, var(--accent), var(--gold));
    z-index: 2;
}
.vida-tile--light .vida-tile__shade { display: none; }
.vida-tile--light .vida-tile__title { color: var(--dark); }
.vida-tile--light .vida-tile__desc  { color: var(--text-light); }
/* Si vida-tile--light tiene imagen inline, la suprimimos visualmente y solo dejamos un tinte cream */
.vida-tile--light[style*="background-image"] {
    background-image: linear-gradient(135deg, #fff 0%, var(--cream) 100%) !important;
}

/* Tone: sage gradient sólido */
.vida-tile--sage {
    background-image: linear-gradient(135deg, var(--sage) 0%, var(--sage-deep) 100%) !important;
    color: #fff;
    box-shadow: 0 12px 32px -12px rgba(74,107,82,.4);
}
.vida-tile--sage .vida-tile__shade { display: none; }
.vida-tile--sage::after {
    content: '';
    position: absolute;
    bottom: -60px; right: -40px;
    width: 220px; height: 220px;
    border-radius: 50%;
    background: radial-gradient(circle, rgba(255,255,255,.12) 0%, transparent 65%);
    pointer-events: none;
    z-index: 0;
}

/* Tone: red — FIX del bug de texto invisible
   Stack correcto:
     fondo  → background-image gradient (z=auto)
     glow   → ::after (z=0)
     pattern → ::before (z=0)
     body   → z=3 (siempre encima)
*/
.vida-tile--red {
    background-image:
        radial-gradient(120% 100% at 0% 0%, rgba(255,255,255,.18) 0%, transparent 50%),
        linear-gradient(140deg, #d8333e 0%, var(--accent) 50%, #9d1623 100%) !important;
    background-color: var(--accent) !important;
    color: #fff !important;
    box-shadow: var(--shadow-red);
    text-align: left;
}
.vida-tile--red .vida-tile__shade { display: none !important; }
.vida-tile--red::before {
    content: '';
    position: absolute;
    inset: 0;
    background-image:
        radial-gradient(circle at 1px 1px, rgba(255,255,255,.12) 1px, transparent 0);
    background-size: 24px 24px;
    opacity: .4;
    z-index: 0;
    pointer-events: none;
}
.vida-tile--red::after {
    content: '';
    position: absolute;
    top: -60px; right: -50px;
    width: 240px; height: 240px;
    background: radial-gradient(circle, rgba(255,255,255,.22) 0%, transparent 65%);
    pointer-events: none;
    z-index: 0;
}
.vida-tile--red .vida-tile__body {
    position: relative;
    z-index: 3;
}
.vida-tile--red .vida-tile__title,
.vida-tile--red .vida-tile__desc {
    color: #fff !important;
    opacity: 1 !important;
    text-shadow: 0 1px 2px rgba(0,0,0,.15);
}
.vida-tile--red .vida-tile__title { font-size: 1.55rem; }
.vida-tile--red .vida-tile__highlight {
    color: var(--accent) !important;
    background: #fff !important;
    border-color: #fff !important;
    box-shadow: 0 6px 18px rgba(0,0,0,.22);
    font-weight: 800;
}

@media (max-width: 960px) {
    .vida-bento { grid-auto-rows: 200px; }
    .vida-tile--lg { grid-column: span 12; grid-row: span 2; }
    .vida-tile--md { grid-column: span 6; }
    .vida-tile--sm { grid-column: span 6; }
    .vida-tile--lg .vida-tile__title { font-size: 1.7rem; }
}
@media (max-width: 560px) {
    .vida-bento { grid-auto-rows: 220px; }
    .vida-tile--md, .vida-tile--sm { grid-column: span 12; grid-row: span 1; }
    .vida-tile--lg { grid-row: span 2; }
}

/* =========================================================
   STATS V6 — Mesh gradient + números display gigantes
   ========================================================= */
.stats-section {
    background: var(--grad-stats);
    color: #fff;
    padding: clamp(64px, 8vw, 100px) 0;
    position: relative;
    overflow: hidden;
    isolation: isolate;
}
.stats-section::before {
    content: '';
    position: absolute;
    inset: 0;
    background-image: var(--grain);
    opacity: .25;
    mix-blend-mode: overlay;
    z-index: 0;
    pointer-events: none;
}
.stats-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
    gap: 32px;
    position: relative;
    z-index: 1;
}
.stat-item {
    text-align: center;
    padding: 16px 8px;
    border-right: 1px solid rgba(255,255,255,.08);
}
.stat-item:last-child { border-right: 0; }
.stat-item__num {
    font-family: var(--font-display);
    font-weight: 400;
    font-style: italic;
    font-size: clamp(3rem, 5.5vw, 4.4rem);
    line-height: 0.95;
    display: flex;
    justify-content: center;
    align-items: baseline;
    gap: 4px;
    margin-bottom: 14px;
    background: linear-gradient(180deg, #fff 0%, var(--gold-warm) 100%);
    -webkit-background-clip: text;
    background-clip: text;
    -webkit-text-fill-color: transparent;
    letter-spacing: -0.02em;
}
.stat-item__num em {
    font-style: italic;
    font-size: 0.45em;
    -webkit-text-fill-color: var(--gold-warm);
    margin-left: 4px;
    font-weight: 300;
}
.stat-item__label {
    font-family: 'Inter', sans-serif;
    font-size: .78rem;
    color: rgba(255, 255, 255, .72);
    line-height: 1.5;
    max-width: 200px;
    margin: 0 auto;
    text-transform: uppercase;
    letter-spacing: 0.12em;
    font-weight: 500;
}
@media (max-width: 600px) {
    .stat-item { border-right: 0; border-bottom: 1px solid rgba(255,255,255,.08); padding-bottom: 28px; }
    .stat-item:last-child { border-bottom: 0; }
}

/* =========================================================
   VOCES V6 — Cards editoriales con quote mark gigante + acento lateral
   ========================================================= */
.voces-section {
    padding: clamp(72px, 9vw, 120px) 0;
    background:
        radial-gradient(60% 50% at 100% 0%, rgba(193,45,56,.04), transparent 50%),
        radial-gradient(50% 50% at 0% 100%, rgba(200,162,75,.05), transparent 50%),
        linear-gradient(180deg, #fff 0%, var(--bg-alt) 100%);
}
.voces-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
    gap: 28px;
}
.voce-card {
    position: relative;
    background: #fff;
    border-radius: 22px;
    padding: 44px 34px 32px;
    box-shadow: 0 12px 32px -16px rgba(15, 23, 42, .15);
    border: 1px solid var(--border-soft);
    overflow: hidden;
    transition: transform .5s var(--ease-snap), box-shadow .5s var(--ease-snap), border-color .35s;
    isolation: isolate;
}
.voce-card::after {
    content: '';
    position: absolute;
    top: 0; left: 0; right: 0;
    height: 3px;
    background: currentColor;
    opacity: .9;
    z-index: 0;
}
.voce-card:hover {
    transform: translateY(-8px);
    box-shadow: 0 32px 70px -24px rgba(15, 23, 42, .22);
    border-color: transparent;
}
.voce-card__mark {
    position: absolute;
    top: 8px;
    left: 22px;
    font-family: var(--font-display);
    font-weight: 700;
    font-style: italic;
    font-size: 8rem;
    line-height: 1;
    color: currentColor;
    opacity: .12;
    pointer-events: none;
    z-index: 0;
}
.voce-card__quote {
    font-family: var(--font-display);
    font-style: italic;
    font-weight: 400;
    font-size: 1.14rem;
    line-height: 1.5;
    color: var(--dark);
    margin: 18px 0 30px;
    position: relative;
    z-index: 1;
    letter-spacing: -0.005em;
}
.voce-card__author {
    display: flex;
    align-items: center;
    gap: 14px;
    padding-top: 20px;
    border-top: 1px solid var(--border-soft);
    position: relative;
    z-index: 1;
}
.voce-card__avatar {
    width: 54px;
    height: 54px;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    font-family: 'Inter', sans-serif;
    font-weight: 800;
    font-size: 1rem;
    color: #fff;
    flex-shrink: 0;
    box-shadow: 0 6px 18px -6px currentColor;
}
.voce-card__meta strong {
    display: block;
    font-family: 'Inter', sans-serif;
    font-weight: 700;
    font-size: .98rem;
    color: var(--dark);
    margin-bottom: 2px;
}
.voce-card__meta span {
    display: block;
    font-size: .8rem;
    color: var(--text-light);
    line-height: 1.4;
}
.voce-card__origen { color: currentColor !important; font-weight: 600; opacity: .85; margin-top: 4px; }

.voce-card--red  { color: var(--accent); }
.voce-card--red  .voce-card__avatar { background: linear-gradient(135deg, var(--accent), var(--accent-hover)); }
.voce-card--gold { color: var(--gold-deep); }
.voce-card--gold .voce-card__avatar { background: linear-gradient(135deg, var(--gold-warm), var(--gold-deep)); }
.voce-card--sage { color: var(--sage-deep); }
.voce-card--sage .voce-card__avatar { background: linear-gradient(135deg, var(--sage), var(--sage-deep)); }
.voce-card--dusk { color: var(--dusk); }
.voce-card--dusk .voce-card__avatar { background: linear-gradient(135deg, #5a3a82, var(--dusk)); }

/* =========================================================
   VISITA CAMPUS V6
   ========================================================= */
.visita-section {
    padding: clamp(72px, 9vw, 120px) 0;
    background: var(--cream);
    position: relative;
    overflow: hidden;
}
.visita-section::before {
    content: '';
    position: absolute;
    top: 50%; left: -10%;
    width: 40%; height: 80%;
    background: radial-gradient(circle, rgba(200,162,75,.1) 0%, transparent 65%);
    transform: translateY(-50%);
    z-index: 0;
}
.visita-card {
    display: grid;
    grid-template-columns: 1.1fr 1fr;
    gap: 56px;
    background: #fff;
    border-radius: 26px;
    padding: 56px;
    box-shadow: var(--shadow-bold);
    border: 1px solid rgba(15, 23, 42, .04);
    align-items: center;
    position: relative;
    overflow: hidden;
    z-index: 1;
}
.visita-card::before {
    content: '';
    position: absolute;
    top: -60px; right: -60px;
    width: 240px; height: 240px;
    background: radial-gradient(circle, rgba(193,45,56,.12) 0%, transparent 65%);
    pointer-events: none;
}
.visita-card::after {
    content: '';
    position: absolute;
    bottom: -80px; left: -80px;
    width: 280px; height: 280px;
    background: radial-gradient(circle, rgba(200,162,75,.14) 0%, transparent 65%);
    pointer-events: none;
}
.visita-card__copy { position: relative; z-index: 1; }
.visita-card__eyebrow {
    display: inline-block;
    font-family: 'Inter', sans-serif;
    font-size: .72rem;
    font-weight: 700;
    letter-spacing: 0.24em;
    text-transform: uppercase;
    color: var(--accent);
    margin-bottom: 18px;
    padding: 6px 14px;
    background: rgba(193,45,56,.08);
    border-radius: 999px;
}
.visita-card__title {
    font-family: var(--font-display);
    font-weight: 400;
    font-size: clamp(1.9rem, 3.2vw, 2.6rem);
    line-height: 1.1;
    color: var(--dark);
    margin: 0 0 22px;
    letter-spacing: -0.02em;
}
.visita-card__lead {
    font-size: 1rem;
    color: var(--text);
    line-height: 1.7;
    margin: 0 0 26px;
}
.visita-card__bullets {
    list-style: none;
    padding: 0;
    margin: 0;
}
.visita-card__bullets li {
    position: relative;
    padding-left: 32px;
    margin-bottom: 12px;
    font-size: .95rem;
    color: var(--text);
    line-height: 1.5;
}
.visita-card__bullets li::before {
    content: '';
    position: absolute;
    left: 0; top: 10px;
    width: 20px; height: 2px;
    background: linear-gradient(90deg, var(--accent), var(--gold));
    border-radius: 1px;
}

.visita-form {
    background: linear-gradient(160deg, #fff 0%, var(--bg-alt) 100%);
    border-radius: 20px;
    padding: 36px 32px;
    border: 1px solid var(--border-soft);
    box-shadow: 0 8px 24px -16px rgba(15,23,42,.1);
    position: relative;
    z-index: 1;
}
.visita-form__title {
    font-family: var(--font-display);
    font-size: 1.4rem;
    font-weight: 500;
    color: var(--dark);
    margin: 0 0 24px;
    letter-spacing: -0.01em;
}
.visita-form__field { margin-bottom: 16px; }
.visita-form__field label {
    display: block;
    font-size: .78rem;
    font-weight: 600;
    color: var(--text);
    margin-bottom: 6px;
    letter-spacing: 0.04em;
    text-transform: uppercase;
}
.visita-form__field input {
    width: 100%;
    padding: 14px 16px;
    border: 1.5px solid var(--border);
    border-radius: 12px;
    font-family: 'Inter', sans-serif;
    font-size: .95rem;
    color: var(--dark);
    background: #fff;
    transition: border-color .25s, box-shadow .25s, transform .15s;
}
.visita-form__field input:focus {
    outline: none;
    border-color: var(--accent);
    box-shadow: 0 0 0 4px rgba(193, 45, 56, .12);
    transform: translateY(-1px);
}
.visita-form__submit {
    width: 100%;
    margin-top: 14px;
    box-shadow: var(--shadow-red);
}
.visita-form__note {
    font-size: .8rem;
    color: var(--text-light);
    text-align: center;
    margin: 16px 0 0;
}

@media (max-width: 900px) {
    .visita-card { grid-template-columns: 1fr; padding: 40px 32px; gap: 32px; border-radius: 22px; }
}
@media (max-width: 520px) {
    .visita-card { padding: 32px 24px; }
    .visita-form { padding: 28px 22px; }
}

/* =========================================================
   CTA FINAL V6 — Cinematic closer
   ========================================================= */
.cta-final {
    position: relative;
    padding: clamp(88px, 12vw, 160px) 0;
    color: #fff;
    background: var(--grad-cta);
    overflow: hidden;
    isolation: isolate;
}
.cta-final__bg {
    position: absolute;
    inset: 0;
    background-image: url('img/hero-2.jpg');
    background-size: cover;
    background-position: center;
    opacity: .14;
    z-index: 0;
    filter: grayscale(25%) contrast(1.1);
}
.cta-final__noise {
    position: absolute;
    inset: 0;
    background-image: var(--grain);
    opacity: .25;
    mix-blend-mode: overlay;
    z-index: 1;
    pointer-events: none;
}
.cta-final::before,
.cta-final::after {
    content: '';
    position: absolute;
    width: 80px; height: 80px;
    border: 1px solid rgba(255,255,255,.22);
    z-index: 1;
    pointer-events: none;
}
.cta-final::before { top: 40px; left: 40px; border-right: 0; border-bottom: 0; }
.cta-final::after  { bottom: 40px; right: 40px; border-left: 0; border-top: 0; }

.cta-final__inner {
    position: relative;
    z-index: 2;
    text-align: center;
}
.cta-final__eyebrow {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    font-family: 'Inter', sans-serif;
    font-size: .76rem;
    font-weight: 700;
    letter-spacing: 0.28em;
    text-transform: uppercase;
    color: var(--gold-warm);
    margin-bottom: 32px;
    padding: 9px 20px;
    border: 1px solid rgba(230, 186, 94, .4);
    border-radius: 999px;
    background: rgba(230, 186, 94, .06);
    backdrop-filter: blur(6px);
}
.cta-final__title {
    font-family: var(--font-display);
    font-weight: 300;
    font-style: italic;
    font-size: clamp(3rem, 7.2vw, 6rem);
    line-height: 1.04;
    color: #fff;
    margin: 0 auto 32px;
    max-width: 950px;
    letter-spacing: -0.025em;
}
.cta-final__title span {
    display: inline-block;
    opacity: 0;
    transform: translateY(24px);
    filter: blur(10px);
    transition: opacity .9s var(--ease-snap), transform .9s var(--ease-snap), filter .9s var(--ease-snap);
}
.cta-final__title.is-visible span { opacity: 1; transform: none; filter: blur(0); }
.cta-final__title.is-visible span:nth-child(1) { transition-delay: 0ms; }
.cta-final__title.is-visible span:nth-child(2) { transition-delay: 140ms; color: var(--gold-warm); }
.cta-final__title.is-visible span:nth-child(3) { transition-delay: 280ms; }
.cta-final__title.is-visible span:nth-child(4) { transition-delay: 420ms; font-style: normal; font-weight: 500; }

.cta-final__lead {
    font-size: 1.1rem;
    color: rgba(255, 255, 255, .82);
    max-width: 620px;
    margin: 0 auto 48px;
    line-height: 1.65;
}
.cta-final__actions { margin-bottom: 32px; }
.cta-final__btn {
    box-shadow: 0 28px 70px -16px rgba(193, 45, 56, .55);
    padding: 22px 60px !important;
    font-size: 1.02rem !important;
    position: relative;
    overflow: hidden;
}
.cta-final__btn::after {
    content: '';
    position: absolute; inset: 0;
    background: linear-gradient(120deg, transparent 0%, rgba(255,255,255,.25) 50%, transparent 100%);
    transform: translateX(-100%);
    transition: transform .8s var(--ease-snap);
}
.cta-final__btn:hover::after { transform: translateX(100%); }
.cta-final__micro {
    font-size: .92rem;
    color: rgba(255, 255, 255, .68);
    margin: 0;
}
.cta-final__micro a {
    color: var(--gold-warm);
    font-weight: 600;
    border-bottom: 1px solid rgba(230, 186, 94, .45);
}
.cta-final__micro a:hover { color: #fff; border-color: #fff; }

@media (max-width: 768px) {
    .cta-final::before, .cta-final::after { width: 40px; height: 40px; }
    .cta-final::before { top: 20px; left: 20px; }
    .cta-final::after  { bottom: 20px; right: 20px; }
}

/* =========================================================
   FIXES TRANSVERSALES
   ========================================================= */
/* Promo strip — más punch */
.promo-strip { background: linear-gradient(180deg, var(--bg-alt) 0%, #fff 100%); padding: 56px 0 64px; }
.promo-slide--navy {
    background: linear-gradient(135deg, var(--ink) 0%, var(--ink-2) 100%) !important;
    color: #fff;
}
.promo-slide--dark {
    background: linear-gradient(135deg, #1a1033 0%, var(--dusk) 100%) !important;
    color: #fff;
}
.promo-slide--gradient {
    background: linear-gradient(135deg, var(--accent) 0%, #7b1622 100%) !important;
    color: #fff;
}
.promo-slide__title {
    font-family: var(--font-display);
    font-weight: 400;
    letter-spacing: -0.015em;
}

/* Carrera-feature — más editorial */
.carrera-feature {
    border-radius: 24px;
    overflow: hidden;
    box-shadow: var(--shadow-bold);
    margin-bottom: 64px;
}
.carrera-feature__title {
    font-family: var(--font-display);
    font-weight: 500;
    letter-spacing: -0.018em;
}

/* Cards de diplomados — hover lift */
.card--diploma {
    transition: transform .45s var(--ease-snap), box-shadow .45s var(--ease-snap);
    border-radius: 18px;
    overflow: hidden;
}
.card--diploma:hover {
    transform: translateY(-6px);
    box-shadow: 0 30px 60px -24px rgba(15, 23, 42, .2);
}
.card__title {
    font-family: var(--font-display) !important;
    font-weight: 500 !important;
    letter-spacing: -0.012em;
}
.card__badge {
    background: rgba(255,255,255,.95) !important;
    color: var(--accent) !important;
    font-family: 'Inter', sans-serif;
    font-weight: 700;
    letter-spacing: 0.16em;
    text-transform: uppercase;
}

/* Diplomados header */
.diplomados-header { text-align: center; margin: 64px 0 36px; }
.diplomados-header h3 {
    font-family: var(--font-display);
    font-size: clamp(1.6rem, 3vw, 2.2rem);
    font-weight: 400;
    font-style: italic;
    color: var(--dark);
    margin: 12px 0 8px;
    letter-spacing: -0.01em;
}
.diplomados-header p {
    color: var(--text-light);
    max-width: 540px;
    margin: 0 auto;
}
.diplomados-header__rule {
    display: inline-block;
    width: 44px; height: 2px;
    background: linear-gradient(90deg, var(--accent), var(--gold));
    border-radius: 1px;
}

/* Mobile-first urgent fixes (mantenidos de v5) */
@media (max-width: 768px) {
    .section { padding: clamp(56px, 8vw, 88px) 0 !important; }
    .btn--sm { padding: 12px 22px !important; min-height: 44px; }
    .section-title { margin-bottom: 44px; }
}

/* Override del hero original cuando coexista con hero-v5 */
.is-home .hero { display: none; }

/* Scroll progress (refuerzo color) */
.scroll-progress {
    height: 3px;
    background: linear-gradient(90deg, var(--accent), var(--gold), var(--accent)) !important;
    background-size: 200% 100% !important;
    animation: progress-shimmer 3s linear infinite;
}
@keyframes progress-shimmer {
    0%   { background-position: 0% 50%; }
    100% { background-position: 200% 50%; }
}

/* =========================================================
   Campaign refresh 2026-06-06 — Universidad Internacional
   Assets: new campus renders + "Aqui construimos tu futuro"
   ========================================================= */
.hero-v5 {
    min-height: 88vh;
}
.hero-v5__bg {
    background-position: center 42%;
    filter: saturate(1.04) contrast(1.02);
}
.hero-v5__overlay {
    background:
        linear-gradient(90deg, rgba(5, 12, 31, .94) 0%, rgba(12, 26, 58, .78) 42%, rgba(12, 26, 58, .16) 100%),
        radial-gradient(70% 70% at 12% 24%, rgba(193, 45, 56, .46), transparent 58%),
        radial-gradient(50% 45% at 92% 16%, rgba(200, 162, 75, .18), transparent 60%);
}
.hero-v5__copy {
    max-width: 780px;
}
.hero-v5__title {
    max-width: 880px;
    letter-spacing: 0;
}
.hero-v5__lead {
    max-width: 610px;
}
.hero-v5__verse {
    background: rgba(5, 12, 31, .34);
    border: 1px solid rgba(255, 255, 255, .16);
    border-left: 3px solid var(--gold-warm);
    border-radius: 18px;
    backdrop-filter: blur(10px);
}

.campus-futuro {
    padding: clamp(64px, 8vw, 104px) 0;
    background:
        linear-gradient(180deg, #ffffff 0%, #f8fafc 100%);
    overflow: hidden;
}
.campus-futuro__grid {
    display: grid;
    grid-template-columns: minmax(0, 1.05fr) minmax(340px, .95fr);
    gap: clamp(28px, 5vw, 64px);
    align-items: center;
}
.campus-futuro__media {
    border-radius: 18px;
    overflow: hidden;
    box-shadow: 0 26px 70px -28px rgba(15, 23, 42, .32);
    border: 1px solid rgba(15, 23, 42, .08);
    background: #fff;
}
.campus-futuro__media img {
    width: 100%;
    aspect-ratio: 16 / 10;
    object-fit: cover;
}
.campus-futuro__copy {
    max-width: 560px;
}
.campus-futuro__eyebrow {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    font-family: 'Inter', sans-serif;
    font-size: .72rem;
    font-weight: 800;
    letter-spacing: .18em;
    text-transform: uppercase;
    color: var(--accent);
    margin-bottom: 18px;
}
.campus-futuro__eyebrow::before {
    content: '';
    width: 8px;
    height: 8px;
    border-radius: 50%;
    background: var(--accent);
}
.campus-futuro__title {
    font-family: var(--font-display);
    font-size: clamp(2rem, 4vw, 3.2rem);
    font-weight: 450;
    line-height: 1.05;
    letter-spacing: 0;
    margin-bottom: 20px;
}
.campus-futuro__lead {
    color: var(--text);
    font-size: 1.04rem;
    line-height: 1.75;
    margin-bottom: 24px;
}
.campus-futuro__points {
    display: grid;
    gap: 12px;
    margin: 0 0 28px;
}
.campus-futuro__point {
    padding: 16px 18px;
    border-left: 3px solid var(--accent);
    background: #fff;
    box-shadow: 0 12px 32px -24px rgba(15, 23, 42, .28);
}
.campus-futuro__point strong {
    display: block;
    color: var(--dark);
    font-weight: 800;
    margin-bottom: 3px;
}
.campus-futuro__point span {
    display: block;
    color: var(--text-light);
    font-size: .94rem;
    line-height: 1.55;
}

.vida-tile {
    background-position: center;
}
.vida-tile--lg {
    background-position: center 46%;
}
.vida-tile--sage {
    background-position: center 35%;
}
.vida-tile__shade {
    background:
        linear-gradient(180deg, rgba(5, 12, 31, .04) 0%, rgba(5, 12, 31, .7) 100%),
        linear-gradient(90deg, rgba(5, 12, 31, .52), rgba(5, 12, 31, .08));
}

.visita-card {
    background:
        linear-gradient(110deg, rgba(255, 255, 255, .97) 0%, rgba(255, 255, 255, .92) 52%, rgba(255, 255, 255, .72) 100%),
        url('/wp-content/themes/uninter/assets/img/uninter-campus-front.jpg') center / cover no-repeat;
}
.cta-final__bg {
    background:
        linear-gradient(180deg, rgba(6, 13, 34, .82) 0%, rgba(11, 24, 56, .94) 100%),
        url('/wp-content/themes/uninter/assets/img/uninter-campus-wide.jpg') center / cover no-repeat;
}
.cta-final__title {
    letter-spacing: 0;
}

@media (max-width: 980px) {
    .campus-futuro__grid {
        grid-template-columns: 1fr;
    }
    .campus-futuro__copy {
        max-width: 720px;
    }
}

@media (max-width: 768px) {
    .hero-v5 {
        min-height: auto;
    }
    .hero-v5__inner {
        padding-left: 20px;
        padding-right: 20px;
    }
    .hero-v5__bg {
        background-position: 58% center;
    }
    .hero-v5__title {
        font-size: clamp(2.15rem, 9.2vw, 2.65rem);
        line-height: 1.05;
    }
    .hero-v5__title-line {
        max-width: 100%;
    }
    .hero-v5__overlay {
        background:
            linear-gradient(180deg, rgba(5, 12, 31, .78) 0%, rgba(5, 12, 31, .96) 58%, rgba(5, 12, 31, .99) 100%),
            radial-gradient(100% 70% at 20% 20%, rgba(193, 45, 56, .34), transparent 62%);
    }
    .hero-v5__ctas {
        margin-bottom: 38px;
    }
    .hero-v5__ctas .btn {
        width: 100%;
        justify-content: center;
    }
    .hero-v5__meta {
        display: grid;
        grid-template-columns: 1fr;
        gap: 14px;
    }
    .campus-futuro {
        padding-top: 52px;
    }
    .campus-futuro__media img {
        aspect-ratio: 4 / 3;
    }
    .campus-futuro__point {
        padding: 14px 16px;
    }
}

@media (max-width: 520px) {
    .campus-futuro__media {
        border-radius: 12px;
    }
    .campus-futuro__title {
        font-size: clamp(1.8rem, 10vw, 2.35rem);
    }
}

/* Careers from the 2026 campaign deck */
.carreras-2026 {
    margin-bottom: clamp(52px, 7vw, 84px);
}
.carreras-2026__header {
    max-width: 760px;
    margin: 0 auto 34px;
    text-align: center;
}
.carreras-2026__kicker {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 7px 14px;
    border-radius: 999px;
    background: rgba(193, 45, 56, .09);
    color: var(--accent);
    font-family: 'Inter', sans-serif;
    font-size: .72rem;
    font-weight: 800;
    letter-spacing: .18em;
    text-transform: uppercase;
    margin-bottom: 16px;
}
.carreras-2026__header h3 {
    font-family: var(--font-display);
    font-size: clamp(1.9rem, 3.8vw, 2.8rem);
    font-weight: 450;
    line-height: 1.08;
    letter-spacing: 0;
    margin: 0 0 12px;
}
.carreras-2026__header p {
    color: var(--text-light);
    font-size: 1rem;
    line-height: 1.7;
    max-width: 620px;
    margin: 0 auto;
}
.carreras-2026__grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 22px;
}
.career-promo-card {
    background: #fff;
    border: 1px solid rgba(15, 23, 42, .09);
    border-radius: 18px;
    overflow: hidden;
    box-shadow: 0 18px 50px -34px rgba(15, 23, 42, .42);
    transition: transform .35s var(--ease-snap), box-shadow .35s var(--ease-snap), border-color .35s var(--ease-snap);
}
.career-promo-card:hover {
    transform: translateY(-5px);
    border-color: rgba(193, 45, 56, .22);
    box-shadow: 0 28px 68px -34px rgba(15, 23, 42, .5);
}
.career-promo-card__image {
    min-height: 260px;
    background-size: cover;
    background-position: center;
    position: relative;
}
.career-promo-card__image::after {
    content: '';
    position: absolute;
    inset: 0;
    background: linear-gradient(180deg, transparent 55%, rgba(8, 15, 34, .32) 100%);
}
.career-promo-card:nth-child(2) .career-promo-card__image {
    background-size: contain;
    background-repeat: no-repeat;
    background-color: #ef1018;
}
.career-promo-card__body {
    padding: 24px 24px 26px;
}
.career-promo-card__tag {
    display: inline-block;
    color: var(--accent);
    font-family: 'Inter', sans-serif;
    font-size: .68rem;
    font-weight: 800;
    letter-spacing: .16em;
    text-transform: uppercase;
    margin-bottom: 10px;
}
.career-promo-card h3 {
    font-family: var(--font-display);
    font-size: 1.55rem;
    font-weight: 520;
    line-height: 1.1;
    letter-spacing: 0;
    margin: 0 0 10px;
}
.career-promo-card p {
    color: var(--text);
    font-size: .94rem;
    line-height: 1.62;
    margin: 0 0 18px;
}
.career-promo-card__meta {
    list-style: none;
    padding: 0;
    margin: 0 0 20px;
    display: grid;
    gap: 8px;
}
.career-promo-card__meta li {
    position: relative;
    padding-left: 18px;
    color: var(--text-light);
    font-size: .84rem;
    font-weight: 650;
}
.career-promo-card__meta li::before {
    content: '';
    position: absolute;
    left: 0;
    top: .7em;
    width: 7px;
    height: 7px;
    border-radius: 50%;
    background: var(--accent);
}
.career-promo-card__cta {
    display: inline-flex;
    align-items: center;
    min-height: 44px;
    padding: 0 18px;
    border-radius: 999px;
    background: var(--accent);
    color: #fff !important;
    font-weight: 800;
    font-size: .9rem;
    box-shadow: 0 12px 26px -18px rgba(193, 45, 56, .7);
}
.career-promo-card__cta:hover {
    background: var(--accent-hover);
    color: #fff !important;
}

@media (max-width: 980px) {
    .carreras-2026__grid {
        grid-template-columns: 1fr;
        max-width: 620px;
        margin: 0 auto;
    }
    .career-promo-card__image {
        min-height: 340px;
    }
}

@media (max-width: 520px) {
    .career-promo-card {
        border-radius: 14px;
    }
    .career-promo-card__image {
        min-height: 270px;
    }
    .career-promo-card__body {
        padding: 22px 20px 24px;
    }
}

/* Clean academic presentation for the now-prominent careers block */
.carreras-home {
    padding-top: clamp(58px, 7vw, 86px) !important;
}
.carreras-home .section-title {
    margin-bottom: 34px;
}
.carreras-home .section-title h2 {
    font-size: clamp(2rem, 4vw, 3rem);
}
.carreras-2026 {
    margin-bottom: clamp(42px, 6vw, 68px);
}
.carreras-2026__header {
    max-width: 680px;
    margin-bottom: 28px;
}
.carreras-2026__header h3 {
    display: none;
}
.carreras-2026__header p {
    font-size: .98rem;
}
.carreras-2026__grid {
    gap: 18px;
}
.career-promo-card {
    position: relative;
    border-radius: 12px;
    border: 1px solid rgba(15, 23, 42, .1);
    box-shadow: 0 16px 38px -32px rgba(15, 23, 42, .45);
    overflow: hidden;
}
.career-promo-card::before {
    content: '';
    position: absolute;
    inset: 0 0 auto;
    height: 4px;
    background: linear-gradient(90deg, var(--accent), var(--gold));
}
.career-promo-card__body {
    min-height: 330px;
    padding: 28px 26px 26px;
    display: flex;
    flex-direction: column;
}
.career-promo-card__number {
    font-family: var(--font-display);
    font-size: 3.4rem;
    line-height: .9;
    color: rgba(193, 45, 56, .12);
    margin-bottom: 10px;
}
.career-promo-card__tag {
    margin-bottom: 8px;
}
.career-promo-card h3 {
    font-size: 1.6rem;
    margin-bottom: 6px;
}
.career-promo-card__area {
    display: block;
    color: var(--accent);
    font-size: .88rem;
    margin-bottom: 14px;
}
.career-promo-card p {
    margin-bottom: 18px;
}
.career-promo-card__meta {
    margin-top: auto;
}
.career-promo-card__cta {
    width: fit-content;
}

@media (max-width: 980px) {
    .career-promo-card__body {
        min-height: 0;
    }
}
