/* 1. Reset de CSS Profissional */
* { margin: 0; padding: 0; box-sizing: border-box; }
body, input, label, button, legend { font-family: 'Roboto', sans-serif; }
ul, ol { list-style: none; }
a { text-decoration: none; color: inherit; }
img { max-width: 100%; display: block; }

/* 2. Design System - Variáveis Globais */
:root {
  --cor-primaria: #28a745; --cor-primaria-escura: #218838; --cor-secundaria: #ffc107; --cor-fundo: #f8f9fa; --cor-superficie: #ffffff; --cor-texto-principal: #212529; --cor-texto-secundario: #6c757d; --cor-borda: #dee2e6; --cor-erro: #dc3545; --cor-fundo-erro: #f8d7da; --fonte-principal: 'Poppins', sans-serif; --fonte-secundaria: 'Roboto', sans-serif; --tamanho-fonte-xg: 3rem; --tamanho-fonte-g: 2.25rem; --tamanho-fonte-m: 1.5rem; --tamanho-fonte-p: 1rem; --tamanho-fonte-xp: 0.875rem; --espacamento-xp: 8px; --espacamento-p: 16px; --espacamento-m: 24px; --espacamento-g: 32px; --espacamento-xg: 48px; --espacamento-xxg: 64px;
}

/* 3. Estilos do Layout Global COM CSS GRID */
body { font-size: var(--tamanho-fonte-p); color: var(--cor-texto-principal); background-color: var(--cor-fundo); display: grid; grid-template-columns: 1fr min(1100px, 95%) 1fr; grid-template-rows: auto auto 1fr auto; grid-template-areas: ". header ." "nav nav nav" ". main ." "footer footer footer"; min-height: 100vh; }
header { grid-area: header; }
nav { grid-area: nav; }
main { grid-area: main; }
footer { grid-area: footer; }
.container { max-width: 1100px; margin: 0 auto; padding: 0 var(--espacamento-p); width: 100%; }
header { background-color: var(--cor-superficie); padding: var(--espacamento-m) 0; text-align: center; border-bottom: 1px solid var(--cor-borda); }
nav { background-color: var(--cor-primaria); padding: var(--espacamento-p) 0; position: relative; }
main { padding: var(--espacamento-xg) 0; }
section { background-color: var(--cor-superficie); padding: var(--espacamento-g); border-radius: 8px; box-shadow: 0 4px 8px rgba(0, 0, 0, 0.05); margin-bottom: var(--espacamento-g); }
footer { background-color: var(--cor-texto-principal); color: var(--cor-fundo); text-align: center; padding: var(--espacamento-m) 0; }
h1, h2, h3 { font-family: var(--fonte-principal); font-weight: 700; margin-bottom: var(--espacamento-p); }
h1 { font-size: var(--tamanho-fonte-g); }
h2 { font-size: var(--tamanho-fonte-m); color: var(--cor-primaria); }
h3 { font-size: var(--tamanho-fonte-p); }
p { line-height: 1.6; margin-bottom: var(--espacamento-p); }

/* 4. Componentes */
#menu { display: flex; justify-content: center; gap: var(--espacamento-m); align-items: center; }
#menu a { color: var(--cor-superficie); font-family: var(--fonte-principal); font-weight: 500; transition: color 0.3s ease; padding: var(--espacamento-xp) 0; }
#menu a:hover { color: var(--cor-secundaria); }
#nossos-projetos .cards-container { display: flex; flex-wrap: wrap; gap: var(--espacamento-g); margin-top: var(--espacamento-g); }
.card { flex: 1 1 300px; background-color: var(--cor-fundo); border: 1px solid var(--cor-borda); border-radius: 8px; overflow: hidden; display: flex; flex-direction: column; transition: transform 0.3s ease, box-shadow 0.3s ease; }
.card:hover { transform: translateY(-5px); box-shadow: 0 8px 16px rgba(0, 0, 0, 0.1); }
.card img { width: 100%; height: 200px; object-fit: cover; }
.card-content { padding: var(--espacamento-m); display: flex; flex-direction: column; flex-grow: 1; }
.card-content h3 { margin-bottom: var(--espacamento-p); }
.card-content p { flex-grow: 1; margin-bottom: var(--espacamento-m); }
.btn { display: inline-block; background-color: var(--cor-primaria); color: var(--cor-superficie); padding: var(--espacamento-p) var(--espacamento-m); border-radius: 4px; text-align: center; font-family: var(--fonte-principal); font-weight: 500; transition: background-color 0.3s ease; border: none; cursor: pointer; }
.btn:hover { background-color: var(--cor-primaria-escura); }

/* 5. Formulário e Validação Avançada */
form { display: flex; flex-direction: column; gap: 0; margin-top: var(--espacamento-g); }
fieldset { border: 1px solid var(--cor-borda); border-radius: 8px; padding: var(--espacamento-m); margin-bottom: var(--espacamento-g); }
legend { font-family: var(--fonte-principal); font-weight: 700; color: var(--cor-primaria); padding: 0 var(--espacamento-xp); }
.form-control { margin-bottom: var(--espacamento-m); }
label { display: block; margin-bottom: var(--espacamento-xp); font-weight: 500; }
input[type="text"], input[type="email"], input[type="date"], input[type="tel"] { width: 100%; padding: var(--espacamento-p); border: 1px solid var(--cor-borda); border-radius: 4px; font-size: var(--tamanho-fonte-p); transition: border-color 0.3s ease, box-shadow 0.3s ease; }
input:focus { outline: none; border-color: var(--cor-primaria); box-shadow: 0 0 0 3px rgba(40, 167, 69, 0.2); }
.form-actions { display: flex; gap: var(--espacamento-p); }
.btn-secondary { background-color: var(--cor-texto-secundario); }
.btn-secondary:hover { background-color: var(--cor-texto-principal); }
.error-message { color: var(--cor-erro); font-size: var(--tamanho-fonte-xp); margin-top: var(--espacamento-xp); display: none; }
.form-control.error .error-message { display: block; }
.form-control.error input { border-color: var(--cor-erro); background-color: var(--cor-fundo-erro); }

/* 6. Responsividade e Menu Hambúrguer */
#btn-mobile { display: none; }
@media (max-width: 768px) {
  body { grid-template-columns: 1fr; grid-template-areas: "header" "nav" "main" "footer"; }
  nav .container { display: flex; align-items: center; justify-content: space-between; }
  #btn-mobile { display: flex; padding: .5rem 1rem; font-size: 1rem; border: none; background: none; cursor: pointer; gap: .5rem; color: var(--cor-superficie); }
  #hamburger { display: block; border-top: 2px solid; width: 20px; }
  #hamburger::after, #hamburger::before { content: ''; display: block; width: 20px; height: 2px; background: currentColor; margin-top: 5px; transition: .3s; position: relative; }
  #menu { display: block; position: absolute; width: 100%; top: 65px; left: 0; background: var(--cor-texto-principal); height: 0; transition: height .4s ease-in-out; visibility: hidden; overflow-y: auto; z-index: 1000; }
  #menu li { padding: 1rem 0; margin: 0 1rem; border-bottom: 1px solid rgba(255, 255, 255, 0.1); }
  #nav.active #menu { height: calc(100vh - 65px); visibility: visible; }
  #nav.active #hamburger { border-top-color: transparent; }
  #nav.active #hamburger::before { transform: rotate(135deg); }
  #nav.active #hamburger::after { transform: rotate(-135deg); top: -7px; }
}