:root {
    --color-primario-fondo: #FAF3E0; /* Crema muy suave / Beige */
    --color-texto-principal: #5D4037; /* Marrón oscuro cálido */
    --color-texto-secundario: #795548; /* Marrón medio */
    --color-acento: #B87333; /* Cobre / Terracota desaturado */
    --color-acento-hover: #A26A2D;
    --color-titulos: #4E342E; /* Marrón más oscuro para títulos */
    --color-blanco: #FFFFFF;
    --color-gris-suave-fondo: #F1E9DA; /* Un beige ligeramente más oscuro para fondos de sección */

    --font-titulos: 'Merriweather', serif;
    --font-cuerpo: 'Lato', sans-serif;
}

body {
    font-family: var(--font-cuerpo);
    color: var(--color-texto-principal);
    background-color: var(--color-primario-fondo);
    padding-top: 70px; /* Ajuste para navbar fija */
}

h1, h2, h3, h4, h5, h6, .logo, .navbar-brand {
    font-family: var(--font-titulos);
    color: var(--color-titulos);
}

/* Navbar Customization */
.navbar {
    background-color: rgba(255, 255, 255, 0.95); /* Blanco con ligera transparencia */
    backdrop-filter: blur(5px);
    box-shadow: 0 2px 5px rgba(0,0,0,0.05);
    min-height: 70px;
}
.navbar-brand.logo {
    font-size: 1.7rem;
    font-weight: 700;
}
.navbar .nav-link {
    color: var(--color-texto-secundario);
    font-weight: 700;
    padding: 0.5rem 1rem;
    position: relative;
}
.navbar .nav-link:hover,
.navbar .nav-link.active { /* Bootstrap usa .active para el link activo */
    color: var(--color-acento);
}
.navbar .nav-link::after {
    content: '';
    position: absolute;
    bottom: 0;
    left: 1rem; /* Alineado con padding */
    right: 1rem; /* Alineado con padding */
    width: calc(100% - 2rem);
    height: 2px;
    background-color: var(--color-acento);
    transform: scaleX(0);
    transition: transform 0.3s ease;
}
.navbar .nav-link:hover::after,
.navbar .nav-link.active::after {
    transform: scaleX(1);
}
.navbar-toggler {
    border-color: rgba(0,0,0,0.1);
}
.navbar-toggler-icon {
    background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 30 30'%3e%3cpath stroke='rgba(78, 52, 46, 0.8)' stroke-linecap='round' stroke-miterlimit='10' stroke-width='2' d='M4 7h22M4 15h22M4 23h22'/%3e%3c/svg%3e");
}


/* Hero Section */
#hero {
    background-image: linear-gradient(rgba(0,0,0,0.4), rgba(0,0,0,0.2)), url('../images/image_banner_1.png'); /* Reemplazar con imagen cálida y serena */
    background-size: cover;
    background-position: center center;
    min-height: calc(100vh - 70px); /* 70px es la altura de la navbar */
}
#hero h1 {
    color: var(--color-blanco);
    font-weight: 700;
}
#hero .lead {
    color: rgba(255,255,255,0.9);
    max-width: 700px;
    margin-left: auto;
    margin-right: auto;
}
.hero-contact strong {
    font-size: 1.2em;
}

/* Custom Button Primary */
.btn-custom-primary {
    background-color: var(--color-acento);
    border-color: var(--color-acento);
    color: var(--color-blanco);
    padding: 0.75rem 1.5rem;
    font-weight: 700;
}
.btn-custom-primary:hover {
    background-color: var(--color-acento-hover);
    border-color: var(--color-acento-hover);
    color: var(--color-blanco);
    transform: translateY(-2px);
}

/* Custom Section Background */
.section-custom-bg-light {
    background-color: var(--color-gris-suave-fondo);
}

/* Servicios Card Custom */
.servicio-card-custom {
    background-color: var(--color-blanco);
    border: 1px solid rgba(0,0,0,0.08);
    transition: transform 0.3s ease, box-shadow 0.3s ease;
}
.servicio-card-custom:hover {
    transform: translateY(-5px);
    box-shadow: 0 8px 20px rgba(0,0,0,0.08);
}
.servicio-card-custom .card-title {
    color: var(--color-titulos);
}

/* Icon Color */
.icon-custom-color {
    color: var(--color-acento);
}

/* Cobertura Badges */
.bg-custom-accent {
    background-color: var(--color-acento) !important; /* Usar !important con cuidado si Bootstrap lo sobreescribe */
    color: var(--color-blanco);
}

/* Porque Elegirnos Items */
.porque-item-custom {
    background-color: var(--color-blanco); /* Si la sección tiene fondo gris, el item blanco */
    /* Si la sección tiene fondo blanco, el item puede ser gris suave */
    /* background-color: var(--color-gris-suave-fondo); */
    box-shadow: 0 2px 8px rgba(0,0,0,0.05);
}
#porque-elegirnos.section-custom-bg-light .porque-item-custom {
    background-color: var(--color-blanco);
}


/* Contacto */
#contacto label {
    color: var(--color-texto-secundario);
    font-weight: 600;
}
#contacto .form-control {
    border-color: #D1C4E9; /* Un borde suave color lavanda cálido */
    background-color: var(--color-blanco); /* Asegurar contraste */
}
#contacto .form-control:focus {
    border-color: var(--color-acento);
    box-shadow: 0 0 0 0.25rem rgba(184, 115, 51, 0.25); /* Sombra con color acento */
}

/* Botones de sucursal */
.btn-sucursal {
    background-color: var(--color-gris-suave-fondo);
    border: 1px solid var(--color-texto-secundario);
    color: var(--color-texto-secundario);
    font-size: 0.9rem;
}
.btn-sucursal.active, .btn-sucursal:hover {
    background-color: var(--color-acento);
    border-color: var(--color-acento);
    color: var(--color-blanco);
}


/* Footer */
footer {
    background-color: var(--color-texto-principal);
    color: var(--color-primario-fondo);
}
footer p {
    opacity: 0.9;
}

