:root {
    --naranja: #fa5e00;
    --azul: #002a7a;
    --azul-dark: #00297a;
    --gris: #404040;
    --bg-dark: #1c1c1c;
    --white: #ffffff;
}

* { margin: 0; padding: 0; box-sizing: border-box; }
body { font-family: 'Lato', sans-serif; color: var(--gris); overflow-x: hidden; }
.container { max-width: 1140px; margin: 0 auto; padding: 0 20px; }
.white-light {
    color: #ffffff !important;
    font-size: 1.5rem;          /* Aumenta el tamaño (puedes usar px también, ej: 20px) */
    font-weight: 1000;           /* Aumenta el grosor (400 es normal, 500-600 es semi-bold) */
    letter-spacing: 0.5px;
    text-decoration: none;
    opacity: 0.9;
    display: inline-block;      /* Necesario para que el margin-bottom funcione correctamente */
    margin-bottom: 15px;        /* Espacio de separación hacia abajo */
}

.white-light:hover {
    color: #ffffff;
    opacity: 1;
}

/* HEADER */
#main-header {
    position: fixed; width: 100%; top: 0; z-index: 9999;
    background: rgba(255,255,255,0.9); padding: 15px 0; transition: 0.3s;
}
.header-flex { display: flex; justify-content: space-between; align-items: center; }
.logo img { height: 50px; }

#nav-menu ul { display: flex; list-style: none; }
#nav-menu ul li a { 
    text-decoration: none; color: #000; font-weight: bold; 
    text-transform: uppercase; font-size: 12px; padding: 10px 15px;
}
#nav-menu ul li a:hover { color: var(--naranja); }
.blog-btn { color: var(--azul) !important; }

.menu-toggle { display: none; } /* Oculto en PC */

/* SECCIONES */
.full-page {
    height: 100vh; width: 100%; background-size: cover; background-position: center;
    background-attachment: fixed; display: flex; align-items: center;
}
.blue-text { color: var(--azul); }
.section-title { font-size: 40px; font-weight: bold; margin-bottom: 20px; }
.section-title.blue { color: var(--azul); }
.section-title.orange { color: var(--naranja); }

/* CLIENTES GRID */
.clients-grid { display: grid; grid-template-columns: repeat(5, 1fr); margin-top: 40px; }
.client-box { border-right: 1px solid var(--naranja); border-bottom: 1px solid var(--naranja); height: 110px; display: flex; align-items: center; justify-content: center; padding: 10px; }
.client-box:nth-child(5n) { border-right: none; }
.no-border-bottom { border-bottom: none; }
.client-box img { max-width: 130px; max-height: 80px; }

/* FOOTER */
#main-footer { background: var(--bg-dark); border-top: 5px solid var(--naranja); padding-top: 40px; color: #fff; }
.footer-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 20px; padding-bottom: 40px; }
.footer-col.links a { color: #fff; display: block; margin-bottom: 10px; text-decoration: none; font-weight: bold; font-size: 14px; }
.social-icons i { background: var(--naranja); width: 30px; height: 30px; line-height: 30px; text-align: center; border-radius: 3px; margin-right: 5px; cursor: pointer; }
.footer-col.brands { display: flex; flex-direction: column; align-items: center; gap: 20px; }
.f-logo { max-width: 180px; }
.sub-footer { background: #0a0a0a; padding: 15px 0; text-align: center; font-size: 11px; }

/* Específicos para Territorios */
.section-title-large { font-size: 50px; font-weight: 900; margin-bottom: 10px;  }
.section-subtitle { font-size: 30px; font-style: italic; margin-bottom: 20px; font-weight: 300; }
.hero-desc { font-size: 22px; max-width: 800px; margin: 0 auto; font-style: italic; }
 .blanco {
        color: white;
    }



.overlay-light { position: absolute; top: 0; left: 0; width: 100%; height: 100%; background: rgba(0,0,0,0.2); }

.step-bar { background: #3f3f3f; padding: 40px 0; }
.step-bar h3 { font-size: 20px; margin-bottom: 10px; letter-spacing: 1px; }
.steps { font-size: 22px; font-weight: bold; }
.orange-text { color: var(--naranja); }

.case-study-section { padding: 80px 0; background: #fff; }
.desc-black { font-size: 18px; color: #000; margin-bottom: 30px; line-height: 1.5; }
.contact-call { font-size: 24px; color: #000; margin-bottom: 10px; }
.desc-blue { color: var(--azul); font-size: 18px; margin-bottom: 20px; }

.circle-frame {
    width: 300px; height: 300px; border-radius: 50%; overflow: hidden;
    border: 8px solid #f0f0f0; display: flex; align-items: center; justify-content: center;
}
.circle-frame img { width: 100%; height: 100%; object-fit: cover; }

.btn-blue {
    display: inline-block; padding: 12px 35px; background: var(--azul);
    color: #fff; text-decoration: none; font-weight: bold; border-radius: 4px;
}
.active-link { color: var(--naranja) !important; }


/* Estilos Específicos para Activos Digitales */
.overlay-light-white { position: absolute; top:0; left:0; width:100%; height:100%; background: rgba(255,255,255,0.5); }
.hero-desc-dark { font-size: 22px; color: #0a0a0a; font-style: italic; max-width: 900px; margin: 0 auto; z-index: 5; position: relative; }

.solutions-bar { background: #3f3f3f; padding: 60px 0; }
.solutions-grid { display: grid; grid-template-columns: repeat(6, 1fr); gap: 20px; margin-top: 30px; }
.solution-item { text-align: center; color: #fff; font-size: 13px; }
.solution-item img { width: 64px; margin-bottom: 15px; transition: 0.3s; }
.solution-item a { color: #fff; text-decoration: underline; font-style: italic; }
.solution-item:hover img { transform: scale(1.1); }

.content-block-white { padding: 80px 0; background: #fff; }
.text-intro { font-size: 18px; color: #000; font-style: italic; text-align: center; max-width: 900px; margin: 0 auto 40px; }
.blue-dark { color: #2e3192; }

.grid-2-col { display: grid; grid-template-columns: 1fr 1fr; gap: 40px; align-items: center; margin-bottom: 40px; }
.grid-2-col.reverse { direction: rtl; }
.grid-2-col.reverse div { direction: ltr; }

.img-fluid { max-width: 100%; height: auto; border-radius: 4px; }
.img-center { display: block; margin: 0 auto; max-width: 100%; }
.italic { font-style: italic; }
.text-right { text-align: right; }
.margin-v-40 { margin: 40px 0; }

.others-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 30px; margin-top: 40px; }
.other-item { text-align: center; }
.other-item img { width: 64px; margin-bottom: 10px; }
.other-item h4 { font-size: 18px; margin-bottom: 5px; }
.other-item p { font-size: 15px; color: #393836; }

.azul{
    color: blue;
}
.blanco{
    color: white;
}


/* Estilos específicos Marketing */
.orange-text { color: #fa5e15; }
.title-orange { color: #f85f17; font-size: 28px; font-weight: bold; margin-bottom: 20px; }
.title-blue { color: #003480; font-size: 28px; font-weight: bold; margin-bottom: 20px; }
.white-p { color: #fff; font-size: 16px; line-height: 1.5; margin-bottom: 20px; }

/* Botones idénticos alineados a la izquierda */
.btn-hero {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 230px; 
    height: 55px; 
    text-decoration: none;
    font-size: 13px;
    font-weight: bold;
    text-transform: uppercase;
    border: 2px solid #222;
    box-sizing: border-box;
}
.btn-white {
    /* Color de fondo y texto */
    background-color: #ffffff;
    color: #333333;
    
    /* Estructura y Espaciado */
    display: inline-block;
    padding: 12px 28px;
    text-decoration: none; /* Quita el subrayado */
    
    /* Bordes y Sombra */
    border-radius: 50px; /* Bordes redondeados */
    border: 1px solid #e0e0e0;
    box-shadow: 0 4px 6px rgba(0, 0, 0, 0.1);
    
    /* Tipografía */
    font-weight: bold;
    font-family: sans-serif;
    font-size: 14px;
    letter-spacing: 1px;
    text-transform: uppercase;
    
    /* Animación */
    transition: all 0.3s ease;
}

/* Efecto al pasar el mouse */
.btn-white:hover {
    background-color: #f8f9fa;
    transform: translateY(-2px); /* Se eleva un poquito */
    box-shadow: 0 6px 12px rgba(0, 0, 0, 0.15);
}
.btn-black { background: #222; color: #fff; border-color: #222; }

/* Overlay blanco degradado para cabeceras interiores */
.hero-overlay-white {
    background: linear-gradient(to right, rgba(255,255,255,1) 0%, rgba(255,255,255,0.8) 40%, rgba(255,255,255,0) 100%);
    height: 100%;
    display: flex;
    align-items: center;
}

