/**
 * AEPSO 2026 - Core Styles
 * Estilos base compartidos por todos los micrositios
 * 
 * Archivo: /assets/css/core.css
 * 
 * Los colores específicos de cada patología están en /themes/[slug].css
 * y se aplican via Variables CSS
 */

/* ==================== RESET & BASE ==================== */
* { margin: 0; padding: 0; box-sizing: border-box; }
html { scroll-behavior: smooth; }

[id] {
    scroll-margin-top: 5rem;
}
body { 
    font-family: var(--font-body, 'DM Sans'), system-ui, sans-serif; 
    overflow-x: hidden;
    -webkit-font-smoothing: antialiased;
}
.font-display { font-family: var(--font-display, 'Playfair Display'), Georgia, serif; }

/* ==================== VARIABLES CSS DINÁMICAS ==================== */
/* Estos valores se sobreescriben por patología */
:root {
    --color-primary: #0f2942;
    --color-primary-light: #1a3a5c;
    --color-primary-dark: #0a1f30;
    --color-accent: #f59e0b;
    --color-accent-hover: #d97706;
    --hero-gradient-start: #0a1f30;
    --hero-gradient-end: #1a3a5c;
}

/* ==================== HERO GRADIENT DINÁMICO ==================== */
.hero-gradient {
    background: linear-gradient(135deg, var(--hero-gradient-start) 0%, var(--color-primary) 50%, var(--color-primary-light) 100%);
}

.media-overlay {
    background: linear-gradient(135deg, 
        rgba(var(--color-primary-rgb, 15, 41, 66), 0.92) 0%, 
        rgba(var(--color-primary-rgb, 26, 58, 92), 0.8) 50%, 
        rgba(var(--color-primary-rgb, 42, 90, 130), 0.7) 100%
    );
}

/* ==================== PARTÍCULAS ANIMADAS ==================== */
.particles {
    position: absolute;
    inset: 0;
    overflow: hidden;
    z-index: 1;
}

.particle {
    position: absolute;
    background: rgba(255, 255, 255, 0.1);
    border-radius: 50%;
    animation: float-particle linear infinite;
}

@keyframes float-particle {
    0% { transform: translateY(100vh) rotate(0deg); opacity: 0; }
    10% { opacity: 1; }
    90% { opacity: 1; }
    100% { transform: translateY(-100px) rotate(720deg); opacity: 0; }
}

/* ==================== NAVEGACIÓN ==================== */
.hover\:text-primary:hover { color: var(--color-primary, #0f2942); }

/* ==================== MENÚ MOBILE ==================== */
.mobile-sidebar {
    position: fixed; 
    top: 0; 
    left: 0;
    width: 100%; 
    max-width: 320px; 
    height: 100vh;
    background: white; 
    z-index: 200;
    transform: translateX(-100%);
    transition: transform 0.3s ease;
    overflow-y: auto;
    box-shadow: 4px 0 20px rgba(0,0,0,0.1);
}

.mobile-sidebar.open { transform: translateX(0); }

.mobile-overlay {
    position: fixed; 
    inset: 0;
    background: rgba(0,0,0,0.5); 
    z-index: 199;
    opacity: 0; 
    visibility: hidden;
    transition: all 0.3s ease;
}

.mobile-overlay.open { opacity: 1; visibility: visible; }

.mobile-submenu { 
    max-height: 0; 
    overflow: hidden; 
    transition: max-height 0.3s ease; 
}

.mobile-submenu.open { max-height: 500px; }

/* ==================== DROPDOWN DESKTOP ==================== */
.dropdown { position: relative; }

.dropdown-menu {
    position: absolute; 
    top: calc(100% + 4px); 
    left: -8px;
    min-width: 220px; 
    background: white;
    border-radius: 10px;
    box-shadow: 0 4px 6px -1px rgba(0,0,0,0.07), 
                0 10px 20px -2px rgba(0,0,0,0.06),
                0 0 0 1px rgba(0,0,0,0.03);
    opacity: 0; 
    visibility: hidden;
    transform: translateY(4px);
    transition: opacity 0.18s ease, visibility 0.18s ease, transform 0.18s ease;
    z-index: 100; 
    padding: 4px;
}

.dropdown:hover .dropdown-menu { 
    opacity: 1; 
    visibility: visible; 
    transform: translateY(0); 
}

.dropdown-menu a { 
    display: block; 
    padding: 8px 12px; 
    color: #4a5568; 
    font-size: 13px;
    font-weight: 450;
    line-height: 1.3;
    border-radius: 6px;
    transition: all 0.15s ease;
    text-decoration: none;
}

.dropdown-menu a:hover { 
    background: var(--color-primary, #0f2942);
    color: white;
    padding-left: 14px;
}

.dropdown-menu a + a {
    margin-top: 1px;
    padding-top: 9px;
    border-top: 1px solid rgba(0,0,0,0.05);
}

/* ==================== HERO SLIDER ==================== */
.hero-slide {
    position: absolute; 
    inset: 0;
    opacity: 0; 
    visibility: hidden;
    transition: opacity 1s ease, visibility 1s ease;
}

.hero-slide.active { opacity: 1; visibility: visible; }

.hero-slide .slide-content {
    opacity: 0; 
    transform: translateY(30px);
    transition: opacity 0.8s ease 0.3s, transform 0.8s ease 0.3s;
}

.hero-slide.active .slide-content { 
    opacity: 1; 
    transform: translateY(0); 
}

.slide-indicator {
    width: 40px; 
    height: 4px; 
    border-radius: 2px;
    background: rgba(255, 255, 255, 0.3);
    transition: all 0.4s ease; 
    cursor: pointer;
    border: none;
}

.slide-indicator.active { 
    background: white; 
    width: 60px; 
}

.slide-arrow {
    position: absolute; 
    top: 50%; 
    transform: translateY(-50%);
    width: 48px; 
    height: 48px; 
    border-radius: 50%;
    background: rgba(255, 255, 255, 0.1);
    backdrop-filter: blur(10px);
    border: 1px solid rgba(255, 255, 255, 0.2);
    display: flex; 
    align-items: center; 
    justify-content: center;
    color: white; 
    cursor: pointer; 
    transition: all 0.3s ease; 
    z-index: 20;
}

.slide-arrow:hover { background: rgba(255, 255, 255, 0.2); }
.slide-arrow.prev { left: 24px; }
.slide-arrow.next { right: 24px; }

@media (max-width: 1024px) { 
    .slide-arrow { display: none; } 
}

/* ==================== BOTÓN PRIMARIO DINÁMICO ==================== */
.btn-primary {
    background: linear-gradient(135deg, var(--color-accent) 0%, var(--color-accent-hover) 100%);
    transition: all 0.3s ease;
    text-decoration: none;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 0.5rem;
    padding: 0.875rem 1.75rem;
    border-radius: 0.5rem;
    font-weight: 600;
    font-size: 1rem;
    color: #fff;
    border: none;
    cursor: pointer;
}

.btn-primary:hover { 
    box-shadow: 0 8px 24px rgba(245, 158, 11, 0.35); 
    transform: translateY(-2px); 
}

/* ==================== CARDS CON EFECTO TILT 3D ==================== */
.tilt-card {
    transform-style: preserve-3d;
    perspective: 1000px;
}

.tilt-card-inner {
    transition: transform 0.6s cubic-bezier(0.16, 1, 0.3, 1), box-shadow 0.6s;
    position: relative;
    overflow: hidden;
}

.tilt-card:hover .tilt-card-inner {
    box-shadow: 0 50px 80px -20px rgba(15, 41, 66, 0.25);
}

.card-shine {
    position: absolute; 
    inset: 0;
    background: linear-gradient(135deg, rgba(255,255,255,0) 0%, rgba(255,255,255,0.15) 50%, rgba(255,255,255,0) 100%);
    opacity: 0; 
    transition: opacity 0.3s;
    pointer-events: none; 
    border-radius: inherit; 
    z-index: 5;
}

.tilt-card:hover .card-shine { opacity: 1; }

.card-gradient-overlay {
    position: absolute; 
    inset: 0;
    opacity: 0; 
    transition: opacity 0.5s ease;
    border-radius: inherit; 
    z-index: 1;
}

.tilt-card:hover .card-gradient-overlay { opacity: 1; }

/* Hover con color de la patología */
.card-gradient-hover { 
    background: linear-gradient(135deg, var(--color-primary) 0%, var(--color-primary-light) 100%); 
}

.float-icon { animation: floatIcon 6s ease-in-out infinite; }

@keyframes floatIcon {
    0%, 100% { transform: translateY(0) rotate(0deg); }
    25% { transform: translateY(-10px) rotate(3deg); }
    75% { transform: translateY(5px) rotate(-3deg); }
}

/* ==================== CARDS GENERALES ==================== */
.card-hover { 
    transition: all 0.4s cubic-bezier(0.16, 1, 0.3, 1); 
}

.card-hover:hover { 
    transform: translateY(-8px); 
    box-shadow: 0 25px 50px -12px rgba(15, 41, 66, 0.2); 
}

.img-hover { overflow: hidden; }
.img-hover img { transition: transform 0.5s ease; }
.img-hover:hover img { transform: scale(1.05); }

/* ==================== WHATSAPP FLOTANTE ==================== */
.whatsapp-float {
    position: fixed; 
    bottom: 24px; 
    right: 24px;
    width: 56px; 
    height: 56px;
    background: #25D366; 
    border-radius: 50%;
    display: flex; 
    align-items: center; 
    justify-content: center;
    box-shadow: 0 4px 16px rgba(37, 211, 102, 0.4);
    z-index: 1000; 
    transition: all 0.3s ease;
    animation: pulse-whatsapp 2s infinite;
    text-decoration: none;
}

.whatsapp-float:hover { 
    transform: scale(1.08); 
    box-shadow: 0 6px 24px rgba(37, 211, 102, 0.5); 
}

@keyframes pulse-whatsapp {
    0%, 100% { box-shadow: 0 4px 16px rgba(37, 211, 102, 0.4); }
    50% { box-shadow: 0 4px 24px rgba(37, 211, 102, 0.6), 0 0 0 8px rgba(37, 211, 102, 0.1); }
}

/* ==================== SCROLL REVEAL ==================== */
.scroll-reveal { 
    opacity: 0; 
    transform: translateY(30px); 
    transition: all 0.7s cubic-bezier(0.16, 1, 0.3, 1); 
}

.scroll-reveal.visible { 
    opacity: 1; 
    transform: translateY(0); 
}

.stagger-1 { transition-delay: 0.1s; }
.stagger-2 { transition-delay: 0.2s; }
.stagger-3 { transition-delay: 0.3s; }
.stagger-4 { transition-delay: 0.4s; }
.stagger-5 { transition-delay: 0.5s; }
.stagger-6 { transition-delay: 0.6s; }
.stagger-7 { transition-delay: 0.7s; }

/* Variantes de dirección */
.scroll-reveal--left {
    opacity: 0;
    transform: translateX(-40px);
    transition: all 0.8s cubic-bezier(0.16, 1, 0.3, 1);
}
.scroll-reveal--left.visible {
    opacity: 1;
    transform: translateX(0);
}

.scroll-reveal--right {
    opacity: 0;
    transform: translateX(40px);
    transition: all 0.8s cubic-bezier(0.16, 1, 0.3, 1);
}
.scroll-reveal--right.visible {
    opacity: 1;
    transform: translateX(0);
}

.scroll-reveal--scale {
    opacity: 0;
    transform: scale(0.9);
    transition: all 0.7s cubic-bezier(0.16, 1, 0.3, 1);
}
.scroll-reveal--scale.visible {
    opacity: 1;
    transform: scale(1);
}

/* Counter animado */
.counter-number {
    font-size: 3rem;
    font-weight: 800;
    line-height: 1;
    background: linear-gradient(135deg, rgba(var(--color-primary-rgb), 1), rgba(var(--color-primary-rgb), 0.7));
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
}

.counter-label {
    font-size: 0.875rem;
    color: var(--color-text-muted);
    text-transform: uppercase;
    letter-spacing: 0.05em;
    margin-top: 0.25rem;
}

/* Stat cards */
.stat-card {
    text-align: center;
    padding: 2rem 1.5rem;
    background: #fff;
    border-radius: var(--radius-lg);
    box-shadow: 0 2px 12px rgba(0,0,0,0.06);
    transition: transform 0.4s ease, box-shadow 0.4s ease;
}
.stat-card:hover {
    transform: translateY(-6px);
    box-shadow: 0 12px 30px rgba(0,0,0,0.1);
}

/* Grid de stats */
.stats-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 1.5rem;
    max-width: 800px;
    margin: 0 auto;
}
@media (max-width: 600px) {
    .stats-grid { grid-template-columns: 1fr; }
    .counter-number { font-size: 2.5rem; }
}

/* Value cards */
.value-card {
    display: flex;
    align-items: flex-start;
    gap: 1.25rem;
    padding: 1.5rem;
    background: rgba(var(--color-primary-rgb), 0.04);
    border-radius: var(--radius-lg);
    border-left: 4px solid rgba(var(--color-primary-rgb), 0.3);
    transition: all 0.4s ease;
}
.value-card:hover {
    background: rgba(var(--color-primary-rgb), 0.08);
    border-left-color: rgba(var(--color-primary-rgb), 0.8);
    transform: translateX(6px);
}
.value-card__icon {
    flex-shrink: 0;
    width: 48px;
    height: 48px;
    border-radius: 12px;
    background: linear-gradient(135deg, rgba(var(--color-primary-rgb), 0.15), rgba(var(--color-primary-rgb), 0.05));
    display: flex;
    align-items: center;
    justify-content: center;
    color: rgba(var(--color-primary-rgb), 1);
}
.value-card__title {
    font-weight: 700;
    font-size: 1rem;
    margin-bottom: 0.25rem;
}
.value-card__text {
    font-size: 0.9rem;
    color: var(--color-text-muted);
    line-height: 1.6;
}

/* Grid 2x2 para valores */
.values-grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 1rem;
}

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

/* Disease list - vertical clean list */
.disease-list {
    display: flex;
    flex-direction: column;
    gap: 0;
}

.disease-list__item {
    display: flex;
    align-items: center;
    gap: 0.75rem;
    padding: 0.7rem 0;
    font-size: 0.95rem;
    font-weight: 500;
    color: #374151;
    border-bottom: 1px solid #f0f0f0;
}

.disease-list__item:last-child {
    border-bottom: none;
}

.disease-list__bullet {
    width: 8px;
    height: 8px;
    border-radius: 50%;
    background: var(--color-primary);
    flex-shrink: 0;
}

/* Service cards - neutral elegant */
.service-card {
    display: flex;
    gap: 1rem;
    align-items: center;
    padding: 1rem 1.25rem;
    background: #f8f9fa;
    border-radius: 12px;
    border: 1px solid #eee;
    transition: all 0.3s ease;
}

.service-card:hover {
    background: #fff;
    border-color: #ddd;
    box-shadow: 0 4px 15px rgba(0,0,0,0.06);
    transform: translateX(4px);
}

.service-card__icon {
    flex-shrink: 0;
    width: 44px;
    height: 44px;
    border-radius: 10px;
    background: var(--color-primary);
    display: flex;
    align-items: center;
    justify-content: center;
    color: #fff;
}

.service-card__title {
    margin: 0 0 0.15rem;
    font-size: 0.95rem;
    font-weight: 600;
    color: #1a1a2e;
}

.service-card__text {
    margin: 0;
    font-size: 0.85rem;
    color: #6b7280;
}

/* Timeline line accent */
.timeline-accent {
    position: relative;
    padding-left: 2rem;
}
.timeline-accent::before {
    content: '';
    position: absolute;
    left: 0;
    top: 0;
    bottom: 0;
    width: 3px;
    background: linear-gradient(to bottom, rgba(var(--color-primary-rgb), 0.8), rgba(var(--color-primary-rgb), 0.1));
    border-radius: 3px;
}

/* Orgs badge row */
.org-badges {
    display: flex;
    flex-wrap: wrap;
    gap: 0.75rem;
    margin-top: 1.25rem;
}
.org-badge {
    display: inline-flex;
    align-items: center;
    gap: 0.4rem;
    padding: 0.5rem 1.15rem;
    border-radius: 50px;
    font-size: 0.8rem;
    font-weight: 700;
    letter-spacing: 0.04em;
    background: rgba(var(--color-primary-rgb), 0.06);
    border: 1px solid rgba(var(--color-primary-rgb), 0.15);
    color: rgba(var(--color-primary-rgb), 0.85);
    transition: all 0.3s ease;
}
.org-badge:hover {
    background: rgba(var(--color-primary-rgb), 0.12);
    border-color: rgba(var(--color-primary-rgb), 0.4);
    transform: translateY(-2px);
    box-shadow: 0 4px 12px rgba(var(--color-primary-rgb), 0.1);
}

/* Sponsor logo grid */
.sponsor-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
    gap: 1.5rem;
    max-width: 900px;
    margin: 2rem auto 0;
}

/* Para grids con solo 2 logos - centrado */
.sponsor-grid--2col {
    grid-template-columns: repeat(2, 1fr);
    max-width: 520px;
}

.sponsor-logo {
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 1.5rem 2rem;
    background: #fff;
    border-radius: var(--radius-lg);
    border: 1px solid rgba(0,0,0,0.06);
    box-shadow: 0 2px 8px rgba(0,0,0,0.04);
    transition: all 0.4s ease;
    min-height: 100px;
}

.sponsor-logo:hover {
    transform: translateY(-4px);
    box-shadow: 0 8px 25px rgba(0,0,0,0.08);
    border-color: rgba(var(--color-primary-rgb), 0.2);
}

.sponsor-logo img {
    max-height: 50px;
    max-width: 100%;
    object-fit: contain;
    transition: all 0.4s ease;
}

.sponsor-logo:hover img {
    transform: scale(1.05);
}

@media (max-width: 600px) {
    .sponsor-grid {
        grid-template-columns: repeat(2, 1fr);
        gap: 1rem;
    }
    .sponsor-logo {
        padding: 1rem;
        min-height: 80px;
    }
}

/* ==================== ANIMACIONES ADICIONALES ==================== */

/* Float para tiles del mosaico */
@keyframes float {
    0%, 100% { transform: translateY(0); }
    50% { transform: translateY(-10px); }
}

/* Fade in */
.animate-fade-in {
    animation: fadeIn 0.8s ease-out forwards;
}

@keyframes fadeIn {
    from { opacity: 0; transform: translateY(20px); }
    to { opacity: 1; transform: translateY(0); }
}

/* ==================== UTILIDADES ==================== */
.line-clamp-2 {
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
}

.line-clamp-3 {
    display: -webkit-box;
    -webkit-line-clamp: 3;
    -webkit-box-orient: vertical;
    overflow: hidden;
}

/* ==================== PÁGINAS DE CONTENIDO (ESTÁTICAS) ==================== */
/* Estilos para páginas informativas: qué es, tipos, diagnóstico, tratamiento, etc. */

/* --- Variables locales --- */
:root {
    --content-spacing: 4rem;
    --content-radius: 1rem;
    --color-text: #1e293b;
    --color-text-muted: #64748b;
    --color-bg-soft: #f8fafc;
}

@media (min-width: 768px) {
    :root { --content-spacing: 6rem; }
}

/* --- Container --- */
.content-container {
    width: 100%;
    max-width: 1200px;
    margin: 0 auto;
    padding: 0 1.5rem;
}

@media (min-width: 768px) {
    .content-container { padding: 0 2rem; }
}

/* --- Secciones --- */
.content-section {
    padding: var(--content-spacing) 0;
}

.content-section--alt {
    background: var(--color-bg-soft);
}

.content-section--primary {
    background: linear-gradient(135deg, var(--color-primary-light) 0%, var(--color-primary) 100%);
    color: #fff;
}

/* --- Hero interno --- */
.content-hero {
    background: linear-gradient(135deg, var(--hero-gradient-start) 0%, var(--hero-gradient-end) 100%);
    color: #fff;
    padding: 3rem 0 4rem;
    position: relative;
    overflow: hidden;
}

.content-hero::before {
    content: '';
    position: absolute;
    top: -50%;
    right: -20%;
    width: 60%;
    height: 200%;
    background: radial-gradient(circle, rgba(255,255,255,0.05) 0%, transparent 70%);
    pointer-events: none;
}

.content-hero__inner {
    position: relative;
    z-index: 1;
    max-width: 700px;
}

.content-hero__badge {
    display: inline-block;
    background: rgba(255, 255, 255, 0.15);
    padding: 0.4rem 1rem;
    border-radius: 2rem;
    font-size: 0.85rem;
    font-weight: 500;
    margin-bottom: 1.5rem;
    backdrop-filter: blur(10px);
}

.content-hero__title {
    font-family: var(--font-body);
    font-size: clamp(2rem, 5vw, 3.5rem);
    font-weight: 700;
    line-height: 1.15;
    margin: 0 0 1rem;
}

.content-hero__subtitle {
    font-size: 1.125rem;
    line-height: 1.6;
    opacity: 0.9;
    margin: 0;
}

@media (min-width: 768px) {
    .content-hero { padding: 5rem 0 6rem; }
    .content-hero__subtitle { font-size: 1.25rem; }
}

/* --- Títulos de sección --- */
.section-title {
    font-family: var(--font-body);
    font-size: clamp(1.75rem, 4vw, 2.5rem);
    font-weight: 700;
    color: var(--color-primary-light);
    margin: 0 0 1.5rem;
    line-height: 1.2;
}

.section-title--light {
    color: #fff;
}

.section-title--center {
    text-align: center;
}

.section-title--sm {
    font-size: 1.3rem;
    margin-bottom: 1rem;
}

.section-subtitle {
    font-size: 1.125rem;
    color: var(--color-text-muted);
    max-width: 600px;
    margin: -0.5rem 0 3rem;
    line-height: 1.6;
}

.section-subtitle--center {
    text-align: center;
    margin-left: auto;
    margin-right: auto;
}

.section-eyebrow {
    display: inline-block;
    color: var(--color-accent);
    font-weight: 600;
    font-size: 0.9rem;
    text-transform: uppercase;
    letter-spacing: 0.5px;
    margin-bottom: 0.5rem;
}

.section-eyebrow--light {
    color: rgba(255,255,255,0.7);
}

/* --- Grids --- */
.content-grid {
    display: grid;
    gap: 2rem;
    align-items: center;
}

.content-grid--2col {
    grid-template-columns: 1fr;
}

@media (min-width: 768px) {
    .content-grid--2col {
        grid-template-columns: 1fr 1fr;
        gap: 4rem;
    }
}

.content-grid--3col {
    grid-template-columns: 1fr;
}

@media (min-width: 768px) {
    .content-grid--3col {
        grid-template-columns: repeat(3, 1fr);
        gap: 1.5rem;
    }
}

/* --- Bloque de estadística grande --- */
.stat-block {
    text-align: center;
    max-width: 600px;
    margin: 0 auto;
}

.stat-block__number {
    font-family: var(--font-body);
    font-size: clamp(4rem, 12vw, 8rem);
    font-weight: 700;
    color: var(--color-primary);
    line-height: 1;
    margin-bottom: 1rem;
}

.stat-block__text {
    font-size: 1.125rem;
    line-height: 1.6;
    color: var(--color-text);
    margin: 0 0 0.5rem;
}

.stat-block__highlight {
    font-size: 1.25rem;
    font-weight: 600;
    color: var(--color-primary);
    margin: 0;
}

/* --- Cards de información --- */
.info-card {
    background: #fff;
    border-radius: var(--content-radius);
    padding: 2rem;
    box-shadow: 0 4px 20px rgba(0, 0, 0, 0.08);
    transition: all 0.3s ease;
    border: 2px solid transparent;
}

.info-card:hover {
    transform: translateY(-4px);
    box-shadow: 0 8px 30px rgba(0, 0, 0, 0.12);
}

.info-card--bordered {
    border-color: var(--color-primary);
}

.info-card--accent {
    border-color: var(--color-accent);
}

.info-card__icon {
    width: 60px;
    height: 60px;
    margin: 0 auto 1rem;
    color: var(--color-primary-light);
}

.info-card__title {
    font-size: 1.25rem;
    font-weight: 600;
    margin: 0 0 1rem;
    color: var(--color-text);
}

.info-card__list {
    list-style: none;
    padding: 0;
    margin: 0;
    text-align: left;
}

.info-card__list li {
    padding: 0.5rem 0 0.5rem 1.5rem;
    position: relative;
    font-size: 0.95rem;
    line-height: 1.5;
}

.info-card__list li::before {
    content: '•';
    position: absolute;
    left: 0;
    color: var(--color-primary);
    font-weight: bold;
}

.info-card--accent .info-card__list li::before {
    color: var(--color-accent);
}

/* --- Cards con imagen header --- */
.info-card--media {
    padding: 0;
    overflow: hidden;
}

.info-card__header {
    padding: 1.5rem;
    background: linear-gradient(135deg, 
        rgba(var(--color-primary-rgb), 0.05) 0%,
        rgba(var(--color-accent-rgb), 0.05) 100%
    );
    display: flex;
    justify-content: center;
}

.info-card__body {
    padding: 1.5rem;
}

/* --- Comparison cards (Aguda vs Crónica) --- */
.comparison-grid {
    display: grid;
    gap: 1.5rem;
    margin-top: 3rem;
}

@media (min-width: 768px) {
    .comparison-grid {
        grid-template-columns: 1fr 1fr;
        gap: 2rem;
    }
}

.comparison-card {
    text-align: center;
}

.comparison-card__number {
    font-family: var(--font-body);
    font-size: 3.5rem;
    font-weight: 700;
    line-height: 1;
    color: var(--color-primary);
}

.comparison-card--alt .comparison-card__number {
    color: var(--color-accent);
}

.comparison-card--alt .info-card__list li::before {
    color: var(--color-accent);
}

.comparison-card--alt {
    border-color: var(--color-accent);
}

.comparison-card__duration {
    display: flex;
    align-items: baseline;
    justify-content: center;
    gap: 0.25rem;
    margin-bottom: 1.5rem;
}

.comparison-card__symbol {
    font-size: 1.5rem;
    font-weight: 300;
    color: var(--color-text-muted);
}

.comparison-card__unit {
    font-size: 1rem;
    color: var(--color-text-muted);
}

/* --- Myth Buster / Info Box --- */
.info-box {
    background: linear-gradient(135deg, 
        rgba(var(--color-accent-rgb), 0.08) 0%,
        rgba(var(--color-accent-rgb), 0.02) 100%
    );
    border-radius: var(--content-radius);
    padding: 2.5rem 2rem;
    border: 1px solid rgba(var(--color-accent-rgb), 0.2);
}

@media (min-width: 768px) {
    .info-box { padding: 3rem; }
}

.info-box__badge {
    display: inline-block;
    background: var(--color-accent);
    color: #fff;
    padding: 0.35rem 1rem;
    border-radius: 2rem;
    font-size: 0.8rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.5px;
    margin-bottom: 1rem;
}

.info-box__title {
    font-family: var(--font-body);
    font-size: clamp(1.5rem, 4vw, 2rem);
    color: var(--color-primary-light);
    margin: 0 0 2rem;
    text-align: center;
}

.info-box__grid {
    display: grid;
    gap: 1rem;
}

@media (min-width: 768px) {
    .info-box__grid {
        grid-template-columns: repeat(3, 1fr);
        gap: 1.5rem;
    }
}

.info-box__item {
    background: #fff;
    border-radius: 0.75rem;
    padding: 1.5rem;
    text-align: center;
    box-shadow: 0 2px 10px rgba(0, 0, 0, 0.05);
}

.info-box__icon {
    width: 50px;
    height: 50px;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    margin: 0 auto 1rem;
    font-size: 1.25rem;
    font-weight: bold;
}

.info-box__icon--success {
    background: #dcfce7;
    color: #16a34a;
}

.info-box__icon--error {
    background: #fee2e2;
    color: #dc2626;
}

.info-box__icon--warning {
    background: #fef3c7;
    color: #d97706;
}

/* --- Lista de pasos --- */
.steps-list {
    margin-top: 2rem;
}

.steps-list__item {
    display: flex;
    gap: 1rem;
    margin-bottom: 1.5rem;
}

.steps-list__item:last-child {
    margin-bottom: 0;
}

.steps-list__number {
    flex-shrink: 0;
    width: 36px;
    height: 36px;
    background: var(--color-primary);
    color: #fff;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    font-weight: 600;
    font-size: 0.9rem;
}

.steps-list__content h4 {
    font-size: 1rem;
    font-weight: 600;
    color: var(--color-primary-light);
    margin: 0 0 0.25rem;
}

.steps-list__content p {
    margin: 0;
    font-size: 0.95rem;
    color: var(--color-text);
}

/* --- Highlight Box --- */
.highlight-box {
    background: rgba(255, 255, 255, 0.1);
    border-left: 4px solid rgba(255, 255, 255, 0.5);
    padding: 1rem 1.5rem;
    border-radius: 0 0.5rem 0.5rem 0;
    backdrop-filter: blur(10px);
    text-align: left;
}

.highlight-box p {
    margin: 0;
    font-size: 1rem;
    line-height: 1.6;
}

.content-section--primary .highlight-box,
.content-section--primary .highlight-box p,
.content-section--primary .highlight-box strong {
    color: #fff;
}

.content-section--primary .text-lead {
    color: rgba(255,255,255,0.9);
}

.highlight-box--light {
    background: linear-gradient(135deg, 
        rgba(var(--color-primary-rgb), 0.05) 0%,
        rgba(var(--color-accent-rgb), 0.05) 100%
    );
    border-left-color: var(--color-primary);
}

/* --- Síntomas cards (con lista iconizada) --- */
.symptom-list {
    list-style: none;
    padding: 0;
    margin: 0;
}

.symptom-list li {
    display: flex;
    gap: 0.75rem;
    padding: 0.75rem 0;
    border-bottom: 1px solid #f0f0f0;
    font-size: 0.95rem;
    line-height: 1.5;
}

.symptom-list li:last-child {
    border-bottom: none;
    padding-bottom: 0;
}

.symptom-list__icon {
    flex-shrink: 0;
    width: 24px;
    text-align: center;
}

/* --- CTA Section --- */
.cta-box {
    background: linear-gradient(135deg, 
        rgba(var(--color-primary-rgb), 0.05) 0%,
        rgba(var(--color-accent-rgb), 0.05) 100%
    );
    border-radius: var(--content-radius);
    padding: 2.5rem 2rem;
    text-align: center;
    border: 1px solid rgba(var(--color-primary-rgb), 0.1);
}

@media (min-width: 768px) {
    .cta-box { padding: 4rem; }
}

.cta-box__title {
    font-family: var(--font-body);
    font-size: clamp(1.5rem, 4vw, 2rem);
    color: var(--color-primary-light);
    margin: 0 0 1rem;
}

.cta-box__text {
    font-size: 1.1rem;
    color: var(--color-text-muted);
    margin: 0 auto 2rem;
    max-width: 500px;
}

.cta-box__buttons {
    display: flex;
    flex-direction: column;
    gap: 1rem;
    justify-content: center;
}

@media (min-width: 480px) {
    .cta-box__buttons { flex-direction: row; }
}

/* --- Botones secundarios --- */
.btn-secondary {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 0.5rem;
    padding: 0.875rem 1.75rem;
    border-radius: 0.5rem;
    font-weight: 600;
    font-size: 1rem;
    text-decoration: none;
    transition: all 0.3s ease;
    background: transparent;
    color: var(--color-primary);
    border: 2px solid var(--color-primary);
}

.btn-secondary:hover {
    background: var(--color-primary);
    color: #fff;
}

.btn-secondary svg,
.btn-primary svg {
    width: 18px;
    height: 18px;
}

/* --- Placeholder para imágenes --- */
.placeholder-img {
    background: linear-gradient(135deg, 
        rgba(var(--color-primary-rgb), 0.1) 0%,
        rgba(var(--color-accent-rgb), 0.1) 100%
    );
    border: 2px dashed rgba(var(--color-primary-rgb), 0.3);
    border-radius: var(--content-radius);
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    padding: 2rem;
    text-align: center;
    min-height: 200px;
}

.placeholder-img span {
    font-size: 1rem;
    color: var(--color-primary);
    font-weight: 500;
}

.placeholder-img small {
    font-size: 0.8rem;
    color: var(--color-text-muted);
    margin-top: 0.5rem;
}

/* --- Utilidades de texto --- */
.text-center { text-align: center; }
.text-lead { font-size: 1.125rem; line-height: 1.7; color: #374151; margin-bottom: 1rem; }
.text-muted { color: var(--color-text-muted); }
.text-subtitle { font-size: 0.95rem; color: var(--color-text-muted); margin-bottom: 1rem; }

/* ==================== COMPONENTES DE CONTENIDO ==================== */
/* Componentes reutilizables para páginas estáticas */

/* --- Animaciones base --- */
@keyframes pulse-ring {
    0% { transform: scale(1); opacity: 0.6; }
    100% { transform: scale(1.8); opacity: 0; }
}

@keyframes float-icon {
    0%, 100% { transform: translateY(0); }
    50% { transform: translateY(-8px); }
}

@keyframes float-card {
    0%, 100% { transform: translateY(0); }
    50% { transform: translateY(-6px); }
}

@keyframes glow-shadow {
    0%, 100% { box-shadow: 0 8px 25px var(--shadow-color); }
    50% { box-shadow: 0 12px 35px var(--shadow-color-strong); }
}

@keyframes gentle-pulse {
    0%, 100% { transform: scale(1); }
    50% { transform: scale(1.05); }
}

@keyframes spin-slow {
    from { transform: rotate(0deg); }
    to { transform: rotate(360deg); }
}

@keyframes flow-down {
    0% { transform: translateY(-100%); }
    100% { transform: translateY(100%); }
}

@keyframes shake-subtle {
    0%, 100% { transform: translateX(0); }
    25% { transform: translateX(-2px) rotate(-1deg); }
    75% { transform: translateX(2px) rotate(1deg); }
}

@keyframes float-bubble {
    0%, 100% { transform: translate(0, 0) scale(1); }
    25% { transform: translate(15px, -20px) scale(1.1); }
    50% { transform: translate(25px, -10px) scale(1.05); }
    75% { transform: translate(10px, -25px) scale(1.15); }
}

@keyframes check-bounce {
    0%, 100% { transform: scale(1); }
    50% { transform: scale(1.15); }
}

/* --- Image Frame (borde blanco para imágenes) --- */
.image-frame {
    background: #fff;
    border-radius: 24px;
    overflow: hidden;
    box-shadow: 0 4px 6px rgba(0,0,0,0.04), 0 10px 40px rgba(0,0,0,0.08);
    border: 1px solid rgba(0,0,0,0.06);
    padding: 8px;
}

.image-frame img {
    width: 100%;
    height: auto;
    display: block;
    border-radius: 16px;
}

/* --- Goal Cards (metas/objetivos) --- */
.goal-card {
    background: #fff;
    border-radius: 20px;
    padding: 2rem 1.5rem;
    text-align: center;
    position: relative;
    overflow: hidden;
    box-shadow: 0 4px 6px rgba(0,0,0,0.04), 0 10px 30px rgba(0,0,0,0.08);
    border: 1px solid rgba(0,0,0,0.06);
    cursor: default;
    animation: float-card 4s ease-in-out infinite;
    animation-delay: var(--animation-delay, 0s);
}

.goal-card::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    height: 4px;
    background: linear-gradient(90deg, var(--card-color), var(--card-color-light));
}

.goal-card__icon-wrapper {
    position: relative;
    width: 80px;
    height: 80px;
    margin: 0 auto 1.25rem;
}

.goal-card__icon {
    width: 80px;
    height: 80px;
    background: #fff;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    position: relative;
    z-index: 2;
    animation: float-icon 3s ease-in-out infinite, glow-shadow 3s ease-in-out infinite;
    animation-delay: var(--animation-delay, 0s);
    --shadow-color: var(--icon-shadow);
    --shadow-color-strong: var(--icon-shadow-strong);
    box-shadow: 0 8px 25px var(--icon-shadow);
}

.goal-card__ring {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    border-radius: 50%;
    border: 2px solid var(--card-color);
    animation: pulse-ring 2.5s ease-out infinite;
    animation-delay: var(--ring-delay, 0s);
}

.goal-card__title {
    margin: 0 0 0.5rem;
    font-size: 1.2rem;
    font-weight: 700;
    color: var(--card-color);
}

.goal-card__text {
    margin: 0;
    font-size: 0.9rem;
    color: var(--color-text-muted);
    line-height: 1.5;
}

/* --- Step Cards (pasos escalonados) --- */
.step-card {
    display: flex;
    gap: 1.5rem;
    align-items: flex-start;
    margin-bottom: 1rem;
}

.step-card__number {
    flex-shrink: 0;
    width: 64px;
    height: 64px;
    border-radius: 18px;
    display: flex;
    align-items: center;
    justify-content: center;
    color: #fff;
    font-size: 1.6rem;
    font-weight: 700;
    position: relative;
    cursor: default;
    animation: gentle-pulse 3s ease-in-out infinite;
    animation-delay: var(--animation-delay, 0s);
    background: var(--step-gradient);
    box-shadow: var(--step-shadow);
}

.step-card__number::after {
    content: '';
    position: absolute;
    inset: -6px;
    border-radius: 24px;
    border: 2px dashed var(--step-color);
    opacity: 0.4;
    animation: spin-slow 12s linear infinite;
}

.step-card__content {
    flex: 1;
    background: #fff;
    border-radius: 18px;
    padding: 1.75rem;
    box-shadow: 0 4px 6px rgba(0,0,0,0.04), 0 10px 30px rgba(0,0,0,0.08);
    border-left: 5px solid var(--step-color);
}

.step-card__title {
    margin: 0 0 0.5rem;
    font-size: 1.2rem;
    color: var(--color-text);
    font-weight: 700;
}

.step-card__text {
    margin: 0;
    font-size: 0.95rem;
    color: var(--color-text-muted);
    line-height: 1.7;
}

/* Step connector */
.step-connector {
    display: flex;
    align-items: center;
    margin-left: 30px;
    margin-bottom: 1rem;
    position: relative;
}

.step-connector__line {
    width: 4px;
    height: 35px;
    position: relative;
    overflow: hidden;
    background: linear-gradient(180deg, var(--from-color), var(--to-color));
}

.step-connector__line::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 50%;
    background: rgba(255,255,255,0.6);
    animation: flow-down 1.5s ease-in-out infinite;
}

.step-connector__text {
    margin-left: 1.5rem;
    font-size: 0.85rem;
    color: var(--color-text-muted);
    font-style: italic;
}

/* --- Feature Check (lista de características con tilde) --- */
.feature-check {
    display: flex;
    gap: 1rem;
    align-items: flex-start;
    padding: 0.75rem 1rem;
    background: #fff;
    border-radius: 12px;
    box-shadow: 0 2px 8px rgba(0,0,0,0.04);
    border: 1px solid rgba(0,0,0,0.05);
    transition: all 0.3s ease;
}

.feature-check:hover {
    transform: translateX(8px);
    box-shadow: 0 4px 15px rgba(0,0,0,0.08);
}

.feature-check:hover .feature-check__icon {
    animation: check-bounce 0.5s ease;
}

.feature-check__icon {
    flex-shrink: 0;
    width: 40px;
    height: 40px;
    border-radius: 10px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: var(--check-bg, rgba(16, 185, 129, 0.1));
    box-shadow: 0 4px 12px var(--check-shadow, rgba(16, 185, 129, 0.2));
}

.feature-check__content h4 {
    margin: 0 0 0.25rem;
    font-size: 0.95rem;
    color: var(--color-text);
    font-weight: 600;
}

.feature-check__content p {
    margin: 0;
    font-size: 0.85rem;
    color: var(--color-text-muted);
}

/* --- Stat Cards (estadísticas) --- */
.stat-card {
    background: #fff;
    border-radius: 16px;
    padding: 1.25rem;
    text-align: center;
    box-shadow: 0 4px 15px rgba(0,0,0,0.08);
    transition: all 0.4s cubic-bezier(0.175, 0.885, 0.32, 1.275);
    cursor: default;
    position: relative;
    overflow: hidden;
}

.stat-card::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    height: 3px;
    background: var(--stat-color);
    transform: scaleX(0);
    transition: transform 0.3s ease;
}

.stat-card:hover {
    transform: translateY(-6px) scale(1.02);
    box-shadow: 0 12px 30px rgba(0,0,0,0.12);
}

.stat-card:hover::before {
    transform: scaleX(1);
}

.stat-card:hover .stat-card__number {
    transform: scale(1.1);
}

.stat-card__number {
    font-size: 2.25rem;
    font-weight: 800;
    transition: transform 0.3s ease;
    display: block;
    color: var(--stat-color);
}

.stat-card__label {
    font-size: 0.85rem;
    color: var(--color-text-muted);
    margin-top: 0.25rem;
}

/* Stat card siempre activa (cuando no es clickeable) */
.stat-card--active {
    transform: translateY(-6px) scale(1.02);
    box-shadow: 0 12px 30px rgba(0,0,0,0.12);
}

.stat-card--active::before {
    transform: scaleX(1);
}

.stat-card--active .stat-card__number {
    transform: scale(1.1);
}

/* --- Myth Cards (mitos/lo que no funciona) --- */
.myth-card {
    background: #fff;
    border-radius: 20px;
    padding: 2rem 1.5rem;
    box-shadow: 0 4px 6px rgba(0,0,0,0.04), 0 10px 30px rgba(0,0,0,0.08);
    border: 1px solid rgba(0,0,0,0.06);
    transition: all 0.4s cubic-bezier(0.175, 0.885, 0.32, 1.275);
    position: relative;
    overflow: hidden;
    cursor: default;
    text-align: center;
}

.myth-card::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    height: 4px;
    background: var(--myth-color);
}

.myth-card:hover {
    transform: translateY(-8px);
    box-shadow: 0 15px 40px var(--myth-shadow);
}

.myth-card:hover .myth-card__icon {
    animation: shake-subtle 0.5s ease-in-out;
}

.myth-card__icon-wrapper {
    position: relative;
    width: 72px;
    height: 72px;
    margin: 0 auto 1.25rem;
}

.myth-card__icon {
    width: 72px;
    height: 72px;
    background: var(--myth-bg);
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    position: relative;
    box-shadow: 0 8px 20px var(--myth-shadow);
}

.myth-card__title {
    margin: 0 0 0.75rem;
    font-size: 1.15rem;
    font-weight: 700;
    color: var(--myth-color);
}

.myth-card__text {
    margin: 0;
    font-size: 0.9rem;
    color: var(--color-text-muted);
    line-height: 1.6;
}

/* --- Fact Row (lista de checks/mitos inline) --- */
.fact-list {
    display: flex;
    flex-direction: column;
    gap: 1rem;
    margin-top: 2rem;
}

.fact-row {
    display: flex;
    align-items: center;
    gap: 1rem;
    padding: 1.25rem 1.5rem;
    background: #fff;
    border-radius: 12px;
    box-shadow: 0 2px 8px rgba(0,0,0,0.06);
    transition: all 0.3s ease;
}

.fact-row:hover {
    transform: translateX(4px);
    box-shadow: 0 4px 16px rgba(0,0,0,0.1);
}

.fact-row__icon {
    flex-shrink: 0;
    width: 32px;
    height: 32px;
    background: linear-gradient(135deg, var(--color-primary), var(--color-primary-light));
    color: #fff;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    font-weight: 700;
    font-size: 0.85rem;
}

.fact-row__text {
    margin: 0;
    font-size: 1.05rem;
    line-height: 1.5;
}

/* --- Info Callout (cajas destacadas) --- */
.info-callout {
    background: linear-gradient(135deg, var(--color-primary) 0%, var(--color-accent) 100%);
    border-radius: 20px;
    padding: 2.5rem;
    color: #fff;
    position: relative;
    overflow: hidden;
}

.info-callout__bubble {
    position: absolute;
    background: rgba(255,255,255,0.12);
    border-radius: 50%;
    animation: float-bubble 6s ease-in-out infinite;
}

.info-callout__bubble--top-right {
    top: -30px;
    right: -30px;
    width: 140px;
    height: 140px;
}

.info-callout__bubble--bottom-left {
    bottom: -40px;
    left: -40px;
    width: 120px;
    height: 120px;
    animation-delay: 1s;
}

.info-callout__bubble--center {
    top: 20%;
    right: 20%;
    width: 80px;
    height: 80px;
    animation-delay: 2s;
}

.info-callout__content {
    position: relative;
    z-index: 1;
}

.info-callout--horizontal .info-callout__content {
    display: flex;
    align-items: flex-start;
    gap: 1.5rem;
}

.info-callout__icon {
    flex-shrink: 0;
    width: 56px;
    height: 56px;
    background: rgba(255,255,255,0.2);
    border-radius: 14px;
    display: flex;
    align-items: center;
    justify-content: center;
}

.info-callout__title {
    margin: 0 0 0.75rem;
    font-size: 1.25rem;
    font-weight: 700;
}

.info-callout__text {
    margin: 0;
    font-size: 1rem;
    opacity: 0.95;
    line-height: 1.6;
}

/* --- Duration Item (puntos de duración) --- */
.duration-item {
    display: flex;
    gap: 1rem;
    align-items: flex-start;
    padding: 0.75rem 1rem;
    background: #fff;
    border-radius: 12px;
    box-shadow: 0 2px 8px rgba(0,0,0,0.04);
    border: 1px solid rgba(0,0,0,0.05);
    transition: all 0.3s ease;
}

.duration-item:hover {
    transform: translateX(8px);
    box-shadow: 0 4px 15px rgba(0,0,0,0.08);
}

.duration-item__icon {
    flex-shrink: 0;
    width: 40px;
    height: 40px;
    border-radius: 10px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: var(--check-bg);
    box-shadow: 0 4px 12px var(--check-shadow);
}

.duration-item__title {
    margin: 0 0 0.25rem;
    font-size: 0.95rem;
    color: var(--color-text);
    font-weight: 600;
}

.duration-item__text {
    margin: 0;
    font-size: 0.85rem;
    color: var(--color-text-muted);
    line-height: 1.6;
}

/* ── Color modifiers para componentes ── */
/* Estos eliminan la necesidad de inline styles */

/* Goal card modifiers */
.goal-card--primary { --card-color: var(--color-primary, #802470); --card-color-light: var(--color-primary-light, #9A3D8A); --animation-delay: 0s; }
.goal-card--secondary { --card-color: var(--color-secondary, #2D2B71); --card-color-light: #3D3B8A; --animation-delay: 0.5s; }
.goal-card--tertiary { --card-color: var(--color-tertiary, #047CA5); --card-color-light: #0891B2; --animation-delay: 1s; }

.goal-card--primary .goal-card__icon { --icon-shadow: rgba(128,36,112,0.25); --icon-shadow-strong: rgba(128,36,112,0.4); color: var(--color-primary, #802470); }
.goal-card--secondary .goal-card__icon { --icon-shadow: rgba(45,43,113,0.25); --icon-shadow-strong: rgba(45,43,113,0.4); color: var(--color-secondary, #2D2B71); }
.goal-card--tertiary .goal-card__icon { --icon-shadow: rgba(4,124,165,0.25); --icon-shadow-strong: rgba(4,124,165,0.4); color: var(--color-tertiary, #047CA5); }

.goal-card--primary .goal-card__ring { --ring-delay: 0s; }
.goal-card--secondary .goal-card__ring { --ring-delay: 0.8s; }
.goal-card--tertiary .goal-card__ring { --ring-delay: 1.6s; }

/* Step card modifiers */
.step-card--primary .step-card__number { --step-gradient: linear-gradient(135deg, #802470, #9A3D8A); --step-shadow: 0 8px 25px rgba(128,36,112,0.35); --step-color: #802470; --animation-delay: 0s; }
.step-card--secondary .step-card__number { --step-gradient: linear-gradient(135deg, #2D2B71, #3D3B8A); --step-shadow: 0 8px 25px rgba(45,43,113,0.35); --step-color: #2D2B71; --animation-delay: 1s; }
.step-card--tertiary .step-card__number { --step-gradient: linear-gradient(135deg, #047CA5, #0891B2); --step-shadow: 0 8px 25px rgba(4,124,165,0.35); --step-color: #047CA5; --animation-delay: 2s; }
.step-card--quaternary .step-card__number { --step-gradient: linear-gradient(135deg, #802470, #2D2B71); --step-shadow: 0 8px 25px rgba(128,36,112,0.35); --step-color: #802470; --animation-delay: 3s; }

.step-card--primary .step-card__content { --step-color: #802470; }
.step-card--secondary .step-card__content { --step-color: #2D2B71; }
.step-card--tertiary .step-card__content { --step-color: #047CA5; }
.step-card--quaternary .step-card__content { --step-color: #802470; }

/* Step connector modifiers */
.step-connector--1-2 .step-connector__line { --from-color: #802470; --to-color: #2D2B71; }
.step-connector--2-3 .step-connector__line { --from-color: #2D2B71; --to-color: #047CA5; }
.step-connector--3-4 .step-connector__line { --from-color: #047CA5; --to-color: #802470; }

/* Feature check / duration item color modifiers */
.check--primary { --check-bg: rgba(128,36,112,0.1); --check-shadow: rgba(128,36,112,0.2); color: #802470; }
.check--secondary { --check-bg: rgba(45,43,113,0.1); --check-shadow: rgba(45,43,113,0.2); color: #2D2B71; }
.check--tertiary { --check-bg: rgba(4,124,165,0.1); --check-shadow: rgba(4,124,165,0.2); color: #047CA5; }

/* Stat card color modifiers */
.stat-card--primary { --stat-color: #802470; }
.stat-card--secondary { --stat-color: #2D2B71; }
.stat-card--tertiary { --stat-color: #047CA5; }

/* Myth card color modifiers */
.myth-card--primary { --myth-color: #802470; --myth-shadow: rgba(128,36,112,0.2); --myth-bg: rgba(128,36,112,0.1); }
.myth-card--secondary { --myth-color: #2D2B71; --myth-shadow: rgba(45,43,113,0.2); --myth-bg: rgba(45,43,113,0.1); }
.myth-card--tertiary { --myth-color: #047CA5; --myth-shadow: rgba(4,124,165,0.2); --myth-bg: rgba(4,124,165,0.1); }

/* Highlight box (reemplaza inline styles) */
.highlight-box {
    margin-top: 1.5rem;
    padding: 1rem;
    border-radius: 12px;
    background: rgba(128,36,112,0.05);
}

.highlight-box p {
    margin: 0;
    font-size: 0.9rem;
    color: var(--color-text-muted);
    line-height: 1.6;
}

/* --- Grid utilities --- */
.grid-goals {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
    gap: 2rem;
}

.grid-myths {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
    gap: 1.5rem;
    max-width: 950px;
    margin: 2.5rem auto 0;
}

.grid-stats {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 1.25rem;
}

/* --- Diagnostic Step (numbered items) --- */
.diag-step {
    display: flex;
    gap: 1rem;
    align-items: center;
    padding: 0.75rem 1rem;
    background: rgba(var(--color-primary-rgb), 0.05);
    border-radius: 12px;
    transition: all 0.3s ease;
}

.diag-step:hover {
    transform: translateX(8px);
    box-shadow: 0 4px 15px rgba(0,0,0,0.08);
}

.diag-step__number {
    flex-shrink: 0;
    width: 40px;
    height: 40px;
    background: var(--step-bg, var(--color-primary));
    border-radius: 10px;
    display: flex;
    align-items: center;
    justify-content: center;
    color: #fff;
    font-weight: 700;
    font-size: 1rem;
    transition: transform 0.3s ease;
}

.diag-step:hover .diag-step__number {
    transform: scale(1.1);
}

.diag-step__title {
    margin: 0 0 0.25rem;
    font-size: 1rem;
    color: var(--color-text);
    font-weight: 600;
}

.diag-step__text {
    margin: 0;
    font-size: 0.9rem;
    color: var(--color-text-muted);
}

/* --- Criteria Card (centered icon card) --- */
.grid-criteria {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
    gap: 1.5rem;
    max-width: 900px;
    margin: 2rem auto 0;
}

.criteria-card {
    background: #fff;
    border-radius: 20px;
    padding: 2rem;
    box-shadow: 0 4px 6px rgba(0,0,0,0.04), 0 10px 40px rgba(0,0,0,0.08);
    border: 1px solid rgba(0,0,0,0.06);
    text-align: center;
    transition: all 0.4s cubic-bezier(0.175, 0.885, 0.32, 1.275);
    position: relative;
}

.criteria-card:hover {
    transform: translateY(-8px);
    box-shadow: 0 12px 40px rgba(0,0,0,0.12);
}

.criteria-card__icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 64px;
    height: 64px;
    background: var(--check-bg);
    border-radius: 16px;
    margin-bottom: 1rem;
    transition: transform 0.3s ease;
    color: var(--card-color);
}

.criteria-card:hover .criteria-card__icon {
    transform: scale(1.1) rotate(5deg);
}

.criteria-card__icon svg {
    width: 32px;
    height: 32px;
}

.criteria-card__title {
    margin: 0 0 0.75rem;
    color: var(--card-color);
    font-size: 1.1rem;
    font-weight: 700;
}

.criteria-card__text {
    margin: 0;
    font-size: 0.9rem;
    color: var(--color-text-muted);
    line-height: 1.5;
}

/* Criteria card color modifiers */
.criteria-card--primary { --check-bg: linear-gradient(135deg, rgba(128,36,112,0.15), rgba(128,36,112,0.05)); --card-color: #802470; --check-shadow: rgba(128,36,112,0.15); }
.criteria-card--secondary { --check-bg: linear-gradient(135deg, rgba(45,43,113,0.15), rgba(45,43,113,0.05)); --card-color: #2D2B71; --check-shadow: rgba(45,43,113,0.15); }
.criteria-card--tertiary { --check-bg: linear-gradient(135deg, rgba(4,124,165,0.15), rgba(4,124,165,0.05)); --card-color: #047CA5; --check-shadow: rgba(4,124,165,0.15); }

/* --- Lab Card (study cards) --- */
.grid-labs {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
    gap: 1.25rem;
    max-width: 1000px;
    margin: 2rem auto 0;
}

.lab-card {
    background: #fff;
    border-radius: 16px;
    padding: 1.5rem;
    box-shadow: 0 4px 6px rgba(0,0,0,0.04), 0 10px 40px rgba(0,0,0,0.08);
    border: 1px solid rgba(0,0,0,0.06);
    transition: all 0.3s ease;
}

.lab-card:hover {
    transform: translateY(-4px);
    box-shadow: 0 8px 30px rgba(0,0,0,0.1);
}

.lab-card__header {
    display: flex;
    align-items: center;
    gap: 1rem;
    margin-bottom: 0.75rem;
}

.lab-card__icon {
    width: 40px;
    height: 40px;
    background: var(--check-bg);
    border-radius: 10px;
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--card-color);
    flex-shrink: 0;
    box-shadow: 0 4px 12px var(--check-shadow);
}

.lab-card__icon svg {
    width: 20px;
    height: 20px;
}

.lab-card__title {
    margin: 0;
    font-size: 1rem;
    color: var(--color-text);
    font-weight: 600;
}

.lab-card__text {
    margin: 0;
    font-size: 0.85rem;
    color: var(--color-text-muted);
    line-height: 1.5;
}

/* Lab card color modifiers */
.lab-card--primary { --check-bg: linear-gradient(135deg, rgba(128,36,112,0.15), rgba(128,36,112,0.05)); --check-shadow: rgba(128,36,112,0.15); --card-color: #802470; }
.lab-card--secondary { --check-bg: linear-gradient(135deg, rgba(45,43,113,0.15), rgba(45,43,113,0.05)); --check-shadow: rgba(45,43,113,0.15); --card-color: #2D2B71; }
.lab-card--tertiary { --check-bg: linear-gradient(135deg, rgba(4,124,165,0.15), rgba(4,124,165,0.05)); --check-shadow: rgba(4,124,165,0.15); --card-color: #047CA5; }

/* --- Checklist Item --- */
.checklist-item {
    display: flex;
    gap: 0.75rem;
    align-items: center;
    padding: 0.5rem 0;
    transition: transform 0.2s ease;
}

.checklist-item:hover {
    transform: translateX(6px);
}

.checklist-item__dot {
    flex-shrink: 0;
    width: 28px;
    height: 28px;
    background: var(--color-primary);
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: transform 0.3s ease;
}

.checklist-item:hover .checklist-item__dot {
    transform: scale(1.15);
}

.checklist-item__dot svg {
    width: 14px;
    height: 14px;
}

.checklist-item__text {
    font-size: 0.95rem;
    color: var(--color-text);
}

/* --- Specialist Card --- */
.grid-specialists {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
    gap: 2rem;
    max-width: 700px;
    margin: 2rem auto 0;
}

.specialist-card {
    background: #fff;
    border-radius: 20px;
    padding: 2rem;
    box-shadow: 0 4px 6px rgba(0,0,0,0.04), 0 10px 40px rgba(0,0,0,0.08);
    border-top: 4px solid var(--card-color);
    text-align: center;
    transition: all 0.4s cubic-bezier(0.175, 0.885, 0.32, 1.275);
}

.specialist-card:hover {
    transform: translateY(-8px);
    box-shadow: 0 12px 40px rgba(0,0,0,0.12);
}

.specialist-card__icon {
    width: 80px;
    height: 80px;
    margin: 0 auto 1.25rem;
    background: var(--check-bg);
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--card-color);
    transition: transform 0.3s ease;
}

.specialist-card:hover .specialist-card__icon {
    transform: scale(1.1) rotate(5deg);
}

.specialist-card__icon svg {
    width: 40px;
    height: 40px;
}

.specialist-card__name {
    margin: 0 0 0.5rem;
    color: var(--card-color);
    font-size: 1.3rem;
    font-weight: 700;
}

.specialist-card__desc {
    margin: 0;
    color: var(--color-text-muted);
    font-size: 0.95rem;
    line-height: 1.5;
}

/* Specialist card color modifiers */
.specialist-card--primary { --card-color: var(--color-primary, #802470); --check-bg: linear-gradient(135deg, rgba(128,36,112,0.15), rgba(128,36,112,0.05)); }
.specialist-card--tertiary { --card-color: #047CA5; --check-bg: linear-gradient(135deg, rgba(4,124,165,0.15), rgba(4,124,165,0.05)); }

/* --- Callout estudios (centrado con burbujas) --- */
.info-callout--centered .info-callout__content {
    text-align: center;
}

.info-callout--centered .info-callout__content h2 {
    margin: 0 0 1rem;
    font-size: 1.5rem;
    font-weight: 700;
}

.info-callout--centered .info-callout__content p {
    margin: 0 auto;
    font-size: 1.05rem;
    opacity: 0.95;
    line-height: 1.7;
    max-width: 600px;
}

/* Additional bubble positions */
.info-callout__bubble--bottom-right {
    bottom: 20%;
    left: 20%;
    width: 60px;
    height: 60px;
    animation-delay: 3s;
}

.info-callout__bubble--mid-right {
    top: 60%;
    right: 10%;
    width: 40px;
    height: 40px;
    animation-delay: 2.5s;
    animation-direction: reverse;
}

/* --- Compare Grid (Alergia vs UCE) --- */
.compare-grid {
    display: grid;
    grid-template-columns: 1fr auto 1fr;
    gap: 2rem;
    align-items: center;
    margin-top: 2rem;
}

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

.compare-card {
    background: #fff;
    border-radius: 20px;
    padding: 2rem;
    box-shadow: 0 4px 6px rgba(0,0,0,0.04), 0 10px 40px rgba(0,0,0,0.08);
    border: 1px solid rgba(0,0,0,0.06);
    text-align: center;
    transition: all 0.4s cubic-bezier(0.175, 0.885, 0.32, 1.275);
}

.compare-card:hover {
    transform: translateY(-6px);
    box-shadow: 0 12px 40px rgba(0,0,0,0.12);
}

.compare-card--highlight {
    border: 2px solid var(--color-primary);
}

/* Variante light: cards blancas sobre fondo primary */
.criteria-card--light {
    --card-color: rgba(var(--color-primary-rgb), 1);
    --check-bg: linear-gradient(135deg, rgba(var(--color-primary-rgb), 0.12), rgba(var(--color-primary-rgb), 0.04));
    --check-shadow: rgba(var(--color-primary-rgb), 0.15);
}

.criteria-card--light .compare-card__title {
    color: rgba(var(--color-primary-rgb), 1);
}

.criteria-card--light .compare-card__text {
    color: #555;
}

.compare-card__icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 80px;
    height: 80px;
    border-radius: 20px;
    margin-bottom: 1.25rem;
    color: var(--card-color);
    background: var(--check-bg);
    box-shadow: 0 4px 15px var(--check-shadow, rgba(0,0,0,0.1));
    transition: transform 0.3s ease;
}

.compare-card:hover .compare-card__icon {
    transform: scale(1.1);
}

.compare-card__icon svg {
    width: 40px;
    height: 40px;
}

.compare-card__title {
    margin: 0 0 0.75rem;
    font-size: 1.2rem;
    font-weight: 700;
    color: var(--card-color);
}

.compare-card__text {
    margin: 0;
    font-size: 0.9rem;
    color: var(--color-text-muted);
    line-height: 1.5;
}

.compare-vs {
    font-size: 1.5rem;
    font-weight: 700;
    color: var(--color-text-muted);
}

.content-section--primary .compare-vs {
    color: rgba(255,255,255,0.5);
}

/* --- Trigger Card (factores desencadenantes) --- */
.grid-triggers {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
    gap: 1.5rem;
    max-width: 950px;
    margin: 2.5rem auto 0;
}

/* Para secciones con 4 cards en línea (ej: causas) */
.grid-triggers--4col {
    grid-template-columns: repeat(4, 1fr);
    max-width: 1100px;
}

@media (max-width: 900px) {
    .grid-triggers--4col {
        grid-template-columns: repeat(2, 1fr);
    }
}

@media (max-width: 600px) {
    .grid-triggers--4col {
        grid-template-columns: 1fr;
    }
}

.trigger-card {
    background: #fff;
    border-radius: 20px;
    padding: 2rem 1.5rem;
    text-align: center;
    position: relative;
    overflow: hidden;
    box-shadow: 0 4px 6px rgba(0,0,0,0.04), 0 10px 30px rgba(0,0,0,0.08);
    border: 1px solid rgba(0,0,0,0.06);
    transition: all 0.4s cubic-bezier(0.175, 0.885, 0.32, 1.275);
    cursor: default;
}

.trigger-card::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    height: 4px;
    background: var(--trigger-gradient, var(--check-bg));
}

.trigger-card:hover {
    transform: translateY(-8px);
    box-shadow: 0 15px 40px var(--check-shadow, rgba(0,0,0,0.12));
}

.trigger-card:hover .trigger-card__icon {
    animation: shake-subtle 0.5s ease-in-out;
}

.trigger-card__header {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 0;
}

.trigger-card__icon {
    width: 72px;
    height: 72px;
    margin: 0 auto 1.25rem;
    background: var(--check-bg);
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--card-color);
    font-size: 1.5rem;
    box-shadow: 0 8px 20px var(--check-shadow, rgba(0,0,0,0.1));
    transition: transform 0.3s ease;
}

.trigger-card__icon svg {
    width: 30px;
    height: 30px;
}

.trigger-card__title,
.trigger-card__name {
    margin: 0 0 0.75rem;
    font-size: 1.15rem;
    font-weight: 700;
    color: var(--card-color);
}

.trigger-card__text {
    margin: 0;
    font-size: 0.9rem;
    color: var(--color-text-muted);
    line-height: 1.6;
}

/* Trigger card color modifiers */
.trigger-card--primary { --card-color: var(--color-primary, #802470); --check-bg: linear-gradient(135deg, rgba(128,36,112,0.15), rgba(128,36,112,0.05)); --check-shadow: rgba(128,36,112,0.2); --trigger-gradient: linear-gradient(90deg, var(--color-primary, #802470), var(--color-primary-light, #9A3D8A)); }
.trigger-card--secondary { --card-color: #2D2B71; --check-bg: linear-gradient(135deg, rgba(45,43,113,0.15), rgba(45,43,113,0.05)); --check-shadow: rgba(45,43,113,0.2); --trigger-gradient: linear-gradient(90deg, #2D2B71, #3D3B8A); }
.trigger-card--tertiary { --card-color: #047CA5; --check-bg: linear-gradient(135deg, rgba(4,124,165,0.15), rgba(4,124,165,0.05)); --check-shadow: rgba(4,124,165,0.2); --trigger-gradient: linear-gradient(90deg, #047CA5, #0891B2); }
.trigger-card--cold { --card-color: #047CA5; --check-bg: linear-gradient(135deg, rgba(4,124,165,0.15), rgba(4,124,165,0.05)); --check-shadow: rgba(4,124,165,0.2); --trigger-gradient: linear-gradient(90deg, #047CA5, #2D2B71); }
.trigger-card--sun { --card-color: #D97706; --check-bg: linear-gradient(135deg, rgba(245,158,11,0.15), rgba(245,158,11,0.05)); --check-shadow: rgba(245,158,11,0.2); --trigger-gradient: linear-gradient(90deg, #F59E0B, #D97706); }
.trigger-card--heat { --card-color: #EF4444; --check-bg: linear-gradient(135deg, rgba(239,68,68,0.15), rgba(239,68,68,0.05)); --check-shadow: rgba(239,68,68,0.2); --trigger-gradient: linear-gradient(90deg, #EF4444, #DC2626); }
.trigger-card--accent { --card-color: var(--color-accent, #047CA5); --check-bg: linear-gradient(135deg, rgba(4,124,165,0.15), rgba(4,124,165,0.05)); --check-shadow: rgba(4,124,165,0.2); --trigger-gradient: linear-gradient(90deg, var(--color-accent, #047CA5), var(--color-primary, #802470)); }

/* --- Autoimmune pill (inline badge) --- */
.pill-badge {
    display: inline-flex;
    align-items: center;
    gap: 0.75rem;
    background: rgba(255,255,255,0.2);
    padding: 1rem 1.5rem;
    border-radius: 30px;
    margin-top: 2rem;
}

.pill-badge svg {
    width: 24px;
    height: 24px;
}

.pill-badge__text {
    font-size: 0.95rem;
    font-weight: 600;
}

/* --- Autoimmune box (white glass panel inside dark section) --- */
.glass-box {
    background: rgba(255,255,255,0.15);
    border-radius: 16px;
    padding: 2rem;
    text-align: left;
}

.glass-box p {
    font-size: 1.05rem;
    margin: 0 0 1rem;
    opacity: 0.95;
}

.glass-box p:last-child {
    font-size: 1rem;
    margin: 0;
    opacity: 0.9;
}

/* --- Dark section text utilities --- */
.section-text--light {
    font-size: 1.15rem;
    opacity: 0.95;
    margin-bottom: 2rem;
}

/* --- Symptom Intro Card (ronchas/angioedema top cards) --- */
.grid-symptoms-intro {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
    gap: 2rem;
    max-width: 700px;
    margin: 0 auto;
}

.symptom-intro-card {
    text-align: center;
    padding: 2.5rem 2rem;
    background: #fff;
    border-radius: 20px;
    box-shadow: 0 4px 20px rgba(0,0,0,0.06);
    border-top: 4px solid var(--card-color);
    transition: all 0.4s cubic-bezier(0.175, 0.885, 0.32, 1.275);
}

.symptom-intro-card:hover {
    transform: translateY(-8px);
    box-shadow: 0 12px 40px rgba(0,0,0,0.12);
}

.symptom-intro-card__thumb {
    width: 90px;
    height: 90px;
    margin: 0 auto 1.25rem;
    border-radius: 50%;
    overflow: hidden;
    box-shadow: 0 4px 12px rgba(0,0,0,0.1);
    transition: transform 0.3s ease;
}

.symptom-intro-card:hover .symptom-intro-card__thumb {
    transform: scale(1.1);
}

.symptom-intro-card__thumb img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.symptom-intro-card__name {
    margin: 0 0 0.5rem;
    color: var(--card-color);
    font-size: 1.4rem;
    font-weight: 700;
}

.symptom-intro-card__sub {
    margin: 0;
    color: var(--color-text-muted);
    font-size: 0.95rem;
}

.symptom-intro-card--primary { --card-color: var(--color-primary); }
.symptom-intro-card--accent { --card-color: var(--color-accent); }

a.symptom-intro-card {
    text-decoration: none;
    color: inherit;
    cursor: pointer;
}

/* --- Feature Item (icon box + title + text) --- */
.feature-item {
    display: flex;
    gap: 1rem;
    align-items: center;
    transition: transform 0.3s ease;
}

.feature-item:hover {
    transform: translateX(8px);
}

.feature-item__icon {
    flex-shrink: 0;
    width: 48px;
    height: 48px;
    border-radius: 12px;
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--card-color);
    background: var(--check-bg, #fff);
    box-shadow: 0 4px 12px var(--check-shadow, rgba(0,0,0,0.08));
    transition: transform 0.3s ease;
}

.feature-item:hover .feature-item__icon {
    transform: scale(1.1) rotate(5deg);
}

.feature-item__icon svg {
    width: 24px;
    height: 24px;
}

.feature-item__title {
    margin: 0 0 0.25rem;
    font-size: 1.05rem;
    color: var(--color-text);
    font-weight: 600;
}

.feature-item__text {
    margin: 0;
    font-size: 0.9rem;
    color: var(--color-text-muted);
    line-height: 1.5;
}

/* Feature item on white bg (icon uses white bg + shadow) */
.feature-item--white { --check-bg: #fff; --check-shadow: rgba(0,0,0,0.08); }

/* Feature item with primary color bg */
.feature-item--primary { --card-color: var(--color-primary); --check-bg: #fff; --check-shadow: rgba(128,36,112,0.12); }

/* Feature item with accent color bg */
.feature-item--accent { --card-color: var(--color-accent); --check-bg: linear-gradient(135deg, rgba(var(--color-accent-rgb), 0.15), rgba(var(--color-accent-rgb), 0.05)); --check-shadow: rgba(4,124,165,0.12); }

/* --- Consult Card (urgency levels) --- */
.grid-consult {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(250px, 1fr));
    gap: 1.5rem;
    max-width: 900px;
    margin: 2rem auto 0;
}

.consult-card {
    background: #fff;
    border-radius: 16px;
    padding: 1.75rem;
    box-shadow: 0 2px 12px rgba(0,0,0,0.06);
    border-left: 4px solid var(--card-color);
    transition: all 0.4s cubic-bezier(0.175, 0.885, 0.32, 1.275);
    position: relative;
    overflow: hidden;
}

.consult-card::after {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    width: 0;
    height: 100%;
    background: linear-gradient(90deg, var(--card-bg-hover), transparent);
    transition: width 0.4s ease;
    z-index: 0;
}

.consult-card:hover::after {
    width: 100%;
}

.consult-card:hover {
    transform: translateY(-6px) scale(1.02);
    box-shadow: 0 12px 30px var(--check-shadow);
}

.consult-card__title {
    margin: 0 0 0.5rem;
    font-size: 1.05rem;
    font-weight: 700;
    color: var(--card-color);
    position: relative;
    z-index: 1;
}

.consult-card__text {
    margin: 0;
    font-size: 0.9rem;
    color: var(--color-text-muted);
    line-height: 1.5;
    position: relative;
    z-index: 1;
}

.consult-card--primary { --card-color: var(--color-primary, #802470); --check-shadow: rgba(128,36,112,0.15); --card-bg-hover: rgba(128,36,112,0.04); }
.consult-card--secondary { --card-color: #2D2B71; --check-shadow: rgba(45,43,113,0.15); --card-bg-hover: rgba(45,43,113,0.04); }
.consult-card--tertiary { --card-color: #047CA5; --check-shadow: rgba(4,124,165,0.15); --card-bg-hover: rgba(4,124,165,0.04); }

/* --- Scale Bar (UAS7 horizontal bars) --- */
.scale-panel {
    background: #fff;
    border-radius: 20px;
    padding: 2rem 2.5rem;
    box-shadow: 0 8px 30px rgba(0,0,0,0.08);
}

.scale-panel__title {
    text-align: center;
    margin: 0 0 2rem;
    color: var(--color-text);
    font-size: 1rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.05em;
}

.scale-bars {
    display: flex;
    flex-direction: column;
    gap: 0.875rem;
}

.scale-row {
    display: flex;
    align-items: center;
    gap: 1rem;
}

.scale-row__label {
    width: 70px;
    text-align: right;
    flex-shrink: 0;
    font-size: 1.1rem;
    font-weight: 700;
    color: var(--bar-color);
    white-space: nowrap;
}

.scale-row__bar {
    flex: 1;
    height: 40px;
    background: var(--bar-color);
    border-radius: 10px;
    display: flex;
    align-items: center;
    padding: 0 1.25rem;
    box-shadow: 0 2px 8px var(--bar-shadow);
    transform-origin: left center;
    animation: bar-grow 0.8s cubic-bezier(0.25, 0.46, 0.45, 0.94) both;
    animation-delay: var(--bar-delay, 0s);
    transition: transform 0.3s ease, box-shadow 0.3s ease;
}

.scale-row__bar:hover {
    transform: scaleX(1.03);
    box-shadow: 0 4px 16px var(--bar-shadow);
}

.scale-row__bar span {
    color: #fff;
    font-weight: 600;
    font-size: 0.9rem;
}

@keyframes bar-grow {
    from { transform: scaleX(0); opacity: 0; }
    to { transform: scaleX(1); opacity: 1; }
}

.scale-row--green { --bar-color: #10B981; --bar-shadow: rgba(16,185,129,0.3); --bar-delay: 0s; }
.scale-row--lime { --bar-color: #84CC16; --bar-shadow: rgba(132,204,22,0.3); --bar-delay: 0.15s; }
.scale-row--amber { --bar-color: #F59E0B; --bar-shadow: rgba(245,158,11,0.3); --bar-delay: 0.3s; }
.scale-row--red { --bar-color: #EF4444; --bar-shadow: rgba(239,68,68,0.3); --bar-delay: 0.45s; }

/* Scale footer meta badge */
.scale-meta {
    margin-top: 1.75rem;
    padding-top: 1.25rem;
    border-top: 1px solid #f0f0f0;
    text-align: center;
}

.scale-meta__badge {
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    background: rgba(16,185,129,0.1);
    color: #10B981;
    padding: 0.5rem 1rem;
    border-radius: 20px;
    font-size: 0.85rem;
    font-weight: 600;
}

.scale-meta__badge svg {
    width: 16px;
    height: 16px;
}

/* --- Gauge Panel (UCT semicircle) --- */
.gauge-panel {
    background: #fff;
    border-radius: 20px;
    padding: 2rem 2.5rem;
    box-shadow: 0 8px 30px rgba(0,0,0,0.08);
}

.gauge-panel__title {
    text-align: center;
    margin: 0 0 1.5rem;
    color: var(--color-text);
    font-size: 1rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.05em;
}

.gauge-wrapper {
    position: relative;
    width: 200px;
    height: 120px;
    margin: 0 auto;
}

.gauge-wrapper svg {
    width: 100%;
    height: 100%;
}

.gauge-progress {
    stroke-dasharray: 251;
    stroke-dashoffset: 251;
    animation: gauge-fill 1.5s cubic-bezier(0.25, 0.46, 0.45, 0.94) 0.3s forwards;
}

@keyframes gauge-fill {
    to { stroke-dashoffset: 0; }
}

.gauge-value {
    position: absolute;
    bottom: 5px;
    left: 50%;
    transform: translateX(-50%);
    text-align: center;
}

.gauge-value__number {
    font-size: 2.25rem;
    font-weight: 700;
    color: var(--color-primary);
    line-height: 1;
}

.gauge-value__label {
    font-size: 0.8rem;
    color: var(--color-text-muted);
}

.gauge-markers {
    display: flex;
    justify-content: space-between;
    margin-top: 0.5rem;
    padding: 0 0.5rem;
    max-width: 200px;
    margin-left: auto;
    margin-right: auto;
}

.gauge-markers span {
    font-size: 0.75rem;
    color: #666;
}

.gauge-legend {
    display: flex;
    justify-content: center;
    gap: 1.5rem;
    margin-top: 1.5rem;
}

.gauge-legend__item {
    display: flex;
    align-items: center;
    gap: 0.4rem;
}

.gauge-legend__dot {
    width: 10px;
    height: 10px;
    border-radius: 2px;
}

.gauge-legend__label {
    font-size: 0.75rem;
    color: #666;
}

/* --- Comparison List (UAS7 vs UCT) --- */
.compare-list-card {
    border: 2px solid var(--card-color);
    border-radius: 16px;
    padding: 2rem;
    background: #fff;
    transition: all 0.4s cubic-bezier(0.175, 0.885, 0.32, 1.275);
}

.compare-list-card:hover {
    transform: translateY(-6px);
    box-shadow: 0 12px 30px var(--check-shadow);
}

.compare-list-card__title {
    text-align: center;
    margin: 0 0 1.25rem;
    font-size: 1.3rem;
    font-weight: 700;
    color: var(--card-color);
}

.compare-list-card__icon {
    display: flex;
    justify-content: center;
    margin-bottom: 1.25rem;
}

.compare-list-card__icon-inner {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 64px;
    height: 64px;
    background: var(--check-bg);
    border-radius: 16px;
    color: var(--card-color);
    transition: transform 0.3s ease;
}

.compare-list-card:hover .compare-list-card__icon-inner {
    transform: scale(1.1) rotate(5deg);
}

.compare-list-card__icon-inner svg {
    width: 32px;
    height: 32px;
}

.compare-list {
    list-style: none;
    padding: 0;
    margin: 0;
}

.compare-list li {
    padding: 0.5rem 0;
    border-bottom: 1px solid #f0f0f0;
    display: flex;
    align-items: center;
    gap: 0.5rem;
    font-size: 0.9rem;
}

.compare-list li:last-child {
    border-bottom: none;
}

.compare-list__dot {
    color: var(--card-color);
    font-size: 1.2rem;
    line-height: 1;
}

/* --- Score Step (numbered circle + text inline) --- */
.score-step {
    display: flex;
    align-items: center;
    gap: 0.75rem;
    margin-bottom: 0.75rem;
}

.score-step:last-child {
    margin-bottom: 0;
}

.score-step__number {
    flex-shrink: 0;
    width: 28px;
    height: 28px;
    background: var(--color-primary);
    color: #fff;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 0.85rem;
    font-weight: 600;
    transition: transform 0.3s ease;
}

.score-step:hover .score-step__number {
    transform: scale(1.15);
}

/* --- Note text (footer notes) --- */
.note-text {
    text-align: center;
    margin-top: 2rem;
    font-size: 0.9rem;
    color: var(--color-text-muted);
    max-width: 600px;
    margin-left: auto;
    margin-right: auto;
    line-height: 1.6;
}

/* --- Spacing utilities --- */
.max-w-900 { max-width: 900px; margin-left: auto; margin-right: auto; }
.max-w-800 { max-width: 800px; margin-left: auto; margin-right: auto; }
.max-w-700 { max-width: 700px; margin-left: auto; margin-right: auto; }
.max-w-650 { max-width: 650px; margin-left: auto; margin-right: auto; }
.mt-2 { margin-top: 2rem; }
.mt-1-5 { margin-top: 1.5rem; }
.mt-2-5 { margin-top: 2.5rem; }
.mb-1-5 { margin-bottom: 1.5rem; }
.mb-2-5 { margin-bottom: 2.5rem; }
.gap-1 { gap: 1rem; }
.gap-1-25 { gap: 1.25rem; }
.gap-1-5 { gap: 1.5rem; }
.flex-col { display: flex; flex-direction: column; }
.order-1 { order: 1; }
.order-2 { order: 2; }
.line-height-17 { line-height: 1.7; }

/* --- Colores como clases (valores de fallback) --- */
.color-primary { color: var(--color-primary, #802470); }
.color-secondary { color: var(--color-secondary, #2D2B71); }
.color-tertiary { color: var(--color-tertiary, #047CA5); }
.color-accent { color: var(--color-accent, #f59e0b); }
.bg-primary { background: var(--color-primary, #802470); }
.bg-secondary { background: var(--color-secondary, #2D2B71); }
.bg-tertiary { background: var(--color-tertiary, #047CA5); }

/* --- Info Card Thumb (imagen pequeña dentro de info-card--media) --- */
.info-card__thumb {
    width: 120px;
    height: 120px;
    object-fit: cover;
    border-radius: 12px;
    box-shadow: 0 4px 12px rgba(0,0,0,0.1);
}

/* ═══════════════════════════════════════════ */
/* FOOTER LAYOUT                               */
/* ═══════════════════════════════════════════ */
.footer-grid {
    display: grid;
    grid-template-columns: 1.2fr 2.8fr;
    gap: 3rem;
    align-items: start;
}

.footer-brand {
    max-width: 280px;
}

.footer-links {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(150px, auto));
    gap: 1.5rem 2.5rem;
    justify-content: end;
}

@media (max-width: 1024px) {
    .footer-grid {
        grid-template-columns: 1fr;
        gap: 2rem;
    }
    .footer-links {
        justify-content: start;
    }
}

@media (max-width: 640px) {
    .footer-links {
        grid-template-columns: repeat(2, 1fr);
        gap: 1.5rem;
    }
}
