/* =========================================================
   SUPPRESS — home.css  (seções da Home)
   ========================================================= */

/* ---------- 1. HERO (banner — wordmark + figura em anel de névoa) ---------- */
.hero{
  position:relative;
  min-height:100svh;
  display:flex;align-items:center;
  background:#0b0b0c;
  color:#fff;overflow:hidden;isolation:isolate;
}
/* foto de fundo */
.hero__bg{position:absolute;inset:0;z-index:0;overflow:hidden}
.hero__bg img{
  width:100%;height:100%;object-fit:cover;object-position:center 38%;
  transform:scale(1.06) translateY(var(--py,0px));will-change:transform;
}
/* overlay para legibilidade do texto (mais escuro à esquerda) */
.hero__scrim{
  position:absolute;inset:0;z-index:1;pointer-events:none;
  background:
    linear-gradient(90deg, rgba(8,9,11,.92) 0%, rgba(8,9,11,.78) 32%, rgba(8,9,11,.32) 62%, rgba(8,9,11,.08) 100%),
    linear-gradient(0deg, rgba(8,9,11,.75) 0%, rgba(8,9,11,0) 40%);
}
/* conteúdo */
.hero__content{position:relative;z-index:3;width:100%;padding-top:var(--header-h)}
.hero__eyebrow{
  display:inline-flex;align-items:center;gap:12px;
  font-family:var(--font-display);font-weight:600;text-transform:uppercase;
  letter-spacing:.2em;font-size:clamp(.72rem,1.1vw,.84rem);color:var(--color-primary-light);
  margin-bottom:18px;
}
.hero__eyebrow::before{content:"";width:30px;height:2px;background:var(--color-primary)}
.hero__title{
  color:#fff;font-family:var(--font-display);font-weight:600;
  font-size:clamp(1.8rem,3vw,2.85rem);line-height:1.14;letter-spacing:-.005em;
  text-transform:none;margin-bottom:18px;text-shadow:0 4px 30px rgba(0,0,0,.5);max-width:19ch;
}
.hero__sub{
  font-size:clamp(1rem,1.25vw,1.15rem);line-height:1.65;color:#dcdcdc;
  max-width:52ch;margin-bottom:32px;text-shadow:0 2px 16px rgba(0,0,0,.5);
}
.hero__actions{display:flex;gap:16px;flex-wrap:wrap;align-items:center}
.hero__rfq{
  display:inline-flex;align-items:center;gap:14px;white-space:nowrap;
  background:var(--color-primary);border:1px solid var(--color-primary);
  border-radius:50px;padding:10px 10px 10px 26px;
  font-family:var(--font-display);font-weight:600;text-transform:uppercase;
  letter-spacing:.04em;font-size:1.05rem;color:#fff;
  box-shadow:0 12px 30px rgba(255,102,0,.32);
  transition:background .25s var(--ease),box-shadow .25s var(--ease),transform .25s var(--ease);
}
.hero__rfq:hover{background:var(--color-primary-dark);transform:translateY(-2px);box-shadow:0 16px 38px rgba(255,102,0,.4)}
.hero__rfq .ico{
  width:42px;height:42px;flex:none;border-radius:50%;background:rgba(255,255,255,.18);
  display:flex;align-items:center;justify-content:center;transition:transform .25s var(--ease)}
.hero__rfq:hover .ico{transform:rotate(45deg)}
.hero__rfq .ico svg{width:20px;height:20px;color:#fff}
.hero__ghost{
  display:inline-flex;align-items:center;gap:10px;
  font-family:var(--font-display);font-weight:600;text-transform:uppercase;letter-spacing:.04em;
  font-size:1.02rem;color:#fff;padding:14px 22px;border:1px solid rgba(255,255,255,.4);border-radius:50px;
  transition:background .25s var(--ease),border-color .25s}
.hero__ghost:hover{background:rgba(255,255,255,.12);border-color:#fff}

/* social bottom-left */
.hero__social{position:absolute;left:var(--gutter);bottom:30px;z-index:4;display:flex;gap:14px}
.hero__social a{
  width:40px;height:40px;border:1px solid rgba(255,255,255,.28);border-radius:8px;
  background:rgba(8,9,11,.35);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);
  display:flex;align-items:center;justify-content:center;color:#eee;transition:.2s}
.hero__social a:hover{background:var(--color-primary);border-color:var(--color-primary);color:#fff}
.hero__social svg{width:17px;height:17px;fill:currentColor}

/* scroll indicator bottom-center */
.hero__scroll{position:absolute;left:50%;bottom:28px;transform:translateX(-50%);z-index:4;display:flex}
.hero__scroll .mouse{width:24px;height:38px;border:2px solid rgba(255,255,255,.55);border-radius:14px;position:relative}
.hero__scroll .mouse::after{content:"";position:absolute;left:50%;top:7px;width:3px;height:7px;background:#fff;border-radius:2px;transform:translateX(-50%);animation:scrolldot 1.6s infinite}
@keyframes scrolldot{0%{opacity:0;transform:translate(-50%,0)}40%{opacity:1}80%{opacity:0;transform:translate(-50%,12px)}100%{opacity:0}}

@media (max-width:860px){
  .hero__bg img{object-position:center 42%}
  .hero__scrim{background:
    linear-gradient(90deg, rgba(8,9,11,.9) 0%, rgba(8,9,11,.7) 55%, rgba(8,9,11,.4) 100%),
    linear-gradient(0deg, rgba(8,9,11,.82) 0%, rgba(8,9,11,0) 46%)}
}
/* below this width the hero switches from "absolute-positioned social row
   pinned to the viewport bottom" to a normal stacked flow — at small
   viewport heights the title/CTA block grows tall enough to collide with
   the pinned social icons otherwise */
@media (max-width:768px){
  .hero{min-height:auto;display:block;padding:calc(var(--header-h) + 28px) 0 40px}
  .hero__content{padding-top:0}
  .hero__title{font-size:clamp(1.35rem,6.2vw,1.85rem);margin-bottom:14px}
  .hero__sub{font-size:.95rem;margin-bottom:24px}
  .hero__actions{gap:12px}
  /* static flow puts these icons over lighter/busier parts of the photo
     (the scrim's bottom-fade no longer sits under them), so they need a
     more opaque chip to stay legible instead of the desktop translucency */
  .hero__social{position:relative;z-index:4;left:auto;bottom:auto;margin-top:28px;padding-left:var(--gutter)}
  .hero__social a{background:rgba(10,11,13,.92);border-color:rgba(255,255,255,.55);color:#fff;-webkit-backdrop-filter:none;backdrop-filter:none;box-shadow:0 4px 16px rgba(0,0,0,.45)}
  .hero__social svg{width:19px;height:19px}
  .hero__scroll{display:none}
}
@media (max-width:560px){
  .hero__social{gap:10px}
}

/* ---------- 1b. CLIENTES (faixa rolante) ---------- */
.logos-strip{
  background:var(--color-dark);color:#fff;
  padding:18px 0;position:relative;overflow:hidden;
  border-top:1px solid rgba(255,255,255,.06);
}
.logos-strip__label{
  display:block;text-align:center;
  font-family:var(--font-display);font-weight:400;text-transform:uppercase;
  letter-spacing:.24em;font-size:.72rem;color:rgba(255,255,255,.56);margin-bottom:14px;
}
.marquee{
  position:relative;width:100%;overflow:hidden;
  -webkit-mask-image:linear-gradient(90deg,transparent 0,#000 7%,#000 93%,transparent 100%);
          mask-image:linear-gradient(90deg,transparent 0,#000 7%,#000 93%,transparent 100%);
}
.marquee__track{
  display:flex;width:max-content;gap:clamp(28px,4vw,56px);align-items:center;
  animation:marquee 72s linear infinite;
}
.marquee:hover .marquee__track{animation-play-state:paused}
@keyframes marquee{from{transform:translateX(0)}to{transform:translateX(-50%)}}
.logo-item{
  display:inline-flex;align-items:center;gap:0;color:rgba(255,255,255,.54);
  transition:color .25s, opacity .25s, filter .25s;white-space:nowrap;
}
.logo-item:hover{color:rgba(255,255,255,.86)}
.logo-item img{
  width:clamp(70px,5.5vw,100px);height:38px;object-fit:contain;flex:none;border-radius:0;
  background:transparent;padding:0;box-shadow:none;
  filter:brightness(0) invert(1);opacity:.55;
  transition:opacity .25s;
}
.logo-item:hover img{opacity:1}
.logo-item .nm{
  position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;
  clip:rect(0,0,0,0);white-space:nowrap;border:0;
}
@media (prefers-reduced-motion:reduce){.marquee__track{animation:none;justify-content:center;flex-wrap:wrap;width:100%}}

/* ---------- 1c. VIDEO INSTITUCIONAL ---------- */
.brand-film{
  background:
    linear-gradient(180deg,#fff 0%,#f7f7f5 100%);
  overflow:hidden;
}
.brand-film__grid{
  display:grid;
  grid-template-columns:minmax(0,.82fr) minmax(0,1.18fr);
  gap:clamp(34px,5vw,72px);
  align-items:center;
}
.brand-film__copy{
  max-width:460px;
}
.brand-film__copy h2{
  margin-bottom:18px;
}
.brand-film__copy p{
  color:var(--color-gray);
  font-size:var(--text-lg);
  line-height:1.62;
  margin-bottom:28px;
}
.brand-film__media{
  position:relative;
  aspect-ratio:16/9;
  border-radius:6px;
  overflow:hidden;
  background:#0b0b0c;
  border:1px solid rgba(0,0,0,.08);
  box-shadow:0 24px 70px rgba(0,0,0,.2);
}
.brand-film__media::before{
  content:"";
  position:absolute;
  inset:-1px;
  pointer-events:none;
  border:1px solid rgba(255,255,255,.18);
  z-index:1;
}
.brand-film__media iframe{
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
  border:0;
}
@media (max-width:900px){
  .brand-film__grid{grid-template-columns:1fr}
  .brand-film__copy{max-width:680px}
}

/* ---------- FACADE — vídeos YouTube (evita carregar iframe até o clique) ---------- */
.yt-facade{
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
  border:0;
  padding:0;
  cursor:pointer;
  background:#0b0b0c;
}
.yt-facade img{
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
  object-fit:cover;
}
.yt-facade__play{
  position:absolute;
  inset:0;
  margin:auto;
  width:68px;
  height:68px;
  display:flex;
  align-items:center;
  justify-content:center;
  border-radius:50%;
  background:var(--color-primary);
  color:#fff;
  transition:transform .25s var(--ease),background .25s;
}
.yt-facade__play svg{width:28px;height:28px;margin-left:3px}
.yt-facade:hover .yt-facade__play{transform:scale(1.08);background:var(--color-primary-dark,var(--color-primary))}

/* ---------- 2b. SINAIS DE ALERTA ---------- */
.signals{border-top:1px solid var(--color-border)}
.signals__grid{display:grid;grid-template-columns:1fr 1.1fr;gap:clamp(40px,6vw,84px);align-items:start}
.signals__text{position:sticky;top:120px}
.signals__text h2{margin-bottom:16px}
.signals__dash{display:inline-flex;align-items:center;gap:6px;margin-bottom:18px}
.signals__dash i{width:5px;height:5px;border-radius:50%;background:var(--color-primary-light)}
.signals__dash b{display:block;width:38px;height:3px;border-radius:2px;background:var(--color-primary)}
.signals__text p{color:var(--color-gray);font-size:var(--text-lg);max-width:46ch}
.signals__cta{margin-top:30px}

.signals__cards{display:grid;grid-template-columns:repeat(2,1fr);gap:18px}
.signal-card{
  background:var(--color-white);border:1px solid var(--color-border);border-radius:4px;
  padding:24px;transition:transform .3s var(--ease),box-shadow .3s var(--ease),border-color .3s;
  position:relative;overflow:hidden;
}
.signal-card::before{content:"";position:absolute;left:0;top:0;width:4px;height:0;background:var(--color-primary);transition:height .35s var(--ease)}
.signal-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-md);border-color:transparent}
.signal-card:hover::before{height:100%}
.signal-card .ic{width:46px;height:46px;border-radius:4px;background:#fff3eb;color:var(--color-primary);display:flex;align-items:center;justify-content:center;margin-bottom:16px;flex:none}
.signal-card .ic svg{width:24px;height:24px}
.signal-card h3{margin-bottom:8px;text-transform:none;font-size:1.05rem;line-height:1.3}
.signal-card p{color:var(--color-gray);font-size:.92rem;line-height:1.6}
.signal-card--wide{grid-column:1 / -1}
.signals__dots{display:none}
@media (max-width:860px){.signals__grid{grid-template-columns:1fr}.signals__text{position:static;top:auto;margin-bottom:8px}}
/* on phones, 5 full-height cards stacked in one column made this section an
   extremely long scroll — swap to a swipeable horizontal carousel (native
   scroll-snap, so touch drag/momentum works with no extra JS) with dots to
   show progress, same pattern as the other carousels on this page */
@media (max-width:640px){
  .signals__cards{
    display:flex;grid-template-columns:none;overflow-x:auto;scroll-snap-type:x mandatory;
    gap:14px;margin-inline:calc(var(--gutter) * -1);padding-inline:var(--gutter);
    padding-bottom:4px;-webkit-overflow-scrolling:touch;scrollbar-width:none;
  }
  .signals__cards::-webkit-scrollbar{display:none}
  .signal-card,.signal-card--wide{grid-column:auto;flex:0 0 82%;scroll-snap-align:center}
  .signals__dots{display:flex;justify-content:center;gap:2px;margin-top:14px}
  .signals__dots button{width:24px;height:24px;display:grid;place-items:center;background:transparent;border-radius:50%}
  .signals__dots button::before{content:"";width:8px;height:8px;border-radius:50%;background:var(--color-border);transition:background .25s var(--ease),width .25s var(--ease)}
  .signals__dots button.active::before{background:var(--color-primary);width:22px;border-radius:4px}
}

/* ---------- 3. MERCADOS (carrossel coverflow 3D) ---------- */
.markets-section{position:relative;overflow:hidden}
.markets-section::before{
  content:"";position:absolute;left:50%;top:-10%;transform:translateX(-50%);
  width:min(70vw,900px);height:340px;pointer-events:none;
  background:radial-gradient(60% 100% at 50% 0%, rgba(255,118,28,.16), rgba(255,118,28,0) 70%);
}
.markets-stage{
  position:relative;
  perspective:1700px;perspective-origin:50% 50%;
  height:clamp(310px,34vw,500px);
  margin-top:8px;
}
.markets{
  position:absolute;inset:0;
  transform-style:preserve-3d;
}
.market-card{
  position:absolute;left:50%;top:50%;
  width:clamp(440px,48vw,760px);aspect-ratio:5/3;
  margin:0;border-radius:6px;overflow:hidden;isolation:isolate;color:#fff;
  display:flex;flex-direction:column;justify-content:flex-end;
  transform:translate(-50%,-50%);
  transform-origin:center center;
  box-shadow:0 30px 64px rgba(0,0,0,.55);
  transition:transform .6s var(--ease),opacity .5s var(--ease),box-shadow .4s var(--ease);
  will-change:transform;cursor:pointer;
}
.market-card .ph{position:absolute;inset:0;z-index:-2}
.market-card>picture,.market-card>img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:-2;display:block}
.market-card>picture>img{width:100%;height:100%;object-fit:cover}
.market-card::after{content:"";position:absolute;inset:0;z-index:-1;background:linear-gradient(180deg,transparent 30%,rgba(0,0,0,.7));transition:.35s}
.market-card__body{padding:18px 22px;transition:transform .35s var(--ease),opacity .35s;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}
.market-card .ic{width:36px;height:36px;color:var(--color-primary-light);margin-bottom:8px}
.market-card .ic svg{width:100%;height:100%}
.market-card h3{color:#fff;font-size:1.5rem;text-transform:uppercase;line-height:1.04;text-wrap:balance}
.market-card .go{display:inline-flex;align-items:center;gap:6px;margin-top:12px;font-size:.82rem;text-transform:uppercase;letter-spacing:.1em;font-weight:500;color:var(--color-primary-light);opacity:0;transform:translateY(8px);transition:.3s}
.market-card.is-active::after{background:linear-gradient(180deg,transparent 30%,rgba(0,0,0,.65))}
.market-card.is-active .go{opacity:1;transform:none}
/* navegação */
.mk-nav{
  position:absolute;top:50%;transform:translateY(-50%);z-index:20;
  width:54px;height:54px;border-radius:50%;
  background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.2);
  color:#fff;display:flex;align-items:center;justify-content:center;
  -webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);
  transition:background .25s var(--ease),border-color .25s,transform .25s;
}
.mk-nav:hover{background:var(--color-primary);border-color:var(--color-primary)}
.mk-nav svg{width:24px;height:24px}
.mk-prev{left:max(8px,2vw)}
.mk-next{right:max(8px,2vw)}
.mk-prev:hover{transform:translateY(-50%) scale(1.08)}
.mk-next:hover{transform:translateY(-50%) scale(1.08)}
.mk-dots{display:flex;justify-content:center;gap:4px;margin-top:26px;flex-wrap:wrap}
.mk-dots button{
  width:24px;height:24px;display:grid;place-items:center;
  background:transparent;border-radius:50%;
}
.mk-dots button::before{
  content:"";width:9px;height:9px;border-radius:50%;background:rgba(255,255,255,.24);
  transition:background .25s var(--ease),width .25s var(--ease);
}
.mk-dots button:hover::before{background:rgba(255,255,255,.5)}
.mk-dots button.active::before{background:var(--color-primary);width:26px;border-radius:5px}

/* the coverflow effect (perspective + rotateY per card, driven by
   go()/layout() in main.js) stays on at every width — just scale the
   stage/card down so the fanned side-cards fit inside a phone screen
   instead of overflowing it; tx/ry offsets in JS are % based, so they
   scale automatically with the card's own width */
@media (max-width:900px){
  .markets-stage{height:clamp(260px,50vw,420px)}
  .market-card{width:clamp(320px,62vw,520px)}
}
@media (max-width:560px){
  .markets-stage{height:clamp(230px,60vw,300px);margin-top:32px}
  .market-card{width:clamp(220px,74vw,300px)}
  .market-card__body{padding:14px 16px}
  .market-card h3{font-size:1.15rem}
  .market-card .ic{width:30px;height:30px;margin-bottom:4px}
  .mk-nav{width:42px;height:42px}
  .mk-nav svg{width:18px;height:18px}
  .mk-prev{left:0}
  .mk-next{right:0}
  .mk-dots{margin-top:20px}
}

/* ---------- 3b. OUTRAS APLICAÇÕES ---------- */
.special-apps{border-top:1px solid rgba(255,255,255,.08)}
.special-apps .section-head p{color:rgba(255,255,255,.6);max-width:54ch;margin-inline:auto}
.special-apps__grid{display:grid;grid-template-columns:repeat(2,1fr);gap:20px;margin-top:clamp(30px,4vw,48px)}
.special-app{
  position:relative;border-radius:6px;overflow:hidden;
  aspect-ratio:5/3;display:flex;flex-direction:column;justify-content:flex-end;
  color:#fff;transition:transform .4s var(--ease),box-shadow .4s var(--ease);
}
.special-app:hover{transform:translateY(-6px);box-shadow:0 24px 60px rgba(0,0,0,.4)}
.special-app>picture{display:contents}
.special-app img{position:absolute;inset:-12% 0;width:100%;height:124%;object-fit:cover;z-index:0}
.special-app__overlay{position:absolute;inset:0;z-index:1;background:linear-gradient(180deg,transparent 25%,rgba(0,0,0,.75))}
.special-app__body{position:relative;z-index:2;padding:clamp(20px,3vw,32px)}
.special-app__body .ic{width:40px;height:40px;color:var(--color-primary-light);margin-bottom:10px}
.special-app__body .ic svg{width:100%;height:100%}
.special-app__body h3{font-size:clamp(1.2rem,1.8vw,1.5rem);text-transform:uppercase;margin-bottom:8px}
.special-app__body p{font-size:.9rem;line-height:1.6;color:rgba(255,255,255,.78);max-width:48ch}
.special-app__body .go{display:inline-flex;align-items:center;gap:6px;margin-top:14px;font-size:.82rem;text-transform:uppercase;letter-spacing:.1em;font-weight:500;color:var(--color-primary-light);opacity:0;transform:translateY(6px);transition:.3s}
.special-app:hover .go{opacity:1;transform:none}
.apps-stage{position:relative}
.sa-nav,.sa-dots{display:none}
/* below this, desktop's plain 2-col grid becomes the same coverflow
   carousel used in "Onde atuamos" — nav/dots reuse the .mk- look since
   it's the same dark section background */
@media (max-width:700px){
  /* the description paragraph was overlapping the photo once the card
     shrinks for the carousel — drop it here, keep it on desktop */
  .special-app__body p{display:none}
  .special-app.is-active .go{opacity:1;transform:none}

  .apps-stage{perspective:1500px;perspective-origin:50% 50%;height:clamp(230px,60vw,300px);margin-top:8px}
  .special-apps__grid{position:absolute;inset:0;display:block;transform-style:preserve-3d}
  .special-app{position:absolute;left:50%;top:50%;width:clamp(220px,74vw,300px);margin:0;transform:translate(-50%,-50%);transform-origin:center center;will-change:transform}

  .sa-nav{
    position:absolute;top:50%;transform:translateY(-50%);z-index:20;
    width:42px;height:42px;border-radius:50%;
    background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.2);
    color:#fff;display:flex;align-items:center;justify-content:center;
    -webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);
  }
  .sa-nav svg{width:18px;height:18px}
  .sa-prev{left:0}
  .sa-next{right:0}
  .sa-dots{display:flex;justify-content:center;gap:2px;margin-top:16px;flex-wrap:wrap}
  .sa-dots button{width:24px;height:24px;display:grid;place-items:center;background:transparent;border-radius:50%}
  .sa-dots button::before{content:"";width:8px;height:8px;border-radius:50%;background:rgba(255,255,255,.24);transition:background .25s var(--ease),width .25s var(--ease)}
  .sa-dots button.active::before{background:var(--color-primary);width:22px;border-radius:4px}
}

/* ---------- 4. VALOR / DIFERENCIAIS ---------- */
.value{display:grid;grid-template-columns:1.1fr .9fr;gap:clamp(40px,6vw,84px);align-items:end}
.value__media{position:relative;display:flex;justify-content:center;align-items:flex-end}
.value__media .ph{aspect-ratio:4/4.6;border-radius:4px}
.value__photo{display:block;width:auto;height:clamp(440px,48vw,620px);object-fit:contain;flex:none}
.value__media .badge{
  position:absolute;left:0;bottom:24px;background:var(--color-primary);color:#fff;
  padding:20px 24px;border-radius:4px;box-shadow:var(--shadow-md);text-align:center;
}
.value__media .badge .n{font-family:var(--font-display);font-weight:700;font-size:2.8rem;line-height:.9}
.value__media .badge .t{font-size:.78rem;text-transform:uppercase;letter-spacing:.08em;font-weight:500;margin-top:6px}
.diffs{display:flex;flex-direction:column;gap:22px;margin:30px 0 34px}
.diff{display:flex;gap:18px;align-items:flex-start}
.diff .ic{width:52px;height:52px;flex:none;border:2px solid var(--color-primary);border-radius:4px;color:var(--color-primary);display:flex;align-items:center;justify-content:center}
.diff .ic svg{width:26px;height:26px}
.diff h3{font-size:1.2rem;text-transform:none;margin-bottom:3px}
.diff p{font-size:.95rem;color:var(--color-gray)}
@media (max-width:860px){.value{grid-template-columns:1fr;align-items:center}.value__media{order:-1}.value__photo{height:clamp(280px,50vw,360px)}}

/* ---------- 5. PRODUTOS — showcase (mesmo componente da página Produtos) ---------- */
.product-showcase{
  position:relative;isolation:isolate;overflow:clip;
  padding:clamp(3rem,7vw,6rem) 0;
  background:
    radial-gradient(85% 65% at 74% 58%, rgba(255,102,0,.18) 0%, rgba(255,102,0,0) 60%),
    radial-gradient(150% 130% at 50% 55%, #23232a 0%, #15151a 42%, #0a0a0c 100%);
  color:#fff;
}
.showcase__glow{position:absolute;top:6%;right:-8%;width:55vw;height:55vw;max-width:760px;max-height:760px;z-index:-1;pointer-events:none;
  background:radial-gradient(circle, rgba(255,102,0,.24) 0%, rgba(255,102,0,0) 68%);filter:blur(20px);
  animation:psGlow 9s ease-in-out infinite alternate}
.showcase__grid-bg{position:absolute;inset:80px 0 0 0;z-index:-1;pointer-events:none;
  background-image:linear-gradient(rgba(255,255,255,.04) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.04) 1px,transparent 1px);
  background-size:56px 56px;
  -webkit-mask-image:radial-gradient(110% 95% at 50% 45%, #000 30%, transparent 80%);
          mask-image:radial-gradient(110% 95% at 50% 45%, #000 30%, transparent 80%)}

.showcase__inner{display:grid;grid-template-columns:1fr;gap:clamp(1.5rem,3vw,2.5rem);align-items:center}
@media (min-width:900px){
  .showcase__inner{grid-template-columns:clamp(340px,34vw,440px) minmax(0,1fr);gap:clamp(2rem,4vw,4rem)}
}

.ps-info{width:100%;max-width:440px}
@media (max-width:899px){.ps-info{order:3;max-width:none;text-align:center}}
.ps-info__line{display:inline-block;font-size:.75rem;font-weight:600;letter-spacing:.2em;text-transform:uppercase;color:#FF8533;margin-bottom:.75rem}
.ps-info__name{font-family:var(--font-display);font-weight:700;line-height:.92;font-size:clamp(3rem,8vw,5.5rem);letter-spacing:-.02em;color:#fff;margin:0 0 1rem;text-transform:none}
.ps-info__name b{color:#FF6600;font-weight:700}
.ps-info__tagline{font-size:1.125rem;line-height:1.55;color:rgba(255,255,255,.72);margin-bottom:1.5rem}
.ps-info__actions{display:flex;gap:1rem;flex-wrap:wrap;align-items:center;margin-top:.5rem}
@media (max-width:899px){.ps-info__actions{justify-content:center}}
.ps-info__cta{gap:.5rem}
.ps-info__cta svg{width:18px;height:18px}
.ps-info__proposal{font-size:.875rem;font-weight:500;letter-spacing:.04em;padding:12px 24px;border:1px solid rgba(255,255,255,.22);border-radius:9999px;background:rgba(255,255,255,.06);color:rgba(255,255,255,.85);transition:background .25s,border-color .25s,color .25s;text-decoration:none;display:inline-block}
.ps-info__proposal:hover{background:rgba(255,255,255,.12);border-color:rgba(255,255,255,.4);color:#fff}

.ps-stage{position:relative;min-width:0;perspective:1400px;min-height:clamp(280px,42vw,520px);display:flex;align-items:center;justify-content:center}
@media (max-width:899px){.ps-stage{order:1}}
.ps-stage__ghost{position:absolute;top:48%;left:50%;transform:translate(-50%,-50%);max-width:100%;overflow:hidden;font-family:var(--font-display);font-weight:700;font-size:clamp(7rem,18vw,15rem);line-height:1;color:rgba(255,255,255,.045);letter-spacing:-.04em;z-index:0;pointer-events:none;user-select:none;white-space:nowrap}
.ps-stage__imgs{position:relative;width:100%;height:100%;min-height:inherit;z-index:1}
.ps-img{position:absolute;inset:0;margin:auto;width:auto;height:auto;max-width:100%;max-height:clamp(260px,40vw,500px);object-fit:contain;opacity:0;transform:translateX(48px) scale(.92);transition:opacity .6s cubic-bezier(.25,.46,.45,.94),transform .7s cubic-bezier(.25,.46,.45,.94);filter:drop-shadow(0 34px 42px rgba(0,0,0,.55));pointer-events:none;will-change:opacity,transform}
.ps-img.is-active{opacity:1;transform:translateX(0) scale(1);pointer-events:auto;animation:psFloat 6s ease-in-out .7s infinite alternate}
.ps-img--wide{max-height:none;max-width:120%;width:clamp(460px,70vw,900px);margin-left:auto;margin-right:-8%;left:auto;right:-4%}
.ps-stage__shadow{position:absolute;bottom:6%;left:50%;width:min(62%,440px);height:42px;transform:translateX(-50%);background:radial-gradient(ellipse, rgba(0,0,0,.65) 0%, rgba(0,0,0,0) 72%);filter:blur(11px);z-index:0}

/* now a 3rd grid item inside .showcase__inner (after ps-info/ps-stage) so
   it can be reordered on mobile to sit right under the product photo —
   grid-column spans both columns so it still sits on its own full-width
   row beneath the info+stage pair on desktop, same as before */
/* min-width:0 is required now that this is a grid item: without it, its
   default min-width:auto lets the unwrapped 9-thumbnail row (meant to
   scroll via .ps-thumbs' own overflow-x:auto) force the whole grid track
   to grow to fit all of them, which was overflowing/clipping everything
   else in the column on mobile */
.showcase__controls{display:flex;align-items:center;justify-content:center;gap:1rem;grid-column:1 / -1;min-width:0;position:relative}
@media (max-width:899px){.showcase__controls{order:2}}
.ps-nav{flex-shrink:0;width:48px;height:48px;border-radius:50%;display:inline-flex;align-items:center;justify-content:center;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.18);color:#fff;cursor:pointer;transition:background .2s ease,border-color .2s ease,transform .2s ease}
.ps-nav svg{width:22px;height:22px}
.ps-nav:hover{background:#FF6600;border-color:#FF6600;transform:scale(1.06)}
.ps-nav:focus-visible{outline:2px solid #FF8533;outline-offset:2px}
.ps-thumbs{display:flex;align-items:center;gap:.75rem;overflow-x:auto;padding:.5rem;scrollbar-width:none;scroll-snap-type:x proximity}
.ps-thumbs::-webkit-scrollbar{display:none}
.ps-thumb{flex-shrink:0;width:76px;height:60px;padding:6px;border-radius:8px;background:#1b1b21;border:1px solid rgba(255,255,255,.08);cursor:pointer;opacity:.45;scroll-snap-align:center;transition:opacity .2s ease,border-color .2s ease,background .2s ease,transform .2s ease}
.ps-thumb img{width:100%;height:100%;object-fit:contain}
.ps-thumb:hover{opacity:.8;transform:translateY(-2px)}
.ps-thumb.is-active{opacity:1;background:#2b1d10;border-color:#FF6600}
.ps-thumb:focus-visible{outline:2px solid #FF8533;outline-offset:2px}
.ps-counter{position:absolute;right:var(--gutter,clamp(16px,4vw,32px));bottom:-2px;font-family:var(--font-display);font-weight:600;font-size:.875rem;color:rgba(255,255,255,.55)}
.ps-counter [data-current]{color:#fff;font-size:1.125rem}
.ps-counter__sep{margin:0 4px}
/* on phones the desktop clamp() floors (48px title, 460px "wide" product
   photo) are bigger than the viewport itself, causing the overflow/crop
   seen in the showcase — give this breakpoint its own, viewport-relative
   scale. The thumbnail rail also switches from a horizontal strip under
   the photo to a vertical rail beside it (like a product-page gallery):
   it shares the photo's row as a narrow left column instead of its own
   full-width row, so the photo ends up centered-but-shifted-right in the
   remaining space, and switching equipment doesn't need a big scroll. */
@media (max-width:680px){
  .product-showcase{padding:2.5rem 0 2rem}
  .showcase__inner{gap:1.25rem;grid-template-columns:60px 1fr}
  .ps-info__line{font-size:.68rem;margin-bottom:.5rem}
  .ps-info__name{font-size:clamp(1.9rem,10vw,2.4rem);line-height:1.06;margin-bottom:.6rem}
  .ps-info__tagline{font-size:.95rem;margin-bottom:1.1rem}
  .ps-info__actions{flex-direction:column;align-items:stretch;gap:.7rem}
  .ps-info__cta,.ps-info__proposal{
    width:100%;justify-content:center;text-align:center;
    white-space:normal;font-size:.92rem;padding:14px 18px;
  }
  .ps-info{grid-column:1 / -1}

  .ps-stage{grid-column:2;grid-row:1;min-height:clamp(200px,62vw,300px)}
  .ps-img{max-height:clamp(180px,54vw,300px)}
  .ps-img--wide{
    width:90%;max-width:340px;
    left:0;right:0;margin-left:auto;margin-right:auto;
  }
  .ps-stage__ghost{font-size:clamp(4rem,26vw,6.5rem)}

  .showcase__controls{
    grid-column:1;grid-row:1;
    display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.5rem;
  }
  .ps-nav{width:30px;height:30px}
  .ps-nav svg{width:14px;height:14px}
  .ps-nav--prev svg,.ps-nav--next svg{transform:rotate(90deg)} /* ‹/› become ^/v for a vertical rail */
  .ps-thumbs{
    flex-direction:column;max-height:clamp(140px,40vw,200px);padding:0;gap:.4rem;
    overflow-x:hidden;overflow-y:auto;scroll-snap-type:y proximity;
  }
  .ps-thumb{width:44px;height:36px;flex-shrink:0}
  .ps-counter{position:static;text-align:center;margin-top:0}
}

@keyframes psGlow{from{transform:translate(0,0) scale(1);opacity:.9}to{transform:translate(-3%,4%) scale(1.08);opacity:1}}
@keyframes psFloat{from{transform:translateX(0) scale(1) translateY(0)}to{transform:translateX(0) scale(1) translateY(-14px)}}
@keyframes psSwapUp{from{opacity:0;transform:translateY(18px)}to{opacity:1;transform:translateY(0)}}
@media (prefers-reduced-motion:no-preference){
  .ps-info.is-swap>*{animation:psSwapUp .5s cubic-bezier(.25,.46,.45,.94) backwards}
  .ps-info.is-swap>*:nth-child(1){animation-delay:.05s}
  .ps-info.is-swap>*:nth-child(2){animation-delay:.1s}
  .ps-info.is-swap>*:nth-child(3){animation-delay:.15s}
  .ps-info.is-swap>*:nth-child(4){animation-delay:.2s}
}
@media (prefers-reduced-motion:reduce){
  .showcase__glow{animation:none}
  .ps-img{transition:opacity .3s ease;transform:none}
  .ps-img.is-active{animation:none;transform:none}
}

/* ---------- 5.5 ESTUDO DE CASO — Porto Sudeste ---------- */
.case-study{background:var(--color-white);position:relative;overflow:hidden}
.case-study__grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(2rem,5vw,4rem);align-items:center}
.case-study__title{color:var(--color-dark);font-size:clamp(1.6rem,3vw,2.4rem);margin-bottom:1rem}
.case-study__hl{color:var(--color-primary)}
.case-study__text{color:var(--color-gray);line-height:1.7;margin-bottom:1.5rem}

.ps-counters{display:flex;flex-wrap:wrap;gap:1rem;margin-bottom:1.5rem}
.ps-counter-card{background:var(--color-bg);border:1px solid var(--color-border);border-radius:12px;padding:16px 20px;text-align:center;flex:1;min-width:120px}
.ps-counter-num{font-family:var(--font-display);font-size:clamp(1.8rem,3vw,2.5rem);font-weight:800;color:var(--color-dark);line-height:1}
.ps-counter-num--primary{color:var(--color-primary)}
.ps-counter-num small{font-size:.45em}
.ps-counter-label{font-size:.7rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--color-gray);margin-top:4px}

.case-study__actions{display:flex;gap:.75rem;flex-wrap:wrap}

.case-study__media{position:relative}
.case-study__img{width:100%;height:auto;border-radius:16px;box-shadow:var(--shadow-lg);display:block}
.case-study__badge{position:absolute;top:16px;left:16px;background:rgba(0,0,0,.75);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border:1px solid rgba(255,255,255,.15);border-radius:10px;padding:10px 16px;display:flex;align-items:center;gap:10px}
.case-study__dot{width:8px;height:8px;border-radius:50%;background:#5EE8A2;box-shadow:0 0 0 4px rgba(94,232,162,.2);flex:none}
.case-study__badge span:last-child{font-size:.7rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:#fff}

@media (max-width:860px){
  /* photo first (Gestalt: lead with the proof shot), stats/text below —
     same stacking pattern used by the other image+copy sections on this
     page (.value, .signals, etc.) */
  .case-study__grid{grid-template-columns:1fr;gap:1.75rem}
  .case-study__media{order:-1}
}
@media (max-width:640px){
  .case-study__title{font-size:clamp(1.5rem,7vw,1.9rem)}
  /* flex+min-width(120px) was forcing an uneven 2-then-1 wrap once 3 cards
     no longer fit a phone's width side by side — a real 3-col grid keeps
     them even and legible instead of lopsided */
  .ps-counters{display:grid;grid-template-columns:repeat(3,1fr);gap:.6rem}
  .ps-counter-card{min-width:0;padding:12px 8px}
  .ps-counter-num{font-size:clamp(1.3rem,7vw,1.8rem)}
  .ps-counter-label{font-size:.62rem;letter-spacing:.06em}
  .case-study__badge{padding:8px 12px;gap:8px;top:10px;left:10px}
  .case-study__badge span:last-child{font-size:.6rem}
  .case-study__actions{flex-direction:column;align-items:stretch}
  .case-study__actions .btn{width:100%;justify-content:center}
}

/* ---------- 6. CASES / CLIENTES ---------- */
.client-logos{display:grid;grid-template-columns:repeat(5,1fr);gap:0;border:1px solid var(--color-border);border-radius:4px;overflow:hidden;margin-bottom:clamp(40px,5vw,64px)}
.client-logos .cl{
  display:flex;align-items:center;justify-content:center;padding:30px 18px;min-height:120px;
  border-right:1px solid var(--color-border);border-bottom:1px solid var(--color-border);
  font-family:var(--font-display);font-weight:700;font-size:1.3rem;letter-spacing:.02em;
  color:var(--color-gray-light);text-transform:uppercase;transition:.25s;
}
.client-logos .cl:hover{color:var(--color-dark);background:var(--color-bg)}
/* ---------- 6b. TESTIMONIALS — arremesso de carta (Wiza-style) ---------- */
.quote-carousel{position:relative;max-width:900px;margin-inline:auto;overflow:visible}
.quote-deck{position:relative;display:flex;justify-content:center;align-items:center;pointer-events:none}
.quote-slide+.quote-slide{margin-left:-100%}
.quote-slide{
  flex:0 0 auto;width:100%;
  background:#3B3B3B;color:#fff;border-radius:1.2rem;
  padding:clamp(32px,4vw,48px) clamp(32px,4vw,52px);
  box-shadow:0 32px 24px -12px rgba(0,0,0,.16),0 6px 4px rgba(0,0,0,.06),0 1px 1px rgba(0,0,0,.08);
  transform-origin:100% 100%;
  will-change:transform;
  display:flex;flex-direction:column;justify-content:center;
  pointer-events:none;
}
.quote-slide::before{content:"\201C";position:absolute;right:28px;top:8px;font-family:Georgia,serif;font-size:6rem;color:rgba(255,102,0,.18);line-height:1;pointer-events:none}
.quote-slide blockquote{position:relative;font-family:var(--font-display);font-weight:400;font-size:clamp(1rem,1.4vw,1.15rem);line-height:1.65;text-transform:none}
.quote-slide .by{margin-top:20px;font-size:.92rem;color:var(--color-gray-light)}
.quote-slide .by b{color:var(--color-primary-light);display:block;font-size:1rem;text-transform:uppercase;font-family:var(--font-display);letter-spacing:.03em}
/* texto só aparece no card da frente */
.quote-slide::before,.quote-slide blockquote,.quote-slide .by{opacity:0;transition:opacity .2s .15s var(--ease)}
.quote-slide.is-front{pointer-events:auto}
.quote-slide.is-front::before,.quote-slide.is-front blockquote,.quote-slide.is-front .by{opacity:1}
/* Fase 1: card de trás é arremessado (sobe + gira 50° do pivô inf-dir)
   Fase 2: volta ao centro como novo ativo */
.quote-slide.dealing{animation:wizaDeal .8s cubic-bezier(.76,0,.24,1) both}
@keyframes wizaDeal{
  0%  {transform:translate(10px,-10px) rotate(0deg) scale(.92);z-index:-1}
  50% {transform:translate(10px,-160px) rotate(50deg) scale(.92);z-index:10}
  100%{transform:translate(0,0) rotate(0deg) scale(1);z-index:10}
}
.quote-nav{display:flex;gap:10px;margin-top:36px;align-items:center;justify-content:center}
.quote-prev,.quote-next{
  width:44px;height:44px;border-radius:50%;
  background:#fff;border:1px solid rgba(0,0,0,.08);
  box-shadow:0 2px 4px rgba(0,0,0,.08),0 1px 1px rgba(0,0,0,.04);
  color:var(--color-dark);display:flex;align-items:center;justify-content:center;
  cursor:pointer;transition:background .25s,border-color .25s,color .25s;
}
.quote-prev:hover,.quote-next:hover{background:var(--color-primary);border-color:var(--color-primary);color:#fff}
.quote-prev svg,.quote-next svg{width:18px;height:18px}
.quote-dots{display:flex;gap:6px;margin-left:12px}
.quote-dots span{width:8px;height:8px;border-radius:50%;background:var(--color-border);cursor:pointer;transition:background .25s,width .25s}
.quote-dots span.active{background:var(--color-primary);width:22px;border-radius:4px}
@media (prefers-reduced-motion:reduce){.quote-slide{transition:none}.quote-slide.dealing{animation:none}}
@media (max-width:680px){.client-logos{grid-template-columns:repeat(2,1fr)}.quote-feature{grid-template-columns:1fr}.quote-feature .qmark{display:none}}

/* ---------- 7. CTA FINAL / DIAGNÓSTICO ---------- */
.diag{color:#fff;position:relative;overflow:hidden;
  background:
    radial-gradient(80% 70% at 28% 50%, rgba(255,102,0,.18) 0%, rgba(255,102,0,0) 60%),
    radial-gradient(150% 130% at 40% 50%, #23232a 0%, #15151a 42%, #0a0a0c 100%);
}
/* mesma grade técnica do showcase, concentrada atrás do texto (esquerda) */
.diag::before{content:"";position:absolute;inset:0;pointer-events:none;
  background-image:linear-gradient(rgba(255,255,255,.04) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.04) 1px,transparent 1px);
  background-size:56px 56px;
  -webkit-mask-image:radial-gradient(100% 95% at 28% 50%, #000 28%, transparent 78%);
          mask-image:radial-gradient(100% 95% at 28% 50%, #000 28%, transparent 78%)}
.diag__grid{display:grid;grid-template-columns:1fr 1.05fr;gap:clamp(40px,5vw,70px);align-items:center;position:relative;z-index:1}
.diag h2{color:#fff;font-size:clamp(1.7rem,2.9vw,2.55rem)}
.diag__sub{font-size:var(--text-lg);margin:16px 0 28px;color:rgba(255,255,255,.92)}
.diag__check{display:flex;flex-direction:column;gap:14px}
.diag__check li{display:flex;gap:12px;align-items:flex-start;font-weight:400}
.diag__check svg{width:24px;height:24px;flex:none;background:#fff;color:var(--color-primary);border-radius:50%;padding:4px}
/* form card */
.form-card{background:#fff;border-radius:6px;padding:clamp(26px,3vw,38px);box-shadow:var(--shadow-md);color:var(--color-dark-mid)}
.form-card h3{color:var(--color-dark);font-size:1.6rem;text-transform:none;margin-bottom:6px}
.form-card .fc-sub{font-size:.92rem;color:var(--color-gray);margin-bottom:22px}
.field{margin-bottom:16px}
.field label{display:block;font-size:.82rem;font-weight:500;text-transform:uppercase;letter-spacing:.05em;color:var(--color-dark-mid);margin-bottom:6px}
.field label .req{color:var(--color-primary)}
.field input,.field select,.field textarea{
  width:100%;padding:12px 14px;border:1.5px solid var(--color-border);border-radius:3px;
  background:var(--color-bg);transition:border-color .2s,background .2s;font-size:.95rem;
}
.field input:focus,.field select:focus,.field textarea:focus{border-color:var(--color-primary);background:#fff;outline:2px solid rgba(255,102,0,.45);outline-offset:-1px}
.field input:focus-visible,.field select:focus-visible,.field textarea:focus-visible{outline:2px solid #FF6600;outline-offset:1px}
.field textarea{resize:vertical;min-height:84px}
.field.invalid input,.field.invalid select,.field.invalid textarea{border-color:#e03131;background:#fff5f5}
.field .err{display:none;color:#e03131;font-size:.78rem;margin-top:5px;font-weight:400}
.field.invalid .err{display:block}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.check-lgpd{display:flex;gap:10px;align-items:flex-start;font-size:.82rem;color:var(--color-gray);margin:6px 0 20px}
.check-lgpd input{width:18px;height:18px;margin-top:2px;flex:none;accent-color:var(--color-primary)}
.form-success{display:none;text-align:center;padding:30px 10px}
.form-success.show{display:block}
.form-success .ok{width:68px;height:68px;border-radius:50%;background:#eafaf0;color:var(--color-success);display:flex;align-items:center;justify-content:center;margin:0 auto 18px}
.form-success .ok svg{width:36px;height:36px}
.form-success h3{color:var(--color-dark)}
.form-success p{color:var(--color-gray);margin-top:8px}
@media (max-width:860px){
  .diag__grid{grid-template-columns:1fr;gap:clamp(24px,4vw,40px)}
  .diag__info{text-align:center}
  .diag h2{font-size:clamp(1.4rem,5vw,1.8rem)}
  .diag__sub{font-size:.95rem;margin:12px 0 20px}
  /* align-items:center here centered each checklist row independently by
     its own (different) text width, so the checkmarks zig-zagged instead
     of lining up — center the list as a whole block instead and keep the
     rows left-aligned inside it, so every checkmark sits at the same x */
  .diag__check{align-items:flex-start;gap:10px;width:fit-content;margin-inline:auto;text-align:left}
  .diag__check li{font-size:.9rem}
  .form-row{grid-template-columns:1fr}
  .form-card{padding:24px 20px;border-radius:12px}
  .form-card h3{font-size:1.25rem;margin-bottom:4px}
  .form-card .fc-sub{font-size:.85rem;margin-bottom:18px}
  .field{margin-bottom:14px}
  .field label{font-size:.78rem;margin-bottom:5px}
  .field input,.field select,.field textarea{
    font-size:16px;padding:14px 14px;border-radius:8px;
    border-width:1.5px;background:#f8f8f8;
  }
  .field textarea{min-height:72px}
  .check-lgpd{font-size:.76rem;gap:8px;margin:4px 0 16px}
  .check-lgpd input{width:20px;height:20px}
  .btn--block{width:100%;padding:16px;font-size:.95rem;border-radius:8px}
}
@media (max-width:560px){
  .diag::before{display:none}
  .diag .section{padding-block:clamp(36px,6vw,48px)}
  .form-card{padding:20px 16px}
  .field input,.field select,.field textarea{padding:13px 12px}
}

/* ---------- 6b. DEPOIMENTOS — card único ---------- */
/* single card, content swapped via JS — same idea across every
   breakpoint instead of separate desktop/mobile carousel mechanisms */
.tst{max-width:720px;margin:0 auto;cursor:grab;touch-action:pan-y}
.tst.is-dragging{cursor:grabbing;user-select:none}
.tst__card{
  position:relative;
  background:
    radial-gradient(120% 130% at 26% 0%, rgba(255,102,0,.16) 0%, rgba(255,102,0,0) 55%),
    linear-gradient(180deg,#232329 0%,#16161a 100%);
  border:1px solid rgba(255,255,255,.08);
  border-radius:20px;
  padding:clamp(28px,4vw,44px) clamp(24px,4vw,40px) clamp(24px,4vw,32px);
  color:#fff;
  box-shadow:0 30px 70px rgba(0,0,0,.35);
  /* fixed height (not min-height) sized to the longest testimonial
     (Bianca Martins) plus a safety margin, so every card is the same
     size regardless of quote length — measured empirically per
     breakpoint rather than guessed, since line-wrapping depends on the
     actual font/width at each size */
  height:440px;display:flex;flex-direction:column;overflow:hidden;
}
.tst__head{display:flex;align-items:center;gap:14px;margin-bottom:24px;flex-wrap:wrap}
.tst__avatar{
  width:56px;height:56px;flex:none;border-radius:50%;
  background:linear-gradient(135deg,var(--color-primary),var(--color-primary-dark));
  color:#fff;font-family:var(--font-display);font-weight:700;font-size:1.1rem;letter-spacing:.02em;
  display:flex;align-items:center;justify-content:center;
  box-shadow:0 8px 20px rgba(255,102,0,.35);
}
.tst__identity{display:flex;flex-direction:column;margin-right:auto;min-width:0}
.tst__identity strong{font-family:var(--font-display);font-weight:600;font-size:1rem;text-transform:uppercase;letter-spacing:.02em;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.tst__identity span{font-size:.8rem;color:rgba(255,255,255,.55);margin-top:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.tst__stars{display:flex;align-items:center;gap:3px;flex:none;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.1);border-radius:50px;padding:7px 12px;color:#FFB020}
.tst__stars svg{width:13px;height:13px}
/* h3 inherits main.css's global heading reset (color:var(--color-dark)),
   which is near-black — without an explicit color here it was rendering
   almost invisible against this card's dark background */
.tst__headline{color:#fff;font-family:var(--font-display);font-weight:700;text-transform:uppercase;font-size:clamp(1.3rem,2.6vw,1.9rem);line-height:1.15;margin-bottom:14px}
.tst__quote{font-size:1rem;line-height:1.75;color:rgba(255,255,255,.8)}
.tst__company{margin-top:auto;padding-top:20px;font-family:var(--font-display);font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--color-primary-light);font-size:.85rem}

/* fade-up swap when the content changes — reuses the same keyframe as
   the product showcase's info panel for a consistent feel */
@media (prefers-reduced-motion:no-preference){
  .tst__card.is-swap .tst__head,
  .tst__card.is-swap .tst__headline,
  .tst__card.is-swap .tst__quote,
  .tst__card.is-swap .tst__company{animation:psSwapUp .5s cubic-bezier(.25,.46,.45,.94) backwards}
  .tst__card.is-swap .tst__headline{animation-delay:.05s}
  .tst__card.is-swap .tst__quote{animation-delay:.1s}
  .tst__card.is-swap .tst__company{animation-delay:.15s}
}

.tst__dots{display:flex;justify-content:center;gap:2px;margin-top:18px}
.tst__dots button{width:24px;height:24px;display:grid;place-items:center;background:transparent;border-radius:50%}
.tst__dots button::before{content:"";width:7px;height:7px;border-radius:50%;background:var(--color-border);transition:background .25s var(--ease),width .25s var(--ease)}
.tst__dots button:hover::before{background:var(--color-gray-light)}
.tst__dots button.active::before{background:var(--color-primary);width:20px;border-radius:4px}

@media (max-width:640px){
  .tst__card{height:520px;padding:24px 20px 20px;border-radius:16px}
  .tst__avatar{width:48px;height:48px;font-size:1rem}
  .tst__identity strong{font-size:.9rem}
  .tst__identity span{font-size:.75rem}
  .tst__stars{padding:5px 9px;gap:2px}
  .tst__stars svg{width:11px;height:11px}
  .tst__headline{font-size:clamp(1.15rem,6vw,1.4rem)}
  .tst__quote{font-size:.92rem;line-height:1.7}
}

/* ---------- 8. BLOG PREVIEW ---------- */
.blog-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:26px}
.post-card{background:#fff;border:1px solid var(--color-border);border-radius:4px;overflow:hidden;transition:transform .3s var(--ease),box-shadow .3s var(--ease)}
.post-card:hover{transform:translateY(-6px);box-shadow:var(--shadow-md)}
.post-card .ph{aspect-ratio:16/10}
.post-card__link{display:block}
.post-card__image{aspect-ratio:16/10;overflow:hidden}
.post-card__image img{width:100%;height:100%;object-fit:cover;display:block}
.post-card__body{display:block;padding:24px}
.post-card .cat{display:inline-block;background:#fff3eb;color:#B34700;font-family:var(--font-display);font-weight:600;font-size:.74rem;letter-spacing:.1em;text-transform:uppercase;padding:5px 11px;border-radius:3px;margin-bottom:14px}
.post-card h3{font-size:1.32rem;text-transform:none;line-height:1.2;margin-bottom:10px;transition:color .2s}
.post-card:hover h3{color:var(--color-primary)}
.post-card p{font-size:.92rem;color:var(--color-gray);margin-bottom:16px}
.post-card .meta{display:flex;gap:16px;font-size:.8rem;color:var(--color-gray);border-top:1px solid var(--color-border);padding-top:14px}
.post-card .meta span{display:inline-flex;align-items:center;gap:6px}
.post-card .meta svg{width:14px;height:14px}
@media (max-width:920px){.blog-grid{grid-template-columns:1fr;max-width:460px;margin-inline:auto}}
/* below this, cards switch from "photo on top" to a compact horizontal
   list row (thumbnail left, title/meta right) — with 3 full-size photo
   cards stacked, this section was one of the longest scrolls on the
   page; a compact list keeps all 3 posts visible without needing a
   carousel gesture to see the ones a swipe would otherwise hide */
@media (max-width:640px){
  .blog-grid{gap:12px;max-width:none}
  .post-card{display:flex;align-items:stretch;border-radius:10px}
  .post-card:hover{transform:none}
  .post-card__link{flex:0 0 92px}
  .post-card__image{aspect-ratio:auto;height:100%}
  .post-card__body{flex:1;min-width:0;padding:12px 14px;display:flex;flex-direction:column;justify-content:center}
  .post-card .cat{font-size:.62rem;letter-spacing:.06em;padding:3px 8px;margin-bottom:6px}
  .post-card h3{
    font-size:.92rem;line-height:1.3;margin-bottom:6px;
    display:-webkit-box;-webkit-box-orient:vertical;-webkit-line-clamp:2;overflow:hidden;
  }
  .post-card p{display:none}
  .post-card .meta{border-top:none;padding-top:0;gap:10px;font-size:.68rem}
  .post-card .meta svg{width:12px;height:12px}
}

/* section header with side action */
.head-row{display:flex;justify-content:space-between;align-items:flex-end;gap:24px;flex-wrap:wrap;margin-bottom:clamp(40px,5vw,60px)}

/* ---------- ANTES E DEPOIS (comparison slider) ---------- */
/* ---------- ANTES E DEPOIS (eraser reveal) ---------- */
.eraser-wrap{max-width:960px;margin-inline:auto}
.eraser{position:relative;border-radius:8px;overflow:hidden;box-shadow:var(--shadow-md);cursor:none;user-select:none;line-height:0}
.eraser__after{display:block;width:100%;height:auto}
.eraser__canvas{position:absolute;inset:0;width:100%;height:100%;cursor:none}
.eraser__tag{position:absolute;top:16px;font-family:var(--font-display);font-weight:600;font-size:.78rem;letter-spacing:.1em;text-transform:uppercase;padding:6px 14px;border-radius:3px;z-index:2;pointer-events:none}
.eraser__tag--before{left:16px;background:rgba(0,0,0,.6);color:#fff;transition:opacity .4s}
.eraser.is-erasing .eraser__tag--before{opacity:0}
.eraser__tag--after{right:16px;background:var(--color-primary);color:#fff;opacity:0;transition:opacity .4s}
.eraser.is-erasing .eraser__tag--after{opacity:1}
.eraser__hint{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px;color:#fff;font-family:var(--font-display);font-weight:500;font-size:.9rem;letter-spacing:.04em;text-shadow:0 2px 12px rgba(0,0,0,.5);pointer-events:none;z-index:3;transition:opacity .5s}
.eraser.is-erasing .eraser__hint{opacity:0}
.eraser__hint-mobile{display:none}
@media (hover:none),(max-width:860px){.eraser__hint-desktop{display:none}.eraser__hint-mobile{display:inline}}
/* intro copy above the widget — same mouse/touch swap as .eraser__hint,
   so it doesn't tell touch users to "pass the mouse" over the photo */
.ba-intro-mobile{display:none}
@media (hover:none),(max-width:860px){.ba-intro-desktop{display:none}.ba-intro-mobile{display:inline}}

/* ---------- 5.6 VÍDEO - SOLUÇÃO EM AÇÃO ---------- */
.video-solution__media{
  position:relative;max-width:880px;margin-inline:auto;aspect-ratio:16/9;
  border-radius:6px;overflow:hidden;background:#0b0b0c;
  border:1px solid rgba(0,0,0,.08);box-shadow:var(--shadow-md);
}
.video-solution__media iframe{position:absolute;inset:0;width:100%;height:100%;border:0}
.head-row .section-head{margin-bottom:0}
