/* S/A Comunicação — Shared motion + duotone helpers */

/* Better line breaking — balanced headings, pretty paragraphs (no orphans) */
h1, h2, h3, h4, .display, .h-display, .kinetic { text-wrap: balance; }
.paragraph, .lead, .bio p, .srv p, .srv-card p, .pill p, .quad-cell p, .chega p { text-wrap: pretty; }
/* Específicos: títulos que devem caber em uma linha quando possível */
.action-head .h-display { text-wrap: pretty; }

/* Manifesto — coluna editorial alinhada
   Todos os elementos dentro do container do manifesto compartilham
   o mesmo max-width e a mesma margem esquerda. */
.manifesto > .container > * {
  max-width: 1080px;
  margin-left: 0;
  margin-right: 0;
}
.manifesto > .container > .quad {
  margin-top: clamp(48px, 6vw, 72px);
}
.manifesto .section-head { margin-bottom: 18px; }
.manifesto .h-display {
  margin-bottom: 24px;
  text-wrap: balance;
  /* mesmo size do services.title (.h-display padrão) */
}
[data-i18n="manifesto.body"] {
  text-wrap: pretty;
  margin-top: 0;
  margin-bottom: clamp(40px, 5vw, 64px);
  line-height: 1.6;
  font-size: clamp(17px, 1.3vw, 20px);
}

/* Hero subtitle / leads — fluidez */
.lead, [data-i18n="hero.subtitle"] {
  text-wrap: pretty;
  max-width: 56ch;
  line-height: 1.5;
}

/* Action cards — parágrafos sem quebras feias */
.action-card p {
  text-wrap: pretty;
  hyphens: none;
  max-width: 38ch;
}

/* Service cards — texto fluido */
.srv p, .srv-card p {
  text-wrap: pretty;
  hyphens: none;
}

/* Pillars / quad cells — texto fluido */
.pill p, .quad-cell p {
  text-wrap: pretty;
  hyphens: none;
}

/* Network text */
[data-i18n="network.body"] {
  text-wrap: pretty;
  max-width: 56ch;
  line-height: 1.55;
}

/* Action lead */
[data-i18n="action.lead"] {
  text-wrap: pretty;
  max-width: 56ch;
  line-height: 1.5;
}


/* Reveal */
[data-reveal] { opacity: 0; transform: translateY(18px); transition: opacity .9s cubic-bezier(.2,.6,.2,1), transform .9s cubic-bezier(.2,.6,.2,1); }
[data-reveal].is-revealed { opacity: 1; transform: translateY(0); }
[data-reveal="stagger"] > * { opacity: 0; transform: translateY(18px); transition: opacity .8s cubic-bezier(.2,.6,.2,1), transform .8s cubic-bezier(.2,.6,.2,1); }
[data-reveal="stagger"] > .is-revealed { opacity: 1; transform: translateY(0); }
@media (prefers-reduced-motion: reduce) {
  [data-reveal], [data-reveal="stagger"] > * { opacity: 1 !important; transform: none !important; transition: none !important; }
}

/* Magnetic / Tilt */
[data-magnetic], [data-tilt] { transition: transform .35s cubic-bezier(.2,.6,.2,1); will-change: transform; }

/* Duotone — uniformiza fotos com fundos diferentes */
.duotone { position: relative; overflow: hidden; isolation: isolate; }
.duotone img {
  width: 100%; height: 100%; object-fit: cover; object-position: center top;
  filter: grayscale(1) contrast(1.05) brightness(.95);
  mix-blend-mode: luminosity;
}
.duotone::before {
  content: ""; position: absolute; inset: 0; z-index: -1;
  background: linear-gradient(180deg, #d8eef5 0%, #b6dde7 60%, #7fbecc 100%);
}
.duotone::after {
  content: ""; position: absolute; inset: 0;
  background: linear-gradient(180deg, rgba(14,95,119,.0) 55%, rgba(14,95,119,.35) 100%);
  pointer-events: none;
  transition: opacity .4s ease;
}
.duotone:hover img { filter: grayscale(.6) contrast(1.05) brightness(.98); }

/* Service icon glyphs default sizing */
.glyph { width: 44px; height: 44px; display: block; }
.glyph svg { width: 100%; height: 100%; display: block; }


/* Careers section — Trabalhe Conosco */
.careers {
  padding: clamp(80px, 10vw, 140px) 0;
  border-bottom: 1px solid #e8e8ec;
  background:
    radial-gradient(ellipse at 100% 0%, rgba(26,171,203,.08) 0%, transparent 50%),
    linear-gradient(180deg, #ffffff 0%, #f6fbfc 100%);
}
.careers-grid {
  display: grid; grid-template-columns: 1.4fr 1fr;
  gap: clamp(40px, 5vw, 88px); align-items: start;
}
.careers-points {
  list-style: none; padding: 0; margin: 0;
  display: grid; gap: 0;
  border-top: 1px solid #e8e8ec;
}
.careers-points li {
  display: grid; grid-template-columns: 160px 1fr; gap: 24px;
  padding: 22px 0; border-bottom: 1px solid #e8e8ec;
  align-items: baseline;
}
.careers-points strong {
  font-family: "Bricolage Grotesque", system-ui, sans-serif;
  font-weight: 500; font-size: 16px; letter-spacing: -.01em;
  color: #0E5F77;
}
.careers-points span {
  color: #2c2c30; font-size: 15px; line-height: 1.5;
  text-wrap: pretty;
}
@media (max-width: 880px) {
  .careers-grid { grid-template-columns: 1fr; }
  .careers-points li { grid-template-columns: 1fr; gap: 6px; }
}

/* Markets grid — substitui o mapa-múndi */
.markets-wrap { margin-top: clamp(48px, 6vw, 80px); }
.markets-kicker {
  font-family: "Bricolage Grotesque", system-ui, sans-serif;
  font-size: clamp(13px, 1vw, 15px);
  font-weight: 500;
  letter-spacing: .22em;
  text-transform: uppercase;
  color: rgba(255,255,255,.6);
  margin: 0 0 28px;
  padding-bottom: 16px;
  border-bottom: 1px solid rgba(255,255,255,.16);
}
.markets {
  list-style: none; padding: 0; margin: 0;
  display: grid; grid-template-columns: repeat(4, 1fr);
  gap: 0;
}
.markets li {
  display: flex; align-items: baseline; justify-content: space-between; gap: 14px;
  padding: 22px 24px 22px 0;
  border-top: 1px solid rgba(255,255,255,.1);
  font-family: "Bricolage Grotesque", system-ui, sans-serif;
  font-weight: 400;
  font-size: clamp(18px, 1.6vw, 24px);
  letter-spacing: -.015em;
  color: rgba(255,255,255,.92);
  position: relative;
  transition: color .25s ease, padding-left .3s ease;
}
.markets li:hover { color: #fff; padding-left: 6px; }
.markets li:hover::before {
  content: ""; position: absolute; left: 0; top: 50%; transform: translateY(-50%);
  width: 3px; height: 16px; background: #1AABCB;
}
.markets li em {
  font-style: normal;
  font-size: clamp(10px, .85vw, 12px);
  letter-spacing: .14em; text-transform: uppercase;
  color: rgba(255,255,255,.45);
  font-weight: 500;
}
.markets li .hq {
  background: linear-gradient(110deg, #1AABCB 0%, #0E5F77 70%);
  -webkit-background-clip: text; background-clip: text;
  -webkit-text-fill-color: transparent; color: transparent;
  font-style: italic;
  font-family: "Instrument Serif", "Times New Roman", serif;
  font-size: 1.12em;
}
@media (max-width: 900px) { .markets { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 540px) { .markets { grid-template-columns: 1fr; } }

/* Light variant — quando não está sobre fundo preto (.network) */
section:not(.network) .markets-kicker { color: #6b6b73; border-bottom-color: #e8e8ec; }
section:not(.network) .markets li {
  color: #2c2c30;
  border-top-color: #e8e8ec;
}
section:not(.network) .markets li:hover { color: #0E5F77; }
section:not(.network) .markets li em { color: #6b6b73; }

/* Action card sólido — sem vídeo, fluido azul */
.action-card.action-card--solid {
  background:
    radial-gradient(circle at 75% 25%, rgba(26,171,203,.45), transparent 60%),
    radial-gradient(circle at 20% 90%, rgba(14,95,119,.6), transparent 50%),
    linear-gradient(155deg, #1a4a5c 0%, #0E5F77 50%, #0a3a48 100%);
  position: relative; overflow: hidden;
}
.action-card.action-card--solid::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: 32px 32px;
  opacity: .5;
  z-index: 0;
}
.action-card.action-card--solid > .action-content { position: relative; z-index: 1; }

/* Vídeo Manifesto — kinetic typography abertura */
.manifesto-video {
  position: relative;
  min-height: 100vh;
  background:
    radial-gradient(ellipse at 20% 80%, rgba(26,171,203,.18), transparent 55%),
    radial-gradient(ellipse at 80% 20%, rgba(26,171,203,.10), transparent 55%),
    radial-gradient(ellipse at 50% 50%, #0E5F77 0%, #0a3a48 50%, #06070a 100%);
  display: grid; place-items: center;
  overflow: hidden;
  color: #fff;
}
.mv-bg {
  position: absolute; inset: 0; pointer-events: none;
  background:
    linear-gradient(rgba(255,255,255,.025) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,.025) 1px, transparent 1px);
  background-size: 56px 56px;
  opacity: .6;
  animation: mvGridDrift 30s linear infinite;
}
@keyframes mvGridDrift { from { background-position: 0 0; } to { background-position: 56px 56px; } }

.mv-stage {
  position: relative; z-index: 1;
  display: flex; flex-direction: column; align-items: center;
  gap: clamp(36px, 5vw, 72px);
  width: 90vw; max-width: 1200px;
  padding: 100px 0;
}
.mv-logo {
  width: clamp(180px, 18vw, 300px);
  height: auto;
  opacity: .95;
  filter: drop-shadow(0 16px 40px rgba(26,171,203,.35));
  animation: mvLogoBreath 4s ease-in-out infinite alternate;
}
@keyframes mvLogoBreath {
  from { opacity: .8; transform: scale(1); }
  to   { opacity: 1;  transform: scale(1.03); }
}

.mv-lines {
  position: relative;
  width: 100%;
  height: clamp(180px, 24vw, 320px);
}
.mv-line {
  position: absolute; inset: 0;
  display: grid; place-items: center; text-align: center;
  font-family: "Bricolage Grotesque", system-ui, sans-serif;
  font-weight: 250;
  font-size: clamp(34px, 5.4vw, 88px);
  line-height: 1.05; letter-spacing: -.04em;
  opacity: 0; transform: translateY(24px);
  text-wrap: balance;
  padding: 0 .04em .14em;
  animation: mvCycle 28s infinite;
}
.mv-line em {
  font-family: "Instrument Serif", "Times New Roman", serif;
  font-style: italic; font-weight: 400;
  font-size: 1.04em;
  background: linear-gradient(110deg, #1AABCB 0%, #7fcadc 100%);
  -webkit-background-clip: text; background-clip: text;
  -webkit-text-fill-color: transparent; color: transparent;
  display: inline-block;
  padding: .02em .04em .14em;
  margin: -.02em -.04em -.14em;
  line-height: 1.04;
}
.mv-line:nth-child(1) { animation-delay: 0s; }
.mv-line:nth-child(2) { animation-delay: 4s; }
.mv-line:nth-child(3) { animation-delay: 8s; }
.mv-line:nth-child(4) { animation-delay: 12s; }
.mv-line:nth-child(5) { animation-delay: 16s; }
.mv-line:nth-child(6) { animation-delay: 20s; }
.mv-line:nth-child(7) { animation-delay: 24s; }
@keyframes mvCycle {
  0%   { opacity: 0; transform: translateY(24px); }
  3%   { opacity: 1; transform: translateY(0); }
  12%  { opacity: 1; transform: translateY(0); }
  15%  { opacity: 0; transform: translateY(-24px); }
  100% { opacity: 0; transform: translateY(-24px); }
}

/* Skip continue */
.mv-skip {
  position: absolute; left: 50%; bottom: clamp(28px, 4vw, 56px);
  transform: translateX(-50%);
  display: inline-flex; align-items: center; gap: 10px;
  font-family: "Bricolage Grotesque", system-ui, sans-serif;
  font-size: 12px; font-weight: 500;
  letter-spacing: .22em; text-transform: uppercase;
  color: rgba(255,255,255,.7);
  text-decoration: none;
  padding: 10px 18px;
  border: 1px solid rgba(255,255,255,.18);
  border-radius: 999px;
  background: rgba(255,255,255,.03);
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  animation: mvSkipBounce 2.4s ease-in-out infinite;
  transition: color .25s ease, border-color .25s ease, background .25s ease;
}
.mv-skip:hover { color: #fff; border-color: #1AABCB; background: rgba(26,171,203,.08); }
.mv-skip svg { animation: mvArrow 1.6s ease-in-out infinite; }
@keyframes mvSkipBounce {
  0%, 100% { transform: translate(-50%, 0); }
  50%      { transform: translate(-50%, 4px); }
}
@keyframes mvArrow {
  0%, 100% { transform: translateY(0); }
  50%      { transform: translateY(3px); }
}

@media (prefers-reduced-motion: reduce) {
  .mv-line { animation: none; opacity: 1; transform: none; position: relative; }
  .mv-line:not(:first-child) { display: none; }
  .mv-bg, .mv-logo, .mv-skip, .mv-skip svg { animation: none; }
}

/* Footer 4 colunas (com Acessibilidade) */
.foot .foot-cols { grid-template-columns: repeat(4, 1fr) !important; }
@media (max-width: 880px) { .foot .foot-cols { grid-template-columns: 1fr !important; } }

/* Coluna Acessibilidade */
.foot-a11y { display: grid; gap: 10px; }
.foot-a11y a {
  display: inline-flex !important; align-items: center; gap: 10px;
  font-size: 13.5px;
}
.foot-a11y svg { flex-shrink: 0; opacity: .9; }
.foot-a11y a:hover svg { color: #1AABCB; }
.foot-a11y-tags {
  display: flex; flex-wrap: wrap; gap: 6px; margin-top: 4px;
}
.foot-a11y-tags em {
  font-style: normal;
  display: inline-block;
  padding: 4px 10px;
  border: 1px solid rgba(255,255,255,.16);
  border-radius: 999px;
  font-size: 10.5px;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: rgba(255,255,255,.65);
}

/* Footer address — visível e elegante */
.foot-address-line {
  display: block !important;
  line-height: 1.55;
  font-size: 14px;
  color: rgba(255,255,255,.78) !important;
  font-style: normal;
}

/* Action cards — h3 padronizado nos 3 cards (Reputação 360° / Crise & Issues / Inteligência) */
.action-card h3,
.action-content h3 {
  font-size: clamp(24px, 2.2vw, 30px) !important;
  line-height: 1.15 !important;
  font-weight: 400 !important;
  letter-spacing: -.02em !important;
  text-wrap: balance;
}

/* Texto justificado em parágrafos institucionais */
.manifesto .paragraph,
.action-head .paragraph,
.careers .paragraph,
[data-i18n="network.body"],
[data-i18n="manifesto.body"] {
  text-align: justify;
  text-justify: inter-word;
  hyphens: none;
}
@media (max-width: 720px) {
  .manifesto .paragraph,
  .action-head .paragraph,
  .careers .paragraph,
  [data-i18n="network.body"],
  [data-i18n="manifesto.body"] {
    text-align: left;
  }
}

/* Abracom logo no footer */
.foot-abracom-link {
  display: inline-block;
  margin-top: 8px;
  padding: 10px 14px;
  background: #fff;
  border-radius: 6px;
  width: fit-content;
  transition: transform .25s ease, box-shadow .25s ease;
}
.foot-abracom-link:hover {
  transform: translateY(-2px);
  box-shadow: 0 8px 20px -8px rgba(26,171,203,.4);
}
.foot-abracom-logo {
  width: 160px; height: auto; display: block;
}

/* Botão Libras no header */
.libras-btn {
  display: inline-flex; align-items: center; gap: 6px;
  padding: 6px 10px; border-radius: 999px;
  background: transparent; color: #0E5F77; cursor: pointer;
  border: 1px solid #1AABCB;
  font-family: "Bricolage Grotesque", sans-serif;
  font-weight: 500; font-size: 11.5px; letter-spacing: .12em;
  line-height: 1; text-transform: uppercase;
  transition: background .25s ease, color .25s ease, transform .2s ease;
}
.libras-btn:hover { background: #1AABCB; color: #fff; transform: translateY(-1px); }
.libras-btn svg { display: block; }
@media (max-width: 720px) {
  .libras-btn span, .a11y-trigger span { display: none; }
  .libras-btn, .a11y-trigger { padding: 8px; }
}

/* Acessibilidade — Painel + Alto contraste */
.a11y { position: relative; display: inline-flex; align-items: center; }
.a11y-trigger {
  display: inline-flex; align-items: center; gap: 6px;
  padding: 6px 10px; border-radius: 999px;
  background: #1AABCB; color: #fff; border: 0;
  font-family: "Bricolage Grotesque", sans-serif;
  font-weight: 500; font-size: 11.5px; letter-spacing: .12em;
  cursor: pointer; line-height: 1;
  transition: background .25s ease, transform .2s ease;
}
.a11y-trigger:hover { background: #0E5F77; transform: translateY(-1px); }
.a11y-trigger svg { display: block; }
.a11y-panel {
  position: absolute; right: 0; top: calc(100% + 10px);
  background: #fff; border: 1px solid #e8e8ec; border-radius: 12px;
  padding: 8px; min-width: 230px;
  display: none; flex-direction: column; gap: 2px;
  box-shadow: 0 30px 60px -20px rgba(14,95,119,.18);
  z-index: 100;
}
.a11y-panel.is-open { display: flex; }
.a11y-panel button {
  display: flex; align-items: center; gap: 10px;
  text-align: left; padding: 10px 12px;
  background: transparent; border: 0; cursor: pointer; border-radius: 8px;
  font-family: "Bricolage Grotesque", sans-serif;
  font-size: 13px; color: #2c2c30; font-weight: 500;
  width: 100%;
  transition: background .2s ease, color .2s ease;
}
.a11y-panel button:hover { background: #eaf6fa; color: #0E5F77; }
.a11y-panel button strong { color: #1AABCB; font-weight: 600; }

/* Alto contraste */
.a11y-contrast,
.a11y-contrast body { background: #000 !important; color: #ffe600 !important; }
.a11y-contrast a, .a11y-contrast .nav a, .a11y-contrast .display .italic,
.a11y-contrast .h-display, .a11y-contrast .lead, .a11y-contrast .paragraph,
.a11y-contrast h1, .a11y-contrast h2, .a11y-contrast h3, .a11y-contrast h4,
.a11y-contrast .display .line { color: #ffe600 !important; -webkit-text-fill-color: #ffe600 !important; background: none !important; }
.a11y-contrast .topbar { background: #000 !important; border-bottom-color: #ffe600 !important; }
.a11y-contrast .hero-image-tint, .a11y-contrast .hero-stage img { display: none !important; }
.a11y-contrast .hero-stage { background: #000 !important; }
.a11y-contrast .btn, .a11y-contrast .link-cta { color: #ffe600 !important; border-color: #ffe600 !important; background: #000 !important; }
.a11y-contrast .foot { background: #000 !important; }

/* VLibras override — combinar com paleta */
[vw][vw] [vw-access-button] { background: #1AABCB !important; }

/* Language buttons with flags */
.lang button {
  display: inline-flex !important;
  align-items: center !important;
  gap: 6px !important;
  padding: 4px 10px !important;
}
.lang .flag {
  width: 18px; height: 13px; display: block; flex-shrink: 0;
  border-radius: 2px;
  box-shadow: 0 0 0 1px rgba(0,0,0,.06);
}
.lang button > span { line-height: 1; }

/* Tag chip */
.tagchip {
  display: inline-flex; align-items: center; gap: 8px;
  padding: 6px 12px; border: 1px solid #e8e8ec; border-radius: 999px;
  font-size: 11.5px; letter-spacing: .12em; text-transform: uppercase;
  color: #6b6b73;
}
.tagchip::before { content: "▲"; color: #1AABCB; font-size: 9px; }

/* ===========================================================
   COOKIES — Banner LGPD + Modal de configuração
   =========================================================== */

.cookies-banner {
  position: fixed; left: 16px; right: 16px; bottom: 16px; z-index: 200;
  max-width: 1100px; margin: 0 auto;
  background: #06070a; color: #fff;
  border: 1px solid rgba(255,255,255,.12);
  border-radius: 14px;
  padding: 20px 24px;
  display: grid; grid-template-columns: 1fr auto; gap: 20px;
  align-items: center;
  box-shadow: 0 30px 80px -20px rgba(0,0,0,.4);
  animation: cookieRise .6s cubic-bezier(.2,.6,.2,1) both;
  backdrop-filter: blur(18px);
}
.cookies-banner[hidden] { display: none; }
@keyframes cookieRise {
  from { opacity: 0; transform: translateY(20px); }
  to   { opacity: 1; transform: translateY(0); }
}
.cookies-banner h3 {
  margin: 0 0 8px;
  font-family: "Bricolage Grotesque", sans-serif;
  font-size: 15px; font-weight: 500; letter-spacing: -.005em;
  display: inline-flex; align-items: center; gap: 8px;
}
.cookies-banner h3::before {
  content: "🍪"; font-size: 18px;
}
.cookies-banner p {
  margin: 0; font-size: 13.5px; line-height: 1.5;
  color: rgba(255,255,255,.8); max-width: 70ch;
}
.cookies-banner a { color: #1AABCB; border-bottom: 1px solid rgba(26,171,203,.4); }
.cookies-banner a:hover { color: #fff; border-bottom-color: #fff; }
.cookies-actions {
  display: inline-flex; align-items: center; gap: 8px; flex-wrap: wrap;
}
.cookies-btn {
  display: inline-flex; align-items: center; gap: 6px;
  padding: 10px 18px; border-radius: 999px;
  font: 500 12px "Bricolage Grotesque", sans-serif;
  letter-spacing: .04em; cursor: pointer; border: 1px solid;
  transition: background .25s ease, color .25s ease, transform .2s ease, border-color .25s ease;
  white-space: nowrap;
}
.cookies-btn--primary { background: #1AABCB; color: #fff; border-color: #1AABCB; }
.cookies-btn--primary:hover { background: #0E5F77; border-color: #0E5F77; transform: translateY(-1px); }
.cookies-btn--ghost { background: transparent; color: rgba(255,255,255,.85); border-color: rgba(255,255,255,.2); }
.cookies-btn--ghost:hover { color: #fff; border-color: #fff; }
.cookies-btn--link {
  background: none; border: 0; padding: 8px 4px;
  color: rgba(255,255,255,.7); font-size: 12px;
  text-decoration: underline; text-underline-offset: 3px;
}
.cookies-btn--link:hover { color: #fff; }

@media (max-width: 720px) {
  .cookies-banner {
    grid-template-columns: 1fr; gap: 14px;
    left: 12px; right: 12px; bottom: 12px;
    padding: 18px;
  }
  .cookies-actions { width: 100%; }
  .cookies-btn { flex: 1; justify-content: center; padding: 10px 14px; font-size: 11.5px; }
}

/* Modal de configuração */
.cookies-modal {
  position: fixed; inset: 0; z-index: 300;
  display: grid; place-items: center; padding: 16px;
  background: rgba(6,7,10,.7);
  backdrop-filter: blur(8px);
  animation: cookieFade .3s ease both;
}
.cookies-modal[hidden] { display: none; }
@keyframes cookieFade { from { opacity: 0; } to { opacity: 1; } }
.cookies-modal-content {
  background: #fff; color: #0a0a0c;
  width: 100%; max-width: 560px; max-height: 90vh; overflow-y: auto;
  border-radius: 16px;
  padding: 32px;
  position: relative;
  animation: cookieSlide .35s cubic-bezier(.2,.6,.2,1) both;
}
@keyframes cookieSlide {
  from { opacity: 0; transform: translateY(20px) scale(.98); }
  to   { opacity: 1; transform: translateY(0) scale(1); }
}
.cookies-modal h2 {
  margin: 0 0 8px; font-family: "Bricolage Grotesque", sans-serif;
  font-weight: 400; font-size: 26px; letter-spacing: -.02em;
}
.cookies-modal p { color: #6b6b73; font-size: 14.5px; line-height: 1.55; margin: 0 0 22px; }
.cookies-categories { display: grid; gap: 14px; margin-bottom: 24px; }
.cookies-cat {
  display: grid; grid-template-columns: 1fr auto; gap: 16px;
  padding: 16px;
  border: 1px solid #e8e8ec; border-radius: 10px;
  align-items: start;
}
.cookies-cat strong { font-family: "Bricolage Grotesque", sans-serif; font-weight: 500; font-size: 15px; color: #0a0a0c; display: block; margin-bottom: 4px; }
.cookies-cat span { font-size: 13px; color: #6b6b73; line-height: 1.45; }
.cookies-cat--locked strong::after { content: " · obrigatório"; font-size: 11px; color: #1AABCB; letter-spacing: .08em; text-transform: uppercase; }

/* Toggle switch */
.cookies-switch { position: relative; display: inline-block; width: 44px; height: 24px; flex-shrink: 0; }
.cookies-switch input { opacity: 0; width: 0; height: 0; }
.cookies-switch .slider {
  position: absolute; cursor: pointer; inset: 0;
  background: #e8e8ec; border-radius: 999px;
  transition: background .25s ease;
}
.cookies-switch .slider::before {
  content: ""; position: absolute;
  height: 18px; width: 18px; left: 3px; top: 3px;
  background: #fff; border-radius: 50%;
  transition: transform .25s ease;
  box-shadow: 0 1px 3px rgba(0,0,0,.15);
}
.cookies-switch input:checked + .slider { background: #1AABCB; }
.cookies-switch input:checked + .slider::before { transform: translateX(20px); }
.cookies-switch input:disabled + .slider { background: #cfdce0; cursor: not-allowed; }

.cookies-modal-foot {
  display: flex; justify-content: space-between; gap: 12px; flex-wrap: wrap;
}
.cookies-close-x {
  position: absolute; right: 16px; top: 16px;
  width: 32px; height: 32px; border-radius: 50%;
  background: transparent; border: 1px solid #e8e8ec; cursor: pointer;
  display: grid; place-items: center;
  font-size: 18px; line-height: 1; color: #6b6b73;
  transition: background .2s ease, color .2s ease;
}
.cookies-close-x:hover { background: #f6fbfc; color: #0a0a0c; }

@media (max-width: 480px) {
  .cookies-modal-content { padding: 22px; }
  .cookies-modal h2 { font-size: 22px; }
  .cookies-cat { padding: 14px; }
}

/* Marquee variants */
.marquee { overflow: hidden; }
.marquee-track { display: inline-flex; gap: 32px; white-space: nowrap; animation: marquee 38s linear infinite; }
@keyframes marquee { from { transform: translateX(0); } to { transform: translateX(-50%); } }
@media (prefers-reduced-motion: reduce) { .marquee-track { animation: none; } }

/* ===========================================================
   MOBILE OPTIMIZATION — refinamento completo para celular
   =========================================================== */

@media (max-width: 960px) {
  .topbar { padding: 14px 20px !important; gap: 8px !important; flex-wrap: wrap !important; }
  .markets { grid-template-columns: repeat(2, 1fr) !important; }
}

@media (max-width: 720px) {
  input, textarea, select { font-size: 16px !important; }

  /* Topbar mobile — distribuído sem espaços vazios */
  .topbar {
    padding: 10px 16px !important;
    gap: 8px !important;
    flex-wrap: wrap !important;
    row-gap: 6px !important;
    display: grid !important;
    grid-template-columns: auto 1fr auto !important;
    grid-template-areas: "brand actions actions" "lang lang lang" !important;
    align-items: center !important;
  }
  .topbar > .brand { grid-area: brand; }
  .topbar > .libras-btn { grid-area: actions; justify-self: end; margin-right: 4px; }
  .topbar > .a11y { grid-area: actions; justify-self: end; }
  .topbar > .libras-btn ~ .a11y { justify-self: end; }
  .topbar > .lang { grid-area: lang; }

  /* Posiciona Libras e A11y lado a lado dentro da área "actions" */
  .topbar { grid-template-columns: auto 1fr auto auto !important;
    grid-template-areas: "brand . libras a11y" "lang lang lang lang" !important; }
  .topbar > .libras-btn { grid-area: libras; justify-self: end; margin: 0; }
  .topbar > .a11y { grid-area: a11y; justify-self: end; }

  .brand-logo { height: 26px !important; }
  .libras-btn, .a11y-trigger {
    padding: 7px 10px !important; font-size: 10px !important; letter-spacing: .08em !important;
  }
  .libras-btn span, .a11y-trigger span { display: none !important; }
  .libras-btn svg, .a11y-trigger svg { width: 16px !important; height: 16px !important; }

  /* Lang — full width, scroll horizontal sem scrollbar visível */
  .lang {
    width: 100% !important;
    overflow-x: auto !important;
    -webkit-overflow-scrolling: touch;
    scrollbar-width: none; -ms-overflow-style: none;
    padding: 4px !important; gap: 3px !important;
    justify-content: space-around !important;
    margin: 0 !important;
  }
  .lang::-webkit-scrollbar { display: none; }
  .lang button {
    padding: 6px 8px !important; font-size: 10px !important;
    flex: 1; min-width: 38px;
    display: inline-flex !important; align-items: center; justify-content: center; gap: 4px !important;
  }
  .lang button > span { display: inline !important; font-size: 9.5px !important; }
  .lang .flag { width: 14px; height: 10px; }

  /* Manifesto-video kinetic */
  .manifesto-video { min-height: 92vh; }
  .mv-stage { padding: 60px 0 !important; gap: 28px !important; width: 92vw !important; }
  .mv-logo { width: clamp(120px, 32vw, 180px) !important; }
  .mv-lines { height: clamp(150px, 32vw, 220px) !important; }
  .mv-line {
    font-size: clamp(28px, 8.5vw, 44px) !important;
    line-height: 1.1 !important; padding: 0 8px !important;
  }
  .mv-skip { bottom: 22px !important; padding: 8px 14px !important; font-size: 10px !important; }

  /* Hero — slideshow + tint reforçado */
  .hero { padding: 80px 0 60px !important; }
  .hero-image-tint {
    background:
      linear-gradient(180deg, rgba(255,255,255,.97) 0%, rgba(255,255,255,.92) 30%, rgba(255,255,255,.55) 70%, rgba(255,255,255,.85) 100%) !important;
  }
  .display { font-size: clamp(38px, 12vw, 64px) !important; line-height: 1.05 !important; margin-bottom: 22px !important; }
  .lead { font-size: 15px !important; line-height: 1.55 !important; margin-bottom: 24px !important; }
  .link-cta { font-size: 13px; }

  /* Hero figures 2col */
  .hero-figures { padding-top: 32px !important; }
  .figures { grid-template-columns: repeat(2, 1fr) !important; gap: 0 !important; }
  .figures li {
    padding: 18px 14px 18px 0 !important;
    border-right: 1px solid #e8e8ec !important;
    border-bottom: 1px solid #e8e8ec !important;
  }
  .figures li:nth-child(2n) { border-right: 0 !important; padding-right: 0 !important; }
  .figures li:nth-last-child(-n+2) { border-bottom: 0 !important; }
  .figures strong { font-size: clamp(32px, 9vw, 44px) !important; }
  .figures span { font-size: 11.5px !important; line-height: 1.35 !important; }

  /* Cities marquee */
  .cities { padding: 44px 0 !important; }
  .cities-track { font-size: clamp(32px, 9.5vw, 56px) !important; line-height: 1.15 !important; }
  .cities-track span { padding: 0 14px !important; }

  /* Action cards */
  .action { padding: 60px 0 !important; }
  .action-grid { grid-template-columns: 1fr !important; gap: 14px !important; }
  .action-card { min-height: 340px !important; padding: 20px !important; }
  .action-card h3 { font-size: 22px !important; line-height: 1.15 !important; }
  .action-card p { font-size: 14px !important; line-height: 1.5 !important; }
  .action-tag { font-size: 10.5px !important; }

  /* Section heads */
  section { padding: 60px 0 !important; }
  .section-head, .row-head {
    margin-bottom: 22px !important; padding-bottom: 18px !important; gap: 14px !important;
  }
  .section-head .num, .row-head .num { font-size: 30px !important; }
  .section-head .kicker, .row-head .kicker { font-size: 13px !important; letter-spacing: .18em !important; }
  .section-head .kicker::before, .row-head .kicker::before { width: 24px !important; }

  /* h-display */
  .h-display { font-size: clamp(28px, 8vw, 44px) !important; line-height: 1.1 !important; }
  .manifesto .h-display { font-size: clamp(28px, 8vw, 42px) !important; }

  /* Manifesto */
  [data-i18n="manifesto.body"] { font-size: 16px !important; line-height: 1.6 !important; text-align: left !important; }
  .quad { grid-template-columns: 1fr !important; margin-top: 32px !important; }
  .quad-cell {
    border-right: 0 !important; border-bottom: 1px solid #e8e8ec !important; padding: 22px 0 !important;
  }
  .pillars { grid-template-columns: 1fr !important; }
  .pill {
    border-right: 0 !important; border-bottom: 1px solid #e8e8ec !important; padding: 24px 0 !important;
  }

  /* Services 1col */
  .srv-grid { grid-template-columns: 1fr !important; }
  .srv-card, .srv { padding: 22px 18px !important; }
  .srv-card h4, .srv h4 { font-size: 17px !important; }
  .srv-card p, .srv p { font-size: 14px !important; }

  /* Partners */
  .people { grid-template-columns: 1fr !important; gap: 32px !important; }
  .person { grid-template-columns: 110px 1fr !important; gap: 16px !important; }
  .portrait { width: 110px !important; }
  .bio h3 { font-size: 22px !important; line-height: 1.2 !important; }
  .bio .role { font-size: 11px !important; margin-bottom: 10px !important; }
  .bio p { font-size: 14px !important; line-height: 1.55 !important; }

  /* Network */
  .network-grid, .net-grid { grid-template-columns: 1fr !important; gap: 28px !important; }
  .network-stats, .net-stats { gap: 0 !important; }
  .network-stats li, .net-stats li { padding: 16px 0 !important; }
  .network-stats strong, .net-stats strong { font-size: clamp(34px, 9vw, 48px) !important; }

  /* Markets */
  .markets { grid-template-columns: 1fr !important; }
  .markets li { font-size: 17px !important; padding: 14px 14px 14px 0 !important; }
  .markets li em { font-size: 10px !important; }
  .markets-kicker { font-size: 11px !important; }

  /* Careers */
  .careers-grid { grid-template-columns: 1fr !important; gap: 28px !important; }
  .careers-points li {
    grid-template-columns: 1fr !important; gap: 4px !important; padding: 16px 0 !important;
  }
  .careers-points strong { font-size: 15px !important; }
  .careers-points span { font-size: 14px !important; }

  /* Contact */
  .contact-grid { grid-template-columns: 1fr !important; gap: 28px !important; }
  .contact-list a { font-size: 18px !important; }
  .form { padding: 18px !important; }

  /* Footer */
  .foot { padding: 48px 0 18px !important; }
  .foot-grid { grid-template-columns: 1fr !important; gap: 28px !important; }
  .foot-cols { grid-template-columns: 1fr !important; gap: 24px !important; }
  .foot-h { font-size: 10.5px !important; }
  .foot-cols a { font-size: 13.5px !important; }
  .foot-bot {
    flex-direction: column !important; align-items: flex-start !important;
    gap: 8px !important; margin-top: 32px !important;
  }
  .foot-abracom-logo { width: 130px !important; }
  .foot-address-line { font-size: 13px !important; }
  .foot-a11y-tags em { font-size: 9.5px !important; padding: 3px 8px !important; }

  /* Performance — anim mais lentas */
  .hero-slides .slide { animation-duration: 60s !important; }
  .cities-track { animation-duration: 80s !important; }

  /* Justify desliga */
  .manifesto .paragraph,
  .action-head .paragraph,
  .careers .paragraph,
  [data-i18n="network.body"],
  [data-i18n="manifesto.body"] {
    text-align: left !important; text-justify: auto !important;
  }
}

/* Touch targets — mínimo 44px (Apple HIG) */
@media (max-width: 720px) and (pointer: coarse) {
  .nav a, .lang button, .libras-btn, .a11y-trigger,
  .link-cta, .btn, .form button,
  .markets li, .srv-card, .srv,
  .a11y-panel button,
  .iprex-legend li,
  .foot-cols a {
    min-height: 44px;
  }
  .lang button, .libras-btn, .a11y-trigger { padding: 8px 10px !important; }
  .link-cta, .btn { padding: 12px 18px !important; }
}

/* Safe area iOS (notch) */
@supports (padding: env(safe-area-inset-top)) {
  .topbar { padding-top: max(12px, env(safe-area-inset-top)) !important; }
  .foot { padding-bottom: max(18px, env(safe-area-inset-bottom)) !important; }
}

/* iOS Safari — corrige 100vh com 100dvh quando suportado */
@supports (height: 100dvh) {
  .manifesto-video { min-height: 100dvh !important; }
}

/* Performance: pausa carrosséis quando não visíveis (prefers-reduced-data) */
@media (prefers-reduced-data: reduce) {
  .hero-slides .slide:not(:first-child) { display: none; }
  .cities-track, .marquee-track { animation-play-state: paused; }
}

/* Mobile pequeno (≤420px) */
@media (max-width: 420px) {
  .display { font-size: clamp(34px, 11vw, 52px) !important; }
  .figures strong { font-size: clamp(28px, 9vw, 40px) !important; }
  .cities-track { font-size: clamp(30px, 10vw, 48px) !important; }
  .person { grid-template-columns: 90px 1fr !important; }
  .portrait { width: 90px !important; }
  .mv-line { font-size: clamp(24px, 8vw, 38px) !important; }
  .mv-logo { width: clamp(100px, 28vw, 140px) !important; }
}

