:root{
  --eco-green:#34b84a;
  --eco-green-dark:#24943a;
  --eco-green-soft:#e9f8ec;
  --eco-orange:#ff681f;
  --eco-orange-soft:#fff1e9;
  --eco-blue:#095b8f;
  --eco-blue-soft:#e9f4fb;
  --eco-ink:#102f3d;
  --eco-muted:#536a78;
  --eco-bg:#f7fbf8;
  --eco-line:#dceee2;
  --eco-white:#fff;
}

*{ box-sizing:border-box; }

html{ scroll-behavior:smooth; }

body{
  margin:0;
  font-family:'Comfortaa', system-ui, -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
  color:var(--eco-ink);
  background:var(--eco-bg);
}

img{ max-width:100%; }

a{ color:inherit; }

.navbar{
  min-height:78px;
  background:rgba(247,251,248,.94);
  border-bottom:1px solid rgba(16,47,61,.08);
  backdrop-filter:blur(16px);
  transition:box-shadow .2s ease, background .2s ease;
}

.navbar.is-scrolled{
  background:rgba(247,251,248,.98);
  box-shadow:0 14px 34px rgba(16,47,61,.08);
}

.brand-logo{
  width:52px;
  height:52px;
  object-fit:contain;
  display:block;
}

.footer-logo{
  width:68px;
  height:68px;
  object-fit:contain;
  display:block;
  filter:drop-shadow(0 8px 18px rgba(0,0,0,.18));
}

.nav-link{
  color:var(--eco-ink);
  font-size:.94rem;
  font-weight:700;
  text-transform:uppercase;
}

.nav-link:hover,
.nav-link:focus{ color:var(--eco-green-dark); }

.resources-trigger{
  appearance:none;
  background:transparent;
  border:0;
  display:flex;
  align-items:center;
  gap:.35rem;
  padding:.5rem;
}

.resources-trigger i{
  font-size:.82rem;
  transition:transform .18s ease;
}

.nav-item-mega:hover .resources-trigger,
.nav-item-mega:focus-within .resources-trigger,
.navbar.mega-open .resources-trigger{ color:var(--eco-green-dark); }

.navbar.mega-open .resources-trigger i{ transform:rotate(180deg); }

.mega-menu{
  position:absolute;
  top:100%;
  left:0;
  width:100%;
  background:#fff;
  border-top:1px solid rgba(16,47,61,.08);
  border-bottom:1px solid rgba(16,47,61,.08);
  box-shadow:0 28px 58px rgba(16,47,61,.12);
  opacity:0;
  visibility:hidden;
  transform:translateY(-8px);
  transition:opacity .18s ease, transform .18s ease, visibility .18s ease;
}

.navbar.mega-open .mega-menu,
.navbar:has(.nav-item-mega:hover) .mega-menu,
.mega-menu:hover{
  opacity:1;
  visibility:visible;
  transform:translateY(0);
}

.mega-menu-grid{
  display:grid;
  grid-template-columns:repeat(3, minmax(0, 1fr));
  padding:3rem 0;
}

.mega-menu-column{
  display:grid;
  gap:2.6rem;
  padding:0 2.35rem;
  border-right:1px solid rgba(16,47,61,.14);
}

.mega-menu-column:first-child{ padding-left:0; }

.mega-menu-column:last-child{
  border-right:0;
  padding-right:0;
}

.mega-resource{
  display:grid;
  grid-template-columns:64px minmax(0, 1fr);
  gap:1.35rem;
}

.mega-resource > i{
  color:var(--eco-green);
  font-size:2.2rem;
  line-height:1;
  margin-top:.15rem;
}

.mega-resource h2{
  margin:0 0 .65rem;
  color:var(--eco-green);
  font-size:1.35rem;
  font-weight:700;
}

.mega-resource p{
  max-width:360px;
  margin:0 0 1rem;
  color:#3f3f3f;
  line-height:1.45;
}

.mega-resource a{
  display:block;
  width:max-content;
  max-width:100%;
  margin-top:.42rem;
  color:var(--eco-green-dark);
  font-weight:700;
  text-decoration:underline;
  text-underline-offset:3px;
}

.mega-resource a::before{
  content:"> ";
  text-decoration:none;
}

.navbar-toggler{
  border:1px solid var(--eco-line);
  padding:.55rem .7rem;
}

.btn-eco,
.btn-eco-outline{
  min-height:46px;
  border-radius:999px;
  padding:.72rem 1.1rem;
  display:inline-flex;
  align-items:center;
  gap:.5rem;
  font-weight:700;
  line-height:1;
}

.btn-eco{
  background:var(--eco-green);
  border:1px solid var(--eco-green);
  color:#fff;
  box-shadow:0 14px 28px rgba(36,148,58,.18);
}

.btn-eco:hover,
.btn-eco:focus{
  background:var(--eco-green-dark);
  border-color:var(--eco-green-dark);
  color:#fff;
  transform:translateY(-1px);
}

.btn-eco-outline{
  background:#fff;
  border:1px solid var(--eco-line);
  color:var(--eco-ink);
}

.btn-eco-outline:hover,
.btn-eco-outline:focus{
  border-color:var(--eco-blue);
  color:var(--eco-blue);
}

.hero{
  min-height:calc(100svh - 18px);
  padding:118px 0 46px;
  display:flex;
  align-items:center;
  background:
    linear-gradient(90deg, rgba(247,251,248,.98) 0%, rgba(247,251,248,.92) 45%, rgba(247,251,248,.18) 100%),
    url('../img/hero-sostenibilidad.jpg') center/cover no-repeat;
  border-bottom:1px solid rgba(16,47,61,.08);
}

.eyebrow{
  display:inline-flex;
  align-items:center;
  gap:.45rem;
  max-width:100%;
  border:1px solid var(--eco-line);
  background:rgba(255,255,255,.82);
  color:var(--eco-green-dark);
  border-radius:999px;
  padding:.48rem .78rem;
  font-size:.82rem;
  font-weight:700;
}

h1{
  max-width:780px;
  margin:1.2rem 0 0;
  font-size:clamp(2.5rem, 6vw, 5rem);
  font-weight:700;
  line-height:1.07;
}

.hero-text{
  max-width:680px;
  margin:1.25rem 0 0;
  color:var(--eco-muted);
  font-size:1.08rem;
  line-height:1.8;
}

.hero-strip{
  max-width:780px;
  margin-top:2.4rem;
  display:grid;
  grid-template-columns:repeat(3, minmax(0, 1fr));
  border:1px solid var(--eco-line);
  background:rgba(255,255,255,.88);
  box-shadow:0 22px 48px rgba(16,47,61,.09);
}

.hero-strip-item{
  padding:1rem;
  border-right:1px solid var(--eco-line);
}

.hero-strip-item:last-child{ border-right:0; }

.hero-strip strong{
  display:block;
  font-size:1.35rem;
  color:var(--eco-green-dark);
  line-height:1.1;
}

.hero-strip span{
  display:block;
  margin-top:.35rem;
  color:var(--eco-muted);
  font-size:.86rem;
  line-height:1.45;
}

.section-padding{ padding:82px 0; }

.section-kicker{
  display:inline-flex;
  align-items:center;
  gap:.45rem;
  color:var(--eco-green-dark);
  font-size:.84rem;
  font-weight:700;
  margin-bottom:.9rem;
}

.section-title{
  max-width:780px;
  font-size:clamp(2rem, 4vw, 3.25rem);
  line-height:1.13;
  font-weight:700;
  margin:0;
}

.section-subtitle{
  color:var(--eco-muted);
  line-height:1.75;
  font-size:1rem;
}

.resource-card,
.course-card,
.audience-card,
.news-card{
  height:100%;
  background:#fff;
  border:1px solid var(--eco-line);
  border-radius:8px;
  box-shadow:0 18px 38px rgba(16,47,61,.06);
}

.resource-card,
.audience-card,
.news-card{ padding:1.35rem; }

.resource-card{
  display:block;
  color:var(--eco-ink);
  text-decoration:none;
  transition:transform .18s ease, border-color .18s ease, box-shadow .18s ease;
}

.resource-card:hover,
.resource-card:focus{
  transform:translateY(-4px);
  border-color:rgba(255,104,31,.45);
  box-shadow:0 24px 48px rgba(16,47,61,.1);
  color:var(--eco-ink);
  outline:0;
}

.icon-box{
  width:44px;
  height:44px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  border-radius:8px;
  background:var(--eco-green-soft);
  color:var(--eco-green-dark);
  font-size:1.25rem;
  flex:0 0 auto;
}

#plataforma .row.g-4 > div:nth-child(3n+2) .icon-box,
#comunidad .row.g-4 > div:nth-child(2) .icon-box{ background:var(--eco-blue-soft); color:var(--eco-blue); }

#plataforma .row.g-4 > div:nth-child(3n+3) .icon-box,
#comunidad .row.g-4 > div:nth-child(3) .icon-box{ background:var(--eco-orange-soft); color:var(--eco-orange); }

.resource-card h3,
.audience-card h3,
.news-card h3{
  margin:1rem 0 .55rem;
  font-size:1.04rem;
  font-weight:700;
}

.resource-card p,
.audience-card p,
.news-card p{
  margin:0;
  color:var(--eco-muted);
  line-height:1.65;
  font-size:.94rem;
}

.course-card{ overflow:hidden; }

.course-cover{
  min-height:280px;
  display:flex;
  align-items:flex-end;
  padding:1.35rem;
  color:#fff;
  background:
    linear-gradient(180deg, rgba(16,47,61,.04), rgba(16,47,61,.76)),
    url('../img/curso-sostenibilidad.jpg') center/cover no-repeat;
}

.tag{
  display:inline-flex;
  border:1px solid rgba(255,255,255,.36);
  background:rgba(255,255,255,.18);
  border-radius:999px;
  padding:.38rem .72rem;
  color:#fff;
  font-size:.78rem;
  font-weight:700;
  backdrop-filter:blur(12px);
}

.feature-list{
  display:grid;
  gap:.85rem;
  margin:1.5rem 0 0;
  padding:0;
  list-style:none;
}

.feature-list li{
  display:flex;
  align-items:flex-start;
  gap:.75rem;
  color:var(--eco-muted);
  line-height:1.6;
}

.feature-list i{
  margin-top:.15rem;
  color:var(--eco-green-dark);
}

.audience-band{
  background:
    linear-gradient(135deg, rgba(9,91,143,.08), rgba(52,184,74,.12)),
    #fff;
  border-top:1px solid var(--eco-line);
  border-bottom:1px solid var(--eco-line);
}

.news-card{
  display:flex;
  flex-direction:column;
  gap:1rem;
}

.news-card img{
  width:100%;
  aspect-ratio:16/10;
  object-fit:cover;
  border-radius:8px;
}

.cta{
  background:var(--eco-ink);
  color:#fff;
  border-radius:8px;
  padding:2.4rem;
  overflow:hidden;
  position:relative;
}

.cta::before{
  content:"";
  position:absolute;
  inset:0;
  background:linear-gradient(120deg, rgba(52,184,74,.28), rgba(255,104,31,.18), rgba(9,91,143,.22));
  opacity:.95;
}

.cta > *{ position:relative; z-index:1; }

.cta p{ color:rgba(255,255,255,.82); }

.subscribe-cta-form{
  display:grid;
  grid-template-columns:1fr;
  gap:.75rem;
}

.subscribe-cta-form input{
  width:100%;
  min-height:54px;
  border:1px solid rgba(255,255,255,.34);
  border-radius:999px;
  background:rgba(255,255,255,.95);
  padding:.85rem 1.05rem;
  color:var(--eco-ink);
  font:inherit;
}

.subscribe-cta-form button{
  min-height:54px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:.45rem;
  border:0;
  border-radius:999px;
  background:#fff;
  color:var(--eco-ink);
  padding:.85rem 1.2rem;
  font:inherit;
  font-weight:700;
}

.subscribe-cta-form button:hover,
.subscribe-cta-form button:focus{
  background:var(--eco-green);
  color:#fff;
}

.subscribe-cta-status{
  margin:.8rem 0 0;
  font-size:.95rem;
  font-weight:700;
}

.subscribe-cta-status.is-ok{
  color:#bdf3c9;
}

.subscribe-cta-status.is-error{
  color:#ffd2c2;
}

.footer{
  background:#0d241c;
  color:rgba(255,255,255,.76);
  padding:54px 0 28px;
}

.footer a{
  color:rgba(255,255,255,.76);
  text-decoration:none;
}

.footer a:hover,
.footer a:focus{ color:#fff; }

.social-link{
  width:42px;
  height:42px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  border:1px solid rgba(255,255,255,.18);
  border-radius:999px;
}

.resource-page{
  min-height:100vh;
  background:
    linear-gradient(90deg, rgba(247,251,248,.98), rgba(247,251,248,.9)),
    url('../img/hero-sostenibilidad.jpg') center/cover no-repeat;
}

.resource-shell{
  min-height:100vh;
  padding:128px 0 54px;
  display:flex;
  align-items:center;
}

.resource-logo img{
  width:64px;
  height:64px;
  object-fit:contain;
  margin-bottom:2rem;
}

.resource-page-card{
  max-width:760px;
  background:rgba(255,255,255,.9);
  border:1px solid var(--eco-line);
  border-radius:8px;
  padding:2rem;
  box-shadow:0 24px 60px rgba(16,47,61,.1);
}

.resource-page-card h1{
  margin:.6rem 0 1rem;
}

.resource-page-card p{
  max-width:660px;
  color:var(--eco-muted);
  line-height:1.75;
  margin-bottom:1.6rem;
}

.puntos-body{
  background:#f6faf7;
}

.puntos-hero{
  padding:132px 0 44px;
  background:
    linear-gradient(135deg, rgba(52,184,74,.12), rgba(9,91,143,.08)),
    #f8fcf9;
  border-bottom:1px solid var(--eco-line);
}

.puntos-hero-grid{
  display:grid;
  grid-template-columns:minmax(0,1fr) auto;
  gap:2rem;
  align-items:end;
}

.puntos-hero h1{
  font-size:clamp(3.1rem, 8vw, 6.6rem);
  margin:.8rem 0 1rem;
}

.puntos-hero p{
  max-width:850px;
  color:var(--eco-muted);
  font-size:1.2rem;
  line-height:1.8;
  margin:0;
}

.puntos-hero-stats{
  min-width:180px;
  padding:1.2rem 1.35rem;
  border:1px solid var(--eco-line);
  border-radius:8px;
  background:#fff;
  box-shadow:0 16px 44px rgba(16,47,61,.08);
}

.puntos-hero-stats strong{
  display:block;
  color:var(--eco-green);
  font-size:2.6rem;
  line-height:1;
}

.puntos-hero-stats span{
  display:block;
  color:var(--eco-muted);
  margin-top:.45rem;
}

.puntos-map-section{
  padding:0;
}

.puntos-alert-section{
  padding:22px 0 0;
  background:#f6faf7;
}

.puntos-map-shell{
  display:grid;
  grid-template-columns:minmax(320px, 410px) minmax(0,1fr);
  gap:0;
  padding:0;
  border-bottom:1px solid var(--eco-line);
}

.puntos-panel{
  height:calc(100vh - 78px);
  min-height:720px;
  overflow:auto;
  padding:1.4rem;
  background:#fff;
  border-right:1px solid var(--eco-line);
}

.puntos-search{
  display:grid;
  gap:.7rem;
}

.puntos-search label{
  color:var(--eco-ink);
  font-weight:700;
}

.puntos-search-box{
  display:flex;
  align-items:center;
  gap:.65rem;
  border:1px solid var(--eco-line);
  border-radius:8px;
  background:#f8fbf9;
  padding:.85rem 1rem;
}

.puntos-search-box i{
  color:var(--eco-green);
}

.puntos-search-box input{
  width:100%;
  border:0;
  outline:0;
  background:transparent;
  color:var(--eco-ink);
}

.puntos-categories{
  display:flex;
  flex-wrap:wrap;
  gap:.55rem;
  margin:1.25rem 0;
}

.puntos-filter{
  display:inline-flex;
  align-items:center;
  gap:.4rem;
  border:1px solid rgba(16,47,61,.12);
  border-radius:999px;
  background:#fff;
  color:var(--eco-ink);
  padding:.48rem .75rem;
  font-weight:700;
  font-size:.86rem;
  line-height:1.1;
}

.puntos-filter::before{
  content:"";
  width:.6rem;
  height:.6rem;
  border-radius:999px;
  background:var(--marker-color, var(--eco-green));
}

.puntos-filter span{
  color:var(--eco-muted);
  font-weight:600;
}

.puntos-filter.is-active{
  border-color:rgba(52,184,74,.32);
  background:rgba(52,184,74,.1);
  color:var(--eco-green);
}

.puntos-results-heading{
  display:flex;
  align-items:baseline;
  gap:.4rem;
  color:var(--eco-muted);
  margin-bottom:.85rem;
}

.puntos-results-heading strong{
  color:var(--eco-ink);
  font-size:1.35rem;
}

.puntos-list{
  display:grid;
  gap:.7rem;
}

.puntos-list-item{
  display:grid;
  grid-template-columns:auto minmax(0,1fr);
  align-items:start;
  gap:.8rem;
  width:100%;
  border:1px solid var(--eco-line);
  border-radius:8px;
  background:#fff;
  color:var(--eco-ink);
  padding:.9rem;
  text-align:left;
  box-shadow:0 12px 30px rgba(16,47,61,.05);
}

.puntos-list-item:hover,
.puntos-list-item:focus{
  border-color:rgba(52,184,74,.36);
  box-shadow:0 16px 36px rgba(16,47,61,.08);
}

.puntos-list-dot{
  width:.9rem;
  height:.9rem;
  border-radius:999px;
  margin-top:.25rem;
  background:var(--marker-color, var(--eco-green));
  box-shadow:0 0 0 4px rgba(52,184,74,.12);
}

.puntos-list-item strong,
.puntos-list-item small{
  display:block;
}

.puntos-list-item strong{
  font-size:.98rem;
  margin-bottom:.25rem;
}

.puntos-list-item small{
  color:var(--eco-muted);
  line-height:1.45;
}

.puntos-map-wrap{
  min-width:0;
  background:#d7ecf1;
}

.puntos-map{
  width:100%;
  height:calc(100vh - 78px);
  min-height:720px;
}

.puntos-marker-wrap{
  background:transparent;
  border:0;
}

.puntos-marker{
  position:relative;
  display:block;
  width:34px;
  height:34px;
  background:var(--marker-color, var(--eco-green));
  border:3px solid #fff;
  border-radius:50% 50% 50% 0;
  transform:rotate(-45deg);
  box-shadow:0 6px 16px rgba(16,47,61,.28);
}

.puntos-marker::after{
  content:"";
  position:absolute;
  width:12px;
  height:12px;
  top:8px;
  left:8px;
  border-radius:50%;
  background:#fff;
}

.puntos-popup{
  min-width:220px;
}

.puntos-popup img{
  width:100%;
  max-height:120px;
  object-fit:contain;
  margin-bottom:.8rem;
  border-radius:8px;
  background:#fff;
}

.puntos-popup strong{
  display:block;
  color:var(--eco-ink);
  font-size:1rem;
  line-height:1.35;
}

.puntos-popup span{
  display:block;
  color:var(--eco-green);
  margin:.2rem 0 .4rem;
  font-weight:700;
}

.puntos-popup p{
  color:var(--eco-muted);
  margin:.35rem 0 .65rem;
}

.puntos-popup-place{
  margin:.2rem 0 .35rem !important;
  color:var(--eco-ink) !important;
  font-weight:700;
}

.puntos-popup div{
  display:flex;
  gap:.75rem;
  flex-wrap:wrap;
}

.puntos-popup a{
  color:var(--eco-green);
  font-weight:700;
  text-decoration:none;
}

.puntos-popup a:hover,
.puntos-popup a:focus{
  text-decoration:underline;
}

.puntos-cta-section{
  padding:64px 0;
}

.puntos-admin-section{
  padding:64px 0;
  background:#fff;
  border-top:1px solid var(--eco-line);
}

.puntos-admin-list{
  margin-top:2.4rem;
}

.puntos-admin-grid{
  display:grid;
  grid-template-columns:repeat(2, minmax(0, 1fr));
  gap:.9rem;
}

.puntos-admin-card{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:1rem;
  padding:1rem;
  border:1px solid var(--eco-line);
  border-radius:8px;
  background:#fff;
  box-shadow:0 12px 30px rgba(16,47,61,.05);
}

.puntos-admin-card > div:first-child{
  display:grid;
  grid-template-columns:auto minmax(0,1fr);
  gap:.8rem;
  align-items:start;
  min-width:0;
}

.puntos-admin-card strong,
.puntos-admin-card small{
  display:block;
}

.puntos-admin-card strong{
  color:var(--eco-ink);
}

.puntos-admin-card small{
  color:var(--eco-muted);
  line-height:1.5;
}

.puntos-cta{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:1.5rem;
  padding:2rem;
  border:1px solid var(--eco-line);
  border-radius:8px;
  background:#fff;
  box-shadow:0 18px 46px rgba(16,47,61,.07);
}

.puntos-cta h2{
  margin:.55rem 0 .6rem;
}

.puntos-cta p{
  max-width:740px;
  color:var(--eco-muted);
  margin:0;
  line-height:1.7;
}

.about-body{
  background:var(--eco-bg);
}

.about-header{
  padding:150px 0 72px;
  background:
    linear-gradient(90deg, rgba(247,251,248,.98) 0%, rgba(247,251,248,.9) 48%, rgba(247,251,248,.2) 100%),
    url('../img/guias-naturaleza.jpg') center/cover no-repeat;
  border-bottom:1px solid var(--eco-line);
}

.about-hero-grid{
  display:grid;
  grid-template-columns:minmax(0, 1fr) 340px;
  gap:3rem;
  align-items:end;
}

.about-hero-copy h1{
  margin:.85rem 0 1.15rem;
  font-size:clamp(2.35rem, 5.4vw, 4.8rem);
}

.about-hero-copy p{
  max-width:760px;
  margin:0;
  color:var(--eco-muted);
  font-size:1.08rem;
  line-height:1.8;
}

.about-hero-panel{
  background:rgba(255,255,255,.9);
  border:1px solid var(--eco-line);
  border-radius:8px;
  padding:1.4rem;
  box-shadow:0 24px 58px rgba(16,47,61,.11);
}

.about-hero-panel img{
  width:92px;
  height:92px;
  object-fit:contain;
  display:block;
  margin-bottom:1.2rem;
}

.about-hero-panel p{
  margin:0;
  color:var(--eco-muted);
  line-height:1.65;
}

.about-section{
  padding:76px 0;
}

.about-lead{
  margin:0 0 1.4rem;
  color:var(--eco-muted);
  font-size:1.03rem;
  line-height:1.8;
}

.about-pillar-grid{
  display:grid;
  grid-template-columns:repeat(3, minmax(0, 1fr));
  gap:1rem;
}

.about-pillar-card,
.about-value-card,
.about-statement-grid article{
  background:#fff;
  border:1px solid var(--eco-line);
  border-radius:8px;
  box-shadow:0 18px 38px rgba(16,47,61,.06);
}

.about-pillar-card{
  padding:1.2rem;
}

.about-pillar-card span{
  width:46px;
  height:46px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  border-radius:8px;
  background:var(--eco-green-soft);
  color:var(--eco-green-dark);
  font-size:1.25rem;
}

.about-pillar-card:nth-child(1) span{ background:var(--eco-blue-soft); color:var(--eco-blue); }
.about-pillar-card:nth-child(2) span{ background:var(--eco-orange-soft); color:var(--eco-orange); }

.about-pillar-card h3,
.about-value-card h3{
  margin:1rem 0 .55rem;
  font-size:1.02rem;
  font-weight:700;
}

.about-pillar-card p,
.about-value-card p{
  margin:0;
  color:var(--eco-muted);
  line-height:1.65;
  font-size:.92rem;
}

.about-mission-band{
  background:
    linear-gradient(135deg, rgba(9,91,143,.08), rgba(52,184,74,.12)),
    #fff;
  border-top:1px solid var(--eco-line);
  border-bottom:1px solid var(--eco-line);
}

.about-statement-grid{
  display:grid;
  grid-template-columns:repeat(2, minmax(0, 1fr));
  gap:1.2rem;
}

.about-statement-grid article{
  padding:1.6rem;
}

.about-statement-grid h2{
  margin:.45rem 0 .8rem;
  font-size:clamp(1.55rem, 2.6vw, 2.4rem);
  font-weight:700;
}

.about-statement-grid p{
  margin:0;
  color:var(--eco-muted);
  line-height:1.75;
}

.about-values-grid{
  display:grid;
  grid-template-columns:repeat(5, minmax(0, 1fr));
  gap:1rem;
}

.about-value-card{
  padding:1.15rem;
}

.contact-body{
  background:var(--eco-bg);
}

.contact-header{
  padding:150px 0 72px;
  background:
    linear-gradient(90deg, rgba(247,251,248,.98), rgba(247,251,248,.82)),
    url('../img/hero-sostenibilidad.jpg') center/cover no-repeat;
  border-bottom:1px solid var(--eco-line);
}

.contact-hero{
  max-width:820px;
}

.contact-hero h1{
  margin:.85rem 0 1rem;
}

.contact-hero p{
  max-width:720px;
  color:var(--eco-muted);
  font-size:1.08rem;
  line-height:1.8;
  margin:0;
}

.contact-section{
  padding:76px 0;
}

.sponsor-body{
  background:var(--eco-bg);
}

.sponsor-header{
  padding:132px 0 70px;
  background:
    linear-gradient(90deg, rgba(247,251,248,.98), rgba(247,251,248,.84)),
    url('../img/hero-sostenibilidad.jpg') center/cover no-repeat;
  border-bottom:1px solid var(--eco-line);
}

.sponsor-hero-grid{
  display:grid;
  grid-template-columns:minmax(0,1fr) minmax(280px, 390px);
  gap:2rem;
  align-items:center;
}

.sponsor-hero-grid h1{
  max-width:940px;
  margin:.7rem 0 1rem;
  font-size:clamp(3.1rem, 7vw, 6rem);
}

.sponsor-hero-grid p{
  max-width:800px;
  color:var(--eco-muted);
  font-size:1.15rem;
  line-height:1.8;
  margin:0;
}

.sponsor-hero-card{
  display:grid;
  gap:1rem;
  padding:1.5rem;
  border:1px solid var(--eco-line);
  border-radius:8px;
  background:#fff;
  box-shadow:0 18px 46px rgba(16,47,61,.08);
}

.sponsor-hero-card i{
  width:58px;
  height:58px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  border-radius:999px;
  background:var(--eco-green-soft);
  color:var(--eco-green);
  font-size:1.6rem;
}

.sponsor-hero-card strong{
  color:var(--eco-ink);
  font-size:1.35rem;
}

.sponsor-hero-card span{
  color:var(--eco-muted);
  line-height:1.7;
}

.sponsor-section{
  padding:74px 0;
}

.sponsor-impact-grid,
.sponsor-plan-grid{
  display:grid;
  grid-template-columns:repeat(3, minmax(0, 1fr));
  gap:1rem;
}

.sponsor-plan-grid{
  grid-template-columns:repeat(3, minmax(0, 1fr));
}

.sponsor-impact-card,
.sponsor-plan-card{
  border:1px solid var(--eco-line);
  border-radius:8px;
  background:#fff;
  box-shadow:0 14px 34px rgba(16,47,61,.06);
}

.sponsor-impact-card{
  padding:1.35rem;
}

.sponsor-impact-card span,
.sponsor-plan-head > span{
  width:48px;
  height:48px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  border-radius:999px;
  background:var(--eco-green-soft);
  color:var(--eco-green);
  font-size:1.25rem;
}

.sponsor-impact-card h3{
  margin:1rem 0 .55rem;
}

.sponsor-impact-card p{
  color:var(--eco-muted);
  line-height:1.7;
  margin:0;
}

.sponsor-plan-card{
  display:flex;
  flex-direction:column;
  gap:1.25rem;
  padding:2rem 1.5rem 1.5rem;
}

.sponsor-plan-head{
  display:flex;
  flex-direction:column;
  align-items:center;
  text-align:center;
  gap:1rem;
}

.sponsor-plan-head > span{
  width:auto;
  height:auto;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  border-radius:0;
  background:transparent;
  color:var(--plan-color, var(--eco-green));
  font-size:1.05rem;
  font-weight:700;
}

.sponsor-plan-head h3{
  margin:0;
  color:var(--eco-ink);
  font-size:1.55rem;
}

.sponsor-plan-head img{
  width:min(220px, 72%);
  aspect-ratio:1;
  object-fit:contain;
  display:block;
}

.sponsor-plan-head p,
.sponsor-plan-card li span{
  color:var(--eco-muted);
  line-height:1.6;
}

.sponsor-price{
  padding:.25rem 1rem 1rem;
  border-radius:8px;
  background:transparent;
  text-align:center;
}

.sponsor-price strong{
  display:block;
  color:var(--eco-ink);
  font-size:2.05rem;
  line-height:1;
}

.sponsor-price span{
  color:var(--eco-muted);
  font-size:1rem;
}

.sponsor-plan-card ul{
  display:grid;
  gap:.75rem;
  padding:0;
  margin:0;
  list-style:none;
  flex:1;
}

.sponsor-plan-card li{
  display:grid;
  grid-template-columns:auto minmax(0,1fr);
  gap:.55rem;
}

.sponsor-plan-card li i{
  color:var(--plan-color, var(--eco-green));
  margin-top:.2rem;
}

.sponsor-plan-card .btn{
  width:100%;
  justify-content:center;
}

.sponsor-ods-section{
  background:#fff;
}

.sponsor-ods-grid{
  display:grid;
  grid-template-columns:minmax(0,1fr) minmax(280px, 430px);
  gap:2rem;
  align-items:center;
}

.sponsor-ods-grid h2{
  margin:.6rem 0 1.35rem;
  font-size:clamp(2.4rem, 5vw, 4.6rem);
}

.sponsor-ods-list{
  display:grid;
  gap:1rem;
  max-width:780px;
}

.sponsor-ods-list p{
  display:grid;
  grid-template-columns:auto minmax(0,1fr);
  gap:1rem;
  margin:0;
  color:var(--eco-muted);
  font-size:1.05rem;
  line-height:1.75;
}

.sponsor-ods-list i{
  color:var(--eco-ink);
  font-size:1.45rem;
  margin-top:.15rem;
}

.sponsor-ods-card{
  padding:1.5rem;
  border:1px solid var(--eco-line);
  border-radius:8px;
  background:#e9eef2;
  box-shadow:0 18px 42px rgba(16,47,61,.07);
}

.sponsor-ods-card img{
  width:96px;
  height:96px;
  object-fit:contain;
  margin-bottom:1.2rem;
}

.sponsor-ods-card p{
  color:#334b56;
  line-height:1.8;
  margin-bottom:1.2rem;
}

.sponsor-ods-card a{
  display:inline-flex;
  align-items:center;
  gap:.45rem;
  color:var(--eco-green);
  font-weight:700;
  text-decoration:none;
}

.sponsor-ods-card a:hover,
.sponsor-ods-card a:focus{
  color:var(--eco-green-dark);
  text-decoration:underline;
  text-underline-offset:4px;
}

.sponsor-note{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:1.5rem;
  padding:2rem;
  border:1px solid var(--eco-line);
  border-radius:8px;
  background:#fff;
  box-shadow:0 18px 46px rgba(16,47,61,.07);
}

.sponsor-note h2{
  margin:.55rem 0 .6rem;
}

.sponsor-note p{
  max-width:840px;
  color:var(--eco-muted);
  line-height:1.75;
  margin:0;
}

.contact-layout{
  display:grid;
  grid-template-columns:minmax(0, .78fr) minmax(0, 1.22fr);
  gap:1.4rem;
  align-items:start;
}

.contact-info-panel,
.contact-form-panel{
  background:#fff;
  border:1px solid var(--eco-line);
  border-radius:8px;
  box-shadow:0 18px 38px rgba(16,47,61,.06);
}

.contact-info-panel{
  padding:1.6rem;
  position:sticky;
  top:104px;
}

.contact-info-panel h2,
.contact-form-panel h2{
  margin:.45rem 0 .8rem;
  font-size:clamp(1.55rem, 2.8vw, 2.35rem);
  font-weight:700;
}

.contact-info-panel p{
  color:var(--eco-muted);
  line-height:1.75;
  margin:0 0 1.2rem;
}

.contact-email-card{
  display:flex;
  align-items:center;
  gap:1rem;
  padding:1rem;
  border:1px solid var(--eco-line);
  border-radius:8px;
  background:var(--eco-green-soft);
  color:var(--eco-ink);
  text-decoration:none;
}

.contact-email-card i{
  width:44px;
  height:44px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  border-radius:8px;
  background:var(--eco-green);
  color:#fff;
  flex:0 0 auto;
}

.contact-email-card strong{
  display:block;
  margin-bottom:.2rem;
}

.contact-form-panel{
  padding:1.4rem;
}

.contact-form{
  box-shadow:none;
}

.contact-quick-grid{
  display:grid;
  grid-template-columns:repeat(4, minmax(0, 1fr));
  gap:1rem;
}

.contact-quick-grid a{
  display:grid;
  gap:.6rem;
  min-height:100%;
  padding:1.25rem;
  background:#fff;
  border:1px solid var(--eco-line);
  border-radius:8px;
  color:var(--eco-ink);
  text-decoration:none;
  box-shadow:0 16px 34px rgba(16,47,61,.06);
}

.contact-quick-grid i{
  width:46px;
  height:46px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  border-radius:8px;
  background:var(--eco-blue-soft);
  color:var(--eco-blue);
  font-size:1.25rem;
}

.contact-quick-grid a:nth-child(2) i{ background:var(--eco-green-soft); color:var(--eco-green-dark); }
.contact-quick-grid a:nth-child(3) i{ background:var(--eco-orange-soft); color:var(--eco-orange); }
.contact-quick-grid a:nth-child(4) i{ background:var(--eco-blue-soft); color:var(--eco-blue); }

.contact-quick-grid strong{
  font-size:1.05rem;
}

.contact-quick-grid span{
  color:var(--eco-muted);
  line-height:1.65;
  font-size:.92rem;
}

.jobs-body{
  background:#f8faf8;
}

.jobs-header{
  padding:140px 0 54px;
  background:
    linear-gradient(90deg, rgba(247,251,248,.98), rgba(247,251,248,.84)),
    url('../img/guias-naturaleza.jpg') center/cover no-repeat;
  border-bottom:1px solid var(--eco-line);
}

.jobs-section{
  padding:70px 0;
}

.jobs-toolbar{
  display:flex;
  align-items:end;
  justify-content:space-between;
  gap:1.25rem;
  margin-bottom:1.4rem;
}

.jobs-toolbar h2{
  margin:0;
  font-size:clamp(1.8rem, 3vw, 2.45rem);
  font-weight:700;
}

.jobs-toolbar p{
  color:var(--eco-muted);
  margin:.35rem 0 0;
}

.jobs-grid{
  display:grid;
  grid-template-columns:repeat(2, minmax(0, 1fr));
  gap:1rem;
}

.job-card{
  display:grid;
  grid-template-columns:116px minmax(0, 1fr);
  gap:1.1rem;
  background:#fff;
  border:1px solid rgba(16,47,61,.08);
  border-radius:8px;
  padding:1.2rem;
  box-shadow:0 14px 30px rgba(16,47,61,.07);
}

.job-card-logo{
  width:116px;
  height:116px;
  display:flex;
  align-items:center;
  justify-content:center;
  border-radius:8px;
  background:linear-gradient(180deg, #fff, #f8faf8);
  border:1px solid var(--eco-line);
  overflow:hidden;
}

.job-card-logo img{
  width:100%;
  height:100%;
  object-fit:contain;
  padding:.7rem;
}

.job-card-logo span{
  color:var(--eco-green-dark);
  font-size:2rem;
  font-weight:700;
}

.job-company{
  display:inline-flex;
  color:var(--eco-green-dark);
  font-size:.85rem;
  font-weight:700;
  margin-bottom:.35rem;
}

.job-card h3{
  margin:0 0 .65rem;
  font-size:1.3rem;
  font-weight:700;
}

.job-card h3 a{
  color:inherit;
  text-decoration:none;
}

.job-card h3 a:hover,
.job-card h3 a:focus{
  color:var(--eco-green-dark);
  text-decoration:underline;
  text-underline-offset:4px;
}

.job-card p{
  color:var(--eco-muted);
  line-height:1.65;
  margin:0;
}

.job-meta{
  display:flex;
  flex-wrap:wrap;
  gap:.7rem 1rem;
  margin-top:1rem;
  color:#4d5f68;
  font-size:.88rem;
}

.job-meta span{
  display:inline-flex;
  align-items:center;
  gap:.4rem;
}

.job-actions{
  display:flex;
  align-items:baseline;
  flex-wrap:wrap;
  gap:.65rem;
  margin-top:1.1rem;
}

.job-actions form{
  display:inline-flex;
  align-items:baseline;
  margin:0;
}

.job-actions button{
  appearance:none;
  border:0;
  background:transparent;
  color:#b42318;
  padding:0;
  font:inherit;
  font-weight:700;
  line-height:1.2;
  text-decoration:underline;
  text-underline-offset:4px;
  cursor:pointer;
}

.job-actions .directory-edit-link{
  margin-top:0;
}

.jobs-empty{
  grid-column:1 / -1;
}

.jobs-form-section{
  background:#fff;
  border-top:1px solid var(--eco-line);
}

.blog-body{
  background:#f8faf8;
}

.blog-header{
  padding:140px 0 58px;
  background:
    linear-gradient(90deg, rgba(247,251,248,.98), rgba(247,251,248,.78)),
    url('../img/blog-energia.jpg') center/cover no-repeat;
  border-bottom:1px solid var(--eco-line);
}

.blog-hero{
  max-width:850px;
}

.blog-hero h1{
  margin:.85rem 0 1rem;
}

.blog-hero p{
  max-width:720px;
  color:var(--eco-muted);
  font-size:1.06rem;
  line-height:1.75;
  margin:0;
}

.blog-section{
  padding:70px 0;
}

.blog-toolbar{
  display:flex;
  align-items:end;
  justify-content:space-between;
  gap:1.25rem;
  margin-bottom:1rem;
}

.blog-toolbar h2{
  margin:0;
  font-size:clamp(1.8rem, 3vw, 2.45rem);
  font-weight:700;
}

.blog-toolbar p{
  color:var(--eco-muted);
  margin:.35rem 0 0;
}

.blog-category-strip{
  display:flex;
  gap:.55rem;
  overflow:auto;
  padding:.4rem 0 1.25rem;
}

.blog-category-strip a{
  min-height:40px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  border:1px solid var(--eco-line);
  border-radius:999px;
  background:#fff;
  color:var(--eco-ink);
  padding:.58rem .9rem;
  font-size:.86rem;
  font-weight:700;
  text-decoration:none;
  white-space:nowrap;
}

.blog-category-strip a:hover,
.blog-category-strip a:focus,
.blog-category-strip a.is-active{
  background:var(--eco-green);
  border-color:var(--eco-green);
  color:#fff;
}

.blog-grid{
  display:grid;
  grid-template-columns:repeat(3, minmax(0, 1fr));
  gap:1rem;
}

.blog-empty{
  grid-column:1 / -1;
}

.blog-card{
  display:flex;
  flex-direction:column;
  min-height:100%;
  background:#fff;
  border:1px solid rgba(16,47,61,.08);
  border-radius:8px;
  overflow:hidden;
  box-shadow:0 14px 30px rgba(16,47,61,.07);
}

.blog-cover{
  display:flex;
  align-items:center;
  justify-content:center;
  width:100%;
  aspect-ratio:16/10;
  background:linear-gradient(135deg, var(--eco-blue-soft), var(--eco-green-soft));
  color:var(--eco-green-dark);
  text-decoration:none;
}

.blog-cover img{
  width:100%;
  height:100%;
  object-fit:cover;
}

.blog-cover span{
  width:58px;
  height:58px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  border-radius:999px;
  background:rgba(255,255,255,.82);
  font-size:1.5rem;
}

.blog-card-content{
  display:flex;
  flex-direction:column;
  flex:1;
  padding:1.2rem;
}

.blog-meta{
  display:flex;
  align-items:center;
  flex-wrap:wrap;
  gap:.5rem;
  margin-bottom:.8rem;
}

.blog-meta span{
  min-height:30px;
  display:inline-flex;
  align-items:center;
  border:1px solid var(--eco-line);
  border-radius:999px;
  background:var(--eco-green-soft);
  color:var(--eco-green-dark);
  padding:.36rem .68rem;
  font-size:.76rem;
  font-weight:700;
}

.blog-meta .blog-status{
  background:var(--eco-blue-soft);
  color:var(--eco-blue);
}

.blog-card h3{
  margin:0 0 .7rem;
  font-size:1.25rem;
  font-weight:700;
  line-height:1.28;
}

.blog-card h3 a{
  color:inherit;
  text-decoration:none;
}

.blog-card h3 a:hover,
.blog-card h3 a:focus{
  color:var(--eco-green-dark);
  text-decoration:underline;
  text-underline-offset:4px;
}

.blog-card p{
  color:var(--eco-muted);
  line-height:1.65;
  margin:0;
}

.blog-card-footer{
  display:flex;
  flex-wrap:wrap;
  gap:.65rem 1rem;
  margin-top:1rem;
  color:#4d5f68;
  font-size:.88rem;
}

.blog-card-footer span{
  display:inline-flex;
  align-items:center;
  gap:.4rem;
}

.home-blog-link{
  display:inline-flex;
  align-items:center;
  gap:.45rem;
}

.blog-actions{
  display:flex;
  align-items:baseline;
  flex-wrap:wrap;
  gap:.75rem;
  margin-top:auto;
  padding-top:1rem;
}

.blog-actions form{
  margin:0;
}

.blog-actions button{
  appearance:none;
  border:0;
  background:transparent;
  color:#b42318;
  padding:0;
  font:inherit;
  font-weight:700;
  line-height:1.2;
  text-decoration:underline;
  text-underline-offset:4px;
  cursor:pointer;
}

.blog-form-section{
  background:#fff;
  border-top:1px solid var(--eco-line);
}

.blog-detail-main{
  padding:132px 0 72px;
}

.blog-detail{
  max-width:1040px;
  margin:0 auto;
  background:#fff;
  border:1px solid rgba(16,47,61,.08);
  border-radius:8px;
  overflow:hidden;
  box-shadow:0 18px 46px rgba(16,47,61,.12);
}

.blog-detail-cover,
.blog-detail-placeholder{
  width:100%;
  aspect-ratio:16/7;
}

.blog-detail-cover{
  display:block;
  object-fit:cover;
}

.blog-detail-placeholder{
  display:flex;
  align-items:center;
  justify-content:center;
  background:linear-gradient(135deg, var(--eco-blue-soft), var(--eco-green-soft));
  color:var(--eco-green-dark);
  font-size:2.2rem;
}

.blog-detail-content{
  padding:2rem;
}

.blog-detail-content h1{
  margin:.7rem 0 1rem;
  max-width:900px;
  font-size:clamp(2rem, 4.2vw, 3.4rem);
  line-height:1.14;
}

.blog-detail-excerpt{
  max-width:850px;
  color:var(--eco-muted);
  font-size:1.06rem;
  line-height:1.75;
  margin:0;
}

.blog-article-body{
  margin-top:2rem;
  padding-top:2rem;
  border-top:1px solid rgba(16,47,61,.08);
  color:#334b56;
  font-size:1.04rem;
  line-height:1.9;
  overflow-wrap:anywhere;
}

.blog-article-body p,
.blog-article-body ul,
.blog-article-body ol{
  margin-bottom:1.1rem;
}

.blog-article-body ul,
.blog-article-body ol{
  padding-left:1.5rem;
}

.blog-article-body li{
  margin-bottom:.45rem;
}

.blog-article-body a{
  color:var(--eco-blue);
  font-weight:700;
}

.blog-detail-actions{
  margin-top:2rem;
  padding-top:0;
}

.admin-body{
  min-height:100vh;
  background:
    linear-gradient(90deg, rgba(247,251,248,.98), rgba(247,251,248,.82)),
    url('../img/hero-sostenibilidad.jpg') center/cover no-repeat;
}

.admin-login-shell{
  min-height:100vh;
  display:flex;
  align-items:center;
  justify-content:center;
  padding:2rem;
}

.admin-login-card{
  width:min(100%, 480px);
  background:#fff;
  border:1px solid rgba(16,47,61,.08);
  border-radius:8px;
  padding:1.6rem;
  box-shadow:0 24px 58px rgba(16,47,61,.13);
}

.admin-login-card img{
  width:70px;
  height:70px;
  object-fit:contain;
  display:block;
  margin-bottom:1.1rem;
}

.admin-login-card h1{
  margin:.45rem 0 .7rem;
  font-size:clamp(2rem, 4vw, 3rem);
}

.admin-login-card p{
  color:var(--eco-muted);
  line-height:1.7;
  margin:0 0 1.2rem;
}

.admin-panel-shell{
  min-height:100vh;
  display:grid;
  grid-template-columns:280px minmax(0, 1fr);
}

.admin-sidebar{
  position:sticky;
  top:0;
  min-height:100vh;
  display:flex;
  flex-direction:column;
  gap:1.25rem;
  padding:1.25rem;
  background:#0d241c;
  color:rgba(255,255,255,.78);
}

.admin-brand{
  display:flex;
  align-items:center;
  gap:.75rem;
  color:#fff;
  text-decoration:none;
  font-weight:700;
  font-size:1.1rem;
}

.admin-brand img{
  width:52px;
  height:52px;
  object-fit:contain;
}

.admin-nav{
  display:grid;
  gap:.45rem;
}

.admin-nav a,
.admin-sidebar-footer a{
  display:flex;
  align-items:center;
  gap:.6rem;
  border-radius:8px;
  color:rgba(255,255,255,.78);
  text-decoration:none;
}

.admin-nav a{
  padding:.8rem .9rem;
}

.admin-nav a:hover,
.admin-nav a:focus,
.admin-nav a.is-active{
  background:rgba(255,255,255,.1);
  color:#fff;
}

.admin-sidebar-footer{
  display:grid;
  gap:.7rem;
  margin-top:auto;
  padding-top:1rem;
  border-top:1px solid rgba(255,255,255,.14);
}

.admin-sidebar-footer span{
  color:#fff;
  font-weight:700;
}

.admin-sidebar-footer a{
  padding:0;
}

.admin-content{
  padding:2rem;
}

.admin-content-header{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:1rem;
  margin-bottom:1.25rem;
}

.admin-content-header h1{
  margin:.45rem 0 0;
  font-size:clamp(2.4rem, 5vw, 4.6rem);
}

.admin-header-actions{
  display:flex;
  align-items:center;
  justify-content:flex-end;
  gap:.75rem;
  flex-wrap:wrap;
}

.admin-grid{
  display:grid;
  grid-template-columns:minmax(280px, 390px) minmax(0, 1fr);
  gap:1rem;
  align-items:start;
}

.admin-dashboard-grid{
  display:grid;
  grid-template-columns:repeat(4, minmax(0, 1fr));
  gap:1rem;
}

.admin-stat-card{
  min-height:176px;
  display:grid;
  align-content:space-between;
  gap:1rem;
  border:1px solid var(--eco-line);
  border-radius:8px;
  background:#fff;
  padding:1.25rem;
  color:var(--eco-ink);
  text-decoration:none;
  box-shadow:0 14px 34px rgba(16,47,61,.06);
  transition:transform .18s ease, box-shadow .18s ease, border-color .18s ease;
}

.admin-stat-card:hover,
.admin-stat-card:focus{
  color:var(--eco-ink);
  border-color:rgba(52,184,74,.35);
  box-shadow:0 20px 42px rgba(16,47,61,.1);
  transform:translateY(-2px);
}

.admin-stat-card span{
  width:52px;
  height:52px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  border-radius:999px;
  background:var(--eco-green-soft);
  color:var(--eco-green-dark);
  font-size:1.35rem;
}

.admin-stat-card strong{
  display:block;
  font-size:clamp(2.4rem, 5vw, 4rem);
  line-height:1;
}

.admin-stat-card small{
  color:var(--eco-muted);
  font-size:.95rem;
  font-weight:700;
  text-transform:uppercase;
}

.admin-card{
  border:1px solid var(--eco-line);
  border-radius:8px;
  background:#fff;
  padding:1.25rem;
  box-shadow:0 14px 34px rgba(16,47,61,.06);
}

.admin-card h2{
  margin:0 0 1rem;
  font-size:1.35rem;
}

.admin-card .directory-form,
.admin-modal .directory-form,
.admin-modal .modal-body{
  display:grid;
  gap:.75rem;
}

.admin-modal{
  border:0;
  border-radius:8px;
  box-shadow:0 24px 70px rgba(16,47,61,.22);
  max-height:calc(100vh - 3.5rem);
  overflow:hidden;
}

.admin-modal > .directory-form{
  min-height:0;
  max-height:inherit;
  display:flex;
  flex-direction:column;
}

.admin-modal .modal-body{
  min-height:0;
  overflow-y:auto;
  overscroll-behavior:contain;
}

.admin-modal .modal-header,
.admin-modal .modal-footer{
  flex:0 0 auto;
  border-color:rgba(16,47,61,.08);
}

.admin-modal .modal-title{
  color:var(--eco-ink);
  font-size:1.35rem;
  font-weight:700;
}

.admin-form-note{
  color:var(--eco-muted);
  line-height:1.5;
}

.admin-check{
  display:flex;
  align-items:center;
  gap:.7rem;
  margin:.45rem 0;
  color:var(--eco-ink);
  font-weight:700;
}

.admin-check input{
  appearance:none;
  width:48px;
  height:28px;
  min-height:0;
  flex:0 0 auto;
  border:1px solid var(--eco-line);
  border-radius:999px;
  background:#dfe8e2;
  padding:0;
  position:relative;
  cursor:pointer;
  transition:background .18s ease, border-color .18s ease;
}

.admin-check input::before{
  content:"";
  position:absolute;
  width:22px;
  height:22px;
  top:2px;
  left:2px;
  border-radius:999px;
  background:#fff;
  box-shadow:0 2px 6px rgba(16,47,61,.18);
  transition:transform .18s ease;
}

.admin-check input:checked{
  background:var(--eco-green);
  border-color:var(--eco-green);
}

.admin-check input:checked::before{
  transform:translateX(20px);
}

.admin-check input:focus{
  outline:0;
  box-shadow:0 0 0 .2rem rgba(52,184,74,.16);
}

.admin-table-wrap{
  width:100%;
  overflow:auto;
}

.admin-table{
  width:100%;
  min-width:640px;
  border-collapse:separate;
  border-spacing:0;
}

.admin-table-wide{
  min-width:920px;
}

.admin-table th,
.admin-table td{
  padding:.85rem .75rem;
  border-bottom:1px solid rgba(16,47,61,.08);
  color:var(--eco-muted);
  vertical-align:middle;
}

.admin-table th{
  color:var(--eco-ink);
  font-size:.82rem;
  text-transform:uppercase;
}

.admin-table td:first-child{
  color:var(--eco-ink);
  font-weight:700;
}

.admin-status{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:30px;
  border-radius:999px;
  padding:.35rem .75rem;
  background:#eef2f4;
  color:var(--eco-muted);
  font-size:.78rem;
  font-weight:700;
}

.admin-status.is-active{
  background:var(--eco-green-soft);
  color:var(--eco-green-dark);
}

.admin-status.is-muted{
  background:#eef2f4;
  color:var(--eco-muted);
}

.admin-row-actions{
  display:flex;
  align-items:baseline;
  justify-content:flex-end;
  gap:.75rem;
  white-space:nowrap;
}

.admin-row-actions a,
.admin-row-actions button{
  border:0;
  background:transparent;
  padding:0;
  color:var(--eco-blue);
  font:inherit;
  font-weight:700;
  text-decoration:underline;
  text-underline-offset:4px;
}

.admin-row-actions button{
  color:#b31d14;
}

.admin-row-actions form{
  margin:0;
}

.calendar-body{
  background:#f8faf8;
}

.calendar-header{
  padding:140px 0 54px;
  background:
    linear-gradient(90deg, rgba(247,251,248,.98), rgba(247,251,248,.84)),
    url('../img/hero-sostenibilidad.jpg') center/cover no-repeat;
  border-bottom:1px solid var(--eco-line);
}

.calendar-section{
  padding:70px 0;
}

.calendar-shell{
  display:grid;
  grid-template-columns:300px minmax(0, 1fr);
  gap:1.4rem;
  align-items:start;
}

.calendar-sidebar,
.calendar-main,
.calendar-events-panel{
  background:#fff;
  border:1px solid rgba(16,47,61,.08);
  border-radius:8px;
  box-shadow:0 16px 34px rgba(16,47,61,.07);
}

.calendar-sidebar{
  position:sticky;
  top:104px;
  padding:1rem;
}

.calendar-filter-block + .calendar-filter-block{
  margin-top:1.2rem;
  padding-top:1.2rem;
  border-top:1px solid rgba(16,47,61,.08);
}

.calendar-filter-block > span,
.calendar-filter-heading{
  margin-bottom:.7rem;
}

.calendar-filter-block > span{
  display:block;
  color:var(--eco-ink);
  font-weight:700;
}

.calendar-filter-heading{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:.75rem;
}

.calendar-filter-heading span{
  color:var(--eco-ink);
  font-weight:700;
}

.calendar-filter-heading a{
  color:var(--eco-green-dark);
  font-size:.82rem;
  font-weight:700;
  text-decoration:underline;
  text-underline-offset:3px;
}

.calendar-chip-grid,
.calendar-category-list{
  display:flex;
  flex-wrap:wrap;
  gap:.5rem;
}

.calendar-chip-grid a,
.calendar-category-list a{
  min-height:38px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  border:1px solid var(--eco-line);
  border-radius:999px;
  background:#f8faf8;
  color:var(--eco-ink);
  padding:.5rem .72rem;
  font-size:.85rem;
  font-weight:700;
  text-decoration:none;
}

.calendar-chip-grid a:hover,
.calendar-chip-grid a:focus,
.calendar-chip-grid a.is-active,
.calendar-category-list a:hover,
.calendar-category-list a:focus,
.calendar-category-list a.is-active{
  background:var(--eco-green);
  border-color:var(--eco-green);
  color:#fff;
}

.calendar-year-grid a{
  min-width:70px;
}

.calendar-main{
  padding:1.2rem;
}

.calendar-main-header{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:1rem;
  margin-bottom:1rem;
}

.calendar-main-header h2{
  margin:0;
  font-size:clamp(1.7rem, 3vw, 2.35rem);
  font-weight:700;
}

.calendar-weekdays,
.calendar-grid{
  display:grid;
  grid-template-columns:repeat(7, minmax(0, 1fr));
}

.calendar-weekdays{
  gap:.45rem;
  margin-bottom:.45rem;
}

.calendar-weekdays span{
  color:var(--eco-muted);
  font-size:.78rem;
  font-weight:700;
  text-align:center;
  text-transform:uppercase;
}

.calendar-grid{
  gap:.45rem;
}

.calendar-day{
  min-height:118px;
  border:1px solid var(--eco-line);
  border-radius:8px;
  background:#fbfdfb;
  padding:.65rem;
}

.calendar-day.is-empty{
  background:#f3f7f4;
  border-style:dashed;
}

.calendar-day.has-events{
  background:#fff;
  border-color:rgba(52,184,74,.45);
}

.calendar-day-number{
  width:30px;
  height:30px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  border-radius:999px;
  color:var(--eco-ink);
  font-weight:700;
  margin-bottom:.55rem;
}

.calendar-day.has-events .calendar-day-number{
  background:var(--eco-green-soft);
  color:var(--eco-green-dark);
}

.calendar-event-pill{
  display:block;
  margin-top:.35rem;
  padding:.38rem .45rem;
  border-radius:8px;
  background:var(--eco-green-soft);
  color:var(--eco-green-dark);
  font-size:.75rem;
  font-weight:700;
  line-height:1.35;
  text-decoration:none;
}

.calendar-events-panel{
  margin-top:1.4rem;
  padding:1.2rem;
}

.calendar-events-header{
  display:flex;
  align-items:flex-end;
  justify-content:space-between;
  gap:1rem;
  margin-bottom:1rem;
}

.calendar-events-header h2{
  margin:0;
  font-size:clamp(1.55rem, 2.6vw, 2.2rem);
  font-weight:700;
}

.calendar-events-list{
  display:grid;
  gap:.9rem;
}

.calendar-event-card{
  display:grid;
  grid-template-columns:74px minmax(0, 1fr);
  gap:1rem;
  border:1px solid var(--eco-line);
  border-radius:8px;
  padding:1rem;
  background:#fff;
}

.calendar-event-card time{
  width:74px;
  height:74px;
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  border-radius:8px;
  background:var(--eco-green);
  color:#fff;
  line-height:1;
}

.calendar-event-card time strong{
  font-size:1.7rem;
}

.calendar-event-card time span{
  margin-top:.25rem;
  font-size:.82rem;
  font-weight:700;
  text-transform:uppercase;
}

.calendar-category{
  display:inline-flex;
  margin-bottom:.45rem;
  color:var(--eco-green-dark);
  font-size:.82rem;
  font-weight:700;
}

.calendar-event-card h3{
  margin:0 0 .45rem;
  font-size:1.2rem;
  font-weight:700;
}

.calendar-event-card h3 a{
  color:inherit;
  text-decoration:none;
}

.calendar-event-card h3 a:hover,
.calendar-event-card h3 a:focus{
  color:var(--eco-green-dark);
  text-decoration:underline;
  text-underline-offset:4px;
}

.calendar-event-card p{
  margin:0;
  color:var(--eco-muted);
  line-height:1.65;
}

.calendar-event-meta{
  display:flex;
  flex-wrap:wrap;
  gap:.65rem 1rem;
  margin-top:.8rem;
  color:#4d5f68;
  font-size:.88rem;
}

.calendar-event-meta span,
.calendar-event-meta a{
  display:inline-flex;
  align-items:center;
  gap:.4rem;
  color:inherit;
  font-weight:700;
  text-decoration:none;
}

.calendar-event-meta a{
  color:var(--eco-green-dark);
  text-decoration:underline;
  text-underline-offset:3px;
}

.calendar-event-actions{
  display:flex;
  align-items:baseline;
  flex-wrap:wrap;
  gap:.8rem;
  margin-top:.85rem;
}

.calendar-event-actions form{
  margin:0;
}

.calendar-event-actions button{
  appearance:none;
  border:0;
  background:transparent;
  color:#b42318;
  padding:0;
  font:inherit;
  font-weight:700;
  line-height:1.2;
  text-decoration:underline;
  text-underline-offset:4px;
  cursor:pointer;
}

.calendar-manage-panel{
  margin-top:1.4rem;
  padding:1.4rem;
  background:#fff;
  border:1px solid rgba(16,47,61,.08);
  border-radius:8px;
  box-shadow:0 16px 34px rgba(16,47,61,.07);
}

.calendar-check{
  width:max-content;
  max-width:100%;
  display:inline-flex;
  align-items:center;
  gap:.6rem;
  margin:0;
  color:var(--eco-ink);
  font-weight:700;
  line-height:1.2;
  cursor:pointer;
}

.calendar-check input{
  appearance:auto;
  width:18px !important;
  min-width:18px;
  max-width:18px;
  height:18px !important;
  min-height:18px !important;
  margin:0 !important;
  padding:0;
  flex:0 0 18px;
  accent-color:var(--eco-green);
}

.directory-form .calendar-check input{
  width:18px !important;
}

.directory-body{
  background:#f8faf8;
}

.calendar-detail-date{
  flex-direction:column;
  gap:.3rem;
  background:var(--eco-green);
  color:#fff;
}

.calendar-detail-date strong{
  font-size:4rem;
  line-height:1;
}

.calendar-detail-date span{
  color:#fff;
  font-size:1.1rem;
  font-weight:700;
}

.directory-header{
  padding:140px 0 54px;
  background:
    linear-gradient(90deg, rgba(247,251,248,.98), rgba(247,251,248,.86)),
    url('../img/hero-sostenibilidad.jpg') center/cover no-repeat;
  border-bottom:1px solid var(--eco-line);
}

.directory-topbar{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:1rem;
  margin-bottom:64px;
}

.directory-logo img{
  width:58px;
  height:58px;
  object-fit:contain;
}

.directory-actions{
  display:flex;
  gap:.75rem;
  flex-wrap:wrap;
}

.directory-hero{
  max-width:850px;
}

.directory-hero h1{
  margin:.8rem 0 1rem;
}

.directory-hero p{
  max-width:720px;
  color:var(--eco-muted);
  font-size:1.06rem;
  line-height:1.75;
  margin:0;
}

.directory-section{
  padding:64px 0;
}

.directory-alert{
  border-radius:8px;
  margin-bottom:1.5rem;
}

.directory-tabs{
  display:flex;
  flex-wrap:wrap;
  gap:.8rem;
  margin-bottom:2rem;
}

.directory-tabs a{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:44px;
  padding:.7rem 1rem;
  border:1px solid var(--eco-line);
  border-radius:999px;
  background:#fff;
  color:var(--eco-ink);
  font-weight:700;
  text-decoration:none;
}

.directory-tabs a.is-active{
  background:var(--eco-green);
  border-color:var(--eco-green);
  color:#fff;
}

.directory-layout{
  display:grid;
  grid-template-columns:310px minmax(0, 1fr);
  gap:1.6rem;
  align-items:start;
}

.directory-filter-panel{
  position:sticky;
  top:98px;
  background:#fff;
  border:1px solid rgba(16,47,61,.08);
  border-radius:8px;
  box-shadow:0 14px 30px rgba(16,47,61,.07);
  overflow:hidden;
}

.directory-filter-header{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:1rem;
  padding:1rem 1.05rem;
  border-bottom:1px solid rgba(16,47,61,.08);
  font-weight:700;
}

.directory-filter-header strong{
  min-width:34px;
  height:28px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  border-radius:999px;
  background:var(--eco-green-soft);
  color:var(--eco-green-dark);
  font-size:.85rem;
}

.directory-filter-list{
  display:grid;
  max-height:690px;
  overflow:auto;
  padding:.45rem;
}

.directory-filter-link{
  display:grid;
  grid-template-columns:38px minmax(0, 1fr) auto;
  align-items:center;
  gap:.75rem;
  padding:.72rem .7rem;
  border-radius:8px;
  color:var(--eco-ink);
  text-decoration:none;
}

.directory-filter-link:hover,
.directory-filter-link:focus,
.directory-filter-link.is-active{
  background:var(--eco-green-soft);
  color:var(--eco-green-dark);
}

.directory-filter-icon{
  width:38px;
  height:38px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  border-radius:8px;
  background:#f3f7f4;
  color:var(--eco-green);
  font-size:1.08rem;
}

.directory-filter-link.is-active .directory-filter-icon{
  background:var(--eco-green);
  color:#fff;
}

.directory-filter-link span:nth-child(2){
  min-width:0;
  font-size:.92rem;
  font-weight:700;
  line-height:1.35;
}

.directory-filter-link strong{
  color:var(--eco-muted);
  font-size:.82rem;
}

.directory-results{
  min-width:0;
}

.directory-toolbar{
  display:flex;
  align-items:end;
  justify-content:space-between;
  gap:1.25rem;
  margin-bottom:1.25rem;
}

.directory-toolbar h2{
  margin:0;
  font-size:clamp(1.8rem, 3vw, 2.45rem);
  font-weight:700;
}

.directory-toolbar p{
  color:var(--eco-muted);
  margin:.35rem 0 0;
}

.directory-search{
  position:relative;
  width:min(100%, 360px);
  flex:0 0 auto;
}

.directory-search i{
  position:absolute;
  left:1rem;
  top:50%;
  transform:translateY(-50%);
  color:var(--eco-muted);
}

.directory-search input{
  width:100%;
  min-height:48px;
  border:1px solid var(--eco-line);
  border-radius:999px;
  background:#fff;
  padding:.75rem 1rem .75rem 2.75rem;
  color:var(--eco-ink);
  font:inherit;
  box-shadow:0 10px 24px rgba(16,47,61,.06);
}

.directory-list{
  display:grid;
  gap:1.6rem;
}

.directory-card{
  position:relative;
  display:grid;
  grid-template-columns:240px minmax(0, 1fr);
  background:#fff;
  border:1px solid rgba(16,47,61,.08);
  border-radius:8px;
  box-shadow:0 12px 28px rgba(16,47,61,.09);
  overflow:hidden;
}

.directory-like-button{
  position:absolute;
  top:1.25rem;
  right:1.25rem;
  z-index:2;
  width:42px;
  height:42px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  border:0;
  background:#fff;
  color:#f3122f;
  border-radius:999px;
  font-size:1.35rem;
}

.directory-like-button.is-liked{
  background:#fff3f5;
}

.directory-card-logo{
  min-height:236px;
  display:flex;
  align-items:center;
  justify-content:center;
  padding:1.5rem;
  background:linear-gradient(180deg, #fff, #f8faf8);
}

.directory-card-logo img{
  width:100%;
  max-width:230px;
  max-height:160px;
  object-fit:contain;
}

.directory-card-logo span{
  width:150px;
  height:150px;
  display:flex;
  align-items:center;
  justify-content:center;
  border-radius:999px;
  background:var(--eco-green-soft);
  color:var(--eco-green-dark);
  font-size:3rem;
  font-weight:700;
}

.directory-card-content{
  padding:1.7rem 4.2rem 1.3rem 1.4rem;
}

.directory-card-content h3{
  margin:0 0 .75rem;
  font-size:1.65rem;
  font-weight:700;
}

.directory-card-content h3 a{
  color:inherit;
  text-decoration:none;
}

.directory-card-content h3 a:hover,
.directory-card-content h3 a:focus{
  color:var(--eco-green-dark);
}

.directory-card-content p{
  max-width:760px;
  color:var(--eco-muted);
  line-height:1.65;
  margin:0 0 1rem;
}

.directory-contact-list{
  display:grid;
  gap:.45rem;
}

.directory-contact-list a,
.directory-contact-list span{
  display:flex;
  align-items:flex-start;
  gap:.75rem;
  color:#4d4d4d;
  font-size:1.08rem;
  line-height:1.45;
  text-decoration:none;
  overflow-wrap:anywhere;
}

.directory-contact-list i{
  color:#808080;
  margin-top:.12rem;
}

.directory-socials{
  display:flex;
  gap:.5rem;
  margin-top:1rem;
}

.directory-socials a{
  width:36px;
  height:36px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  border:1px solid var(--eco-line);
  border-radius:999px;
  color:var(--eco-green-dark);
  text-decoration:none;
}

.directory-profile-link{
  display:inline-flex;
  align-items:center;
  margin-top:1rem;
  color:var(--eco-green-dark);
  font-weight:700;
  text-decoration:underline;
  text-underline-offset:4px;
}

.directory-card-actions{
  display:flex;
  align-items:baseline;
  gap:1rem;
  flex-wrap:wrap;
}

.directory-card-actions form,
.glossary-card-actions form,
.entity-delete-form{
  display:inline-flex;
  align-items:baseline;
  margin:0;
}

.directory-card-actions button,
.glossary-card-actions button{
  display:inline-flex;
  align-items:baseline;
  appearance:none;
  border:0;
  background:transparent;
  color:#b42318;
  padding:0;
  font:inherit;
  font-weight:700;
  line-height:1.2;
  text-decoration:underline;
  text-underline-offset:4px;
  cursor:pointer;
}

.directory-card-actions .directory-profile-link,
.directory-card-actions .directory-edit-link{
  margin-top:0;
}

.directory-edit-link,
.directory-cancel-edit{
  display:inline-flex;
  margin-top:1rem;
  color:var(--eco-blue);
  font-weight:700;
  text-decoration:underline;
  text-underline-offset:4px;
}

.directory-current-logo{
  display:block;
  margin-top:.45rem;
  color:var(--eco-muted);
  line-height:1.45;
}

.entity-header{
  padding:140px 0 78px;
  background:
    linear-gradient(90deg, rgba(247,251,248,.98), rgba(247,251,248,.78)),
    url('../img/hero-sostenibilidad.jpg') center/cover no-repeat;
  border-bottom:1px solid var(--eco-line);
}

.entity-main{
  margin-top:-58px;
  padding-bottom:70px;
}

.entity-profile{
  background:#fff;
  border:1px solid rgba(16,47,61,.08);
  border-radius:8px;
  box-shadow:0 18px 46px rgba(16,47,61,.12);
  overflow:hidden;
}

.entity-identity{
  position:relative;
  display:grid;
  grid-template-columns:280px minmax(0, 1fr);
  gap:2rem;
  align-items:center;
  padding:2.2rem 5rem 2.2rem 2.2rem;
}

.entity-logo{
  min-height:220px;
  display:flex;
  align-items:center;
  justify-content:center;
  border-radius:8px;
  background:linear-gradient(180deg, #fff, #f8faf8);
}

.entity-logo img{
  max-width:220px;
  max-height:150px;
  object-fit:contain;
}

.entity-logo span{
  width:150px;
  height:150px;
  display:flex;
  align-items:center;
  justify-content:center;
  border-radius:999px;
  background:var(--eco-green-soft);
  color:var(--eco-green-dark);
  font-size:3rem;
  font-weight:700;
}

.entity-title-block h1{
  margin:.8rem 0 1rem;
}

.entity-title-block p{
  max-width:760px;
  color:var(--eco-muted);
  font-size:1.05rem;
  line-height:1.75;
  margin:0;
}

.entity-actions{
  grid-column:2;
  display:flex;
  flex-wrap:wrap;
  gap:.75rem;
}

.entity-category{
  display:inline-flex;
  align-items:center;
  gap:.55rem;
  color:var(--eco-green-dark);
  font-weight:700;
}

.entity-like{
  top:1.4rem;
  right:1.4rem;
  box-shadow:0 10px 22px rgba(16,47,61,.08);
}

.entity-info-grid{
  display:grid;
  grid-template-columns:1.35fr .65fr;
  gap:1px;
  background:rgba(16,47,61,.08);
}

.entity-info-card{
  background:#fff;
  padding:2rem 2.2rem;
}

.entity-info-card h2{
  margin:0 0 1.2rem;
  font-size:1.35rem;
  font-weight:700;
}

.entity-detail-list{
  display:grid;
  gap:1rem;
}

.entity-detail-list div{
  display:grid;
  gap:.25rem;
}

.entity-detail-list span{
  color:var(--eco-muted);
  font-size:.86rem;
  font-weight:700;
  text-transform:uppercase;
}

.entity-detail-list a{
  color:var(--eco-ink);
  font-size:1.05rem;
  text-decoration:none;
  overflow-wrap:anywhere;
}

.entity-detail-list a:hover,
.entity-detail-list a:focus{
  color:var(--eco-green-dark);
}

.entity-stats span{
  display:inline-flex;
  align-items:center;
  gap:.6rem;
  font-size:1.15rem;
}

.entity-stats i{
  color:#f3122f;
}

.entity-socials{
  margin-top:1.2rem;
}

.entity-related{
  padding-top:3rem;
}

.entity-related h2{
  margin:.5rem 0 1.2rem;
  font-size:clamp(1.6rem, 3vw, 2.25rem);
  font-weight:700;
}

.entity-related-grid{
  display:grid;
  grid-template-columns:repeat(3, minmax(0, 1fr));
  gap:1rem;
}

.entity-related-card{
  display:grid;
  gap:.55rem;
  background:#fff;
  border:1px solid rgba(16,47,61,.08);
  border-radius:8px;
  padding:1.2rem;
  color:var(--eco-ink);
  text-decoration:none;
  box-shadow:0 12px 26px rgba(16,47,61,.08);
}

.entity-related-card span{
  width:120px;
  height:74px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  border-radius:8px;
  background:#f8faf8;
  color:var(--eco-green-dark);
  font-weight:700;
}

.entity-related-card img{
  max-width:100%;
  max-height:58px;
  object-fit:contain;
}

.entity-related-card small{
  color:var(--eco-muted);
}

.directory-card-footer{
  grid-column:2;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:1rem;
  min-height:74px;
  padding:.9rem 1.6rem .9rem 1.4rem;
  border-top:1px solid rgba(16,47,61,.1);
  color:#4d4d4d;
  font-size:1.12rem;
}

.directory-card-footer > span{
  display:flex;
  align-items:center;
  gap:.65rem;
}

.directory-card-footer .bi-heart-fill{
  color:#808080;
  font-size:1.35rem;
}

.directory-card-category i{
  width:48px;
  height:48px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  border-radius:999px;
  background:#f0f0f0;
  color:var(--eco-green);
}

.directory-empty{
  background:#fff;
  border:1px dashed var(--eco-line);
  border-radius:8px;
  padding:2rem;
  text-align:center;
}

.directory-empty i{
  color:var(--eco-green);
  font-size:2rem;
}

.directory-empty h3{
  margin:.8rem 0 .5rem;
  font-weight:700;
}

.directory-empty p{
  color:var(--eco-muted);
  margin:0;
}

.directory-form-section{
  background:#fff;
  border-top:1px solid var(--eco-line);
}

.directory-form-shell{
  display:grid;
  grid-template-columns:minmax(0, .75fr) minmax(0, 1.25fr);
  gap:3rem;
  align-items:start;
}

.directory-form-shell h2{
  font-size:clamp(1.8rem, 3vw, 2.5rem);
  font-weight:700;
  margin:.6rem 0 1rem;
}

.directory-form-shell p{
  color:var(--eco-muted);
  line-height:1.75;
  margin:0;
}

.directory-form{
  background:var(--eco-bg);
  border:1px solid var(--eco-line);
  border-radius:8px;
  padding:1.4rem;
}

.directory-form label{
  display:block;
  margin-bottom:.45rem;
  color:var(--eco-ink);
  font-weight:700;
  font-size:.9rem;
}

.directory-form input,
.directory-form select,
.directory-form textarea{
  width:100%;
  min-height:46px;
  border:1px solid var(--eco-line);
  border-radius:8px;
  background:#fff;
  padding:.75rem .85rem;
  color:var(--eco-ink);
  font:inherit;
}

.directory-form textarea{
  resize:vertical;
}

.directory-form .admin-check input[type="checkbox"]{
  appearance:none;
  width:48px;
  height:28px;
  min-height:0;
  flex:0 0 48px;
  border:1px solid var(--eco-line);
  border-radius:999px;
  background:#dfe8e2;
  padding:0;
  position:relative;
  cursor:pointer;
  transition:background .18s ease, border-color .18s ease;
}

.directory-form .admin-check input[type="checkbox"]::before{
  content:"";
  position:absolute;
  width:22px;
  height:22px;
  top:2px;
  left:2px;
  border-radius:999px;
  background:#fff;
  box-shadow:0 2px 6px rgba(16,47,61,.18);
  transition:transform .18s ease;
}

.directory-form .admin-check input[type="checkbox"]:checked{
  background:var(--eco-green);
  border-color:var(--eco-green);
}

.directory-form .admin-check input[type="checkbox"]:checked::before{
  transform:translateX(20px);
}

.directory-form .admin-check input[type="checkbox"]:focus{
  outline:0;
  box-shadow:0 0 0 .2rem rgba(52,184,74,.16);
}

.blog-editor-toolbar{
  display:flex;
  flex-wrap:wrap;
  gap:.4rem;
  margin-bottom:.55rem;
}

.blog-editor-toolbar button{
  width:42px;
  height:38px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  border:1px solid var(--eco-line);
  border-radius:8px;
  background:#fff;
  color:var(--eco-ink);
  font-size:1.1rem;
}

.blog-editor-toolbar button:hover,
.blog-editor-toolbar button:focus{
  border-color:rgba(52,184,74,.35);
  color:var(--eco-green);
}

.blog-rich-editor{
  height:430px;
  max-height:430px;
  width:100%;
  border:1px solid var(--eco-line);
  border-radius:8px;
  background:#fff;
  padding:1rem;
  color:var(--eco-ink);
  line-height:1.7;
  outline:none;
  overflow-y:auto;
}

.blog-rich-editor:focus{
  border-color:rgba(52,184,74,.55);
  box-shadow:0 0 0 .2rem rgba(52,184,74,.12);
}

.blog-rich-editor:empty::before{
  content:attr(data-placeholder);
  color:var(--eco-muted);
}

.blog-rich-editor p,
.blog-rich-editor ul,
.blog-rich-editor ol{
  margin:0 0 1rem;
}

.blog-rich-editor ul,
.blog-rich-editor ol{
  padding-left:1.4rem;
}

.blog-rich-editor li{
  margin:.25rem 0;
}

.blog-editor-source{
  display:none;
}

.glossary-header{
  background:
    linear-gradient(90deg, rgba(247,251,248,.98), rgba(247,251,248,.84)),
    url('../img/guias-naturaleza.jpg') center/cover no-repeat;
}

.glossary-hero{
  max-width:940px;
}

.glossary-tabs a{
  gap:.65rem;
}

.glossary-tabs span{
  min-width:30px;
  height:26px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  border-radius:999px;
  background:rgba(16,47,61,.08);
  font-size:.82rem;
}

.glossary-tabs a.is-active span{
  background:rgba(255,255,255,.22);
  color:#fff;
}

.glossary-panel{
  background:#fff;
  border:1px solid rgba(16,47,61,.08);
  border-radius:8px;
  padding:1.35rem;
  box-shadow:0 16px 34px rgba(16,47,61,.07);
}

.glossary-toolbar{
  display:flex;
  align-items:flex-end;
  justify-content:space-between;
  gap:1.25rem;
  padding-bottom:1.15rem;
  border-bottom:1px solid rgba(16,47,61,.08);
}

.glossary-toolbar h2{
  margin:0;
  font-size:clamp(1.8rem, 3vw, 2.45rem);
  font-weight:700;
}

.glossary-toolbar p{
  margin:.35rem 0 0;
  color:var(--eco-muted);
}

.glossary-search{
  width:min(100%, 430px);
}

.glossary-letter-strip{
  display:flex;
  gap:.5rem;
  overflow:auto;
  padding:1rem 0 1.2rem;
}

.glossary-letter-strip a{
  min-width:42px;
  min-height:40px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  border:1px solid var(--eco-line);
  border-radius:8px;
  background:#f8faf8;
  color:var(--eco-ink);
  font-weight:700;
  text-decoration:none;
}

.glossary-letter-strip a:first-child{
  min-width:72px;
}

.glossary-letter-strip a:hover,
.glossary-letter-strip a:focus,
.glossary-letter-strip a.is-active{
  background:var(--eco-green);
  border-color:var(--eco-green);
  color:#fff;
}

.glossary-grid{
  display:grid;
  grid-template-columns:repeat(2, minmax(0, 1fr));
  gap:1rem;
}

.glossary-card{
  display:flex;
  flex-direction:column;
  min-height:100%;
  border:1px solid rgba(16,47,61,.08);
  border-radius:8px;
  background:linear-gradient(180deg, #fff, #fbfdfb);
  padding:1.25rem;
  box-shadow:0 10px 24px rgba(16,47,61,.06);
}

.glossary-card-top{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:1rem;
  margin-bottom:1rem;
}

.glossary-letter{
  width:44px;
  height:44px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  border-radius:8px;
  background:var(--eco-green-soft);
  color:var(--eco-green-dark);
  font-size:1.2rem;
  font-weight:700;
}

.glossary-category{
  min-height:32px;
  display:inline-flex;
  align-items:center;
  border:1px solid var(--eco-line);
  border-radius:999px;
  padding:.38rem .72rem;
  color:var(--eco-muted);
  font-size:.78rem;
  font-weight:700;
}

.glossary-card h3{
  margin:0 0 .7rem;
  font-size:1.55rem;
  font-weight:700;
}

.glossary-card p{
  margin:0;
  color:var(--eco-muted);
  line-height:1.72;
}

.glossary-context{
  display:grid;
  gap:.35rem;
  margin-top:1rem;
  padding-top:1rem;
  border-top:1px solid rgba(16,47,61,.08);
}

.glossary-context strong{
  color:var(--eco-green-dark);
  font-size:.82rem;
  text-transform:uppercase;
}

.glossary-context span{
  color:#4d4d4d;
  line-height:1.65;
}

.glossary-edit-link{
  margin-top:0;
}

.glossary-card-actions{
  display:flex;
  align-items:baseline;
  flex-wrap:wrap;
  gap:1rem;
  margin-top:auto;
  padding-top:1rem;
}

.glossary-empty{
  grid-column:1 / -1;
}

.glossary-pagination{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:1rem;
  margin-top:1.25rem;
  padding-top:1.25rem;
  border-top:1px solid rgba(16,47,61,.08);
}

.glossary-pagination > div{
  display:flex;
  align-items:center;
  justify-content:center;
  gap:.45rem;
  flex-wrap:wrap;
}

.glossary-pagination a,
.glossary-pagination span{
  min-width:40px;
  min-height:40px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:.35rem;
  border-radius:8px;
  color:var(--eco-ink);
  font-weight:700;
  text-decoration:none;
}

.glossary-pagination > a{
  min-width:124px;
  padding:0 .85rem;
  border:1px solid var(--eco-line);
  background:#fff;
}

.glossary-pagination > div a{
  border:1px solid var(--eco-line);
  background:#f8faf8;
}

.glossary-pagination a:hover,
.glossary-pagination a:focus,
.glossary-pagination a.is-active{
  background:var(--eco-green);
  border-color:var(--eco-green);
  color:#fff;
}

.glossary-pagination a.is-disabled{
  pointer-events:none;
  opacity:.45;
}

@media(max-width:991px){
  .navbar{ min-height:70px; }
  .brand-logo{ width:48px; height:48px; }
  .resources-trigger{
    width:100%;
    justify-content:flex-start;
  }
  .mega-menu{
    position:static;
    max-height:0;
    overflow:hidden;
    border:0;
    box-shadow:none;
    opacity:1;
    visibility:visible;
    transform:none;
    transition:max-height .2s ease;
  }
  .navbar.mega-open .mega-menu{
    max-height:calc(100vh - 70px);
    overflow-y:auto;
    overscroll-behavior:contain;
  }
  .mega-menu-grid{
    grid-template-columns:1fr;
    padding:.45rem 0 1rem;
  }
  .mega-menu-column{
    gap:0;
    padding:0;
    border-right:0;
  }
  .mega-menu-column + .mega-menu-column{
    margin-top:0;
    padding-top:0;
    border-top:0;
  }
  .mega-resource{
    display:block;
    padding:.95rem 0;
    border-bottom:1px solid rgba(16,47,61,.1);
  }
  .mega-menu-column:last-child .mega-resource:last-child{ border-bottom:0; }
  .mega-resource > i,
  .mega-resource p{ display:none; }
  .mega-resource h2{
    margin:0 0 .45rem;
    font-size:1rem;
  }
  .mega-resource a{
    width:100%;
    margin-top:.25rem;
    font-size:.95rem;
    line-height:1.35;
    overflow-wrap:anywhere;
  }
  .hero{
    padding:104px 0 42px;
    background:
      linear-gradient(180deg, rgba(247,251,248,.98) 0%, rgba(247,251,248,.9) 62%, rgba(247,251,248,.34) 100%),
      url('../img/hero-sostenibilidad.jpg') center/cover no-repeat;
  }
  .hero-strip{ grid-template-columns:1fr; }
  .hero-strip-item{ border-right:0; border-bottom:1px solid var(--eco-line); }
  .hero-strip-item:last-child{ border-bottom:0; }
  .about-hero-grid,
  .about-statement-grid{
    grid-template-columns:1fr;
  }
  .about-hero-panel{
    max-width:420px;
  }
  .sponsor-hero-grid,
  .sponsor-impact-grid,
  .sponsor-ods-grid,
  .sponsor-plan-grid{
    grid-template-columns:1fr;
  }
  .sponsor-hero-card{
    max-width:460px;
  }
  .sponsor-note{
    align-items:flex-start;
    flex-direction:column;
  }
  .about-pillar-grid{
    grid-template-columns:1fr;
  }
  .about-values-grid{
    grid-template-columns:repeat(2, minmax(0, 1fr));
  }
  .contact-layout,
  .contact-quick-grid,
  .jobs-grid,
  .blog-grid{
    grid-template-columns:1fr;
  }
  .blog-toolbar{
    align-items:flex-start;
    flex-direction:column;
  }
  .calendar-shell{
    grid-template-columns:1fr;
  }
  .calendar-sidebar{
    position:static;
  }
  .calendar-main-header{
    align-items:flex-start;
    flex-direction:column;
  }
  .calendar-events-header{
    align-items:flex-start;
    flex-direction:column;
  }
  .jobs-toolbar{
    align-items:flex-start;
    flex-direction:column;
  }
  .contact-info-panel{
    position:static;
  }
  .directory-layout{
    grid-template-columns:1fr;
  }
  .directory-filter-panel{
    position:static;
  }
  .directory-filter-list{
    display:flex;
    gap:.45rem;
    max-height:none;
    overflow:auto;
    padding:.65rem;
  }
  .directory-filter-link{
    min-width:230px;
  }
  .directory-card{
    grid-template-columns:1fr;
  }
  .directory-card-logo{
    min-height:180px;
    justify-content:flex-start;
  }
  .directory-card-content{
    padding:0 1.4rem 1.4rem;
  }
  .directory-card-footer{
    grid-column:1;
  }
  .directory-form-shell{
    grid-template-columns:1fr;
  }
  .directory-toolbar{
    align-items:flex-start;
    flex-direction:column;
  }
  .glossary-toolbar{
    align-items:flex-start;
    flex-direction:column;
  }
  .directory-search{
    width:100%;
  }
  .glossary-grid{
    grid-template-columns:1fr;
  }
  .glossary-pagination{
    align-items:stretch;
    flex-direction:column;
  }
  .glossary-pagination > a{
    width:100%;
  }
  .entity-identity,
  .entity-info-grid,
  .entity-related-grid{
    grid-template-columns:1fr;
  }
  .entity-actions{
    grid-column:1;
  }
  .entity-identity{
    padding:1.4rem;
  }
  .puntos-hero-grid{
    grid-template-columns:1fr;
    align-items:start;
  }
  .puntos-hero-stats{
    max-width:220px;
  }
  .puntos-map-shell{
    grid-template-columns:1fr;
  }
  .puntos-panel,
  .puntos-map{
    height:auto;
    min-height:0;
  }
  .puntos-panel{
    border-right:0;
    border-bottom:1px solid var(--eco-line);
  }
  .puntos-map{
    height:70vh;
    min-height:460px;
  }
  .puntos-list{
    grid-template-columns:repeat(2, minmax(0, 1fr));
  }
  .puntos-admin-grid{
    grid-template-columns:1fr;
  }
  .puntos-cta{
    align-items:flex-start;
    flex-direction:column;
  }
  .admin-panel-shell{
    grid-template-columns:1fr;
  }
  .admin-sidebar{
    position:static;
    min-height:auto;
  }
  .admin-content{
    padding:1.25rem;
  }
  .admin-content-header{
    align-items:flex-start;
    flex-direction:column;
  }
  .admin-header-actions{
    width:100%;
    justify-content:flex-start;
  }
  .admin-dashboard-grid{
    grid-template-columns:repeat(2, minmax(0, 1fr));
  }
  .admin-grid{
    grid-template-columns:1fr;
  }
}

@media(max-width:575px){
  .section-padding{ padding:62px 0; }
  .cta{ padding:1.6rem; }
  .btn-eco,
  .btn-eco-outline{ width:100%; justify-content:center; }
  .directory-actions,
  .directory-actions .btn{
    width:100%;
  }
  .admin-dashboard-grid{
    grid-template-columns:1fr;
  }
  .directory-topbar{
    align-items:flex-start;
    flex-direction:column;
    margin-bottom:42px;
  }
  .directory-card-footer{
    align-items:flex-start;
    flex-direction:column;
  }
  .directory-filter-link{
    min-width:210px;
  }
  .about-header{
    padding-bottom:52px;
  }
  .about-section{
    padding:58px 0;
  }
  .contact-header{
    padding-bottom:52px;
  }
  .sponsor-header{
    padding:112px 0 52px;
  }
  .sponsor-hero-grid h1{
    font-size:3rem;
  }
  .sponsor-section{
    padding:58px 0;
  }
  .sponsor-note{
    padding:1.35rem;
  }
  .contact-section{
    padding:58px 0;
  }
  .jobs-section{
    padding:58px 0;
  }
  .blog-section{
    padding:58px 0;
  }
  .blog-detail-main{
    padding:112px 0 58px;
  }
  .blog-detail-content{
    padding:1.35rem;
  }
  .blog-detail-cover,
  .blog-detail-placeholder{
    aspect-ratio:16/11;
  }
  .calendar-section{
    padding:58px 0;
  }
  .calendar-weekdays{
    display:none;
  }
  .calendar-grid{
    grid-template-columns:1fr;
  }
  .calendar-day.is-empty{
    display:none;
  }
  .calendar-day{
    min-height:auto;
  }
  .calendar-event-card{
    grid-template-columns:1fr;
  }
  .job-card{
    grid-template-columns:1fr;
  }
  .job-card-logo{
    width:100%;
    max-width:160px;
  }
  .about-values-grid{
    grid-template-columns:1fr;
  }
  .puntos-hero{
    padding:112px 0 34px;
  }
  .puntos-hero h1{
    font-size:3.1rem;
  }
  .puntos-panel{
    padding:1rem;
  }
  .puntos-list{
    grid-template-columns:1fr;
  }
  .puntos-admin-card{
    align-items:flex-start;
    flex-direction:column;
  }
  .puntos-map{
    height:64vh;
    min-height:390px;
  }
  .puntos-cta{
    padding:1.35rem;
  }
}
