/* --- Paleta de Colores (NUEVA - Tema Naranja) --- */
:root {
    --background-color: #E2E5E9;
    --content-background: #F4F9fC;
    --primary-text-color: #212529;
    --secondary-text-color: #6c757d;
    --border-color: #dee2e6;
    --accent-color: #D97941; /* Naranja principal */
    --accent-color-hover: #C86A35;
    --button-text-color: #ffffff;
}

/* --- Estilos Base y Reset --- */
* {
    margin: 0;
    padding: 0;
    box-sizing: border-box;
}

body {
    font-family: 'Poppins', sans-serif;
    background-color: var(--background-color);
    color: var(--primary-text-color);
    line-height: 1.5;
    padding-top: 130px; /* Espacio para header fijo */
}

/* --- Botones --- */
.btn-primary {
    background-color: var(--accent-color);
    border-color: var(--accent-color);
    color: var(--button-text-color);
}

.btn-primary:hover {
    background-color: var(--accent-color-hover);
    border-color: var(--accent-color-hover);
}

.btn-outline-primary {
    color: var(--accent-color);
    border-color: var(--accent-color);
}

.btn-outline-primary:hover {
    background-color: var(--accent-color);
    border-color: var(--accent-color);
    color: white;
}

/* --- Header Fijo --- */
.main-header {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 70px;
    background-image: linear-gradient(to right, var(--background-color), var(--content-background));
    border-bottom: 1px solid var(--border-color);
    z-index: 1030;
    display: flex;
    align-items: center;
    padding: 0 1rem;
}

.header-content {
    display: grid;
    grid-template-columns: 200px 1fr 200px; /* Izquierda, Centro, Derecha */
    align-items: center;
    width: 100%;
    gap: 1rem;
}

.header-left { justify-self: start; }
.header-center { justify-self: center; }
.header-right { justify-self: end; }

.client-logo {
    max-height: 45px;
    max-width: 180px;
    object-fit: contain;
}

/* --- Barra de Contexto --- */
.context-bar {
    position: fixed;
    top: 70px;
    left: 0;
    width: 100%;
    height: 60px;
    background-color: var(--content-background);
    border-bottom: 1px solid var(--border-color);
    z-index: 1029;
    display: flex;
    align-items: center;
    padding: 0 1rem;
}

.header-controls {
    flex-grow: 1;
    justify-content: center;
    display: flex;
    align-items: center;
    gap: 1rem;
}

/* Responsive */
@media (max-width: 992px) {
    .project-view-selector label, .project-view-selector select {
        display: none;
    }
    .header-content {
        grid-template-columns: 1fr auto 1fr;
    }
    .header-center {
        display: none; /* Ocultar el logo central en móvil para dar espacio */
    }
}

@media (max-width: 768px) {
    .header-left .client-logo {
        max-height: 35px;
    }
    body {
        padding-top: 80px;
    }
}
