/* =====================
   COOPNAMET Estilos Base
   Paleta: Verde (#1b7d3c / #23964b / #33b35d), Blanco (#ffffff), Gris (#f5f7f8 / #e1e5e8 / #6b7280), Oscuros (#1a1d21 / #2c3136)
   Tipografía: 'Inter', 'Segoe UI', Arial, sans-serif
   ===================== */

:root {
  --color-primary: #1b7d3c;
  --color-primary-alt: #23964b;
  --color-accent: #33b35d;
  --color-accent-glow: #45c86d;
  --color-bg: #ffffff;
  --color-bg-alt: #f5f7f8;
  --color-bg-soft: #eef3ef;
  --color-border: #e1e5e8;
  --color-text: #2c3136;
  --color-text-light: #6b7280;
  --color-dark: #101214;
  --radius-sm: 4px;
  --radius-md: 10px;
  --radius-lg: 22px;
  --shadow-sm: 0 2px 4px rgba(0,0,0,.06);
  --shadow-md: 0 4px 20px -2px rgba(0,0,0,.14);
  --shadow-lg: 0 10px 30px -6px rgba(0,0,0,.22);
  --transition: .35s cubic-bezier(.4,.2,.2,1);
  --gradient-primary: linear-gradient(135deg,#1b7d3c 0%,#33b35d 60%,#45c86d 100%);
  --gradient-dark: linear-gradient(135deg,#0f1f14,#132a1a 45%,#1b3b25 100%);
  --header-height: 74px;
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; scroll-padding-top: var(--header-height); }
body:not(.home) main { padding-top: calc(var(--header-height) + 12px); }
body.home main { padding-top:0; }
@media (max-width:900px){ :root { --header-height:66px; } html { scroll-padding-top:66px; } main { padding-top:66px; } }
body {
  margin: 0;
  font-family: Inter, 'Segoe UI', Arial, sans-serif;
  color: var(--color-text);
  background: radial-gradient(circle at 10% 15%, #ffffff 0%, #f4f9f5 55%, #eef3ef 100%);
  line-height: 1.5;
  font-size: 16px;
  -webkit-font-smoothing: antialiased;
}
/* Header */
.site-header { background:rgba(0,0,0,.25); backdrop-filter:blur(4px); border-bottom:1px solid rgba(255,255,255,.15); position:fixed; width:100%; top:0; z-index:90; transition:background .4s ease, box-shadow .4s ease, border-color .4s ease; }
.site-header.scrolled { background:rgba(255,255,255,.97); border-color: var(--color-border); box-shadow:0 4px 18px -6px rgba(0,0,0,.18); }
.site-header .container { min-height:74px; display:flex; align-items:center; }
.logo { display:flex; align-items:center; padding:0.25rem 0.5rem 0.25rem 0.4rem; background:transparent; backdrop-filter:none; border-radius:0; box-shadow:none; position:relative; margin-left:0; }
.site-header:not(.scrolled) .logo, .site-header.scrolled .logo { background:transparent; box-shadow:none; }
.logo img { height:58px; display:block; object-fit:contain; transition:opacity .35s ease; }
/* Estado base: solo logo blanco visible */
.logo img.logo-colored { opacity:0; }
.logo img.logo-white { position:absolute; left:0.55rem; top:50%; transform:translateY(-50%); opacity:1; }

/* En escritorio, permitir el efecto de cambiar a logo a color al hacer scroll en la home */
@media (min-width: 881px){
  .site-header:not(.scrolled) .logo img.logo-colored { opacity:0; }
  .site-header:not(.scrolled) .logo img.logo-white { opacity:1; }
  .home.show-colored-logo .site-header .logo img.logo-colored { opacity:1 !important; }
  .home.show-colored-logo .site-header .logo img.logo-white { opacity:0 !important; }
}
/* Move header content closer to left edge */
.site-header .container { padding-left:0; width:100%; }
@media (max-width:720px){
  .logo { padding:0.25rem 0.45rem 0.25rem 0.35rem; }
  .logo img { height:50px; }
  .site-header .container { padding-left:0; }
}
.main-nav { display:flex; align-items:center; gap:1rem; }
.main-nav { align-items:center; }
.main-nav .menu { list-style:none; margin:0; padding:0; display:flex; gap:.5rem; }
.main-nav .menu li a { padding:.95rem 1.15rem .95rem; display:flex; align-items:center; justify-content:center; min-width:110px; font-weight:600; letter-spacing:.3px; color:var(--color-text); border-radius: var(--radius-sm); position:relative; transition:background .35s ease, color .35s ease; }
.main-nav .menu li { display:flex; align-items:center; }
.site-header:not(.scrolled) .main-nav .menu li a { color:#ffffff; }
.site-header.scrolled .main-nav .menu li a { color: var(--color-text); }
.main-nav .menu li a:hover { background:rgba(27,125,60,.65); color:#fff; }
.main-nav .menu li a.active { background:rgba(27,125,60,.92); color:#fff; box-shadow:0 6px 20px -6px rgba(27,125,60,.55); }
.site-header:not(.scrolled) .main-nav .menu li a { text-shadow:0 2px 8px rgba(0,0,0,.55); }

/* Header: páginas internas (no inicio) en negro con opacidad */
body:not(.home) .site-header { background:rgba(0,0,0,.9) !important; border-bottom:1px solid rgba(255,255,255,.18) !important; box-shadow:0 6px 24px -10px rgba(0,0,0,.5); }
body:not(.home) .site-header.scrolled { background:rgba(0,0,0,.9) !important; border-color:rgba(255,255,255,.18) !important; box-shadow:0 6px 24px -10px rgba(0,0,0,.5) !important; }
body:not(.home) .site-header .main-nav .menu li a,
body:not(.home) .site-header.scrolled .main-nav .menu li a { color:#fff !important; }
body:not(.home) .site-header .main-nav .menu li a { text-shadow:0 2px 8px rgba(0,0,0,.55); }
/* Logo blanco siempre en páginas internas (solo escritorio) */
@media (min-width: 881px){
  body:not(.home) .site-header .logo img.logo-white { opacity:1 !important; }
  body:not(.home) .site-header .logo img.logo-colored { opacity:0 !important; }
}
.nav-toggle { display:none; background: var(--color-primary); color:#fff; border:none; padding:.6rem .9rem; border-radius: var(--radius-sm); font-size:1.1rem; }

/* Nueva Home */
.hero-home { padding:6.5rem 0 3.5rem; }
.hero-inner { display:flex; flex-direction:column; align-items:center; gap:1.8rem; }
.hero-photo { margin:0; width:100%; max-width:760px; border-radius:24px; overflow:hidden; box-shadow:0 12px 40px -12px rgba(0,0,0,.25); }
.hero-photo img { width:100%; height:auto; display:block; object-fit:cover; }
.hero-cards { display:flex; flex-wrap:wrap; justify-content:center; gap:1.4rem; margin-top:-120px; position:relative; }
.calc-card { background:#fff; width:290px; padding:1.4rem 1.25rem 1.65rem; border-radius:28px; box-shadow:0 12px 32px -10px rgba(0,0,0,.18); border:1px solid var(--color-border); display:flex; flex-direction:column; align-items:flex-start; gap:.55rem; position:relative; }
.calc-card::after { content:""; position:absolute; inset:0; border-radius:inherit; background:radial-gradient(circle at 30% 18%, rgba(27,125,60,.15), transparent 70%); opacity:0; transition:var(--transition); }
.calc-card:hover { transform:translateY(-8px); }
.calc-card:hover::after { opacity:1; }
.calc-card h2 { margin:0 0 .35rem; font-size:1.35rem; line-height:1.15; }
.calc-card .card-text { font-size:.85rem; color:var(--color-text-light); margin:0 0 .7rem; }
.icon-wrap { font-size:2rem; line-height:1; }
.hero-cards .btn { width:100%; text-align:center; }
@media (max-width:820px){
  .hero-cards { margin-top:-90px; }
  .calc-card { width:260px; }
}
@media (max-width:640px){
  .hero-cards { margin-top:-70px; }
}

.feature-row { padding:1.2rem 0 2.2rem; }
.feature-row-list { display:grid; gap:1rem 1.6rem; grid-template-columns: repeat(auto-fit,minmax(260px,1fr)); }
.feature-item { display:flex; align-items:flex-start; gap:.9rem; background:var(--color-bg-alt); padding:.9rem 1rem; border:1px solid var(--color-border); border-radius:18px; box-shadow: var(--shadow-sm); }
.feature-icon-circle { flex-shrink:0; width:56px; height:56px; border-radius:50%; background:var(--color-primary); display:flex; align-items:center; justify-content:center; font-size:1.6rem; color:#fff; box-shadow:0 8px 20px -6px rgba(27,125,60,.45); }
.feature-text h3 { margin:.2rem 0 .35rem; font-size:1rem; }
.feature-text p { margin:0; font-size:.8rem; color:var(--color-text-light); line-height:1.35; }
.features-overlay { display:flex; flex-wrap:wrap; gap:1rem; justify-content:center; margin:-120px auto 2rem; position:relative; z-index:2; }
.features-overlay .feature-item { background:rgba(255,255,255,.85); backdrop-filter:blur(6px); border:1px solid rgba(255,255,255,.4); box-shadow:0 6px 24px -10px rgba(0,0,0,.25); }
.features-overlay .feature-item.mini { flex:1 1 240px; min-width:240px; }
.fondo-bg { background-image:url('assets/img/fondo.jpg'); background-size:cover; background-position:center; position:relative; }
.fondo-bg::before { content:""; position:absolute; inset:0; background:transparent; }
.fondo-bg > .container { position:relative; z-index:3; }
/* Servicios organizados */
.services-sequential { display:grid; grid-template-columns:repeat(auto-fit,minmax(280px,1fr)); gap:2.2rem; position:relative; margin-top:1.5rem; }
.service-row { background:#fff; border:1px solid var(--color-border); border-radius:28px; padding:1.4rem 1.2rem 1.6rem; display:flex; flex-direction:column; gap:1rem; box-shadow:0 10px 28px -12px rgba(0,0,0,.18); position:relative; overflow:hidden; opacity:0; transform:translateY(50px); transition:opacity .7s ease, transform .7s cubic-bezier(.25,.6,.3,1); }
.service-row.in { opacity:1; transform:translateY(0); }
.service-row::before { content:""; position:absolute; inset:0; background:radial-gradient(circle at 30% 18%, rgba(27,125,60,.12), transparent 70%); opacity:0; transition:opacity .45s ease; }
.service-row:hover::before { opacity:1; }
.service-media { width:72px; height:72px; border-radius:22px; background:var(--color-primary); display:flex; align-items:center; justify-content:center; font-size:2rem; color:#fff; box-shadow:0 12px 26px -10px rgba(0,0,0,.35); }
.service-icon { width:100%; height:100%; display:flex; align-items:center; justify-content:center; }
.service-content h3 { margin:.2rem 0 .4rem; font-size:1.25rem; }
.service-content p { margin:0 0 .9rem; font-size:.85rem; color:var(--color-text-light); line-height:1.4; }
.service-row .btn { align-self:flex-start; }
@media (max-width:640px){ .services-sequential { gap:1.4rem; } .service-row { padding:1.25rem 1rem 1.35rem; } }
/* Remove old alternating layout styles */
.service-row.left .service-media, .service-row.right .service-media, .service-row.left .service-content, .service-row.right .service-content { order:initial; }
/* Hero Slider */
.hero-slider { position: relative; width:100%; height:70vh; min-height:480px; overflow:hidden; background:#000; border-bottom:1px solid var(--color-border); }
.hero-slider .slide { will-change:transform; }
.hero-slider.parallax-active .slide.active { animation: none; }
@media (prefers-reduced-motion: no-preference){
  .hero-slider.parallax-active .slide.active { transition: opacity 1.2s ease, transform 3.5s ease; }
}
/* Parallax transform applied inline via JS */
.hero-slider .slides { position:relative; width:100%; height:100%; }
.slide { position:absolute; inset:0; background-size:cover; background-position:center; opacity:0; transition: opacity 1.5s ease, transform 3.5s ease; transform:scale(1.08); }
.slide.active { opacity:1; transform:scale(1); }
.slide .overlay { background:linear-gradient(115deg, rgba(0,0,0,.65) 0%, rgba(0,0,0,.45) 40%, rgba(0,0,0,.25) 70%); color:#fff; position:absolute; inset:0; display:flex; flex-direction:column; justify-content:center; padding:4.5rem 8% 3rem; z-index:2; }
@media (max-width: 640px){
  .slide .overlay { padding:5.5rem 6% 2.5rem; }
}
.slide h1 { font-size:clamp(2rem,5vw,3.2rem); margin:0 0 1rem; line-height:1.1; }
.slide p { font-size:clamp(1rem,2.2vw,1.25rem); max-width:52ch; }
.slider-arrow { position:absolute; top:50%; transform:translateY(-50%); background:rgba(0,0,0,.4); color:#fff; border:none; width:52px; height:52px; border-radius:50%; font-size:1.9rem; line-height:1; cursor:pointer; display:flex; align-items:center; justify-content:center; backdrop-filter: blur(2px); transition:var(--transition); }
.slider-arrow:hover { background:rgba(27,125,60,.8); box-shadow:0 8px 24px -6px rgba(0,0,0,.4); }
.slider-arrow:active { transform:translateY(-50%) scale(.92); }
.slider-arrow.prev { left:24px; }
.slider-arrow.next { right:24px; }
.slider-arrow:focus-visible { outline:3px solid #fff; }

/* Intro */
.intro-section { padding:3rem 0 2rem; }
.intro-section h2 { margin-top:0; font-size:2rem; }
.intro-text p { font-size:1.05rem; max-width:70ch; }

/* Features */
.features-section { padding:2rem 0 3rem; }
.features-section h2 { text-align:center; margin:0 0 2rem; font-size:2rem; }
.card-grid { display:grid; gap:1.5rem; grid-template-columns: repeat(auto-fit,minmax(240px,1fr)); }
.card { background: var(--color-bg-alt); padding:1.25rem 1.1rem 1.4rem; border-radius: var(--radius-lg); position:relative; overflow:hidden; box-shadow: var(--shadow-sm); border:1px solid var(--color-border); display:flex; flex-direction:column; gap:.6rem; transition: var(--transition); }
.card::before { content:""; position:absolute; inset:0; background:radial-gradient(circle at 30% 20%, rgba(51,179,93,.15), transparent 60%); opacity:0; transition:var(--transition); }
.card:hover { transform:translateY(-8px); box-shadow: var(--shadow-lg); border-color: var(--color-primary-alt); }
.card:hover::before { opacity:1; }
.card-icon { font-size:1.9rem; }
.card h3 { margin:.3rem 0 .3rem; font-size:1.15rem; }
.card p { flex-grow:1; color: var(--color-text-light); font-size:.95rem; }
.card-link { font-weight:600; font-size:.9rem; }
.card-link:hover { text-decoration:underline; }

/* Quiénes Somos */
.contenido-quienes { padding:3rem 0; }
.contenido-quienes h1 { font-size:2.2rem; margin-top:0; }
.texto-extenso p { margin:0 0 1.1rem; text-align:justify; }
.antecedentes { margin-top:1.75rem; }
.antecedentes h2 { font-size:1.9rem; margin:0 0 1rem; }
.timeline {
  position:relative;
  margin-top:2.2rem;
  display:grid;
  gap:2rem;
  padding:0 0 0 1.5rem;
}
.timeline::before {
  content:"";
  position:absolute;
  left:1.1rem;
  top:0.4rem;
  bottom:0.4rem;
  width:3px;
  background:linear-gradient(180deg, rgba(27,125,60,.2), rgba(51,179,93,.65));
}
.timeline-item {
  position:relative;
  display:grid;
  grid-template-columns: 120px minmax(0,1fr);
  gap:1.4rem;
  align-items:flex-start;
  opacity:0;
  transform:translateY(40px);
  transition:opacity .7s ease, transform .7s cubic-bezier(.25,.6,.3,1);
  transition-delay: var(--timeline-delay, 0s);
}
.timeline-item:nth-child(even) .timeline-body {
  background:linear-gradient(135deg, rgba(27,125,60,.08), rgba(51,179,93,.18));
}
.timeline-item.in { opacity:1; transform:translateY(0); }
.timeline-marker {
  position:relative;
  display:flex;
  flex-direction:column;
  align-items:flex-start;
  gap:.45rem;
  min-width:0;
}
.timeline-year {
  font-size:1.1rem;
  font-weight:700;
  color:var(--color-primary);
  letter-spacing:.04em;
}
.timeline-icon {
  width:44px;
  height:44px;
  border-radius:14px;
  background:#fff;
  border:1px solid rgba(27,125,60,.25);
  display:flex;
  align-items:center;
  justify-content:center;
  font-size:1.4rem;
  box-shadow:0 12px 24px -14px rgba(0,0,0,.35);
}
.timeline-body {
  background:#fff;
  border-radius:22px;
  padding:1.2rem 1.3rem 1.3rem;
  border:1px solid rgba(27,125,60,.14);
  box-shadow:0 16px 32px -24px rgba(0,0,0,.3);
}
.timeline-body h3 {
  margin:0 0 .4rem;
  font-size:1.25rem;
}
.timeline-body p {
  margin:0;
  color:var(--color-text-light);
  line-height:1.55;
}
.timeline-item::before {
  content:"";
  position:absolute;
  left:-1.35rem;
  top:1.4rem;
  width:18px;
  height:18px;
  border-radius:50%;
  background:#fff;
  border:4px solid var(--color-primary);
  box-shadow:0 6px 16px -10px rgba(0,0,0,.4);
}
.timeline-item:nth-child(even)::before { border-color:var(--color-accent); }
@media (max-width:680px){
  .timeline { padding:0; }
  .timeline::before { left:0.45rem; }
  .timeline-item { grid-template-columns:minmax(0,1fr); padding-left:1.6rem; }
  .timeline-marker { flex-direction:row; align-items:center; gap:.8rem; }
  .timeline-item::before { left:-0.05rem; }
}
.valores { margin-top:3rem; }
.valores-grid { display:grid; gap:1.5rem; grid-template-columns: repeat(auto-fit,minmax(260px,1fr)); }
.valor-item { background: var(--color-bg-alt); padding:1.2rem 1rem 1.3rem; border-radius: var(--radius-md); border:1px solid var(--color-border); box-shadow: var(--shadow-sm); position:relative; overflow:hidden; }
.valor-item::after { content:""; position:absolute; inset:0; background:linear-gradient(120deg,rgba(27,125,60,.08),rgba(51,179,93,.15)); opacity:0; transition:var(--transition); }
.valor-item:hover::after { opacity:1; }
.valor-item h3 { margin-top:0; }

/* Servicios */
.servicios-page { padding:3rem 0; }
.servicios-page h1 { margin-top:0; font-size:2.2rem; }
.servicio-bloque { margin-top:2.8rem; }
.servicio-bloque h2 { font-size:1.8rem; margin:0 0 1rem; }
.servicio-grid { display:grid; gap:1.5rem; grid-template-columns: repeat(auto-fit,minmax(260px,1fr)); }
.servicio-item { background: var(--color-bg-alt); padding:1.2rem 1rem 1.3rem; border-radius: var(--radius-md); border:1px solid var(--color-border); box-shadow: var(--shadow-sm); position:relative; overflow:hidden; }
.servicio-item::before { content:""; position:absolute; top:0; left:0; right:0; height:4px; background:var(--gradient-primary); opacity:.5; transition:var(--transition); }
.servicio-item:hover::before { opacity:1; }
.servicio-item:hover { box-shadow: var(--shadow-md); }
.servicio-item h3 { margin-top:0; font-size:1.15rem; }
.servicio-item ul { padding-left:1.2rem; margin:.5rem 0 0; font-size:.9rem; }

/* Recursos */
.resources-hero { background:linear-gradient(145deg,rgba(27,125,60,.08),rgba(6,49,24,.1)); padding:5rem 0 4rem; }
.resources-hero-inner { display:grid; gap:3rem; align-items:center; grid-template-columns:repeat(auto-fit,minmax(280px,1fr)); }
.resources-hero-copy h1 { font-size:2.6rem; line-height:1.12; margin:1rem 0; }
.resources-hero-copy p { font-size:1.05rem; max-width:560px; }
.resources-hero-actions { display:flex; flex-wrap:wrap; gap:1rem; margin-top:2.1rem; }
.resources-hero-summary { display:grid; gap:1.1rem; }
.resources-hero-card { display:flex; gap:1rem; align-items:flex-start; background:var(--color-bg); border:1px solid rgba(6,49,24,.08); border-radius:var(--radius-lg); padding:1.4rem 1.6rem; box-shadow:var(--shadow-sm); }
.resources-hero-card-icon { font-size:1.8rem; line-height:1; }
.resources-hero-card h3 { margin:0 0 .35rem; font-size:1.1rem; }
.resources-hero-card p { margin:0; font-size:.9rem; color:var(--color-text-light); }

.resources-library { padding:4.5rem 0; background:var(--color-bg); }
.resources-toolbar { display:flex; justify-content:space-between; gap:1.6rem; align-items:flex-start; flex-wrap:wrap; }
.resources-toolbar h2 { margin:0 0 .4rem; }
.resources-toolbar p { margin:0; max-width:560px; color:var(--color-text-light); }
.resources-count { display:inline-flex; align-items:center; gap:.4rem; background:rgba(27,125,60,.12); color:var(--color-primary); padding:.45rem .9rem; border-radius:999px; font-weight:600; font-size:.9rem; }
.resources-count strong { font-size:1.1rem; }

.resource-filters { display:flex; flex-wrap:wrap; gap:.6rem; margin:2rem 0 2.2rem; }
.resource-chip { padding:.55rem 1.05rem; border-radius:999px; border:1px solid var(--color-border); background:var(--color-bg-alt); cursor:pointer; font-weight:600; font-size:.9rem; transition:var(--transition); }
.resource-chip:hover,
.resource-chip:focus-visible { border-color:var(--color-primary); color:var(--color-primary); outline:none; }
.resource-chip.active { background:var(--color-primary); color:#fff; border-color:var(--color-primary); }

.resource-grid { display:grid; gap:1.5rem; grid-template-columns:repeat(auto-fit,minmax(260px,1fr)); }
.resource-card { background:var(--color-bg); border:1px solid var(--color-border); border-radius:var(--radius-lg); padding:1.8rem; display:flex; flex-direction:column; gap:1.2rem; box-shadow:var(--shadow-sm); transition:var(--transition); position:relative; }
.resource-card:hover { transform:translateY(-4px); box-shadow:var(--shadow-md); }
.resource-card.is-hidden { display:none; }

.resource-card-header { display:flex; align-items:center; justify-content:space-between; gap:1rem; }
.resource-icon { width:52px; height:52px; border-radius:16px; background:linear-gradient(145deg,rgba(27,125,60,.14),rgba(6,49,24,.08)); display:grid; place-items:center; color:var(--color-primary); flex-shrink:0; }
.resource-icon svg { width:26px; height:26px; fill:currentColor; }
.resource-pill { background:rgba(6,49,24,.08); color:var(--color-text-light); padding:.35rem .7rem; border-radius:999px; font-size:.75rem; font-weight:600; text-transform:uppercase; letter-spacing:.5px; }
.resource-card-body h3 { margin:0 0 .4rem; font-size:1.15rem; }
.resource-card-body p { margin:0; font-size:.95rem; color:var(--color-text); }
.resource-meta { display:flex; gap:.6rem; list-style:none; padding:0; margin:.2rem 0 0; font-size:.75rem; text-transform:uppercase; letter-spacing:.4px; color:var(--color-text-light); }
.resource-card-footer { display:flex; align-items:center; gap:1rem; flex-wrap:wrap; }
.resource-preview { font-weight:600; color:var(--color-primary); }
.resource-preview:hover,
.resource-preview:focus-visible { text-decoration:underline; outline:none; }

.resources-empty { margin-top:2rem; font-size:.95rem; color:var(--color-text-light); text-align:center; }

/* Noticias */
.noticias-page { padding:3rem 0; }
.noticias-page h1 { margin-top:0; font-size:2.2rem; }
.noticias-lista { display:grid; gap:1.6rem; grid-template-columns: repeat(auto-fit,minmax(300px,1fr)); margin-top:2rem; }
.noticia-item { background: var(--color-bg-alt); padding:1.3rem 1.1rem 1.6rem; border-radius: var(--radius-md); border:1px solid var(--color-border); box-shadow: var(--shadow-sm); display:flex; flex-direction:column; position:relative; overflow:hidden; }
.noticia-item::before { content:""; position:absolute; inset:0; background:linear-gradient(140deg,rgba(27,125,60,.12),transparent 70%); opacity:0; transition:var(--transition); }
.noticia-item:hover::before { opacity:1; }
.noticia-item:hover { box-shadow: var(--shadow-md); }
.noticia-item h2 { margin:0 0 .4rem; font-size:1.2rem; }
.noticia-item .fecha { font-size:.75rem; letter-spacing:.5px; text-transform:uppercase; color: var(--color-text-light); margin:0 0 .7rem; }
.noticia-item p { font-size:.9rem; flex-grow:1; }
.leer-mas { font-weight:600; font-size:.85rem; margin-top:.8rem; }

/* Educación */
.education-hero { background:linear-gradient(145deg,rgba(27,125,60,.08),rgba(6,49,24,.1)); padding:5rem 0 4rem; }
.education-hero-inner { display:grid; gap:3rem; align-items:center; grid-template-columns:repeat(auto-fit,minmax(280px,1fr)); }
.education-hero-copy h1 { font-size:2.8rem; line-height:1.15; margin:1rem 0; }
.education-hero-copy p { font-size:1.05rem; max-width:580px; }
.badge { display:inline-flex; align-items:center; gap:.4rem; font-size:.75rem; text-transform:uppercase; letter-spacing:.6px; font-weight:600; padding:.35rem .75rem; border-radius:999px; }
.badge-soft { background:rgba(27,125,60,.12); color:var(--color-primary); }
.sr-only { position:absolute; width:1px; height:1px; padding:0; margin:-1px; overflow:hidden; clip:rect(0,0,0,0); border:0; }
.hero-actions { display:flex; flex-wrap:wrap; gap:1rem; margin-top:2.2rem; }
.btn-ghost[data-scroll-target] { border:1px solid rgba(27,125,60,.3); }
.education-hero-cards { display:grid; gap:1.2rem; }
.hero-card { background:var(--color-bg); border:1px solid rgba(6,49,24,.08); border-radius:var(--radius-lg); padding:1.5rem; box-shadow:var(--shadow-sm); transition:var(--transition); }
.hero-card:hover { transform:translateY(-4px); box-shadow:var(--shadow-md); }

.education-hub { padding:4.5rem 0; }
.education-hub h2 { text-align:center; margin-bottom:.6rem; }
.section-lead { text-align:center; max-width:700px; margin:0 auto 2.5rem; font-size:1.05rem; color:var(--color-text-light); }
.hub-grid { display:grid; gap:1rem; grid-template-columns:repeat(auto-fit,minmax(220px,1fr)); }
.hub-card { background:var(--color-bg-alt); border:1px solid var(--color-border); border-radius:var(--radius-md); padding:1.4rem 1.2rem; text-align:left; cursor:pointer; display:grid; gap:.7rem; align-content:start; transition:var(--transition); }
.hub-card:hover, .hub-card:focus-visible { outline:none; border-color:var(--color-primary); box-shadow:0 12px 30px rgba(27,125,60,.12); transform:translateY(-3px); }
.hub-icon { font-size:1.8rem; }

.finance-lab { padding:4.5rem 0; }
.lab-tabs { display:flex; flex-wrap:wrap; gap:.8rem; margin-bottom:2rem; }
.lab-tab { padding:.65rem 1.1rem; border-radius:999px; border:1px solid var(--color-border); background:var(--color-bg); cursor:pointer; transition:var(--transition); font-weight:600; }
.lab-tab.active { background:var(--color-primary); color:#fff; border-color:var(--color-primary); }
.lab-panel { display:none; gap:2.5rem; align-items:flex-start; }
.lab-panel.active { display:grid; grid-template-columns:repeat(auto-fit,minmax(260px,1fr)); }
.lab-form, .lab-result { background:var(--color-bg-alt); border:1px solid var(--color-border); border-radius:var(--radius-md); padding:1.6rem; box-shadow:var(--shadow-sm); display:grid; gap:1rem; }
.lab-form label { display:grid; gap:.4rem; font-weight:600; font-size:.9rem; }
.lab-form input[type="number"], .lab-form input[type="range"] { width:100%; }
.range-output { font-size:.85rem; color:var(--color-text-light); }
.lab-highlight { font-size:1.15rem; font-weight:700; color:var(--color-primary); }
.lab-tips { list-style:none; padding:0; margin:0; display:grid; gap:.6rem; }
.lab-tips li { font-size:.9rem; background:rgba(27,125,60,.08); padding:.7rem .8rem; border-radius:var(--radius-sm); }
.lab-stats { display:grid; gap:.4rem; grid-template-columns:repeat(2,minmax(0,1fr)); }
.lab-stats dt { font-size:.8rem; text-transform:uppercase; letter-spacing:.5px; color:var(--color-text-light); margin:0; }
.lab-stats dd { margin:0; font-weight:700; font-size:1rem; }
.budget-panel { display:grid; gap:1.5rem; grid-template-columns:repeat(auto-fit,minmax(260px,1fr)); }
.budget-grid { display:grid; gap:.8rem .9rem; grid-template-columns:repeat(auto-fit,minmax(160px,1fr)); }
.budget-item { display:grid; gap:.35rem; font-size:.9rem; }
.budget-results { display:grid; gap:1rem; }
.budget-bars { display:grid; gap:.8rem; }
.budget-bar { background:rgba(6,49,24,.08); border-radius:var(--radius-sm); overflow:hidden; }
.budget-bar span { display:block; height:.6rem; background:linear-gradient(120deg,var(--color-primary),#49c187); }
.budget-bar small { display:block; font-size:.75rem; color:var(--color-text-light); margin-top:.2rem; }

.education-coach { padding:4.5rem 0; background:var(--color-bg-alt); }
.coach-widget { display:grid; gap:1.5rem; background:var(--color-bg); border-radius:var(--radius-lg); padding:2rem; border:1px solid var(--color-border); box-shadow:var(--shadow-sm); }
.coach-chat { max-height:320px; overflow-y:auto; display:grid; gap:1rem; padding-right:.4rem; }
.coach-message { display:grid; gap:.3rem; padding:1rem 1.2rem; border-radius:var(--radius-md); max-width:520px; font-size:.95rem; position:relative; }
.coach-message--bot { background:rgba(27,125,60,.1); }
.coach-message--user { background:var(--color-bg-alt); margin-left:auto; border:1px solid var(--color-border); }
.coach-menu { display:flex; flex-wrap:wrap; gap:.8rem; justify-content:flex-start; }
.coach-menu button { padding:.65rem 1rem; border-radius:999px; border:1px solid var(--color-border); background:var(--color-bg-alt); cursor:pointer; font-weight:600; transition:var(--transition); }
.coach-menu button:hover, .coach-menu button:focus-visible { border-color:var(--color-primary); background:rgba(27,125,60,.12); outline:none; }

.education-quiz { padding:4.5rem 0; }
.quiz-card { background:var(--color-bg); border-radius:var(--radius-lg); padding:2.2rem; border:1px solid var(--color-border); box-shadow:var(--shadow-sm); display:grid; gap:1.5rem; }
.quiz-options { display:grid; gap:.9rem; }
.quiz-option { padding:1rem 1.2rem; border-radius:var(--radius-md); border:1px solid var(--color-border); cursor:pointer; font-weight:600; transition:var(--transition); text-align:left; background:var(--color-bg-alt); }
.quiz-option:hover { border-color:var(--color-primary); }
.quiz-option[disabled] { cursor:not-allowed; opacity:.6; }
.quiz-option.correct { border-color:#1b7d3c; background:rgba(27,125,60,.15); }
.quiz-option.incorrect { border-color:#c9503d; background:rgba(201,80,61,.15); }
.quiz-footer { display:flex; justify-content:space-between; align-items:center; flex-wrap:wrap; gap:1rem; }
.quiz-badge { font-weight:700; color:var(--color-primary); }

/* Redirección */
.redirect-page { display:flex; min-height:100vh; align-items:center; justify-content:center; background:var(--color-bg-alt); }
.redirect-wrapper { text-align:center; display:grid; gap:1rem; padding:4rem 1.5rem; background:var(--color-bg); border:1px solid var(--color-border); border-radius:var(--radius-lg); box-shadow:var(--shadow-sm); }

@media (max-width: 960px) {
  .resources-hero-inner { grid-template-columns:1fr; }
  .resources-hero-copy h1 { font-size:2.3rem; }
  .education-hero-copy h1 { font-size:2.3rem; }
  .quiz-card { padding:1.8rem; }
}

@media (max-width: 720px) {
  .resources-hero { padding:4rem 0 3rem; }
  .resources-hero-actions { flex-direction:column; align-items:flex-start; }
  .resources-toolbar { flex-direction:column; align-items:flex-start; }
  .resource-card-footer { flex-direction:column; align-items:flex-start; }
  .education-hero { padding:4rem 0 3rem; }
  .hero-actions { flex-direction:column; align-items:flex-start; }
  .lab-panel.active { grid-template-columns:1fr; }
  .budget-panel { grid-template-columns:1fr; }
  .coach-widget { padding:1.6rem; }
}

@media (prefers-reduced-motion: reduce) {
  .hero-card:hover,
  .hub-card:hover,
  .lab-tab,
  .quiz-option,
  .action-item { transition:none; transform:none; }
}

/* Contacto */
.contacto-page {
  padding:4rem 0 3.5rem;
  display:flex;
  flex-direction:column;
  gap:3rem;
}
.contacto-intro {
  display:grid;
  grid-template-columns: repeat(auto-fit,minmax(280px,1fr));
  gap:2.5rem;
  align-items:flex-start;
  background:#fff;
  border:1px solid var(--color-border);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-sm);
  padding:2.8rem 2.4rem;
}
.contacto-texto h1 {
  margin:0 0 1rem;
  font-size:2.2rem;
}
.contacto-texto p {
  margin:0;
  color:var(--color-text-light);
  line-height:1.6;
}
.contacto-canales {
  margin-top:2.4rem;
  display:grid;
  gap:1.6rem;
}
.contacto-canal {
  display:flex;
  gap:1.1rem;
  align-items:flex-start;
}
.contacto-icono {
  flex-shrink:0;
  width:62px;
  height:62px;
  border-radius:50%;
  background:#f2d447;
  display:flex;
  align-items:center;
  justify-content:center;
  box-shadow:0 12px 24px -12px rgba(0,0,0,.4);
}
.contacto-icono svg {
  width:28px;
  height:28px;
  fill:var(--color-primary);
}
.contacto-label {
  display:block;
  font-weight:600;
  text-transform:uppercase;
  font-size:.75rem;
  letter-spacing:.6px;
  color:var(--color-text-light);
  margin-bottom:.25rem;
}
.contacto-valor {
  display:block;
  font-size:1.1rem;
  font-weight:700;
  color:var(--color-primary);
  text-decoration:none;
}
.contacto-valor:hover { color:var(--color-primary-alt); }
.contacto-horario {
  display:block;
  margin-top:.3rem;
  font-size:.85rem;
  color:var(--color-text-light);
}
.contacto-mapa {
  display:flex;
  align-items:stretch;
}
.contacto-mapa .mapa-embed {
  border-radius:24px;
  overflow:hidden;
  box-shadow:0 18px 36px -16px rgba(0,0,0,.32);
  width:100%;
}
.mapa-embed iframe {
  display:block;
  width:100%;
  height:380px;
  border:0;
}
.contacto-form-block {
  padding:0;
  border-radius: var(--radius-lg);
  border:1px solid rgba(35,150,75,.12);
  box-shadow: var(--shadow-sm);
}
.contacto-form-inner {
  max-width:760px;
  margin:0 auto;
  padding:2.8rem 2.4rem;
  display:flex;
  flex-direction:column;
  gap:1.8rem;
}
.contacto-form-inner h2 {
  margin:0;
  font-size:2rem;
}
.contacto-form-inner p {
  margin:0;
  color:var(--color-text-light);
}
.contacto-form {
  display:grid;
  gap:1.5rem;
}
.contacto-form .form-row {
  display:grid;
  grid-template-columns: repeat(auto-fit,minmax(220px,1fr));
  gap:1.2rem;
}
.contacto-form .campo {
  display:flex;
  flex-direction:column;
  gap:.45rem;
}
.contacto-form label {
  font-weight:600;
  font-size:.9rem;
}
.contacto-form input,
.contacto-form textarea {
  padding:.8rem .95rem;
  border:1px solid var(--color-border);
  border-radius: var(--radius-md);
  font:inherit;
  background:#fff;
  transition:border-color .25s ease, box-shadow .25s ease;
}
.contacto-form input:focus,
.contacto-form textarea:focus {
  outline:none;
  border-color:var(--color-primary);
  box-shadow:0 0 0 3px rgba(33,179,93,.18);
}
.contacto-form textarea {
  resize:vertical;
  min-height:140px;
}
@media (max-width:720px){
  .contacto-intro { padding:2.4rem 1.8rem; }
  .contacto-icono { width:54px; height:54px; }
  .contacto-form-inner { padding:2.4rem 1.8rem; }
  .mapa-embed iframe { height:320px; }
}

/* Footer */
.site-footer { background: var(--gradient-dark); color:#fff; margin-top:4rem; position:relative; overflow:hidden; }
.site-footer::before { content:""; position:absolute; inset:0; background:radial-gradient(circle at 15% 35%, rgba(51,179,93,.18), transparent 60%); opacity:.4; pointer-events:none; }
.footer-grid { display:grid; gap:2rem; grid-template-columns: repeat(auto-fit,minmax(240px,1fr)); padding:3rem 0 2.5rem; }
.footer-logo { height:50px; margin-bottom:.5rem; }
.footer-links, .contact-info, .social-links { list-style:none; margin:0; padding:0; display:grid; gap:.45rem; }
.footer-links a, .contact-info li, .social-links a { color:#d1d5db; font-size:.9rem; }
.footer-links a:hover, .social-links a:hover { color:#fff; }
.footer-bottom { border-top:1px solid #2f3439; padding:1rem 0; text-align:center; font-size:.75rem; letter-spacing:.5px; text-transform:uppercase; }
/* Variante barra contacto compacta (si se usa) */
.footer-contact-bar { background:#0b3820; color:#fff; padding:1.1rem 0; font-size:.8rem; }
.footer-contact-bar .bar-inner { display:flex; flex-wrap:wrap; align-items:center; justify-content:space-between; gap:1rem; }
.footer-contact-bar img { height:42px; }
.footer-contact-bar a { color:#fff; font-weight:600; }

/* Utilities */
.container { width:min(1200px,92%); margin:0 auto; }
.flex { display:flex; }
.align-center { align-items:center; }
.between { justify-content:space-between; }

/* Buttons */
.btn { display:inline-block; padding:.75rem 1.2rem; border-radius: var(--radius-md); font-weight:600; cursor:pointer; transition: var(--transition); }
.btn-primary, .btn-solid { background: var(--color-primary); color:#fff; position:relative; }
.btn-primary:hover, .btn-solid:hover { background: var(--color-primary-alt); box-shadow:0 8px 26px -8px rgba(0,0,0,.35); }
.btn-solid { border-radius:40px; }

/* Acceso Socios Button (removido) */

/* Responsive Nav */
@media (max-width: 880px) {
  .nav-toggle { display:block; }
  .main-nav { flex-wrap:wrap; }
  /* Menú móvil fijo y centrado para que no se desplace al hacer scroll */
  .main-nav .menu {
    position: fixed;
    top: 80px;
    left: 50%;
    transform: translateX(-50%);
    width: 80%;
    max-width: 380px;
    flex-basis:auto;
    flex-direction:column;
    background:rgba(0,0,0,.78);
    backdrop-filter:blur(10px);
    border:1px solid rgba(255,255,255,.18);
    border-radius: var(--radius-md);
    padding:.85rem .95rem .95rem;
    display:none;
    box-shadow:0 14px 38px -14px rgba(0,0,0,.65);
    z-index:95;
  }
  .main-nav .menu.open { display:flex; }
  .main-nav .menu li a { color:#fff !important; text-shadow:0 2px 8px rgba(0,0,0,.6); width:100%; justify-content:flex-start; padding:.85rem .95rem; border-radius:12px; }
  .main-nav .menu li a.active { background:rgba(27,125,60,.9); box-shadow:0 6px 20px -6px rgba(27,125,60,.55); }
  .main-nav .menu li a:hover { background:rgba(27,125,60,.7); }
  .main-nav .menu li a::after { bottom:4px; }
  /* Logo ajuste en modo móvil: evitar versión grande y mantener sólo blanco */
  .logo img { height:46px; }
  .logo img.logo-colored { display:none; }
  .logo img.logo-white { opacity:1 !important; position:relative; left:auto; top:auto; transform:none; }
  body.home .site-header.scrolled .logo img.logo-white { opacity:1; }
  body.home .site-header.scrolled .logo img.logo-colored { display:none; }
  .home.show-colored-logo .site-header .logo img.logo-colored { display:block !important; opacity:1 !important; }
  .home.show-colored-logo .site-header .logo img.logo-white { opacity:0 !important; }
  .acceso-btn { order:3; }
}

/* Utilidades */
.text-center { text-align:center; }
.hidden { display:none !important; }

/* Animaciones y transiciones adicionales */
.card, .valor-item, .servicio-item, .noticia-item { will-change:transform; }

/* Accesibilidad */
:focus-visible { outline:2px dashed var(--color-primary-alt); outline-offset:2px; }

/* Placeholder imágenes slider (pueden reemplazarse con fotos reales) */
.hero-slider .slide { background-color:#1b7d3c; }
.hero-slider .slide:nth-child(2) { background-color:#23964b; }
.hero-slider .slide:nth-child(3) { background-color:#33b35d; }
.hero-slider .slide:nth-child(4) { background-color:#145a2c; }

/* Calculadoras */
.tools-main {
  width:min(1200px,92%);
  margin:0 auto;
  padding:4rem 0 4.5rem;
  display:flex;
  flex-direction:column;
  gap:3rem;
}
.tools-hero {
  display:grid;
  grid-template-columns: repeat(auto-fit,minmax(280px,1fr));
  gap:3rem;
  align-items:center;
  padding:3.2rem 3rem;
  border-radius:40px;
  background:linear-gradient(135deg,#f1fbf4 0%, #e0f6ea 45%, #d2efdf 100%);
  border:1px solid rgba(51,179,93,.18);
  box-shadow:0 24px 50px -22px rgba(27,125,60,.35);
  position:relative;
  overflow:hidden;
}
.tools-hero::after {
  content:"";
  position:absolute;
  top:-120px;
  right:-140px;
  width:320px;
  height:320px;
  background:conic-gradient(from 0deg, rgba(27,125,60,.18), rgba(51,179,93,0));
  filter:blur(14px);
  opacity:.6;
}
.tools-hero-copy { position:relative; z-index:2; display:flex; flex-direction:column; gap:1.2rem; }
.tools-eyebrow {
  font-size:.8rem;
  letter-spacing:.4rem;
  text-transform:uppercase;
  color:var(--color-primary);
  font-weight:700;
}
.tools-hero-copy h1 { margin:0; font-size:clamp(2.1rem,4vw,3rem); line-height:1.1; }
.tools-hero-copy p { margin:0; font-size:1.05rem; color:var(--color-text-light); max-width:52ch; }
.tools-hero-actions { display:flex; flex-wrap:wrap; gap:1rem; }
.tools-hero-graphic { position:relative; z-index:2; display:flex; flex-direction:column; gap:1.4rem; align-items:flex-end; justify-content:center; }
.tools-hero-card {
  background:#fff;
  border-radius:28px;
  padding:1.6rem 1.8rem;
  box-shadow:0 22px 44px -20px rgba(0,0,0,.35);
  border:1px solid rgba(27,125,60,.14);
  min-width:240px;
}
.metric-label { font-size:.75rem; text-transform:uppercase; letter-spacing:.35rem; color:var(--color-text-light); font-weight:600; }
.metric-value { display:block; margin-top:.4rem; font-size:1.9rem; font-weight:700; color:var(--color-primary); }
.metric-caption { display:block; margin-top:.3rem; font-size:.85rem; color:var(--color-text-light); }
.tools-hero-progress { display:flex; flex-direction:column; gap:.35rem; align-items:flex-end; }
.progress-meter { width:220px; height:12px; border-radius:999px; background:rgba(27,125,60,.12); overflow:hidden; position:relative; }
.progress-fill { position:absolute; inset:0; background:var(--gradient-primary); border-radius:inherit; }
.progress-text { font-size:.8rem; font-weight:600; color:var(--color-primary); }
.btn-outline {
  border:1px solid var(--color-primary);
  color:var(--color-primary);
  background:transparent;
}
.btn-outline:hover { background:var(--color-primary); color:#fff; }
.btn-ghost {
  border:1px solid transparent;
  color:var(--color-text-light);
  background:rgba(255,255,255,.6);
}
.btn-ghost:hover { color:var(--color-primary); background:rgba(27,125,60,.08); }
.tools-highlights { display:grid; grid-template-columns: repeat(auto-fit,minmax(240px,1fr)); gap:1.6rem; }
.tool-card {
  background:#fff;
  border:1px solid var(--color-border);
  border-radius:28px;
  padding:1.6rem 1.4rem;
  display:flex;
  gap:1.2rem;
  align-items:flex-start;
  box-shadow:0 18px 30px -20px rgba(0,0,0,.35);
  transition:transform .35s ease, box-shadow .35s ease;
}
.tool-card:hover { transform:translateY(-8px); box-shadow:0 26px 44px -24px rgba(0,0,0,.4); }
.tool-card-icon {
  flex-shrink:0;
  width:60px;
  height:60px;
  border-radius:20px;
  background:linear-gradient(140deg, rgba(27,125,60,.12), rgba(51,179,93,.22));
  display:flex;
  align-items:center;
  justify-content:center;
  font-size:1.8rem;
}
.tool-card-body h2 { margin:0 0 .4rem; font-size:1.35rem; }
.tool-card-body p { margin:0 0 1rem; font-size:.9rem; color:var(--color-text-light); }
.tool-link {
  display:inline-flex;
  align-items:center;
  gap:.45rem;
  font-weight:600;
  font-size:.9rem;
  color:var(--color-primary);
  background:none;
  border:none;
  cursor:pointer;
  padding:0;
  text-decoration:none;
}
.tool-link::after { content:"→"; font-size:1rem; transition:transform .3s ease; }
.tool-link:hover::after { transform:translateX(4px); }
.tools-workbench {
  background:#fff;
  border:1px solid rgba(27,125,60,.12);
  border-radius:36px;
  padding:2.4rem 2.2rem 2.6rem;
  box-shadow:0 24px 44px -26px rgba(0,0,0,.35);
}
.tools-tabs { display:flex; gap:.6rem; flex-wrap:wrap; margin-bottom:1.8rem; }
.tool-tab {
  border:none;
  background:rgba(27,125,60,.08);
  color:var(--color-text-light);
  padding:.65rem 1.35rem;
  border-radius:999px;
  font-weight:600;
  cursor:pointer;
  transition:background .3s ease, color .3s ease, box-shadow .3s ease;
}
.tool-tab.active {
  background:var(--gradient-primary);
  color:#fff;
  box-shadow:0 16px 32px -18px rgba(27,125,60,.55);
}
.tools-layout { display:grid; grid-template-columns: minmax(0,1fr) 300px; gap:2rem; align-items:start; }
.tool-panels { position:relative; }
.tool-panel { display:flex; flex-direction:column; gap:1.8rem; }
.tool-panel[hidden] { display:none; }
.tool-panel.active { animation: toolFade .4s ease; }
@keyframes toolFade { from{opacity:0; transform:translateY(12px);} to{opacity:1; transform:translateY(0);} }
.tool-form { display:flex; flex-direction:column; gap:1.5rem; }
.field-row { display:grid; grid-template-columns: repeat(auto-fit,minmax(220px,1fr)); gap:1.2rem; }
.field { display:flex; flex-direction:column; gap:.4rem; }
.field label { font-weight:600; font-size:.9rem; }
.field input, .field select {
  padding:.85rem .95rem;
  border:1px solid var(--color-border);
  border-radius:var(--radius-md);
  font:inherit;
  transition:border-color .25s ease, box-shadow .25s ease;
  background:#fff;
}
.field input:focus, .field select:focus { outline:none; border-color:var(--color-primary); box-shadow:0 0 0 3px rgba(33,179,93,.18); }
.tool-actions { display:flex; flex-wrap:wrap; gap:.8rem; }
.tool-results {
  border:1px solid rgba(27,125,60,.14);
  border-radius:26px;
  background:linear-gradient(135deg, rgba(27,125,60,.05), rgba(51,179,93,.08));
  padding:1.6rem 1.4rem;
  min-height:140px;
  display:flex;
  flex-direction:column;
  gap:1rem;
}
.result-grid { display:grid; grid-template-columns: repeat(auto-fit,minmax(220px,1fr)); gap:1rem; }
.result-card {
  background:#fff;
  border:1px solid rgba(27,125,60,.12);
  border-radius:22px;
  padding:1rem 1.1rem 1.2rem;
  display:flex;
  flex-direction:column;
  gap:.35rem;
  box-shadow:0 12px 24px -18px rgba(0,0,0,.25);
}
.result-card.emphasis { border-color:var(--color-primary); box-shadow:0 16px 32px -22px rgba(27,125,60,.4); }
.result-label { font-size:.75rem; text-transform:uppercase; letter-spacing:.3rem; color:var(--color-text-light); font-weight:600; }
.result-value { font-size:1.4rem; font-weight:700; color:var(--color-primary); }
.result-note { font-size:.8rem; color:var(--color-text-light); }
.tool-hint { margin:0; color:var(--color-text-light); font-size:.9rem; }
.tabla-ahorro {
  margin-top:1.5rem;
  border:1px solid rgba(27,125,60,.12);
  border-radius:20px;
  overflow:hidden;
  background:#fff;
  box-shadow:0 16px 32px -26px rgba(0,0,0,.35);
}
.tabla-ahorro table { width:100%; border-collapse:collapse; font-size:.85rem; }
.tabla-ahorro th, .tabla-ahorro td { padding:.6rem .75rem; border-bottom:1px solid var(--color-border); text-align:right; }
.tabla-ahorro th { background:var(--color-primary); color:#fff; text-align:center; }
.tabla-ahorro tr:nth-child(even) td { background:var(--color-bg-soft); }
.tabla-ahorro caption { text-align:left; font-weight:600; margin:0 0 .5rem; padding:1rem 1.1rem 0; }
.tool-aside { display:flex; flex-direction:column; gap:1.2rem; }
.tool-aside-card {
  background:linear-gradient(135deg,#102d1c,#134528);
  color:#eef9f1;
  border-radius:24px;
  padding:1.6rem 1.4rem;
  display:flex;
  flex-direction:column;
  gap:.8rem;
  box-shadow:0 18px 36px -22px rgba(0,0,0,.55);
}
.tool-aside-card h3 { margin:0; font-size:1.2rem; }
.tool-aside-card ul { margin:0; padding-left:1.2rem; display:grid; gap:.6rem; font-size:.9rem; }
.tool-aside-card[hidden] { display:none; }
@media (max-width:1024px){
  .tools-layout { grid-template-columns:1fr; }
  .tool-aside { order:-1; }
}
@media (max-width:720px){
  .tools-main { padding:3.2rem 0 3.8rem; }
  .tools-hero { padding:2.6rem 2.1rem; }
  .tools-hero-actions { justify-content:flex-start; }
  .tools-workbench { padding:2rem 1.6rem; }
}
/* Reveal Animations */
.reveal { opacity:0; transform:translateY(40px); transition:opacity .9s ease, transform .9s cubic-bezier(.25,.6,.3,1); }
.reveal.in { opacity:1; transform:translateY(0); }
.reveal[data-delay="100"] { transition-delay:.1s; }
.reveal[data-delay="200"] { transition-delay:.2s; }
.reveal[data-delay="300"] { transition-delay:.3s; }
.reveal[data-delay="400"] { transition-delay:.4s; }

/* Fancy underline on nav links */
.main-nav .menu li a { position:relative; }
.main-nav .menu li a::after { content:""; position:absolute; left:12px; right:12px; bottom:6px; height:3px; background:var(--gradient-primary); transform:scaleX(0); transform-origin:left; transition:transform .45s cubic-bezier(.4,.2,.2,1); border-radius:3px; }
.main-nav .menu li a:hover::after, .main-nav .menu li a.active::after { transform:scaleX(1); }
.bg-green-soft { background:linear-gradient(135deg,#f0f9f3 0%, #e4f5ea 40%, #d7efdf 100%); }
.bg-green-alt { background:linear-gradient(125deg,#eaf7ee 0%, #d9f1e2 55%, #cbe9d6 100%); }
.bg-green-soft, .bg-green-alt { position:relative; }
.bg-green-soft::before, .bg-green-alt::before { content:""; position:absolute; inset:0; background:radial-gradient(circle at 8% 12%, rgba(27,125,60,.06), transparent 60%); pointer-events:none; }
/* Formas decorativas adicionales */
.bg-green-soft::after, .bg-green-alt::after { content:""; position:absolute; top:10%; left:65%; width:240px; height:240px; background:conic-gradient(from 0deg, rgba(27,125,60,.18), rgba(51,179,93,.0) 65%); filter:blur(18px); opacity:.55; border-radius:50%; pointer-events:none; }
.bg-green-alt .shape-float, .bg-green-soft .shape-float { position:absolute; width:160px; height:160px; background:linear-gradient(140deg, rgba(33,179,93,.25), rgba(27,125,60,.35)); top:55%; left:8%; transform:rotate(25deg); border-radius:32px; filter:blur(6px); opacity:.4; pointer-events:none; }
.bg-green-alt .shape-ring, .bg-green-soft .shape-ring { position:absolute; width:180px; height:180px; border:6px solid rgba(27,125,60,.25); top:25%; right:10%; border-radius:50%; backdrop-filter:blur(2px); pointer-events:none; }

/* Fade-in for green sections */
.bg-green-soft, .bg-green-alt { opacity:0; transform:translateY(40px); transition:opacity .9s ease, transform .9s cubic-bezier(.25,.6,.3,1); }
.bg-green-soft.in, .bg-green-alt.in { opacity:1; transform:translateY(0); }
/* Overlap efecto (sección sube sobre slider) */
.overlap-target { margin-top:-80px; padding-top:140px; border-top-left-radius:36px; border-top-right-radius:36px; box-shadow:0 -6px 30px -10px rgba(0,0,0,.25); }
@media (max-width:820px){ .overlap-target { margin-top:-60px; padding-top:120px; } }
@media (max-width:640px){ .overlap-target { margin-top:-40px; padding-top:100px; } }
.overlap-target.scroll-inset { will-change:transform; }
.calc-section { padding:2rem 0 1.5rem; }
.calc-grid { display:flex; flex-wrap:wrap; gap:1.5rem; justify-content:center; }
.calc-section .calc-card { margin-top:0; }
.btn-oval { display:inline-block; background:var(--color-primary); color:#fff !important; padding:.55rem 1rem .6rem; border-radius:40px; font-size:.75rem; letter-spacing:.5px; text-transform:uppercase; font-weight:600; box-shadow:0 6px 20px -8px rgba(0,0,0,.25); }
.btn-oval:hover { background:var(--color-primary-alt); }
/* Parallax Productos y Servicios */
.ps-parallax { position:absolute; inset:0; overflow:hidden; pointer-events:none; z-index:1; }
.services-grid-home { position:relative; }
.ps-layer { position:absolute; inset:0; background-size:600px 600px; background-repeat:no-repeat; background-position:center; will-change:transform; }
.ps-layer.gradient-base { background:radial-gradient(circle at 40% 35%, rgba(27,125,60,.15), rgba(27,125,60,.05) 40%, transparent 70%); }
.ps-layer.circles { mix-blend-mode:screen; opacity:.55; }
.ps-layer.lines { mix-blend-mode:multiply; opacity:.28; }
/* Depth scaling applied via JS */
.services-sequential { position:relative; z-index:2; }
.services-grid-home::before { content:""; position:absolute; top:0; left:0; right:0; height:0; background:none; pointer-events:none; z-index:0; }
/* Productos y Servicios heading banner */
.services-heading-banner {
  position: relative;
  margin: 2.5rem 0 1.5rem;
  border-radius: 0;
  overflow: visible;
  min-height: auto;
  display: flex;
  align-items: flex-end;
  padding: 0;
  isolation: isolate;
  background: transparent;
  backdrop-filter: none;
}
.services-heading-banner::before {
  content: "";
  position: absolute;
  inset: 0;
  background: none;
  z-index: 1;
  pointer-events: none;
}
.services-heading-banner::after {
  content: "";
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 0;
  background: none;
  opacity: 0;
  z-index: 3;
}
.shb-slides { position:absolute; inset:0; z-index:0; }
.shb-slide { position:absolute; inset:0; background-size:cover; background-position:center; opacity:0; animation: shbFade 21s linear infinite; }
.shb-slide.s1 { background-image:url('assets/img/gente.jpg'); animation-delay:0s; }
.shb-slide.s2 { background-image:url('assets/img/gente2.jpg'); animation-delay:7s; }
.shb-slide.s3 { background-image:url('assets/img/gente3.jpg'); animation-delay:14s; }
@keyframes shbFade {
  0% { opacity:0; transform:scale(1) translateY(0); }
  4% { opacity:1; }
  30% { opacity:1; transform:scale(1.04) translateY(-2%); }
  33% { opacity:0; }
  100% { opacity:0; }
}
.services-heading-banner h2 {
  position: relative;
  z-index: 2;
  color: #0a7034;
  font-size: clamp(2.2rem, 4vw, 3.6rem);
  font-weight: 700;
  letter-spacing: .5px;
  text-shadow: 0 2px 8px rgba(255,255,255,0.3);
  margin: 0;
  padding: 1rem 0 1.5rem;
}
@media (max-width: 680px) {
  .services-heading-banner { min-height:120px; padding:1.6rem 1.4rem 1.2rem; }
  .services-heading-banner h2 { font-size: clamp(1.7rem, 6vw, 2.4rem); }
}
/* Fallback single image if needed */
.services-heading-banner.single-image .shb-slide:not(.s1) { display:none; }
.services-heading-banner.single-image .shb-slide.s1 { opacity:1; animation: shbPan 15s ease-in-out infinite; }
@keyframes shbPan { 0%{transform:scale(1) translateY(0);} 50%{transform:scale(1.06) translateY(-3%);} 100%{transform:scale(1) translateY(0);} }
.features-overlay + .services-heading-banner { margin-top: 1rem; }
/* Full-width background for Productos y Servicios section */
.services-full-bg {
  width:100vw;
  position:relative;
  left:50%;
  right:50%;
  margin-left:-50vw;
  margin-right:-50vw; /* full-bleed technique */
  background-image:url('assets/img/gente2.jpg');
  background-size:cover;
  background-position:center;
  background-attachment:scroll;
  z-index:1;
}
.services-full-bg::before {
  content:"";
  position:absolute; inset:0;
  background:linear-gradient(to bottom, rgba(0,0,0,0.55) 0%, rgba(0,0,0,0.35) 45%, rgba(0,0,0,0) 100%) !important;
}
.services-full-bg .container { position:relative; z-index:2; }
/* reduce top gradient from earlier pseudo-element to avoid double darkening */
.services-full-bg.services-grid-home::before { height:0; background:none; }
/* Overlap: slider extends visually until heading */
.hero-slider { position:relative; }
.hero-slider::after {
  content:""; position:absolute; left:0; right:0; bottom:-80px; height:160px;
  background:linear-gradient(to bottom, rgba(0,0,0,0.2) 0%, rgba(0,0,0,0.1) 40%, transparent 70%, transparent 100%);
  pointer-events:none; z-index:5;
}
.services-overlap { margin-top:-120px; position:relative; z-index:6; background:transparent; }
.services-overlap .services-heading-banner { margin-top:0; }
@media (max-width:900px){
  .services-overlap { margin-top:-90px; }
  .hero-slider::after { bottom:-60px; height:130px; }
}
@media (max-width:600px){
  .services-overlap { margin-top:-70px; }
  .hero-slider::after { bottom:-50px; height:110px; }
}
/* Remove previous full-bg adjustments if still present */
.services-full-bg { background:none !important; width:auto; left:auto; margin:0; }

/* Presupuesto 360 Styles */
.budget-container {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 3rem;
  align-items: start;
}

.budget-section h3 {
  margin-top: 0;
  margin-bottom: 1.5rem;
  font-size: 1.2rem;
  color: var(--color-text);
}

.income-label {
  display: block;
  font-weight: 700;
  color: var(--color-primary);
  margin-bottom: 0.5rem;
  font-size: 1.1rem;
}

.input-wrapper.large-input {
  position: relative;
  display: flex;
  align-items: center;
  margin-top: 0.8rem;
}

.input-wrapper.large-input .currency-icon {
  position: absolute;
  left: 1.2rem;
  font-size: 1.5rem;
  color: #fff;
  background: #2ecc71;
  width: 32px;
  height: 32px;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 4px;
  font-weight: bold;
  z-index: 2;
}

.input-wrapper.large-input input {
  width: 100%;
  padding: 1rem 1rem 1rem 4rem;
  font-size: 1.8rem;
  font-weight: 700;
  color: var(--color-primary);
  border: 2px solid var(--color-primary);
  border-radius: 12px;
  outline: none;
  background: #fff;
}

.budget-grid-inputs {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
  gap: 1.5rem;
  margin-top: 2rem;
}

.budget-input-item {
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
  font-weight: 600;
  color: var(--color-text-light);
  font-size: 0.95rem;
}

.budget-input-item .input-icon {
  margin-right: 0.3rem;
}

.budget-input-item input {
  padding: 0.8rem;
  border: 1px solid var(--color-border);
  border-radius: 8px;
  font-size: 1.1rem;
  font-weight: 600;
  color: var(--color-text);
}

.budget-results-col {
  background: #fff;
  padding: 2rem;
  border-radius: 24px;
  box-shadow: 0 10px 30px -10px rgba(0,0,0,0.1);
  border: 1px solid var(--color-border);
}

.budget-results-col h3 {
  margin-top: 0;
  font-size: 1.1rem;
  margin-bottom: 1.5rem;
}

.balance-card {
  background: linear-gradient(135deg, #e8f5e9 0%, #c8e6c9 100%);
  padding: 2rem;
  border-radius: 16px;
  text-align: center;
  margin-bottom: 2rem;
  border: 1px solid rgba(46, 204, 113, 0.2);
}

.balance-label {
  display: block;
  font-size: 0.85rem;
  text-transform: uppercase;
  letter-spacing: 1px;
  color: var(--color-text-light);
  margin-bottom: 0.5rem;
  font-weight: 600;
}

.balance-amount {
  display: block;
  font-size: 2.5rem;
  font-weight: 800;
  color: var(--color-primary);
}

.budget-bars-list {
  display: flex;
  flex-direction: column;
  gap: 1.2rem;
  margin-bottom: 2rem;
}

.budget-bar-item {
  display: flex;
  flex-direction: column;
  gap: 0.4rem;
}

.budget-bar-header {
  display: flex;
  justify-content: space-between;
  font-size: 0.9rem;
  font-weight: 600;
  color: var(--color-text);
}

.budget-bar-track {
  height: 8px;
  background: #f0f0f0;
  border-radius: 4px;
  overflow: hidden;
}

.budget-bar-fill {
  height: 100%;
  background: var(--color-primary);
  border-radius: 4px;
  transition: width 0.5s ease;
}

.budget-feedback {
  background: #f1f8f4;
  padding: 1rem;
  border-radius: 8px;
  font-size: 0.9rem;
  color: var(--color-text);
  border-left: 4px solid var(--color-primary);
}

@media (max-width: 850px) {
  .budget-container {
    grid-template-columns: 1fr;
    gap: 2rem;
  }
}
