/* =============================================================================
   IMPORTARGY — CSS v1.4
   Minimalista, moderno, dark-first — Fondo unificado sin “cortes”
   -------------------------------------------------------------------------
   Convenciones:
   - Secciones comentadas y ordenadas
   - Gradientes de acento via ::before (se funden con el fondo global)
   - Banner usa <img> (no hay bloque duplicado con .banner__bg)
   ========================================================================== */


/* ========== 1) DESIGN TOKENS / ROOT VARS ================================== */
:root{
  --bg:#0b1220;
  --bg-2:#0f172a;
  --surface:#111827;

  --text:#e5e7eb;
  --muted:#9aa4b2;

  --brand:#22c55e;   /* verde fresh */
  --brand-2:#7dd3fc; /* cian sutil */

  --ring: 0 0 0 6px color-mix(in oklab, var(--brand) 25%, transparent);
  --radius:16px;
  --container:1120px;
  --shadow: 0 10px 32px rgba(0,0,0,.35);

  /* Banner */
  --banner-h: clamp(42vh, 55vh, 64vh);
}


/* ========== 2) RESET BÁSICO / BASE ======================================== */
*{ box-sizing:border-box }
html,body{ height:100% }

body{
  margin:0;
  font-family:Inter,system-ui,-apple-system,Segoe UI,Roboto,Ubuntu,"Helvetica Neue",Arial,sans-serif;

  /* Fondo global unificado: linear + dos radiales suaves
     (evita “cortes” entre secciones) */
  background:
    radial-gradient(1200px 800px at 85% -10%, color-mix(in oklab, var(--brand) 14%, transparent) 0%, transparent 60%),
    radial-gradient(1000px 700px at 10% 120%, color-mix(in oklab, var(--brand-2) 12%, transparent) 0%, transparent 58%),
    linear-gradient(180deg, var(--bg) 0%, color-mix(in oklab, var(--bg) 70%, var(--bg-2)) 40%, var(--bg-2) 100%);
  color:var(--text);
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
}

.container{ max-width:var(--container); margin:0 auto; padding:0 20px }


/* ========== 3) HEADER / NAV =============================================== */
.header{
  position:sticky; top:0; z-index:50;
  backdrop-filter:saturate(180%) blur(10px);
  background:color-mix(in oklab, var(--bg-2) 92%, transparent);
  border-bottom:1px solid rgba(255,255,255,.06);
}
.header__inner{ display:flex; align-items:center; justify-content:space-between; padding:14px 0 }
.brand{ display:flex; align-items:center; gap:10px; color:var(--text); text-decoration:none; font-weight:700 }
.brand__dot{ width:12px; height:12px; border-radius:50%; background:linear-gradient(135deg,var(--brand),var(--brand-2)) }
.brand__text{ letter-spacing:.2px }

.nav{ display:flex; gap:20px; align-items:center }
.nav a{ color:var(--text); text-decoration:none; opacity:.9 }
.nav a:hover{ opacity:1 }
.nav-toggle{ display:none; background:none; border:0; color:var(--text); font-size:22px }

.nav-mobile{
  display:none; flex-direction:column; gap:14px; padding:14px 20px;
  border-top:1px solid rgba(255,255,255,.08)
}
.nav-mobile a{ color:var(--text); text-decoration:none }


/* ========== 4) BOTONES ===================================================== */
.btn{
  --p:12px;
  display:inline-flex; align-items:center; justify-content:center;
  padding:10px 16px; border-radius:999px; border:1px solid rgba(255,255,255,.12);
  text-decoration:none; color:var(--text); font-weight:600; gap:8px;
  transition:transform .08s ease, box-shadow .2s ease, background .2s ease;
  background:transparent;
}
.btn:hover{ transform:translateY(-1px) }
.btn:focus-visible{ outline:none; box-shadow:var(--ring) }
.btn--primary{ background:linear-gradient(135deg,var(--brand),var(--brand-2)); color:#071016; border-color:transparent }
.btn--ghost{ background:transparent }
.btn--sm{ padding:8px 12px; font-size:.95rem }
.btn--block{ display:block; width:100% }


/* ========== 5) BANNER PARALLAX (usa <img>) ================================ */
.banner-parallax{
  position: relative; z-index:0;
  height: var(--banner-h);
  display:grid; place-items:center; text-align:center;
  overflow: clip; /* recorta el desplazamiento */
  isolation:isolate;
}
.banner__img{
  position:absolute; inset:-10% -10%;
  width:120%; height:120%; object-fit:cover;
  transform:translateY(0); will-change:transform; z-index:-2;
}
.banner__overlay{
  position:absolute; inset:0; z-index:-1;
  background:
    radial-gradient(1000px 400px at 80% -10%, rgba(0,0,0,.35), transparent),
    linear-gradient(180deg, rgba(0,0,0,.35), rgba(0,0,0,.55));
}
.banner__content{ position:relative; padding:0 20px }
.banner__title{ font-size:clamp(1.8rem, 4.5vw, 3rem); line-height:1.1; margin:0 }
.banner__subtitle{ color:var(--muted); margin:6px 0 12px }
.banner__cta{ display:inline-flex; gap:10px; justify-content:center }
.banner__credit{
  position:absolute; right:10px; bottom:10px;
  color:rgba(255,255,255,.7); font-size:.8rem
}
.banner__credit a{ color:rgba(255,255,255,.85); text-decoration:none }

@media (prefers-reduced-motion: reduce){
  .banner__img{ transform:none !important; }
}


/* ========== 6) HERO ======================================================== */
.hero{ padding:72px 0 32px }
.hero__grid{ display:grid; grid-template-columns:1.2fr .8fr; gap:32px; align-items:center }
.hero__copy h1{ font-size:clamp(2rem,6vw,3rem); line-height:1.1; margin:0 0 12px }
.lead{ font-size:1.1rem; color:var(--muted); max-width:58ch }
.hero__cta{ display:flex; gap:12px; margin:18px 0 10px }
.hero__bullets{ list-style:none; padding:0; margin:10px 0 0; display:grid; gap:6px }
.hero__bullets li{ display:flex; align-items:center; gap:8px; color:var(--muted) }
.hero__card{
  background:linear-gradient(180deg,#0f172a,#0b1220);
  border:1px solid rgba(255,255,255,.06);
  border-radius:var(--radius); padding:18px; box-shadow:var(--shadow)
}
.kpi{ display:grid; grid-template-columns:repeat(3,1fr); gap:8px }
.kpi__item{ background:rgba(255,255,255,.03); border:1px solid rgba(255,255,255,.06); border-radius:12px; padding:12px; text-align:center }
.kpi__num{ display:block; font-weight:700; font-size:1.4rem }
.kpi__label{ color:var(--muted); font-size:.9rem }
.hero__note{ margin-top:12px; color:var(--muted); font-size:.95rem }


/* ========== 7) SECCIONES / ACENTOS SIN CORTES ============================= */
.section{ padding:56px 0 }

/* Las secciones con acento se funden con el fondo global vía ::before */
.section--alt,
.cta{ position:relative; z-index:0; background:transparent }

/* Overlay suave sin “bordes” */
.section--alt::before,
.cta::before{
  content:""; position:absolute; inset:-80px 0; z-index:-1;
  background:
    radial-gradient(900px 420px at 80% -10%, color-mix(in oklab, var(--brand) 18%, transparent) 0%, transparent 60%),
    radial-gradient(900px 420px at 10% 110%, color-mix(in oklab, var(--brand-2) 14%, transparent) 0%, transparent 60%);
  -webkit-mask-image: linear-gradient(to bottom, transparent 0, #000 80px, #000 calc(100% - 80px), transparent 100%);
          mask-image: linear-gradient(to bottom, transparent 0, #000 80px, #000 calc(100% - 80px), transparent 100%);
  pointer-events:none;
}

.section__head{ display:flex; align-items:end; justify-content:space-between; gap:16px; margin-bottom:16px }
.section h2{ margin:0 0 8px }
.muted{ color:var(--muted) }


/* ========== 8) CARDS / LISTADOS =========================================== */
.cards{ display:grid; grid-template-columns:repeat(3,1fr); gap:16px }
.card{
  background:rgba(255,255,255,.03);
  border:1px solid rgba(255,255,255,.06);
  border-radius:16px; padding:18px; box-shadow:var(--shadow)
}
.card__icon{ font-size:22px; opacity:.9 }
.card h3{ margin:8px 0 6px }

.steps{ list-style:none; padding:0; margin:0; display:grid; grid-template-columns:repeat(3,1fr); gap:16px }
.steps li{ display:flex; gap:12px; align-items:flex-start; background:rgba(255,255,255,.03); border:1px solid rgba(255,255,255,.06); border-radius:16px; padding:16px }
.steps__badge{
  display:inline-grid; place-items:center; min-width:28px; height:28px; border-radius:999px;
  background:linear-gradient(135deg,var(--brand),var(--brand-2)); color:#071016; font-weight:700
}

.grid-2{ display:grid; grid-template-columns:repeat(2,1fr); gap:16px }
.list{ list-style:none; margin:0; padding:0; display:grid; gap:8px }
.list li{ display:flex; gap:8px; color:var(--muted) }

.chips{ display:flex; flex-wrap:wrap; gap:10px }
.chip{
  padding:8px 12px; border-radius:999px;
  background:rgba(125,211,252,.1); border:1px solid rgba(125,211,252,.24); color:#c7f9ff
}


/* ========== 9) FAQ ======================================================== */
.faq{ display:grid; gap:10px }
.faq__item{ border:1px solid rgba(255,255,255,.08); border-radius:14px; background:rgba(255,255,255,.03) }
.faq__q{
  width:100%; text-align:left; background:transparent; border:0; color:var(--text);
  font-weight:600; padding:14px 16px; display:flex; align-items:center; justify-content:space-between; gap:12px
}
.faq__q i{ transition:transform .2s ease }
.faq__q[aria-expanded="true"] i{ transform:rotate(45deg) }
.faq__a{ display:grid; grid-template-rows:0fr; transition:grid-template-rows .22s ease; padding:0 16px }
.faq__a > *{ overflow:hidden }
.faq__item.open .faq__a{ grid-template-rows:1fr; padding:0 16px 14px }


/* ========== 10) CTA / FORM =============================================== */
.cta{
  padding:48px 0;
  border-top:1px solid rgba(255,255,255,.06);
  border-bottom:1px solid rgba(255,255,255,.06);
}
.cta__inner{ display:grid; grid-template-columns:1.2fr .8fr; align-items:start; gap:24px }

.form{ background:rgba(255,255,255,.03); border:1px solid rgba(255,255,255,.08); border-radius:16px; padding:16px }
.form__row{ display:grid; grid-template-columns:1fr 1fr; gap:12px; margin-bottom:12px }
.form__row:nth-child(2){ grid-template-columns:1fr }
.form input,.form textarea{
  width:100%; padding:12px 14px; border-radius:12px; border:1px solid rgba(255,255,255,.14);
  background:rgba(4,8,16,.5); color:var(--text)
}
.form input::placeholder,.form textarea::placeholder{ color:rgba(255,255,255,.45) }
.form__actions{ display:flex; gap:10px }
.form__hint{ color:var(--muted); font-size:.9rem; margin-top:8px }


/* ========== 11) FOOTER ==================================================== */
.footer{ padding:26px 0 }
.footer__inner{ display:flex; justify-content:space-between; align-items:center; border-top:1px solid rgba(255,255,255,.06); padding-top:16px }
.footer__brand{ display:flex; align-items:center; gap:10px }
.footer__meta{ display:flex; gap:16px; color:var(--muted) }
.footer .brand__dot{ width:10px; height:10px; border-radius:50%; background:linear-gradient(135deg,var(--brand),var(--brand-2)) }


/* ========== 12) PRICING / TARIFARIO ====================================== */
.pricing{ display:grid; grid-template-columns:repeat(2,1fr); gap:16px }
.price-card{
  position:relative; background:rgba(255,255,255,.03);
  border:1px solid rgba(255,255,255,.06); border-radius:16px; padding:18px;
  box-shadow:var(--shadow); display:grid; gap:12px;
}
.price-card__head{ display:grid; gap:4px }
.price-card__title{ margin:0 }
.price-card__subtitle{ margin:0; color:var(--muted); font-size:.95rem }
.price-card__price{ display:grid; gap:4px }
.price-card__amount{
  font-size:1.8rem; font-weight:800; letter-spacing:.2px;
  background:linear-gradient(135deg,var(--brand),var(--brand-2));
  -webkit-background-clip:text; background-clip:text; color:transparent;
}
.price-card__note{ color:var(--muted); font-size:.9rem }
.price-card__features{ list-style:none; margin:0; padding:0; display:grid; gap:8px; color:var(--text) }
.price-card__features li{ display:flex; gap:8px; align-items:flex-start }
.price-card__features li::before{
  content:"✓"; display:inline-flex; align-items:center; justify-content:center;
  width:20px; height:20px; border-radius:999px;
  background:rgba(125,211,252,.18); border:1px solid rgba(125,211,252,.3);
  font-size:.82rem; line-height:1.1; flex:0 0 20px; color:#e5f7ff;
}
.price-card__actions{ display:flex; gap:10px; flex-wrap:wrap }
.price-card__foot{ font-size:.85rem }
.price-card--pro{
  background:
    radial-gradient(800px 400px at 100% -20%, rgba(34,197,94,.12), transparent),
    rgba(255,255,255,.04);
  border-color:rgba(34,197,94,.25);
}
.price-card__badge{
  position:absolute; top:12px; right:12px;
  padding:6px 10px; border-radius:999px;
  background:linear-gradient(135deg,var(--brand),var(--brand-2));
  color:#071016; font-weight:700; font-size:.8rem
}


/* ========== 13) OFICINAS ================================================== */
.office-grid{ display:grid; grid-template-columns:repeat(2,1fr); gap:16px }
.office-card{
  background:rgba(255,255,255,.03);
  border:1px solid rgba(255,255,255,.06);
  border-radius:16px; padding:18px; box-shadow:var(--shadow);
  display:grid; gap:8px;
}
.office-card__title{ margin:0 }
.office-card__addr, .office-card__city{ margin:0; color:var(--text) }
.office-card__actions{ display:flex; gap:10px; flex-wrap:wrap; margin-top:6px }


/* ========== 14) POR QUÉ ELEGIRNOS ======================================== */
.pq__grid{ display:grid; grid-template-columns:1.1fr .9fr; gap:24px; align-items:center }
.pq__copy{ display:grid; gap:12px }
.pq__badges{ display:flex; flex-wrap:wrap; gap:8px }
.pq__badge{
  padding:6px 10px; border-radius:999px;
  background:rgba(125,211,252,.12); border:1px solid rgba(125,211,252,.28);
  font-size:.88rem
}
.pq__list{ list-style:none; margin:6px 0 0; padding:0; display:grid; gap:8px; color:var(--text) }
.pq__list li{ display:flex; gap:8px; align-items:flex-start; color:var(--muted) }
.pq__cta{ display:flex; gap:10px; margin-top:4px; flex-wrap:wrap }
.pq__media img{
  border-radius:16px; border:1px solid rgba(255,255,255,.08); box-shadow:var(--shadow);
  width:100%; height:auto; object-fit:cover; aspect-ratio:9 / 16; /* 1080x1920 */
}


/* ========== 15) RESPONSIVE BREAKPOINTS =================================== */
@media (max-width: 980px){
  .nav{ display:none }
  .nav-toggle{ display:inline-flex }

  .hero__grid{ grid-template-columns:1fr }
  .cards{ grid-template-columns:repeat(2,1fr) }
  .steps{ grid-template-columns:repeat(2,1fr) }

  .cta__inner{ grid-template-columns:1fr }

  .pricing{ grid-template-columns:1fr }
  .office-grid{ grid-template-columns:1fr }
  .pq__grid{ grid-template-columns:1fr; gap:18px }
}

@media (max-width: 640px){
  .cards{ grid-template-columns:1fr }
  .steps{ grid-template-columns:1fr }
  .form__row{ grid-template-columns:1fr }
}


/* ========== 16) LEGACY / OPCIONAL (no usado normalmente) ================== */
/* Ribbon fija (si no la usás, podés borrar este bloque) */
.cta-ribbon{
  position:fixed; left:0; right:0; bottom:0; z-index:60;
  display:flex; gap:12px; align-items:center; justify-content:center;
  padding:10px 16px; background:rgba(15,23,42,.9); backdrop-filter:blur(6px);
  border-top:1px solid rgba(255,255,255,.08)
}
.cta-ribbon__actions{ display:flex; gap:8px }
@media (max-width:640px){ .cta-ribbon span{ display:none } }

/* WhatsApp FAB (si lo usás) */
.wa-fab{
  position:fixed; right:16px; bottom:72px; z-index:61; display:grid; place-items:center;
  width:52px; height:52px; border-radius:50%; background:#22c55e; color:#071016;
  box-shadow:0 10px 24px rgba(0,0,0,.35); text-decoration:none; font-weight:700
}
