    @import url('https://fonts.googleapis.com/css2?family=Sora:wght@300;400;600;700;800&family=DM+Sans:opsz,wght@9..40,300;9..40,400;9..40,500&display=swap');

    :root {
        --c-deep: #002D4F;
        --c-ocean: #0077B6;
        --c-light: #00B4D8;
        --c-pale: #CAF0F8;
        --c-foam: #EAF6FF;
        --c-sand: #F9C74F;
        --c-sand-d: #E8A817;
        --c-green: #2EC4B6;
        --c-dark: #0D1B2A;
        --c-mid: #3A5A72;
        --c-muted: #6E8FA5;
        --ease: cubic-bezier(.22, 1, .36, 1);
        --fh: 'Sora', sans-serif;
        --fb: 'DM Sans', sans-serif;
    }

    body {
        font-family: var(--fb);
        background: #F0F7FC;
        margin: 0;
    }

    /* ========== HERO CONTACTO ========== */
    .contact-hero {
        position: relative;
        min-height: 50vh;
        display: flex;
        flex-direction: column;
        overflow: hidden;
        background: linear-gradient(135deg, rgba(0, 28, 52, .92) 0%, rgba(0, 100, 160, .74) 55%, rgba(0, 165, 200, .52) 100%);
    }

    .contact-hero-bg {
        position: absolute;
        inset: -10% 0;
        background: url('https://images.unsplash.com/photo-1507679799987-c73779587ccf?auto=format&fit=crop&w=1920&q=80') center/cover no-repeat;
        will-change: transform;
        opacity: .3;
        mix-blend-mode: overlay;
    }

    .contact-grain {
        position: absolute;
        inset: 0;
        opacity: .04;
        pointer-events: none;
        background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
        background-size: 180px;
        z-index: 1;
    }

    .contact-hero-content {
        position: relative;
        z-index: 10;
        flex: 1;
        display: flex;
        align-items: center;
        justify-content: center;
        padding: 100px 0 95px;
    }

    .contact-hero-inner {
        max-width: 800px;
    }

    [data-anim] {
        opacity: 0;
        transform: translateY(24px);
    }

    [data-anim].anim-in {
        animation: contactIn .7s var(--ease) forwards;
    }

    @keyframes contactIn {
        to {
            opacity: 1;
            transform: translateY(0);
        }
    }

    .contact-eyebrow {
        display: inline-flex;
        align-items: center;
        gap: 8px;
        background: rgba(255, 255, 255, .13);
        backdrop-filter: blur(10px);
        border: 1px solid rgba(255, 255, 255, .28);
        color: #fff;
        font-family: var(--fh);
        font-size: .72rem;
        font-weight: 700;
        letter-spacing: .10em;
        text-transform: uppercase;
        padding: 7px 16px;
        border-radius: 999px;
        margin-bottom: 20px;
    }

    .contact-pulse {
        width: 8px;
        height: 8px;
        border-radius: 50%;
        background: var(--c-sand);
        animation: pulseDot 2.2s ease-in-out infinite;
    }

    @keyframes pulseDot {

        0%,
        100% {
            box-shadow: 0 0 0 0 rgba(249, 199, 79, .7);
        }

        50% {
            box-shadow: 0 0 0 7px rgba(249, 199, 79, 0);
        }
    }

    .contact-title {
        font-family: var(--fh);
        font-size: clamp(2rem, 4.2vw, 3.1rem);
        font-weight: 800;
        color: #fff;
        line-height: 1.1;
        letter-spacing: -.025em;
        margin-bottom: 14px;
    }

    .contact-title-bar {
        display: block;
        width: 64px;
        height: 4px;
        background: linear-gradient(90deg, var(--c-sand), var(--c-light));
        border-radius: 99px;
        margin: 12px auto 0;
    }

    .contact-subtitle {
        font-size: clamp(.93rem, 1.4vw, 1.05rem);
        font-weight: 300;
        color: rgba(255, 255, 255, .80);
        max-width: 520px;
        margin: 0 auto;
        line-height: 1.75;
    }

    /* Olas */
    .contact-waves {
        position: absolute;
        bottom: 0;
        left: 0;
        width: 200%;
        height: 90px;
        z-index: 5;
        pointer-events: none;
    }

    .contact-wave {
        position: absolute;
        bottom: 0;
        width: 100%;
        height: 90px;
        transform: translateY(90px);
    }

    .contact-wave.wave-enter {
        animation: waveRise var(--rd, .9s) var(--ease) forwards, waveScroll var(--sd, 14s) linear var(--rd, .9s) infinite;
    }

    .contact-wave-back {
        --rd: .85s;
        --sd: 20s;
    }

    .contact-wave-front {
        --rd: 1.1s;
        --sd: 12s;
    }

    @keyframes waveRise {
        from {
            transform: translateY(90px);
        }

        to {
            transform: translateY(0);
        }
    }

    @keyframes waveScroll {
        from {
            transform: translateX(0);
        }

        to {
            transform: translateX(-50%);
        }
    }

    /* ========== TARJETAS PRINCIPALES ========== */
    .contact-main {
        padding: 80px 0 100px;
        background: #F0F7FC;
    }

    [data-reveal] {
        opacity: 0;
        transform: translateY(32px);
        transition: opacity .65s var(--ease), transform .65s var(--ease);
    }

    [data-reveal].revealed {
        opacity: 1;
        transform: translateY(0);
    }

    .contact-card {
        background: #fff;
        border-radius: 24px;
        overflow: hidden;
        box-shadow: 0 8px 32px rgba(0, 45, 79, .08);
        border: 1px solid rgba(0, 119, 182, .08);
        height: 100%;
        transition: transform .35s var(--ease), box-shadow .35s var(--ease);
    }

    .contact-card:hover {
        transform: translateY(-6px);
        box-shadow: 0 20px 48px rgba(0, 45, 79, .14);
    }

    .contact-card-icon {
        background: linear-gradient(135deg, var(--c-ocean), var(--c-light));
        width: 70px;
        height: 70px;
        border-radius: 50%;
        display: flex;
        align-items: center;
        justify-content: center;
        margin: 32px auto 20px;
        font-size: 2rem;
        color: #fff;
        box-shadow: 0 10px 20px rgba(0, 119, 182, .25);
    }

    .contact-card-title {
        font-family: var(--fh);
        font-size: 1.4rem;
        font-weight: 700;
        color: var(--c-dark);
        text-align: center;
        margin-bottom: 24px;
    }

    .contact-card-body {
        padding: 0 28px 32px;
    }

    .contact-text {
        color: var(--c-mid);
        line-height: 1.65;
        margin-bottom: 1rem;
    }

    .contact-list {
        list-style: none;
        padding: 0;
        margin: 20px 0;
    }

    .contact-list li {
        display: flex;
        align-items: center;
        gap: 8px;
        margin-bottom: 12px;
        font-size: .95rem;
        color: var(--c-mid);
    }

    .contact-list i {
        color: var(--c-green);
        font-size: .85rem;
    }

    .contact-quote {
        font-family: var(--fh);
        font-style: italic;
        font-size: .95rem;
        color: var(--c-ocean);
        text-align: center;
        margin-top: 20px;
        padding-top: 12px;
        border-top: 1px dashed rgba(0, 119, 182, .2);
    }

    /* Items de contacto */
    .contact-info-item {
        display: flex;
        gap: 16px;
        margin-bottom: 24px;
    }

    .contact-info-icon {
        width: 40px;
        height: 40px;
        background: rgba(0, 119, 182, .08);
        border-radius: 12px;
        display: flex;
        align-items: center;
        justify-content: center;
        font-size: 1.2rem;
        color: var(--c-ocean);
        flex-shrink: 0;
    }

    .contact-info-content {
        font-size: .93rem;
        color: var(--c-mid);
        line-height: 1.5;
    }

    .contact-info-content strong {
        color: var(--c-dark);
        font-weight: 700;
    }

    .contact-link {
        color: var(--c-ocean);
        text-decoration: none;
        font-weight: 600;
        transition: color .2s;
    }

    .contact-link:hover {
        color: var(--c-deep);
    }

    /* Botones */
    .contact-buttons {
        margin: 28px 0 20px;
    }

    .contact-btn-wa {
        display: inline-flex;
        align-items: center;
        justify-content: center;
        width: 100%;
        background: #25D366;
        color: #fff;
        font-family: var(--fh);
        font-weight: 700;
        font-size: .95rem;
        padding: 14px 24px;
        border-radius: 999px;
        text-decoration: none;
        transition: all .25s var(--ease);
        box-shadow: 0 6px 22px rgba(37, 211, 102, .32);
    }

    .contact-btn-wa:hover {
        transform: translateY(-3px);
        box-shadow: 0 12px 28px rgba(37, 211, 102, .44);
        color: #fff;
        filter: brightness(1.02);
    }

    .contact-divider {
        margin: 28px 0 20px;
        border-color: rgba(0, 119, 182, .1);
    }

    .contact-social-title {
        font-family: var(--fh);
        font-size: .85rem;
        font-weight: 700;
        color: var(--c-muted);
        text-transform: uppercase;
        letter-spacing: .08em;
        margin-bottom: 12px;
    }

    .contact-social-link {
        display: inline-flex;
        align-items: center;
        background: linear-gradient(135deg, #833AB4, #E1306C, #FD1D1D);
        -webkit-background-clip: text;
        background-clip: text;
        color: transparent;
        font-family: var(--fh);
        font-weight: 700;
        font-size: 1rem;
        text-decoration: none;
        transition: opacity .2s;
    }

    .contact-social-link i {
        color: #E1306C;
        background: none;
        -webkit-background-clip: unset;
        background-clip: unset;
    }

    .contact-social-link:hover {
        opacity: .8;
    }

    /* Tarjeta mapa */
    .contact-map-card {
        background: #fff;
        border-radius: 24px;
        overflow: hidden;
        box-shadow: 0 8px 32px rgba(0, 45, 79, .08);
        border: 1px solid rgba(0, 119, 182, .08);
        transition: transform .35s var(--ease), box-shadow .35s var(--ease);
    }

    .contact-map-card:hover {
        transform: translateY(-4px);
        box-shadow: 0 20px 48px rgba(0, 45, 79, .12);
    }

    .contact-map-header {
        display: flex;
        align-items: center;
        gap: 10px;
        padding: 18px 24px;
        background: linear-gradient(135deg, var(--c-ocean), var(--c-light));
        color: #fff;
        font-family: var(--fh);
        font-weight: 700;
        font-size: .95rem;
    }

    .contact-map-header i {
        font-size: 1.1rem;
    }

    .contact-map-body {
        line-height: 0;
    }

    /* Responsive */
    @media (max-width: 991px) {
        .contact-hero-content {
            padding: 80px 0 70px;
        }

        .contact-card-icon {
            width: 60px;
            height: 60px;
            font-size: 1.6rem;
        }

        .contact-card-title {
            font-size: 1.25rem;
        }

        .contact-card-body {
            padding: 0 20px 28px;
        }
    }

    @media (max-width: 768px) {
        .contact-main {
            padding: 56px 0 70px;
        }

        .contact-title {
            font-size: 1.9rem;
        }

        .contact-info-item {
            gap: 12px;
        }

        .contact-info-icon {
            width: 36px;
            height: 36px;
            font-size: 1rem;
        }
    }

    @media (max-width: 480px) {
        .contact-btn-wa {
            font-size: .85rem;
            padding: 12px 20px;
        }

        .contact-list li {
            font-size: .85rem;
        }
    }
