.elementor-9967 .elementor-element.elementor-element-86160b3{--display:flex;--padding-top:0px;--padding-bottom:0px;--padding-left:0px;--padding-right:0px;}.elementor-9967 .elementor-element.elementor-element-86160b3:not(.elementor-motion-effects-element-type-background), .elementor-9967 .elementor-element.elementor-element-86160b3 > .elementor-motion-effects-container > .elementor-motion-effects-layer{background-color:transparent;background-image:linear-gradient(133deg, var( --e-global-color-75d05c9 ) 0%, var( --e-global-color-6faf128 ) 100%);}.elementor-9967 .elementor-element.elementor-element-86160b3 > .elementor-shape-bottom .elementor-shape-fill, .elementor-9967 .elementor-element.elementor-element-86160b3 > .e-con-inner > .elementor-shape-bottom .elementor-shape-fill{fill:var( --e-global-color-astglobalcolor5 );}.elementor-9967 .elementor-element.elementor-element-86160b3 > .elementor-shape-bottom svg, .elementor-9967 .elementor-element.elementor-element-86160b3 > .e-con-inner > .elementor-shape-bottom svg{width:calc(300% + 1.3px);height:101px;}.elementor-9967 .elementor-element.elementor-element-050790e{--display:flex;--padding-top:0px;--padding-bottom:0px;--padding-left:0px;--padding-right:0px;}.elementor-9967 .elementor-element.elementor-element-3ba9b28{--display:flex;--padding-top:0px;--padding-bottom:0px;--padding-left:0px;--padding-right:0px;}.elementor-9967 .elementor-element.elementor-element-3ba9b28 > .elementor-shape-top .elementor-shape-fill, .elementor-9967 .elementor-element.elementor-element-3ba9b28 > .e-con-inner > .elementor-shape-top .elementor-shape-fill{fill:#FFFFFF;}.elementor-9967 .elementor-element.elementor-element-3ba9b28 > .elementor-shape-top svg, .elementor-9967 .elementor-element.elementor-element-3ba9b28 > .e-con-inner > .elementor-shape-top svg{width:calc(300% + 1.3px);height:48px;}.elementor-9967 .elementor-element.elementor-element-579ffc6{--display:flex;}.elementor-9967 .elementor-element.elementor-element-579ffc6 > .elementor-shape-top .elementor-shape-fill, .elementor-9967 .elementor-element.elementor-element-579ffc6 > .e-con-inner > .elementor-shape-top .elementor-shape-fill{fill:#F7FBF9;}.elementor-9967 .elementor-element.elementor-element-579ffc6 > .elementor-shape-top svg, .elementor-9967 .elementor-element.elementor-element-579ffc6 > .e-con-inner > .elementor-shape-top svg{width:calc(300% + 1.3px);height:76px;}.elementor-9967 .elementor-element.elementor-element-579ffc6 > .elementor-shape-bottom .elementor-shape-fill, .elementor-9967 .elementor-element.elementor-element-579ffc6 > .e-con-inner > .elementor-shape-bottom .elementor-shape-fill{fill:#F7FBF9;}.elementor-9967 .elementor-element.elementor-element-579ffc6 > .elementor-shape-bottom svg, .elementor-9967 .elementor-element.elementor-element-579ffc6 > .e-con-inner > .elementor-shape-bottom svg{width:calc(300% + 1.3px);height:110px;}.elementor-9967 .elementor-element.elementor-element-501b039{--display:flex;--flex-direction:column;--container-widget-width:calc( ( 1 - var( --container-widget-flex-grow ) ) * 100% );--container-widget-height:initial;--container-widget-flex-grow:0;--container-widget-align-self:initial;--flex-wrap-mobile:wrap;--align-items:center;--padding-top:40px;--padding-bottom:0px;--padding-left:0px;--padding-right:0px;}.elementor-9967 .elementor-element.elementor-element-bdf41dd{text-align:center;}.elementor-9967 .elementor-element.elementor-element-bdf41dd .elementor-heading-title{font-size:2.2em;}.elementor-9967 .elementor-element.elementor-element-7b78424{width:var( --container-widget-width, 61% );max-width:61%;--container-widget-width:61%;--container-widget-flex-grow:0;text-align:center;line-height:1.4em;color:#1E2F23E8;}.elementor-9967 .elementor-element.elementor-element-b122f0d{padding:0px 0px 40px 0px;}.elementor-9967 .elementor-element.elementor-element-6b532d2{--display:flex;}.elementor-9967 .elementor-element.elementor-element-6b532d2 > .elementor-shape-top .elementor-shape-fill, .elementor-9967 .elementor-element.elementor-element-6b532d2 > .e-con-inner > .elementor-shape-top .elementor-shape-fill{fill:#F7FBF9;}.elementor-9967 .elementor-element.elementor-element-6b532d2 > .elementor-shape-top svg, .elementor-9967 .elementor-element.elementor-element-6b532d2 > .e-con-inner > .elementor-shape-top svg{width:calc(257% + 1.3px);height:85px;}.elementor-9967 .elementor-element.elementor-element-5d1faae{--display:flex;--flex-direction:column;--container-widget-width:100%;--container-widget-height:initial;--container-widget-flex-grow:0;--container-widget-align-self:initial;--flex-wrap-mobile:wrap;}.elementor-9967 .elementor-element.elementor-element-3a2aa51{--display:flex;--flex-direction:column;--container-widget-width:100%;--container-widget-height:initial;--container-widget-flex-grow:0;--container-widget-align-self:initial;--flex-wrap-mobile:wrap;--padding-top:0px;--padding-bottom:0px;--padding-left:0px;--padding-right:0px;}.elementor-9967 .elementor-element.elementor-element-299ae4a{--display:flex;--flex-direction:column;--container-widget-width:100%;--container-widget-height:initial;--container-widget-flex-grow:0;--container-widget-align-self:initial;--flex-wrap-mobile:wrap;}.elementor-9967 .elementor-element.elementor-element-299ae4a:not(.elementor-motion-effects-element-type-background), .elementor-9967 .elementor-element.elementor-element-299ae4a > .elementor-motion-effects-container > .elementor-motion-effects-layer{background-color:var( --e-global-color-astglobalcolor2 );}.elementor-9967 .elementor-element.elementor-element-dd15f7d{--display:flex;--padding-top:0px;--padding-bottom:0px;--padding-left:0px;--padding-right:0px;}@media(max-width:767px){.elementor-9967 .elementor-element.elementor-element-050790e{--padding-top:0px;--padding-bottom:0px;--padding-left:0px;--padding-right:0px;}}/* Start custom CSS for html, class: .elementor-element-a542d1f */#hero-solidario {

  padding: 100px 0 90px;
  overflow: hidden;
}
#hero-solidario .hero-wrap {
  display: grid;
  grid-template-columns: 1.15fr .85fr;
  gap: 40px;
  align-items: center;
}
#hero-solidario .rep-heading-1 {
  font-size: 2.6rem;
  line-height: 1.2;
  margin-bottom: 18px;
}
#hero-solidario .rep-hero-sub {
  margin-top: 8px;
  font-size: 1.05rem;
  opacity: 0.95;
}
#hero-solidario .hero-cta {
  margin-top: 24px;
}
#hero-solidario .rep-btn-accent {
  font-size: 1.05rem;
  padding: 14px 28px;
}
#hero-solidario .rep-trust {
  display: block;
  margin-top: 18px;
  opacity: .85;
}
#hero-solidario .hero-visual img {
  max-width: 480px;
  width: 100%;
  border-radius: 12px;
  filter: drop-shadow(0 10px 24px rgba(0,0,0,.25));
}
@media(max-width:900px){
  #hero-solidario .hero-wrap{grid-template-columns:1fr;text-align:center;}
  #hero-solidario .hero-visual img{margin:0 auto;}
}/* End custom CSS */
/* Start custom CSS for html, class: .elementor-element-025a01c *//* ===========================================================
   BLOQUE 2 · Beneficios Tangibles
   =========================================================== */
#beneficios {
  background: var(--rep-white);
  padding: 100px 0 110px;
  overflow: hidden;
}

#beneficios .rep-heading-2 {
  font-weight: 700;
  margin-bottom: 8px;
}

#beneficios .rep-benefits-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(290px, 1fr));
  gap: 32px;
  margin-top: 40px;
}

/* --- Tarjeta --- */
#beneficios .rep-benefit {
  text-align: left;
  background: rgba(147,241,201,.06);
  border: 1px solid rgba(147,241,201,.25);
  border-radius: 18px;
  padding: 38px 30px;
  transition: all .35s ease;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 10px rgba(0,0,0,.05);
}

#beneficios .rep-benefit:hover {
  background: rgba(147,241,201,.12);
  transform: translateY(-6px);
  box-shadow: 0 8px 28px rgba(0,0,0,.08);
}

/* --- Icono superior --- */
#beneficios .rep-benefit-icon {
  width: 60px;
  height: 60px;
  margin-bottom: 20px;
  background: linear-gradient(135deg, var(--rep-mint) 0%, var(--rep-teal) 100%);
  border-radius: 14px;
  display: flex;
  align-items: center;
  justify-content: center;
  box-shadow: 0 6px 18px rgba(0,0,0,.1);
}
#beneficios .rep-benefit-icon img {
  width: 34px;
  height: 34px;
  filter: brightness(0) invert(1);
  transition: transform .3s ease;
}
#beneficios .rep-benefit:hover .rep-benefit-icon img {
  transform: scale(1.08);
}

#beneficios h3.rep-heading-3 {
  color: var(--rep-forest);
  font-size: 1.25rem;
  margin: 0 0 10px;
}

#beneficios p.rep-text-body {
  color: var(--rep-text-secondary);
  font-size: 1.05rem;
  line-height: 1.6;
}

@media(max-width:768px){
  #beneficios .rep-benefit {padding:30px 24px;}
  #beneficios .rep-benefit-icon{width:52px;height:52px;margin-bottom:14px;}
  #beneficios h3.rep-heading-3{font-size:1.15rem;}
}/* End custom CSS */
/* Start custom CSS for html, class: .elementor-element-8773395 *//* ===========================================================
   BLOQUE 3 · Hosting para quienes hacen algo bueno (FORZADO)
   =========================================================== */
#hosting-bueno {
  /* fallback mint */
  padding: 110px 0 120px;
  text-align: center;
}

#hosting-bueno h2 {
  margin-bottom: 16px;
  font-weight: 700;
  font-size: 2rem;
  color: var(--rep-forest, #123c36); /* fallback verde oscuro */
}

#hosting-bueno p {
  font-size: 1.05rem;
  line-height: 1.7;
  color: var(--rep-text-secondary, #1f3e39); /* fallback gris verdoso */
}

#hosting-bueno p strong {
  color: var(--rep-teal, #41999F);
}

/* Botón */
#hosting-bueno .rep-btn-primary {
  margin-top: 16px;
  font-size: 1.05rem;
  padding: 14px 30px;
  border-radius: 14px;
  background: var(--rep-teal, #41999F);
  color: var(--rep-white, #fff);
  transition: background .3s ease, transform .3s ease, box-shadow .3s ease;
}
#hosting-bueno .rep-btn-primary:hover {
  background: #368f95;
  transform: translateY(-3px);
  box-shadow: 0 8px 20px rgba(65,153,159,.3);
}

/* Fade-up */
#hosting-bueno h2,
#hosting-bueno p,
#hosting-bueno .rep-btn-primary {
  opacity: 1;
  transform: none; /* sin animación para testear visibilidad */
}/* End custom CSS */
/* Start custom CSS for html, class: .elementor-element-a2fe499 *//* ===========================================================
   BLOQUE 4 · Rendimiento profesional, ética garantizada (REFINED)
   =========================================================== */
#hosting-etico {

  padding: 110px 0;
  color: var(--rep-white, #fff);
  position: relative;
  overflow: hidden;
}

/* Grid */
#hosting-etico .rep-grid-2 {
  display: grid;
  grid-template-columns: 1.1fr 0.9fr;
  gap: 80px;
  align-items: center;
}

/* Texto */
#hosting-etico h2 {
  font-size: 2.2rem;
  margin-bottom: 18px;
  font-weight: 700;
  color: var(--rep-white, #fff);
}

#hosting-etico p {
  color: rgba(255,255,255,.95); /* más claro */
  line-height: 1.7;
  margin-bottom: 28px;
}
#hosting-etico p strong {
  color: #93F1C9; /* menta luminosa */
}

/* Lista técnica */
#hosting-etico .rep-list {
  list-style: none;
  padding: 0;
  margin: 0;
}
#hosting-etico .rep-list li {
  display: flex;
  align-items: center;
  gap: 10px;
  margin: 8px 0;
  color: rgba(255,255,255,.92);
  font-weight: 500;
}
#hosting-etico .rep-list li::before { content: none !important; }
#hosting-etico .rep-check {
  width: 18px;
  height: 18px;
  flex-shrink: 0;
  background: url('data:image/svg+xml;utf8,<svg fill="none" stroke="%23F7D450" stroke-width="2.3" xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24"><path stroke-linecap="round" stroke-linejoin="round" d="M5 13l4 4L19 7"/></svg>')
              center/contain no-repeat;
  filter: drop-shadow(0 0 2px rgba(247,212,80,.3));
}

/* Tarjeta ética clara */
#hosting-etico .rep-ethic-card--light {
  background: #ffffff;
  border-radius: 18px;
  padding: 50px 40px;
  box-shadow: 0 18px 36px rgba(0,0,0,.15);
  color: var(--rep-forest, #123c36);
  transition: transform .4s ease, box-shadow .4s ease;
}
#hosting-etico .rep-ethic-card--light:hover {
  transform: translateY(-4px);
  box-shadow: 0 22px 46px rgba(0,0,0,.2);
}

#hosting-etico .rep-ethic-card--light .rep-quote-icon {
  width: 38px;
  height: 38px;
  color: var(--rep-teal, #41999F);
  margin-bottom: 16px;
}

#hosting-etico .rep-ethic-card--light .rep-quote p {
  font-size: 1.25rem;
  line-height: 1.6;
  color: var(--rep-forest, #123c36);
  margin: 0;
}
#hosting-etico .rep-ethic-card--light .rep-quote footer {
  font-size: .95rem;
  color: var(--rep-teal, #41999F);
  margin-top: 10px;
}

/* Responsive */
@media (max-width: 900px) {
  #hosting-etico .rep-grid-2 {
    grid-template-columns: 1fr;
    gap: 50px;
  }
  #hosting-etico h2 {
    font-size: 1.9rem;
  }
  #hosting-etico .rep-ethic-card--light {
    padding: 40px 30px;
  }
}/* End custom CSS */
/* Start custom CSS for container, class: .elementor-element-579ffc6 */.elementor-9967 .elementor-element.elementor-element-579ffc6 {background: linear-gradient(160deg, #2a686d 0%, #21595e 100%)}/* End custom CSS */
/* Start custom CSS for html, class: .elementor-element-207ea61 *//* ===========================================================
   BLOQUE 6 · ¿Por qué llamamos a esto Hosting Solidario?
   =========================================================== */
#porque-solidario {

  padding: 110px 0 120px;
  position: relative;
  overflow: hidden;
}

#porque-solidario h2 {
  font-size: 2rem;
  font-weight: 700;
  margin-bottom: 14px;
  color: var(--rep-forest, #113C35);
}

#porque-solidario p {
  color: var(--rep-text-secondary, #315750);
  line-height: 1.7;
  font-size: 1.05rem;
}

/* --- Grid de iconos --- */
#porque-solidario .rep-icons-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(250px, 1fr));
  gap: 32px;
  margin-top: 50px;
}

#porque-solidario .rep-icon-card {
  background: #fff;
  border-radius: 16px;
  padding: 30px 24px 36px;
  box-shadow: 0 4px 12px rgba(0,0,0,.05);
  text-align: center;
  transition: transform .3s ease, box-shadow .3s ease;
}
#porque-solidario .rep-icon-card:hover {
  transform: translateY(-4px);
  box-shadow: 0 10px 22px rgba(0,0,0,.1);
}

#porque-solidario .rep-icon-card h3 {
  font-size: 1.1rem;
  font-weight: 600;
  color: var(--rep-forest, #103C36);
  margin: 18px 0 10px;
}

#porque-solidario .rep-icon-card p {
  font-size: .96rem;
  color: var(--rep-text-secondary, #355851);
  line-height: 1.6;
}

#porque-solidario .rep-icon {
  width: 54px;
  height: 54px;
  object-fit: contain;
  opacity: .9;
  filter: brightness(0) saturate(100%) invert(29%) sepia(24%) saturate(750%) hue-rotate(122deg) brightness(94%) contrast(90%);
  transition: filter .3s ease, transform .3s ease;
  margin: 0 auto;
}
#porque-solidario .rep-icon-card:hover .rep-icon {
  transform: scale(1.08);
  filter: none;
}

/* --- Responsive --- */
@media(max-width:768px){
  #porque-solidario h2{font-size:1.7rem;}
}/* End custom CSS */
/* Start custom CSS for container, class: .elementor-element-6b532d2 */.elementor-9967 .elementor-element.elementor-element-6b532d2 {background: var(--rep-bg-mint, #E6F7F5)}/* End custom CSS */
/* Start custom CSS for html, class: .elementor-element-03d10c7 */#plan-solidario {
  padding: 110px 0 120px;
  position: relative;
  overflow: hidden;
}

/* Título y texto central */
#plan-solidario h2 {
  font-weight: 700;
  font-size: 2rem;
  margin-bottom: 14px;
}
#plan-solidario p {
  font-size: 1.05rem;
  line-height: 1.7;
}

/* --- Checklist Grid --- */
#plan-solidario .rep-checklist-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit,minmax(320px,1fr));
  gap: 36px;
  margin-top: 40px;
}

#plan-solidario .rep-checklist {
  list-style: none;
  padding: 0;
  margin: 0;
}

#plan-solidario .rep-checklist li {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  margin-bottom: 12px;
  color: var(--rep-text-secondary,#345750);
  line-height: 1.6;
  font-size: 1rem;
}

/* Check icon SVG */
#plan-solidario .rep-check {
  width: 20px;
  height: 20px;
  flex-shrink: 0;
  background: url('data:image/svg+xml;utf8,<svg fill="none" stroke="%2341999F" stroke-width="2.4" xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24"><path stroke-linecap="round" stroke-linejoin="round" d="M5 13l4 4L19 7"/></svg>') center/contain no-repeat;
  transition: transform .3s ease;
}
#plan-solidario .rep-checklist li:hover .rep-check {
  transform: scale(1.1);
}

/* --- Enlace a Ecologi --- */
#plan-solidario a {
  color: var(--rep-teal,#41999F);
  text-decoration: underline;
  transition: color .3s ease;
}
#plan-solidario a:hover {
  color: var(--rep-green,#93F1C9);
}

/* --- Responsive --- */
@media (max-width:768px) {
  #plan-solidario { padding: 80px 0 100px; }
  #plan-solidario h2 { font-size: 1.7rem; }
}/* End custom CSS */
/* Start custom CSS for html, class: .elementor-element-a3e0008 *//* ===========================================================
   BLOQUE 9 · Formulario Plan Solidario
   =========================================================== */
#form-solidario {
  background: var(--rep-bg-light,#f3f9f8);
  padding: 110px 0 120px;
}
.solidario-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit,minmax(340px,1fr));
  gap: 50px;
}
.solidario-copy p { color: var(--rep-text-secondary); }
.solidario-card form label {
  display:block;
  margin-bottom:12px;
}
.solidario-card input,
.solidario-card select,
.solidario-card textarea {
  width:100%;
  border:1px solid rgba(0,0,0,.15);
  border-radius:10px;
  padding:10px 12px;
  font-size:.95rem;
  transition:border-color .3s ease,box-shadow .3s ease;
}
.solidario-card input:focus,
.solidario-card select:focus,
.solidario-card textarea:focus {
  border-color:var(--rep-teal);
  box-shadow:0 0 0 3px rgba(65,153,159,.2);
  outline:none;
}

/* Checkboxes alineados */
.rep-checkboxes {
  margin:14px 0 20px;
  display:flex;
  flex-direction:column;
  gap:6px;
}
.rep-checkboxes label {
  display:flex;
  align-items:center;
  gap:8px;
  color:var(--rep-text-secondary);
  font-size:.95rem;
}

/* Estados del card */
.solidario-state {
  text-align:center;
  padding:20px 0;
}
.solidario-state .icon {
  font-size:2rem;
  color:var(--rep-teal);
}
.solidario-state.error .icon { color:#c33; }
.solidario-state .actions {
  display:flex;
  gap:10px;
  justify-content:center;
  margin-top:10px;
}

/* Responsive */
@media(max-width:768px){
  .solidario-grid{grid-template-columns:1fr;}
}
/* --- Checkboxes alineados y accesibles --- */
.rep-checkboxes {
  margin: 18px 0 24px;
  display: flex;
  flex-direction: column;
  gap: 10px;
}

.rep-checkboxes label {
  display: flex;
  align-items: center;
  gap: 10px;
  font-size: .95rem;
  color: var(--rep-text-secondary);
  line-height: 1.4;
  cursor: pointer;
  position: relative;
}

/* Normaliza tamaño y espaciado del checkbox */
.rep-checkboxes input[type="checkbox"] {
  appearance: none;
  -webkit-appearance: none;
  width: 18px;
  height: 18px;
  border: 2px solid rgba(0, 0, 0, .25);
  border-radius: 4px;
  display: inline-block;
  position: relative;
  flex-shrink: 0;
  transition: all .25s ease;
  background: #fff;
}

/* Estado hover y foco */
.rep-checkboxes input[type="checkbox"]:hover {
  border-color: var(--rep-teal);
}
.rep-checkboxes input[type="checkbox"]:focus {
  outline: none;
  border-color: var(--rep-teal);
  box-shadow: 0 0 0 3px rgba(65,153,159,.25);
}

/* Estado marcado */
.rep-checkboxes input[type="checkbox"]:checked {
  background-color: var(--rep-teal);
  border-color: var(--rep-teal);
}
.rep-checkboxes input[type="checkbox"]:checked::after {
  content: "";
  position: absolute;
  top: 2px;
  left: 5px;
  width: 4px;
  height: 8px;
  border-right: 2px solid #fff;
  border-bottom: 2px solid #fff;
  transform: rotate(45deg);
}

/* Mejora para pantallas táctiles */
@media (hover: none) {
  .rep-checkboxes input[type="checkbox"]:focus {
    box-shadow: none;
  }
}/* End custom CSS */
/* Start custom CSS for html, class: .elementor-element-7e0a396 */#cierre-replanta {
  background: var(--rep-teal,#41999F);
  padding: 100px 0 110px;
}
#cierre-replanta .rep-cert-logo {
  width: 90px;
  height: auto;
  opacity: .85;
}
#cierre-replanta a.rep-text-link:hover {
  text-decoration: underline;
}
#cierre-replanta .rep-btn-primary {
  background: #93F1C9!important;
  color: #0c3c2a!important;
}
#cierre-replanta .rep-btn-primary:hover {
  background: #7ae5b7;
}/* End custom CSS */