* {
  font-family: "Archivo", sans-serif;
}
body #back_to_top{
	width: unset !important;
}
.fixed {
	border-radius: 25px;
}
.header_bottom{
	background: transparent !important;
}
.a
/* 1) Remova o filtro do container que contem o texto */
.scroll_header_top_area.glass-surface,
.scroll_header_top_area.glass {
  filter: none !important;
  background: transparent !important;
  isolation: isolate; /* mantem tudo contido */
}

/* 2) Recrie o "glass" como camada de fundo */
.scroll_header_top_area.glass-surface::before {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 0;                /* fica atras do texto */
  /* seu efeito glass aqui (ajuste a gosto) */
  backdrop-filter: blur(12px) saturate(140%);
  -webkit-backdrop-filter: blur(12px) saturate(140%);
  background: rgba(255,255,255,0.06);
  border-bottom: 1px solid rgba(255,255,255,0.08);
}

/* 3) Texto negativo de fato (menus, etc.) */
.scroll_header_top_area .main_menu a span,
.scroll_header_top_area .mobile_menu a span,
.scroll_header_top_area .q_logo img + span,
.scroll_header_top_area .side_menu_button_wrapper,
.scroll_header_top_area .header_inner_left .mobile_menu_button span,
.scroll_header_top_area .header_inner_left .mobile_menu_button i {
  position: relative;
  z-index: 1;                 /* acima do ::before */
  color: #fff;                /* base branca */
  mix-blend-mode: difference; /* inverte conforme fundo real */
  text-shadow: 0 0 1px rgba(0,0,0,.4), 0 0 1px rgba(255,255,255,.4);
}

/* 4) Garante que nada acima mate o blend */
.scroll_header_top_area .header_inner,
.scroll_header_top_area .header_top_bottom_holder,
.scroll_header_top_area .header_bottom,
.scroll_header_top_area .container,
.scroll_header_top_area .container_inner {
  background: transparent !important;
  filter: none !important;          /* importante: nenhum filter em ancestrais do texto */
  transform: none !important;       /* evite criar stacking context desnecessario */
  will-change: auto !important;
}

/* Opcional: quando estiver 'sticky', mantenha comportamento */
.scroll_header_top_area.fixed,
.scroll_header_top_area.scrolled_not_transparent {
  background: transparent !important;
}

body .content.content_top_margin{
	margin-top: 0 !important;
}
body h1{
	font-size: clamp(34px, 4.2vw, 75px);
	line-height: 1.2;
	font-weight: 400;
}
body h2{
	font-size: clamp(22px, 3vw, 51px);
	line-height: 1.2;
}
/* ==============
   Banner Motion — sequencial & slow
   Ordem: H1 -> P -> A (com stagger)
   ============== */

:root{
  --mv-ease: cubic-bezier(.22,.86,.26,1);
  --mv-gap: 160ms;          /* respiro entre cada bloco */
  --mv-dur-h1: 1200ms;      /* antes: 700ms */
  --mv-dur-p:  900ms;       /* antes: 420ms */
  --mv-dur-a:  800ms;       /* antes: 420ms */
  --mv-stagger-a: 140ms;    /* intervalo entre links */
}

/* base: começam invisíveis e preparados para animar */
#banner h1,
#banner p,
#banner a {
  opacity: 0;
  will-change: transform, opacity, clip-path;
  animation-fill-mode: forwards;
}

/* 1) H1 — Vector Sweep v2 (reveal por clip) */
#banner h1{
  transform: translateY(10px) scale(.985);
  letter-spacing: -0.06em;
  filter: blur(6px);
  background: linear-gradient(90deg,#fff 0%,#e8edff 50%,#fff 100%);
  -webkit-background-clip: text;
  color: transparent;

  /* começa imediatamente */
  animation: mv-h1-sweep var(--mv-dur-h1) var(--mv-ease) 0ms forwards;
}

@keyframes mv-h1-sweep{
  0%{
    opacity:0;
    transform: translateY(10px) scale(.985);
    filter: blur(6px);
    clip-path: polygon(0 0, 0 0, 0 100%, 0 100%);
  }
  60%{
    opacity:1;
    transform: translateY(0) scale(1.01);
    filter: blur(0);
    clip-path: polygon(0 0, 95% 0, 95% 100%, 0 100%);
  }
  100%{
    opacity:1;
    transform: translateY(0) scale(1);
    clip-path: polygon(0 0, 100% 0, 100% 100%, 0 100%);
    filter: blur(0);
  }
}

/* 2) P — Ambient Rise (fade+lift) 
   inicia só DEPOIS do H1 terminar + gap */
#banner p{
  transform: translateY(12px);
  animation: mv-ambient-rise var(--mv-dur-p) ease-out 
             calc(var(--mv-dur-h1) + var(--mv-gap)) forwards;
}

@keyframes mv-ambient-rise{
  from{ opacity:0; transform: translateY(12px); filter: blur(2px); }
  to  { opacity:1; transform: translateY(0);    filter: blur(0); }
}

/* 3) A — Depth Pop (3D leve)
   container com perspective e início após P + gap */
#banner{ perspective: 900px; }

#banner a{
  transform: translateZ(-60px) rotateX(8deg) translateY(8px);
  animation: mv-depth-pop var(--mv-dur-a) var(--mv-ease)
             calc(var(--mv-dur-h1) + var(--mv-gap) + var(--mv-dur-p) + var(--mv-gap)) forwards;
}
#banner a:nth-of-type(2){
  animation-delay: calc(
    var(--mv-dur-h1) + var(--mv-gap) + var(--mv-dur-p) + var(--mv-gap) + var(--mv-stagger-a)
  );
}
#banner a:nth-of-type(3){
  animation-delay: calc(
    var(--mv-dur-h1) + var(--mv-gap) + var(--mv-dur-p) + var(--mv-gap) + (2 * var(--mv-stagger-a))
  );
}
#banner a:nth-of-type(n+4){
  animation-delay: calc(
    var(--mv-dur-h1) + var(--mv-gap) + var(--mv-dur-p) + var(--mv-gap) + (3 * var(--mv-stagger-a))
  );
}

@keyframes mv-depth-pop{
  to{
    opacity:1;
    transform: translateZ(0) rotateX(0) translateY(0);
  }
}

/* acessibilidade */
@media (prefers-reduced-motion: reduce){
  #banner *, #banner *::before, #banner *::after{
    animation: none !important;
    transition: none !important;
    opacity: 1 !important;
    transform: none !important;
    filter: none !important;
    clip-path: none !important;
  }
}
header.fixed{
	padding-top: 15px !important;
	padding-bottom: 15px !important;
}
/* ===== base que você já tinha ===== */
.btn-1 img, .btn-2 img{
  max-width: 25px;
  margin-left: 20px;
}
a{
	display: inline-block;
	text-align: center;
	width: -webkit-fill-available !important;
}
.btns-div {
  display: flex;
  gap: 12px;
  flex-wrap: wrap;
  max-width: -webkit-fill-available;
}
.btn-1,
.btn-2 {
  position: relative;
  border: 0;
  outline: 0;
  cursor: pointer;
  border-radius: 12px;
  font-weight: 600;
  letter-spacing: 0.2px;
  transform: translateZ(0);
  transition: all 0.3s ease, transform 0.3s ease !important;
  font-size: 16px;
  flex: 1;
  display: flex;
  align-items: center;
  justify-content: center;
  box-shadow: none;
  overflow: hidden;
}

/* ===== BTN 1 (mantido com brilho líquido) ===== */
.btn-1 {
  background: linear-gradient(135deg, #00c2a8, #0be0ff);
  color: #fff !important;
  padding: 12px 18px;
}
.btn-1::after{
  content:"";
  position:absolute;
  inset:0;
  border-radius:12px;
  background: linear-gradient(120deg, transparent, rgba(255,255,255,.45), transparent);
  transform: translateX(-110%);
  transition: transform .6s ease;
  pointer-events:none;
}
.btn-1:hover::after{ transform: translateX(110%); }
.btn-1:hover{
  filter: brightness(1.08);
  transform: translateY(-2px);
  box-shadow: 0 0 20px rgba(11,224,255,.35);
}
.btn-1:active{ transform: translateY(0); filter: brightness(.95); }

/* =========================================================
   BTN 2 — QUANTUM FLICKER (micropontos piscando nas bordas)
   - Não altera o background interno
   - Somente contorno/brilho
   - Sem mudar HTML
   Camadas:
   ::after  = anel suave (base cromática discreta)
   ::before = micropontos "random-like" via conic + steps
   ========================================================= */
.btn-2 {
  background: var(--btn2-bg);
  color: #e8ebef !important;
  border: 1px solid var(--btn2-bd);
  padding: 12px 18px;
  z-index: 1;
}

/* Anel base suave (coerente com btn-1) — só borda */
.btn-2::after{
  content:"";
  position:absolute;
  inset:-1px;
  border-radius:12px;
  padding:1.25px; /* espessura do anel base */
  background: linear-gradient(135deg, #00c2a8, #0be0ff);
  opacity:.0;
  filter: blur(.6px);
  transition: opacity .35s ease, filter .35s ease;
  pointer-events:none;
  /* máscara pra exibir só a borda */
  -webkit-mask: linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0);
  -webkit-mask-composite: xor; mask-composite: exclude;
  z-index: 2;
}

/* Micropontos cintilando (multi-camadas + velocidades/delays) */
.btn-2::before{
  content:"";
  position:absolute;
  inset:-2px;          /* cobre a borda externa */
  border-radius:13px;
  padding:2px;         /* espessura da faixa dos pontos */
  /* Três camadas de pontos com intensidades diferentes */
  background:
    /* camada 1: ciano forte, pontos maiores */
    repeating-conic-gradient(from var(--flick-a1, 0deg),
      rgba(11,224,255,.95) 0 2deg, transparent 2deg 22deg),
    /* camada 2: ciano médio, pontos médios */
    repeating-conic-gradient(from var(--flick-a2, 120deg),
      rgba(11,224,255,.6) 0 1.5deg, transparent 1.5deg 18deg),
    /* camada 3: branco frio, pontos pequenos (cintila) */
    repeating-conic-gradient(from var(--flick-a3, 240deg),
      rgba(255,255,255,.9) 0 1deg, transparent 1deg 24deg);
  /* máscara: mostra só o contorno */
  -webkit-mask: linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0);
  -webkit-mask-composite: xor; mask-composite: exclude;
  opacity: 0;
  filter: blur(.35px);
  transition: opacity .25s ease;
  pointer-events:none;
  z-index: 3;
}

/* Interação: ativa o anel base + flicker com "random-like" (steps) */
.btn-2:hover{
  transform: translateY(-2px);
  box-shadow: 0 12px 28px rgba(0,0,0,.28);
  border-color: rgba(255,255,255,.18);
}
.btn-2:hover::after{
  opacity:.9;
  filter: blur(1px);
}
.btn-2:hover::before{
  opacity: 1;
  animation:
    flick-a1 1200ms steps(18) infinite,
    flick-a2 920ms  80ms steps(16) infinite,
    flick-a3 760ms  140ms steps(14) infinite;
}
.btn-2:active{ transform: translateY(0); box-shadow:none; }

/* “falso aleatório”: cada layer tem velocidade/delay diferentes */
@keyframes flick-a1 { from{ --flick-a1: 0deg; } to{ --flick-a1: 360deg; } }
@keyframes flick-a2 { from{ --flick-a2: 0deg; } to{ --flick-a2: 360deg; } }
@keyframes flick-a3 { from{ --flick-a3: 0deg; } to{ --flick-a3: 360deg; } }

/* zera qualquer translate global antigo compartilhado */
.btn-1:hover, .btn-2:hover{ /* intencionalmente vazio */ }


header{
	background: #0000007d;
}
.brilho-azul{
	color: #42f5f9;
	text-shadow: 0 0 4px #fff;
}
.grid-sec{
	max-width: 1700px;
	padding: 80px 25px;
	margin: 0 auto !important;
}
.stretch>div{
	display: flex;
	flex-wrap: wrap;
}
.stretch-item *{
	height: 100% !important;
	object-fit: cover;
}
.area-btns{
    display: flex;
    flex-wrap: wrap;
    gap: 15px;
    align-items: center;
    justify-content: flex-start;
    margin-top: 30px;
}
.center{
	display: flex;
	flex-wrap: wrap;
    align-items: center;
    justify-content: center;
}
.video-bg {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  overflow: hidden;
  z-index: -1;
}

.video-bg video {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.bd-rds-25 img{
	border-radius: 25px;
	margin: 20px 0 0;
}
.sub p{
	margin: 15px auto 25px !important;
	font-size: 20px;
	max-width: 800px;
}

@media (min-width: 769px){
	body header{
		max-width: 1700px !important;
    left: 50% !important;
    transform: translateX(-50%) !important;
    width: 100% !important;
    margin-top: 20px !important;
    padding-top: 0 !important;
	}
}
@media (max-width: 768px){
	.btns-div{
		flex-direction: column;
	}
	.video-bg{
		opacity: 0.6;
	}
	.sub p{
		font-size: 17px;
	}
	body h1{
		text-align: center;
	}
	.invert>div{
		display: flex;
		flex-direction: column-reverse;
	}
	.scroll_header_top_area.fixed, .scroll_header_top_area.scrolled_not_transparent{
		background: #0000008c !important;
		position: fixed !important;
	}
	.mobile_menu{
		background: transparent !important
	}
}