body{
    background: #fff;
    font-family: 'Open Sans', sans-serif;
    font-weight: 300;
    font-size: 18px;
    position: relative;
    width: 100%;
    height: 100%;
    overflow-x: hidden;
}

section#home>.overlay>.container>.row{
    margin-top: 60px!important;
    margin-bottom: 60px!important;
}

.btn-primary{
    background-color: var(--theme-color);
    border-color: var(--theme-color);
}

.front-theme{
    height: 333px;
    margin: auto;
    padding: 2px;
    border-color: var(--theme-color);
    border-width: 1px;
    border-style: solid;
    border-radius: 3px;
}

.front-theme-btn{
    margin-top: 4px;
    margin-bottom: 4px;
}

.front-feature-icon{
    color: var(--theme-color);
    font-size: 60px;
}

img{
    max-width: 100%;
    height: auto;
}

/* =======================================
   GRID DE THEMES
   ======================================= */
.theme-grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 20px;
}

/* Tablet */
@media (min-width: 768px) {
    .theme-grid {
        grid-template-columns: repeat(3, 1fr);
    }
}

/* PC */
@media (min-width: 1200px) {
    .theme-grid {
        grid-template-columns: repeat(4, 1fr);
    }
}

/* =======================================
   TARhTAS
   ======================================= */
.theme-box {
    position: relative;
    overflow: hidden;
    border-radius: 12px;
}

/* Imagen base */
.theme-box img {
    width: 100%;
    height: auto;
    display: block;
    object-fit: cover;
}

/* =======================================
   🔥 CUADRADOS PERFECTOS EN MÓVIL
   ======================================= */
@media (max-width: 768px) {

    .theme-box {
        height: 0;
        padding-bottom: 100%; /* 🔥 cuadrado */
    }

    .theme-box img {
        position: absolute;
        top: 0;
        left: 0;
        width: 100%;
        height: 100%;
        object-fit: cover;
    }

    .theme-box .btn {
        position: absolute;
        bottom: 10px;
        left: 10px;
        right: 10px;
        z-index: 2;
    }
}

/* =======================================
   BOTONES
   ======================================= */
.theme-box .btn {
    width: 100%;
    margin-top: 10px;
}

/* =======================================
   NAVBAR Y GENERAL
   ======================================= */
.navbar-logo{
    height: 43px;
}

.overlay {
    width: 100%;
    height: 100%;
    background-image: 
        linear-gradient(rgba(4,123,233,0.6), rgba(4,123,233,0.6)),
        url('https://taiply.com/assets/front/one/img/home-bg.jpg');
    background-size: cover;
    background-position: center;
}

/* =======================================
   RESPONSIVE GENERAL
   ======================================= */
@media screen and ( max-width: 767px ) {
    .navbar-default .nav li a {
        height: auto;
        line-height: 2em;
    }
}

/* =======================================
   CONTACTO
   ======================================= */
#contact .overlay {
    background-image: url('https://taiply.com/assets/front/one/img/taiply-fondo.jpg');
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
}

/* =======================================
   IDIOMA
   ======================================= */
#language-options a {
    display: block;
    padding: 8px 12px;
    color: #333;
    transition: all 0.3s ease;
}

#language-options a:hover {
    background-color: #4f7fdd;
    color: #fff;
}

.language-options a.active {
    background: #3498db;
    color: white !important;
}
section#home{
    margin-top: 73px;
}
#home .col-md-10 h1,
#home .col-md-10 p {
    color: #fff;
}
