/* SiteServing - styles.css */
:root {
  --color-primary: #2c5f2d;
  --color-primary-dark: #1e4620;
  --color-secondary: #0056b3;
  --color-accent: #8b0000;
  --color-text: #222222;
  --color-text-light: #555555;
  --color-bg: #ffffff;
  --color-bg-alt: #f8f9fa;
  --color-border: #dee2e6;
  --color-warning: #ffc107;
  --color-success: #198754;
  --font-base: 'Segoe UI', Tahoma, Geneva, Verdana, sans-serif;
  --font-heading: 'Georgia', serif;
  --spacing-xs: 0.5rem;
  --spacing-sm: 1rem;
  --spacing-md: 1.5rem;
  --spacing-lg: 2rem;
  --spacing-xl: 3rem;
  --border-radius: 8px;
  --shadow-sm: 0 2px 4px rgba(0,0,0,0.08);
  --shadow-md: 0 4px 12px rgba(0,0,0,0.12);
  --max-width: 1200px;
  --container-padding: 1rem;
}
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; font-size: 16px; }
body { font-family: var(--font-base); font-size: 1.125rem; line-height: 1.6; color: var(--color-text); background: var(--color-bg); }
h1, h2, h3, h4, h5, h6 { font-family: var(--font-heading); font-weight: 700; line-height: 1.3; margin-bottom: var(--spacing-sm); color: var(--color-text); }
h1 { font-size: 2.25rem; }
h2 { font-size: 1.75rem; border-bottom: 3px solid var(--color-primary); padding-bottom: 0.5rem; }
h3 { font-size: 1.375rem; color: var(--color-secondary); }
p { margin-bottom: var(--spacing-sm); }
a { color: var(--color-secondary); text-decoration: none; transition: color 0.2s; }
a:hover { color: var(--color-primary-dark); text-decoration: underline; }
img { max-width: 100%; height: auto; display: block; border-radius: var(--border-radius); }
.container { max-width: var(--max-width); margin: 0 auto; padding: 0 var(--container-padding); }
.sr-only { position: absolute; width: 1px; height: 1px; padding: 0; margin: -1px; overflow: hidden; clip: rect(0,0,0,0); white-space: nowrap; border: 0; }
.text-center { text-align: center; }
.mt-1 { margin-top: var(--spacing-sm); } .mt-2 { margin-top: var(--spacing-md); } .mt-3 { margin-top: var(--spacing-lg); }
.mb-1 { margin-bottom: var(--spacing-sm); } .mb-2 { margin-bottom: var(--spacing-md); } .mb-3 { margin-bottom: var(--spacing-lg); }
.ad-label { display: inline-block; background: var(--color-warning); color: #000; font-size: 0.75rem; font-weight: 600; padding: 0.25rem 0.5rem; border-radius: 4px; text-transform: uppercase; margin-bottom: var(--spacing-xs); }
.site-header { background: var(--color-bg); border-bottom: 1px solid var(--color-border); position: sticky; top: 0; z-index: 1000; box-shadow: var(--shadow-sm); }
.header-inner { display: flex; align-items: center; justify-content: space-between; padding: var(--spacing-sm) 0; gap: var(--spacing-md); }
.logo { display: flex; align-items: center; gap: var(--spacing-xs); font-family: var(--font-heading); font-size: 1.5rem; font-weight: 700; color: var(--color-primary); }
.nav-toggle { display: none; background: none; border: none; font-size: 1.5rem; cursor: pointer; color: var(--color-text); padding: var(--spacing-xs); }
.main-nav ul { display: flex; list-style: none; gap: var(--spacing-sm); flex-wrap: wrap; }
.main-nav a { font-weight: 500; padding: var(--spacing-xs) var(--spacing-sm); border-radius: 4px; }
.main-nav a:hover, .main-nav a.active { background: var(--color-bg-alt); color: var(--color-primary); text-decoration: none; }
.hero { background: linear-gradient(135deg, var(--color-primary) 0%, var(--color-secondary) 100%); color: white; padding: var(--spacing-xl) 0; text-align: center; }
.hero h1 { color: white; border: none; font-size: 2.5rem; }
.hero p { font-size: 1.25rem; max-width: 700px; margin: 0 auto var(--spacing-md); opacity: 0.95; }
.hero-cta { display: inline-block; background: white; color: var(--color-primary); font-weight: 600; padding: 0.75rem 1.5rem; border-radius: var(--border-radius); transition: transform 0.2s; }
.hero-cta:hover { transform: translateY(-2px); text-decoration: none; }
.section { padding: var(--spacing-lg) 0; }
.section-alt { background: var(--color-bg-alt); }
.section-title { text-align: center; margin-bottom: var(--spacing-lg); }
.articles-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(280px, 1fr)); gap: var(--spacing-md); }
.article-card { background: var(--color-bg); border: 1px solid var(--color-border); border-radius: var(--border-radius); overflow: hidden; transition: box-shadow 0.2s; }
.article-card:hover { box-shadow: var(--shadow-md); }
.article-card-img { height: 180px; background: var(--color-bg-alt); display: flex; align-items: center; justify-content: center; color: var(--color-text-light); font-size: 0.875rem; }
.article-card-content { padding: var(--spacing-sm); }
.article-meta { font-size: 0.875rem; color: var(--color-text-light); margin-bottom: var(--spacing-xs); }
.article-card h3 { font-size: 1.125rem; margin-bottom: var(--spacing-xs); }
.article-link { display: inline-block; margin-top: var(--spacing-xs); font-weight: 500; }
.newsletter-block { background: var(--color-primary); color: white; padding: var(--spacing-lg); border-radius: var(--border-radius); text-align: center; }
.newsletter-block h3 { color: white; border: none; }
.newsletter-form { display: flex; flex-wrap: wrap; gap: var(--spacing-sm); justify-content: center; margin-top: var(--spacing-sm); }
.newsletter-form input[type="email"], .newsletter-form input[type="text"] { padding: 0.75rem; border: none; border-radius: 4px; min-width: 250px; font-size: 1rem; }
.newsletter-form .checkbox-group { display: flex; align-items: flex-start; gap: var(--spacing-xs); font-size: 0.875rem; width: 100%; justify-content: center; }
.newsletter-form button { background: var(--color-secondary); color: white; border: none; padding: 0.75rem 1.5rem; border-radius: 4px; font-weight: 600; cursor: pointer; transition: background 0.2s; }
.newsletter-form button:hover { background: #004494; }
.form-group { margin-bottom: var(--spacing-md); }
.form-group label { display: block; font-weight: 500; margin-bottom: var(--spacing-xs); }
.form-group input, .form-group textarea, .form-group select { width: 100%; padding: 0.75rem; border: 1px solid var(--color-border); border-radius: 4px; font-size: 1rem; font-family: inherit; }
.form-checkbox { display: flex; align-items: flex-start; gap: var(--spacing-xs); font-size: 0.95rem; }
.btn { display: inline-block; background: var(--color-primary); color: white; border: none; padding: 0.75rem 1.5rem; border-radius: 4px; font-weight: 600; cursor: pointer; transition: background 0.2s; text-align: center; }
.btn:hover { background: var(--color-primary-dark); }
.btn-secondary { background: var(--color-secondary); }
.btn-secondary:hover { background: #004494; }
.avisos { background: #fff3cd; border-left: 4px solid var(--color-warning); padding: var(--spacing-sm); margin: var(--spacing-md) 0; font-size: 0.95rem; }
.avisos strong { color: #856404; }
.site-footer { background: #1a1a1a; color: #e0e0e0; padding: var(--spacing-lg) 0 var(--spacing-sm); font-size: 0.95rem; }
.footer-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(200px, 1fr)); gap: var(--spacing-md); margin-bottom: var(--spacing-lg); }
.footer-section h4 { color: white; font-size: 1.1rem; margin-bottom: var(--spacing-sm); }
.footer-section a { color: #bbb; }
.footer-section a:hover { color: white; }
.footer-legal { border-top: 1px solid #444; padding-top: var(--spacing-sm); font-size: 0.875rem; color: #aaa; }
.footer-legal a { color: #ccc; }
.cookie-banner { position: fixed; bottom: 0; left: 0; right: 0; background: #222; color: white; padding: var(--spacing-md); z-index: 2000; box-shadow: 0 -2px 10px rgba(0,0,0,0.2); display: none; }
.cookie-banner.show { display: block; }
.cookie-content { max-width: var(--max-width); margin: 0 auto; }
.cookie-buttons { display: flex; flex-wrap: wrap; gap: var(--spacing-xs); margin-top: var(--spacing-sm); }
.cookie-buttons button { padding: 0.5rem 1rem; border: none; border-radius: 4px; font-weight: 500; cursor: pointer; font-size: 0.9rem; }
.btn-accept { background: var(--color-success); color: white; }
.btn-necessary { background: #6c757d; color: white; }
.btn-settings { background: transparent; border: 1px solid #aaa !important; color: white; }
.cookie-modal { position: fixed; top: 0; left: 0; right: 0; bottom: 0; background: rgba(0,0,0,0.6); display: none; align-items: center; justify-content: center; z-index: 2001; padding: var(--spacing-md); }
.cookie-modal.show { display: flex; }
.modal-content { background: white; color: var(--color-text); max-width: 600px; width: 100%; max-height: 90vh; overflow-y: auto; border-radius: var(--border-radius); padding: var(--spacing-lg); }
.cookie-category { border: 1px solid var(--color-border); border-radius: var(--border-radius); padding: var(--spacing-sm); margin-bottom: var(--spacing-sm); }
.cookie-category-header { display: flex; justify-content: space-between; align-items: center; margin-bottom: var(--spacing-xs); }
.cookie-save { margin-top: var(--spacing-md); text-align: right; }
.article-header { margin-bottom: var(--spacing-lg); }
.article-meta-full { display: flex; flex-wrap: wrap; gap: var(--spacing-sm); font-size: 0.95rem; color: var(--color-text-light); margin-bottom: var(--spacing-sm); }
.article-image { width: 100%; height: 400px; background: var(--color-bg-alt); border-radius: var(--border-radius); margin-bottom: var(--spacing-md); display: flex; align-items: center; justify-content: center; color: var(--color-text-light); }
.article-content { font-size: 1.1rem; }
.advertorial-badge { background: var(--color-accent); color: white; padding: 0.5rem 1rem; border-radius: 4px; font-weight: 600; text-transform: uppercase; font-size: 0.875rem; display: inline-block; margin-bottom: var(--spacing-md); }
.checklist { list-style: none; }
.checklist li { padding-left: 1.5rem; position: relative; margin-bottom: 0.5rem; }
.checklist li::before { content: "✓"; position: absolute; left: 0; color: var(--color-success); font-weight: bold; }
@media (max-width: 768px) {
  .nav-toggle { display: block; }
  .main-nav { position: absolute; top: 100%; left: 0; right: 0; background: white; border-bottom: 1px solid var(--color-border); max-height: 0; overflow: hidden; transition: max-height 0.3s; }
  .main-nav.active { max-height: 400px; }
  .main-nav ul { flex-direction: column; padding: var(--spacing-sm); gap: var(--spacing-xs); }
  h1 { font-size: 1.875rem; }
  .hero h1 { font-size: 2rem; }
  .newsletter-form { flex-direction: column; align-items: stretch; }
  .newsletter-form input { min-width: auto; }
  .article-image { height: 250px; }
  .article-content  {
    padding-left: 15px;
    padding-right: 15px;
  }
  
}
:focus { outline: 3px solid var(--color-secondary); outline-offset: 2px; }
.article-image img,
.article-card-img img {
  display: block; width: 100%; max-height: 100%; object-fit: cover;
}
ul, ol {
  list-style-position: inside;
}

.newsletter-block .checkbox-group a{
  color: #fff;
}

.section.container {
    padding-left: 1rem !important;
    padding-right: 1rem !important;
  }