/*
Theme Name: GestionSimple
Theme URI: https://gestionsimple.com
Author: GestionSimple
Author URI: https://gestionsimple.com
Description: Tema One-Page para GestiónSimple — consultoría e implementación de Odoo ERP. Inspirado en el diseño corporativo azul de la marca, con secciones para Hero, Problemas, Solución, Servicios, Sectores, Beneficios, Proceso, Clientes, Planes y CTA de contacto.
Version: 1.1.0
Requires at least: 6.0
Tested up to: 6.6
Requires PHP: 7.4
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Text Domain: gestionsimple
Tags: one-page, business, custom-colors, custom-logo, custom-menu, featured-images, threaded-comments, translation-ready, blog
*/

/* ==========================================================================
   1. Design Tokens (paleta inspirada en logo GestiónSimple)
   ========================================================================== */
:root {
  --gs-bg: #fbfbfd;
  --gs-surface: #f3f6fb;
  --gs-card: #ffffff;
  --gs-fg: #0f1a2e;
  --gs-muted: #5a6b85;
  --gs-border: #e3e8f1;
  --gs-primary: #1f4ea1;        /* azul corporativo */
  --gs-primary-glow: #3a7be0;   /* azul claro */
  --gs-primary-fg: #ffffff;
  --gs-accent: #eaf1fb;
  --gs-destructive: #d64545;
  --gs-radius: 14px;
  --gs-radius-lg: 22px;
  --gs-radius-xl: 28px;
  --gs-shadow-sm: 0 1px 2px rgba(15, 26, 46, 0.06);
  --gs-shadow-md: 0 4px 14px rgba(15, 26, 46, 0.08);
  --gs-shadow-lg: 0 24px 48px -16px rgba(15, 26, 46, 0.18);
  --gs-shadow-glow: 0 24px 60px -18px rgba(31, 78, 161, 0.45);
  --gs-gradient: linear-gradient(135deg, var(--gs-primary) 0%, var(--gs-primary-glow) 100%);
  --gs-gradient-mesh:
    radial-gradient(at 20% 0%, rgba(58, 123, 224, 0.20) 0px, transparent 50%),
    radial-gradient(at 80% 0%, rgba(31, 78, 161, 0.14) 0px, transparent 50%),
    radial-gradient(at 0% 50%, rgba(120, 170, 230, 0.10) 0px, transparent 50%);
  --gs-ease: cubic-bezier(0.32, 0.72, 0, 1);
}

/* ==========================================================================
   2. Reset & Base
   ========================================================================== */
*, *::before, *::after { box-sizing: border-box; }
html { scroll-behavior: smooth; -webkit-text-size-adjust: 100%; }
body {
  margin: 0;
  background: var(--gs-bg);
  color: var(--gs-fg);
  font-family: 'Inter', ui-sans-serif, system-ui, -apple-system, "Segoe UI", Roboto, sans-serif;
  font-size: 16px;
  line-height: 1.6;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}
img { max-width: 100%; height: auto; display: block; }
a { color: var(--gs-primary); text-decoration: none; transition: color .2s var(--gs-ease); }
a:hover { color: var(--gs-primary-glow); }
h1, h2, h3, h4, h5, h6 {
  font-family: 'Inter', sans-serif;
  letter-spacing: -0.02em;
  line-height: 1.15;
  margin: 0 0 .5em;
  color: var(--gs-fg);
}
h1 { font-size: clamp(2.25rem, 4vw + 1rem, 3.75rem); font-weight: 600; }
h2 { font-size: clamp(1.75rem, 2vw + 1rem, 2.5rem); font-weight: 600; }
h3 { font-size: 1.25rem; font-weight: 600; }
p  { margin: 0 0 1em; color: var(--gs-fg); }
ul { padding-left: 1.25rem; }

/* ==========================================================================
   3. Layout helpers
   ========================================================================== */
.gs-container { max-width: 1200px; margin: 0 auto; padding: 0 1.5rem; }
.gs-section { padding: 6rem 0; }
.gs-section--surface { background: var(--gs-surface); border-top: 1px solid var(--gs-border); }
.gs-section--bordered { border-top: 1px solid var(--gs-border); }
.gs-eyebrow {
  text-transform: uppercase;
  letter-spacing: .14em;
  font-size: .8rem;
  font-weight: 600;
  /*color: var(--gs-primary);*/
	color: #3776d8 !important;
  margin: 0 0 .75rem;
}
.gs-section__head { max-width: 640px; margin: 0 auto 4rem; text-align: center; }
.gs-section__head p { color: var(--gs-muted); font-size: 1.05rem; }
.gs-text-gradient {
  background: var(--gs-gradient);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
}

/* ==========================================================================
   4. Buttons
   ========================================================================== */
.gs-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: .5rem;
  padding: .85rem 1.4rem;
  font-size: .95rem;
  font-weight: 600;
  border-radius: 10px;
  border: 1px solid transparent;
  cursor: pointer;
  transition: all .2s var(--gs-ease);
  text-decoration: none;
  line-height: 1;
}
.gs-btn--primary { background: var(--gs-gradient); color: var(--gs-primary-fg); box-shadow: var(--gs-shadow-glow); }
.gs-btn--primary:hover { transform: translateY(-1px); opacity: .95; color: var(--gs-primary-fg); }
.gs-btn--ghost { background: transparent; color: var(--gs-fg); }
.gs-btn--ghost:hover { background: var(--gs-accent); }
.gs-btn--outline { background: var(--gs-card); color: var(--gs-fg); border-color: var(--gs-border); }
.gs-btn--outline:hover { border-color: var(--gs-primary); color: var(--gs-primary); }
.gs-btn--secondary { background: var(--gs-card); color: var(--gs-fg); box-shadow: var(--gs-shadow-md); }
.gs-btn--secondary:hover { transform: translateY(-1px); }
.gs-btn--lg { padding: 1rem 1.6rem; font-size: 1rem; }

/* ==========================================================================
   5. Header / Navbar
   ========================================================================== */
.gs-header {
  position: fixed; top: 0; left: 0; right: 0; z-index: 50;
  background: rgba(255,255,255,.82);
  backdrop-filter: saturate(180%) blur(14px);
  -webkit-backdrop-filter: saturate(180%) blur(14px);
  border-bottom: 1px solid rgba(227, 232, 241, .7);
}
.gs-header__inner { display: flex; align-items: center; justify-content: space-between; height: 68px; }
.gs-header__logo img { height: 36px; width: auto; }
.gs-nav { display: none; gap: 2rem; }
.gs-nav a { color: var(--gs-muted); font-size: .92rem; font-weight: 500; }
.gs-nav a:hover { color: var(--gs-fg); }
.gs-header__cta { display: none; gap: .5rem; align-items: center; }
.gs-burger { background: none; border: 0; cursor: pointer; padding: .5rem; color: var(--gs-fg); }
.gs-mobile-menu { display: none; padding: 1rem 0 1.5rem; border-top: 1px solid var(--gs-border); }
.gs-mobile-menu.is-open { display: block; }
.gs-mobile-menu a { display: block; padding: .65rem 0; color: var(--gs-muted); font-weight: 500; }
.gs-mobile-menu .gs-btn { margin-top: .75rem; width: 100%; }
@media (min-width: 900px) {
  .gs-nav, .gs-header__cta { display: flex; }
  .gs-burger { display: none; }
  .gs-mobile-menu { display: none !important; }
}

/* ==========================================================================
   6. Hero
   ========================================================================== */
/* HERO — modern decision dashboard */
.gs-hero { position: relative; padding: 8rem 0 4rem; background: var(--gs-gradient-mesh), var(--gs-bg); overflow: hidden; }
.gs-hero__grid-bg {
  position: absolute; inset: 0; z-index: 0; pointer-events: none; opacity: .045;
  background-image:
    linear-gradient(to right, var(--gs-fg) 1px, transparent 1px),
    linear-gradient(to bottom, var(--gs-fg) 1px, transparent 1px);
  background-size: 48px 48px;
}
.gs-hero .gs-container { position: relative; z-index: 1; }
.gs-hero__layout { display: grid; grid-template-columns: 1fr; gap: 3rem; align-items: center; }
@media (min-width: 992px) { .gs-hero__layout { grid-template-columns: 1.05fr 1fr; gap: 2.5rem; } }
.gs-hero__copy { max-width: 620px; }
.gs-hero__badge {
  display: inline-flex; align-items: center; gap: .5rem;
  padding: .35rem 1rem; border-radius: 999px;
  background: rgba(255,255,255,.7); border: 1px solid var(--gs-border);
  font-size: .75rem; font-weight: 500; color: var(--gs-muted); margin-bottom: 1.25rem;
  backdrop-filter: blur(8px);
}
.gs-hero__badge .dot { width: 8px; height: 8px; border-radius: 50%; background: var(--gs-primary); box-shadow: 0 0 0 4px rgba(31,78,161,.18); }
.gs-hero h1 { margin-bottom: 1.25rem; }
.gs-hero__sub { font-size: 1.1rem; color: var(--gs-muted); margin: 0 0 2rem; }
.gs-hero__actions { display: flex; flex-wrap: wrap; gap: .75rem; }
.gs-hero__bullets { list-style: none; margin: 1.75rem 0 0; padding: 0; display: flex; flex-wrap: wrap; gap: 1.25rem; font-size: .8rem; color: var(--gs-muted); }
.gs-hero__bullets li { display: inline-flex; align-items: center; gap: .35rem; }

.gs-hero__dash { position: relative; }
.gs-hero__glow { position: absolute; inset: -1.5rem; border-radius: 32px; background: var(--gs-gradient); opacity: .18; filter: blur(60px); z-index: 0; }

.gs-hero__chip {
  position: absolute; z-index: 3;
  display: none; align-items: center; gap: .6rem;
  padding: .6rem .85rem; background: rgba(255,255,255,.92);
  border: 1px solid var(--gs-border); border-radius: 16px;
  box-shadow: var(--gs-shadow-lg); backdrop-filter: blur(10px); font-size: .82rem;
}
@media (min-width: 768px) { .gs-hero__chip { display: inline-flex; } }
.gs-hero__chip--tl { top: 2.5rem; right: -.75rem; }
.gs-hero__chip--bl { bottom: 2.5rem; left: -1rem; }
.gs-hero__chip strong { font-weight: 600; color: var(--gs-fg); }
.gs-hero__chip-icon { width: 36px; height: 36px; border-radius: 12px; background: var(--gs-gradient); color: #fff; display: grid; place-items: center; }
.gs-hero__chip-icon svg { width: 18px; height: 18px; }
.gs-hero__chip-icon--up { background: #ecfdf5; color: #059669; font-weight: 700; font-size: 1rem; }

.gs-dash { position: relative; z-index: 1; background: rgba(255,255,255,.92); border: 1px solid var(--gs-border); border-radius: var(--gs-radius-lg); padding: 1.1rem; box-shadow: var(--gs-shadow-lg); backdrop-filter: blur(10px); }
.gs-dash__bar { display: flex; align-items: center; justify-content: space-between; margin-bottom: 1rem; }
.gs-dash__dots { display: flex; align-items: center; gap: .35rem; }
.gs-dash__dots span { width: 10px; height: 10px; border-radius: 50%; background: var(--gs-border); }
.gs-dash__dots span:nth-child(1) { background: #ef4444; }
.gs-dash__dots span:nth-child(2) { background: #f59e0b; }
.gs-dash__dots span:nth-child(3) { background: #10b981; }
.gs-dash__dots em { font-style: normal; margin-left: .65rem; font-size: .72rem; color: var(--gs-muted); font-weight: 500; }
.gs-dash__live { font-size: .65rem; font-weight: 600; padding: .15rem .55rem; border-radius: 999px; background: rgba(16,185,129,.12); color: #059669; }

.gs-dash__kpis { display: grid; grid-template-columns: repeat(3, 1fr); gap: .65rem; }
.gs-dash__kpi { padding: .75rem; border: 1px solid var(--gs-border); border-radius: 12px; background: #fff; }
.gs-dash__kpi-head { display: flex; align-items: center; justify-content: space-between; }
.gs-dash__kpi-icon { width: 28px; height: 28px; border-radius: 8px; background: var(--gs-accent); color: var(--gs-primary); display: grid; place-items: center; }
.gs-dash__kpi-icon svg { width: 14px; height: 14px; }
.gs-dash__delta { font-size: .65rem; font-weight: 700; }
.gs-dash__delta.is-up { color: #059669; }
.gs-dash__delta.is-down { color: var(--gs-destructive); }
.gs-dash__kpi-label { font-size: .6rem; text-transform: uppercase; letter-spacing: .04em; color: var(--gs-muted); margin: .5rem 0 .15rem; }
.gs-dash__kpi-value { font-size: .9rem; font-weight: 600; color: var(--gs-fg); margin: 0; }

.gs-dash__chart { margin-top: .75rem; padding: .9rem; border: 1px solid var(--gs-border); border-radius: 12px; background: #fff; }
.gs-dash__chart-head { display: flex; align-items: center; justify-content: space-between; margin-bottom: .65rem; }
.gs-dash__small { font-size: .68rem; color: var(--gs-muted); margin: 0; font-weight: 500; }
.gs-dash__big { font-size: 1rem; font-weight: 600; color: var(--gs-fg); margin: .15rem 0 0; }
.gs-dash__pos { color: #059669; font-size: .72rem; font-weight: 500; margin-left: .35rem; }
.gs-dash__tabs { display: flex; gap: .25rem; }
.gs-dash__tabs span { font-size: .65rem; padding: .25rem .55rem; border-radius: 6px; background: var(--gs-surface); color: var(--gs-muted); }
.gs-dash__tabs span.is-active { background: var(--gs-primary); color: #fff; }
.gs-dash__svg { width: 100%; height: 90px; display: block; }

.gs-dash__bottom { margin-top: .65rem; display: grid; grid-template-columns: 3fr 2fr; gap: .65rem; }
.gs-dash__panel { padding: .75rem; border: 1px solid var(--gs-border); border-radius: 12px; background: #fff; }
.gs-dash__panel--center { display: flex; flex-direction: column; align-items: center; justify-content: center; }
.gs-dash__panel .gs-dash__small { margin-bottom: .5rem; }
.gs-dash__row { display: flex; align-items: center; gap: .5rem; margin-top: .4rem; }
.gs-dash__row-name { width: 78px; font-size: .7rem; color: var(--gs-fg); }
.gs-dash__bar-track { flex: 1; height: 6px; background: var(--gs-surface); border-radius: 999px; overflow: hidden; }
.gs-dash__bar-fill { height: 100%; background: var(--gs-gradient); border-radius: 999px; }
.gs-dash__row-pct { width: 30px; text-align: right; font-size: .65rem; color: var(--gs-muted); }
.gs-dash__donut { width: 80px; height: 80px; }

.gs-hero__trust { margin-top: 4rem; padding-top: 2rem; border-top: 1px solid var(--gs-border); display: grid; grid-template-columns: repeat(2, 1fr); gap: 1.25rem; }
@media (min-width: 640px) { .gs-hero__trust { grid-template-columns: repeat(4, 1fr); } }
.gs-hero__stat-k { font-size: 1.5rem; font-weight: 600; color: var(--gs-fg); margin: 0; letter-spacing: -0.02em; }
.gs-hero__stat-v { font-size: .75rem; color: var(--gs-muted); margin: 0; }

/* ==========================================================================
   7. Grids genéricos
   ========================================================================== */
.gs-grid { display: grid; gap: 1.5rem; }
.gs-grid--2 { grid-template-columns: repeat(1, minmax(0,1fr)); }
.gs-grid--4 { grid-template-columns: repeat(1, minmax(0,1fr)); }
@media (min-width: 720px) {
  .gs-grid--2 { grid-template-columns: repeat(2, minmax(0,1fr)); }
  .gs-grid--4 { grid-template-columns: repeat(2, minmax(0,1fr)); }
}
@media (min-width: 1024px) {
  .gs-grid--4 { grid-template-columns: repeat(4, minmax(0,1fr)); }
}

/* ==========================================================================
   8. Cards
   ========================================================================== */
.gs-card {
  background: var(--gs-card);
  border: 1px solid var(--gs-border);
  border-radius: var(--gs-radius-lg);
  padding: 2rem;
  transition: all .25s var(--gs-ease);
}
.gs-card:hover { box-shadow: var(--gs-shadow-md); transform: translateY(-2px); }
.gs-card__icon {
  display: inline-flex; align-items: center; justify-content: center;
  width: 48px; height: 48px; border-radius: 12px;
  background: var(--gs-gradient); color: #fff; box-shadow: var(--gs-shadow-md);
  margin-bottom: 1.25rem;
}
.gs-card__icon svg { width: 22px; height: 22px; }
.gs-card h3 { margin-bottom: .5rem; }
.gs-card p  { color: var(--gs-muted); font-size: .95rem; margin: 0; }
.gs-card__tags { display: flex; flex-wrap: wrap; gap: .4rem; margin-top: 1.25rem; }
.gs-card__tag {
  border: 1px solid var(--gs-border); background: var(--gs-bg);
  padding: .25rem .65rem; border-radius: 999px; font-size: .75rem; color: var(--gs-muted); font-weight: 500;
}

/* Problemas (icono rojo suave) */
.gs-card--problem .gs-card__icon { background: rgba(214, 69, 69, .12); color: var(--gs-destructive); box-shadow: none; }

/* Sectors mosaic */
.gs-mosaic {
  display: grid; gap: 1px;
  background: var(--gs-border);
  border: 1px solid var(--gs-border);
  border-radius: var(--gs-radius-xl);
  overflow: hidden;
  grid-template-columns: 1fr;
}
@media (min-width: 720px) { .gs-mosaic { grid-template-columns: repeat(2,1fr); } }
@media (min-width: 1024px) { .gs-mosaic { grid-template-columns: repeat(4,1fr); } }
.gs-mosaic__item { background: var(--gs-card); padding: 2rem; transition: background .2s var(--gs-ease); }
.gs-mosaic__item:hover { background: var(--gs-accent); }
.gs-mosaic__item svg { width: 28px; height: 28px; color: var(--gs-primary); }
.gs-mosaic__item h3 { margin-top: 1.25rem; }
.gs-mosaic__item p  { color: var(--gs-muted); font-size: .9rem; margin: .5rem 0 0; }

/* ==========================================================================
   9. Solution split
   ========================================================================== */
.gs-split { display: grid; gap: 4rem; align-items: center; grid-template-columns: 1fr; }
@media (min-width: 1024px) { .gs-split { grid-template-columns: 1fr 1fr; } }
.gs-checklist { list-style: none; padding: 0; margin: 2rem 0 0; }
.gs-checklist li { display: flex; gap: .75rem; align-items: flex-start; padding: .35rem 0; font-size: .95rem; }
.gs-checklist li::before {
  content: "✓"; flex: 0 0 22px; height: 22px;
  display: inline-flex; align-items: center; justify-content: center;
  background: rgba(31, 78, 161, .1); color: var(--gs-primary);
  border-radius: 50%; font-size: .75rem; font-weight: 700; margin-top: .15rem;
}
.gs-stats { display: grid; grid-template-columns: 1fr 1fr; gap: 1rem; position: relative; }
.gs-stats::before {
  content:""; position: absolute; inset: -1.5rem; border-radius: 28px;
  background: var(--gs-gradient); opacity: .08; filter: blur(40px); z-index:0;
}
.gs-stat {
  position: relative; background: var(--gs-card); border: 1px solid var(--gs-border);
  padding: 1.5rem; border-radius: var(--gs-radius); box-shadow: var(--gs-shadow-sm);
}
.gs-stat__value { font-size: 1.85rem; font-weight: 600; letter-spacing: -.02em; }
.gs-stat__value.gradient { background: var(--gs-gradient); -webkit-background-clip: text; background-clip: text; color: transparent; }
.gs-stat__label { margin-top: .35rem; font-size: .75rem; color: var(--gs-muted); }

/* ==========================================================================
   10. Process timeline
   ========================================================================== */
.gs-process { display: grid; gap: 2.5rem; grid-template-columns: 1fr; position: relative; }
@media (min-width: 1024px) { .gs-process { grid-template-columns: repeat(4,1fr); gap: 1.5rem; } }
.gs-step__num {
  width: 60px; height: 60px; border-radius: 18px;
  display: inline-flex; align-items: center; justify-content: center;
  background: var(--gs-card); border: 1px solid var(--gs-border);
  font-weight: 600; color: var(--gs-primary); box-shadow: var(--gs-shadow-sm);
  margin-bottom: 1.25rem;
}

/* ==========================================================================
   11. Benefits
   ========================================================================== */
.gs-benefit { display: flex; gap: 1.25rem; }
.gs-benefit__icon {
  flex: 0 0 48px; height: 48px; border-radius: 12px;
  background: var(--gs-card); border: 1px solid var(--gs-border);
  display: inline-flex; align-items: center; justify-content: center;
  color: var(--gs-primary); box-shadow: var(--gs-shadow-sm);
}
.gs-benefit__icon svg { width: 20px; height: 20px; }
.gs-benefit p { color: var(--gs-muted); font-size: .95rem; margin: .35rem 0 0; }

/* ==========================================================================
   12. Logos marquee
   ========================================================================== */
.gs-marquee {
  position: relative; overflow: hidden; margin-top: 4rem;
  -webkit-mask-image: linear-gradient(to right, transparent, #000 12%, #000 88%, transparent);
          mask-image: linear-gradient(to right, transparent, #000 12%, #000 88%, transparent);
}
.gs-marquee__track {
  display: flex; gap: 1rem; width: max-content;
  animation: gs-marquee 40s linear infinite;
}
.gs-marquee:hover .gs-marquee__track { animation-play-state: paused; }
@keyframes gs-marquee { from { transform: translateX(0); } to { transform: translateX(-50%); } }
.gs-logo-card {
  display: flex; align-items: center; gap: .75rem;
  width: 220px; height: 96px; flex-shrink: 0;
  border: 1px solid var(--gs-border); background: var(--gs-card);
  border-radius: 18px; padding: 0 1.25rem;
  transition: all .25s var(--gs-ease);
}
.gs-logo-card:hover { border-color: rgba(31,78,161,.4); box-shadow: var(--gs-shadow-md); }
.gs-logo-card__badge {
  width: 40px; height: 40px; border-radius: 10px;
  display: inline-flex; align-items: center; justify-content: center;
  background: var(--gs-gradient); color: #fff; font-weight: 700; font-size: .85rem;
  box-shadow: var(--gs-shadow-sm); flex-shrink: 0;
}
.gs-logo-card__name { font-weight: 600; font-size: .9rem; letter-spacing: -.01em; }

.gs-stats-row { margin-top: 3rem; display: flex; flex-wrap: wrap; justify-content: center; gap: 2.5rem; text-align: center; }
.gs-stats-row .gs-stat__value { font-size: 1.5rem; }

/* ==========================================================================
   13. Pricing
   ========================================================================== */
.gs-pricing { display: grid; gap: 1.5rem; grid-template-columns: 1fr; margin-top: 4rem; }
@media (min-width: 1024px) { .gs-pricing { grid-template-columns: repeat(3,1fr); } }
.gs-plan {
  position: relative; display: flex; flex-direction: column;
  background: var(--gs-card); border: 1px solid var(--gs-border);
  border-radius: var(--gs-radius-xl); padding: 2.25rem;
  transition: all .25s var(--gs-ease);
}
.gs-plan:hover { box-shadow: var(--gs-shadow-md); }
.gs-plan--highlight { border-color: var(--gs-primary); box-shadow: var(--gs-shadow-glow); }
@media (min-width: 1024px) {
  .gs-plan--highlight { transform: translateY(-1rem) scale(1.02); }
}
.gs-plan__badge {
  position: absolute; top: -14px; left: 50%; transform: translateX(-50%);
  background: var(--gs-gradient); color: #fff;
  padding: .35rem .85rem; border-radius: 999px;
  font-size: .72rem; font-weight: 700; box-shadow: var(--gs-shadow-md);
}
.gs-plan__desc { color: var(--gs-muted); font-size: .9rem; margin: .5rem 0 1.5rem; }
.gs-plan__price { display: flex; align-items: baseline; gap: .35rem; margin-bottom: 2rem; }
.gs-plan__price small { color: var(--gs-muted); font-size: .85rem; font-weight: 500; }
.gs-plan__price .amount { font-size: 2.75rem; font-weight: 600; letter-spacing: -.02em; }
.gs-plan__price .period { color: var(--gs-muted); font-size: .85rem; }
.gs-plan__features { list-style: none; padding: 0; margin: 0 0 2rem; flex: 1; }
.gs-plan__features li { display: flex; gap: .65rem; padding: .35rem 0; font-size: .9rem; }
.gs-plan__features li::before {
  content: "✓"; flex: 0 0 20px; height: 20px;
  display: inline-flex; align-items: center; justify-content: center;
  background: rgba(31,78,161,.1); color: var(--gs-primary);
  border-radius: 50%; font-size: .7rem; font-weight: 700; margin-top: .15rem;
}
.gs-plan--highlight .gs-plan__features li::before { background: var(--gs-gradient); color: #fff; }
.gs-pricing__note { text-align: center; margin-top: 2.5rem; font-size: .8rem; color: var(--gs-muted); }

/* ==========================================================================
   14. CTA banner
   ========================================================================== */
.gs-cta {
  position: relative; overflow: hidden;
  background: var(--gs-gradient); color: #fff;
  border-radius: var(--gs-radius-xl); padding: 4rem 2rem;
  text-align: center; box-shadow: var(--gs-shadow-glow);
}
.gs-cta::before {
  content:""; position: absolute; inset: 0;
  background: radial-gradient(circle at 30% 0%, rgba(255,255,255,.2), transparent 50%);
}
.gs-cta__inner { position: relative; max-width: 640px; margin: 0 auto; }
.gs-cta h2 { color: #fff; }
.gs-cta p  { color: rgba(255,255,255,.85); margin-bottom: 2rem; }
.gs-cta .gs-btn--ghost { color: #fff; }
.gs-cta .gs-btn--ghost:hover { background: rgba(255,255,255,.12); }
.gs-cta .gs-icon-cal { width: 36px; height: 36px; opacity: .85; margin: 0 auto 1.5rem; display:block; }

/* ==========================================================================
   15. Footer
   ========================================================================== */
.gs-footer { background: var(--gs-surface); border-top: 1px solid var(--gs-border); padding: 4rem 0 2rem; }
.gs-footer__grid { display: grid; gap: 2.5rem; grid-template-columns: 1fr; }
@media (min-width: 900px) { .gs-footer__grid { grid-template-columns: 2fr 1fr 1.2fr; } }
.gs-footer h4 { font-size: .9rem; font-weight: 600; margin-bottom: 1rem; }
.gs-footer ul { list-style: none; padding: 0; margin: 0; }
.gs-footer li { padding: .25rem 0; color: var(--gs-muted); font-size: .9rem; }
.gs-footer li a { color: var(--gs-muted); }
.gs-footer li a:hover { color: var(--gs-fg); }
.gs-footer__brand img { height: 40px; margin-bottom: 1rem; }
.gs-footer__brand p { color: var(--gs-muted); font-size: .9rem; max-width: 360px; }
.gs-footer__bottom {
  display: flex; flex-wrap: wrap; justify-content: space-between; gap: 1rem;
  margin-top: 3rem; padding-top: 1.75rem; border-top: 1px solid var(--gs-border);
  font-size: .78rem; color: var(--gs-muted);
}

/* ==========================================================================
   16. Reveal animation
   ========================================================================== */
.gs-reveal { opacity: 0; transform: translateY(20px); transition: opacity .6s var(--gs-ease), transform .6s var(--gs-ease); }
.gs-reveal.is-visible { opacity: 1; transform: none; }

/* ==========================================================================
   17. Accessibility
   ========================================================================== */
:focus-visible { outline: 2px solid var(--gs-primary); outline-offset: 3px; border-radius: 6px; }
@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after { animation-duration: .01ms !important; transition-duration: .01ms !important; }
}

/* ========== MÓDULOS Y SERVICIOS ========== */
.gs-modules {
	display: grid;
	grid-template-columns: repeat(1, minmax(0, 1fr));
	gap: 1.25rem;
	margin-top: 4rem;
}
@media (min-width: 640px) {
	.gs-modules { grid-template-columns: repeat(2, minmax(0, 1fr)); }
}
@media (min-width: 1024px) {
	.gs-modules { grid-template-columns: repeat(4, minmax(0, 1fr)); }
}
.gs-module {
	display: flex;
	flex-direction: column;
	align-items: center;
	text-align: center;
	padding: 2rem 1.5rem;
	background: var(--gs-card, #fff);
	border: 1px solid var(--gs-border, #e5e7eb);
	border-radius: 1rem;
	transition: transform .25s ease, box-shadow .25s ease, border-color .25s ease;
}
.gs-module:hover {
	transform: translateY(-4px);
	border-color: color-mix(in oklab, var(--gs-primary, #1e3a8a) 40%, transparent);
	box-shadow: 0 14px 40px -18px color-mix(in oklab, var(--gs-primary, #1e3a8a) 35%, transparent);
}
.gs-module__icon {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 3rem;
	height: 3rem;
	margin-bottom: 1.25rem;
	border-radius: .85rem;
	background: color-mix(in oklab, var(--gs-primary, #1e3a8a) 10%, transparent);
	color: var(--gs-primary, #1e3a8a);
	transition: background .25s ease, color .25s ease;
}
.gs-module__icon svg { width: 1.5rem; height: 1.5rem; }
.gs-module:hover .gs-module__icon {
	background: var(--gs-primary, #1e3a8a);
	color: #fff;
}
.gs-module__title {
	font-size: 1rem;
	font-weight: 600;
	letter-spacing: -0.01em;
	margin: 0;
}
.gs-module__desc {
	margin-top: .5rem;
	font-size: .875rem;
	line-height: 1.55;
	color: var(--gs-muted, #64748b);
}

.gs-btn--lg svg {
    width: 20px;
    height: 20px;
}

.gs-no-display {
    display: none;
}


