/* ============================================================
    GRUPO VPG — Estilos Landing Page
   ============================================================ */

:root {
    --lime:       #96c93d;
    --lime-dark:  #7db52e;
    --navy:       #1b2f4e;
    --navy-light: #243d62;
    --slate:      #546879;
    --white:      #ffffff;
    --off-white:  #f8f9fa;
    --light-gray: #f0f2f5;
    --border:     #dde3ec;
    --text-dark:  #1a1a2e;
    --text-mid:   #444455;
    --text-muted: #6c757d;
    --shadow-sm:  0 2px 8px rgba(0,0,0,0.08);
    --shadow-md:  0 4px 20px rgba(0,0,0,0.12);
    --shadow-lg:  0 8px 40px rgba(0,0,0,0.16);
    --radius:     10px;
    --radius-lg:  18px;
    --transition: 0.28s ease;
}

*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{font-family:'Segoe UI',system-ui,-apple-system,sans-serif;color:var(--text-dark);background:var(--white);line-height:1.6;font-size:17px;font-weight:500}
/* Homepage: fondo oscuro para que nunca asome blanco entre secciones dark */
body.page-home{background:#0c1a2e}
/* Elimina cualquier background blanco que pueda asomar entre secciones oscuras */
.hero + .hero-svc-bridge,.hero~.hero-svc-bridge{background:transparent}

/* ---- NAVBAR ---- */
header {
    background: #254056;
    padding: 20px 40px;
    height: auto;
    min-height: 100vh;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: flex-start;
    box-shadow: var(--shadow-sm);
    position: fixed;
    top: 0;
    right: 0;
    width: 280px;
    gap: 30px;
    z-index: 1000;
    transition: right .3s ease;
}
header.open {
    right: 0;
}

.logo-compact {
    display: flex;
    align-items: center;
    gap: 10px;
    text-decoration: none;
    flex-shrink: 0;
    width: 100%;
    justify-content: center;
}

.logo-icon {
    width: 46px;
    height: 46px;
    background: var(--navy);
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--lime);
    font-weight: 900;
    font-size: 10px;
    text-align: center;
    line-height: 1.2;
    border: 2px solid var(--lime);
    flex-shrink: 0;
}

.logo-text {
    font-size: 14px;
    font-weight: 800;
    color: #ffffff;
    letter-spacing: -0.5px;
}

.logo-text span {
    color: var(--lime);
}

/* Logo imagen en cabecera */
.site-logo {
    display: block;
    height: auto;
    max-height: 50px;
    max-width: 140px;
    object-fit: contain;
}

/* Header canvas (solo index.php) */
#hdr-canvas {
    position: absolute;
    inset: 0;
    z-index: 0;
    pointer-events: none;
    display: block;
}

/* Asegurar que nav y logo queden por encima del canvas */
header .logo-compact,
header nav {
    position: relative;
    z-index: 1;
}

/* Wrapper del SVG animado en el logo */
#hdr-logo-wrap {
    height: 50px;
    max-width: 140px;
    display: flex;
    align-items: center;
}

#hdr-logo-wrap svg {
    display: block;
    height: 50px;
    max-width: 140px;
    width: auto;
}

/* Navegación vertical */
nav.nav-vertical {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 24px;
    width: 100%;
}

nav.nav-vertical a {
    text-decoration: none;
    color: rgba(255, 255, 255, 0.95);
    font-size: 16px;
    font-weight: 700;
    letter-spacing: 0.4px;
    text-transform: uppercase;
    padding-bottom: 3px;
    border-bottom: 2px solid transparent;
    transition: color var(--transition), border-color var(--transition);
    white-space: nowrap;
}

nav.nav-vertical a:hover,
nav.nav-vertical a.active {
    color: var(--lime);
    border-bottom-color: var(--lime);
}

.nav-right {
    display: flex;
    align-items: center;
    gap: 14px;
}

/* Selector de Idioma con Banderas */
.lang-selector {
    display: flex;
    gap: 0;
    align-items: center;
    justify-content: center;
    width: 100%;
    padding: 0;
}

.lang-flag-img {
    width: 60px;
    height: 60px;
    object-fit: contain;
    cursor: pointer;
    transition: all 0.3s ease;
    opacity: 0.6;
    filter: grayscale(20%);
}

.lang-flag-img:hover {
    opacity: 0.9;
    transform: scale(1.15);
    filter: grayscale(0%);
}

.btn-lang {
    display: flex;
    align-items: center;
    gap: 5px;
    background: transparent;
    border: 1.5px solid rgba(255, 255, 255, 0.12);
    border-radius: 20px;
    padding: 5px 12px;
    font-size: 12px;
    font-weight: 600;
    color: rgba(255, 255, 255, 0.95);
    cursor: pointer;
    transition: all var(--transition);
}

.btn-lang:hover {
    border-color: var(--lime);
    color: var(--lime);
}

.lang-flag-btn {
    background: transparent;
    border: none;
    cursor: pointer;
    padding: 0;
    width: 56px;
    height: 56px;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: transform 0.2s;
}

.lang-flag-btn:hover {
    transform: scale(1.1);
}

.lang-flag-btn img {
    width: 55px;
    height: 55px;
    object-fit: contain;
    display: block;
}

nav.nav-vertical .btn-lang {
    width: 100%;
    justify-content: center;
}

.btn-nav {
    background: transparent;
    border: 2px solid var(--lime);
    color: var(--lime);
    padding: 8px 22px;
    border-radius: 25px;
    font-size: 13px;
    font-weight: 700;
    cursor: pointer;
    transition: all var(--transition);
    text-decoration: none;
    white-space: nowrap;
    display: inline-flex;
    align-items: center;
    gap: 8px;
}

.btn-nav:hover {
    background: var(--lime);
    color: var(--white);
}

.btn-nav-vertical {
    width: 100%;
    justify-content: center;
    padding: 10px 16px;
    font-size: 12px;
}

/* Forzar color blanco en el texto y el icono del selector de idioma */
.btn-lang i,
.btn-lang span {
    color: #ffffff !important;
}

.btn-lang .lang-flag {
    width: 28px;
    height: 28px;
    object-fit: contain;
    display: block;
}

.btn-lang .flag-icon {
    width: 14px;
    height: 14px;
    object-fit: contain;
}

.btn-lang:hover i,
.btn-lang:hover span {
    color: #ffffff !important;
}

.menu-toggle {
    display: none;
    flex-direction: column;
    gap: 5px;
    cursor: pointer;
    padding: 10px 12px;
    position: fixed;
    top: 16px;
    right: 16px;
    z-index: 2001;
    background: var(--navy);
    border-radius: 8px;
    box-shadow: 0 2px 12px rgba(0,0,0,.3);
}

.menu-toggle span {
    width: 24px;
    height: 2.5px;
    background: #ffffff;
    border-radius: 2px;
    transition: all var(--transition);
}

.menu-toggle.open span:nth-child(1) {
    transform: rotate(45deg) translate(5px, 5px);
}

.menu-toggle.open span:nth-child(2) {
    opacity: 0;
}

.menu-toggle.open span:nth-child(3) {
    transform: rotate(-45deg) translate(5px, -5px);
}

/* En desktop el header ocupa 280px a la derecha */
body {
    margin-right: 280px;
    margin-left: 0;
}

/* ---- REDES SOCIALES NAV (VERTICAL) ---- */
.nav-social {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 12px;
    padding: 12px 0;
    border-top: 1px solid rgba(150, 201, 61, 0.15);
    border-bottom: 1px solid rgba(150, 201, 61, 0.15);
    margin: 8px 0;
}

.nav-social .social-link {
    width: 52px;
    height: 52px;
    border-radius: 14px;
    background: rgba(255, 255, 255, 0.1);
    border: 1px solid rgba(255, 255, 255, 0.15);
    display: flex;
    align-items: center;
    justify-content: center;
    color: #fff;
    font-size: 18px;
    transition: all var(--transition);
    text-decoration: none;
    position: relative;
}

.nav-social .social-link:hover {
    background: var(--lime);
    border-color: var(--lime);
    color: var(--navy);
    transform: scale(1.08);
}

.notification-badge {
    position: absolute;
    top: -6px;
    right: -6px;
    background: #ef4444;
    color: #fff;
    font-size: 13px;
    font-weight: 700;
    min-width: 28px;
    height: 28px;
    border-radius: 14px;
    display: flex;
    align-items: center;
    justify-content: center;
    opacity: 0;
    transform: scale(0.8);
    transition: all 0.3s ease;
    pointer-events: none;
}

.notification-badge.active {
    opacity: 1;
    transform: scale(1);
    animation: badgeAppear 0.5s ease-out forwards, badgePulse 1.5s ease-in-out 0.5s infinite;
    pointer-events: auto;
}

@keyframes badgeAppear {
    0% {
        opacity: 0;
        transform: scale(0.5);
    }
    100% {
        opacity: 1;
        transform: scale(1);
    }
}

@keyframes badgeBounce {
    0%, 100% { transform: scale(1) translateY(0); }
    30% { transform: scale(1.3) translateY(-5px); }
    50% { transform: scale(0.9) translateY(2px); }
    70% { transform: scale(1.1) translateY(-2px); }
}

@keyframes badgePulse {
    0%, 100% {
        transform: scale(1);
        box-shadow: 0 0 0 0 rgba(239, 68, 68, 0.6);
    }
    50% {
        transform: scale(1.1);
        box-shadow: 0 0 0 8px rgba(239, 68, 68, 0);
    }
}

/* ═══ VPG SPEED-DIAL ════════════════════════════════════ */
.vpg-speeddial {
    position: fixed;
    right: 50px;
    bottom: 30px;
    z-index: 1001;
    display: flex;
    flex-direction: row;
    align-items: flex-end;
    gap: 10px;
    pointer-events: none;
}
.vpg-speeddial > * { pointer-events: auto; }

/* Row: punto de pivote centrado sobre el toggle (avatar=150px → 75px desde cada borde) */
.vpg-sd-row {
    position: absolute;
    bottom: 75px;   /* centro vertical del avatar */
    right: 75px;    /* centro horizontal del avatar */
    width: 0;
    height: 0;
    pointer-events: none;
}
/* Cada ítem se posiciona absolutamente desde el pivote */
.vpg-sd-item {
    position: absolute;
    width: 65px;
    height: 65px;
    bottom: -32px;  /* centra el ítem (65px / 2) sobre el pivote */
    right: -32px;
    display: flex;
    align-items: center;
    justify-content: center;
    opacity: 0;
    visibility: hidden;
    transform: translate(0, 0) scale(.25);
    transition: opacity .22s ease var(--sd-d,0s),
                visibility .22s ease var(--sd-d,0s),
                transform .28s cubic-bezier(.34,1.56,.64,1) var(--sd-d,0s);
    pointer-events: none;
}
.vpg-speeddial.open .vpg-sd-item {
    opacity: 1;
    visibility: visible;
    pointer-events: auto;
    transform: translate(var(--sd-tx,0px), var(--sd-ty,0px)) scale(1);
}
/* Tooltip flotante */
.vpg-sd-tip {
    position: absolute;
    bottom: calc(100% + 8px);
    left: 50%;
    transform: translateX(-50%);
    background: rgba(12,24,38,.92);
    color: #fff;
    font-size: 11px;
    font-weight: 700;
    padding: 5px 12px;
    border-radius: 6px;
    white-space: nowrap;
    border: 1px solid rgba(255,255,255,.15);
    pointer-events: none;
    opacity: 0;
    transition: opacity .2s ease;
}
/* Siempre visible cuando el dial está abierto */
.vpg-speeddial.open .vpg-sd-item .vpg-sd-tip {
    opacity: 1;
}
/* Desktop: abanico hacia la izquierda → etiqueta al exterior (izquierda) de cada burbuja */
@media (min-width: 769px) {
    .vpg-sd-tip {
        bottom: auto;
        top: 50%;
        left: auto;
        right: calc(100% + 12px);
        transform: translateY(-50%);
    }
    /* WhatsApp va recto arriba → su etiqueta se pone encima del círculo */
    .vpg-sd-tip--top {
        top: auto;
        right: auto;
        left: 50%;
        bottom: calc(100% + 10px);
        transform: translateX(-50%);
    }
}
.vpg-sd-btn {
    width: 65px;
    height: 65px;
    border-radius: 50%;
    border: none;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 26px;
    cursor: pointer;
    text-decoration: none;
    flex-shrink: 0;
    box-shadow: 0 5px 18px rgba(0,0,0,.4);
    transition: transform .2s ease, box-shadow .2s ease;
}
.vpg-sd-btn:hover {
    transform: scale(1.18);
    box-shadow: 0 10px 26px rgba(0,0,0,.5);
}
.vpg-sd-phone { background:#1b2f4e; color:#96c93d; border:2px solid rgba(150,201,61,.4); }
.vpg-sd-form  { background:#1e3a5f; color:#60a5fa; border:2px solid rgba(96,165,250,.4); }
.vpg-sd-cv    { background:#2d1f4e; color:#c084fc; border:2px solid rgba(192,132,252,.4); }
.vpg-sd-wa    { background:#064e3b; color:#34d399; border:2px solid rgba(52,211,153,.4); }
.vpg-sd-phone:hover { background:#96c93d; color:#1b2f4e; border-color:#96c93d; }
.vpg-sd-form:hover  { background:#3b82f6; color:#fff;     border-color:#3b82f6; }
.vpg-sd-cv:hover    { background:#a855f7; color:#fff;     border-color:#a855f7; }
.vpg-sd-wa:hover    { background:#25D366; color:#fff;     border-color:#25D366; }

.vpg-sd-toggle {
    background: none;
    border: none;
    cursor: pointer;
    padding: 0;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 4px;
    flex-shrink: 0;
    transition: transform .3s cubic-bezier(.34,1.56,.64,1);
}
.vpg-sd-toggle:hover  { transform: scale(1.08); }
.vpg-sd-toggle.active { transform: scale(1.05); }
.vpg-sd-avatar {
    width: 150px;
    height: 150px;
    object-fit: contain;
    display: block;
}
@media (max-width: 768px) {
    .vpg-speeddial { left: 16px; right: auto; bottom: 18px; }
    .vpg-sd-row { bottom: 52px; left: 52px; right: auto; }
    .vpg-sd-item { bottom: -32px; left: -32px; right: auto; }
    .vpg-sd-avatar { width: 104px; height: 104px; }
}

/* ═══ VPG MODALES ════════════════════════════════════════ */
.vpg-modal-overlay {
    position: fixed;
    inset: 0;
    background: rgba(10,20,35,.65);
    backdrop-filter: blur(6px);
    z-index: 10000;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 20px;
    opacity: 0;
    visibility: hidden;
    transition: opacity .25s ease, visibility .25s;
}
.vpg-modal-overlay.open { opacity: 1; visibility: visible; }
.vpg-modal-box {
    background: #fff;
    border-radius: 20px;
    box-shadow: 0 20px 70px rgba(0,0,0,.3);
    position: relative;
    max-height: 92vh;
    overflow-y: auto;
    width: 100%;
    transform: scale(.88) translateY(16px);
    opacity: 0;
    transition: transform .3s cubic-bezier(.34,1.56,.64,1), opacity .3s ease;
}
.vpg-modal-overlay.open .vpg-modal-box { transform: scale(1) translateY(0); opacity: 1; }
.vpg-mcls {
    position: absolute;
    top: 14px; right: 14px;
    width: 34px; height: 34px;
    border-radius: 50%;
    border: 1px solid rgba(255,255,255,.3);
    background: rgba(255,255,255,.15);
    color: rgba(255,255,255,.85);
    font-size: 15px;
    cursor: pointer;
    display: flex; align-items: center; justify-content: center;
    transition: all .2s;
    z-index: 2;
}
.vpg-mcls:hover { background: rgba(255,255,255,.3); color: #fff; transform: rotate(90deg); }
.vpg-mcls-light { border-color: #e5e7eb; background: #f9fafb; color: #6b7280; }
.vpg-mcls-light:hover { background: #fee2e2; color: #ef4444; border-color: #fca5a5; }

/* ── Modal Teléfonos ── */
.vpg-phone-box { max-width: 660px; padding: 0; overflow: hidden; }
.vpg-ph-head {
    display: flex; align-items: center; gap: 18px;
    padding: 32px 36px 24px;
}
.vpg-ph-icon {
    width: 52px; height: 52px;
    border-radius: 14px;
    background: #1b2f4e; color: #96c93d;
    display: flex; align-items: center; justify-content: center;
    font-size: 22px; flex-shrink: 0;
}
.vpg-ph-head h2 { font-size: 21px; font-weight: 800; color: #1e293b; margin: 0; }
.vpg-ph-head h2 span { color: #96c93d; }
.vpg-ph-head p { font-size: 13px; color: #94a3b8; margin: 3px 0 0; }
.vpg-ph-sep { border: none; border-top: 1px solid #f1f5f9; margin: 0 36px 28px; }
.vpg-ph-cols {
    display: grid;
    grid-template-columns: 1fr 1px 1fr;
    grid-template-rows: auto auto;
    gap: 0 36px;
    padding: 0 36px 36px;
}
/* Fila superior — punta de pirámide, ocupa las 3 columnas del grid */
.vpg-ph-col--top {
    grid-column: 1 / -1;
    text-align: center;
    background: linear-gradient(135deg, #f0f7e6 0%, #e8f5d0 100%);
    border: 1.5px solid rgba(150,201,61,.35);
    border-radius: 14px;
    padding: 18px 24px 20px;
    margin-bottom: 24px;
}
.vpg-ph-col--top h3 {
    font-size: 11px !important;
    text-transform: uppercase;
    letter-spacing: .08em;
    color: #4a7c1f !important;
    margin-bottom: 6px !important;
}
.vpg-ph-col--top a {
    font-size: 28px !important;
    color: #1e6a2e !important;
    justify-content: center;
}
.vpg-ph-col--top a:hover { color: #155a24 !important; }
.vpg-ph-col--top p { text-align: center; font-size: 12px !important; color: #6b9a40 !important; margin-top: 5px !important; }
.vpg-ph-cols--center {
    grid-template-columns: 1fr;
    max-width: 360px;
    margin: 0 auto;
}
.vpg-ph-div { background: #e2e8f0; }
.vpg-ph-col h3 { font-size: 13px; font-weight: 700; color: #475569; margin: 0 0 8px; }
.vpg-ph-col h3:not(:first-child) { margin-top: 22px; }
.vpg-ph-col a {
    display: inline-flex; align-items: center; gap: 6px;
    font-size: 20px; font-weight: 800;
    color: #2563eb; text-decoration: none; line-height: 1.2;
    transition: color .2s;
}
.vpg-ph-col a:hover { color: #1d4ed8; }
.vpg-ph-col a.vpg-wa-lnk { color: #16a34a; font-size: 18px; }
.vpg-ph-col a.vpg-wa-lnk:hover { color: #15803d; }
.vpg-ph-col p { font-size: 11.5px; color: #94a3b8; margin: 4px 0 0; }
@media (max-width: 520px) {
    .vpg-ph-head { padding: 24px 20px 18px; }
    .vpg-ph-sep { margin: 0 20px 20px; }
    .vpg-ph-cols { grid-template-columns: 1fr; gap: 0; padding: 0 20px 24px; }
    .vpg-ph-div { display: none; }
    .vpg-ph-col a { font-size: 17px; }
    .vpg-ph-col--top { margin-bottom: 18px; }
    .vpg-ph-col--top a { font-size: 22px !important; }
}

/* ── Modal Formulario ── */
.vpg-form-box { max-width: 500px; padding: 0; overflow: hidden; }
.vpg-fh {
    display: flex; align-items: center; gap: 16px;
    padding: 26px 32px 20px;
    border-bottom: 1px solid #f1f5f9;
}
.vpg-fh-icon {
    width: 46px; height: 46px;
    border-radius: 13px;
    background: #1b2f4e; color: #96c93d;
    display: flex; align-items: center; justify-content: center;
    font-size: 20px; flex-shrink: 0;
}
.vpg-fh h2 { font-size: 17px; font-weight: 800; color: #1e293b; margin: 0; }
.vpg-fh p  { font-size: 12px; color: #94a3b8; margin: 2px 0 0; }
.vpg-form-inner { padding: 22px 32px 26px; }
.vpg-form-box .vpg-fg { display: flex; flex-direction: column; gap: 5px; margin-bottom: 14px; }
.vpg-form-box .vpg-row { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; }
.vpg-form-box .vpg-fg label {
    font-size: 10px; font-weight: 800;
    text-transform: uppercase; letter-spacing: .7px; color: #64748b;
}
.vpg-form-box .vpg-fg label span { color: #ef4444; }
.vpg-fi { position: relative; }
.vpg-fi > i { position: absolute; left: 12px; top: 50%; transform: translateY(-50%); color: #94a3b8; font-size: 13px; pointer-events: none; }
.vpg-fi > i.ta-i { top: 13px; transform: none; }
.vpg-form-box input,
.vpg-form-box select,
.vpg-form-box textarea {
    width: 100%; box-sizing: border-box;
    border: 1.5px solid #e2e8f0; border-radius: 10px;
    padding: 10px 12px 10px 36px;
    font-size: 13.5px; font-family: inherit; color: #1e293b; background: #fff;
    outline: none;
    transition: border-color .2s, box-shadow .2s;
}
.vpg-form-box textarea { min-height: 96px; resize: vertical; padding-left: 36px; }
.vpg-form-box input:focus,
.vpg-form-box select:focus,
.vpg-form-box textarea:focus { border-color: #96c93d; box-shadow: 0 0 0 3px rgba(150,201,61,.12); }
.vpg-submit-btn {
    width: 100%; padding: 13px;
    background: #1b2f4e; color: #fff;
    border: none; border-radius: 11px;
    font-size: 14px; font-weight: 700; cursor: pointer;
    display: flex; align-items: center; justify-content: center; gap: 8px;
    margin-top: 6px;
    transition: background .2s, transform .15s;
}
.vpg-submit-btn:hover { background: #254056; transform: translateY(-1px); }
.vpg-privacy {
    text-align: center; font-size: 11px; color: #94a3b8;
    margin-top: 10px;
    display: flex; align-items: center; justify-content: center; gap: 4px;
}
.vpg-privacy i { color: #96c93d; }
@media (max-width: 480px) {
    .vpg-fh { padding: 18px 18px 14px; }
    .vpg-form-inner { padding: 16px 18px 20px; }
    .vpg-form-box .vpg-row { grid-template-columns: 1fr; }
}

/* ── Modal WhatsApp ── */
.vpg-wa-box { max-width: 380px; padding: 0; overflow: hidden; }
.vpg-wa-hd {
    background: #075e54; padding: 20px 56px 18px 20px;
    color: #fff; display: flex; align-items: center; gap: 13px; position: relative;
}
.vpg-wa-hd-ico {
    width: 46px; height: 46px;
    background: rgba(255,255,255,.18); border-radius: 50%;
    display: flex; align-items: center; justify-content: center;
    font-size: 24px; flex-shrink: 0;
}
.vpg-wa-hd h2 { font-size: 16px; font-weight: 800; margin: 0; }
.vpg-wa-hd p  { font-size: 11.5px; color: rgba(255,255,255,.72); margin: 3px 0 0; }
.vpg-wa-bg {
    background: #e5ddd5;
    padding: 16px 16px 8px;
}
.vpg-wa-bubble {
    background: #dcf8c6;
    border-radius: 0 10px 10px 10px;
    padding: 9px 13px; font-size: 13.5px; color: #1e293b;
    display: inline-block; max-width: 82%; line-height: 1.5;
    box-shadow: 0 1px 3px rgba(0,0,0,.12);
}
.vpg-wa-opts { padding: 6px 16px 20px; display: flex; flex-direction: column; gap: 7px; }
.vpg-wa-opt {
    display: flex; align-items: center; gap: 12px;
    padding: 11px 13px; border-radius: 11px;
    border: 1.5px solid #e5e7eb;
    text-decoration: none; color: #1e293b;
    font-size: 13px; font-weight: 600; background: #fff;
    transition: all .2s;
}
.vpg-wa-opt:hover { background: #f0fdf4; border-color: #16a34a; color: #16a34a; transform: translateX(3px); }
.vpg-wa-opt-ico { color: #16a34a; font-size: 17px; width: 22px; text-align: center; flex-shrink: 0; }
.vpg-wa-opt span { flex: 1; }
.vpg-wa-opt-arr { color: #94a3b8; font-size: 11px; transition: color .2s, transform .2s; flex-shrink: 0; }
.vpg-wa-opt:hover .vpg-wa-opt-arr { color: #16a34a; transform: translateX(2px); }

/* ---- HERO PÁGINA INTERNA ---- */
.page-hero{background:#254056;padding:60px 60px 50px;text-align:center;color:#fff}
.page-hero .tag{display:inline-block;background:rgba(150,201,61,.15);color:var(--lime);border:1px solid rgba(150,201,61,.3);border-radius:20px;padding:4px 14px;font-size:11.5px;font-weight:700;letter-spacing:0.8px;text-transform:uppercase;margin-bottom:14px}
.page-hero h1{font-size:34px;font-weight:800;color:#fff}

/* ---- HERO ---- */
.hero {
    min-height: 100vh;
    display: flex;
    align-items: center;
    justify-content: center;
    position: relative;
    overflow: hidden;
    padding: 0;
    background: #1b2f4e;
}
.hero-video-bg{
    position:absolute;inset:0;
    width:100%;height:100%;
    object-fit:cover;
    z-index:0;
    pointer-events:none;
}
.hero-overlay{
    position:absolute;inset:0;
    background:
        linear-gradient(160deg, rgba(27,47,78,.88) 0%, rgba(37,64,86,.82) 50%, rgba(27,47,78,.92) 100%),
        radial-gradient(ellipse at 70% 50%, rgba(150,201,61,.08) 0%, transparent 65%);
    pointer-events:none;
}
/* Círculos decorativos */
.hero-circle{
    position:absolute;border-radius:50%;pointer-events:none;
    border:1px solid rgba(150,201,61,.12);
}
.hero-circle-1{width:600px;height:600px;top:-200px;right:-200px;border:1.5px solid rgba(150,201,61,.08);animation:rotateSlow 40s linear infinite}
.hero-circle-2{width:340px;height:340px;bottom:-100px;left:-80px;border:1px solid rgba(255,255,255,.05);animation:rotateSlow 28s linear infinite reverse}
@keyframes rotateSlow{to{transform:rotate(360deg)}}
/* Contenido centrado */
.hero-inner{
    position:relative;z-index:2;
    max-width:820px;
    text-align:center;
    padding:100px 40px 130px;
    margin:0 auto;
}
.hero-badge{
    display:inline-flex;align-items:center;gap:8px;
    background:rgba(150,201,61,.15);
    color:var(--lime);
    border:1px solid rgba(150,201,61,.35);
    border-radius:30px;
    padding:6px 18px;
    font-size:12px;font-weight:700;letter-spacing:.8px;text-transform:uppercase;
    margin-bottom:28px;
}
.hero-badge-dot{
    width:7px;height:7px;border-radius:50%;background:var(--lime);
    animation:pulseDot 1.6s ease-in-out infinite;
    flex-shrink:0;
}
@keyframes pulseDot{
    0%,100%{box-shadow:0 0 0 0 rgba(150,201,61,.6)}
    50%{box-shadow:0 0 0 6px rgba(150,201,61,0)}
}
.hero-inner h1{
    font-size:clamp(26px,4vw,48px);
    font-weight:800;
    color:#ffffff;
    line-height:1.2;
    margin-bottom:22px;
    text-shadow:0 2px 16px rgba(0,0,0,.25);
}
.hero-inner h1 strong{color:var(--lime)}
.hero-lead{
    font-size:26px;
    font-weight:600;
    color:#ffffff;
    max-width:1100px;
    margin:0 auto 40px;
    line-height:1.5;
    text-shadow:0 2px 16px rgba(0,0,0,.4)
}
.hero-actions{display:flex;gap:16px;flex-wrap:wrap;justify-content:center;margin-bottom:60px}
.btn-primary{background:var(--lime);color:#1b2f4e;border:none;padding:14px 32px;border-radius:30px;font-size:15px;font-weight:800;cursor:pointer;transition:background var(--transition),transform var(--transition),box-shadow var(--transition);text-decoration:none;display:inline-flex;align-items:center;gap:8px;box-shadow:0 4px 20px rgba(150,201,61,.45)}
.btn-primary:hover{background:var(--lime-dark);transform:translateY(-2px);box-shadow:0 8px 28px rgba(150,201,61,.5)}
.btn-outline-light{background:transparent;color:#ffffff;border:2px solid rgba(255,255,255,.4);padding:12px 28px;border-radius:30px;font-size:15px;font-weight:700;cursor:pointer;transition:all var(--transition);text-decoration:none;display:inline-flex;align-items:center;gap:8px;backdrop-filter:blur(4px)}
.btn-outline-light:hover{background:rgba(255,255,255,.12);border-color:rgba(255,255,255,.7);color:#fff}
/* Compatibilidad con btn-outline dentro de otros contextos (servicios, etc.) */
.btn-outline{background:transparent;color:var(--navy);border:2px solid var(--navy);padding:12px 28px;border-radius:30px;font-size:15px;font-weight:700;cursor:pointer;transition:all var(--transition);text-decoration:none;display:inline-flex;align-items:center;gap:8px}
.btn-outline:hover{background:var(--navy);color:var(--white)}
/* Estadísticas */
.hero-stats{
    display:flex;align-items:center;justify-content:center;gap:0;
    background:rgba(255,255,255,.06);
    border:1px solid rgba(255,255,255,.1);
    border-radius:16px;
    padding:22px 40px;
    backdrop-filter:blur(8px);
    max-width:520px;
    margin:0 auto;
}
.hero-stat{flex:1;text-align:center}
.hero-stat strong{display:block;font-size:28px;font-weight:800;color:var(--lime);line-height:1}
.hero-stat span{font-size:12px;color:rgba(255,255,255,.6);font-weight:500;margin-top:4px;display:block;letter-spacing:.3px}
.hero-stat-divider{width:1px;height:44px;background:rgba(255,255,255,.15);flex-shrink:0;margin:0 24px}
/* Flecha scroll */
.hero-arrow{position:absolute;bottom:28px;left:50%;transform:translateX(-50%);color:rgba(255,255,255,.5);font-size:20px;animation:bounce 1.8s infinite;cursor:pointer;z-index:2}
@keyframes bounce{0%,100%{transform:translateX(-50%) translateY(0)}50%{transform:translateX(-50%) translateY(8px)}}

/* ── ANIMACIÓN SVG HERO (GSAP) ── */
#hero-svg-wrapper {
    margin-bottom: 22px;
    min-height: 280px;
    display: flex;
    align-items: center;
    justify-content: center;
}

#hero-svg-wrapper svg {
    display: block;
    max-width: 100%;
    height: auto;
    max-height: 360px;
    width: auto;
    filter: drop-shadow(0 0 15px rgba(168, 188, 67, 0.15));
}

/* ═══════════════════════════════════════════════════════
   HERO V2 — z-index layers: video(1) overlay(2) line(3) person(4) content(5)
   ═══════════════════════════════════════════════════════ */

.hero.hero-v2 {
    position: relative;
    height: 100vh;
    overflow: hidden;
    align-items: stretch;
    justify-content: stretch;
    padding: 0;
}

/* CAPA 1: video — cinematográfico */
/* CAPA 1: video — hardware accelerated, sin filtros CSS que traben */
.hero.hero-v2 .hero-video-bg {
    z-index: 1;
    transform: translateZ(0);
    backface-visibility: hidden;
}

/* CAPA 2: Overlay direccional izq oscuro → der transparente */
.hv2-overlay {
    position: absolute;
    inset: 0;
    z-index: 2;
    pointer-events: none;
    background: linear-gradient(
        110deg,
        rgba(3,  8, 20, 0.97)  0%,
        rgba(5, 12, 28, 0.90) 35%,
        rgba(5, 12, 28, 0.40) 58%,
        rgba(3,  8, 20, 0.04) 100%
    );
}

/* CAPA 2b: Color grading — tint azul-verde cinematográfico sobre el video */
.hv2-colorgrade {
    position: absolute;
    inset: 0;
    z-index: 2;
    pointer-events: none;
    background:
        radial-gradient(ellipse at 72% 45%, rgba(0, 80, 50, 0.22) 0%, transparent 55%),
        linear-gradient(180deg, rgba(8, 5, 28, 0.28) 0%, transparent 45%);
}

/* CAPA 2c: Viñeta — solo borde superior e inferior, no los lados */
.hv2-vignette {
    position: absolute;
    inset: 0;
    z-index: 2;
    pointer-events: none;
    background:
        linear-gradient(to bottom, rgba(0,0,0,0.35) 0%, transparent 18%),
        linear-gradient(to top,    rgba(0,0,0,0.25) 0%, transparent 18%);
}

/* CAPA 2d: Glow ambiental verde — simula luz emitida desde la línea curva */
.hv2-ambient-glow {
    position: absolute;
    bottom: 0;
    right: 0;
    width: 65%;
    height: 60%;
    z-index: 2;
    pointer-events: none;
    background: radial-gradient(
        ellipse at 85% 100%,
        rgba(158, 255,   0, 0.14)  0%,
        rgba(  0, 255, 170, 0.07) 28%,
        transparent                60%
    );
}

/* CAPA 3: Línea curva diagonal */
.hv2-curve-wrap {
    position: absolute;
    bottom: 0;
    left: 0;
    right: 0;
    height: 500px;
    z-index: 10;
    pointer-events: none;
    overflow: visible;
}
.hv2-curve-svg {
    width: 100%;
    height: 100%;
    overflow: visible;
    /* Un solo drop-shadow sutil — evita repaint costoso */
    filter: drop-shadow(0 -6px 22px rgba(158, 255, 0, 0.55));
}

/* Barrido y pulso eliminados — solo brillo estático en la línea */
.hv2-sweep-body { display: none; }
.hv2-svg-anim   { display: none; }

@keyframes hvSvgPulse {
    0%   { stroke-dashoffset: 1800; opacity: 0.3; }
    50%  { opacity: 0.85; }
    100% { stroke-dashoffset: -300; opacity: 0.3; }
}

@keyframes hvSweep {
    to { stroke-dashoffset: -420; }
}

/* CAPA 4: Persona PNG — absoluta, anclada al fondo derecho */
.hv2-person {
    position: absolute;
    bottom: 0;
    right: 5%;
    height: 92%;
    z-index: 4;
    display: flex;
    align-items: flex-end;
    pointer-events: none;
}
.hv2-person-img {
    height: 100%;
    width: auto;
    max-width: 600px;
    object-fit: contain;
    object-position: bottom center;
    display: block;
    transform-origin: bottom center;
    will-change: transform;
    /* Perspectiva 3D: leve rotación Y + inclinación X hacia el espectador */
    transform: perspective(1000px) rotateY(-6deg) rotateX(1.5deg);
    /* Sombras asimétricas que simulan volumen:
       izquierda oscura = lado alejado de la "fuente de luz" (contenido)
       abajo-der = contacto con el suelo
       tinte azul = rebote ambiental del fondo
       verde sutil = luz de la línea neon cercana */
    filter:
        drop-shadow(-22px   0    40px rgba(0,   2,  14, 0.90))
        drop-shadow(  0   28px   32px rgba(0,   0,   0, 0.70))
        drop-shadow( 14px  -6px  24px rgba(10,  80, 160, 0.22))
        drop-shadow(-14px   0    20px rgba(140, 255,  0, 0.12));
    /* Fundido inferior — ancla la figura al suelo */
    mask-image: linear-gradient(
        to bottom,
        black 0%,
        black 70%,
        rgba(0,0,0,0.5) 85%,
        transparent 100%
    );
    -webkit-mask-image: linear-gradient(
        to bottom,
        black 0%,
        black 70%,
        rgba(0,0,0,0.5) 85%,
        transparent 100%
    );
}

/* CAPA 5: Contenido de texto — absoluto, mitad izquierda, centrado vertical */
.hv2-content {
    position: absolute;
    inset: 0 48% 0 0;
    z-index: 5;
    display: flex;
    flex-direction: column;
    justify-content: center;
    padding: 100px 0 100px 64px;
    max-width: 620px;
}

/* Bloque animado: logo ↔ titular (stack en la misma celda de grid) */
.hv2-anim-block {
    display: grid;
    width: 100%;
    min-height: 240px;
    margin-bottom: 20px;
    align-items: start;
}
.hv2-phase {
    grid-column: 1;
    grid-row: 1;
    opacity: 0;
    transition: opacity 0.7s ease;
    pointer-events: none;
    width: 100%;
}
.hv2-phase.active {
    opacity: 1;
    pointer-events: auto;
}
.hv2-logo-img {
    width: 400px;
    max-width: 100%;
    height: auto;
    filter: drop-shadow(0 0 32px rgba(150, 201, 61, 0.55)) brightness(1.1);
}
@keyframes hvLogoFloat {
    0%, 100% { transform: translateY(0);    filter: drop-shadow(0 0 28px rgba(150,201,61,0.50)) brightness(1.08); }
    50%       { transform: translateY(-8px); filter: drop-shadow(0 0 44px rgba(150,201,61,0.85)) brightness(1.15); }
}
.hv2-title {
    font-size: clamp(30px, 3.6vw, 54px);
    font-weight: 900;
    color: #fff;
    line-height: 1.15;
    margin: 0;
    letter-spacing: -0.5px;
    text-shadow: 0 2px 32px rgba(0, 0, 0, 0.70);
}
.hv2-title em {
    font-style: normal;
    color: #9EFF00;
    display: block;
    text-shadow: 0 0 28px rgba(158, 255, 0, 0.45);
}

.hv2-lead {
    font-size: 19px;
    color: #ffffff;
    margin: 0 0 34px;
    font-weight: 700;
    line-height: 1.55;
    letter-spacing: 0.01em;
    text-shadow:
        0 1px 8px rgba(0, 0, 0, 0.55),
        0 0 28px rgba(158, 255, 0, 0.18);
}

.hv2-actions { margin-bottom: 40px; }
.hv2-cta {
    font-size: 16px !important;
    padding: 16px 36px !important;
    border-radius: 40px !important;
    background: #9EFF00 !important;
    color: #0a1628 !important;
    box-shadow: 0 6px 28px rgba(158, 255, 0, 0.55), 0 0 0 0 rgba(158,255,0,0.4) !important;
    gap: 12px !important;
    font-weight: 800 !important;
    transition: box-shadow .3s, transform .3s !important;
}
.hv2-cta:hover {
    transform: translateY(-3px) !important;
    box-shadow: 0 10px 36px rgba(158, 255, 0, 0.70), 0 0 0 6px rgba(158,255,0,0.15) !important;
}

/* Prueba social */
.hv2-social {
    display: flex;
    align-items: center;
    gap: 14px;
}
.hv2-social-icons {
    display: flex;
    align-items: center;
    gap: 0;
}
.hv2-icon-badge {
    width: 38px;
    height: 38px;
    border-radius: 50%;
    border: 2px solid rgba(158, 255, 0, 0.55);
    background: rgba(10, 22, 40, 0.75);
    display: flex;
    align-items: center;
    justify-content: center;
    margin-left: -10px;
    color: #9EFF00;
    font-size: 14px;
    backdrop-filter: blur(4px);
    -webkit-backdrop-filter: blur(4px);
}
.hv2-icon-badge:first-child { margin-left: 0; }
.hv2-social-text strong {
    display: block;
    color: #fff;
    font-size: 14px;
    font-weight: 800;
    line-height: 1.3;
}
.hv2-social-text span {
    font-size: 12px;
    color: rgba(255, 255, 255, 0.50);
    font-weight: 500;
}

/* ── Responsive hero-v2 ── */
@media (min-width: 1600px) {
    .hv2-person       { height: 98%; right: 8%; }
    .hv2-person-img   { max-width: 720px; }
    .hv2-content      { padding-left: 80px; max-width: 680px; }
}
@media (min-width: 1920px) {
    .hv2-person       { height: 100%; right: 10%; }
    .hv2-person-img   { max-width: 860px; }
    .hv2-title        { font-size: 62px; }
    .hv2-content      { padding-left: 100px; max-width: 760px; }
}
@media (max-width: 1200px) {
    .hv2-content { padding-left: 48px; }
    .hv2-person  { right: 2%; height: 88%; }
}
@media (max-width: 960px) {
    .hv2-content { inset: 0 44% 0 0; padding-left: 36px; }
    .hv2-person  { right: 0; height: 82%; }
    .hv2-person-img { max-width: 460px; }
}

/* Responsive hero */
@media(max-width:768px){
    /* Header colapsado en móvil — hamburguesa lo abre */
    header { right: -300px; }
    body { margin-right: 0; }
    .menu-toggle { display: flex; }
    .hero-inner{padding:80px 24px 110px}
    .hero-inner h1{font-size:26px}
    .hero-lead{font-size:18px}
    .hero-stats{flex-direction:column;gap:16px;padding:20px 24px}
    .hero-stat-divider{width:80px;height:1px;margin:0}
    /* hero-v2 mobile: texto arriba, persona abajo translucida */
    .hero.hero-v2 { height: auto; min-height: 100vh; }
    .hv2-content {
        position: relative;
        inset: auto;
        width: 100%;
        max-width: 100%;
        padding: 110px 24px 280px;
        text-align: left;
    }
    .hv2-person {
        height: 55%;
        right: 0;
        opacity: 0.35;
        z-index: 3;
    }
    .hv2-anim-block { min-height: 200px; }
    .hv2-title      { font-size: 28px; }
    .hv2-lead       { font-size: 16px; }
    .hv2-curve-wrap { height: 200px; }
    .hv2-logo-img   { width: 240px; }
}

/* ---- CARRUSEL DE HISTORIA ---- */
.history-carousel-section {
    padding: 80px 20px;
    background: linear-gradient(135deg, rgba(37, 64, 86, .05) 0%, rgba(150, 201, 61, .08) 100%);
}

/* =============================================
   TIMELINE SECTION — Nuestra Historia
   ============================================= */
.tl-section {
    padding: 90px 0 80px;
    background: linear-gradient(170deg, #f8fafc 0%, rgba(150,201,61,.04) 60%, #f0f4f0 100%);
    overflow: hidden;
}

.tl-header {
    text-align: center;
    padding: 0 24px;
    margin-bottom: 52px;
}

.tl-main-title {
    font-size: 38px;
    font-weight: 900;
    color: var(--navy);
    margin: 12px 0 14px;
    line-height: 1.2;
}

.tl-main-sub {
    font-size: 15px;
    color: var(--text-muted);
    max-width: 520px;
    margin: 0 auto;
    line-height: 1.7;
}

/* ---- Barra de navegación ---- */
.tl-nav {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 20px;
    padding: 0 40px;
    margin-bottom: 32px;
}

.tl-btn {
    width: 44px;
    height: 44px;
    border-radius: 50%;
    border: 2px solid var(--lime);
    background: transparent;
    color: var(--lime);
    font-size: 16px;
    cursor: pointer;
    flex-shrink: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: all .25s ease;
}

.tl-btn:hover {
    background: var(--lime);
    color: var(--navy);
    transform: scale(1.1);
}

.tl-btn:disabled {
    opacity: .35;
    cursor: default;
    transform: none;
}

.tl-progress-bar {
    flex: 1;
    max-width: 320px;
    height: 4px;
    background: rgba(37,64,86,.12);
    border-radius: 4px;
    overflow: hidden;
}

.tl-progress-fill {
    height: 100%;
    background: linear-gradient(90deg, var(--lime), var(--navy));
    border-radius: 4px;
    transition: width .4s ease;
    width: 0%;
}

/* ---- Viewport scrolleable ---- */
.tl-viewport {
    position: relative;
    overflow: visible;      /* cards con zoom no quedan clippeadas */
    padding: 24px 0 36px;
}
/* Capa de recorte horizontal para el carousel */
.tl-section { overflow: hidden; }

.tl-track {
    display: flex;
    gap: 16px;
    padding: 0 60px;
    transition: transform .6s cubic-bezier(.25,.46,.45,.94);
    will-change: transform;
    position: relative;
    z-index: 2;
}

/* Cards no activas: ligeramente reducidas y atenuadas */
.tl-item {
    display: flex;
    flex-direction: column;
    align-items: center;
    min-width: 240px;
    width: 240px;
    flex-shrink: 0;
    position: relative;
    cursor: pointer;
    transition: transform .4s ease, opacity .4s ease;
    opacity: .55;
    transform: scale(.93);
}
.tl-item.is-active {
    opacity: 1;
    transform: scale(1);
}

/* ---- Línea central ---- */
.tl-line {
    position: absolute;
    top: 50%;
    left: 0;
    right: 0;
    height: 3px;
    background: rgba(37,64,86,.1);
    transform: translateY(6px);
    z-index: 0;
}

.tl-line-fill {
    height: 100%;
    background: linear-gradient(90deg, var(--lime) 0%, var(--navy) 100%);
    width: 0%;
    transition: width .5s ease;
    border-radius: 3px;
}

/* ---- Stems (palitos que conectan card con punto) ---- */
.tl-stem {
    width: 2px;
    height: 48px;
    background: rgba(37,64,86,.2);
    flex-shrink: 0;
    transition: background .3s ease;
}

.tl-item.is-active .tl-stem {
    background: var(--lime);
}

/* ---- Punto central ---- */
.tl-dot {
    width: 16px;
    height: 16px;
    border-radius: 50%;
    background: var(--white);
    border: 3px solid rgba(37,64,86,.25);
    flex-shrink: 0;
    position: relative;
    transition: all .3s ease;
    z-index: 3;
}

.tl-dot-year {
    position: absolute;
    bottom: -22px;
    left: 50%;
    transform: translateX(-50%);
    font-size: 10px;
    font-weight: 700;
    color: var(--text-muted);
    white-space: nowrap;
    letter-spacing: .3px;
    opacity: 0;
    transition: opacity .3s ease;
}

.tl-dot--active,
.tl-item.is-active .tl-dot {
    width: 20px;
    height: 20px;
    border-color: var(--lime);
    background: var(--lime);
    box-shadow: 0 0 0 5px rgba(150,201,61,.2);
}

.tl-item.is-active .tl-dot-year,
.tl-item:hover .tl-dot-year {
    opacity: 1;
}

/* ---- Card de timeline (hover-reveal) ---- */
.tl-card {
    width: 220px;
    height: 300px;
    background: var(--white);
    border-radius: 1.5rem;
    padding: 5px;
    overflow: hidden;
    flex-shrink: 0;
    position: relative;
    border: 1px solid var(--border);
    box-shadow: 0 4px 20px rgba(27,47,78,.08);
    transition: box-shadow .3s ease, border-color .3s ease;
    cursor: pointer;
    display: flex;
    flex-direction: column;
}

.tl-card--top  { margin-bottom: 0; }
.tl-card--bottom { margin-top: 0; }

.tl-item:hover .tl-card,
.tl-item.is-active .tl-card {
    box-shadow: 0 16px 42px rgba(27,47,78,.15);
    border-color: rgba(150,201,61,.45);
}

/* ---- Focus: zoom + acercamiento al hacer clic ---- */
.tl-item.is-focused { z-index: 20; }
.tl-item.is-focused .tl-card {
    transform: scale(1.12) translateY(-10px);
    box-shadow: 0 40px 80px rgba(27,47,78,.30),
                0 0 0 2.5px var(--lime);
    border-color: var(--lime);
    cursor: zoom-out;
    transition: transform .35s cubic-bezier(.34,1.56,.64,1),
                box-shadow .35s ease, border-color .2s ease;
}
.tl-item.is-focused .tl-stem { background: var(--lime); }
.tl-item.is-focused .tl-dot {
    width: 22px; height: 22px;
    border-color: var(--lime); background: var(--lime);
    box-shadow: 0 0 0 8px rgba(150,201,61,.22);
}
.tl-item.is-focused .tl-dot-year { opacity: 1; }

/* ─── Área de imagen / icóno ─── */
.tl-card-img {
    border-radius: 1.25rem;
    background: linear-gradient(145deg, #08152b 0%, #1b2f4e 55%, #1d3a5c 100%);
    height: calc(62% - 5px);
    flex-shrink: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    position: relative;
    overflow: hidden;
    transition: height 0.28s cubic-bezier(.4,0,.2,1);
}

/* Brillo decorativo radial */
.tl-card-img::after {
    content: "";
    position: absolute;
    inset: 0;
    background: radial-gradient(circle at 65% 28%, rgba(150,201,61,.22) 0%, transparent 65%);
    pointer-events: none;
    z-index: 0;
}

/* Frosted-glass en borde inferior de imagen */
.tl-card-img::before {
    content: "";
    position: absolute;
    inset: auto 0 0;
    height: 42%;
    -webkit-mask: linear-gradient(transparent, #000 80%);
    mask: linear-gradient(transparent, #000 80%);
    backdrop-filter: blur(10px);
    border-radius: 0 0 1.25rem 1.25rem;
    translate: 0 0;
    transition: translate 0.28s ease;
    z-index: 2;
    pointer-events: none;
}

/* Hover: imagen se encoge, glass desaparece */
.tl-item:hover .tl-card .tl-card-img,
.tl-item.is-focused .tl-card .tl-card-img {
    height: calc(42% - 5px);
}
.tl-item:hover .tl-card-img::before,
.tl-item.is-focused .tl-card-img::before {
    translate: 0 110%;
}

.tl-card-img img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
    border-radius: 1.25rem;
    position: relative;
    z-index: 0;
}

.tl-card-img-placeholder {
    width: 68px;
    height: 68px;
    border-radius: 50%;
    background: rgba(150,201,61,.15);
    border: 2px solid rgba(150,201,61,.38);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 30px;
    color: var(--lime);
    position: relative;
    z-index: 1;
    transition: transform .3s ease, background .3s ease;
    flex-direction: column;
    gap: 6px;
}

/* Año visible siempre debajo del ícono */
.tl-card-img-label {
    font-size: 13px;
    font-weight: 900;
    color: #fff;
    letter-spacing: 1px;
    position: absolute;
    bottom: 18px;
    left: 0; right: 0;
    text-align: center;
    z-index: 3;
    text-shadow: 0 2px 8px rgba(0,0,0,.7);
    pointer-events: none;
    opacity: 1;
    transition: opacity .25s ease;
}
/* Al hacer hover la etiqueta sube y se desvanece */
.tl-item:hover .tl-card-img-label,
.tl-item.is-focused .tl-card-img-label {
    opacity: 0;
}

.tl-item:hover .tl-card-img-placeholder,
.tl-item.is-active .tl-card-img-placeholder,
.tl-item.is-focused .tl-card-img-placeholder {
    transform: scale(1.1) rotate(-5deg);
    background: rgba(150,201,61,.28);
}

/* ─── Cuerpo de texto ─── */
.tl-card-body {
    flex: 1;
    min-height: 0;
    overflow: hidden;
    padding: 10px 13px 8px;
    display: flex;
    flex-direction: column;
    gap: 5px;
}

.tl-card-year {
    display: inline-block;
    font-size: 10px;
    font-weight: 800;
    letter-spacing: 1px;
    color: var(--lime-dark);
    background: rgba(150,201,61,.1);
    border: 1px solid rgba(150,201,61,.2);
    border-radius: 20px;
    padding: 2px 9px;
    text-transform: uppercase;
    align-self: flex-start;
    opacity: 0;
    translate: 0 -180%;
    transition: opacity .35s ease, translate .25s ease;
}

.tl-card-title {
    font-size: 13px;
    font-weight: 800;
    color: var(--navy);
    margin: 0;
    line-height: 1.3;
    opacity: 0;
    translate: 0 -220%;
    transition: opacity .4s ease, translate .25s ease;
}

.tl-card-text {
    font-size: 11.5px;
    color: var(--text-muted);
    line-height: 1.5;
    margin: 0;
    opacity: 0;
    translate: 0 100%;
    transition: opacity .4s ease .12s, translate .25s ease .12s;
    display: -webkit-box;
    -webkit-line-clamp: 3;
    -webkit-box-orient: vertical;
    overflow: hidden;
}

/* Hover/focused → texto se revela */
.tl-item:hover .tl-card .tl-card-year,
.tl-item:hover .tl-card .tl-card-title,
.tl-item:hover .tl-card .tl-card-text,
.tl-item.is-focused .tl-card .tl-card-year,
.tl-item.is-focused .tl-card .tl-card-title,
.tl-item.is-focused .tl-card .tl-card-text {
    opacity: 1;
    translate: 0 0;
}
.tl-item.is-focused .tl-card-text {
    -webkit-line-clamp: unset;
    overflow: visible;
    display: block;
}

/* ---- Indicadores de punto ---- */
.tl-dots-nav {
    display: flex;
    justify-content: center;
    gap: 10px;
    margin-top: 28px;
    padding: 0 24px;
}

.tl-dot-nav {
    width: 10px;
    height: 10px;
    border-radius: 50%;
    border: 2px solid var(--lime);
    background: transparent;
    cursor: pointer;
    transition: all .25s ease;
    padding: 0;
}

.tl-dot-nav.is-active {
    background: var(--lime);
    transform: scale(1.3);
}

.tl-dot-nav:hover {
    transform: scale(1.15);
}

/* ---- CTA ---- */
.tl-cta {
    text-align: center;
    margin-top: 48px;
}

/* ---- Responsivo ---- */
@media (max-width: 900px) {
    .tl-item {
        min-width: 220px;
        width: 220px;
    }
    .tl-card {
        width: 192px;
        height: 275px;
    }
    .tl-track {
        padding: 0 32px;
    }
}

@media (max-width: 640px) {
    .tl-main-title {
        font-size: 28px;
    }
    .tl-item {
        min-width: 200px;
        width: 200px;
    }
    .tl-card {
        width: 178px;
        height: 255px;
    }
    .tl-track {
        padding: 0 20px;
    }
    .tl-card-img-placeholder {
        width: 54px;
        height: 54px;
        font-size: 24px;
    }
}

/* Responsivo */
@media (max-width: 768px) {
    .history-carousel-section {
        padding: 60px 20px;
    }
    
    .history-main-title {
        font-size: 32px;
    }
    
    .carousel-container {
        height: auto;
        min-height: 380px;
        margin: 0 20px;
    }
    
    .carousel-card {
        padding: 36px 28px;
    }
    
    .carousel-card-number {
        font-size: 48px;
    }
    
    .carousel-card-icon {
        width: 60px;
        height: 60px;
        font-size: 32px;
    }
    
    .carousel-card-title {
        font-size: 20px;
    }
    
    .carousel-controls {
        padding: 0;
    }
    
    .carousel-btn {
        width: 40px;
        height: 40px;
        font-size: 16px;
    }
    
    .carousel-counter {
        font-size: 12px;
    }
}

/* ---- FRANJAS DECORATIVAS ---- */
.banner-lime { display: none; }
.banner-navy{background:var(--navy);height:8px}
.banner-slate{background:var(--slate);height:8px}

/* ---- SECCIÓN GENÉRICA ---- */
.section{padding:90px 60px}
.section-alt{background:var(--off-white)}
.section-header{text-align:center;margin-bottom:56px}
.section-header .tag{display:inline-block;background:rgba(150,201,61,.1);color:var(--lime-dark);border:1px solid rgba(150,201,61,.25);border-radius:20px;padding:4px 14px;font-size:11.5px;font-weight:700;letter-spacing:0.8px;text-transform:uppercase;margin-bottom:12px}
.section-header h2{font-size:32px;font-weight:800;color:var(--navy);margin-bottom:14px}
.section-header p{font-size:16px;color:var(--text-muted);max-width:560px;margin:0 auto;line-height:1.7}

/* ---- SERVICIOS ---- */
.services-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:28px}
.service-card{background:var(--white);border:1px solid var(--border);border-radius:var(--radius-lg);padding:36px 28px;transition:transform var(--transition),box-shadow var(--transition),border-color var(--transition);position:relative;overflow:hidden}
.service-card::before{content:'';position:absolute;top:0;left:0;width:4px;height:100%;background:var(--lime);border-radius:4px 0 0 4px;transform:scaleY(0);transition:transform var(--transition)}
.service-card:hover{transform:translateY(-6px);box-shadow:var(--shadow-md)}
.service-card:hover::before{transform:scaleY(1)}
.service-icon{width:56px;height:56px;background:rgba(150,201,61,.1);border-radius:14px;display:flex;align-items:center;justify-content:center;font-size:24px;color:var(--lime-dark);margin-bottom:20px}
.service-card h3{font-size:19px;font-weight:700;color:var(--navy);margin-bottom:10px}
.service-card p{font-size:16px;font-weight:700;color:var(--text-muted);line-height:1.7}
.service-link{display:inline-flex;align-items:center;gap:6px;margin-top:16px;font-size:13px;font-weight:700;color:var(--lime-dark);text-decoration:none;transition:gap var(--transition)}
.service-link:hover{gap:10px}

/* ---- PÁGINA SERVICIOS ---- */
.services-page-section{background:var(--white)}
.services-page-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:32px}
.service-page-card{display:flex;flex-direction:column;background:var(--white);border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden;transition:transform var(--transition),box-shadow var(--transition);position:relative}
.service-page-card::before{content:'';position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(90deg,var(--lime),var(--lime-dark));transform:scaleX(0);transform-origin:left;transition:transform var(--transition)}
.service-page-card:hover{transform:translateY(-6px);box-shadow:var(--shadow-md)}
.service-page-card:hover::before{transform:scaleX(1)}
.spc-icon{background:linear-gradient(135deg,#254056 0%,#1b2f4e 100%);padding:36px;display:flex;align-items:center;justify-content:center;font-size:40px;color:var(--lime)}
.spc-body{padding:28px;display:flex;flex-direction:column;flex:1}
.service-page-card h3{font-size:19px;font-weight:700;color:var(--navy);margin-bottom:10px}
.service-page-card p{font-size:16px;font-weight:700;color:var(--text-muted)}
.spc-body h3{font-size:18px;font-weight:800;color:var(--navy);margin-bottom:10px}
.spc-body p{font-size:14px;color:var(--text-muted);line-height:1.8;flex:1;margin-bottom:18px}
@media(max-width:960px){.services-page-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:600px){.services-page-grid{grid-template-columns:1fr}}

/* ---- HERO PÁGINA INTERNA (hero texto) ---- */
.page-hero p{font-size:16px;color:rgba(255,255,255,.7);max-width:560px;margin:12px auto 0}

/* ---- CARRUSEL 3D DE VIDEOS ---- */
.video-carousel-section{background:#1b2f4e;padding:72px 48px 80px;position:relative;overflow:hidden}
.video-carousel-section::before{content:'';position:absolute;top:0;left:0;right:0;height:140px;background:linear-gradient(to bottom,#0f1f35 0%,transparent 100%);z-index:1;pointer-events:none}
/* Encabezado */
.vc-header{text-align:center;max-width:700px;margin:0 auto 48px;position:relative;z-index:2}
.vc-badge{display:inline-flex;align-items:center;gap:7px;background:rgba(150,201,61,.15);color:var(--lime);border:1px solid rgba(150,201,61,.3);border-radius:20px;padding:5px 16px;font-size:11.5px;font-weight:700;letter-spacing:.8px;text-transform:uppercase;margin-bottom:18px}
.vc-title{font-size:clamp(26px,2.6vw,40px);font-weight:900;color:#fff;margin:0 0 14px;line-height:1.15}
.vc-desc{color:rgba(255,255,255,.6);font-size:15.5px;line-height:1.75}
/* Contenedor 3D */
.vc-container{max-width:900px;margin:0 auto;position:relative;z-index:2;display:flex;flex-direction:column;align-items:center;gap:18px}
.vc3d-carousel{perspective:2400px;display:grid;place-items:center;width:100%;overflow:visible}
.vc3d-carousel *{transform-style:preserve-3d}
.vc3d-items{
  --width:clamp(240px,35vw,380px);
  --spacing:160px;
  display:grid;
  width:var(--width);
  aspect-ratio:4/5;
  --c3-angle:calc(360deg / var(--items-total,4));
  --c3-C:calc(var(--c3-angle) / 2);
  --c3-B:calc(90deg - var(--c3-C));
  --c3-c:clamp(120px,13vw,190px);
  --c3-b:calc(var(--c3-c) * sin(var(--c3-B)) / sin(var(--c3-C)));
  --tz:calc(var(--c3-b) + var(--spacing));
  translate:0 0 calc(var(--tz) * -1);
  animation:vc3dRotate calc(var(--items-total,4) * 10s) linear infinite;
}
.vc3d-items:hover{animation-play-state:paused}
@keyframes vc3dRotate{to{transform:rotateY(360deg)}}
.vc3d-item{grid-area:1/1;transform:rotateY(calc(var(--c3-angle) * var(--item-index))) translateZ(var(--tz));display:flex}
/* Cara de la tarjeta */
.vc3d-face{width:100%;height:100%;background:#0a0e14;border:1.5px solid rgba(255,255,255,.1);border-radius:18px;overflow:hidden;display:flex;flex-direction:column;box-shadow:0 16px 60px rgba(0,0,0,.65);transition:border-color .3s;cursor:pointer}
.vc3d-face:hover{border-color:rgba(150,201,61,.5)}
/* Thumbnail */
.vc3d-thumb{position:relative;flex:0 0 62%;background:#111;overflow:hidden}
.vc3d-thumb img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .45s ease}
.vc3d-face:hover .vc3d-thumb img{transform:scale(1.06)}
.vc3d-thumb::after{content:'';position:absolute;inset:0;background:linear-gradient(to bottom,transparent 40%,rgba(0,0,0,.55) 100%);pointer-events:none}
.vc3d-no-thumb{width:100%;height:100%;display:flex;align-items:center;justify-content:center;color:rgba(255,255,255,.18);font-size:48px}
/* Badge de plataforma */
.vc3d-platform{position:absolute;top:10px;left:12px;z-index:2;font-size:.7rem;font-weight:800;letter-spacing:.06em;color:#fff;padding:4px 10px;border-radius:99px;display:flex;align-items:center;gap:5px;text-transform:uppercase}
.vc3d-yt{background:#cc0000}
.vc3d-vm{background:#1ab7ea}
.vc3d-tt{background:#010101;border:1px solid rgba(255,255,255,.25)}
/* Botón play */
.vc3d-play{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);z-index:2;width:58px;height:58px;background:rgba(0,0,0,.65);border:2.5px solid rgba(255,255,255,.85);border-radius:50%;color:#fff;font-size:20px;display:flex;align-items:center;justify-content:center;padding-left:4px;pointer-events:none;transition:background .25s,border-color .25s,transform .25s}
.vc3d-face:hover .vc3d-play{background:var(--lime);border-color:var(--lime);transform:translate(-50%,-50%) scale(1.12)}
/* Info */
.vc3d-info{flex:1;padding:14px 16px 16px;display:flex;flex-direction:column;gap:6px;background:linear-gradient(160deg,#131b26 0%,#0d1520 100%)}
.vc3d-info h3{font-size:clamp(.8rem,1.5vw,.95rem);font-weight:700;color:#fff;line-height:1.3;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.vc3d-info p{font-size:.74rem;color:rgba(255,255,255,.5);line-height:1.5;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;flex:1}
.vc3d-cta{display:flex;align-items:center;justify-content:center;gap:7px;padding:9px 14px;background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.15);border-radius:9px;font-size:.78rem;font-weight:700;color:rgba(255,255,255,.8);margin-top:auto;transition:background .2s,border-color .2s,color .2s}
.vc3d-face:hover .vc3d-cta{background:rgba(150,201,61,.18);border-color:rgba(150,201,61,.5);color:var(--lime)}
/* Hint */
.vc3d-hint{font-size:.7rem;color:rgba(255,255,255,.3);text-align:center}
.vc3d-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:14px;min-height:220px;background:rgba(255,255,255,.04);border:1px dashed rgba(255,255,255,.12);border-radius:16px;color:rgba(255,255,255,.35);font-size:.85rem;text-align:center;padding:32px}
.vc3d-empty i{font-size:2.2rem;color:rgba(150,201,61,.35)}
/* Modal */
.vc3d-modal{display:none;position:fixed;inset:0;z-index:9999;background:rgba(0,0,0,.9);align-items:center;justify-content:center;padding:24px}
.vc3d-modal.open{display:flex}
.vc3d-modal-inner{position:relative;width:100%;max-width:900px}
.vc3d-modal-close{position:absolute;top:-44px;right:0;background:none;border:none;color:rgba(255,255,255,.7);font-size:30px;cursor:pointer;line-height:1;transition:color .2s}
.vc3d-modal-close:hover{color:#fff}
.vc3d-modal-player{position:relative;padding-bottom:56.25%;height:0;border-radius:14px;overflow:hidden;background:#000}
.vc3d-modal-player iframe{position:absolute;top:0;left:0;width:100%;height:100%;border:none}
.vc3d-modal-caption{margin-top:14px;text-align:center}
.vc3d-modal-caption h4{color:#fff;font-size:1.05rem;font-weight:700}
.vc3d-modal-caption p{color:rgba(255,255,255,.55);font-size:.88rem;margin-top:5px}
/* Responsive */
@media(max-width:960px){.vc3d-items{--width:clamp(200px,48vw,300px)}}
@media(max-width:768px){.video-carousel-section{padding:52px 20px 64px}.vc3d-items{--width:clamp(180px,60vw,260px)}}
@media(max-width:480px){.vc3d-items{--width:clamp(160px,72vw,230px)}}

/* ---- Layout 2 columnas (videos) ---- */
.vc-main-layout{display:grid;grid-template-columns:1fr 1fr;gap:32px 64px;align-items:center;max-width:1280px;margin:0 auto;position:relative;z-index:2}
.vc-center-panel{display:flex;flex-direction:column;align-items:center;gap:20px}
.vc-center-panel .vc3d-items{--width:clamp(240px,26vw,340px)}
/* Paneles laterales */
.vc-side-panel{display:flex;flex-direction:column;gap:22px}
.vc-side-badge{display:inline-flex;align-items:center;gap:8px;background:rgba(150,201,61,.15);color:var(--lime);border:1px solid rgba(150,201,61,.45);border-radius:20px;padding:7px 18px;font-size:13px;font-weight:800;letter-spacing:1.2px;text-transform:uppercase;width:fit-content;box-shadow:0 0 14px rgba(150,201,61,.15)}
.vc-side-title{font-size:clamp(1.9rem,2.8vw,2.6rem);font-weight:900;color:#fff;line-height:1.1;margin:0;letter-spacing:-.02em;text-shadow:0 2px 24px rgba(0,0,0,.4)}
.vc-side-text{color:rgba(255,255,255,.72);font-size:1rem;line-height:1.9;margin:0}
/* Grid de tarjetas de características */
.vc-feat-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.vc-feat-card{display:flex;align-items:flex-start;gap:12px;background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.08);border-radius:14px;padding:16px 16px 16px 14px;transition:background .25s,border-color .25s}
.vc-feat-card:hover{background:rgba(150,201,61,.08);border-color:rgba(150,201,61,.25)}
.vc-feat-icon{flex-shrink:0;width:36px;height:36px;background:rgba(150,201,61,.15);border-radius:10px;display:flex;align-items:center;justify-content:center;color:var(--lime);font-size:15px}
.vc-feat-card div{display:flex;flex-direction:column;gap:3px}
.vc-feat-card strong{font-size:1rem;font-weight:900;color:#fff;line-height:1.2}
.vc-feat-card span{font-size:.88rem;color:rgba(255,255,255,.65);line-height:1.5}
/* CTA */
.vc-side-cta{display:inline-flex;align-items:center;gap:9px;background:transparent;border:1.5px solid rgba(150,201,61,.5);color:var(--lime);border-radius:10px;padding:11px 20px;font-size:.82rem;font-weight:800;letter-spacing:.04em;text-decoration:none;transition:background .25s,border-color .25s,color .25s;width:fit-content}
.vc-side-cta:hover{background:var(--lime);border-color:var(--lime);color:#0d1520}
/* Pills bar */
.vc-pills-bar{display:flex;flex-wrap:wrap;justify-content:center;gap:7px;width:100%}
.vc-pill-btn{display:inline-flex;align-items:center;gap:6px;padding:5px 12px 5px 6px;background:rgba(255,255,255,.06);border:1.5px solid rgba(255,255,255,.11);border-radius:99px;color:rgba(255,255,255,.5);font-size:.72rem;font-weight:600;cursor:pointer;transition:background .2s,border-color .2s,color .2s;max-width:190px}
.vc-pill-btn:hover{background:rgba(150,201,61,.13);border-color:rgba(150,201,61,.35);color:rgba(255,255,255,.85)}
.vc-pill-btn.active{background:rgba(150,201,61,.2);border-color:var(--lime);color:#fff}
.vc-pill-thumb{width:34px;height:24px;border-radius:5px;overflow:hidden;flex-shrink:0;background:#111;display:block}
.vc-pill-thumb img{width:100%;height:100%;object-fit:cover;display:block}
.vc-pill-icon{width:24px;height:24px;border-radius:5px;display:inline-flex;align-items:center;justify-content:center;font-size:.72rem;flex-shrink:0}
.vc-pill-icon.vc-pill-yt{background:#cc0000;color:#fff}
.vc-pill-icon.vc-pill-vm{background:#1ab7ea;color:#fff}
.vc-pill-icon.vc-pill-tt{background:#010101;color:#fff;border:1px solid rgba(255,255,255,.2)}
.vc-pill-label{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:120px}
/* Responsive layout columnas */
@media(max-width:900px){
  .vc-main-layout{grid-template-columns:1fr;max-width:560px}
  .vc-side-left{order:2}
  .vc-center-panel{order:1}
  .vc-center-panel .vc3d-items{--width:clamp(220px,55vw,360px)}
  .vc-feat-grid{grid-template-columns:1fr 1fr}
}
@media(max-width:600px){.vc-main-layout{max-width:100%}.vc-feat-grid{grid-template-columns:1fr}}


.about-section{padding-bottom:0}
.about-inner{display:flex;align-items:center;gap:72px}
.about-media{flex:0 0 420px;height:460px;background:linear-gradient(135deg,#1b2f4e 0%,#243d62 100%);border-radius:var(--radius-lg);display:flex;align-items:center;justify-content:center;color:rgba(255,255,255,.25);font-size:64px;position:relative;box-shadow:var(--shadow-lg);overflow:hidden}
.about-media img{width:100%;height:100%;object-fit:cover;object-position:top center;display:block;border-radius:var(--radius-lg)}
.about-media::after{content:'';position:absolute;bottom:0;right:0;width:200px;height:200px;background:radial-gradient(circle,rgba(150,201,61,.25) 0%,transparent 70%);pointer-events:none}
.about-content{flex:1}
.about-content .tag{display:inline-block;background:rgba(150,201,61,.1);color:var(--lime-dark);border:1px solid rgba(150,201,61,.25);border-radius:20px;padding:4px 14px;font-size:11.5px;font-weight:700;letter-spacing:0.8px;text-transform:uppercase;margin-bottom:14px}
.about-content h2{font-size:30px;font-weight:800;color:var(--navy);line-height:1.3;margin-bottom:16px}
.about-content p{font-size:15px;color:var(--text-muted);line-height:1.8;margin-bottom:18px}
.about-portfolio-intro{font-size:14px;font-weight:700;color:var(--navy);margin-bottom:10px!important}
.about-portfolio-list{list-style:none;padding:0;margin:0 0 28px;display:flex;flex-direction:column;gap:9px}
.about-portfolio-list li{display:flex;align-items:center;gap:10px;font-size:14.5px;color:var(--text-muted);font-weight:500}
.about-portfolio-list li i{color:var(--lime-dark);font-size:16px}

/* Hero page badges */
.page-hero-content{position:relative;z-index:1}
.page-hero-badges{display:flex;flex-wrap:wrap;justify-content:center;gap:8px;margin-bottom:18px}
.page-hero-badges .tag{background:rgba(255,255,255,.12);color:rgba(255,255,255,.9);border-color:rgba(255,255,255,.3);font-size:11px}

/* Stats clásicos */
.about-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-bottom:32px}
.stat-item{text-align:center}
.stat-number{font-size:32px;font-weight:900;color:var(--lime-dark);display:block}
.stat-label{font-size:12px;color:var(--text-muted);font-weight:600;letter-spacing:0.3px}

/* Barra de métricas (lima) */
.about-metrics-bar{background:var(--lime);display:grid;grid-template-columns:repeat(4,1fr);text-align:center;padding:48px 60px}
.about-metric{padding:0 24px}
.about-metric strong{display:block;font-size:38px;font-weight:900;color:var(--navy);line-height:1;margin-bottom:8px}
.about-metric span{font-size:13px;font-weight:600;color:var(--navy);letter-spacing:0.2px;opacity:.8}
.about-metric+.about-metric{border-left:1px solid rgba(27,47,78,.15)}

/* ---- BLOQUES DE SERVICIOS ---- */
.svc-block{background:var(--white)}
.svc-block--alt{background:var(--bg)}
.svc-block-head{display:flex;align-items:center;gap:20px;margin-bottom:24px}
.svc-block-head h2{font-size:28px;font-weight:800;color:var(--navy);margin:0}
.svc-num{width:52px;height:52px;background:var(--navy);color:var(--lime);font-size:20px;font-weight:900;border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0;font-style:italic}
.svc-lead{font-size:30px;color:var(--text-muted);line-height:1.8;margin-bottom:32px;max-width:860px}
.svc-two-col{display:grid;grid-template-columns:1fr 1fr;gap:48px;margin-bottom:16px}
.svc-sub-title{font-size:30px;font-weight:700;color:var(--navy);margin-bottom:14px;padding-bottom:8px;border-bottom:2px solid var(--lime);text-transform:uppercase;letter-spacing:0.5px}
.svc-mt{margin-top:40px}
.svc-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:10px}
.svc-list li{display:flex;align-items:flex-start;gap:10px;font-size:14px;color:var(--text-muted);line-height:1.6}
.svc-list li i{color:var(--lime-dark);margin-top:3px;flex-shrink:0;font-size:11px}
.svc-location{font-size:30px;color:var(--text-muted);display:flex;gap:8px;align-items:flex-start;line-height:1.6;margin-top:8px}
.svc-location i{color:var(--lime-dark);margin-top:3px;flex-shrink:0}
.svc-accredited{font-size:16px;font-weight:700;color:var(--text-muted);margin-top:32px;padding-top:20px;border-top:1px solid var(--border);display:flex;align-items:center;gap:8px}
.svc-accredited i{color:var(--lime-dark)}

/* NOM mini cards */
.noms-mini-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-bottom:8px}
.nom-mini-card{background:var(--white);border:1px solid var(--border);border-radius:var(--radius);padding:16px 12px;text-align:center;box-shadow:var(--shadow-sm);transition:box-shadow var(--transition),transform var(--transition)}
.nom-mini-card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}
.svc-block--alt .nom-mini-card{background:var(--white)}
.nom-mini-card i{font-size:22px;color:var(--lime-dark);display:block;margin-bottom:8px}
.nom-mini-code{display:block;font-size:10px;font-weight:800;color:var(--navy);letter-spacing:-0.2px;margin-bottom:4px}
.nom-mini-desc{display:block;font-size:11px;color:var(--text-muted);line-height:1.4}

/* Label types */
.labels-type-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.labels-type-card{background:var(--white);border:2px solid var(--lime);border-radius:var(--radius);padding:28px 16px;text-align:center}
.svc-block--alt .labels-type-card{background:var(--white)}
.labels-type-card i{font-size:30px;color:var(--lime-dark);display:block;margin-bottom:12px}
.labels-type-card span{font-size:14px;font-weight:700;color:var(--navy)}

/* OCP norms grid */
.ocp-norms-grid{display:flex;flex-wrap:wrap;gap:7px}
.ocp-norm-chip{background:rgba(27,47,78,.06);color:var(--navy);border:1px solid var(--border);border-radius:6px;padding:4px 10px;font-size:10.5px;font-weight:700;letter-spacing:0.2px}

/* Hero navigation pills */
.page-hero-nav{display:flex;flex-wrap:wrap;justify-content:center;gap:10px;margin-top:28px}
.phn-pill{display:inline-flex;align-items:center;gap:7px;background:rgba(255,255,255,.1);color:rgba(255,255,255,.85);border:1px solid rgba(255,255,255,.2);border-radius:25px;padding:8px 18px;font-size:13px;font-weight:600;text-decoration:none;transition:all .25s;backdrop-filter:blur(4px)}
.phn-pill:hover,.phn-pill:focus{background:var(--lime);color:var(--navy);border-color:var(--lime)}

/* Block head tag */
.svc-block-head .tag{display:block;margin-bottom:6px}

/* Label type card small description */
.labels-type-card small{display:block;font-size:12px;color:var(--text-muted);margin-top:6px;font-weight:400}

/* Highlight card (columna derecha UVA / OCP) */
.svc-highlight-card{background:linear-gradient(135deg,#1b2f4e 0%,#243d62 100%);border-radius:var(--radius-lg);padding:36px 32px;display:flex;flex-direction:column;align-items:flex-start;height:100%}
.shc-icon{width:56px;height:56px;background:rgba(150,201,61,.15);border-radius:14px;display:flex;align-items:center;justify-content:center;font-size:26px;color:var(--lime);margin-bottom:18px;flex-shrink:0}
.svc-highlight-card h4{font-size:18px;font-weight:800;color:#fff;margin-bottom:18px;line-height:1.3}
.shc-list{list-style:none;padding:0;margin:0 0 auto;display:flex;flex-direction:column;gap:10px}
.shc-list li{display:flex;align-items:flex-start;gap:10px;font-size:14px;color:rgba(255,255,255,.8);line-height:1.5}
.shc-list li i{color:var(--lime);font-size:11px;margin-top:3px;flex-shrink:0}
.shc-cta{display:inline-flex;align-items:center;gap:8px;background:var(--lime);color:var(--navy);border-radius:25px;padding:10px 24px;font-size:13px;font-weight:800;text-decoration:none;transition:background var(--transition),transform var(--transition);white-space:nowrap;margin-top:28px;flex-shrink:0}
.shc-cta:hover{background:var(--lime-dark);transform:translateY(-2px)}

/* Almacenaje — stats bar */
.alm-stats-bar{display:grid;grid-template-columns:repeat(4,1fr);background:var(--navy);border-radius:var(--radius-lg);overflow:hidden;margin-top:16px}
.alm-stat{padding:28px 24px;text-align:center;border-right:1px solid rgba(255,255,255,.08)}
.alm-stat:last-child{border-right:none}
.alm-stat > i{font-size:24px;color:var(--lime);display:block;margin-bottom:10px}
.alm-stat strong{display:block;font-size:22px;font-weight:900;color:#fff;line-height:1;margin-bottom:6px}
.alm-stat span{font-size:12px;font-weight:600;color:rgba(255,255,255,.6);letter-spacing:.2px;display:block}

/* Almacenaje — location card */
.alm-location-card{background:var(--white);border:1px solid var(--border);border-radius:var(--radius-lg);padding:28px;display:flex;gap:20px;align-items:flex-start;box-shadow:var(--shadow-sm)}
.alm-location-icon{width:52px;height:52px;flex-shrink:0;background:rgba(150,201,61,.1);border-radius:14px;display:flex;align-items:center;justify-content:center;font-size:24px;color:var(--lime-dark)}
.alm-location-card strong{font-size:16px;font-weight:800;color:var(--navy);display:block;margin-bottom:10px}

/* ¿Por qué elegirnos? */
.about-why-section{padding-top:72px;padding-bottom:72px;background:var(--bg)}
.about-why-title{font-size:32px;font-weight:900;color:var(--navy);text-align:center;margin-bottom:48px}
.about-why-grid{display:grid;grid-template-columns:1fr 1fr;gap:24px 60px;max-width:720px;margin:0 auto}
.about-why-item{display:flex;align-items:flex-start;gap:16px;font-size:15px;color:var(--text-muted);font-weight:500;line-height:1.6}
.about-why-item i{color:var(--lime-dark);font-size:18px;margin-top:2px;flex-shrink:0}

/* Tira de contacto */
.about-contact-strip{background:var(--navy);padding:64px 0}
.contact-strip-inner h3{font-size:28px;font-weight:800;color:#fff;text-align:center;margin-bottom:40px}
.contact-strip-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:32px}
.contact-strip-col{display:flex;flex-direction:column;gap:6px}
.contact-strip-col i{font-size:22px;color:var(--lime);margin-bottom:6px}
.contact-strip-col strong{font-size:12px;font-weight:700;color:#fff;text-transform:uppercase;letter-spacing:0.7px;margin-bottom:2px}
.contact-strip-col a,.contact-strip-col span{font-size:14px;color:rgba(255,255,255,.7);text-decoration:none;line-height:1.6;transition:color .2s}
.contact-strip-col a:hover{color:var(--lime)}
/* ---- CONTACTO REDISEÑO (portada) ---- */
.ct2-section{
    background: var(--navy);
    padding: 90px 0;
    position: relative;
    overflow: hidden;
    background-image:
        url('../background/BK_Serv.png');
    background-attachment: fixed;
    background-position: center;
    background-size: cover;
    background-blend-mode: overlay;
}
.ct2-section::before{
    content: '';
    position: absolute;
    inset: 0;
    background: linear-gradient(135deg, rgba(12, 26, 46, 0.47) 0%, rgba(27, 47, 78, 0.502) 60%, rgba(27, 47, 78, 0.548) 100%);
    pointer-events: none;
    z-index: 0;
}
.ct2-section::after{
    content: '';
    position: absolute;
    bottom: -80px;
    left: -60px;
    width: 320px;
    height: 320px;
    background: radial-gradient(circle, rgba(150, 201, 61, 0.05) 0%, transparent 65%);
    pointer-events: none;
    z-index: 1;
}
.ct2-wrap{
    max-width: 1160px;
    margin: 0 auto;
    padding: 0 60px;
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 80px;
    align-items: center;
    position: relative;
    z-index: 2;
}
.ct2-eyebrow{display:inline-flex;align-items:center;gap:7px;background:rgba(150,201,61,.12);color:var(--lime);border:1px solid rgba(150,201,61,.25);border-radius:20px;padding:5px 16px;font-size:11px;font-weight:700;letter-spacing:.8px;text-transform:uppercase;margin-bottom:22px}
.ct2-title{font-size:40px;font-weight:900;color:#fff;line-height:1.15;margin-bottom:18px}
.ct2-lead{font-size:15px;color:rgba(255,255,255,.58);line-height:1.85;margin-bottom:34px;max-width:400px}
.ct2-btns{display:flex;flex-wrap:wrap;gap:12px}
.ct2-cards{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.ct2-card{background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.07);border-left:3px solid var(--lime);border-radius:14px;padding:22px 20px;display:flex;gap:14px;align-items:flex-start;transition:background .2s,transform .2s,box-shadow .2s}
.ct2-card:hover{background:rgba(255,255,255,.09);transform:translateY(-3px);box-shadow:0 8px 28px rgba(0,0,0,.25)}
.ct2-card-icon{width:44px;height:44px;border-radius:11px;background:rgba(150,201,61,.15);color:var(--lime);display:flex;align-items:center;justify-content:center;font-size:18px;flex-shrink:0}
.ct2-icon-wa{background:rgba(37,211,102,.14);color:#25d366}
.ct2-card-body{display:flex;flex-direction:column;gap:3px;min-width:0}
.ct2-card-body strong{font-size:10.5px;font-weight:700;text-transform:uppercase;letter-spacing:.7px;color:rgba(255,255,255,.4);margin-bottom:5px}
.ct2-card-body a,.ct2-card-body span{font-size:14px;color:rgba(255,255,255,.82);text-decoration:none;line-height:1.65;transition:color .2s;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.ct2-card-body a:hover{color:var(--lime)}
.ct2-wa-hint{font-size:12px!important;color:rgba(37,211,102,.7)!important;font-weight:600}
@media(max-width:960px){.ct2-wrap{grid-template-columns:1fr;gap:44px;padding:0 40px}.ct2-title{font-size:32px}.ct2-section::before,.ct2-section::after{display:none}}
@media(max-width:600px){.ct2-wrap{padding:0 24px}.ct2-cards{grid-template-columns:1fr}.ct2-title{font-size:27px}}

/* ---- NOMS (rediseño) ---- */
/* ---- SECCIÓN NORMATIVAS — Carrusel con hover ---- */
.noms-section-new{background:linear-gradient(180deg,#1b2f4e 0%,#142640 35%,#0f1f35 65%,#1b2f4e 100%)}
.noms-header{background:linear-gradient(135deg,#1b2f4e 0%,#254056 60%,#2e5068 100%);padding:70px 60px 60px;text-align:center;position:relative;overflow:hidden}
.noms-header::before{content:'';position:absolute;top:-80px;right:-80px;width:360px;height:360px;background:radial-gradient(circle,rgba(150,201,61,.15) 0%,transparent 70%);pointer-events:none}
.noms-badge{display:inline-flex;align-items:center;gap:7px;background:rgba(150,201,61,.15);color:var(--lime);border:1px solid rgba(150,201,61,.35);border-radius:20px;padding:5px 16px;font-size:12px;font-weight:700;letter-spacing:0.8px;text-transform:uppercase;margin-bottom:18px}
.noms-header h2{font-size:34px;font-weight:800;color:#fff;line-height:1.25;margin-bottom:14px}
.noms-header p{font-size:16px;color:rgba(255,255,255,.7);max-width:560px;margin:0 auto}

.noms-simple-divider{height:40px;background:transparent;position:relative}
.noms-simple-divider::before{content:'';position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);width:60px;height:4px;background:linear-gradient(90deg,var(--lime),var(--lime-dark));border-radius:2px}

/* Carrusel wrapper */
.noms-carousel-section{position:relative;padding:60px 100px 70px;background:transparent}
.noms-carousel-outer{overflow:hidden;cursor:default}
.noms-carousel-track{display:flex;gap:24px;will-change:transform}

/* Tarjeta */
.norm-card{min-width:460px;width:460px;position:relative;border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-sm);border:1px solid var(--border);transition:box-shadow var(--transition),transform var(--transition);outline:none;cursor:default;flex-shrink:0}
.norm-card:hover,.norm-card:focus-within{box-shadow:var(--shadow-lg);transform:translateY(-4px)}

/* Cara frontal */
.norm-card-front{background:var(--white)}
.norm-card-icon-area{background:linear-gradient(135deg,#1b2f4e 0%,#254056 100%);height:200px;display:flex;align-items:center;justify-content:center;font-size:64px;color:var(--lime);position:relative}
.norm-card-img-area{height:230px;overflow:hidden}
.norm-card-img-area img{width:100%;height:100%;object-fit:cover;display:block}
.norm-card-info{padding:26px 28px 28px}
.norm-code-chip{display:inline-block;background:rgba(150,201,61,.12);color:var(--lime-dark);border:1px solid rgba(150,201,61,.3);border-radius:20px;padding:3px 12px;font-size:11.5px;font-weight:800;letter-spacing:.6px;margin-bottom:10px}
.norm-card-sub{font-size:14px;font-weight:600;color:var(--navy);margin-bottom:14px;line-height:1.4}
.norm-hover-hint{font-size:11.5px;color:var(--text-muted);display:flex;align-items:center;gap:5px;opacity:.7;transition:opacity var(--transition)}
.norm-card:hover .norm-hover-hint{opacity:0}

/* Overlay detallado — desliza desde abajo */
.norm-card-overlay{position:absolute;inset:0;background:linear-gradient(160deg,#1b2f4e 0%,#254056 100%);transform:translateY(100%);transition:transform .38s cubic-bezier(.4,0,.2,1);padding:0;overflow:hidden;pointer-events:none}
.norm-card:hover .norm-card-overlay,.norm-card:focus-within .norm-card-overlay{transform:translateY(0);pointer-events:auto}
.norm-overlay-scroll{padding:26px 24px 24px;height:100%;overflow-y:auto}
.norm-overlay-tag{display:inline-flex;align-items:center;gap:6px;background:rgba(150,201,61,.18);color:var(--lime);border:1px solid rgba(150,201,61,.35);border-radius:20px;padding:3px 12px;font-size:11px;font-weight:700;letter-spacing:.5px;margin-bottom:12px}
.norm-card-overlay h3{font-size:16px;font-weight:800;color:#fff;margin-bottom:6px;line-height:1.3}
.norm-card-overlay h4{font-size:13px;font-weight:600;color:rgba(255,255,255,.75);margin-bottom:12px;line-height:1.4}
.norm-card-overlay p{font-size:12.5px;color:rgba(255,255,255,.65);line-height:1.75;margin-bottom:14px}
.norm-overlay-list{list-style:none;display:flex;flex-direction:column;gap:8px}
.norm-overlay-list li{display:flex;align-items:flex-start;gap:8px;font-size:12px;color:rgba(255,255,255,.8);font-weight:500;line-height:1.5}
.norm-overlay-list li i{color:var(--lime);font-size:11px;flex-shrink:0;margin-top:3px}

/* Flechas */
.noms-arrow{position:absolute;top:50%;transform:translateY(-50%);width:46px;height:46px;border-radius:50%;background:rgba(255,255,255,.08);border:1.5px solid rgba(255,255,255,.15);color:#fff;font-size:16px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all var(--transition);box-shadow:var(--shadow-sm);z-index:10}
.noms-arrow:hover{background:var(--lime);border-color:var(--lime);color:#fff;transform:translateY(-50%) scale(1.08)}
.noms-prev{left:20px}
.noms-next{right:20px}
/* Dots */
.noms-dots{display:flex;justify-content:center;gap:9px;margin-top:28px}
.noms-dot{width:10px;height:10px;border-radius:50%;background:rgba(255,255,255,.2);border:none;cursor:pointer;padding:0;transition:background var(--transition),transform var(--transition)}
.noms-dot.active{background:var(--lime);transform:scale(1.3)}

/* ===== NUEVOS ESTILOS: GRUPOS DE NORMATIVAS EXPANDIBLES ===== */
.norms-groups-container{display:flex;flex-direction:column;gap:16px;padding:60px 100px 70px;background:transparent}

.norm-group{border:1px solid rgba(255,255,255,.1);border-radius:var(--radius-lg);overflow:hidden;background:rgba(255,255,255,.04);box-shadow:var(--shadow-sm);transition:box-shadow var(--transition),border-color var(--transition)}

.norm-group.is-expanded{box-shadow:var(--shadow-md);border-color:var(--lime)}

.norm-group-header{display:flex;align-items:center;justify-content:space-between;padding:28px 32px;cursor:pointer;user-select:none;transition:background var(--transition);outline:none}

.norm-group-header:hover{background:rgba(150,201,61,.08)}

.norm-group-header:focus{outline:2px solid var(--lime);outline-offset:2px}

.norm-group-header-left{display:flex;align-items:center;gap:20px;flex:1}

.norm-group-icon{width:56px;height:56px;border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:24px;color:#fff;flex-shrink:0}

.norm-group-title-area{display:flex;flex-direction:column;gap:4px}

.norm-group-title{font-size:16px;font-weight:800;color:#fff;margin:0;line-height:1.3}

.norm-group-code{font-size:12px;font-weight:700;color:rgba(255,255,255,.45);letter-spacing:.5px;text-transform:uppercase}

.norm-group-toggle{width:32px;height:32px;border-radius:50%;background:rgba(150,201,61,.1);display:flex;align-items:center;justify-content:center;color:var(--lime);font-size:14px;transition:transform var(--transition),background var(--transition);flex-shrink:0}

.norm-group-header:hover .norm-group-toggle{background:rgba(150,201,61,.2)}

.norm-group-content{max-height:0;opacity:0;visibility:hidden;overflow:hidden;transition:max-height .4s cubic-bezier(.4,0,.2,1),opacity .4s ease,visibility .4s ease}

.norm-group-inner{padding:0 32px 32px;display:flex;flex-direction:column;gap:32px}

.norm-group-section{display:flex;flex-direction:column;gap:16px}

.norm-group-section-title{font-size:14px;font-weight:800;color:rgba(255,255,255,.5);text-transform:uppercase;letter-spacing:.8px;margin:0}

.norm-services-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:12px}

.norm-service-tag{display:flex;align-items:center;gap:8px;padding:10px 14px;border:1.5px solid;border-radius:8px;font-size:12px;font-weight:600;color:rgba(255,255,255,.8);transition:all var(--transition)}

.norm-service-tag:hover{transform:translateY(-2px);box-shadow:0 6px 12px rgba(0,0,0,.08)}

.norm-service-tag i{font-size:10px;flex-shrink:0}

.norm-codes-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:12px}

.norm-code-card{border:1.5px solid;border-radius:10px;padding:14px;transition:all var(--transition);cursor:default;display:flex;flex-direction:column;gap:8px;background:rgba(255,255,255,.05)}

.norm-code-card:hover{transform:translateY(-4px);box-shadow:0 8px 16px rgba(0,0,0,.12)}

.norm-code-badge{display:inline-flex;align-items:center;justify-content:center;width:40px;height:40px;border-radius:50%;color:#fff;font-weight:800;font-size:11px;flex-shrink:0}

.norm-code-info{display:flex;flex-direction:column;gap:4px}

.norm-code-info strong{font-size:13px;font-weight:700;color:#fff;line-height:1.3}

.norm-code-info small{font-size:11px;color:rgba(255,255,255,.45);line-height:1.3;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}

/* Responsive */
@media(max-width:960px){
    .noms-carousel-section{padding:40px 60px 50px}
    .norm-card{min-width:calc(50% - 12px);width:calc(50% - 12px)}
    .noms-header{padding:48px 24px 40px}
    .noms-header h2{font-size:24px}
}
@media(max-width:640px){
    .noms-carousel-section{padding:32px 48px 44px}
    .norm-card{min-width:100%;width:100%}
    .noms-prev{left:4px}.noms-next{right:4px}
    .noms-arrow{width:38px;height:38px;font-size:14px}
}

/* ---- GRID ESTÁTICO NOMs (servicios.php) ---- */
.sv-noms-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:24px;margin-top:8px}
.sv-noms-grid .norm-card{width:100%;min-width:0;flex-shrink:unset;border-top:3px solid var(--lime)}
.sv-noms-grid .norm-card:hover,.sv-noms-grid .norm-card:focus-within{box-shadow:0 12px 40px rgba(150,201,61,.18),var(--shadow-lg);transform:translateY(-5px)}
.sv-noms-grid .norm-card-icon-area{height:155px;overflow:hidden}
.sv-noms-grid .norm-card-icon-area::after{content:'';position:absolute;inset:0;background:linear-gradient(135deg,rgba(150,201,61,.12) 0%,transparent 55%);pointer-events:none}
.sv-noms-grid .norm-code-chip{background:var(--lime);color:#fff;border-color:var(--lime);font-size:11px}
@media(max-width:960px){.sv-noms-grid{grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:20px}}
@media(max-width:520px){.sv-noms-grid{grid-template-columns:1fr;gap:16px}}

/* ---- DIAPOSITIVAS (SDX) ---- */
.sdx-section{position:relative;background:linear-gradient(150deg,#071525 0%,#0e2240 50%,#071a34 100%);padding:80px 48px 96px;overflow:hidden}
/* Glows decorativos */
.sdx-bg-dec{position:absolute;inset:0;pointer-events:none;overflow:hidden}
.sdx-glow{border-radius:50%;filter:blur(80px);position:absolute;opacity:.35}
.sdx-glow-1{width:500px;height:500px;background:radial-gradient(circle,#96c93d55,transparent 70%);top:-120px;left:-80px}
.sdx-glow-2{width:600px;height:600px;background:radial-gradient(circle,#1d4e8955,transparent 70%);bottom:-150px;right:-100px}
.sdx-container{position:relative;z-index:1;max-width:1200px;margin:0 auto}
/* Header */
.sdx-header{text-align:center;max-width:640px;margin:0 auto 52px}
.sdx-eyebrow{display:inline-flex;align-items:center;gap:8px;background:rgba(150,201,61,.12);color:#96c93d;border:1px solid rgba(150,201,61,.35);border-radius:99px;padding:6px 18px;font-size:11px;font-weight:800;letter-spacing:1px;text-transform:uppercase;margin-bottom:18px}
.sdx-title{font-size:clamp(1.8rem,2.8vw,2.6rem);font-weight:900;color:#fff;line-height:1.2;margin:0 0 14px}
.sdx-title span{color:#96c93d}
.sdx-subtitle{font-size:.95rem;color:rgba(255,255,255,.65);line-height:1.75;margin:0}
/* Badge tipo */
.sdx-type-badge{display:inline-flex;align-items:center;gap:4px;padding:2px 7px;border-radius:99px;font-size:8px;font-weight:800;letter-spacing:.6px;text-transform:uppercase;flex-shrink:0}
.sdx-type-pdf{background:rgba(239,68,68,.2);color:#f87171;border:1px solid rgba(239,68,68,.3)}
.sdx-type-image{background:rgba(59,130,246,.2);color:#93c5fd;border:1px solid rgba(59,130,246,.3)}
/* Botones */
.sdx-btn-dl{display:inline-flex;align-items:center;gap:7px;background:#96c93d;color:#0a1628;border:none;border-radius:10px;padding:9px 20px;font-size:.8rem;font-weight:800;text-decoration:none;transition:background .2s,transform .15s;white-space:nowrap;cursor:pointer}
.sdx-btn-dl:hover{background:#a8d94a;transform:translateY(-1px)}
.sdx-btn-open{display:inline-flex;align-items:center;justify-content:center;width:36px;height:36px;background:rgba(255,255,255,.08);color:#fff;border:1px solid rgba(255,255,255,.15);border-radius:10px;font-size:.8rem;text-decoration:none;transition:background .2s;cursor:pointer}
.sdx-btn-open:hover{background:rgba(255,255,255,.15)}
/* ── FEATURED (1 sola) ── */
.sdx-featured{background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.1);border-radius:24px;overflow:hidden;backdrop-filter:blur(6px)}
.sdx-feat-header{display:flex;align-items:flex-start;justify-content:space-between;gap:24px;padding:28px 32px;border-bottom:1px solid rgba(255,255,255,.08);flex-wrap:wrap}
.sdx-feat-info{flex:1;display:flex;flex-direction:column;gap:8px}
.sdx-feat-title{font-size:1.3rem;font-weight:800;color:#fff;margin:0}
.sdx-feat-desc{font-size:.85rem;color:rgba(255,255,255,.6);margin:0;line-height:1.6}
.sdx-feat-actions{display:flex;align-items:center;gap:10px;flex-shrink:0}
.sdx-feat-frame{background:#0a1628;min-height:660px;position:relative}
.sdx-feat-frame .sdx-iframe{position:absolute;inset:0;width:100%;height:100%;border:none;display:block}
.sdx-feat-img{width:100%;max-height:700px;object-fit:contain;display:block}
/* ── LAYOUT MULTI ── */
.sdx-layout{display:grid;grid-template-columns:280px 1fr;border-radius:24px;overflow:hidden;border:1px solid rgba(255,255,255,.1)}
/* Sidebar */
.sdx-sidebar{background:rgba(7,21,37,.75);border-right:1px solid rgba(255,255,255,.08);padding:16px;display:flex;flex-direction:column;gap:8px;max-height:700px;overflow-y:auto}
.sdx-sidebar::-webkit-scrollbar{width:4px}
.sdx-sidebar::-webkit-scrollbar-thumb{background:rgba(255,255,255,.15);border-radius:4px}
.sdx-card{display:flex;align-items:center;gap:12px;width:100%;text-align:left;background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.07);border-radius:14px;padding:12px;cursor:pointer;transition:background .2s,border-color .2s;color:#fff}
.sdx-card:hover{background:rgba(255,255,255,.08);border-color:rgba(255,255,255,.15)}
.sdx-card--active{background:rgba(150,201,61,.1)!important;border-color:rgba(150,201,61,.5)!important}
.sdx-card--active .sdx-card-arr{color:#96c93d;opacity:1}
.sdx-card-thumb{width:52px;height:52px;border-radius:10px;overflow:hidden;flex-shrink:0;background:rgba(255,255,255,.06);display:flex;align-items:center;justify-content:center}
.sdx-card-thumb img{width:100%;height:100%;object-fit:cover}
.sdx-card-icon{width:52px;height:52px;display:flex;align-items:center;justify-content:center;font-size:1.4rem;border-radius:10px}
.sdx-card-icon--pdf{background:rgba(239,68,68,.15);color:#f87171}
.sdx-card-icon--image{background:rgba(59,130,246,.15);color:#93c5fd}
.sdx-card-body{flex:1;display:flex;flex-direction:column;gap:3px;min-width:0}
.sdx-card-type{font-size:9px;font-weight:800;letter-spacing:.7px;text-transform:uppercase;color:rgba(255,255,255,.4)}
.sdx-card-title{font-size:.8rem;font-weight:700;color:#e2e8f0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.sdx-card-arr{font-size:.65rem;color:rgba(255,255,255,.25);flex-shrink:0;transition:color .2s}
/* Viewer */
.sdx-viewer{background:#071525;display:flex;flex-direction:column}
.sdx-panel{display:none;flex-direction:column;min-height:700px}
.sdx-panel--active{display:flex}
.sdx-panel-bar{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:18px 24px;border-bottom:1px solid rgba(255,255,255,.08);flex-wrap:wrap;background:rgba(255,255,255,.03)}
.sdx-panel-bar-left{display:flex;align-items:center;gap:12px;min-width:0;flex:1}
.sdx-panel-name{font-size:.9rem;font-weight:800;color:#fff;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.sdx-panel-desc{font-size:.75rem;color:rgba(255,255,255,.5);margin-top:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.sdx-panel-bar-right{display:flex;align-items:center;gap:8px;flex-shrink:0}
.sdx-frame-wrap{flex:1;position:relative;min-height:580px}
.sdx-iframe{position:absolute;inset:0;width:100%;height:100%;border:none;display:block}
.sdx-img-wrap{display:flex;align-items:center;justify-content:center;min-height:580px;padding:24px}
.sdx-img{max-width:100%;max-height:640px;object-fit:contain;border-radius:8px;box-shadow:0 8px 40px rgba(0,0,0,.4)}
/* Responsive */
@media(max-width:900px){
  .sdx-layout{grid-template-columns:1fr;border-radius:20px}
  .sdx-sidebar{max-height:none;flex-direction:row;overflow-x:auto;overflow-y:hidden;border-right:none;border-bottom:1px solid rgba(255,255,255,.08)}
  .sdx-card{min-width:200px;flex-shrink:0}
  .sdx-card-arr{display:none}
}
@media(max-width:768px){
  .sdx-section{padding:52px 20px 64px}
  .sdx-frame-wrap,.sdx-panel{min-height:420px}
  .sdx-feat-header{padding:20px}
  .sdx-feat-title{font-size:1.1rem}
  .sdx-feat-frame{min-height:460px}
}
@media(max-width:480px){
  .sdx-frame-wrap{min-height:320px}
  .sdx-feat-frame{min-height:340px}
  .sdx-panel-name{font-size:.8rem}
  .sdx-btn-dl span{display:none}
  .sdx-btn-dl{padding:9px 13px}
}

/* ---- CARRUSEL CLIENTES ---- */
.carousel-track-wrapper{overflow:hidden;position:relative}
.carousel-track-wrapper::before,.carousel-track-wrapper::after{content:'';position:absolute;top:0;width:80px;height:100%;z-index:2}
.carousel-track-wrapper::before{left:0;background:linear-gradient(to right,var(--off-white),transparent)}
.carousel-track-wrapper::after{right:0;background:linear-gradient(to left,var(--off-white),transparent)}
.carousel-track{display:flex;gap:24px;width:max-content;animation:scrollTrack 28s linear infinite}
.carousel-track:hover{animation-play-state:paused}
@keyframes scrollTrack{from{transform:translateX(0)}to{transform:translateX(-50%)}}
.client-card{width:160px;height:90px;background:var(--white);border:1px solid var(--border);border-radius:var(--radius);display:flex;align-items:center;justify-content:center;padding:16px;flex-shrink:0;transition:box-shadow var(--transition)}
.client-card:hover{box-shadow:var(--shadow-md)}
.client-card i{font-size:26px;color:#bcc8d4}
.stars{display:flex;justify-content:center;gap:6px;margin-bottom:36px}
.stars i{color:#f5c518;font-size:26px}

/* ---- CONTACTO REDISEÑADO ---- */
.cnt-hero{background:linear-gradient(135deg,#1a2d49 0%,#253f5a 100%);padding:80px 60px 0}
.cnt-hero-inner{max-width:1200px;margin:0 auto;text-align:center}
.cnt-hero-inner h2{font-size:36px;font-weight:900;color:#fff;margin:14px 0 10px;line-height:1.2}
.cnt-hero-lead{font-size:16px;color:rgba(255,255,255,.62);line-height:1.75;max-width:540px;margin:0 auto 48px}
.cnt-cards-row{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;margin-bottom:0}
.cnt-card{background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.12);border-radius:16px;padding:32px 28px;text-align:left;backdrop-filter:blur(6px);transition:background .25s,transform .25s}
.cnt-card:hover{background:rgba(255,255,255,.13);transform:translateY(-3px)}
.cnt-card-icon{width:52px;height:52px;background:var(--lime);border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:22px;color:#1b2f4e;margin-bottom:18px;flex-shrink:0}
.cnt-card strong{display:block;font-size:12px;font-weight:800;color:#fff;text-transform:uppercase;letter-spacing:1px;margin-bottom:12px}
.cnt-card span{display:block;font-size:14px;color:rgba(255,255,255,.72);line-height:1.7}
a.cnt-card-link{display:block;font-size:14px;color:rgba(255,255,255,.85);text-decoration:none;line-height:1.7;transition:color .2s}
a.cnt-card-link:hover{color:var(--lime)}
.cnt-actions-row{display:flex;justify-content:center;gap:14px;padding:38px 0 0}
.cnt-action-btn{display:inline-flex;align-items:center;gap:8px;padding:13px 26px;border-radius:30px;font-size:14px;font-weight:700;text-decoration:none;transition:all .25s;white-space:nowrap}
.cnt-action-btn i{font-size:15px}
.cnt-btn-wa{background:#25d366;color:#fff}.cnt-btn-wa:hover{background:#1daa52;color:#fff;transform:translateY(-2px)}
.cnt-btn-msg{background:var(--lime);color:#1b2f4e}.cnt-btn-msg:hover{background:var(--lime-dark);color:#1b2f4e;transform:translateY(-2px)}
.cnt-btn-info{background:rgba(255,255,255,.1);color:#fff;border:1px solid rgba(255,255,255,.2)}.cnt-btn-info:hover{background:rgba(255,255,255,.18);transform:translateY(-2px)}
.cnt-body{background:var(--white);padding-top:70px;padding-bottom:80px}
.cnt-map-form{display:grid;grid-template-columns:1fr 1.25fr;gap:60px;align-items:start;max-width:1200px;margin:0 auto;padding:0 60px}
.cnt-map-col h3,.cnt-map-col h3+p{display:block}

/* ---- SERVICIOS EN PORTADA ---- */
.svc-home-section{background:var(--light-gray) url(../img/fondo_services.jpeg) center/cover no-repeat fixed;overflow-x:hidden}
.svc-home-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:24px}
.svc-home-card{background:var(--white);border-radius:var(--radius-lg);padding:32px 28px;border:1.5px solid var(--border);text-decoration:none;display:flex;flex-direction:column;transition:all .25s}
.svc-home-card:hover{border-color:var(--lime);transform:translateY(-5px);box-shadow:var(--shadow-md)}
.svc-home-icon{width:56px;height:56px;background:rgba(150,201,61,.12);border-radius:14px;display:flex;align-items:center;justify-content:center;font-size:24px;color:var(--lime-dark);margin-bottom:14px;flex-shrink:0}
.svc-home-num{font-size:10.5px;font-weight:800;color:var(--lime-dark);text-transform:uppercase;letter-spacing:1.5px;margin-bottom:10px}
.svc-home-card h3{font-size:15.5px;font-weight:800;color:var(--navy);margin-bottom:10px;line-height:1.35}
.svc-home-card p{font-size:13.5px;color:var(--text-muted);line-height:1.7;margin-bottom:20px;flex:1}
.svc-home-link{display:inline-flex;align-items:center;gap:6px;font-size:13px;font-weight:700;color:var(--lime-dark);transition:gap .2s;margin-top:auto}
.svc-home-card:hover .svc-home-link{gap:10px}
.svc-home-card:hover .svc-home-link i{transform:translateX(2px)}
.contact-info h2{font-size:28px;font-weight:800;color:var(--navy);margin-bottom:12px}
.contact-info p{font-size:15px;color:var(--text-muted);line-height:1.8;margin-bottom:30px}
.contact-item{display:flex;align-items:center;gap:14px;margin-bottom:18px}
.contact-item-icon{width:44px;height:44px;background:rgba(150,201,61,.1);border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:18px;color:var(--lime-dark);flex-shrink:0}
.contact-item-text span{display:block;font-size:11px;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:0.5px}
.contact-item-text a,.contact-item-text p{font-size:14px;color:var(--text-dark);text-decoration:none;font-weight:600}
.contact-social{display:flex;gap:10px;margin-top:24px}
.contact-social a{width:40px;height:40px;border-radius:50%;background:var(--light-gray);display:flex;align-items:center;justify-content:center;color:var(--slate);font-size:16px;text-decoration:none;transition:all var(--transition)}
.contact-social a:hover{background:var(--navy);color:var(--white)}
.contact-form-box{background:var(--white);border-radius:var(--radius-lg);padding:40px;box-shadow:var(--shadow-md);border:1px solid var(--border)}
.form-group{margin-bottom:18px}
.form-group label{display:block;font-size:12.5px;font-weight:700;color:var(--slate);letter-spacing:0.3px;text-transform:uppercase;margin-bottom:6px}
.form-group input,.form-group textarea,.form-group select{width:100%;padding:11px 16px;border:1.5px solid var(--border);border-radius:8px;font-size:14px;color:var(--text-dark);background:var(--white);transition:border-color var(--transition),box-shadow var(--transition);outline:none;font-family:inherit}
.form-group input:focus,.form-group textarea:focus,.form-group select:focus{border-color:var(--lime);box-shadow:0 0 0 3px rgba(150,201,61,.15)}
.form-group textarea{resize:vertical;min-height:110px}
.map-wrapper{width:100%;height:300px;border-radius:var(--radius);overflow:hidden;border:1.5px solid var(--border);margin-top:28px}
.map-placeholder{width:100%;height:100%;background:var(--light-gray);display:flex;align-items:center;justify-content:center;color:var(--text-muted);font-size:14px;gap:8px}

/* ======================================================
   ACREDITACIONES Y ORGANISMOS — Premium
   ====================================================== */
.acred-section{position:relative;background:url('../background/BK_Serv.png') center center/cover no-repeat;padding:72px 0 0;overflow:hidden}
.acred-section::before{content:'';position:absolute;inset:0;background:rgba(10,20,38,.76);pointer-events:none;z-index:0}
.acred-bg-grid{position:absolute;inset:0;pointer-events:none;background-image:linear-gradient(rgba(150,201,61,.03) 1px,transparent 1px),linear-gradient(90deg,rgba(150,201,61,.03) 1px,transparent 1px);background-size:60px 60px}
.acred-top-line{position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,transparent,var(--lime),transparent)}

/* Cabecera */
.acred-header{text-align:center;max-width:680px;margin:0 auto 36px;padding:0 20px;position:relative;z-index:2}
.acred-title{font-size:clamp(1.3rem,2.2vw,1.9rem);font-weight:800;color:#fff;letter-spacing:-.2px;line-height:1.25;margin:0}

/* Pista del carrusel */
.acred-track-wrapper{position:relative;overflow:hidden;padding:10px 0 10px;margin-bottom:0;z-index:2}
.acred-track-wrapper::before,.acred-track-wrapper::after{content:'';position:absolute;top:0;width:160px;height:100%;z-index:2;pointer-events:none}
.acred-track-wrapper::before{left:0;background:linear-gradient(to right,rgba(10,20,38,.9),transparent)}
.acred-track-wrapper::after{right:0;background:linear-gradient(to left,rgba(10,20,38,.9),transparent)}
.acred-track{display:flex;align-items:stretch;gap:20px;width:max-content;will-change:transform}
.acred-track.is-running{animation:acredMarquee var(--acred-dur,28s) linear infinite}
.acred-track.is-running:hover{animation-play-state:paused}
@keyframes acredMarquee{from{transform:translateX(0)}to{transform:translateX(var(--acred-dist,-50%))}}

/* Tarjeta de logo */
.acred-logo-card{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:0;width:210px;height:120px;padding:24px 28px;background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.09);border-radius:16px;flex-shrink:0;transition:background .35s,border-color .35s,transform .35s,box-shadow .35s;cursor:default;position:relative;overflow:hidden}
/* Capa de glow interno al hover */
.acred-logo-card::before{content:'';position:absolute;inset:0;border-radius:16px;background:radial-gradient(ellipse at 50% 120%,rgba(150,201,61,.18) 0%,transparent 70%);opacity:0;transition:opacity .35s}
.acred-logo-card:hover::before{opacity:1}
.acred-logo-card:hover{background:rgba(255,255,255,.10);border-color:rgba(150,201,61,.5);transform:translateY(-6px);box-shadow:0 0 0 1px rgba(150,201,61,.2),0 16px 40px rgba(0,0,0,.4),0 0 28px rgba(150,201,61,.12)}
.acred-logo-inner{width:100%;height:100%;display:flex;align-items:center;justify-content:center}
.acred-logo-inner img{max-width:100%;max-height:68px;object-fit:contain;filter:grayscale(100%) opacity(.55) brightness(1.15);transition:filter .4s ease,transform .35s ease}
.acred-logo-card:hover .acred-logo-inner img{filter:grayscale(0%) opacity(1) brightness(1.1) drop-shadow(0 0 8px rgba(150,201,61,.35));transform:scale(1.06)}
.acred-logo-name{display:none}

/* Fila de confianza */
.acred-trust-row{display:flex;align-items:center;justify-content:center;gap:0;border-top:1px solid rgba(255,255,255,.08);margin-top:56px;padding:36px 20px}
.acred-trust-item{flex:1;max-width:220px;text-align:center;padding:0 24px}
.acred-trust-item strong{display:block;font-size:32px;font-weight:900;color:#fff;letter-spacing:-1px;line-height:1;margin-bottom:6px}
.acred-trust-item span{font-size:12px;font-weight:600;color:rgba(255,255,255,.45);text-transform:uppercase;letter-spacing:.8px;line-height:1.4}
.acred-trust-sep{width:1px;height:52px;background:rgba(255,255,255,.1);flex-shrink:0}

/* Responsive */
@media(max-width:960px){.acred-trust-row{gap:0;flex-wrap:wrap}.acred-trust-sep{display:none}.acred-trust-item{flex:0 0 50%;max-width:50%;padding:16px 20px 0}}
@media(max-width:768px){.acred-section{padding:70px 0 0}.acred-title{font-size:24px}.acred-logo-card{width:160px;height:96px;padding:18px 16px}.acred-logo-inner img{max-height:52px}.acred-track{gap:14px}}
@media(max-width:480px){.acred-logo-card{width:136px;height:86px;padding:14px 12px}.acred-logo-inner img{max-height:44px}.acred-trust-item{flex:0 0 100%;max-width:100%}}

/* ---- WIDGETS FLOTANTES ---- */
.float-widgets{display:none!important}
.float-btn{display:flex;align-items:center;gap:10px;padding:12px 20px;border-radius:30px;font-size:14px;font-weight:700;text-decoration:none;box-shadow:var(--shadow-md);transition:all var(--transition);white-space:nowrap;border:none;cursor:pointer}
.float-btn:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg)}
.float-btn-whatsapp{background:#25d366;color:#fff}
.float-btn-call{background:var(--navy);color:#fff}
.float-btn-register{background:var(--lime);color:#fff}
.float-btn i{font-size:18px}

/* ======================================================
   CONÓCENOS — HERO REDISEÑO (cn2-)
   ====================================================== */
.cn2-hero{background:linear-gradient(155deg,#0b1724 0%,#1b2f4e 55%,#1e3656 100%);position:relative;overflow:hidden}
.cn2-grid-overlay{position:absolute;inset:0;pointer-events:none;background-image:linear-gradient(rgba(150,201,61,.035) 1px,transparent 1px),linear-gradient(90deg,rgba(150,201,61,.035) 1px,transparent 1px);background-size:68px 68px}
.cn2-hero-wrap{position:relative;z-index:2;display:grid;grid-template-columns:1fr 1fr;gap:56px;align-items:center;max-width:1320px;margin:0 auto;padding:90px 60px 50px}
.cn2-eyebrow{display:inline-flex;align-items:center;gap:7px;background:rgba(150,201,61,.12);color:var(--lime);border:1px solid rgba(150,201,61,.25);border-radius:20px;padding:5px 16px;font-size:11px;font-weight:700;letter-spacing:.8px;text-transform:uppercase;margin-bottom:20px}
.cn2-title{font-size:clamp(34px,4.2vw,58px);font-weight:900;color:#fff;line-height:1.12;margin:0 0 20px}
.cn2-lime{color:var(--lime)}
.cn2-muted{color:rgba(255,255,255,.42);font-weight:600}
.cn2-sub{font-size:15px;color:rgba(255,255,255,.56);line-height:1.75;margin-bottom:34px}
.cn2-btns{display:flex;gap:14px;flex-wrap:wrap}
/* Feature cards (columna derecha) */
.cn2-hero-right{display:flex;flex-direction:column;gap:8px;max-height:420px;overflow-y:auto;scrollbar-width:thin;scrollbar-color:rgba(150,201,61,.4) transparent}
.cn2-hero-right::-webkit-scrollbar{width:3px}.cn2-hero-right::-webkit-scrollbar-track{background:transparent}.cn2-hero-right::-webkit-scrollbar-thumb{background:rgba(150,201,61,.4);border-radius:4px}
.cn2-feat-card{display:flex;align-items:center;gap:14px;background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.09);border-radius:14px;padding:13px 16px;text-decoration:none;transition:all .25s}
.cn2-feat-card:hover{background:rgba(150,201,61,.1);border-color:rgba(150,201,61,.35);transform:translateX(5px)}
.cn2-feat-icon{width:44px;height:44px;flex-shrink:0;background:rgba(150,201,61,.12);border-radius:11px;display:flex;align-items:center;justify-content:center;font-size:18px;color:var(--lime)}
.cn2-feat-body{flex:1;min-width:0}
.cn2-feat-num{font-size:10px;font-weight:800;color:var(--lime);text-transform:uppercase;letter-spacing:1px;display:block;margin-bottom:2px;opacity:.7}
.cn2-feat-body h3{font-size:14px;font-weight:700;color:#fff;margin:0 0 2px;line-height:1.3}
.cn2-feat-body p{font-size:12px;color:rgba(255,255,255,.48);margin:0;line-height:1.4}
.cn2-feat-arr{color:rgba(255,255,255,.18);font-size:13px;flex-shrink:0;transition:color .2s,transform .2s}
.cn2-feat-card:hover .cn2-feat-arr{color:var(--lime);transform:translateX(3px)}
/* Stats bar */
.cn2-stats-bar{position:relative;z-index:2;display:flex;align-items:center;justify-content:center;background:rgba(0,0,0,.28);border-top:1px solid rgba(255,255,255,.07);padding:24px 60px}
.cn2-stat{flex:1;text-align:center;max-width:220px}
.cn2-stat strong{display:block;font-size:28px;font-weight:900;color:var(--lime);line-height:1;margin-bottom:5px}
.cn2-stat span{font-size:12px;color:rgba(255,255,255,.48);font-weight:500;letter-spacing:.3px}
.cn2-sep{width:1px;height:44px;background:rgba(255,255,255,.1);flex-shrink:0;margin:0 24px}
/* ===== ANIMATED WAVE DIVIDERS (legacy – ya reemplazadas por cn3) ===== */
@keyframes an-wave{100%{background-position-x:-1600px}}

/* === NÚMEROS (kn-) === */
.kn-section{background:linear-gradient(135deg,#0f1e30 0%,#1b2f4e 100%);padding:80px 0}
.kn-inner{max-width:1400px;margin:0 auto;padding:0 60px;text-align:center}
.kn-header{margin-bottom:52px}
.kn-eyebrow{display:inline-flex;align-items:center;gap:7px;background:rgba(150,201,61,.12);color:var(--lime);border:1px solid rgba(150,201,61,.25);border-radius:20px;padding:5px 16px;font-size:11px;font-weight:700;letter-spacing:.8px;text-transform:uppercase;margin-bottom:16px}
.kn-header h2{font-size:32px;font-weight:900;color:#fff;line-height:1.25}
.kn-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:28px;margin-bottom:44px}
.kn-item{background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.07);border-radius:20px;padding:40px 32px;transition:all .25s;position:relative;overflow:hidden}
.kn-item::after{content:'';position:absolute;bottom:0;left:0;right:0;height:3px;background:var(--lime);transform:scaleX(0);transform-origin:left;transition:transform .3s}
.kn-item:hover{background:rgba(255,255,255,.08);transform:translateY(-4px)}
.kn-item:hover::after{transform:scaleX(1)}
.kn-item--featured{background:linear-gradient(135deg,rgba(150,201,61,.1) 0%,rgba(150,201,61,.04) 100%);border-color:rgba(150,201,61,.22)}
.kn-icon{width:52px;height:52px;background:rgba(150,201,61,.12);border-radius:14px;display:flex;align-items:center;justify-content:center;font-size:22px;color:var(--lime);margin:0 auto 18px}
.kn-num{display:block;font-size:46px;font-weight:900;color:#fff;line-height:1;margin-bottom:10px}
.kn-item--featured .kn-num{color:var(--lime)}
.kn-lbl{display:block;font-size:13px;font-weight:600;color:rgba(255,255,255,.52);letter-spacing:.2px;line-height:1.4}
.kn-cta{padding-top:0}
/* === ¿POR QUÉ ELEGIRNOS? (cn2-why-) === */
.cn2-why-section{background:var(--off-white);padding:80px 60px}
.cn2-why-inner{max-width:1100px;margin:0 auto;padding:0 60px}
.cn2-why-head{text-align:center;margin-bottom:48px}
.cn2-why-head .tag{margin-bottom:12px}
.cn2-why-head h2{font-size:32px;font-weight:900;color:var(--navy);line-height:1.25}
.cn2-why-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.cn2-why-item{display:flex;gap:16px;align-items:flex-start;background:var(--white);border:1px solid var(--border);border-radius:var(--radius-lg);padding:26px 22px;transition:all .25s}
.cn2-why-item:hover{box-shadow:var(--shadow-md);transform:translateY(-3px);border-color:rgba(150,201,61,.4)}
.cn2-why-icon{width:46px;height:46px;flex-shrink:0;background:rgba(150,201,61,.1);border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:20px;color:var(--lime-dark);transition:background .25s}
.cn2-why-item:hover .cn2-why-icon{background:rgba(150,201,61,.2)}
.cn2-why-item h3{font-size:15px;font-weight:800;color:var(--navy);margin-bottom:6px;line-height:1.3}
.cn2-why-item p{font-size:13.5px;color:var(--text-muted);line-height:1.7;margin:0}
/* === CONTACTO STRIP (cn2-contact-) === */
.cn2-contact-section{
    background: var(--navy);
    padding: 80px 0;
    position: relative;
    overflow: hidden;
    background-image:
        url('../background/BK_Serv.png');
    background-attachment: fixed;
    background-position: center;
    background-size: cover;
    background-blend-mode: overlay;
}
.cn2-contact-section::before{
    content: '';
    position: absolute;
    inset: 0;
    background: linear-gradient(135deg, rgba(12, 26, 46, 0.50) 0%, rgba(27, 47, 78, 0.50) 60%, rgba(27, 47, 78, 0.60) 100%);
    pointer-events: none;
    z-index: 0;
}
.cn2-contact-wrap{
    max-width: 1160px;
    margin: 0 auto;
    padding: 0 60px;
    display: grid;
    grid-template-columns: 340px 1fr;
    gap: 60px;
    align-items: start;
    position: relative;
    z-index: 1;
}
.cn2-contact-left h2{font-size:34px;font-weight:900;color:#fff;line-height:1.2;margin:14px 0 12px}
.cn2-contact-left p{font-size:15px;color:rgba(255,255,255,.52);line-height:1.8;margin-bottom:28px}
.cn2-contact-btns{display:flex;flex-direction:column;gap:10px;max-width:240px}
.cn2-contact-btns .cnt-action-btn{justify-content:center}
.cn2-contact-cards{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.cn2-cinfo-card{background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.07);border-left:3px solid var(--lime);border-radius:14px;padding:20px 18px;display:flex;gap:14px;align-items:flex-start;transition:background .2s}
.cn2-cinfo-card:hover{background:rgba(255,255,255,.09)}
.cn2-cinfo-icon{width:40px;height:40px;flex-shrink:0;background:rgba(150,201,61,.12);border-radius:10px;color:var(--lime);font-size:16px;display:flex;align-items:center;justify-content:center}
.cn2-cinfo-icon--social{background:rgba(255,255,255,.07);color:rgba(255,255,255,.65)}
.cn2-cinfo-card>div{display:flex;flex-direction:column;gap:4px;min-width:0}
.cn2-cinfo-card strong{font-size:10px;font-weight:800;text-transform:uppercase;letter-spacing:.8px;color:rgba(255,255,255,.36);margin-bottom:4px}
.cn2-cinfo-card a,.cn2-cinfo-card span{font-size:13.5px;color:rgba(255,255,255,.78);text-decoration:none;line-height:1.65;transition:color .2s}
.cn2-cinfo-card a:hover{color:var(--lime)}
.cn2-social-link{display:flex;align-items:center;gap:7px}
.cn2-social-link i{color:var(--lime);width:16px;text-align:center}

/* ======================================================
   CONÓCENOS — ¿QUIÉNES SOMOS? (qss)
   ====================================================== */
.qss-section{background:var(--white);padding:90px 60px 0 60px}
.qss-grid{display:grid;grid-template-columns:360px 1fr;gap:0;align-items:stretch;border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-lg)}
/* Tarjeta izquierda oscura */
.qss-left-card{
    background:linear-gradient(170deg,#1b2f4e 0%,#0f1e30 100%);
    padding:44px 36px;display:flex;flex-direction:column;
    position:relative;overflow:hidden;
}
.qss-left-card::before{
    content:'';position:absolute;bottom:-60px;right:-60px;
    width:260px;height:260px;border-radius:50%;
    background:radial-gradient(circle,rgba(150,201,61,.12) 0%,transparent 70%);
    pointer-events:none;
}
.qss-years{display:flex;align-items:flex-end;gap:4px;margin-bottom:24px}
.qss-num{font-size:72px;font-weight:900;color:var(--lime);line-height:1;font-style:italic}
.qss-plus{font-size:44px;font-weight:900;color:var(--lime);line-height:1.3;margin-left:2px}
.qss-years-lbl{font-size:14px;color:rgba(255,255,255,.55);font-weight:600;line-height:1.4;margin-left:10px;padding-bottom:6px;text-transform:uppercase;letter-spacing:.5px}
.qss-brand{font-size:24px;font-weight:900;color:#fff;margin-bottom:10px;letter-spacing:-0.5px}
.qss-tagline{font-size:13.5px;color:rgba(255,255,255,.62);line-height:1.7;margin-bottom:0;flex:1}
.qss-hr{border:none;border-top:1px solid rgba(255,255,255,.12);margin:24px 0}
.qss-contact-mini{display:flex;flex-direction:column;gap:8px;margin-bottom:24px}
.qss-clink{display:flex;align-items:center;gap:10px;font-size:13px;color:rgba(255,255,255,.75);text-decoration:none;transition:color .2s}
.qss-clink i{color:var(--lime);width:16px;text-align:center;font-size:13px;flex-shrink:0}
.qss-clink:hover{color:var(--lime)}
.qss-social{display:flex;gap:10px;margin-top:auto}
.qss-social-btn{width:40px;height:40px;border-radius:50%;background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.15);display:flex;align-items:center;justify-content:center;color:rgba(255,255,255,.8);font-size:15px;text-decoration:none;transition:all .25s}
.qss-social-btn:hover{background:var(--lime);border-color:var(--lime);color:var(--navy)}
/* Columna derecha */
.qss-right-col{background:var(--white);padding:44px 48px;display:flex;flex-direction:column;justify-content:center}
.qss-title{font-size:28px;font-weight:800;color:var(--navy);margin:10px 0 14px;line-height:1.3}
.qss-title strong{color:var(--lime-dark)}
.qss-desc{font-size:15px;color:var(--text-muted);line-height:1.8;margin-bottom:28px}
.qss-portfolio-lbl{font-size:12px;font-weight:700;color:var(--navy);text-transform:uppercase;letter-spacing:.8px;margin-bottom:14px}
.qss-svc-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:32px}
.qss-svc-card{display:flex;align-items:center;gap:12px;background:var(--light-gray);border:1.5px solid var(--border);border-radius:var(--radius);padding:12px 14px;text-decoration:none;transition:all .25s;font-size:13px;font-weight:600;color:var(--navy);line-height:1.3}
.qss-svc-card i{font-size:17px;color:var(--lime-dark);flex-shrink:0;width:20px;text-align:center}
.qss-svc-card span{display:flex;flex-direction:column;gap:1px}
.qss-svc-card em{font-style:normal;font-size:10.5px;font-weight:500;color:var(--text-muted)}
.qss-svc-card:hover{background:rgba(150,201,61,.08);border-color:var(--lime);color:var(--navy);transform:translateY(-2px)}

/* ======================================================
   CONÓCENOS — VENTAJAS COMPETITIVAS
   ====================================================== */
.ventajas-section{background:var(--off-white)}
.ventajas-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.ventaja-card{background:var(--white);border:1px solid var(--border);border-radius:var(--radius-lg);padding:36px 28px;display:flex;flex-direction:column;transition:all .28s;position:relative;overflow:hidden}
.ventaja-card::after{content:'';position:absolute;bottom:0;left:0;right:0;height:4px;background:linear-gradient(90deg,var(--lime),var(--lime-dark));transform:scaleX(0);transform-origin:left;transition:transform .28s}
.ventaja-card:hover{transform:translateY(-5px);box-shadow:var(--shadow-md)}
.ventaja-card:hover::after{transform:scaleX(1)}
.ventaja-card--featured{background:linear-gradient(135deg,#1b2f4e 0%,#243d62 100%);border-color:transparent;color:#fff}
.ventaja-card--featured h3{color:#fff}
.ventaja-card--featured p{color:rgba(255,255,255,.65)}
.ventaja-card--featured::after{background:var(--lime)}
.ventaja-icon{width:56px;height:56px;background:rgba(150,201,61,.12);border-radius:14px;display:flex;align-items:center;justify-content:center;font-size:24px;color:var(--lime-dark);margin-bottom:20px;flex-shrink:0;transition:background .25s}
.ventaja-icon--featured{background:rgba(150,201,61,.18);color:var(--lime)}
.ventaja-card--featured .ventaja-icon{background:rgba(150,201,61,.18)}
.ventaja-card:hover .ventaja-icon{background:rgba(150,201,61,.2)}
.ventaja-card h3{font-size:17px;font-weight:800;color:var(--navy);margin-bottom:10px;line-height:1.3}
.ventaja-card p{font-size:14px;color:var(--text-muted);line-height:1.75}

/* ======================================================
   CONÓCENOS — TIRA DE CONTACTO (grid-5)
   ====================================================== */
.cs-grid-5{grid-template-columns:repeat(5,1fr) !important}
.cs-social-row{display:flex;flex-direction:column;gap:8px;margin-top:4px}
.cs-social-btn{display:flex;align-items:center;gap:8px;font-size:13px;color:rgba(255,255,255,.75);text-decoration:none;transition:color .2s}
.cs-social-btn i{font-size:15px;color:var(--lime)}
.cs-social-btn:hover{color:var(--lime)}

/* ======================================================
   CONTACTO — HERO SPLIT
   ====================================================== */
.ct-hero{
    background:#04101e;
    position:relative;overflow:hidden;
}
/* Wrapper principal del efecto split */
.ct-split-wrap{
    position:relative;width:100%;min-height:620px;
    overflow:hidden;cursor:crosshair;user-select:none;
}
/* ── Lado caliente: imagen ── */
.ct-hot-layer{
    position:absolute;inset:0;z-index:1;
}
.ct-hot-layer img{
    position:absolute;inset:0;
    width:100%;height:100%;
    object-fit:cover;object-position:center;
    pointer-events:none;user-select:none;
}
.ct-hot-tint{
    position:absolute;inset:0;
    background:linear-gradient(140deg,rgba(30, 44, 102, 0.55) 0%,rgba(1, 17, 82, 0.35) 50%,rgba(5, 12, 86, 0.5) 100%);
    pointer-events:none;
}
/* ── Lado frío: panel de contacto ── */
.ct-cold-layer{
    position:absolute;inset:0;z-index:2;
    background:linear-gradient(160deg,#04101e 0%,#0b1c33 45%,#122542 100%);
    clip-path:polygon(0 0,61% 0,47% 100%,0 100%);
    overflow:hidden;
}
.ct-cold-layer::before{
    content:'';position:absolute;inset:0;pointer-events:none;
    background-image:
        radial-gradient(circle at 10% 90%,rgba(50,100,200,.13) 0%,transparent 45%),
        radial-gradient(circle at 70% 15%,rgba(80,140,220,.07) 0%,transparent 35%),
        repeating-linear-gradient(45deg,transparent,transparent 40px,rgba(255,255,255,.012) 40px,rgba(255,255,255,.012) 41px);
}
.ct-cold-snow{
    position:absolute;inset:0;width:100%;height:100%;
    pointer-events:none;z-index:1;filter:blur(.5px);
}
.ct-cold-content{
    position:relative;z-index:2;
    padding:44px 36px 40px 56px;
    max-width:min(500px,46vw);width:100%;
    height:100%;display:flex;flex-direction:column;justify-content:center;
    overflow:hidden;
}
.ct-cold-content .tag{display:inline-flex;align-items:center;gap:7px;margin-bottom:14px}
.ct-hero-title{
    font-size:clamp(22px,2.4vw,38px);font-weight:900;
    color:#fff;line-height:1.15;margin-bottom:10px;
    text-shadow:0 2px 24px rgba(0,0,0,.35);
}
.ct-hero-title strong{color:var(--lime)}
.ct-hero-sub{font-size:13.5px;color:rgba(255,255,255,.62);line-height:1.7;margin-bottom:18px;max-width:100%}
.ct-hero-btns{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:18px}
.ct-hero-cards{display:grid;grid-template-columns:1fr 1fr;gap:10px}
/* ── Línea divisora ── */
.ct-split-line{
    position:absolute;top:50%;left:55%;
    width:3px;height:180%;
    background:linear-gradient(to bottom,transparent 0%,rgba(255,255,255,.95) 25%,#fff 50%,rgba(255,255,255,.95) 75%,transparent 100%);
    transform:translateX(-50%) translateY(-50%) rotate(15deg);
    transform-origin:center center;
    z-index:6;pointer-events:none;
    box-shadow:0 0 10px rgba(255,255,255,.55),0 0 28px rgba(255,255,255,.18);
}
/* ── Hint de interacción ── */
.ct-split-hint{
    position:absolute;bottom:18px;left:50%;transform:translateX(-50%);
    z-index:7;display:flex;align-items:center;gap:8px;
    background:rgba(0,0,0,.5);color:rgba(255,255,255,.85);
    padding:6px 16px;border-radius:24px;
    font-size:12px;font-weight:600;
    backdrop-filter:blur(8px);
    pointer-events:none;white-space:nowrap;
    transition:opacity .5s;
}
.ct-split-wrap:hover .ct-split-hint{opacity:0}
.ct-ic{
    display:flex;gap:10px;align-items:flex-start;
    background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.1);
    border-radius:12px;padding:13px 14px;
    backdrop-filter:blur(6px);
    transition:background .25s,transform .25s;
}
.ct-ic:hover{background:rgba(255,255,255,.12);transform:translateY(-2px)}
.ct-ic-icon{
    width:36px;height:36px;flex-shrink:0;border-radius:9px;
    background:rgba(150,201,61,.18);display:flex;align-items:center;justify-content:center;
    font-size:15px;color:var(--lime);
}
.ct-ic-body{display:flex;flex-direction:column;gap:2px}
.ct-ic-body strong{font-size:10.5px;font-weight:800;color:rgba(255,255,255,.5);text-transform:uppercase;letter-spacing:.7px;margin-bottom:3px}
.ct-ic-body a{font-size:12.5px;color:rgba(255,255,255,.88);text-decoration:none;transition:color .2s;line-height:1.45}
.ct-ic-body a:hover{color:var(--lime)}
.ct-ic-body span{font-size:12.5px;color:rgba(255,255,255,.72);line-height:1.45}
.ct-ic-body small{font-size:11px;color:rgba(255,255,255,.42);margin-top:3px;line-height:1.35}
/* ── Toggle efecto split (fuera del hero) ── */
.ct-split-toggle-bar{
    background:var(--navy);
    border-bottom:1px solid rgba(255,255,255,.07);
    padding:9px 72px;
    display:flex;justify-content:flex-end;align-items:center;
    position:relative;z-index:10;
}
.ct-split-toggle-btn{
    display:inline-flex;align-items:center;gap:9px;
    background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.18);
    border-radius:22px;padding:6px 18px;
    color:rgba(255,255,255,.75);font-size:12.5px;font-weight:600;
    cursor:pointer;transition:background .2s,border-color .2s,color .2s;
    white-space:nowrap;
}
.ct-split-toggle-btn:hover{background:rgba(255,255,255,.13);color:#fff}
.ct-split-toggle-btn.is-locked{
    border-color:var(--lime);color:var(--lime);
}
.ct-split-toggle-btn i{font-size:13px;transition:color .2s}
/* Bottom bar */
.ct-hero-bar{
    position:relative;z-index:2;
    background:rgba(0,0,0,.28);border-top:1px solid rgba(255,255,255,.07);
    padding:14px 72px;
}
.ct-hero-bar-inner{
    max-width:1400px;margin:0 auto;
    display:flex;align-items:center;gap:24px;flex-wrap:wrap;
}
.ct-hero-bar-inner span,.ct-hero-bar-inner a{
    display:flex;align-items:center;gap:8px;
    font-size:13px;color:rgba(255,255,255,.55);text-decoration:none;
    transition:color .2s;
}
.ct-hero-bar-inner a:hover{color:var(--lime)}
.ct-hero-bar-inner i{color:var(--lime);font-size:13px}
.ct-hb-divider{width:1px;height:18px;background:rgba(255,255,255,.15);flex-shrink:0}

/* ======================================================
   CONTACTO — BODY (mapa + formulario)
   ====================================================== */
.ct-body-section{
    background:var(--off-white);
    padding:0;
}
.ct-body-grid{
    display:grid;grid-template-columns:380px 1fr;
    min-height:680px;
}
/* Sidebar izquierda */
.ct-sidebar{
    background:var(--navy);
    padding:48px 36px;
    display:flex;flex-direction:column;gap:0;
}
.ct-sidebar-top{margin-bottom:20px}
.ct-sidebar-title{
    display:flex;align-items:center;gap:10px;
    font-size:20px;font-weight:800;color:#fff;margin-bottom:6px;
}
.ct-sidebar-title i{color:var(--lime);font-size:20px}
.ct-sidebar-sub{font-size:13px;color:rgba(255,255,255,.5);margin-bottom:0}
/* Mapa */
.ct-map-wrapper{
    width:100%;height:220px;border-radius:var(--radius);
    overflow:hidden;border:2px solid rgba(255,255,255,.1);
    margin-bottom:22px;flex-shrink:0;
}
/* Tarjeta dirección */
.ct-address-card{
    display:flex;gap:14px;align-items:flex-start;
    background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.1);
    border-radius:12px;padding:18px 16px;margin-bottom:22px;
}
.ct-addr-icon{
    width:40px;height:40px;flex-shrink:0;
    background:rgba(150,201,61,.15);border-radius:10px;
    display:flex;align-items:center;justify-content:center;
    font-size:16px;color:var(--lime);
}
.ct-address-card strong{display:block;font-size:13px;font-weight:700;color:#fff;margin-bottom:6px}
.ct-address-card p{font-size:12.5px;color:rgba(255,255,255,.6);line-height:1.65;margin:0}
/* Social block */
.ct-social-block{margin-top:auto;padding-top:20px;border-top:1px solid rgba(255,255,255,.1)}
.ct-social-lbl{display:flex;align-items:center;gap:8px;font-size:12px;font-weight:700;color:rgba(255,255,255,.5);text-transform:uppercase;letter-spacing:.7px;margin-bottom:14px}
.ct-social-lbl i{color:var(--lime)}
.ct-social-btns{display:grid;grid-template-columns:1fr 1fr;gap:9px}
.ct-soc-btn{
    display:flex;align-items:center;gap:8px;
    background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.1);
    border-radius:9px;padding:10px 12px;
    font-size:12.5px;font-weight:600;color:rgba(255,255,255,.8);
    text-decoration:none;transition:all .22s;
}
.ct-soc-btn:hover{background:rgba(255,255,255,.14);border-color:rgba(255,255,255,.25);color:#fff;transform:translateY(-1px)}
.ct-soc-btn i{font-size:14px;flex-shrink:0}
.ct-soc-fb:hover{border-color:#1877f2;color:#fff;background:rgba(24,119,242,.18)}
.ct-soc-ig:hover{border-color:#e1306c;color:#fff;background:rgba(225,48,108,.15)}
.ct-soc-tt:hover{border-color:#fff;color:#fff;background:rgba(255,255,255,.1)}
.ct-soc-yt:hover{border-color:#ff0000;color:#fff;background:rgba(255,0,0,.15)}

/* ── Columna formulario ── */
.ct-form-col{
    background:var(--white);
    padding:56px 64px;
    display:flex;align-items:flex-start;justify-content:center;
}
.ct-form-box{
    width:100%;max-width:620px;
}
/* Header del form */
.ct-form-hd{display:flex;align-items:center;gap:18px;margin-bottom:28px;padding-bottom:24px;border-bottom:1px solid var(--border)}
.ct-form-hd-icon{
    width:56px;height:56px;flex-shrink:0;
    background:linear-gradient(135deg,var(--navy) 0%,var(--navy-light) 100%);
    border-radius:14px;display:flex;align-items:center;justify-content:center;
    font-size:22px;color:var(--lime);
}
.ct-form-title{font-size:22px;font-weight:800;color:var(--navy);margin:0 0 4px}
.ct-form-sub{font-size:13.5px;color:var(--text-muted);margin:0}
/* Alertas */
.ct-alert{
    display:flex;align-items:flex-start;gap:12px;
    padding:16px 18px;border-radius:10px;margin-bottom:20px;
    font-size:14px;font-weight:500;
}
.ct-alert i{font-size:16px;margin-top:1px;flex-shrink:0}
.ct-alert-ok{background:rgba(150,201,61,.1);border:1.5px solid rgba(150,201,61,.35);color:#3d6b00}
.ct-alert-ok i{color:#5a8f00}
.ct-alert-err{background:rgba(220,53,69,.08);border:1.5px solid rgba(220,53,69,.3);color:#842029}
.ct-alert-err i{color:#dc3545}
/* Campos del formulario */
.ct-form{display:flex;flex-direction:column;gap:18px}
.ct-row-2{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.ct-field{display:flex;flex-direction:column;gap:6px}
.ct-label{font-size:12.5px;font-weight:700;color:var(--slate);letter-spacing:.3px;text-transform:uppercase}
.ct-req{color:var(--lime-dark)}
.ct-input-wrap{position:relative}
.ct-input-icon{
    position:absolute;left:15px;top:50%;transform:translateY(-50%);
    font-size:13.5px;color:var(--text-muted);pointer-events:none;
    transition:color .2s;
}
.ct-textarea-wrap .ct-textarea-icon{top:16px;transform:none}
.ct-input{
    width:100%;padding:12px 14px 12px 42px;
    border:1.5px solid var(--border);border-radius:9px;
    font-size:14px;color:var(--text-dark);background:var(--white);
    outline:none;transition:border-color .22s,box-shadow .22s;
    font-family:inherit;
}
.ct-input:focus{border-color:var(--lime);box-shadow:0 0 0 3px rgba(150,201,61,.14)}
.ct-input:focus ~ .ct-input-icon,.ct-input-wrap:focus-within .ct-input-icon{color:var(--lime-dark)}
.ct-select{cursor:pointer;appearance:none;-webkit-appearance:none;padding-right:36px}
.ct-textarea{resize:vertical;min-height:120px;padding-top:13px}
/* Botón submit */
.ct-submit{
    display:flex;align-items:center;justify-content:center;gap:10px;
    background:linear-gradient(135deg,var(--navy) 0%,#243d62 100%);
    color:#fff;border:none;border-radius:10px;
    padding:15px 32px;font-size:15px;font-weight:800;
    cursor:pointer;width:100%;
    transition:all .25s;position:relative;overflow:hidden;
    letter-spacing:.2px;
}
.ct-submit::before{
    content:'';position:absolute;inset:0;
    background:linear-gradient(135deg,var(--lime-dark) 0%,var(--lime) 100%);
    opacity:0;transition:opacity .25s;
}
.ct-submit:hover::before{opacity:1}
.ct-submit > *{position:relative;z-index:1}
.ct-submit:hover{color:var(--navy);transform:translateY(-2px);box-shadow:0 6px 24px rgba(150,201,61,.4)}
.ct-submit-arrow{margin-left:auto;opacity:0;transform:translateX(-4px);transition:all .25s}
.ct-submit:hover .ct-submit-arrow{opacity:1;transform:translateX(0)}
.ct-form-note{
    font-size:12px;color:var(--text-muted);text-align:center;
    display:flex;align-items:center;justify-content:center;gap:6px;
    margin-top:4px;
}
.ct-form-note i{color:var(--lime-dark)}

/* ======================================================
   CONTACTO — RESPONSIVE
   ====================================================== */
@media(max-width:1100px){
    .ct-split-wrap{min-height:560px}
    .ct-cold-content{padding:44px 32px 40px 40px;max-width:min(480px,47vw)}
    .ct-split-toggle-bar{padding:9px 36px}
    .ct-hero-bar{padding:14px 36px}
    .ct-body-grid{grid-template-columns:1fr}
    .ct-sidebar{padding:40px 36px;flex-direction:row;flex-wrap:wrap;gap:24px;align-items:flex-start}
    .ct-sidebar-top{width:100%}
    .ct-map-wrapper{height:200px;flex:1 1 300px}
    .ct-address-card{flex:1 1 260px;margin-bottom:0}
    .ct-social-block{width:100%;margin-top:0;padding-top:16px}
    .ct-social-btns{grid-template-columns:repeat(4,1fr)}
    .ct-form-col{padding:40px 36px}
}
@media(max-width:768px){
    .ct-split-wrap{min-height:auto;cursor:default}
    .ct-cold-layer{clip-path:none!important;background:rgba(4,16,30,.92)}
    .ct-split-line,.ct-split-hint{display:none}
    .ct-cold-content{padding:36px 24px 36px;max-width:100%;height:auto;justify-content:flex-start}
    .ct-hero-cards{grid-template-columns:1fr 1fr}
    .ct-split-toggle-bar{padding:9px 24px}
    .ct-hero-bar{padding:12px 24px}
    .ct-hero-bar-inner{gap:16px}
    .ct-hb-divider{display:none}
    .ct-hero-btns{flex-direction:column}
    .ct-form-col{padding:32px 24px}
    .ct-row-2{grid-template-columns:1fr}
    .ct-social-btns{grid-template-columns:1fr 1fr}
}
@media(max-width:500px){
    .ct-hero-title{font-size:24px}
    .ct-hero-cards{grid-template-columns:1fr}
    .ct-sidebar{padding:28px 20px}
    .ct-form-col{padding:24px 16px}
}

/* ---- FOOTER ---- */
footer{background:var(--navy);color:var(--white);padding:64px 60px 40px;border-top:3px solid var(--lime)}
.footer-inner{display:grid;grid-template-columns:1.7fr 1fr 1fr 1.4fr;gap:52px;margin-bottom:48px}
.footer-logo{height:54px;object-fit:contain;filter:brightness(0) invert(1);display:block;margin-bottom:16px}
.footer-brand p{font-size:18px;color:#8fa4b8;line-height:1.8;max-width:240px;font-weight:500}
/* social rows en brand col */
.foot-social-row{display:flex;flex-direction:column;gap:8px;margin-top:20px}
.foot-soc-link{display:flex;align-items:center;gap:12px;text-decoration:none;transition:opacity .2s}
.foot-soc-link:hover{opacity:.8}
.foot-soc-icon{width:38px;height:38px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:15px;color:#fff;flex-shrink:0}
.foot-soc-fb{background:#1877f2}
.foot-soc-ig{background:radial-gradient(circle at 30% 107%,#fdf497 0%,#fdf497 5%,#fd5949 45%,#d6249f 60%,#285aeb 90%)}
.foot-soc-tk{background:#000}
.foot-soc-link>span:last-child{font-size:15px;color:#aec4d8;font-weight:600}
/* cols */
.footer-col h4{font-size:14px;font-weight:800;text-transform:uppercase;letter-spacing:1.2px;color:var(--white);margin-bottom:20px;padding-bottom:10px;position:relative}
.footer-col h4::after{content:'';position:absolute;left:0;bottom:0;width:24px;height:2px;background:var(--lime)}
.footer-col ul{list-style:none}
.footer-col ul li{margin-bottom:11px}
.footer-col ul li a{font-size:15px;color:#8fa4b8;text-decoration:none;transition:color var(--transition);font-weight:500}
.footer-col ul li a:before{content:'›';margin-right:6px;color:var(--lime);font-weight:700}
.footer-col ul li a:hover{color:var(--lime)}
/* contacto col */
.footer-col-contact .footer-contact-details{margin-top:4px;display:flex;flex-direction:column;gap:12px}
.footer-col-contact .footer-contact-details p{font-size:15px;color:#8fa4b8;line-height:1.65;display:flex;align-items:flex-start;gap:10px;margin:0;font-weight:500}
.footer-col-contact .footer-contact-details p i{color:var(--lime);margin-top:3px;flex-shrink:0;width:14px;text-align:center}
.footer-col-contact .footer-contact-details a{color:#8fa4b8;text-decoration:none;transition:color .2s}
.footer-col-contact .footer-contact-details a:hover{color:var(--lime)}
.social-icons{display:flex;gap:10px;margin-top:4px}
.social-icons a{width:38px;height:38px;border-radius:50%;background:rgba(255,255,255,.08);display:flex;align-items:center;justify-content:center;color:#8fa4b8;font-size:15px;text-decoration:none;transition:all var(--transition)}
.social-icons a:hover{background:var(--lime);color:var(--navy)}
.footer-bottom{border-top:1px solid rgba(255,255,255,.08);padding-top:24px;display:flex;justify-content:space-between;align-items:center;font-size:14px;color:#607d8b;flex-wrap:wrap;gap:10px;font-weight:500}
.footer-bottom a{color:#607d8b;text-decoration:none}
.footer-bottom a:hover{color:var(--lime)}

/* ======================================================
   ÉTICA (et-)
   ====================================================== */
/* Hero */
.et-hero{background:linear-gradient(155deg,#0b1724 0%,#1b2f4e 55%,#1e3656 100%);padding:90px 60px 70px;position:relative;overflow:hidden}
.et-hero::before{content:'';position:absolute;inset:0;background-image:linear-gradient(rgba(150,201,61,.03) 1px,transparent 1px),linear-gradient(90deg,rgba(150,201,61,.03) 1px,transparent 1px);background-size:60px 60px;pointer-events:none}
.et-hero-inner{max-width:860px;margin:0 auto;position:relative;z-index:1;text-align:center}
.et-eyebrow{display:inline-flex;align-items:center;gap:7px;background:rgba(150,201,61,.12);color:var(--lime);border:1px solid rgba(150,201,61,.25);border-radius:20px;padding:5px 16px;font-size:11px;font-weight:700;letter-spacing:.8px;text-transform:uppercase;margin-bottom:20px}
.et-hero h1{font-size:clamp(32px,4.5vw,54px);font-weight:900;color:#fff;line-height:1.15;margin-bottom:18px}
.et-accent{color:var(--lime)}
.et-hero p{font-size:16px;color:rgba(255,255,255,.6);line-height:1.75;max-width:620px;margin:0 auto 28px}
.et-hero-meta{display:flex;align-items:center;justify-content:center;gap:24px;flex-wrap:wrap}
.et-hero-meta span{font-size:12.5px;color:rgba(255,255,255,.4);display:flex;align-items:center;gap:6px}
.et-hero-meta i{color:var(--lime)}
/* Layout */
.et-main{background:var(--off-white)}
.et-layout{max-width:1200px;margin:0 auto;display:grid;grid-template-columns:280px 1fr;gap:40px;align-items:start}
/* Sidebar */
.et-sidebar{position:sticky;top:96px}
.et-sidebar-card{background:var(--white);border:1px solid var(--border);border-radius:var(--radius-lg);padding:28px 24px;box-shadow:var(--shadow-sm)}
.et-sidebar-card h3{font-size:13px;font-weight:800;text-transform:uppercase;letter-spacing:.8px;color:var(--navy);margin-bottom:18px;display:flex;align-items:center;gap:8px}
.et-sidebar-card h3 i{color:var(--lime)}
.et-index{display:flex;flex-direction:column;gap:2px}
.et-index a{font-size:13px;color:var(--text-muted);text-decoration:none;padding:7px 10px;border-radius:8px;transition:all .2s;display:flex;align-items:center;gap:7px;line-height:1.35}
.et-index a::before{content:counter(et-idx);counter-increment:et-idx;font-size:10px;font-weight:800;color:var(--lime);background:rgba(150,201,61,.1);border-radius:5px;padding:1px 6px;min-width:22px;text-align:center;flex-shrink:0}
.et-index{counter-reset:et-idx}
.et-index a:hover{background:rgba(150,201,61,.08);color:var(--navy)}
.et-sidebar-info{margin-top:20px;background:rgba(150,201,61,.08);border-left:3px solid var(--lime);border-radius:0 8px 8px 0;padding:12px 14px;display:flex;gap:10px;align-items:flex-start}
.et-sidebar-info i{color:var(--lime);flex-shrink:0;margin-top:2px;font-size:13px}
.et-sidebar-info span{font-size:12px;color:var(--text-muted);line-height:1.6}
/* Article */
.et-article{min-width:0}
.et-intro-card{background:var(--navy);border-radius:var(--radius-lg);padding:32px 36px;display:flex;gap:24px;align-items:flex-start;margin-bottom:36px}
.et-intro-icon{width:52px;height:52px;flex-shrink:0;background:rgba(150,201,61,.15);border-radius:14px;display:flex;align-items:center;justify-content:center;font-size:22px;color:var(--lime)}
.et-intro-card h2{font-size:18px;font-weight:800;color:#fff;margin-bottom:10px}
.et-intro-card p{font-size:14.5px;color:rgba(255,255,255,.65);line-height:1.8;margin:0}
.et-intro-card strong{color:rgba(255,255,255,.9)}
.et-section-label{margin-bottom:24px}
.et-section-label span{display:inline-flex;align-items:center;gap:8px;font-size:11px;font-weight:800;text-transform:uppercase;letter-spacing:1px;color:var(--lime);background:rgba(150,201,61,.1);border-radius:20px;padding:5px 16px;border:1px solid rgba(150,201,61,.2)}
/* Declarations */
.et-declarations{display:flex;flex-direction:column;gap:14px;margin-bottom:36px}
.et-decl{background:var(--white);border:1px solid var(--border);border-radius:var(--radius-lg);padding:24px 28px;display:grid;grid-template-columns:auto 1fr auto;gap:20px;align-items:flex-start;transition:box-shadow .2s,border-color .2s}
.et-decl:hover{box-shadow:var(--shadow-md);border-color:rgba(150,201,61,.35)}
.et-decl-num{font-size:11px;font-weight:900;color:var(--lime);background:rgba(150,201,61,.1);border-radius:8px;padding:4px 9px;letter-spacing:.5px;height:fit-content;line-height:1.4}
.et-decl-body h3{font-size:15px;font-weight:800;color:var(--navy);margin-bottom:8px;line-height:1.3}
.et-decl-body p{font-size:14px;color:var(--text-muted);line-height:1.8;margin:0}
.et-decl-icon{width:38px;height:38px;flex-shrink:0;background:var(--off-white);border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:15px;color:var(--text-muted);transition:all .2s}
.et-decl:hover .et-decl-icon{background:rgba(150,201,61,.1);color:var(--lime)}
.et-decl--highlight{border-left:4px solid var(--lime);background:linear-gradient(135deg,rgba(150,201,61,.04) 0%,var(--white) 100%)}
.et-decl--highlight .et-decl-icon{background:rgba(150,201,61,.12);color:var(--lime)}
.et-decl--conformidad{border-left:4px solid #3b82f6;background:linear-gradient(135deg,rgba(59,130,246,.04) 0%,var(--white) 100%)}
.et-decl--conformidad .et-decl-num{color:#3b82f6;background:rgba(59,130,246,.1)}
.et-decl--conformidad .et-decl-icon{background:rgba(59,130,246,.1);color:#3b82f6}
/* Footer note */
.et-version-note{background:var(--white);border:1px solid var(--border);border-radius:var(--radius-lg);padding:22px 24px;display:flex;gap:14px;align-items:flex-start}
.et-version-note i{color:var(--lime);font-size:16px;flex-shrink:0;margin-top:2px}
.et-version-note p{font-size:13.5px;color:var(--text-muted);line-height:1.75;margin:0}
.et-version-note strong{color:var(--navy)}
/* Responsive */
@media(max-width:960px){
    .et-layout{grid-template-columns:1fr;gap:28px}
    .et-sidebar{position:static}
    .et-hero{padding:60px 24px 50px}
    .et-decl{grid-template-columns:auto 1fr;padding:20px}
    .et-decl-icon{display:none}
    .et-intro-card{padding:24px;gap:16px}
}
@media(max-width:600px){
    .et-hero{padding:48px 20px 40px}
    .et-hero h1{font-size:28px}
    .et-intro-card{flex-direction:column;gap:14px}
    .et-decl{grid-template-columns:auto 1fr;gap:14px;padding:18px 16px}
}

/* ======================================================
   PRIVACIDAD (pv-)
   ====================================================== */
.pv-hero{padding-bottom:80px}
.pv-section{background:var(--white);border:1px solid var(--border);border-radius:var(--radius-lg);padding:32px 36px;margin-bottom:20px}
.pv-section--alt{background:rgba(27,47,78,.03)}
.pv-section--highlight{border-left:4px solid var(--lime);background:linear-gradient(135deg,rgba(150,201,61,.03) 0%,var(--white) 100%)}
.pv-section--conformidad{border-left:4px solid #3b82f6;background:linear-gradient(135deg,rgba(59,130,246,.04) 0%,var(--white) 100%)}
.pv-section-head{display:flex;align-items:center;gap:16px;margin-bottom:18px}
.pv-section-head h2{font-size:18px;font-weight:800;color:var(--navy);margin:0}
.pv-section-icon{width:46px;height:46px;flex-shrink:0;background:rgba(27,47,78,.07);border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:18px;color:var(--navy)}
.pv-icon--green{background:rgba(34,197,94,.1);color:#16a34a}
.pv-icon--blue{background:rgba(59,130,246,.1);color:#2563eb}
.pv-icon--lime{background:rgba(150,201,61,.12);color:var(--lime-dark)}
.pv-lead{font-size:14.5px;color:var(--text-muted);line-height:1.85;margin:0 0 16px}
.pv-note{font-size:13.5px;color:var(--text-muted);background:rgba(150,201,61,.07);border-left:3px solid var(--lime);border-radius:0 8px 8px 0;padding:12px 16px;line-height:1.7;margin-top:8px}
.pv-list{list-style:none;display:flex;flex-direction:column;gap:10px;margin:12px 0 0}
.pv-list li{display:flex;align-items:flex-start;gap:12px;font-size:14px;color:var(--text-dark);line-height:1.5}
.pv-list li i{color:var(--lime);flex-shrink:0;font-size:13px;margin-top:3px}
.pv-badge{display:inline-flex;align-items:center;font-size:10px;font-weight:700;letter-spacing:.4px;background:rgba(150,201,61,.12);color:var(--lime-dark);border-radius:6px;padding:2px 8px;margin-left:8px;vertical-align:middle;text-transform:uppercase}
.pv-badge--muted{background:rgba(27,47,78,.07);color:var(--text-muted)}
.pv-purpose-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin:12px 0 16px}
.pv-purpose-item{background:var(--off-white);border:1px solid var(--border);border-radius:10px;padding:14px 16px;display:flex;align-items:center;gap:10px;font-size:13px;color:var(--text-dark);font-weight:500;line-height:1.4;transition:all .2s}
.pv-purpose-item:hover{border-color:rgba(150,201,61,.4);background:rgba(150,201,61,.05)}
.pv-purpose-item i{color:var(--lime);font-size:15px;flex-shrink:0}
.pv-contact-box{display:inline-flex;align-items:center;gap:12px;background:rgba(150,201,61,.08);border:1px solid rgba(150,201,61,.2);border-radius:10px;padding:14px 20px;margin:4px 0 0}
.pv-contact-box i{color:var(--lime);font-size:16px}
.pv-contact-box a{font-size:14.5px;font-weight:600;color:var(--navy);text-decoration:none;transition:color .2s}
.pv-contact-box a:hover{color:var(--lime-dark)}
.pv-timeline{display:flex;align-items:center;gap:0;margin-top:24px;flex-wrap:wrap;gap:8px}
.pv-tl-step{display:flex;align-items:flex-start;gap:12px;flex:1;min-width:140px}
.pv-tl-dot{width:40px;height:40px;flex-shrink:0;border-radius:10px;background:rgba(27,47,78,.07);display:flex;align-items:center;justify-content:center;font-size:15px;color:var(--text-muted)}
.pv-tl-dot--lime{background:rgba(150,201,61,.12);color:var(--lime-dark)}
.pv-tl-dot--green{background:rgba(34,197,94,.1);color:#16a34a}
.pv-tl-step>div{display:flex;flex-direction:column;gap:3px}
.pv-tl-step strong{font-size:13px;font-weight:700;color:var(--navy);line-height:1.3}
.pv-tl-step span{font-size:12px;color:var(--text-muted);line-height:1.4}
.pv-tl-arrow{color:rgba(27,47,78,.25);font-size:14px;flex-shrink:0;align-self:center}
@media(max-width:960px){
    .pv-section{padding:24px 20px}
    .pv-purpose-grid{grid-template-columns:1fr 1fr}
    .pv-timeline{flex-direction:column;align-items:flex-start}
    .pv-tl-arrow{transform:rotate(90deg)}
}
@media(max-width:600px){
    .pv-purpose-grid{grid-template-columns:1fr}
    .pv-section-head h2{font-size:16px}
}
.modal-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,.55);z-index:2000;align-items:center;justify-content:center}
.modal-overlay.active{display:flex}
.modal-box{background:var(--white);border-radius:var(--radius-lg);padding:44px;max-width:480px;width:90%;box-shadow:var(--shadow-lg);position:relative;animation:modalIn .3s ease}
@keyframes modalIn{from{opacity:0;transform:scale(.92)}to{opacity:1;transform:scale(1)}}
.modal-close{position:absolute;top:16px;right:16px;background:none;border:none;font-size:20px;cursor:pointer;color:var(--text-muted)}
.modal-close:hover{color:var(--text-dark)}
.modal-box h3{font-size:22px;font-weight:800;color:var(--navy);margin-bottom:6px}
.modal-box p{font-size:14px;color:var(--text-muted);margin-bottom:28px}
.modal-tabs{display:flex;gap:0;border-bottom:2px solid var(--border);margin-bottom:24px}
.modal-tab{padding:9px 20px;font-size:13px;font-weight:600;color:var(--text-muted);cursor:pointer;border-bottom:3px solid transparent;margin-bottom:-2px}
.modal-tab.active{color:var(--navy);border-bottom-color:var(--lime)}
.modal-panel{display:none}
.modal-panel.active{display:block}

/* ---- RESPONSIVE ---- */
/* Sidebar — responsive rules (nav ya es siempre colapsada) */
@media (max-width:960px){
    body.nav-open::before{content:'';position:fixed;inset:0;background:rgba(0,0,0,.45);z-index:999}
    .hero{flex-direction:column;padding:48px 24px 60px;min-height:auto}
    .hero-media{max-width:100%;width:100%;height:280px}
    .hero-content{max-width:100%;padding-left:0;padding-top:36px}
    .hero-content h1{font-size:26px}
    .about-inner{flex-direction:column;gap:40px}
    .about-media{width:100%;flex:none}
    .contact-inner{grid-template-columns:1fr}
    .cnt-hero{padding:60px 24px 0}
    .cnt-cards-row{grid-template-columns:1fr}
    .cnt-actions-row{flex-wrap:wrap;gap:10px;padding:28px 0 0}
    .cnt-map-form{grid-template-columns:1fr;gap:40px;padding:0 24px}
    .svc-home-grid{grid-template-columns:1fr 1fr}
    .section{padding:60px 24px}
    .footer-inner{grid-template-columns:1fr 1fr;gap:36px}
    footer{padding:48px 24px 32px}
    .footer-bottom{flex-direction:column;text-align:center}
    .float-btn span{display:none}
    .float-btn{padding:14px;border-radius:50%}
    .svc-two-col{grid-template-columns:1fr}
    .noms-mini-grid{grid-template-columns:repeat(2,1fr)}
    .alm-stats-bar{grid-template-columns:1fr 1fr}
    .alm-stat{border-right:none;border-bottom:1px solid rgba(255,255,255,.08)}
    .alm-stat:nth-child(even){border-right:none}
    .contact-strip-grid{grid-template-columns:1fr 1fr}
    .cs-grid-5{grid-template-columns:1fr 1fr !important}
    .cn2-hero-wrap{grid-template-columns:1fr;gap:36px;padding:60px 40px 36px}
    .cn2-hero-right{display:grid;grid-template-columns:1fr 1fr;gap:10px;max-height:none;overflow-y:visible}
    .cn2-stats-bar{padding:18px 32px;flex-wrap:wrap;gap:14px}
    .cn2-sep{display:none}
    .cn2-stat{min-width:40%;flex:none}
    .kn-grid{grid-template-columns:1fr 1fr;gap:16px}
    .kn-inner{padding:0 40px}
    .cn2-why-grid{grid-template-columns:1fr 1fr;gap:16px}
    .cn2-why-inner{padding:0 40px}
    .cn2-why-section{padding:60px 40px}
    .cn2-contact-wrap{grid-template-columns:1fr;gap:36px;padding:0 40px}
    .cn2-contact-btns{flex-direction:row;max-width:none}
    .cn2-contact-cards{grid-template-columns:1fr}
    .qss-grid{grid-template-columns:1fr;box-shadow:none}
    .qss-section{padding:60px 40px 60px 40px}
    .qss-left-card{padding:36px 24px}
    .qss-right-col{padding:36px 24px}
    .qss-svc-grid{grid-template-columns:1fr}
    .about-metrics-bar{grid-template-columns:1fr 1fr;padding:40px 24px}
    .about-metric+.about-metric{border-left:none;border-top:1px solid rgba(27,47,78,.15);padding-top:24px}
}
@media (max-width:600px){
    .hero-actions{flex-direction:column}
    .footer-inner{grid-template-columns:1fr}
    .about-stats{grid-template-columns:1fr 1fr}
    .noms-mini-grid{grid-template-columns:1fr 1fr}
    .contact-strip-grid{grid-template-columns:1fr}
    .labels-type-grid{grid-template-columns:1fr 1fr}
    .page-hero-badges{gap:6px}
    .svc-home-grid{grid-template-columns:1fr}
    .cnt-action-btn{width:100%;justify-content:center}
    .cnt-hero-inner h2{font-size:26px}
    .phn-pill{font-size:12px;padding:6px 14px}
    .alm-location-card{flex-direction:column}
    .svc-highlight-card{height:auto}
    .cn2-hero-wrap{padding:48px 20px 28px}
    .cn2-title{font-size:30px}
    .cn2-hero-right{grid-template-columns:1fr;max-height:none;overflow-y:visible}
    .cn2-stats-bar{padding:16px 20px}
    .kn-grid{grid-template-columns:1fr 1fr}
    .kn-inner{padding:0 20px}
    .cn2-why-grid{grid-template-columns:1fr}
    .cn2-why-inner{padding:0 20px}
    .cn2-why-section{padding:60px 20px}
    .cn2-contact-wrap{padding:0 20px}
    .cn2-contact-cards{grid-template-columns:1fr}
    .cn2-contact-btns{flex-direction:column;max-width:none}
    .qss-svc-grid{grid-template-columns:1fr}
    .qss-section{padding:60px 20px 60px 20px}
    .cs-grid-5{grid-template-columns:1fr !important}
}

/* ============================================================
   SERVICIOS — REDISEÑO COMPLETO (2026)
   ============================================================ */

/* ---- Hero ---- */
.sv-hero{background:linear-gradient(135deg,#0a1628 0%,#1b2f4e 100%);color:#fff;padding:0}
.sv-hero-inner{max-width:1240px;margin:0 auto;display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center;padding:80px 60px 60px}
.sv-hero-accent{color:var(--lime)}
.sv-hero-title{font-size:38px;font-weight:900;line-height:1.12;margin:12px 0 18px;color:#fff}
.sv-hero-sub{font-size:15px;color:rgba(255,255,255,.72);line-height:1.75;margin-bottom:32px}
.sv-hero-sub strong{color:#fff}
.sv-hero-actions{display:flex;gap:14px;flex-wrap:wrap}
.sv-hero-right{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.sv-hero-card{background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.12);border-radius:14px;padding:22px 18px;text-decoration:none;transition:all .25s;display:block}
.sv-hero-card:hover{background:rgba(150,201,61,.1);border-color:rgba(150,201,61,.4);transform:translateY(-3px)}
.sv-hero-card i{font-size:26px;color:var(--lime);display:block;margin-bottom:10px}
.sv-hero-card h4{font-size:13px;font-weight:700;color:#fff;margin:0 0 5px}
.sv-hero-card p{font-size:11.5px;color:rgba(255,255,255,.55);line-height:1.5;margin:0}

/* Stats bar */
.sv-stats-bar{background:rgba(0,0,0,.3);border-top:1px solid rgba(255,255,255,.1);padding:22px 60px;display:flex;justify-content:center}
.sv-stat{flex:1;text-align:center;padding:0 24px;position:relative}
.sv-stat+.sv-stat::before{content:'';position:absolute;left:0;top:50%;transform:translateY(-50%);height:36px;width:1px;background:rgba(255,255,255,.15)}
.sv-stat strong{display:block;font-size:26px;font-weight:900;color:var(--lime);line-height:1;margin-bottom:4px}
.sv-stat span{font-size:11px;color:rgba(255,255,255,.62)}

/* ---- Sticky sidebar layout ---- */
.sv-wrap{max-width:1240px;margin:0 auto;display:grid;grid-template-columns:220px 1fr;gap:40px;padding:52px 60px;align-items:start}
.sv-sidenav{position:sticky;top:90px;background:var(--white);border:1px solid var(--border);border-radius:14px;overflow:hidden;box-shadow:var(--shadow-sm)}
.sv-sidenav-title{font-size:10px;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:1px;padding:14px 16px 10px;border-bottom:1px solid var(--border)}
.sv-sidenav-item{display:flex;align-items:center;gap:10px;padding:13px 16px;font-size:12.5px;font-weight:600;color:var(--text-muted);text-decoration:none;border-left:3px solid transparent;transition:all .2s}
.sv-sidenav-item:hover{color:var(--navy);background:rgba(27,47,78,.04)}
.sv-sidenav-item.active{color:var(--navy);background:rgba(150,201,61,.09);border-left-color:var(--lime)}
.sv-sidenav-item i{width:14px;text-align:center;font-size:13px;color:var(--lime-dark)}
.sv-sidenav-num{font-size:9px;font-style:italic;color:var(--lime-dark);font-weight:900;width:14px;text-align:center}

/* ---- Sections ---- */
.sv-content{min-width:0}
.sv-section{padding-bottom:56px;margin-bottom:56px;border-bottom:1px solid var(--border)}
.sv-section:last-child{border-bottom:none;margin-bottom:0}
.sv-section-head{display:flex;align-items:flex-start;gap:16px;margin-bottom:20px}
.sv-section-badge{width:46px;height:46px;background:var(--navy);color:var(--lime);font-size:17px;font-weight:900;border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0;font-style:italic;margin-top:4px}
.sv-section-head h2{font-size:24px;font-weight:800;color:var(--navy);margin:4px 0 0}

/* ---- Process steps ---- */
.sv-steps{display:flex;gap:0;margin:28px 0 40px;position:relative}
.sv-steps::before{content:'';position:absolute;top:26px;left:44px;right:44px;height:2px;background:linear-gradient(90deg,var(--lime) 0%,rgba(27,47,78,.25) 100%);z-index:0}
.sv-step{flex:1;text-align:center;position:relative;z-index:1;padding:0 8px}
.sv-step-icon{width:54px;height:54px;background:var(--navy);border-radius:50%;display:flex;align-items:center;justify-content:center;margin:0 auto 12px;border:3px solid #fff;box-shadow:0 0 0 3px var(--lime)}
.sv-step-icon i{font-size:19px;color:var(--lime)}
.sv-step-n{font-size:9px;font-weight:700;color:var(--lime-dark);text-transform:uppercase;letter-spacing:1px;margin-bottom:3px}
.sv-step-title{font-size:12.5px;font-weight:700;color:var(--navy);margin-bottom:4px}
.sv-step-desc{font-size:11px;color:var(--text-muted);line-height:1.5}

/* ---- Etiquetados service cards ---- */
.sv-spc-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin:24px 0}
.sv-spc-card{background:var(--white);border:1px solid var(--border);border-radius:14px;overflow:hidden;display:flex;flex-direction:column;transition:all .25s}
.sv-spc-card:hover{box-shadow:var(--shadow-md);transform:translateY(-3px);border-color:var(--lime)}
.sv-spc-top{background:linear-gradient(135deg,#1b2f4e 0%,#254056 100%);padding:28px;text-align:center}
.sv-spc-top i{font-size:36px;color:var(--lime)}
.sv-spc-body{padding:22px;flex:1;display:flex;flex-direction:column}
.sv-spc-body h3{font-size:15px;font-weight:800;color:var(--navy);margin-bottom:8px}
.sv-spc-body p{font-size:13px;color:var(--text-muted);line-height:1.7;flex:1;margin-bottom:14px}
.sv-spc-link{font-size:12.5px;font-weight:700;color:var(--lime-dark);text-decoration:none;display:flex;align-items:center;gap:6px}
.sv-spc-link i{transition:transform .2s}
.sv-spc-link:hover i{transform:translateX(4px)}

/* ---- Label types (horizontal) ---- */
.sv-label-types{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin:20px 0}
.sv-label-card{background:var(--white);border:2px solid var(--border);border-radius:12px;padding:18px 16px;display:flex;align-items:flex-start;gap:14px;transition:border-color .2s}
.sv-label-card:hover{border-color:var(--lime)}
.sv-label-icon{width:44px;height:44px;background:rgba(150,201,61,.12);border-radius:10px;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.sv-label-icon i{font-size:18px;color:var(--lime-dark)}
.sv-label-card h5{font-size:13px;font-weight:700;color:var(--navy);margin-bottom:4px}
.sv-label-card p{font-size:11.5px;color:var(--text-muted);line-height:1.5;margin:0}

/* ---- OCP certification flow ---- */
.sv-cert-flow{display:flex;gap:6px;margin:28px 0 40px}
.sv-cert-step{flex:1;background:var(--white);border:1px solid var(--border);border-radius:12px;padding:16px 10px;text-align:center;position:relative}
.sv-cert-step+.sv-cert-step::before{content:'\f054';font-family:'Font Awesome 6 Free';font-weight:900;position:absolute;left:-10px;top:50%;transform:translateY(-50%);font-size:9px;color:var(--lime-dark);z-index:1}
.sv-cert-step-n{width:28px;height:28px;background:var(--navy);color:var(--lime);font-size:11px;font-weight:900;border-radius:50%;display:flex;align-items:center;justify-content:center;margin:0 auto 10px}
.sv-cert-step h5{font-size:11.5px;font-weight:700;color:var(--navy);margin-bottom:4px}
.sv-cert-step p{font-size:10.5px;color:var(--text-muted);line-height:1.5;margin:0}

/* ---- Almacenaje services grid ---- */
.sv-alm-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
.sv-alm-card{background:var(--white);border:1px solid var(--border);border-radius:12px;padding:18px 16px;display:flex;align-items:flex-start;gap:13px;transition:all .2s}
.sv-alm-card:hover{border-color:var(--lime);box-shadow:var(--shadow-sm)}
.sv-alm-card-icon{width:42px;height:42px;background:rgba(27,47,78,.07);border-radius:10px;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.sv-alm-card-icon i{font-size:18px;color:var(--navy)}
.sv-alm-card h5{font-size:13px;font-weight:700;color:var(--navy);margin-bottom:4px}
.sv-alm-card p{font-size:11.5px;color:var(--text-muted);line-height:1.5;margin:0}

/* ---- Bottom CTA ---- */
.sv-cta-section{background:linear-gradient(135deg,#0a1628 0%,#1b2f4e 100%);padding:72px 60px;text-align:center;color:#fff}
.sv-cta-inner{max-width:700px;margin:0 auto}
.sv-cta-section h2{font-size:30px;font-weight:900;margin-bottom:14px;line-height:1.25;color:#fff}
.sv-cta-section p{font-size:15px;color:rgba(255,255,255,.72);margin-bottom:36px;line-height:1.7}
.sv-cta-actions{display:flex;gap:16px;justify-content:center;flex-wrap:wrap}
.sv-cta-wa{display:inline-flex;align-items:center;gap:10px;background:#25d366;color:#fff;font-size:15px;font-weight:700;padding:14px 28px;border-radius:var(--radius);text-decoration:none;transition:all .2s}
.sv-cta-wa:hover{background:#1ebe5a;transform:translateY(-2px)}

/* ---- Responsive ---- */
@media(max-width:1024px){
    .sv-hero-inner{grid-template-columns:1fr;gap:40px;padding:60px 40px 50px}
    .sv-wrap{grid-template-columns:1fr;padding:40px}
    .sv-sidenav{position:static;display:flex;flex-direction:row;flex-wrap:wrap;border-radius:10px}
    .sv-sidenav-title{display:none}
    .sv-sidenav-item{flex:1;min-width:130px;border-left:none;border-bottom:3px solid transparent;justify-content:center;padding:12px 8px;font-size:11.5px}
    .sv-sidenav-item.active{border-bottom-color:var(--lime);border-left:none;background:rgba(150,201,61,.08)}
    .sv-sidenav-num{display:none}
    .sv-sidenav div[style]{width:100%}
}
@media(max-width:768px){
    .sv-hero-inner{padding:50px 24px 40px}
    .sv-hero-right{grid-template-columns:1fr 1fr}
    .sv-hero-title{font-size:28px}
    .sv-stats-bar{padding:20px 24px;flex-wrap:wrap;gap:16px}
    .sv-stat+.sv-stat::before{display:none}
    .sv-wrap{padding:24px 20px}
    .sv-steps{flex-direction:column;gap:20px}
    .sv-steps::before{display:none}
    .sv-step{text-align:left;display:flex;align-items:flex-start;gap:14px;padding:0}
    .sv-step-icon{flex-shrink:0;margin:0}
    .sv-spc-grid,.sv-label-types,.sv-alm-grid{grid-template-columns:1fr}
    .sv-cert-flow{flex-direction:column}
    .sv-cert-step+.sv-cert-step::before{display:none}
    .sv-cta-section{padding:50px 24px}
    .sv-cta-section h2{font-size:22px}
    .sv-sidenav-item span:last-child{display:none}
}

/* ======================================================
   ¿QUIÉNES SOMOS? — HERO CON IMAGEN DE FONDO
   ====================================================== */
.hqs-section {
    position: relative;
    min-height: 620px;
    display: flex;
    align-items: stretch;
    overflow: hidden;
}
/* Transición fluida desde el hero — degradado superior */
.hqs-section::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    height: 160px;
    background: linear-gradient(
        to bottom,
        #070c18 0%,
        rgba(7, 12, 24, 0.60) 40%,
        transparent 100%
    );
    z-index: 2;
    pointer-events: none;
}
/* Imagen de fondo */
.hqs-bg {
    position: absolute;
    inset: 0;
    background-size: cover;
    background-position: center right;
    background-repeat: no-repeat;
    z-index: 0;
}
/* Overlay degradado hacia la derecha */
.hqs-overlay {
    position: absolute;
    inset: 0;
    background: linear-gradient(
        100deg,
        rgba(10, 20, 40, 0.92) 0%,
        rgba(10, 20, 40, 0.82) 45%,
        rgba(10, 20, 40, 0.30) 75%,
        rgba(10, 20, 40, 0.05) 100%
    );
    z-index: 1;
}
/* Contenedor interior */
.hqs-inner {
    position: relative;
    z-index: 2;
    max-width: 1200px;
    margin: 0 auto;
    padding: 80px 40px;
    width: 100%;
}
/* Columna izquierda: máximo 580px */
.hqs-left {
    max-width: 580px;
    display: flex;
    flex-direction: column;
    gap: 22px;
}
/* Eyebrow */
.hqs-eyebrow {
    font-size: 11.5px;
    font-weight: 800;
    letter-spacing: 2.5px;
    text-transform: uppercase;
    color: var(--lime);
    margin: 0;
}
/* Título */
.hqs-title {
    font-size: clamp(38px, 5vw, 62px);
    font-weight: 900;
    color: #fff;
    line-height: 1.05;
    margin: 0;
    letter-spacing: -1.5px;
}
.hqs-title span { color: var(--lime); }
/* Subtítulo */
.hqs-subtitle {
    font-size: 15px;
    color: rgba(255,255,255,.65);
    margin: 0;
    line-height: 1.6;
}
/* Grid de estadísticas */
.hqs-stats {
    display: flex;
    gap: 14px;
    flex-wrap: wrap;
}
.hqs-stat {
    display: flex;
    align-items: center;
    gap: 13px;
    background: rgba(255,255,255,.08);
    border: 1px solid rgba(255,255,255,.14);
    border-radius: 14px;
    padding: 14px 18px;
    backdrop-filter: blur(8px);
    flex: 1;
    min-width: 140px;
    transition: background .25s, border-color .25s;
}
.hqs-stat:hover {
    background: rgba(150,201,61,.14);
    border-color: rgba(150,201,61,.4);
}
.hqs-stat-ico {
    font-size: 22px;
    color: var(--lime);
    flex-shrink: 0;
    width: 28px;
    text-align: center;
}
.hqs-stat-num {
    font-size: 20px;
    font-weight: 900;
    color: #fff;
    line-height: 1.1;
}
.hqs-stat-lbl {
    font-size: 10.5px;
    color: rgba(255,255,255,.6);
    font-weight: 600;
    line-height: 1.3;
    margin-top: 1px;
}
/* Card de descripción */
.hqs-card {
    background: rgba(255,255,255,.09);
    border: 1px solid rgba(255,255,255,.15);
    border-radius: 18px;
    padding: 26px 28px;
    backdrop-filter: blur(10px);
    display: flex;
    flex-direction: column;
    gap: 18px;
}
.hqs-card p {
    font-size: 14.5px;
    color: rgba(255,255,255,.82);
    line-height: 1.75;
    margin: 0;
}
.hqs-card p strong { color: #fff; font-weight: 700; }
/* Botón CTA */
.hqs-cta {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    background: var(--lime);
    color: var(--navy);
    font-size: 13.5px;
    font-weight: 800;
    padding: 12px 24px;
    border-radius: 50px;
    text-decoration: none;
    align-self: flex-start;
    transition: background .2s, transform .2s, box-shadow .2s;
    box-shadow: 0 6px 20px rgba(150,201,61,.35);
}
.hqs-cta:hover {
    background: var(--lime-dark);
    transform: translateY(-2px);
    box-shadow: 0 10px 28px rgba(150,201,61,.45);
}
/* Responsive */
@media (max-width: 768px) {
    .hqs-inner { padding: 60px 24px; }
    .hqs-left { max-width: 100%; }
    .hqs-overlay {
        background: linear-gradient(
            180deg,
            rgba(10,20,40,.92) 0%,
            rgba(10,20,40,.85) 60%,
            rgba(10,20,40,.7) 100%
        );
    }
    .hqs-stats { gap: 10px; }
    .hqs-stat { min-width: calc(50% - 5px); }
}
@media (max-width: 480px) {
    .hqs-stat { min-width: 100%; }
    .hqs-card { padding: 20px; }
}

/* ======================================================
    QUIÉNES SOMOS — TARJETA CON PARALLAX 3D (legacy, unused)
    ====================================================== */
.home-about-section{
    background:linear-gradient(180deg,#ffffff 0%,#f8faf5 100%);
    padding:100px 0;
    position:relative;
    overflow:hidden
}
.home-about-container{
    max-width:1200px;
    margin:0 auto;
    padding:0 40px;
    position:relative;
    z-index:1
}
.home-about-header{
    text-align:center;
    max-width:720px;
    margin:0 auto 50px
}
.home-about-header .tag{margin-bottom:16px}
.home-about-title{
    font-size:42px;
    font-weight:900;
    color:var(--navy);
    margin:0 0 16px;
    line-height:1.1;
    letter-spacing:-1px
}
.container-3d{
    perspective:1000px;
    display:flex;
    justify-content:center;
    align-items:center;
    margin-bottom:60px
}
.card-3d{
    width:100%;
    max-width:1100px;
    background:var(--white);
    border-radius:24px;
    overflow:hidden;
    box-shadow:0 25px 80px rgba(27,47,78,.2);
    transform-style:preserve-3d;
    transition:transform 0.1s ease-out;
    cursor:pointer
}
.card-3d:hover{
    box-shadow:0 35px 100px rgba(150,201,61,.3)
}
.card-3d-inner{
    display:grid;
    grid-template-columns:1fr 1fr;
    transform-style:preserve-3d;
    width:100%;
    height:100%
}
.card-3d-content{
    padding:60px;
    display:flex;
    flex-direction:column;
    justify-content:center;
    gap:24px;
    transform-style:preserve-3d
}
.about-card-intro{
    font-size:20px;
    font-weight:700;
    color:var(--navy);
    line-height:1.6;
    margin:0
}
.about-card-text{
    font-size:15px;
    color:var(--text-muted);
    line-height:1.8;
    margin:0
}
.about-card-text strong{
    color:var(--navy);
    font-weight:700
}
.about-card-badges{
    display:flex;
    flex-wrap:wrap;
    gap:12px;
    margin-top:8px
}
.about-badge{
    display:inline-flex;
    align-items:center;
    gap:8px;
    background:linear-gradient(135deg,rgba(150,201,61,.12) 0%,rgba(150,201,61,.06) 100%);
    color:var(--lime-dark);
    border:1.5px solid rgba(150,201,61,.35);
    border-radius:50px;
    padding:10px 20px;
    font-size:13px;
    font-weight:700;
    transition:all 0.3s ease
}
.about-badge:hover{
    background:var(--lime);
    color:var(--navy);
    transform:translateY(-2px);
    box-shadow:0 6px 15px rgba(150,201,61,.3)
}
.about-badge i{font-size:14px}
.card-3d-image{
    position:relative;
    min-height:420px;
    overflow:hidden;
    transform-style:preserve-3d;
    background:linear-gradient(135deg,var(--navy) 0%,var(--navy-light) 100%);
    border-radius:0 24px 24px 0
}
.card-3d-image img{
    width:100%;
    height:100%;
    object-fit:cover;
    border-radius:0 24px 24px 0
}
.card-3d-image-overlay{
    position:absolute;
    bottom:0;
    left:0;
    right:0;
    background:linear-gradient(transparent,rgba(27,47,78,.95));
    padding:60px 32px 32px
}
.overlay-content{
    display:flex;
    align-items:center;
    gap:14px;
    color:#fff
}
.overlay-content i{
    font-size:32px;
    color:var(--lime)
}
.overlay-content span{
    font-size:15px;
    font-weight:700;
    line-height:1.4
}
/* Historia V2 */
.history-section{
    margin-bottom:60px
}
.history-header{
    text-align:center;
    margin-bottom:48px
}
.history-header .tag{
    margin-bottom:16px;
    display:inline-block
}
.history-main-title{
    font-size:36px;
    font-weight:900;
    color:var(--navy);
    margin:0;
    line-height:1.2
}
.history-timeline-v2{
    position:relative;
    display:grid;
    grid-template-columns:repeat(3,1fr);
    gap:24px
}
.timeline-line{
    position:absolute;
    top:60px;
    left:16.66%;
    right:16.66%;
    height:4px;
    background:linear-gradient(90deg,var(--lime),var(--lime-dark),var(--lime));
    border-radius:2px;
    z-index:0
}
.history-card-v2{
    background:var(--white);
    border-radius:20px;
    padding:32px;
    position:relative;
    box-shadow:0 4px 30px rgba(27,47,78,.08);
    border:1px solid rgba(150,201,61,.15);
    overflow:hidden;
    transition:all .3s ease;
    z-index:1
}
.history-card-v2:hover{
    transform:translateY(-8px);
    box-shadow:0 16px 50px rgba(27,47,78,.15);
    border-color:var(--lime)
}
.history-card-number{
    font-size:64px;
    font-weight:900;
    color:rgba(150,201,61,.12);
    line-height:1;
    margin-bottom:16px;
    position:absolute;
    top:16px;
    right:24px
}
.history-card-icon{
    width:56px;
    height:56px;
    background:linear-gradient(135deg,var(--lime) 0%,var(--lime-dark) 100%);
    border-radius:16px;
    display:flex;
    align-items:center;
    justify-content:center;
    font-size:24px;
    color:#fff;
    margin-bottom:20px;
    box-shadow:0 8px 24px rgba(150,201,61,.3)
}
.history-card-content h4{
    font-size:18px;
    font-weight:800;
    color:var(--navy);
    margin:0 0 12px;
    line-height:1.3
}
.history-card-content p{
    font-size:14px;
    color:var(--text-muted);
    line-height:1.7;
    margin:0
}
.history-card-accent{
    position:absolute;
    bottom:0;
    left:0;
    right:0;
    height:4px;
    background:linear-gradient(90deg,var(--lime),var(--lime-dark));
    transform:scaleX(0);
    transform-origin:left;
    transition:transform .3s ease
}
.history-card-v2:hover .history-card-accent{
    transform:scaleX(1)
}
/* Stats */
.home-about-stats{
    display:grid;
    grid-template-columns:repeat(4,1fr);
    gap:24px;
    margin-bottom:40px
}
.stat-card{
    background:var(--white);
    border-radius:20px;
    padding:32px 24px;
    text-align:center;
    box-shadow:0 2px 24px rgba(27,47,78,.05);
    border:1px solid rgba(150,201,61,.12);
    transition:all .3s;
    position:relative;
    overflow:hidden
}
.stat-card:hover{
    transform:translateY(-6px);
    box-shadow:0 12px 40px rgba(27,47,78,.1);
    border-color:rgba(150,201,61,.3)
}
.stat-card::after{
    content:'';
    position:absolute;
    bottom:0;
    left:0;
    right:0;
    height:3px;
    background:linear-gradient(90deg,var(--lime),var(--lime-dark));
    opacity:0;
    transition:opacity .3s
}
.stat-card:hover::after{opacity:1}
.stat-card-featured{
    background:linear-gradient(135deg,var(--navy) 0%,var(--navy-light) 100%);
    border-color:var(--navy)
}
.stat-card-featured .stat-icon,
.stat-card-featured .stat-number,
.stat-card-featured .stat-label,
.stat-card-featured .stat-desc{color:#fff}
.stat-card-featured .stat-icon{background:rgba(150,201,61,.2)}
.stat-icon{
    width:56px;
    height:56px;
    background:rgba(150,201,61,.12);
    border-radius:16px;
    display:flex;
    align-items:center;
    justify-content:center;
    font-size:24px;
    color:var(--lime);
    margin:0 auto 20px
}
.stat-number{
    font-size:42px;
    font-weight:900;
    color:var(--navy);
    line-height:1;
    margin-bottom:8px
}
.stat-unit{font-size:20px;font-weight:700}
.stat-label{
    font-size:15px;
    font-weight:800;
    color:var(--navy);
    margin-bottom:8px;
    line-height:1.3
}
.stat-desc{
    font-size:13px;
    color:var(--text-muted);
    line-height:1.5
}
.home-about-cta{text-align:center}
/* Responsive */
@media(max-width:1024px){
    .about-card{grid-template-columns:1fr}
    .about-card-image{min-height:300px}
    .home-about-stats{grid-template-columns:repeat(2,1fr)}
}
@media(max-width:768px){
    .history-timeline{
        grid-template-columns:1fr;
        gap:28px;
        padding:32px 24px
    }
    .history-marker{
        flex-direction:row;
        justify-content:flex-start
    }
    .home-about-title{font-size:32px}
    .about-card-content{padding:32px}
}
@media(max-width:900px){
    .history-timeline-v2{grid-template-columns:1fr;gap:20px}
    .timeline-line{display:none}
    .history-card-v2{text-align:center}
    .history-card-icon{margin-left:auto;margin-right:auto}
    .history-main-title{font-size:28px}
}
@media(max-width:600px){
    .home-about-section{padding:60px 0}
    .home-about-container{padding:0 20px}
    .home-about-title{font-size:28px}
    .home-about-stats{grid-template-columns:1fr}
    .stat-card{padding:24px 20px}
    .stat-number{font-size:36px}
    .history-card-v2{padding:24px}
    .history-card-number{font-size:48px}
    .card-3d-image{border-radius:0}
    .card-3d-image img{border-radius:0}
}

/* ======================================================
   SECCIÓN NUESTRA MISIÓN (mission-section)
   ====================================================== */
.mission-section{background:var(--white);padding:80px 0;position:relative}
.mission-section::before{
    content:'';position:absolute;top:-100px;right:-120px;
    width:500px;height:500px;
    background:radial-gradient(circle,rgba(150,201,61,.08) 0%,transparent 70%);
    pointer-events:none;border-radius:50%
}
.mission-container{
    max-width:1240px;margin:0 auto;padding:0 60px;
    display:grid;grid-template-columns:1fr 1fr;gap:48px;
    align-items:stretch;position:relative;z-index:1
}
/* Tarjeta principal (izquierda) */
.mission-card{
    background:linear-gradient(135deg,#1b2f4e 0%,#243d62 100%);
    border-radius:var(--radius-lg);padding:48px 42px;
    display:flex;flex-direction:column;color:#fff;
    position:relative;overflow:hidden;box-shadow:var(--shadow-lg)
}
.mission-card::after{
    content:'';position:absolute;bottom:-60px;right:-60px;
    width:280px;height:280px;
    background:radial-gradient(circle,rgba(150,201,61,.12) 0%,transparent 70%);
    border-radius:50%;pointer-events:none
}
.mission-main .mission-icon-badge{
    width:64px;height:64px;background:rgba(150,201,61,.18);
    border-radius:16px;display:flex;align-items:center;justify-content:center;
    font-size:28px;color:var(--lime);margin-bottom:20px;flex-shrink:0
}
.mission-title{
    font-size:28px;font-weight:900;color:#fff;
    margin:0 0 18px;line-height:1.2;position:relative;z-index:2
}
.mission-text{
    font-size:15px;color:rgba(255,255,255,.75);line-height:1.8;
    margin-bottom:24px;flex:1;position:relative;z-index:2
}
.mission-text .accent{color:var(--lime);font-weight:700}
.mission-divider{
    border:none;border-top:2px solid rgba(255,255,255,.15);
    margin:24px 0;position:relative;z-index:2
}
.mission-highlights{
    display:flex;flex-direction:column;gap:14px;position:relative;z-index:2
}
.mission-highlight-item{
    display:flex;align-items:flex-start;gap:12px;font-size:14px;
    color:rgba(255,255,255,.85);line-height:1.6
}
.mission-highlight-item i{
    color:var(--lime);font-size:14px;flex-shrink:0;margin-top:2px
}
/* Tarjetas secundarias (derecha) */
.mission-cards-right{
    display:grid;grid-template-columns:1fr;gap:20px;
    grid-template-rows:auto auto
}
.mission-secondary{
    background:var(--white);border:1.5px solid rgba(150,201,61,.2);
    border-radius:var(--radius-lg);padding:36px 32px;
    display:flex;flex-direction:column;gap:16px;
    transition:all .25s;position:relative;overflow:hidden;
    box-shadow:var(--shadow-sm)
}
.mission-secondary::after{
    content:'';position:absolute;top:0;left:0;right:0;height:3px;
    background:linear-gradient(90deg,var(--lime),var(--lime-dark));
    transform:scaleX(0);transform-origin:left;transition:transform .3s
}
.mission-secondary:hover{
    border-color:rgba(150,201,61,.5);box-shadow:var(--shadow-md);
    transform:translateY(-4px)
}
.mission-secondary:hover::after{transform:scaleX(1)}
.mission-card-icon{
    width:56px;height:56px;background:rgba(150,201,61,.1);
    border-radius:14px;display:flex;align-items:center;justify-content:center;
    font-size:24px;color:var(--lime);flex-shrink:0
}
.mission-secondary h3{
    font-size:16px;font-weight:800;color:var(--navy);
    margin:0;line-height:1.3
}
.mission-secondary p{
    font-size:14px;color:var(--text-muted);line-height:1.75;
    margin:0
}
.mission-secondary p .accent{
    color:var(--lime-dark);font-weight:700
}
/* Responsive */
@media(max-width:960px){
    .mission-container{grid-template-columns:1fr;gap:32px;padding:0 40px}
    .mission-card{padding:36px 28px}
    .mission-cards-right{grid-template-columns:1fr 1fr}
}
@media(max-width:600px){
    .mission-section{padding:60px 0}
    .mission-container{padding:0 20px;gap:24px}
    .mission-card{padding:28px 20px}
    .mission-title{font-size:22px}
    .mission-text{font-size:14px}
    .mission-cards-right{grid-template-columns:1fr;gap:16px}
    .mission-secondary{padding:24px 16px}
    .mission-secondary h3{font-size:14px}
}

/* ======================================================
   BOLSA DE TRABAJO (jobs-)
   ====================================================== */
.jobs-hero{
    background:linear-gradient(150deg,#0a1628 0%,#1b2f4e 50%,#243d62 100%);
    padding:100px 60px 80px;position:relative;overflow:hidden;
    text-align:center;color:#fff
}
.jobs-hero::before{
    content:'';position:absolute;inset:0;
    background-image:radial-gradient(circle at 20% 80%, rgba(150,201,61,.1) 0%, transparent 40%),
                      radial-gradient(circle at 85% 20%, rgba(150,201,61,.08) 0%, transparent 35%);
    pointer-events:none
}
.jobs-hero-inner{
    max-width:800px;margin:0 auto;position:relative;z-index:1
}
.jobs-badge{
    display:inline-flex;align-items:center;gap:8px;
    background:rgba(150,201,61,.15);color:var(--lime);
    border:1px solid rgba(150,201,61,.35);border-radius:30px;
    padding:6px 18px;font-size:12px;font-weight:700;
    letter-spacing:.8px;text-transform:uppercase;margin-bottom:24px
}
.jobs-badge-dot{
    width:6px;height:6px;border-radius:50%;background:var(--lime);
    animation:pulseDot 1.6s ease-in-out infinite;flex-shrink:0
}
.jobs-hero-title{
    font-size:clamp(32px,4.5vw,52px);font-weight:900;
    line-height:1.2;margin-bottom:20px;text-shadow:0 2px 16px rgba(0,0,0,.25)
}
.jobs-hero-sub{
    font-size:17px;color:rgba(255,255,255,.72);
    line-height:1.8;max-width:600px;margin:0 auto
}

/* Section vacantes */
.jobs-section{background:var(--off-white);padding:80px 60px}
.jobs-inner{max-width:1200px;margin:0 auto}
.jobs-header h2{
    font-size:32px;font-weight:900;color:var(--navy);margin-bottom:12px
}
.jobs-header p{
    font-size:16px;color:var(--text-muted);line-height:1.7;
    max-width:560px;margin:0
}
.jobs-badge{
    display:inline-flex;align-items:center;gap:8px;
    background:rgba(150,201,61,.1);color:var(--lime-dark);
    border:1px solid rgba(150,201,61,.25);border-radius:20px;
    padding:5px 14px;font-size:11.5px;font-weight:700;
    letter-spacing:.8px;text-transform:uppercase;margin-bottom:12px
}
.jobs-grid{
    display:grid;grid-template-columns:repeat(auto-fill,minmax(340px,1fr));
    gap:28px;margin-bottom:56px
}
.job-card{
    background:var(--white);border:1px solid var(--border);
    border-radius:var(--radius-lg);overflow:hidden;
    display:flex;flex-direction:column;
    transition:all .28s;box-shadow:var(--shadow-sm);
    position:relative
}
.job-card::before{
    content:'';position:absolute;top:0;left:0;width:4px;height:100%;
    background:var(--lime);transform:scaleY(0);
    transition:transform .28s;transform-origin:top;z-index:10
}
.job-card:hover{
    box-shadow:var(--shadow-md);transform:translateY(-6px);
    border-color:rgba(150,201,61,.3)
}
.job-card:hover::before{transform:scaleY(1)}
.job-card-badge{
    display:inline-block;background:rgba(150,201,61,.25);
    color:var(--lime);border-radius:20px;
    padding:4px 12px;font-size:10px;font-weight:800;
    text-transform:uppercase;letter-spacing:.5px;
    margin:16px 16px 0 16px;align-self:flex-start
}
.job-card-title{
    font-size:18px;font-weight:800;color:var(--navy);
    margin:10px 16px 0;line-height:1.3;padding:0
}
.job-card-meta{display:flex;flex-direction:column;gap:6px;margin:12px 16px 0;padding:0;list-style:none}
.job-meta-item{
    font-size:12px;color:var(--text-muted);
    display:flex;align-items:center;gap:6px
}
.job-meta-item i{color:var(--lime-dark);font-size:11px;flex-shrink:0}
.job-card-desc{
    font-size:14px;color:var(--text-muted);
    line-height:1.75;margin:12px 16px 16px;padding:0;flex:1
}
.job-card-btn{
    display:inline-flex;align-items:center;gap:8px;
    color:var(--lime-dark);font-size:13px;
    font-weight:700;text-decoration:none;
    transition:gap .2s;margin:0 16px 16px;align-self:flex-start
}
.job-card-btn i{font-size:11px;transition:transform .2s}
.job-card:hover .job-card-btn{gap:12px}
.job-card:hover .job-card-btn i{transform:translateX(3px)}
.jobs-empty{
    text-align:center;padding:80px 60px;background:var(--white);
    border:2px dashed var(--border);border-radius:var(--radius-lg)
}
.jobs-empty i{
    font-size:56px;color:var(--text-muted);margin-bottom:20px;
    display:block;opacity:.5
}
.jobs-empty h3{
    font-size:20px;font-weight:800;color:var(--navy);margin-bottom:10px
}
.jobs-empty p{
    font-size:14px;color:var(--text-muted);margin:0
}

/* Form section */
.jobs-form-section{
    background:var(--off-white);padding:64px 60px
}
.jobs-form-inner{
    max-width:680px;margin:0 auto
}
.jobs-form-header{
    text-align:center;margin-bottom:44px
}
.jobs-form-header h2{
    font-size:28px;font-weight:900;color:var(--navy);margin-bottom:12px
}
.jobs-form-header p{
    font-size:15px;color:var(--text-muted);line-height:1.7;margin:0
}
.jobs-form{
    display:flex;flex-direction:column;gap:18px;
    background:var(--white);padding:40px;border-radius:var(--radius-lg);
    border:1px solid var(--border);box-shadow:var(--shadow-sm)
}
.jobs-form-row{
    display:grid;grid-template-columns:1fr 1fr;gap:16px
}
.jobs-form-group{display:flex;flex-direction:column;gap:6px}
.jobs-label{
    font-size:12.5px;font-weight:700;color:var(--slate);
    letter-spacing:.3px;text-transform:uppercase
}
.jobs-required{color:var(--lime-dark);font-weight:700}
.jobs-form input[type="text"],
.jobs-form input[type="email"],
.jobs-form input[type="tel"],
.jobs-form textarea,
.jobs-form select{
    padding:12px 15px;border:1.5px solid var(--border);
    border-radius:9px;font-size:14px;color:var(--text-dark);
    background:var(--white);outline:none;width:100%;
    transition:border-color .22s,box-shadow .22s;font-family:inherit
}
.jobs-form input:focus,
.jobs-form textarea:focus,
.jobs-form select:focus{
    border-color:var(--lime);box-shadow:0 0 0 3px rgba(150,201,61,.14)
}
.jobs-form textarea{resize:vertical;min-height:120px}
.jobs-form .btn-primary{
    margin-top:8px;display:flex;align-items:center;
    justify-content:center;gap:10px;position:relative;
    overflow:hidden;width:100%
}
.jobs-form .btn-primary::before{
    content:'';position:absolute;inset:0;
    background:linear-gradient(135deg,var(--lime-dark) 0%,var(--lime) 100%);
    opacity:0;transition:opacity .25s;z-index:0
}
.jobs-form .btn-primary:hover::before{opacity:1}
.jobs-form .btn-primary > *{position:relative;z-index:1}
.jobs-form .btn-primary:hover{
    color:var(--navy);transform:translateY(-2px);
    box-shadow:0 6px 24px rgba(150,201,61,.4)
}

/* Alerts */
.alert{
    display:flex;align-items:flex-start;gap:12px;
    padding:16px 18px;border-radius:12px;margin-bottom:20px;
    font-size:14px;font-weight:500
}
.alert i{font-size:16px;margin-top:1px;flex-shrink:0}
.alert-success{
    background:rgba(34,197,94,.1);border:1.5px solid rgba(34,197,94,.35);
    color:#156f2f
}
.alert-success i{color:#16a34a}
.alert-error{
    background:rgba(220,53,69,.08);border:1.5px solid rgba(220,53,69,.3);
    color:#842029
}
.alert-error i{color:#dc3545}

/* Responsive */
@media(max-width:960px){
    .jobs-hero{padding:80px 40px 60px}
    .jobs-section{padding:60px 40px}
    .jobs-grid{grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:20px}
    .jobs-form-section{padding:48px 40px}
    .jobs-form-row{grid-template-columns:1fr}
}
@media(max-width:768px){
    .jobs-hero{padding:60px 24px 50px}
    .jobs-hero-title{font-size:28px}
    .jobs-section{padding:40px 24px}
    .jobs-grid{grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:16px}
    .jobs-form-section{padding:36px 24px}
    .jobs-label{font-size:12px}
}
@media(max-width:600px){
    .jobs-hero{padding:48px 20px 40px}
    .jobs-hero-title{font-size:24px}
    .jobs-hero-sub{font-size:15px}
    .jobs-section{padding:32px 20px}
    .jobs-header h2{font-size:24px}
    .jobs-grid{grid-template-columns:1fr}
    .jobs-form-section{padding:28px 20px}
    .jobs-form-header h2{font-size:22px}
    .jobs-form{padding:28px 20px}
}

/* Enhanced About "Who We Are" Section Styles - COMPACT VERSION */
.about-who-we-are {
    display: block;
    padding: 100px 40px;
    position: relative;
    max-width: 1000px;
    margin: 0 auto;
    text-align: center;
}

.about-left-col {
    display: flex;
    flex-direction: column;
    gap: 28px;
    width: 100%;
    align-items: center;
}

.about-right-col {
    display: none;
}

.about-who-title {
    font-size: 72px;
    font-weight: 900;
    background: linear-gradient(135deg, var(--navy) 0%, var(--lime) 100%);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
    line-height: 1.1;
    letter-spacing: -1px;
    margin: 0;
    padding: 0;
    position: relative;
}

.about-who-intro {
    font-size: 20px;
    font-weight: 500;
    color: #444;
    line-height: 1.8;
    margin: 0;
    padding: 0;
    max-width: 700px;
}

.about-mission-vision {
    display: none;
}

/* Mission & Vision Section - NEW LARGE SECTION */
.mission-vision-section {
    background: linear-gradient(135deg, #8b6f47, #6b5a3f);
    padding: 100px 40px;
    color: white;
    position: relative;
}

.mv-card {
    display: flex;
    flex-direction: column;
    gap: 24px;
    padding: 40px 32px;
    background: linear-gradient(135deg, #ffffff, #f8f9fb);
    border: 1px solid #e5e7eb;
    border-radius: 16px;
    transition: all 0.4s ease;
    justify-content: flex-start;
    align-items: flex-start;
    text-align: left;
    position: relative;
    overflow: hidden;
}

.mv-card::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    width: 4px;
    height: 100%;
    background: linear-gradient(180deg, var(--lime), transparent);
    z-index: 1;
}

.mv-card:hover {
    transform: translateY(-8px);
    box-shadow: 0 20px 40px rgba(0, 0, 0, 0.1);
    border-color: var(--lime);
}

.mv-icon {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 64px;
    height: 64px;
    background: linear-gradient(135deg, var(--lime), #7ab82e);
    border-radius: 12px;
    color: white;
    font-size: 28px;
    box-shadow: 0 4px 15px rgba(150, 201, 61, 0.25);
    position: relative;
    z-index: 2;
}

.mv-card:hover .mv-icon {
    transform: scale(1.05) rotate(5deg);
    box-shadow: 0 12px 25px rgba(150, 201, 61, 0.4);
}

.mv-title {
    font-size: 20px;
    font-weight: 700;
    color: var(--navy);
    margin: 0;
    padding: 0;
    text-transform: uppercase;
    letter-spacing: 2px;
    position: relative;
    z-index: 2;
}

.mv-text {
    font-size: 15px;
    font-weight: 400;
    color: #5a6c7d;
    line-height: 1.8;
    margin: 0;
    padding: 0;
    letter-spacing: 0.2px;
    position: relative;
    z-index: 2;
}

/* Enhanced Image Wrapper with 3D Parallax */
.about-image-wrapper {
    position: relative;
    width: 100%;
    border-radius: 30px;
    overflow: clip;
    height: auto;
    transform-style: preserve-3d;
    transition: transform 0.1s ease-out;
    box-shadow: 0 20px 50px rgba(0, 0, 0, 0.15);
}

.about-main-image {
    width: 100%;
    height: auto;
    object-fit: contain;
    display: block;
    border-radius: 30px;
    transform-style: preserve-3d;
    transition: transform 0.1s ease-out;
}

.about-experience-badge {
    position: absolute;
    bottom: 24px;
    right: 24px;
    background: linear-gradient(135deg, #3b82f6, #1e40af);
    color: white;
    width: 180px;
    height: 70px;
    border-radius: 50px;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 4px;
    box-shadow: 0 10px 30px rgba(59, 130, 246, 0.3);
    text-align: center;
    animation: badgePulse 2s ease-in-out infinite;
    transition: all 0.3s ease;
}

@keyframes badgePulse {
    0%, 100% { transform: scale(1); }
    50% { transform: scale(1.05); }
}

.about-experience-badge:hover {
    transform: scale(1.1) rotate(-2deg);
    box-shadow: 0 15px 40px rgba(59, 130, 246, 0.5);
}

.badge-number {
    font-size: 32px;
    font-weight: 900;
    color: white;
    line-height: 1;
    text-shadow: 0 2px 4px rgba(0, 0, 0, 0.3);
}

.badge-text {
    font-size: 11px;
    font-weight: 600;
    color: rgba(255, 255, 255, 0.95);
    line-height: 1.3;
    text-transform: uppercase;
    letter-spacing: 0.5px;
}

/* Responsive: Tablet (960px) */
@media(max-width:960px){
    .about-who-we-are {
        padding: 80px 32px;
    }

    .about-who-title {
        font-size: 56px;
    }

    .about-mission-vision {
        grid-template-columns: 1fr 1fr;
        gap: 32px;
    }

    .mv-card {
        padding: 32px 24px;
        gap: 20px;
    }

    .about-image-wrapper {
        aspect-ratio: 1;
        width: 100%;
        max-width: 400px;
        margin: 0 auto;
    }

    .about-experience-badge {
        width: 160px;
        height: 60px;
        bottom: 20px;
        right: 20px;
    }

    .badge-number {
        font-size: 28px;
    }

    .badge-text {
        font-size: 10px;
    }
}

/* Responsive: Mobile (768px) */
@media(max-width:768px){
    .about-who-we-are {
        padding: 60px 24px;
    }

    .about-left-col {
        gap: 20px;
    }

    .about-who-title {
        font-size: 48px;
    }

    .about-who-intro {
        font-size: 18px;
    }

    .about-mission-vision {
        grid-template-columns: 1fr;
        gap: 20px;
    }

    .mv-card {
        flex-direction: column;
        align-items: center;
        gap: 12px;
        padding: 24px 16px;
    }

    .mv-icon {
        flex-shrink: 0;
        width: 64px;
        height: 64px;
        font-size: 28px;
    }

    .mv-title {
        font-size: 16px;
        letter-spacing: 0.5px;
    }

    .mv-text {
        font-size: 13px;
    }

    .about-image-wrapper {
        aspect-ratio: 1;
        max-width: 100%;
    }

    .about-experience-badge {
        width: 140px;
        height: 52px;
        bottom: 16px;
        right: 16px;
    }

    .badge-number {
        font-size: 24px;
    }

    .badge-text {
        font-size: 9px;
    }
}

/* Responsive: Small Mobile (600px) */
@media(max-width:600px){
    .about-who-we-are {
        padding: 48px 20px;
    }

    .about-left-col {
        gap: 20px;
    }

    .about-who-title {
        font-size: 40px;
    }

    .about-who-intro {
        font-size: 16px;
    }

    .about-mission-vision {
        grid-template-columns: 1fr;
        gap: 16px;
    }

    .mv-card {
        flex-direction: column;
        gap: 12px;
        padding: 20px 16px;
    }

    .mv-icon {
        width: 56px;
        height: 56px;
        font-size: 24px;
    }

    .mv-title {
        font-size: 15px;
        letter-spacing: 0.3px;
    }

    .mv-text {
        font-size: 12px;
        line-height: 1.5;
    }

    .about-image-wrapper {
        aspect-ratio: 1;
        width: 100%;
    }

    .about-experience-badge {
        width: 130px;
        height: 48px;
        bottom: 12px;
        right: 12px;
    }

    .badge-number {
        font-size: 22px;
    }

    .badge-text {
        font-size: 8px;
    }
}

/* Mission & Vision Dark Section */
.mission-vision-section {
    background: linear-gradient(135deg, var(--navy), #0f1f35);
    padding: 100px 40px;
    color: white;
    position: relative;
    text-align: center;
    overflow: hidden;
}

.mv-section-header {
    display: flex;
    flex-direction: column;
    gap: 16px;
    align-items: center;
    margin-bottom: 60px;
}

.mv-badge {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    background: rgba(150, 201, 61, 0.15);
    border: 1px solid rgba(150, 201, 61, 0.5);
    color: var(--lime);
    padding: 8px 16px;
    border-radius: 50px;
    font-size: 12px;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 1px;
}

.mv-section-title {
    font-size: 56px;
    font-weight: 900;
    color: white;
    margin: 0;
    line-height: 1.2;
}

.mv-section-subtitle {
    font-size: 18px;
    color: rgba(255, 255, 255, 0.8);
    margin: 0;
}

.mv-section-content {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 60px;
    align-items: stretch;
}

.mv-card-dark {
    background: rgba(0, 0, 0, 0.3);
    border: 1px solid rgba(150, 201, 61, 0.2);
    border-radius: 20px;
    padding: 40px;
    display: flex;
    flex-direction: column;
    gap: 24px;
    text-align: left;
}

.mv-card-dark .mv-icon {
    width: 64px;
    height: 64px;
    background: rgba(150, 201, 61, 0.2);
    border: 2px solid var(--lime);
    border-radius: 12px;
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--lime);
    font-size: 28px;
    margin: 0 0 0 0;
    box-shadow: none;
}

.mv-card-dark .mv-title {
    color: white;
    font-size: 22px;
}

.mv-card-dark .mv-text {
    color: rgba(255, 255, 255, 0.85);
    line-height: 1.8;
}

.mv-tags-container {
    display: flex;
    flex-wrap: wrap;
    gap: 12px;
}

.mv-tag {
    background: rgba(150, 201, 61, 0.2);
    border: 1px solid var(--lime);
    color: var(--lime);
    padding: 6px 12px;
    border-radius: 20px;
    font-size: 11px;
    font-weight: 600;
    text-transform: uppercase;
}

.mv-image-side {
    position: relative;
    border-radius: 20px;
    overflow: visible;
    perspective: 1000px;
    max-width: 100%;
}

.mv-image-side img {
    width: 100%;
    height: auto;
    object-fit: cover;
    display: block;
    transform-style: preserve-3d;
    transition: transform 0.3s ease-out;
    transform: translateZ(20px);
    border-radius: 20px;
}

.mv-image-side:hover img {
    transform: translateZ(40px) rotateZ(1deg);
}

.mv-image-side::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background: linear-gradient(135deg, rgba(150, 201, 61, 0.1) 0%, rgba(27, 47, 78, 0.15) 100%);
    pointer-events: none;
    z-index: 2;
    border-radius: 20px;
}

.mv-image-side::after {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    box-shadow: inset 0 0 40px rgba(0, 0, 0, 0.2), 0 20px 50px rgba(0, 0, 0, 0.3);
    pointer-events: none;
    z-index: 3;
    border-radius: 20px;
}

.mv-col-left {
    display: flex;
    flex-direction: column;
    gap: 32px;
}

.mv-col-right {
    display: flex;
    flex-direction: column;
    gap: 24px;
}

.mv-stats-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 16px;
    margin-top: 24px;
}

.mv-stat {
    background: rgba(0, 0, 0, 0.3);
    border: 1px solid rgba(150, 201, 61, 0.2);
    border-radius: 12px;
    padding: 20px 16px;
    text-align: center;
}

.mv-stat-number {
    font-size: 28px;
    font-weight: 900;
    color: var(--lime);
    margin-bottom: 4px;
}

.mv-stat-label {
    font-size: 11px;
    color: rgba(255, 255, 255, 0.7);
    text-transform: uppercase;
    letter-spacing: 0.5px;
}

@media(max-width:1024px){
    .mission-vision-section {
        padding: 80px 32px;
    }
    .mv-section-title {
        font-size: 44px;
    }
    .mv-section-content {
        gap: 40px;
    }
    .mv-stats-grid {
        grid-template-columns: 1fr 1fr;
    }
    .mv-stat-number {
        font-size: 22px;
    }
}

@media(max-width:768px){
    .mission-vision-section {
        padding: 60px 20px;
    }
    .mv-section-title {
        font-size: 34px;
    }
    .mv-section-subtitle {
        font-size: 15px;
    }
    .mv-section-content {
        grid-template-columns: 1fr;
        gap: 36px;
    }
    .mv-col-left,
    .mv-col-right {
        gap: 24px;
    }
    .mv-card-dark {
        padding: 24px;
        gap: 16px;
    }
    .mv-card-dark .mv-icon {
        width: 52px;
        height: 52px;
        font-size: 22px;
    }
    .mv-card-dark .mv-title {
        font-size: 18px;
    }
    .mv-stats-grid {
        grid-template-columns: 1fr 1fr;
    }
    .mv-stat-number {
        font-size: 20px;
    }
    .mv-stat {
        padding: 14px 10px;
    }
}

@media(max-width:480px){
    .mission-vision-section {
        padding: 48px 16px;
    }
    .mv-section-title {
        font-size: 26px;
    }
    .mv-section-subtitle {
        font-size: 14px;
    }
    .mv-badge {
        font-size: 10px;
        padding: 6px 12px;
    }
    .mv-card-dark {
        padding: 20px 16px;
    }
    .mv-stats-grid {
        grid-template-columns: 1fr;
    }
    .mv-stat {
        padding: 12px;
    }
    .mv-stat-number {
        font-size: 18px;
    }
    .mv-stat-label {
        font-size: 10px;
    }
    .mv-tags-container {
        gap: 8px;
    }
    .mv-tag {
        font-size: 10px;
        padding: 4px 10px;
    }
}

/* ========== SERVICIOS INTERACTIVOS CON VIDEO ========== */



.svc-stage {
    position: relative;
    isolation: isolate;
}

.svc-custom-cursor {
    position: absolute;
    width: 24px;
    height: 24px;
    border: 2px solid rgba(150, 201, 61, 0.7);
    border-radius: 50%;
    pointer-events: none;
    transform: translate(-50%, -50%);
    z-index: 80;
    opacity: 0;
    transition: opacity .25s ease-in-out, transform .18s ease-in-out, box-shadow .25s ease-in-out;
    box-shadow: 0 0 18px rgba(150, 201, 61, .35);
}

.svc-stage.is-hover .svc-custom-cursor {
    opacity: 1;
}

.svc-custom-cursor.is-active {
    transform: translate(-50%, -50%) scale(1.6);
    box-shadow: 0 0 26px rgba(150, 201, 61, .55);
}

.svc-spotlight {
    position: absolute;
    width: 280px;
    height: 280px;
    border-radius: 50%;
    background: radial-gradient(circle, rgba(150, 201, 61, .18), rgba(9, 16, 30, 0));
    filter: blur(10px);
    pointer-events: none;
    transform: translate(-50%, -50%);
    opacity: 0;
    transition: opacity .3s ease-in-out;
    z-index: 1;
}

.svc-stage.is-hover .svc-spotlight {
    opacity: 1;
}

.svc-video-container {
    max-width: 1040px;
    min-height: 460px;
    margin: 36px auto 10px;
    position: relative;
    display: flex;
    align-items: center;
    justify-content: center;
    overflow: visible;
    transition: all .45s ease-in-out;
}

/* El phone pulsa hasta que el usuario hace clic */
.svc-phone.is-pulsing {
    animation:
        phoneCardPulse 2.4s ease-in-out infinite,
        phoneCardBorderGlow 2.4s ease-in-out infinite !important;
    cursor: pointer;
}

.svc-video-container::before {
    content: '';
    position: absolute;
    inset: 6% 18%;
    background: repeating-linear-gradient(
        120deg,
        rgba(255, 255, 255, .08),
        rgba(255, 255, 255, .08) 1px,
        transparent 1px,
        transparent 18px
    );
    opacity: .12;
    animation: linesMove 14s ease-in-out infinite;
    z-index: 1;
    pointer-events: none;
}

@keyframes linesMove {
    0%, 100% { transform: translateX(0); }
    50% { transform: translateX(-18px); }
}

/* Pulso de borde del celular antes del primer clic */
@keyframes phoneCardPulse {
    0%,100% {
        box-shadow:
            0 32px 80px rgba(10,22,40,.75),
            0 0 0 0   rgba(150,201,61,.0),
            0 0 0 0   rgba(150,201,61,.0);
    }
    40% {
        box-shadow:
            0 32px 80px rgba(10,22,40,.75),
            0 0 0 8px  rgba(150,201,61,.28),
            0 0 0 18px rgba(150,201,61,.10);
    }
    100% {
        box-shadow:
            0 32px 80px rgba(10,22,40,.75),
            0 0 0 0   rgba(150,201,61,.0),
            0 0 0 0   rgba(150,201,61,.0);
    }
}
@keyframes phoneCardBorderGlow {
    0%,100% { border-color: rgba(255,255,255,.18); }
    50%     { border-color: rgba(150,201,61,.75);  }
}

.svc-float-layer {
    position: absolute;
    display: block;
    z-index: 2;
    pointer-events: none;
    transition: transform .45s ease-in-out, filter .45s ease-in-out, opacity .45s ease-in-out;
    animation: floatDrift 8s ease-in-out infinite;
}

.svc-float-dot {
    width: 120px;
    height: 120px;
    border-radius: 50%;
    background: radial-gradient(circle at 30% 30%, rgba(150, 201, 61, .55), rgba(150, 201, 61, .06));
    top: 14%;
    left: 10%;
}

.svc-float-ring {
    width: 140px;
    height: 140px;
    border-radius: 50%;
    border: 1.5px solid rgba(255, 255, 255, .35);
    top: 68%;
    left: 14%;
    box-shadow: 0 0 26px rgba(255, 255, 255, .14);
}

.svc-float-square {
    width: 92px;
    height: 92px;
    border-radius: 16px;
    background: linear-gradient(135deg, rgba(27, 47, 78, .78), rgba(66, 93, 132, .25));
    top: 22%;
    right: 10%;
}

.svc-float-tri {
    width: 0;
    height: 0;
    border-left: 44px solid transparent;
    border-right: 44px solid transparent;
    border-bottom: 76px solid rgba(150, 201, 61, .32);
    right: 15%;
    bottom: 12%;
    filter: drop-shadow(0 4px 12px rgba(150, 201, 61, .2));
}

@keyframes floatDrift {
    0%, 100% { transform: translateY(0); }
    50% { transform: translateY(-10px); }
}

/* svc-video-wrapper eliminado — el phone es ahora el contenedor principal */

.svc-video {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
    pointer-events: none;
    background: #000;
    z-index: 1;
}

@keyframes videoBreath {
    0%, 100% { transform: scale(1); }
    50% { transform: scale(1.06); }
}

.svc-particles {
    position: absolute;
    inset: 0;
    pointer-events: none;
    z-index: 2;
}

.svc-particle {
    position: absolute;
    width: 4px;
    height: 4px;
    border-radius: 50%;
    background: rgba(255, 255, 255, .6);
    box-shadow: 0 0 10px rgba(150, 201, 61, .48);
    animation-name: particleFloat;
    animation-timing-function: ease-in-out;
    animation-iteration-count: infinite;
}

@keyframes particleFloat {
    0%, 100% { transform: translateY(0) scale(1); opacity: .3; }
    50% { transform: translateY(-14px) scale(1.2); opacity: .85; }
}

.svc-video-overlay {
    position: absolute;
    inset: 0;
    background: linear-gradient(165deg, rgba(5, 10, 20, .86), rgba(16, 27, 48, .32));
    display: flex;
    align-items: center;
    justify-content: center;
    transition: opacity .4s ease-in-out, backdrop-filter .4s ease-in-out, background .4s ease-in-out;
    backdrop-filter: blur(2px);
    z-index: 2;
    opacity: 0;
    pointer-events: none;
}

.svc-video-overlay.visible {
    opacity: 1;
    pointer-events: auto;
}

.svc-video-overlay.hidden {
    pointer-events: none;
    opacity: 0;
}

.svc-click-hint {
    color: #fff;
    font-size: 17px;
    font-weight: 700;
    letter-spacing: .4px;
    text-align: center;
    text-shadow: 0 2px 14px rgba(0, 0, 0, .35);
    padding: 10px 16px;
    border-radius: 999px;
    background: rgba(255, 255, 255, .12);
    border: 1px solid rgba(255, 255, 255, .25);
    backdrop-filter: blur(10px);
    animation: pulse-text 1.8s ease-in-out infinite;
}

@keyframes pulse-text {
    0%, 100% { opacity: 1; transform: translateY(0); }
    50% { opacity: .88; transform: translateY(-3px); }
}

.svc-circles-container {
    position: absolute;
    inset: 0;
    z-index: 30;
    opacity: 0;
    pointer-events: none;
    transition: opacity .45s ease-in-out;
}

.svc-circles-container.visible {
    opacity: 1;
    pointer-events: auto;
}

.svc-circle {
    position: absolute;
    width: 76px;
    height: 76px;
    border-radius: 50%;
    border: 1px solid rgba(255, 255, 255, .45);
    background: #384222;
    color: #93ba35;
    font-size: 28px;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    box-shadow: 0 12px 28px #0a1628;
    transition: transform .35s ease-in-out, filter .35s ease-in-out;
}

.svc-circle:nth-child(1) { left: 12%; top: 29%; }
.svc-circle:nth-child(2) { left: 11%; top: 62%; }
.svc-circle:nth-child(3) { right: 12%; top: 29%; }
.svc-circle:nth-child(4) { right: 11%; top: 62%; }

.svc-circle:hover {
    transform: translateY(-6px) scale(1.09) rotateX(8deg) rotateY(-8deg);
    background: rgba(150, 201, 61, .78);
    box-shadow: 0 14px 30px rgba(150, 201, 61, .42), 0 0 22px rgba(150, 201, 61, .28);
}

.svc-circle.is-active {
    background: #254056;
    box-shadow: 0 14px 30px rgba(37, 64, 86, .42), 0 0 22px rgba(37, 64, 86, .28);
}

.svc-circle i {
    text-shadow: 0 0 14px rgba(150, 201, 61, .65);
}

/* === CÍRCULOS DESPLEGADOS: ANIMACIONES Y ESTILOS === */
@keyframes circleIn {
    from { opacity: 0; transform: scale(0.15); }
    to   { opacity: 1; transform: scale(1); }
}

@keyframes circleRing {
    0%   { box-shadow: 0 10px 24px rgba(10,22,40,.8), 0 0 0 0 rgba(150,201,61,.7); }
    65%  { box-shadow: 0 12px 32px rgba(10,22,40,.8), 0 0 0 16px rgba(150,201,61,0); }
    100% { box-shadow: 0 10px 24px rgba(10,22,40,.8), 0 0 0 0 rgba(150,201,61,.7); }
}

@keyframes circleGlow {
    0%,100% { filter: brightness(1);    border-color: rgba(255,255,255,.45); }
    50%     { filter: brightness(1.35); border-color: rgba(150,201,61,.9);   }
}

/* Hint — "Toca un ícono para explorar" */
.svc-circles-hint{
    position:absolute;
    bottom:8%;
    left:50%;
    transform:translateX(-50%);
    display:flex;
    align-items:center;
    gap:8px;
    background:rgba(10,22,40,.72);
    border:1px solid rgba(150,201,61,.45);
    border-radius:30px;
    padding:7px 16px 7px 12px;
    pointer-events:none;
    opacity:0;
    transition:opacity .4s;
    white-space:nowrap;
    z-index:35;
    animation:hintFade 3.2s 1s ease-in-out infinite;
}
.svc-circles-container.visible .svc-circles-hint{opacity:1}
.svc-circles-hint.hidden{animation:none!important;opacity:0!important}
.svc-ch-icon{color:var(--lime);font-size:14px;animation:hintBounce 1s ease-in-out infinite}
.svc-ch-text{font-size:11.5px;font-weight:700;color:rgba(255,255,255,.88);letter-spacing:.3px}
@keyframes hintFade{
    0%,100%{opacity:1}
    50%{opacity:.4}
}
@keyframes hintBounce{
    0%,100%{transform:translateY(0) rotate(-10deg)}
    50%{transform:translateY(-3px) rotate(-10deg)}
}

/* Entrada escalonada + pulso de anillo */
.svc-circles-container.visible .svc-circle:nth-child(1) {
    animation: circleIn .42s .05s cubic-bezier(.34,1.56,.64,1) both,
               circleRing 2.2s .55s ease-in-out infinite,
               circleGlow 2.2s .55s ease-in-out infinite;
}
.svc-circles-container.visible .svc-circle:nth-child(2) {
    animation: circleIn .42s .18s cubic-bezier(.34,1.56,.64,1) both,
               circleRing 2.2s .68s ease-in-out infinite,
               circleGlow 2.2s .68s ease-in-out infinite;
}
.svc-circles-container.visible .svc-circle:nth-child(3) {
    animation: circleIn .42s .11s cubic-bezier(.34,1.56,.64,1) both,
               circleRing 2.2s .61s ease-in-out infinite,
               circleGlow 2.2s .61s ease-in-out infinite;
}
.svc-circles-container.visible .svc-circle:nth-child(4) {
    animation: circleIn .42s .24s cubic-bezier(.34,1.56,.64,1) both,
               circleRing 2.2s .74s ease-in-out infinite,
               circleGlow 2.2s .74s ease-in-out infinite;
}

/* Etiqueta flotante bajo cada círculo (usa el atributo title) */
.svc-circles-container.visible .svc-circle::after {
    content: attr(title);
    position: absolute;
    bottom: -30px;
    left: 50%;
    transform: translateX(-50%);
    background: rgba(27,47,78,.92);
    color: #fff;
    font-size: 10px;
    font-weight: 700;
    white-space: nowrap;
    padding: 4px 10px;
    border-radius: 20px;
    pointer-events: none;
    letter-spacing: .3px;
    border: 1px solid rgba(150,201,61,.35);
    opacity: 0;
    transition: opacity .25s ease-in-out;
    z-index: 2;
}
.svc-circles-container.visible .svc-circle:hover::after,
.svc-circles-container.visible .svc-circle.is-active::after {
    opacity: 1;
}

/* Círculo activo: detener pulso, resaltar con borde lima */
.svc-circles-container.visible .svc-circle.is-active {
    background: #254056;
    border: 2px solid rgba(150,201,61,.75);
    box-shadow: 0 0 28px rgba(150,201,61,.48), 0 14px 30px rgba(37,64,86,.5);
    animation: none;
}

/* === TARJETA OVERLAY REVEAL === */

/* Contenedor externo — posicionado por JS (transform: translateY(-50%)) */
.svc-card-detail {
    position: absolute;
    width: 480px;
    height: 286px;
    opacity: 0;
    pointer-events: none;
    z-index: 40;
}

.svc-card-detail.card-right { /* JS sets left  */ }
.svc-card-detail.card-left  { /* JS sets right */ }

.svc-card-detail.visible {
    opacity: 1;
    pointer-events: auto;
}

/* Envoltura interna — overflow:hidden + animación de pop (sin conflicto con transform del padre) */
.svc-cd-inner {
    width: 100%;
    height: 100%;
    border-radius: 16px;
    overflow: hidden;
    position: relative;
    border: 1px solid rgba(255,255,255,.13);
    box-shadow: 0 24px 60px rgba(10,22,40,.5), 0 0 0 1px rgba(255,255,255,.05);
}

.svc-card-detail.visible .svc-cd-inner {
    animation: svcCardPop .65s cubic-bezier(.26,.53,.74,1.48) both;
}

@keyframes svcCardPop {
    0%   { transform: scale(.42); opacity: 0; }
    100% { transform: scale(1);   opacity: 1; }
}

/* ---------- Overlay deslizable (frente) ---------- */
.svc-cd-overlay {
    position: absolute;
    inset: 0;
    display: flex;
    background: var(--card-accent-bg, #1b2f4e);
    transition: transform .45s cubic-bezier(.4,0,.2,1);
    z-index: 2;
    overflow: hidden;
}

.svc-cd-inner:hover .svc-cd-overlay {
    transform: translateX(-290px);
}

/* Panel izquierdo 190px */
.svc-cd-overlay-content {
    position: relative;
    display: flex;
    flex-direction: column;
    justify-content: center;
    gap: 10px;
    width: 190px;
    min-width: 190px;
    height: 100%;
    padding: 22px 16px;
    border-right: 2px solid transparent;
    border-image: linear-gradient(to bottom, transparent 0%, var(--card-accent, #96c93d) 40% 60%, transparent 100%) 0 100%;
    z-index: 1;
}

.svc-card-detail.visible .svc-cd-overlay-content {
    animation: svcSlideLeft .7s cubic-bezier(.26,.53,.74,1.48) .28s both;
}

@keyframes svcSlideLeft {
    0%   { opacity: 0; transform: translateX(-40px); }
    100% { opacity: 1; transform: translateX(0); }
}

/* Icono circular en overlay */
.svc-cd-oc-icon {
    width: 50px;
    height: 50px;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 22px;
    background: rgba(255,255,255,.12);
    border: 2px solid rgba(255,255,255,.18);
    box-shadow: 0 0 20px rgba(0,0,0,.2);
    flex-shrink: 0;
}

.svc-cd-oc-icon i {
    color: var(--card-accent, #96c93d);
}

.svc-cd-overlay-content h3 {
    font-size: 12.5px;
    font-weight: 800;
    color: #fff;
    line-height: 1.35;
    margin: 0;
    text-shadow: 0 1px 4px rgba(0,0,0,.35);
}

/* Pista de hover */
.svc-cd-oc-hint {
    display: flex;
    align-items: center;
    gap: 5px;
    font-size: 10.5px;
    color: rgba(255,255,255,.45);
    font-weight: 600;
    letter-spacing: .3px;
    transition: color .25s;
}

.svc-cd-inner:hover .svc-cd-oc-hint {
    color: var(--card-accent, #96c93d);
}

/* Imagen (parte derecha del overlay) */
.svc-cd-img {
    position: absolute;
    top: 0;
    right: 0;
    width: 290px;
    height: 100%;
    background-size: cover;
    background-position: center;
    transition: width .45s cubic-bezier(.4,0,.2,1);
}

.svc-card-detail.visible .svc-cd-img {
    animation: svcImgSlide .7s cubic-bezier(.26,.53,.74,1.48) .48s both;
}

@keyframes svcImgSlide {
    0%   { opacity: 0; transform: translateX(40px); }
    100% { opacity: 1; transform: translateX(0); }
}

.svc-cd-inner:hover .svc-cd-img {
    width: 120px;
}

/* Degradado sobre la imagen para que se funda con el overlay */
.svc-cd-img::after {
    content: '';
    position: absolute;
    inset: 0;
    background: linear-gradient(to right, var(--card-accent-bg, #1b2f4e) 0%, transparent 55%);
}

/* Puntos decorativos */
.svc-cd-dots {
    position: absolute;
    bottom: 14px;
    left: 16px;
    display: flex;
    gap: 6px;
    z-index: 3;
    transition: transform .35s ease .28s;
}

.svc-cd-inner:hover .svc-cd-dots {
    transform: translateX(290px);
}

.svc-cd-dot {
    width: 7px;
    height: 7px;
    border-radius: 50%;
    background: rgba(255,255,255,.35);
    border: 1px solid rgba(255,255,255,.5);
    transition: background .3s ease .28s;
}

.svc-cd-dot:nth-child(1) { animation: svcDotUp .7s cubic-bezier(.26,.53,.74,1.48) 1.0s both; }
.svc-cd-dot:nth-child(2) { animation: svcDotUp .7s cubic-bezier(.26,.53,.74,1.48) 1.2s both; }
.svc-cd-dot:nth-child(3) { animation: svcDotUp .7s cubic-bezier(.26,.53,.74,1.48) 1.4s both; }

@keyframes svcDotUp {
    0%   { opacity: 0; transform: translateY(20px); }
    100% { opacity: 1; transform: translateY(0); }
}

.svc-cd-inner:hover .svc-cd-dot {
    background: var(--card-accent, #96c93d);
}

/* ---------- Panel de texto (atrás del overlay, siempre presente) ---------- */
.svc-cd-text {
    position: absolute;
    top: 0;
    right: 0;
    width: 290px;
    height: 100%;
    padding: 20px 18px 20px 16px;
    background: #fff;
    box-shadow: inset 1px 0 14px rgba(0,0,0,.06);
    display: flex;
    flex-direction: column;
    justify-content: center;
    gap: 9px;
    overflow-y: auto;
    z-index: 1;
}

.svc-cd-text p {
    font-size: 12px;
    line-height: 1.62;
    color: #3d4f66;
    margin: 0;
}

/* Mini-lista de servicios */
.svc-card-svcs {
    list-style: none;
    padding: 0;
    margin: 0;
    border-top: 1px solid rgba(0,0,0,.07);
    padding-top: 8px;
}

.svc-card-svcs li {
    font-size: 11.5px;
    color: #3d4f66;
    padding: 2px 0;
    display: flex;
    align-items: center;
    gap: 7px;
    font-weight: 500;
}

.svc-card-svcs li i {
    color: var(--card-accent, #96c93d);
    font-size: 9px;
    flex-shrink: 0;
}

.svc-cd-text .btn-primary {
    font-size: 11.5px;
    padding: 9px 14px;
    width: 100%;
    text-align: center;
    margin-top: 2px;
    transition: transform .25s, box-shadow .25s, filter .25s;
}

.svc-cd-text .btn-primary:hover {
    transform: translateY(-2px) scale(1.02);
    filter: brightness(1.05);
}

/* Botón cerrar — z-index sobre todo */
.svc-card-close {
    position: absolute;
    top: 10px;
    right: 10px;
    width: 34px;
    height: 34px;
    border: 0;
    border-radius: 50%;
    background: rgba(27,47,78,.65);
    color: #fff;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 14px;
    cursor: pointer;
    z-index: 50;
    padding: 0;
    transition: background .3s, transform .3s, box-shadow .3s;
    backdrop-filter: blur(6px);
}

.svc-card-close:hover,
.svc-card-close:focus {
    background: rgba(150,201,61,.85);
    transform: rotate(90deg) scale(1.1);
    box-shadow: 0 4px 14px rgba(150,201,61,.4);
    outline: none;
}

.svc-stage.has-active-card .svc-phone,
.svc-stage.has-active-card .svc-circle:not(.is-active) {
    filter: blur(2px) saturate(0.85);
    opacity: .6;
}

.svc-reveal {
    opacity: 1;
    transform: translateY(0);
    transition: opacity .65s ease-in-out, transform .65s ease-in-out;
}

.svc-reveal.in-view {
    opacity: 1;
    transform: translateY(0);
}

.svc-stage.is-hover .svc-float-layer {
    filter: blur(1.2px);
    opacity: .78;
}

@media (max-width: 1200px) {
    .svc-circle:nth-child(1) { left: 5%; }
    .svc-circle:nth-child(2) { left: 4%; }
    .svc-circle:nth-child(3) { right: 5%; }
    .svc-circle:nth-child(4) { right: 4%; }
}

@media (max-width: 1024px) {
    .svc-custom-cursor { display: none; }

    .svc-video-container {
        min-height: auto;
        padding: 0 10px;
        flex-direction: column;
        align-items: center;
    }

    /* .svc-phone mantiene su width fija de 256px */

    .svc-circles-container {
        position: static;
        inset: auto;
        margin-top: 22px;
        display: grid;
        grid-template-columns: repeat(2, minmax(70px, 1fr));
        gap: 16px;
        justify-items: center;
        width: 100%;
        max-width: 360px;
    }

    .svc-circle,
    .svc-circle:nth-child(1),
    .svc-circle:nth-child(2),
    .svc-circle:nth-child(3),
    .svc-circle:nth-child(4) {
        position: relative;
    }

    /* Card oculta por defecto en tablet/móvil */
    .svc-card-detail {
        display: none;
        position: static !important;
        width: min(92%, 480px);
        height: auto;
        margin: 18px auto 0;
        top: auto !important;
        left: auto !important;
        right: auto !important;
        transform: none !important;
        max-width: 480px;
    }

    .svc-card-detail.card-left,
    .svc-card-detail.card-right {
        position: static !important;
    }

    /* Mostrar solo cuando tiene la clase visible */
    .svc-card-detail.visible {
        display: block;
        position: static !important;
        top: auto !important;
        left: auto !important;
        right: auto !important;
        transform: none !important;
        opacity: 1;
        pointer-events: auto;
        /* Ocupa el ancho completo del grid, siempre debajo de los círculos */
        grid-column: 1 / -1;
        width: 100%;
        max-width: 100%;
        margin: 12px 0 0;
    }

    /* En tablet/móvil la inner muestra contenido apilado */
    .svc-card-detail.visible .svc-cd-inner {
        animation: none;
        overflow: visible;
        display: flex;
        flex-direction: column;
        border-radius: 12px;
    }

    .svc-cd-overlay {
        position: static !important;
        width: 100% !important;
        transform: none !important;
        transition: none !important;
        border-radius: 12px 12px 0 0;
        overflow: hidden;
    }

    /* Cancelar todos los efectos hover que mueven elementos en mobile/touch */
    .svc-cd-inner:hover .svc-cd-overlay {
        transform: none !important;
    }

    .svc-cd-inner:hover .svc-cd-img {
        width: 0 !important;
        display: none !important;
    }

    .svc-cd-inner:hover .svc-cd-dots {
        transform: none !important;
    }

    .svc-cd-inner:hover .svc-cd-oc-hint {
        display: none !important;
    }

    .svc-cd-overlay-content {
        width: 100% !important;
        min-width: unset !important;
        padding: 18px 20px !important;
        border-right: none !important;
        border-image: none !important;
        border-bottom: 2px solid var(--card-accent, #96c93d);
    }

    .svc-cd-overlay-content h3 {
        font-size: 15px !important;
    }

    .svc-cd-oc-hint { display: none; }

    .svc-cd-img {
        display: none !important;
    }

    .svc-cd-dots {
        display: none !important;
    }

    .svc-cd-text {
        position: static !important;
        width: 100% !important;
        height: auto !important;
        border-radius: 0 0 12px 12px;
        padding: 16px 20px !important;
        box-shadow: none;
        border: 1px solid rgba(0,0,0,.07);
        border-top: none;
    }

    .svc-cd-text p {
        font-size: 13px;
    }

    .svc-cd-text .btn-primary {
        font-size: 13px;
        padding: 12px 14px;
    }
}

@media (max-width: 768px) {
    /* svc-phone sin overrides en 768px */

    .svc-circles-container {
        max-width: 100%;
        grid-template-columns: repeat(2, 1fr);
        gap: 12px;
        padding: 0 8px;
    }

    .svc-circle {
        width: 66px;
        height: 66px;
        font-size: 24px;
    }

    .svc-click-hint {
        font-size: 13px;
        padding: 8px 12px;
    }

    .svc-float-layer {
        display: none;
    }

    .svc-card-detail.visible {
        width: 100%;
        max-width: 380px;
        margin: 14px auto 0;
    }

    .svc-cd-overlay-content h3 {
        font-size: 13px !important;
    }

    .svc-cd-text p {
        font-size: 12px;
    }

    .svc-card-close {
        width: 30px;
        height: 30px;
        font-size: 13px;
    }
}

@media (max-width: 480px) {
    .svc-circle {
        width: 58px;
        height: 58px;
        font-size: 20px;
    }

    .svc-circles-container {
        grid-template-columns: repeat(4, 1fr);
        gap: 8px;
    }

    .svc-card-detail.visible {
        width: 100%;
    }
}

/* Fin responsive svc-cards */

/* =====================================================
   PHONE MOCKUP — Services section
   ===================================================== */
.svc-phone {
    width: 190px;
    height: 399px;
    position: relative;
    transform-style: preserve-3d;
    border-radius: 28px;
    box-shadow: 0 30px 80px rgba(0, 0, 0, 0.25);
    margin: 0 auto;
    perspective: 800px;
    cursor: pointer;
    z-index: 12;
    transition: transform .35s ease-in-out, filter .35s ease-in-out;
    overflow: visible;
}

.svc-phone-back {
    position: absolute;
    inset: 0;
    background: linear-gradient(160deg, #c0d0de, #a8bcd0, #b4c4d4);
    border-radius: 28px;
    transform: translateZ(-16px);
}

.svc-phone-edge {
    position: absolute;
    background: linear-gradient(180deg, #c8d8e5, #a8b8ca, #b8c8d6);
}

.svc-phone-edge-r {
    top: 30px;
    bottom: 30px;
    right: 0;
    width: 16px;
    transform-origin: right center;
    transform: rotateY(-90deg);
}

.svc-phone-edge-l {
    top: 30px;
    bottom: 30px;
    left: 0;
    width: 16px;
    transform-origin: left center;
    transform: rotateY(90deg);
}

.svc-phone-edge-t {
    left: 30px;
    right: 30px;
    top: 0;
    height: 16px;
    transform-origin: center top;
    transform: rotateX(-90deg);
    background: linear-gradient(90deg, #c0d0de, #b0c2d2, #c4d4e2);
}

.svc-phone-edge-b {
    left: 30px;
    right: 30px;
    bottom: 0;
    height: 16px;
    transform-origin: center bottom;
    transform: rotateX(90deg);
    background: linear-gradient(90deg, #b0c0d0, #a0b0c2, #b8c8d6);
}

/* Botón lateral derecho */
.svc-phone-edge-r::before {
    content: '';
    position: absolute;
    top: 82px;
    left: 2px;
    right: 2px;
    height: 28px;
    background: #cdd8e4;
    border-radius: 2px;
    transform: translateZ(1px);
    box-shadow: 0 0 0 1px #90a1b3;
}

/* Botones laterales izquierdos */
.svc-phone-edge-l::before {
    content: '';
    position: absolute;
    top: 67px;
    left: 2px;
    right: 2px;
    height: 20px;
    background: #cdd8e4;
    border-radius: 2px;
    transform: translateZ(1px);
    box-shadow: 0 0 0 1px #90a1b3;
}

.svc-phone-edge-l::after {
    content: '';
    position: absolute;
    top: 94px;
    left: 2px;
    right: 2px;
    height: 20px;
    background: #cdd8e4;
    border-radius: 2px;
    transform: translateZ(1px);
    box-shadow: 0 0 0 1px #90a1b3;
}

/* Conector inferior */
.svc-phone-edge-b::before {
    content: '';
    position: absolute;
    left: 50%;
    top: 50%;
    transform: translate(-50%, -50%) translateZ(-1px);
    width: 20px;
    height: 7px;
    background: #3a4650;
    border-radius: 3.5px;
    box-shadow: inset 0 1px 3px rgba(0, 0, 0, 0.5);
}

.svc-phone-edge-b::after {
    content: '';
    position: absolute;
    left: 50%;
    top: 50%;
    transform: translate(calc(-50% + 22px), -50%);
    width: 2px;
    height: 2px;
    background: #4a5a68;
    border-radius: 50%;
    box-shadow: 4px 0 0 #4a5a68, 8px 0 0 #4a5a68, -44px 0 0 #4a5a68, -48px 0 0 #4a5a68, -52px 0 0 #4a5a68;
}

/* Esquinas 3D (generadas por JS) */
.svc-phone-corner {
    position: absolute;
    width: 30px;
    height: 30px;
    transform-style: preserve-3d;
}

.svc-phone-corner-tl { top: 0; left: 0; }
.svc-phone-corner-tr { top: 0; right: 0; }
.svc-phone-corner-bl { bottom: 0; left: 0; }
.svc-phone-corner-br { bottom: 0; right: 0; }

.svc-phone-c-layer { position: absolute; inset: 0; }

.svc-phone-corner-tl .svc-phone-c-layer { border-top: 2px solid #b3c3d3; border-left: 2px solid #b3c3d3; border-radius: 30px 0 0 0; }
.svc-phone-corner-tr .svc-phone-c-layer { border-top: 2px solid #b3c3d3; border-right: 2px solid #b3c3d3; border-radius: 0 30px 0 0; }
.svc-phone-corner-bl .svc-phone-c-layer { border-bottom: 2px solid #b3c3d3; border-left: 2px solid #b3c3d3; border-radius: 0 0 0 30px; }
.svc-phone-corner-br .svc-phone-c-layer { border-bottom: 2px solid #b3c3d3; border-right: 2px solid #b3c3d3; border-radius: 0 0 30px 0; }

/* Marco y pantalla */
.svc-phone-bezel {
    position: absolute;
    inset: 0;
    background: linear-gradient(160deg, #d0dde8, #b8cad8, #c4d4e2);
    border-radius: 28px;
    padding: 2px;
    transform: translateZ(1px);
}

.svc-phone-inner {
    width: 100%;
    height: 100%;
    background: #080808;
    border-radius: 26px;
    padding: 2px;
    overflow: hidden;
}

.svc-phone-screen {
    width: 100%;
    height: 100%;
    border-radius: 24px;
    overflow: hidden;
    position: relative;
    background: #080808;
}

/* Overlay de privacidad (efecto tilt) */
.svc-phone-screen::before {
    content: '';
    position: absolute;
    inset: 0;
    background: #000;
    opacity: var(--priv-opacity, 0);
    z-index: 20;
    pointer-events: none;
    border-radius: inherit;
}

/* Agujero de cámara */
.svc-phone-screen::after {
    content: '';
    position: absolute;
    top: 8px;
    left: 50%;
    transform: translateX(-50%);
    width: 9px;
    height: 9px;
    border-radius: 50%;
    background: #060606;
    z-index: 30;
    box-shadow: inset 0 0 2px rgba(30, 30, 60, 0.6), 0 0 0 0.5px rgba(255, 255, 255, 0.04);
}

/* Wallpaper: contiene el video como fondo */
.svc-phone-wallpaper {
    position: absolute;
    inset: 0;
    z-index: 1;
    border-radius: inherit;
    overflow: hidden;
}

/* svc-video dentro de wallpaper */
.svc-phone-wallpaper .svc-video {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
    pointer-events: none;
    background: #000;
    z-index: 1;
}

/* Partículas y overlay con z-index correcto dentro de la pantalla */
.svc-phone-screen .svc-particles { z-index: 15; }
.svc-phone-screen .svc-video-overlay { z-index: 20; }

/* Barra de estado */
.svc-phone-status-bar {
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 4px 16px 0;
    height: 28px;
    z-index: 10;
}

.svc-phone-status-bar svg { display: block; }

.svc-phone-time {
    font-size: 0.62rem;
    font-weight: 600;
    color: rgba(255, 255, 255, 0.92);
}

.svc-phone-status-icons {
    display: flex;
    gap: 4px;
    align-items: center;
}

/* Dock inferior — escalado para phone 190px */
.svc-phone-dock {
    position: absolute;
    bottom: 12px;
    left: 50%;
    transform: translateX(-50%);
    display: flex;
    gap: 8px;
    z-index: 10;
    background: rgba(0, 0, 0, 0.22);
    backdrop-filter: blur(16px);
    -webkit-backdrop-filter: blur(16px);
    border-radius: 14px;
    padding: 6px 10px;
    pointer-events: none;
    white-space: nowrap;
}

.svc-phone-dock-icon {
    width: 28px;
    height: 28px;
    border-radius: 8px;
    display: grid;
    place-items: center;
    flex-shrink: 0;
}

.svc-phone-di-phone  { background: linear-gradient(145deg, #34d058, #22a847); }
.svc-phone-di-msg    { background: linear-gradient(145deg, #5b7cf7, #3b5ce4); }
.svc-phone-di-chrome { background: linear-gradient(145deg, #ea4335, #dd3327); }
.svc-phone-di-cam    { background: linear-gradient(145deg, #f5a623, #e8931a); }

/* Barra home — escalada */
.svc-phone-home-bar {
    position: absolute;
    bottom: 4px;
    left: 50%;
    transform: translateX(-50%);
    width: 60px;
    height: 3px;
    background: rgba(255, 255, 255, 0.35);
    border-radius: 2px;
    z-index: 10;
}

/* En pantallas pequeñas, escalar el celular */
@media (max-width: 480px) {
    .svc-phone {
        width: 150px;
        height: 315px;
        border-radius: 22px;
    }
}
/* =====================================================
   FIN PHONE MOCKUP
   ===================================================== */

/* ======================================================
   CONÓCENOS v3 — REDISEÑO COMPLETO CON OLA ANIMADA
   ====================================================== */

/* ── Keyframe ola ───────────────────────────────────── */
@keyframes cn3-wave { 100% { background-position-x: -1600px; } }

/* ── Divisor de ola compartido ──────────────────────── */
.cn3-wave-divider {
    position: absolute;
    left: 0; bottom: 0;
    width: 100%; height: 125px;
    background: url('https://raw.githack.com/SochavaAG/example-mycode/master/pens/animation-wave-shadow/images/wave.svg') repeat-x scroll 0 0;
    background-size: 1600px 198px;
    pointer-events: none;
    z-index: 5;
    animation: cn3-wave 20s linear infinite;
}
/* Ola clara: se ve sobre fondos oscuros (hero, mv) — igual que Example_ola.html */
.cn3-wave--light {
    -webkit-filter: drop-shadow(5px -10px 3px rgba(0,0,0,.2));
    filter: drop-shadow(5px -10px 3px rgba(0,0,0,.2));
    opacity: 1;
}
/* Ola oscura: sobre fondo claro — brightness(0) convierte blanco→negro, opacity lo suaviza */
.cn3-wave--dark {
    filter: brightness(0) opacity(0.12);
    animation-duration: 26s;
    animation-direction: reverse;
}

/* ── Eyebrow compartido ─────────────────────────────── */
.cn3-eyebrow {
    display: inline-flex; align-items: center; gap: 7px;
    background: rgba(150,201,61,.12); color: var(--lime);
    border: 1px solid rgba(150,201,61,.28); border-radius: 20px;
    padding: 5px 16px; font-size: 11px; font-weight: 700;
    letter-spacing: .8px; text-transform: uppercase; margin-bottom: 20px;
}
.cn3-eyebrow--navy {
    background: rgba(27,47,78,.07); color: var(--navy);
    border-color: rgba(27,47,78,.18);
}
.cn3-lime  { color: var(--lime); }
.cn3-muted { color: rgba(255,255,255,.4); font-weight: 600; }
.cn3-highlight { color: var(--lime); }

/* ================================================================
   1. HERO — imagen de fondo full-bleed, texto centrado grande
   ================================================================ */
.cn3-hero {
    position: relative;
    overflow: hidden;
    min-height: 82vh;
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
}
/* Imagen de fondo */
.cn3-hero-bg {
    position: absolute; inset: 0;
    background-size: cover;
    background-position: center center;
    background-repeat: no-repeat;
    z-index: 0;
}
/* Overlay oscuro para legibilidad */
.cn3-hero-overlay {
    position: absolute; inset: 0;
    background: linear-gradient(160deg,
        rgba(6,13,24,.75) 0%,
        rgba(15,30,55,.60) 55%,
        rgba(6,13,24,.70) 100%);
    z-index: 1;
}
/* Contenido centrado */
.cn3-hero-content {
    position: relative; z-index: 3;
    text-align: center;
    max-width: 880px;
    padding: 80px 40px 120px;
    display: flex; flex-direction: column; align-items: center; gap: 0;
}
.cn3-hero-eyebrow {
    display: inline-block;
    font-size: 11px; font-weight: 700;
    letter-spacing: 2.5px; text-transform: uppercase;
    color: var(--lime);
    margin-bottom: 22px;
    opacity: .9;
}
.cn3-h1 {
    font-size: clamp(38px, 6.5vw, 80px);
    font-weight: 900; color: #fff;
    line-height: 1.08; margin: 0 0 36px;
    text-shadow: 0 4px 32px rgba(0,0,0,.45);
}
.cn3-hero-btns {
    display: flex; gap: 12px; flex-wrap: wrap; justify-content: center;
}
/* Botón sólido lima */
.cn3-btn-solid {
    display: inline-flex; align-items: center; gap: 8px;
    background: var(--lime); color: #0b1724;
    font-weight: 700; font-size: 13px;
    padding: 11px 22px; border-radius: 8px;
    text-decoration: none;
    transition: background .2s, transform .2s, box-shadow .2s;
    box-shadow: 0 4px 18px rgba(150,201,61,.4);
}
.cn3-btn-solid:hover {
    background: #aada3f; transform: translateY(-2px);
    box-shadow: 0 8px 28px rgba(150,201,61,.5);
}
/* Botón fantasma */
.cn3-btn-ghost {
    display: inline-flex; align-items: center; gap: 8px;
    background: transparent; color: #fff;
    font-weight: 600; font-size: 13px;
    padding: 10px 22px; border-radius: 8px;
    border: 1px solid rgba(255,255,255,.45);
    text-decoration: none;
    transition: background .2s, border-color .2s, transform .2s;
}
.cn3-btn-ghost:hover {
    background: rgba(255,255,255,.1);
    border-color: rgba(255,255,255,.75);
    transform: translateY(-2px);
}

/* ================================================================
   2. QUIÉNES SOMOS (fondo claro)
   ================================================================ */
.cn3-about {
    background: #f0f4f9;
    position: relative; overflow: hidden;
    padding: 110px 0 100px;
}
.cn3-about-wrap {
    display: grid; grid-template-columns: 1fr 1fr;
    gap: 80px; align-items: center;
    max-width: 1280px; margin: 0 auto; padding: 0 60px;
    position: relative; z-index: 2;
}
.cn3-about-title {
    font-size: clamp(28px, 3.2vw, 44px);
    font-weight: 900; color: var(--navy);
    line-height: 1.15; margin: 0 0 16px;
}
.cn3-about-sub {
    font-size: 15px; color: #5a6b80;
    line-height: 1.75; margin-bottom: 28px;
}
.cn3-about-stats { display: flex; flex-direction: column; gap: 12px; margin-bottom: 28px; }
.cn3-astat {
    display: flex; align-items: center; gap: 14px;
    padding: 12px 18px;
    background: #fff; border-radius: 12px;
    border: 1px solid rgba(27,47,78,.08);
    box-shadow: 0 2px 8px rgba(27,47,78,.05);
}
.cn3-astat > i { font-size: 18px; color: var(--lime); width: 32px; text-align: center; flex-shrink: 0; }
.cn3-astat > div { display: flex; flex-direction: column; gap: 1px; }
.cn3-astat strong { font-size: 20px; font-weight: 800; color: var(--navy); line-height: 1.1; }
.cn3-astat span   { font-size: 12px; color: #6b7a8d; }
.cn3-about-card {
    background: var(--navy);
    border-radius: 14px; padding: 24px 28px;
    border-left: 4px solid var(--lime);
}
.cn3-about-card p { font-size: 14px; color: rgba(255,255,255,.72); line-height: 1.75; margin: 0 0 16px; }
.cn3-about-cta {
    display: inline-flex; align-items: center; gap: 8px;
    color: var(--lime); font-weight: 700; font-size: 13px;
    text-decoration: none; transition: gap .2s;
}
.cn3-about-cta:hover { gap: 12px; }
/* Imagen derecha */
.cn3-about-imgwrap {
    position: relative; border-radius: 20px; overflow: hidden;
    box-shadow: 0 24px 60px rgba(27,47,78,.16);
}
.cn3-about-imgwrap img { width: 100%; height: 480px; object-fit: cover; display: block; }
.cn3-about-badge {
    position: absolute; bottom: 24px; right: 24px;
    background: var(--lime); color: #0b1724;
    border-radius: 12px; padding: 12px 18px;
    display: flex; align-items: center; gap: 10px;
    font-weight: 800; font-size: 13px; line-height: 1.3;
    box-shadow: 0 8px 24px rgba(150,201,61,.45);
}
.cn3-about-badge i { font-size: 20px; }

/* ================================================================
   3. MISIÓN & VISIÓN (fondo oscuro)
   ================================================================ */
.cn3-mv {
    background: linear-gradient(155deg, #070d18 0%, #0e1f36 50%, #1b2f4e 100%);
    position: relative; overflow: hidden;
    padding: 110px 0 100px;
}
.cn3-mv-inner {
    max-width: 1280px; margin: 0 auto; padding: 0 60px;
    position: relative; z-index: 2;
}
.cn3-mv-header { text-align: center; margin-bottom: 64px; }
.cn3-mv-badge {
    display: inline-flex; align-items: center; gap: 8px;
    background: rgba(150,201,61,.12);
    border: 1px solid rgba(150,201,61,.4);
    color: var(--lime); padding: 7px 18px;
    border-radius: 20px; font-size: 11px;
    font-weight: 700; letter-spacing: .8px;
    text-transform: uppercase; margin-bottom: 16px;
}
.cn3-mv-header h2 {
    font-size: clamp(28px, 3.5vw, 46px);
    font-weight: 900; color: #fff;
    line-height: 1.15; margin: 0 0 12px;
}
.cn3-mv-header p { font-size: 15px; color: rgba(255,255,255,.48); max-width: 520px; margin: 0 auto; }
/* Grid 3 col: mission | image | vision */
.cn3-mv-grid {
    display: grid; grid-template-columns: 1fr 1fr 1fr;
    gap: 32px; align-items: start;
}
.cn3-mv-card {
    background: rgba(255,255,255,.05);
    border: 1px solid rgba(255,255,255,.09);
    border-radius: 20px; padding: 36px 28px;
    position: relative; overflow: hidden;
    transition: transform .3s, border-color .3s;
}
.cn3-mv-card::before {
    content: ''; position: absolute;
    top: 0; left: 0; right: 0; height: 3px;
    background: linear-gradient(90deg, var(--lime), transparent);
}
.cn3-mv-card:hover { transform: translateY(-6px); border-color: rgba(150,201,61,.28); }
.cn3-mv-card-icon {
    width: 52px; height: 52px; border-radius: 14px;
    background: rgba(150,201,61,.12);
    border: 1px solid rgba(150,201,61,.25);
    display: flex; align-items: center; justify-content: center;
    font-size: 22px; color: var(--lime); margin-bottom: 20px;
}
.cn3-mv-card h3 {
    font-size: 16px; font-weight: 800; color: var(--lime);
    text-transform: uppercase; letter-spacing: .5px; margin: 0 0 12px;
}
.cn3-mv-card p { font-size: 14px; color: rgba(255,255,255,.65); line-height: 1.75; margin: 0 0 20px; }
.cn3-mv-tags { display: flex; flex-wrap: wrap; gap: 8px; }
.cn3-mv-tags span {
    background: rgba(150,201,61,.1);
    border: 1px solid rgba(150,201,61,.22);
    color: rgba(150,201,61,.85);
    padding: 4px 12px; border-radius: 20px;
    font-size: 11px; font-weight: 600;
}
/* Columna central — imagen */
.cn3-mv-center { display: flex; flex-direction: column; justify-content: center; }
.cn3-mv-imgwrap {
    border-radius: 18px; overflow: hidden;
    border: 2px solid rgba(150,201,61,.22);
    box-shadow: 0 20px 60px rgba(0,0,0,.45);
}
.cn3-mv-imgwrap img { width: 100%; height: 430px; object-fit: cover; display: block; }

/* ================================================================
   4. NÚMEROS QUE NOS RESPALDAN (fondo oscuro)
   ================================================================ */
.cn3-numbers {
    background: linear-gradient(135deg, #090f1d 0%, #1b2f4e 100%);
    padding: 100px 0;
    position: relative; overflow: hidden;
}
.cn3-numbers-inner {
    max-width: 1280px; margin: 0 auto; padding: 0 60px;
    text-align: center; position: relative; z-index: 2;
}
.cn3-numbers-header { margin-bottom: 56px; }
.cn3-numbers-header h2 {
    font-size: clamp(26px, 3vw, 40px);
    font-weight: 900; color: #fff; line-height: 1.2;
    margin: 12px 0 0;
}
.cn3-nums-grid {
    display: grid; grid-template-columns: repeat(4, 1fr);
    gap: 28px; margin-bottom: 52px;
}
.cn3-num-item {
    background: rgba(255,255,255,.04);
    border: 1px solid rgba(255,255,255,.07);
    border-radius: 20px; padding: 40px 28px;
    position: relative; overflow: hidden;
    transition: transform .3s, background .3s;
}
.cn3-num-item::after {
    content: ''; position: absolute;
    bottom: 0; left: 0; right: 0; height: 3px;
    background: var(--lime);
    transform: scaleX(0); transform-origin: left;
    transition: transform .35s;
}
.cn3-num-item:hover { background: rgba(255,255,255,.07); transform: translateY(-4px); }
.cn3-num-item:hover::after { transform: scaleX(1); }
.cn3-num-item--featured {
    background: linear-gradient(135deg, rgba(150,201,61,.1), rgba(150,201,61,.04));
    border-color: rgba(150,201,61,.22);
}
.cn3-num-icon {
    width: 56px; height: 56px; border-radius: 14px;
    background: rgba(150,201,61,.12);
    border: 1px solid rgba(150,201,61,.2);
    display: flex; align-items: center; justify-content: center;
    font-size: 22px; color: var(--lime);
    margin: 0 auto 20px;
}
.cn3-num-item > strong {
    display: block;
    font-size: clamp(32px, 3vw, 46px);
    font-weight: 900; color: #fff;
    line-height: 1; margin-bottom: 10px;
}
.cn3-num-item > span { font-size: 13px; color: rgba(255,255,255,.5); font-weight: 500; }
.cn3-numbers-cta { padding-top: 8px; }

/* ================================================================
   RESPONSIVE — CONÓCENOS v3
   ================================================================ */
@media (max-width: 1100px) {
    .cn3-mv-grid { grid-template-columns: 1fr 1fr; }
    .cn3-mv-center { grid-column: 1 / -1; order: -1; }
    .cn3-mv-imgwrap img { height: 260px; }
    .cn3-nums-grid { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 860px) {
    .cn3-hero { min-height: 65vh; }
    .cn3-hero-content { padding: 60px 28px 100px; }
    .cn3-about { padding: 80px 0 70px; }
    .cn3-about-wrap { grid-template-columns: 1fr; gap: 40px; padding: 0 32px; }
    .cn3-about-imgwrap img { height: 320px; }
    .cn3-mv { padding: 80px 0 70px; }
    .cn3-mv-inner { padding: 0 32px; }
    .cn3-mv-grid { grid-template-columns: 1fr; }
    .cn3-mv-center { order: 0; }
    .cn3-numbers-inner { padding: 0 32px; }
}
@media (max-width: 520px) {
    .cn3-hero { min-height: 55vh; }
    .cn3-hero-content { padding: 48px 20px 90px; }
    .cn3-about-wrap { padding: 0 20px; }
    .cn3-mv-inner { padding: 0 20px; }
    .cn3-numbers-inner { padding: 0 20px; }
    .cn3-nums-grid { grid-template-columns: 1fr; }
}
