@font-face{
  font-family:"Font Awesome 6 Free";
  src:url("/common/fonts/fontawesome/webfonts/fa-regular-400.woff2") format("woff2");
  font-weight:400;font-style:normal;font-display:swap;
}
@font-face{
  font-family:"Font Awesome 6 Free";
  src:url("/common/fonts/fontawesome/webfonts/fa-solid-900.woff2") format("woff2");
  font-weight:900;font-style:normal;font-display:swap;
}
@font-face{
  font-family:"Font Awesome 6 Brands";
  src:url("/common/fonts/fontawesome/webfonts/fa-brands-400.woff2") format("woff2");
  font-weight:400;font-style:normal;font-display:swap;
}
@font-face{
  font-family:"flaticon_sasly";
  src:url("/common/fonts/flaticon/flaticon_sasly.woff2?ddc3cc99bc293d3eab307e1659c15501") format("woff2");
  font-weight:normal;font-style:normal;font-display:swap;
}

@font-face{
  font-family: "Lato";
  src: url("/assets/fonts/lato/Lato-Regular.woff2") format("woff2");
  font-weight: 400;
  font-style: normal;
  font-display: swap;      /* pode trocar para 'optional' se quiser menos flash */
  /* métricas sugeridas para reduzir reflow vs fallback */
  ascent-override: 90%;
  descent-override: 22%;
  line-gap-override: 0%;
  size-adjust: 101%;
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+2000-206F, U+2074, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}

/* 700 Bold */
@font-face{
  font-family: "Lato";
  src: url("/assets/fonts/lato/Lato-Bold.woff2") format("woff2");
  font-weight: 700;
  font-style: normal;
  font-display: swap;
  ascent-override: 90%;
  descent-override: 22%;
  line-gap-override: 0%;
  size-adjust: 101%;
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+2000-206F, U+2074, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}

/* 900 Black */
@font-face{
  font-family: "Lato";
  src: url("/assets/fonts/lato/Lato-Black.woff2") format("woff2");
  font-weight: 900;
  font-style: normal;
  font-display: swap;
  ascent-override: 90%;
  descent-override: 22%;
  line-gap-override: 0%;
  size-adjust: 101%;
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+2000-206F, U+2074, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}

.sub-title-span {margin-bottom:24px !important;}
@media(max-width:948px) {.sub-title-span{ margin-bottom:16px !important;}}


.grid-container { display: grid; gap: 30px; }
.grid-container.two-cols { grid-template-columns: 1fr 1fr; align-items: center; }
.grid-container.three-cols { grid-template-columns: repeat(3, 1fr); }
.check-list { margin-top: 20px; }
.check-list li { display: flex; align-items: center; gap: 10px; }
.check-list li i { color: var(--color-brand-purple); }

.client-section { padding-top: 0; padding-bottom: 0; }
.client-section .container { padding-top: var(--section-spacing); }
.client-slider-wrapper { overflow: hidden; padding: 25px 0; position: relative; background: rgba(16, 15, 26, 0.7); backdrop-filter: blur(10px); -webkit-backdrop-filter: blur(10px); border-top: 1px solid rgba(167, 62, 249, 0.2); border-bottom: 1px solid rgba(60, 109, 250, 0.2); -webkit-mask-image: linear-gradient(to right, transparent, black 15%, black 85%, transparent); mask-image: linear-gradient(to right, transparent, black 15%, black 85%, transparent); }
.company-slider { display: flex; align-items: center; width: fit-content; animation: slideLeft 40s linear infinite; }
.company-slider:hover { animation-play-state: paused; }
.client-item, .client-separator { display: flex; align-items: center; padding: 0 15px; flex-shrink: 0; }
.client-item img { max-height: 60px; filter: grayscale(1) brightness(0.7); opacity: 0.6; transition: 0.3s ease; }
.client-item:hover img { filter: grayscale(0) brightness(1); opacity: 1; transform: scale(1.1); }
.client-separator { width: 28px; height: 28px; background: url("../images/icon/separador-clientes.webp") center/contain no-repeat; }
@keyframes slideLeft { from { transform: translateX(0); } to { transform: translateX(-50%); } }

.container {padding-top: 20px;}

.stat-item, .stat-card, .feature-card, .key-feature-card, .contact-card { position: relative; background-clip: padding-box; border-radius: 10px; background-color: rgba(255, 255, 255, 0.05); }
.stat-item {
    padding: 20px 40px;
    justify-content: center;
    display: flex
;
    flex-direction: column;
    align-items: center;

}
.stat-card, .feature-card, .key-feature-card { padding: 30px; }
.stat-item::before, .stat-card::before, .feature-card::before, .key-feature-card::before, .contact-card::before { content: ''; position: absolute; inset: 0; border-radius: inherit; padding: 1.5px; background: var(--gradient-border); -webkit-mask: linear-gradient(#fff 0 0) content-box, linear-gradient(#fff 0 0); -webkit-mask-composite: xor; mask-composite: exclude; pointer-events: none; opacity: 0.7; transition: opacity 0.3s ease; }
.stat-item:hover::before, .stat-card:hover::before, .feature-card:hover::before, .key-feature-card:hover::before, .contact-card:hover::before { opacity: 1; }

.stats-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 10px; }
.stat-card { text-align: center; }
.stat-card h2 { font-size: 2.5rem; font-weight: 900; }
.feature-card { height: 100%; backdrop-filter: blur(10px); text-align: center;}
.feature-card .icon { width: 60px; height: 60px; border-radius: 50%; background: var(--color-light); display: flex; align-items: center; justify-content: center; margin: 0 auto 20px; }
.feature-card .icon i[class^="flaticon-"]::before { font-size: 28px; background: var(--gradient-text); -webkit-background-clip: text; -webkit-text-fill-color: transparent; }

.content-image-section .grid-item { position: relative; }
.content-image-section .grid-item > img { border-radius: 20px; position: relative; z-index: 1; transition: transform 0.8s cubic-bezier(0.2, 1, 0.3, 1); }
.content-image-section .grid-item:hover > img { transform: perspective(1000px) rotateY(-5deg) rotateX(2deg) scale(1.05); }
.content-image-section .grid-item::after { content: ''; position: absolute; bottom: -20px; left: 10%; width: 80%; height: 60%; background: var(--color-brand-blue); filter: blur(100px); opacity: 0.3; z-index: 0; }

.integration-tools-wrapper{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,140px));gap:20px;justify-content:center;justify-items:center;margin:40px auto 0;}
.integration-tools-wrapper .tools-item .thumbnail{background-color:rgba(38,35,71,.5);border:1px solid rgba(255,255,255,.05);border-radius:12px;height:80px;padding:15px;display:flex;align-items:center;justify-content:center;transition:.3s ease;}
.integration-tools-wrapper .tools-item .thumbnail:hover{transform:translateY(-5px);background-color:rgba(57,53,102,.7);}
.integration-tools-wrapper .tools-item .thumbnail img{height:40px;width:auto;object-fit:contain;filter:grayscale(1);opacity:.7;transition:.3s ease;}
.integration-tools-wrapper .tools-item .thumbnail:hover img{filter:grayscale(0);opacity:1;}
@media (min-width:768px){.integration-tools-wrapper{grid-template-columns:repeat(auto-fit,minmax(160px,160px));}}

.key-features-section { background-color: var(--color-dark-secondary); }
.key-feature-card { text-align: center; background: var(--color-dark); }
.key-feature-card h4 { margin-bottom: 10px; }

@media(min-width:900px){ .contact-section .contact-grid { grid-template-columns: 1fr 1.5fr; }}

.contact-card { display: flex; align-items: center; gap: 20px; margin-bottom: 20px; transition: 0.3s ease; min-height: 100px; background-color: transparent;}
.contact-card:hover { transform: translateY(-5px); }
.card-icon i { font-size: 24px; background: var(--gradient-text); -webkit-background-clip: text; -webkit-text-fill-color: transparent; }
.card-content h5 { font-size: 1rem; color: var(--color-light); }
.card-content p { font-size: 0.9rem; color: var(--color-text); }
.premium-form-wrapper { padding: 40px; border-radius: 20px; border: 1px solid var(--color-border); background: rgba(16, 14, 30, 0.7); }
.form-header { text-align: center; }
.form-header h3 { font-size: 1.8rem; }
.form_control { width: 100%; padding: 14px 20px; background: rgba(0, 0, 0, 0.25); border: 1px solid var(--color-border); border-radius: 8px; color: var(--color-light); }
.form_control:focus { outline: none; border-color: var(--color-brand-purple); }
.form-privacy-notice { text-align: center; font-size: 0.8rem; }
.form-privacy-notice a { color: var(--color-brand-purple); text-decoration: underline; }

.faq-container { max-width: 800px; margin: 40px auto 0; text-align: left; }
.faq-item { margin: 12px 0; border-radius: 14px; background: linear-gradient(135deg, rgba(255, 255, 255, 0.05), rgba(255, 255, 255, 0.02)); border: 1px solid var(--color-border); transition: 0.3s ease; padding: 10px 0px;}
.faq-item:hover {border:solid #a73ef9 1px;}

.faq-item summary { list-style: none; cursor: pointer; padding: 16px 18px; display: flex; align-items: center; gap: 14px; }
.faq-item summary::-webkit-details-marker { display: none; }
.faq-item summary h3 { font-size: 1.1rem; font-weight: 700; margin: 0; }
.faq-item summary::before { content: ''; width: 18px; height: 18px; flex-shrink: 0; transform: rotate(-90deg); transition: transform 0.25s ease; background-image: url("data:image/svg+xml,%3Csvg width='18' height='18' viewBox='0 0 24 24' xmlns='http://www.w3.org/2000/svg'%3E%3Cdefs%3E%3ClinearGradient id='g' x1='0' y1='0' x2='1' y2='1'%3E%3Cstop stop-color='%23A73EF9'/%3E%3Cstop offset='1' stop-color='%233c6dfa'/%3E%3C/linearGradient%3E%3C/defs%3E%3Cpath d='M8 10l4 4 4-4' stroke='url(%23g)' stroke-width='2.2' stroke-linecap='round' stroke-linejoin='round' fill='none'/%3E%3C/svg%3E"); }
.faq-item[open] summary::before { transform: rotate(0); }
.faq-body { padding: 0 18px 18px; color: var(--color-text); }
.map-wrapper { margin-top: 40px; border-radius: 14px; overflow: hidden; border: 1px solid var(--color-border); aspect-ratio: 16/9; }
.map-wrapper iframe { width: 100%; height: 100%; border: 0; }

.ss-fab { position: fixed; right: 24px; bottom: 80px; width: 60px; height: 60px; border-radius: 50%; display: flex; align-items: center; justify-content: center; z-index: 900; border: 2px solid transparent; background: linear-gradient(var(--color-light), var(--color-light)) padding-box, var(--gradient-primary) border-box; backdrop-filter: blur(10px); transition: transform 0.3s ease, opacity 0.3s ease; }
.ss-fab i { font-size: 24px; background: var(--gradient-text); -webkit-background-clip: text; -webkit-text-fill-color: transparent; }
.ss-fab.is-hidden { opacity: 0; transform: translateY(20px); pointer-events: none; }
.ss-fab__pulse { position: absolute; inset: 0; border-radius: inherit; box-shadow: 0 0 0 0 rgba(60, 109, 250, .35); animation: ssfabpulse 2.2s ease-out infinite; }
@keyframes ssfabpulse{ 60%{box-shadow:0 0 0 18px rgba(60,109,250,0)} }
.fixed-ticker-banner { position: fixed; bottom: 0; left: 0; width: 100%; z-index: 900; padding: 15px 0; background: var(--color-brand-purple); white-space: nowrap; overflow: hidden; transition: transform 0.4s ease, opacity 0.4s ease; }
.fixed-ticker-banner.is-hidden { transform: translateY(100%); opacity: 0; }
.ticker-track { display: flex; width: fit-content; animation: ticker-scroll 40s linear infinite; }
.ticker-content { display: flex; align-items: center; }
.ticker-content span { margin: 0 30px; font-weight: 500; }
.ticker-separator { flex-shrink: 0; width: 18px; height: 18px; background: url("../images/icon/ticker-separator.png") center/contain no-repeat; }
@keyframes ticker-scroll { from { transform: translateX(0); } to { transform: translateX(-50%); } }

@media (max-width: 991px) {
    .desktop-nav-menu, .desktop-cta { display: none; }
    .mobile-menu-toggle { display: block; }
    .grid-container.two-cols, .grid-container.three-cols, .footer-grid, .contact-grid { grid-template-columns: 1fr; }
    .grid-container.two-cols.reverse-on-desktop { display: flex; flex-direction: column-reverse; }
    .footer-cta { flex-direction: column; text-align: center; }
    .cta-content { max-width: 100%; }
    .cta-image { display: none; }
    .footer-bottom { flex-direction: column; gap: 10px; }
    .premium-navbar { padding: 15px; }
}

@media (max-width: 768px) {
    h1 { font-size: 2.5rem; }
    h2 { font-size: 1.8rem; }
    .theme-btn-gradient { padding: 14px 28px; font-size: 0.9rem; }
    .hero-stats { gap: 20px; }
    .hero-stats h2 { font-size: 2.5rem; }
    .ss-fab { width: 50px; height: 50px; right: 15px; bottom: 75px; }
    .ss-fab i { font-size: 20px; }
    .fixed-ticker-banner { padding: 12px 0; }
    .ticker-content span { font-size: 0.9rem; margin: 0 20px; }
}


/* =======================================================
   CSS Adicional para a Seção "A Força por Trás..."
   ======================================================= */

/* Cria a nova classe de lista para não conflitar com a anterior */
.check-list-alt {
    margin-top: 30px;
}

/* Define cada item da lista como um container flex */
.check-list-alt li {
    display: flex;
    align-items: flex-start; /* Alinha o topo do ícone com o topo do bloco de texto */
    gap: 15px; /* Espaço entre o ícone e o texto */
    margin-bottom: 25px; /* Espaço entre os itens da lista */
}

.check-list-alt li:last-child {
    margin-bottom: 0;
}

/* Estiliza o ícone */
.check-list-alt i {
    font-size: 24px; /* Ícone levemente maior */
    color: var(--color-brand-blue); /* Cor azul da sua paleta */
    margin-top: 2px; /* Pequeno ajuste para alinhar perfeitamente com a linha do H4 */
}

/* Estiliza o H4 (subtítulo) */
.check-list-alt .list-content h4, h4, h5 {
    font-size: 22px; /* Tamanho de fonte solicitado */
    color: var(--color-light);
    margin-bottom: 8px; /* Espaçamento menor para o parágrafo abaixo */
    z-index: 10;
}

/* Garante que o parágrafo dentro da lista não tenha margem extra */
.check-list-alt .list-content p {
    margin-bottom: 0;
    color: var(--color-text);
    line-height: 1.6;
}

.grid-container.two-cols.reverse-on-desktop {
    margin-top: 50px;
}

p.section-subtitle, .section-title.text-center.animate-on-scroll.is-visible {
    margin-bottom: 20px;
}

/* =======================================================
   CSS Adicional para a Seção de Contato (Refinado)
   ======================================================= */

.contact-section {
    background-image: radial-gradient(circle at top left, rgba(167, 62, 249, 0.2), transparent 40%),
                      radial-gradient(circle at bottom right, rgba(60, 109, 250, 0.2), transparent 50%);
}

.contact-card {
    border-radius: 16px; /* Borda mais arredondada */
    min-height: auto;
    padding: 25px;
}

.contact-card .card-content .main-info {
    font-size: 1rem;
    color: var(--color-light);
    font-weight: 500;
}
.contact-card .card-content .sub-info {
    font-size: 0.8rem;
    color: var(--color-text);
    margin-top: 5px;
}

.premium-form-wrapper {
    box-shadow: 0 15px 50px rgba(0, 0, 0, 0.3);
    border-radius: 20px;
    padding: 40px;
    background: rgba(16, 14, 30, 0.7);
    backdrop-filter: blur(20px);
    -webkit-backdrop-filter: blur(20px);
    border: 1px solid var(--color-border);
}

.form-row {
    display: flex;
    flex-wrap: wrap;
    gap: 0 30px; /* Espaçamento horizontal */
}
.form-group {
    width: 100%;
    margin-bottom: 25px;
}
.form-group.half-width {
    width: calc(50% - 15px);
}

.form-group .group-label {
    display: block;
    margin-bottom: 12px;
    color: rgba(255, 255, 255, 0.7);
    font-size: 14px;
}

.choices-wrapper {
    display: flex;
    flex-wrap: wrap;
    gap: 25px;
    align-items: center;
    min-height: 48px;
}

.choice-item input[type="radio"],
.choice-item input[type="checkbox"] {
    display: none;
}

.choice-item label {
    display: flex;
    align-items: center;
    color: rgba(255, 255, 255, 0.9);
    font-size: 15px;
    cursor: pointer;
    position: relative;
}

.choice-item label::before {
    content: "";
    display: inline-block;
    width: 20px;
    height: 20px;
    margin-right: 12px;
    border-radius: 5px;
    background-color: rgba(0, 0, 0, 0.25);
    border: 1px solid var(--color-border);
    transition: all 0.2s ease-in-out;
}

.choice-item label:hover::before {
    border-color: var(--color-brand-purple);
}

.choice-item input:checked + label::before {
    background-color: var(--color-brand-purple);
    border-color: var(--color-brand-purple);
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='14' fill='white' viewBox='0 0 16 16'%3E%3Cpath d='M10.97 4.97a.75.75 0 0 1 1.07 1.05l-3.99 4.99a.75.75 0 0 1-1.08.02L4.324 8.384a.75.75 0 1 1 1.06-1.06l2.094 2.093 3.473-4.425a.267.267 0 0 1 .02-.022z'/%3E%3C/svg%3E");
    background-position: center;
    background-repeat: no-repeat;
}

.premium-form-wrapper .theme-btn-gradient {
    width: 100%;
    margin-top: 10px;
    padding: 18px;
}

@media (max-width: 768px) {
    .form-group.half-width {
        width: 100%;
    }
    .form-row {
        gap: 0;
    }
}

h2.h2_contato {
    margin: 0;
}

.section-title.text-center {
    margin-bottom: 20px;
}


/* =======================================================
   CSS Adicional para a Seção "Recursos Exclusivos" (Versão Final Corrigida)
   ======================================================= */

/* A seção pai não precisa de cor de fundo específica, ela usará o padrão do body ou da regra :nth-of-type */
.key-features-wrapper{position:relative;background:linear-gradient(35deg,rgba(81,219,218,0) 0,rgba(81,219,218,0) 52%,rgba(1,74,119,.08) 60%,rgba(1,74,119,.24) 76%,rgba(1,74,119,.52) 100%);border:0;outline:0;box-shadow:none;border-radius:24px;padding:60px 40px;backdrop-filter:saturate(130%) blur(6px);-webkit-backdrop-filter:saturate(130%) blur(6px);overflow:hidden}
.key-features-wrapper::before{content:"";position:absolute;top:-16%;right:-12%;width:150%;height:170%;background:radial-gradient(640px 420px at 92% 6%,rgba(1,74,119,1) 0,rgba(1,74,119,.75) 34%,rgba(1,74,119,.35) 58%,rgba(1,74,119,0) 78%);filter:blur(48px);opacity:.95;z-index:0;pointer-events:none}
.key-features-wrapper>*{position:relative;z-index:1}
.key-features-wrapper .blur-shape{display:none}



/* =======================================================
   CSS Adicional para o Footer (Final)
   ======================================================= */
/* =======================================================
   CSS FINAL - FOOTER ESTILIZADO
   ======================================================= */

.site-footer {
  padding-top: var(--section-spacing);
  position: relative;
  z-index: 1;
  
}


.footer-widgets-wrapper>.container {
    border-top: none;
}

@media(max-width:948px){
    .site-footer {
        padding-top: 0 !important;
        margin-top: -50px;
    }
}

/* CTA superior (mantém seu estilo original) */
.footer-cta {
  position: relative;
  border-radius: 10px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  overflow: hidden;
  margin-bottom: -100px;
  z-index: 2;
}
.cta-content {flex:1;max-width:60%;padding:0 0 0 50px;}
.cta-image {flex-shrink:0;}

/* =======================================================
   BLOCO PRINCIPAL DO FOOTER - EM CAIXA E COM BACKGROUND
   ======================================================= */

.footer-widgets-wrapper{
  position:relative;
  max-width:96%;
  margin:0 auto;
  background:linear-gradient(35deg, #020816 0%, rgb(0 46 46 / 10%) 42%, rgba(1, 74, 119, .24) 66%, rgba(1, 74, 119, .50) 100%);
  border-radius:24px 24px 0px 0px;
  padding:150px 24px 50px;
  overflow:hidden;
}

/* Brilho radial no canto inferior direito */
.blur-shape-footer{
  position:absolute;
  bottom:-220px;
  right:-220px;
  width:900px;
  height:900px;
  background:
    radial-gradient(560px 560px at 88% 92%,
      rgba(1,74,119,.95) 0%,
      rgba(1,74,119,.62) 40%,
      rgba(1,74,119,0) 74%),
    radial-gradient(420px 420px at 92% 96%,
      rgba(81,219,218,.35) 0%,
      rgba(81,219,218,0) 70%);
  filter:blur(22px);
  opacity:.95;
  z-index:0;
  pointer-events:none;
}

/* Conteúdo sobre o brilho */
.footer-widgets-wrapper>.container{
  position:relative;
  z-index:1;
  padding-top:0;
  padding-bottom:0;
}

/* GRID INTERNO DO FOOTER */
.footer-grid{
  display:grid;
  grid-template-columns:2fr 1fr 1fr 1fr;
  gap:30px;
}

/* Logo e textos */
.footer-logo{max-width:350px;}
.footer-widget h4{margin-bottom:20px;}
.footer-widget ul li{margin-bottom:10px;}
.footer-widget a:hover{color:var(--color-light);}
.footer-widget p{opacity:.85;}

/* =======================================================
   ÍCONES SOCIAIS
   ======================================================= */
.social-links{
  display:flex;
  gap:15px;
  margin-top:25px;
}
.social-links a{
  display:flex;
  align-items:center;
  justify-content:center;
  width:42px;
  height:42px;
  border-radius:50%;
  color:var(--color-light);
  background-image:var(--gradient-primary);
  background-size:200% auto;
  box-shadow:0 4px 15px rgba(0,0,0,0.2);
  transition:all .4s ease;
}
.social-links a:hover{
  background-position:right center;
  transform:translateY(-3px);
  box-shadow:0 8px 25px rgba(167,62,249,0.3);
}
.social-links i{font-size:18px;}

/* =======================================================
   COPYRIGHT
   ======================================================= */
.footer-copyright {
    width: 96%;
    left: 50%;
    transform: translateX(-50%);
    position: relative;
    background-color: #4095ff12;
    z-index: -1;
    
}
.footer-copyright .container{
  display:flex;
  justify-content:space-between;
  align-items:center;
  padding-top:25px;
  padding-bottom:25px;
  font-size:.9rem;
  color:var(--color-text);
}
.footer-copyright span{
  color:var(--color-brand-purple);
  font-weight:bold;
}
.footer-copyright .copyright-nav a:hover{
  color:var(--color-light);
}

/* =======================================================
   RESPONSIVIDADE
   ======================================================= */
@media(max-width:768px){
  .footer-widgets-wrapper{padding-top:120px;}
  .footer-grid{grid-template-columns:1fr !important;}
  .footer-copyright .container{
    flex-direction:column;
    gap:15px;
    text-align:center;
  }
}


.back-to-top{
  position:relative;
  display:flex;
  align-items:center;
  justify-content:center;
  width:54px;
  height:54px;
  margin:-50px auto 0;
  border-radius:50%;
  background:linear-gradient(90deg,#3C6DFA 0%,#014A77 100%);
  color:#fff;
  font-size:22px;
  box-shadow:0 6px 20px rgba(0,0,0,.25);
  transition:all .35s ease;
  text-decoration:none;
  z-index:10;
}
.back-to-top:hover{
  transform:translateY(-4px);
  box-shadow:0 10px 25px rgba(60,109,250,.45);
  background:linear-gradient(90deg,#014A77 0%,#3C6DFA 100%);
}
.back-to-top i{
  pointer-events:none;
}


ul.check-list-alt {
    z-index: 10;
    position: relative;
}

@media(max-width:768px){
.key-features-wrapper{

padding:50px 12px;
}

.cta-content {
    flex: 1;
    max-width: 100%;
    padding: 0;
}
.footer-cta {
    padding: 50px 12px;
}

.footer-logo {
    max-width: 100%;
    margin-top: -8px;
}

.footer-copyright {
    padding-bottom: 32px;
}


}




/* Tablet */
@media (max-width: 1024px) {
  h1 { font-size: clamp(2.4rem, 6.5vw, 3.8rem); }
  h2 { font-size: clamp(1.7rem, 4.6vw, 2.3rem); }
  h3 { font-size: clamp(1.25rem, 3.6vw, 1.5rem); }
  .hero-content > p { line-height: 1.65; max-width: 700px; }
  p { font-size: 1.05rem; }
}

/* Mobile grande */
@media (max-width: 768px) {
  h1 { font-size: clamp(2.1rem, 7vw, 3.2rem); }
  h2 { font-size: clamp(1.55rem, 5vw, 2rem); }
  h3 { font-size: clamp(1.18rem, 4.2vw, 1.4rem); }
  .hero-content > p { line-height: 1.6; max-width: 640px; }
  p { font-size: 1rem; }
}

/* Mobile compacto */
@media (max-width: 480px) {
  h1 { font-size: clamp(1.9rem, 8vw, 2.6rem); }
  h2 { font-size: clamp(1.4rem, 6vw, 1.8rem); }
  h3 { font-size: clamp(1.1rem, 4.8vw, 1.3rem); }
  .hero-content > p { line-height: 1.55; max-width: 92vw; }
  p { font-size: 0.98rem; }
}

/* Segurança contra zoom automático do iOS */
@supports (-webkit-touch-callout: none) {
  input, select, textarea { font-size: 16px; }
}


@media(min-width:940px){
img.img_mockup {
    width: 98%;
}

.grid-item.animate-on-scroll.grad_1.is-visible, .grid-item.animate-on-scroll.grad_2.is-visible {
    padding-right: 30px;
}
}




/* ===== Tech Lines BG (section #inicio) ===== */
#inicio.hero-section { position: relative; overflow: hidden; }

#inicio .hero-tech-bg {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  pointer-events: none;
  z-index: 0; /* deixe seu conteúdo com z-index maior se precisar */
}

/* Suaviza o brilho em telas de alta densidade */
@media (min-resolution: 2dppx) {
  #inicio .hero-tech-bg { image-rendering: auto; }
}

/* Respeita usuários com redução de movimento */
@media (prefers-reduced-motion: reduce) {
  #inicio .hero-tech-bg { display: none; }
}

/* Paleta ajustável por CSS variables (opcional) */
#inicio.hero-section {
  --core-1: #f741f7; /* principal */
  --core-2: #00fff2; /* ciano */
  --core-3: #00ff4d; /* verde */
  --wire-alpha: 0.10;   /* opacidade dos fios */
  --pulse-alpha: 0.65;   /* opacidade do pulso */
  --glow: 12px;         /* raio do glow do pulso */
}




/* Garantir layout em linha no nav */
.premium-navbar { display:flex; align-items:center; gap:12px; position:relative; }

/* Bandeiras mobile entre logo e toggle */
.lang-quick {
  display:none; /* só mostra no mobile */
  align-items:center;
  gap:10px;
  margin-left: 6px;
  z-index: 5; /* acima do canvas/efeitos */
}
.lang-quick a {
  display:flex; align-items:center; gap:6px;
  padding:6px 8px; border-radius:10px;
  background: rgba(255,255,255,0.06);
  border: 1px solid rgba(255,255,255,0.12);
  line-height:1; text-decoration:none;
}
.lang-quick img { display:block; width:20px; height:14px; object-fit:cover; }
.lang-quick span { font-size:.85rem; font-weight:600; color:#fff; }

/* Desktop mantém a language-selector tradicional; esconde no mobile */
.language-selector { display:flex; gap:10px; }
@media (max-width: 992px) {
  .language-selector { display:none; }   /* esconde a de desktop */
  .lang-quick { display:flex; }          /* mostra a de mobile */
}

/* Afinar quando a barra ficar apertada */
@media (max-width: 420px) {
  .lang-quick a { padding:5px 6px; gap:5px; }
  .lang-quick span { font-size:.78rem; }
  .lang-quick img { width:18px; height:12px; }
}

/* Evita sobreposição pelo botão/CTA em alguns temas */
.mobile-menu-toggle { z-index: 6; position: relative; }

/* Caso seu nav use justify-content: space-between num reset */
.premium-navbar { justify-content: space-between; }
/* Garante que o bloco centralize bem:
   Logo | [lang-quick] | (menus/cta/toggle) */
.brand-logo { flex:0 0 auto; }
.lang-quick { flex:0 0 auto; }
.desktop-nav-menu, .desktop-cta, .mobile-menu-toggle { flex:0 0 auto; }

.center_mobile{text-align: center;}







   /* Wrapper para a Timeline */
.timeline-wrapper {
    max-width: 800px;
    margin: 40px auto 0;
}

/* Linha vertical principal da Timeline */
.ss-timeline {
    position: relative;
    padding-left: 40px;
}
.ss-timeline::before {
    content: '';
    position: absolute;
    left: 10px;
    top: 10px;
    bottom: 10px;
    width: 3px;
    background: var(--gradient-border);
    border-radius: 3px;
}

/* Item individual da Timeline */
.ss-tl-item {
    display: grid;
    grid-template-columns: 80px 1fr;
    align-items: start;
    gap: 20px;
    margin-bottom: 30px;
    position: relative;
}
.ss-tl-item:last-child {
    margin-bottom: 0;
}

/* Ano do item */
.ss-tl-year {
    color: var(--color-light);
    font-size: 1.5rem;
    font-weight: 700;
    text-align: right;
    line-height: 1;
}

/* Corpo de texto do item */
.ss-tl-body {
    position: relative;
    padding-top: 2px;
}
.ss-tl-body p {
    margin-bottom: 0;
    line-height: 1.6;
}

/* Círculo decorativo em cada item */
.ss-tl-body::before {
    content: '';
    position: absolute;
    left: -17%; /* (gap + padding-left da timeline) - (metade da largura do ponto) */
    top: 0.5em;
    width: 14px;
    height: 14px;
    border-radius: 50%;
    background: var(--color-brand-purple);
    border: 3px solid var(--color-dark);
    z-index: 1;
}

/* Responsividade da Timeline */
@media (max-width: 575px) {
    .ss-timeline {
        padding-left: 20px;
    }
    .ss-tl-item {
        grid-template-columns: 60px 1fr;
        gap: 15px;
    }
    .ss-tl-year {
        font-size: 1.2rem;
    }
    .ss-tl-body::before {
        left: -34%;
    }
}


/* ===================================================================
   CSS Adicional - Páginas Legais (Termos, Privacidade, etc.)
   =================================================================== */

/* Container principal para o conteúdo de texto */
.legal-content-section {
    background-image: none; /* Remove o background de imagem padrão das seções pares */
}
.legal-content-wrapper {
    max-width: 900px;
    margin: 0 auto;
    padding: 20px 0;
}

/* Tópico individual (cada seção dos termos) */
.legal-topic {
    margin-bottom: 40px;
}
.legal-topic h3 {
    font-size: 1.8rem;
    margin-bottom: 1rem;
    padding-bottom: 0.5rem;
    border-bottom: 1px solid var(--color-border);
}
.legal-topic p, .legal-topic li {
    font-size: 1.1rem;
    line-height: 1.8;
    color: var(--color-text);
}
.legal-topic a {
    color: var(--color-brand-purple);
    font-weight: 600;
    text-decoration: underline;
}

/* Listas customizadas */
.legal-list {
    list-style: none;
    padding-left: 0;
    margin: 1rem 0;
}
.legal-list li {
    position: relative;
    padding-left: 28px;
    margin-bottom: 12px;
}
.legal-list li::before {
    content: '';
    position: absolute;
    left: 0;
    top: 0.6em;
    width: 10px;
    height: 10px;
    border-radius: 50%;
    background: radial-gradient(circle at 35% 35%, var(--color-brand-pink), var(--color-brand-purple));
    box-shadow: 0 0 8px rgba(167, 62, 249, 0.5);
}
.legal-list.summary li a {
    color: var(--color-text);
    text-decoration: none;
    transition: color 0.3s ease;
}
.legal-list.summary li a:hover {
    color: var(--color-light);
}

/* Linha horizontal com gradiente */
.legal-hr {
    height: 2px;
    border: 0;
    margin: 60px 0;
    background: linear-gradient(90deg, transparent, var(--color-brand-purple), var(--color-brand-blue), transparent);
    opacity: 0.4;
}

@media(max-width: 768px) {
    .legal-topic h3 { font-size: 1.5rem; }
    .legal-topic p, .legal-topic li { font-size: 1rem; }
}



/* ===================================================================
   CSS Adicional - Página de FAQ com Abas
   =================================================================== */

.faq-tabs-wrapper {
    max-width: 1100px;
    margin: 0 auto;
}

/* Navegação das abas */
.faq-tabs-nav {
    display: flex;
    justify-content: center;
    margin-bottom: 40px;
    border-bottom: 1px solid var(--color-border);
}
.faq-tabs-nav ul {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
}
.faq-tab-link {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 12px 25px;
    color: var(--color-text);
    font-weight: 600;
    border-bottom: 3px solid transparent;
    transition: color 0.3s ease, border-color 0.3s ease;
    margin-bottom: -1px; /* Alinha a borda inferior com a do wrapper */
}
.faq-tab-link:hover {
    color: var(--color-light);
}
.faq-tab-link.is-active {
    color: var(--color-light);
    border-image: var(--gradient-border) 1;
}
.faq-tab-link i {
    font-size: 1.1rem;
    opacity: 0.8;
}

/* Conteúdo das abas */
.faq-tab-pane {
    display: none;
    animation: fadeIn 0.5s ease-in-out;
}
.faq-tab-pane.is-active {
    display: block;
}

@keyframes fadeIn {
    from { opacity: 0; transform: translateY(10px); }
    to { opacity: 1; transform: translateY(0); }
}

@media (max-width: 768px) {
    .faq-tabs-nav ul {
        flex-direction: column;
        width: 100%;
    }
    .faq-tab-link {
        justify-content: center;
        border-bottom-width: 2px;
    }
}

p.form-privacy-notice {
    margin-top: 20px;
}