/**
 * Estilos - Christian Rolon Intendente Municipal
 */
html { scroll-behavior: smooth; }

.reveal { opacity: 0; transform: translateY(20px); transition: opacity 0.6s ease, transform 0.6s ease; }
.reveal.visible { opacity: 1; transform: translateY(0); }
.delay-1 { transition-delay: 0.1s; }
.delay-2 { transition-delay: 0.2s; }
.delay-3 { transition-delay: 0.3s; }

.card-hover { transition: transform 0.3s ease, box-shadow 0.3s ease; }
.card-hover:hover { transform: translateY(-4px); box-shadow: 0 20px 25px -5px rgb(0 0 0 / 0.1), 0 8px 10px -6px rgb(0 0 0 / 0.1); }

/* Header logo */
.header-logo__imgs { align-items: center; gap: 0; }
.header-logo__icon { height: 3.5rem; width: auto; object-fit: contain; display: block; }
.header-logo__divider { width: 2px; height: 3.5rem; background-color: #E72929; flex-shrink: 0; margin: 0 0.5rem; }
.header-logo__cr { height: 3.5rem; width: auto; object-fit: contain; display: block; }

/* Hero inicio: fondo ayo.jpg difuminado + filtro rojo */
.hero-home { position: relative; background-color: #991b1b; min-height: 100vh; display: flex; flex-direction: column; overflow: hidden; }
.hero-home::before {
    content: '';
    position: absolute;
    inset: -40px;
    background-image: url('../images/hero/ayo.jpg');
    background-size: cover;
    background-position: center;
    filter: blur(8px);
    z-index: 0;
}
.hero-home::after {
    content: '';
    position: absolute;
    inset: 0;
    background-color: rgba(153, 27, 27, 0.72);
    z-index: 1;
}
.hero-home__inner { position: relative; z-index: 2; width: 100%; max-width: 1280px; margin-left: auto; margin-right: auto; padding: 1.5rem 1rem 2rem; flex: 1; display: flex; flex-direction: column; min-height: 0; }
@media (max-width: 639px) {
    .hero-home { min-height: auto; padding-bottom: 2rem; }
}
@media (min-width: 768px) { .hero-home__inner { padding: 2rem 1.5rem 2rem; } }
@media (min-width: 1024px) { .hero-home__inner { padding: 1.5rem 2rem 1.5rem; } }
.hero-home__grid { display: grid; grid-template-columns: 1fr; gap: 1.5rem; align-items: center; flex: 1; min-height: 0; }
@media (min-width: 1024px) {
    .hero-home__grid { grid-template-columns: 42% 58%; gap: 2.5rem; align-items: center; min-height: 0; height: auto; }
}
.hero-home__content { display: flex; flex-direction: column; justify-content: center; order: 1; }
.hero-home__media { order: 2; }
.hero-home__content-inner { max-width: 30rem; }
.hero-home__badge { display: inline-block; padding: 0.4rem 1rem; background-color: #eab308; color: #111827; font-size: 0.75rem; font-weight: 700; letter-spacing: 0.06em; text-transform: uppercase; border-radius: 0.25rem; margin-bottom: 1rem; }
.hero-home__title { font-size: clamp(2.25rem, 5vw, 3.75rem); font-weight: 700; color: #fff; line-height: 1.08; margin: 0 0 0.35rem; letter-spacing: -0.02em; }
.hero-home__subtitle { font-size: 1rem; font-weight: 600; color: rgba(255,255,255,0.9); margin: 0 0 1rem; }
.hero-home__lead { font-size: 1.0625rem; line-height: 1.6; color: rgba(255,255,255,0.95); margin: 0 0 1.5rem; max-width: 26rem; }
@media (min-width: 768px) { .hero-home__lead { font-size: 1.125rem; margin-bottom: 1.75rem; } }
.hero-home__actions { display: flex; flex-wrap: wrap; gap: 0.75rem 1rem; }
.hero-home__btn { display: inline-flex; align-items: center; gap: 0.5rem; padding: 0.875rem 1.75rem; font-weight: 600; font-size: 1rem; border-radius: 0.5rem; transition: background-color 0.2s, color 0.2s, transform 0.2s; }
.hero-home__btn-icon { width: 1.25rem; height: 1.25rem; }
.hero-home__btn:hover { transform: translateY(-2px); }
.hero-home__btn--primary { background-color: #eab308; color: #111827; }
.hero-home__btn--primary:hover { background-color: #ca9a04; }
.hero-home__btn--outline { border: 2px solid #fff; color: #fff; background: rgba(255,255,255,0.08); }
.hero-home__btn--outline:hover { background: #fff; color: #991b1b; }

.hero-home__media { position: relative; display: none; min-height: 0; }
@media (min-width: 640px) { .hero-home__media { display: flex; min-height: 38vh; max-height: 45vh; align-items: flex-end; justify-content: center; } }
@media (min-width: 1024px) {
    .hero-home__media { min-height: 70vh; max-height: 85vh; align-items: flex-end; justify-content: flex-end; }
}
.hero-home__media .hero-home__image { width: 100%; height: 100%; min-height: 50vh; object-fit: contain; object-position: bottom center; filter: drop-shadow(0 28px 56px rgba(0,0,0,0.3)); }
@media (min-width: 1024px) {
    .hero-home__media .hero-home__image { position: absolute; inset: 0; width: 100%; height: 100%; min-height: 0; object-fit: contain; object-position: bottom right; }
}
.hero-home__media .hero-placeholder { position: absolute; inset: 0; display: flex; align-items: center; justify-content: center; font-weight: 600; font-size: 0.875rem; color: rgba(255,255,255,0.8); }

.stats-band { background: linear-gradient(90deg, #7f1d1d 0%, #991b1b 50%, #7f1d1d 100%); }

.wave-divider { line-height: 0; display: block; width: 100%; overflow: hidden; margin-bottom: -1px; }
.wave-divider svg { width: 100%; height: 80px; display: block; vertical-align: middle; }
@media (min-width: 768px) { .wave-divider svg { height: 100px; } }

.container { max-width: 1280px; }

/* Voz y Voto (podcast/videos) */
.podcast-hero { background: linear-gradient(180deg, #7f1d1d 0%, #991b1b 35%, #b91c1c 100%); background-image: linear-gradient(90deg, rgba(255,255,255,0.03) 1px, transparent 1px), linear-gradient(180deg, #7f1d1d 0%, #991b1b 35%, #b91c1c 100%); background-size: 60px 100%, 100% 100%; }
.podcast-hero__accent { position: absolute; top: 2rem; left: 50%; transform: translateX(-50%); width: 12px; height: 12px; border-radius: 50%; background: #eab308; }
.podcast-hero__mic-wrap { width: 120px; height: 120px; margin: 0 auto 1.5rem; border-radius: 50%; background: rgba(255,255,255,0.15); display: flex; align-items: center; justify-content: center; }
.podcast-hero__mic { width: 56px; height: 56px; color: #fff; }
.podcast-featured__art { position: relative; background: linear-gradient(180deg, #fecaca 0%, #f87171 50%, #dc2626 100%); }
.podcast-featured__art::before { content: ''; position: absolute; inset: 0; background: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 100 100' fill='none' stroke='rgba(255,255,255,0.3)' stroke-width='1'%3E%3Cpath d='M20 50 Q30 30 50 50 Q70 70 80 50'/%3E%3C/svg%3E") center/80% no-repeat; pointer-events: none; }
.podcast-platform:hover, .voz-platform:hover { color: #fff !important; }
.podcast-platform:hover svg, .voz-platform:hover svg, .voz-platform:hover .voz-platform-icon { color: inherit; }
.line-clamp-2 { display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden; }

:focus-visible { outline: 2px solid #b91c1c; outline-offset: 2px; }
