/* ALTERADO (D5): @import "../fonts/fonts.css" removido. CSS @import causa serial
   loading (browser baixa fonts.css apenas APÓS terminar style.css). Solução:
   fonts.css agora é carregado via <link> direto no HTML, em paralelo com style.css. */

/* NOVO (C2): declaração de cascade layers ITCSS — define a ORDEM de
   especificidade para overrides futuros sem refactor amplo. Qualquer regra
   fora de @layer continua tendo prioridade máxima (cobre todo o CSS atual,
   sem regressão). Novas regras devem ser escritas em @layer apropriado:
     - settings   — :root tokens
     - generic    — reset / normalize
     - elements   — estilos de tags puras (h1, a, img)
     - objects    — padrões de layout reutilizáveis (.o-container, .o-grid)
     - components — UI (.c-card, .header, .theme-btn)
     - utilities  — atômicas (.visually-hidden, .u-mt-md)
   Browser support: Chrome 99+, Safari 15.4+, Firefox 97+ (2022+). */
@layer settings, generic, elements, objects, components, utilities;

@keyframes clientesMarquee {
    0% {
        transform: translate(0)
    }

    to {
        transform: translate(-33.3333%)
    }
}

@keyframes faqOpen {
    0% {
        opacity: 0;
        transform: translateY(-6px)
    }

    to {
        opacity: 1;
        transform: translateY(0)
    }
}

@keyframes fadeInUp {
    0% {
        opacity: 0;
        transform: translateY(30px)
    }

    to {
        opacity: 1;
        transform: translateY(0)
    }
}

:root {
    --pdv-azul-profundo: #294964;
    --pdv-laranja: #c76e30;
    --pdv-verde-escuro: #3f4738;
    --pdv-verde-oliva: #a7b287;
    --pdv-amarelo-dourado: #faae3f;
    --pdv-marrom-escuro: #50281f;
    --pdv-azul-claro: #c5e9ea;
    --pdv-cinza-azulado: #798e91;
    --pdv-white: #fff;
    --pdv-off-white: #f7f8fa;
    --pdv-gray-100: #e8eaed;
    --pdv-gray-200: #cdd1d6;
    --pdv-gray-400: #8a919b;
    --pdv-gray-600: #4a5261;
    --pdv-gray-800: #2a2f38;
    --pdv-black: #111318;
    --pdv-text-primary: #2f3640;
    --pdv-text-secondary: #4a6468;
    --pdv-text-tertiary: #5c6b70;
    --pdv-text-on-dark: #f0f4f5;
    --pdv-text-on-dark-muted: #c5d5d8;
    --pdv-success: #3f4738;
    --pdv-warning: #faae3f;
    --pdv-error: #9b2c2c;
    --pdv-info: #294964;
    --pdv-azul-profundo-05: rgba(41, 73, 100, 0.05);
    --pdv-azul-profundo-10: rgba(41, 73, 100, 0.1);
    --pdv-azul-profundo-15: rgba(41, 73, 100, 0.15);
    --pdv-azul-profundo-40: rgba(41, 73, 100, 0.4);
    --pdv-azul-profundo-90: rgba(41, 73, 100, 0.9);
    --pdv-azul-profundo-95: rgba(41, 73, 100, 0.95);
    --pdv-azul-profundo-e6: rgba(41, 73, 100, 0.9);
    --pdv-azul-profundo-c7: rgba(41, 73, 100, 0.78);
    --pdv-azul-profundo-66: rgba(41, 73, 100, 0.4);
    --pdv-azul-profundo-99: rgba(41, 73, 100, 0.6);
    --pdv-laranja-08: rgba(199, 110, 48, 0.08);
    --pdv-laranja-12: rgba(199, 110, 48, 0.12);
    --pdv-laranja-15: rgba(199, 110, 48, 0.15);
    --pdv-laranja-1f: rgba(199, 110, 48, 0.12);
    --pdv-laranja-22: rgba(199, 110, 48, 0.22);
    --pdv-laranja-33: rgba(199, 110, 48, 0.2);
    --pdv-laranja-38: rgba(199, 110, 48, 0.22);
    --pdv-laranja-52: rgba(199, 110, 48, 0.32);
    --pdv-laranja-66: rgba(199, 110, 48, 0.4);
    --pdv-laranja-80: rgba(199, 110, 48, 0.5);
    --pdv-white-05: rgba(255, 255, 255, 0.05);
    --pdv-white-06: rgba(255, 255, 255, 0.06);
    --pdv-white-0d: rgba(255, 255, 255, 0.05);
    --pdv-white-0f: rgba(255, 255, 255, 0.06);
    --pdv-white-10: rgba(255, 255, 255, 0.1);
    --pdv-white-12: rgba(255, 255, 255, 0.12);
    --pdv-white-14: rgba(255, 255, 255, 0.08);
    --pdv-white-15: rgba(255, 255, 255, 0.15);
    --pdv-white-1a: rgba(255, 255, 255, 0.1);
    --pdv-white-20: rgba(255, 255, 255, 0.2);
    --pdv-white-22: rgba(255, 255, 255, 0.22);
    --pdv-white-2e: rgba(255, 255, 255, 0.18);
    --pdv-white-38: rgba(255, 255, 255, 0.22);
    --pdv-white-fa: rgba(255, 255, 255, 0.98);
    --pdv-black-10: rgba(17, 19, 24, 0.1);
    --pdv-black-45: rgba(17, 19, 24, 0.45);
    --pdv-black-73: rgba(17, 19, 24, 0.45);
    --pdv-black-92: rgba(17, 19, 24, 0.92);
    --pdv-black-99: rgba(17, 19, 24, 0.6);
    --pdv-black-66: rgba(17, 19, 24, 0.4);
    --pdv-black-18: rgba(17, 19, 24, 0.18);
    --pdv-amarelo-12: rgba(250, 174, 63, 0.12);
    --pdv-amarelo-22: rgba(250, 174, 63, 0.22);
    --pdv-amarelo-1f: rgba(250, 174, 63, 0.12);
    --pdv-amarelo-38: rgba(250, 174, 63, 0.22);
    --pdv-amarelo-40: rgba(250, 174, 63, 0.25);
    --pdv-amarelo-73: rgba(250, 174, 63, 0.45);
    --pdv-marrom-59: rgba(80, 40, 31, 0.35);
    --space-3xs: 0.125rem;
    --space-2xs: 0.25rem;
    --space-xs: 0.5rem;
    --space-sm: 0.75rem;
    --space-md: 1rem;
    --space-lg: 1.25rem;
    --space-xl: 1.5rem;
    --space-2xl: 2rem;
    --space-3xl: 2.5rem;
    --space-4xl: 3rem;
    --space-5xl: 4rem;
    --space-6xl: 5rem;
    --space-7xl: 6rem;
    --space-8xl: 7.5rem;
    --font-heading: "Pogonia", sans-serif;
    --font-body: "Grift", sans-serif;
    --font-mono: "JetBrains Mono", ui-monospace, SFMono-Regular, Menlo, monospace;
    --fw-light: 300;
    --fw-regular: 400;
    --fw-bold: 700;
    --type-display-hero: 3.052rem;
    --type-display-lg: 2.441rem;
    --type-heading-1: 1.953rem;
    --type-heading-2: 1.563rem;
    --type-heading-3: 1.25rem;
    --type-heading-4: 1.125rem;
    --type-subtitle: 1.1875rem;
    --type-body-lg: 1.125rem;
    --type-body: 1rem;
    --type-body-sm: .889rem;
    --type-caption: .75rem;
    --type-overline: .6875rem;
    --lh-display: 1.2;
    --lh-heading: 1.3;
    --lh-body: 1.7;
    --lh-body-sm: 1.65;
    --ls-display: -.02em;
    --ls-heading: -.01em;
    --ls-body: .005em;
    --ls-uppercase: .08em;
    --ls-button: .04em;
    /* NOVO: variantes do laranja brand p/ contraste WCAG AA (1.4.3) em texto.
       --pdv-laranja (#c76e30) tem 3.71:1 sobre branco — passa 3:1 (UI/texto large)
       mas falha 4.5:1 (texto normal). Use --pdv-laranja-text (#9d5524, 5.56:1)
       em texto regular pequeno sobre fundo claro. Em fundo escuro azul-profundo,
       use --pdv-amarelo-dourado p/ links (#faae3f, 4.96:1). */
    --pdv-laranja-text: #9d5524;
    --primary-color: var(--pdv-laranja);
    --secondary-color: var(--pdv-azul-profundo);
    --bg-light: var(--pdv-off-white);
    --text-color: var(--pdv-text-primary);
    --heading-color: var(--pdv-azul-profundo);
    --layout-max-width: 1320px;
    --layout-gutter: clamp(28px, 4vw, 56px);
    --transition: .25s cubic-bezier(.4, 0, .2, 1);
    --transition-fast: .15s cubic-bezier(.4, 0, .2, 1);
    --transition-slow: .4s cubic-bezier(.4, 0, .2, 1);
    --radius-none: 0;
    --radius-sm: 4px;
    --radius-md: 8px;
    --radius-lg: 12px;
    --radius-xl: 16px;
    --radius-2xl: 24px;
    --radius-full: 9999px;
    --radius-card: 4px;
    --radius-btn: 2px;
    --radius-input: 2px;
    --shadow-sm: 0 1px 2px var(--pdv-azul-profundo-05), 0 0 0 .5px var(--pdv-azul-profundo-05);
    --shadow-md: 0 4px 12px var(--pdv-azul-profundo-10), 0 0 0 .5px var(--pdv-azul-profundo-05);
    --shadow-lg: 0 8px 24px var(--pdv-azul-profundo-15), 0 0 0 .5px var(--pdv-azul-profundo-10);
    --shadow-xl: 0 16px 48px var(--pdv-azul-profundo-40), 0 0 0 .5px var(--pdv-azul-profundo-10);
    --shadow-inner: inset 0 2px 6px var(--pdv-azul-profundo-10);
    --shadow-glow: 0 0 20px rgba(199, 110, 48, 0.25);

    /* NOVO (C5): escala canônica de z-index para evitar valores soltos.
       Ordem de empilhamento: base < dropdown < sticky-header < modal < toast. */
    --z-base: 1;
    --z-dropdown: 100;
    --z-sticky: 1000;
    --z-modal-backdrop: 2000;
    --z-modal: 3000;
    --z-gallery: 3010;
    --z-toast: 4000;

    /* NOVO (C6): tokens de breakpoint como REFERÊNCIA documentacional.
       NÃO usar dentro de @media (browsers não interpolam custom properties em
       media queries até CSS Conditional Values L5). Use valores literais nos
       @media, e essas vars apenas em código JS para consistência. */
    --breakpoint-sm: 480px;
    --breakpoint-md: 768px;
    --breakpoint-lg: 1024px;
    --breakpoint-xl: 1280px
}

* {
    box-sizing: border-box;
    margin: 0;
    padding: 0
}

::selection {
    background-color: var(--pdv-laranja);
    color: var(--pdv-white)
}

html {
    scroll-behavior: smooth;
    -webkit-text-size-adjust: 100%;
    text-size-adjust: 100%
}

body,
html {
    scroll-padding-top: var(--header-offset, 95px)
}

@media (width<=768px) {

    body,
    html {
        scroll-padding-top: var(--header-offset, 72px)
    }
}

body {
    font-family: var(--font-body);
    font-size: var(--type-body);
    font-weight: var(--fw-light);
    color: var(--text-color);
    line-height: var(--lh-body);
    letter-spacing: var(--ls-body);
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    text-rendering: optimizelegibility;
    font-feature-settings: "kern" 1, "liga" 1;
    background: linear-gradient(#fff 0, #fafbfc 50%, #f7f8fa 100%);
    overflow-x: hidden
}

[role=button],
a,
body,
button,
input,
label,
select,
summary,
textarea {
    -webkit-tap-highlight-color: transparent
}

[role=button],
a,
button,
summary {
    touch-action: manipulation
}

@media (hover:hover) and (pointer:fine) {
    body {
        background-attachment: fixed
    }
}

:focus-visible {
    outline: 2px solid var(--pdv-laranja);
    outline-offset: 2px
}

/* NOVO (G5): banner de aviso quando JS está desabilitado.
   Aparece como faixa colorida no topo, fora do fluxo do header sticky. */
.noscript-banner {
    background: var(--pdv-amarelo-dourado);
    color: var(--pdv-azul-profundo);
    font-family: var(--font-body);
    font-size: var(--type-body-sm);
    padding: var(--space-md) var(--space-xl);
    margin: 0;
    text-align: center;
    border-bottom: 2px solid var(--pdv-laranja)
}

.noscript-banner strong {
    font-weight: var(--fw-bold);
    margin-right: var(--space-xs)
}

/* NOVO (D7): content-visibility: auto em seções abaixo da fold acelera paint
   inicial — o browser pula renderização de conteúdo fora do viewport.
   contain-intrinsic-size dá uma altura placeholder enquanto o conteúdo não
   é pintado, evitando CLS (estimativas conservadoras). */
.faq-area,
.manifesto-area,
.contact-area,
.clientes-area,
.galeria-projetos-area,
.fornecedores-editorial-area,
.about-cta-band {
    content-visibility: auto;
    contain-intrinsic-size: 0 800px
}

/* NOVO: mitiga WCAG 2.4.11 (foco não obscurecido) — quando um elemento focável
   recebe foco perto do topo do viewport, o navegador rola pra manter
   scroll-margin-top de distância do header sticky (95px desktop, 72px mobile). */
:where(a, button, input, textarea, select, summary, [tabindex]) {
    scroll-margin-top: var(--header-offset, 110px)
}

/* NOVO: utility a11y — esconde visualmente mas mantém para leitores de tela.
   Usado em h2 da stats-area (#925), em honeypots de form e onde mais for útil.
   Padrão clip-path moderno (Bootstrap 5 / GOV.UK design system). */
.visually-hidden {
    border: 0;
    clip: rect(0 0 0 0);
    clip-path: inset(50%);
    height: 1px;
    margin: -1px;
    overflow: hidden;
    padding: 0;
    position: absolute;
    white-space: nowrap;
    width: 1px;
}

.icon {
    vertical-align: -.125em;
    color: currentColor;
    fill: currentColor;
    shape-rendering: geometricprecision;
    text-rendering: geometricprecision;
    -webkit-backface-visibility: hidden;
    backface-visibility: hidden;
    flex-shrink: 0;
    width: 1em;
    height: 1em;
    display: inline-block;
    transform: translateZ(0)
}

.icon-lg {
    width: 1.25em;
    height: 1.25em
}

.contact-channel .icon,
.footer-social-link .icon[href*=whatsapp i],
.header-social-link--whatsapp .icon {
    width: 24px;
    height: 24px
}

@media (width<=768px) {
    .header-social-link .icon {
        width: 22px;
        height: 22px
    }

    .header-social-link--email .icon,
    .header-social-link--whatsapp .icon {
        width: 24px;
        height: 24px
    }
}

.svg-sprite {
    visibility: hidden;
    width: 0;
    height: 0;
    position: absolute;
    overflow: hidden
}

.skip-link {
    z-index: 9999;
    background-color: var(--pdv-azul-profundo);
    color: var(--pdv-white);
    font-family: var(--font-heading);
    font-weight: var(--fw-regular);
    border-radius: 0 0 var(--radius-md)0;
    transition: top var(--transition-fast);
    padding: 12px 24px;
    text-decoration: none;
    position: absolute;
    top: -9999px;
    left: 0
}

.skip-link:focus {
    outline: 2px solid var(--pdv-laranja);
    outline-offset: 2px;
    top: 0
}

.footer-logo-img,
.logo-img {
    object-fit: contain;
    width: auto;
    max-width: 170px;
    height: 52px;
    display: block
}

.footer-logo-img {
    max-width: 200px;
    height: 140px
}

.theme-btn-icon {
    margin-left: 8px
}

.about-cta {
    margin-top: 16px
}

/* NOVO (A6/A7): subtítulo padrão de section (logo abaixo do h2 .section-title).
   Substitui o uso de <p> solto sem classe que herdava estilo de body. */
.section-subtitle {
    font-family: var(--font-body);
    font-weight: var(--fw-light);
    font-size: var(--type-body-lg);
    line-height: var(--lh-body);
    color: var(--pdv-text-secondary);
    max-width: 56ch;
    margin: var(--space-md) auto 0
}

/* NOVO (A7): bloco de 3 beneficios "Sem obras / Sem sujeira / Sem improvisos"
   abaixo do subtitulo de Como Funciona. Cada item entra com stagger via
   .reveal (IntersectionObserver no js/main.js). */
.process-benefits {
    grid-template-columns: repeat(3, auto);
    justify-content: center;
    align-items: center;
    gap: clamp(20px, 4vw, 56px);
    list-style: none;
    padding: 0;
    margin: var(--space-2xl) auto 0;
    display: grid
}

.process-benefit {
    align-items: center;
    gap: var(--space-sm);
    font-family: var(--font-heading);
    font-weight: var(--fw-bold);
    font-size: var(--type-body-lg);
    color: var(--pdv-azul-profundo);
    display: inline-flex
}

.process-benefit .icon {
    color: var(--pdv-laranja);
    width: 22px;
    height: 22px;
    flex-shrink: 0
}

.process-benefit:nth-child(1) { transition-delay: 0ms }
.process-benefit:nth-child(2) { transition-delay: 150ms }
.process-benefit:nth-child(3) { transition-delay: 300ms }

@media (max-width: 600px) {
    .process-benefits {
        grid-template-columns: 1fr;
        gap: var(--space-md);
        justify-content: start
    }
}

/* NOVO (A5): deeplink decorado abaixo do CTA principal "Fale com um
   Especialista". O usuario precisa de affordance clara que o texto eh
   um link, com respiro acima/abaixo. */
.about-deeplink {
    margin-top: var(--space-2xl);
    margin-bottom: var(--space-md);
    font-size: var(--type-body-sm)
}

.about-deeplink a {
    align-items: center;
    gap: var(--space-xs);
    color: var(--pdv-laranja-text);
    font-family: var(--font-heading);
    font-weight: var(--fw-bold);
    text-decoration: none;
    border-bottom: 2px solid transparent;
    padding-bottom: 2px;
    transition: border-color var(--transition-fast), color var(--transition-fast);
    display: inline-flex
}

.about-deeplink a::after {
    content: "→";
    transition: transform var(--transition-fast);
    margin-left: var(--space-2xs);
    font-size: 1.1em
}

.about-deeplink a:hover,
.about-deeplink a:focus-visible {
    color: var(--pdv-azul-profundo);
    border-bottom-color: var(--pdv-laranja)
}

.about-deeplink a:hover::after,
.about-deeplink a:focus-visible::after {
    transform: translateX(3px)
}

h1,
h2,
h3,
h4,
h5,
h6 {
    color: var(--heading-color);
    line-height: var(--lh-heading);
    letter-spacing: var(--ls-heading);
    text-wrap: balance
}

h4,
h5,
h6 {
    font-family: var(--font-heading);
    font-weight: var(--fw-regular)
}

b,
strong {
    font-weight: var(--fw-bold)
}

p {
    font-size: var(--type-body);
    max-width: 65ch
}

a {
    color: inherit;
    transition: var(--transition);
    text-decoration: none
}

ul {
    list-style: none
}

.container {
    width: min(calc(100% - (var(--layout-gutter)*2)), var(--layout-max-width));
    margin: 0 auto;
    padding: 0
}

.sub-title,
.theme-btn,
h1,
h2,
h3 {
    font-family: var(--font-heading);
    font-weight: var(--fw-bold)
}

.sub-title,
.theme-btn {
    text-transform: uppercase;
    align-items: center;
    display: inline-flex
}

.theme-btn,
.theme-btn:before {
    transition: var(--transition);
    border-radius: var(--radius-btn)
}

.theme-btn {
    background-color: var(--primary-color);
    min-height: 52px;
    color: var(--pdv-white);
    font-size: var(--type-subtitle);
    letter-spacing: var(--ls-button);
    z-index: 1;
    cursor: pointer;
    box-shadow: var(--shadow-sm);
    text-shadow: 0 1px 1px #29496459;
    border: 0;
    justify-content: center;
    padding: 18px 40px;
    position: relative;
    overflow: hidden
}

.theme-btn:before {
    content: "";
    /* ALTERADO: hover do CTA agora preenche com amarelo-dourado da marca
       (era --secondary-color azul). Combina com o brand acent + reforca
       affordance de clique. Contraste WCAG: #294964 sobre #faae3f ≈ 6.6:1. */
    background-color: var(--pdv-amarelo-dourado);
    z-index: -1;
    width: 100%;
    height: 100%;
    position: absolute;
    top: 0;
    left: -100%
}

.theme-btn:hover:before {
    left: 0
}

.theme-btn:hover {
    /* ALTERADO: cor do texto no hover passa a ser azul-profundo (sobre o
       novo fundo amarelo). text-shadow zerado p/ nao reduzir contraste. */
    color: var(--pdv-azul-profundo);
    text-shadow: none;
    box-shadow: var(--shadow-md);
    transform: translateY(-1px)
}

.theme-btn:active {
    box-shadow: var(--shadow-sm);
    transform: translateY(0)scale(.98)
}

.sub-title {
    /* ALTERADO: --pdv-laranja-text p/ passar WCAG 1.4.3 (4.5:1) em texto pequeno */
    color: var(--pdv-laranja-text);
    font-size: var(--type-body-sm);
    letter-spacing: var(--ls-uppercase);
    background: #c76e3014;
    border: 1px solid #c76e3026;
    gap: 10px;
    margin-bottom: 16px;
    padding: 8px 20px
}

.sub-title .icon {
    flex-shrink: 0;
    width: 18px;
    height: 18px
}

.section-title {
    font-size: var(--type-display-lg);
    font-weight: var(--fw-bold);
    letter-spacing: var(--ls-display);
    color: var(--secondary-color);
    margin-bottom: 24px
}

.topbar {
    background-color: var(--secondary-color);
    color: var(--pdv-text-on-dark);
    padding: 10px 0;
    padding-top: calc(10px + env(safe-area-inset-top, 0));
    padding-left: env(safe-area-inset-left, 0);
    padding-right: env(safe-area-inset-right, 0);
    font-size: var(--type-body-sm);
    font-weight: var(--fw-regular)
}

.topbar .container {
    justify-content: space-between;
    align-items: center;
    display: flex
}

.topbar-left ul,
.topbar-right ul {
    align-items: center;
    gap: 24px;
    display: flex
}

.topbar-left .icon {
    color: var(--pdv-text-on-dark-muted);
    margin-right: 8px
}

.header {
    background-color: var(--pdv-white);
    z-index: 1000;
    position: sticky;
    top: 0;
    box-shadow: 0 2px 10px #2949640f
}

.header .container {
    justify-content: space-between;
    align-items: center;
    padding: 20px 0;
    display: flex
}

.hero h1,
.logo {
    font-weight: var(--fw-bold)
}

.logo,
.main-menu a,
.main-menu button.submenu-link {
    font-family: var(--font-heading);
    text-transform: uppercase;
    align-items: center
}

.logo {
    color: var(--secondary-color);
    letter-spacing: -.01em;
    gap: 12px;
    font-size: 28px;
    display: flex
}

.main-menu {
    gap: 32px;
    display: flex
}

.main-menu a.nav-cta.is-active:before,
.menu-socials {
    display: none
}

.main-menu a,
.main-menu button.submenu-link {
    font-weight: var(--fw-regular);
    color: var(--pdv-text-primary);
    font-size: var(--type-body);
    letter-spacing: var(--ls-body);
    transition: var(--transition);
    min-height: 48px;
    display: inline-flex
}

.main-menu a.is-active,
.main-menu a:hover,
.main-menu button.submenu-link:hover {
    /* ALTERADO: --pdv-laranja-text p/ contraste 4.5:1 (texto normal em fundo branco) */
    color: var(--pdv-laranja-text)
}

.main-menu a.is-active {
    position: relative
}

@media (width>768px) {
    .main-menu a,
    .main-menu button.submenu-link {
        position: relative
    }

    .main-menu a:before {
        content: "";
        position: absolute;
        bottom: 6px;
        left: 0;
        right: 0;
        height: 2px;
        background: linear-gradient(90deg, var(--pdv-laranja) 0%, var(--pdv-amarelo-dourado) 100%);
        border-radius: var(--radius-full);
        transform: scaleX(0);
        transform-origin: center;
        opacity: 0;
        transition: transform .35s cubic-bezier(.25, 1, .5, 1), opacity .35s ease
    }

    .main-menu a.is-active:before {
        transform: scaleX(1);
        opacity: 1
    }

    .main-menu a.nav-cta:before {
        display: none !important
    }
}

.main-menu a.nav-cta.is-active {
    color: var(--pdv-white);
    background-color: var(--pdv-laranja);
    box-shadow: 0 0 0 2px #c76e3038, 0 6px 18px #c76e3052, inset 0 1px #ffffff38
}

.about-list li,
.header-actions,
.header-socials {
    align-items: center;
    gap: 20px;
    display: flex
}

.about-list li,
.header-socials {
    gap: 12px
}

.header-social-link,
.mobile-toggle {
    color: var(--secondary-color);
    transition: var(--transition);
    border: 1px solid #29496424;
    justify-content: center;
    align-items: center
}

.header-social-link {
    width: 48px;
    height: 48px;
    padding: 0;
    margin: 0;
    box-sizing: border-box;
    cursor: pointer;
    box-shadow: var(--shadow-sm);
    background: linear-gradient(#fffffffa 0, #f7f8fafa 100%);
    font-size: 1.25rem;
    display: inline-flex
}

.header-social-link:hover {
    box-shadow: var(--shadow-md);
    color: var(--pdv-white);
    background: linear-gradient(135deg, #f58529 0, #dd2a7b 52%, #8134af 100%);
    border-color: #0000;
    transform: translateY(-2px)
}

.header-social-link--whatsapp:hover {
    background: linear-gradient(135deg, #25d366 0, #128c7e 100%)
}

.header-social-link--email:hover {
    background: linear-gradient(135deg, var(--pdv-azul-profundo) 0%, #3d6d8e 100%);
    color: var(--pdv-white);
    border-color: #0000
}

.header-social-link--email .icon {
    width: 1.4em;
    height: 1.4em
}

/* Circulos sociais do menu mobile com diametro identico: neutraliza o
   min-height:48px que .main-menu a impoe aos links <a> (Instagram/WhatsApp)
   e normaliza o <button> do e-mail no Safari/iOS (appearance). */
.menu-socials .header-social-link {
    min-height: 0;
    -webkit-appearance: none;
    appearance: none;
}

.mobile-toggle {
    border-radius: var(--radius-md);
    cursor: pointer;
    background: 0 0;
    min-width: 48px;
    min-height: 48px;
    padding: 10px;
    font-size: 24px;
    display: none
}

.mobile-toggle:hover {
    box-shadow: var(--shadow-sm)
}

.mobile-toggle:hover,
.mobile-toggle[aria-expanded=true] {
    background: var(--pdv-off-white)
}

.hero {
    z-index: 1;
    background: url(../images/bg/hero-bg.webp) 50%/cover;
    height: min(85vh, 700px)
}

.hero:before {
    background: linear-gradient(90deg, #294964fc 0, #294964db 60%, #2949649e 100%);
    width: 100%;
    height: 100%;
    top: 0;
    left: 0
}

.hero-content {
    max-width: 760px
}

.hero p,
.hero-subtitle {
    color: var(--pdv-text-on-dark)
}

.hero-subtitle {
    font-family: var(--font-heading);
    font-weight: var(--fw-regular);
    text-transform: uppercase;
    letter-spacing: var(--ls-uppercase);
    margin-bottom: 24px;
    display: block
}

.hero h1 {
    color: var(--pdv-white);
    font-size: var(--type-display-hero);
    line-height: var(--lh-display);
    text-transform: none;
    letter-spacing: var(--ls-display);
    max-width: 28ch;
    margin-bottom: 25px
}

.hero p {
    font-size: var(--type-heading-3);
    max-width: 56ch;
    margin-bottom: 40px
}

.hero-btns {
    gap: 24px;
    display: flex
}

/* ALTERADO: hero CTA agora usa amarelo-dourado no hover, mesmo padrao do
   .theme-btn global; texto preto-azul p/ contraste 6.6:1 sobre amarelo. */
.theme-btn-hero:before {
    background-color: var(--pdv-amarelo-dourado)
}

.theme-btn-hero:hover {
    color: var(--pdv-azul-profundo);
    text-shadow: none;
    box-shadow: 0 8px 24px rgba(250, 174, 63, 0.4)
}

.features-grid {
    grid-template-columns: repeat(3, 1fr);
    gap: 30px;
    display: grid;
    /* ALTERADO: features-grid passou a ser <ul> (semântica de lista); zerar list-style. */
    list-style: none;
    padding: 0;
    margin: 0
}

.feature-box,
.feature-icon {
    transition: var(--transition-slow);
    display: flex
}

.feature-box {
    background-color: var(--pdv-white);
    box-shadow: var(--shadow-sm);
    border-bottom: 2px solid var(--primary-color);
    gap: 24px;
    padding: clamp(24px, 4vw, 40px)
}

.feature-box:hover {
    box-shadow: var(--shadow-lg);
    transform: translateY(-3px)
}

.feature-icon {
    background-color: var(--bg-light);
    width: 64px;
    height: 64px;
    color: var(--primary-color);
    flex-shrink: 0;
    justify-content: center;
    align-items: center;
    font-size: 28px
}

.feature-box:hover .feature-icon {
    background-color: var(--secondary-color);
    color: var(--pdv-white);
    transform: scale(1.1)rotate(3deg)
}

.about-content .text-desc,
.feature-content h3 {
    font-size: var(--type-heading-3);
    font-weight: var(--fw-bold);
    color: var(--secondary-color);
    margin-bottom: 8px
}

.feature-content p {
    font-size: var(--type-body-sm);
    color: var(--pdv-text-secondary);
    margin: 0
}

.about-area {
    padding: 120px 0
}

.about-wrapper {
    grid-template-columns: 1fr 1fr;
    align-items: center;
    gap: 60px;
    display: grid
}

.about-image {
    position: relative
}

.about-img-1,
.about-img-2 {
    aspect-ratio: 4/3;
    object-fit: cover;
    border-radius: var(--radius-lg);
    width: 85%;
    height: auto;
    box-shadow: var(--shadow-md);
    display: block
}

.about-img-2 {
    border: 8px solid var(--pdv-white);
    width: 50%;
    position: absolute;
    bottom: -30px;
    right: 0
}

.experience-badge {
    background-color: var(--primary-color);
    color: var(--pdv-white);
    text-align: center;
    box-shadow: var(--shadow-glow);
    cursor: default;
    padding: 32px;
    position: absolute;
    top: 40px;
    left: -20px
}

/* NOVO: selo "+20 anos de mercado" como um post-it colado entre a foto da
   fabrica e o background da pagina. Giro anti-horario sutil + drop-shadow
   direcional dao sensacao de objeto fisico apoiado sobre os dois layers. */
.experience-seal {
    position: absolute;
    top: 24px;
    left: -64px;
    width: clamp(110px, 13vw, 150px);
    height: auto;
    z-index: 2;
    pointer-events: none;
    transform: rotate(-8deg);
    transform-origin: center center;
    /* Duas drop-shadows compostas: uma direcional (mais forte) p/ a sensacao
       de objeto colado/fisico; outra ambiente (mais difusa) p/ profundidade. */
    filter:
      drop-shadow(4px 8px 8px rgba(41, 73, 100, 0.28))
      drop-shadow(0 16px 24px rgba(41, 73, 100, 0.12));
    transition: transform var(--transition-fast)
}

/* Microinteracao: leve straighten no hover (humaniza o efeito post-it). */
@media (hover: hover) {
    .experience-seal:hover {
        transform: rotate(-3deg) scale(1.02)
    }
}

@media (max-width: 768px) {
    .experience-seal {
        top: 16px;
        left: -8px;
        width: clamp(96px, 26vw, 130px)
    }
}

.experience-badge p,
.experience-badge-number {
    font-family: var(--font-heading);
    font-weight: var(--fw-bold)
}

.experience-badge-number {
    color: var(--pdv-white);
    letter-spacing: var(--ls-heading);
    margin-bottom: 0;
    font-size: 3rem;
    line-height: 1;
    display: block
}

.experience-badge p {
    text-transform: uppercase;
    font-size: var(--type-caption);
    letter-spacing: var(--ls-uppercase);
    margin-top: 8px
}

.about-content .text-desc {
    font-size: var(--type-body-lg);
    font-weight: var(--fw-light);
    margin-bottom: 24px
}

.about-list {
    grid-template-columns: 1fr 1fr;
    gap: 16px;
    margin: 32px 0;
    display: grid
}

.about-list li {
    color: var(--pdv-gray-800);
    align-items: flex-start
}

.about-list .icon {
    color: var(--primary-color);
    flex-shrink: 0;
    width: 20px;
    height: 20px;
    margin-top: 4px
}

.section-divider-banner {
    background: linear-gradient(90deg, var(--pdv-azul-profundo) 0%, #325778 100%);
    align-items: center;
    min-height: 30vh;
    display: flex;
    box-shadow: inset 0 1px #ffffff0f, inset 0 -1px #1113181f
}

.about-list li,
.contact-form label,
.section-divider-banner p {
    font-family: var(--font-heading);
    font-weight: var(--fw-regular)
}

.section-divider-banner p {
    text-align: center;
    max-width: none;
    color: var(--pdv-white);
    letter-spacing: var(--ls-uppercase);
    text-transform: uppercase;
    margin: 0;
    font-size: clamp(1.4rem, 4.2vh, 3rem);
    line-height: 1.15
}

.section-divider-banner p strong {
    font-weight: var(--fw-bold);
    color: var(--pdv-amarelo-dourado);
    text-shadow: 0 1px 2px #00000040
}

.services-area {
    background-color: var(--bg-light);
    padding: 100px 0
}

.section-header {
    text-align: center;
    max-width: 700px;
    margin: 0 auto 80px
}

.services-grid {
    grid-template-columns: repeat(4, 1fr);
    gap: 30px;
    display: grid
}

.service-card {
    background-color: var(--pdv-white);
    text-align: center;
    transition: var(--transition);
    z-index: 1;
    border: 1px solid var(--pdv-gray-100);
    box-shadow: var(--shadow-sm);
    padding: 40px 32px;
    position: relative;
    overflow: hidden
}

.service-card:before {
    content: "";
    background-color: var(--secondary-color);
    width: 100%;
    height: 0;
    transition: var(--transition);
    z-index: -1;
    position: absolute;
    top: 0;
    left: 0
}

.service-card:hover {
    box-shadow: var(--shadow-lg);
    transform: translateY(-3px)
}

.service-card:hover:before {
    height: 100%
}

.service-card h3,
.service-icon {
    transition: var(--transition);
    margin-bottom: 16px
}

.service-icon {
    color: var(--primary-color);
    font-size: 48px
}

.service-card:hover .service-icon,
.service-card:hover h3,
.service-card:hover p {
    color: var(--pdv-white);
    transition: color var(--transition)
}

.service-card h3 {
    font-size: var(--type-heading-3);
    font-weight: var(--fw-bold)
}

.service-card p,
.sust-card p {
    font-size: var(--type-body-sm);
    text-align: left
}

.service-card p {
    transition: var(--transition);
    color: var(--pdv-text-secondary);
    margin-bottom: 0
}

.sustainability {
    background-color: var(--pdv-verde-escuro);
    color: var(--pdv-white);
    z-index: 1;
    padding: 120px 0;
    position: relative;
    overflow: hidden
}

.sust-glow {
    pointer-events: none;
    z-index: 0;
    border-radius: 50%;
    position: absolute
}

.sust-glow--top {
    background: radial-gradient(circle, #a7b2871a 0, #0000 70%);
    width: 700px;
    height: 700px;
    top: -300px;
    left: 20%
}

.sust-glow--bottom {
    background: radial-gradient(circle, #a7b2870f 0, #0000 70%);
    width: 500px;
    height: 500px;
    bottom: -200px;
    right: -100px
}

.sust-split {
    z-index: 1;
    grid-template-columns: 5fr 7fr;
    align-items: start;
    gap: clamp(40px, 5vw, 96px);
    display: grid;
    position: relative
}

.sust-intro {
    position: sticky;
    top: 140px
}

.sub-title--green {
    color: #c8d4aa;
    background: #c8d4aa1f;
    border-color: #c8d4aa4d
}

.sust-card h3,
.sust-title {
    font-family: var(--font-heading);
    font-weight: var(--fw-bold);
    color: var(--pdv-white)
}

.sust-title {
    letter-spacing: var(--ls-display);
    margin-bottom: 24px;
    font-size: clamp(2.2rem, 4vw, 3.25rem);
    line-height: 1.15
}

.sust-desc {
    font-size: var(--type-body-lg);
    color: var(--pdv-white);
    line-height: var(--lh-body);
    max-width: 400px;
    margin: 0
}

.footer-widget h3:after,
.sust-accent {
    border-radius: var(--radius-full);
    width: 48px;
    height: 3px
}

.sust-accent {
    background: linear-gradient(90deg, #c8d4aa, #0000);
    margin-top: 40px
}

.sust-grid {
    grid-template-columns: repeat(2, 1fr);
    gap: 20px;
    display: grid
}

.sust-card {
    -webkit-backdrop-filter: blur(4px);
    background: #ffffff08;
    border: 1px solid #ffffff0f;
    border-radius: 20px;
    padding: 32px;
    transition: transform .4s, border-color .4s, background .4s;
    position: relative;
    overflow: hidden
}

.sust-card:hover {
    background: #a7b2870f;
    border-color: #a7b2874d;
    transform: translateY(-6px)
}

.sust-card-glow {
    opacity: 0;
    pointer-events: none;
    background: linear-gradient(135deg, #a7b2870f 0, #0000 60%);
    transition: opacity .5s;
    position: absolute;
    inset: 0
}

.sust-card:hover .sust-card-glow {
    opacity: 1
}

.sust-card-inner {
    z-index: 1;
    flex-direction: column;
    height: 100%;
    display: flex;
    position: relative
}

.sust-card-icon {
    color: #c8d4aa;
    background: #ffffff0a;
    border: 1px solid #ffffff14;
    border-radius: 16px;
    justify-content: center;
    align-items: center;
    width: 56px;
    height: 56px;
    margin-bottom: 24px;
    transition: transform .4s, background .4s, color .4s;
    display: flex;
    box-shadow: 0 4px 16px #0000001f
}

.sust-card:hover .sust-card-icon {
    color: #e0e8cc;
    background: #c8d4aa26;
    transform: scale(1.08)
}

.sust-card-icon .icon,
.sust-card-icon svg {
    width: 28px;
    height: 28px;
    color: inherit;
    stroke: currentColor;
    display: block
}

.sust-card h3 {
    font-size: var(--type-heading-4);
    margin-bottom: 10px;
    line-height: 1.3;
    transition: color .3s
}

.sust-card:hover h3 {
    color: #e0e8cc
}

.sust-card p {
    font-family: var(--font-body);
    font-weight: var(--fw-light);
    color: var(--pdv-text-on-dark-muted);
    margin: 0;
    line-height: 1.65
}

.fazendinhando-logo-link {
    display: inline-flex;
    flex-direction: column;
    align-items: flex-start;
    gap: 8px;
    margin-top: 16px;
    /* ALTERADO: removido `outline: none` sem substituto (violava WCAG 2.4.7).
       Foco agora cai no :focus-visible global (linha 250) com outline laranja. */
    border-radius: var(--radius-sm)
}

/* NOVO (A8): "Saiba mais ↗" abaixo da logo Fazendinhando, indica que o
   card e clicavel sem precisar inferir do contexto. */
.saiba-mais {
    font-family: var(--font-body);
    font-weight: var(--fw-bold);
    font-size: var(--type-body-sm);
    letter-spacing: .02em;
    color: var(--pdv-amarelo-dourado);
    transition: transform var(--transition-fast)
}

.saiba-mais-arrow {
    display: inline-block;
    margin-left: var(--space-2xs);
    transition: transform var(--transition-fast)
}

.sust-card--linked:hover .saiba-mais-arrow,
.fazendinhando-logo-link:hover .saiba-mais-arrow,
.fazendinhando-logo-link:focus-visible .saiba-mais-arrow {
    transform: translate(2px, -2px)
}

/* Mobile: section sustentabilidade — títulos brancos + textos à esquerda */
@media (max-width: 768px) {
    .sustainability .sub-title,
    .sustainability .sub-title--green,
    .sustainability .sust-title,
    .sustainability .sust-card h3 {
        color: var(--pdv-white)
    }
    .sustainability .sust-desc,
    .sustainability .sust-deeplink,
    .sustainability .sust-card p,
    .sustainability .sust-card--linked .pillar-icon ~ p,
    .sustainability .sust-card--linked p {
        text-align: left
    }
    .sustainability .fazendinhando-logo-link {
        margin-left: 0;
        margin-right: auto;
        align-items: flex-start
    }
    .sustainability .fazendinhando-logo-img {
        margin: 0
    }
}

.fazendinhando-logo-img {
    height: 48px;
    width: auto;
    filter: brightness(0) invert(1);
    transition: filter .8s ease;
    display: block
}

.fazendinhando-logo-link:hover .fazendinhando-logo-img,
.fazendinhando-logo-link:focus .fazendinhando-logo-img {
    filter: none
}

/* NOVO: em dispositivos sem hover (touch/mobile) a logo da Fazendinhando ja
   aparece colorida por default — nao depende de hover (que nao existe em touch). */
@media (hover: none), (max-width: 768px) {
    .fazendinhando-logo-img {
        filter: none
    }
}

/* NOVO: card-link pattern — o card inteiro vira clicavel sem aninhar <a>'s.
   O ::after do link expande para cobrir o card e captura o click em qualquer
   area; o link real (com a imagem) continua acessivel para foco/screen reader. */
.sust-card--linked {
    cursor: pointer
}

.sust-card--linked .fazendinhando-logo-link::after {
    content: "";
    position: absolute;
    inset: 0;
    z-index: 2
}

.sust-card--linked .fazendinhando-logo-link:focus-visible::after {
    outline: 2px solid var(--pdv-laranja);
    outline-offset: -4px;
    border-radius: var(--radius-md)
}

@media (width<=1024px) {
    .sust-split {
        grid-template-columns: 1fr;
        gap: 48px
    }

    .sust-intro {
        max-width: 560px;
        position: static
    }

    .sust-accent {
        display: none
    }

    .sust-grid {
        grid-template-columns: repeat(2, 1fr)
    }
}

@media (width<=640px) {
    .sustainability {
        padding: 80px 0
    }

    .sust-grid {
        grid-template-columns: 1fr
    }

    .sust-title {
        font-size: 2rem
    }

    .sust-glow {
        display: none
    }
}

.cliente-box:hover,
.clientes-area {
    background-color: var(--pdv-white)
}

.clientes-area {
    padding: 100px 0
}

.clientes-marquee {
    margin-top: 50px;
    position: relative;
    overflow: hidden
}

.clientes-marquee:after,
.clientes-marquee:before {
    content: "";
    z-index: 2;
    pointer-events: none;
    width: clamp(64px, 8vw, 140px);
    position: absolute;
    top: 0;
    bottom: 0
}

.clientes-marquee:before {
    background: linear-gradient(to right, var(--pdv-white) 0%, #ffffffe0 35%, #fff0 100%);
    left: -2px
}

.clientes-marquee:after {
    background: linear-gradient(to left, var(--pdv-white) 0%, #ffffffe0 35%, #fff0 100%);
    right: -2px
}

.clientes-track {
    width: max-content;
    animation: 26s linear infinite clientesMarquee
}

.clientes-marquee:hover .clientes-track {
    animation-play-state: paused
}

.cliente-box,
.clientes-sequence,
.clientes-track {
    align-items: center;
    display: flex
}

.clientes-sequence {
    gap: 30px;
    padding-right: 30px
}

.cliente-box {
    /* ALTERADO: bg-light (off-white #f7f8fa) -> white (#fff); cards agora
       se misturam com o fundo da .clientes-area (também branco), removendo
       a moldura cinza visual em torno dos logos. */
    background-color: var(--pdv-white);
    text-align: center;
    transition: var(--transition-fast);
    filter: grayscale(50%);
    opacity: .85;
    border: 1px solid #0000;
    flex: none;
    justify-content: center;
    width: 200px;
    height: 100px;
    padding: 0;
    overflow: hidden
}

.cliente-box:hover {
    filter: grayscale(0%);
    opacity: 1;
    box-shadow: var(--shadow-md);
    border-color: var(--pdv-gray-100);
    transform: translateY(-2px)
}

.cliente-box .cliente-logo {
    object-fit: contain;
    width: 100%;
    height: 100%;
    display: block
}

.footer {
    color: var(--pdv-gray-200);
    z-index: 1;
    background-color: #1a2e40;
    padding-top: 80px;
    position: relative;
    overflow: hidden
}

/* ALTERADO: h4 -> h3 (heading do footer subiu na hierarquia em Cat. A para
   evitar pulo h2->h4). Mesmas regras visuais, apenas seletor atualizado. */
.footer-widget h3 {
    color: var(--pdv-white);
    margin-bottom: 30px;
    padding-bottom: 16px;
    font-family: var(--font-heading);
    font-weight: var(--fw-bold);
    font-size: 1rem;
    position: relative
}

.footer-widget h3:after {
    content: "";
    background-color: var(--primary-color);
    position: absolute;
    bottom: 0;
    left: 0
}

.footer-logo,
.manifesto-intro h2 {
    font-family: var(--font-heading);
    font-weight: var(--fw-bold);
    color: var(--pdv-white)
}

.footer-logo {
    align-items: center;
    gap: 12px;
    margin-bottom: 24px;
    font-size: 1.75rem;
    display: flex
}

.footer-bottom,
.manifesto-pillar-card .pillar-body p {
    font-size: var(--type-body-sm);
    color: var(--pdv-text-on-dark-muted)
}

.footer-bottom {
    text-align: center;
    background-color: #11131866;
    border-top: 1px solid #ffffff0d;
    padding: 16px 0
}

.manifesto-area {
    background-color: var(--pdv-azul-profundo);
    z-index: 1;
    padding: 120px 0;
    position: relative;
    overflow: hidden
}

.manifesto-area:after,
.manifesto-grid:before {
    content: "";
    pointer-events: none;
    position: absolute
}

.manifesto-area:after {
    opacity: .03;
    filter: brightness(0)invert();
    z-index: -1;
    background-image: url("../images/grafismos/Grafismo PDV-08.svg");
    background-position: 50%;
    background-repeat: no-repeat;
    background-size: cover;
    inset: 0
}

.manifesto-grid {
    grid-template-columns: 1.1fr 1fr;
    align-items: center;
    gap: 72px;
    display: grid;
    position: relative
}

.manifesto-grid:before {
    background: linear-gradient(#0000 0, #faae3f40 30% 70%, #0000 100%);
    width: 1px;
    top: 10%;
    bottom: 10%;
    left: calc(55% - 36px)
}

.manifesto-intro {
    max-width: 560px
}

.manifesto-intro .sub-title {
    margin-bottom: 24px
}

.manifesto-intro h2 {
    font-size: var(--type-display-lg);
    line-height: var(--lh-display);
    letter-spacing: var(--ls-display);
    text-wrap: balance;
    margin-bottom: 28px
}

.manifesto-divider-x {
    background: linear-gradient(90deg, var(--pdv-amarelo-dourado), var(--pdv-laranja));
    border-radius: var(--radius-full);
    width: 64px;
    height: 3px;
    margin: 0 0 28px
}

.manifesto-text {
    font-size: var(--type-body-lg);
    color: var(--pdv-text-on-dark);
    line-height: var(--lh-body);
    max-width: 50ch;
    font-weight: var(--fw-light);
    margin-bottom: 36px
}

.manifesto-cta {
    margin-top: 0
}

.manifesto-pillars-v {
    flex-direction: column;
    gap: 18px;
    margin: 0;
    padding: 0;
    list-style: none;
    display: flex
}

.manifesto-pillar-card {
    border-radius: var(--radius-card);
    transition: var(--transition);
    -webkit-backdrop-filter: blur(2px);
    background: #11131873;
    border: 1px solid #ffffff1a;
    grid-template-columns: auto auto 1fr;
    /* ALTERADO: align-items: center -> start; número e ícone agora alinham
       pela altura do título (h3.pillar-title) em vez de pelo centro vertical
       de todo o card (que incluía a descrição). */
    align-items: start;
    column-gap: 20px;
    padding: 24px 28px;
    display: grid;
    position: relative;
    overflow: hidden
}

.manifesto-pillar-card:before {
    content: "";
    background: var(--pdv-amarelo-dourado);
    transform-origin: top;
    width: 3px;
    transition: transform .3s;
    position: absolute;
    top: 0;
    bottom: 0;
    left: 0;
    transform: scaleY(0)
}

.manifesto-pillar-card:hover {
    background: #11131899;
    border-color: #faae3f73;
    transform: translate(4px)
}

.manifesto-pillar-card:hover:before {
    transform: scaleY(1)
}

.pillar-num {
    font-family: var(--font-heading);
    font-weight: var(--fw-bold);
    color: var(--pdv-amarelo-dourado);
    letter-spacing: var(--ls-display);
    opacity: .35;
    min-width: 56px;
    font-size: 2.5rem;
    line-height: 1;
    transition: opacity .25s
}

.manifesto-pillar-card:hover .pillar-num {
    opacity: .7
}

.manifesto-pillar-card .pillar-icon {
    border-radius: var(--radius-card);
    width: 48px;
    height: 48px;
    transition: var(--transition);
    background: #faae3f1f;
    border: 1px solid #faae3f40;
    flex-shrink: 0;
    justify-content: center;
    align-items: center;
    margin: 0;
    display: flex
}

.manifesto-pillar-card:hover .pillar-icon {
    background: var(--pdv-amarelo-dourado);
    border-color: var(--pdv-amarelo-dourado)
}

.manifesto-pillar-card .pillar-icon .icon {
    width: 22px;
    height: 22px;
    color: var(--pdv-amarelo-dourado);
    transition: color var(--transition-fast)
}

.manifesto-pillar-card:hover .pillar-icon .icon {
    color: var(--pdv-azul-profundo)
}

.pillar-body {
    min-width: 0
}

.pillar-title {
    font-family: var(--font-heading);
    font-weight: var(--fw-bold);
    font-size: var(--type-body-lg);
    color: var(--pdv-white);
    margin-bottom: 4px;
    line-height: 1.3
}

.manifesto-pillar-card .pillar-body p {
    font-family: var(--font-body);
    font-weight: var(--fw-light);
    text-align: left;
    max-width: none;
    margin: 0;
    line-height: 1.55
}

@media (width<=1024px) {
    .manifesto-grid {
        grid-template-columns: 1fr;
        gap: 48px
    }

    .manifesto-grid:before {
        display: none
    }

    .manifesto-intro {
        text-align: left;
        max-width: none
    }

    .manifesto-area:after {
        opacity: .025
    }
}

@media (width<=640px) {
    .manifesto-area {
        padding: 80px 0
    }

    .manifesto-intro h2 {
        font-size: var(--type-heading-1)
    }

    .manifesto-pillar-card {
        grid-template-rows: auto auto;
        grid-template-columns: auto 1fr;
        row-gap: 12px;
        padding: 20px
    }

    .pillar-num {
        grid-area: 1/1;
        min-width: auto;
        font-size: 1.75rem
    }

    .manifesto-pillar-card .pillar-icon {
        grid-area: 1/2;
        justify-self: start
    }

    .pillar-body {
        grid-area: 2/1/auto/-1
    }
}

.contact-modal {
    z-index: 2000;
    opacity: 0;
    visibility: hidden;
    transition: opacity var(--transition), visibility var(--transition);
    justify-content: center;
    align-items: center;
    display: flex;
    position: fixed;
    inset: 0
}

.contact-modal[hidden] {
    display: none
}

.contact-modal.is-open {
    opacity: 1;
    visibility: visible
}

.contact-modal-backdrop {
    backdrop-filter: blur(4px);
    cursor: pointer;
    background: #11131899;
    position: absolute;
    inset: 0
}

.contact-modal-content {
    z-index: 1;
    background: var(--pdv-white);
    width: calc(100% - 48px);
    max-width: 520px;
    box-shadow: var(--shadow-xl);
    max-height: 90vh;
    transition: transform var(--transition);
    padding: 40px;
    position: relative;
    overflow-y: auto;
    transform: scale(.95)translateY(10px)
}

.contact-modal.is-open .contact-modal-content {
    transform: scale(1)translateY(0)
}

.contact-modal-header {
    justify-content: space-between;
    align-items: center;
    margin-bottom: 8px;
    display: flex
}

.contact-modal-header h2 {
    font-size: var(--type-heading-2);
    color: var(--heading-color);
    margin: 0
}

.contact-modal-close {
    border: 1px solid var(--pdv-gray-100);
    border-radius: var(--radius-full);
    width: 48px;
    height: 48px;
    color: var(--pdv-gray-400);
    cursor: pointer;
    transition: var(--transition);
    background: 0 0;
    flex-shrink: 0;
    justify-content: center;
    align-items: center;
    display: inline-flex
}

.contact-modal-close .icon {
    width: 20px;
    height: 20px;
    transform: rotate(45deg)
}

.contact-modal-close:hover {
    background: var(--pdv-off-white);
    border-color: var(--pdv-gray-200);
    color: var(--heading-color)
}

.contact-modal-desc {
    color: var(--pdv-text-secondary);
    font-size: var(--type-body);
    font-weight: var(--fw-light);
    max-width: none;
    margin-bottom: 28px
}

.contact-form .form-group {
    margin-bottom: 20px
}

.contact-form label {
    font-size: var(--type-body-sm);
    color: var(--heading-color);
    margin-bottom: 6px;
    display: block
}

.contact-form input[type=email],
.contact-form input[type=tel],
.contact-form input[type=text],
.contact-form textarea {
    width: 100%;
    font-family: var(--font-body);
    font-weight: var(--fw-light);
    font-size: var(--type-body);
    color: var(--text-color);
    background: var(--pdv-off-white);
    border: 1px solid var(--pdv-gray-200);
    border-radius: var(--radius-md);
    transition: var(--transition);
    outline: 0;
    padding: 14px 16px
}

.contact-form input:focus,
.contact-form textarea:focus {
    border-color: var(--primary-color);
    background: var(--pdv-white);
    box-shadow: 0 0 0 3px #c76e3026
}

.contact-form input:focus-visible,
.contact-form textarea:focus-visible {
    outline: 2px solid var(--pdv-laranja);
    outline-offset: 2px
}

.contact-form input::placeholder,
.contact-form textarea::placeholder {
    color: var(--pdv-gray-400);
    font-weight: var(--fw-light)
}

.contact-form textarea {
    resize: vertical;
    min-height: 100px
}

.contact-form-submit {
    justify-content: center;
    width: 100%;
    margin-top: 8px
}

@media (width<=768px) {
    .contact-modal-content {
        width: calc(100% - 32px);
        max-height: 95vh;
        padding: 28px 24px
    }

    .contact-modal-header h2 {
        font-size: var(--type-heading-3)
    }
}

.faq-area {
    background-color: var(--bg-light);
    padding: 100px 0
}

.faq-list {
    flex-direction: column;
    gap: 12px;
    max-width: 820px;
    margin: 0 auto;
    display: flex
}

.faq-item {
    background-color: var(--pdv-white);
    border: 1px solid var(--pdv-gray-100);
    box-shadow: var(--shadow-sm);
    transition: var(--transition);
    overflow: hidden
}

.faq-item:hover,
.faq-item[open] {
    border-color: var(--pdv-gray-200);
    box-shadow: var(--shadow-md)
}

.faq-item[open] {
    border-color: var(--primary-color)
}

.faq-item summary {
    cursor: pointer;
    font-family: var(--font-heading);
    font-weight: var(--fw-regular);
    color: var(--heading-color);
    transition: var(--transition);
    justify-content: space-between;
    align-items: center;
    gap: 20px;
    min-height: 48px;
    padding: 22px 28px;
    list-style: none;
    display: flex
}

.faq-item summary::-webkit-details-marker {
    display: none
}

.faq-item summary::marker {
    content: ""
}

.faq-item summary:hover {
    background-color: #29496405
}

.faq-item summary:focus-visible {
    outline: 2px solid var(--pdv-laranja);
    outline-offset: -2px;
    border-radius: var(--radius-lg)
}

.faq-question {
    font-size: var(--type-body-lg);
    text-align: left;
    flex: 1;
    line-height: 1.4
}

.faq-chevron {
    width: 24px;
    height: 24px;
    color: var(--primary-color);
    transition: transform var(--transition);
    flex-shrink: 0
}

.faq-item[open] .faq-chevron {
    transform: rotate(45deg)
}

.faq-answer {
    color: var(--pdv-text-secondary);
    font-family: var(--font-body);
    font-weight: var(--fw-light);
    font-size: var(--type-body);
    line-height: var(--lh-body);
    padding: 0 28px 24px;
    animation: .3s ease-out faqOpen
}

.faq-answer p {
    max-width: none;
    margin: 0
}

.faq-answer p+p {
    margin-top: 12px
}

.faq-answer strong {
    color: var(--heading-color);
    font-family: var(--font-heading);
    font-weight: var(--fw-bold)
}

.reveal {
    opacity: 0;
    transition: opacity .6s ease-out, transform .6s ease-out;
    transform: translateY(30px)
}

.reveal.active {
    opacity: 1;
    transform: translateY(0)
}

@media (prefers-reduced-motion:reduce) {

    *,
    :after,
    :before {
        scroll-behavior: auto !important;
        transition-duration: .01ms !important;
        animation-duration: .01ms !important;
        animation-iteration-count: 1 !important
    }

    .reveal {
        opacity: 1;
        transform: none
    }

    .clientes-track {
        animation: none
    }
}

@media (width<=1024px) {
    :root {
        --layout-gutter: 24px
    }

    .hero h1 {
        font-size: 2.75rem
    }

    .about-wrapper,
    .features-grid {
        grid-template-columns: 1fr
    }

    .footer-grid,
    .services-grid,
    .sust-grid {
        grid-template-columns: repeat(2, 1fr)
    }

    .experience-badge {
        top: 0;
        left: 0
    }
}

@media (width<=768px) {
    body {
        font-size: .9375rem;
        line-height: 1.5
    }

    .features-grid {
        gap: 16px
    }

    .topbar {
        display: none
    }

    .main-menu {
        background: var(--pdv-white);
        opacity: 0;
        visibility: hidden;
        pointer-events: none;
        flex-direction: column;
        gap: 2px;
        width: 100%;
        max-height: 0;
        padding: 0 24px;
        transition: max-height .5s cubic-bezier(.22, 1, .36, 1), padding .5s cubic-bezier(.22, 1, .36, 1), opacity .3s ease-out, visibility 0s linear .3s;
        display: flex;
        position: absolute;
        top: calc(100% - 1px);
        left: 0;
        overflow: hidden;
        box-shadow: 0 18px 40px #2949641f;
        border-bottom-left-radius: 5px;
        border-bottom-right-radius: 5px
    }

    .main-menu.is-open {
        opacity: 1;
        visibility: visible;
        pointer-events: auto;
        max-height: calc(100vh - 72px);
        padding: 18px 24px 28px;
        transition: max-height .5s cubic-bezier(.22, 1, .36, 1), padding .5s cubic-bezier(.22, 1, .36, 1), opacity .3s ease-out 50ms, visibility linear;
        overflow-y: auto;
        border-bottom-left-radius: 5px;
        border-bottom-right-radius: 5px
    }

    .main-menu>a {
        opacity: 0;
        border-bottom: none;
        padding: 14px 0;
        transition: transform .45s cubic-bezier(.22, 1, .36, 1), opacity .35s ease-out, color .2s;
        transform: translateY(-10px)
    }

    .main-menu>a.is-active:before {
        content: "";
        background: var(--pdv-laranja);
        position: absolute;
        transform-origin: 50%;
        width: 3px;
        height: 22px;
        animation: .32s cubic-bezier(.22, 1, .36, 1) forwards navBarIn;
        top: 50%;
        bottom: auto;
        left: -10px;
        transform: translateY(-50%)scaleY(0)
    }

    @keyframes navBarIn {
        0% {
            opacity: 0;
            transform: translateY(-50%)scaleY(0)
        }

        to {
            opacity: 1;
            transform: translateY(-50%)scaleY(1)
        }
    }

    .main-menu>a.is-active {
        padding-left: 0
    }

    .main-menu.is-open .menu-socials,
    .main-menu.is-open>a {
        opacity: 1;
        transform: translateY(0)
    }

    .main-menu.is-open>a:first-child {
        transition-delay: 80ms, 80ms, 0s
    }

    .main-menu.is-open>a:nth-child(2) {
        transition-delay: .12s, .12s, 0s
    }

    .main-menu.is-open>a:nth-child(3) {
        transition-delay: .16s, .16s, 0s
    }

    .main-menu.is-open>a:nth-child(4) {
        transition-delay: .2s, .2s, 0s
    }

    .main-menu.is-open>a:nth-child(5) {
        transition-delay: .24s, .24s, 0s
    }

    .main-menu.is-open>a:nth-child(6) {
        transition-delay: .28s, .28s, 0s
    }

    .main-menu.is-open>a:nth-child(7) {
        transition-delay: .32s, .32s, 0s
    }

    .main-menu.is-open>a:nth-child(8) {
        transition-delay: .36s, .36s, 0s
    }

    .menu-socials {
        opacity: 0;
        justify-content: center;
        gap: 12px;
        margin-top: 8px;
        padding-top: 24px;
        transition: transform .45s cubic-bezier(.22, 1, .36, 1) .42s, opacity .35s ease-out .42s;
        display: flex;
        transform: translateY(-10px)
    }

    .header-actions .header-socials,
    .header-actions .theme-btn {
        display: none
    }

    .mobile-toggle {
        display: inline-flex
    }

    .header-actions {
        gap: 12px
    }

    .header-socials {
        gap: 8px
    }

    .header-social-link {
        width: 44px;
        height: 44px;
        font-size: 1.1rem
    }

    .footer-grid,
    .services-grid,
    .sust-grid {
        grid-template-columns: 1fr
    }

    .section-divider-banner {
        min-height: 30vh
    }

    .section-divider-banner p {
        letter-spacing: .05em
    }

    .clientes-sequence {
        gap: 20px;
        padding-right: 20px
    }

    .cliente-box {
        width: 160px;
        height: 80px;
        padding: 0
    }

    .hero h1 {
        font-size: var(--type-display-lg)
    }

    .about-img-2 {
        display: none
    }

    .about-img-1 {
        width: 100%
    }

    .section-title {
        font-size: var(--type-heading-1)
    }
}

.cliente-box,
.contact-modal-content,
.experience-badge,
.faq-item,
.feature-box,
.feature-icon,
.service-card,
.service-icon,
.sust-card {
    border-radius: var(--radius-card)
}

.header-social-link,
.pillar-icon,
.sub-title {
    border-radius: var(--radius-full)
}

.main-menu a.nav-cta {
    background-color: var(--pdv-laranja);
    color: var(--pdv-white);
    border-radius: var(--radius-btn);
    letter-spacing: var(--ls-button);
    font-weight: var(--fw-bold);
    min-height: 40px;
    transition: var(--transition);
    padding: 10px 20px
}

.main-menu a.nav-cta:hover {
    background-color: var(--pdv-azul-profundo);
    color: var(--pdv-white);
    box-shadow: var(--shadow-sm);
    transform: translateY(-1px)
}

.hero {
    background: var(--pdv-azul-profundo)url(../images/bg/hero-bg.webp)center/cover no-repeat;
    isolation: isolate;
    align-items: center;
    height: auto;
    min-height: 560px;
    padding: 80px 0;
    display: flex;
    position: relative;
    overflow: hidden
}

/* PERF: no mobile o hero usa a variante leve (LCP). Vem apos a regra
   global .hero p/ vencer por ordem em <=768px; desktop mantem hero-bg.webp. */
@media (max-width: 768px) {
    .hero {
        background-image: url(../images/bg/hero-bg-mobile.webp);
    }
}

.hero:before {
    content: "";
    z-index: 0;
    pointer-events: none;
    background: linear-gradient(90deg, #294964f5 0, #294964e6 50%, #294964c7 100%);
    display: block;
    position: absolute;
    inset: 0
}

.hero .container {
    z-index: 2;
    position: relative
}

.hero-content {
    padding-bottom: 0
}

.hero-subtitle {
    border-radius: var(--radius-btn);
    font-size: var(--type-body-sm);
    background: #ffffff14;
    border: 1px solid #ffffff2e;
    padding: 8px 16px
}

.hero h1 {
    font-size: clamp(2rem, 5vw, var(--type-display-hero))
}

.hero-btns {
    margin-top: 32px
}

.hero-features {
    background: var(--pdv-white);
    border-top: 3px solid var(--pdv-laranja);
    z-index: 3;
    padding: 28px 0;
    position: relative;
    box-shadow: 0 2px 12px #2949640d
}

.hero-features .features-grid {
    grid-template-columns: repeat(3, 1fr);
    align-items: center;
    gap: 0;
    display: grid
}

.hero-features .feature-box {
    border: 0;
    border-right: 1px solid var(--pdv-gray-100);
    box-shadow: none;
    background: 0 0;
    border-radius: 0;
    /* ALTERADO: align-items center -> flex-start; o icone alinha pelo topo
       com o h3 do feature-content (em vez de ficar centralizado entre h3 e p). */
    align-items: flex-start;
    gap: 18px;
    padding: 8px 32px;
    transition: none;
    display: flex
}

.hero-features .feature-box:last-child {
    border-right: none
}

.hero-features .feature-box:hover {
    box-shadow: none;
    transform: none
}

.hero-features .feature-box:hover .feature-icon {
    background-color: var(--pdv-laranja);
    color: var(--pdv-white);
    transform: none
}

.hero-features .feature-icon {
    border-radius: var(--radius-btn);
    width: 48px;
    height: 48px;
    color: var(--pdv-laranja);
    transition: var(--transition);
    background-color: #c76e3014;
    flex-shrink: 0;
    font-size: 22px
}

.hero-features .feature-content h3 {
    font-size: var(--type-body-lg);
    font-weight: var(--fw-bold);
    color: var(--pdv-azul-profundo);
    margin-bottom: 2px
}

.hero-features .feature-content p {
    font-size: var(--type-body-sm);
    color: var(--pdv-text-secondary);
    max-width: none;
    margin: 0;
    line-height: 1.5
}

.stats-area {
    background-color: var(--pdv-azul-profundo);
    padding: 48px 0;
    position: relative;
    overflow: hidden
}

.stats-area:before {
    content: "";
    pointer-events: none;
    background-image: radial-gradient(#ffffff0a 1px, #0000 1px);
    background-size: 24px 24px;
    position: absolute;
    inset: 0
}

.stats-grid {
    z-index: 1;
    grid-template-columns: repeat(4, 1fr);
    gap: 0;
    display: grid;
    position: relative
}

.stat-item {
    text-align: center;
    transition: var(--transition);
    background-color: #0000;
    border-right: 1px solid #ffffff1f;
    padding: 28px 24px
}

.stat-item:last-child {
    border-right: none
}

.stat-item:hover {
    background-color: #ffffff0a
}

.stat-label,
.stat-number {
    font-family: var(--font-heading)
}

.stat-number {
    font-weight: var(--fw-bold);
    font-size: var(--type-display-lg);
    color: var(--pdv-white);
    letter-spacing: var(--ls-display);
    line-height: 1
}

.stat-label {
    font-weight: var(--fw-regular);
    font-size: var(--type-caption);
    color: var(--pdv-text-on-dark-muted);
    text-transform: uppercase;
    letter-spacing: var(--ls-uppercase);
    margin-top: 10px
}

.experience-badge-number small {
    font-size: 1.5rem;
    font-weight: var(--fw-bold);
    vertical-align: 12px
}

.sub-title--dark {
    color: var(--pdv-amarelo-dourado);
    background: #faae3f1f;
    border-color: #faae3f38
}

.process-area {
    background-color: var(--pdv-white);
    padding: 100px 0;
    position: relative;
    overflow: hidden
}

.process-graphic {
    opacity: .04;
    pointer-events: none;
    z-index: 0;
    width: 500px;
    height: 500px;
    position: absolute;
    top: 50%;
    right: -120px;
    transform: translateY(-50%)
}

.process-graphic img {
    object-fit: contain;
    width: 100%;
    height: 100%
}

.process-area .container {
    z-index: 1;
    position: relative
}

.process-steps {
    counter-reset: process;
    grid-template-columns: repeat(3, 1fr);
    gap: 24px;
    max-width: 1100px;
    margin: 0 auto;
    padding: 0;
    list-style: none;
    display: grid;
    position: relative
}

.process-steps:before {
    content: "";
    background: linear-gradient(to right, var(--pdv-laranja) 0%, var(--pdv-amarelo-dourado) 50%, var(--pdv-laranja) 100%);
    z-index: 0;
    opacity: .35;
    height: 2px;
    position: absolute;
    top: 52px;
    left: 16.66%;
    right: 16.66%
}

.process-step {
    background: var(--pdv-white);
    border: 1px solid var(--pdv-gray-100);
    border-radius: var(--radius-card);
    text-align: center;
    z-index: 1;
    transition: var(--transition);
    border-top: 3px solid var(--pdv-laranja);
    padding: 32px 28px;
    position: relative
}

.process-step:hover {
    box-shadow: var(--shadow-lg);
    border-color: var(--pdv-gray-200);
    border-top-color: var(--pdv-laranja);
    transform: translateY(-4px)
}

.process-step-head {
    flex-direction: column;
    align-items: center;
    gap: 16px;
    margin-bottom: 20px;
    display: flex
}

.process-step-num {
    font-family: var(--font-heading);
    font-weight: var(--fw-bold);
    color: var(--pdv-laranja);
    letter-spacing: var(--ls-display);
    opacity: .25;
    font-size: 3rem;
    line-height: 1
}

.process-step-icon {
    background: var(--pdv-azul-profundo);
    width: 56px;
    height: 56px;
    color: var(--pdv-white);
    border-radius: var(--radius-card);
    box-shadow: var(--shadow-sm);
    justify-content: center;
    align-items: center;
    font-size: 22px;
    display: flex
}

.process-step-title {
    font-family: var(--font-heading);
    font-weight: var(--fw-bold);
    font-size: var(--type-heading-3);
    color: var(--pdv-azul-profundo);
    margin-bottom: 12px
}

.process-step-text {
    font-size: var(--type-body-sm);
    color: var(--pdv-text-secondary);
    line-height: var(--lh-body);
    text-align: center;
    max-width: 28ch;
    margin: 0 auto
}

.testimonials-area {
    background-color: var(--pdv-off-white);
    padding: 100px 0
}

.testimonials-grid {
    grid-template-columns: repeat(3, 1fr);
    gap: 28px;
    max-width: 1200px;
    margin: 0 auto;
    display: grid
}

.testimonial-card {
    background: var(--pdv-white);
    border: 1px solid var(--pdv-gray-100);
    border-top: 3px solid var(--pdv-laranja);
    border-radius: var(--radius-card);
    transition: var(--transition);
    box-shadow: var(--shadow-sm);
    flex-direction: column;
    gap: 20px;
    padding: 32px 28px;
    display: flex
}

.testimonial-card:hover {
    box-shadow: var(--shadow-md);
    transform: translateY(-3px)
}

.testimonial-stars {
    color: var(--pdv-amarelo-dourado);
    gap: 4px;
    display: flex
}

.testimonial-stars .icon {
    width: 18px;
    height: 18px
}

.testimonial-text {
    font-family: var(--font-body);
    font-weight: var(--fw-light);
    font-size: var(--type-body);
    color: var(--pdv-text-primary);
    line-height: var(--lh-body);
    quotes: "“" "”";
    border-left: 2px solid var(--pdv-gray-100);
    flex: 1;
    max-width: none;
    margin: 0;
    padding-left: 8px;
    font-style: italic;
    position: relative
}

.testimonial-author {
    border-top: 1px solid var(--pdv-gray-100);
    align-items: center;
    gap: 14px;
    margin: 0;
    padding-top: 16px;
    display: flex
}

.testimonial-avatar,
.testimonial-name {
    font-family: var(--font-heading);
    font-weight: var(--fw-bold);
    font-size: var(--type-body-sm)
}

.testimonial-avatar {
    background: linear-gradient(135deg, var(--pdv-laranja) 0%, var(--pdv-azul-profundo) 100%);
    border-radius: var(--radius-full);
    width: 44px;
    height: 44px;
    color: var(--pdv-white);
    flex-shrink: 0;
    justify-content: center;
    align-items: center;
    display: flex
}

.testimonial-name {
    color: var(--pdv-azul-profundo)
}

.testimonial-role {
    font-size: var(--type-caption);
    color: var(--pdv-text-tertiary);
    margin-top: 2px
}

.contact-area {
    background-color: var(--pdv-white);
    padding: 100px 0;
    position: relative
}

.contact-wrapper {
    grid-template-columns: 1fr 1.4fr;
    align-items: start;
    gap: 56px;
    max-width: 1100px;
    margin: 0 auto;
    display: grid
}

.contact-info,
.contact-info-title {
    color: var(--pdv-white);
    position: relative
}

.contact-info {
    background: linear-gradient(165deg, var(--pdv-azul-profundo) 0%, #1f3a50 100%);
    border-radius: var(--radius-card);
    padding: 40px 32px;
    overflow: hidden
}

.contact-info:before {
    content: "";
    pointer-events: none;
    background-image: radial-gradient(#ffffff0a 1px, #0000 1px);
    background-size: 20px 20px;
    position: absolute;
    inset: 0
}

.contact-info-title {
    font-family: var(--font-heading);
    font-weight: var(--fw-bold);
    font-size: var(--type-heading-3);
    z-index: 1;
    margin-bottom: 8px
}

.contact-info-desc {
    font-size: var(--type-body-sm);
    color: var(--pdv-text-on-dark-muted);
    z-index: 1;
    max-width: none;
    margin-bottom: 32px;
    position: relative
}

.contact-channel {
    transition: var(--transition-fast);
    z-index: 1;
    color: inherit;
    border-bottom: 1px solid #ffffff14;
    align-items: center;
    gap: 16px;
    padding: 14px 0;
    display: flex;
    position: relative
}

.contact-channel:last-child {
    border-bottom: none
}

.contact-channel:hover {
    padding-left: 8px
}

.contact-channel-icon {
    background-color: var(--pdv-laranja);
    width: 40px;
    height: 40px;
    color: var(--pdv-white);
    border-radius: var(--radius-btn);
    flex-shrink: 0;
    justify-content: center;
    align-items: center;
    line-height: 0;
    display: inline-flex
}

.contact-channel-icon .icon,
.contact-channel-icon svg {
    width: 20px;
    height: 20px;
    color: var(--pdv-white);
    fill: currentColor;
    stroke: currentColor;
    flex-shrink: 0;
    display: block
}

.contact-channel-info {
    flex-direction: column;
    gap: 2px;
    display: flex
}

.contact-channel-label {
    font-family: var(--font-heading);
    font-weight: var(--fw-regular);
    font-size: var(--type-caption);
    color: var(--pdv-text-on-dark-muted);
    text-transform: uppercase;
    letter-spacing: var(--ls-uppercase)
}

.contact-channel-value {
    font-family: var(--font-heading);
    font-weight: var(--fw-bold);
    font-size: var(--type-body);
    color: var(--pdv-white)
}

.contact-form-inline {
    background: var(--pdv-white);
    border: 1px solid var(--pdv-gray-100);
    border-top: 3px solid var(--pdv-laranja);
    border-radius: var(--radius-card);
    box-shadow: var(--shadow-md);
    padding: 40px
}

.contact-form-inline label,
.contact-form-title {
    font-family: var(--font-heading);
    font-weight: var(--fw-bold);
    font-size: var(--type-heading-3);
    color: var(--pdv-azul-profundo);
    margin-bottom: 24px
}

/* NOVO: instrução de campos obrigatórios; texto sutil, fundo branco/off-white. */
.form-help {
    font-family: var(--font-body);
    font-size: var(--type-body-sm);
    color: var(--pdv-text-tertiary);
    margin: -16px 0 20px;
    display: block
}

.form-help span[aria-hidden] {
    color: var(--pdv-laranja);
    font-weight: var(--fw-bold)
}

.contact-modal-desc .form-help {
    margin: 8px 0 0
}

.contact-form-inline .form-row {
    grid-template-columns: 1fr 1fr;
    gap: 16px;
    margin-bottom: 0;
    display: grid
}

.contact-form-inline .form-group {
    margin-bottom: 16px
}

.contact-form-inline label {
    font-weight: var(--fw-regular);
    font-size: var(--type-body-sm);
    margin-bottom: 6px;
    display: block
}

.contact-form-inline input[type=email],
.contact-form-inline input[type=tel],
.contact-form-inline input[type=text] {
    min-height: 48px
}

.contact-form-inline input[type=email],
.contact-form-inline input[type=tel],
.contact-form-inline input[type=text],
.contact-form-inline textarea {
    width: 100%;
    font-family: var(--font-body);
    font-weight: var(--fw-light);
    font-size: var(--type-body);
    color: var(--pdv-text-primary);
    background: var(--pdv-off-white);
    border: 1px solid var(--pdv-gray-200);
    border-radius: var(--radius-input);
    transition: var(--transition);
    outline: 0;
    padding: 14px 16px
}

.contact-form-inline input:focus,
.contact-form-inline textarea:focus {
    border-color: var(--pdv-laranja);
    background: var(--pdv-white);
    box-shadow: 0 0 0 3px #c76e301f
}

.contact-form-inline input:focus-visible,
.contact-form-inline textarea:focus-visible {
    outline: 2px solid var(--pdv-laranja);
    outline-offset: 2px
}

.contact-form-inline textarea {
    resize: vertical;
    min-height: 120px
}

.contact-form-inline .contact-form-submit {
    justify-content: center;
    width: 100%;
    margin-top: 8px
}

.footer-grid {
    grid-template-columns: 1fr 1fr;
    align-items: start;
    gap: 64px;
    margin-bottom: 48px;
    display: grid;
    position: relative
}

.footer-grid:before {
    content: "";
    pointer-events: none;
    background: linear-gradient(#0000 0, #ffffff1f 20% 80%, #0000 100%);
    width: 1px;
    position: absolute;
    top: 0;
    bottom: 0;
    left: 50%
}

.footer-widget--brand {
    max-width: 460px
}

.footer-widget--brand p {
    max-width: 42ch;
    margin-bottom: 24px
}

.footer-socials {
    gap: 10px;
    margin-top: 8px;
    display: flex
}

.footer-social-link {
    border-radius: var(--radius-full);
    width: 46px;
    height: 46px;
    color: var(--pdv-text-on-dark);
    transition: var(--transition);
    background: #ffffff0f;
    border: 1px solid #ffffff1a;
    justify-content: center;
    align-items: center;
    font-size: 1.05rem;
    display: inline-flex
}

.footer-contact-card:hover .footer-contact-card-icon,
.footer-social-link:hover {
    background: var(--pdv-laranja);
    border-color: var(--pdv-laranja);
    color: var(--pdv-white)
}

.footer-social-link:hover {
    transform: translateY(-2px)
}

button.footer-social-link[data-open-email-modal] .icon {
    width: 1.2rem;
    height: 1.2rem
}

.footer-credit {
    font-size: var(--type-body-sm);
    color: var(--pdv-text-on-dark-muted);
    text-align: center;
    flex: none;
    margin: 0
}

.footer-contact-card-body strong,
.footer-credit a {
    font-family: var(--font-heading);
    font-weight: var(--fw-bold)
}

.footer-credit a {
    /* ALTERADO: --pdv-laranja sobre fundo azul-profundo tinha 2.58:1 (falhava
       até em texto large). --pdv-amarelo-dourado dá 4.96:1 e mantém harmonia
       de paleta com o footer escuro. */
    color: var(--pdv-amarelo-dourado);
    transition: var(--transition-fast);
    border-bottom: 1px solid #0000
}

.footer-credit a:hover {
    color: var(--pdv-amarelo-dourado);
    border-bottom-color: var(--pdv-amarelo-dourado)
}

.footer-contact-cards {
    flex-direction: column;
    gap: 14px;
    font-style: normal;
    display: flex
}

.footer-contact-card {
    border-radius: var(--radius-card);
    color: inherit;
    transition: var(--transition);
    -webkit-backdrop-filter: blur(2px);
    background: #29496466;
    border: 1px solid #ffffff1a;
    align-items: flex-start;
    gap: 16px;
    padding: 18px 20px;
    text-decoration: none;
    display: flex
}

.footer-contact-card:hover {
    background: #29496499;
    border-color: #c76e3080;
    transform: translate(2px)
}

.footer-contact-card-icon {
    border-radius: var(--radius-btn);
    width: 40px;
    height: 40px;
    color: var(--pdv-laranja);
    transition: var(--transition);
    background: #c76e302e;
    border: 1px solid #c76e3066;
    flex-shrink: 0;
    justify-content: center;
    align-items: center;
    display: flex
}

.footer-contact-card:hover .footer-contact-card-icon {
    box-shadow: 0 0 0 3px #c76e3033
}

.footer-contact-card-icon .icon,
.footer-contact-card-icon svg {
    width: 18px;
    height: 18px;
    color: inherit;
    fill: currentColor;
    stroke: currentColor;
    display: block
}

.footer-contact-card-body {
    flex-direction: column;
    flex: 1;
    gap: 4px;
    min-width: 0;
    display: flex
}

.footer-contact-card-body strong {
    font-size: var(--type-body-sm);
    color: var(--pdv-white);
    line-height: 1.3
}

.footer-contact-card-body span,
.footer-legal a {
    font-size: var(--type-body-sm);
    color: var(--pdv-text-on-dark-muted)
}

.footer-contact-card-body span {
    font-family: var(--font-body);
    font-weight: var(--fw-light);
    line-height: 1.5
}

.footer-bottom .container {
    flex-wrap: wrap;
    justify-content: space-between;
    align-items: center;
    gap: 20px;
    display: flex
}

.footer-copyright {
    flex: none;
    margin: 0
}

.footer-legal {
    gap: 20px;
    margin: 0;
    padding: 0;
    display: flex
}

.footer-legal li {
    margin: 0
}

.footer-legal a {
    transition: var(--transition-fast)
}

.back-to-top,
.footer-legal a:hover {
    color: var(--pdv-white)
}

.back-to-top {
    right: calc(24px + env(safe-area-inset-right, 0));
    bottom: calc(24px + env(safe-area-inset-bottom, 0));
    background: var(--pdv-laranja);
    border-radius: var(--radius-btn);
    cursor: pointer;
    width: 48px;
    height: 48px;
    box-shadow: var(--shadow-md);
    opacity: 0;
    visibility: hidden;
    transition: opacity var(--transition), visibility var(--transition), transform var(--transition), background-color 0.4s cubic-bezier(0.25, 0.8, 0.25, 1);
    z-index: 900;
    border: 0;
    justify-content: center;
    align-items: center;
    display: inline-flex;
    position: fixed;
    transform: translateY(12px)
}

.back-to-top.is-over-cta {
    background: var(--pdv-azul-profundo) !important
}

.back-to-top.is-visible {
    opacity: 1;
    visibility: visible;
    transform: translateY(0)
}

.back-to-top:hover {
    background: var(--pdv-azul-profundo);
    box-shadow: var(--shadow-lg);
    transform: translateY(-2px)
}

.back-to-top .icon {
    width: 20px;
    height: 20px
}

@media (width<=1024px) {
    .stats-grid {
        grid-template-columns: repeat(2, 1fr)
    }

    .stat-item:nth-child(2n) {
        border-right: none
    }

    .hero-features .features-grid {
        grid-template-columns: repeat(3, 1fr)
    }

    .hero-features .feature-box {
        gap: 12px;
        padding: 8px 16px
    }

    .hero-features .feature-icon {
        width: 40px;
        height: 40px
    }

    .process-steps {
        grid-template-columns: 1fr;
        gap: 20px
    }

    .footer-grid:before,
    .process-steps:before {
        display: none
    }

    .testimonials-grid {
        grid-template-columns: 1fr;
        max-width: 640px
    }

    .contact-wrapper,
    .footer-grid {
        grid-template-columns: 1fr;
        gap: 32px
    }

    .footer-grid {
        gap: 40px
    }

    .footer-widget--brand {
        grid-column: auto;
        max-width: none
    }
}

@media (width<=768px) {
    .theme-btn {
        letter-spacing: .04em;
        white-space: normal;
        gap: 10px;
        width: 100%;
        min-height: 48px;
        padding: 14px 22px;
        font-size: .95rem;
        line-height: 1.25;
        display: flex
    }

    .main-menu a.nav-cta {
        width: auto;
        color: var(--pdv-laranja);
        background-color: #0000;
        padding: 14px 0;
        display: inline-flex
    }

    .theme-btn-icon {
        flex-shrink: 0;
        width: 1em;
        height: 1em
    }

    .theme-btn-hero {
        letter-spacing: .03em;
        padding: 14px 20px;
        font-size: .95rem
    }

    .footer-widget--brand {
        text-align: center
    }

    .footer-widget--brand p {
        max-width: 42ch;
        margin-left: auto;
        margin-right: auto
    }

    .footer-logo {
        display: inline-block
    }

    .footer-socials {
        justify-content: center;
        gap: 14px
    }

    .hero {
        padding: 80px 0 0
    }

    .hero-features {
        padding: 16px 0
    }

    .hero-features .features-grid {
        grid-template-columns: 1fr;
        gap: 4px
    }

    .hero-features .feature-box {
        border-right: none;
        border-bottom: 1px solid var(--pdv-gray-100);
        padding: 14px 0
    }

    .hero-features .feature-box:last-child {
        border-bottom: none
    }

    .stat-number {
        font-size: var(--type-heading-1)
    }

    .contact-form-inline {
        padding: 28px 24px
    }

    .contact-form-inline .form-row,
    .footer-grid {
        grid-template-columns: 1fr
    }

    .footer-grid {
        gap: 32px
    }

    .footer-widget--brand {
        grid-column: auto
    }

    .footer-bottom .container {
        text-align: center;
        flex-direction: column
    }

    .footer-legal {
        justify-content: center
    }

    .main-menu a.nav-cta.is-active {
        color: var(--pdv-laranja);
        box-shadow: none;
        background-color: #0000;
        padding-left: 0
    }

    .main-menu>a.nav-cta.is-active:before {
        content: "";
        background: var(--pdv-laranja);
        transform-origin: 50%;
        width: 3px;
        height: 22px;
        animation: .32s cubic-bezier(.22, 1, .36, 1) forwards navBarIn;
        display: block;
        position: absolute;
        top: 50%;
        bottom: auto;
        left: -10px;
        transform: translateY(-50%)scaleY(0)
    }

    .back-to-top {
        bottom: 16px;
        right: 16px
    }
}

.toast {
    width: 360px;
    max-width: calc(100vw - 32px);
    color: var(--pdv-white);
    opacity: 0;
    z-index: 9999;
    pointer-events: none;
    font-family: var(--font-body);
    border-radius: 16px;
    padding: 24px 20px 24px 40px;
    transition: opacity .32s, transform .42s cubic-bezier(.22, 1, .36, 1);
    position: fixed;
    bottom: 32px;
    right: 32px;
    overflow: visible;
    transform: translate(calc(100% + 48px))scale(.96);
    box-shadow: 0 10px 30px #0000002e
}

.toast.is-visible {
    opacity: 1;
    pointer-events: auto;
    transform: translate(0)scale(1)
}

.toast-bg-wrapper {
    z-index: 0;
    border-radius: 16px;
    position: absolute;
    inset: 0;
    overflow: hidden
}

.toast-blobs {
    width: 150px;
    height: 100px;
    fill: var(--toast-dark);
    opacity: .72;
    position: absolute;
    bottom: 0;
    left: 0
}

.toast-badge {
    z-index: 2;
    justify-content: center;
    align-items: center;
    width: 60px;
    height: 60px;
    display: flex;
    position: absolute;
    top: -24px;
    left: -4px
}

.bubble-bg,
.bubble-icon {
    stroke-linecap: round;
    stroke-linejoin: round
}

.bubble-bg {
    z-index: -1;
    width: 100%;
    height: 100%;
    fill: var(--toast-dark);
    stroke: #ffffff80;
    stroke-width: 1.5px;
    filter: drop-shadow(0 4px 6px #00000026);
    position: absolute;
    inset: 0
}

.bubble-icon {
    z-index: 1;
    fill: none;
    width: 22px;
    height: 22px;
    stroke: var(--pdv-white);
    stroke-width: 3.5px;
    position: relative
}

.toast-close {
    color: inherit;
    cursor: pointer;
    z-index: 2;
    opacity: .8;
    background: 0 0;
    border: 0;
    /* ALTERADO: padding maior para satisfazer WCAG 2.5.8 target size (24x24 mínimo).
       Padding 8 + svg 12 = 28x28 efetivo. */
    padding: 8px;
    border-radius: var(--radius-full);
    transition: opacity .2s, background-color .2s;
    display: flex;
    align-items: center;
    justify-content: center;
    position: absolute;
    top: 12px;
    right: 12px
}

.toast-close:hover {
    opacity: 1;
    background-color: rgba(255, 255, 255, 0.1)
}

/* ALTERADO: separar :focus-visible do :hover; foco precisa ser visível
   (WCAG 2.4.7) — o :hover apenas muda opacity/bg, sem indicar foco a usuários
   de teclado. */
.toast-close:focus-visible {
    opacity: 1;
    outline: 2px solid var(--pdv-white);
    outline-offset: 2px
}

.toast-close svg {
    fill: none;
    stroke: currentColor;
    stroke-width: 2.5px;
    stroke-linecap: round;
    stroke-linejoin: round;
    width: 12px;
    height: 12px
}

.toast-content {
    z-index: 1;
    color: inherit;
    margin-left: 10px;
    position: relative
}

.toast .toast-title {
    font-family: var(--font-heading);
    font-size: 20px;
    font-weight: var(--fw-bold);
    letter-spacing: .3px;
    color: inherit;
    text-shadow: 0 1px 2px #00000040;
    max-width: none;
    margin: 0 0 6px;
    line-height: 1.15
}

.toast .toast-message {
    font-family: var(--font-body);
    font-size: 13.5px;
    font-weight: var(--fw-regular);
    color: inherit;
    text-shadow: 0 1px 1px #0000002e;
    max-width: none;
    margin: 0;
    line-height: 1.45
}

.toast .toast-message a {
    color: inherit;
    text-underline-offset: 2px;
    font-weight: var(--fw-bold);
    text-decoration: underline
}

.toast.error,
.toast.success {
    --toast-dark: var(--pdv-black)
}

.toast.success {
    --toast-bg: var(--pdv-verde-escuro);
    background-color: var(--toast-bg)
}

.toast.error {
    --toast-bg: var(--pdv-error)
}

.toast.error,
.toast.info,
.toast.warning {
    background-color: var(--toast-bg)
}

.toast.warning {
    --toast-bg: var(--pdv-warning);
    --toast-dark: var(--pdv-marrom-escuro);
    color: var(--pdv-marrom-escuro)
}

.toast.warning .bubble-icon {
    stroke: var(--pdv-white)
}

.toast.info {
    --toast-bg: var(--pdv-azul-profundo);
    --toast-dark: var(--pdv-laranja)
}

@media (width<=520px) {
    .toast {
        width: auto;
        bottom: 16px;
        left: 16px;
        right: 16px;
        transform: translate(calc(100% + 32px))scale(.96)
    }

    .toast.is-visible {
        transform: translate(0)scale(1)
    }
}

.about-img-1,
.about-img-2 {
    image-rendering: auto;
    image-rendering: smooth;
    image-rendering: high-quality;
    -webkit-backface-visibility: hidden;
    backface-visibility: hidden;
    transform: translateZ(0);
    will-change: transform;
    filter: blur(.3px) contrast(1.02) saturate(1.03)
}

.hero {
    image-rendering: auto;
    image-rendering: smooth;
    image-rendering: high-quality;
    -webkit-backface-visibility: hidden;
    backface-visibility: hidden;
    transform: translateZ(0)
}

@media (min-resolution:2dppx) {

    .about-img-1,
    .about-img-2 {
        filter: blur(.45px) contrast(1.03) saturate(1.03)
    }
}

.has-submenu {
    position: relative;
    align-items: center;
    display: inline-flex
}

.has-submenu:after {
    content: "";
    position: absolute;
    top: 100%;
    left: 0;
    width: max(100%, 230px);
    height: 32px;
    z-index: 1000;
    display: none
}

.submenu-toggle {
    cursor: pointer;
    align-items: center;
    display: inline-flex;
    background: 0 0;
    border: 0;
    color: inherit;
    padding: 8px 10px;
    min-height: 44px;
    min-width: 44px;
    justify-content: center
}

.main-menu button.submenu-link .caret {
    margin-left: 10px
}

.caret {
    border-left: 4px solid #0000;
    border-right: 4px solid #0000;
    border-top: 5px solid currentColor;
    width: 0;
    height: 0;
    transition: transform .2s;
    display: inline-block
}

.submenu {
    min-width: 210px;
    background: var(--pdv-white);
    box-shadow: var(--shadow-md);
    border-radius: var(--radius-md);
    flex-direction: column;
    gap: 2px;
    margin-top: 0;
    padding: 8px;
    transition: opacity .2s, transform .2s, visibility .2s;
    display: flex;
    position: absolute;
    top: calc(100% + 26px);
    left: 0;
    z-index: 1001;
    opacity: 0;
    visibility: hidden;
    transform: translateY(8px)
}

.submenu a {
    min-height: auto;
    border-radius: var(--radius-md);
    padding: 10px 14px;
    white-space: nowrap;
    display: block
}

.submenu a:hover {
    /* ALTERADO: --pdv-laranja-text p/ contraste em fundo branco/off-white */
    color: var(--pdv-laranja-text);
    background: var(--pdv-off-white, #f3f4f6)
}

.has-submenu:hover:after,
.has-submenu.is-submenu-open:after {
    display: block
}

.has-submenu:hover .submenu,
.has-submenu.is-submenu-open .submenu {
    opacity: 1;
    visibility: visible;
    transform: translateY(0)
}

.has-submenu:hover .caret,
.has-submenu.is-submenu-open .caret {
    transform: rotate(180deg)
}

.main-menu.is-open>.has-submenu {
    opacity: 1;
    transform: translateY(0)
}

.testimonials-area[hidden] {
    display: none !important
}

@media (max-width:768px) {
    .has-submenu {
        display: flex;
        flex-wrap: wrap;
        width: 100%;
        align-items: center
    }

    .has-submenu:after {
        display: none !important
    }

    .has-submenu>.submenu-link {
        flex: 1
    }

    .has-submenu>.submenu-toggle {
        padding: 8px 16px;
        min-width: 48px;
        margin-left: auto
    }

    .main-menu button.submenu-link.submenu-toggle {
        flex: 0 0 100%;
        width: 100%;
        min-width: 0;
        padding: 14px 0;
        margin-left: 0;
        justify-content: flex-start
    }

    .main-menu button.submenu-link.submenu-toggle .caret {
        margin-left: auto;
        margin-right: 20px
    }

    .submenu {
        flex-basis: 100%;
        box-shadow: none;
        background: 0 0;
        margin: 0;
        padding: 0 0 0 16px;
        transition: max-height .3s ease;
        position: static;
        opacity: 1;
        visibility: visible;
        transform: none;
        max-height: 0;
        overflow: hidden
    }

    .submenu-toggle[aria-expanded=true]+.submenu {
        max-height: 320px;
        padding: 4px 0 8px 16px
    }

    .submenu-toggle[aria-expanded=true] .caret {
        transform: rotate(180deg)
    }
}

.has-submenu.is-parent-active>.submenu-link {
    color: var(--primary-color);
    position: relative
}

.has-submenu.is-parent-active>.submenu-link:before {
    content: "";
    background: var(--pdv-laranja);
    width: 6px;
    height: 6px;
    animation: .32s cubic-bezier(.22, 1, .36, 1) forwards navDotIn;
    position: absolute;
    bottom: 2px;
    left: 50%;
    transform: translate(-50%)scale(0)
}

@media (max-width:768px) {
    .has-submenu.is-parent-active>.submenu-link {
        padding-left: 0
    }

    .has-submenu.is-parent-active>.submenu-link:before {
        left: -10px;
        bottom: auto;
        top: 50%;
        width: 3px;
        height: 22px;
        transform: translateY(-50%) scaleY(0);
        transform-origin: center;
        animation: navBarIn 320ms cubic-bezier(.22, 1, .36, 1) forwards
    }

    .submenu>a.is-active {
        color: var(--pdv-laranja);
        font-weight: var(--fw-bold)
    }

    .submenu>a.is-active:before {
        display: none
    }
}

/* Galeria técnica off-site */
.galeria-projetos-area {
    position: relative;
    isolation: isolate;
    overflow: hidden;
    padding: 112px 0;
    background: var(--pdv-azul-profundo);
    color: var(--pdv-white);
}

.galeria-projetos-area::before {
    content: "";
    position: absolute;
    inset: 0;
    background-image: linear-gradient(90deg, rgba(255, 255, 255, 0.07) 1px, transparent 1px), linear-gradient(0deg, rgba(255, 255, 255, 0.05) 1px, transparent 1px);
    background-size: 96px 96px;
    opacity: 0.26;
    pointer-events: none;
    z-index: 0;
}

.galeria-projetos-area::after {
    content: "";
    position: absolute;
    right: 0;
    bottom: 0;
    width: min(680px, 48vw);
    height: min(680px, 48vw);
    background: radial-gradient(circle at 72% 72%, rgba(199, 110, 48, 0.28) 0%, rgba(199, 110, 48, 0.16) 32%, rgba(199, 110, 48, 0) 72%);
    pointer-events: none;
    z-index: 0;
}

.galeria-projetos-area .container {
    position: relative;
    z-index: 2;
}

.galeria-projetos-header {
    display: grid;
    grid-template-columns: minmax(0, 1.05fr) minmax(280px, 0.75fr);
    gap: clamp(32px, 5vw, 76px);
    align-items: end;
    margin-bottom: 44px;
}

.galeria-projetos-header .sub-title {
    background: rgba(255, 255, 255, 0.1);
    color: var(--pdv-white);
    border-color: rgba(255, 255, 255, 0.2);
}

.galeria-projetos-header .section-title {
    color: var(--pdv-white);
    margin-bottom: 0;
    max-width: 560px;
}

.galeria-title-line {
    display: block;
    white-space: nowrap;
}

.galeria-projetos-header .section-subtitle {
    color: rgba(255, 255, 255, 0.78);
    text-align: left;
    margin: 0;
    max-width: 54ch;
}

.galeria-carousel {
    position: relative;
    width: 100vw;
    margin-left: calc(50% - 50vw);
    margin-right: calc(50% - 50vw);
    --galeria-edge-fade: clamp(104px, 10vw, 220px);
}

.galeria-carousel-track {
    position: relative;
    z-index: 3;
    display: flex;
    gap: 20px;
    width: 100%;
    overflow-x: auto;
    overflow-y: hidden;
    scroll-snap-type: x mandatory;
    scroll-padding-inline: max(var(--layout-gutter), calc((100vw - var(--layout-max-width)) / 2));
    padding: 18px max(var(--layout-gutter), calc((100vw - var(--layout-max-width)) / 2)) 86px;
    margin-bottom: -54px;
    scrollbar-width: none;
    -webkit-mask-image: linear-gradient(90deg, transparent 0, #000 var(--galeria-edge-fade), #000 calc(100% - var(--galeria-edge-fade)), transparent 100%);
    mask-image: linear-gradient(90deg, transparent 0, #000 var(--galeria-edge-fade), #000 calc(100% - var(--galeria-edge-fade)), transparent 100%);
}

.galeria-carousel-track::-webkit-scrollbar {
    display: none;
}

.galeria-card {
    flex: 0 0 clamp(232px, 22vw, 292px);
    margin: 0;
    position: relative;
    z-index: 2;
    isolation: isolate;
    scroll-snap-align: start;
}

.galeria-card::after {
    content: "";
    position: absolute;
    left: 8%;
    right: 8%;
    bottom: -24px;
    height: 48px;
    background: radial-gradient(ellipse at center, rgba(2, 12, 22, 0.62) 0%, rgba(2, 12, 22, 0.36) 42%, rgba(2, 12, 22, 0) 76%);
    filter: blur(12px);
    opacity: 0.9;
    pointer-events: none;
    transform: translateY(8px);
    z-index: -1;
}

.galeria-card-button {
    position: relative;
    z-index: 1;
    display: block;
    width: 100%;
    aspect-ratio: 4 / 5;
    border: 1px solid rgba(255, 255, 255, 0.18);
    border-radius: var(--radius-card);
    overflow: hidden;
    cursor: pointer;
    background: var(--pdv-azul-profundo);
    box-shadow: 0 22px 56px rgba(2, 12, 22, 0.42), 0 0 0 1px rgba(255, 255, 255, 0.04);
    padding: 0;
    text-align: left;
    transition: transform var(--transition-fast), border-color var(--transition-fast), box-shadow var(--transition-fast);
}

.galeria-card-button img {
    width: 100%;
    height: 100%;
    display: block;
    object-fit: cover;
    object-position: center;
    opacity: 1;
    transition: transform var(--transition-slow), filter var(--transition-slow), opacity var(--transition-slow);
}

.galeria-card-button img[data-gallery-lazy="true"] {
    opacity: 0;
}

.galeria-card-overlay {
    position: absolute;
    inset: auto 0 0;
    display: grid;
    gap: 6px;
    padding: 74px 18px 18px;
    background: linear-gradient(180deg, rgba(15, 30, 43, 0), rgba(15, 30, 43, 0.82) 34%, rgba(15, 30, 43, 0.96) 100%);
    color: var(--pdv-white);
}

.galeria-card-kicker {
    width: fit-content;
    padding: 4px 8px;
    border-radius: var(--radius-btn);
    background: var(--pdv-laranja);
    color: var(--pdv-white);
    font-family: var(--font-body);
    font-size: 0.72rem;
    font-weight: var(--fw-bold);
    letter-spacing: var(--ls-uppercase);
    text-transform: uppercase;
}

.galeria-card-title {
    font-family: var(--font-heading);
    font-size: var(--type-heading-4);
    font-weight: var(--fw-bold);
    line-height: 1.1;
}

.galeria-card-text {
    color: rgba(255, 255, 255, 0.78);
    font-family: var(--font-body);
    font-size: 0.84rem;
    font-weight: var(--fw-light);
    line-height: 1.45;
}

.galeria-card-button:focus-visible {
    outline: 3px solid var(--pdv-amarelo-dourado);
    outline-offset: 4px;
}

.galeria-carousel-nav {
    position: absolute;
    top: 50%;
    z-index: 4;
    width: 52px;
    height: 52px;
    display: grid;
    place-items: center;
    border: 1px solid rgba(255, 255, 255, 0.22);
    border-radius: var(--radius-full);
    background: rgba(255, 255, 255, 0.12);
    color: var(--pdv-white);
    cursor: pointer;
    transform: translateY(-50%);
    backdrop-filter: blur(8px);
    -webkit-backdrop-filter: blur(8px);
    transition: background-color var(--transition-fast), border-color var(--transition-fast), transform var(--transition-fast);
}

.galeria-carousel-nav .icon {
    width: 24px;
    height: 24px;
}

.galeria-carousel-nav--prev {
    left: max(20px, calc((100vw - var(--layout-max-width)) / 2 - 26px));
}

.galeria-carousel-nav--next {
    right: max(20px, calc((100vw - var(--layout-max-width)) / 2 - 26px));
}

.galeria-carousel-nav:hover {
    background: var(--pdv-laranja);
    border-color: var(--pdv-laranja);
}

.galeria-carousel-nav--prev:hover {
    transform: translateY(-50%) translateX(-4px);
}

.galeria-carousel-nav--next:hover {
    transform: translateY(-50%) translateX(4px);
}

@media (hover: hover) {
    .galeria-card-button:hover {
        transform: translateY(-8px);
        border-color: rgba(250, 174, 63, 0.72);
        box-shadow: 0 26px 58px rgba(0, 0, 0, 0.36);
    }

    .galeria-card-button:hover img {
        transform: scale(1.06);
        filter: saturate(1.05) contrast(1.04);
    }
}

@media (max-width: 1180px) {
    .galeria-projetos-header {
        grid-template-columns: 1fr;
        gap: 20px;
    }

    .galeria-projetos-header .section-title {
        font-size: 2.25rem;
        max-width: 560px;
    }
}

@media (max-width: 991px) {
    .galeria-projetos-area {
        padding: 88px 0;
    }

    .galeria-projetos-header {
        grid-template-columns: 1fr;
        gap: 20px;
    }

    .galeria-projetos-header .section-title {
        font-size: 2.08rem;
        max-width: 560px;
    }

    .galeria-title-line {
        white-space: normal;
    }

    .galeria-carousel-nav--prev {
        left: 10px;
    }

    .galeria-carousel-nav--next {
        right: 10px;
    }
}

@media (max-width: 768px) {
    .galeria-projetos-area {
        padding: 72px 0;
    }

    .galeria-projetos-header .section-title {
        font-size: 1.72rem;
        line-height: 1.24;
        max-width: 100%;
    }

    .galeria-card {
        flex-basis: min(78vw, 300px);
    }

    .galeria-carousel {
        --galeria-edge-fade: clamp(56px, 18vw, 120px);
    }

    .galeria-card-overlay {
        padding: 72px 16px 16px;
    }

    .galeria-carousel-nav {
        top: auto;
        bottom: 20px;
        width: 48px;
        height: 48px;
        transform: none;
    }

    .galeria-carousel-nav--prev:hover,
    .galeria-carousel-nav--next:hover {
        transform: none;
    }

    .galeria-carousel-nav--prev {
        left: 12px;
    }

    .galeria-carousel-nav--next {
        right: 12px;
    }

    .galeria-carousel-track {
        padding-top: 14px;
        padding-bottom: 94px;
        margin-bottom: -58px;
        -webkit-mask-image: none;
        mask-image: none;
    }
}

/* Galaxy Orbit WOW Section */
.fornecedores-editorial-area {
    background: linear-gradient(180deg, rgba(41, 73, 100, 0.04) 0%, var(--pdv-white) 350px, var(--pdv-white) 100%);
    padding: 80px 0;
    position: relative;
    overflow: hidden;
    z-index: 1;
}

/* Grafismo ocupando 100% do background da section */
.fornecedores-editorial-area::before {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background-image: url("../images/grafismos/Grafismo%20PDV-03.svg");
    background-repeat: no-repeat;
    background-position: left center;
    background-size: cover;
    opacity: 0.08;
    pointer-events: none;
    z-index: 0;

    /* Máscara de degradê para suavizar a imagem de baixo para cima (mobile) */
    -webkit-mask-image: linear-gradient(to bottom, rgba(0, 0, 0, 1) 0%, rgba(0, 0, 0, 0.7) 45%, rgba(0, 0, 0, 0) 90%);
    mask-image: linear-gradient(to bottom, rgba(0, 0, 0, 1) 0%, rgba(0, 0, 0, 0.7) 45%, rgba(0, 0, 0, 0) 90%);
}

.fornecedores-editorial-row {
    display: flex;
    flex-direction: column;
    gap: 48px;
    position: relative;
    z-index: 2;
}

.fornecedores-editorial-left-col {
    width: 100%;
    text-align: left;
}

.fornecedores-editorial-left-col .sub-title {
    margin-bottom: 24px;
    font-size: var(--type-body-sm);
    letter-spacing: var(--ls-uppercase);
    padding: 10px 24px;
}

.fornecedores-editorial-left-col .section-title {
    margin-bottom: 24px;
    font-size: clamp(2.4rem, 4.5vw, 3.8rem);
    line-height: 1.15;
}

.fornecedores-editorial-left-col .text-desc {
    color: var(--pdv-text-primary);
    margin: 0;
    font-size: clamp(1.1rem, 2vw, 1.25rem);
    line-height: 1.8;
    font-family: var(--font-body);
    font-weight: var(--fw-light);
}

.fornecedores-editorial-right-col {
    width: 100%;
    position: relative;
    padding: 10px 0;
}

.fornecedores-editorial-dots-bg {
    position: absolute;
    inset: 0;
    background-image: radial-gradient(rgba(41, 73, 100, 0.08) 1px, transparent 1px);
    background-size: 24px 24px;
    pointer-events: none;
    z-index: -1;
    border-radius: var(--radius-lg);
}

.fornecedores-editorial-logos-grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 16px;
    padding: 10px;
}

.fornecedor-editorial-card {
    background: var(--pdv-white);
    border: 1px solid rgba(41, 73, 100, 0.08);
    box-shadow: var(--shadow-sm);
    border-radius: var(--radius-md);
    height: 140px;
    display: flex;
    justify-content: center;
    align-items: center;
    padding: 16px;
    transition: var(--transition);
}

.fornecedor-editorial-card img {
    max-width: 92%;
    max-height: 92%;
    width: auto;
    height: auto;
    object-fit: contain;
    transition: var(--transition);
}

/* Desktop Overrides */
@media (min-width: 992px) {
    .fornecedores-editorial-area {
        background: linear-gradient(95deg, rgba(41, 73, 100, 0.04) 0%, var(--pdv-white) 40%, var(--pdv-white) 100%);
        padding: 120px 0;
    }

    .fornecedores-editorial-area::before {
        /* Máscara de degradê horizontal para o desktop: de direita (transparente) para esquerda (visível) */
        -webkit-mask-image: linear-gradient(to right, rgba(0, 0, 0, 1) 0%, rgba(0, 0, 0, 0.8) 35%, rgba(0, 0, 0, 0) 80%);
        mask-image: linear-gradient(to right, rgba(0, 0, 0, 1) 0%, rgba(0, 0, 0, 0.8) 35%, rgba(0, 0, 0, 0) 80%);
    }

    .fornecedores-editorial-row {
        display: grid;
        grid-template-columns: 4.5fr 7.5fr;
        gap: clamp(48px, 6vw, 80px);
        align-items: center;
    }

    .fornecedores-editorial-left-col {
        max-width: 520px;
    }

    .fornecedores-editorial-right-col {
        padding: 30px;
    }

    .fornecedores-editorial-logos-grid {
        grid-template-columns: repeat(3, 1fr);
        gap: 24px;
        padding: 40px 10px;
    }

    .fornecedor-editorial-card {
        height: 190px;
        border-radius: var(--radius-lg);
        padding: 20px;
    }

    /* Scattered Staggered Effect on Desktop */
    .fornecedores-editorial-logos-grid .fornecedor-editorial-card:nth-child(3n + 1) {
        margin-top: 24px;
    }

    .fornecedores-editorial-logos-grid .fornecedor-editorial-card:nth-child(3n) {
        margin-top: -24px;
    }

    @media (hover: hover) {
        .fornecedor-editorial-card:hover {
            transform: translateY(-6px);
            box-shadow: var(--shadow-md);
            border-color: var(--pdv-laranja);
        }

        .fornecedor-editorial-card:hover img {
            transform: scale(1.05);
        }
    }
}

/* Tablet Adjustments */
@media (min-width: 768px) and (max-width: 991px) {
    .fornecedores-editorial-logos-grid {
        grid-template-columns: repeat(3, 1fr);
        gap: 20px;
    }

    .fornecedor-editorial-card {
        height: 160px;
    }
}

/* Gallery Modal Styles */
.fornecedor-editorial-card {
    cursor: pointer;
    outline: none;
    transition: transform var(--transition-fast), box-shadow var(--transition-fast);
}

.fornecedor-editorial-card:hover {
    transform: translateY(-4px) scale(1.02);
    box-shadow: var(--shadow-lg);
}

.fornecedor-editorial-card:focus-visible {
    outline: 3px solid var(--pdv-laranja);
    outline-offset: 4px;
}

.gallery-modal {
    position: fixed;
    inset: 0;
    z-index: 3000;
    display: flex;
    justify-content: center;
    align-items: center;
    opacity: 0;
    visibility: hidden;
    transition: opacity var(--transition-slow), visibility var(--transition-slow);
}

.gallery-modal:not([hidden]) {
    display: flex;
}

.gallery-modal.is-open {
    opacity: 1;
    visibility: visible;
}

.gallery-modal-backdrop {
    position: absolute;
    inset: 0;
    background-color: rgba(17, 19, 24, 0.92);
    backdrop-filter: blur(12px);
    -webkit-backdrop-filter: blur(12px);
    cursor: pointer;
}

.gallery-modal-content {
    position: relative;
    z-index: 2;
    width: 90%;
    max-width: 900px;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 24px;
    user-select: none;
}

.gallery-modal-slider {
    position: relative;
    width: 100%;
    display: flex;
    justify-content: center;
    align-items: center;
    min-height: 250px;
}

.gallery-modal-img {
    max-width: 100%;
    max-height: 65vh;
    object-fit: contain;
    border-radius: var(--radius-md);
    box-shadow: 0 20px 50px rgba(0, 0, 0, 0.5);
    opacity: 0;
    transform: scale(0.95);
    transition: opacity 0.3s ease, transform 0.3s ease;
    background-color: var(--pdv-white);
    padding: 20px;
}

.gallery-modal[data-active-gallery="galeria-projetos"] .gallery-modal-img {
    background-color: transparent;
    padding: 0;
}

.gallery-modal.is-open .gallery-modal-img.is-active {
    opacity: 1;
    transform: scale(1);
}

.gallery-modal-info {
    text-align: center;
    color: var(--pdv-white);
    z-index: 2;
}

.gallery-modal-caption {
    font-family: var(--font-heading);
    font-weight: var(--fw-bold);
    font-size: var(--type-heading-3);
    color: var(--pdv-white);
    margin-bottom: 6px;
    text-transform: uppercase;
    letter-spacing: var(--ls-heading);
}

.gallery-modal-counter {
    font-family: var(--font-body);
    font-weight: var(--fw-light);
    font-size: var(--type-body-sm);
    color: var(--pdv-gray-400);
}

.gallery-modal-close {
    position: fixed;
    top: 32px;
    right: 32px;
    z-index: 3020;
    border: 1px solid rgba(255, 255, 255, 0.15);
    border-radius: var(--radius-full);
    width: 56px;
    height: 56px;
    color: var(--pdv-white);
    cursor: pointer;
    background: rgba(255, 255, 255, 0.05);
    backdrop-filter: blur(4px);
    -webkit-backdrop-filter: blur(4px);
    display: flex;
    justify-content: center;
    align-items: center;
    transition: var(--transition-fast);
}

.gallery-modal-close .icon {
    width: 24px;
    height: 24px;
    transform: rotate(45deg);
    transition: transform 0.3s ease;
}

.gallery-modal-close:hover {
    background: var(--pdv-laranja);
    border-color: var(--pdv-laranja);
    transform: scale(1.05);
}

.gallery-modal-close:hover .icon {
    transform: rotate(135deg);
}

.gallery-modal-nav {
    position: fixed;
    top: 50%;
    transform: translateY(-50%);
    z-index: 3010;
    border: 1px solid rgba(255, 255, 255, 0.15);
    border-radius: var(--radius-full);
    width: 56px;
    height: 56px;
    color: var(--pdv-white);
    cursor: pointer;
    background: rgba(255, 255, 255, 0.05);
    backdrop-filter: blur(4px);
    -webkit-backdrop-filter: blur(4px);
    display: flex;
    justify-content: center;
    align-items: center;
    transition: var(--transition-fast);
}

.gallery-modal-nav--prev {
    left: 48px;
}

.gallery-modal-nav--next {
    right: 48px;
}

.gallery-modal-nav .icon {
    width: 24px;
    height: 24px;
}

.gallery-modal-nav:hover {
    background: var(--pdv-laranja);
    border-color: var(--pdv-laranja);
}

.gallery-modal-nav--prev:hover {
    transform: translateY(-50%) translateX(-4px);
}

.gallery-modal-nav--next:hover {
    transform: translateY(-50%) translateX(4px);
}

.gallery-modal-nav:active {
    transform: translateY(-50%) scale(0.95);
}

.gallery-modal-dots {
    display: flex;
    justify-content: center;
    align-items: center;
    gap: 8px;
    margin-top: 8px;
    z-index: 2;
}

.gallery-modal-dot {
    width: 8px;
    height: 8px;
    border-radius: var(--radius-full);
    background-color: rgba(255, 255, 255, 0.25);
    border: 0;
    padding: 0;
    cursor: pointer;
    transition: width 0.24s cubic-bezier(0.25, 0.8, 0.25, 1), background-color 0.24s, transform 0.24s;
}

.gallery-modal-dot:hover {
    background-color: rgba(255, 255, 255, 0.65);
    transform: scale(1.15);
}

.gallery-modal-dot.is-active {
    background-color: var(--pdv-laranja);
    width: 20px;
    transform: scale(1);
}

@media (max-width: 991px) {
    .gallery-modal-nav {
        width: 48px;
        height: 48px;
    }

    .gallery-modal-nav--prev {
        left: 24px;
    }

    .gallery-modal-nav--next {
        right: 24px;
    }

    .gallery-modal-close {
        top: 24px;
        right: 24px;
        width: 48px;
        height: 48px;
    }
}

@media (max-width: 768px) {
    .gallery-modal-content {
        width: 95%;
    }

    .gallery-modal-img {
        max-height: 50vh;
        padding: 10px;
    }

    .gallery-modal-nav {
        display: flex !important;
        position: fixed !important;
        top: auto !important;
        bottom: 32px !important;
        transform: none !important;
        width: 50px !important;
        height: 50px !important;
        z-index: 3010 !important;
    }

    .gallery-modal-nav--prev {
        left: 24px !important;
    }

    .gallery-modal-nav--next {
        right: 24px !important;
    }

    .gallery-modal-nav--prev:hover {
        transform: translateX(-4px) !important;
    }

    .gallery-modal-nav--next:hover {
        transform: translateX(4px) !important;
    }

    .gallery-modal-nav:active {
        transform: scale(0.95) !important;
    }

    .gallery-modal-info {
        padding: 0 80px !important;
    }

    .gallery-modal-caption {
        font-size: var(--type-heading-4);
    }
}

/* ==========================================================================
   Equalização e Alinhamento Premium dos Clientes
   ========================================================================== */

/* Caixa do logotipo do cliente na marquee: largura automática, centralização perfeita e sem cortes */
.clientes-sequence .cliente-box {
    position: relative !important;
    /* Permite elevação de empilhamento via z-index */
    z-index: 1 !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    width: auto !important;
    /* Permite largura dinâmica de acordo com o aspecto da logo */
    min-width: 170px !important;
    /* Largura mínima para logos quadradas/pequenas */
    height: 90px !important;
    /* Altura fixa para manter todas na mesma linha */
    padding: 0 28px !important;
    /* Respiro lateral confortável para cada marca */
    box-sizing: border-box !important;
    overflow: visible !important;
    /* Garante que nada fique cortado */
    filter: none !important;
    /* Sem escala de cinza por padrão */
    opacity: 1 !important;
    /* Opacidade máxima */
    /* ALTERADO: bg-light -> white (igual ao fundo da .clientes-area). */
    background-color: var(--pdv-white);
    border: 1px solid var(--pdv-gray-100);
    border-radius: var(--radius-card);
    transition: transform var(--transition-fast), box-shadow var(--transition-fast), border-color var(--transition-fast);
    flex-shrink: 0 !important;
    /* Impede distorção pelo flexbox */
}

/* Efeito Hover Premium nas caixas de clientes */
.clientes-sequence .cliente-box:hover {
    transform: translateY(-4px) !important;
    /* Elevação suave ligeiramente maior para destaque */
    box-shadow: var(--shadow-lg) !important;
    /* Sombra mais nítida e premium */
    border-color: var(--pdv-gray-200) !important;
    z-index: 10 !important;
    /* Garante que fique acima dos vizinhos na marquee */
}

/* Espaçamento interno de segurança no container do marquee para evitar cortes superiores/inferiores */
.clientes-marquee {
    padding-top: 12px !important;
    padding-bottom: 12px !important;
    margin-top: 38px !important;
    /* Ajusta margem externa para manter equilíbrio de grid */
}

/* Imagens das logos: altura máxima unificada para alinhamento vertical e largura auto */
.clientes-sequence .cliente-logo {
    display: block !important;
    width: auto !important;
    height: auto !important;
    max-height: 52px !important;
    /* Altura máxima uniforme e elegante */
    max-width: 160px !important;
    /* Largura máxima para logos muito horizontais */
    object-fit: contain !important;
    /* Impede distorções e cortes */
    transform: none !important;
    /* Remove qualquer distorção de escala artificial */
    transition: none !important;
}

/* Ajustes de responsividade para dispositivos móveis */
@media (max-width: 768px) {
    .clientes-sequence .cliente-box {
        height: 75px !important;
        min-width: 130px !important;
        padding: 0 18px !important;
    }

    .clientes-sequence .cliente-logo {
        max-height: 42px !important;
        max-width: 110px !important;
    }
}

/* ==========================================================================
   Desativação de Animações Conflitantes e Travamentos
   ========================================================================== */

/* Anula animações de reveal (surgimento bottom to top) que travavam e atrasavam o carregamento */
.reveal {
    opacity: 1 !important;
    transform: none !important;
    transition: none !important;
    animation: none !important;
}

/* Desativa a animação nativa CSS do marquee para dar lugar ao controle JS de alta precisão */
.clientes-track {
    animation: none !important;
    display: flex !important;
    will-change: transform;
}

.clientes-marquee:hover .clientes-track {
    animation-play-state: running !important;
}

/* ==========================================================================
   Ajustes Finos e Correções do Marquee dos Clientes
   ========================================================================== */

/* 1. Dar um padding vertical no marquee para que os cards subam sem bater no overflow: hidden */
.clientes-marquee {
    padding: 16px 0 !important;
}

/* 2. Cursor de ponteiro e tempo de transição otimizados para os cards de clientes */
.cliente-box {
    cursor: pointer;
    position: relative;
    transition: transform 0.3s cubic-bezier(0.25, 0.8, 0.25, 1), box-shadow 0.3s cubic-bezier(0.25, 0.8, 0.25, 1), border-color 0.3s, background-color 0.3s !important;
}

/* 3. Correção do corte superior no hover (z-index de sobreposição elevado) e fundo branco nas transparentes */
.cliente-box:hover {
    position: relative;
    z-index: 100 !important;
    /* Mantém o card acima dos vizinhos na trilha da marquee */
    transform: translateY(-6px) scale(1.03) !important;
    box-shadow: 0 12px 28px rgba(41, 73, 100, 0.15), 0 8px 10px rgba(41, 73, 100, 0.1) !important;
    background-color: var(--pdv-white) !important;
    /* Força fundo branco para valorizar logos transparentes */
    border-color: var(--pdv-gray-200) !important;
}
