/* ====================================================================
   LANDING DE CATEGORÍA — bloques de diseño (Expositores)
   Portado desde la maqueta. Usa las variables de gsj-global.
   ==================================================================== */
:root{--paper:#f4f6f3;--mint:#e8f5ec;--cream:#f7f5ee;--lavanda:#eeecf8;--peach:#fdf0ea;--sky:#e8f1f8}

/* ====================================================================
   UTILIDADES
   ==================================================================== */
.wrap{max-width:1400px;margin:0 auto;padding:0 28px}
.eyebrow{font-size:12px;font-weight:700;letter-spacing:.16em;text-transform:uppercase;color:var(--g);display:inline-block}
.btn-primary{
  display:inline-flex;align-items:center;gap:8px;
  background:var(--g);color:#fff;
  border-radius:999px;padding:14px 26px;font-size:15px;font-weight:600;
  transition:.15s;
}
.btn-primary:hover{background:var(--gd)}
.btn-outline{
  display:inline-flex;align-items:center;gap:8px;
  border:1.5px solid var(--ink);color:var(--ink);
  border-radius:999px;padding:13px 24px;font-size:15px;font-weight:600;
  transition:.15s;
}
.btn-outline:hover{background:var(--ink);color:#fff}

/* ====================================================================
   SECCIÓN 1 · HERO
   ==================================================================== */
.hero{background:#fff;position:relative;overflow:hidden;padding-top:34px}
.hero__in{position:relative;z-index:2;max-width:1400px;margin:0 auto;padding:clamp(40px,5vw,84px) 28px;min-height:clamp(440px,40vw,560px);display:flex;align-items:center}
/* breadcrumb */
.crumb{font-size:13px;color:var(--mut);font-weight:600;display:flex;gap:8px;flex-wrap:wrap;align-items:center;margin-bottom:18px}
.crumb span{color:#c4c4bd}

.hero__eyebrow{font-size:14px;font-weight:700;color:var(--g);margin-bottom:10px;letter-spacing:.04em}
.hero__h{
  font-size:clamp(36px,4.4vw,58px);font-weight:300;
  letter-spacing:-.03em;line-height:1.02;margin:0 0 8px;
}
.hero__h strong{font-weight:700;color:var(--ink)}
.hero__p{
  font-size:clamp(16px,1.4vw,19px);color:var(--mut);font-weight:500;
  line-height:1.65;max-width:520px;margin:20px 0 36px;
}
.hero__ctas{display:flex;gap:14px;flex-wrap:wrap;align-items:center;margin-bottom:36px}
/* Pills de prueba */
.hero__proofs{display:flex;flex-wrap:nowrap;gap:8px;margin-top:4px}
.hero__proof{display:inline-flex;align-items:center;gap:6px;border:1px solid var(--line);border-radius:999px;padding:6px 12px 6px 6px;font-size:12.5px;font-weight:600;background:#fff;white-space:nowrap}
.hero__proof-ic{width:24px;height:24px;border-radius:50%;background:var(--mint);display:flex;align-items:center;justify-content:center;flex:none}
.hero__proof-ic svg{width:12px;height:12px;color:var(--g)}
/* Media / silueta */
.hero__text{max-width:600px}
.hero__halo{
  position:absolute;width:min(480px,92%);aspect-ratio:1;border-radius:50%;
  top:50%;left:50%;transform:translate(-50%,-50%);
  background:radial-gradient(circle at 40% 36%,#d4ece0,#d4ece0 40%,transparent 68%);
  z-index:0;
}
.hero__img{width:100%;height:100%;object-fit:cover;object-position:center}
/* Pills flotantes sobre la silueta */
.hero__float{
  position:absolute;z-index:2;display:flex;flex-direction:column;gap:7px;align-items:center;text-align:center;
  background:rgba(255,255,255,.88);backdrop-filter:blur(10px);
  border:1px solid rgba(255,255,255,.9);border-radius:16px;padding:14px 16px;
  box-shadow:0 12px 28px rgba(0,0,0,.14);max-width:160px;
  animation:heroFloat 5.5s ease-in-out infinite;
}
.hero__float-ic{width:40px;height:40px;border-radius:10px;background:var(--mint);display:flex;align-items:center;justify-content:center;flex:none}
.hero__float-ic svg{width:20px;height:20px;color:var(--g)}
.hero__float-t{font-size:13px;font-weight:700;color:var(--ink);line-height:1.2}
.hero__float--a{top:6%;left:-4%;animation-delay:0s}
.hero__float--b{top:40%;right:-5%;animation-delay:1s}
.hero__float--c{bottom:6%;left:2%;animation-delay:2s}
@keyframes heroFloat{0%,100%{transform:translateY(0)}50%{transform:translateY(-8px)}}
@media(prefers-reduced-motion:reduce){.hero__float{animation:none}}

@media(max-width:960px){
  .hero__in{grid-template-columns:1fr;gap:36px;padding:44px 28px 56px}
  .hero__media{min-height:340px}
  .hero__float--b{right:0}
}

/* ====================================================================
   SECCIÓN 2 · SUBCATEGORÍAS
   ==================================================================== */
.subcat-sec{background:var(--paper);border-top:1px solid var(--line);padding:64px 0}
.subcat-sec__head{margin-bottom:36px}
.subcat-sec__h{font-size:clamp(26px,3vw,38px);margin-top:10px}
.subcat-grid{
  display:grid;grid-template-columns:repeat(5,1fr);gap:16px;
}
.subcat-card{
  position:relative;border-radius:20px;overflow:hidden;
  background:#fff;border:1px solid var(--line);
  display:flex;flex-direction:column;
  transition:transform .2s,box-shadow .2s;
}
.subcat-card:hover{transform:translateY(-5px);box-shadow:0 18px 40px rgba(0,0,0,.1)}
.subcat-card__vis{
  aspect-ratio:1;overflow:hidden;background:#f3f2ee;
  display:flex;align-items:center;justify-content:center;
}
.subcat-card__vis img{width:100%;height:100%;object-fit:cover;transition:.4s}
.subcat-card:hover .subcat-card__vis img{transform:scale(1.06)}
/* Placeholder cuando no hay imagen */
.subcat-card__icon{
  width:64px;height:64px;background:var(--mint);border-radius:16px;
  display:flex;align-items:center;justify-content:center;
}
.subcat-card__icon svg{width:32px;height:32px;color:var(--g)}
.subcat-card__b{padding:16px 18px 20px;flex:1;display:flex;flex-direction:column;gap:6px}
.subcat-card__t{font-size:15px;font-weight:700;line-height:1.25;color:var(--ink)}
.subcat-card__p{font-size:13px;color:var(--mut);line-height:1.5;flex:1}
.subcat-card__link{
  display:inline-flex;align-items:center;gap:4px;font-size:13px;font-weight:700;color:var(--g);margin-top:8px;
}
.subcat-card__link svg{width:14px;height:14px;transition:transform .15s}
.subcat-card:hover .subcat-card__link svg{transform:translateX(3px)}

@media(max-width:1100px){.subcat-grid{grid-template-columns:repeat(3,1fr)}}
@media(max-width:700px){.subcat-grid{grid-template-columns:repeat(2,1fr);gap:12px}}
@media(max-width:440px){.subcat-grid{grid-template-columns:1fr}}

/* ====================================================================
   SECCIÓN 3 · BLOQUE SEO
   ==================================================================== */
.seo-block{background:#fff;padding:80px 0}
.seo-block__lead{
  display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(36px,5vw,72px);
  align-items:center;margin-bottom:72px;
}
.seo-block__h{font-size:clamp(28px,3.2vw,44px);line-height:1.05;margin:14px 0 20px}
.seo-block__p{font-size:clamp(16px,1.35vw,18px);color:var(--mut);line-height:1.65}
.seo-block__p strong{color:var(--ink);font-weight:700}
/* Pills de confianza */
.trust-pills{display:flex;flex-direction:column;gap:16px}
.trust-pill{
  display:flex;align-items:flex-start;gap:14px;
  background:var(--paper);border-radius:16px;padding:18px 20px;
}
.trust-pill__ic{
  width:44px;height:44px;border-radius:12px;background:var(--mint);
  display:flex;align-items:center;justify-content:center;flex:none;
}
.trust-pill__ic svg{width:22px;height:22px;color:var(--g)}
.trust-pill__t{font-size:15px;font-weight:700;color:var(--ink);margin-bottom:3px}
.trust-pill__p{font-size:13.5px;color:var(--mut);line-height:1.5}
/* Ventajas grid */
.seo-block__motivos-h{font-size:clamp(22px,2.5vw,32px);margin-bottom:32px}
.motivos-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:28px 36px}
.motivo{padding-left:18px;border-left:3px solid var(--g)}
.motivo__t{font-size:clamp(16px,1.5vw,18px);font-weight:700;color:var(--ink);margin-bottom:6px}
.motivo__p{font-size:15px;color:var(--mut);line-height:1.55}

@media(max-width:860px){
  .seo-block__lead{grid-template-columns:1fr;gap:28px}
  .motivos-grid{grid-template-columns:1fr 1fr}
}
@media(max-width:560px){.motivos-grid{grid-template-columns:1fr}}

/* ====================================================================
   SECCIÓN 4 · LONG-FORM
   ==================================================================== */
.longform{border-top:1px solid var(--line)}

/* Lead intro */
.lf-intro-wrap{max-width:820px;margin:0 auto;padding:72px 28px 56px}
.lf-lead__intro{font-size:clamp(18px,1.9vw,22px);font-weight:500;color:var(--ink);line-height:1.55;margin-bottom:18px}
.lf-lead__p{font-size:16.5px;color:var(--mut);line-height:1.75;margin-bottom:14px}
.lf-lead__p strong{color:var(--ink);font-weight:600}

/* Secciones con fondo pastel */
.lf-sec{padding:clamp(56px,6vw,80px) 28px}
.lf-sec--mint{background:#e8f5ec}
.lf-sec--cream{background:#f7f5ee}
.lf-sec--lavanda{background:#eeecf8}
.lf-sec--peach{background:#fdf0ea}
.lf-sec--white{background:#fff;border:none}
.lf-sec__in{max-width:1100px;margin:0 auto}
.lf-sec__prose{max-width:820px;margin:0 auto}
.lf-h{font-size:clamp(24px,2.8vw,34px);font-weight:600;letter-spacing:-.02em;line-height:1.08;color:var(--ink);margin-bottom:32px}
.lf-sec__sub{font-size:16.5px;color:var(--mut);line-height:1.65;margin:-12px 0 30px;max-width:64ch}

/* Tarjetas de formatos */
.lf-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.lf-card{
  display:flex;flex-direction:column;gap:10px;
  background:#fff;border-radius:20px;padding:28px 24px 24px;
  box-shadow:0 4px 18px rgba(0,0,0,.06);
}
.lf-card__ic{
  width:44px;height:44px;border-radius:12px;background:var(--mint);
  display:flex;align-items:center;justify-content:center;flex:none;
}
.lf-card__ic svg{width:22px;height:22px;color:var(--g)}
.lf-card__t{font-size:17px;font-weight:700;color:var(--ink);letter-spacing:-.01em;line-height:1.25}
.lf-card__p{font-size:15px;color:var(--mut);line-height:1.6;flex:1}
.lf-card__when{
  font-size:13.5px;color:var(--ink);background:#f0f8f3;
  border-left:3px solid var(--g);border-radius:0 8px 8px 0;
  padding:8px 12px;line-height:1.5;
}
.lf-card__when strong{font-weight:700;color:var(--g)}

/* Tabla de materiales */
.lf-tablewrap{max-width:820px;margin:24px auto 0;overflow-x:auto;-webkit-overflow-scrolling:touch}
.lf-tablewrap table{width:100%;border-collapse:collapse;font-size:15px;min-width:480px}
.lf-tablewrap th,.lf-tablewrap td{border:1px solid var(--line);padding:12px 16px;text-align:left;vertical-align:top}
.lf-tablewrap th{font-weight:700;color:var(--ink);background:#f2f0e9}
.lf-tablewrap td{color:var(--mut)}
.lf-tablewrap td strong{color:var(--ink);font-weight:600}

/* Pasos de proceso */
.lf-steps{display:grid;grid-template-columns:repeat(4,1fr);gap:0}
.lf-step{padding:4px 28px;border-left:1px solid var(--line)}
.lf-step:first-child{padding-left:0;border-left:0}
.lf-step__n{display:block;font-size:clamp(42px,4vw,56px);font-weight:800;line-height:1;color:rgba(0,135,58,.22);letter-spacing:-.03em;margin-bottom:12px}
.lf-step__t{display:block;font-weight:700;font-size:17px;color:var(--ink);margin-bottom:6px}
.lf-step__p{display:block;font-size:14.5px;color:var(--mut);line-height:1.55}

/* Tarjetas de sectores */
.lf-sectors{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.lf-sector{
  background:#fff;border-radius:18px;padding:24px 22px;
  box-shadow:0 4px 16px rgba(0,0,0,.06);display:flex;flex-direction:column;gap:8px;
}
.lf-sector__ic{
  width:40px;height:40px;border-radius:10px;background:var(--peach);
  display:flex;align-items:center;justify-content:center;flex:none;
}
.lf-sector__ic svg{width:20px;height:20px;color:#c0552a}
.lf-sector__t{font-size:15px;font-weight:700;color:var(--ink);line-height:1.25}
.lf-sector__p{font-size:14px;color:var(--mut);line-height:1.55}

/* Features "por qué GSJ" */
.lf-feats{display:grid;grid-template-columns:repeat(3,1fr);gap:32px}
.lf-feat{display:flex;flex-direction:column;gap:8px}
.lf-feat__num{
  font-size:clamp(44px,5vw,64px);font-weight:800;line-height:1;
  color:rgba(0,135,58,.18);letter-spacing:-.04em;
}
.lf-feat__t{font-size:17px;font-weight:700;color:var(--ink);letter-spacing:-.01em}
.lf-feat__p{font-size:15px;color:var(--mut);line-height:1.6}

@media(max-width:860px){
  .lf-cards{grid-template-columns:1fr 1fr}
  .lf-steps{grid-template-columns:1fr 1fr;gap:20px}
  .lf-step{border-left:0;padding:0;border-top:1px solid var(--line);padding-top:20px}
  .lf-step:nth-child(-n+2){border-top:0;padding-top:0}
  .lf-feats{grid-template-columns:1fr}
}
@media(max-width:600px){
  .lf-cards{grid-template-columns:1fr}
  .lf-sectors{grid-template-columns:1fr 1fr}
  .lf-steps{grid-template-columns:1fr}
  .lf-step{border-top:1px solid var(--line);padding-top:20px}
  .lf-step:first-child{border-top:0;padding-top:0}
}
@media(max-width:440px){.lf-sectors{grid-template-columns:1fr}}

/* ====================================================================
   SECCIÓN 5 · PROYECTOS
   ==================================================================== */
.proyectos{border-top:1px solid var(--line);padding:80px 0;background:var(--sky)}
.proyectos__head{margin-bottom:32px}
.proyectos__h{font-size:clamp(28px,3.2vw,44px);margin-top:10px}
.proyectos__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.prj-card{display:block;color:inherit}
.prj-card__im{
  position:relative;aspect-ratio:4/3;border-radius:18px;overflow:hidden;background:#dce9e4;
  display:flex;align-items:center;justify-content:center;
}
.prj-card__im img{width:100%;height:100%;object-fit:cover;transition:.45s}
.prj-card:hover .prj-card__im img{transform:scale(1.05)}
.prj-card__placeholder{
  display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;
  width:100%;height:100%;
}
.prj-card__placeholder svg{width:48px;height:48px;color:var(--g);opacity:.4}
.prj-card__placeholder span{font-size:13px;font-weight:600;color:var(--mut);opacity:.7}
.prj-card__tag{position:absolute;top:12px;left:12px;background:#fff;color:var(--ink);font-weight:600;font-size:12px;padding:5px 12px;border-radius:999px}
.prj-card__t{font-size:17px;font-weight:600;line-height:1.3;margin-top:14px;color:var(--ink)}
.prj-card:hover .prj-card__t{color:var(--g)}
.prj-card__meta{font-size:13px;color:var(--mut);margin-top:5px;font-weight:500}

@media(max-width:900px){.proyectos__grid{grid-template-columns:1fr 1fr}}
@media(max-width:560px){.proyectos__grid{grid-template-columns:1fr}}

/* ====================================================================
   SECCIÓN 6 · FAQ
   ==================================================================== */
.faq{
  background:var(--ink);color:#fff;
  border-radius:clamp(28px,4vw,48px) clamp(28px,4vw,48px) 0 0;
  margin-top:0;
}
.faq__in{max-width:1100px;margin:0 auto;padding:clamp(58px,7vw,90px) clamp(24px,5vw,40px) clamp(84px,10vw,120px)}
.faq__h{font-size:clamp(26px,3vw,38px);font-weight:600;letter-spacing:-.02em;margin-bottom:32px;color:#fff}
.faq__item{border-bottom:1px solid rgba(255,255,255,.15)}
.faq__q{
  display:flex;align-items:center;justify-content:space-between;gap:16px;
  cursor:pointer;list-style:none;padding:22px 0;
  font-size:clamp(16px,1.5vw,18px);font-weight:600;color:#fff;
}
.faq__q::-webkit-details-marker{display:none}
.faq__ic{position:relative;width:18px;height:18px;flex:none}
.faq__ic::before,.faq__ic::after{content:"";position:absolute;background:var(--g);transition:.2s}
.faq__ic::before{top:8px;left:0;width:18px;height:2px}
.faq__ic::after{left:8px;top:0;width:2px;height:18px}
.faq__item[open] .faq__ic::after{transform:scaleY(0)}
.faq__a{padding:0 0 22px}
.faq__a p{font-size:16px;line-height:1.7;color:rgba(255,255,255,.78);margin:0}

/* ====================================================================
   SECCIÓN 7 · OPINIONES
   ==================================================================== */
.opiniones{background:#f4f6f2;padding:90px 28px}
.ops__in{max-width:1400px;margin:0 auto}
.ops__head{text-align:center;max-width:700px;margin:0 auto 44px}
.ops__eyebrow{display:inline-block;font-size:12px;font-weight:700;letter-spacing:.16em;text-transform:uppercase;color:var(--g)}
.ops__t{font-size:clamp(30px,3.8vw,50px);line-height:1.04;margin:12px 0 16px;color:var(--ink)}
.ops__rating{display:inline-flex;align-items:center;gap:8px;font-size:15px;color:var(--ink)}
.ops__rating strong{font-size:17px}
.ops__stars{color:#f5b50a;letter-spacing:1px}
.ops__rsub{color:var(--mut)}
.ops__marquee{position:relative;overflow:hidden;-webkit-mask:linear-gradient(90deg,transparent,#000 5%,#000 95%,transparent);mask:linear-gradient(90deg,transparent,#000 5%,#000 95%,transparent)}
.ops__track{display:flex;gap:22px;width:max-content;animation:opsScroll 50s linear infinite}
.ops__marquee:hover .ops__track{animation-play-state:paused}
@keyframes opsScroll{from{transform:translateX(0)}to{transform:translateX(-50%)}}
.opcard{flex:0 0 360px;width:360px;background:#fff;border:1px solid var(--line);border-radius:18px;padding:26px 24px}
.opcard__stars{color:#f5b50a;font-size:15px;letter-spacing:2px;margin-bottom:12px}
.opcard__txt{font-size:15px;line-height:1.6;color:#3a3a35;margin-bottom:20px}
.opcard__foot{display:flex;align-items:center;gap:12px}
.opcard__av{width:42px;height:42px;border-radius:50%;background:var(--g);color:#fff;display:inline-flex;align-items:center;justify-content:center;font-weight:700;font-size:16px;flex:none}
.opcard__name{font-weight:600;color:var(--ink);font-size:14px}
.opcard__sub{display:flex;align-items:center;gap:6px;color:var(--mut);font-size:12.5px;margin-top:2px}
@media(prefers-reduced-motion:reduce){.ops__track{animation:none;flex-wrap:wrap;justify-content:center;width:auto}}
@media(max-width:600px){.opcard{flex-basis:300px;width:300px}}

/* ====================================================================
   SECCIÓN 8 · DEL BLOG
   ==================================================================== */
.blog-sec{background:var(--lavanda);padding:90px 28px}
.blog-sec__in{max-width:1200px;margin:0 auto}
.blog-sec__head{display:flex;justify-content:space-between;align-items:flex-end;gap:20px;margin-bottom:36px}
.blog-sec__ey{font-size:12px;font-weight:700;letter-spacing:.16em;text-transform:uppercase;color:var(--g);display:inline-block}
.blog-sec__h{font-size:clamp(28px,3.4vw,46px);line-height:1.04;margin-top:10px;color:var(--ink)}
.blog-sec__link{font-weight:600;color:var(--g);white-space:nowrap}
.blog-sec__link:hover{text-decoration:underline}
.blog-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.blog-card{display:flex;flex-direction:column;background:#fff;border:1px solid var(--line);border-radius:18px;overflow:hidden;transition:transform .2s,box-shadow .2s}
.blog-card:hover{transform:translateY(-4px);box-shadow:0 16px 34px rgba(0,0,0,.1)}
.blog-card__im{aspect-ratio:16/10;overflow:hidden;background:#dddaf0;display:flex;align-items:center;justify-content:center}
.blog-card__im svg{width:48px;height:48px;color:#9e9ac8;opacity:.5}
.blog-card__b{padding:22px 22px 26px;display:flex;flex-direction:column;gap:10px}
.blog-card__cat{font-size:11px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--g)}
.blog-card__t{font-size:17px;line-height:1.3;color:var(--ink);font-weight:600}
.blog-card:hover .blog-card__t{color:var(--g)}
.blog-card__p{font-size:14.5px;line-height:1.55;color:var(--mut);margin:0}
.blog-card__date{font-size:12.5px;color:var(--mut);font-weight:500}

@media(max-width:880px){.blog-grid{grid-template-columns:1fr}.blog-sec{padding:64px 22px}.blog-sec__head{flex-direction:column;align-items:flex-start;gap:8px}}

/* ====================================================================
   SECCIÓN 9 · VÍDEOS
   ==================================================================== */
.videos-sec{background:#fff;padding:80px 28px 88px;border-top:1px solid var(--line)}
.videos-sec__head{max-width:1400px;margin:0 auto 24px;display:flex;justify-content:space-between;align-items:flex-end;gap:20px}
.videos-sec__ey{font-size:12px;font-weight:700;letter-spacing:.16em;text-transform:uppercase;color:var(--g);display:inline-block}
.videos-sec__h{font-size:clamp(28px,3.4vw,46px);line-height:1.04;margin-top:10px;color:var(--ink)}
.videos-sec__link{font-weight:600;color:var(--g);white-space:nowrap}
.videos-sec__link:hover{text-decoration:underline}
.videos-row{
  display:flex;gap:16px;overflow-x:auto;scroll-snap-type:x mandatory;scroll-behavior:smooth;
  max-width:1400px;margin:0 auto;padding:8px 0 16px;scrollbar-width:none;
}
.videos-row::-webkit-scrollbar{display:none}
.vcard{flex:0 0 calc((100% - 32px)/3);scroll-snap-align:start;cursor:pointer}
.vcard__thumb{
  position:relative;display:block;aspect-ratio:16/9;border-radius:16px;overflow:hidden;
  background:#e8e6de;display:flex;align-items:center;justify-content:center;
  transition:transform .3s,box-shadow .3s;
}
.vcard:hover .vcard__thumb{transform:scale(1.02);box-shadow:0 14px 30px rgba(0,0,0,.16)}
.vcard__thumb-bg{position:absolute;inset:0;display:flex;align-items:center;justify-content:center}
.vcard__thumb-bg svg{width:56px;height:56px;color:var(--ink);opacity:.2}
.vcard__play{
  position:absolute;width:60px;height:60px;border-radius:50%;
  background:rgba(255,255,255,.88);display:flex;align-items:center;justify-content:center;
  box-shadow:0 4px 16px rgba(0,0,0,.2);transition:.2s;z-index:1;
}
.vcard:hover .vcard__play{background:var(--g)}
.vcard__play svg{width:22px;height:22px;color:var(--ink);margin-left:3px;transition:.15s}
.vcard:hover .vcard__play svg{color:#fff}
.vcard__t{font-size:14.5px;font-weight:600;margin-top:12px;line-height:1.3;color:var(--ink)}
.vcard__ch{font-size:13px;color:var(--mut);margin-top:4px}

@media(max-width:760px){.vcard{flex:0 0 80%}}
@media(max-width:480px){.vcard{flex:0 0 90%}}

/* ====================================================================
   SECCIÓN 10 · CTA FINAL CON FORMULARIO
   ==================================================================== */
.cta-sec{
  background:var(--gd);color:#fff;
  border-radius:clamp(28px,4vw,48px) clamp(28px,4vw,48px) 0 0;
  scroll-margin-top:90px;
}
.cta-sec__in{
  max-width:1400px;margin:0 auto;
  padding:clamp(56px,6vw,88px) clamp(24px,5vw,40px);
  display:grid;grid-template-columns:1fr 1.05fr;gap:64px;align-items:center;
}
.cta-sec__ey{font-size:12px;font-weight:700;letter-spacing:.16em;text-transform:uppercase;color:rgba(255,255,255,.7)}
.cta-sec__h{font-size:clamp(30px,3.8vw,50px);font-weight:300;letter-spacing:-.025em;line-height:1.04;margin:12px 0 16px}
.cta-sec__h strong{font-weight:700}
.cta-sec__p{color:rgba(255,255,255,.85);font-size:17px;line-height:1.65;max-width:460px;margin-bottom:32px}
.cta-sec__wa{
  display:inline-flex;align-items:center;gap:9px;font-weight:600;font-size:15px;color:#fff;
  background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.25);
  border-radius:999px;padding:12px 20px;transition:.15s;
}
.cta-sec__wa:hover{background:rgba(255,255,255,.22)}
.cta-sec__wa svg{width:20px;height:20px;flex:none}
/* Formulario */
.cta-form{background:#fff;color:var(--ink);border-radius:24px;padding:36px;box-shadow:0 30px 70px rgba(0,0,0,.25)}
.cta-form__title{font-size:20px;font-weight:700;color:var(--ink);margin-bottom:24px}
.cta-form__row{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-bottom:14px}
.cta-form__field{margin-bottom:14px}
.cta-form__label{display:block;font-size:13px;font-weight:600;color:var(--ink);margin-bottom:6px}
.cta-form__input,
.cta-form__textarea{
  width:100%;border:1px solid transparent;border-radius:12px;padding:13px 15px;
  font-family:inherit;font-size:15px;line-height:1.4;
  background:#f6f6f3;color:var(--ink);outline:none;transition:.15s;
}
.cta-form__input:focus,.cta-form__textarea:focus{border-color:var(--g);background:#fff;box-shadow:0 0 0 3px rgba(0,135,58,.1)}
.cta-form__textarea{resize:vertical;min-height:100px}
.cta-form__legal{font-size:12px;color:var(--mut);line-height:1.5;margin-bottom:18px}
.cta-form__legal a{color:var(--g);text-decoration:underline}
.cta-form__submit{
  width:100%;background:var(--g);color:#fff;border-radius:999px;
  padding:16px;font-size:16px;font-weight:600;font-family:inherit;
  cursor:pointer;border:0;transition:.15s;
}
.cta-form__submit:hover{background:var(--gd)}

@media(max-width:860px){
  .cta-sec__in{grid-template-columns:1fr;gap:32px;padding:56px 24px}
  .cta-form__row{grid-template-columns:1fr}
}
@media(max-width:460px){.cta-form{padding:24px 20px}}

.mockup-footer{
  background:var(--ink);color:rgba(255,255,255,.5);
  padding:32px 28px;text-align:center;font-size:13px;font-weight:500;
}

/* ajustes lienzo: chrome real arriba, sin barra de maqueta */

body{overflow-x:clip}
.screen-reader-text{position:absolute!important;width:1px!important;height:1px!important;padding:0!important;margin:-1px!important;overflow:hidden!important;clip:rect(0 0 0 0)!important;white-space:nowrap!important;border:0!important}
.lz-band{background:linear-gradient(180deg,#fbfdfb 0%,#edf6f0 100%);padding:clamp(64px,7vw,104px) 0}
.lz-band .catx{background:transparent}
.lz-band .catnav{background:transparent}

/* Ver todos — card verde de marca (número dinámico) */
.pcard--more{position:relative;display:flex;flex-direction:column;justify-content:center;border-radius:16px;text-decoration:none;background:linear-gradient(158deg,#00a046,#006b2e);color:#fff;padding:24px 22px;min-height:clamp(240px,27vw,292px);align-self:stretch;overflow:hidden;transition:transform .2s,box-shadow .2s}
.pcard--more::after{content:"";position:absolute;right:-46px;bottom:-46px;width:150px;height:150px;border-radius:50%;border:18px solid rgba(255,255,255,.08)}
.pcard--more:hover{transform:translateY(-3px);box-shadow:0 16px 34px rgba(0,107,46,.32)}
.pcard--more__c{position:relative;z-index:1;display:flex;flex-direction:column}
.pcard--more__count{font-size:clamp(40px,4.4vw,56px);font-weight:300;letter-spacing:-.03em;line-height:1}
.pcard--more__lbl{font-size:13px;color:rgba(255,255,255,.85);font-weight:500;margin-top:6px;line-height:1.3}
.pcard--more__lbl b{display:block;font-size:15px;font-weight:700;color:#fff}
.pcard--more__cta{margin-top:18px;display:inline-flex;align-items:center;gap:8px;font-weight:700;font-size:14px;color:#fff}
.pcard--more__cta svg{width:17px;height:17px;transition:transform .25s}
.pcard--more:hover .pcard--more__cta svg{transform:translateX(5px)}
/* Menú: imágenes más pequeñas y pegadas a la derecha */
.lz-band .catnav a[href*="/escaparate/"] .acc__b-img,.lz-band .catnav a[href*="/grandes-superficies/"] .acc__b-img{width:36%!important;height:92%!important;right:0!important;bottom:0!important;object-position:right bottom!important}

.lz-pitch{background:#fff;padding:clamp(30px,3.5vw,50px) 28px}
.lz-pitch__in{max-width:780px;margin:0 auto;text-align:center}
/* Copy comercial central tras el hero (texto centrado) */
.lz-pitch{background:#fff;padding:clamp(30px,3.5vw,50px) 28px}
.lz-pitch__in{max-width:740px;margin:0 auto;text-align:center}
.lz-pitch__lead{font-size:clamp(19px,1.9vw,25px);line-height:1.6;color:var(--ink);font-weight:500;letter-spacing:-.01em}
.lz-pitch__lead em{font-style:normal;font-weight:700;color:var(--g)}
/* Bloque-puente formatos (cabecera centrada) */
.lz-bridge__in{max-width:1400px;margin:0 auto;padding:0 28px clamp(28px,3.2vw,44px);text-align:center}
.lz-bridge__ey{display:inline-block;font-size:12px;font-weight:800;letter-spacing:.14em;text-transform:uppercase;color:var(--g)}
.lz-bridge__h{font-size:clamp(28px,3.4vw,44px);font-weight:600;letter-spacing:-.02em;line-height:1.08;margin:12px 0 0;color:var(--ink)}
.lz-bridge__line{display:block;width:54px;height:3px;background:var(--g);border-radius:2px;margin:18px auto 14px}
.lz-bridge__p{color:var(--mut);font-weight:500;max-width:560px;margin:0 auto;font-size:clamp(15px,1.3vw,18px);line-height:1.6}
.seo{border-top:none!important}
/* Bloque fabricantes (imagen a sangre + panel) */
.lz-fab{position:relative;background:#fff;min-height:clamp(600px,48vw,720px);display:flex;align-items:center;overflow:hidden}
.lz-fab__img{position:absolute;right:0;top:0;bottom:0;width:56%;overflow:hidden}
.lz-fab__img img{width:100%;height:100%;object-fit:cover;object-position:center}

.lz-fab__panel{position:relative;z-index:2;max-width:1400px;margin:0 auto;padding:clamp(48px,6vw,90px) 28px;width:100%}
.lz-fab__box{max-width:520px}
.lz-fab__h{font-size:clamp(28px,3.4vw,46px);font-weight:300;letter-spacing:-.025em;line-height:1.05;color:var(--ink);margin:0}
.lz-fab__h b{font-weight:700}
.lz-fab__p{font-size:clamp(16px,1.35vw,18.5px);line-height:1.65;color:var(--mut);font-weight:500;margin:20px 0 0}
.lz-fab__proofs{display:flex;flex-wrap:wrap;gap:10px;margin-top:26px}
.lz-fab__proof{display:inline-flex;align-items:center;gap:8px;background:#fff;border:1px solid var(--line);border-radius:999px;padding:9px 16px 9px 10px;font-size:13.5px;font-weight:700}
.lz-fab__proof .ic{width:28px;height:28px;border-radius:50%;background:#e8f5ec;display:flex;align-items:center;justify-content:center;color:var(--g)}
.lz-fab__proof svg{width:15px;height:15px}
@media(max-width:900px){.lz-fab{display:block;min-height:0}.lz-fab__img{position:relative;width:100%;height:300px}.lz-fab__panel{padding:32px 28px}}
.hero__scene{position:absolute;right:0;top:0;bottom:0;width:54%;z-index:1}
.hero__scene::after{content:"";position:absolute;inset:0;background:linear-gradient(90deg,#fff 0%,#fff 4%,rgba(255,255,255,0) 40%)}
/* Capacidades del bloque fabricantes */
.lz-cap{list-style:none;margin:24px 0 0;padding:0;display:grid;gap:14px}
.lz-cap li{display:flex;gap:12px;align-items:flex-start;font-size:15px;color:var(--mut);line-height:1.45}
.lz-cap b{color:var(--ink);font-weight:700}
.lz-cap__ic{flex:none;width:34px;height:34px;border-radius:9px;background:#e8f5ec;display:flex;align-items:center;justify-content:center;color:var(--g)}
.lz-cap__ic svg{width:18px;height:18px}
.lz-fab__cta{display:inline-flex;align-items:center;gap:8px;margin-top:28px;background:var(--g);color:#fff;font-weight:700;padding:13px 24px;border-radius:999px;font-size:15px;text-decoration:none}
.lz-fab__cta:hover{background:var(--gd)}
.lz-fab__cta svg{width:16px;height:16px}
/* Capacidades superpuestas animadas */
.lz-fab__caps{position:absolute;inset:0;z-index:3;pointer-events:none}
.lz-fcap{position:absolute;display:inline-flex;align-items:center;gap:10px;background:rgba(18,20,14,.34);-webkit-backdrop-filter:blur(16px) saturate(140%);backdrop-filter:blur(16px) saturate(140%);border:1px solid rgba(255,255,255,.22);border-radius:14px;padding:12px 17px 12px 13px;font-size:14.5px;font-weight:700;color:#fff;box-shadow:0 16px 34px rgba(0,0,0,.32);white-space:nowrap;opacity:0}
.lz-fab__caps.in .lz-fcap{animation:fcapIn .6s cubic-bezier(.22,1,.36,1) forwards, fcapFloat 5.5s ease-in-out infinite}
.lz-fcap__ic{width:34px;height:34px;border-radius:9px;background:var(--g);display:flex;align-items:center;justify-content:center;color:#fff;flex:none}
.lz-fcap__ic svg{width:18px;height:18px}
.lz-fcap--1{top:11%;left:21%;animation-delay:.25s,1.6s}
.lz-fcap--2{top:39%;right:17%;animation-delay:.5s,1.9s}
.lz-fcap--3{bottom:31%;left:17%;animation-delay:.75s,2.2s}
.lz-fcap--4{bottom:11%;right:21%;animation-delay:1s,2.5s}
@keyframes fcapIn{from{opacity:0;transform:translateY(16px) scale(.96)}to{opacity:1;transform:translateY(0) scale(1)}}
@keyframes fcapFloat{0%,100%{transform:translateY(0)}50%{transform:translateY(-7px)}}
@media(prefers-reduced-motion:reduce){.lz-fcap{animation:none;opacity:1}}
@media(max-width:900px){.lz-fcap{font-size:12px;padding:8px 12px 8px 9px}.lz-fcap--2,.lz-fcap--4{right:3%}.lz-fcap--1,.lz-fcap--3{left:3%}}
/* Bloque madera (imagen izquierda + texto derecha) */
.lz-wood{background:#faf7f1;position:relative;min-height:clamp(640px,52vw,780px);display:flex;align-items:center;overflow:hidden}
.lz-wood__panel{position:relative;z-index:2;max-width:1400px;margin:0 auto;padding:clamp(48px,6vw,90px) 28px;width:100%}
.lz-wood__img{position:absolute;left:0;top:0;bottom:0;width:56%;overflow:hidden}
.lz-wood__img img{width:100%;height:100%;object-fit:cover}
.lz-wood__box{max-width:520px;margin-left:auto}
.lz-wood__ey{display:inline-block;font-size:12px;font-weight:800;letter-spacing:.14em;text-transform:uppercase;color:var(--g)}
.lz-wood__h{font-size:clamp(28px,3.4vw,46px);font-weight:300;letter-spacing:-.025em;line-height:1.06;color:var(--ink);margin:12px 0 0}
.lz-wood__h b{font-weight:700}
.lz-wood__p{font-size:clamp(16px,1.35vw,18.5px);line-height:1.65;color:var(--mut);font-weight:500;margin:18px 0 0}
.lz-wood__cta{display:inline-flex;align-items:center;gap:8px;margin-top:26px;background:var(--ink);color:#fff;font-weight:700;padding:13px 24px;border-radius:999px;font-size:15px;text-decoration:none}
.lz-wood__cta:hover{background:#000}
.lz-wood__cta svg{width:16px;height:16px}
@media(max-width:900px){.lz-wood{display:block;min-height:0}.lz-wood__img{position:relative;width:100%;height:300px;border-radius:0}.lz-wood__panel{padding:32px 28px}}
.lz-fab__ey{display:inline-block;font-size:12px;font-weight:800;letter-spacing:.14em;text-transform:uppercase;color:var(--g);margin-bottom:12px}
.lz-fab__h + .lz-fab__p{margin-top:18px}
.lz-pitch__h2{font-size:clamp(26px,3vw,40px);font-weight:300;letter-spacing:-.02em;line-height:1.12;color:var(--ink);margin:0 0 16px}
.lz-pitch__h2 em{font-style:normal;font-weight:600;color:var(--g)}
/* Mini bloque proceso */
.lz-proc{background:var(--ink);color:#fff;padding:clamp(50px,6vw,84px) 0}
.lz-proc__in{max-width:1400px;margin:0 auto;padding:0 28px}
.lz-proc__ey{display:inline-block;font-size:12px;font-weight:800;letter-spacing:.14em;text-transform:uppercase;color:#8fe3ad}
.lz-proc__h{font-size:clamp(24px,2.8vw,38px);font-weight:300;letter-spacing:-.02em;line-height:1.1;color:#fff;margin:12px 0 0;max-width:18ch}
.lz-proc__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(24px,3vw,48px);margin-top:clamp(30px,4vw,48px)}
.lz-proc__step .n{display:block;font-size:36px;font-weight:300;color:#8fe3ad;letter-spacing:-.02em;line-height:1}
.lz-proc__step h3{font-size:18px;font-weight:700;margin:12px 0 8px;color:#fff}
.lz-proc__step p{font-size:14.5px;line-height:1.6;color:rgba(255,255,255,.78)}
@media(max-width:760px){.lz-proc__grid{grid-template-columns:1fr;gap:26px}}
/* Sectores — carrusel fotográfico */
.lz-sec{padding:clamp(50px,6vw,84px) 0;background:#fff}
.lz-sec__head{max-width:1400px;margin:0 auto;padding:0 28px;display:flex;justify-content:space-between;align-items:flex-end;gap:20px;margin-bottom:28px}
.lz-sec__ey{display:inline-block;font-size:12px;font-weight:800;letter-spacing:.14em;text-transform:uppercase;color:var(--g)}
.lz-sec__h{font-size:clamp(26px,3.2vw,42px);font-weight:300;letter-spacing:-.02em;line-height:1.08;margin:10px 0 0;color:var(--ink)}
.lz-sec__p{color:var(--mut);font-weight:500;margin:10px 0 0;max-width:46ch}
.lz-sec__nav{display:flex;gap:10px;flex:none}
.lz-sec__btn{width:46px;height:46px;border-radius:50%;border:1px solid var(--line);background:#fff;color:var(--ink);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:.15s}
.lz-sec__btn:hover{background:var(--g);color:#fff;border-color:var(--g)}
.lz-sec__btn svg{width:20px;height:20px}
.lz-sec__track{display:flex;gap:18px;overflow-x:auto;scroll-snap-type:x mandatory;scroll-padding-inline:28px;-webkit-overflow-scrolling:touch;max-width:1400px;margin:0 auto;padding:4px 28px 8px;scrollbar-width:none}
.lz-sec__track::-webkit-scrollbar{display:none}
.lz-seccard{position:relative;flex:0 0 clamp(260px,26vw,330px);aspect-ratio:3/4;border-radius:20px;overflow:hidden;background-size:cover;background-position:center;scroll-snap-align:start;background-color:#e9ebe7}
.lz-seccard::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(0,0,0,.05) 0%,rgba(0,0,0,0) 35%,rgba(0,0,0,.72) 100%)}
.lz-seccard__chip{position:absolute;top:14px;left:14px;z-index:2;background:rgba(16,17,12,.4);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border:1px solid rgba(255,255,255,.25);color:#fff;font-size:13px;font-weight:700;padding:8px 14px;border-radius:999px}
.lz-seccard__cap{position:absolute;left:0;right:0;bottom:0;z-index:2;padding:18px 18px 20px;color:#fff}
.lz-seccard__cap p{font-size:14px;line-height:1.45;font-weight:500;color:rgba(255,255,255,.95)}
.lz-seccard__soon{display:inline-block;margin-top:8px;font-size:11px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:#fff;background:rgba(255,255,255,.18);padding:4px 9px;border-radius:6px}
.lz-seccard--ph::after{background:linear-gradient(180deg,rgba(0,0,0,0) 40%,rgba(0,0,0,.5) 100%)}
.lz-seccard--calzado{background-color:#e7eef3}.lz-seccard--cosmetica{background-color:#f5ecf2}.lz-seccard--optica{background-color:#eef2ec}.lz-seccard--textil{background-color:#f3efe7}
@media(max-width:760px){.lz-sec__head{flex-direction:column;align-items:flex-start}.lz-sec__nav{display:none}}
/* Antes/después marca */
@property --pos{syntax:"<percentage>";inherits:false;initial-value:50%}
.ba{position:absolute;inset:0;overflow:hidden;--pos:50%}
.ba:hover{animation-play-state:paused}
@keyframes baSweep{0%{--pos:14%}50%{--pos:86%}100%{--pos:14%}}
.ba img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;-webkit-user-drag:none;user-select:none}
.ba__top{clip-path:inset(0 50% 0 0);animation:baTop 8s ease-in-out infinite}
.ba__line{position:absolute;top:0;bottom:0;left:50%;animation:baMove 8s ease-in-out infinite;width:2px;background:#fff;box-shadow:0 0 0 1px rgba(0,0,0,.08);transform:translateX(-1px);pointer-events:none}
.ba__grab{position:absolute;top:50%;left:50%;animation:baMove 8s ease-in-out infinite;transform:translate(-50%,-50%);width:42px;height:42px;border-radius:50%;background:#fff;border:0;display:flex;align-items:center;justify-content:center;color:var(--ink);box-shadow:0 6px 18px rgba(0,0,0,.25);cursor:default}
.ba__grab svg{width:18px;height:18px}
.ba__lbl{position:absolute;top:16px;z-index:3;font-size:12px;font-weight:700;color:#fff;background:rgba(16,17,12,.45);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);padding:6px 12px;border-radius:999px;pointer-events:none}
.ba__lbl--l{left:16px}.ba__lbl--r{right:16px}
@keyframes baTop{0%,100%{clip-path:inset(0 88% 0 0)}50%{clip-path:inset(0 12% 0 0)}}
@keyframes baMove{0%,100%{left:12%}50%{left:88%}}
.ba:hover .ba__top,.ba:hover .ba__line,.ba:hover .ba__grab{animation-play-state:paused}
/* Proyectos */
.lz-proj{padding:clamp(50px,6vw,84px) 0;background:#fff}
.lz-proj__in{max-width:1400px;margin:0 auto;padding:0 28px}
.lz-proj__head{display:flex;justify-content:space-between;align-items:flex-end;gap:24px;margin-bottom:30px}
.lz-proj__ey{display:inline-block;font-size:12px;font-weight:800;letter-spacing:.14em;text-transform:uppercase;color:var(--g)}
.lz-proj__h{font-size:clamp(26px,3.2vw,42px);font-weight:300;letter-spacing:-.02em;line-height:1.08;margin:10px 0 0;color:var(--ink)}
.lz-proj__p{color:var(--mut);font-weight:500;margin:12px 0 0;max-width:54ch;line-height:1.6}
.lz-proj__all{flex:none;display:inline-flex;align-items:center;gap:8px;font-weight:700;font-size:15px;color:var(--g);white-space:nowrap}
.lz-proj__all svg{width:16px;height:16px;transition:transform .2s}.lz-proj__all:hover svg{transform:translateX(4px)}
.lz-proj__grid{display:grid;grid-template-columns:1fr 1fr;gap:24px}
.lz-projcard{display:block;color:inherit;text-decoration:none;border-radius:20px;overflow:hidden;border:1px solid var(--line);background:#fff;transition:transform .2s,box-shadow .2s}
.lz-projcard:hover{transform:translateY(-4px);box-shadow:0 22px 46px rgba(0,0,0,.1)}
.lz-projcard__im{aspect-ratio:16/10;overflow:hidden;background:#f3f2ee}
.lz-projcard__im img{width:100%;height:100%;object-fit:cover;transition:.45s}
.lz-projcard:hover .lz-projcard__im img{transform:scale(1.05)}
.lz-projcard__b{padding:20px 22px 22px}
.lz-projcard__cat{display:inline-block;font-size:11px;font-weight:800;letter-spacing:.1em;text-transform:uppercase;color:var(--g)}
.lz-projcard__t{font-size:20px;font-weight:700;color:var(--ink);margin:8px 0 0;line-height:1.25}
.lz-projcard__go{display:inline-flex;align-items:center;gap:7px;margin-top:14px;font-weight:700;font-size:14px;color:var(--ink)}
.lz-projcard__go svg{width:15px;height:15px;transition:transform .2s}.lz-projcard:hover .lz-projcard__go svg{transform:translateX(4px)}
@media(max-width:760px){.lz-proj__head{flex-direction:column;align-items:flex-start}.lz-proj__grid{grid-template-columns:1fr}}
.cblog{background:#eaf4ee!important}
.cblog__in{max-width:1400px!important}
/* Vídeos como carrusel de sectores */
.lz-vids{background:#fff}
.lz-seccard--vid{flex:0 0 clamp(300px,34vw,440px);aspect-ratio:16/9}
.lz-seccard--vid::after{background:linear-gradient(180deg,rgba(0,0,0,.15) 0%,rgba(0,0,0,0) 40%,rgba(0,0,0,.72) 100%)}
.lz-vid__play{position:absolute;top:46%;left:50%;transform:translate(-50%,-50%);z-index:3;width:58px;height:58px;border-radius:50%;background:rgba(255,255,255,.92);display:flex;align-items:center;justify-content:center;color:var(--ink);transition:.2s;box-shadow:0 8px 22px rgba(0,0,0,.25)}
.lz-vid__play svg{width:24px;height:24px;margin-left:3px}
.lz-seccard--vid:hover .lz-vid__play{background:var(--g);color:#fff;transform:translate(-50%,-50%) scale(1.08)}
.lz-seccard--chan{background:linear-gradient(158deg,#00a046,#006b2e);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:14px;text-align:center;color:#fff}
.lz-seccard--chan::after{display:none}
.lz-vidchan{width:60px;height:60px;border-radius:50%;background:rgba(255,255,255,.18);display:flex;align-items:center;justify-content:center}
.lz-vidchan svg{width:26px;height:26px;color:#fff;margin-left:3px}
.lz-vidchan__t{font-weight:700;font-size:15px;color:#fff;max-width:60%}

/* ====================================================================
   AJUSTES DE INTEGRACIÓN EN EL TEMA
   (.gsj-cat a{color:inherit} pisaba el color de los botones)
   ==================================================================== */
/* Botones con texto blanco sobre fondo de color */
.gsj-cat a.lz-fab__cta,
.gsj-cat a.lz-wood__cta { color: #fff; }
/* Enlace "Ver todos los proyectos" en verde */
.gsj-cat a.lz-proj__all { color: var(--g); }
/* Hero: botón principal verde con texto blanco */
.gsj-cat .hero a.btn-primary { background: var(--g); color: #fff; border: 0; }
/* Pesos de titulares (gsj-cat h*{font-weight:600} pisa el 300 de la maqueta) */
.gsj-cat .hero__h,
.gsj-cat .lz-pitch__h2,
.gsj-cat .lz-fab__h,
.gsj-cat .lz-sec__h,
.gsj-cat .lz-proc__h,
.gsj-cat .lz-wood__h,
.gsj-cat .lz-proj__h,
.gsj-cat .lz-bridge__h { font-weight: 300; }
.gsj-cat .hero__h strong { font-weight: 700; }
/* Botones-flecha del carrusel: círculo perfecto (un padding del tema los deformaba) */
.gsj-cat .lz-sec__btn { width: 46px; height: 46px; padding: 0; min-width: 0; flex: 0 0 46px; }

/* ---- Opiniones: estilo de home.css (versión nueva) ---- */
.ops{background:#f4f6f2;padding:90px 28px}
.ops__in{max-width:1400px;margin:0 auto}
.ops__head{text-align:center;max-width:700px;margin:0 auto 44px}
.ops__eyebrow{display:inline-block;font-size:12px;font-weight:700;letter-spacing:.16em;text-transform:uppercase;color:var(--g)}
.ops__t{font-size:clamp(32px,4vw,52px);line-height:1.04;margin:12px 0 16px}
.ops__rating{display:inline-flex;align-items:center;gap:8px;font-size:15px;color:var(--ink)}
.ops__rating strong{font-size:17px}
.ops__stars{color:#f5b50a;letter-spacing:1px}
.ops__rsub{color:var(--mut)}
.g-ico{width:18px;height:18px;flex:0 0 auto}
.ops__marquee{position:relative;overflow:hidden;-webkit-mask:linear-gradient(90deg,transparent,#000 5%,#000 95%,transparent);mask:linear-gradient(90deg,transparent,#000 5%,#000 95%,transparent)}
.ops__track{display:flex;gap:22px;width:max-content;animation:opsScroll 48s linear infinite}
.ops__marquee:hover .ops__track{animation-play-state:paused}
.opcard{flex:0 0 360px;width:360px;background:#fff;border:1px solid var(--line);border-radius:18px;padding:26px 24px}
.opcard__stars{color:#f5b50a;font-size:15px;letter-spacing:2px;margin-bottom:12px}
.opcard__txt{font-size:15px;line-height:1.6;color:#3a3a35;margin-bottom:20px}
.opcard__foot{display:flex;align-items:center;gap:12px}
.opcard__av{width:42px;height:42px;border-radius:50%;background:var(--g);color:#fff;display:inline-flex;align-items:center;justify-content:center;font-weight:700;font-size:16px;flex:0 0 auto}
.opcard__name{font-weight:600;color:var(--ink);font-size:14px}
.opcard__sub{display:flex;align-items:center;gap:6px;color:var(--mut);font-size:12.5px;margin-top:2px}
.opcard__sub .g-ico{width:13px;height:13px}
@keyframes scroll{to{transform:translateX(-50%)}}
@keyframes opsScroll{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* Proyectos en carrusel */
.lz-projsec .lz-sec__track .lz-projcard{flex:0 0 clamp(300px,34vw,420px);scroll-snap-align:start}

/* Red de seguridad: evita desborde horizontal (p.ej. marquee de opiniones).
   IMPORTANTE: usar overflow-x:clip y NO hidden. `hidden` en html/body crea un
   contenedor de scroll que ROMPE position:sticky del header (en unas secciones
   sí y en otras no). `clip` contiene el desborde sin romper el sticky. */
html{overflow-x:clip}
body{overflow-x:clip}
.gsj-cat{overflow-x:clip;max-width:100%}

/* ---- Títulos .display (solo en home.css; faltaban en categoría) ---- */
.gsj-cat .display { font-family: 'Manrope', sans-serif; font-weight: 300; letter-spacing: -.025em; line-height: .85; }
.gsj-cat .display em { font-style: normal; color: var(--g); font-weight: 600; }
/* "Ver más artículos" del blog en verde (gsj-cat a lo oscurecía) */
.gsj-cat a.cblog__link { color: var(--g); }
/* CTA: esquinas superiores redondeadas (una regla .ccta{border-radius:0} las anulaba) */
.gsj-cat .ccta { border-radius: clamp(28px,4vw,48px) clamp(28px,4vw,48px) 0 0; }
/* Card "Ver todos": el contador heredaba oscuro de .gsj-cat a */
.gsj-cat a.pcard--more{color:#fff}

/* Hero: mostrar el expositor completo en pantallas anchas */
.gsj-cat .hero__img{object-fit:contain;object-position:100% 50%}
.gsj-cat .hero__scene{width:50%}

/* ---- Hero responsive (apila imagen arriba + texto debajo, sin solape) ---- */
@media(max-width:820px){
  .gsj-cat .hero{padding-top:0;display:flex;flex-direction:column}
  .gsj-cat .hero__scene{position:relative!important;inset:auto!important;width:100%!important;height:clamp(300px,72vw,440px)!important;order:-1}
  .gsj-cat .hero__scene::after{display:none}
  .gsj-cat .hero__img{object-fit:cover!important;object-position:center}
  .gsj-cat .hero__in{position:relative;z-index:2;min-height:0!important;align-items:flex-start!important;padding:20px 28px 40px;background:#fff}
  .gsj-cat .hero .crumb{margin-bottom:12px}
  .gsj-cat .hero__h br{display:none}
  .gsj-cat .hero__proofs{flex-wrap:wrap}
}

/* ---- Blog en carrusel (Expositores) ---- */
.lz-blogsec{background:#eaf4ee}
.lz-blogsec .lz-sec__track .cblog__card{flex:0 0 clamp(280px,80vw,360px);scroll-snap-align:start}

/* Evitar que los chips del fabricante desborden en móvil */
.gsj-cat .lz-fab__img{overflow:hidden}
.gsj-cat .lz-fab__caps{overflow:hidden}

/* ---- Fabricante en móvil: foto más alta + chips iguales que el hero ---- */
@media(max-width:900px){
  .gsj-cat .lz-fab__img{height:auto;overflow:visible}
  .gsj-cat .lz-fab__img > img{height:clamp(320px,74vw,460px);border-radius:0}
  .gsj-cat .lz-fab__caps{position:static;display:flex;flex-wrap:wrap;gap:8px;padding:14px 0 0;overflow:visible}
  .gsj-cat .lz-fcap{position:static!important;inset:auto!important;opacity:1!important;transform:none!important;animation:none!important;width:auto;max-width:none;background:#fff;color:var(--ink);border:1px solid var(--line);border-radius:999px;box-shadow:none;font-size:12.5px;font-weight:600;padding:6px 12px 6px 6px;gap:6px}
  .gsj-cat .lz-fcap__ic{width:24px;height:24px;border-radius:50%;background:var(--mint);color:var(--g)}
  .gsj-cat .lz-fcap__ic svg{width:12px;height:12px}
}

/* ---- Móvil: fotos de fabricante y madera alineadas a 28px (no a sangre) ---- */
@media(max-width:900px){
  .gsj-cat .lz-fab__img{width:auto;margin:0 28px;border-radius:18px}
  .gsj-cat .lz-fab__img > img{border-radius:18px}
  .gsj-cat .lz-wood__img{width:auto!important;margin:0 28px;border-radius:18px;overflow:hidden}
}

/* ---- Form CTA en móvil: menos padding lateral y más compacto ---- */
@media(max-width:600px){
  .ccta__in{padding:40px 14px}
  .ccta__form{padding:26px 18px;border-radius:18px}
  .gsj-cf7 p{margin:0 0 12px}
  .gsj-cf7 input[type=text],.gsj-cf7 input[type=email],.gsj-cf7 input[type=tel],.gsj-cf7 textarea{padding:12px 14px;margin-top:6px}
  .gsj-cf7 textarea{min-height:84px}
}

/* ---- Fabricante y madera: en escritorio la imagen ocupa la mitad (sin invadir el texto) ---- */
@media(min-width:901px){
  .gsj-cat .lz-fab__img{left:50%;right:0;width:auto}
  .gsj-cat .lz-fab__box{max-width:460px}
  .gsj-cat .lz-wood__img{left:0;right:50%;width:auto}
  .gsj-cat .lz-wood__box{max-width:460px;margin-left:auto}
}

/* ---- Fix: icono del tirador del slider antes/después (Astra lo dejaba en blanco) ---- */
.gsj-cat .ba__grab{color:#14150f!important}
.gsj-cat .ba__grab svg{stroke:#14150f!important;fill:none!important;width:18px;height:18px}

/* ---- Muebles: acercar el chip "A medida" a la silla (escena más central) ---- */
@media(min-width:901px){
  body.term-muebles-carton .gsj-cat .lz-fcap--1{top:17%;left:34%}
  body.term-muebles-carton .gsj-cat .lz-fcap--3{bottom:27%;left:21%}
}

/* ---- Muebles: subir el bloque FAQ para que la curva se solape con el bloque anterior (sin huecos blancos) ---- */
body.term-muebles-carton .gsj-cat .cfaq{margin-top:clamp(-56px,-5vw,-32px);position:relative;z-index:2}

/* ---- Muebles: el hero es una escena (no un producto flotante). Que rellene la
   caja del hero (cover) en escritorio para que la altura visible sea idéntica a
   la de Expositores y no salte al cambiar de sección ---- */
@media(min-width:821px){
  body.term-muebles-carton .gsj-cat .hero__img{object-fit:cover!important;object-position:center}
}

/* ---- Hero de categoría: ALTURA FIJA idéntica en todas las secciones ----
   El alto dejaba de coincidir entre Expositores y Muebles porque dependía del
   contenido del texto (min-height + lo que ocupara). Con height fijo (clamp) el
   hero mide lo mismo en todas las secciones y no saltan los altos al cambiar. */
@media(min-width:821px){
  .gsj-cat .hero__in{height:clamp(480px,40vw,560px);min-height:0}
}

/* ---- Fix definitivo del tirador del slider antes/después (.ba__grab):
   Astra pisaba el <button> con padding/min-width (sale ovalado) y color blanco
   (icono invisible). Forzamos tamaño, sin padding y el icono oscuro. ---- */
.gsj-cat .ba__grab{width:42px!important;height:42px!important;min-width:0!important;padding:0!important;border-radius:50%!important;background:#fff!important;color:#14150f!important;display:flex!important;align-items:center;justify-content:center}
.gsj-cat .ba__grab svg{width:18px!important;height:18px!important;display:block;stroke:#14150f!important;fill:none!important;opacity:1!important}

/* Bloque sostenibilidad (importado de la home) para landings de categoría */
.gsj-cat .sost{background:#0c3b24;color:#fff;padding:96px 28px}
.gsj-cat .sost__head{max-width:820px;margin:0 auto 56px;text-align:center}
.gsj-cat .sost__eyebrow{display:inline-block;font-size:12px;font-weight:700;letter-spacing:.16em;text-transform:uppercase;color:#7fd29c;margin-bottom:14px}
.gsj-cat .sost__t{font-size:clamp(34px,4.6vw,60px);line-height:1;margin-bottom:16px;color:#fff}
.gsj-cat .sost__s{color:rgba(255,255,255,.78);font-size:18px;line-height:1.5}
.gsj-cat .sost__grid{max-width:1400px;margin:0 auto;display:grid;grid-template-columns:repeat(3,1fr);gap:48px}
.gsj-cat .sost__n{display:block;font-family:'Manrope',sans-serif;font-weight:300;font-size:clamp(60px,7vw,100px);line-height:1;letter-spacing:-.03em;padding-bottom:20px;border-bottom:1px solid rgba(255,255,255,.18);margin-bottom:18px}
.gsj-cat .sost__it{display:flex;align-items:center;gap:10px;font-size:20px;font-weight:600;margin-bottom:8px;color:#fff}
.gsj-cat .sost__ic{width:22px;height:22px;color:#7fd29c;flex:0 0 auto}
.gsj-cat .sost__d{color:rgba(255,255,255,.72);font-size:15px;line-height:1.6}
@media(max-width:780px){.gsj-cat .sost{padding:76px 28px}.gsj-cat .sost__grid{grid-template-columns:1fr;gap:40px}}

/* Sección de vídeo incrustado (landings de categoría) */
.gsj-cat .lzvid{padding:clamp(48px,7vw,92px) 28px;background:#fff}
.gsj-cat .lzvid__in{max-width:1000px;margin:0 auto;text-align:center}
.gsj-cat .lzvid__ey{display:inline-block;font-size:12px;font-weight:700;letter-spacing:.16em;text-transform:uppercase;color:var(--g,#16a34a);margin-bottom:14px}
.gsj-cat .lzvid__h{font-size:clamp(28px,3.6vw,46px);line-height:1.06;margin:0 0 28px;font-weight:800;color:var(--ink,#14150f)}
.gsj-cat .lzvid__frame{position:relative;width:100%;aspect-ratio:16/9;border-radius:18px;overflow:hidden;box-shadow:0 30px 60px rgba(0,0,0,.14);background:#000}
.gsj-cat .lzvid__frame iframe{position:absolute;inset:0;width:100%;height:100%;border:0}
@media(max-width:600px){.gsj-cat .lzvid__frame{border-radius:12px}}

/* Hero displays y packaging: mostrar el producto completo (contain centrado) */
@media(min-width:821px){
  body.term-displays .gsj-cat .hero__img,
  body.term-packaging .gsj-cat .hero__img{object-fit:contain!important;object-position:center!important}
}

/* Packaging: superponer las preguntas frecuentes sobre el bloque de sostenibilidad */
body.term-packaging .gsj-cat .cfaq{margin-top:clamp(-72px,-6vw,-40px);position:relative;z-index:2}

/* Botones (negros y verdes): el texto se mantiene blanco también en hover */
.gsj-cat a.lz-fab__cta:hover,
.gsj-cat a.lz-wood__cta:hover,
.gsj-cat a.btn-primary:hover,
.gsj-cat a.pcard--more:hover{color:#fff !important}

/* Subcategorías: bloque de texto centrado (SEO) tras los productos */
.gsj-cat .subcat-lead{max-width:840px;margin:0 auto;padding:clamp(44px,6vw,88px) 28px;text-align:center}
.gsj-cat .subcat-lead__ey{display:inline-block;font-size:12px;font-weight:700;letter-spacing:.16em;text-transform:uppercase;color:var(--g);margin-bottom:14px}
.gsj-cat .subcat-lead__h{font-size:clamp(28px,3.6vw,46px);line-height:1.08;font-weight:800;color:var(--ink);margin:0 0 18px}
.gsj-cat .subcat-lead__h b{color:var(--g)}
.gsj-cat .subcat-lead__p{color:var(--mut,#5b5b54);font-size:17px;line-height:1.6;margin:0 auto 14px;max-width:740px}

/* CTA final: se superpone un poco al bloque anterior (subcategorías y landings) */
.gsj-cat .ccta{margin-top:clamp(-72px,-6vw,-40px);position:relative;z-index:3}

/* Subcategorías: la CTA verde no se monta sobre el bloque de foto ni lleva esquinas redondeadas. */
.gsj-subcat .ccta{margin-top:0;border-radius:0}
