/* ============================================================
   MANTENIMIENTO WEB — Hoja depurada
   - Mantiene utilidades base y grid/cards
   - Igualamos la cabecera al estilo "Nosotros"
   - Dejamos comentado lo que no aporta en esta página
============================================================ */
:root{
  --text:#1a1a1a; --text-dim:#5a5a5a; --bg:#fff; --gray:#f7f8fb;
  --green:#22c55e; --blue:#3b82f6; --violet:#7c4dff; --violetDark:#5b2cff; --amber:#f59e0b;
  --radius:18px; --shadow:0 12px 30px rgba(20,20,41,.12);
}

html,body{margin:0;background:var(--bg);color:var(--text);font-family:Inter,system-ui,sans-serif;line-height:1.55}
.mw-wrap{max-width:1200px;margin:0 auto;padding:0 24px}

.u-center{text-align:center}
.u-muted{color:var(--text-dim)}

.u-pill{border-radius:999px;padding:.35rem .7rem;font-weight:800;display:inline-block}
.u-pill--green{background:rgba(34,197,94,.12);color:#1f8c43;border:1px solid rgba(34,197,94,.3)}
.u-pill--blue{background:rgba(59,130,246,.12);color:#2253a8;border:1px solid rgba(59,130,246,.3)}
.u-pill--violet{background:rgba(124,77,255,.12);color:#4b2bb4;border:1px solid rgba(124,77,255,.3)}
/* .u-pill--amber{background:rgba(245,158,11,.12);color:#b36d00;border:1px solid rgba(245,158,11,.35)} */
/* ↑ No se usa en esta página; se deja comentado para evitar CSS muerto. */


/* ============================================================
   Titulares de sección + layout
============================================================ */
section{padding: clamp(56px, 8vw, 96px) 0}
h2{
  font-size:clamp(1.65rem,4vw,2.5rem); margin:0 0 1rem; color:#0f4227; position:relative; display:inline-block; padding-bottom:.35rem
}
h2::after{
  content:""; position:absolute; left:0; right:0; bottom:0; height:6px; border-radius:6px;
  background:linear-gradient(90deg,var(--green),var(--violet)); opacity:.35
}
h3{ margin:.2rem 0 .5rem }
.mw-section--alt{ background:var(--gray) }
.mw-lead{ color:var(--text-dim); max-width:70ch }

.mw-grid{ display:grid; gap:22px }
.mw-grid--3{ grid-template-columns:repeat(1,minmax(0,1fr)) }
@media (min-width:780px){ .mw-grid--3{ grid-template-columns:repeat(3,minmax(0,1fr)) } }

.mw-card,.mw-plan{
  background:#fff; border:1px solid #ececf3; border-radius:18px; padding:20px; box-shadow:0 10px 24px rgba(20,20,41,.08);
  transition: transform .16s ease, box-shadow .2s ease;
}
.mw-card:hover,.mw-plan:hover{ transform:translateY(-2px) }

/* Listas con mini-iconos (se usan en planes/beneficios) */
.mw-mini{ list-style:none; margin:.6rem 0 0; padding:0; display:grid; gap:.5rem; color:var(--text-dim); font-size:.98rem }
.mw-mini li{ display:grid; grid-template-columns:24px 1fr; gap:.55rem }
.mw-ico{ width:20px; height:20px }

/* Planes (si la página no muestra planes, puedes comentar todo este bloque) */
/*
.mw-plans{ display:grid; gap:22px }
@media (min-width:980px){ .mw-plans{ grid-template-columns:1.1fr 1.2fr 1.1fr } }
.mw-plan{ position:relative }
.mw-badge{ background:rgba(34,197,94,.12); color:#1f8c43; border:1px solid rgba(34,197,94,.25); padding:.3rem .55rem; border-radius:999px; font-weight:900; font-size:.8rem }
.mw-tag{ position:absolute; top:-12px; left:16px; background:linear-gradient(135deg,#f59e0b,#22c55e); color:#0c0c14; font-weight:900; padding:.35rem .6rem; border-radius:10px; box-shadow:0 10px 24px rgba(20,20,41,.12); font-size:.8rem }
.mw-plan--popular{ border:2px solid color-mix(in oklab, var(--green) 55%, #fff 45%); box-shadow:0 18px 45px rgba(34,197,94,.22) }
.mw-price{ font-size:1.8rem; font-weight:900; margin:.2rem 0 .6rem; color:#0f4227 }
.mw-cta-row{ display:flex; gap:.6rem; flex-wrap:wrap; margin-top:.9rem }
*/

/* CTA oscura (si no la usas en esta página, comenta) */
/*
.mw-cta{ background:radial-gradient(900px 480px at 85% 10%, rgba(34,197,94,.18), transparent 60%); color:#fff }
.mw-cta .mw-wrap{ background:#0c0c14; border:1px solid rgba(255,255,255,.08); border-radius:22px; padding:32px }
.mw-cta h2{ color:#fff }
.mw-cta p{ color:#e9e9f4 }
.mw-cta .mw-btn--ghost{ border:1.5px solid rgba(255,255,255,.6); color:#fff }
*/

/* Acordeón FAQ (si no hay acordeón, puedes comentar) */
/*
.mw-acc{ border:1px solid #e2e2ea; border-radius:14px; padding:14px; background:#fff; margin-bottom:10px }
.mw-acc summary{ cursor:pointer; font-weight:900 }
.mw-acc[open] summary{ color:#1f8c43 }
.mw-acc__content{ padding-top:10px; color:var(--text-dim) }
*/

/* Reveal suave (igual que “Nosotros”) */
[data-anim]{ opacity:0; transform:translateY(12px); transition:opacity .5s ease, transform .5s ease }
[data-anim].is-in{ opacity:1; transform:none }

/* ============================================================
   Bullets con “check” dibujándose (mismo efecto que Nosotros)
============================================================ */
.icon-check .tick-circle,
.icon-check .tick-mark{
  stroke: currentColor; fill: none; stroke-width: 3; stroke-linecap: round; stroke-linejoin: round;
  stroke-dasharray: 100; stroke-dashoffset: 100;
}
.icon-check .tick-circle{ opacity:.30 }
.icon-check.is-in .tick-circle{ animation: checkDraw .9s ease forwards }
.icon-check.is-in .tick-mark{ animation: checkDraw .8s ease .25s forwards }
@keyframes checkDraw { to { stroke-dashoffset: 0 } }

/* Color por si currentColor hereda claro en el hero */
.sh-bullets .icon-check{ color:#2b2b2b; opacity:.95 }

/* Accesibilidad: reduce motion */
@media (prefers-reduced-motion: reduce){
  .icon-check .tick-circle, .icon-check .tick-mark{
    animation:none !important; stroke-dasharray:0; stroke-dashoffset:0;
  }
}
/* ============================================================
   SECCIÓN: PLANES DE MANTENIMIENTO (3 columnas responsivas)
============================================================ */

/* Contenedor de los planes */
.mw-plans {
  display: grid;
  gap: 28px;
  margin-top: 2rem;
  /* tres columnas amplias a partir de 1000px */
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
}

/* Cada plan (tarjeta) */
.mw-plan {
  background: #fff;
  border: 1px solid #ececf3;
  border-radius: 18px;
  padding: 24px 22px 28px;
  box-shadow: 0 10px 28px rgba(20, 20, 41, .08);
  transition: transform .2s ease, box-shadow .25s ease, border-color .2s ease;
}

/* Animación al hacer hover */
.mw-plan:hover {
  transform: translateY(-4px);
  border-color: rgba(130, 189, 3, .3);
  box-shadow: 0 18px 42px rgba(34, 197, 94, .15);
}

/* Título y texto */
.mw-plan h3 {
  font-size: 1.2rem;
  font-weight: 800;
  margin: .2rem 0 .35rem;
}
.mw-plan .u-muted {
  color: var(--text-dim);
  margin-bottom: .6rem;
}

/* Precio */
.mw-price {
  font-size: 1.6rem;
  font-weight: 900;
  color: #0f4227;
  margin-bottom: .8rem;
}

/* Lista interna */
.mw-mini {
  list-style: none;
  padding: 0;
  margin: 0 0 1rem;
  display: grid;
  gap: .45rem;
  font-size: .97rem;
  color: var(--text-dim);
}
.mw-mini li {
  display: grid;
  grid-template-columns: 22px 1fr;
  align-items: center;
  gap: .45rem;
}
.mw-ico {
  width: 18px;
  height: 18px;
  flex-shrink: 0;
}

/* Cintas / etiquetas de cada plan */
.mw-badge {
  display: inline-block;
  background: rgba(34, 197, 94, .12);
  color: #1f8c43;
  border: 1px solid rgba(34, 197, 94, .25);
  border-radius: 999px;
  padding: .25rem .6rem;
  font-weight: 800;
  font-size: .8rem;
  margin-bottom: .3rem;
}

.mw-tag {
  display: inline-block;
  background: linear-gradient(135deg, #f59e0b, #22c55e);
  color: #0c0c14;
  font-weight: 800;
  padding: .35rem .6rem;
  border-radius: 10px;
  box-shadow: 0 10px 24px rgba(20, 20, 41, .12);
  font-size: .8rem;
  margin-bottom: .4rem;
}

/* Plan popular */
.mw-plan--popular {
  border: 2px solid color-mix(in oklab, var(--green) 60%, #fff 40%);
  box-shadow: 0 18px 45px rgba(34, 197, 94, .22);
  transform: translateY(-2px);
}
.mw-plan--popular:hover {
  transform: translateY(-6px);
}

/* Fila de CTA dentro de cada plan */
.mw-cta-row {
  display: flex;
  flex-wrap: wrap;
  gap: .6rem;
  margin-top: .8rem;
}

/* Ajuste responsivo */
@media (max-width: 960px) {
  .mw-plans { grid-template-columns: repeat(auto-fit, minmax(240px, 1fr)); }
}
@media (max-width: 680px) {
  .mw-plans { grid-template-columns: 1fr; }
}
