:root {
  --lg-brown: #7a4b2a;
  --lg-brown-dark: #3d2417;
  --lg-brown-soft: #b9825d;
  --lg-cream: #fff7ee;
  --lg-sand: #f5decb;
  --lg-green: #567a35;
  --lg-green-dark: #304b22;
  --lg-ink: #2b211b;
  --lg-muted: #6f625a;
  --lg-card: #ffffff;
  --lg-shadow: 0 1.25rem 3rem rgba(61, 36, 23, .12);
}

* { box-sizing: border-box; }

html { 
  scroll-behavior: smooth; 
  scroll-padding-top: 90px;
}

body {
  font-family: system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  color: var(--lg-ink);
  background: linear-gradient(180deg, #fffaf4 0%, #fff 45%, #fffaf4 100%);
  line-height: 1.65;
}

a { 
  color: var(--lg-brown); 
  transition: color 0.3s ease;
}
a:hover { color: var(--lg-green-dark); }

.skip-link {
  position: absolute;
  left: -999px;
  top: 1rem;
  z-index: 9999;
  padding: .75rem 1rem;
  background: #fff;
  border: 2px solid var(--lg-green);
  border-radius: .75rem;
}
.skip-link:focus { left: 1rem; }

.site-navbar {
  background: rgba(255, 250, 244, .92);
  backdrop-filter: blur(16px);
  border-bottom: 1px solid rgba(122, 75, 42, .12);
}

.navbar-brand {
  font-weight: 900;
  letter-spacing: -.03em;
  color: var(--lg-brown-dark) !important;
  transition: transform 0.3s ease;
}

.navbar-brand:hover {
  transform: scale(1.02);
}

.navbar-brand img {
  height: 65px;
  width: auto;
  object-fit: contain;
  border-radius: 8px;
}

.nav-link {
  font-weight: 700;
  color: var(--lg-muted) !important;
  border-radius: 0.5rem;
  padding-inline: 1rem !important;
  transition: all 0.3s ease;
}

.nav-link.active,
.nav-link:hover,
.nav-link:focus {
  color: var(--lg-brown-dark) !important;
  background: rgba(122, 75, 42, 0.08);
}

.hero {
  position: relative;
  overflow: hidden;
  background:
    radial-gradient(circle at 18% 18%, rgba(86,122,53,.15), transparent 34%),
    radial-gradient(circle at 88% 8%, rgba(122,75,42,.18), transparent 28%),
    linear-gradient(135deg, #fff3e6 0%, #f8ddc8 50%, #fff8ef 100%);
  border-bottom: 1px solid rgba(122, 75, 42, .12);
}

.hero::after {
  content: "";
  position: absolute;
  inset: auto -8rem -8rem auto;
  width: 24rem;
  height: 24rem;
  border-radius: 50%;
  background: rgba(86, 122, 53, .10);
  pointer-events: none;
}

.hero .container { position: relative; z-index: 1; }

.eyebrow {
  display: inline-flex;
  align-items: center;
  gap: .5rem;
  margin-bottom: 1rem;
  padding: .45rem .8rem;
  border-radius: 999px;
  background: rgba(255,255,255,.72);
  color: var(--lg-green-dark);
  font-weight: 800;
  font-size: .875rem;
  box-shadow: 0 .5rem 1.5rem rgba(61,36,23,.08);
}

.display-heading {
  font-weight: 950;
  letter-spacing: -.055em;
  line-height: .98;
  color: var(--lg-brown-dark);
}

.lead-strong {
  font-size: 1.15rem;
  color: #4f4038;
  max-width: 64ch;
}

.btn {
  transition: all 0.3s ease-in-out;
}

.btn-brown {
  --bs-btn-color: #fff;
  --bs-btn-bg: var(--lg-brown);
  --bs-btn-border-color: var(--lg-brown);
  --bs-btn-hover-color: #fff;
  --bs-btn-hover-bg: var(--lg-brown-dark);
  --bs-btn-hover-border-color: var(--lg-brown-dark);
  --bs-btn-focus-shadow-rgb: 122, 75, 42;
  font-weight: 800;
  border-radius: 999px;
  padding: .78rem 1.15rem;
}

.btn-green {
  --bs-btn-color: #fff;
  --bs-btn-bg: var(--lg-green);
  --bs-btn-border-color: var(--lg-green);
  --bs-btn-hover-color: #fff;
  --bs-btn-hover-bg: var(--lg-green-dark);
  --bs-btn-hover-border-color: var(--lg-green-dark);
  font-weight: 800;
  border-radius: 999px;
  padding: .78rem 1.15rem;
}

.btn-outline-brown {
  --bs-btn-color: var(--lg-brown-dark);
  --bs-btn-border-color: rgba(122,75,42,.45);
  --bs-btn-hover-color: #fff;
  --bs-btn-hover-bg: var(--lg-brown);
  --bs-btn-hover-border-color: var(--lg-brown);
  font-weight: 800;
  border-radius: 999px;
  padding: .78rem 1.15rem;
}

.btn-brown, .btn-green, .btn-outline-brown {
  color: var(--bs-btn-color) !important;
  background-color: var(--bs-btn-bg) !important;
  border-color: var(--bs-btn-border-color) !important;
}

.btn-brown:hover, .btn-green:hover, .btn-outline-brown:hover {
  color: var(--bs-btn-hover-color) !important;
  background-color: var(--bs-btn-hover-bg) !important;
  border-color: var(--bs-btn-hover-border-color) !important;
}

.section { padding: 5rem 0; }
.section-tight { padding: 3.25rem 0; }
.section-title {
  color: var(--lg-brown-dark);
  font-weight: 900;
  letter-spacing: -.035em;
}
.section-kicker {
  color: var(--lg-green-dark);
  font-weight: 900;
  letter-spacing: .08em;
  text-transform: uppercase;
  font-size: .78rem;
}

.feature-card,
.info-card,
.legal-card,
.stat-card,
.image-card {
  background: var(--lg-card);
  border: 1px solid rgba(122,75,42,.13);
  border-radius: 1.5rem;
  box-shadow: var(--lg-shadow);
}

.feature-card { 
  padding: 1.5rem; 
}

.feature-card .icon-pill {
  width: 48px;
  height: 48px;
  display: inline-grid;
  place-items: center;
  border-radius: 1rem;
  color: #fff;
  background: var(--lg-green);
  font-size: 1.35rem;
  margin-bottom: 1rem;
}

.stat-card {
  padding: 1.35rem;
  border: 1px solid rgba(86,122,53,.16);
}
.stat-value {
  font-size: clamp(2rem, 4vw, 3rem);
  font-weight: 950;
  line-height: 1;
  color: var(--lg-brown);
}

.image-card {
  overflow: hidden;
  border-radius: 1.75rem;
  border: 1px solid rgba(122,75,42,.12);
}

.image-card img { 
  width: 100%; 
  height: auto; 
  display: block; 
}

.image-card.hero-poster img {
  max-height: 640px;
  object-fit: contain;
  background: #fff3e6;
}

.callout {
  background: linear-gradient(135deg, var(--lg-brown-dark), var(--lg-brown));
  color: #fff;
  border-radius: 2rem;
  padding: clamp(2rem, 4vw, 3.5rem);
  box-shadow: var(--lg-shadow);
}
.callout a:not(.btn) { color: #fff; }

/* Corrección de color para el botón .btn-light en el .callout */
.callout .btn-light {
  color: var(--lg-brown-dark) !important;
}

.use-list li,
.check-list li,
.cross-list li {
  margin-bottom: .55rem;
}

.check-list i { color: var(--lg-green); }
.cross-list i { color: #a23b2b; }

.accordion-button {
  font-weight: 800;
  color: var(--lg-brown-dark);
}
.accordion-button:not(.collapsed) {
  background: #fff0e2;
  color: var(--lg-brown-dark);
  box-shadow: none;
}
.accordion-item {
  border-color: rgba(122,75,42,.16);
  border-radius: 1rem !important;
  overflow: hidden;
  margin-bottom: 1rem;
}

.form-control,
.form-select {
  border-radius: 1rem;
  border-color: rgba(122,75,42,.25);
  padding: .8rem 1rem;
  transition: border-color 0.3s ease, box-shadow 0.3s ease;
}
.form-control:focus,
.form-select:focus {
  border-color: var(--lg-green);
  box-shadow: 0 0 0 .25rem rgba(86,122,53,.15);
}

.footer {
  background: var(--lg-brown-dark);
  color: #f8eadf;
  padding: 3rem 0 2rem;
}
.footer a { color: #f8eadf; text-decoration: none; }
.footer a:hover { color: #fff; text-decoration: underline; }
.footer .logos-wrap {
  background: #fff;
  border-radius: 1rem;
  padding: .85rem;
  display: inline-block;
  max-width: 100%;
}
.footer .logos-wrap img { max-width: min(100%, 720px); height: auto; }

.cookie-banner {
  position: fixed;
  inset: auto 1rem 1rem 1rem;
  z-index: 1055;
  max-width: 920px;
  margin: auto;
  border-radius: 1.25rem;
  background: #fff;
  border: 1px solid rgba(122,75,42,.18);
  box-shadow: 0 1.25rem 3.5rem rgba(0,0,0,.2);
  padding: 1rem;
  display: none;
}
.cookie-banner.show { display: block; }

.breadcrumb-item a { color: var(--lg-brown-dark); font-weight: 700; }
.badge-soft {
  background: rgba(86,122,53,.12);
  color: var(--lg-green-dark);
  border: 1px solid rgba(86,122,53,.16);
}

@media (max-width: 991.98px) {
  .navbar-nav { padding-top: 1rem; gap: .35rem; }
  .display-heading { font-size: clamp(2.6rem, 12vw, 4.25rem); }
  .section { padding: 3.5rem 0; }
}