/* --- Reset e Estilos Globais --- */
body, html { margin: 0; padding: 0; font-family: 'Poppins', sans-serif; background-color: #f4f7f9; color: #333; font-size: 13px; }
* { box-sizing: border-box; }
:root { --primary-color: #667eea; /* Cor padrão, será sobrescrita pelo PHP */ }

/* --- Animações e Utilitários --- */
.hidden { display: none; }
@keyframes fadeIn { from { opacity: 0; transform: translateY(-10px); } to { opacity: 1; transform: translateY(0); } }
@keyframes spin { from { transform: rotate(0deg); } to { transform: rotate(360deg); } }
.animate-fade-in { animation: fadeIn 0.5s ease-out forwards; }
.animate-spin { animation: spin 1s linear infinite; height: 1.25rem; width: 1.25rem; margin: auto; }

/* --- Layout Global da Página --- */
.page-container { display: flex; flex-direction: column; min-height: 100vh; }
.main-header { background-color: #fff; box-shadow: 0 2px 4px rgba(0,0,0,0.05); padding: 15px 40px; width: 100%; z-index: 100; }
.header-top { display: flex; justify-content: space-between; align-items: center; max-width: 1200px; margin: 0 auto; padding-bottom: 15px; border-bottom: 1px solid #eee; }
.company-logo { height: 40px; }
.user-info span { font-weight: 500; }
.main-nav { max-width: 1200px; margin: 10px auto 0; display: flex; align-items: center; gap: 20px; }
.main-nav a { text-decoration: none; color: #555; padding: 8px 12px; border-radius: 6px; font-weight: 500; font-size: 0.95rem; transition: background-color 0.2s, color 0.2s; }
.main-nav a:hover { background-color: #f0f0f0; color: #111; }
.main-nav a[href*='logout'] { margin-left: auto; color: #ef4444; }
.main-nav a[href*='logout']:hover { background-color: #fee2e2; color: #c82b2b; }
.main-content { flex-grow: 1; width: 100%; max-width: 1900px; margin: 30px auto; padding: 0 20px; }
.main-footer { text-align: center; padding: 20px; font-size: 0.9rem; color: #888; background-color: #fff; border-top: 1px solid #eee; margin-top: auto; }

/* --- Card de Consulta CNPJ --- */
.consulta-cnj-container { background-color: #fff; padding: 30px; border-radius: 12px; box-shadow: 0 8px 30px rgba(0,0,0,0.08); margin-bottom: 30px; }
.consulta-cnj-container h2 { margin-top: 0; margin-bottom: 5px; font-size: 1.8rem; font-weight: 600; color: #111; }
.consulta-cnj-container p { margin-top: 0; margin-bottom: 25px; color: #666; }
.consulta-form { display: flex; gap: 10px; }
.input-group-dashboard { display: contents; }
.consulta-form input { flex-grow: 1; padding: 15px 20px; border: 1px solid #ddd; border-radius: 8px; font-size: 1rem; font-family: 'Poppins', sans-serif; transition: border-color 0.3s, box-shadow 0.3s; }
.consulta-form input:focus { outline: none; border-color: var(--primary-color); box-shadow: 0 0 0 3px color-mix(in srgb, var(--primary-color) 20%, transparent); }
.btn-consultar { display: flex; align-items: center; justify-content: center; padding: 15px 30px; border: none; background-color: var(--primary-color); color: #fff; font-size: 1rem; font-weight: 600; cursor: pointer; border-radius: 8px; transition: background-color 0.3s; }
.btn-consultar:hover { filter: brightness(0.9); }
.btn-consultar:disabled { background-color: #ccc; cursor: not-allowed; }

/* --- Mensagem de Erro --- */
.error-message { margin-top: 1rem; color: #c82b2b; font-weight: 500; background-color: #fee2e2; padding: 1rem; border-radius: 0.5rem; }

/* --- Card de Resultados --- */
.result-card { background-color: #fff; padding: 1.5rem; border-radius: 0.5rem; box-shadow: 0 4px 20px rgba(0,0,0,0.05); margin-top: 30px; }
.result-title { font-size: 1.25rem; font-weight: 700; color: #2d3748; margin-bottom: 1.5rem; }
.result-grid { display: grid; gap: 1.5rem; margin-bottom: 1.5rem; }
.result-grid.main-info-1 { grid-template-columns: 3fr 3fr 1.5fr; }
.result-grid.main-info-2 { grid-template-columns: 2fr 1fr 1.5fr 1fr; border-bottom: 1px solid #e2e8f0; padding-bottom: 1.5rem; }
.result-item-label { font-size: 0.875rem; color: #718096; }
.result-item-value { font-weight: 600; color: #2d3748; }
.result-item-value.status-ativa { color: #38a169; }
.result-item-value.status-inativa { color: #e53e3e; }

/* --- Seções Acordeão (Accordion) --- */
.accordion-container { display: flex; flex-direction: column; gap: 1rem; }
.accordion { background-color: #f7fafc; border-radius: 0.5rem; cursor: pointer; }
.accordion summary { display: flex; align-items: center; justify-content: space-between; font-size: 1.125rem; font-weight: 500; color: #4a5568; list-style: none; padding: 0.75rem; }
.accordion summary::-webkit-details-marker { display: none; }
.accordion-arrow { transition: transform 0.3s; }
.accordion[open] .accordion-arrow { transform: rotate(180deg); }
.accordion-content { margin-top: 0; padding: 0 0.75rem 0.75rem; font-size: 0.875rem; }

/* Acordeão: Endereço */
.address-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(220px, 1fr)); gap: 1rem; }
.address-grid .result-item-value { font-weight: 500; }

/* Acordeão: CNAE */
.cnae-section .result-item-label { margin-top: 1rem; }
.cnae-section .result-item-value { margin-bottom: 0.5rem; }
.cnae-section ul { list-style-type: disc; list-style-position: inside; font-weight: 500; color: #2d3748; padding-left: 1rem; }

/* Acordeão: QSA (Tabela) */
.qsa-table { overflow-x: auto; }
.qsa-grid { display: grid; min-width: 900px; gap: 1rem; }
.qsa-header { grid-template-columns: 2fr 1fr 1.5fr 1fr 1fr 1fr 1.5fr; font-weight: 600; color: #4a5568; margin-bottom: 0.5rem; padding-bottom: 0.5rem; border-bottom: 2px solid #e2e8f0; }
.qsa-row { grid-template-columns: 2fr 1fr 1.5fr 1fr 1fr 1fr 1.5fr; padding: 0.75rem 0; border-bottom: 1px solid #edf2f7; }
.qsa-row:last-child { border-bottom: none; }
.qsa-row .result-item-value { font-weight: 500; }
