:root{
  --brand:  #2BAE4F;        /* verde logo */
  --brand2: #FAF005;        /* amarillo logo */

  --seed: #E6D200;          /* amarillo semilla */
  --seed-2: #C8B800;        /* oliva/semilla oscuro */
  --seed-bg: #FFF7C2;       /* fondo semilla claro */
  --seed-text: #2B2B2B;     /* texto oscuro */
  --seed-line: rgba(0,0,0,.10);

  --text: #1a1a1a;
  --muted: #6b6b6b;
  --line: rgba(0,0,0,.10);

  --shadow: 0 10px 30px rgba(43,174,79,.10);
  --radius: 18px;
}

*{box-sizing:border-box}
html,body{height:100%}

body{
  margin:0;
  font-family: ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Helvetica, Arial;
  color: var(--text);
  background:#fff;
  overflow-x:hidden;
}

a{ color:inherit; text-decoration:none; }

.container{ width:min(1120px, 92%); margin:0 auto; }

/* Ajuste por header fijo */
main{ padding-top: 78px; }
section{ scroll-margin-top: 95px; }

/* Decor blur (opcional) */
.blur{
  position:absolute; inset:-120px -60px auto auto;
  width:480px;height:480px;border-radius:999px;
  background:
    radial-gradient(circle at 30% 30%, rgba(43,174,79,.18), transparent 55%),
    radial-gradient(circle at 60% 60%, rgba(230,210,0,.16), transparent 55%);
  filter: blur(22px);
  opacity:.9;
  pointer-events:none;
}

/* ================= HEADER (FIJO) ================= */
header{
  position: fixed;
  top:0; left:0; right:0;
  z-index: 9999;
  background: linear-gradient(180deg, var(--seed-bg), rgba(255,247,194,.92));
  border-bottom: 1px solid var(--seed-line);
  backdrop-filter: blur(10px);
}

.nav{
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding:12px 0;
  gap:14px;
}

.brand{
  display:flex;
  align-items:center;
  gap:12px;
}

.logoImg{
  height:44px;
  width:auto;
  display:block;
}

.brandText{
  font-weight:900;
  color: var(--seed-text);
  font-size:18px;
}

/* Menú desktop como botones */
.menu{
  display:flex;
  align-items:center;
  gap:10px;
}

.menu a{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding:10px 12px;
  border-radius:14px;
  border:1px solid rgba(0,0,0,.10);
  background: rgba(255,255,255,.55);
  color: var(--seed-text);
  font-size:14px;
  font-weight:800;
  transition: .18s ease;
}

.menu a:hover{
  background: rgba(255,255,255,.85);
  transform: translateY(-1px);
}

/* CTA */
.menu a.cta{
  border:1px solid rgba(0,0,0,.12);
  background: linear-gradient(135deg, var(--seed), var(--seed-2));
  color:#111;
  box-shadow: 0 10px 22px rgba(0,0,0,.10);
}
.menu a.cta:hover{ filter: brightness(1.02); }

/* Activo */
.menu a.active{
  border-color: rgba(43,174,79,.55);
  background: rgba(43,174,79,.14);
  color:#0f2a16;
  box-shadow: 0 10px 22px rgba(43,174,79,.12);
}

/* Burger + menú móvil */
.burger{
  display:none;
  width:44px; height:44px;
  border-radius:14px;
  border:1px solid rgba(0,0,0,.12);
  background: rgba(255,255,255,.65);
  color: var(--seed-text);
  cursor:pointer;
}

.mobileMenu{
  display:none;
  padding: 0 0 12px 0;
}
.mobileMenu.open{ display:block; }

.mobileMenu a{
  display:block;
  margin-top:10px;
  padding:12px 14px;
  border-radius:14px;
  border:1px solid rgba(0,0,0,.10);
  background: rgba(255,255,255,.70);
  color: var(--seed-text);
  font-weight:800;
}
.mobileMenu a:hover{ background: rgba(255,255,255,.92); }

/* ================= HERO ================= */
.hero{ padding:90px 0 60px; }

.heroGrid{
  display:grid;
  grid-template-columns: 1.1fr .9fr;
  gap:40px;
  align-items:center;
}

.pill{
  display:inline-flex;
  align-items:center;
  gap:8px;
  padding:8px 14px;
  border-radius:999px;
  background: rgba(43,174,79,.08);
  color: var(--brand);
  font-size:13px;
}

.dot{
  width:8px; height:8px;
  border-radius:999px;
  background: var(--brand);
}

h1{
  font-size: clamp(36px, 4vw, 54px);
  margin:20px 0;
  line-height:1.1;
  font-weight:900;
  background: linear-gradient(90deg, #1F8F3A, #2BAE4F);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
}

.titleWithIcon{
  display:flex;
  align-items:center;
  gap:14px;
  flex-wrap:wrap;
}
.titleIcon{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  width:42px; height:42px;
  border-radius:12px;
  background: linear-gradient(135deg, var(--brand), var(--brand2));
  color:#08101e;
}
.titleIcon svg{ width:22px; height:22px; }

.lead{
  color: var(--muted);
  font-size:17px;
  line-height:1.7;
}

.heroActions{
  display:flex;
  gap:14px;
  margin-top:24px;
  flex-wrap:wrap;
}

.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding:12px 18px;
  border-radius:14px;
  font-weight:700;
  border:1px solid var(--line);
  background:#fff;
  transition:.25s ease;
}
.btn:hover{ transform:translateY(-3px); }

.btn.primary{
  background: linear-gradient(135deg, var(--brand), var(--brand2));
  color:#08101e;
  border:none;
}

/* Stats */
.stats{
  margin-top:18px;
  display:flex;
  gap:10px;
  flex-wrap:wrap;
}
.stat{
  padding:12px 14px;
  border-radius:16px;
  border:1px solid rgba(0,0,0,.08);
  background: rgba(255,255,255,.75);
  min-width: 190px;
}
.stat b{ display:block; font-size:14px; }
.stat span{ display:block; color: var(--muted); font-size:13px; margin-top:4px; }

/* Card con vídeo */
.heroCard{
  position:relative;
  border-radius: var(--radius);
  overflow:hidden;
  min-height:340px;
  box-shadow: 0 18px 50px rgba(0,0,0,.14);
  border:1px solid rgba(0,0,0,.08);
}

.heroVideo{
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
  object-fit:cover;
}

/* Overlay para legibilidad */
.heroCard::after{
  content:"";
  position:absolute;
  inset:0;
  background: linear-gradient(180deg, rgba(0,0,0,.18), rgba(0,0,0,.62));
  pointer-events:none;
}

/* Asegura que overlay de contenido esté por encima */
.heroCard .overlay{
  position:absolute;
  inset:auto 0 0 0;
  padding:18px;
  display:grid;
  gap:10px;
  z-index:2;
}

/* Si mantienes <div class="img"> en HTML, lo anulamos para que no tape el vídeo */
.heroCard .img{ display:none !important; }

.miniCards{
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap:10px;
}
.mini{
  padding:12px;
  border-radius:16px;
  background: rgba(255,255,255,.14);
  border:1px solid rgba(255,255,255,.18);
  color:#fff;
}
.mini b{ display:block; font-size:13px; }
.mini span{ display:block; color: rgba(255,255,255,.85); font-size:12.5px; margin-top:4px; }

/* ================= SECTIONS ================= */
section{ padding:95px 0; }

.sectionTitle h2{
  font-size:30px;
  margin:0 0 10px 0;
}
.sectionTitle p{
  margin:0;
  color: var(--muted);
  line-height:1.7;
}

/* ================= GRID + TARJETAS ================= */
.grid3{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:24px;
  margin-top:30px;
}

.grid2{
  display:grid;
  grid-template-columns:repeat(2,1fr);
  gap:24px;
  margin-top:30px;
}

.card{
  background: rgba(43,174,79,.08);
  border: 1px solid rgba(43,174,79,.18);
  border-radius: var(--radius);
  padding:24px;
  box-shadow: var(--shadow);
  transition:.25s ease;
  overflow:hidden;
}

.card:hover{
  background: rgba(43,174,79,.14);
  transform: translateY(-5px);
  box-shadow: 0 16px 35px rgba(43,174,79,.20);
}

.card h3{ margin:0 0 8px 0; color:#1a1a1a; }
.card p{ margin:0; color:#3f3f3f; line-height:1.7; }

.badge{
  display:inline-block;
  padding:6px 12px;
  border-radius:999px;
  background: rgba(43,174,79,.15);
  color: var(--brand);
  font-size:12px;
  margin-bottom:12px;
}

/* Imágenes en tarjetas (Calidad) */
.cardImg{
  width:100%;
  height:180px;
  object-fit:cover;
  border-radius:14px;
  margin-bottom:16px;
  box-shadow: 0 6px 18px rgba(0,0,0,.08);
  transition:.4s ease;
}
.card:hover .cardImg{ transform: scale(1.05); }

/* ================= CONTACTO ================= */
.contactWrap{
  display:grid;
  grid-template-columns:1.1fr .9fr;
  gap:30px;
}

.form{ display:grid; gap:10px; }
.field{ display:grid; gap:6px; }

label{ font-size:13px; color: var(--muted); }

input, textarea{
  width:100%;
  padding:12px 14px;
  border-radius:12px;
  border:1px solid var(--line);
  background:#fff;
  font-family:inherit;
}
textarea{ min-height:120px; resize:vertical; }

input:focus, textarea:focus{
  border-color: var(--brand);
  outline:none;
}

.formActions{
  display:flex;
  gap:10px;
  flex-wrap:wrap;
  align-items:center;
}

.help{ color: var(--muted); font-size:12.5px; line-height:1.6; }

/* Mapa */
.mapContainer{
  position:relative;
  width:100%;
  border-radius:16px;
  overflow:hidden;
  box-shadow: 0 10px 25px rgba(0,0,0,.10);
  margin-top:14px;
}
.mapContainer iframe{
  width:100%;
  height:260px;
  border:0;
  display:block;
}

/* ================= FOOTER ================= */
footer{
  background:#f5f5f5;
  padding:30px 0;
  margin-top:60px;
  font-size:14px;
  color:var(--muted);
}

.foot{
  display:flex;
  justify-content:space-between;
  gap:12px;
  flex-wrap:wrap;
}
.footLinks{
  display:flex;
  gap:14px;
  flex-wrap:wrap;
}

/* ================= MODAL PRIVACIDAD ================= */
.modal{
  position:fixed;
  inset:0;
  display:none;
  z-index:10000;
}
.modal.open{ display:block; }

.modalBackdrop{
  position:absolute;
  inset:0;
  background: rgba(0,0,0,.55);
}

.modalDialog{
  position:relative;
  width: min(860px, 92vw);
  max-height: min(78vh, 780px);
  overflow:auto;
  margin: 10vh auto 0;
  border-radius: 18px;
  background:#fff;
  border:1px solid rgba(0,0,0,.10);
  box-shadow: 0 22px 70px rgba(0,0,0,.25);
  padding: 22px 22px 18px;
}

.modalClose{
  position:absolute;
  top:12px;
  right:12px;
  width:40px;
  height:40px;
  border-radius:12px;
  border:1px solid rgba(0,0,0,.10);
  background: rgba(0,0,0,.03);
  cursor:pointer;
  font-size:18px;
}

.modalDialog h2{
  margin: 0 44px 12px 0;
  color:#1F8F3A;
  font-weight:900;
}

.modalBody{
  color:#1a1a1a;
  line-height:1.7;
  font-size:14px;
}
.modalBody a{
  color:#1F8F3A;
  font-weight:700;
}

/* ================= RESPONSIVE ================= */
@media (max-width: 900px){
  .heroGrid,
  .grid3,
  .grid2,
  .contactWrap{
    grid-template-columns:1fr;
  }
}

@media (max-width: 820px){
  .menu{ display:none; }
  .burger{ display:inline-flex; align-items:center; justify-content:center; }
  .miniCards{ grid-template-columns:1fr; }
}
/* ===== Cookie Banner Sutil ===== */
.cookieBanner{
  position: fixed;
  bottom: 0;
  left: 0;
  right: 0;
  background: rgba(255,255,255,.96);
  border-top: 1px solid rgba(0,0,0,.08);
  box-shadow: 0 -6px 20px rgba(0,0,0,.08);
  padding: 14px 0;
  z-index: 9998;
  display: none;
}

.cookieBanner.show{
  display:block;
}

.cookieContent{
  width:min(1120px,92%);
  margin:0 auto;
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:20px;
  font-size:14px;
  color:#444;
}

.cookieContent a{
  color: var(--brand);
  font-weight:700;
}

.cookieBtn{
  background: linear-gradient(135deg, var(--brand), var(--brand2));
  border:none;
  padding:8px 14px;
  border-radius:10px;
  font-weight:700;
  cursor:pointer;
}
