        :root {
            --primary-color: #017DB9;
            --primary-dark: #015a86;
            --text-dark: #333;
            --light-bg: #f8f9fa;
        }

        body {
            font-family: 'Open Sans', sans-serif;
            overflow-x: hidden !important;
			
        }
		
		.texto {
	font-size: 17px;
	white-space: pre-wrap;
	color:var(--cor_segundaria);
}
.negrito {
	font-weight: bold;
}

        h1, h2, h3, h4, h5, .nav-link, .btn {
            font-family: 'Poppins', sans-serif;
        }

        /* Utilitários de Cor e Botão */
        .text-primary-custom { color: var(--primary-color) !important; }
        .bg-primary-custom { background-color: var(--primary-color) !important; }
        
        .btn-primary-custom {
            background-color: var(--primary-color);
            border-color: var(--primary-color);
            color: white;
            padding: 10px 25px;
            border-radius: 50px; /* Botão arredondado moderno */
            transition: all 0.3s ease;
            font-weight: 600;
        }

        .btn-primary-custom:hover {
			 color: white;
            background-color: var(--primary-dark);
            transform: translateY(-2px);
            box-shadow: 0 5px 15px rgba(1, 125, 185, 0.4);
        }

        /* TOPO */
        .top-bar {
            padding-top:10px;
			padding-bottom: 10px;
            background-color: #212529;
            color: #ccc;
            font-size: 0.85rem;
            display: flex;
            align-items: center;
        }
        .top-bar a { color: #ccc; text-decoration: none; transition: 0.3s; }
        .top-bar a:hover { color: var(--primary-color); }

        /* MENU */
        .navbar {
            padding: 15px 0;
            background: white;
            transition: all 0.3s;
        }
        .nav-link {
            color: #444;
            font-weight: 500;
            margin: 0 10px;
            transition: color 0.3s;
        }
        .nav-link:hover, .nav-link.active { color: var(--primary-color); }
        
        /* Dropdown menu ajustes */
        .dropdown-menu {
            border: none;
            box-shadow: 0 10px 30px rgba(0,0,0,0.1);
            border-radius: 0 0 10px 10px;
            padding: 15px;
        }
        .dropdown-item { padding: 8px 15px; border-radius: 5px; }
        .dropdown-item:hover { background-color: #f0f8ff; color: var(--primary-color); }

        /* MEIO 1 - BANNER */
        .hero-section {
            height: 600px;
            background: linear-gradient(rgba(0,0,0,0.6), rgba(0,0,0,0.6)), url('../imagens/banner2.jpg');
            background-size: cover;
            background-position: center;
            display: flex;
            align-items: center;
            color: white;
            position: relative;
        }

        /* MEIO 3 - PRODUTOS CARD */
        .product-card {
            border: none;
            border-radius: 15px;
            overflow: hidden;
            box-shadow: 0 5px 15px rgba(0,0,0,0.05);
            transition: all 0.4s ease;
            background: white;
            height: 100%;
        }
        .product-card:hover {
            transform: translateY(-10px);
            box-shadow: 0 15px 30px rgba(1, 125, 185, 0.2);
        }
        .product-img-wrapper {
            height: 250px;
            overflow: hidden;
        }
        .product-img-wrapper img {
            width: 100%;
            height: 100%;
            object-fit: cover;
            transition: transform 0.5s ease;
        }
        .product-card:hover .product-img-wrapper img {
            transform: scale(1.1);
        }

        /* MEIO 4 - FORMULARIO */
        .contact-section {
            background: linear-gradient(rgba(1, 125, 185, 0.9), rgba(1, 42, 80, 0.9)), url('../imagens/fundo_form.jpg');
            background-attachment: fixed;
            background-size: cover;
            padding: 80px 0;
            color: white;
        }
        .form-control {
            border-radius: 10px;
            padding: 12px;
            border: none;
            background: rgba(255,255,255,0.9);
        }
        .form-control:focus {
            box-shadow: 0 0 0 0.25rem rgba(255,255,255, 0.3);
            background: white;
        }

        /* RODAPE */
        footer {
            background-color: #1A1917;
            color: #b0b0b0;
            padding-top: 60px;
            padding-bottom: 30px;
        }
        footer h5 { color: white; margin-bottom: 20px; position: relative; padding-bottom: 10px; }
        footer h5::after {
            content: '';
            position: absolute;
            left: 0;
            bottom: 0;
            width: 40px;
            height: 3px;
            background-color: var(--primary-color);
        }
        footer ul li { margin-bottom: 10px; }
        footer ul li a { color: #b0b0b0; text-decoration: none; transition: 0.3s; }
        footer ul li a:hover { color: var(--primary-color); padding-left: 5px; }

        /* RODAPE 2 */
        .sub-footer {
            background-color: #000000;
            height: auto;
            min-height: 25px;
            font-size: 12px;
            color: #666;
            display: flex;
            align-items: center;
            justify-content: center;
            padding: 10px 0;
        }
		
		/* Adicione isso ao seu CSS para controlar o tamanho do logo */
.navbar-brand img {
    height: 70px; /* Altura ideal para Desktop */
    width: auto;  /* Mantém a proporção correta */
    transition: all 0.3s ease;
}
.logo_rodape {
	max-width: 80%;
	margin: 0 auto 0 auto;
}

/* Ajuste automático para Celular */
@media (max-width: 991px) {
    .navbar-brand img {
        height: 45px; /* Menor no celular para caber o botão do menu */
    }
}

.centraliza {
	text-align: center;
}

/* --- SEÇÃO INTERNA DE BANNER (PAGE HERO) --- */
        .page-hero {
            background: linear-gradient(rgba(0,0,0,0.7), rgba(1, 125, 185, 0.4)), url('https://images.unsplash.com/photo-1517048676732-d65bc937f952?ixlib=rb-4.0.3&auto=format&fit=crop&w=1920&q=80'); /* Imagem de fundo para páginas internas */
            background-size: cover;
            background-position: center;
            height: 350px; /* Altura menor que o banner da home */
            display: flex;
            align-items: center;
            color: white;
            position: relative;
        }
        .page-hero h1 {
            font-size: 3.5rem;
            font-weight: 700;
        }
        .breadcrumb-custom {
            background: rgba(255,255,255,0.1);
            padding: 8px 15px;
            border-radius: 5px;
        }
        .breadcrumb-custom .breadcrumb-item a {
            color: white;
            text-decoration: none;
            transition: 0.3s;
        }
        .breadcrumb-custom .breadcrumb-item a:hover {
            color: var(--primary-color);
        }
        .breadcrumb-custom .breadcrumb-item.active {
            color: var(--primary-color);
            font-weight: 600;
        }
        .breadcrumb-custom .breadcrumb-item + .breadcrumb-item::before {
            color: #ccc;
        }
		
		
		
		
		
		
		
		
		/* --- SEÇÃO DE CONTEÚDO PRINCIPAL --- */
        .section-content {
            padding: 80px 0;
            background-color: var(--light-bg); /* Fundo claro para o conteúdo */
        }
        .sidebar {
            background-color: white;
            padding: 30px;
            border-radius: 10px;
            box-shadow: 0 5px 15px rgba(0,0,0,0.05);
        }
        .sidebar h5 {
            color: var(--primary-color);
            margin-bottom: 25px;
            font-weight: 700;
            position: relative;
        }
        .sidebar h5::after {
            content: '';
            position: absolute;
            left: 0;
            bottom: -5px;
            width: 40px;
            height: 3px;
            background-color: #eee;
        }
        .sidebar-menu .list-group-item {
            border: none;
            padding: 12px 0;
            font-weight: 500;
            color: #555;
            transition: all 0.3s ease;
        }
        .sidebar-menu .list-group-item:hover,
        .sidebar-menu .list-group-item.active {
            color: var(--primary-color);
            background-color: transparent;
            padding-left: 10px;
        }
        .sidebar-menu .list-group-item.active {
            border-left: 3px solid var(--primary-color);
        }





/* --- ESTILOS ESPECÍFICOS DA PÁGINA DE CONTATO --- */
.contact-info-card {
    background: white;
    padding: 30px;
    border-radius: 10px;
    box-shadow: 0 5px 15px rgba(0,0,0,0.05);
    transition: transform 0.3s ease;
    height: 100%; /* Garante altura uniforme nas colunas */
}
.contact-info-card:hover {
    transform: translateY(-5px);
    box-shadow: 0 10px 25px rgba(1, 125, 185, 0.1);
}
.icon-circle {
    background-color: var(--primary-color);
    color: white;
    width: 60px;
    height: 60px;
    border-radius: 50%;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-size: 1.5rem;
    margin-bottom: 15px;
}
.form-area {
    background: white;
    padding: 40px;
    border-radius: 10px;
    box-shadow: 0 5px 15px rgba(0,0,0,0.05);
    height: 100%;
}
.map-iframe {
    height: 100%;
    min-height: 400px; /* Altura mínima para o mapa */
    border: 0;
    border-radius: 10px;
}

.form-control, .form-select {
    border: 1px solid #ced4da; /* Garante uma borda cinza clara visível */
    border-radius: 5px;
    box-shadow: none; /* Remove o box-shadow padrão do BS que pode confundir */
    transition: all 0.3s ease;
}

/* Estilo de Foco (quando o usuário clica no campo) */
.form-control:focus, .form-select:focus {
    border-color: var(--primary-color); /* Borda primária (azul) no foco */
    box-shadow: 0 0 0 0.25rem rgba(1, 125, 185, 0.25); /* Sombra azul clara no foco */
    outline: 0;
}

/* Opcional: Ajustar o estilo da área do formulário se houver conflito */
.form-area {
    /* ... outros estilos ... */
    background: white;
}


    /* Estilos específicos para a página de detalhes do produto */
    .detalhes_produtos {
        padding: -40px 0;
        background-color: var(--light-bg);
    }
    
    /* Imagem Principal */
    .product-main-image {
        border-radius: 10px;
        overflow: hidden;
        box-shadow: 0 4px 15px rgba(0, 0, 0, 0.1);
        cursor: zoom-in;
    }
    .product-main-image img {
        width: 100%;
        height: auto;
        display: block;
    }

    /* Miniaturas */
    .thumbnail-gallery .thumbnail {
        border: 2px solid transparent;
        border-radius: 5px;
        overflow: hidden;
        cursor: pointer;
        transition: border-color 0.3s ease;
        opacity: 0.7;
    }
    .thumbnail-gallery .thumbnail:hover,
    .thumbnail-gallery .thumbnail.active {
        border-color: var(--primary-color);
        opacity: 1;
    }
    .thumbnail-gallery img {
        width: 100%;
        height: 80px;
        object-fit: cover;
    }

    /* Modal Lightbox */
    .modal-content-custom {
        background-color: transparent;
        border: none;
    }
    .modal-body-custom {
        padding: 0;
    }
    .modal-body-custom img {
        width: 100%;
        height: auto;
        border-radius: 10px;
    }
    .btn-close-white {
        filter: invert(1); /* Deixa o X branco para fundos escuros */
    }

    /* Detalhes e Descrição */
    .product-details {
        padding-left: 20px;
    }
    .product-details h1 {
        font-weight: 700;
        color: var(--text-dark);
    }
    /* Estilo para a linha sob os títulos, se não estiver no seu CSS principal */
    .content-title-line {
        position: relative;
        padding-bottom: 10px;
    }
    .content-title-line::after {
        content: '';
        position: absolute;
        left: 0;
        bottom: 0;
        width: 60px;
        height: 3px;
        background-color: var(--primary-color);
    }

.centraliza {
	text-align: center !important;
}


/* --- CORREÇÃO FINAL DE ALINHAMENTO DO MENU MOBILE --- */
@media (max-width: 991.98px) {
    /* Alinha o contêiner colapsado à esquerda */
    #navbarNav {
        text-align: left !important;
    }
    
    /* 1. Foca na lista de navegação para anular a centralização (ms-auto) */
    #navbarNav .navbar-nav {
        margin-right: 0 !important; /* Desabilita o auto-margin da direita */
        margin-left: 0 !important;  /* Desabilita o auto-margin da esquerda */
        padding-left: 0 !important;
        width: 100%;
        display: block; /* Garante que a UL ocupe a linha inteira */
    }
    
    /* 2. Garante que os itens de lista e o botão não estejam centralizados */
    #navbarNav .nav-item,
    #navbarNav .nav-link,
    #navbarNav .btn {
        text-align: left !important;
        /* Adiciona um padding uniforme para todos os itens */
        padding-left: 1rem !important;
        padding-right: 1rem !important;
		font-size: 18px;
    }
    
    /* 3. Ajuste específico para o botão (Orçamento Online) */
    #navbarNav .nav-item .btn {
        /* Garante que o botão comece na margem esquerda, sem ser empurrado para o centro */
        display: block;
		text-align: center !important;
        margin-left: 1rem !important; 
        margin-right: auto !important; 
    }
}






