/* ================== Paleta de cores ================== */
:root {
    --primary: #2C54EB;
    --primary-dark: #1a378c;
    --accent: #f56600;
    --accent-light: #ffb380;
    --light: #23272f;
    --dark: #ffffff;
    --gray: #bfc4d1;
    --light-gray: #343a40;
}

/* ================== Reset ================== */
* {
    margin: 0;
    padding: 0;
    box-sizing: border-box;
}

body {
    font-family: 'Open Sans', sans-serif;
    color: var(--dark);
    background: #fff;
    line-height: 1.6;
    overflow-x: hidden;
    font-size: 15px;
}

/* ================== Header ================== */
header {
    background-color: var(--dark);
    box-shadow: 0 2px 10px rgba(0,0,0,0.5);
    position: fixed;
    width: 100%;
    top: 0;
    z-index: 1000;
}

.header-container {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 20px 0;
    max-width: 1300px;
    margin: 0 auto;
}

/* Logo quadrada com bordas arredondadas */
.logo-img {
    width: 110px;
    height: 65px;
    border-radius: 16px;
    margin-right: 12px;
    object-fit: cover;
    box-shadow: 0 2px 8px rgba(44,84,235,0.10);
}

.logo-text {
    font-size: 28px;
    font-weight: 700;
    color: var(--accent);
    font-family: 'Montserrat', sans-serif;
}

.logo-highlight {
    color: var(--accent);
}

nav ul {
    display: flex;
    list-style: none;
    align-items: center; /* garante alinhamento vertical uniforme */
}

nav ul li {
    margin-left: 30px;
}

nav ul li a {
    position: relative;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 6px 10px;
    font-weight: 600;
    color: var(--accent);
    transition: color .35s ease, transform .35s ease;
    line-height: 1;
    border-radius: 10px;
}

nav ul li a:hover,
nav ul li a:focus-visible {
    color: var(--light);
    transform: scale(1.15);
}

nav ul li a:focus-visible {
    outline: 2px solid var(--accent);
    outline-offset: 4px;
}

/* Mantém o ícone Instagram maior se desejar destaque */
nav ul li.nav-ig a {
    font-size: 32px;
}

/* Opcional: ajuste tamanho texto dos demais (não afeta ícone) */
nav ul li:not(.nav-ig) a {
    font-size: 16px;
}

nav ul li.nav-ig {
    margin-left: 16px;
    display: flex;
    align-items: center;
}

nav ul li.nav-ig a {
    font-size: 32px;              /* aumentado (antes 24px) */
    padding: 4px 8px;
    line-height: 1;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    color: var(--accent);          /* mesma cor base dos links */
    transition: color .35s ease, transform .35s ease;
    position: relative;
    top: 1px;                      /* micro ajuste vertical */
}

nav ul li.nav-ig a:hover {
    color: var(--light);           /* mesma cor de interação de “Contato” */
    transform: scale(1.15);
}

/* Foco acessível */
nav ul li.nav-ig a:focus-visible {
    outline: 2px solid var(--accent);
    outline-offset: 4px;
    border-radius: 8px;
}

@media (max-width: 680px) {
    nav ul li.nav-ig a {
        font-size: 22px;
        transform: none;
    }
}

/* Transformar os links do Header (exceto Instagram) em botões semelhantes ao CTA */
header nav ul li:not(.nav-ig) a {
        background: var(--dark);
        color: var(--accent);
        font-weight: 700;
        padding: 10px 18px; /* menor que o CTA para caber no header */
        border-radius: 30px;
        border: 2px solid var(--accent);
        box-shadow: 0 2px 14px rgba(245,102,0,0.14);
        transition: background .25s ease, color .25s ease, transform .25s ease, box-shadow .25s ease;
}

header nav ul li:not(.nav-ig) a:hover,
header nav ul li:not(.nav-ig) a:focus-visible {
        background: var(--accent);
        color: var(--dark);
        transform: translateY(-1px) scale(1.05);
        box-shadow: 0 6px 24px rgba(245,102,0,0.22);
}

/* Ajuste de espaçamento entre os itens com botões maiores */
header nav ul li { margin-left: 18px; }

/* Responsivo: reduzir botões no mobile para não quebrar o layout */
@media (max-width: 680px) {
    header nav ul li:not(.nav-ig) a {
        padding: 8px 14px;
        border-radius: 24px;
        font-size: 14px;
    }
}

/* ================== Início Destaque ================== */
.inicio-destaque {
    background: var(--light);
    padding: 160px 0 88px 0; /* mais espaço no topo para não ficar sob o header */
    position: relative;
    overflow: hidden;
    z-index: 1;
    transition: background 2.0s cubic-bezier(.4,0,.2,1);
    border-radius: 0 0 40px 40px;
    box-shadow: 0 8px 32px rgba(44,84,235,0.08);
}

/* Removido o círculo decorativo ("bolinha") da seção Início */
.inicio-destaque::before {
    content: none;          /* antes: "" */
    display: none;
    /* regra original comentada:
    top: -80px;
    left: -80px;
    width: 320px;
    height: 320px;
    background: rgba(255,255,255,0.10);
    border-radius: 50%;
    */
}

.inicio-content {
    display: flex;
    align-items: center;
    justify-content: center;
    min-height: 350px;
    position: relative;
    z-index: 1;
}

.inicio-texto {
    max-width: 760px;           /* um pouco mais largo para caber melhor as linhas */
    text-align: left;           /* alinhamento à esquerda do conteúdo */
    margin: 0 auto;             /* bloco continua centralizado na página */
    color: #f56600;
}

.inicio-texto h1 {
    font-size: clamp(28px, 4.4vw, 38px); /* reduz e torna fluido (antes 42px) */
    font-family: 'Montserrat', sans-serif;
    font-weight: 800;
    margin-bottom: 24px;
    letter-spacing: 1px;                 /* antes 2px */
    line-height: 1.08;
    text-shadow: 0 2px 16px rgba(0,0,0,0.10);
}

.inicio-highlight {
    color: var(--dark);
    background: #f56600;
    border-radius: 12px;
    padding: 0 8px;       /* antes 0 12px (reduz largura total) */
    box-shadow: 0 2px 12px rgba(255,107,107,0.10);
}

.inicio-texto p {
    font-size: 20px;
    margin-bottom: 36px;
    color: #f56600;
    line-height: 1.7;
    text-shadow: 0 1px 8px rgba(0,0,0,0.08);
}

.btn-inicio {
    background: var(--dark);
    color: var(--accent);
    font-size: 18px;
    font-weight: 700;
    padding: 18px 48px;
    border-radius: 40px;
    box-shadow: 0 4px 24px rgba(255,107,107,0.18);
    letter-spacing: 1px;
    transition: all 0.3s;
    border: none;
}

.btn-inicio:hover {
    background: var(--accent);
    color: var(--dark);
    box-shadow: 0 6px 32px rgba(44,84,235,0.18);
    transform: scale(1.05);
}

/* ================== Hero com cartões flutuantes (Início) ================== */
.hero-image {
    position: relative;
    width: 100%;
    max-width: 520px;
    margin: 24px auto 0;
    pointer-events: none; /* evita capturar cliques sobre os cards decorativos */
}

.inicio-content {
    flex-direction: column;
}

@media (min-width: 980px) {
    .inicio-content {
        flex-direction: row;
        gap: 48px;
        justify-content: space-between;
    }
    .inicio-texto { flex: 1 1 520px; text-align: left; }
    .hero-image { flex: 0 1 520px; margin: 0 48px 0 0; }
}

.image-container {
    position: relative;
    width: 100%;
    aspect-ratio: 4 / 3; /* mantém proporção visual */
}

.main-image-placeholder {
    position: absolute;
    top: 50%;
    left: 50%;
    width: 54%;
    height: 54%;
    transform: translate(-50%, -50%);
    display: grid;
    grid-template-rows: 1fr auto; /* foguete centralizado, frase no rodapé */
    align-items: center;
    justify-items: center;
    background: #ffffff;                 /* quadrado branco */
    border: 3px solid var(--accent);     /* borda laranja pedida */
    border-radius: 24px;
    box-shadow: 0 10px 34px rgba(0,0,0,0.16); /* sombra externa suave */
    overflow: hidden;                    /* garante bordas limpas */
    will-change: top, transform;
    animation: floatYCenter 5.0s ease-in-out infinite; /* flutua como os cards */
}


/* Conjunto foguete + chama (um único bloco) */
.rocket-assembly {
    position: relative;
    display: inline-flex;
    flex-direction: column;
    align-items: center;
    justify-content: flex-start;
    margin-top: 0;                        /* centralizado pelo grid do container */
}

.rocket-assembly .rocket-icon {
    font-size: clamp(32px, 5vw, 56px);
    color: var(--accent);
    text-shadow: 0 4px 20px rgba(245,102,0,0.35);
    position: relative;
    z-index: 2;
    display: inline-block;
    transform: rotate(-45deg);            /* vertical, alinhado */
    transform-origin: 50% 50%;
}

/* Chama (foguinho) integrada ao conjunto, posicionada sob o foguete */
.rocket-assembly::before,
.rocket-assembly::after {
    content: "";
    position: absolute;
    top: 100%;
    left: 50%;
    transform: translate(-50%, 0);
    z-index: 1;
    pointer-events: none;
}

/* penacho externo (laranja) */
.rocket-assembly::before {
    width: 22px; height: 44px;
    background: radial-gradient(ellipse at 50% 0%, rgba(255,200,120,0.85) 0%, rgba(255,120,0,0.95) 55%, rgba(255,120,0,0) 72%);
    filter: blur(0.6px);
    animation: flameFlicker 0.6s ease-in-out infinite alternate;
}

/* núcleo da chama (amarelo) */
.rocket-assembly::after {
    width: 12px; height: 28px;
    background: radial-gradient(ellipse at 50% 0%, #FFE07A 0%, #FFC107 55%, rgba(255,193,7,0) 72%);
    filter: blur(0.4px);
    animation: flameFlicker 0.5s ease-in-out infinite alternate-reverse;
}

/* Frase dentro do quadrado (abaixo do fogo) */
.rocket-tagline {
    margin-top: 8px;                     /* grid já posiciona no rodapé */
    padding: 0 12px 14px;
    text-align: center;
    font-size: clamp(12px, 2.5vw, 14px);
    font-weight: 700;
    color: var(--accent);                /* frase em laranja */
    line-height: 1.3;
}

/* Animação de lançamento (sair do quadrado) */

/* Estado de lançamento: pausa a flutuação do quadrado e lança o conjunto verticalmente */
.launching .main-image-placeholder { animation: none; }
.launching .main-image-placeholder .rocket-assembly {
    animation: rocketLaunchUp 1.1s cubic-bezier(.2,.6,.2,1) forwards;
}
.launching .main-image-placeholder .rocket-assembly::before,
.launching .main-image-placeholder .rocket-assembly::after {
    animation-duration: 0.3s; /* chama acelera no lançamento */
}

@keyframes rocketLaunchUp {
    0%   { transform: translateY(0) scale(1); opacity: 1; }
    20%  { transform: translateY(-12px) scale(1.04); }
    60%  { transform: translateY(-160px) scale(1.06); }
    100% { transform: translateY(-280px) scale(1.08); opacity: 0; }
}

@keyframes flameFlicker {
    0%   { transform: translateX(-50%) scaleY(0.85) translateY(0); opacity: 0.9; }
    50%  { transform: translateX(-50%) scaleY(1.10) translateY(2px); opacity: 1; }
    100% { transform: translateX(-50%) scaleY(0.95) translateY(-1px); opacity: 0.85; }
}

/* Flutuação do foguete (move top em px preservando translate) */
@keyframes floatYCenter {
    0%   { top: 50%; }
    50%  { top: calc(50% - 24px); }
    100% { top: 50%; }
}

/* Efeito de aproximação (zoom sutil) ao interagir */
.main-image-placeholder:hover,
.main-image-placeholder:focus-visible {
    transform: translate(-50%, -50%) scale(1.05);
}

.floating-card {
    position: absolute;
    display: inline-flex;
    align-items: center;
    gap: 0; /* sem espaço interno entre elementos, só a logo */
    padding: 12px 20px; /* maior */
    border-radius: 14px;
    background: #ffffff;
    color: #1e1f23;
    border: 2px solid var(--accent);
    box-shadow: 0 8px 24px rgba(245,102,0,0.18), 0 2px 10px rgba(0,0,0,0.06);
    font-weight: 700;
    font-family: 'Montserrat', sans-serif;
    pointer-events: auto; /* permite foco se necessário */
    transform-style: preserve-3d;
    perspective: 700px;
    transition: box-shadow .25s ease, border-color .25s ease;
}
.floating-card-inner {
    display: grid;
    place-items: center;
    width: 75px;
    height: 75px;
    overflow: hidden;            /* recorta a imagem nos cantos do quadrado */
    aspect-ratio: 1 / 1;
    transform-style: preserve-3d;
    transition: transform .25s ease, filter .25s ease;
    will-change: transform, filter;
}

.floating-card i { color: var(--primary); font-size: 28px; filter: drop-shadow(0 4px 8px rgba(0,0,0,0.15)); }

.floating-card span { display: none; }

/* Imagens 3D dentro dos cards */
.floating-card-inner img {
    display: block;              /* remove gaps inline */
    width: 100%;
    height: 100%;
    object-fit: cover;           /* preenche 100% do quadrado */
    background: transparent;     /* garante fundo transparente */
    border-radius: 12px;         /* igual ao quadrado interno */
    box-shadow: none;            /* sem sombra para não parecer maior */
    transform: translateZ(1px);  /* leve profundidade */
}

/* posições dos cartões */
.card-1 { top: -14px; left: -12px; transform: rotate(-5deg); }
.card-2 { bottom: -18px; left: 8px; transform: rotate(4deg); }
.card-3 { top: 10px; right: -12px; transform: rotate(6deg); }
.card-4 { bottom: 10px; right: -8px; transform: rotate(-3deg); }

/* animação sutil de flutuação */
@keyframes floatY {
    0% { transform: translateY(0) rotate(var(--rot, 0deg)); }
    50% { transform: translateY(-16px) rotate(var(--rot, 0deg)); }
    100% { transform: translateY(0) rotate(var(--rot, 0deg)); }
}

.card-1 { --rot: -5deg; animation: floatY 4.5s ease-in-out infinite; }
.card-2 { --rot: 4deg;  animation: floatY 5.2s ease-in-out infinite; }
.card-3 { --rot: 6deg;  animation: floatY 4.8s ease-in-out infinite; }
.card-4 { --rot: -3deg; animation: floatY 5.0s ease-in-out infinite; }

@media (max-width: 600px) {
    .image-container { aspect-ratio: 16 / 12; }
    .floating-card { padding: 10px 12px; border-radius: 12px; }
    .floating-card-inner { width: 38px; height: 38px; }
    .floating-card i { font-size: 22px; }
    .floating-card span { display: none; }
    .card-1 { top: -8px; left: -6px; }
    .card-2 { bottom: -10px; left: 10px; }
    .card-3 { top: 14px; right: -8px; }
    .card-4 { bottom: -6px; right: -6px; }
}

/* Efeito 3D (tilt) básico ao hover - fallback ao JS */
.floating-card:hover,
.floating-card:focus-visible {
    box-shadow:
        0 10px 28px rgba(0,0,0,0.10),
        0 10px 28px rgba(245,102,0,0.18),
        0 0 0 2px rgba(245,102,0,0.10);
    border-color: var(--accent);
}

/* Fallback hover quando JS não está ativo: tilt + pop mais fortes */
.floating-card:hover .floating-card-inner,
.floating-card:focus-visible .floating-card-inner {
    transform: rotateX(10deg) rotateY(-10deg) translateZ(14px) scale(1.08);
    filter: brightness(1.08) contrast(1.08);
}

/* Leve zoom da imagem para reforçar destaque */
.floating-card-inner img { transition: transform .25s ease; }
.floating-card:hover .floating-card-inner img,
.floating-card:focus-visible .floating-card-inner img {
    transform: scale(1.06);
}

/* Efeito shine rápido ao passar o mouse */
.floating-card-inner { position: relative; }
.floating-card-inner::after {
    content: "";
    position: absolute;
    top: -20%;
    left: -120%;
    width: 60%;
    height: 140%;
    background: linear-gradient(75deg, rgba(255,255,255,0) 0%, rgba(255,255,255,0.55) 50%, rgba(255,255,255,0) 100%);
    transform: skewX(-12deg);
    opacity: 0;
    pointer-events: none;
}

.floating-card:hover .floating-card-inner::after,
.floating-card:focus-visible .floating-card-inner::after {
    animation: shineSweep .8s ease forwards;
}

@keyframes shineSweep {
    0% { left: -120%; opacity: 0; }
    10% { opacity: .7; }
    50% { opacity: .6; }
    100% { left: 140%; opacity: 0; }
}

/* Paletas por plataforma */
.card-google i { color: #4285F4; }
.card-instagram i {
    background: radial-gradient(33% 100% at 70% 0%, #FED373 0%, rgba(254,211,115,0) 60%),
                linear-gradient(45deg, #405DE6, #5851DB, #833AB4, #C13584, #E1306C, #FD1D1D);
    -webkit-background-clip: text;
    background-clip: text;
    color: transparent;
}
.card-marketing i { color: var(--primary); }
.card-meta i { color: #1877F2; }

/* Compensa o header fixo nas âncoras (menu) */
section[id] { scroll-margin-top: 110px; }

/* Ajusta padding-top no mobile para não colar no header */
@media (max-width: 680px) {
    .inicio-destaque { padding-top: 140px; }
}

/* ================== Nossa História ================== */
.nossa-historia {
    background: var(--light);
    padding: 80px 0;
    border-radius: 40px;
    box-shadow: 0 8px 32px rgba(44,84,235,0.07);
    margin: 40px 0;
}

.nossa-historia h2 {
    text-align: center;
    font-size: clamp(26px, 3.4vw, 36px);
    margin-bottom: 48px;
    font-family: 'Montserrat', sans-serif;
    font-weight: 800;
    letter-spacing: 1px;
    line-height: 1.15;
    background: linear-gradient(180deg, var(--accent) 0%, #ff8e33 100%);
    -webkit-background-clip: text;
    background-clip: text;
    -webkit-text-fill-color: transparent;
}

.historia-bloco {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 80px; /* aumentado para afastar mais a foto do texto */
    margin-bottom: 56px;
    flex-wrap: wrap;
}

.historia-bloco:last-child {
    margin-bottom: 0;
}

.historia-img {
    width: 320px;
    max-width: 90vw;
    height: 400px;
    object-fit: cover;
    border-radius: 24px;
    box-shadow: 0 4px 24px rgba(44,84,235,0.10);
}

.historia-texto {
    max-width: 540px;
    color: #fff;
    background: rgba(255,255,255,0.04);
    border-radius: 20px;
    padding: 32px 28px;
    box-shadow: 0 2px 12px rgba(44,84,235,0.08);
}

.historia-texto h3 {
    font-size: 20px;
    color: var(--accent);
    margin-bottom: 18px;
    font-family: 'Montserrat', sans-serif;
}

.historia-texto p {
    font-size: 15px;
    line-height: 1.7;
    color: #f56600;
}

/* Alternância de blocos */
.historia-inicio, .historia-atual { flex-direction: row; }
.historia-crescimento { flex-direction: row-reverse; }

/* ================== Serviços ================== */
.servicos {
    background: #23272f;
    padding: 48px 0;
    transition: background 1.2s cubic-bezier(.4,0,.2,1);
    border-radius: 40px;
    box-shadow: 0 8px 32px rgba(44,84,235,0.07);
    margin: 40px 0;
}

.servicos h2 {
    text-align: center;
    font-size: clamp(26px, 3.4vw, 36px);
    margin-bottom: 40px;
    font-family: 'Montserrat', sans-serif;
    font-weight: 800;
    letter-spacing: 1px;
    line-height: 1.15;
    background: linear-gradient(180deg, var(--accent) 0%, #ff8e33 100%);
    -webkit-background-clip: text;
    background-clip: text;
    -webkit-text-fill-color: transparent;
}

.servicos-list {
    display: flex;
    justify-content: center;
    gap: 20px;
    flex-wrap: wrap;
}

.servico-card {
    background: var(--dark);
    border-radius: 16px;
    box-shadow: 0 2px 12px rgba(44,84,235,0.08);
    padding: 20px 14px;
    width: 220px;
    text-align: center;
    transition: transform 0.3s, box-shadow 0.3s;
}

.servico-card:hover {
    transform: translateY(-8px) scale(1.04);
    box-shadow: 0 6px 24px rgba(44,84,235,0.18);
}

.servico-card i {
    font-size: 40px;
    color: var(--primary);
    margin-bottom: 18px;
}

.servico-card h3 {
    font-size: 16px;
    color: var(--accent);
    margin-bottom: 12px;
    font-family: 'Montserrat', sans-serif;
}

.servico-card p {
    color: var(--light);
    font-size: 14px;
}

/* ================== Clientes Novo ================== */
.clientes-novo {
    background: #ffffff;
    padding: 80px 0;
    border-radius: 40px;
    position: relative;
    overflow: hidden;
    box-shadow: 0 4px 18px rgba(0,0,0,0.05);
    
    /* Borda mais grossa com efeito animado */
    border: 6px solid transparent;
    background:
        linear-gradient(#ffffff, #ffffff) padding-box,
        linear-gradient(120deg, var(--accent), #ff8e33, var(--accent)) border-box;
    background-size: 100% 100%, 300% 300%;
    animation: clientesBorderFlow 10s linear infinite;
    transition: box-shadow .5s, transform .5s;
}

.clientes-novo:hover {
    box-shadow: 0 0 0 6px rgba(245,102,0,0.12), 0 12px 40px rgba(0,0,0,0.16);
    transform: translateY(-4px);
}

/* Foco acessível (ex: navegação por âncora) */
.clientes-novo:focus-within {
    box-shadow: 0 0 0 8px rgba(245,102,0,0.25);
    outline: none;
}

/* Animação do gradiente da borda */
@keyframes clientesBorderFlow {
    0%   { background-position: 0 0,    0% 50%; }
    50%  { background-position: 0 0,  100% 50%; }
    100% { background-position: 0 0,    0% 50%; }
}

/* Reduz movimento para usuários sensíveis */
@media (prefers-reduced-motion: reduce) {
    .clientes-novo {
        animation: none;
        background:
            linear-gradient(#ffffff,#ffffff) padding-box,
            linear-gradient(120deg, var(--accent), #ff8e33) border-box;
    }
}

.clientes-novo h2 {
    text-align: center;
    font-size: clamp(26px, 3.4vw, 36px);
    margin-bottom: 56px;
    font-family: 'Montserrat', sans-serif;
    font-weight: 800;
    letter-spacing: 1px;
    line-height: 1.15;
    background: linear-gradient(180deg, var(--accent) 0%, #ff8e33 100%);
    -webkit-background-clip: text;
    background-clip: text;
    -webkit-text-fill-color: transparent;
}

/* Sublinhado/acento animado sob os títulos das seções */
.nossa-historia h2::after,
.servicos h2::after,
.clientes-novo h2::after {
    content: "";
    display: block;
    width: 160px;
    height: 6px;
    margin: 12px auto 0;
    border-radius: 8px;
    background: linear-gradient(90deg, var(--accent), #ff8e33, var(--accent));
    background-size: 200% 100%;
    box-shadow: 0 4px 16px rgba(245,102,0,0.28);
    animation: titleBarFlow 6s ease infinite;
}

@keyframes titleBarFlow {
    0%   { background-position: 0% 50%; }
    50%  { background-position: 100% 50%; }
    100% { background-position: 0% 50%; }
}

@media (prefers-reduced-motion: reduce) {
    .nossa-historia h2::after,
    .servicos h2::after,
    .clientes-novo h2::after { animation: none; background-size: 100% 100%; }
}

.clientes-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
    gap: 32px;
    max-width: 1000px;
    margin: 0 auto;
}

/* Container do flip card */
.cliente-card-novo {
    perspective: 1000px;
    height: 320px;
    width: 100%;
}

/* Card interno com flip */
.cliente-flip-inner {
    position: relative;
    width: 100%;
    height: 100%;
    text-align: center;
    transition: transform 0.8s;
    transform-style: preserve-3d;
    cursor: pointer;
}

.cliente-card-novo:hover .cliente-flip-inner {
    transform: rotateY(180deg);
}

/* Frente e verso do card */
.cliente-flip-front,
.cliente-flip-back {
    position: absolute;
    width: 100%;
    height: 100%;
    backface-visibility: hidden;
    border-radius: 20px;
    border: 3px solid var(--accent); /* borda laranja */
    box-shadow: 0 8px 24px rgba(0,0,0,0.08);
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    padding: 24px;
    background: #ffffff;
}

/* Frente do card (foto e nome) */
.cliente-flip-front {
    background: linear-gradient(135deg, #ffffff 0%, #f8f9fa 100%);
}

.cliente-flip-front img {
    width: 140px;
    height: 140px;
    border-radius: 18px;      /* antes 50% (circular) */
    object-fit: cover;
    border: 4px solid var(--accent);
    box-shadow: 0 4px 16px rgba(245,102,0,0.25);
}

.cliente-nome-novo {
    font-size: 20px;
    font-weight: 700;
    color: #1e1f23;
    margin: 12px 0 8px 0;
    font-family: 'Montserrat', sans-serif;
}

.cliente-empresa-novo {
    font-size: 14px;
    color: #666;
    text-align: center;
    line-height: 1.4;
}

/* Verso do card (feedback) */
.cliente-flip-back {
    transform: rotateY(180deg);
    background: linear-gradient(135deg, var(--accent) 0%, #ff8533 100%);
    color: #ffffff;
    text-align: left;
    justify-content: flex-start;
    padding: 20px;
}

.cliente-frase-novo {
    font-size: 15px;
    line-height: 1.6;
    text-align: center;
    font-style: italic;
    position: relative;
    overflow-y: auto;
    max-height: 100%;
}

.cliente-frase-novo::before {
    content: '"';
    font-size: 40px;
    color: rgba(255,255,255,0.5);
    position: absolute;
    top: -15px;
    left: -5px;
    font-family: serif;
}

.cliente-frase-novo::after {
    content: '"';
    font-size: 40px;
    color: rgba(255,255,255,0.5);
    position: absolute;
    bottom: -25px;
    right: 5px;
    font-family: serif;
}

/* Responsivo */
@media (max-width: 768px) {
    .clientes-grid {
        grid-template-columns: 1fr;
        gap: 24px;
        padding: 0 20px;
    }
    
    .cliente-card-novo {
        height: 300px;
    }
    
    .cliente-flip-front img {
        width: 110px;
        height: 110px;
        border-radius: 16px;
    }
    
    .cliente-nome-novo {
        font-size: 18px;
    }
    
    .cliente-frase-novo {
        font-size: 14px;
    }
}

@media (max-width: 480px) {
    .cliente-card-novo {
        height: 280px;
    }
    
    .cliente-flip-back {
        padding: 16px;
    }
}

/* ================== Contato ================== */
.contato {
    background: #23272f;
    padding: 64px 0;
    position: relative;
    z-index: 1;
    transition: background 1.2s cubic-bezier(.4,0,.2,1);
    border-radius: 40px;
    box-shadow: 0 8px 32px rgba(44,84,235,0.07);
    margin: 40px 0;
}

.contato h2 {
    text-align: center;
    font-size: 28px;
    color: var(--accent);
    margin-bottom: 40px;
    font-family: 'Montserrat', sans-serif;
    letter-spacing: 1px;
}

.contato-subtitulo {
    text-align: center;
    font-size: 20px;
    font-weight: 600;
    color: var(--accent);
    margin: 0 0 32px 0;
    font-family: 'Montserrat', sans-serif;
}

.contato-flex {
    display: flex;
    align-items: flex-start;
    justify-content: center;
    gap: 56px;
    max-width: 900px;
    margin: 0 auto;
}

.contato-form-area {
    flex: 1 1 340px;
    max-width: 400px;
    background: #fff;
    border-radius: 18px;
    box-shadow: 0 2px 16px rgba(44,84,235,0.10);
    padding: 36px 28px;
    margin-left: 12px;
    margin-right: 12px;
    color: var(--);
    display: flex;
    flex-direction: column;
    align-items: stretch;
}

.contato-form-area .contato-titulo {
    margin: 0 0 14px 0;
    text-align: center;
    font-size: 28px;
    font-weight: 700;
    color: var(--accent);
    letter-spacing: .5px;
}

.contato-form-area h3 {
    margin-top: 0;
    text-align: center;
}

.contato-form-area h2,
.contato-form-area label,
.contato-form-area input,
.contato-form-area textarea {
    color: var(--accent);
}

.contato-form-area input,
.contato-form-area textarea {
    border: 1px solid var(--accent-light);
    background: #fff;
}

.contato-form-area input:focus,
.contato-form-area textarea:focus {
    outline: 2px solid var(--accent);
}

form {
    background: transparent;
    box-shadow: none;
    padding: 0;
}

/* ==== ALTERAÇÃO: Card de explicação agora com fundo branco (var(--dark)) ====
   - Corrigido background inválido anterior.
   - Aplicado mesmo padrão de raio e sombra do formulário.
   - Texto mantém cor de destaque (accent) para consistência.
*/
.contato-explicacao {
    flex: 1 1 220px;
    max-width: 400px;
    align-self: center;
    background: var(--dark); /* Fundo branco desejado */
    border-radius: 18px; /* Igual ao formulário */
    padding: 36px 28px;
    margin-left: 12px;
    margin-right: 12px;
    text-align: left;
    box-shadow: 0 2px 16px rgba(44,84,235,0.10); /* Sombra alinhada */
    color: var(--accent);
    display: flex;
    align-items: center;
    line-height: 1.6;
}

.contato-explicacao p {
    color: inherit;
    font-weight: 500;
    font-family: 'Open Sans', sans-serif;
    font-size: 15px;
    letter-spacing: 0.3px;
    margin: 0;
}

.contato-explicacao:hover {
    box-shadow: 0 4px 28px rgba(245,102,0,0.18);
    transform: translateY(-3px);
    transition: 0.35s;
}

.form-group { margin-bottom: 20px; }

label {
    display: block;
    margin-bottom: 8px;
    color: var(--primary);
    font-weight: 600;
    font-family: 'Montserrat', sans-serif;
}

input, textarea {
    width: 100%;
    padding: 10px;
    border-radius: 8px;
    border: 1px solid var(--light-gray);
    background: var(--light);
    color: var(--dark);
    font-size: 15px;
    font-family: 'Open Sans', sans-serif;
    margin-bottom: 8px;
}

input:focus, textarea:focus {
    outline: 2px solid var(--primary);
}

#form-feedback {
    margin-top: 20px;
    text-align: center;
    color: var(--accent);
    font-weight: 600;
}

/* ================== Footer ================== */
footer {
    background: var(--light);
    border-radius: 40px 40px 0 0;
    box-shadow: 0 -8px 32px rgba(44,84,235,0.07);
    padding: 30px 0;
    text-align: center;
    color: var(--gray);
    transition: background 1.2s cubic-bezier(.4,0,.2,1);
}

.footer-content {
    display: flex;
    justify-content: space-between;
    align-items: center;
    max-width: 1200px;
    margin: 0 auto;
    flex-wrap: wrap;
}

/* Centralizar texto do rodapé */
footer .footer-content {
    justify-content: center !important;
}

footer .footer-content p {
    flex: 0 1 auto;
    width: 100%;
    text-align: center;
    margin: 0 auto;
    font-size: 14px;
    letter-spacing: .5px;
    color: #ffffff;
}

.footer-social a {
    color: var(--accent);
    font-size: 24px;
    margin-left: 18px;
    transition: color 0.3s;
}
.footer-social a:hover { color: #fff; }

/* ================== Ícone flutuante do WhatsApp ================== */
.whatsapp-float {
    position: fixed;
    bottom: 32px;
    right: 32px;
    z-index: 9999;
    background: #25d366;
    color: #fff;
    width: 64px;
    height: 64px;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    box-shadow: 0 4px 24px rgba(44,84,235,0.18);
    font-size: 38px;
    cursor: pointer;
    transition: background 0.3s, transform 0.3s;
}
.whatsapp-float:hover {
    background: #128c7e;
    transform: scale(1.08);
}

/* ================== Carrossel de Logos ================== */
.logos-carousel-section {
    width: 100vw;
    position: relative;
    left: 50%;
    right: 50%;
    margin-left: -50vw;
    margin-right: -50vw;
    background: #ffffff;
    padding: 35px 0;
    overflow: hidden;
}

.logos-carousel-wrapper {
    width: 100%;
    overflow: hidden;
    position: relative;
}

.logos-track {
    display: flex;
    align-items: center;
    gap: 28px;
    animation: scroll-logos 20s linear infinite; /* corrigido: garante animação */
    will-change: transform;
}

.logos-carousel-section:hover .logos-track {
    animation-play-state: running !important;
}

.logo-item {
    flex: 0 0 auto;
    width: 150px;
    height: 150px;
    border-radius: 22px;
    background: #f4f4f6;
    display: flex;
    align-items: center;
    justify-content: center;
    box-shadow: 0 4px 12px rgba(0,0,0,0.08);
    transition: transform .3s, box-shadow .3s;
    position: relative;
}

.logo-item::after {
    content: "";
    position: absolute;
    inset: 0;
    border: 1px solid rgba(0,0,0,0.05);
    border-radius: inherit;
    pointer-events: none;
}

.logo-item img {
    max-width: 72%;
    max-height: 72%;
    object-fit: contain;
    filter: grayscale(30%);
    transition: filter .3s, transform .3s;
    border: 3px solid var(--accent); /* borda laranja nas logos */
    border-radius: 16px;
}

/* Fade lateral um pouco menor para aproximar visualmente dos lados */
.logos-carousel-section::before,
.logos-carousel-section::after {
    width: 110px; /* was 140px */
}

/* Tablet */
@media (max-width: 900px) {
    .logo-item {
        width: 120px; /* was 90px */
        height: 120px; /* was 90px */
        border-radius: 18px;
    }
    .logos-track {
        gap: 22px; /* was 28px */
    }
}

/* Mobile */
@media (max-width: 520px) {
    .logo-item {
        width: 100px; /* was 75px */
        height: 100px; /* was 75px */
        border-radius: 16px;
    }
    .logos-track {
        gap: 18px; /* was 22px */
    }
}

@media (max-width: 600px) {
    .inicio-texto h1,
    .servicos h2,
    .clientes-novo h2,
    .contato h2 {
        font-size: 28px;
        text-align: center;
    }
    .cliente-card-novo img { width: 80px; height: 80px; }
    .hero-image img { width: 180px; margin: 0 auto; }
    header { padding: 10px 0; }
    form { padding: 18px; }
}

@media (min-width: 901px) {
    .historia-crescimento { flex-direction: row-reverse !important; }
}

/* Animação reinserida */
@keyframes scroll-logos {
    0% { transform: translateX(0); }
    100% { transform: translateX(-50%); }
}

/* Acessibilidade: reduz movimento */
@media (prefers-reduced-motion: reduce) {
    .logos-track {
        animation: none;
        transform: none;
    }
}

.logos-carousel-head {
    max-width: 1200px;
    margin: 0 auto 26px;
    text-align: center;
    padding: 0 24px;
    position: relative;
}

.logos-carousel-head h2 {
    font-family: 'Montserrat', sans-serif;
    font-size: 30px;
    font-weight: 700;
    margin: 0 0 12px;
    color: #1e1f23;
    position: relative;
    display: inline-block;
}

.logos-carousel-head h2 span {
    position: relative;
    z-index: 2;
}

.logos-carousel-head h2 .accent-part {
    color: var(--accent);
}

.logos-carousel-head h2::after {
    content: "";
    position: absolute;
    left: 50%;
    bottom: -8px;
    transform: translateX(-50%);
    width: 260px;           /* aumentado (antes 180px) */
    height: 6px;
    border-radius: 4px;
    background: var(--accent);
    box-shadow: 0 2px 10px rgba(245,102,0,0.35);
}

.logos-carousel-head p {
    font-family: 'Open Sans', sans-serif;
    font-size: 16px;
    margin: 18px 0 0;
    color: #555;
}

@media (max-width: 600px) {
    .logos-carousel-head h2 { font-size: 24px; }
    .logos-carousel-head h2::after {
        width: 200px;       /* ajusta em mobile */
        height: 5px;
        bottom: -6px;
    }
    .logos-carousel-head p { font-size: 14px; margin-top: 14px; }
}

.inicio-titulo {
    line-height: 1.12;
    font-weight: 700;
}

.marca-completa {
    white-space: nowrap;  /* força tudo na mesma linha em qualquer largura */
    gap: 4px;             /* antes 6px */
    align-items: baseline;
}

.brand-main {
    color: var(--dark);
}

.brand-tag {
    color: #1e1f23;
    font-weight: 600;
    letter-spacing: .5px;
}

/* Linha “Bem-vindo a” centralizada acima do nome da marca */
.inicio-titulo { text-align: center; }
.inicio-texto { text-align: left; }
.inicio-titulo .bem-vindo {
    display: block;
    font-size: 0.9em;
    font-weight: 700;
    margin-bottom: 6px;
    color: var(--accent);
}

/* Centraliza o botão abaixo do título “Ad Aeternum - Soluções Digitais” */
.inicio-texto .btn-inicio {
    display: block;              /* garante que as margens auto funcionem */
    width: max-content;          /* largura exata do conteúdo do botão */
    margin: 12px auto 0;         /* centraliza horizontalmente */
    text-align: center;          /* alinha o texto dentro do botão */
}

/* Se a tela ficar muito estreita, permite quebra suave para não estourar */
@media (max-width: 520px) {
    .marca-completa {
        white-space: nowrap;
        flex-wrap: nowrap;
    }
    .inicio-texto h1,
    .inicio-titulo {
        font-size: 26px; /* ajuste extra para telas muito estreitas */
    }
}

/* ============= Melhorias na Seção Contato ============= */

/* Card de explicação maior e letras aumentadas */
.contato-explicacao {
    padding: 48px 40px !important;      /* aumentado significativamente */
    font-size: 18px !important;         /* aumentado */
    line-height: 1.7;
    border-radius: 20px;
    max-width: 500px;                   /* largura maior */
    background: var(--dark) !important; /* garante fundo branco */
}

.contato-explicacao h3 {
    font-size: 26px !important;         /* aumentado */
    margin-bottom: 20px;
    font-weight: 700;
    color: var(--accent) !important;
    display: block !important;          /* mostra o h3 agora */
}

.contato-explicacao p {
    font-size: 18px !important;         /* garante consistência */
    margin-bottom: 16px;
    color: var(--accent) !important;
}

/* Remove o subtítulo duplicado da seção principal */
.contato-subtitulo {
    display: none;
}

/* Botão enviar igual ao da seção início */
.contato-form button[type="submit"],
.contato-form .btn-enviar,
button[type="submit"] {
    background: #ffffff !important;
    color: var(--accent) !important;
    font-size: 18px !important;
    font-weight: 700 !important;
    padding: 18px 48px !important;
    border-radius: 40px !important;
    border: 1px solid #ffd2ae !important;
    box-shadow: 0 3px 14px rgba(0,0,0,0.06) !important;
    letter-spacing: 1px !important;
    transition: all 0.3s !important;
    cursor: pointer;
    text-transform: none;
    font-family: inherit;
    display: inline-block;
    text-decoration: none;
    text-align: center;
}

.contato-form button[type="submit"]:hover,
.contato-form .btn-enviar:hover,
button[type="submit"]:hover {
    background: var(--accent) !important;
    color: #ffffff !important;
    box-shadow: 0 6px 24px rgba(245,102,0,0.35) !important;
    transform: scale(1.05) !important;
}

/* Override: fotos dos clientes quadradas com bordas arredondadas */
.cliente-flip-front img {
    width: 140px;
    height: 140px;
    border-radius: 18px;      /* antes 50% (circular) */
    object-fit: cover;
    border: 4px solid var(--accent);
    box-shadow: 0 4px 16px rgba(245,102,0,0.25);
}

@media (max-width: 768px) {
    .cliente-flip-front img {
        width: 110px;
        height: 110px;
        border-radius: 16px;
    }
}

@media (max-width: 480px) {
    .cliente-flip-front img {
        width: 100px;
        height: 100px;
        border-radius: 14px;
    }
}

/* Override layout do card de explicação (título no topo e centralizado) */
.contato-explicacao {
    display: flex !important;
    flex-direction: column !important;
    align-items: center !important;
    justify-content: flex-start !important;
    text-align: center !important;
    line-height: 1.7;
}

.contato-explicacao h3 {
    width: 100%;
    text-align: center;
    margin: 0 0 18px 0 !important;
    letter-spacing: .5px;
}

.contato-explicacao p {
    text-align: center;
}

/* Remover sublinhado de todos os links (mantém só o texto) */
a,
a:visited,
a:hover,
a:focus,
a:active {
    text-decoration: none !important;
}

/* Garantia extra para itens do menu e footer */
header nav ul li a,
footer .footer-content a {
    text-decoration: none !important;
}

/* Caso algum <q> ou outro elemento esteja herdando sublinhado */
q {
    text-decoration: none;
}

/* Garante texto à esquerda e imagem à direita no card Crescimento */
.historia-bloco.historia-crescimento {
  flex-direction: row !important;
  flex-wrap: wrap;
}

@media (max-width: 800px) {
  .historia-bloco.historia-crescimento {
    flex-direction: column !important;
    align-items: stretch;
  }
  .historia-bloco.historia-crescimento .historia-texto,
  .historia-bloco.historia-crescimento .historia-img {
    max-width: 100%;
    width: 100%;
  }
  .historia-bloco.historia-crescimento .historia-img {
    height: auto;
    max-height: 300px;
    margin: 0 auto;
    display: block;
  }
}

/* Card 'Momento atual' com fundo branco apenas no texto */
.historia-bloco.historia-atual .historia-texto {
  background: #fff;
  color: #1e1f23;
  box-shadow: 0 2px 12px rgba(44,84,235,0.08);
  border-radius: 20px;
}

.historia-bloco.historia-atual .historia-texto h3 {
  color: var(--accent);
}

.historia-bloco.historia-atual .historia-texto p {
  color: #666;
}

/* Cards 'Onde tudo começou' e 'Crescimento' com fundo branco apenas no texto */
.historia-bloco.historia-inicio .historia-texto,
.historia-bloco.historia-crescimento .historia-texto {
  background: #fff;
  color: #1e1f23;
  box-shadow: 0 2px 12px rgba(44,84,235,0.08);
  border-radius: 20px;
}

.historia-bloco.historia-inicio .historia-texto h3,
.historia-bloco.historia-crescimento .historia-texto h3 {
  color: var(--accent);
}

.historia-bloco.historia-inicio .historia-texto p,
.historia-bloco.historia-crescimento .historia-texto p {
  color: #666;
}

/* Unifica estilo dos botões principais: início e contato */
.btn-inicio, .btn-enviar, .contato-form button[type="submit"] {
    background: #fff !important;
    color: var(--accent) !important;
    font-size: 20px !important;           /* maior */
    font-weight: 800 !important;
    padding: 20px 54px !important;        /* maior */
  border-radius: 40px !important;
  border: 1px solid #ffd2ae !important;
  box-shadow: 0 3px 14px rgba(0,0,0,0.06) !important;
  letter-spacing: 1px !important;
  transition: all 0.3s !important;
  cursor: pointer;
  text-transform: none;
  font-family: inherit;
  display: inline-block;
  text-decoration: none;
  text-align: center;
}
/* ================== Hero Stats (KPIs) ================== */
.hero-stats {
    display: grid;
    grid-template-columns: repeat(3, minmax(120px, 1fr));
    gap: 18px;
    margin: 18px auto 0;
    width: 100%;
    max-width: 760px;
    align-items: stretch;
}

.hero-stats .stat {
    background: #ffffff;
    border: 2px solid var(--accent);
    border-radius: 12px;
    padding: 10px 10px;                  /* menor altura */
    text-align: center;
    box-shadow: 0 6px 20px rgba(245,102,0,0.10);
}

.hero-stats .stat-number {
    display: block;
    font-family: 'Montserrat', sans-serif;
    font-weight: 800;
    font-size: 22px;                      /* um pouco menor */
    color: var(--accent);
    letter-spacing: .5px;
    margin-bottom: 6px;
}

.hero-stats .stat-label {
    display: block;
    font-size: 12px;                      /* menor */
    color: #1e1f23;
    opacity: 0.85;
}

@media (max-width: 680px) {
    .hero-stats {
        grid-template-columns: 1fr 1fr;
        gap: 12px;
        max-width: 520px;
    }
}

@media (max-width: 420px) {
    .hero-stats {
        grid-template-columns: 1fr;
        max-width: 360px;
    }
}

.btn-inicio:hover, .btn-enviar:hover, .contato-form button[type="submit"]:hover {
  background: var(--accent) !important;
  color: #fff !important;
  box-shadow: 0 6px 24px rgba(245,102,0,0.35) !important;
  transform: scale(1.05) !important;
}

/* Efeito de zoom e rotação na foto e elevação no texto dos cards da seção Nossa História ao passar o mouse */
.historia-bloco:hover .historia-img {
  transform: scale(1.06) rotate(-2deg);
  box-shadow: 0 8px 32px rgba(245,102,0,0.18), 0 2px 12px rgba(44,84,235,0.10);
  transition: transform 0.35s, box-shadow 0.35s;
}

.historia-bloco:hover .historia-texto {
  transform: translateY(-8px) scale(1.03);
  box-shadow: 0 8px 32px rgba(44,84,235,0.18), 0 2px 12px rgba(44,84,235,0.08);
  transition: transform 0.35s, box-shadow 0.35s;
}

.historia-img, .historia-texto {
  transition: transform 0.35s, box-shadow 0.35s;
}

/* ================== Efeito de Digitação ================== */
.digitando {
  opacity: 1;
  white-space: pre-line;
  border-right: 2px solid var(--accent);
  animation: blink-cursor 0.8s steps(1) infinite;
  min-height: 1em;
}

@keyframes blink-cursor {
  0%, 100% { border-color: var(--accent); }
  50% { border-color: transparent; }
}
