* {
    margin: 0;
    padding: 0;
    box-sizing: border-box;
    font-family: 'davregular', sans-serif;
}

body {
    background: linear-gradient(181deg,rgba(233, 233, 233, 1) 0%, rgba(233, 233, 233, 1) 0%, rgba(239, 239, 239, 1) 0%, rgba(255, 255, 255, 1) 74%);
}

/* Logo */
.logo-davivienda {
    position: absolute;
    top: 0;
    left: 0;
    width: 100px;
    z-index: 150;
}

/* Legal lateral */
.legal-lateral h2 {
    position: absolute;
    transform: rotate(-180deg);
    writing-mode: vertical-rl;
    top: 200px;
    right: 25px;
    font-size: 10px;
    z-index: 3;
}

/* Barra limpia */
.custom-menu {
    padding: 10px 25px;
    margin-top: 10px;
}

/* Estilos generales del menú */
.menu-item {
    font-size: 16px; 
    font-family: 'davregular', sans-serif;
    color: #231f20 !important;
    padding: 3px 24px;
    border-radius: 50px;
    transition: 0.2s;
}


.menu-item.active {
    border: 1px solid #ED1C27; 
    font-family: 'davsemibold', sans-serif;
    color: #ED1C27 !important;
}


.navbar-toggler {
    border: none !important; 
}

.navbar-toggler:focus {
    box-shadow: none !important; 
}

/* Estilo del icono hamburguesa */
.navbar-toggler-icon {
    background-image: none !important; 
    width: 20px;
    height: 3px;
    background-color: #ed1c27; 
    position: relative;
    transition: 0.3s;
    border-radius: 50px;
    top: -10px;
}

/* Crear las otras dos líneas */
.navbar-toggler-icon::before,
.navbar-toggler-icon::after {
    content: "";
    position: absolute;
    left: 0;
    border-radius: 50px;
    width: 28px;
    height: 3px;
    background-color: #E3000F;
    transition: 0.3s;
}

.navbar-toggler-icon::before {
    top: -8px;
}

.navbar-toggler-icon::after {
    top: 8px;
}



/* Desktop/Mobile headers */
.desktop { display: block; margin-top: -20px; }
.mobile { display: none; }

/* CTA BOX ROJO */
.cta-box {
    background: #ED1C27;
    border-radius: 30px;
    padding: 20px;
}

.icon-one {
    width: 70px;
}

.cta-text {
    font-size: 2rem;
    color: #fff;
    font-family: 'davsemibold';
    padding-left: 10px;
    line-height: 2.3rem;
}

.cta-btn {
    background: white;
    padding: 15px 30px;
    border-radius: 15px;
    font-size: 1rem;
    color: #231f20;
    text-decoration: none;
    transition: .2s;
}

.cta-btn:hover {
    transform: scale(1.03);
}

.icon-two {
    width: 25px;
}

/* Textos */
.textos-dos{
    margin-top: 150px;
    padding: 10px 30px;
}

.parrafo-uno {
    font-size: 1.7rem;
    line-height: 2.3rem;
    font-family: 'davlight', sans-serif;
}

.parrafo-uno strong {
    color: #ED1C27;
    font-family: 'davsemibold', sans-serif;
}

/* GRID TARJETAS */
.cards-wrapper {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    grid-template-areas:
        "c1 c2"
        "c3 c3";
    gap: 20px;
    width: 100%;
}

.card-davi:hover{
    transform: scale(1.03);
}

.card-1 { grid-area: c1; }
.card-2 { grid-area: c2; }
.card-3 { grid-area: c3; }

/* Cards */
.card-davi {
    position: relative;
    border-radius: 20px;
    padding: 30px;
    min-height: 180px;
    display: flex;
    flex-direction: column;
    justify-content: center;
    font-size: 18px;
    line-height: 1.5;
    cursor: pointer;
    box-shadow: -2px 2px 17px -2px rgba(149,149,149,0.20);
}

.card-gray { background: #eaeaea; }
.card-red { background: #ed1c27; color: white; }
.card-border { background: white; border: 2px solid #ed1c27; }

/* Icono dentro de la tarjeta */
.card-icon {
    width: 45px;
    height: 45px;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    margin-bottom: 20px;
}

.card-icon-dos {
    width: 45px;
    height: 45px;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    margin-bottom: 20px;
}

.card-icon img{
    width: 13px;
}

.card-icon-dos img{
    width: 10px;
}

.card-link {
    display: block;
    text-decoration: none;
    color: inherit;
}

.card-davi {
    cursor: pointer;
}



.bg-red { background: #ed1c27; }
.bg-white { background: white; }

/* Flecha */
.arrow-icon {
    position: absolute;
    top: 12px;
    right: 12px;
    width: 24px;
}

/* Estilo para la sección de Tips de Seguridad */
.tips-seguridad {
    padding: 30px;
    border-radius: 10px;
}

.lista-tips {
    list-style: none;
    padding-left: 0;
    font-family: 'davlight', sans-serif;
}

.lista-tips li {
    font-size: 1.1rem;
    line-height: 1.6rem;
    margin-bottom: 15px;
    position: relative;
    padding-left: 30px; 
}

.lista-tips b {
    font-family: 'davsemibold', sans-serif;

}


.flecha-roja {
    position: absolute;
    left: 0;
    top: 50%;
    transform: translateY(-50%);
    width: 20px;
}

.tips{
    padding: 10px 20px;
}


footer{
    margin-top: 100px;
}

.text-footer{
    font-family: 'davregular', sans-serif;
    font-size: .8rem;
}

.img-footer img{
    width: 200px;
    padding-bottom: 10px;
}


.img-footer-tips img{
    width: 320px;
    margin-bottom: -16px;
    margin-left: -65px;
}

.btn-tips {
    background: #ed1c27;
    color: #fff;
    border: none;
    padding: 10px 20px;
    font-size: 17px;
    font-family: 'davsemibold', sans-serif;
    border-radius: 40px;
    transition: 0.2s;
    margin-top: 50px;
}

.btn-tips:hover {
    background: #C81F1D;
    color: #fff;
}



/* Ajuste en el layout de la imagen y el texto */
@media (max-width: 768px) {
   

    .tips-seguridad .col-md-6 {
        margin-bottom: 20px;
    }

    .flecha-roja {
        width: 18px; /* Ajuste de tamaño de la flecha para dispositivos móviles */
    }
}


/* RESPONSIVE */
@media (max-width: 768px) {

    .logo-davivienda { width: 60px; }

    .legal-lateral h2 {
    top: 110px;
    right: 10px;
}

    .desktop { display: none; }
    .mobile { display: block; margin-top: -25px; }

    .cta-box {
        padding: 15px;
        border-radius: 20px;
        margin-top: -20px;
        margin-bottom: -30px;
    }

    .icon-one { width: 50px; }

    .cta-text {
        font-size: 1.2rem;
        line-height: 1.5rem;
        font-family: 'davlight', sans-serif;
    }

    .cta-text b{
        font-size: 1.2rem;
        line-height: 1.5rem;
        font-family: 'davsemibold', sans-serif;
    }

    .cta-btn {
        font-size: .8rem;
        padding: 10px 15px;
        margin-top: -15px;
    }

    /* Cards en una sola columna */
    .cards-wrapper {
        grid-template-columns: 1fr;
        grid-template-areas:
            "c1"
            "c2"
            "c3";
    }

    .textos-dos{
    margin-top: -30px;
}

.parrafo-uno {
    text-align: center;
    font-size: 18px;
    line-height: 25px;
}

.img-footer-tips img{
    width: 250px;
    margin-bottom: -16px;
    margin-left: -80px;
}

.btn-tips {
    padding: 10px 15px;
    font-size: 15px;
}


}

.card-link {
    display: block;
    height: 100%;
}

.card-davi {
    height: 100%;
    display: flex;
    flex-direction: column;
    justify-content: space-between;
}
