.public-body { background-color: var(--bg-surface); display: flex; flex-direction: column; min-height: 100vh; }
.container { width: 100%; max-width: 1200px; margin: 0 auto; padding: 0 var(--spacing-md); }
.public-header { background-color: var(--bg-surface); border-bottom: 1px solid var(--border-color); position: sticky; top: 0; z-index: 100; padding: var(--spacing-sm) 0; }
.header-container { display: flex; align-items: center; justify-content: space-between; }
.brand-link { display: flex; align-items: center; gap: var(--spacing-sm); text-decoration: none; color: var(--text-strong); }
.brand-link .material-symbols-outlined { font-size: 2rem; color: var(--color-primary-600); }
.brand-names { display: flex; flex-direction: column; }
.brand-names .estado { font-size: 0.65rem; text-transform: uppercase; letter-spacing: 0.05em; color: var(--text-muted); font-weight: 600; }
.brand-names .nome { font-size: 1rem; font-weight: 700; line-height: 1.2; }
.public-nav { display: flex; align-items: center; gap: var(--spacing-lg); }
.nav-link { color: var(--text-muted); font-weight: 500; font-size: 0.9rem; }
.nav-link:hover, .nav-link.active { color: var(--color-primary-600); }
.mobile-menu-toggle { display: none; background: none; border: none; font-size: 1.5rem; color: var(--text-strong); cursor: pointer; }
.mobile-nav-panel { display: none; background-color: var(--bg-surface); border-bottom: 1px solid var(--border-color); padding: var(--spacing-md); flex-direction: column; gap: var(--spacing-md); position: absolute; width: 100%; top: 60px; left: 0; z-index: 99; transform: translateY(-100%); transition: transform var(--transition-speed); }
.mobile-nav-panel.open { transform: translateY(0); }
@media (min-width: 769px) { .mobile-nav-panel { display: none !important; } }
@media (max-width: 768px) { .public-nav { display: none; } .mobile-menu-toggle { display: block; } }

.public-main { flex: 1; }
.hero-section { padding: 4rem 0; background-image: linear-gradient(135deg, var(--color-secondary-50) 0%, var(--color-secondary-100) 100%); overflow: hidden; }
.hero-container { display: flex; align-items: center; gap: 3rem; }
.hero-content { flex: 1; }
.hero-badge { display: inline-block; padding: 0.25rem 0.75rem; background-color: var(--color-primary-100); color: var(--color-primary-700); font-size: 0.75rem; font-weight: 600; border-radius: 999px; margin-bottom: 1rem; }
.hero-title { font-size: 2.5rem; font-weight: 800; line-height: 1.2; color: var(--text-strong); margin-bottom: 1rem; }
.hero-title span { color: var(--color-primary-600); }
.hero-subtitle { font-size: 1.125rem; color: var(--text-muted); margin-bottom: 2rem; }
.hero-actions { display: flex; gap: 1rem; }
.hero-image { flex: 1; position: relative; }

.mockup-window { background-color: var(--bg-surface); border-radius: var(--radius-lg); box-shadow: var(--shadow-lg); border: 1px solid var(--border-color); overflow: hidden; width: 100%; max-width: 500px; margin-left: auto; }
.mockup-header { background-color: var(--color-secondary-50); padding: 0.75rem 1rem; display: flex; gap: 0.5rem; border-bottom: 1px solid var(--border-color); }
.dot { width: 10px; height: 10px; border-radius: 50%; }
.dot.red { background-color: #ef4444; }
.dot.yellow { background-color: #eab308; }
.dot.green { background-color: #22c55e; }
.mockup-body { display: flex; height: 300px; }
.mockup-sidebar { width: 60px; background-color: var(--color-primary-900); }
.mockup-content { flex: 1; padding: 1.5rem; background-color: var(--bg-body); }
.skeleton-title { height: 20px; width: 40%; background-color: var(--color-secondary-200); border-radius: var(--radius-sm); margin-bottom: 1rem; }
.skeleton-text { height: 12px; background-color: var(--color-secondary-200); border-radius: var(--radius-sm); margin-bottom: 0.5rem; }
.w-75 { width: 75%; }
.mockup-chart { height: 100px; background-color: var(--bg-surface); border-radius: var(--radius-md); margin: 1.5rem 0; border: 1px solid var(--border-color); }
.mockup-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 0.5rem; }
.mockup-card { height: 60px; background-color: var(--bg-surface); border-radius: var(--radius-md); border: 1px solid var(--border-color); }

@media (max-width: 992px) {
    .hero-container { flex-direction: column; text-align: center; }
    .hero-actions { justify-content: center; }
    .hero-image { width: 100%; margin-top: 2rem; }
    .mockup-window { margin: 0 auto; }
}

.stats-section { padding: 3rem 0; background-color: var(--color-primary-900); color: white; }
.stats-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(200px, 1fr)); gap: 2rem; text-align: center; }
.stat-value { font-size: 2rem; font-weight: 700; color: var(--color-primary-100); margin-bottom: 0.5rem; }
.stat-label { font-size: 0.875rem; color: var(--color-secondary-300); font-weight: 500; }

.features-section { padding: 4rem 0; }
.features-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(300px, 1fr)); gap: 2rem; }
.feature-card { background-color: var(--bg-surface); padding: 2rem; border-radius: var(--radius-lg); box-shadow: var(--shadow-sm); border: 1px solid var(--border-color); transition: transform var(--transition-speed), box-shadow var(--transition-speed); }
.feature-card:hover { transform: translateY(-5px); box-shadow: var(--shadow-md); }
.feature-icon { width: 48px; height: 48px; background-color: var(--color-primary-100); color: var(--color-primary-600); border-radius: var(--radius-md); display: flex; align-items: center; justify-content: center; margin-bottom: 1rem; }
.feature-card h3 { font-size: 1.25rem; margin-bottom: 0.5rem; color: var(--text-strong); }
.feature-card p { color: var(--text-muted); }

.benefits-section { padding: 4rem 0; background-color: var(--color-secondary-50); border-top: 1px solid var(--border-color); }
.benefits-list { list-style: none; max-width: 800px; margin: 0 auto; }
.benefits-list li { display: flex; align-items: flex-start; margin-bottom: 1rem; padding: 1rem; background-color: var(--bg-surface); border-radius: var(--radius-md); border: 1px solid var(--border-color); }
.benefits-list li .material-symbols-outlined { margin-right: 1rem; font-size: 1.5rem; }
.text-primary { color: var(--color-primary-600); }

.public-footer { background-color: var(--color-secondary-900); color: var(--color-secondary-300); padding-top: 3rem; }
.footer-container { display: flex; justify-content: space-between; flex-wrap: wrap; gap: 2rem; margin-bottom: 2rem; }
.footer-info h4 { color: white; font-size: 1.125rem; margin-bottom: 1rem; }
.footer-info p { margin-bottom: 0.25rem; font-size: 0.875rem; }
.footer-links { display: flex; flex-direction: column; gap: 0.5rem; }
.footer-links a { color: var(--color-secondary-300); font-size: 0.875rem; }
.footer-links a:hover { color: white; }
.footer-bottom { border-top: 1px solid rgba(255,255,255,0.1); padding: 1.5rem 0; font-size: 0.75rem; }
