/* ============================================================
   SOMA HOSPITALAR — Sistema de Design
   Editorial Healthcare
   Fontes: League Spartan (display) + Montserrat (corpo)
   ============================================================ */

/* ---------- Tokens ---------- */
:root{
  /* Paleta da marca */
  --deep:#034447;
  --deep-2:#02363a;
  --teal:#218488;
  --teal-soft:#9fcccd;
  --red:#cc3230;
  --red-dark:#a8231f;

  /* Neutros (warm paper) */
  --paper:#faf7f0;        /* fundo principal */
  --paper-2:#f1ece0;      /* fundo alt / cream */
  --paper-3:#e8e2d2;      /* divisores quentes */
  --ink:#0c1c1d;
  --ink-2:#23383a;
  --muted:#5e7274;
  --line:#dbd5c5;
  --line-cool:#dce8e8;
  --white:#ffffff;

  /* WhatsApp */
  --wa:#22c25e;
  --wa-2:#1aa64f;

  /* Layout */
  --maxw:1320px;
  --maxw-narrow:1080px;
  --gutter:clamp(20px, 4vw, 56px);
  --pad-section:clamp(72px, 11vw, 140px);

  /* Radius / shadow */
  --r-sm:10px;
  --r-md:18px;
  --r-lg:28px;
  --r-pill:999px;
  --shadow-sm:0 8px 22px -14px rgba(3,68,71,.35);
  --shadow-md:0 22px 60px -28px rgba(3,68,71,.45);
  --shadow-deep:0 36px 80px -36px rgba(3,68,71,.55);

  /* Easing */
  --ease:cubic-bezier(.22,.61,.36,1);

  /* Fontes */
  --ff-display:'League Spartan',ui-sans-serif,system-ui,sans-serif;
  --ff-body:'Montserrat',ui-sans-serif,system-ui,sans-serif;
}

/* ---------- Reset ---------- */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%;scroll-padding-top:90px}
body{
  font-family:var(--ff-body);
  color:var(--ink);
  background:var(--paper);
  line-height:1.65;
  font-size:16px;
  font-weight:400;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
img,svg{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
ul{list-style:none}
button{font:inherit;color:inherit;background:none;border:0;cursor:pointer}
::selection{background:var(--deep);color:var(--paper)}

/* ---------- Tipografia ---------- */
h1,h2,h3,h4,.display,.eyebrow-num{
  font-family:var(--ff-display);
  color:var(--deep);
  font-weight:700;
  line-height:1;
  letter-spacing:-.015em;
  text-wrap:balance;
}
.display{
  font-size:clamp(2.8rem, 7.5vw, 6.2rem);
  font-weight:700;
  text-transform:uppercase;
  line-height:.95;
  letter-spacing:-.025em;
}
.h-1{font-size:clamp(2.4rem, 5.4vw, 4.4rem); text-transform:uppercase; line-height:.98; letter-spacing:-.02em}
.h-2{font-size:clamp(1.9rem, 3.6vw, 3rem); text-transform:uppercase; line-height:1.02; letter-spacing:-.015em}
.h-3{font-size:clamp(1.25rem, 1.6vw, 1.5rem); line-height:1.1; letter-spacing:-.005em}
.h-4{font-size:1.08rem; line-height:1.2; letter-spacing:0}

.lead{font-size:clamp(1.05rem,1.3vw,1.2rem); color:var(--ink-2); max-width:62ch; line-height:1.55; font-weight:400}
.muted{color:var(--muted)}

.eyebrow{
  display:inline-flex; align-items:center; gap:.7rem;
  font-family:var(--ff-body);
  font-size:.72rem; font-weight:700;
  text-transform:uppercase; letter-spacing:.22em;
  color:var(--teal);
}
.eyebrow::before{
  content:""; width:28px; height:2px; background:var(--red); border-radius:2px;
}
.eyebrow.is-light{color:var(--teal-soft)}
.eyebrow.is-light::before{background:var(--red)}
.eyebrow-num{
  font-size:.78rem; font-weight:600; color:var(--muted);
  font-family:var(--ff-body); letter-spacing:.18em; text-transform:uppercase;
}

.accent-teal{color:var(--teal)}
.accent-red{color:var(--red)}
.accent-deep{color:var(--deep)}

/* ---------- Layout helpers ---------- */
.container{
  width:100%; max-width:var(--maxw);
  margin-inline:auto;
  padding-inline:var(--gutter);
}
.container--narrow{max-width:var(--maxw-narrow)}
section{position:relative}
.section{padding-block:var(--pad-section)}
.section--top{padding-top:0}
.section--tint{background:var(--paper-2)}
.section--dark{background:var(--deep); color:#dfeaea}
.section--dark h1,.section--dark h2,.section--dark h3,.section--dark h4{color:#fff}
.section--dark .muted{color:#a8c0c1}
.section--dark .lead{color:#cfe1e2}
.section--ink{background:var(--ink); color:#dfeaea}
.section--ink h1,.section--ink h2,.section--ink h3,.section--ink h4{color:#fff}
.center{text-align:center}
.center .eyebrow{justify-content:center}

/* Grid system */
.grid{display:grid; gap:24px}
.grid--2{grid-template-columns:repeat(2,1fr)}
.grid--3{grid-template-columns:repeat(3,1fr)}
.grid--4{grid-template-columns:repeat(4,1fr)}
.grid--12{grid-template-columns:repeat(12,1fr)}
.flow > * + *{margin-top:1.1rem}
.flow-lg > * + *{margin-top:1.6rem}

/* ---------- Decorative dots (brand motif) ---------- */
.dots{display:inline-flex; align-items:center; gap:8px}
.dot{width:12px; height:12px; border-radius:50%; flex:0 0 auto}
.dot--red{background:var(--red)}
.dot--teal{background:var(--teal)}
.dot--deep{background:var(--deep)}
.dot--soft{background:var(--teal-soft)}
.dot--ring{background:transparent; border:2px solid currentColor}
.dot--sm{width:8px; height:8px}
.dot--md{width:16px; height:16px}
.dot--lg{width:18px; height:18px}
.dot--xl{width:26px; height:26px}

/* ---------- Buttons ---------- */
.btn{
  --bg:var(--deep);
  --fg:#fff;
  --bd:transparent;
  display:inline-flex; align-items:center; justify-content:center; gap:.7rem;
  font-family:var(--ff-body); font-weight:600; font-size:.92rem;
  letter-spacing:.01em;
  padding:15px 28px;
  border-radius:var(--r-pill);
  background:var(--bg); color:var(--fg);
  border:1.5px solid var(--bd);
  line-height:1; white-space:nowrap;
  transition:transform .25s var(--ease), box-shadow .25s var(--ease), background .25s, color .25s, border-color .25s;
  cursor:pointer;
}
.btn svg{width:18px; height:18px}
.btn:hover{transform:translateY(-2px); box-shadow:0 18px 32px -16px rgba(3,68,71,.4)}
.btn--red{--bg:var(--red)}
.btn--red:hover{box-shadow:0 18px 32px -16px rgba(204,50,48,.55)}
.btn--teal{--bg:var(--teal)}
.btn--wa{--bg:var(--wa)}
.btn--wa:hover{box-shadow:0 18px 32px -16px rgba(34,194,94,.55)}
.btn--ghost{--bg:transparent; --fg:var(--ink); --bd:var(--ink)}
.btn--ghost:hover{--bg:var(--ink); --fg:var(--paper); box-shadow:none}
.btn--ghost-light{--bg:transparent; --fg:#fff; --bd:rgba(255,255,255,.4)}
.btn--ghost-light:hover{--bg:#fff; --fg:var(--deep); --bd:#fff; box-shadow:none}
.btn--outline-teal{--bg:transparent; --fg:var(--teal); --bd:var(--teal)}
.btn--outline-teal:hover{--bg:var(--teal); --fg:#fff}
.btn--lg{padding:18px 32px; font-size:.98rem}
.btn--block{display:flex; width:100%}

/* ---------- Navbar ---------- */
.nav{
  position:sticky; top:0; z-index:50;
  background:rgba(250,247,240,.88);
  backdrop-filter:saturate(1.5) blur(14px);
  -webkit-backdrop-filter:saturate(1.5) blur(14px);
  border-bottom:1px solid var(--line);
}
.nav__inner{
  display:flex; align-items:center; justify-content:space-between; gap:24px;
  min-height:78px; padding-block:14px;
}
.brand{display:inline-flex; align-items:center; gap:12px}
.brand img{height:46px; width:auto}
.brand__txt{display:flex; flex-direction:column; line-height:1}
.brand__name{
  font-family:var(--ff-display); font-weight:700; font-size:1.2rem;
  letter-spacing:.04em; color:var(--deep); text-transform:uppercase;
}
.brand__name span{font-weight:400; color:var(--teal)}
.brand__tag{
  font-family:var(--ff-body); font-weight:600; font-size:.6rem;
  letter-spacing:.24em; text-transform:uppercase; color:var(--muted);
  margin-top:4px;
}
.nav__links{display:flex; align-items:center; gap:4px}
.nav__links a{
  font-weight:500; font-size:.9rem; color:var(--ink-2);
  padding:10px 16px; border-radius:var(--r-pill);
  transition:color .2s, background .2s;
}
.nav__links a:hover{color:var(--deep); background:rgba(33,132,136,.08)}
.nav__links a.is-active{color:var(--deep); background:rgba(33,132,136,.12)}
.nav__cta{margin-left:10px}
.nav__cta .btn{padding:11px 18px; font-size:.84rem; color:#fff}
.nav__toggle{display:none; padding:8px; color:var(--deep)}
.nav__toggle svg{width:28px; height:28px}

/* ---------- HERO ---------- */
.hero{
  background:var(--paper);
  padding-block:clamp(40px,5vw,72px) clamp(72px,10vw,128px);
}
.hero__grid{display:grid; grid-template-columns:1fr; max-width:960px; margin-inline:auto; text-align:center}
.hero__stats{display:flex; flex-direction:column; gap:14px}
.hero__stat{
  background:#fff; border-radius:var(--r-md);
  border-left:3px solid var(--teal);
  padding:20px 24px;
  box-shadow:var(--shadow-sm);
  display:flex; align-items:center; gap:18px;
}
.hero__stat__icon{
  width:46px; height:46px; border-radius:50%;
  background:rgba(33,132,136,.08);
  display:flex; align-items:center; justify-content:center;
  flex-shrink:0; color:var(--teal);
}
.hero__stat__icon svg{width:22px; height:22px}
.hero__stat__body{display:flex; flex-direction:column; gap:2px}
.hero__stat__value{
  font-size:1.15rem; font-weight:800;
  color:var(--deep); line-height:1.1;
  font-family:var(--ff-head);
}
.hero__stat__label{
  font-size:.72rem; font-weight:600;
  color:var(--muted); text-transform:uppercase; letter-spacing:.12em;
}

/* ---------- Coverage / Cobertura Nacional ---------- */
.coverage{
  display:grid; grid-template-columns:1fr 1fr;
  gap:clamp(40px,6vw,88px); align-items:center;
}
.coverage__map{display:flex; align-items:center; justify-content:center}
.coverage__map-wrap{
  position:relative; display:inline-block;
  transition:transform .7s var(--ease), filter .7s var(--ease);
  will-change:transform;
  filter:drop-shadow(0 12px 40px rgba(3,68,71,.18));
}
.coverage__map-wrap:hover{
  transform:perspective(1000px) rotateY(-6deg) rotateX(3deg) scale(1.03);
  filter:drop-shadow(0 28px 60px rgba(3,68,71,.28));
}
.coverage__map-wrap img{width:100%; max-width:440px; display:block}
.coverage__dot{
  position:absolute; width:7px; height:7px;
  background:var(--teal); border-radius:50%;
  transform:translate(-50%,-50%);
  animation:dot-pulse 2.4s ease-in-out infinite;
}
.coverage__dot:nth-child(2n){animation-delay:.4s}
.coverage__dot:nth-child(3n){animation-delay:.8s}
.coverage__dot:nth-child(4n){animation-delay:1.2s}
.coverage__dot:nth-child(5n){animation-delay:1.6s}
@keyframes dot-pulse{
  0%,100%{opacity:.55; transform:translate(-50%,-50%) scale(1)}
  50%{opacity:1; transform:translate(-50%,-50%) scale(1.35)}
}
.coverage__vals{
  display:grid; grid-template-columns:1fr 1fr; gap:20px 32px;
  margin-top:36px; padding-top:28px; border-top:1px solid var(--line);
}
.hero__meta{
  display:flex; align-items:center; gap:14px;
  font-family:var(--ff-body); font-size:.74rem; font-weight:600;
  letter-spacing:.22em; text-transform:uppercase; color:var(--muted);
  margin-bottom:30px;
}
.hero__meta .bar{height:1px; flex:1; background:var(--line)}
.hero__title{
  font-size:clamp(2.4rem, 5.5vw, 5rem);
  text-transform:uppercase; line-height:.95; letter-spacing:-.025em;
  color:var(--deep);
}
.hero__title em{font-style:normal; color:var(--teal); display:block}
.hero__title-accent{display:block; color:#218488}
.hero__title .underline{
  position:relative; display:inline-block;
}
.hero__title .underline::after{
  content:""; position:absolute; left:-3%; right:-3%; bottom:.08em; height:.12em;
  background:var(--red); opacity:.85; z-index:-1;
}
.hero__title-line{display:block}
.hero__title-line--d{display:flex; align-items:center; justify-content:center; gap:clamp(8px,1vw,14px)}
.hero__decos{display:flex; align-items:center; gap:clamp(5px,.6vw,9px)}
.hero__decos--v{flex-direction:column; gap:clamp(4px,.5vw,8px); align-items:center}
.hero__sub{
  font-size:clamp(1.05rem, 1.3vw, 1.22rem); color:var(--ink-2);
  margin-top:28px; max-width:54ch; line-height:1.55; margin-inline:auto;
}
.hero__cta{display:flex; flex-wrap:wrap; gap:14px; margin-top:36px; justify-content:center}
.hero__chips{
  display:flex; flex-wrap:wrap; gap:8px;
  margin-top:42px; justify-content:center;
}
.chip{
  display:inline-flex; align-items:center; gap:8px;
  font-size:.76rem; font-weight:600; color:var(--ink-2);
  background:transparent; border:1px solid var(--line);
  padding:8px 14px; border-radius:var(--r-pill);
  letter-spacing:.04em;
}
.chip .dot{width:7px; height:7px}

/* Hero visual side */
.hero__visual{position:relative; aspect-ratio:1/1; max-width:520px; margin-inline:auto}
.hero__brand-frame{
  position:absolute; inset:0;
  background:linear-gradient(155deg, var(--deep) 0%, #022a2d 100%);
  border-radius:var(--r-lg);
  overflow:hidden;
  box-shadow:var(--shadow-deep);
}
.hero__brand-frame::before{
  content:""; position:absolute; inset:0; opacity:.5;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='60' height='60' viewBox='0 0 60 60'%3E%3Cg fill='none' stroke='%23ffffff' stroke-opacity='0.06' stroke-width='1'%3E%3Cpath d='M30 4v52M4 30h52'/%3E%3C/g%3E%3C/svg%3E");
}
.hero__brand-frame::after{
  content:""; position:absolute; right:-25%; bottom:-25%; width:75%; height:75%;
  background:radial-gradient(circle, rgba(33,132,136,.55), transparent 70%);
}
.hero__brand-frame img{
  position:absolute; left:50%; top:50%;
  width:62%; transform:translate(-50%,-50%);
  filter:drop-shadow(0 22px 36px rgba(0,0,0,.5));
}
.hero__brand-frame .label{
  position:absolute; left:24px; top:24px;
  font-family:var(--ff-body); font-size:.66rem; letter-spacing:.22em;
  font-weight:600; text-transform:uppercase; color:#9fcccd;
}
.hero__brand-frame .label .bullet{
  display:inline-block; width:8px; height:8px; border-radius:50%;
  background:var(--red); margin-right:8px; vertical-align:middle;
}
.hero__brand-frame .stamp{
  position:absolute; right:24px; bottom:24px;
  font-family:var(--ff-display); font-weight:700; font-size:.9rem;
  letter-spacing:.16em; text-transform:uppercase; color:#fff;
}
.hero__stat-card{
  position:absolute; left:-12%; bottom:-8%;
  background:var(--paper); border:1px solid var(--line);
  border-radius:var(--r-md); padding:22px 26px;
  box-shadow:var(--shadow-md); min-width:220px;
}
.hero__stat-card .label{
  font-size:.7rem; font-weight:700; letter-spacing:.2em;
  text-transform:uppercase; color:var(--muted); margin-bottom:8px;
  display:flex; align-items:center; gap:8px;
}
.hero__stat-card .label .dot{width:8px; height:8px; background:var(--red)}
.hero__stat-card b{
  display:block; font-family:var(--ff-display); font-size:2.4rem;
  color:var(--deep); line-height:1;
}
.hero__stat-card p{font-size:.82rem; color:var(--muted); margin-top:6px}

/* ---------- Marquee / stat bar ---------- */
.statline{
  background:var(--deep); color:#dfeaea;
  border-top:1px solid var(--deep-2); border-bottom:1px solid var(--deep-2);
  padding:34px 0; position:relative; overflow:hidden;
}
.statline__grid{
  display:grid; grid-template-columns:repeat(4,1fr);
  gap:1px; background:rgba(255,255,255,.1);
}
.statline__grid--values{grid-template-columns:repeat(3,1fr)}
.statline__grid--values > div{padding:14px 28px}
.statline__grid--values b{
  font-family:var(--ff-display); font-size:clamp(1.6rem,2.4vw,2.1rem);
  color:#fff; letter-spacing:-.01em; text-transform:uppercase;
}
.statline__grid--values b.num{color:var(--red)}
.statline__grid--values span{
  font-size:.86rem; line-height:1.5; letter-spacing:.04em;
  text-transform:none; color:#bdd6d7; font-weight:500; max-width:36ch;
}
.statline__grid > div{
  background:var(--deep); padding:8px 24px;
  display:flex; flex-direction:column; gap:6px;
}
.statline__grid b{
  font-family:var(--ff-display); font-size:clamp(2rem,3.6vw,2.8rem);
  color:#fff; line-height:1; letter-spacing:-.02em;
}
.statline__grid span{
  font-size:.78rem; letter-spacing:.14em; text-transform:uppercase;
  color:#9fcccd; font-weight:600;
}
.statline__grid .num{color:var(--red)}

/* ---------- Section head ---------- */
.section-head{
  display:grid; grid-template-columns:1.2fr 1fr; gap:clamp(30px,5vw,72px);
  align-items:center; margin-bottom:clamp(40px,5vw,72px);
}
.eyebrow + .section-head{margin-top:14px}
.section-head__title{font-size:clamp(2rem, 4vw, 3.4rem); text-transform:uppercase; line-height:.98}
.section-head__title em{font-style:normal; color:var(--teal)}
.section-head--center{grid-template-columns:1fr; text-align:center; max-width:780px; margin-inline:auto}
.section-head--center .eyebrow{justify-content:center}

/* ---------- Manifesto / two-col rich text ---------- */
.manifesto{
  display:grid; grid-template-columns:1.1fr 1fr; gap:clamp(40px,6vw,90px);
  align-items:start;
}
.manifesto__big{
  font-family:var(--ff-display); font-weight:700;
  font-size:clamp(1.9rem, 3.2vw, 2.7rem);
  text-transform:uppercase; line-height:1.04; letter-spacing:-.015em;
  color:var(--deep);
}
.manifesto__big em{font-style:normal; color:var(--teal)}
.manifesto__body p{color:var(--ink-2); font-size:1.04rem; line-height:1.7}
.manifesto__body p + p{margin-top:18px}
.checks{display:grid; gap:14px; margin-top:28px}
.checks li{
  display:flex; gap:14px; align-items:flex-start;
  font-weight:500; color:var(--ink-2); font-size:.98rem;
}
.checks li svg{flex:0 0 auto; width:22px; height:22px; color:var(--teal); margin-top:2px}
.section--dark .checks li{color:#dfeaea}
.section--dark .checks li svg{color:var(--teal-soft)}

/* ---------- Pillars (servicos main) ---------- */
.pillars{display:grid; grid-template-columns:1fr 1fr; gap:24px}
.pillar{
  position:relative; overflow:hidden;
  background:var(--deep); color:#dfeaea;
  border-radius:var(--r-lg); padding:46px 42px 42px;
  min-height:340px; display:flex; flex-direction:column;
  transition:transform .35s var(--ease);
}
.pillar:hover{transform:translateY(-4px)}
.pillar::before{
  content:""; position:absolute; right:-30%; top:-30%; width:80%; height:80%;
  background:radial-gradient(circle, rgba(33,132,136,.45), transparent 70%);
}
.pillar__num{
  font-family:var(--ff-display); font-size:1rem; font-weight:600;
  letter-spacing:.16em; text-transform:uppercase; color:var(--teal-soft);
  margin-bottom:auto;
}
.pillar__num::before{content:"— "; opacity:.6}
.pillar__title{
  position:relative; font-size:clamp(1.7rem, 2.4vw, 2.2rem);
  color:#fff; text-transform:uppercase; margin-top:28px; line-height:1.05;
}
.pillar__body{position:relative; color:#bdd6d7; font-size:1rem; margin-top:14px; line-height:1.6}
.pillar__cta{
  position:relative; display:inline-flex; align-items:center; gap:8px;
  margin-top:22px; font-weight:600; font-size:.88rem;
  color:#fff; letter-spacing:.06em; text-transform:uppercase;
}
.pillar__cta svg{width:18px; height:18px; transition:transform .25s var(--ease)}
.pillar:hover .pillar__cta svg{transform:translateX(4px)}
.pillar--alt{background:var(--paper-2); color:var(--ink-2)}
.pillar--alt::before{background:radial-gradient(circle, rgba(204,50,48,.18), transparent 70%)}
.pillar--alt .pillar__num{color:var(--red)}
.pillar--alt .pillar__title{color:var(--deep)}
.pillar--alt .pillar__body{color:var(--ink-2)}
.pillar--alt .pillar__cta{color:var(--deep)}

/* ---------- Services offers (dois blocos destaque) ---------- */
.svc-offers{
  display:grid; grid-template-columns:1fr 1fr; gap:14px;
  margin-bottom:56px;
}
.svc-offer{
  border-radius:var(--r-md); padding:36px 32px;
}
.svc-offer--blue{background:var(--deep)}
.svc-offer--red{background:var(--red)}
.svc-offer__name{
  font-family:var(--ff-display); font-weight:700; line-height:1.2;
  font-size:clamp(1.15rem,1.6vw,1.4rem); color:#fff;
  margin-bottom:10px;
}
.svc-offer__desc{font-size:.88rem; color:rgba(255,255,255,.65); line-height:1.6}

/* ---------- Services checklist ---------- */
.svc-check{
  display:grid; grid-template-columns:1fr 1fr; column-gap:56px;
}
.svc-check__item{
  display:flex; align-items:flex-start; gap:16px;
  padding:24px 0;
}
.svc-check__item:nth-child(n+3){border-top:1px solid var(--line)}
.svc-check__item:nth-child(-n+2){padding-top:0}
.svc-check__ic{
  flex:0 0 40px; height:40px; border-radius:10px;
  background:rgba(33,132,136,.1); color:var(--teal);
  display:grid; place-items:center; margin-top:2px;
}
.svc-check__ic svg{width:20px; height:20px}
.svc-check__body strong{
  display:block; color:var(--deep);
  font-size:1rem; font-weight:700; margin-bottom:4px; line-height:1.2;
}
.svc-check__body span{font-size:.9rem; color:var(--muted); line-height:1.5}

/* ---------- Bento (categorias de produtos) ---------- */
.bento{
  display:grid; grid-template-columns:repeat(12,1fr); gap:14px;
  grid-auto-rows:minmax(170px, auto);
}
.bento__card{
  position:relative; overflow:hidden;
  background:var(--paper); border:1px solid var(--line);
  border-radius:var(--r-md); padding:30px 28px;
  display:flex; flex-direction:column; justify-content:space-between; gap:20px;
  transition:transform .3s var(--ease), border-color .3s, box-shadow .3s var(--ease);
  text-decoration:none; color:inherit;
}
.bento__card:hover{transform:translateY(-4px); box-shadow:var(--shadow-md); border-color:var(--teal-soft)}
.bento__card .top{display:flex; justify-content:space-between; align-items:flex-start}
.bento__card .ic{
  width:54px; height:54px; border-radius:14px;
  background:var(--paper-2); color:var(--teal);
  display:grid; place-items:center;
}
.bento__card .ic svg{width:26px; height:26px}
.bento__card .count{
  font-family:var(--ff-display); font-size:.78rem; font-weight:600;
  letter-spacing:.16em; color:var(--red); text-transform:uppercase;
}
.bento__card h3{font-size:1.3rem; color:var(--deep); text-transform:uppercase; margin-bottom:6px; line-height:1.05; letter-spacing:-.01em}
.bento__card p{font-size:.92rem; color:var(--muted); line-height:1.55}
.bento__card .arrow{
  display:inline-flex; align-items:center; gap:8px; margin-top:16px;
  font-size:.82rem; font-weight:600; letter-spacing:.06em;
  text-transform:uppercase; color:var(--deep);
}
.bento__card .arrow svg{width:16px; height:16px; transition:transform .25s var(--ease)}
.bento__card:hover .arrow svg{transform:translateX(4px)}

.bento__card--dark{background:var(--deep); color:#dfeaea}
.bento__card--dark h3{color:#fff}
.bento__card--dark p{color:#a8c0c1}
.bento__card--dark .ic{background:rgba(255,255,255,.08); color:var(--teal-soft)}
.bento__card--dark .arrow{color:#fff}

.bento__card--red{background:var(--red); color:#fff}
.bento__card--red h3{color:#fff}
.bento__card--red p{color:rgba(255,255,255,.85)}
.bento__card--red .ic{background:rgba(255,255,255,.18); color:#fff}
.bento__card--red .arrow{color:#fff}
.bento__card--red .count{color:#fff; opacity:.85}

/* Tamanhos no grid */
.bento__card.col-4{grid-column:span 4}
.bento__card.col-6{grid-column:span 6}
.bento__card.col-8{grid-column:span 8}
.bento__card.col-12{grid-column:span 12}
.bento__card.row-2{grid-row:span 2}

/* ---------- Diferenciais (numbered list) ---------- */
.diffs{
  display:grid; grid-template-columns:repeat(3,1fr);
  gap:1px; background:rgba(255,255,255,.12);
  border-radius:var(--r-md); overflow:hidden;
}
.diff{
  background:var(--deep); color:#dfeaea;
  padding:42px 32px; min-height:240px;
  display:flex; flex-direction:column; gap:14px;
}
.diff__num{
  font-family:var(--ff-display); font-weight:700;
  font-size:3.2rem; color:var(--red); line-height:.9;
}
.diff h3{color:#fff; text-transform:uppercase; font-size:1.15rem; line-height:1.1; letter-spacing:-.005em}
.diff p{color:#bdd6d7; font-size:.95rem; line-height:1.55}

/* ---------- Clients ---------- */
.clients{display:grid; grid-template-columns:repeat(4,1fr); gap:16px; align-items:start}
.client-item{display:flex; flex-direction:column; gap:10px}
.client-logo{
  background:#9ECDCF; border:1px solid rgba(3,68,71,.12);
  border-radius:var(--r-md);
  display:flex; align-items:center; justify-content:center;
  height:150px; padding:10px; overflow:hidden;
  transition:transform .25s var(--ease), box-shadow .25s;
  text-decoration:none;
}
.client-logo:hover{transform:translateY(-3px); box-shadow:0 8px 24px rgba(3,68,71,.2)}
.client-logo img{width:74%; height:auto; display:block}
/* Per-logo width — controls visual size; card clips excess height via overflow:hidden */
.client-logo--abeas img    {width:68%}
.client-logo--medial img   {width:76%}
.client-logo--oncologia img{width:77%}
.client-logo--julio img    {width:77%}
.client-logo--uei img      {width:74%}
.client-logo--porto img    {width:77%}
.client-logo--hoesp img    {width:63%}
/* Caption outside cards */
.client-caption{padding:0 2px}
.client-caption__name{
  font-size:.68rem; font-weight:700; font-family:var(--ff-display); letter-spacing:.04em;
  color:var(--deep); line-height:1.3; text-transform:uppercase; display:block;
}
.client-caption__loc{
  font-size:.6rem; font-weight:500; color:var(--muted);
  font-family:var(--ff-body); display:block; margin-top:2px;
}
/* CTA card */
.client-logo--cta{
  background:var(--red); border-color:transparent; gap:10px; cursor:pointer; flex-direction:column;
}
.client-logo--cta:hover{background:#b82b29; transform:translateY(-3px); box-shadow:0 8px 28px rgba(204,50,48,.45)}
.client-logo--cta svg{width:28px; height:28px; color:#fff; opacity:.9}
.client-logo--cta strong{font-size:.92rem; font-weight:700; font-family:var(--ff-display); color:#fff; text-align:center; line-height:1.2}
.client-logo--cta span{font-size:.74rem; color:rgba(255,255,255,.82); text-align:center; line-height:1.3}

/* ---------- Process timeline ---------- */
.process{display:grid; grid-template-columns:repeat(4,1fr); gap:24px; position:relative}
.process::before{
  content:""; position:absolute; left:6%; right:6%; top:32px;
  height:1px; background:repeating-linear-gradient(90deg, var(--paper-3) 0 8px, transparent 8px 14px);
  z-index:0;
}
.proc{
  position:relative; z-index:1; padding-top:0;
}
.proc__num{
  display:grid; place-items:center;
  width:64px; height:64px; border-radius:50%;
  background:var(--paper); border:1px solid var(--line);
  font-family:var(--ff-display); font-weight:700; font-size:1.4rem;
  color:var(--deep); margin-bottom:20px;
}
.proc.is-active .proc__num{background:var(--red); color:#fff; border-color:var(--red)}
.proc h3{font-size:1.05rem; color:var(--deep); margin-bottom:8px}
.proc p{font-size:.9rem; color:var(--muted); line-height:1.55}

/* ---------- Quote slab ---------- */
.quote{
  position:relative; padding:clamp(50px,7vw,90px);
  background:var(--ink); color:#fff;
  border-radius:var(--r-lg); overflow:hidden;
}
.quote::before{
  content:""; position:absolute; inset:0; opacity:.18;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='80' height='80' viewBox='0 0 80 80'%3E%3Cg fill='none' stroke='%23ffffff' stroke-opacity='0.06' stroke-width='1'%3E%3Cpath d='M40 4v72M4 40h72'/%3E%3C/g%3E%3C/svg%3E");
}
.quote__mark{
  font-family:var(--ff-display); font-weight:700; font-size:7rem;
  line-height:.7; color:var(--red); margin-bottom:8px;
  position:relative;
}
.quote__txt{
  position:relative; font-family:var(--ff-display); font-weight:600;
  font-size:clamp(1.5rem, 2.6vw, 2.2rem); text-transform:uppercase;
  line-height:1.15; letter-spacing:-.01em; max-width:1080px;
}
.quote__txt em{font-style:normal; color:var(--teal-soft)}
.quote__src{
  position:relative; margin-top:32px; font-size:.78rem; letter-spacing:.18em;
  text-transform:uppercase; color:#9fcccd;
}

/* ---------- WhatsApp Block (contact section) ---------- */
.wa-block{
  display:grid; grid-template-columns:1.1fr 1fr;
  gap:0;
  background:var(--paper-2);
  border-radius:var(--r-lg); overflow:hidden;
  border:1px solid var(--line);
}
.wa-block__left{padding:clamp(40px,5vw,72px); display:flex; flex-direction:column; justify-content:center}
.wa-block__right{
  position:relative; background:var(--deep); color:#fff;
  padding:clamp(40px,5vw,72px); display:flex; flex-direction:column; justify-content:center;
  overflow:hidden;
}
.wa-block__right::before{
  content:""; position:absolute; right:-25%; bottom:-30%; width:90%; height:90%;
  background:radial-gradient(circle, rgba(34,194,94,.35), transparent 65%);
}
.wa-block__right .badge{
  position:relative;
  display:inline-flex; align-items:center; gap:8px;
  font-size:.72rem; font-weight:700; letter-spacing:.22em;
  text-transform:uppercase; color:var(--wa);
  background:rgba(34,194,94,.16); padding:8px 16px; border-radius:var(--r-pill);
  margin-bottom:20px; align-self:flex-start;
}
.wa-block__right .badge .dot{
  width:8px; height:8px; background:var(--wa); animation:pulse 1.8s ease-in-out infinite;
}
.wa-block__right h2{position:relative; font-size:clamp(1.8rem,3.2vw,2.6rem); text-transform:uppercase; color:#fff; line-height:1.02; margin-bottom:16px}
.wa-block__right p{position:relative; color:#cfe1e2; font-size:1rem; line-height:1.6; margin-bottom:28px; max-width:42ch}
.wa-block__right .btn{position:relative; align-self:flex-start}

/* Contact channels */
.cch{display:grid; gap:14px}
.cch__item{
  display:flex; gap:18px; align-items:flex-start;
  background:var(--paper); border:1px solid var(--line);
  padding:20px; border-radius:var(--r-md);
  transition:transform .25s var(--ease), border-color .25s;
  color:inherit;
}
.cch__item:hover{transform:translateY(-2px); border-color:var(--teal-soft)}
.cch__item .ic{
  flex:0 0 auto; width:46px; height:46px; border-radius:12px;
  background:var(--paper-2); color:var(--teal);
  display:grid; place-items:center;
}
.cch__item .ic svg{width:22px; height:22px}
.cch__item .label{font-size:.7rem; font-weight:700; letter-spacing:.2em; text-transform:uppercase; color:var(--muted); margin-bottom:6px}
.cch__item b{display:block; font-family:var(--ff-display); font-weight:600; color:var(--deep); font-size:1.05rem; letter-spacing:-.005em; line-height:1.2}
.cch__item span{font-size:.88rem; color:var(--muted); display:block; margin-top:4px}
.cch__item.is-wa .ic{background:rgba(34,194,94,.12); color:var(--wa-2)}

/* ---------- Form (contact) ---------- */
.form{
  background:var(--paper); border:1px solid var(--line);
  border-radius:var(--r-md); padding:clamp(28px,3vw,40px);
}
.form__title{
  font-family:var(--ff-display); font-weight:700; font-size:1.4rem;
  color:var(--deep); text-transform:uppercase; letter-spacing:-.005em;
  margin-bottom:6px;
}
.form__hint{color:var(--muted); font-size:.9rem; margin-bottom:24px}
.field{margin-bottom:16px}
.field label{
  display:block; font-weight:600; font-size:.78rem;
  letter-spacing:.14em; text-transform:uppercase;
  color:var(--ink-2); margin-bottom:8px;
}
.field input, .field select, .field textarea{
  width:100%; font-family:var(--ff-body); font-size:.94rem; color:var(--ink);
  padding:14px 16px; background:#fff;
  border:1px solid var(--line); border-radius:12px;
  transition:border-color .2s, box-shadow .2s;
}
.field input:focus, .field select:focus, .field textarea:focus{
  outline:none; border-color:var(--teal);
  box-shadow:0 0 0 4px rgba(33,132,136,.15);
}
.field textarea{min-height:130px; resize:vertical}
.form .row{display:grid; grid-template-columns:1fr 1fr; gap:14px}

/* ---------- Footer ---------- */
.footer{
  background:var(--ink); color:#a8c0c1;
  padding:40px 0 28px;
  position:relative; overflow:hidden;
}
.footer__top{
  position:relative; display:flex;
  align-items:center; justify-content:space-between;
  gap:32px; padding-bottom:14px; border-bottom:1px solid rgba(255,255,255,.1);
}
.footer .brand__name{color:#fff}
.footer .brand__name span{color:var(--teal-soft)}
.footer .brand__tag{color:#7e9899}
.footer__lead{display:none}
.footer__dots{display:none}
.footer h4{display:none}
.footer__links{display:none}
.footer__contact{display:flex; flex-direction:row; align-items:center; gap:24px}
.footer__contact div{
  display:flex; flex-direction:row; gap:8px; align-items:center;
  font-size:.84rem; color:#a8c0c1; white-space:nowrap; line-height:1;
}
.footer__contact a{color:#a8c0c1; transition:color .2s}
.footer__contact a:hover{color:#fff}
.footer__contact svg{
  width:14px; height:14px; flex:0 0 auto;
  color:var(--teal-soft);
}
.footer__bot{
  position:relative; padding-top:12px;
  display:flex; justify-content:space-between; flex-wrap:wrap; gap:10px;
  font-size:.74rem; color:#7e9899;
}
.footer__bot a:hover{color:#fff}

/* ---------- Pulse no nav btn ---------- */
.nav__cta .btn--wa, .nav__cta .btn{position:relative; padding-left:34px}
.nav__cta .btn--wa::before, .nav__cta .btn::before{
  content:""; position:absolute; left:14px; top:50%;
  width:8px; height:8px; border-radius:50%; background:#fff;
  transform:translateY(-50%);
  animation:wa-nav-pulse 1.4s ease-in-out infinite;
  box-shadow:0 0 0 0 rgba(255,255,255,.7);
}
@keyframes wa-nav-pulse{
  0%,100%{opacity:1; transform:translateY(-50%) scale(1); box-shadow:0 0 0 0 rgba(255,255,255,.7)}
  50%{opacity:.45; transform:translateY(-50%) scale(.7); box-shadow:0 0 0 6px rgba(255,255,255,0)}
}

/* ---------- Floating WhatsApp ---------- */
.wa-float{
  position:fixed; right:22px; bottom:22px; z-index:60;
  width:60px; height:60px;
  display:flex; align-items:center; justify-content:center;
  background:var(--wa); color:#fff;
  border-radius:50%;
  box-shadow:0 16px 36px -12px rgba(34,194,94,.6);
  transition:transform .25s var(--ease), box-shadow .25s var(--ease);
}
.wa-float svg{width:26px; height:26px; flex:0 0 auto}
.wa-float .label{
  position:absolute; right:74px; top:50%; transform:translateY(-50%) translateX(8px);
  background:#fff; color:var(--ink); font-weight:600; font-size:.86rem;
  padding:9px 16px; border-radius:var(--r-pill);
  white-space:nowrap; pointer-events:none;
  opacity:0;
  box-shadow:0 12px 28px -10px rgba(0,0,0,.25), 0 0 0 1px rgba(0,0,0,.05);
  transition:opacity .25s var(--ease), transform .3s var(--ease);
}
.wa-float:hover{transform:translateY(-3px)}
.wa-float:hover .label{opacity:1; transform:translateY(-50%) translateX(0)}
.wa-float .pulse{
  position:absolute; inset:-4px; border-radius:inherit;
  border:2px solid var(--wa); opacity:.6;
  animation:pulse-ring 2.4s ease-out infinite; pointer-events:none;
}
@keyframes pulse-ring{
  0%{transform:scale(.9); opacity:.6}
  100%{transform:scale(1.5); opacity:0}
}
@keyframes pulse{
  0%,100%{opacity:1; transform:scale(1)}
  50%{opacity:.4; transform:scale(.85)}
}

/* ---------- Hero: Brasil integrado ---------- */
.hero__visual--brazil{
  position:relative; aspect-ratio:auto; max-width:none;
  margin-inline:0; display:flex; align-items:center; justify-content:center;
}
.hero__brazil{
  position:relative; width:100%; max-width:520px; margin-inline:auto;
}
.hero__brazil-img{
  width:100%; height:auto; display:block;
  /* 3D look: perspective tilt + layered shadow */
  transform:perspective(1400px) rotateY(-12deg) rotateX(6deg);
  transform-origin:center center;
  filter:
    drop-shadow(0 1px 0 rgba(33,132,136,.4))
    drop-shadow(0 24px 28px rgba(3,68,71,.28))
    drop-shadow(0 8px 12px rgba(3,68,71,.18));
  transition:transform .8s var(--ease);
}
.hero__brazil:hover .hero__brazil-img{
  transform:perspective(1400px) rotateY(-6deg) rotateX(3deg);
}
.hero__brazil-tag{
  position:absolute;
  left:50%; top:42%; transform:translate(-50%, -50%);
  display:inline-flex; align-items:center; gap:10px;
  background:#fff; color:var(--deep);
  font-family:var(--ff-body); font-weight:700; font-size:.74rem;
  letter-spacing:.2em; text-transform:uppercase; white-space:nowrap;
  padding:11px 18px; border-radius:var(--r-pill);
  box-shadow:
    0 14px 28px -8px rgba(3,68,71,.25),
    0 0 0 1px rgba(3,68,71,.06);
}
.hero__brazil-pulse{
  width:8px; height:8px; border-radius:50%;
  background:var(--red); flex:0 0 auto;
  animation:hero-brazil-pulse 1.5s ease-in-out infinite;
  box-shadow:0 0 0 0 rgba(204,50,48,.55);
}
@keyframes hero-brazil-pulse{
  0%,100%{opacity:1; transform:scale(1); box-shadow:0 0 0 0 rgba(204,50,48,.55)}
  50%{opacity:.65; transform:scale(.7); box-shadow:0 0 0 6px rgba(204,50,48,0)}
}
@media (max-width: 1080px){
  .hero__brazil{max-width:380px}
}
@media (prefers-reduced-motion: reduce){
  .hero__brazil-img{transform:none}
  .hero__brazil-pulse{animation:none}
}

/* ---------- Sobre (integrado ao hero) ---------- */
.section--about{
  padding-block:clamp(56px, 6vw, 84px) clamp(72px, 9vw, 120px);
}
.about__inner{
  max-width:1080px; margin-inline:auto;
  display:flex; flex-direction:column; gap:48px;
}
.about__inner .eyebrow{align-self:flex-start}
.about__phrase{
  font-family:var(--ff-display); font-weight:600;
  font-size:clamp(1.8rem, 3.2vw, 2.6rem);
  line-height:1.15; letter-spacing:-.015em;
  color:var(--deep); max-width:30ch;
}
.about__phrase em{font-style:normal; color:var(--teal)}
.about__values{
  display:grid; grid-template-columns:repeat(4, 1fr); gap:18px;
  padding-top:8px; border-top:1px solid var(--line);
  margin-top:8px;
}
.about-val{
  display:flex; flex-direction:column; gap:10px;
  padding-top:24px;
}
.about-val__ic{
  width:42px; height:42px; border-radius:12px;
  background:rgba(33,132,136,.1); color:var(--teal);
  display:grid; place-items:center; margin-bottom:4px;
}
.about-val__ic svg{width:22px; height:22px}
.about-val b{
  display:block; font-family:var(--ff-display); font-weight:700;
  color:var(--deep); font-size:1rem; line-height:1.2;
}
.about-val span{
  color:var(--muted); font-size:.9rem; line-height:1.5;
}

/* ---------- Hero map (Brasil) ---------- */
.hero__visual--map{aspect-ratio:auto; max-width:520px}
.brmap{
  position:relative;
  background:linear-gradient(155deg, #04545a 0%, var(--deep) 55%, #022e31 100%);
  border-radius:var(--r-lg);
  padding:28px 28px 24px;
  box-shadow:var(--shadow-deep);
  overflow:hidden;
  color:#dfeaea;
}
.brmap::before{
  content:""; position:absolute; right:-30%; bottom:-30%; width:70%; height:70%;
  background:radial-gradient(circle, rgba(204,50,48,.22), transparent 65%);
  pointer-events:none;
}
.brmap__head{
  position:relative; display:flex; align-items:center; justify-content:space-between;
  gap:12px; margin-bottom:14px; flex-wrap:wrap;
}
.brmap__tag{
  display:inline-flex; align-items:center; gap:10px;
  font-family:var(--ff-body); font-weight:700; font-size:.72rem;
  letter-spacing:.22em; text-transform:uppercase;
  color:#fff; background:rgba(255,255,255,.08);
  border:1px solid rgba(255,255,255,.18);
  padding:7px 14px; border-radius:var(--r-pill);
}
.brmap__tag .dot{
  width:8px; height:8px; background:var(--red);
  animation:brmap-pulse 1.6s ease-in-out infinite;
}
.brmap__sub{
  font-size:.72rem; font-weight:600; letter-spacing:.16em;
  text-transform:uppercase; color:#9fcccd;
}
.brmap__svg{
  position:relative; width:100%; height:auto; display:block;
  max-height:340px;
}
.brmap__pin .brmap__ring{
  fill:rgba(204,50,48,.18);
  stroke:var(--red); stroke-width:1.5;
  transform-origin:center; transform-box:fill-box;
  animation:brmap-pulse-ring 2.4s ease-out infinite;
}
.brmap__pin .brmap__dot{
  fill:var(--red);
  filter:drop-shadow(0 0 6px rgba(204,50,48,.7));
  transition:r .25s var(--ease);
}
.brmap__pin--hq .brmap__dot{fill:#fff}
.brmap__pin--hq .brmap__ring{
  fill:rgba(255,255,255,.18);
  stroke:#fff;
}
.brmap__hq{
  fill:var(--red); font-family:var(--ff-display);
  font-size:9px; font-weight:700; pointer-events:none;
  dominant-baseline:central;
}
.brmap__pin.is-active .brmap__dot,
.brmap__pin:hover .brmap__dot{r:8}
.brmap__pin.is-active .brmap__ring,
.brmap__pin:hover .brmap__ring{r:18; stroke-width:2}
@keyframes brmap-pulse-ring{
  0%{r:8; opacity:.7}
  100%{r:22; opacity:0}
}
.brmap__pin--hq .brmap__ring{animation:none}
@keyframes brmap-pulse{
  0%,100%{transform:scale(1); opacity:1}
  50%{transform:scale(.5); opacity:.4}
}

.brmap__cities{
  position:relative;
  display:grid; grid-template-columns:1fr 1fr; gap:8px 14px;
  margin-top:14px; padding-top:14px;
  border-top:1px solid rgba(255,255,255,.1);
}
.brmap__cities li{
  display:flex; align-items:center; gap:10px;
  font-family:var(--ff-body); cursor:default;
  padding:6px 4px; border-radius:8px;
  transition:background .2s;
}
.brmap__cities li:hover,
.brmap__cities li.is-active{background:rgba(255,255,255,.06)}
.brmap__city-dot{
  width:8px; height:8px; border-radius:50%; background:var(--red);
  box-shadow:0 0 0 3px rgba(204,50,48,.22);
  flex:0 0 auto;
}
.brmap__cities .is-hq .brmap__city-dot{
  background:#fff; box-shadow:0 0 0 3px rgba(255,255,255,.22);
}
.brmap__cities b{
  display:block; font-family:var(--ff-display); font-weight:600;
  color:#fff; font-size:.9rem; line-height:1.1; letter-spacing:-.005em;
}
.brmap__cities em{
  font-style:normal; font-size:.72rem; letter-spacing:.14em;
  text-transform:uppercase; color:#9fcccd; font-weight:600;
}

/* ---------- Marquee (substitui statline) ---------- */
.marquee{
  background:var(--deep); color:#fff;
  padding:28px 0; overflow:hidden; position:relative;
  border-top:1px solid var(--deep-2); border-bottom:1px solid var(--deep-2);
}
.marquee::before,
.marquee::after{
  content:""; position:absolute; top:0; bottom:0; width:80px;
  z-index:2; pointer-events:none;
}
.marquee::before{left:0; background:linear-gradient(90deg, var(--deep), transparent)}
.marquee::after{right:0; background:linear-gradient(-90deg, var(--deep), transparent)}
.marquee__track{
  display:flex; align-items:center; gap:36px;
  width:max-content;
  animation:marquee-scroll 38s linear infinite;
}
.marquee__item{
  font-family:var(--ff-display); font-weight:700;
  font-size:clamp(1.4rem, 2.4vw, 2rem);
  letter-spacing:.02em; text-transform:uppercase;
  white-space:nowrap; color:#fff;
}
.marquee__sep{display:inline-flex; align-items:center}
.marquee__sep .dot{width:10px; height:10px}
@keyframes marquee-scroll{
  from{transform:translateX(0)}
  to{transform:translateX(-50%)}
}
@media (prefers-reduced-motion:reduce){
  .marquee__track{animation:none}
}

/* ---------- Nav: link de Suporte ---------- */
.nav__support{
  display:inline-flex !important; align-items:center; gap:8px;
  font-size:.84rem !important; font-weight:600 !important;
  color:var(--red) !important;
  padding:9px 14px !important; border-radius:var(--r-pill);
  border:1px solid rgba(204,50,48,.25);
  background:rgba(204,50,48,.06) !important;
  margin-left:6px;
  transition:background .2s, color .2s, border-color .2s;
}
.nav__support:hover,
.nav__support.is-active{
  background:var(--red) !important; color:#fff !important; border-color:var(--red);
}
.support-dot{
  width:7px; height:7px; border-radius:50%; background:var(--red);
  animation:support-pulse 1.4s ease-in-out infinite; flex:0 0 auto;
}
.nav__support:hover .support-dot,
.nav__support.is-active .support-dot{background:#fff}
@keyframes support-pulse{
  0%,100%{transform:scale(1); opacity:1}
  50%{transform:scale(.5); opacity:.35}
}

/* ============================================================
   PÁGINA SUPORTE
   ============================================================ */
.page-support{background:var(--paper)}

.support-hero{
  position:relative; overflow:hidden;
  padding-block:clamp(40px,5vw,72px) clamp(60px,7vw,100px);
  background:
    radial-gradient(900px 480px at 90% -10%, rgba(204,50,48,.12), transparent 60%),
    radial-gradient(700px 420px at -5% 110%, rgba(33,132,136,.08), transparent 60%),
    var(--paper);
  border-bottom:1px solid var(--line);
}
.support-hero .crumbs{margin-bottom:36px}
.support-hero__grid{
  display:grid; grid-template-columns:1.05fr 1fr;
  gap:clamp(36px,5vw,72px); align-items:start;
}
.support-hero__copy{padding-top:8px}
.support-hero__badge{
  display:inline-flex; align-items:center; gap:10px;
  font-family:var(--ff-body); font-weight:700; font-size:.72rem;
  letter-spacing:.22em; text-transform:uppercase; color:var(--red);
  background:rgba(204,50,48,.08);
  border:1px solid rgba(204,50,48,.28);
  padding:9px 16px; border-radius:var(--r-pill);
  margin-bottom:24px;
}
.support-hero__title{
  font-family:var(--ff-display); font-weight:700;
  font-size:clamp(2.2rem, 5vw, 3.8rem); line-height:.98;
  text-transform:uppercase; color:var(--deep); letter-spacing:-.02em;
  margin-bottom:22px;
}
.support-hero__title em{font-style:normal; color:var(--red)}
.support-hero__sub{
  font-size:clamp(1rem,1.2vw,1.12rem); color:var(--ink-2);
  line-height:1.55; max-width:50ch; margin-bottom:36px;
}
.support-hero__steps{
  display:grid; gap:12px; margin-bottom:14px;
}
.support-hero__steps li{
  display:grid; grid-template-columns:44px 1fr; gap:16px; align-items:center;
  padding:14px 18px; border:1px solid rgba(3,68,71,.09);
  border-radius:var(--r-md); background:rgba(255,255,255,.55);
  transition:border-color .2s var(--ease), background .2s var(--ease), transform .2s var(--ease);
}
.support-hero__steps li:hover{
  border-color:rgba(33,132,136,.32);
  background:rgba(255,255,255,.85);
}
.support-hero__steps .step-num{
  font-family:var(--ff-display); font-weight:700; font-size:1.25rem;
  color:var(--red); letter-spacing:-.01em; line-height:1;
  text-align:center;
}
.support-hero__steps b{
  display:block; font-family:var(--ff-display); font-weight:600;
  color:var(--deep); font-size:1.35rem; line-height:1.1; letter-spacing:-.01em;
  margin-bottom:0;
}
.support-hero__steps span{color:var(--muted); font-size:.86rem; line-height:1.5}
.support-hero__direct{
  display:flex; align-items:center; gap:14px; flex-wrap:wrap;
  padding-top:4px;
}
.support-direct{
  display:inline-flex; align-items:center; gap:8px;
  font-weight:600; font-size:.92rem; color:var(--wa-2);
  text-decoration:underline; text-decoration-color:rgba(34,194,94,.4);
  text-underline-offset:4px;
}
.support-direct svg{width:18px; height:18px}
.support-direct:hover{color:var(--deep); text-decoration-color:var(--deep)}

.support-hero__tips{
  margin-top:36px;
  padding:24px 26px 26px;
  background:rgba(33,132,136,.05);
  border:1px solid rgba(33,132,136,.14);
  border-left:3px solid var(--teal);
  border-radius:var(--r-md);
}
.support-hero__tips .eyebrow{margin-bottom:12px}
.support-hero__tips-title{
  font-family:var(--ff-display);
  font-weight:700;
  font-size:clamp(1.2rem,1.5vw,1.4rem);
  line-height:1.22; letter-spacing:-.005em;
  color:var(--deep);
  margin:0 0 16px;
}
.support-hero__tips-title em{font-style:normal; color:var(--teal)}
.support-hero__tips .support-checklist{margin-top:0}
.support-hero__tips .support-checklist li{
  font-size:.93rem; color:var(--ink-2);
}
.support-hero__tips .support-checklist li svg{width:18px; height:18px}

/* Steps block — "Como funciona" (catálogo) */
.steps-block{
  padding:24px 26px 26px;
  background:rgba(33,132,136,.05);
  border:1px solid rgba(33,132,136,.14);
  border-left:3px solid var(--teal);
  border-radius:var(--r-md);
  margin-left:auto;
}
.steps-block .eyebrow{display:block; margin-bottom:20px}
.steps{display:flex; flex-direction:column}
.step{display:flex; gap:16px}
.step__marker{display:flex; flex-direction:column; align-items:center; flex-shrink:0; width:32px}
.step__num{
  width:32px; height:32px; border-radius:50%;
  background:var(--teal); color:#fff;
  font-family:var(--ff-head); font-size:.82rem; font-weight:700;
  display:flex; align-items:center; justify-content:center;
  flex-shrink:0; box-shadow:0 2px 8px rgba(33,132,136,.25);
}
.step__line{width:2px; flex:1; background:rgba(33,132,136,.18); margin:5px 0; min-height:18px}
.step__content{padding-bottom:20px; padding-top:5px}
.step:last-child .step__content{padding-bottom:0}
.step__content strong{display:block; font-size:.9rem; font-weight:700; color:var(--ink); line-height:1.3; margin-bottom:3px}
.step__content span{font-size:.82rem; color:var(--muted); line-height:1.5}

/* How strip — faixa horizontal de passos (catálogo) */
.how-strip{
  background:var(--deep);
  padding:clamp(28px,3.5vw,40px) 0;
  margin-bottom:clamp(32px,4vw,56px);
}
.how-strip__label{
  font-size:.72rem; font-weight:600; letter-spacing:.1em; text-transform:uppercase;
  color:rgba(255,255,255,.4); margin:0 0 20px;
}
.how-strip__steps{
  display:grid; grid-template-columns:repeat(3,1fr); gap:0;
}
.how-step{
  display:flex; align-items:flex-start; gap:16px;
  padding:0 clamp(20px,3vw,40px);
  border-right:1px solid rgba(255,255,255,.1);
}
.how-step:first-child{padding-left:0}
.how-step:last-child{border-right:none}
.how-step__num{
  width:34px; height:34px; border-radius:50%;
  background:rgba(255,255,255,.1); border:1.5px solid rgba(255,255,255,.22);
  color:#fff; font-family:var(--ff-head); font-size:.85rem; font-weight:700;
  display:flex; align-items:center; justify-content:center; flex-shrink:0;
}
.how-step__content strong{display:block; color:#fff; font-size:1rem; font-weight:700; margin-bottom:5px; line-height:1.3}
.how-step__content span{color:rgba(255,255,255,.62); font-size:.88rem; line-height:1.55}

/* Suporte form */
.support-hero__form-wrap{
  position:sticky; top:96px;
}
.support-form{
  background:#fff; border:1px solid var(--line);
  border-radius:var(--r-lg);
  padding:clamp(22px, 2.4vw, 32px) clamp(22px, 2.4vw, 32px) clamp(40px, 4vw, 56px);
  box-shadow:var(--shadow-md);
}
.support-form__head{
  margin-bottom:18px;
  padding-bottom:16px;
  border-bottom:1px solid rgba(3,68,71,.08);
}
.support-form__tag{
  display:inline-flex; align-items:center; gap:8px;
  font-size:.68rem; font-weight:700; letter-spacing:.2em;
  text-transform:uppercase; color:var(--red);
  background:rgba(204,50,48,.08);
  padding:5px 12px; border-radius:var(--r-pill);
  margin-bottom:10px;
}
.support-form__head h2{
  font-size:clamp(1.5rem,2.4vw,2rem);
  text-transform:uppercase; line-height:1.02; letter-spacing:-.01em;
  color:var(--deep); margin-bottom:6px;
}
.support-form__head p{color:var(--muted); font-size:.88rem}
.support-form__hint{
  font-size:.78rem; color:var(--muted); text-align:center;
  margin-top:14px; line-height:1.5;
}

/* Urgency radio cards */
.urg-grid{display:grid; gap:8px}
.urg{position:relative; cursor:pointer; display:block}
.urg input{position:absolute; opacity:0; pointer-events:none}
.urg span{
  display:block; padding:11px 14px;
  border:1px solid var(--line); border-radius:12px;
  background:#fbfbf8; transition:.2s var(--ease);
  text-transform:none; letter-spacing:0;
}
.urg b{text-transform:uppercase; letter-spacing:.06em}
.urg b{
  display:block; font-family:var(--ff-display); font-weight:600;
  color:var(--deep); font-size:.9rem; line-height:1.2;
  margin-bottom:2px;
}
.urg em{font-style:normal; font-size:.78rem; color:var(--muted); line-height:1.4}
.urg:hover span{border-color:var(--teal-soft); background:#fff}
.urg input:checked + span{
  border-color:var(--red); background:rgba(204,50,48,.04);
  box-shadow:0 0 0 4px rgba(204,50,48,.08);
}
.urg input:focus-visible + span{outline:2px solid var(--teal); outline-offset:2px}

/* Support form fields — vertical rhythm */
.support-form .field{margin-bottom:14px}
.support-form .row{
  display:grid; grid-template-columns:1fr 1fr;
  column-gap:14px; row-gap:14px;
  margin-bottom:14px;
}
.support-form .row .field{margin-bottom:0}
/* Subtle section break between urgency and contact fields */
.support-form > .field:first-of-type{
  margin-bottom:18px;
  padding-bottom:18px;
  border-bottom:1px solid rgba(3,68,71,.08);
}
.support-form label{
  font-weight:600; font-size:.72rem;
  letter-spacing:.14em; text-transform:uppercase;
  color:var(--ink-2); margin-bottom:7px; display:block;
}
.support-form .field input,
.support-form .field select,
.support-form .field textarea{
  padding:10px 14px; font-size:.9rem;
}
.support-form .field textarea{min-height:88px}
.support-form > button[type="submit"]{margin-top:4px}
.support-form__hint{margin-top:10px}

/* Support info section */
.support-info{padding-block:clamp(64px,8vw,108px)}
.support-info__grid{
  display:grid; grid-template-columns:1.1fr 1fr;
  gap:clamp(36px,5vw,72px); align-items:start;
}
.support-checklist{display:grid; gap:14px; margin-top:14px}
.support-checklist li{
  display:flex; gap:14px; align-items:center;
  font-weight:500; color:var(--ink-2); font-size:.98rem;
}
.support-checklist li svg{flex:0 0 auto; width:18px; height:18px; color:var(--teal)}
.support-cards{display:grid; gap:18px}
.support-card{
  background:var(--paper-2); border:1px solid var(--line);
  border-radius:var(--r-md); padding:28px;
  display:grid; gap:8px;
  transition:transform .25s var(--ease), border-color .2s;
}
.support-card:hover{transform:translateY(-3px); border-color:var(--teal-soft)}
.support-card__ic{
  width:48px; height:48px; border-radius:12px;
  background:var(--paper); color:var(--teal);
  display:grid; place-items:center; margin-bottom:8px;
}
.support-card__ic svg{width:22px; height:22px}
.support-card h3{
  font-family:var(--ff-display); font-weight:600; font-size:1.15rem;
  color:var(--deep); letter-spacing:-.005em; line-height:1.1;
}
.support-card p{color:var(--muted); font-size:.92rem; line-height:1.5}
.support-card__note{
  display:inline-block; font-size:.74rem; font-weight:700;
  letter-spacing:.14em; text-transform:uppercase; color:var(--red);
  background:rgba(204,50,48,.08); padding:5px 12px; border-radius:999px;
  margin-top:4px;
}
.support-card__link{
  display:inline-flex; align-items:center; gap:6px;
  margin-top:6px; font-weight:600; color:var(--deep);
  font-size:.92rem;
}
.support-card__link:hover{color:var(--teal)}
.support-card--accent{background:var(--deep); color:#dfeaea; border-color:transparent}
.support-card--accent h3{color:#fff}
.support-card--accent p{color:#bdd6d7}
.support-card--accent .support-card__ic{background:rgba(255,255,255,.1); color:var(--teal-soft)}
.support-card--accent .support-card__link{color:#fff}
.support-card--accent .support-card__link:hover{color:var(--teal-soft)}

/* ---------- Uniform card heights ---------- */
.diff p{min-height:4.6em}
.proc p{min-height:4.2em}
.reveal{opacity:0; transform:translateY(20px); transition:opacity .7s var(--ease), transform .7s var(--ease)}
.reveal.is-in{opacity:1; transform:none}
@media (prefers-reduced-motion:reduce){
  .reveal{opacity:1; transform:none}
  *,*::before,*::after{transition-duration:.01ms !important; animation-duration:.01ms !important}
}

/* ============================================================
   PRODUTOS — página interna
   ============================================================ */
.pagehead{
  background:var(--paper);
  padding-block:clamp(48px,7vw,96px) clamp(36px,5vw,64px);
  border-bottom:1px solid var(--line);
}
.crumbs{
  font-family:var(--ff-body); font-size:.72rem; font-weight:600;
  letter-spacing:.2em; text-transform:uppercase; color:var(--muted);
  margin-bottom:24px; display:flex; align-items:center; gap:8px;
}
.crumbs a{color:var(--teal)}
.crumbs a:hover{color:var(--deep)}
.crumbs .sep{opacity:.4}
.pagehead h1{font-size:clamp(2.6rem,6vw,5rem); color:var(--deep); text-transform:uppercase; line-height:.96; letter-spacing:-.025em; margin-bottom:18px}
.pagehead h1 em{font-style:normal; color:var(--teal)}
.pagehead__lead{font-size:1.1rem; color:var(--ink-2); max-width:64ch; line-height:1.55}

.catnav{
  position:sticky; top:78px; z-index:40;
  background:rgba(250,247,240,.92);
  backdrop-filter:blur(10px); -webkit-backdrop-filter:blur(10px);
  border-top:1px solid var(--line);
  border-bottom:1px solid var(--line);
  padding:14px 0;
}
.catnav__inner{display:flex; gap:8px; overflow-x:auto; scrollbar-width:none; padding-bottom:6px; margin-bottom:-6px}
.catnav__inner::-webkit-scrollbar{display:none}
.catnav a{
  flex:0 0 auto; display:inline-flex; align-items:center; gap:8px;
  padding:9px 16px; border-radius:var(--r-pill);
  background:transparent; border:1px solid var(--line);
  font-weight:600; font-size:.82rem; color:var(--ink-2);
  transition:background .2s, color .2s, border-color .2s;
}
.catnav a:hover{background:var(--deep); color:#fff; border-color:var(--deep)}
.catnav a .tag{font-size:.7rem; color:var(--red); font-weight:700}
.catnav a:hover .tag{color:#fff}

.catblock{margin-bottom:clamp(72px,9vw,120px); scroll-margin-top:160px}
.catblock:last-child{margin-bottom:0}
.section--catalog{padding-top:clamp(32px,4vw,48px); padding-bottom:clamp(24px,3vw,40px)}
.catblock__head{
  margin-bottom:42px;
  padding-bottom:28px; border-bottom:1px solid var(--line);
}
.catblock__body .label{
  font-size:.72rem; font-weight:700; letter-spacing:.22em;
  text-transform:uppercase; color:var(--red); margin-bottom:10px;
}
.catblock__body h2{font-size:clamp(1.6rem,3vw,2.4rem); text-transform:uppercase; line-height:1.02; color:var(--deep); letter-spacing:-.015em}
.catblock__dots{display:flex; gap:7px; align-items:center; margin:14px 0 10px}
.catblock__body p{color:var(--muted); font-size:.95rem; max-width:60ch}
.catblock__count{
  display:flex; flex-direction:column; align-items:flex-end; gap:4px;
}
.catblock__count b{font-family:var(--ff-display); font-size:1.6rem; color:var(--teal); letter-spacing:-.01em}
.catblock__count span{font-size:.72rem; font-weight:600; letter-spacing:.16em; text-transform:uppercase; color:var(--muted)}

.eqgrid{display:grid; grid-template-columns:repeat(3,1fr); gap:18px}
.eqcard{
  background:var(--paper); border:1px solid var(--line);
  border-radius:var(--r-md); padding:24px 24px 60px;
  position:relative; overflow:visible;
  transition:transform .25s var(--ease), border-color .25s, box-shadow .25s var(--ease);
  display:flex; flex-direction:column;
}
.eqcard:hover{transform:translateY(-3px); box-shadow:var(--shadow-sm); border-color:var(--teal)}
.eqcard__head{display:flex; align-items:flex-start; justify-content:space-between; gap:14px; margin-bottom:14px}
.eqcard h3{font-family:var(--ff-display); font-weight:600; font-size:1.08rem; color:var(--deep); letter-spacing:-.005em; line-height:1.15}
.eqcard__tag{
  flex:0 0 auto; font-size:.62rem; font-weight:700; letter-spacing:.16em;
  text-transform:uppercase; padding:5px 10px; border-radius:999px;
  background:var(--paper-2); color:var(--teal);
}
.eqcard p{font-size:.88rem; color:var(--muted); line-height:1.6; flex:1}
.eqcard__meta{
  margin-top:14px; padding-top:14px; border-top:1px dashed var(--line);
  font-size:.72rem; font-weight:600; letter-spacing:.1em; text-transform:uppercase;
  color:var(--teal);
}
.eqcard__cta{
  display:inline-flex; align-items:center; gap:6px;
  margin-top:14px;
  font-size:.74rem; font-weight:700; letter-spacing:.16em;
  text-transform:uppercase; color:var(--deep);
}
.eqcard__cta svg{width:14px; height:14px; transition:transform .25s var(--ease)}
.eqcard__cta:hover svg{transform:translateX(3px)}

.eqcard--wide{grid-column:1/-1; text-align:center; background:var(--paper-2); border-style:dashed}
.eqcard--wide h3{font-size:1.3rem; margin-bottom:6px}
.eqcard--wide p{max-width:60ch; margin-inline:auto}
.eqcard--wide .eqcard__cta{justify-content:center}

/* ---------- Responsivo ---------- */
@media (max-width: 1080px){
  .hero__grid{grid-template-columns:1fr; gap:48px}
  .hero__visual{
    aspect-ratio:auto; max-width:460px;
    display:grid; gap:18px;
  }
  .hero__brand-frame{position:relative; inset:auto; aspect-ratio:1/1}
  .hero__stat-card{
    position:relative; left:auto; right:auto; bottom:auto; top:auto;
    width:100%; min-width:0;
  }
  .manifesto{grid-template-columns:1fr; gap:32px}
  .pillars{grid-template-columns:1fr}
  .wa-block{grid-template-columns:1fr}
  .footer__top{grid-template-columns:1fr 1fr}
  .section-head{grid-template-columns:1fr; gap:18px}
  .clients{grid-template-columns:repeat(3,1fr)}
  .diffs{grid-template-columns:1fr}
  .process{grid-template-columns:repeat(2,1fr); gap:32px}
  .process::before{display:none}
  .eqgrid{grid-template-columns:repeat(2,1fr)}
  .bento{grid-template-columns:repeat(6,1fr)}
  .bento__card.col-4{grid-column:span 6}
  .bento__card.col-6{grid-column:span 6}
  .bento__card.col-8{grid-column:span 6}
  .bento__card.col-12{grid-column:span 6}
}
@media (max-width: 1100px){
  .nav__toggle{display:inline-flex}
  .nav__links{
    position:absolute; left:0; right:0; top:100%;
    flex-direction:column; align-items:stretch; gap:4px;
    background:var(--paper); border-bottom:1px solid var(--line);
    padding:18px var(--gutter) 26px;
    transform:translateY(-12px); opacity:0; visibility:hidden;
    transition:.25s var(--ease); box-shadow:var(--shadow-md);
    max-height:calc(100vh - 78px); overflow-y:auto;
  }
  .nav__links.is-open{transform:none; opacity:1; visibility:visible}
  .nav__links a{padding:14px 18px}
  .nav__cta{margin:8px 0 0}
  .nav__cta .btn{width:100%}
  .hero__stats{display:none}
  .hero__brazil{max-width:320px; margin-top:24px}
  .about__values{grid-template-columns:repeat(2, 1fr)}
  .coverage{grid-template-columns:1fr}
  .coverage__map{display:none}
  .statline__grid{grid-template-columns:repeat(2,1fr)}
  .statline__grid--values{grid-template-columns:1fr}
  .emergency{display:none}
  .support-hero__grid{grid-template-columns:1fr; gap:36px}
  .support-hero__form-wrap{position:static}
  .support-info__grid{grid-template-columns:1fr}
  .support-form .row{grid-template-columns:1fr}
  .svc-offers{grid-template-columns:1fr}
  .svc-check{grid-template-columns:1fr}
  .svc-check__item:nth-child(n+2){border-top:1px solid var(--line)}
  .svc-check__item:nth-child(-n+2){padding-top:24px}
  .svc-check__item:first-child{padding-top:0}
  .clients{grid-template-columns:repeat(2,1fr)}
  .footer__top{grid-template-columns:1fr}
  .catblock__head{padding-bottom:20px}
  .eqgrid{grid-template-columns:1fr}
  .coverage__vals{grid-template-columns:1fr}
  .bento{grid-template-columns:1fr}
  .bento__card.col-4,.bento__card.col-6,.bento__card.col-8,.bento__card.col-12{grid-column:1/-1}
  .form .row{grid-template-columns:1fr}
  .process{grid-template-columns:1fr}
  .wa-float .label{display:none}
  .wa-float{padding:0; border-radius:50%; width:56px; height:56px}
}

/* ---------- Cart / Seleção de equipamentos ---------- */
.eqcard{ cursor:pointer; }
.eqcard.is-selected{
  border-color:var(--teal);
  border-width:2px;
  background:rgba(33,132,136,.05);
  box-shadow:0 0 0 3px rgba(33,132,136,.12);
}
.eqcard__select{
  position:absolute; bottom:16px; right:16px;
  width:28px; height:28px; border-radius:50%;
  border:1.5px solid var(--line); background:var(--paper);
  display:flex; align-items:center; justify-content:center;
  cursor:pointer; transition:background .2s, border-color .2s, transform .2s;
  color:var(--muted); flex-shrink:0;
  z-index:2;
}
.eqcard__select svg{ width:13px; height:13px; transition:opacity .15s; }
.eqcard__select .ico-check{ display:none }
.eqcard__select .ico-plus{ display:block }
.eqcard.is-selected .eqcard__select{
  background:var(--teal); border-color:var(--teal); color:#fff;
}
.eqcard.is-selected .eqcard__select .ico-check{ display:block }
.eqcard.is-selected .eqcard__select .ico-plus{ display:none }
.eqcard__select:hover{ transform:scale(1.15); border-color:var(--teal) }

/* Cart badge flutuante */
.cart-badge{
  position:fixed; bottom:28px; left:50%; transform:translateX(-50%) translateY(20px);
  z-index:55; display:flex; align-items:center; gap:10px;
  background:var(--deep); color:#fff;
  padding:12px 22px; border-radius:var(--r-pill);
  box-shadow:0 12px 32px -8px rgba(3,68,71,.5);
  cursor:pointer; white-space:nowrap;
  opacity:0; pointer-events:none;
  transition:opacity .3s var(--ease), transform .3s var(--ease);
  font-size:.88rem; font-weight:600;
}
.cart-badge.is-visible{
  opacity:1; pointer-events:auto; transform:translateX(-50%) translateY(0);
}
.cart-badge svg{ flex:0 0 auto; color:var(--teal-soft) }
.cart-badge__cta{ color:var(--teal-soft); margin-left:4px }
.cart-badge:hover{ background:#045254 }

/* Seção de proposta */
.cart-section{ background:var(--paper-2); padding-block:clamp(32px,4vw,48px) }
.cart-section__inner{
  display:grid; grid-template-columns:1fr; gap:clamp(32px,5vw,72px); align-items:start;
  max-width:580px; margin-inline:auto;
}
.cart-section__inner.has-selections{
  grid-template-columns:1fr 1fr; max-width:none; margin-inline:0;
}
.cart-section__left{ display:none }
.cart-section__inner.has-selections .cart-section__left{ display:block }
.cart-section__left .form-title,
.cart-section__right .form-title{
  font-family:var(--ff-display); font-weight:700; color:var(--deep);
  font-size:1rem; margin-bottom:20px;
}

/* Lista de itens selecionados */
.cart-list{ display:flex; flex-direction:column; gap:10px }
.cart-empty{ font-size:.88rem; color:var(--muted); font-style:italic }
.cart-item{
  display:flex; align-items:center; gap:12px;
  padding:12px 14px; background:var(--paper);
  border:1px solid var(--line); border-radius:var(--r-md);
}
.cart-item__info{ flex:1; min-width:0 }
.cart-item__name{
  display:block; font-weight:600; font-size:.88rem;
  color:var(--ink); white-space:nowrap; overflow:hidden; text-overflow:ellipsis;
}
.cart-item__cat{ display:block; font-size:.76rem; color:var(--muted); margin-top:2px }
.cart-item__qty{
  display:flex; align-items:center; gap:6px;
  font-size:.88rem; font-weight:600; color:var(--deep);
}
.qty-btn{
  width:24px; height:24px; border-radius:50%;
  border:1.5px solid var(--line); background:var(--paper);
  display:flex; align-items:center; justify-content:center;
  cursor:pointer; font-size:.9rem; line-height:1;
  color:var(--ink-2); transition:border-color .2s, background .2s;
}
.qty-btn:hover{ border-color:var(--teal); background:rgba(33,132,136,.08) }
.cart-item__remove{
  width:24px; height:24px; border-radius:50%; border:none;
  background:transparent; color:var(--muted); cursor:pointer;
  font-size:1.1rem; line-height:1; display:flex; align-items:center; justify-content:center;
  transition:color .2s, background .2s; flex-shrink:0;
}
.cart-item__remove:hover{ color:var(--red); background:rgba(204,50,48,.08) }

@media(max-width:768px){
  .cart-section__inner,
  .cart-section__inner.has-selections{ grid-template-columns:1fr; max-width:none; margin-inline:0 }
  .cart-badge{ font-size:.82rem; padding:10px 18px }
}

/* ---------- Brands (multimarcas) ---------- */
.brands{display:grid; grid-template-columns:repeat(5,1fr); gap:12px}
.brand-logo{
  background:#fff; border:1px solid var(--line);
  border-radius:var(--r-md);
  display:flex; align-items:center; justify-content:center;
  padding:22px 20px; overflow:hidden;
  transition:transform .25s var(--ease), box-shadow .25s;
}
.brand-logo:hover{transform:translateY(-3px); box-shadow:0 8px 24px rgba(3,68,71,.2)}
.brand-logo img,.brand-logo svg{height:34px; width:auto; max-width:82%; object-fit:contain; display:block}
.brand-logo--tall{padding:14px 18px}
.brand-logo--tall img{height:130px; max-width:82%}
.brand-logo--cdk img{height:160px; max-width:88%}

@media(max-width:1100px){
  .brands{grid-template-columns:repeat(5,1fr)}
}
@media(max-width:768px){
  .brands{grid-template-columns:repeat(2,1fr)}
}

/* Print/export niceties */
@media print {
  .wa-float, .nav, .footer{display:none}
}
