/* ======= DRA. MADIAN SCARLETT — NEUROCIRUJANA — Diseño Premium ======= */
@import url('https://fonts.googleapis.com/css2?family=Playfair+Display:ital,wght@0,400;0,600;0,700;1,400&family=Inter:wght@300;400;500;600;700&display=swap');

:root {
    /* Paleta Neurológica */
    --primary:        #0D1B2A;
    --primary-light:  #1A3550;
    --primary-mid:    #0F2640;
    --accent-teal:    #00C8E0;
    --accent-teal-dark: #0097B2;
    --accent-glow:    rgba(0, 229, 255, 0.15);
    --teal-soft:      rgba(0, 229, 255, 0.08);
    --bg-light:       #F0F5FB;
    --bg-white:       #FFFFFF;
    --text-dark:      #0D1B2A;
    --text-body:      #3A4A5C;
    --text-light:     #7A8EA0;
    --shadow-sm:  0 2px 8px  rgba(13, 27, 42, 0.07);
    --shadow-md:  0 4px 24px rgba(13, 27, 42, 0.11);
    --shadow-lg:  0 12px 48px rgba(13, 27, 42, 0.15);
    --radius:     14px;
    --radius-lg:  22px;
}

/* === RESET === */
*, *::before, *::after { box-sizing: border-box; }

body {
    font-family: 'Inter', sans-serif;
    color: var(--text-dark);
    line-height: 1.65;
    margin: 0; padding: 0;
    overflow-x: hidden;
}

h1, h2, h3 {
    font-family: 'Playfair Display', serif;
    color: var(--primary);
    line-height: 1.2;
    margin: 0 0 0.5em;
}

p { color: var(--text-body); margin: 0 0 1em; }
img { max-width: 100%; height: auto; }
a { text-decoration: none; color: inherit; }

/* === SCROLL REVEAL === */
.dr-reveal {
    opacity: 1; transform: translateY(0);
    transition: opacity 0.8s cubic-bezier(0.25, 0.46, 0.45, 0.94),
                transform 0.8s cubic-bezier(0.25, 0.46, 0.45, 0.94);
}
.js-ready .dr-reveal { opacity: 0; transform: translateY(32px); }
.js-ready .dr-reveal.dr-animate { opacity: 1; transform: translateY(0); }

/* ============================================================
   NAVBAR
   ============================================================ */
.site-navbar {
    position: fixed; top: 0; left: 0; right: 0; z-index: 1000;
    background: rgba(13, 27, 42, 0.97);
    border-bottom: 1px solid rgba(0, 229, 255, 0.1);
    box-shadow: 0 2px 20px rgba(0, 229, 255, 0.06);
    transition: padding 0.3s ease, box-shadow 0.3s ease;
    backdrop-filter: blur(12px);
}
.site-navbar.scrolled { box-shadow: 0 4px 30px rgba(0, 229, 255, 0.10); }
.site-navbar.scrolled .nav-inner { padding-top: 8px; padding-bottom: 8px; }
.site-navbar.scrolled .nav-logo img { height: 50px; }

.nav-inner {
    max-width: 1280px; margin: 0 auto;
    display: flex; align-items: center;
    justify-content: space-between;
    padding: 8px 24px; gap: 20px;
    transition: padding 0.3s ease;
}

.nav-logo {
    display: flex;
    align-items: center;
    gap: 12px;
    text-decoration: none;
    transition: opacity 0.2s;
}
.nav-logo:hover { opacity: 0.85; }

.nav-logo-icon {
    height: 52px;
    width: auto;
    display: block;
    transition: height 0.3s ease;
}
.site-navbar.scrolled .nav-logo-icon { height: 44px; }

.nav-logo-text {
    display: flex;
    flex-direction: column;
    gap: 1px;
    line-height: 1;
}
.nav-logo-name {
    font-family: 'Playfair Display', serif;
    font-size: 1.05rem;
    font-weight: 600;
    color: #fff;
    letter-spacing: 0.5px;
    white-space: nowrap;
}
.nav-logo-title {
    font-family: 'Inter', sans-serif;
    font-size: 0.62rem;
    font-weight: 500;
    color: rgba(0, 229, 255, 0.8);
    letter-spacing: 2.5px;
    text-transform: uppercase;
    white-space: nowrap;
}

.nav-logo img {
    height: 64px; width: auto;
    transition: height 0.3s ease;
    display: block;
}
/* Nuevo logo horizontal (ya incluye ícono + nombre) */
.nav-logo-img {
    height: 64px;
    width: auto;
    object-fit: contain;
}

.nav-links {
    display: flex; align-items: center; gap: 32px;
    flex: 1; justify-content: center;
}
.nav-links a {
    color: rgba(255,255,255,0.85);
    font-size: 0.95rem; font-weight: 500;
    transition: color 0.2s; white-space: nowrap;
    position: relative;
}
.nav-links a::after {
    content: ''; position: absolute; bottom: -4px; left: 0;
    width: 0; height: 1px;
    background: var(--accent-teal);
    transition: width 0.3s ease;
}
.nav-links a:hover { color: var(--accent-teal); }
.nav-links a:hover::after { width: 100%; }

.nav-contact {
    display: flex; align-items: center; gap: 14px; white-space: nowrap;
}

.nav-phone {
    display: flex; align-items: center; gap: 6px;
    color: rgba(255,255,255,0.75);
    font-size: 0.9rem; font-weight: 500; transition: color 0.2s;
}
.nav-phone:hover { color: var(--accent-teal); }

.nav-cta {
    display: inline-flex; align-items: center; gap: 7px;
    background: linear-gradient(135deg, var(--primary-light), var(--accent-teal));
    color: #fff !important;
    padding: 10px 20px; border-radius: 8px;
    font-weight: 700; font-size: 0.9rem;
    box-shadow: 0 4px 16px rgba(0,200,224,0.25);
    transition: transform 0.2s, box-shadow 0.2s;
}
.nav-cta:hover {
    transform: translateY(-2px) scale(1.04);
    box-shadow: 0 8px 26px rgba(0,200,224,0.4); color: #fff !important;
}

.nav-hamburger {
    display: none; background: none; border: none;
    color: var(--accent-teal); font-size: 1.6rem;
    cursor: pointer; padding: 4px 8px; flex-shrink: 0;
}

/* ──────────────────────────────────────────────────────────
   NAVBAR — RESPONSIVE MÓVIL
────────────────────────────────────────────────────────── */
@media (max-width: 860px) {

    /* Reducir padding del inner */
    .nav-inner {
        padding: 8px 16px;
        gap: 12px;
    }

    /* Logo más pequeño */
    .nav-logo-icon { height: 40px; }
    .nav-logo-name { font-size: 0.92rem; }
    .nav-logo-title { font-size: 0.58rem; letter-spacing: 2px; }

    /* Ocultar el número de teléfono en móvil */
    .nav-phone { display: none; }

    /* Los links van en menú desplegable */
    .nav-links {
        display: none;               /* Oculto por defecto */
        position: fixed;
        top: 64px;                   /* Altura del navbar */
        left: 0; right: 0;
        background: rgba(5, 14, 28, 0.98);
        backdrop-filter: blur(20px);
        flex-direction: column;
        align-items: center;
        gap: 0;
        padding: 0;
        z-index: 999;
        border-bottom: 1px solid rgba(0,229,255,0.12);
        box-shadow: 0 8px 30px rgba(0,0,20,0.5);
    }
    .nav-links.open { display: flex; }
    .nav-links a {
        width: 100%;
        text-align: center;
        padding: 18px 24px;
        font-size: 1rem;
        border-bottom: 1px solid rgba(255,255,255,0.05);
    }
    .nav-links a:last-child { border-bottom: none; }
    .nav-links a::after { display: none; } /* sin underline en móvil */

    /* El botón "Agendar Cita" más pequeño */
    .nav-cta {
        padding: 8px 14px;
        font-size: 0.8rem;
        gap: 5px;
    }
    .nav-cta svg { width: 14px; height: 14px; }

    /* Mostrar hamburguesa */
    .nav-hamburger { display: block; }

    /* Ocultar el SVG del botón WhatsApp en nav para ganar espacio */
    .nav-contact { gap: 8px; }
}

/* Extra pequeño (iPhone SE, etc.) */
@media (max-width: 400px) {
    .nav-logo-name { font-size: 0.82rem; }
    .nav-logo-title { display: none; }   /* Ocultar "NEUROCIRUJANA" si no cabe */
    .nav-cta span { display: none; }     /* Mostrar solo el ícono del botón */
    .nav-logo-icon { height: 36px; }
}

/* ============================================================
   HERO — INSIDE THE BRAIN (Neuronas + Sinapsis + EEG)
   ============================================================ */

.hero-section {
    position: relative; min-height: 100vh;
    background: radial-gradient(ellipse at 30% 40%, #0a1628 0%, #050e1a 45%, #020810 100%);
    display: flex; align-items: center; justify-content: center;
    overflow: hidden; padding: 80px 20px 60px;
}

/* Capa de gradiente violet profundo */
.hero-neuro-bg {
    position: absolute; inset: 0;
    background:
        radial-gradient(ellipse at 20% 30%, rgba(123,79,212,0.12) 0%, transparent 55%),
        radial-gradient(ellipse at 80% 70%, rgba(0,229,255,0.07) 0%, transparent 50%),
        radial-gradient(ellipse at 55% 15%, rgba(123,79,212,0.06) 0%, transparent 40%);
    pointer-events: none; z-index: 0;
    animation: neuroBgShift 8s ease-in-out infinite alternate;
}
@keyframes neuroBgShift {
    0%   { opacity: 0.7; }
    100% { opacity: 1; }
}

/* Neuronas SVG animadas */
.neuron-field {
    position: absolute; inset: 0; z-index: 1; pointer-events: none; overflow: hidden;
}

/* Neurona individual = círculo glowante */
.neuron {
    position: absolute;
    border-radius: 50%;
    pointer-events: none;
}
.neuron-body {
    background: radial-gradient(circle at 35% 35%, rgba(0,229,255,0.9) 0%, rgba(0,180,220,0.6) 40%, rgba(0,100,160,0.2) 100%);
    border-radius: 50%;
    box-shadow: 0 0 12px rgba(0,229,255,0.7), 0 0 30px rgba(0,229,255,0.3), 0 0 60px rgba(0,229,255,0.1);
    animation: neuronPulse var(--pulse-dur, 3s) ease-in-out infinite;
    animation-delay: var(--pulse-delay, 0s);
}
@keyframes neuronPulse {
    0%, 100% { transform: scale(1); opacity: 0.7; box-shadow: 0 0 12px rgba(0,229,255,0.6), 0 0 30px rgba(0,229,255,0.2); }
    50%       { transform: scale(1.35); opacity: 1;  box-shadow: 0 0 20px rgba(0,229,255,0.9), 0 0 50px rgba(0,229,255,0.4), 0 0 80px rgba(0,229,255,0.15); }
}

/* Partículas (neurotransmisores) */
.neuro-particles { position: absolute; inset: 0; pointer-events: none; z-index: 2; overflow: hidden; }
.np {
    position: absolute;
    background: rgba(0,229,255,0.7);
    border-radius: 50%;
    opacity: 0;
    animation: floatNP var(--d,8s) ease-in-out var(--dl,0s) infinite;
}
.np.violet { background: rgba(157, 111, 239, 0.75); }
@keyframes floatNP {
    0%   { opacity: 0;    transform: translateY(100vh) scale(0); }
    15%  { opacity: 0.6; }
    85%  { opacity: 0.5; }
    100% { opacity: 0;    transform: translateY(-15vh) scale(1.2); }
}

/* Sinapsis SVG canvas */
.synapse-svg {
    position: absolute; inset: 0; width: 100%; height: 100%;
    z-index: 2; pointer-events: none; overflow: visible;
}
.synapse-line {
    fill: none;
    stroke: rgba(0,229,255,0.25);
    stroke-width: 0.8;
    stroke-dasharray: 400;
    stroke-dashoffset: 400;
    animation: synapseSignal var(--sd, 4s) linear var(--sdl, 0s) infinite;
}
.synapse-line.violet { stroke: rgba(123,79,212,0.3); }
@keyframes synapseSignal {
    0%   { stroke-dashoffset: 400; opacity: 0; }
    10%  { opacity: 1; }
    90%  { opacity: 1; }
    100% { stroke-dashoffset: 0; opacity: 0; }
}

/* EEG line removed — Neurocirujana, no cardiólogo */

/* Hero content */
.hero-content {
    position: relative; z-index: 10;
    text-align: center; max-width: 920px; width: 100%;
}
.hero-title {
    font-family: 'Playfair Display', serif !important;
    font-size: clamp(2.2rem, 5vw, 3.9rem) !important;
    font-weight: 700 !important; color: #FFFFFF !important;
    -webkit-text-fill-color: #FFFFFF !important;
    margin-bottom: 14px;
    text-shadow: 0 0 60px rgba(0,229,255,0.25), 0 2px 12px rgba(0,0,0,0.8);
    letter-spacing: 0.3px; line-height: 1.15;
}
.hero-subtitle {
    font-family: 'Inter', sans-serif !important;
    font-size: clamp(0.9rem, 1.8vw, 1.15rem) !important;
    color: rgba(0, 229, 255, 0.8) !important;
    -webkit-text-fill-color: rgba(0,229,255,0.8) !important;
    font-weight: 300 !important; margin-bottom: 20px;
    letter-spacing: 3px; text-transform: uppercase;
    text-shadow: 0 1px 8px rgba(0,0,0,0.6) !important;
}
.hero-specialty-tags {
    display: flex; gap: 10px; justify-content: center;
    flex-wrap: wrap; margin-bottom: 42px;
}
.hero-tag {
    background: rgba(0,229,255,0.1);
    border: 1px solid rgba(0,229,255,0.25);
    color: rgba(0,229,255,0.9);
    padding: 6px 16px; border-radius: 50px;
    font-size: 0.82rem; font-weight: 500; letter-spacing: 0.5px;
    backdrop-filter: blur(8px);
}

.hero-cta {
    display: inline-flex; align-items: center; gap: 10px;
    background: linear-gradient(135deg, var(--primary-light), var(--accent-teal));
    color: #FFFFFF; font-family: 'Inter', sans-serif;
    font-size: 1.1rem; font-weight: 700;
    padding: 18px 50px; border-radius: 50px;
    text-decoration: none; transition: all 0.3s ease;
    box-shadow: 0 8px 30px rgba(0,200,224,0.25);
    border: 1px solid rgba(0,200,224,0.3);
    text-transform: uppercase; letter-spacing: 1.5px;
}
.hero-cta:hover {
    transform: translateY(-3px) scale(1.04);
    box-shadow: 0 12px 40px rgba(0,200,224,0.5);
    color: #FFFFFF;
}
.hero-cta svg { width: 22px; height: 22px; }

/* === WAVE DIVIDER === */
.wave-divider { position: relative; margin-top: -2px; line-height: 0; z-index: 10; }
.wave-divider svg { display: block; width: 100%; height: 60px; }

/* ============================================================
   SECCIÓN LABELS — SHARED
   ============================================================ */
.section-center { text-align: center; margin-bottom: 50px; }
.section-label {
    display: inline-block;
    color: var(--accent-teal-dark);
    font-size: 0.78rem; font-weight: 700;
    letter-spacing: 3px; text-transform: uppercase;
    margin-bottom: 10px;
    position: relative;
}
.section-label::before, .section-label::after {
    content: '—'; margin: 0 8px; opacity: 0.5;
}
.section-title {
    font-size: clamp(1.7rem, 3vw, 2.3rem);
    color: var(--primary); margin-top: 0;
}

/* ============================================================
   AUTHORITY
   ============================================================ */
.authority-section { padding: 90px 20px; background: var(--bg-white); }
.authority-container {
    max-width: 1100px; margin: 0 auto;
    display: grid; grid-template-columns: 1fr 1.2fr;
    gap: 60px; align-items: center;
}
.authority-photo-wrapper { position: relative; }
.authority-photo {
    width: 100%; max-width: 420px;
    border-radius: var(--radius-lg); box-shadow: var(--shadow-lg);
    border: 3px solid rgba(0,229,255,0.12);
}
.authority-badge {
    position: absolute; bottom: -16px; right: -16px;
    background: linear-gradient(135deg, var(--primary), var(--primary-light));
    color: #fff; padding: 12px 20px; border-radius: var(--radius);
    font-family: 'Inter', sans-serif; font-size: 0.82rem; font-weight: 600;
    box-shadow: var(--shadow-md); display: flex; align-items: center; gap: 8px;
    border: 1px solid rgba(0,229,255,0.2);
}
.authority-badge svg { width: 18px; height: 18px; color: var(--accent-teal-dark); stroke: var(--accent-teal-dark); }

.authority-info h2 { font-size: clamp(1.6rem, 3vw, 2.2rem); margin-bottom: 8px; }
.authority-specialty {
    color: var(--accent-teal-dark); font-weight: 600; font-size: 1.05rem;
    margin-bottom: 20px; display: block;
}
.authority-text { font-size: 1.05rem; margin-bottom: 24px; }

/* Cédulas grid */
.cedulas-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 12px; margin-bottom: 28px; }
.cedula-item {
    background: var(--bg-light); border-radius: var(--radius); padding: 14px;
    border: 1px solid rgba(0,229,255,0.1); text-align: center;
    transition: border-color 0.25s ease, transform 0.25s ease;
}
.cedula-item:hover { border-color: rgba(0,229,255,0.35); transform: translateY(-2px); }
.cedula-label { font-size: 0.72rem; font-weight: 600; color: var(--text-light); text-transform: uppercase; letter-spacing: 0.5px; margin-bottom: 6px; }
.cedula-number { font-family: 'Playfair Display', serif; font-size: 1.05rem; color: var(--primary); font-weight: 700; }

/* Trust badges */
.trust-badges { display: flex; gap: 12px; flex-wrap: wrap; margin-bottom: 28px; }
.trust-badge {
    display: flex; align-items: center; gap: 10px;
    background: var(--bg-light); border: 1px solid rgba(0,0,0,0.06);
    border-radius: var(--radius); padding: 10px 16px;
    transition: box-shadow 0.2s, border-color 0.2s;
    cursor: pointer;
}
.trust-badge:hover { box-shadow: var(--shadow-md); border-color: rgba(0,229,255,0.2); }

.trust-badge-num { font-size: 0.82rem; font-weight: 600; color: var(--primary); }
.trust-badge-stars { display: flex; align-items: center; gap: 2px; }
.trust-badge-stars span { font-size: 0.75rem; color: var(--text-light); margin-left: 4px; }

/* Auth CTA */
.authority-cta {
    display: inline-flex; align-items: center; gap: 8px;
    background: linear-gradient(135deg, var(--primary), var(--accent-teal));
    color: #fff; padding: 14px 36px; border-radius: 50px;
    font-size: 0.95rem; font-weight: 700;
    box-shadow: 0 8px 24px rgba(0,151,178,0.3);
    transition: all 0.3s ease;
    border: 1px solid rgba(0,200,224,0.15);
}
.authority-cta:hover { transform: translateY(-2px) scale(1.03); box-shadow: 0 12px 36px rgba(0,151,178,0.45); color: #fff; }
.authority-cta svg { width: 20px; height: 20px; }

/* ============================================================
   PRESS
   ============================================================ */
.press-section { padding: 80px 20px; background: var(--bg-light); }
.press-grid {
    max-width: 1100px; margin: 0 auto;
    display: grid; grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
    gap: 24px;
}
.press-card {
    background: var(--bg-white); border-radius: var(--radius-lg);
    overflow: hidden; box-shadow: var(--shadow-sm);
    border: 1px solid rgba(0,0,0,0.05);
    transition: transform 0.3s ease, box-shadow 0.3s ease;
    display: block;
}
.press-card:hover { transform: translateY(-6px); box-shadow: var(--shadow-md); }
.press-card img { width: 100%; height: 200px; object-fit: cover; display: block; }
.press-card-body { padding: 20px; }
.press-card-source {
    display: flex; align-items: center; gap: 6px;
    color: var(--accent-teal-dark); font-size: 0.8rem; font-weight: 700;
    text-transform: uppercase; letter-spacing: 1px; margin-bottom: 10px;
}
.press-card-source svg { width: 14px; height: 14px; stroke: var(--accent-teal-dark); }
.press-card-title { font-family: 'Playfair Display', serif; font-size: 1.1rem; color: var(--primary); line-height: 1.35; margin-bottom: 14px; }
.press-card-readmore {
    display: flex; align-items: center; gap: 6px;
    color: var(--accent-teal-dark); font-size: 0.85rem; font-weight: 600;
    transition: gap 0.2s;
}
.press-card:hover .press-card-readmore { gap: 10px; }

/* ============================================================
   EXPERIENCE + GALLERY
   ============================================================ */
.experience-section { padding: 90px 20px; background: var(--bg-white); }
.experience-container {
    max-width:1200px; margin:0 auto;
    display:grid; grid-template-columns:1fr 1fr; gap:50px; align-items:start;
}

/* Accordion */
.exp-category {
    border: 1px solid rgba(0,229,255,0.1);
    border-radius: var(--radius); overflow:hidden; margin-bottom:14px;
    background: var(--bg-light); transition: border-color 0.3s;
}
.exp-category:hover { border-color: rgba(0,229,255,0.25); }
.exp-category-title {
    display:flex; align-items:center; gap:12px;
    padding:18px 20px; cursor:pointer; font-weight:600;
    font-size:1rem; color:var(--primary);
    transition:background 0.2s, color 0.2s;
}
.exp-category-title svg:first-child { width:20px; height:20px; stroke:var(--accent-teal); flex-shrink:0; }
.exp-chevron { margin-left:auto; transition:transform 0.3s ease; stroke:var(--text-light); }
.exp-category.active .exp-chevron { transform:rotate(180deg); }
.exp-category.active .exp-category-title { color:var(--accent-teal-dark); }

.exp-list-wrapper { max-height:0; overflow:hidden; transition:max-height 0.4s ease; }
.exp-category.active .exp-list-wrapper { max-height:600px; }

.exp-list { list-style:none; margin:0; padding:0 20px 16px 52px; }
.exp-list li {
    padding:7px 0; border-bottom:1px solid rgba(0,229,255,0.07);
    font-size:0.95rem; color:var(--text-body); position:relative;
}
.exp-list li::before { content:'›'; color:var(--accent-teal-dark); position:absolute; left:-18px; font-size:1.1rem; }
.exp-list li:last-child { border-bottom:none; }

.logros-grid { padding:0 20px 16px; display:flex; flex-direction:column; gap:10px; }
.logro-badge {
    display:flex; align-items:flex-start; gap:10px;
    background: rgba(0,151,178,0.06); border-radius:10px; padding:12px 14px;
    border-left:3px solid var(--accent-teal-dark); font-size:0.9rem; color:var(--text-body);
}
.logro-badge svg { width:16px; height:16px; stroke:var(--accent-teal-dark); flex-shrink:0; margin-top:2px; }

/* Gallery masonry */
.gallery-masonry {
    columns:2; column-gap:14px;
}
.gallery-masonry img {
    display:block; width:100%; margin-bottom:12px;
    border-radius:10px; object-fit:cover;
    transition:transform 0.3s ease, box-shadow 0.3s ease;
    cursor:zoom-in;
}
.gallery-masonry img:hover { transform:scale(1.02); box-shadow:var(--shadow-md); }

/* ============================================================
   BLOG
   ============================================================ */
.blog-section { padding:80px 20px; background:var(--bg-light); }
.blog-grid {
    max-width:1100px; margin:0 auto;
    display:grid; grid-template-columns:repeat(auto-fit, minmax(300px, 1fr)); gap:24px;
}
.blog-card {
    background:var(--bg-white); border-radius:var(--radius-lg);
    overflow:hidden; box-shadow:var(--shadow-sm);
    border:1px solid rgba(0,0,0,0.05);
    transition:transform 0.3s ease, box-shadow 0.3s ease; display:block;
}
.blog-card:hover { transform:translateY(-6px); box-shadow:var(--shadow-md); }
.blog-card-img { width:100%; height:200px; object-fit:cover; display:block; background:var(--bg-light); }
.blog-card-body { padding:22px; }
.blog-card-date { font-size:0.78rem; color:var(--accent-teal-dark); font-weight:600; text-transform:uppercase; letter-spacing:1px; margin-bottom:8px; }
.blog-card-title { font-family:'Playfair Display',serif; font-size:1.15rem; color:var(--primary); margin-bottom:10px; line-height:1.35; }
.blog-card-excerpt { font-size:0.9rem; color:var(--text-body); margin-bottom:14px; }
.blog-card-link { color:var(--primary-light); font-size:0.9rem; font-weight:600; transition:color 0.2s; }
.blog-card:hover .blog-card-link { color:var(--accent-teal-dark); }
.blog-btn-wrapper { text-align:center; margin-top:44px; }

/* ============================================================
   TESTIMONIALS
   ============================================================ */
.testimonials-section { padding:80px 20px; background:var(--bg-white); }
.testimonials-header { text-align:center; margin-bottom:50px; }
.google-rating-badge {
    display:inline-flex; align-items:center; gap:12px;
    background:var(--bg-light); border:1px solid rgba(0,0,0,0.07);
    border-radius:50px; padding:10px 22px; margin-bottom:24px;
}
.google-logo { width:28px; height:28px; }
.google-rating-text { font-weight:700; font-size:0.95rem; color:var(--primary); }
.google-stars { display:flex; gap:2px; }
.google-stars svg, .testimonial-stars svg { width:16px; height:16px; fill:#FBBC04; }

.testimonials-grid {
    max-width:1100px; margin:0 auto;
    display:grid; grid-template-columns:repeat(auto-fit, minmax(300px, 1fr)); gap:22px;
}
.testimonial-card {
    background:var(--bg-light); border-radius:var(--radius-lg);
    padding:26px; border:1px solid rgba(0,229,255,0.08);
    box-shadow:var(--shadow-sm);
    transition:transform 0.3s ease, box-shadow 0.3s ease;
}
.testimonial-card:hover { transform:translateY(-4px); box-shadow:var(--shadow-md); border-color:rgba(0,229,255,0.2); }
.testimonial-google-mark {
    display:flex; align-items:center; gap:6px;
    font-size:0.78rem; color:var(--text-light); font-weight:600; margin-bottom:12px;
}
.testimonial-google-mark img { width:14px; height:14px; }
.testimonial-stars { display:flex; gap:2px; margin-bottom:12px; }
.testimonial-text { font-style:italic; font-size:0.95rem; color:var(--text-body); margin-bottom:18px; line-height:1.65; }
.testimonial-author { display:flex; align-items:center; gap:12px; }
.testimonial-avatar {
    width:40px; height:40px; border-radius:50%;
    background:linear-gradient(135deg,var(--primary-light),var(--accent-teal));
    display:flex; align-items:center; justify-content:center;
    color:#fff; font-weight:700; font-size:1rem;
}
.testimonial-name { font-weight:600; font-size:0.9rem; color:var(--primary); }
.testimonial-date { font-size:0.8rem; color:var(--text-light); }
.testimonials-btn-wrapper { text-align:center; margin-top:44px; }

/* ============================================================
   SHARED BUTTONS
   ============================================================ */
.btn-outline {
    display:inline-flex; align-items:center; gap:8px;
    border:2px solid var(--primary); color:var(--primary);
    padding:14px 36px; border-radius:50px;
    font-weight:700; font-size:0.95rem; transition:all 0.3s ease;
}
.btn-outline:hover { background:var(--primary); color:#fff; transform:translateY(-2px); box-shadow:var(--shadow-md); }
.btn-outline svg { transition:transform 0.2s; }
.btn-outline:hover svg { transform:translateX(4px); }

/* ============================================================
   FOOTER
   ============================================================ */
.site-footer {
    background:var(--primary); color:rgba(255,255,255,0.85);
    padding:70px 24px 0;
}
.footer-inner {
    max-width:1100px; margin:0 auto;
    display:grid; grid-template-columns:1fr 1fr 1fr; gap:50px;
    padding-bottom:50px; border-bottom:1px solid rgba(0,229,255,0.1);
}
.footer-col-title {
    font-family:'Playfair Display',serif; color:#fff;
    font-size:1.1rem; margin-bottom:20px;
}

.footer-loc-card {
    display:flex; align-items:flex-start; gap:14px;
    padding:14px; border-radius:var(--radius);
    background:rgba(255,255,255,0.04); border:1px solid rgba(0,229,255,0.1);
    cursor:pointer; transition:background 0.2s, border-color 0.2s; margin-bottom:12px;
}
.footer-loc-card:hover { background:rgba(0,229,255,0.07); border-color:rgba(0,229,255,0.25); }
.footer-loc-icon { flex-shrink:0; color:var(--accent-teal); }
.footer-loc-icon svg { stroke:var(--accent-teal); }
.footer-loc-name { font-weight:700; font-size:0.95rem; color:#fff; margin-bottom:4px; }
.footer-loc-addr { font-size:0.82rem; color:rgba(255,255,255,0.55); line-height:1.5; }

.footer-prices { width:100%; border-collapse:collapse; }
.footer-prices tr { border-bottom:1px solid rgba(255,255,255,0.07); }
.footer-prices tr:last-child { border-bottom:none; }
.footer-prices td { padding:10px 0; font-size:0.9rem; color:rgba(255,255,255,0.75); }
.footer-prices td:last-child { text-align:right; color:var(--accent-teal); font-weight:600; }

.footer-wa-btn {
    display:inline-flex; align-items:center; gap:10px;
    background:#25D366; color:#fff;
    padding:12px 22px; border-radius:50px;
    font-weight:700; font-size:0.95rem;
    transition:opacity 0.2s, transform 0.2s;
    margin-bottom:22px;
}
.footer-wa-btn svg { width:20px; height:20px; }
.footer-wa-btn:hover { opacity:0.9; transform:translateY(-2px); color:#fff; }

.footer-sched h4 { font-family:'Playfair Display',serif; color:#fff; font-size:0.95rem; margin:0 0 6px; }
.footer-sched p { font-size:0.87rem; color:rgba(255,255,255,0.6); margin:0 0 3px; }

.footer-bottom {
    max-width:1100px; margin:0 auto;
    padding:22px 0 8px; font-size:0.84rem; color:rgba(255,255,255,0.4);
}
.footer-cedulas-text {
    max-width:1100px; margin:0 auto;
    padding:0 0 20px; font-size:0.8rem; color:rgba(255,255,255,0.3);
}

/* Map modals */
.map-modal-overlay {
    display:none; position:fixed; inset:0; z-index:9000;
    background:rgba(0,0,0,0.75); align-items:center; justify-content:center;
    backdrop-filter:blur(4px);
}
.map-modal-overlay.active { display:flex; }
.map-modal {
    background:#fff; border-radius:var(--radius-lg);
    width:min(720px, 95vw); overflow:hidden;
    box-shadow:0 30px 80px rgba(0,0,0,0.5); position:relative;
}
.map-modal-close {
    position:absolute; top:12px; right:14px; z-index:2;
    background:var(--primary); color:#fff;
    border:none; font-size:1.4rem; cursor:pointer;
    width:34px; height:34px; border-radius:50%;
    display:flex; align-items:center; justify-content:center; line-height:1;
}
.map-modal-close:hover { background:var(--accent-violet); }
.map-modal-title { padding:18px 20px 4px 20px; font-family:'Playfair Display',serif; font-size:1.1rem; color:var(--primary); font-weight:700; }
.map-modal-addr { padding:0 20px 14px; font-size:0.88rem; color:var(--text-light); }
.map-modal iframe { width:100%; height:340px; border:none; display:block; }

/* Floating buttons */
.float-social { position:fixed; bottom:28px; right:24px; z-index:900; display:flex; flex-direction:column; gap:12px; }
.float-btn {
    display:flex; align-items:center; gap:8px;
    color:#fff; border-radius:50px; padding:12px 20px;
    font-weight:700; font-size:0.9rem;
    box-shadow:0 6px 24px rgba(0,0,0,0.3); transition:all 0.25s ease;
    white-space:nowrap;
}
.float-btn:hover { transform:translateY(-3px) scale(1.05); box-shadow:0 10px 32px rgba(0,0,0,0.4); color:#fff; }
.float-wa  { background:#25D366; }
.float-ig  { background:linear-gradient(135deg,#f09433,#e6683c,#dc2743,#cc2366,#bc1888); }
.float-label { font-size:0.85rem; }

/* =====================================================
   BLOG.PHP + ARTICULO.PHP + TESTIMONIOS.PHP SHARED
   ===================================================== */
.page-hero {
    padding:120px 24px 70px;
    background:linear-gradient(135deg, var(--primary) 0%, var(--primary-light) 100%);
    text-align:center; position:relative; overflow:hidden;
}
.page-hero::before {
    content:''; position:absolute; inset:0;
    background:radial-gradient(ellipse at 50% 50%, rgba(0,229,255,0.08) 0%, transparent 60%);
    pointer-events:none;
}
.page-hero h1 { color:#fff; font-size:clamp(1.8rem,4vw,2.8rem); margin-bottom:12px; }
.page-hero p { color:rgba(255,255,255,0.7); font-size:1rem; max-width:600px; margin:0 auto; }
.page-hero .section-label { color:var(--accent-teal); }
.page-hero .section-label::before, .page-hero .section-label::after { color:rgba(0,229,255,0.4); }

/* Category badges */
.cat-badges { display:flex; gap:10px; justify-content:center; flex-wrap:wrap; margin-top:18px; }
.cat-badge {
    background:rgba(0,151,178,0.12); border:1px solid rgba(0,151,178,0.3);
    color:rgba(0,200,220,0.95); padding:6px 16px; border-radius:50px;
    font-size:0.8rem; font-weight:600; cursor:pointer;
    transition:background 0.2s;
}
.cat-badge:hover, .cat-badge.active { background:var(--accent-teal-dark); color:#fff; }

/* ============================================================
   BLOG PAGE
   ============================================================ */
.blog-page-section { padding:70px 24px 90px; background:var(--bg-white); }
.blog-page-grid {
    max-width:1100px; margin:0 auto;
    display:grid; grid-template-columns:repeat(auto-fill,minmax(300px,1fr)); gap:24px;
}
.blog-featured {
    max-width:1100px; margin:0 auto 44px;
    background:var(--bg-light); border-radius:var(--radius-lg);
    overflow:hidden; display:grid; grid-template-columns:1fr 1fr;
    box-shadow:var(--shadow-md); border:1px solid rgba(0,229,255,0.08);
}
.blog-featured img { width:100%; height:100%; object-fit:cover; display:block; }
.blog-featured-body { padding:40px; }
.blog-featured-tag { display:inline-block; background:var(--accent-teal); color:var(--primary); padding:4px 14px; border-radius:50px; font-size:0.78rem; font-weight:700; letter-spacing:1px; text-transform:uppercase; margin-bottom:16px; }
.blog-featured-title { font-family:'Playfair Display',serif; font-size:1.6rem; color:var(--primary); margin-bottom:14px; }
.blog-featured-excerpt { color:var(--text-body); margin-bottom:22px; }

/* ============================================================
   ARTICULO PAGE
   ============================================================ */
.art-layout {
    max-width:1100px; margin:0 auto;
    display:grid; grid-template-columns:1fr 340px; gap:40px;
    padding:60px 24px 90px; align-items:start;
}
.art-main { min-width: 0; }
.art-lead { font-size:1.15rem; color:var(--text-dark); font-weight:500; line-height:1.7; margin-bottom:30px; padding-bottom:30px; border-bottom:2px solid var(--bg-light); }
.art-body { font-size:1rem; color:var(--text-body); line-height:1.75; }
.art-body h2 { font-size:1.5rem; margin-top:32px; }
.art-body h3 { font-size:1.2rem; margin-top:24px; }
.art-body p { margin-bottom:18px; }
.art-body img { border-radius:var(--radius); box-shadow:var(--shadow-sm); margin:20px 0; }
.art-cta {
    margin-top:40px; padding:30px; border-radius:var(--radius-lg);
    background:linear-gradient(135deg,var(--primary),var(--primary-light));
    text-align:center; color:#fff;
}
.art-cta h3 { color:#fff; margin-bottom:10px; }
.art-cta p { color:rgba(255,255,255,0.7); margin-bottom:20px; }
.art-back { display:inline-flex; align-items:center; gap:6px; color:var(--accent-teal); font-weight:600; font-size:0.9rem; margin-top:28px; transition:gap 0.2s; }
.art-back:hover { gap:10px; }

.art-sidebar { min-width: 0; }
.sidebar-card { background:var(--bg-light); border-radius:var(--radius); padding:22px; margin-bottom:22px; border:1px solid rgba(0,229,255,0.08); }
.sidebar-card h3 { font-size:1rem; margin-bottom:16px; color:var(--primary); }
.sidebar-recent li { padding:10px 0; border-bottom:1px solid rgba(0,229,255,0.07); font-size:0.9rem; }
.sidebar-recent li:last-child { border-bottom:none; }
.sidebar-recent a { color:var(--primary); font-weight:500; transition:color 0.2s; }
.sidebar-recent a:hover { color:var(--accent-teal); }
.sidebar-dr-img { width:100%; border-radius:var(--radius); object-fit:cover; height:180px; display:block; margin-bottom:14px; }
.sidebar-cedulas { list-style:none; padding:0; margin:0; }
.sidebar-cedulas li { font-size:0.83rem; color:var(--text-body); padding:5px 0; display:flex; gap:6px; }
.sidebar-cedulas li::before { content:'✓'; color:var(--accent-teal); flex-shrink:0; }

/* ============================================================
   TESTIMONIOS PAGE
   ============================================================ */
.test-hero-stats { display:flex; align-items:center; gap:20px; justify-content:center; flex-wrap:wrap; margin-top:24px; }
.stat-big { font-size:3.5rem; font-weight:700; color:#fff; font-family:'Playfair Display',serif; line-height:1; }
.stat-label { font-size:0.9rem; color:rgba(255,255,255,0.65); margin-top:4px; }
.test-stars-big { display:flex; gap:3px; margin-top:8px; }
.test-stars-big svg { width:28px; height:28px; fill:#FBBC04; }
.test-grid-section { padding:70px 24px 90px; background:var(--bg-white); }
.test-grid {
    max-width:1100px; margin:0 auto;
    display:grid; grid-template-columns:repeat(auto-fill,minmax(300px,1fr)); gap:22px;
    margin-bottom:50px;
}
.test-leave-cta { max-width:600px; margin:0 auto; text-align:center; }
.test-leave-cta h2 { margin-bottom:14px; }
.test-leave-cta p { margin-bottom:24px; }
.pagination { display:flex; gap:6px; justify-content:center; margin-bottom:50px; flex-wrap:wrap; }
.pagination a, .pagination span {
    display:flex; align-items:center; justify-content:center;
    width:38px; height:38px; border-radius:50%; border:1px solid rgba(0,0,0,0.1);
    font-size:0.9rem; font-weight:600; transition:all 0.2s; color:var(--primary);
}
.pagination a:hover { background:var(--accent-teal); border-color:var(--accent-teal); color:var(--primary); }
.pagination .active { background:var(--primary); border-color:var(--primary); color:#fff; }

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width:1024px) {
    .experience-container { grid-template-columns:1fr; }
    .gallery-masonry { columns:3; }
    .art-layout { grid-template-columns:1fr; }
    .art-sidebar { order:-1; }
    .blog-featured { grid-template-columns:1fr; }
}

@media (max-width:768px) {
    .authority-container { grid-template-columns:1fr; }
    .authority-photo { max-width:340px; margin:0 auto; }
    .cedulas-grid { grid-template-columns:1fr 1fr; }
    .footer-inner { grid-template-columns:1fr; gap:36px; }

    .nav-links { display:none; flex-direction:column; position:absolute; top:100%; left:0; right:0; background:rgba(13,27,42,0.97); padding:20px; gap:0; border-bottom:1px solid rgba(0,229,255,0.1); }
    .nav-links.open { display:flex; }
    .nav-links a { padding:12px 0; border-bottom:1px solid rgba(0,229,255,0.07); }
    .nav-links a:last-child { border-bottom:none; }
    .nav-hamburger { display:flex; }
    .nav-inner { position:relative; }

    .gallery-masonry { columns:2; }
    .blog-featured { grid-template-columns:1fr; }
    .float-label { display:none; }
    .float-btn { padding:12px; border-radius:50%; }
}

@media (max-width:480px) {
    .hero-specialty-tags { gap:6px; }
    .hero-tag { font-size:0.76rem; padding:5px 12px; }
    .gallery-masonry { columns:2; }
    .cedulas-grid { grid-template-columns:1fr; }
    .test-hero-stats { flex-direction:column; }
}

/* ============================================================
   HERO BRAIN CANVAS — Cerebro 3D animado con Canvas
   ============================================================ */

.hero-brain-canvas {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    z-index: 3;
    pointer-events: none;
    display: block;
}

/* ============================================================
   SEGUROS ACEPTADOS — Ticker infinito
   ============================================================ */
.seguros-section {
    background: var(--bg-deep, #020B18);
    padding: 64px 0 56px;
    border-top: 1px solid rgba(0,229,255,0.08);
    overflow: hidden;
}
.seguros-container {
    max-width: 1100px;
    margin: 0 auto;
    text-align: center;
}
.seguros-header { margin-bottom: 40px; padding: 0 24px; }
.seguros-title {
    font-family: var(--font-heading);
    font-size: clamp(1.5rem, 3vw, 2rem);
    font-weight: 700;
    color: #fff;
    margin-bottom: 8px;
}
.seguros-sub {
    color: rgba(255,255,255,0.5);
    font-size: 0.95rem;
}

/* ── Ticker wrapper: mask de fade en los bordes ── */
.seguros-ticker-wrap {
    position: relative;
    width: 100%;
    overflow: hidden;
    padding: 24px 0;
    border-top: 1px solid rgba(255,255,255,0.06);
    border-bottom: 1px solid rgba(255,255,255,0.06);
    /* Fade suave en los bordes */
    -webkit-mask-image: linear-gradient(to right, transparent 0%, black 10%, black 90%, transparent 100%);
    mask-image: linear-gradient(to right, transparent 0%, black 10%, black 90%, transparent 100%);
}

/* ── Cinta que se mueve ── */
.seguros-ticker {
    display: flex;
    align-items: center;
    gap: 0;
    width: max-content;
    animation: tickerScroll 28s linear infinite;
}
.seguros-ticker:hover { animation-play-state: paused; }

@keyframes tickerScroll {
    0%   { transform: translateX(0); }
    100% { transform: translateX(-50%); /* 50% porque está duplicado */ }
}

/* ── Cada logo ── */
.seguro-item {
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 0 40px;
    flex-shrink: 0;
}
.seguro-item img {
    height: 52px;
    width: auto;
    display: block;
    object-fit: contain;
    /* Logos tienen fondo blanco — los ponemos sobre tarjetas */
    background: #fff;
    border-radius: 10px;
    padding: 10px 16px;
    box-sizing: content-box;
    opacity: 0.75;
    transition: opacity 0.3s, box-shadow 0.3s, transform 0.3s;
    filter: grayscale(30%);
}
.seguro-item img:hover {
    opacity: 1;
    filter: none;
    box-shadow: 0 4px 24px rgba(0,229,255,0.15);
    transform: scale(1.05);
}

.seguros-note {
    margin-top: 28px;
    padding: 0 24px;
    font-size: 0.82rem;
    color: rgba(255,255,255,0.28);
    letter-spacing: 0.3px;
}

/* ── Móvil: ticker más rápido (sensación de uno a la vez) ── */
@media (max-width: 600px) {
    .seguro-item { padding: 0 24px; }
    .seguro-item img { height: 38px; padding: 8px 12px; }
    .seguros-ticker { animation-duration: 18s; }
}


