/* ===================================================================
   MS MOBILE SOLUTION — Landing mobiliario de oficina
   Mobile-first · compacto · premium
   =================================================================== */

/* ---------- Tokens ---------- */
:root{
  --red: #e11122;
  --red-600: #c20e1c;
  --red-700: #9d0a15;
  --red-soft: #fdecee;

  --wa: #25d366;
  --wa-600: #1ebe5a;

  --ink-900: #0e0f12;
  --ink-800: #15171c;
  --ink-700: #1d2026;
  --ink-600: #2a2e37;

  --gray-700: #3c424d;
  --gray-600: #5a616d;
  --gray-500: #7a818d;
  --gray-400: #a3a9b4;
  --gray-300: #ccd0d7;
  --gray-200: #e6e8ec;
  --gray-100: #f1f3f6;
  --mist: #f5f6f9;
  --paper: #ffffff;

  --line: rgba(14,15,18,.10);
  --line-light: rgba(255,255,255,.16);

  --font-head: "Plus Jakarta Sans", system-ui, sans-serif;
  --font-body: "Inter", system-ui, -apple-system, "Segoe UI", sans-serif;

  --r-xs: 10px;
  --r-sm: 13px;
  --r: 18px;
  --r-lg: 26px;
  --pill: 999px;

  --sh-sm: 0 1px 2px rgba(15,18,26,.05), 0 3px 10px rgba(15,18,26,.05);
  --sh: 0 8px 24px rgba(15,18,26,.09);
  --sh-lg: 0 22px 55px rgba(15,18,26,.18);
  --sh-red: 0 12px 30px rgba(225,17,34,.32);
  --sh-wa: 0 12px 28px rgba(37,211,102,.34);

  --container: 1180px;
  --header-h: 62px;
  --ease: cubic-bezier(.22,.61,.36,1);
}

/* ---------- Reset ---------- */
*,*::before,*::after{box-sizing:border-box}
*{margin:0}
html{
  -webkit-text-size-adjust:100%;
  scroll-behavior:smooth;
  scroll-padding-top:calc(var(--header-h) + 12px);
}
body{
  font-family:var(--font-body);
  color:var(--ink-800);
  background:var(--paper);
  line-height:1.6;
  font-size:16px;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
img,svg{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
button{font:inherit;color:inherit;cursor:pointer;border:none;background:none}
input,select,textarea{font:inherit}
ul{list-style:none;padding:0}
h1,h2,h3,h4{font-family:var(--font-head);font-weight:800;line-height:1.12;letter-spacing:-.02em}

.ic{width:20px;height:20px;flex:0 0 auto;fill:none}
.ic-inline{width:15px;height:15px;display:inline-block;vertical-align:-2px}

.container{
  width:100%;
  max-width:var(--container);
  margin-inline:auto;
  padding-inline:clamp(1rem,5vw,2rem);
}

.skip-link{
  position:absolute;left:-999px;top:0;z-index:200;
  background:var(--ink-900);color:#fff;padding:.7rem 1rem;border-radius:0 0 10px 0;
}
.skip-link:focus{left:0}

:focus-visible{outline:2px solid var(--red);outline-offset:3px;border-radius:6px}

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:.5rem;
  font-family:var(--font-head);font-weight:700;font-size:.95rem;
  padding:.85rem 1.3rem;border-radius:var(--pill);
  line-height:1;white-space:nowrap;
  transition:transform .25s var(--ease), box-shadow .25s var(--ease), background .25s var(--ease);
  will-change:transform;
}
.btn .ic{width:18px;height:18px}
.btn:active{transform:scale(.96)}
.btn-sm{padding:.6rem .95rem;font-size:.85rem}
.btn-lg{padding:1rem 1.55rem;font-size:1rem}
.btn-block{width:100%}

.btn-primary{background:linear-gradient(135deg,var(--red),var(--red-700));color:#fff;box-shadow:var(--sh-red)}
.btn-primary:hover{transform:translateY(-2px);box-shadow:0 16px 38px rgba(225,17,34,.42)}

.btn-wa{background:var(--wa);color:#06371b;box-shadow:var(--sh-wa)}
.btn-wa:hover{transform:translateY(-2px);background:var(--wa-600)}

.btn-light{background:#fff;color:var(--ink-900);box-shadow:var(--sh)}
.btn-light:hover{transform:translateY(-2px);box-shadow:var(--sh-lg)}

.btn-ghost-light{background:rgba(255,255,255,.08);color:#fff;border:1px solid rgba(255,255,255,.35);backdrop-filter:blur(6px)}
.btn-ghost-light:hover{background:rgba(255,255,255,.16);transform:translateY(-2px)}

/* ---------- Header ---------- */
.site-header{
  position:fixed;inset:0 0 auto 0;z-index:100;
  height:var(--header-h);
  display:flex;align-items:center;
  background:rgba(255,255,255,.72);
  backdrop-filter:saturate(150%) blur(14px);
  -webkit-backdrop-filter:saturate(150%) blur(14px);
  border-bottom:1px solid transparent;
  transition:background .3s var(--ease), box-shadow .3s var(--ease), border-color .3s var(--ease);
}
.site-header.scrolled{
  background:rgba(255,255,255,.92);
  box-shadow:0 6px 24px rgba(15,18,26,.08);
  border-bottom-color:var(--line);
}
.header-inner{display:flex;align-items:center;justify-content:space-between;gap:1rem;width:100%}
.brand{display:flex;align-items:center}
.brand-logo{height:40px;width:auto;object-fit:contain}

.nav-desktop{display:none;gap:1.6rem}
.nav-desktop a{
  font-family:var(--font-head);font-weight:600;font-size:.92rem;color:var(--gray-700);
  position:relative;padding:.2rem 0;transition:color .2s var(--ease);
}
.nav-desktop a::after{
  content:"";position:absolute;left:0;bottom:-3px;width:0;height:2px;
  background:var(--red);border-radius:2px;transition:width .28s var(--ease);
}
.nav-desktop a:hover{color:var(--ink-900)}
.nav-desktop a:hover::after{width:100%}

.header-actions{display:flex;align-items:center;gap:.6rem}
.header-cta .ic{width:16px;height:16px}

.menu-toggle{
  display:inline-flex;align-items:center;justify-content:center;
  width:42px;height:42px;border-radius:12px;color:var(--ink-900);
  background:var(--gray-100);transition:background .2s var(--ease)}
.menu-toggle:hover{background:var(--gray-200)}
.menu-toggle .ic{width:24px;height:24px}

/* Mobile menu */
.mobile-menu{
  position:absolute;top:var(--header-h);left:0;right:0;
  background:rgba(255,255,255,.98);
  backdrop-filter:blur(14px);
  border-bottom:1px solid var(--line);
  box-shadow:var(--sh-lg);
  padding:.8rem clamp(1rem,5vw,2rem) 1.1rem;
  display:grid;gap:.9rem;
  animation:menuDrop .3s var(--ease);
}
.mobile-menu[hidden]{display:none}
@keyframes menuDrop{from{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:none}}
.mobile-menu nav{display:grid;gap:.15rem}
.mobile-menu nav a{
  display:flex;align-items:center;gap:.8rem;
  font-family:var(--font-head);font-weight:600;font-size:1rem;color:var(--gray-700);
  padding:.75rem .6rem;border-radius:12px;transition:background .2s,color .2s}
.mobile-menu nav a .ic{width:20px;height:20px;color:var(--red)}
.mobile-menu nav a:hover{background:var(--mist);color:var(--ink-900)}

/* ---------- Sections ---------- */
.section{padding-block:clamp(2.7rem,8.5vw,5.5rem);position:relative}
.section-light{background:var(--mist)}
.section-paper{background:var(--paper)}
.section-dark{background:var(--ink-900);color:#fff}
.section-dark .sec-lead{color:var(--gray-400)}

.sec-head{max-width:640px;margin-bottom:1.6rem}
.sec-head-row{display:flex;align-items:flex-end;justify-content:space-between;gap:1rem;max-width:100%}
.sec-title{font-size:clamp(1.35rem,5vw,2.3rem);color:var(--ink-900)}
.section-dark .sec-title,.sec-head-light .sec-title{color:#fff}
.sec-lead{color:var(--gray-600);margin-top:.5rem;font-size:.96rem}
.sec-hint{display:none;align-items:center;gap:.4rem;color:var(--gray-500);font-size:.85rem;font-weight:600;white-space:nowrap}
.sec-hint .ic{width:16px;height:16px}

.eyebrow{
  display:inline-flex;align-items:center;gap:.5rem;
  font-family:var(--font-head);font-weight:700;font-size:.72rem;
  letter-spacing:.14em;text-transform:uppercase;color:var(--red);
  margin-bottom:.7rem;
}
.eyebrow .dot{width:7px;height:7px;border-radius:50%;background:var(--red);box-shadow:0 0 0 4px var(--red-soft)}
.eyebrow-light{color:#fff}
.eyebrow-light .dot{background:var(--red);box-shadow:0 0 0 4px rgba(225,17,34,.28)}

.hl{color:var(--red)}
.hl-underline{position:relative;white-space:nowrap}
.hl-underline::after{content:"";position:absolute;left:0;right:0;bottom:.05em;height:.32em;background:rgba(255,255,255,.28);z-index:-1;border-radius:3px}

/* ---------- Hero ---------- */
.hero{
  position:relative;min-height:92svh;
  display:flex;flex-direction:column;
  padding-top:var(--header-h);
  overflow:hidden;background:var(--mist);
}
.hero-media{position:absolute;inset:0;z-index:0}
.hero-img{width:100%;height:100%;object-fit:cover;object-position:center}
.hero-scrim{
  position:absolute;inset:0;
  background:
    radial-gradient(115% 75% at 50% 12%, rgba(255,255,255,.34), rgba(255,255,255,0) 58%),
    radial-gradient(80% 55% at 88% 6%, rgba(225,17,34,.10), transparent 60%),
    linear-gradient(180deg, rgba(255,255,255,.55) 0%, rgba(255,255,255,.14) 18%, rgba(255,255,255,.05) 48%, rgba(245,246,249,.62) 85%, var(--mist) 100%);
}
.hero-inner{position:relative;z-index:2;flex:1;display:flex;align-items:center;justify-content:center;padding:1.6rem 0 2.2rem}
.hero-card{
  position:relative;z-index:2;width:100%;max-width:600px;text-align:center;
  background:rgba(255,255,255,.74);
  -webkit-backdrop-filter:blur(22px) saturate(150%);
          backdrop-filter:blur(22px) saturate(150%);
  border:1px solid rgba(255,255,255,.8);
  border-radius:var(--r-lg);
  box-shadow:0 30px 70px rgba(15,18,26,.22), inset 0 1px 0 rgba(255,255,255,.75);
  padding:clamp(1.5rem,5.5vw,2.5rem) clamp(1.25rem,5vw,2.5rem);
}
.hero-logo{
  height:clamp(66px,18vw,98px);width:auto;margin:0 auto clamp(.9rem,3vw,1.3rem);
  filter:drop-shadow(0 8px 18px rgba(15,18,26,.14));
}
.hero-card .eyebrow{justify-content:center}
.hero-title{
  font-size:clamp(1.55rem,5.6vw,3rem);color:var(--ink-900);
  margin:0 auto .55rem;max-width:20ch;
}
.hero-sub{
  font-size:clamp(.95rem,3.3vw,1.12rem);color:var(--gray-600);
  max-width:42ch;margin:0 auto clamp(1.1rem,4vw,1.5rem);
}
.hero-cta{display:flex;flex-wrap:wrap;gap:.7rem;justify-content:center}
.hero-cta .btn{flex:1 1 auto;min-width:max-content}

.btn-outline-dark{background:rgba(255,255,255,.55);color:var(--ink-900);border:1px solid var(--gray-300)}
.btn-outline-dark:hover{background:#fff;border-color:var(--ink-900);transform:translateY(-2px)}

/* Floating glass chips (desktop) */
.hero-chip{
  position:absolute;z-index:3;display:none;align-items:center;gap:.6rem;
  background:rgba(255,255,255,.82);
  -webkit-backdrop-filter:blur(12px) saturate(150%);
          backdrop-filter:blur(12px) saturate(150%);
  border:1px solid rgba(255,255,255,.85);
  border-radius:16px;padding:.6rem .85rem;
  box-shadow:0 16px 36px rgba(15,18,26,.20);
}
.hero-chip-ic{display:inline-flex;align-items:center;justify-content:center;width:34px;height:34px;border-radius:10px;background:var(--red-soft);color:var(--red);flex:0 0 auto}
.hero-chip-ic-wa{background:var(--wa);color:#06371b}
.hero-chip-ic .ic{width:18px;height:18px}
.hero-chip-tx{display:flex;flex-direction:column;line-height:1.18;text-align:left}
.hero-chip-tx strong{font-family:var(--font-head);font-weight:700;font-size:.84rem;color:var(--ink-900)}
.hero-chip-tx small{font-size:.72rem;color:var(--gray-500)}
.hero-chip-a{top:9%;left:1%}
.hero-chip-b{bottom:12%;right:1%}

/* Marquee */
.marquee{
  position:relative;z-index:2;
  background:linear-gradient(90deg,var(--red-700),var(--red) 50%,var(--red-700));
  overflow:hidden;padding:.72rem 0;
  -webkit-mask-image:linear-gradient(90deg,transparent,#000 6%,#000 94%,transparent);
          mask-image:linear-gradient(90deg,transparent,#000 6%,#000 94%,transparent);
}
.marquee-track{display:flex;gap:2.2rem;width:max-content;animation:marquee 28s linear infinite}
.marquee-track span{display:inline-flex;align-items:center;gap:.45rem;font-size:.8rem;font-weight:600;color:rgba(255,255,255,.96);white-space:nowrap}
.marquee-track .ic{width:15px;height:15px;color:#fff;stroke:#fff}
@keyframes marquee{from{transform:translateX(0)}to{transform:translateX(-50%)}}
.hero:hover .marquee-track{animation-play-state:paused}

/* ===== Hero — móvil: layout dividido (imagen destacada arriba + contenido limpio) ===== */
@media (max-width:767.98px){
  .hero{
    display:block;
    min-height:0;
    padding-top:var(--header-h);
    background:var(--paper);
  }
  /* La imagen pasa a ser un panel protagonista en la parte superior */
  .hero-media{
    position:relative;inset:auto;
    width:100%;height:clamp(232px,40vh,330px);
    border-radius:0 0 26px 26px;overflow:hidden;
    box-shadow:0 16px 38px rgba(15,18,26,.16);
  }
  .hero-scrim{
    background:linear-gradient(180deg, rgba(255,255,255,.22) 0%, rgba(255,255,255,0) 28%);
  }
  /* El contenido va debajo, limpio, sobre fondo claro (sin recuadro encima de la imagen) */
  .hero-inner{
    display:block;z-index:auto;
    padding:1.5rem 0 1.7rem;text-align:center;
  }
  .hero-card{
    background:transparent;
    -webkit-backdrop-filter:none;backdrop-filter:none;
    border:0;box-shadow:none;border-radius:0;
    width:100%;max-width:none;padding:0;
  }
  .hero-logo{height:clamp(58px,15vw,74px);margin:0 auto .85rem;filter:none}
  .hero-title{font-size:clamp(1.55rem,6.2vw,2.05rem);max-width:22ch;margin-bottom:.5rem}
  .hero-sub{font-size:clamp(.92rem,3.7vw,1.06rem);max-width:36ch;margin-bottom:1.15rem}
  .hero-cta{flex-direction:column;gap:.6rem}
  .hero-cta .btn{width:100%;flex:none}
  .hero-chip{display:none}
}

/* ---------- Benefits ---------- */
.benefit-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:.8rem}
.bcard{
  background:var(--paper);border:1px solid var(--line);border-radius:var(--r);
  padding:1.05rem 1rem;box-shadow:var(--sh-sm);
  transition:transform .3s var(--ease), box-shadow .3s var(--ease), border-color .3s var(--ease);
}
.bcard:hover{transform:translateY(-4px);box-shadow:var(--sh);border-color:rgba(225,17,34,.25)}
.bcard-ic{
  display:inline-flex;align-items:center;justify-content:center;
  width:42px;height:42px;border-radius:12px;margin-bottom:.7rem;
  background:var(--red-soft);color:var(--red);
}
.bcard-ic .ic{width:22px;height:22px}
.bcard h3{font-size:1rem;color:var(--ink-900);margin-bottom:.2rem}
.bcard p{font-size:.84rem;color:var(--gray-600);line-height:1.45}
.bcard-cta{
  background:linear-gradient(140deg,var(--ink-800),var(--ink-900));
  border-color:transparent;color:#fff;
}
.bcard-cta:hover{box-shadow:var(--sh-lg);border-color:transparent}
.bcard-cta h3{color:#fff}
.bcard-cta p{color:rgba(255,255,255,.82);display:flex;align-items:center;gap:.35rem;font-weight:600}
.bcard-ic-light{background:rgba(225,17,34,.95);color:#fff}

/* ---------- Products carousel ---------- */
.pills{display:flex;gap:.5rem;overflow-x:auto;padding-bottom:.3rem;margin-bottom:1rem;scrollbar-width:none}
.pills::-webkit-scrollbar{display:none}
.pill{
  flex:0 0 auto;
  font-family:var(--font-head);font-weight:600;font-size:.85rem;
  padding:.5rem 1rem;border-radius:var(--pill);
  background:var(--gray-100);color:var(--gray-600);
  border:1px solid transparent;
  transition:all .25s var(--ease);
}
.pill:hover{background:var(--gray-200);color:var(--ink-800)}
.pill.is-active{background:var(--ink-900);color:#fff}

.carousel{position:relative}
.carousel-track{
  display:flex;gap:.85rem;overflow-x:auto;
  scroll-snap-type:x mandatory;
  scroll-padding-left:clamp(1rem,5vw,2rem);
  padding:.3rem .2rem 1rem;
  margin-inline:-.2rem;
  -webkit-overflow-scrolling:touch;
  scrollbar-width:none;
}
.carousel-track::-webkit-scrollbar{display:none}
.pcard{
  flex:0 0 79%;max-width:310px;scroll-snap-align:start;
  background:var(--paper);border:1px solid var(--line);border-radius:var(--r);
  overflow:hidden;box-shadow:var(--sh-sm);
  display:flex;flex-direction:column;
  transition:transform .3s var(--ease), box-shadow .3s var(--ease);
}
.pcard.is-hidden{display:none}
.pcard:hover{transform:translateY(-4px);box-shadow:var(--sh)}
.pcard-media{
  position:relative;aspect-ratio:4/3;overflow:hidden;
  background:linear-gradient(135deg,var(--ink-700),var(--ink-900));
}
.pcard-media img{width:100%;height:100%;object-fit:cover;transition:transform .6s var(--ease)}
.pcard:hover .pcard-media img{transform:scale(1.06)}
.pcard-media.img-failed img{opacity:0}
.pcard-tag{
  position:absolute;left:.6rem;top:.6rem;z-index:2;
  display:inline-flex;align-items:center;gap:.35rem;
  font-family:var(--font-head);font-weight:700;font-size:.74rem;
  padding:.34rem .6rem;border-radius:var(--pill);
  background:rgba(255,255,255,.92);color:var(--ink-900);
  backdrop-filter:blur(4px);box-shadow:var(--sh-sm);
}
.pcard-tag .ic{width:15px;height:15px;color:var(--red)}
.pcard-tag-accent{background:var(--red);color:#fff}
.pcard-tag-accent .ic{color:#fff}
.pcard-body{padding:.95rem 1rem 1.05rem;display:flex;flex-direction:column;gap:.35rem;flex:1}
.pcard-body h3{font-size:1.02rem;color:var(--ink-900);line-height:1.2}
.pcard-body p{font-size:.85rem;color:var(--gray-600);flex:1}
.pcard-link{
  display:inline-flex;align-items:center;gap:.4rem;margin-top:.3rem;
  font-family:var(--font-head);font-weight:700;font-size:.88rem;color:var(--red);
}
.pcard-link .ic{width:16px;height:16px;transition:transform .25s var(--ease)}
.pcard-link:hover .ic{transform:translateX(4px)}

.carousel-controls{display:flex;align-items:center;gap:1rem;margin-top:.2rem}
.carousel-progress{flex:1;height:4px;border-radius:4px;background:var(--gray-200);overflow:hidden}
.carousel-progress span{display:block;height:100%;width:30%;border-radius:4px;background:linear-gradient(90deg,var(--red),var(--red-700));transition:width .25s var(--ease), margin-left .25s var(--ease)}
.carousel-btns{display:flex;gap:.5rem}
.cbtn{
  width:42px;height:42px;border-radius:50%;
  display:inline-flex;align-items:center;justify-content:center;
  background:var(--paper);border:1px solid var(--line);color:var(--ink-900);
  box-shadow:var(--sh-sm);transition:all .25s var(--ease);
}
.cbtn:hover{background:var(--ink-900);color:#fff;border-color:var(--ink-900)}
.cbtn:disabled{opacity:.35;cursor:not-allowed}
.cbtn .ic{width:20px;height:20px}
#prodPrev .ic{transform:rotate(90deg)}
#prodNext .ic{transform:rotate(-90deg)}

/* ---------- Process steps ---------- */
.steps{
  display:flex;gap:.85rem;overflow-x:auto;
  scroll-snap-type:x mandatory;padding:.3rem .2rem 1rem;margin-inline:-.2rem;
  scroll-padding-left:clamp(1rem,5vw,2rem);
  -webkit-overflow-scrolling:touch;scrollbar-width:none;
}
.steps::-webkit-scrollbar{display:none}
.step{
  flex:0 0 72%;max-width:260px;scroll-snap-align:start;
  background:linear-gradient(160deg,var(--ink-800),var(--ink-700));
  border:1px solid var(--line-light);border-radius:var(--r);
  padding:1.2rem 1.1rem;position:relative;overflow:hidden;
  transition:transform .3s var(--ease),border-color .3s var(--ease);
}
.step::before{content:"";position:absolute;right:-30px;top:-30px;width:90px;height:90px;border-radius:50%;background:radial-gradient(circle,rgba(225,17,34,.30),transparent 70%)}
.step:hover{transform:translateY(-4px);border-color:rgba(225,17,34,.45)}
.step-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:.85rem}
.step-num{font-family:var(--font-head);font-weight:800;font-size:1.9rem;color:rgba(255,255,255,.16);line-height:1}
.step-ic{width:30px;height:30px;color:var(--red);stroke:var(--red)}
.step h3{font-size:1.05rem;color:#fff;margin-bottom:.25rem}
.step p{font-size:.86rem;color:var(--gray-400);line-height:1.45}

/* ---------- CTA band ---------- */
.cta-band{
  background:linear-gradient(120deg,var(--red-700),var(--red) 55%,#ff3b4a);
  color:#fff;position:relative;overflow:hidden;
  padding-block:clamp(2.4rem,7vw,4rem);
}
.cta-band::before{content:"";position:absolute;inset:0;background:radial-gradient(circle at 80% -20%,rgba(255,255,255,.22),transparent 50%);pointer-events:none}
.cta-band::after{content:"";position:absolute;left:-40px;bottom:-60px;width:200px;height:200px;border-radius:50%;border:30px solid rgba(255,255,255,.07)}
.cta-band-inner{position:relative;display:grid;gap:1.4rem}
.cta-band-text h2{font-size:clamp(1.5rem,6vw,2.6rem);margin:.2rem 0 .5rem;color:#fff}
.cta-band-text p{color:rgba(255,255,255,.92);font-size:.96rem;max-width:46ch}
.cta-band-action{display:flex;flex-direction:column;align-items:flex-start;gap:.6rem}
.cta-band-note{font-size:.82rem;color:rgba(255,255,255,.85);display:flex;align-items:center;gap:.4rem}

/* ---------- Tabs / Confianza ---------- */
.tabbar{
  display:flex;gap:.3rem;background:var(--gray-100);
  padding:.32rem;border-radius:var(--pill);margin-bottom:1.4rem;
  width:fit-content;max-width:100%;overflow-x:auto;scrollbar-width:none;
}
.tabbar::-webkit-scrollbar{display:none}
.tab{
  flex:0 0 auto;font-family:var(--font-head);font-weight:700;font-size:.88rem;
  padding:.6rem 1.15rem;border-radius:var(--pill);color:var(--gray-600);
  transition:color .25s var(--ease);position:relative;
}
.tab.is-active{color:#fff}
.tab.is-active::before{
  content:"";position:absolute;inset:0;z-index:-1;border-radius:var(--pill);
  background:var(--ink-900);box-shadow:var(--sh-sm);
}
.tab-panel{animation:fadeIn .4s var(--ease)}
.tab-panel[hidden]{display:none}
@keyframes fadeIn{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}

.trust-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:.8rem}
.tcard{
  background:var(--paper);border:1px solid var(--line);border-radius:var(--r);
  padding:1rem .95rem;box-shadow:var(--sh-sm);transition:transform .3s var(--ease),box-shadow .3s var(--ease)}
.tcard:hover{transform:translateY(-3px);box-shadow:var(--sh)}
.tcard-ic{display:inline-flex;align-items:center;justify-content:center;width:40px;height:40px;border-radius:11px;background:var(--red-soft);color:var(--red);margin-bottom:.6rem}
.tcard-ic .ic{width:21px;height:21px}
.tcard h3{font-size:.96rem;color:var(--ink-900);margin-bottom:.15rem}
.tcard p{font-size:.82rem;color:var(--gray-600);line-height:1.4}

/* Testimonials slider */
.slider{overflow:hidden;border-radius:var(--r)}
.slider-track{display:flex;transition:transform .5s var(--ease)}
.testi{
  flex:0 0 100%;background:var(--paper);border:1px solid var(--line);
  border-radius:var(--r);padding:1.4rem 1.3rem;box-shadow:var(--sh-sm);
  position:relative;
}
.stars{display:flex;gap:.15rem;color:#f5a623;margin-bottom:.7rem}
.stars .ic{width:18px;height:18px}
.quote-mark{width:34px;height:34px;color:var(--red-soft);position:absolute;right:1.1rem;top:1.1rem}
.testi blockquote{font-size:1rem;color:var(--ink-800);line-height:1.55;font-weight:500;margin-bottom:1rem}
.testi figcaption{display:flex;flex-direction:column}
.testi figcaption strong{font-family:var(--font-head);font-size:.95rem;color:var(--ink-900)}
.testi figcaption span{font-size:.82rem;color:var(--gray-500)}
.slider-dots{display:flex;justify-content:center;gap:.45rem;margin-top:1rem}
.slider-dots button{width:8px;height:8px;border-radius:50%;background:var(--gray-300);transition:all .25s var(--ease)}
.slider-dots button.is-active{width:24px;border-radius:5px;background:var(--red)}

/* Accordion */
.accordion{display:grid;gap:.6rem}
.acc-item{background:var(--paper);border:1px solid var(--line);border-radius:var(--r-sm);overflow:hidden;transition:border-color .25s var(--ease),box-shadow .25s var(--ease)}
.acc-item.open{border-color:rgba(225,17,34,.3);box-shadow:var(--sh-sm)}
.acc-head{
  width:100%;display:flex;align-items:center;justify-content:space-between;gap:1rem;
  padding:1rem 1.1rem;text-align:left;
  font-family:var(--font-head);font-weight:700;font-size:.95rem;color:var(--ink-900);
}
.acc-chevron{width:20px;height:20px;color:var(--red);transition:transform .3s var(--ease);flex:0 0 auto}
.acc-item.open .acc-chevron{transform:rotate(180deg)}
.acc-panel{display:grid;grid-template-rows:0fr;transition:grid-template-rows .35s var(--ease)}
.acc-item.open .acc-panel{grid-template-rows:1fr}
.acc-inner{overflow:hidden}
.acc-inner p{padding:0 1.1rem 1.05rem;color:var(--gray-600);font-size:.9rem;line-height:1.55}

/* ---------- Contact ---------- */
.section-contact{background:linear-gradient(160deg,var(--ink-900),var(--ink-800));color:#fff;position:relative;overflow:hidden}
.section-contact::before{content:"";position:absolute;right:-10%;top:-20%;width:50%;height:60%;background:radial-gradient(circle,rgba(225,17,34,.25),transparent 70%);pointer-events:none}
.contact-wrap{display:grid;gap:1.6rem;position:relative}
.contact-info .sec-title{color:#fff}
.contact-info .sec-lead{color:var(--gray-400)}
.contact-list{display:grid;gap:.6rem;margin-top:1.3rem}
.contact-list a{
  display:flex;align-items:center;gap:.85rem;
  background:rgba(255,255,255,.05);border:1px solid var(--line-light);
  border-radius:var(--r-sm);padding:.85rem .95rem;
  transition:background .25s var(--ease),transform .25s var(--ease),border-color .25s var(--ease);
}
.contact-list a:hover{background:rgba(255,255,255,.1);transform:translateX(3px);border-color:rgba(225,17,34,.4)}
.contact-ic{display:inline-flex;align-items:center;justify-content:center;width:42px;height:42px;border-radius:11px;background:rgba(255,255,255,.08);color:#fff;flex:0 0 auto}
.contact-ic-wa{background:var(--wa);color:#06371b}
.contact-meta{display:flex;flex-direction:column;flex:1;min-width:0}
.contact-meta small{font-size:.72rem;color:var(--gray-400);text-transform:uppercase;letter-spacing:.08em}
.contact-meta strong{font-family:var(--font-head);font-size:.95rem;color:#fff;overflow:hidden;text-overflow:ellipsis}
.contact-go{width:18px;height:18px;color:var(--gray-400);flex:0 0 auto}

/* Lead form */
.contact-card{background:var(--paper);color:var(--ink-800);border-radius:var(--r-lg);padding:1.4rem 1.3rem;box-shadow:var(--sh-lg)}
.contact-card h3{font-size:1.15rem;color:var(--ink-900);margin-bottom:1rem}
.field{display:grid;gap:.35rem;margin-bottom:.85rem}
.field label{font-family:var(--font-head);font-weight:600;font-size:.82rem;color:var(--gray-700)}
.field input,.field select{
  width:100%;padding:.8rem .9rem;border-radius:12px;
  border:1px solid var(--gray-200);background:var(--gray-100);color:var(--ink-900);
  font-size:.95rem;transition:border-color .2s var(--ease),background .2s var(--ease),box-shadow .2s var(--ease);
}
.field input::placeholder{color:var(--gray-400)}
.field input:focus,.field select:focus{outline:none;border-color:var(--red);background:#fff;box-shadow:0 0 0 4px var(--red-soft)}
.contact-card .btn{margin-top:.4rem}
.form-mini{font-size:.78rem;color:var(--gray-500);text-align:center;margin-top:.7rem}

/* ---------- Footer ---------- */
.site-footer{background:var(--ink-900);color:var(--gray-400)}
.footer-inner{display:grid;gap:1.8rem;padding-block:2.6rem 1.8rem}
.footer-logo-chip{display:inline-flex;background:#fff;padding:.85rem 1.1rem;border-radius:16px;margin-bottom:1rem;box-shadow:0 10px 30px rgba(0,0,0,.25)}
.footer-logo-chip img{height:82px;width:auto}
.footer-brand p{font-size:.88rem;line-height:1.6;max-width:38ch;margin-bottom:1rem}
.footer-social{display:flex;gap:.55rem}
.footer-social a{display:inline-flex;align-items:center;justify-content:center;width:40px;height:40px;border-radius:11px;background:rgba(255,255,255,.06);color:#fff;transition:background .25s var(--ease),transform .25s var(--ease)}
.footer-social a:hover{background:var(--red);transform:translateY(-3px)}
.footer-col h4{font-size:.95rem;color:#fff;margin-bottom:.8rem}
.footer-col ul{display:grid;gap:.5rem}
.footer-col a{font-size:.88rem;color:var(--gray-400);transition:color .2s var(--ease)}
.footer-col a:hover{color:#fff}
.footer-contact li{display:flex;align-items:center;gap:.55rem;font-size:.86rem}
.footer-contact .ic{width:17px;height:17px;color:var(--red);flex:0 0 auto}
.footer-bottom{border-top:1px solid rgba(255,255,255,.08);padding-block:1.1rem}
.footer-bottom p{font-size:.8rem;color:var(--gray-500);text-align:center}

/* ---------- Floating WhatsApp ---------- */
.fab-wa{
  position:fixed;right:16px;bottom:16px;z-index:90;
  width:56px;height:56px;border-radius:50%;
  display:inline-flex;align-items:center;justify-content:center;
  background:var(--wa);color:#fff;box-shadow:var(--sh-wa);
  transition:transform .25s var(--ease);
}
.fab-wa .ic{width:30px;height:30px;position:relative;z-index:2}
.fab-wa:hover{transform:scale(1.08)}
.fab-pulse{position:absolute;inset:0;border-radius:50%;background:var(--wa);z-index:1;animation:pulse 2.4s ease-out infinite}
@keyframes pulse{0%{transform:scale(1);opacity:.6}70%{transform:scale(1.7);opacity:0}100%{opacity:0}}

/* ---------- Reveal (scoped a .js: sin JS el contenido es visible) ---------- */
.js [data-reveal]{opacity:0;transform:translateY(20px);transition:opacity .65s var(--ease),transform .65s var(--ease)}
.js [data-reveal].in{opacity:1;transform:none}
[data-reveal-delay="1"]{transition-delay:.07s}
[data-reveal-delay="2"]{transition-delay:.14s}
[data-reveal-delay="3"]{transition-delay:.21s}
[data-reveal-delay="4"]{transition-delay:.28s}
[data-reveal-delay="5"]{transition-delay:.35s}

/* ===================================================================
   Responsive — Tablet
   =================================================================== */
@media (min-width:680px){
  .benefit-grid{grid-template-columns:repeat(3,1fr);gap:1rem}
  .trust-grid{grid-template-columns:repeat(3,1fr)}
  .pcard{flex-basis:46%}
  .step{flex-basis:38%}
  .sec-hint{display:flex}
  .cta-band-inner{grid-template-columns:1.4fr .9fr;align-items:center}
  .cta-band-action{align-items:flex-end;text-align:right}
  .contact-wrap{grid-template-columns:1fr 1fr;align-items:start}
  .footer-inner{grid-template-columns:2fr 1fr 1.3fr}
  .hero-cta .btn{flex:0 0 auto}
}

/* ===================================================================
   Responsive — Desktop
   =================================================================== */
@media (min-width:1024px){
  :root{--header-h:74px}
  .nav-desktop{display:flex}
  .menu-toggle{display:none}
  .brand-logo{height:46px}
  .hero{min-height:88svh}
  .hero-card{max-width:600px;padding:2.6rem 2.8rem}
  .hero-chip{display:flex}
  .benefit-grid{grid-template-columns:repeat(6,1fr)}
  .bcard{padding:1.3rem 1.15rem}
  .pcard{flex-basis:31%;max-width:340px}
  .step{flex-basis:21%}
  .carousel-btns{gap:.6rem}
  .section{padding-block:clamp(4rem,6vw,6.5rem)}
  .testi{padding:2rem 2rem}
  .testi blockquote{font-size:1.12rem}
}

@media (min-width:1024px) and (hover:hover){
  /* Slightly larger product peek already handled */
}

/* ---------- Reduced motion ---------- */
@media (prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.001ms !important;animation-iteration-count:1 !important;transition-duration:.001ms !important;scroll-behavior:auto !important}
  [data-reveal]{opacity:1;transform:none}
  .marquee-track{animation:none}
  .fab-pulse{display:none}
}
