/* =========================
   CONTACTO
========================= */

.contact-hero{
    padding:140px 0 100px;
    background:var(--cream);
}

.contact-eyebrow{
    display:inline-flex;
    align-items:center;
    justify-content:center;

    background:var(--deep-green);
    color:var(--cream);

    padding:8px 16px;
    border-radius:999px;

    font-size:13px;
    font-weight:900;

    margin-bottom:18px;
}

/* Grid */

.contact-grid{
    display:grid;
    grid-template-columns:repeat(3, 1fr);
    gap:28px;
}

/* Card */

.contact-card{
    position:relative;

    min-height:420px;

    background:linear-gradient(
        135deg,
        #ffffff 0%,
        var(--beige) 65%,
        #ffffff 100%
    );

    border:1px solid var(--border);
    border-radius:34px;

    padding:38px 30px;

    box-shadow:var(--shadow);

    display:flex;
    flex-direction:column;
    align-items:center;
    text-align:center;

    overflow:hidden;
    transition:.3s;
}

.contact-card:hover{
    transform:translateY(-8px);
}

.contact-card::before{
    content:"";
    position:absolute;
    top:0;
    left:0;

    width:100%;
    height:8px;

    background:var(--sage);
}

.contact-card::after{
    content:"";
    position:absolute;
    right:-90px;
    top:-90px;

    width:220px;
    height:220px;

    background:radial-gradient(
        circle,
        rgba(143,175,159,.28),
        rgba(143,175,159,0) 70%
    );

    border-radius:50%;
}

.contact-icon{
    position:relative;
    z-index:2;

    width:76px;
    height:76px;

    border-radius:50%;

    background:var(--deep-green);
    color:var(--cream);

    display:flex;
    align-items:center;
    justify-content:center;

    font-size:34px;

    margin-bottom:24px;

    box-shadow:0 16px 34px rgba(47,93,80,.22);
}

.contact-card h3{
    position:relative;
    z-index:2;

    color:var(--deep-green);

    font-size:32px;
    font-weight:900;
    letter-spacing:-1px;

    margin-bottom:14px;
}

.contact-card p{
    position:relative;
    z-index:2;

    color:var(--muted);

    font-size:17px;
    line-height:1.65;

    margin-bottom:28px;
}

.contact-card .btn-primary{
    position:relative;
    z-index:2;

    margin-top:auto;
    width:100%;
}

/* Formulario */

.contact-form-card{
    align-items:stretch;
}

.contact-form-card .contact-icon,
.contact-form-card h3,
.contact-form-card p{
    align-self:center;
}

.contact-form-card form{
    position:relative;
    z-index:2;

    display:flex;
    flex-direction:column;
    gap:12px;

    margin-top:auto;
}

.contact-form-card input,
.contact-form-card textarea{
    width:100%;

    border:1px solid var(--border);
    border-radius:18px;

    background:rgba(255,255,255,.86);

    padding:15px 16px;

    font-family:inherit;
    font-size:15px;

    color:var(--deep-green);

    outline:none;
}

.contact-form-card textarea{
    resize:none;
}

.contact-form-card input::placeholder,
.contact-form-card textarea::placeholder{
    color:rgba(47,93,80,.55);
}

.contact-form-card input:focus,
.contact-form-card textarea:focus{
    border-color:var(--sage);
    box-shadow:0 0 0 4px rgba(143,175,159,.18);
}

.contact-form-card button{
    width:100%;
    cursor:pointer;
}


/* =========================
   TABLET
========================= */

@media(max-width:900px){

    .contact-hero{
        padding:120px 0 72px;
    }

    .contact-grid{
        grid-template-columns:1fr;
    }

    .contact-card{
        min-height:auto;
        max-width:620px;
        width:100%;

        margin:0 auto;
    }

}


/* =========================
   MOBILE
========================= */

@media(max-width:520px){

    .contact-hero{
        padding:105px 0 58px;
    }

    .contact-card{
        padding:34px 22px;
        border-radius:28px;
    }

    .contact-icon{
        width:68px;
        height:68px;
        font-size:30px;
    }

    .contact-card h3{
        font-size:28px;
    }

    .contact-card p{
        font-size:16px;
    }

    .contact-form-card input,
    .contact-form-card textarea{
        border-radius:16px;
    }

}


/* =========================
   ICONOS REALES CONTACTO
========================= */

.contact-icon{
    background:#ffffff;
    border:1px solid rgba(47,93,80,.14);
    box-shadow:0 16px 34px rgba(31,42,38,.12);
}

/* WhatsApp real */

.contact-icon-whatsapp{
    background:#25D366;
    color:#ffffff;
}

/* Instagram real */

.contact-icon-instagram{
    background:linear-gradient(
        135deg,
        #833AB4,
        #FD1D1D,
        #F77737,
        #FCAF45
    );
    color:#ffffff;
}

/* Gmail / Google */

.contact-icon-gmail{
    background:linear-gradient(
        135deg,
        #5F7CF7,
        #7C97FF
    );

    color:#ffffff;

    border:none;

    box-shadow:0 16px 34px rgba(95,124,247,.18);
}

.contact-icon-gmail i{
    color:#ffffff;
    font-size:28px;
}