/* ============================================================
   QuickMayorista — Landing
   Dirección: claro corporativo · verde esmeralda + navy · sobrio, moderno
   Paleta tomada del logo (icono verde + wordmark navy).
   ============================================================ */

:root{
  /* ---- superficies (light) ---- */
  --bg:         #f6f8fa;   /* fondo de página, gris muy frío y claro */
  --bg-2:       #eef2f5;
  --paper:      #ffffff;
  --surface:    #ffffff;
  --surface-2:  #f4f7f9;

  /* ---- navy de la marca (oscuros) ---- */
  --navy:       #16232f;   /* texto principal / wordmark "QUICK" */
  --navy-2:     #1f3140;
  --navy-3:     #2a3d4d;

  /* ---- bordes ---- */
  --stroke:     #e4eaee;
  --stroke-2:   #d2dbe1;

  /* ---- verde esmeralda de la marca ---- */
  --emerald:        #12a85e;   /* acento primario (contraste sobre blanco) */
  --emerald-2:      #0d8f4f;   /* hover / sombras */
  --emerald-bright: #2bd47a;   /* verde del logo, para detalles */
  --emerald-soft:   #e7f7ee;   /* tint claro de fondo */

  /* mantengo estos nombres por compatibilidad: ahora apuntan al verde */
  --cyan:       #12a85e;
  --violet:     #16232f;
  --lime:       #2bd47a;
  --magenta:    #12a85e;

  /* ---- texto ---- */
  --text:       #16232f;   /* navy ink */
  --muted:      #56646f;
  --muted-2:    #8593a0;

  /* ---- gradientes (un solo hue: verde) ---- */
  --grad:       linear-gradient(100deg,#0d8f4f 0%,#16b364 55%,#2bd47a 100%);
  --grad-soft:  linear-gradient(100deg,#12a85e,#2bd47a);

  /* tipografía */
  --font-display: "Space Grotesk", system-ui, sans-serif;
  --font-body: "Inter", system-ui, sans-serif;
  --font-mono: "JetBrains Mono", monospace;

  --text-hero: clamp(2.7rem, 1rem + 8vw, 7rem);
  --text-h2:   clamp(2rem, 1rem + 3.4vw, 3.6rem);
  --text-h3:   clamp(1.15rem, 1rem + .6vw, 1.5rem);
  --text-lead: clamp(1.02rem, .95rem + .4vw, 1.22rem);

  --space-sec: clamp(4.5rem, 3rem + 7vw, 9.5rem);
  --r: 16px;
  --r-lg: 22px;
  --ease: cubic-bezier(.16,1,.3,1);
  --maxw: 1200px;

  --shadow-sm: 0 1px 2px rgba(22,35,47,.06), 0 1px 3px rgba(22,35,47,.05);
  --shadow:    0 10px 30px -12px rgba(22,35,47,.18), 0 2px 8px -4px rgba(22,35,47,.08);
  --shadow-lg: 0 30px 70px -30px rgba(22,35,47,.30), 0 8px 24px -12px rgba(22,35,47,.14);
}

/* ---------- reset ---------- */
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
html.lenis,html.lenis body{height:auto}
.lenis.lenis-smooth{scroll-behavior:auto!important}
body{
  font-family:var(--font-body);
  background:var(--bg);
  color:var(--text);
  line-height:1.6;
  overflow-x:clip;
  -webkit-font-smoothing:antialiased;
}
img,svg{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
::selection{background:var(--emerald);color:#fff}
.container{width:min(var(--maxw),92vw);margin-inline:auto}
.grad{
  background:var(--grad);-webkit-background-clip:text;background-clip:text;
  color:transparent;
}

/* ---------- overlays desactivados (look limpio, sin grain ni cursor custom) ---------- */
.grain,.cursor,.cursor-dot{display:none!important}
.scroll-progress{position:fixed;top:0;left:0;right:0;height:2px;z-index:8000;pointer-events:none}
.scroll-progress span{display:block;height:100%;width:0;background:var(--grad)}

/* ---------- buttons ---------- */
.btn{
  --bg:var(--surface);
  display:inline-flex;align-items:center;gap:.55rem;
  font-family:var(--font-display);font-weight:600;font-size:.95rem;letter-spacing:.01em;
  padding:.74rem 1.4rem;border-radius:11px;border:1px solid var(--stroke-2);
  background:var(--bg);color:var(--navy);position:relative;
  transition:transform .25s var(--ease),box-shadow .25s var(--ease),border-color .25s,background .25s;
  cursor:pointer;white-space:nowrap;
}
.btn--lg{padding:.95rem 1.7rem;font-size:1.02rem}
.btn--primary{
  background:var(--emerald);border-color:transparent;color:#fff;font-weight:700;
  box-shadow:0 10px 24px -10px rgba(18,168,94,.55), inset 0 1px 0 rgba(255,255,255,.18);
}
.btn--primary:hover{background:var(--emerald-2);transform:translateY(-2px);
  box-shadow:0 16px 32px -12px rgba(18,168,94,.6), inset 0 1px 0 rgba(255,255,255,.18)}
.btn--glass{background:var(--paper);color:var(--navy);box-shadow:var(--shadow-sm)}
.btn--glass:hover{border-color:var(--stroke-2);background:var(--surface-2);transform:translateY(-2px);box-shadow:var(--shadow)}
.btn--ghost{background:transparent;border-color:transparent;padding-inline:.7rem;color:var(--navy);box-shadow:none}
.btn--ghost:hover{color:var(--emerald)}

/* ============================================================
   NAV
   ============================================================ */
.nav{position:fixed;top:0;left:0;right:0;z-index:1000;transition:transform .4s var(--ease)}
.nav__inner{
  width:min(var(--maxw),94vw);margin:.9rem auto 0;
  display:flex;align-items:center;gap:1.4rem;
  padding:.6rem .7rem .6rem 1.1rem;border-radius:14px;
  border:1px solid transparent;transition:background .35s,border-color .35s,backdrop-filter .35s,box-shadow .35s;
}
.nav.is-scrolled .nav__inner{
  background:rgba(255,255,255,.82);border-color:var(--stroke);backdrop-filter:blur(14px) saturate(150%);
  box-shadow:var(--shadow);
}
.brand{display:flex;align-items:center;gap:.6rem;font-family:var(--font-display);font-weight:700;font-size:1.22rem;letter-spacing:-.01em}
.brand__mark{width:34px;height:34px;object-fit:contain;filter:drop-shadow(0 2px 6px rgba(22,35,47,.12))}
.brand__text{color:var(--navy)}
.brand__accent{color:var(--emerald)}
.nav__links{display:flex;gap:1.6rem;margin-left:auto;font-size:.95rem;color:var(--muted);font-weight:500}
.nav__links a{position:relative;transition:color .25s}
.nav__links a::after{content:"";position:absolute;left:0;bottom:-5px;height:2px;width:0;background:var(--emerald);transition:width .3s var(--ease)}
.nav__links a:hover{color:var(--navy)}
.nav__links a:hover::after{width:100%}
.nav__cta{display:flex;align-items:center;gap:.5rem;margin-left:.4rem}
.nav__burger{display:none;flex-direction:column;gap:5px;background:none;border:0;cursor:pointer;padding:6px;margin-left:auto}
.nav__burger span{width:24px;height:2px;background:var(--navy);border-radius:2px;transition:.3s var(--ease)}
.nav__burger[aria-expanded="true"] span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.nav__burger[aria-expanded="true"] span:nth-child(2){opacity:0}
.nav__burger[aria-expanded="true"] span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

.mobile-menu{position:fixed;inset:0;z-index:999;background:rgba(255,255,255,.97);backdrop-filter:blur(20px);
  display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1.5rem;
  font-family:var(--font-display);font-size:1.6rem;color:var(--navy);opacity:0;pointer-events:none;transition:opacity .35s}
.mobile-menu.is-open{opacity:1;pointer-events:auto}
.mobile-menu .btn{font-size:1.1rem;margin-top:1rem}

/* ============================================================
   HERO
   ============================================================ */
.hero{position:relative;min-height:100svh;display:flex;align-items:center;overflow:clip;padding-top:8rem;padding-bottom:4rem;
  background:
    linear-gradient(90deg,
      rgba(246,248,250,.985) 0%, rgba(246,248,250,.95) 24%,
      rgba(246,248,250,.7) 46%, rgba(246,248,250,.32) 66%, rgba(246,248,250,.06) 100%),
    linear-gradient(0deg, var(--bg) 2%, rgba(246,248,250,.0) 38%),
    var(--bg) url("../assets/hero-equipo.webp") no-repeat center / cover;}
.hero__inner{position:relative;z-index:3;display:block}
/* sobre la foto de fondo no van overlays decorativos */
.hero__canvas,.hero__aurora,.hero__grid-lines{display:none}

.hero__content{position:relative;z-index:3;min-width:0;max-width:560px}
.pill{display:inline-flex;align-items:center;gap:.55rem;font-size:.8rem;color:var(--navy);
  padding:.42rem .9rem .42rem .8rem;border:1px solid var(--stroke-2);border-radius:999px;background:var(--paper);box-shadow:var(--shadow-sm);
  font-weight:600;letter-spacing:.01em;margin-bottom:1.6rem}
.pill__dot{width:7px;height:7px;border-radius:50%;background:var(--emerald);box-shadow:0 0 0 3px rgba(18,168,94,.15);animation:pulse 2s infinite}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.4}}

.hero__title{font-family:var(--font-display);font-weight:700;line-height:1.0;letter-spacing:-.025em;color:var(--navy);
  font-size:clamp(2.5rem,1rem+4.6vw,4.7rem);margin-bottom:1.5rem}
.hero__title .line{display:block;overflow:hidden;padding-bottom:.06em}
.hero__title .word{display:inline-block;will-change:transform;transform:translateY(110%);
  transition:transform .95s var(--ease)}
html.js-ready .hero__title.is-revealed .word{transform:translateY(0)}
.hero__title.is-revealed .word:nth-child(2){transition-delay:.06s}
.hero__title .line:nth-child(2) .word{transition-delay:.12s}
.hero__title .line:nth-child(2) .word:nth-child(2){transition-delay:.18s}
.hero__title .line:nth-child(3) .word{transition-delay:.24s}
.hero__title .grad{background:var(--grad);-webkit-background-clip:text;background-clip:text;color:transparent}
.hero__sub{font-size:var(--text-lead);color:var(--muted);max-width:42ch;margin-bottom:2.2rem}
.hero__sub strong{color:var(--navy);font-weight:600}
.hero__actions{display:flex;gap:.9rem;flex-wrap:wrap;margin-bottom:2rem}
.hero__meta{display:flex;align-items:center;gap:1rem;flex-wrap:wrap;font-size:.86rem;color:var(--muted-2)}
.hero__meta strong{color:var(--muted)}
.hero__meta .sep{width:4px;height:4px;border-radius:50%;background:var(--stroke-2)}

@keyframes ping{0%{box-shadow:0 0 0 0 rgba(18,168,94,.45)}70%{box-shadow:0 0 0 9px rgba(18,168,94,0)}100%{box-shadow:0 0 0 0 rgba(18,168,94,0)}}
@keyframes floatchip{0%,100%{transform:translateY(0)}50%{transform:translateY(-12px)}}
.dot{width:8px;height:8px;border-radius:50%}
.dot--ok{background:var(--emerald);box-shadow:0 0 0 3px rgba(18,168,94,.16)}

.hero__scroll{position:absolute;bottom:1.6rem;left:50%;transform:translateX(-50%);z-index:3;
  display:flex;align-items:center;gap:.6rem;font-family:var(--font-mono);font-size:.72rem;color:var(--muted-2);letter-spacing:.1em;text-transform:uppercase}
.mouse{width:20px;height:32px;border:1.5px solid var(--stroke-2);border-radius:12px;display:flex;justify-content:center;padding-top:5px}
.mouse span{width:3px;height:7px;border-radius:2px;background:var(--muted-2);animation:scrolldot 1.6s infinite}
@keyframes scrolldot{0%{opacity:0;transform:translateY(-3px)}40%{opacity:1}100%{opacity:0;transform:translateY(7px)}}

/* ============================================================
   MARQUEE
   ============================================================ */
.marquee-wrap{padding:1.9rem 0;border-block:1px solid var(--stroke);background:var(--paper);overflow:hidden}
.marquee{display:flex;gap:0;width:max-content}
.marquee__track{display:flex;align-items:center;gap:2.4rem;padding-right:2.4rem;
  font-family:var(--font-display);font-size:clamp(1rem,2vw,1.5rem);font-weight:600;color:var(--navy-3);
  animation:scrollx 40s linear infinite}
.marquee__track i{color:var(--emerald);font-style:normal;font-size:.7em}
.marquee__track span{white-space:nowrap;opacity:.75}
@keyframes scrollx{to{transform:translateX(-100%)}}
.marquee:hover .marquee__track{animation-play-state:paused}

/* ============================================================
   SECTION base
   ============================================================ */
.section{padding-block:var(--space-sec);position:relative}
.section__head{max-width:720px;margin-bottom:3.2rem}
.eyebrow{display:inline-block;font-family:var(--font-mono);font-size:.76rem;text-transform:uppercase;letter-spacing:.14em;
  color:var(--emerald);margin-bottom:1rem;padding-left:1.6rem;position:relative;font-weight:600}
.eyebrow::before{content:"";position:absolute;left:0;top:50%;width:1.1rem;height:2px;background:var(--emerald)}
.section__title{font-family:var(--font-display);font-weight:700;font-size:var(--text-h2);line-height:1.04;letter-spacing:-.02em;color:var(--navy)}
.section__lead{margin-top:1.1rem;font-size:var(--text-lead);color:var(--muted);max-width:54ch}

/* ============================================================
   BENTO
   ============================================================ */
.bento{display:grid;grid-template-columns:repeat(4,1fr);grid-auto-rows:minmax(190px,auto);gap:16px}
.bento__card{position:relative;border:1px solid var(--stroke);border-radius:var(--r-lg);padding:1.6rem;
  background:var(--paper);overflow:hidden;box-shadow:var(--shadow-sm);
  transition:transform .35s var(--ease),border-color .35s,box-shadow .35s}
.bento__card::before{content:"";position:absolute;inset:0;border-radius:inherit;padding:1px;
  background:radial-gradient(160px 160px at var(--mx,50%) var(--my,0%),rgba(18,168,94,.45),transparent 70%);
  -webkit-mask:linear-gradient(#000 0 0) content-box,linear-gradient(#000 0 0);-webkit-mask-composite:xor;mask-composite:exclude;
  opacity:0;transition:opacity .4s}
.bento__card:hover{transform:translateY(-5px);border-color:transparent;box-shadow:var(--shadow-lg)}
.bento__card:hover::before{opacity:1}
.bento--lg{grid-column:span 2;grid-row:span 1}
.bento--tall{grid-row:span 2}
.card-ic{width:46px;height:46px;border-radius:13px;display:grid;place-items:center;color:var(--emerald);
  background:var(--emerald-soft);border:1px solid rgba(18,168,94,.18);margin-bottom:1.1rem}
.card-ic svg{width:24px;height:24px}
.bento__card h3{font-family:var(--font-display);font-size:var(--text-h3);font-weight:600;margin-bottom:.5rem;letter-spacing:-.01em;color:var(--navy)}
.bento__card p{color:var(--muted);font-size:.96rem}
.badge-3d{position:absolute;top:1.3rem;right:1.3rem;font-family:var(--font-mono);font-size:.7rem;font-weight:600;
  color:#fff;background:var(--emerald);padding:.2rem .55rem;border-radius:7px;letter-spacing:.05em}
.bento__demo{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:1.3rem}
.tag{font-size:.78rem;padding:.32rem .7rem;border-radius:8px;border:1px solid var(--stroke-2);background:var(--surface-2);color:var(--muted)}
.tag.is-on{background:var(--emerald);color:#fff;border-color:transparent;font-weight:600}
.bento__portal{display:flex;gap:.7rem;margin-top:1.4rem}
.pcard{flex:1;border:1px solid var(--stroke);border-radius:14px;padding:.6rem;background:var(--surface-2);display:flex;flex-direction:column;gap:.4rem}
.pimg{height:50px;border-radius:9px;background:linear-gradient(135deg,#12a85e,#2bd47a)}
.pimg--2{background:linear-gradient(135deg,#16232f,#2a3d4d)}
.pimg--3{background:linear-gradient(135deg,#2bd47a,#9ae6bf)}
.pcard span{height:7px;border-radius:4px;background:var(--stroke-2)}
.pcard b{font-family:var(--font-mono);font-size:.78rem;color:var(--navy)}

/* ============================================================
   SHOWCASE (scrollytelling)
   ============================================================ */
.showcase{padding-block:var(--space-sec);position:relative}
.showcase__grid{display:grid;grid-template-columns:1fr 1fr;gap:4rem;align-items:start}
.showcase__steps{padding-block:6vh}
.showcase__steps .section__title{margin-bottom:2.4rem}
.step{padding:1.5rem 0 1.5rem 1.6rem;border-left:2px solid var(--stroke);position:relative;opacity:.4;transition:opacity .4s,border-color .4s}
.step::before{content:"";position:absolute;left:-7px;top:1.8rem;width:12px;height:12px;border-radius:50%;background:var(--paper);border:2px solid var(--stroke-2);transition:.4s}
.step.is-active{opacity:1;border-color:var(--emerald)}
.step.is-active::before{background:var(--emerald);border-color:var(--emerald);box-shadow:0 0 0 4px rgba(18,168,94,.16)}
.step__n{font-family:var(--font-mono);font-size:.8rem;color:var(--emerald)}
.step h3{font-family:var(--font-display);font-size:var(--text-h3);font-weight:600;margin:.35rem 0 .4rem;color:var(--navy)}
.step p{color:var(--muted);font-size:.98rem;max-width:42ch}

.showcase__visual{position:sticky;top:calc(50vh - 290px);height:580px;display:grid;place-items:center}
.showcase__glow{position:absolute;inset:14% 18%;border-radius:50%;background:radial-gradient(ellipse,rgba(43,212,122,.22),transparent 70%);filter:blur(80px);opacity:.7;z-index:-1}

/* ============================================================
   STATS  (banda navy oscura — contraste / ritmo)
   ============================================================ */
.stats{padding-block:clamp(3.2rem,6vw,5rem);background:var(--navy);color:#fff}
.stats__grid{display:grid;grid-template-columns:repeat(4,1fr);gap:2rem;text-align:center}
.stat__num{display:block;font-family:var(--font-display);font-weight:700;font-size:clamp(2.4rem,5vw,3.8rem);line-height:1;
  background:linear-gradient(100deg,#2bd47a,#7ef0ad);-webkit-background-clip:text;background-clip:text;color:transparent}
.stat span{display:block;margin-top:.6rem;color:rgba(255,255,255,.62);font-size:.92rem;max-width:22ch;margin-inline:auto}

/* ============================================================
   FLOW
   ============================================================ */
.flow{display:grid;grid-template-columns:repeat(3,1fr);gap:2rem;position:relative}
.flow__line{position:absolute;top:26px;left:10%;right:10%;height:2px;background:linear-gradient(90deg,transparent,var(--emerald),var(--emerald-bright),transparent);opacity:.5}
.flow__step{position:relative;padding-top:1rem}
.flow__num{width:52px;height:52px;border-radius:50%;display:grid;place-items:center;font-family:var(--font-display);font-weight:700;font-size:1.3rem;color:var(--navy);
  background:var(--paper);border:1px solid var(--stroke-2);position:relative;z-index:1;margin-bottom:1.2rem;
  box-shadow:0 0 0 6px var(--bg), var(--shadow-sm)}
.flow__step h3{font-family:var(--font-display);font-size:var(--text-h3);font-weight:600;margin-bottom:.4rem;color:var(--navy)}
.flow__step p{color:var(--muted)}
.flow__step p b{color:var(--emerald);font-family:var(--font-mono);font-weight:500;font-size:.92em}

/* ============================================================
   PRICING
   ============================================================ */
.plans{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;align-items:stretch}
.plan{position:relative;border:1px solid var(--stroke);border-radius:var(--r-lg);padding:1.8rem 1.5rem;
  background:var(--paper);display:flex;flex-direction:column;box-shadow:var(--shadow-sm);
  transition:transform .35s var(--ease),border-color .35s,box-shadow .35s}
.plan:hover{transform:translateY(-6px);border-color:var(--stroke-2);box-shadow:var(--shadow)}
.plan--feat{border-color:rgba(18,168,94,.45);background:linear-gradient(180deg,var(--emerald-soft),var(--paper) 42%);
  box-shadow:0 30px 70px -30px rgba(18,168,94,.4)}
.plan__ribbon{position:absolute;top:-12px;left:50%;transform:translateX(-50%);font-family:var(--font-mono);font-size:.7rem;font-weight:600;
  background:var(--emerald);color:#fff;padding:.28rem .8rem;border-radius:999px;letter-spacing:.04em;white-space:nowrap;box-shadow:0 8px 18px -8px rgba(18,168,94,.6)}
.plan__name{font-family:var(--font-display);font-size:1.2rem;font-weight:600;margin-bottom:.6rem;color:var(--navy)}
.plan__price{font-family:var(--font-display);font-size:2.8rem;font-weight:700;line-height:1;display:flex;align-items:baseline;gap:.15rem;color:var(--navy)}
.plan__price .cur{font-size:1.1rem;color:var(--muted)}
.plan__price .per{font-size:.85rem;color:var(--muted-2);font-weight:500;margin-left:.2rem}
.plan__desc{color:var(--muted);font-size:.9rem;margin:.8rem 0 1.3rem;min-height:2.6em}
.plan__list{list-style:none;display:flex;flex-direction:column;gap:.7rem;margin-bottom:1.6rem;flex:1}
.plan__list li{position:relative;padding-left:1.7rem;font-size:.92rem;color:var(--navy-2)}
.plan__list li::before{content:"";position:absolute;left:0;top:.35em;width:14px;height:9px;border-left:2px solid var(--emerald);border-bottom:2px solid var(--emerald);transform:rotate(-45deg)}
.plan__cta{justify-content:center;width:100%}

/* ============================================================
   CTA FINAL  (banda navy oscura)
   ============================================================ */
.cta-final{position:relative;padding-block:clamp(5rem,9vw,9rem);text-align:center;overflow:hidden;background:var(--navy);color:#fff}
.cta-final__aurora{position:absolute;inset:0;background:
  radial-gradient(ellipse 50% 60% at 30% 25%,rgba(43,212,122,.28),transparent 60%),
  radial-gradient(ellipse 46% 56% at 72% 70%,rgba(18,168,94,.22),transparent 60%);
  filter:blur(50px);opacity:.8}
.cta-final__inner{position:relative;z-index:1;max-width:760px;margin-inline:auto}
.cta-final h2{font-family:var(--font-display);font-weight:700;font-size:clamp(2rem,1rem+4vw,3.8rem);line-height:1.04;letter-spacing:-.02em}
.cta-final h2 .grad{background:linear-gradient(100deg,#2bd47a,#7ef0ad);-webkit-background-clip:text;background-clip:text;color:transparent}
.cta-final p{margin:1.2rem auto 2.2rem;color:rgba(255,255,255,.66);font-size:var(--text-lead);max-width:48ch}
.cta-final__actions{display:flex;gap:.9rem;justify-content:center;flex-wrap:wrap}
.cta-final .btn--glass{background:rgba(255,255,255,.08);border-color:rgba(255,255,255,.2);color:#fff;box-shadow:none}
.cta-final .btn--glass:hover{background:rgba(255,255,255,.16)}

/* ============================================================
   FOOTER  (navy oscuro)
   ============================================================ */
.footer{padding-block:3.5rem 2rem;background:var(--navy);color:rgba(255,255,255,.7)}
.footer__grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:2rem;margin-bottom:2.5rem}
.footer__brand .brand__logo{height:42px;width:auto;margin-bottom:.2rem}
.footer__brand p{color:rgba(255,255,255,.6);font-size:.9rem;margin-top:1rem;max-width:32ch}
.footer__col h4{font-family:var(--font-display);font-size:.92rem;margin-bottom:1rem;color:#fff}
.footer__col a{display:block;color:rgba(255,255,255,.62);font-size:.9rem;margin-bottom:.6rem;transition:color .25s}
.footer__col a:hover{color:var(--emerald-bright)}
.footer__bottom{display:flex;justify-content:space-between;padding-top:1.6rem;border-top:1px solid rgba(255,255,255,.12);color:rgba(255,255,255,.45);font-size:.82rem;flex-wrap:wrap;gap:.6rem}

/* ============================================================
   REVEAL (JS-driven)
   ============================================================ */
[data-reveal]{opacity:0;transform:translateY(24px);transition:opacity .8s var(--ease),transform .8s var(--ease)}
[data-reveal].is-in{opacity:1;transform:none}

/* ============================================================
   BROWSER / LAPTOP FRAMES  (capturas reales del sistema)
   ============================================================ */
.frame{position:relative;border-radius:16px;overflow:hidden;border:1px solid var(--stroke);
  background:var(--paper);box-shadow:var(--shadow-lg)}
.frame__bar{display:flex;align-items:center;gap:6px;padding:11px 14px;border-bottom:1px solid var(--stroke);
  background:var(--surface-2)}
.frame__bar>span{width:11px;height:11px;border-radius:50%}
.frame__bar>span:nth-child(1){background:#f0625a}
.frame__bar>span:nth-child(2){background:#f3bd4e}
.frame__bar>span:nth-child(3){background:#2bd47a}
.frame__url{margin-left:12px;font-family:var(--font-mono);font-size:.74rem;color:var(--muted);
  background:var(--paper);border:1px solid var(--stroke);padding:4px 12px;border-radius:7px;display:inline-flex;align-items:center;gap:.4rem;
  max-width:62%;overflow:hidden;white-space:nowrap;text-overflow:ellipsis}
.frame__url svg{width:11px;height:11px;color:var(--emerald);flex:none}
.frame__shot{display:block;width:100%;height:auto;background:#fff}
.frame__glow{position:absolute;inset:auto 8% -26% 8%;height:55%;border-radius:50%;
  background:radial-gradient(ellipse,rgba(43,212,122,.28),transparent 70%);filter:blur(60px);z-index:-1}

/* ============================================================
   SOCIAL PROOF
   ============================================================ */
.proof{padding-block:clamp(2.4rem,5vw,3.4rem);border-bottom:1px solid var(--stroke);background:var(--bg)}
.proof__label{text-align:center;font-family:var(--font-mono);font-size:.74rem;letter-spacing:.14em;
  text-transform:uppercase;color:var(--muted-2);margin-bottom:1.8rem}
.proof__row{display:flex;align-items:center;justify-content:center;gap:clamp(1.4rem,4vw,3.4rem);flex-wrap:wrap}
.proof__item{display:flex;align-items:center;gap:.7rem;color:var(--navy-2);font-family:var(--font-display);
  font-weight:600;font-size:1.05rem;opacity:.92;transition:opacity .3s,color .3s}
.proof__item:hover{opacity:1;color:var(--navy)}
.proof__item .av{width:38px;height:38px;border-radius:11px;display:grid;place-items:center;flex:none;
  background:linear-gradient(135deg,var(--emerald),var(--emerald-bright));color:#fff;font-weight:800;font-size:.95rem;
  box-shadow:0 6px 16px -8px rgba(18,168,94,.6)}
.proof__logo{width:40px;height:40px;border-radius:11px;display:grid;place-items:center;flex:none;
  background:var(--paper);border:1px solid var(--stroke);box-shadow:var(--shadow-sm);padding:5px}
.proof__logo img{width:100%;height:100%;object-fit:contain}
.proof__item small{display:block;font-size:.72rem;color:var(--muted-2);font-weight:500;font-family:var(--font-body)}
.proof__live{display:inline-flex;align-items:center;gap:.5rem;font-family:var(--font-mono);font-size:.82rem;color:var(--muted)}
.proof__live .ping{width:9px;height:9px;border-radius:50%;background:var(--emerald);
  box-shadow:0 0 0 0 rgba(18,168,94,.5);animation:ping 1.8s infinite}

/* ============================================================
   FEATURE SPLIT  (filas alternas captura + texto)
   ============================================================ */
.splits{display:flex;flex-direction:column;gap:clamp(4rem,8vw,7rem)}
.split{display:grid;grid-template-columns:1fr 1fr;gap:clamp(2rem,5vw,4.5rem);align-items:center}
.split:nth-child(even) .split__media{order:-1}
.split__copy .eyebrow{color:var(--emerald)}
.split__copy .eyebrow::before{background:var(--emerald)}
.split__copy h3{font-family:var(--font-display);font-size:clamp(1.6rem,1rem+2vw,2.6rem);font-weight:700;color:var(--navy);
  letter-spacing:-.02em;line-height:1.06;margin-bottom:1rem}
.split__copy p{color:var(--muted);font-size:var(--text-lead);max-width:46ch;margin-bottom:1.6rem}
.split__list{list-style:none;display:flex;flex-direction:column;gap:.85rem;margin-bottom:1.8rem}
.split__list li{position:relative;padding-left:2rem;color:var(--navy-2);font-size:.98rem}
.split__list li::before{content:"";position:absolute;left:0;top:.05em;width:20px;height:20px;border-radius:6px;
  background:var(--emerald-soft);border:1px solid rgba(18,168,94,.3)}
.split__list li::after{content:"";position:absolute;left:6px;top:.42em;width:8px;height:5px;
  border-left:2px solid var(--emerald);border-bottom:2px solid var(--emerald);transform:rotate(-45deg)}
.split__media{position:relative}
.split__media .frame{transition:transform .5s var(--ease)}
.split:hover .split__media .frame{transform:translateY(-6px)}
.split__chip{position:absolute;z-index:3;display:flex;align-items:center;gap:.55rem;color:var(--navy);
  font-size:.8rem;font-weight:600;padding:.6rem .9rem;border-radius:13px;border:1px solid var(--stroke);
  background:var(--paper);box-shadow:var(--shadow);
  animation:floatchip 7s ease-in-out infinite}
.split__chip b{font-family:var(--font-display)}
.split__chip--tl{top:-18px;left:-18px}
.split__chip--br{bottom:-18px;right:-18px;animation-delay:-3s}
.split__chip .dot{width:8px;height:8px}

/* ============================================================
   SHOWCASE visual → browser frame
   ============================================================ */
.showcase__frame{position:relative;width:min(100%,640px)}
.showcase__stage{position:relative;aspect-ratio:16/10;border-radius:0 0 16px 16px;overflow:hidden;background:#fff}
.showcase__frame .panel{position:absolute;inset:0;padding:0;display:block;border-radius:0;
  opacity:0;transform:translateY(12px);transition:opacity .5s var(--ease),transform .5s var(--ease)}
.showcase__frame .panel.is-active{opacity:1;transform:none}
.showcase__frame .panel .frame__shot{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:top left}

/* ============================================================
   COMPARATIVA
   ============================================================ */
.compare{overflow:hidden;border:1px solid var(--stroke);border-radius:var(--r-lg);background:var(--paper);box-shadow:var(--shadow-sm)}
.compare table{width:100%;border-collapse:collapse;min-width:680px}
.compare th,.compare td{padding:1.05rem 1.2rem;text-align:left;border-bottom:1px solid var(--stroke);font-size:.95rem}
.compare thead th{font-family:var(--font-display);font-weight:600;font-size:1rem;color:var(--navy)}
.compare thead th:first-child{color:var(--muted);font-weight:500}
.compare .col-us{background:var(--emerald-soft);position:relative}
.compare thead .col-us{color:var(--navy);border-radius:12px 12px 0 0}
.compare thead .col-us::after{content:"Recomendado";position:absolute;top:-9px;left:50%;transform:translateX(-50%);
  font-family:var(--font-mono);font-size:.62rem;font-weight:600;letter-spacing:.04em;color:#fff;
  background:var(--emerald);padding:.16rem .6rem;border-radius:999px;white-space:nowrap}
.compare td:first-child{color:var(--muted);font-weight:500}
.compare tbody tr:last-child td{border-bottom:0}
.compare .yes{color:var(--emerald-2);font-weight:700}
.compare .no{color:var(--muted-2)}
.compare .partial{color:#c2851a}
.compare .ico{display:inline-grid;place-items:center;width:22px;height:22px;border-radius:50%;font-size:.8rem}
.compare .yes .ico{background:var(--emerald-soft)}
.compare .no .ico{background:var(--surface-2)}

/* ============================================================
   TIENDA ONLINE B2B (storefront destacado)
   ============================================================ */
.storefront{position:relative;padding-block:var(--space-sec);overflow:clip;
  border-block:1px solid var(--stroke);
  background:radial-gradient(ellipse 70% 90% at 50% -10%,rgba(43,212,122,.10),transparent 60%),var(--bg)}
.storefront__head{text-align:center;max-width:760px;margin:0 auto 3rem}
.storefront__head .eyebrow{display:inline-block;color:var(--emerald);padding-left:0;border:1px solid rgba(18,168,94,.3);
  background:var(--emerald-soft);border-radius:999px;padding:.4rem 1rem}
.storefront__head .eyebrow::before{display:none}
.storefront__head h2{font-family:var(--font-display);font-weight:700;font-size:var(--text-h2);color:var(--navy);
  line-height:1.04;letter-spacing:-.02em;margin:1.2rem 0 0}
.storefront__head .grad-em{background:var(--grad);-webkit-background-clip:text;background-clip:text;color:transparent}
.storefront__head p{margin-top:1.1rem;font-size:var(--text-lead);color:var(--muted)}
.storefront__stage{position:relative;max-width:1000px;margin:0 auto}
.storefront__stage .frame__shot{display:block;width:100%;height:auto}
.storefront__stage .frame__url b{color:var(--emerald);font-weight:600}
.storefront__halo{position:absolute;inset:8% 12% -14% 12%;z-index:-1;border-radius:50%;
  background:radial-gradient(ellipse,rgba(43,212,122,.3),transparent 70%);filter:blur(70px)}
.storefront__device-chip{position:absolute;z-index:3;display:flex;align-items:center;gap:.5rem;color:var(--navy);
  font-size:.82rem;font-weight:600;padding:.6rem .9rem;border-radius:13px;border:1px solid var(--stroke);
  background:var(--paper);box-shadow:var(--shadow);
  animation:floatchip 7s ease-in-out infinite}
.storefront__device-chip--1{top:14%;left:-22px}
.storefront__device-chip--2{bottom:18%;right:-22px;animation-delay:-3s}
.storefront__minis{margin-top:1.6rem !important}
.storefront__features{display:grid;grid-template-columns:repeat(4,1fr);gap:1.1rem;max-width:1000px;margin:3rem auto 0}
.sf-feat{border:1px solid var(--stroke);border-radius:var(--r);padding:1.3rem;background:var(--paper);box-shadow:var(--shadow-sm);
  transition:border-color .3s,transform .3s,box-shadow .3s}
.sf-feat:hover{border-color:rgba(18,168,94,.35);transform:translateY(-4px);box-shadow:var(--shadow)}
.sf-feat__ic{width:40px;height:40px;border-radius:11px;display:grid;place-items:center;color:var(--emerald);
  background:var(--emerald-soft);border:1px solid rgba(18,168,94,.2);margin-bottom:.9rem}
.sf-feat__ic svg{width:21px;height:21px}
.sf-feat h4{font-family:var(--font-display);font-size:1.02rem;font-weight:600;margin-bottom:.35rem;color:var(--navy)}
.sf-feat p{color:var(--muted);font-size:.88rem;line-height:1.5}
.storefront__cta{text-align:center;margin-top:2.6rem}

/* ============================================================
   INTEGRACIONES (ARCA + Mercado Pago)
   ============================================================ */
.integra{padding-block:clamp(3rem,6vw,4.6rem);border-block:1px solid var(--stroke);background:var(--paper)}
.integra__head{text-align:center;max-width:680px;margin:0 auto 2.4rem}
.integra__head h2{font-family:var(--font-display);font-weight:700;letter-spacing:-.02em;color:var(--navy);
  font-size:clamp(1.5rem,1rem+2vw,2.3rem);line-height:1.1}
.integra__head p{color:var(--muted);margin-top:.8rem;font-size:var(--text-lead)}
.integra__row{display:flex;flex-wrap:wrap;gap:1.1rem;justify-content:center;align-items:stretch}
.integra__card{display:flex;align-items:center;gap:1.1rem;padding:1.15rem 1.5rem;
  border:1px solid var(--stroke);border-radius:var(--r);background:var(--bg);
  min-width:min(300px,90vw);transition:border-color .3s,transform .3s,box-shadow .3s}
.integra__card:hover{border-color:var(--stroke-2);transform:translateY(-4px);box-shadow:var(--shadow)}
.integra__logo{flex:none;display:grid;place-items:center;background:#fff;border-radius:12px;border:1px solid var(--stroke);
  padding:.7rem 1.1rem}
.integra__logo img{display:block;width:auto;max-width:100%}
.integra__txt b{display:block;font-family:var(--font-display);font-weight:600;font-size:1.02rem;color:var(--navy)}
.integra__txt span{font-size:.84rem;color:var(--muted)}
.integra__more{text-align:center;margin-top:1.6rem;font-size:.9rem;color:var(--muted-2)}

/* ============================================================
   GALERÍA + LIGHTBOX
   ============================================================ */
.gallery{padding-block:var(--space-sec);border-top:1px solid var(--stroke);background:var(--bg)}
.gallery__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-top:3rem}
.gshot{display:block;width:100%;text-align:left;font:inherit;color:inherit;cursor:pointer;
  border:1px solid var(--stroke);border-radius:16px;overflow:hidden;background:var(--paper);padding:0;
  position:relative;box-shadow:var(--shadow-sm);transition:transform .35s var(--ease),border-color .35s,box-shadow .35s}
.gshot:hover{transform:translateY(-5px);border-color:var(--stroke-2);box-shadow:var(--shadow-lg)}
.gshot:focus-visible{outline:2px solid var(--emerald);outline-offset:3px}
.gshot__img{position:relative;aspect-ratio:16/10;overflow:hidden;background:#fff}
.gshot__img img{display:block;width:100%;height:100%;object-fit:cover;object-position:top left}
.gshot__img::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 60%,rgba(22,35,47,.12));opacity:0;transition:opacity .3s}
.gshot:hover .gshot__img::after{opacity:1}
.gshot__cap{display:flex;align-items:center;justify-content:space-between;gap:.5rem;
  padding:.85rem 1rem;border-top:1px solid var(--stroke)}
.gshot__cap b{font-family:var(--font-display);font-weight:600;color:var(--navy);font-size:.95rem}
.gshot__zoom{display:inline-flex;align-items:center;gap:.35rem;font-size:.78rem;color:var(--emerald);
  opacity:.9;font-family:var(--font-mono)}
.gshot__zoom svg{width:14px;height:14px}

.lightbox{position:fixed;inset:0;z-index:10000;background:rgba(22,35,47,.75);backdrop-filter:blur(10px);
  display:flex;align-items:center;justify-content:center;padding:4vmin;
  opacity:0;pointer-events:none;transition:opacity .3s}
.lightbox.is-open{opacity:1;pointer-events:auto}
.lightbox__img{max-width:94vw;max-height:84vh;border-radius:12px;border:1px solid rgba(255,255,255,.18);
  box-shadow:0 50px 130px -30px rgba(0,0,0,.6);transform:scale(.97);transition:transform .3s var(--ease)}
.lightbox.is-open .lightbox__img{transform:scale(1)}
.lightbox__cap{position:absolute;bottom:max(18px,3vmin);left:0;right:0;text-align:center;
  font-family:var(--font-display);font-weight:600;color:#fff;font-size:1.05rem;text-shadow:0 2px 12px rgba(0,0,0,.6)}
.lightbox__btn{position:absolute;width:48px;height:48px;border-radius:50%;display:grid;place-items:center;
  background:rgba(255,255,255,.14);border:1px solid rgba(255,255,255,.25);color:#fff;cursor:pointer;
  backdrop-filter:blur(8px);transition:background .25s,transform .25s}
.lightbox__btn:hover{background:rgba(255,255,255,.26);transform:scale(1.08)}
.lightbox__btn svg{width:22px;height:22px}
.lightbox__close{top:max(16px,3vmin);right:max(16px,3vmin)}
.lightbox__prev{left:max(12px,2vmin);top:50%;margin-top:-24px}
.lightbox__next{right:max(12px,2vmin);top:50%;margin-top:-24px}

/* ============================================================
   FAQ
   ============================================================ */
.faq{max-width:820px;margin:0 auto;display:flex;flex-direction:column;gap:.9rem}
.faq__item{border:1px solid var(--stroke);border-radius:var(--r);overflow:hidden;background:var(--paper);box-shadow:var(--shadow-sm);transition:border-color .3s,box-shadow .3s}
.faq__item[open]{border-color:var(--stroke-2);box-shadow:var(--shadow)}
.faq__q{list-style:none;cursor:pointer;padding:1.2rem 1.4rem;display:flex;justify-content:space-between;
  align-items:center;gap:1rem;font-family:var(--font-display);font-weight:600;font-size:1.05rem;color:var(--navy)}
.faq__q::-webkit-details-marker{display:none}
.faq__q::after{content:"+";font-size:1.6rem;font-weight:400;line-height:1;color:var(--emerald);
  transition:transform .3s var(--ease);flex:none}
.faq__item[open] .faq__q::after{transform:rotate(45deg)}
.faq__a{padding:0 1.4rem 1.3rem;color:var(--muted);font-size:.98rem;line-height:1.65;max-width:68ch}

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width:1100px){
  .bento--lg{grid-column:span 2}
}
@media (max-width:980px){
  .hero__inner{grid-template-columns:1fr;gap:2.4rem}
  .hero__content{max-width:640px}
  .hero__device{justify-self:stretch;max-width:560px;width:100%;margin-inline:auto}
}
@media (max-width:900px){
  .nav__links,.nav__cta{display:none}
  .nav__burger{display:flex}
  .hero{padding-top:6.5rem;min-height:auto;padding-bottom:3.5rem;
    background:
      linear-gradient(180deg, rgba(246,248,250,.975) 0%, rgba(246,248,250,.9) 42%, rgba(246,248,250,.55) 72%, rgba(246,248,250,.25) 100%),
      var(--bg) url("../assets/hero-equipo.webp") no-repeat center top / cover;}
  .hero__content{max-width:none}
  .hero__scroll{display:none}
  .showcase__grid{grid-template-columns:1fr;gap:2rem}
  .showcase__visual{position:relative;top:0;height:auto}
  .bento{grid-template-columns:repeat(2,1fr)}
  .bento--lg,.bento--tall{grid-column:span 2;grid-row:span 1}
  .stats__grid{grid-template-columns:repeat(2,1fr);gap:2rem}
  .flow{grid-template-columns:1fr;gap:1.4rem}
  .flow__line{display:none}
  .plans{grid-template-columns:repeat(2,1fr)}
  .footer__grid{grid-template-columns:1fr 1fr}
  .split{grid-template-columns:1fr;gap:2rem}
  .split:nth-child(even) .split__media{order:0}
  .showcase__frame{width:100%;margin-inline:auto}
  .proof__row{gap:1.4rem 2rem}
  .storefront__features{grid-template-columns:repeat(2,1fr)}
  .storefront__device-chip--1{left:8px;top:8px}
  .storefront__device-chip--2{right:8px;bottom:8px}
  .gallery__grid{grid-template-columns:repeat(2,1fr)}
}
@media (max-width:540px){
  .bento{grid-template-columns:1fr}
  .bento--lg,.bento--tall{grid-column:span 1}
  .stats__grid,.plans{grid-template-columns:1fr}
  .storefront__features{grid-template-columns:1fr}
  .gallery__grid{grid-template-columns:1fr}
  .footer__grid{grid-template-columns:1fr}
  .hero__meta .sep{display:none}
  .footer__bottom{flex-direction:column}
  .device__chip{font-size:.7rem;padding:.5rem .7rem}
  .device__chip--qr{right:6px;top:6px}
  .device__chip--stock{right:6px;bottom:10px}
  .hero__inset{width:66%}
  .split__chip{font-size:.72rem;padding:.5rem .7rem}
  .split__chip--tl{top:-12px;left:6px}
  .split__chip--br{bottom:-12px;right:6px}
}

/* ============================================================
   COOKIE BANNER
   ============================================================ */
.cookiebar{position:fixed;left:50%;bottom:1.2rem;transform:translate(-50%,150%);z-index:10000;
  width:min(680px,94vw);background:var(--navy);color:#fff;border-radius:var(--r);
  box-shadow:0 30px 70px -20px rgba(15,27,38,.6);
  display:flex;align-items:center;gap:1.2rem;padding:1.05rem 1.3rem;flex-wrap:wrap;
  transition:transform .5s var(--ease);opacity:0}
.cookiebar.is-open{transform:translate(-50%,0);opacity:1}
.cookiebar p{font-size:.86rem;color:rgba(255,255,255,.78);flex:1;min-width:230px;line-height:1.5}
.cookiebar a{color:var(--emerald-bright);text-decoration:underline;text-underline-offset:2px}
.cookiebar__actions{display:flex;gap:.6rem;flex-wrap:wrap}
.cookiebar .btn{padding:.55rem 1.1rem;font-size:.85rem}
.cookiebar .btn--ghost{color:rgba(255,255,255,.8);border:1px solid rgba(255,255,255,.22)}
.cookiebar .btn--ghost:hover{color:#fff;background:rgba(255,255,255,.08)}

/* ============================================================
   TESTIMONIOS
   ============================================================ */
.testi{padding-block:var(--space-sec);background:var(--bg)}
.testi__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-top:3rem}
.testi__card{position:relative;border:1px solid var(--stroke);border-radius:var(--r-lg);padding:1.8rem 1.6rem;
  background:var(--paper);box-shadow:var(--shadow-sm);display:flex;flex-direction:column;
  transition:transform .35s var(--ease),box-shadow .35s,border-color .35s}
.testi__card:hover{transform:translateY(-5px);box-shadow:var(--shadow-lg);border-color:var(--stroke-2)}
.testi__quote{font-family:var(--font-display);font-size:1.05rem;line-height:1.5;color:var(--navy);margin-bottom:1.4rem;flex:1}
.testi__quote::before{content:"\201C";display:block;font-family:var(--font-display);font-size:3rem;line-height:.6;
  color:var(--emerald);opacity:.5;margin-bottom:.3rem}
.testi__stars{display:flex;gap:2px;margin-bottom:1rem;color:var(--emerald)}
.testi__stars svg{width:16px;height:16px}
.testi__who{display:flex;align-items:center;gap:.8rem;border-top:1px solid var(--stroke);padding-top:1.1rem}
.testi__av{width:42px;height:42px;border-radius:12px;display:grid;place-items:center;flex:none;
  background:linear-gradient(135deg,var(--emerald),var(--emerald-bright));color:#fff;font-weight:800;font-size:1rem;
  box-shadow:0 6px 16px -8px rgba(18,168,94,.6)}
.testi__av--logo{background:var(--paper);border:1px solid var(--stroke);box-shadow:var(--shadow-sm);padding:5px}
.testi__av--logo img{width:100%;height:100%;object-fit:contain}
.testi__who b{display:block;font-family:var(--font-display);font-weight:600;color:var(--navy);font-size:.95rem}
.testi__who span{font-size:.8rem;color:var(--muted-2)}

/* ============================================================
   CONTACTO
   ============================================================ */
.contact{padding-block:var(--space-sec);border-top:1px solid var(--stroke);background:var(--paper)}
.contact__grid{display:grid;grid-template-columns:.9fr 1.1fr;gap:clamp(2rem,5vw,4rem);align-items:start}
.contact__intro .section__title{margin-bottom:1rem}
.contact__intro p{color:var(--muted);font-size:var(--text-lead);max-width:42ch;margin-bottom:2rem}
.contact__methods{display:flex;flex-direction:column;gap:.9rem}
.contact__method{display:flex;align-items:center;gap:.9rem;padding:1rem 1.1rem;border:1px solid var(--stroke);
  border-radius:var(--r);background:var(--bg);transition:border-color .3s,transform .3s,box-shadow .3s}
.contact__method:hover{border-color:rgba(18,168,94,.35);transform:translateY(-3px);box-shadow:var(--shadow)}
.contact__method .ic{width:42px;height:42px;border-radius:11px;display:grid;place-items:center;flex:none;
  color:var(--emerald);background:var(--emerald-soft);border:1px solid rgba(18,168,94,.2)}
.contact__method .ic svg{width:21px;height:21px}
.contact__method b{display:block;font-family:var(--font-display);font-weight:600;color:var(--navy);font-size:.96rem}
.contact__method span{font-size:.85rem;color:var(--muted)}
.contact__form{border:1px solid var(--stroke);border-radius:var(--r-lg);padding:1.8rem;background:var(--paper);box-shadow:var(--shadow-sm)}
.field{margin-bottom:1.1rem}
.field label{display:block;font-size:.84rem;font-weight:600;color:var(--navy);margin-bottom:.4rem}
.field input,.field textarea{width:100%;font-family:var(--font-body);font-size:.95rem;color:var(--navy);
  background:var(--bg);border:1px solid var(--stroke-2);border-radius:11px;padding:.75rem .9rem;transition:border-color .25s,box-shadow .25s}
.field input:focus,.field textarea:focus{outline:none;border-color:var(--emerald);box-shadow:0 0 0 3px rgba(18,168,94,.14)}
.field textarea{resize:vertical;min-height:110px}
.field-row{display:grid;grid-template-columns:1fr 1fr;gap:1.1rem}
.contact__form .btn{width:100%;justify-content:center;margin-top:.3rem}
.contact__note{font-size:.78rem;color:var(--muted-2);text-align:center;margin-top:.9rem}

/* ============================================================
   FOOTER — fila legal
   ============================================================ */
.footer__legal{display:flex;gap:1.4rem;flex-wrap:wrap}
.footer__legal a{color:rgba(255,255,255,.55)}
.footer__legal a:hover{color:var(--emerald-bright)}

/* ============================================================
   SUB-PÁGINAS (legal / nosotros)
   ============================================================ */
.nav--page .nav__inner{background:rgba(255,255,255,.9);border-color:var(--stroke);
  backdrop-filter:blur(14px) saturate(150%);box-shadow:var(--shadow)}
.page{padding-top:clamp(7.5rem,8vw,9.5rem);padding-bottom:var(--space-sec)}
.page__head{max-width:820px;margin:0 auto 3rem;text-align:center}
.page__head .eyebrow{padding-left:0}
.page__head .eyebrow::before{display:none}
.page__head h1{font-family:var(--font-display);font-weight:700;font-size:clamp(2.1rem,1rem+4vw,3.4rem);
  line-height:1.05;letter-spacing:-.02em;color:var(--navy)}
.page__head h1 .grad{background:var(--grad);-webkit-background-clip:text;background-clip:text;color:transparent}
.page__head p{margin-top:1rem;color:var(--muted);font-size:var(--text-lead)}
.page__updated{margin-top:1rem;font-family:var(--font-mono);font-size:.78rem;color:var(--muted-2)}
.prose{max-width:760px;margin:0 auto}
.prose h2{font-family:var(--font-display);font-weight:700;font-size:clamp(1.3rem,1rem+1.2vw,1.7rem);color:var(--navy);
  letter-spacing:-.01em;margin:2.4rem 0 .8rem;scroll-margin-top:6rem}
.prose h2:first-child{margin-top:0}
.prose h3{font-family:var(--font-display);font-weight:600;font-size:1.1rem;color:var(--navy);margin:1.6rem 0 .5rem}
.prose p{color:var(--muted);margin-bottom:1rem;line-height:1.7}
.prose ul,.prose ol{color:var(--muted);margin:0 0 1.1rem 1.3rem;line-height:1.7}
.prose li{margin-bottom:.5rem}
.prose a{color:var(--emerald-2);text-decoration:underline;text-underline-offset:2px}
.prose strong{color:var(--navy)}
.prose__card{border:1px solid var(--stroke);border-radius:var(--r);background:var(--surface-2);padding:1.2rem 1.4rem;margin:1.4rem 0}
.toc{border:1px solid var(--stroke);border-radius:var(--r);background:var(--paper);box-shadow:var(--shadow-sm);
  padding:1.3rem 1.5rem;margin:0 auto 2.6rem;max-width:760px}
.toc b{display:block;font-family:var(--font-display);font-size:.85rem;text-transform:uppercase;letter-spacing:.08em;
  color:var(--muted-2);margin-bottom:.7rem}
.toc ol{list-style:none;display:grid;grid-template-columns:repeat(2,1fr);gap:.4rem 1.4rem;counter-reset:toc}
.toc li{counter-increment:toc}
.toc a{display:flex;gap:.5rem;color:var(--navy-2);font-size:.9rem;padding:.2rem 0;transition:color .2s}
.toc a::before{content:counter(toc,decimal-leading-zero);font-family:var(--font-mono);color:var(--emerald);font-size:.8rem}
.toc a:hover{color:var(--emerald)}

/* sobre nosotros */
.about-values{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-top:1rem}
.about-val{border:1px solid var(--stroke);border-radius:var(--r);background:var(--paper);box-shadow:var(--shadow-sm);padding:1.5rem}
.about-val .ic{width:44px;height:44px;border-radius:12px;display:grid;place-items:center;color:var(--emerald);
  background:var(--emerald-soft);border:1px solid rgba(18,168,94,.2);margin-bottom:1rem}
.about-val .ic svg{width:23px;height:23px}
.about-val h3{font-family:var(--font-display);font-weight:600;font-size:1.1rem;color:var(--navy);margin-bottom:.4rem}
.about-val p{color:var(--muted);font-size:.92rem}
.about-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:2rem;text-align:center;
  margin:3rem 0;padding:2.4rem;border-radius:var(--r-lg);background:var(--navy);color:#fff}
.about-stats b{display:block;font-family:var(--font-display);font-weight:700;font-size:clamp(1.8rem,4vw,2.6rem);
  background:linear-gradient(100deg,#2bd47a,#7ef0ad);-webkit-background-clip:text;background-clip:text;color:transparent}
.about-stats span{display:block;margin-top:.4rem;font-size:.86rem;color:rgba(255,255,255,.62)}

@media (max-width:900px){
  .testi__grid{grid-template-columns:1fr}
  .contact__grid{grid-template-columns:1fr;gap:2.2rem}
  .about-values{grid-template-columns:1fr}
  .about-stats{grid-template-columns:repeat(2,1fr);gap:1.6rem;padding:1.8rem}
  .toc ol{grid-template-columns:1fr}
}
@media (max-width:540px){
  .field-row{grid-template-columns:1fr}
  .cookiebar{padding:1rem;gap:.8rem}
  .cookiebar__actions{width:100%}
  .cookiebar__actions .btn{flex:1}
}

/* ---------- reduced motion ---------- */
@media (prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.001ms!important;animation-iteration-count:1!important;transition-duration:.001ms!important}
  .hero__title .word{transform:none}
  [data-reveal]{opacity:1;transform:none}
  .marquee__track{animation:none}
}
