:root {
  --verde:       #1a7a45;
  --verde-d:     #0a3320;
  --verde-m:     #2aa85e;
  --verde-l:     rgba(42,168,94,0.12);
  --verde-glow:  rgba(42,168,94,0.35);
  --azul:        #1a5fbf;
  --azul-l:      rgba(26,95,191,0.1);
  --naranja:     #e07a35;
  --naranja-l:   rgba(224,122,53,0.1);
  --amarillo:    #c8a000;
  --amarillo-l:  rgba(200,160,0,0.1);
  --fondo:       #07160e;
  --fondo-2:     #0d2016;
  --blanco:      #fff;
  --texto:       #e8f5ec;
  --texto-soft:  rgba(232,245,236,0.65);
  --gris-l:      rgba(255,255,255,0.1);
  --r:           12px;
  --r2:          20px;
  --r3:          28px;
  --glass:       rgba(255,255,255,0.04);
  --glass-b:     1px solid rgba(255,255,255,0.08);
  --shadow:      0 20px 60px rgba(0,0,0,0.5);
  --shadow-sm:   0 8px 30px rgba(0,0,0,0.3);
}

*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; }

body {
  font-family: 'Syne', sans-serif;
  background: var(--fondo);
  color: var(--texto);
  line-height: 1.75;
  font-size: 15.5px;
  overflow-x: hidden;
}

body::before {
  content: '';
  position: fixed;
  inset: 0;
  background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.03'/%3E%3C/svg%3E");
  pointer-events: none;
  z-index: 0;
  opacity: 0.4;
}

/* =============================================
   NAVIGATION
   ============================================= */
nav {
  position: fixed;
  top: 0; left: 0; right: 0;
  z-index: 1000;
  padding: 0 32px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  height: 64px;
  transition: all 0.4s ease;
}
nav.scrolled {
  background: rgba(7,22,14,0.92);
  backdrop-filter: blur(20px);
  -webkit-backdrop-filter: blur(20px);
  border-bottom: 1px solid rgba(42,168,94,0.2);
  box-shadow: 0 4px 30px rgba(0,0,0,0.4);
}
.nav-logo {
  display: flex;
  align-items: center;
  gap: 10px;
  text-decoration: none;
}
.nav-logo-icon {
  width: 36px; height: 36px;
  background: linear-gradient(135deg, var(--verde-m), var(--verde));
  border-radius: 10px;
  display: flex; align-items: center; justify-content: center;
  font-size: 1.1rem;
  box-shadow: 0 0 20px var(--verde-glow);
}
.nav-logo-text {
  font-family: 'Playfair Display', serif;
  font-size: 1.05rem;
  color: var(--blanco);
  line-height: 1.2;
}
.nav-logo-sub {
  font-family: 'Syne', sans-serif;
  font-size: 0.65rem;
  font-weight: 400;
  color: var(--texto-soft);
  display: block;
}
.nav-links {
  display: flex;
  align-items: center;
  gap: 2px;
}
.nav-links a {
  color: var(--texto-soft);
  text-decoration: none;
  font-size: 0.78rem;
  font-weight: 600;
  letter-spacing: 0.05em;
  text-transform: uppercase;
  padding: 6px 14px;
  border-radius: 30px;
  transition: all 0.2s ease;
}
.nav-links a:hover { color: var(--verde-m); background: var(--verde-l); }

.nav-ham {
  display: none;
  flex-direction: column;
  gap: 5px;
  cursor: pointer;
  padding: 4px;
}
.nav-ham span {
  width: 24px; height: 2px;
  background: var(--texto);
  border-radius: 2px;
  transition: all 0.3s ease;
}
.nav-ham.open span:nth-child(1) { transform: translateY(7px) rotate(45deg); }
.nav-ham.open span:nth-child(2) { opacity: 0; }
.nav-ham.open span:nth-child(3) { transform: translateY(-7px) rotate(-45deg); }

.mobile-menu {
  display: none;
  position: fixed;
  top: 64px; left: 0; right: 0;
  background: rgba(7,22,14,0.97);
  backdrop-filter: blur(20px);
  padding: 20px 32px 28px;
  border-bottom: 1px solid rgba(42,168,94,0.2);
  z-index: 999;
  flex-direction: column;
  gap: 4px;
}
.mobile-menu.open { display: flex; }
.mobile-menu a {
  color: var(--texto-soft);
  text-decoration: none;
  font-size: 0.9rem;
  font-weight: 600;
  letter-spacing: 0.04em;
  padding: 10px 0;
  border-bottom: 1px solid var(--gris-l);
  transition: color 0.2s;
}
.mobile-menu a:hover { color: var(--verde-m); }

/* =============================================
   HERO
   ============================================= */
.hero {
  min-height: 100vh;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  text-align: center;
  padding: 120px 24px 80px;
  position: relative;
  overflow: hidden;
}
.hero-bg {
  position: absolute;
  inset: 0;
  background:
    radial-gradient(ellipse 80% 60% at 50% 0%, rgba(42,168,94,0.25) 0%, transparent 70%),
    radial-gradient(ellipse 50% 50% at 20% 80%, rgba(26,95,191,0.1) 0%, transparent 60%),
    radial-gradient(ellipse 60% 60% at 80% 90%, rgba(26,122,69,0.15) 0%, transparent 60%);
  animation: heroShift 8s ease-in-out infinite alternate;
}
@keyframes heroShift {
  0%   { transform: scale(1) rotate(0deg); }
  100% { transform: scale(1.05) rotate(1deg); }
}
.particles { position: absolute; inset: 0; pointer-events: none; }
.particle {
  position: absolute;
  border-radius: 50%;
  background: var(--verde-m);
  opacity: 0;
  animation: float var(--dur, 6s) ease-in-out var(--delay, 0s) infinite;
}
@keyframes float {
  0%   { transform: translateY(0) scale(0); opacity: 0; }
  20%  { opacity: 0.4; }
  80%  { opacity: 0.2; }
  100% { transform: translateY(-120px) scale(1.5); opacity: 0; }
}
.hero-grid {
  position: absolute;
  inset: 0;
  background-image:
    linear-gradient(rgba(42,168,94,0.04) 1px, transparent 1px),
    linear-gradient(90deg, rgba(42,168,94,0.04) 1px, transparent 1px);
  background-size: 48px 48px;
  mask-image: radial-gradient(ellipse 80% 80% at 50% 50%, black 0%, transparent 100%);
}
.hero-eyebrow {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  background: rgba(42,168,94,0.12);
  border: 1px solid rgba(42,168,94,0.3);
  border-radius: 30px;
  padding: 6px 16px;
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--verde-m);
  margin-bottom: 28px;
  position: relative;
  z-index: 1;
}
.hero-eyebrow::before {
  content: '';
  width: 6px; height: 6px;
  background: var(--verde-m);
  border-radius: 50%;
  box-shadow: 0 0 8px var(--verde-m);
  animation: pulse 2s infinite;
}
@keyframes pulse {
  0%, 100% { opacity: 1; transform: scale(1); }
  50%       { opacity: 0.5; transform: scale(0.8); }
}
.hero h1 {
  font-family: 'Playfair Display', serif;
  font-size: clamp(2.2rem, 5vw, 4rem);
  font-weight: 900;
  line-height: 1.15;
  margin-bottom: 20px;
  position: relative;
  z-index: 1;
}
.hero h1 .accent {
  background: linear-gradient(135deg, #82eeac, var(--verde-m));
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  display: block;
}
.hero-desc {
  font-family: 'Lora', serif;
  font-size: 1.05rem;
  max-width: 560px;
  color: var(--texto-soft);
  margin: 0 auto 36px;
  line-height: 1.8;
  position: relative;
  z-index: 1;
}
.hero-badges {
  display: flex;
  gap: 8px;
  justify-content: center;
  flex-wrap: wrap;
  position: relative;
  z-index: 1;
  margin-bottom: 48px;
}
.hbadge {
  background: var(--glass);
  border: var(--glass-b);
  backdrop-filter: blur(10px);
  border-radius: 30px;
  padding: 5px 14px;
  font-size: 0.76rem;
  font-weight: 600;
  color: var(--texto-soft);
  letter-spacing: 0.02em;
  transition: all 0.2s;
}
.hbadge:hover { border-color: rgba(42,168,94,0.4); color: var(--texto); background: var(--verde-l); }
.hero-scroll {
  position: absolute;
  bottom: 32px;
  left: 50%;
  transform: translateX(-50%);
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 8px;
  color: var(--texto-soft);
  font-size: 0.72rem;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  z-index: 1;
  animation: scrollBounce 2s ease-in-out infinite;
}
@keyframes scrollBounce {
  0%, 100% { transform: translateX(-50%) translateY(0); }
  50%       { transform: translateX(-50%) translateY(6px); }
}

/* =============================================
   LAYOUT
   ============================================= */
.section { padding: 100px 0; position: relative; z-index: 1; }
.section-alt { background: var(--fondo-2); }
.container { max-width: 980px; margin: 0 auto; padding: 0 24px; }
.stitle { text-align: center; margin-bottom: 56px; }
.stitle-eyebrow {
  display: inline-block;
  font-size: 0.7rem; font-weight: 700;
  letter-spacing: 0.15em; text-transform: uppercase;
  color: var(--verde-m); margin-bottom: 12px;
}
.stitle h2 {
  font-family: 'Playfair Display', serif;
  font-size: clamp(1.8rem, 3.5vw, 2.6rem);
  font-weight: 900; color: var(--blanco); margin-bottom: 12px; line-height: 1.2;
}
.stitle p { font-size: 0.95rem; color: var(--texto-soft); max-width: 500px; margin: 0 auto; font-family: 'Lora', serif; }

/* Glass card */
.glass-card {
  background: var(--glass);
  border: var(--glass-b);
  backdrop-filter: blur(16px);
  -webkit-backdrop-filter: blur(16px);
  border-radius: var(--r3);
  padding: 28px 30px;
  transition: all 0.35s cubic-bezier(0.23, 1, 0.32, 1);
}
.glass-card:hover {
  border-color: rgba(42,168,94,0.3);
  transform: translateY(-4px);
  box-shadow: 0 20px 50px rgba(0,0,0,0.4), 0 0 0 1px rgba(42,168,94,0.1);
}

/* =============================================
   INTRO / STATISTICS
   ============================================= */
.intro-text { font-family: 'Lora', serif; font-size: 1rem; color: var(--texto-soft); line-height: 1.85; margin-bottom: 16px; }
.intro-text strong { color: var(--verde-m); font-style: italic; }
.pullquote {
  border-left: 3px solid var(--verde-m);
  margin: 36px 0; padding: 20px 28px;
  font-family: 'Playfair Display', serif; font-style: italic;
  font-size: 1.2rem; color: var(--blanco); line-height: 1.6;
  background: rgba(42,168,94,0.05); border-radius: 0 var(--r2) var(--r2) 0;
}
.stats-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 16px; margin-top: 52px; }
.stat-card {
  background: var(--glass); border: var(--glass-b); border-radius: var(--r2);
  padding: 28px 20px; text-align: center; position: relative; overflow: hidden;
  transition: all 0.35s cubic-bezier(0.23, 1, 0.32, 1);
}
.stat-card::before {
  content: ''; position: absolute; bottom: 0; left: 0; right: 0; height: 2px;
  background: linear-gradient(90deg, transparent, var(--verde-m), transparent);
  transform: scaleX(0); transition: transform 0.4s ease;
}
.stat-card:hover { transform: translateY(-6px); box-shadow: var(--shadow-sm); }
.stat-card:hover::before { transform: scaleX(1); }
.stat-num { font-family: 'Playfair Display', serif; font-size: 2.4rem; font-weight: 900; line-height: 1; color: var(--verde-m); margin-bottom: 8px; }
.stat-label { font-size: 0.76rem; color: var(--texto-soft); line-height: 1.4; font-weight: 600; }

/* =============================================
   TABS (Tipos)
   ============================================= */
.tabs-wrapper { position: relative; }
.tabs-nav { display: flex; gap: 8px; margin-bottom: 28px; flex-wrap: wrap; justify-content: center; }
.tab-btn {
  background: var(--glass); border: var(--glass-b); border-radius: 30px;
  padding: 8px 20px; font-family: 'Syne', sans-serif; font-size: 0.78rem; font-weight: 700;
  color: var(--texto-soft); cursor: pointer; transition: all 0.25s ease; letter-spacing: 0.02em;
  display: flex; align-items: center; gap: 6px;
}
.tab-btn:hover { color: var(--texto); border-color: rgba(255,255,255,0.2); }
.tab-btn.active { background: var(--verde-m); border-color: var(--verde-m); color: #fff; box-shadow: 0 0 20px var(--verde-glow); }
.tab-panel { display: none; animation: fadeSlideIn 0.35s ease; }
.tab-panel.active { display: grid; grid-template-columns: 1fr 1fr; gap: 24px; }
@keyframes fadeSlideIn { from { opacity: 0; transform: translateY(10px); } to { opacity: 1; transform: translateY(0); } }
.tipo-card {
  background: var(--glass); border: var(--glass-b); border-radius: var(--r2);
  padding: 28px; transition: all 0.35s cubic-bezier(0.23, 1, 0.32, 1);
}
.tipo-card:hover { transform: translateY(-4px); box-shadow: var(--shadow-sm); border-color: rgba(42,168,94,0.25); }
.tipo-card-single { grid-column: 1 / -1; }
.tipo-icon-wrap { width: 52px; height: 52px; border-radius: 14px; display: flex; align-items: center; justify-content: center; font-size: 1.5rem; margin-bottom: 16px; }
.tipo-icon-wrap.g  { background: rgba(42,168,94,0.15); }
.tipo-icon-wrap.a  { background: rgba(26,95,191,0.15); }
.tipo-icon-wrap.n  { background: rgba(224,122,53,0.15); }
.tipo-icon-wrap.am { background: rgba(200,160,0,0.15); }
.tipo-card h3 { font-size: 1rem; font-weight: 700; margin-bottom: 10px; }
.tipo-card h3.g  { color: #82eeac; }
.tipo-card h3.a  { color: #7eb3ff; }
.tipo-card h3.n  { color: #ffa96a; }
.tipo-card h3.am { color: #ffd866; }
.tipo-card p { font-size: 0.86rem; color: var(--texto-soft); line-height: 1.75; font-family: 'Lora', serif; }
.tipo-card ul { margin-top: 14px; padding-left: 0; list-style: none; display: flex; flex-direction: column; gap: 6px; }
.tipo-card ul li { font-size: 0.82rem; color: var(--texto-soft); display: flex; align-items: flex-start; gap: 8px; }
.tipo-card ul li::before { content: '→'; color: var(--verde-m); font-weight: 700; flex-shrink: 0; margin-top: 1px; }
.qbox { background: rgba(200,160,0,0.08); border: 1px solid rgba(200,160,0,0.25); border-radius: var(--r2); padding: 20px 24px; margin-top: 32px; font-size: 0.9rem; color: var(--texto-soft); font-family: 'Lora', serif; font-style: italic; }
.qbox strong { color: #ffd866; font-style: normal; }

/* =============================================
   CAUSAS
   ============================================= */
.causas-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 16px; }
.causa-card { background: var(--glass); border: var(--glass-b); border-radius: var(--r2); padding: 24px 22px; transition: all 0.35s cubic-bezier(0.23, 1, 0.32, 1); cursor: default; }
.causa-card:hover { transform: translateY(-4px) scale(1.01); border-color: rgba(42,168,94,0.3); box-shadow: 0 16px 40px rgba(0,0,0,0.3); }
.causa-card-icon { font-size: 1.6rem; margin-bottom: 12px; display: block; }
.causa-card h4 { font-size: 0.9rem; font-weight: 700; color: var(--blanco); margin-bottom: 8px; }
.causa-card p { font-size: 0.82rem; color: var(--texto-soft); line-height: 1.65; font-family: 'Lora', serif; }

/* =============================================
   SALUD
   ============================================= */
.efectos-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 16px; }
.efecto-card { background: var(--glass); border: var(--glass-b); border-radius: var(--r2); padding: 24px 20px; text-align: center; transition: all 0.35s cubic-bezier(0.23, 1, 0.32, 1); }
.efecto-card:hover { transform: translateY(-6px); box-shadow: var(--shadow-sm); border-color: rgba(42,168,94,0.3); }
.efecto-card .ei { font-size: 2rem; margin-bottom: 12px; display: block; transition: transform 0.3s ease; }
.efecto-card:hover .ei { transform: scale(1.15) rotate(-5deg); }
.efecto-card h4 { font-size: 0.88rem; font-weight: 700; color: var(--blanco); margin-bottom: 8px; }
.efecto-card p { font-size: 0.8rem; color: var(--texto-soft); line-height: 1.6; font-family: 'Lora', serif; }
.info-banner { background: var(--verde-l); border: 1px solid rgba(42,168,94,0.25); border-radius: var(--r2); padding: 20px 24px; margin-top: 24px; font-size: 0.9rem; color: var(--texto-soft); font-family: 'Lora', serif; }
.info-banner strong { color: var(--verde-m); }

/* =============================================
   ODS
   ============================================= */
.ods-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 20px; }
.ods-card { border-radius: var(--r3); padding: 36px 32px; position: relative; overflow: hidden; transition: all 0.35s cubic-bezier(0.23, 1, 0.32, 1); }
.ods-card:hover { transform: translateY(-6px); box-shadow: var(--shadow); }
.ods-card.ods11 { background: linear-gradient(145deg, #a85700 0%, #7a3d00 100%); }
.ods-card.ods13 { background: linear-gradient(145deg, #1a5e1a 0%, #0c3a0c 100%); }
.ods-card::after { content: ''; position: absolute; inset: 0; background: radial-gradient(ellipse 60% 60% at 90% 10%, rgba(255,255,255,0.08), transparent); }
.ods-num { font-family: 'Playfair Display', serif; font-size: 5rem; font-weight: 900; opacity: 0.15; line-height: 1; margin-bottom: 8px; position: relative; z-index: 1; }
.ods-card h3 { font-family: 'Playfair Display', serif; font-size: 1.25rem; margin-bottom: 12px; position: relative; z-index: 1; color: #fff; }
.ods-card p { font-size: 0.86rem; opacity: 0.88; line-height: 1.7; position: relative; z-index: 1; font-family: 'Lora', serif; color: #fff; }
.ods-info { background: rgba(26,95,191,0.08); border: 1px solid rgba(26,95,191,0.2); border-radius: var(--r2); padding: 20px 24px; margin-top: 20px; font-size: 0.9rem; color: var(--texto-soft); font-family: 'Lora', serif; }
.ods-info strong { color: #7eb3ff; }

/* =============================================
   SOLUCIONES ACCORDION
   ============================================= */
.sol-list { display: flex; flex-direction: column; gap: 12px; }
.sol-item { background: var(--glass); border: var(--glass-b); border-radius: var(--r2); overflow: hidden; transition: all 0.3s ease; }
.sol-item.open { border-color: rgba(42,168,94,0.35); box-shadow: 0 0 30px rgba(42,168,94,0.08); }
.sol-header { display: flex; align-items: center; gap: 16px; padding: 20px 24px; cursor: pointer; user-select: none; transition: background 0.2s; }
.sol-header:hover { background: rgba(255,255,255,0.03); }
.sol-num { background: var(--verde); color: #fff; font-weight: 700; font-size: 0.85rem; border-radius: 50%; width: 36px; height: 36px; display: flex; align-items: center; justify-content: center; flex-shrink: 0; transition: background 0.2s; }
.sol-item.open .sol-num { background: var(--verde-m); box-shadow: 0 0 16px var(--verde-glow); }
.sol-header h4 { flex: 1; font-size: 0.93rem; font-weight: 700; color: var(--blanco); }
.sol-toggle { color: var(--texto-soft); font-size: 0.9rem; transition: transform 0.3s ease; flex-shrink: 0; }
.sol-item.open .sol-toggle { transform: rotate(180deg); color: var(--verde-m); }
.sol-body { max-height: 0; overflow: hidden; transition: max-height 0.4s cubic-bezier(0.23, 1, 0.32, 1); }
.sol-item.open .sol-body { max-height: 300px; }
.sol-body-inner { padding: 0 24px 24px 76px; font-size: 0.86rem; color: var(--texto-soft); line-height: 1.75; font-family: 'Lora', serif; }

/* =============================================
   ████  IMAGE CAROUSEL  ████
   ============================================= */
.carousels-section { padding: 80px 0; }

.carousel-block {
  margin-bottom: 60px;
}
.carousel-block:last-child { margin-bottom: 0; }

.carousel-label {
  display: flex;
  align-items: center;
  gap: 12px;
  margin-bottom: 20px;
}
.carousel-label-icon {
  width: 36px; height: 36px;
  background: var(--verde-l);
  border: 1px solid rgba(42,168,94,0.3);
  border-radius: 10px;
  display: flex; align-items: center; justify-content: center;
  font-size: 1rem;
}
.carousel-label-text {
  font-size: 0.82rem;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--verde-m);
}
.carousel-label-sub {
  font-size: 0.75rem;
  color: var(--texto-soft);
  font-family: 'Lora', serif;
  margin-top: 1px;
}

/* Carousel container */
.carousel {
  position: relative;
  border-radius: var(--r3);
  overflow: hidden;
  background: rgba(0,0,0,0.3);
  border: var(--glass-b);
  box-shadow: var(--shadow-sm);
  aspect-ratio: 16/7;
}
.carousel:hover .carousel-ctrl { opacity: 1; }

/* Slides track */
.carousel-track {
  display: flex;
  width: 100%;
  height: 100%;
  transition: transform 0.55s cubic-bezier(0.77, 0, 0.175, 1);
}

/* Each slide */
.carousel-slide {
  min-width: 100%;
  height: 100%;
  position: relative;
  overflow: hidden;
}
.carousel-slide img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  transition: transform 0.6s ease;
}
.carousel:hover .carousel-slide.is-active img {
  transform: scale(1.03);
}

/* Slide overlay */
.carousel-slide-overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(to top, rgba(7,22,14,0.75) 0%, transparent 50%);
  pointer-events: none;
}

/* Placeholder for missing images */
.carousel-placeholder {
  width: 100%; height: 100%;
  display: flex; flex-direction: column;
  align-items: center; justify-content: center;
  gap: 12px;
  background: linear-gradient(135deg, rgba(42,168,94,0.06), rgba(26,95,191,0.06));
  color: var(--texto-soft);
  font-family: 'Lora', serif;
}
.carousel-placeholder .ph-icon { font-size: 2.5rem; opacity: 0.4; }
.carousel-placeholder .ph-name { font-size: 0.8rem; opacity: 0.5; letter-spacing: 0.08em; }

/* Controls */
.carousel-ctrl {
  position: absolute;
  top: 50%; transform: translateY(-50%);
  width: 44px; height: 44px;
  background: rgba(7,22,14,0.7);
  backdrop-filter: blur(10px);
  border: 1px solid rgba(42,168,94,0.3);
  border-radius: 50%;
  color: var(--texto);
  font-size: 0.9rem;
  cursor: pointer;
  display: flex; align-items: center; justify-content: center;
  opacity: 0;
  transition: all 0.25s ease;
  z-index: 10;
}
.carousel-ctrl:hover {
  background: rgba(42,168,94,0.25);
  border-color: var(--verde-m);
  color: #fff;
  transform: translateY(-50%) scale(1.08);
}
.carousel-ctrl.prev { left: 14px; }
.carousel-ctrl.next { right: 14px; }

/* Dots */
.carousel-dots {
  position: absolute;
  bottom: 16px; left: 50%; transform: translateX(-50%);
  display: flex; gap: 6px; z-index: 10;
}
.carousel-dot {
  width: 6px; height: 6px;
  border-radius: 3px;
  background: rgba(255,255,255,0.3);
  cursor: pointer;
  transition: all 0.3s ease;
  border: none;
  padding: 0;
}
.carousel-dot.active {
  width: 22px;
  background: var(--verde-m);
  box-shadow: 0 0 8px var(--verde-glow);
}

/* Progress bar */
.carousel-progress {
  position: absolute;
  bottom: 0; left: 0;
  height: 2px;
  background: var(--verde-m);
  width: 0%;
  transition: width linear;
  opacity: 0.7;
  z-index: 10;
}

/* Caption */
.carousel-caption {
  position: absolute;
  bottom: 36px; left: 20px; right: 20px;
  color: #fff;
  z-index: 5;
  pointer-events: none;
}
.carousel-caption-title {
  font-family: 'Playfair Display', serif;
  font-size: 1rem;
  font-weight: 700;
  line-height: 1.3;
  text-shadow: 0 2px 8px rgba(0,0,0,0.5);
}
.carousel-caption-sub {
  font-family: 'Lora', serif;
  font-size: 0.75rem;
  opacity: 0.8;
  margin-top: 3px;
}

/* Counter badge */
.carousel-counter {
  position: absolute;
  top: 14px; right: 14px;
  background: rgba(7,22,14,0.6);
  backdrop-filter: blur(8px);
  border: 1px solid rgba(255,255,255,0.1);
  border-radius: 20px;
  padding: 3px 10px;
  font-size: 0.72rem;
  font-weight: 700;
  color: var(--texto-soft);
  z-index: 10;
}

/* Autoplay toggle */
.carousel-autoplay-btn {
  position: absolute;
  top: 14px; left: 14px;
  width: 30px; height: 30px;
  background: rgba(7,22,14,0.6);
  backdrop-filter: blur(8px);
  border: 1px solid rgba(255,255,255,0.1);
  border-radius: 50%;
  color: var(--texto-soft);
  font-size: 0.7rem;
  cursor: pointer;
  display: flex; align-items: center; justify-content: center;
  z-index: 10;
  transition: all 0.2s;
  opacity: 0;
}
.carousel:hover .carousel-autoplay-btn { opacity: 1; }
.carousel-autoplay-btn:hover { background: rgba(42,168,94,0.2); color: var(--verde-m); }
.carousel-autoplay-btn.playing { color: var(--verde-m); border-color: rgba(42,168,94,0.3); }

/* =============================================
   STREAK BADGE
   ============================================= */
.streak-badge {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  background: rgba(224,122,53,0.1);
  border: 1px solid rgba(224,122,53,0.3);
  border-radius: 30px;
  padding: 5px 14px;
  font-size: 0.78rem;
  font-weight: 700;
  color: var(--naranja);
  letter-spacing: 0.02em;
  transition: all 0.3s ease;
}
.streak-badge.active {
  background: rgba(224,122,53,0.18);
  border-color: rgba(224,122,53,0.5);
  box-shadow: 0 0 14px rgba(224,122,53,0.2);
}
@keyframes streakBump {
  0%   { transform: scale(1); }
  40%  { transform: scale(1.18); box-shadow: 0 0 20px rgba(224,122,53,0.5); }
  100% { transform: scale(1); }
}
.streak-badge.streak-bump { animation: streakBump 0.6s cubic-bezier(0.23,1,0.32,1); }

.modal-streak-info {
  display: inline-block;
  background: rgba(224,122,53,0.12);
  border: 1px solid rgba(224,122,53,0.3);
  border-radius: 20px;
  padding: 6px 16px;
  font-size: 0.82rem;
  font-weight: 700;
  color: var(--naranja);
  margin: 10px 0;
}



/* Day/Level banner */
.cruce-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: 16px;
  margin-bottom: 24px;
}
.cruce-day-badge {
  display: flex;
  align-items: center;
  gap: 10px;
}
.cruce-day-pip {
  width: 10px; height: 10px;
  border-radius: 50%;
  background: var(--verde-m);
  box-shadow: 0 0 10px var(--verde-glow);
  animation: pulse 2s infinite;
}
.cruce-day-label {
  font-size: 0.78rem;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--verde-m);
}
.cruce-day-name {
  font-size: 0.72rem;
  color: var(--texto-soft);
  font-family: 'Lora', serif;
}

/* Level dots */
.cruce-levels {
  display: flex;
  gap: 6px;
  align-items: center;
}
.cruce-level-dot {
  width: 28px; height: 6px;
  border-radius: 3px;
  background: rgba(255,255,255,0.08);
  border: 1px solid rgba(255,255,255,0.1);
  transition: all 0.3s ease;
}
.cruce-level-dot.done {
  background: var(--verde-m);
  box-shadow: 0 0 8px var(--verde-glow);
}
.cruce-level-dot.active {
  background: rgba(42,168,94,0.4);
  border-color: var(--verde-m);
  animation: levelPulse 1.5s ease-in-out infinite;
}
@keyframes levelPulse {
  0%, 100% { box-shadow: 0 0 4px var(--verde-glow); }
  50%       { box-shadow: 0 0 14px var(--verde-glow); }
}

/* Completed state banner */
.cruce-completed-banner {
  display: none;
  align-items: center;
  gap: 10px;
  background: rgba(42,168,94,0.1);
  border: 1px solid rgba(42,168,94,0.3);
  border-radius: var(--r);
  padding: 10px 16px;
  font-size: 0.82rem;
  color: var(--verde-m);
  font-weight: 600;
  margin-bottom: 16px;
}
.cruce-completed-banner.show { display: flex; }
.cruce-completed-banner i { font-size: 1rem; }

/* Word completion highlight */
@keyframes wordComplete {
  0%   { box-shadow: inset 0 0 0 rgba(42,168,94,0); }
  30%  { box-shadow: inset 0 0 0 2px rgba(42,168,94,0.6), 0 0 20px rgba(42,168,94,0.3); }
  100% { box-shadow: inset 0 0 0 rgba(42,168,94,0); }
}
.cell-word-flash { animation: wordComplete 0.8s ease-out; }

/* Crossword grid */
.cruce-wrap {
  display: grid;
  grid-template-columns: auto 1fr;
  gap: 36px;
  align-items: start;
}
.grid-area { overflow-x: auto; }
table.cgrid { border-collapse: collapse; }
table.cgrid td {
  width: 34px; height: 34px;
  border: 1px solid rgba(255,255,255,0.06);
  text-align: center;
  font-size: 0.82rem; font-weight: 600;
  position: relative;
  background: rgba(255,255,255,0.03);
  transition: background 0.15s;
}
table.cgrid td.active { background: rgba(255,255,255,0.06); }
table.cgrid td.blk { background: rgba(0,0,0,0.5); border-color: rgba(0,0,0,0.5); }
table.cgrid td input {
  width: 100%; height: 100%; border: none;
  background: transparent; text-align: center;
  font-size: 0.82rem; font-weight: 700;
  color: var(--texto); text-transform: uppercase;
  outline: none; cursor: pointer; font-family: 'Syne', sans-serif;
  transition: all 0.15s;
}
table.cgrid td input:focus { background: rgba(42,168,94,0.15); }
table.cgrid td input.correct {
  color: var(--verde-m);
  text-shadow: 0 0 8px var(--verde-glow);
}
table.cgrid td input.wrong { color: #ff6b6b; }
table.cgrid td input.hint { color: rgba(255,220,100,0.9); }

.num-badge {
  position: absolute; top: 1px; left: 2px;
  font-size: 7px; color: var(--texto-soft);
  pointer-events: none; line-height: 1; font-family: 'Syne', sans-serif;
}

/* Clues panel */
.pistas h3 { font-size: 0.95rem; font-weight: 700; margin-bottom: 14px; color: var(--blanco); }
.pistas h4 { font-size: 0.72rem; font-weight: 700; color: var(--verde-m); margin: 14px 0 6px; text-transform: uppercase; letter-spacing: 0.08em; }
.pistas li {
  font-size: 0.78rem; color: var(--texto-soft); margin-bottom: 6px; line-height: 1.5;
  list-style: none; padding: 5px 8px; border-radius: 6px;
  border-bottom: 1px solid rgba(255,255,255,0.04);
  transition: all 0.2s; cursor: pointer;
}
.pistas li:hover { background: rgba(42,168,94,0.08); color: var(--texto); }
.pistas li.word-done { color: var(--verde-m); text-decoration: line-through; opacity: 0.7; }
.pistas li span { font-weight: 700; color: var(--texto); margin-right: 4px; }

.cruce-btns { display: flex; gap: 8px; margin-top: 16px; flex-wrap: wrap; }
.cruce-btns button {
  background: transparent; border: 1px solid rgba(255,255,255,0.12); border-radius: var(--r);
  padding: 8px 18px; font-size: 0.8rem; font-weight: 600; cursor: pointer;
  color: var(--texto-soft); font-family: 'Syne', sans-serif; transition: all 0.2s ease; letter-spacing: 0.03em;
}
.cruce-btns button:hover { background: rgba(255,255,255,0.06); color: var(--texto); }
.cruce-btns button.primary { background: var(--verde); border-color: var(--verde); color: #fff; }
.cruce-btns button.primary:hover { background: var(--verde-m); border-color: var(--verde-m); box-shadow: 0 0 20px var(--verde-glow); }

.status-msg { margin-top: 12px; font-size: 0.82rem; min-height: 20px; color: var(--texto-soft); font-family: 'Lora', serif; }
.status-msg.win { color: var(--verde-m); font-weight: 700; text-shadow: 0 0 10px var(--verde-glow); }
.status-msg.fail { color: #ff9f9f; }

/* Progress bar inside crossword */
.cruce-progress-bar {
  height: 3px; background: rgba(255,255,255,0.05); border-radius: 2px; margin-top: 14px; overflow: hidden;
}
.cruce-progress-fill {
  height: 100%; border-radius: 2px;
  background: linear-gradient(90deg, var(--verde), var(--verde-m));
  width: 0%; transition: width 0.4s cubic-bezier(0.23,1,0.32,1);
  box-shadow: 0 0 8px var(--verde-glow);
}

/* =============================================
   MODAL (win celebration)
   ============================================= */
.modal-overlay {
  position: fixed; inset: 0; z-index: 2000;
  background: rgba(7,22,14,0.85);
  backdrop-filter: blur(12px);
  display: flex; align-items: center; justify-content: center;
  opacity: 0; pointer-events: none;
  transition: opacity 0.4s ease;
}
.modal-overlay.show { opacity: 1; pointer-events: all; }

.modal-box {
  background: var(--fondo-2);
  border: 1px solid rgba(42,168,94,0.35);
  border-radius: var(--r3);
  padding: 48px 44px;
  max-width: 480px; width: 90%;
  text-align: center;
  transform: scale(0.85) translateY(20px);
  transition: transform 0.4s cubic-bezier(0.23,1,0.32,1);
  box-shadow: 0 40px 80px rgba(0,0,0,0.6), 0 0 60px rgba(42,168,94,0.1);
  position: relative;
  overflow: hidden;
}
.modal-overlay.show .modal-box { transform: scale(1) translateY(0); }
.modal-box::before {
  content: '';
  position: absolute; inset: 0;
  background: radial-gradient(ellipse 80% 60% at 50% 0%, rgba(42,168,94,0.08), transparent);
}

.modal-confetti {
  font-size: 3rem; margin-bottom: 16px; display: block;
  animation: confettiBounce 0.6s cubic-bezier(0.23,1,0.32,1);
}
@keyframes confettiBounce {
  0%   { transform: scale(0) rotate(-20deg); }
  60%  { transform: scale(1.2) rotate(5deg); }
  100% { transform: scale(1) rotate(0deg); }
}
.modal-title {
  font-family: 'Playfair Display', serif;
  font-size: 1.8rem; font-weight: 900; color: var(--blanco);
  margin-bottom: 8px; position: relative;
}
.modal-subtitle {
  font-family: 'Lora', serif; font-size: 0.95rem;
  color: var(--texto-soft); margin-bottom: 28px; line-height: 1.6; position: relative;
}
.modal-level-info {
  background: var(--verde-l); border: 1px solid rgba(42,168,94,0.2);
  border-radius: var(--r2); padding: 16px 20px; margin-bottom: 24px;
  position: relative;
}
.modal-level-info .mli-label { font-size: 0.72rem; text-transform: uppercase; letter-spacing: 0.1em; color: var(--verde-m); font-weight: 700; margin-bottom: 4px; }
.modal-level-info .mli-val { font-family: 'Playfair Display', serif; font-size: 1.1rem; color: var(--blanco); }
.modal-next-info {
  font-size: 0.8rem; color: var(--texto-soft); font-family: 'Lora', serif; font-style: italic; margin-bottom: 24px; position: relative;
}
.modal-close {
  background: var(--verde); border: none; color: #fff;
  border-radius: var(--r2); padding: 12px 32px;
  font-family: 'Syne', sans-serif; font-size: 0.88rem; font-weight: 700;
  cursor: pointer; letter-spacing: 0.04em;
  transition: all 0.2s; position: relative;
}
.modal-close:hover { background: var(--verde-m); box-shadow: 0 0 24px var(--verde-glow); }

/* Sparkles for modal */
.sparkle {
  position: absolute; pointer-events: none;
  font-size: 1.2rem;
  animation: sparkleFly 2s ease-out forwards;
}
@keyframes sparkleFly {
  0%   { opacity: 1; transform: translate(0,0) scale(1); }
  100% { opacity: 0; transform: translate(var(--tx,40px), var(--ty,-60px)) scale(0.3); }
}

/* =============================================
   TEAM, REFS, FOOTER
   ============================================= */
.team-grid { display: flex; flex-wrap: wrap; gap: 12px; justify-content: center; }
.team-card { background: var(--glass); border: var(--glass-b); border-radius: var(--r2); padding: 18px 24px; text-align: center; min-width: 170px; transition: all 0.3s ease; }
.team-card:hover { border-color: rgba(42,168,94,0.3); transform: translateY(-3px); box-shadow: 0 12px 30px rgba(0,0,0,0.3); }
.team-card .avatar { width: 44px; height: 44px; border-radius: 50%; background: linear-gradient(135deg, var(--verde), var(--verde-m)); display: flex; align-items: center; justify-content: center; font-family: 'Playfair Display', serif; font-size: 1.1rem; color: #fff; margin: 0 auto 10px; }
.team-card .tn { font-size: 0.85rem; font-weight: 600; color: var(--texto); line-height: 1.35; }
.team-card .tm { font-size: 0.72rem; color: var(--texto-soft); margin-top: 4px; font-family: 'Lora', serif; }
.teacher-note { text-align: center; margin-top: 20px; font-size: 0.84rem; color: var(--texto-soft); font-family: 'Lora', serif; }
.teacher-note strong { color: var(--verde-m); font-style: normal; }

.refs-section { background: linear-gradient(180deg, var(--fondo) 0%, var(--fondo-2) 100%); padding: 60px 0; }
.refs-list { list-style: none; display: flex; flex-direction: column; gap: 10px; max-width: 720px; margin: 0 auto; }
.refs-list li { padding: 12px 16px; background: var(--glass); border: var(--glass-b); border-radius: var(--r); font-size: 0.82rem; color: var(--texto-soft); line-height: 1.6; font-family: 'Lora', serif; transition: all 0.2s; display: flex; gap: 10px; align-items: flex-start; }
.refs-list li:hover { border-color: rgba(42,168,94,0.2); background: rgba(42,168,94,0.04); }
.refs-list li .ref-num { color: var(--verde-m); font-family: 'Playfair Display', serif; font-weight: 700; flex-shrink: 0; font-size: 0.9rem; min-width: 20px; }

footer { background: var(--verde-d); color: rgba(255,255,255,0.6); text-align: center; padding: 32px 20px; font-size: 0.82rem; line-height: 1.9; font-family: 'Lora', serif; border-top: 1px solid rgba(42,168,94,0.15); }
footer strong { color: #82eeac; }

#back-top {
  position: fixed; bottom: 28px; right: 28px;
  width: 46px; height: 46px; background: var(--verde); border: none; border-radius: 50%;
  color: #fff; font-size: 1rem; cursor: pointer; display: flex; align-items: center; justify-content: center;
  box-shadow: 0 4px 20px rgba(42,168,94,0.4); transition: all 0.3s ease;
  opacity: 0; transform: translateY(16px); pointer-events: none; z-index: 900;
}
#back-top.visible { opacity: 1; transform: translateY(0); pointer-events: all; }
#back-top:hover { background: var(--verde-m); box-shadow: 0 6px 28px var(--verde-glow); transform: translateY(-2px); }

.chart-container { background: var(--glass); border: var(--glass-b); border-radius: var(--r3); padding: 28px; margin-top: 28px; }
.chart-title { font-size: 0.8rem; font-weight: 700; color: var(--texto-soft); text-transform: uppercase; letter-spacing: 0.08em; margin-bottom: 20px; text-align: center; }
.bar-row { display: flex; align-items: center; gap: 12px; margin-bottom: 14px; }
.bar-label { font-size: 0.76rem; color: var(--texto-soft); width: 120px; flex-shrink: 0; text-align: right; font-family: 'Lora', serif; }
.bar-track { flex: 1; height: 10px; background: rgba(255,255,255,0.05); border-radius: 5px; overflow: hidden; }
.bar-fill { height: 100%; border-radius: 5px; width: 0%; transition: width 1.2s cubic-bezier(0.23, 1, 0.32, 1); }
.bar-val { font-size: 0.76rem; font-weight: 700; color: var(--verde-m); width: 48px; flex-shrink: 0; }

/* =============================================
   RESPONSIVE
   ============================================= */
@media (max-width: 800px) {
  .stats-grid    { grid-template-columns: repeat(2, 1fr); }
  .causas-grid   { grid-template-columns: repeat(2, 1fr); }
  .efectos-grid  { grid-template-columns: repeat(2, 1fr); }
  .ods-grid      { grid-template-columns: 1fr; }
  .cruce-wrap    { grid-template-columns: 1fr; }
  .tab-panel.active { grid-template-columns: 1fr; }
  .nav-links     { display: none; }
  .nav-ham       { display: flex; }
}
@media (max-width: 560px) {
  .stats-grid   { grid-template-columns: repeat(2, 1fr); gap: 10px; }
  .causas-grid  { grid-template-columns: 1fr; }
  .efectos-grid { grid-template-columns: 1fr; }
  .section { padding: 70px 0; }
  .hero h1 { font-size: 2rem; }
  .carousel { aspect-ratio: 4/3; }
  .cruce-wrap { gap: 20px; }
}
/* =============================================
   COMENTARIOS
   ============================================= */
.comentarios-form-wrap {
  max-width: 680px;
  margin: 0 auto 56px;
}
.comentarios-form-card {
  background: var(--glass);
  border: var(--glass-b);
  border-radius: var(--r3);
  padding: 36px 40px;
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
}
.cf-title {
  font-size: 1.15rem;
  font-weight: 700;
  color: var(--verde-m);
  margin-bottom: 24px;
  display: flex;
  align-items: center;
  gap: 10px;
}
.cf-alert {
  padding: 12px 16px;
  border-radius: var(--r);
  font-size: 0.88rem;
  margin-bottom: 18px;
  font-weight: 600;
}
.cf-alert.success { background: rgba(42,168,94,0.15); color: var(--verde-m); border: 1px solid rgba(42,168,94,0.3); }
.cf-alert.error   { background: rgba(224,122,53,0.15); color: var(--naranja); border: 1px solid rgba(224,122,53,0.3); }
.cf-field {
  display: flex;
  flex-direction: column;
  gap: 7px;
  margin-bottom: 18px;
  position: relative;
}
.cf-field label {
  font-size: 0.8rem;
  text-transform: uppercase;
  letter-spacing: .08em;
  color: var(--texto-soft);
  font-family: 'Syne', sans-serif;
  font-weight: 600;
}
.cf-field input,
.cf-field textarea {
  background: rgba(255,255,255,0.05);
  border: 1px solid rgba(255,255,255,0.1);
  border-radius: var(--r);
  color: var(--texto);
  font-family: 'Syne', sans-serif;
  font-size: 0.95rem;
  padding: 12px 16px;
  outline: none;
  resize: vertical;
  transition: border-color 0.3s;
}
.cf-field input:focus,
.cf-field textarea:focus {
  border-color: var(--verde-m);
  background: rgba(42,168,94,0.07);
}
.cf-counter {
  font-size: 0.72rem;
  color: var(--texto-soft);
  text-align: right;
  margin-top: 4px;
}
.cf-btn {
  background: linear-gradient(135deg, var(--verde-m), var(--verde));
  color: #fff;
  border: none;
  border-radius: var(--r2);
  padding: 12px 32px;
  font-size: 0.95rem;
  font-family: 'Syne', sans-serif;
  font-weight: 700;
  cursor: pointer;
  display: flex;
  align-items: center;
  gap: 9px;
  transition: opacity 0.2s, transform 0.2s;
  box-shadow: 0 4px 20px var(--verde-glow);
}
.cf-btn:hover  { opacity: 0.88; transform: translateY(-2px); }
.cf-btn:active { transform: translateY(0); }
.cf-btn:disabled { opacity: 0.5; cursor: not-allowed; transform: none; }

/* Lista */
.comentarios-lista {
  max-width: 680px;
  margin: 0 auto;
  display: flex;
  flex-direction: column;
  gap: 18px;
}
.cf-loading {
  text-align: center;
  color: var(--texto-soft);
  padding: 32px;
  font-size: 0.9rem;
}
.cf-empty {
  text-align: center;
  color: var(--texto-soft);
  padding: 32px;
  font-size: 0.9rem;
}
.comentario-card {
  background: var(--glass);
  border: var(--glass-b);
  border-radius: var(--r2);
  padding: 22px 26px;
  animation: fadeInUp .4s ease both;
}
@keyframes fadeInUp {
  from { opacity:0; transform: translateY(14px); }
  to   { opacity:1; transform: translateY(0); }
}
.cc-header {
  display: flex;
  align-items: center;
  gap: 12px;
  margin-bottom: 12px;
}
.cc-avatar {
  width: 38px; height: 38px;
  border-radius: 50%;
  background: linear-gradient(135deg, var(--verde-m), var(--azul));
  display: flex; align-items: center; justify-content: center;
  font-weight: 800;
  font-size: 0.95rem;
  color: #fff;
  flex-shrink: 0;
}
.cc-meta { display: flex; flex-direction: column; gap: 2px; }
.cc-nombre { font-weight: 700; font-size: 0.95rem; color: var(--texto); }
.cc-fecha  { font-size: 0.75rem; color: var(--texto-soft); }
.cc-msg {
  font-size: 0.93rem;
  color: var(--texto);
  line-height: 1.7;
  white-space: pre-wrap;
  word-break: break-word;
}
@media (max-width: 600px) {
  .comentarios-form-card { padding: 24px 20px; }
}


/* =============================================
   WIDGET DE LOGROS FLOTANTE
   ============================================= */
#logros-widget {
  position: fixed;
  bottom: 28px;
  left: 28px;
  z-index: 9999;
}
.lw-btn {
  width: 56px; height: 56px;
  border-radius: 50%;
  background: linear-gradient(135deg, var(--verde-m), var(--azul));
  border: none;
  cursor: pointer;
  display: flex; align-items: center; justify-content: center;
  font-size: 1.5rem;
  box-shadow: 0 4px 24px rgba(42,168,94,0.4);
  transition: transform 0.2s, box-shadow 0.2s;
  position: relative;
}
.lw-btn:hover { transform: scale(1.1); box-shadow: 0 6px 30px rgba(42,168,94,0.55); }
.lw-badge {
  position: absolute; top: -4px; right: -4px;
  background: var(--naranja); color: #fff;
  font-size: 0.65rem; font-weight: 800;
  width: 18px; height: 18px; border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  display: none;
}

/* Panel */
.lw-panel {
  position: fixed;
  bottom: 96px; left: 28px;
  width: 340px;
  max-height: 80vh;
  background: var(--card-bg);
  border: var(--glass-b);
  border-radius: var(--r3);
  backdrop-filter: blur(16px);
  -webkit-backdrop-filter: blur(16px);
  box-shadow: 0 16px 48px rgba(0,0,0,0.5);
  display: none;
  flex-direction: column;
  overflow: hidden;
  animation: slideUpPanel .25s ease;
}
@keyframes slideUpPanel {
  from { opacity:0; transform: translateY(16px); }
  to   { opacity:1; transform: translateY(0); }
}
.lw-panel.open { display: flex; }

.lw-header {
  padding: 18px 20px 14px;
  border-bottom: 1px solid rgba(255,255,255,0.07);
  display: flex; align-items: center; justify-content: space-between;
  flex-shrink: 0;
}
.lw-header-title { font-size: 1rem; font-weight: 700; color: var(--verde-m); display: flex; align-items: center; gap: 8px; }
.lw-close { background: none; border: none; color: var(--texto-soft); cursor: pointer; font-size: 1.1rem; padding: 4px; }
.lw-close:hover { color: var(--texto); }

.lw-body { overflow-y: auto; flex: 1; padding: 16px 20px; }

/* Auth forms */
.lw-auth { display: flex; flex-direction: column; gap: 12px; }
.lw-auth-title { font-size: 0.85rem; color: var(--texto-soft); text-align: center; margin-bottom: 4px; }
.lw-input {
  background: rgba(255,255,255,0.05);
  border: 1px solid rgba(255,255,255,0.1);
  border-radius: var(--r);
  color: var(--texto);
  font-family: 'Syne', sans-serif;
  font-size: 0.9rem;
  padding: 10px 14px;
  outline: none;
  transition: border-color 0.2s;
}
.lw-input:focus { border-color: var(--verde-m); }
.lw-btn-primary {
  background: linear-gradient(135deg, var(--verde-m), var(--verde));
  color: #fff; border: none; border-radius: var(--r2);
  padding: 11px; font-family: 'Syne',sans-serif;
  font-weight: 700; font-size: 0.9rem; cursor: pointer;
  transition: opacity 0.2s;
}
.lw-btn-primary:hover { opacity: 0.88; }
.lw-btn-primary:disabled { opacity: 0.5; cursor: not-allowed; }
.lw-switch { font-size: 0.78rem; color: var(--texto-soft); text-align: center; }
.lw-switch span { color: var(--verde-m); cursor: pointer; font-weight: 600; }
.lw-switch span:hover { text-decoration: underline; }
.lw-alert { font-size: 0.8rem; padding: 8px 12px; border-radius: var(--r); font-weight: 600; }
.lw-alert.error   { background: rgba(224,122,53,0.15); color: var(--naranja); }
.lw-alert.success { background: rgba(42,168,94,0.15);  color: var(--verde-m); }

/* Dashboard */
.lw-user-info {
  display: flex; align-items: center; gap: 12px;
  padding: 12px 14px;
  background: rgba(255,255,255,0.04);
  border-radius: var(--r2);
  margin-bottom: 16px;
}
.lw-avatar-big {
  width: 44px; height: 44px; border-radius: 50%;
  background: linear-gradient(135deg, var(--verde-m), var(--azul));
  display: flex; align-items: center; justify-content: center;
  font-weight: 800; font-size: 1.1rem; color: #fff; flex-shrink: 0;
}
.lw-user-name { font-weight: 700; font-size: 0.95rem; }
.lw-user-visits { font-size: 0.75rem; color: var(--texto-soft); }
.lw-logout { margin-left: auto; background: none; border: 1px solid rgba(255,255,255,0.1); color: var(--texto-soft); border-radius: var(--r); padding: 4px 10px; font-size: 0.72rem; cursor: pointer; font-family:'Syne',sans-serif; }
.lw-logout:hover { border-color: var(--naranja); color: var(--naranja); }

/* Progreso al siguiente logro */
.lw-next-bar { margin-bottom: 18px; }
.lw-next-label { font-size: 0.75rem; color: var(--texto-soft); margin-bottom: 6px; display: flex; justify-content: space-between; }
.lw-bar-track { height: 6px; background: rgba(255,255,255,0.08); border-radius: 99px; overflow: hidden; }
.lw-bar-fill  { height: 100%; background: linear-gradient(90deg, var(--verde-m), var(--azul)); border-radius: 99px; transition: width 0.6s ease; }

/* Grid de estampas */
.lw-stamps-title { font-size: 0.75rem; text-transform: uppercase; letter-spacing: .08em; color: var(--texto-soft); font-family: 'Syne',sans-serif; font-weight: 700; margin-bottom: 12px; }
.lw-stamps-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 10px;
}
.stamp-card {
  aspect-ratio: 1;
  border-radius: var(--r2);
  border: 1px solid rgba(255,255,255,0.07);
  display: flex; flex-direction: column;
  align-items: center; justify-content: center;
  gap: 4px;
  padding: 6px;
  cursor: pointer;
  transition: transform 0.2s, border-color 0.2s;
  position: relative;
  overflow: hidden;
}
.stamp-card:hover { transform: scale(1.06); }
.stamp-card.locked { opacity: 0.3; filter: grayscale(1); cursor: default; }
.stamp-card.locked:hover { transform: none; }
.stamp-card.unlocked { border-color: rgba(42,168,94,0.35); background: rgba(42,168,94,0.06); }
.stamp-card.unlocked:hover { border-color: var(--verde-m); }
.stamp-card img { width: 36px; height: 36px; object-fit: contain; }
.stamp-card .stamp-emoji { font-size: 1.4rem; }
.stamp-rareza {
  position: absolute; bottom: 3px; left: 0; right: 0;
  text-align: center; font-size: 0.5rem; font-weight: 700;
  text-transform: uppercase; letter-spacing: .05em;
}
.stamp-rareza.Común       { color: #aaa; }
.stamp-rareza.Poco\ común { color: #4caf50; }
.stamp-rareza.Raro        { color: #2196f3; }
.stamp-rareza.Épico       { color: #9c27b0; }
.stamp-rareza.Legendario  { color: #ff9800; }

/* Tooltip de estampa */
.stamp-tooltip {
  position: fixed;
  background: var(--card-bg);
  border: var(--glass-b);
  border-radius: var(--r2);
  padding: 12px 14px;
  font-size: 0.8rem;
  max-width: 200px;
  pointer-events: none;
  z-index: 99999;
  display: none;
  box-shadow: 0 8px 24px rgba(0,0,0,0.4);
}
.stamp-tooltip .st-name  { font-weight: 700; margin-bottom: 4px; }
.stamp-tooltip .st-desc  { color: var(--texto-soft); font-size: 0.75rem; }
.stamp-tooltip .st-req   { margin-top: 6px; font-size: 0.72rem; color: var(--verde-m); }

/* Notificación de nuevo logro */
.lw-notif {
  position: fixed;
  bottom: 96px; left: 28px;
  background: linear-gradient(135deg, var(--verde-m), var(--azul));
  color: #fff;
  border-radius: var(--r2);
  padding: 12px 16px;
  font-size: 0.85rem;
  font-weight: 600;
  display: flex; align-items: center; gap: 10px;
  box-shadow: 0 8px 24px rgba(42,168,94,0.4);
  z-index: 99998;
  animation: notifIn .4s ease;
  max-width: 300px;
}
@keyframes notifIn {
  from { opacity:0; transform: translateX(-20px); }
  to   { opacity:1; transform: translateX(0); }
}

@media (max-width: 400px) {
  .lw-panel { width: calc(100vw - 32px); left: 16px; }
  #logros-widget { left: 16px; bottom: 16px; }
}

/* =============================================
   MAPA DE CONTAMINACIÓN
   ============================================= */
#mapa-leaflet {
  width: 100%;
  height: 480px;
  border-radius: var(--r3);
  overflow: hidden;
  border: var(--glass-b);
  z-index: 1;
}

.mapa-filtros {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin-bottom: 20px;
}

.mf-btn {
  background: rgba(255,255,255,0.05);
  border: 1px solid rgba(255,255,255,0.1);
  color: var(--texto-soft);
  border-radius: 99px;
  padding: 8px 18px;
  font-size: 0.82rem;
  font-family: 'Syne', sans-serif;
  font-weight: 600;
  cursor: pointer;
  transition: all 0.2s;
}
.mf-btn:hover  { border-color: var(--verde-m); color: var(--verde-m); }
.mf-btn.active { background: var(--verde-m); border-color: var(--verde-m); color: #fff; }

.mapa-wrap {
  position: relative;
}

.mapa-legend {
  position: absolute;
  bottom: 16px;
  right: 16px;
  background: rgba(10,20,14,0.92);
  border: var(--glass-b);
  border-radius: var(--r2);
  padding: 12px 16px;
  backdrop-filter: blur(8px);
  z-index: 1000;
}
.ml-title {
  font-size: 0.7rem;
  text-transform: uppercase;
  letter-spacing: .08em;
  color: var(--texto-soft);
  font-weight: 700;
  margin-bottom: 8px;
}
.ml-item {
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: 0.75rem;
  color: var(--texto);
  margin-bottom: 6px;
  font-weight: 500;
}
.ml-dot {
  width: 12px; height: 12px;
  border-radius: 50%;
  flex-shrink: 0;
  box-shadow: 0 0 6px rgba(255,255,255,0.2);
}

/* Panel de info */
.mapa-info-panel {
  margin-top: 20px;
  background: var(--glass);
  border: var(--glass-b);
  border-radius: var(--r2);
  padding: 20px 24px;
  backdrop-filter: blur(12px);
  animation: fadeInUp .3s ease;
}
.mip-header {
  display: flex;
  align-items: center;
  gap: 14px;
  margin-bottom: 12px;
}
.mip-icon   { font-size: 1.8rem; }
.mip-nombre { font-weight: 700; font-size: 1rem; color: var(--texto); }
.mip-tipo   { font-size: 0.75rem; color: var(--verde-m); font-weight: 600; margin-top: 2px; }
.mip-close  { margin-left: auto; background: none; border: none; color: var(--texto-soft); cursor: pointer; font-size: 1.1rem; padding: 4px 8px; }
.mip-close:hover { color: var(--texto); }
.mip-desc   { font-size: 0.9rem; color: var(--texto); line-height: 1.7; margin-bottom: 14px; }
.mip-nivel  { display: flex; align-items: center; gap: 10px; }
.mip-nivel-label { font-size: 0.75rem; color: var(--texto-soft); font-weight: 600; }
.mip-stars  { font-size: 1rem; letter-spacing: 2px; }

/* Override leaflet tiles to match dark theme */
.leaflet-tile { filter: brightness(0.85) saturate(0.7); }
.leaflet-container { background: #0a140e; font-family: 'Syne', sans-serif; }

@media (max-width: 600px) {
  #mapa-leaflet { height: 320px; }
  .mapa-legend  { display: none; }
}

/* =============================================
   ENCUESTA EN PANEL DE LOGROS
   ============================================= */
.lw-encuesta-promo {
  margin-top: 20px;
  background: linear-gradient(135deg, rgba(42,168,94,0.12), rgba(58,130,232,0.08));
  border: 1px solid rgba(42,168,94,0.25);
  border-radius: var(--r2);
  padding: 14px 16px;
  display: flex;
  align-items: center;
  gap: 12px;
}
.lep-icon { font-size: 1.6rem; flex-shrink: 0; }
.lep-text { flex: 1; }
.lep-title { font-weight: 700; font-size: 0.85rem; color: var(--texto); }
.lep-sub   { font-size: 0.75rem; color: var(--texto-soft); margin-top: 3px; }
.lep-btn {
  background: var(--verde-m); color: #fff; border: none;
  border-radius: var(--r); padding: 8px 14px;
  font-family: 'Syne',sans-serif; font-weight: 700;
  font-size: 0.78rem; cursor: pointer; flex-shrink: 0;
  transition: opacity 0.2s;
}
.lep-btn:hover { opacity: 0.85; }

.lw-encuesta-done {
  margin-top: 16px;
  font-size: 0.8rem;
  color: var(--verde-m);
  padding: 10px 14px;
  background: rgba(42,168,94,0.08);
  border-radius: var(--r);
  border: 1px solid rgba(42,168,94,0.2);
}

/* Wrap encuesta */
.lw-enc-wrap { display: flex; flex-direction: column; gap: 14px; }

.enc-header { display: flex; align-items: center; gap: 10px; }
.enc-paso { font-size: 0.72rem; color: var(--texto-soft); font-weight: 700; white-space: nowrap; }
.enc-barra-wrap { flex: 1; height: 4px; background: rgba(255,255,255,0.08); border-radius: 99px; overflow: hidden; }
.enc-barra-fill { height: 100%; background: linear-gradient(90deg, var(--verde-m), var(--azul)); border-radius: 99px; transition: width 0.3s; }

.enc-pregunta { font-size: 0.88rem; font-weight: 600; color: var(--texto); line-height: 1.5; margin: 0; }

.enc-opciones { display: flex; flex-direction: column; gap: 8px; }
.enc-opcion {
  background: rgba(255,255,255,0.04);
  border: 1px solid rgba(255,255,255,0.09);
  border-radius: var(--r);
  color: var(--texto);
  font-family: 'Syne',sans-serif;
  font-size: 0.82rem;
  padding: 10px 14px;
  text-align: left;
  cursor: pointer;
  transition: all 0.2s;
}
.enc-opcion:hover   { border-color: var(--verde-m); background: rgba(42,168,94,0.08); }
.enc-opcion.selected { border-color: var(--verde-m); background: rgba(42,168,94,0.15); color: var(--verde-m); font-weight: 700; }

.enc-nav { display: flex; justify-content: space-between; align-items: center; }
.enc-nav-btn {
  background: rgba(255,255,255,0.06); border: 1px solid rgba(255,255,255,0.1);
  color: var(--texto); border-radius: var(--r); padding: 8px 16px;
  font-family: 'Syne',sans-serif; font-size: 0.8rem; font-weight: 600;
  cursor: pointer; transition: all 0.2s;
}
.enc-nav-btn:hover { border-color: var(--verde-m); color: var(--verde-m); }
.enc-nav-btn.primary { background: var(--verde-m); border-color: var(--verde-m); color: #fff; }
.enc-nav-btn.primary:hover { opacity: 0.85; }

.enc-cancelar {
  background: none; border: none; color: var(--texto-soft);
  font-size: 0.72rem; cursor: pointer; text-align: center;
  font-family: 'Syne',sans-serif; padding: 4px;
}
.enc-cancelar:hover { color: var(--naranja); }

/* Resultados */
.res-seccion { margin-bottom: 14px; }
.res-titulo  { font-size: 0.75rem; font-weight: 700; color: var(--texto-soft); margin-bottom: 8px; text-transform: uppercase; letter-spacing: .04em; }
.res-row     { display: flex; align-items: center; gap: 8px; margin-bottom: 6px; }
.res-label   { font-size: 0.72rem; color: var(--texto); width: 130px; flex-shrink: 0; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.res-bar-wrap { flex: 1; height: 6px; background: rgba(255,255,255,0.06); border-radius: 99px; overflow: hidden; }
.res-bar-fill { height: 100%; background: linear-gradient(90deg, var(--verde-m), var(--azul)); border-radius: 99px; transition: width 0.6s ease; }
.res-pct     { font-size: 0.7rem; color: var(--verde-m); font-weight: 700; width: 30px; text-align: right; }