/* =========================================================
   IKOOGO — Styles (Home)
   Estructura:
   1) Base / Variables / Reset
   2) Helpers de layout y tipografía
   3) Header / Nav
   4) Botones
   5) Hero (decor + card)
   6) Secciones: Servicios (cards)
   7) Secciones: Planes (pricing)
   8) Secciones: Historia (timeline)
   9) Secciones: Contacto
   10) Footer
   11) Utilidades (texto, reveal, toast, a11y)
   12) Motion prefs
   13) Compact tweaks (mínimos)
========================================================= */

/* =========================
   1) Base / Variables / Reset
========================= */
:root{
  --bg: #0b0d14;
  --bg-soft: #0f1320;
  --card: rgba(255,255,255,0.06);
  --border: rgba(255,255,255,0.12);
  --text: #e9ecf1;
  --muted: #a8b0c3;

  /* BRAND IKOOGO */
  --brand-dark: #0E3A4A;     /* azul petróleo */
  --brand-accent: #FF8A00;   /* naranja */

  /* Degradé principal */
  --primary-1: var(--brand-dark);
  --primary-2: #2AA4C7;
  --primary-3: var(--brand-accent);
  --grad: linear-gradient(135deg, var(--primary-1) 0%, var(--primary-2) 55%, var(--primary-3) 100%);

  --radius-xl: 24px;
  --radius-lg: 18px;
  --shadow: 0 10px 30px rgba(0,0,0,.35);
  --blur: 14px;

  --container: 1120px;
  --speed: 650ms;
  --easing: cubic-bezier(.2,.7,.2,1);
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; scroll-padding-top: 80px; }
body{
  margin:0;
  font-family: Inter, system-ui, -apple-system, Segoe UI, Roboto, "Helvetica Neue", Arial, "Noto Sans", "Apple Color Emoji","Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji";
  color: var(--text);
  background:
    radial-gradient(1200px 400px at 20% -10%, rgba(14,58,74,.25), transparent 60%),
    radial-gradient(900px 400px at 90% 10%, rgba(42,164,199,.18), transparent 60%),
    var(--bg);
  line-height:1.6;
}

/* Reset visual menor */
img, svg { display:block; }
img { max-width:100%; height:auto; }
a { color:inherit; }

/* Focus visible accesible */
:focus-visible { outline: 2px solid rgba(255,138,0,.85); outline-offset: 2px; }

/* =========================
   2) Helpers de layout y tipografía
========================= */
.container{max-width:var(--container); margin-inline:auto; padding:0 24px}
.section{padding:88px 0}
.section__head{text-align:center; margin-bottom:34px}
.section__head h2{font-family:Poppins, Inter, sans-serif; font-size:clamp(28px,4vw,44px); margin:0 0 10px}
.max-700{max-width:700px; margin:0 auto}
h1,h2,h3{line-height:1.15}
h3{font-size:18px}
p{margin:0}
.muted{color:var(--muted)}

/* =========================
   3) Header / Nav
========================= */
.site-header{
  position:sticky; top:0; z-index:50; backdrop-filter:saturate(180%) blur(10px);
  background: linear-gradient(180deg, rgba(10,12,20,.8), rgba(10,12,20,.35) 80%, transparent);
  border-bottom:1px solid rgba(255,255,255,.06);
}
.nav{display:flex; align-items:center; justify-content:space-between; height:72px}

.logo{
  display:flex; align-items:center; gap:10px; text-decoration:none;
  color:var(--text); font-weight:800; letter-spacing:.5px
}
.logo__text{background:var(--grad); -webkit-background-clip:text; background-clip:text; color:transparent}
.logo__img{ width:26px; height:26px; object-fit:contain; }
.logo--sm .logo__img{ width:22px; height:22px; } /* versión chica en footer */

.nav__menu{display:flex; align-items:center; gap:22px}
.nav__link{color:var(--muted); text-decoration:none}
.nav__link:hover{color:var(--text)}
.nav__cta{margin-left:8px}

.nav__toggle{display:none; background:transparent; border:0; padding:6px 4px; cursor:pointer}
.nav__bar{display:block; width:26px; height:2px; background:#fff; margin:6px 0; transition:transform .3s ease}

/* Mobile menu */
@media (max-width: 920px){
  .nav__toggle{display:block}
  .nav__menu{
    position:fixed; inset:72px 0 auto 0; background:#0b0f18f2; backdrop-filter: blur(10px);
    transform: translateY(-16px); opacity:0; pointer-events:none; transition:.35s var(--easing);
    display:grid; gap:16px; padding:24px; border-bottom:1px solid var(--border)
  }
  .nav__menu.open{transform: translateY(0); opacity:1; pointer-events:auto}
}

/* =========================
   4) Botones
========================= */
.btn{
  --btn-bg: var(--card);
  --btn-bd: var(--border);
  --btn-fg: var(--text);
  appearance:none; border:1px solid var(--btn-bd); background:var(--btn-bg); color:var(--btn-fg);
  padding:12px 18px; border-radius:14px; text-decoration:none; display:inline-flex; gap:10px;
  align-items:center; justify-content:center; font-weight:600; transition: all .25s var(--easing);
  box-shadow: 0 2px 0 rgba(255,255,255,.05) inset, 0 8px 16px rgba(0,0,0,.15)
}
.btn:hover{transform: translateY(-2px)}
.btn--primary{
  --btn-bg: linear-gradient(135deg, rgba(14,58,74,.25), rgba(255,138,0,.25));
  --btn-bd: transparent;
  box-shadow: 0 0 0 1px rgba(255,255,255,.06) inset, 0 12px 24px rgba(255,138,0,.18)
}
.btn--ghost{background:transparent}
.btn--sm{padding:10px 14px; border-radius:12px; font-size:14px}

/* =========================
   5) Hero (decor + card)
========================= */
.hero{position:relative; padding:110px 0 80px; overflow:hidden}
.eyebrow{text-transform:uppercase; letter-spacing:.18em; color:#b9c1d6; font-size:12px; margin:0 0 10px}
.hero__title{font-family:Poppins, Inter, sans-serif; font-size: clamp(34px, 6vw, 62px); line-height:1.05; margin:0 0 14px}
.grad{background:var(--grad); -webkit-background-clip:text; background-clip:text; color:transparent}
.hero__subtitle{max-width:680px; color:var(--muted); margin:0 0 18px}
.hero__actions{display:flex; gap:12px; flex-wrap:wrap; margin-top:10px}
.hero__grid{display:grid; grid-template-columns:1.2fr .9fr; gap:44px; align-items:center}
@media (max-width: 980px){ .hero__grid{grid-template-columns:1fr} }

/* Decorative blurs */
.decor{
  position:absolute; filter: blur(80px); opacity:.32; pointer-events:none;
  transform: translateZ(0) scale(1); mix-blend-mode: screen;
}
.decor--1{width:700px; height:700px; left:-120px; top:-160px; background: radial-gradient(circle at 50% 50%, var(--brand-dark), transparent 60%)}
.decor--2{width:520px; height:520px; right:-160px; top:-100px; background: radial-gradient(circle at 50% 50%, #2AA4C7, transparent 60%)}
.decor--3{width:420px; height:420px; left:40%; bottom:-120px; background: radial-gradient(circle at 50% 50%, var(--brand-accent), transparent 60%)}

/* Hero card */
.glass{
  background: var(--card);
  border:1px solid var(--border);
  border-radius: var(--radius-xl);
  box-shadow: var(--shadow);
  backdrop-filter: blur(var(--blur));
}
.hero__card{padding:22px}
.hero__card h3{margin:0 0 12px}
.metrics{display:grid; grid-template-columns:repeat(3,1fr); gap:12px}
.metric{padding:12px; border-radius:14px; background: rgba(255,255,255,.04); border:1px solid rgba(255,255,255,.06)}
.metric__label{display:block; color:#c6cde0; font-size:12px}
.metric__value{font-weight:800; font-size:20px}
.sparkline{
  height:76px; margin-top:12px; border-radius:12px; background:
    linear-gradient(180deg, rgba(14,58,74,.24), transparent),
    repeating-linear-gradient(90deg, rgba(255,255,255,.04) 0 1px, transparent 1px 6px);
  position:relative; overflow:hidden;
}
.sparkline::after{
  content:""; position:absolute; inset:auto 0 0 0; height:2px; background:var(--grad);
  animation: rise 3.6s var(--easing) infinite alternate;
}
@keyframes rise{from{transform:translateX(-30%) scaleX(.6)} to{transform:translateX(10%) scaleX(1)}}

/* Trust row */
.trust{display:flex; align-items:center; gap:10px; margin-top:18px; color:#cbd3e6}
.dot{width:6px; height:6px; border-radius:50%; background: #a5b0c9; opacity:.5}

/* =========================
   6) Servicios (cards)
========================= */
.cards{
  display:grid; grid-template-columns: repeat(3, 1fr); gap:18px; margin-top:18px
}
@media (max-width: 1024px){ .cards{grid-template-columns: repeat(2,1fr)} }
@media (max-width: 640px){ .cards{grid-template-columns: 1fr} }

.card{
  padding:22px; transition: transform .25s var(--easing), border-color .25s var(--easing)
}
.card:hover{transform: translateY(-6px); border-color: rgba(255,138,0,.55)}
.card h3{margin:0 0 8px}

/* Contenedor del icono */
.card__icon{
  width:40px; height:40px; display:grid; place-content:center;
  border-radius:12px;
  background: rgba(42,164,199,.12);
  border:1px solid rgba(42,164,199,.22);
  color:#bfe6ff; /* contraste */
}
/* Asegura tamaño y color del SVG */
.card__icon svg{
  width:22px; height:22px; display:block;
  stroke: currentColor;
  fill: none;
  stroke-width: 1.8;
  stroke-linecap: round;
  stroke-linejoin: round;
}

/* =========================
   7) Planes (pricing)
========================= */
.cards--pricing{grid-template-columns: repeat(3, 1fr); margin-top:6px}
.price {
  padding: 26px;
  display: flex;
  flex-direction: column;
  gap: 14px;
  position: relative;
}
.price--featured{
  border-color: rgba(255,138,0,.55);
  box-shadow: 0 0 0 2px rgba(255,138,0,.25) inset, var(--shadow);
  transform: translateY(-6px)
}
.price__badge{
  position:absolute; top:16px; left:16px; font-size:12px; font-weight:700; letter-spacing:.08em;
  padding:6px 10px; border-radius:999px; color:#0c0f17; background:#fff; box-shadow:0 4px 14px rgba(0,0,0,.22)
}
.badge--green{background: #86efac}
.badge--blue{background: #93c5fd}
.badge--red{background: #fca5a5}

.price h3 { margin: 40px 0 4px; font-size: 20px; }
.price__list{margin:6px 0 12px; padding-left:18px}
.price__list li{margin:6px 0}
.price__cta {
  margin-top: auto; display: flex; flex-direction: column; gap: 6px;
}

.plans__summary{display:flex; gap:12px; flex-wrap:wrap; justify-content:center; margin-top:18px}
.plans__chip{padding:10px 14px; border-radius:999px; font-size:14px}

/* =========================
   8) Historia (timeline)
========================= */
.timeline{display:grid; gap:28px; position:relative}
.timeline__item{display:grid; grid-template-columns: 26px 1fr; gap:14px}
.timeline__dot{width:26px; height:26px; border-radius:50%; background:var(--grad); box-shadow:0 0 0 4px rgba(14,58,74,.15)}
.timeline__card{padding:18px}

/* =========================
   9) Contacto
========================= */
.contact__grid{display:grid; grid-template-columns: 1.2fr .8fr; gap:24px; align-items:start}
@media (max-width: 980px){ .contact__grid{grid-template-columns:1fr} }
.form{padding:22px}
.form__row{display:grid; gap:6px; margin-bottom:12px}
input, textarea{
  background:#0f1423; border:1px solid rgba(255,255,255,.1); color:var(--text);
  border-radius:12px; padding:12px 14px; outline:none; transition:border-color .2s
}
input:focus, textarea:focus{border-color: rgba(42,164,199,.45)}
.form__note{color:var(--muted); font-size:12px}
.info__card{padding:18px}
.wa{text-decoration:none; color:#ffd59c}
.wa:hover{color: var(--brand-accent)}

.contact__info a {
  color: #d0d3db;
  text-decoration: none;
  transition: color 0.2s ease;
}
.contact__info a:hover { color: var(--brand-accent); }

/* =========================
   10) Footer
========================= */
.site-footer{padding:36px 0 18px; border-top:1px solid rgba(255,255,255,.06); background: linear-gradient(180deg, rgba(10,12,20,.2), rgba(10,12,20,.6))}
.footer__grid{display:grid; grid-template-columns: 1.4fr 1fr auto; gap:18px; align-items:center}
@media (max-width: 880px){ .footer__grid{grid-template-columns:1fr} }
.footer__links{display:flex; gap:16px; flex-wrap:wrap}
.footer__links a{color:#cdd5ea; text-decoration:none}
.footer__links a:hover{color:var(--brand-accent)}
.footer__bottom{margin-top:18px; display:flex; align-items:center; justify-content:space-between; color:#aeb6cb}
.to-top{color:#d7def1; text-decoration:none; border:1px solid rgba(255,255,255,.15); padding:8px 10px; border-radius:12px}

/* =========================
   11) Utilidades: reveal / toast / a11y
========================= */
[data-reveal]{
  opacity:0; transform: translateY(16px) scale(.98);
  transition: opacity var(--speed) var(--easing), transform var(--speed) var(--easing);
}
.is-inview{opacity:1; transform: none}

.toast {
  position: fixed;
  bottom: 22px;
  left: 50%;
  transform: translateX(-50%);
  background: rgba(20,20,30,0.9);
  color: #fff;
  padding: 12px 20px;
  border-radius: 12px;
  font-size: 15px;
  opacity: 0;
  pointer-events: none;
  transition: opacity .3s ease;
  z-index: 100;
}
.toast.show {
  opacity: 1;
}

/* Skip-link helper si lo usás desde HTML */
.visually-hidden-focusable{position:absolute;width:1px;height:1px;margin:-1px;padding:0;overflow:hidden;clip:rect(0 0 0 0);white-space:nowrap;border:0}
.visually-hidden-focusable:focus{position:static;width:auto;height:auto;margin:0;clip:auto;overflow:visible;background:#12172a;color:#fff;padding:6px 10px;border-radius:8px}

/* =========================
   12) Motion preferences
========================= */
@media (prefers-reduced-motion: reduce){
  html{scroll-behavior:auto}
  [data-reveal]{transition:none}
  .btn, .card:hover, .price--featured{transform:none !important}
}

/* =========================
   13) Compact tweaks (mínimos)
========================= */
body{ font-size: 15px; line-height: 1.55; }

.section{ padding: 76px 0; }       /* antes 88px */
.hero{ padding: 96px 0 68px; }     /* antes 110px 0 80px */

.nav{ height: 66px; }              /* antes 72px */

/* logo levemente más chico en general */
.logo__img{ width: 24px; height: 24px; }
.logo__text{ font-size: 20px; }    /* antes 22px */

.section__head h2{ font-size: clamp(26px, 3.6vw, 40px); }
.hero__title{ font-size: clamp(32px, 5.4vw, 54px); }

.btn{ padding: 10px 16px; }
.btn--sm{ padding: 8px 12px; font-size: 13px; }

.card{ padding: 20px; }
.cards{ gap: 16px; }

.metrics{ gap: 10px; }
.metric{ padding: 10px; }
.metric__value{ font-size: 18px; }

.price{ padding: 22px; }
.price h3{ font-size: 18px; }
.price__list{ margin: 4px 0 10px; }

input, textarea{ padding: 10px 12px; }

.site-footer{ padding: 30px 0 16px; }

/* =========================
   WhatsApp Widget — moderno
========================= */
.wa-widget{
  position: fixed;
  right: 22px;
  bottom: 22px;
  z-index: 90;
}

/* Botón “glass” con aro degradado */
.wa-button{
  position: relative;
  width: 64px; height: 64px;
  border: 0;
  border-radius: 999px;
  display: grid; place-items: center;
  background: rgba(255,255,255,0.08);
  color: #fff;
  backdrop-filter: blur(12px) saturate(160%);
  -webkit-backdrop-filter: blur(12px) saturate(160%);
  box-shadow: 0 12px 28px rgba(0,0,0,.42);
  cursor: pointer;
  transition: transform .22s var(--easing), box-shadow .22s var(--easing);
  overflow: hidden;
}
.wa-button svg{ width: 28px; height: 28px; display:block; }
.wa-button:hover{
  transform: translateY(-2px) scale(1.03);
  box-shadow: 0 18px 36px rgba(0,0,0,.5);
}

/* aro exterior con degradé IKOOGO */
.wa-ring{
  position:absolute; inset: -2px;
  border-radius: 999px;
  background: conic-gradient(from 210deg, var(--brand-dark), #2AA4C7, var(--brand-accent), var(--brand-dark));
  filter: blur(8px) saturate(140%);
  opacity:.9;
  z-index:-1;
}

/* Tarjeta glass */
.wa-card{
  position: absolute;
  right: 78px; bottom: 0;
  width: 340px; max-width: min(92vw, 360px);
  padding: 16px;
  border-radius: 18px;
  border:1px solid rgba(255,255,255,.16);
  background:
    radial-gradient(140% 120% at 100% 0%, rgba(255,138,0,.16), transparent 60%),
    radial-gradient(140% 120% at 0% 100%, rgba(42,164,199,.14), transparent 60%),
    rgba(255,255,255,.06);
  backdrop-filter: blur(14px) saturate(160%);
  -webkit-backdrop-filter: blur(14px) saturate(160%);
  box-shadow: 0 18px 40px rgba(0,0,0,.45);
  opacity:0; transform: translateY(10px) scale(.96);
  transform-origin: bottom right;
  pointer-events: none;
  transition: opacity .28s var(--easing), transform .28s var(--easing);
}
.wa-card.show{ opacity:1; transform: translateY(0) scale(1); pointer-events:auto; }

/* Header */
.wa-card__head{
  display:flex; align-items:center; justify-content:space-between;
  margin-bottom: 12px;
}

/* Bloque marca: avatar a la izquierda, textos a la derecha */
.wa-brand{
  display:flex; align-items:center; gap:10px;
  min-width: 0;
}
.wa-brand__avatar{
  width: 36px; height: 36px;
  border-radius: 50%;
  overflow: hidden;
  display: grid; place-items: center;
  background: var(--grad);
  box-shadow: 0 4px 14px rgba(0,0,0,.28);
  flex-shrink: 0;
}
.wa-brand__avatar img{
  width: 100%; height: 100%;
  object-fit: cover; border-radius: 50%; display:block;
}
.wa-brand__info{
  display:flex; flex-direction:column; line-height:1.2;
}
.wa-brand__info strong{
  font-size: 14px; color: var(--text); letter-spacing:.2px;
}
.wa-online{ color:#86efac; font-size:12px; display:flex; align-items:center; gap:6px;}
.wa-dot{ width:8px; height:8px; border-radius:999px; background:#86efac; box-shadow:0 0 8px #86efac; }

/* Cerrar */
.wa-close{
  background: transparent; border:0; color:#cfd6ea;
  font-size: 22px; line-height: 1; cursor:pointer;
  padding: 2px 6px; border-radius: 8px;
}
.wa-close:hover{ background: rgba(255,255,255,.08); }

/* Mensaje burbuja */
.wa-bubble{
  padding: 12px 14px;
  border-radius: 14px;
  margin: 6px 0 14px;
  background: rgba(255,255,255,.08);
  border:1px solid rgba(255,255,255,.16);
  color: var(--text);
  box-shadow: inset 0 1px 0 rgba(255,255,255,.06);
}

/* CTA ancho y moderno */
.wa-cta{
  display:flex; align-items:center; justify-content:center; gap:10px;
  width:100%;
  text-decoration:none;
  color:#fff; font-weight:700;
  padding: 12px 16px;
  border-radius: 14px;
  background: linear-gradient(135deg, #2AA4C7, #FF8A00);
  box-shadow: 0 8px 22px rgba(255,138,0,.25);
  transition: transform .2s var(--easing), box-shadow .2s var(--easing), filter .2s var(--easing);
}
.wa-cta:hover{
  transform: translateY(-2px);
  box-shadow: 0 12px 30px rgba(255,138,0,.33);
  filter: saturate(115%);
}
.wa-cta svg{ width:18px; height:18px; }

/* Responsive */
@media (max-width: 640px){
  .wa-widget{ right:16px; bottom:16px; }
  .wa-card{ right: 72px; width: 92vw; }
}

/* Motion safe */
@media (prefers-reduced-motion: reduce){
  .wa-card, .wa-button, .wa-cta{ transition:none; }
}

/* =========================================================
   RESPONSIVE OVERRIDES — pegar al final de styles.css
   Breakpoints: 1440 / 1200 / 980 / 768 / 640 / 480
========================================================= */

/* ====== ≥1440px (TV / desktop grande) ====== */
@media (min-width: 1440px){
  :root{ --container: 1240px; }
  .section{ padding: 100px 0; }
  .hero{ padding: 120px 0 90px; }
  .hero__title{ font-size: clamp(48px, 4vw, 68px); }
  .hero__grid{ gap: 56px; }
  .metrics{ gap: 14px; }
  .price{ gap: 18px; }
}

/* ====== 1200–1439px (desktop común ancho) ====== */
@media (min-width: 1200px) and (max-width: 1439px){
  :root{ --container: 1160px; }
}

/* ====== ≤1200px (laptops) ====== */
@media (max-width: 1200px){
  .container{ padding: 0 20px; }
  .hero__grid{ gap: 36px; }
  .cards--pricing{ gap: 16px; }
  .price{ padding: 22px; }
}

/* ====== ≤980px (tablet horizontal) ====== */
@media (max-width: 980px){
  .hero{ padding: 90px 0 64px; }
  .hero__grid{ grid-template-columns: 1fr; }
  .hero__visual{ order: -1; }                 /* gráfico arriba en tablet/móvil */
  .hero__card{ padding: 18px; }

  .contact__grid{ grid-template-columns: 1fr; gap: 18px; }
  .footer__grid{ grid-template-columns: 1fr; gap: 14px; }
  .footer__bottom{ flex-direction: column; gap: 8px; }
}

/* ====== ≤768px (tablet / phablet) ====== */
@media (max-width: 768px){
  body{ font-size: 14.5px; }
  .section{ padding: 64px 0; }
  .section__head{ margin-bottom: 28px; }

  .cards{ grid-template-columns: 1fr 1fr; gap: 14px; }
  .cards--pricing{ grid-template-columns: 1fr; }
  .price--featured{ transform: none; }        /* sin “levantar” en listado 1col */

  .timeline__item{ grid-template-columns: 22px 1fr; }
  .timeline__dot{ width: 22px; height: 22px; }

  .btn{ padding: 10px 14px; }
  .btn--sm{ padding: 8px 12px; font-size: 13px; }

  .nav{ height: 64px; }
  html{ scroll-padding-top: 72px; }           /* compensa header sticky móvil */

  /* WhatsApp card más compacta en tablet */
  .wa-card{ right: 72px; width: min(92vw, 320px); }
}

/* ====== ≤640px (móvil) ====== */
@media (max-width: 640px){
  .container{ padding: 0 16px; }

  .hero{ padding: 78px 0 56px; }
  .hero__title{ font-size: clamp(28px, 8vw, 40px); }
  .hero__subtitle{ font-size: 0.95rem; }

  .cards{ grid-template-columns: 1fr; gap: 12px; }
  .card{ padding: 18px; }
  .card__icon{ width: 36px; height: 36px; }

  .metrics{ grid-template-columns: 1fr 1fr 1fr; gap: 8px; }
  .metric{ padding: 10px; }
  .metric__value{ font-size: 17px; }

  .plans__summary{ gap: 8px; }
  .plans__chip{ font-size: 13px; padding: 8px 12px; }

  .form{ padding: 18px; }
  input, textarea{ font-size: 16px; }         /* evita zoom iOS al enfocar */
  .form__row{ margin-bottom: 10px; }

  .site-footer{ padding: 26px 0 14px; }
  .footer__links{ gap: 12px; }

  /* WhatsApp widget en móvil */
  .wa-widget{ right: 16px; bottom: 16px; }
  .wa-button{ width: 58px; height: 58px; }
  .wa-card{ right: 68px; width: 88vw; padding: 14px; }
  .wa-bubble{ font-size: 14px; }
  .wa-cta{ padding: 11px 14px; }
}

/* ====== ≤480px (móvil chico) ====== */
@media (max-width: 480px){
  .hero__actions{ gap: 10px; }
  .btn{ width: 100%; }                         /* CTAs full-width si te gusta */
  .trust{ flex-wrap: wrap; gap: 8px; }

  .price__badge{ transform: scale(.92); }
  .price h3{ font-size: 17px; }
  .price__list{ padding-left: 16px; }

  .toast{ left: 12px; right: 12px; transform: none; }
}

/* ====== HiDPI icon fix (asegura nítido en móviles) ====== */
.card__icon svg{
  width: 22px; height: 22px;
  stroke: currentColor; fill: none; stroke-width: 1.8;
  shape-rendering: geometricPrecision;
}

/* ========================
   HOTFIX hero “parte superior”
   (añadir al final de styles.css)
======================== */

/* Da aire bajo el header sticky en todos los tamaños */
.hero{
  padding-top: clamp(88px, 12vh, 120px);
}

/* Limita el ancho del bloque de texto y del título */
.hero__copy{ max-width: 640px; }
.hero__title{
  max-width: 36ch;                 /* aprox. 2–3 líneas grandes */
  word-wrap: break-word;
  hyphens: auto;
}
/* Si el navegador soporta balanceado de líneas, úsalo (quedan más prolijas) */
@supports (text-wrap: balance){
  .hero__title{ text-wrap: balance; }
}

/* Recalibra la grilla del hero en desktop y evita superposiciones */
@media (min-width: 981px){
  .hero__grid{
    grid-template-columns: minmax(360px, 560px) 1fr; /* texto fijo cómodo + visual flexible */
    align-items: center;
    gap: 44px;
  }
  .hero__visual{ min-width: 0; }
  .hero__visual .hero__card{
    max-width: 760px;               /* evita que se “salga” del contenedor */
    margin-left: auto;
  }
}

/* En 1200–1440 aprieta un poco para que no desborde */
@media (min-width: 1200px) and (max-width: 1439px){
  .hero__copy{ max-width: 600px; }
  .hero__title{ max-width: 34ch; }
}

/* En tablet/móvil el gráfico va arriba y todo entra sin solaparse */
@media (max-width: 980px){
  .hero__grid{ grid-template-columns: 1fr; gap: 28px; }
  .hero__visual{ order: -1; }
  .hero__copy, .hero__title{ max-width: 100%; }
}

/* Ajustes menores para que los botones no “brinquen” en móvil chico */
@media (max-width: 480px){
  .hero__actions .btn{ width: 100%; }
}

/* === FIX móvil: evitar cortes y scroll lateral === */
html, body { overflow-x: hidden; }

/* Contenedor y secciones más compactos en móvil */
@media (max-width: 480px){
  .container{ padding-inline: 16px; }
  .section{ padding: 64px 0; }
}

/* Hero: apoya al sticky header y evita que se “coma” el inicio */
.hero{
  padding-top: clamp(84px, 12vh, 120px);
}

/* Título y copia con ancho controlado (para que no “empujen”) */
.hero__copy{ max-width: 640px; }
.hero__title{
  max-width: 34ch;
  word-wrap: break-word;
  hyphens: auto;
}
@supports (text-wrap: balance){
  .hero__title{ text-wrap: balance; }
}

/* Grilla del hero responsiva y sin solapes */
@media (min-width: 981px){
  .hero__grid{
    grid-template-columns: minmax(340px,560px) 1fr;
    align-items: center;
    gap: 44px;
  }
  .hero__visual{ min-width: 0; }
  .hero__visual .hero__card{ max-width: 760px; margin-left: auto; }
}
@media (max-width: 980px){
  .hero__grid{ grid-template-columns: 1fr; gap: 28px; }
  .hero__visual{ order: -1; }         /* el gráfico va arriba en móvil */
  .hero__copy, .hero__title{ max-width: 100%; }
  .hero__actions .btn{ width: 100%; }  /* botones en columna */
}

/* Oculta/limita blurs pesados en pantallas chicas (evita cortes visuales) */
@media (max-width: 640px){
  .decor{ filter: blur(50px); opacity:.22; }
  .decor--1, .decor--2, .decor--3{
    width: 60vw; height: 60vw;
  }
}

/* Cards y grids más fluidos */
@media (max-width: 1024px){ .cards{ grid-template-columns: repeat(2,1fr); } }
@media (max-width: 640px){  .cards{ grid-template-columns: 1fr; } }

/* Contacto: una sola columna en tablet/móvil */
@media (max-width: 980px){
  .contact__grid{ grid-template-columns: 1fr; gap: 18px; }
}

/* Footer responsivo */
@media (max-width: 880px){
  .footer__grid{ grid-template-columns: 1fr; gap: 16px; }
}

/* Header sticky: fondo sólido en móvil para evitar artefactos de blur en iOS */
@media (max-width: 640px){
  .site-header{
    background: rgba(10,12,20,.92);
    -webkit-backdrop-filter: none;
    backdrop-filter: none;
  }
}

/* WhatsApp widget: asegura que no cause scroll lateral en móvil */
.wa-widget{ max-width: 100vw; }
@media (max-width: 640px){
  .wa-widget{ right: 16px; bottom: 16px; }
  .wa-card{ right: 72px; width: 92vw; }
}

/* ==== Anti-scroll lateral (defensivo) ==== */
html, body { 
  width: 100%;
  overflow-x: clip;           /* mejor que hidden en móviles modernos */
}

/* Evita que algo dentro del container “se salga” */
.container { 
  overflow: hidden;
}

/* Canvas de la sparkline: que nunca exceda su contenedor */
.sparkline canvas{
  display: block;
  width: 100% !important;
  max-width: 100%;
}

/* Títulos largos: que puedan partir sin empujar el layout */
.hero__title{
  overflow-wrap: anywhere;    /* fallback universal */
  word-break: break-word;
}

/* Grids que a veces generan overscroll por sombras/transform */
.hero__grid,
.cards,
.contact__grid,
.footer__grid{
  overflow: hidden;
}

/* Decoraciones grandes: más pequeñas y “clip” en móvil */
@media (max-width: 640px){
  .decor{ 
    width: 60vw; height: 60vw; 
    filter: blur(50px); opacity: .22;
  }
}

/* WhatsApp card en móvil: que nunca empuje el viewport */
@media (max-width: 640px){
  .wa-widget{ right: 16px; bottom: 16px; max-width: 100vw; }
  .wa-card{ right: 72px; width: 92vw; max-width: 92vw; }
}
