.animated-chars{display:inline-block}
.animated-chars .char{display:inline-block;opacity:0;filter:blur(12px);animation:charFade 2.3s ease forwards}
@keyframes charFade{0%{opacity:0;filter:blur(12px)}100%{opacity:1;filter:blur(0)}}

/* Custom Scrollbar - Remover barra padrão */
::-webkit-scrollbar {
  display: none;
}
html {
  scrollbar-width: none; /* Firefox */
  -ms-overflow-style: none; /* IE and Edge */
}

/* Progress Bar */
.progress-bar {
  position: fixed;
  top: 0;
  left: 0;
  width: 0%;
  height: 3px;
  background: linear-gradient(90deg, #2D8CFF, #00B3FF);
  z-index: 9999;
  transition: width 0.1s ease;
}
/* Fonte base */
:root{
  --bg:#000000; /* preto absoluto */
  --bg-2:#05080F;
  --text:#E6EEF7;
  --muted:#98A7B8;
  --blue:#2D8CFF;
  --blue-2:#1B5FCC;
  --card:#070A0F;
  --stroke:#0E1622;
  --shadow:0 10px 30px rgba(0,0,0,.65);
  --radius:14px;
}

*{box-sizing:border-box}
html,body{height:100%}
html{
  scroll-snap-type:y mandatory;
}
body{
  margin:0;
  background:var(--bg);
  color:var(--text);
  font-family:'Montserrat', -apple-system, BlinkMacSystemFont, 'SF Pro Text', 'SF Pro Display', 'SF UI Text', 'Helvetica Neue', Helvetica, Arial, system-ui, Roboto, Ubuntu, Cantarell, sans-serif;
  line-height:1.6;
}
html{scroll-behavior:smooth}

img,video{max-width:100%;display:block}
a{color:var(--text);text-decoration:none}
/* Transições globais para interatividade */
a,.btn,.portfolio-card,.service-media,.feature,.card{transition:color .2s ease,background .2s ease,transform .25s ease,box-shadow .25s ease,border-color .25s ease}

.container{width:100%;max-width:1200px;margin:0 auto;padding:0}
.section{
  padding:160px 0;
  scroll-snap-align:start;
  scroll-snap-stop:always;
} /* espaçamento bem amplo entre sessões */
.section-spaced{padding-bottom:240px} /* espaçamento extra para seção de vídeos/fotos */
.section-spaced-top{padding-top:240px} /* espaçamento extra para seção de WhatsApp */
.section-compact{padding-top:80px} /* espaçamento reduzido para seção de métricas */

/* Parallax Section */
.parallax-section{position:relative;overflow:hidden}
.parallax-bg{position:absolute;top:0;left:0;width:100%;height:120%;background-image:url('../midia/fundo-sites.jpeg?v=1');background-size:cover;background-position:center;background-attachment:fixed;z-index:-1}
.parallax-video{position:absolute;top:0;left:0;width:100%;height:120%;object-fit:cover;background-attachment:fixed;z-index:-1;border-radius:0}

/* Fix for mobile devices - background-attachment:fixed doesn't work well on mobile */
@media (max-width: 768px) {
  .parallax-bg { 
    background-attachment: scroll; 
    height: 120%; 
  }
  .parallax-video {
    background-attachment: scroll;
    height: 120%;
  }
  .hero-bg-parallax {
    background-attachment: scroll;
    height: 120%;
  }
}
.parallax-content{position:relative;z-index:2;text-align:left;max-width:800px;margin:0 auto;padding:80px 40px;background:rgba(0,0,0,0.7);border-radius:20px;backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,0.2);box-shadow:0 8px 32px rgba(0,0,0,0.5);color:#fff;opacity:0;transform:translateY(30px);transition:opacity 1.2s ease-out, transform 1.2s ease-out}
.parallax-content.animate{opacity:1;transform:translateY(0)}
.parallax-content *{color:#fff !important}

/* WhatsApp Section Animations */
.whatsapp-media{opacity:0;transform:translateX(-50px);transition:opacity 1s ease-out, transform 1s ease-out}
.whatsapp-text{opacity:0;transform:translateX(50px);transition:opacity 1s ease-out, transform 1s ease-out}
.whatsapp-media.animate{opacity:1;transform:translateX(0)}
.whatsapp-text.animate{opacity:1;transform:translateX(0)}

.fullscreen{min-height:100vh;padding:0;display:flex;align-items:center}
.split{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:center;width:100%}
.contact-split{grid-template-columns:1.1fr 1.2fr;gap:24px}
.split-text .title-lg{margin:0 0 10px}
.split-media{background:linear-gradient(180deg,var(--bg-2),#080d14);border:1px solid var(--stroke);border-radius:18px;box-shadow:var(--shadow);padding:8px;aspect-ratio:16/9}
.split-media .map-embed{padding:0;background:none;border:none;box-shadow:none}
.split-media img,.split-media video{border-radius:12px;width:100%;height:100%;object-fit:cover}
.split-media .video-traffic{border-radius:12px;width:100%;height:100%;object-fit:cover;box-shadow:none}

/* Container para múltiplos cards de mídia */
.split-media-container {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 16px;
  width: 100%;
}

/* Card com fundo transparente para imagens PNG */
.split-media.transparent-bg {
  background: transparent;
  border: 2px solid var(--stroke);
  padding: 16px;
  display: flex;
  align-items: center;
  justify-content: center;
}

.split-media.transparent-bg img {
  max-width: 100%;
  max-height: 100%;
  object-fit: contain;
  border-radius: 8px;
}

/* Special styling for PNG images */
.split-media img[src$=".png"] {
  object-fit: contain;
  background: rgba(255, 255, 255, 0.05);
  padding: 20px;
}
.map-embed{width:100%;height:100%;border-radius:12px;overflow:hidden}
.map-embed iframe{width:100%;height:100%;border:none;border-radius:12px}
.center{text-align:center}

/* Header */
.site-header{position:sticky;top:0;z-index:50;background:rgba(7,10,15,.8);backdrop-filter:blur(10px);border-bottom:1px solid var(--stroke)}
.header-inner{display:flex;align-items:center;justify-content:space-between;min-height:90px;position:relative}
.logo{height:80px;flex-shrink:0}
.brand-text{display:none;font-size:18px;font-weight:700;color:var(--text);margin-left:10px}
.nav-toggle{display:none;background:none;border:1px solid var(--stroke);color:var(--text);padding:12px 16px;border-radius:10px;z-index:51;font-size:26px;min-width:60px;min-height:60px;cursor:pointer;transition:all 0.3s ease}
.nav-toggle svg{width:36px;height:36px;display:block}
.nav-toggle:hover{background:rgba(45,140,255,0.1);border-color:var(--blue)}
.nav-list{display:flex;gap:22px;list-style:none;margin:0;padding:0;align-items:center}
.nav-list a{opacity:.9;white-space:nowrap;text-align:center}
.nav-list a:hover{color:var(--blue)}
.nav-list .btn{margin-left:8px}

/* Dropdown Menu */
.dropdown{position:relative}
.dropdown-toggle{display:flex;align-items:center;gap:4px}
.dropdown-toggle::after{content:'';width:12px;height:12px;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23ffffff' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6,9 12,15 18,9'%3E%3C/polyline%3E%3C/svg%3E");background-size:contain;background-repeat:no-repeat;transition:transform 0.3s ease}
.dropdown:hover .dropdown-toggle::after,
.dropdown.open .dropdown-toggle::after{transform:rotate(180deg)}
.dropdown-menu{position:absolute;top:100%;left:0;background:var(--card);border:1px solid var(--stroke);border-radius:12px;box-shadow:0 8px 32px rgba(0,0,0,0.4);padding:8px 0;min-width:200px;opacity:0;visibility:hidden;transform:translateY(-10px);transition:all 0.3s ease;z-index:100}
.dropdown:hover .dropdown-menu{opacity:1;visibility:visible;transform:translateY(0)}
.dropdown-menu li{list-style:none;margin:0}
.dropdown-menu a{display:block;padding:12px 16px;color:var(--text);text-decoration:none;transition:all 0.2s ease;border-radius:8px;margin:0 8px}
.dropdown-menu a:hover{background:rgba(45,140,255,0.1);color:var(--blue)}

/* Grid helpers */
.grid-2{display:grid;grid-template-columns:1.2fr .8fr;gap:40px;align-items:center}
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}

/* Buttons */
.btn{display:inline-block;padding:12px 18px;border-radius:12px;border:1px solid var(--stroke);transition:.2s ease;cursor:pointer;white-space:nowrap;text-align:center}
.btn-primary{background:linear-gradient(180deg,var(--blue),var(--blue-2));border-color:transparent;color:#fff;box-shadow:0 10px 20px rgba(45,140,255,.25)}
.btn-primary:hover{filter:brightness(1.05)}
.btn-ghost{background:transparent}
.btn-ghost:hover{background:rgba(255,255,255,.06)}

/* Efeitos azuis removidos */

/* Hero */
.hero{padding:0;position:relative;overflow:hidden}

/* Hero Mobile Container */
.hero-mobile-container {
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: 100vh;
  text-align: center;
}

/* Hero Logo Mobile com Efeitos de Luz */
.hero-logo-mobile {
  display: none;
  position: relative;
  z-index: 10;
  text-align: center;
  width: 100%;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  margin: 0 auto;
  overflow: visible;
  contain: layout;
}

.logo-glow {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 300px;
  height: 300px;
  margin: 0 auto;
  filter: drop-shadow(0 0 30px rgba(45, 140, 255, 0.8));
}

.hero-logo {
  width: 300px;
  height: 300px;
  animation: logoGlow 2s ease-in-out infinite alternate;
}

.logo-particles {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: 400px;
  height: 400px;
  pointer-events: none;
}

.particle {
  position: absolute;
  width: 4px;
  height: 4px;
  background: rgba(45, 140, 255, 0.8);
  border-radius: 50%;
  animation: particleFloat 4s ease-in-out infinite;
}

.p1 { top: 20%; left: 20%; animation-delay: 0s; }
.p2 { top: 30%; right: 20%; animation-delay: 0.5s; }
.p3 { bottom: 30%; left: 30%; animation-delay: 1s; }
.p4 { bottom: 20%; right: 30%; animation-delay: 1.5s; }
.p5 { top: 50%; left: 10%; animation-delay: 2s; }
.p6 { top: 50%; right: 10%; animation-delay: 2.5s; }

@keyframes logoFloat {
  0%, 100% { transform: translateY(0px); }
  50% { transform: translateY(-10px); }
}

@keyframes logoGlow {
  0% { filter: drop-shadow(0 0 30px rgba(45, 140, 255, 0.8)); }
  100% { filter: drop-shadow(0 0 50px rgba(45, 140, 255, 1)); }
}

@keyframes particleFloat {
  0%, 100% { 
    transform: translateY(0px) scale(1);
    opacity: 0.8;
  }
  50% { 
    transform: translateY(-20px) scale(1.2);
    opacity: 1;
  }
}

/* Título Mobile */
.hero-title-mobile {
  display: none;
  font-size: 42px;
  font-weight: 800;
  color: var(--text);
  margin: 20px 0 0 0;
  text-align: center;
  text-shadow: 0 0 20px rgba(45, 140, 255, 0.5);
  animation: titleGlow 3s ease-in-out infinite alternate;
}

@keyframes titleGlow {
  0% { 
    text-shadow: 0 0 20px rgba(45, 140, 255, 0.5);
    color: var(--text);
  }
  100% { 
    text-shadow: 0 0 30px rgba(45, 140, 255, 0.8);
    color: rgba(45, 140, 255, 0.9);
  }
}

/* Vídeo Mobile - Apenas em mobile */
.video-mobile-section {
  display: none;
  padding: 0;
}

/* Vídeo de Marketing na seção de Produção Audiovisual */
.video-marketing {
  width: 100%;
  height: 100%;
  object-fit: cover;
  border-radius: 12px;
  box-shadow: 0 8px 24px rgba(0, 0, 0, 0.3);
}

/* Vídeo de Tráfego Pago */
.video-traffic {
  width: 100%;
  height: 100%;
  object-fit: cover;
  border-radius: 12px;
  box-shadow: 0 8px 24px rgba(0, 0, 0, 0.3);
}

.video-mobile-container {
  display: none;
}

.video-mobile {
  width: 100vw;
  height: auto;
  max-height: 60vh;
  object-fit: cover;
  display: block;
  margin: 0;
  padding: 0;
  position: relative;
  left: 50%;
  transform: translateX(-50%);
}
.hero-video-bg{
  position:absolute;
  top:0;
  left:0;
  width:100%;
  height:100%;
  z-index:-1;
  overflow:hidden;
  /* Garantir que o container do vídeo cubra toda a tela */
  min-width:100vw;
  min-height:100vh;
}
.hero-video-bg video{
  width:100vw;
  height:100vh;
  object-fit:cover;
  position:absolute;
  top:0;
  left:0;
  transform:none;
  /* Garantir que o vídeo cubra toda a tela */
  aspect-ratio:16/9;
  /* Melhorar a qualidade de renderização */
  image-rendering: -webkit-optimize-contrast;
  image-rendering: crisp-edges;
  /* Suporte para diferentes orientações */
  object-position: center center;
}
.hero-copy{display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;position:relative;z-index:2}
.title-xl{font-size:56px;line-height:1.15;margin:0;font-weight:800;text-align:center}
.you-text{font-family:'Montserrat', sans-serif;font-weight:700;letter-spacing:0.5px}
.text-blue{color:var(--blue)}
.subtitle-text{font-size:42px;font-weight:600;margin-top:16px;display:block}
.title-lg{font-size:42px;line-height:1.2;margin:0 0 16px;font-weight:700}
.subtitle{font-size:18px;color:var(--muted);margin:0 0 24px}
.subtitle, .subtitle-text{font-size:18px;color:var(--muted);margin:0 0 24px;word-break:normal;overflow-wrap:break-word;hyphens:auto;white-space:normal;line-height:1.6}
.hero-actions{display:grid;place-items:center}
.media-card{background:linear-gradient(180deg,var(--bg-2),#080d14);border:1px solid var(--stroke);border-radius:var(--radius);box-shadow:var(--shadow);padding:8px}
.hero-video{border-radius:12px}
/* Hero background animated */
.text-blue{color:var(--blue)}

/* Fix word breaks without affecting letter animation */
.subtitle-text, .subtitle {
  word-break: keep-all;
  overflow-wrap: normal;
  hyphens: none;
  white-space: normal;
  line-height: 1.6;
}

/* Prevent breaking of specific problematic words */
.subtitle-text .animated-chars,
.subtitle .animated-chars {
  word-break: keep-all;
  white-space: nowrap;
  display: inline-block;
}

/* CSS for word groups created by JavaScript */
.word-group {
  white-space: nowrap !important;
  display: inline-block !important;
  word-break: keep-all !important;
  margin-right: 0.3em;
}

/* Ensure proper spacing between word groups */
.word-group + .word-group {
  margin-left: 0.1em;
}

/* Fix for animated text containers */
.animated-chars {
  word-break: keep-all;
  white-space: normal;
  display: inline;
}

/* Prevent word breaking in hero section */
.hero-copy .subtitle {
  word-break: keep-all;
  overflow-wrap: normal;
  hyphens: none;
}

.hero-copy .subtitle .animated-chars {
  word-break: keep-all;
  white-space: nowrap;
  display: inline-block;
}

/* Force no word breaking for titles */
.title-xl, .subtitle-text {
  word-break: keep-all !important;
  overflow-wrap: normal !important;
  hyphens: none !important;
}

/* Specific fixes for problematic words */
.subtitle-text {
  word-break: keep-all !important;
  overflow-wrap: normal !important;
  hyphens: none !important;
  white-space: normal;
}

/* Prevent breaking of common problematic words */
.subtitle-text:before {
  content: "";
  display: inline-block;
  width: 0;
  height: 0;
}
.hero-bg{position:absolute;inset:0;overflow:hidden;pointer-events:none;z-index:-2}
.hero-bg::before,.hero-bg::after{content:"";position:absolute;border-radius:50%;filter:blur(120px);opacity:.25;animation:float 12s ease-in-out infinite}
.hero-bg::before{width:620px;height:620px;left:5%;top:20%;background:radial-gradient(circle at 30% 30%, rgba(45,140,255,.9), transparent 60%)}
.hero-bg::after{width:780px;height:780px;right:5%;bottom:8%;background:radial-gradient(circle at 70% 70%, rgba(27,95,204,.9), transparent 60%);animation-duration:16s}
.blob{position:absolute;border-radius:50%;filter:blur(100px);mix-blend-mode:screen;opacity:.25}
.b1{width:420px;height:420px;left:10%;top:10%;background:radial-gradient(circle, rgba(45,140,255,.8), transparent 60%);animation:blobMove1 10s ease-in-out infinite alternate}
.b2{width:360px;height:360px;right:15%;top:20%;background:radial-gradient(circle, rgba(27,95,204,.85), transparent 60%);animation:blobMove2 12s ease-in-out infinite alternate}
.b3{width:300px;height:300px;left:40%;bottom:15%;background:radial-gradient(circle, rgba(0,179,255,.6), transparent 60%);animation:blobMove3 14s ease-in-out infinite alternate}
@keyframes float{0%,100%{transform:translateY(0) translateX(0)}50%{transform:translateY(-18px) translateX(10px)}}
@keyframes blobMove1{0%{transform:translate(0,0)}50%{transform:translate(60px,-20px) scale(1.1)}100%{transform:translate(-30px,10px) scale(0.95)}}
@keyframes blobMove2{0%{transform:translate(0,0)}50%{transform:translate(-40px,30px) scale(1.05)}100%{transform:translate(30px,-15px) scale(0.9)}}
@keyframes blobMove3{0%{transform:translate(0,0)}50%{transform:translate(20px,40px) scale(1.08)}100%{transform:translate(-20px,-25px) scale(0.92)}}

/* Sobre */
.bullets{margin:16px 0 0 0;padding:0 0 0 18px;color:var(--muted)}
.rounded{border-radius:var(--radius)}
.shadow{box-shadow:var(--shadow)}

/* Logo na seção sobre */
.logo-sobre {
  width: 100%;
  height: auto;
  max-width: 500px;
  min-height: 300px;
  object-fit: contain;
  background: linear-gradient(180deg, var(--bg-2), #080d14);
  border: 1px solid var(--stroke);
  border-radius: 18px;
  box-shadow: var(--shadow);
  padding: 40px;
  display: block;
  margin: 0 auto;
}

/* Marketing Layout */
.marketing-layout {
  display: flex;
  flex-direction: column;
  gap: 40px;
  width: 100%;
}

.marketing-top {
  display: grid;
  grid-template-columns: 40% 60%;
  gap: 0;
  align-items: flex-start;
  min-height: 200px; /* Altura mínima fixa para evitar mudanças */
  width: 100vw;
  margin-left: calc(-50vw + 50%);
}

.marketing-text {
  display: flex;
  flex-direction: column;
  justify-content: flex-start;
  align-items: flex-start;
  position: relative;
  z-index: 10;
  padding-left: 1rem;
}

.marketing-video-center {
  display: flex;
  justify-content: center;
  align-items: center;
  width: 100%;
  z-index: 1;
  padding: 0 1.25rem;
}

.marketing-comments {
  display: flex;
  justify-content: flex-end;
  align-items: flex-start;
  position: relative;
  min-height: 300px; /* Altura mínima para acomodar notificações */
}

.marketing-image {
  width: 100%;
  display: flex;
  justify-content: center;
}

.marketing-header {
  margin-bottom: 0;
  position: relative;
  z-index: 10;
  width: 100%;
  max-width: 100%;
}

/* Imagem grande para marketing */
.split-media.large-image {
  width: 100%;
  max-width: 100%;
  aspect-ratio: 21/9;
  background: linear-gradient(180deg, var(--bg-2), #080d14);
  border: 1px solid var(--stroke);
  border-radius: 18px;
  box-shadow: var(--shadow);
  padding: 8px;
}

.split-media.large-image img {
  border-radius: 12px;
  width: 100%;
  height: 100%;
  object-fit: cover;
}

/* Notification Center */
.notification-center{
  margin-top:0;
  display:flex;
  flex-direction:column;
  gap:8px;
  align-items:flex-end;
  max-width:280px;
  min-height:200px;
  position:absolute;
  top:0;
  right:0;
  z-index:5;
}

/* Testimonials Comments */
.testimonials-comments {
  display: flex;
  justify-content: center;
  align-items: center;
  min-height: 400px;
  position: relative;
}

.testimonials-notification-center {
  display: flex;
  flex-direction: column;
  gap: 12px;
  align-items: center;
  max-width: 600px;
  min-height: 300px;
  position: relative;
}
.note{
  min-height:92px;
  height:auto;
  animation:noteIn 0.75s ease forwards;
}
.note__inner{
  animation:noteInnerIn 0.75s ease forwards;
  background:linear-gradient(135deg,var(--card),#0A0F1A);
  border:1px solid var(--stroke);
  border-radius:16px;
  box-shadow:0 8px 32px rgba(0,0,0,0.4);
  display:grid;
  grid-template-columns:60px 1fr;
  gap:16px;
  padding:16px;
  padding-right:32px;
  width:100%;
  max-width:320px;
  transform-origin:50% 100%;
  transition:all 0.3s ease;
}
.note__inner:hover{
  transform:translateY(-2px);
  box-shadow:0 12px 40px rgba(45,140,255,0.15);
  border-color:var(--blue);
}
.note__content{
  display:flex;
  flex-direction:column;
  justify-content:center;
  min-width:0;
}
.note__title{
  font-size:14px;
  font-weight:600;
  color:var(--text);
  margin:0 0 4px 0;
}
.note__message{
  font-size:12px;
  color:var(--muted);
  white-space:normal;
  overflow:visible;
  line-height:1.3;
  margin:0;
  word-wrap:break-word;
}
.avatar{
  aspect-ratio:1;
  background:transparent;
  border-radius:50%;
  font-size:20px;
  line-height:1;
  display:grid;
  place-items:center;
  text-align:center;
  width:100%;
  box-shadow:none;
}
.note--out{
  animation:noteShrink 0.75s ease forwards;
}
.note--out .note__inner{
  animation:noteOut 0.75s ease forwards;
  transform-origin:50% 50%;
}
@keyframes noteIn{
  from{
    filter:blur(10px);
    opacity:0;
    transform:scale(0.8);
  }
  to{
    filter:blur(0);
    opacity:1;
    transform:scale(1);
  }
}
@keyframes noteInnerIn{
  from{
    filter:blur(10px);
    opacity:0;
    transform:scale(0.8);
  }
  to{
    filter:blur(0);
    opacity:1;
    transform:scale(1);
  }
}
@keyframes noteOut{
  from{
    filter:blur(0);
    opacity:1;
    transform:translateY(0) scale(1);
  }
  to{
    filter:blur(10px);
    opacity:0;
    transform:translateY(-100%) scale(1.1);
  }
}
@keyframes noteShrink{
  from{
    min-height:92px;
    height:auto;
  }
  to{
    min-height:0;
    height:0;
  }
}

/* Cards Serviços */
/* Serviços (sessões explicativas) */
.services-category{margin-top:40px;padding:28px 0;border-top:1px solid var(--stroke)}
.services-category + .services-category{margin-top:6rem}
.category-head{margin-bottom:28px}
.category-head h3{margin:0;font-size:32px}
.category-head .muted{display:none}
.service-row{display:grid;grid-template-columns:1.1fr .9fr;gap:40px;align-items:center;margin-top:32px}
.service-row + .service-row{margin-top:80px}
.service-row.alt{grid-template-columns:.9fr 1.1fr}
.service-text h3{margin:0 0 8px;font-size:24px}
.service-text h4{margin:0 0 8px;font-size:20px}
.service-text p{margin:0 0 10px;color:var(--muted)}
.service-text .bullets{margin-top:8px}
.service-media{overflow:hidden}
.service-media img,.service-media video{width:100%;height:100%;object-fit:cover;border-radius:12px}
.service-media:hover{box-shadow:0 0 0 1px rgba(45,140,255,.4),0 18px 50px rgba(45,140,255,.2)}
/* Serviço lista (texto) */
.service-list{display:grid;gap:16px;margin-top:18px}
.service-item{padding:16px;border-radius:12px;border:1px solid var(--stroke);background:var(--card)}
.service-item h3{margin:0 0 6px}

/* Chips (modelo estilo cartões compactos) */
.chip-list{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:14px;margin-top:18px}
.chip{display:flex;align-items:center;gap:10px;padding:14px 16px;background:var(--card);border:1px solid var(--stroke);border-radius:14px}
.chip .icon{font-size:18px}
.chip:hover{border-color:rgba(45,140,255,.5);box-shadow:0 10px 30px rgba(45,140,255,.18)}

/* Métricas / Contadores */
.stats-section{padding-top:120px}
.stats{display:grid;grid-template-columns:repeat(2,1fr);gap:24px;margin-top:24px}
.mini-stats{display:flex;gap:18px;margin-top:16px}
.mini-stat{background:var(--card);border:1px solid var(--stroke);border-radius:12px;padding:10px 14px}
.mini-label{display:block;color:var(--muted);font-size:12px}
.mini-value{font-weight:800;font-size:20px;color:var(--blue);text-shadow:0 0 10px rgba(45,140,255,.35)}
.mini-value.danger{color:#ff6b6b}
.stat-card{background:var(--card);border:1px solid var(--stroke);border-radius:16px;padding:28px;text-align:center}
.stat-value{font-size:44px;font-weight:800;letter-spacing:1px;color:var(--blue);text-shadow:0 0 14px rgba(45,140,255,.35)}
.stat-label{color:var(--muted);margin-top:6px}

/* Portfolio */
/* Portfolio: estilo carrossel tipo Netflix */
.portfolio-row{position:relative;margin-top:16px}
.portfolio-track{display:flex;gap:14px;overflow-x:auto;scroll-snap-type:x mandatory;padding:8px 0;scroll-behavior:smooth}
.portfolio-track::-webkit-scrollbar{height:8px}
.portfolio-track::-webkit-scrollbar-thumb{background:#0e1622;border-radius:8px}
.portfolio-card{flex:0 0 auto;width:280px;scroll-snap-align:start;background:var(--card);border:1px solid var(--stroke);border-radius:12px;overflow:hidden;position:relative;transition:transform .25s ease, box-shadow .25s ease}
.portfolio-card:hover{transform:translateY(-4px);box-shadow:0 18px 40px rgba(0,0,0,.35)}
.portfolio-card .thumb{position:relative;height:160px;overflow:hidden}
.portfolio-card img,.portfolio-card video{width:100%;height:100%;object-fit:cover;transition:transform .4s ease,filter .4s ease}
.portfolio-card:hover img,.portfolio-card:hover video{transform:scale(1.06);filter:saturate(1.2)}
.portfolio-card .meta{padding:12px}
.portfolio-card .meta h4{margin:0;font-size:15px}
.carousel-btn{position:absolute;top:50%;transform:translateY(-50%);background:rgba(0,0,0,.5);border:1px solid var(--stroke);color:var(--text);width:40px;height:40px;border-radius:50%;display:grid;place-items:center;cursor:pointer;z-index:2}
.carousel-btn:hover{background:rgba(0,0,0,.65)}
.carousel-btn.prev{left:-6px}
.carousel-btn.next{right:-6px}
.edge-fade{position:absolute;top:0;bottom:0;width:60px;z-index:1;pointer-events:none}
.edge-fade.left{left:0;background:linear-gradient(90deg,var(--bg),transparent)}
.edge-fade.right{right:0;background:linear-gradient(270deg,var(--bg),transparent)}

/* Resultados */
.features{gap:18px}
.feature{background:var(--card);border:1px solid var(--stroke);border-radius:var(--radius);padding:18px}
.feature h3{margin:0 0 6px}
.feature p{margin:0;color:var(--muted)}

/* Depoimentos */
.testimonials{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;margin-top:18px}
.testimonial p{color:var(--muted)}
.testimonial h4{margin:10px 0 0}
.testimonial span{color:var(--muted);font-weight:400}

/* Contato */
.contact-form{display:grid;gap:12px;background:var(--card);border:1px solid var(--stroke);border-radius:var(--radius);padding:22px}
.contact-form label{display:grid;gap:6px}
.contact-form input,.contact-form textarea{background:#0B1220;border:1px solid var(--stroke);border-radius:10px;padding:12px;color:var(--text)}
.contact-form input:focus,.contact-form textarea:focus{outline:2px solid rgba(45,140,255,.5)}
.form-feedback{min-height:20px;color:var(--muted);margin:6px 0 0}
.social{list-style:none;display:flex;gap:12px;padding:0;margin:16px 0 0}
.map-placeholder{padding-top:24px}
.map-box{height:auto;border-radius:12px;border:1px dashed var(--stroke);display:flex;align-items:center;justify-content:center;color:var(--muted);overflow:hidden}

/* Loader */
#loader{position:fixed;inset:0;background:linear-gradient(135deg, #070B10 0%, #0A0F1A 100%);display:flex;align-items:center;justify-content:center;z-index:9999;transition:opacity .8s ease, visibility .8s ease}
#loader.hidden{opacity:0;visibility:hidden}
.loader{position:relative;width:300px;height:300px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:40px}
.loader-logo{position:absolute;top:50%;left:50%;transform:translate(-50%, -50%);z-index:10;animation:logoFloat 3s ease-in-out infinite}
.loader-img{width:100px;height:100px;filter:drop-shadow(0 0 30px rgba(45,140,255,0.8));transition:all 0.3s ease}
.loader-rings{position:absolute;top:50%;left:50%;transform:translate(-50%, -50%);width:240px;height:240px}
.ring{position:absolute;border-radius:50%;border:2px solid transparent;animation:spin 3s linear infinite}
.ring1{inset:0;border-top:3px solid var(--blue);border-right:3px solid rgba(45,140,255,0.3);animation-duration:2s;animation-timing-function:cubic-bezier(0.4, 0, 0.6, 1)}
.ring2{inset:30px;border-top:2px solid rgba(45,140,255,0.8);border-right:2px solid rgba(45,140,255,0.2);animation-duration:2.5s;animation-timing-function:cubic-bezier(0.4, 0, 0.6, 1);animation-direction:reverse}
.ring3{inset:60px;border-top:2px solid rgba(45,140,255,0.6);border-left:2px solid rgba(45,140,255,0.1);animation-duration:3s;animation-timing-function:cubic-bezier(0.4, 0, 0.6, 1)}
.loader-text{position:absolute;top:calc(50% + 80px);left:50%;transform:translateX(-50%);display:flex;flex-direction:column;align-items:center;gap:20px;z-index:10}
.brand-text{color:#fff;font-weight:800;font-size:28px;letter-spacing:3px;text-shadow:0 0 30px rgba(45,140,255,0.7);animation:textGlow 2s ease-in-out infinite alternate}
.loading-dots{display:flex;gap:10px;margin-top:10px}
.loading-dots span{width:10px;height:10px;background:linear-gradient(45deg, var(--blue), #00B3FF);border-radius:50%;animation:loading-dots 1.6s ease-in-out infinite both;box-shadow:0 0 15px rgba(45,140,255,0.5)}
.loading-dots span:nth-child(1){animation-delay:-0.4s}
.loading-dots span:nth-child(2){animation-delay:-0.2s}
.loading-dots span:nth-child(3){animation-delay:0s}
@keyframes spin{0%{transform:rotate(0deg)}100%{transform:rotate(360deg)}}
@keyframes loading-dots{0%,80%,100%{transform:scale(0.6);opacity:0.3}40%{transform:scale(1.3);opacity:1}}
@keyframes logoFloat{0%,100%{transform:translate(-50%, -50%) translateY(0px)}50%{transform:translate(-50%, -50%) translateY(-10px)}}
@keyframes textGlow{0%{text-shadow:0 0 30px rgba(45,140,255,0.7)}100%{text-shadow:0 0 40px rgba(45,140,255,1), 0 0 60px rgba(45,140,255,0.3)}}

/* Footer */
.site-footer{
  border-top:1px solid var(--stroke);
  padding:40px 0;
  background:#070B10;
  scroll-snap-align:start;
  scroll-snap-stop:always;
}
.footer-inner{display:flex;justify-content:space-between;align-items:flex-start;gap:40px}
.footer-left{display:flex;flex-direction:column;align-items:flex-start;gap:16px}
.footer-logo{height:80px;width:auto}
.cnpj{color:var(--muted);font-size:14px;margin:0}
.footer-right{display:flex;flex-direction:column;gap:24px;flex:1;max-width:600px}
.footer-links{display:grid;grid-template-columns:repeat(3,1fr);gap:32px}
.footer-column{display:flex;flex-direction:column;gap:12px}
.footer-column h4{color:var(--text);font-size:16px;font-weight:600;margin:0 0 8px}
.footer-column a{color:var(--muted);text-decoration:none;font-size:14px;transition:color 0.3s ease}
.footer-column a:hover{color:var(--blue)}
.footer-bottom{border-top:1px solid var(--stroke);padding-top:20px;text-align:center}
.footer-bottom p{color:var(--muted);font-size:14px;margin:0}

/* Device Animation */
.device {
  position: relative;
  width: 1.8em;
  height: 1.8em;
  display: inline-block;
  margin-left: 10px;
}

.responsive-text {
  font-size: 0.5em;
  font-weight: 400;
  color: var(--muted);
  margin-left: 8px;
  vertical-align: middle;
}

/* Sites Section Layout */
.sites-layout {
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  gap: 24px;
  max-width: 800px;
  margin: 0 auto;
}

.sites-header {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 20px;
  margin-bottom: 0;
}

.sites-title {
  margin: 0;
  text-align: center;
  flex-shrink: 0;
}

.sites-device {
  margin: 0;
  display: inline-block;
  flex-shrink: 0;
}

.sites-text {
  text-align: center;
  margin: 0;
  max-width: 100%;
}

.device__a,
.device__a-1,
.device__a-2,
.device__b,
.device__c,
.device__d,
.device__e,
.device__f,
.device__g {
  animation: device-a 3s cubic-bezier(0.65,0,0.35,1) infinite;
  position: absolute;
  transition: background-color 0.3s ease, box-shadow 0.3s ease;
}

.device__a,
.device__d,
.device__e {
  background-color: hsl(223,10%,70%);
  box-shadow: 0 0 0 0.25em inset;
}

.device__a {
  border-radius: 0.375em;
  top: 0;
  width: 4em;
  height: 2.5em;
  z-index: 1;
}

.device__a-1,
.device__a-2 {
  visibility: hidden;
}

.device__a-1 {
  animation-name: device-a-1;
  top: 2.25em;
  left: 1.5em;
  width: 1em;
  height: 0.25em;
}

.device__a-2 {
  animation-name: device-a-2;
  top: 0.625em;
  right: 0;
  width: 0.25em;
  height: 0.75em;
}

.device__a-1,
.device__a-2,
.device__b,
.device__c,
.device__f,
.device__g {
  background-color: var(--text);
  border-radius: 0.125em;
}

.device__b {
  animation-name: device-b;
  top: 2.25em;
  left: 1.875em;
  width: 0.25em;
  height: 1em;
}

.device__c {
  animation-name: device-c;
  top: 3em;
  left: 1em;
  width: 2em;
  height: 0.25em;
}

.device__d,
.device__e {
  left: 1.25em;
  width: 1.5em;
  height: 0.875em;
  visibility: hidden;
}

.device__d {
  animation-name: device-d;
  border-radius: 0.375em 0.375em 0 0;
  top: 0.75em;
}

.device__e {
  animation-name: device-e;
  border-radius: 0 0 0.375em 0.375em;
  top: 1.625em;
}

.device__f,
.device__g {
  filter: blur(0.375em);
  bottom: 0;
  height: 0.25em;
}

.device__f {
  animation-name: device-f;
  opacity: 0.5;
  left: 1em;
  width: 2em;
}

.device__g {
  animation-name: device-g;
  opacity: 0;
  left: 0;
  width: 4em;
}

/* Dark theme for device */
@media (prefers-color-scheme: dark) {
  .device__a,
  .device__d,
  .device__e {
    background-color: hsl(223,10%,30%);
  }
}

/* Device Animations */
@keyframes device-a {
  from, to {
    animation-timing-function: cubic-bezier(0.33,0,0.67,0);
    left: 0;
    width: 4em;
    height: 2.5em;
    transform: translateY(0);
  }
  12.5% {
    animation-timing-function: cubic-bezier(0.33,1,0.67,1);
    left: 0;
    width: 4em;
    height: 2.5em;
    transform: translateY(1.5em);
  }
  25% {
    animation-timing-function: cubic-bezier(0.33,0,0.67,0);
    left: 0;
    width: 4em;
    height: 2.5em;
    transform: translateY(0.375em);
  }
  37.5% {
    animation-timing-function: cubic-bezier(0.33,1,0.67,1);
    left: 0;
    width: 4em;
    height: 2.5em;
    transform: translateY(1.5em);
  }
  50% {
    animation-timing-function: cubic-bezier(0.33,0,0.67,0);
    left: 1em;
    width: 2em;
    height: 3em;
    transform: translateY(0.125em);
  }
  62.5% {
    animation-timing-function: cubic-bezier(0.33,1,0.67,1);
    left: 1em;
    width: 2em;
    height: 3em;
    transform: translateY(1em);
  }
  75% {
    animation-timing-function: cubic-bezier(0.33,0,0.67,0);
    left: 1em;
    width: 2em;
    height: 2em;
    transform: translateY(0.625em);
  }
  87.5% {
    animation-timing-function: cubic-bezier(0.33,1,0.67,1);
    left: 1em;
    width: 2em;
    height: 2em;
    transform: translateY(1.375em);
  }
}

@keyframes device-a-1 {
  from {
    animation-timing-function: steps(1,end);
    left: 1.5em;
    width: 1em;
    transform: translateY(0);
    visibility: hidden;
  }
  12.5% {
    animation-timing-function: cubic-bezier(0.33,1,0.67,1);
    left: 1.5em;
    width: 1em;
    transform: translateY(0);
    visibility: visible;
  }
  25%, 37.5% {
    animation-timing-function: cubic-bezier(0.33,1,0.67,1);
    left: 1.5em;
    width: 1em;
    transform: translateY(-0.5em);
    visibility: visible;
  }
  50%, 62.5% {
    animation-timing-function: cubic-bezier(0.33,1,0.67,1);
    left: 0.875em;
    width: 0.25em;
    transform: translateY(0);
    visibility: visible;
  }
  75%, to {
    animation-timing-function: cubic-bezier(0.33,1,0.67,1);
    left: 0.875em;
    width: 0.25em;
    transform: translateY(-0.5em);
    visibility: hidden;
  }
}

@keyframes device-a-2 {
  from {
    animation-timing-function: steps(1,end);
    transform: translate(0,0.375em);
    visibility: hidden;
  }
  62.5% {
    animation-timing-function: cubic-bezier(0.33,1,0.67,1);
    transform: translate(0,0.375em);
    visibility: visible;
  }
  75%, 87.5% {
    animation-timing-function: cubic-bezier(0.33,1,0.67,1);
    transform: translate(0.375em,0);
    visibility: visible;
  }
  to {
    transform: translate(0,0.25em);
    visibility: visible;
  }
}

@keyframes device-b {
  from, to {
    animation-timing-function: cubic-bezier(0.33,0,0.67,0);
    transform: translateY(0);
    visibility: visible;
  }
  10%, 12.5% {
    animation-timing-function: steps(1,start);
    transform: translateY(0.75em);
    visibility: visible;
  }
  25% {
    animation-timing-function: steps(1,start);
    top: 2.25em;
    left: 1.875em;
    transform: translateY(0.75em);
    visibility: hidden;
  }
  87.5% {
    animation-timing-function: cubic-bezier(0.33,1,0.67,1);
    transform: translateY(0.75em);
    visibility: hidden;
  }
}

@keyframes device-c {
  from, to {
    animation-timing-function: cubic-bezier(0.33,0,0.67,0);
    transform: translateY(0);
    visibility: visible;
    width: 2em;
  }
  10%, 12.5% {
    animation-timing-function: steps(1,start);
    transform: translateY(0.75em);
    visibility: visible;
    width: 2em;
  }
  25% {
    animation-timing-function: steps(1,start);
    top: 3em;
    left: 1em;
    width: 2em;
    transform: translateY(0.75em);
    visibility: hidden;
  }
  87.5% {
    animation-timing-function: cubic-bezier(0.33,1,0.67,1);
    left: 1.5em;
    transform: translateY(0.75em);
    visibility: hidden;
    width: 1em;
  }
}

@keyframes device-d {
  from {
    animation-timing-function: steps(1,end);
    transform: translateY(0.25em);
    visibility: hidden;
  }
  62.5% {
    animation-timing-function: cubic-bezier(0.33,1,0.67,1);
    transform: translateY(0.25em);
    visibility: visible;
  }
  75% {
    animation-timing-function: cubic-bezier(0.33,0,0.67,0);
    transform: translateY(-0.75em);
  }
  87.5% {
    animation-timing-function: cubic-bezier(0.33,1,0.67,1);
    transform: translateY(0);
  }
  to {
    transform: translateY(-0.75em);
  }
}

@keyframes device-e {
  from {
    animation-timing-function: steps(1,end);
    transform: translateY(1.5em);
    visibility: hidden;
  }
  62.5% {
    animation-timing-function: cubic-bezier(0.33,1,0.67,1);
    transform: translateY(1.5em);
    visibility: visible;
  }
  75% {
    animation-timing-function: cubic-bezier(0.33,0,0.67,0);
    transform: translateY(0.75em);
  }
  87.5% {
    animation-timing-function: cubic-bezier(0.33,1,0.67,1);
    transform: translateY(1.5em);
  }
  to {
    transform: translateY(0);
  }
}

@keyframes device-f {
  from, 50% {
    animation-timing-function: cubic-bezier(0.33,0,0.67,0);
    filter: blur(0.375em);
    opacity: 0;
  }
  62.5% {
    animation-timing-function: cubic-bezier(0.33,1,0.67,1);
    filter: blur(0.1875em);
    opacity: 0.5;
  }
  75%, to {
    filter: blur(0.375em);
    opacity: 0;
  }
}

@keyframes device-g {
  from, 50% {
    animation-timing-function: cubic-bezier(0.33,1,0.67,1);
    background-color: var(--text);
    filter: blur(0.1875em);
    opacity: 0;
  }
  62.5% {
    animation-timing-function: cubic-bezier(0.33,0,0.67,0);
    background-color: var(--text);
    filter: blur(0.375em);
    opacity: 0.5;
  }
  75% {
    animation-timing-function: cubic-bezier(0.33,1,0.67,1);
    filter: blur(0.1875em);
    opacity: 0.5;
    left: 0;
    width: 4em;
  }
  87.5%, to {
    animation-timing-function: cubic-bezier(0.33,0,0.67,0);
    filter: blur(0.375em);
    opacity: 0.5;
    left: 1em;
    width: 2em;
  }
  62.5%, 87.5% {
    animation-timing-function: cubic-bezier(0.33,1,0.67,1);
    filter: blur(0.1875em);
    opacity: 0.5;
    left: 1em;
    width: 2em;
  }
}

/* WhatsApp Float Button */
.whatsapp-float {
  position: fixed;
  bottom: 30px;
  right: 30px;
  width: 60px;
  height: 60px;
  background-color: #25D366;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  box-shadow: 0 4px 12px rgba(37, 211, 102, 0.4);
  z-index: 1000;
  transition: all 0.3s ease;
  animation: pulse 2s infinite;
}

/* Scroll to Top Arrow */
.scroll-to-top {
  position: fixed;
  bottom: 30px;
  left: 30px;
  width: 50px;
  height: 50px;
  background-color: var(--blue);
  border: none;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  box-shadow: 0 4px 12px rgba(45, 140, 255, 0.4);
  z-index: 1000;
  transition: all 0.3s ease;
  cursor: pointer;
  opacity: 0;
  visibility: hidden;
  transform: translateY(20px);
}

.scroll-to-top.visible {
  opacity: 1;
  visibility: visible;
  transform: translateY(0);
}

.scroll-to-top:hover {
  background-color: var(--blue-2);
  transform: translateY(-2px);
  box-shadow: 0 6px 20px rgba(45, 140, 255, 0.6);
}

.scroll-to-top svg {
  width: 24px;
  height: 24px;
  color: white;
  transition: transform 0.3s ease;
}

.scroll-to-top:hover svg {
  transform: translateY(-2px);
}

.whatsapp-float:hover {
  background-color: #128C7E;
  transform: scale(1.1);
  box-shadow: 0 6px 20px rgba(37, 211, 102, 0.6);
}

.whatsapp-float svg {
  width: 32px;
  height: 32px;
  color: white;
}

@keyframes pulse {
  0% {
    box-shadow: 0 0 0 0 rgba(37, 211, 102, 0.7);
  }
  70% {
    box-shadow: 0 0 0 10px rgba(37, 211, 102, 0);
  }
  100% {
    box-shadow: 0 0 0 0 rgba(37, 211, 102, 0);
  }
}


/* Vídeo responsivo para diferentes tamanhos de tela */
@media (max-width: 1200px) {
  .hero-video-bg video {
    object-fit: cover;
    width: 100vw;
    height: 100vh;
    top: 0;
    left: 0;
    transform: none;
    object-position: center center;
  }
}

/* Ajuste para tablets */
@media (max-width: 1024px) {
  .hero-video-bg video {
    object-fit: cover;
    width: 100vw;
    height: 100vh;
    top: 0;
    left: 0;
    transform: none;
    object-position: center center;
  }
}

@media (min-width: 769px) {
  /* Esconder container mobile no desktop */
  .hero-mobile-container {
    display: none !important;
  }
  
  /* Esconder ícone com partículas no desktop */
  .hero-logo-mobile {
    display: none !important;
  }
  
  /* Ajustar vídeos para ocuparem todo container no desktop */
  .video-marketing {
    height: 100%;
    max-height: none;
  }
  
  .video-traffic {
    height: 100%;
    max-height: none;
  }
  
  /* Ajustar Google Maps para ocupar todo container no desktop */
  .map-embed {
    height: 100%;
  }
}

@media (max-width: 768px) {
  /* Ocultar vídeo do hero section em mobile */
  .hero-video-bg {
    display: none;
  }
  
  /* Mostrar logo da Conecta com efeitos de luz */
  .hero-logo-mobile {
    display: block;
  }
  
  /* Mostrar título mobile */
  .hero-title-mobile {
    display: block;
  }
  
  /* Mostrar vídeo mobile abaixo da seção Sobre */
  .video-mobile-section {
    display: block;
  }
  
  /* Ajustar tamanho do logo em mobile */
  .hero-logo {
    width: 260px;
    height: 260px;
  }
  
  .logo-glow {
    width: 260px;
    height: 260px;
  }
  
  .logo-particles {
    width: 360px;
    height: 360px;
  }
}

@media (max-width: 480px) {
  /* Ajustar tamanho do logo em telas pequenas */
  .hero-logo {
    width: 220px;
    height: 220px;
  }
  
  .logo-glow {
    width: 220px;
    height: 220px;
  }
  
  .logo-particles {
    width: 300px;
    height: 300px;
  }
  
  /* Ajustar título mobile */
  .hero-title-mobile {
    font-size: 36px;
    margin: 15px 0 0 0;
  }
  
  /* Ajustar vídeo mobile */
  .video-mobile {
    max-height: 50vh;
  }
  
  .video-mobile-section {
    padding: 0;
  }
}


/* Fallback para dispositivos que não suportam vídeo */
@media (max-width: 320px) {
  .hero-video-bg {
    background: linear-gradient(135deg, #070B10 0%, #0A0F1A 100%);
  }
  
  .hero-video-bg video {
    display: none;
  }
}

/* Orientação landscape em dispositivos móveis */
@media (max-width: 768px) and (orientation: landscape) {
  .hero-video-bg video {
    object-fit: cover;
    width: 100vw;
    height: 100vh;
    top: 0;
    left: 0;
    transform: none;
    /* Otimizar para landscape */
    object-position: center center;
  }
}

/* Suporte para telas ultrawide */
@media (min-width: 1920px) {
  .hero-video-bg video {
    object-fit: cover;
    width: 100vw;
    height: 100vh;
    top: 0;
    left: 0;
    transform: none;
  }
  
  /* Ajustar vídeos para telas grandes */
  .video-marketing {
    height: 100%;
    max-height: none;
  }
  
  .video-traffic {
    height: 100%;
    max-height: none;
  }
  
  .map-embed {
    height: 100%;
  }
}

/* Responsive WhatsApp Button */
@media (max-width: 720px) {
  .whatsapp-float {
    width: 56px;
    height: 56px;
    bottom: 20px;
    right: 20px;
  }
  
  .whatsapp-float svg {
    width: 28px;
    height: 28px;
  }

  .scroll-to-top {
    width: 45px;
    height: 45px;
    bottom: 20px;
    left: 20px;
  }
  
  .scroll-to-top svg {
    width: 20px;
    height: 20px;
  }

  .visual-production-content {
    padding: 20px;
    margin: 20px;
  }

  .gallery-images {
    flex-direction: column;
    gap: 10px;
    padding: 20px;
  }
}

@media (max-width: 420px) {
  .whatsapp-float {
    width: 50px;
    height: 50px;
    bottom: 15px;
    right: 15px;
  }
  
  .whatsapp-float svg {
    width: 24px;
    height: 24px;
  }
}

/* Scroll reveal */
.reveal{opacity:0;transform:translateY(30px);transition:opacity .8s ease,transform .8s ease;will-change:opacity,transform}
.reveal.visible{opacity:1;transform:translateY(0)}
.delay-1{transition-delay:.2s}
.delay-2{transition-delay:.4s}
.delay-3{transition-delay:.6s}

/* Preload prevention - hide animations until page is fully loaded */
.preload * {
  animation-duration: 0s !important;
  animation-delay: 0s !important;
  transition-duration: 0s !important;
  transition-delay: 0s !important;
}

/* Responsive */
@media (max-width: 1024px){
  .grid-2{grid-template-columns:1fr}
  .split{grid-template-columns:1fr}
  .contact-split{grid-template-columns:1fr}
  .marketing-top{grid-template-columns:1fr;gap:24px;min-height:300px}
  .marketing-comments{justify-content:center;min-height:300px}
  .notification-center{position:relative;min-height:300px;align-items:center}
  .marketing-video-center{order:2}
  .marketing-text{order:1}
  .marketing-comments{order:3}
  .split-media-container{grid-template-columns:1fr;gap:12px}
  .split-media img,.split-media video{height:100%}
  .map-embed{height:30vh}
  .cards{grid-template-columns:repeat(3,1fr)}
  .testimonials{grid-template-columns:repeat(2,1fr)}
  .stats{grid-template-columns:repeat(2,1fr)}
  .logo-sobre{max-width:400px;min-height:250px;padding:30px}
  .parallax-content{padding:60px 30px}
}
@media (max-width: 720px){
  .title-xl{font-size:38px;text-align:center;line-height:1.2;margin-bottom:14px}
  .subtitle-text{font-size:28px;text-align:center;margin-top:24px;line-height:1.35;word-break:keep-all;overflow-wrap:normal;hyphens:none;white-space:normal}
  .hero{padding-top:40px}
  .hero-copy{padding:0 22px}
  .title-lg{font-size:32px}
  .nav-toggle{display:block;font-size:24px;min-width:55px;min-height:55px;padding:10px 14px}
  .nav-toggle svg{width:32px;height:32px}
  .nav-list{position:absolute;right:16px;top:100%;background:#0B1220;border:1px solid var(--stroke);border-radius:12px;padding:12px 14px;flex-direction:column;gap:12px;display:flex;min-width:160px;z-index:52;opacity:0;pointer-events:none;transform:translateY(-20px) scale(0.95);transition:opacity 0.4s ease, transform 0.4s ease, visibility 0.4s ease;visibility:hidden}
  .nav-list.open{opacity:1;pointer-events:auto;transform:translateY(0) scale(1);visibility:visible}
  .dropdown-menu{position:static;opacity:0;visibility:hidden;transform:none;box-shadow:none;border:none;background:transparent;padding:8px 0 0 16px;min-width:auto;max-height:0;overflow:hidden;transition:opacity 0.3s ease, max-height 0.3s ease}
  .dropdown.open .dropdown-menu{opacity:1;visibility:visible;max-height:200px}
  .dropdown-menu a{padding:8px 0;margin:0;border-radius:0;border-bottom:1px solid rgba(255,255,255,0.1)}
  .dropdown-menu a:last-child{border-bottom:none}
  .cards{grid-template-columns:repeat(2,1fr)}
  .stats{grid-template-columns:1fr}
  .logo{height:70px;display:none}
  .brand-text{display:inline-block;font-size:16px}
  .header-inner{min-height:80px}
  .logo-sobre{display:none}
  .stats-section{display:none}
  .parallax-content{padding:40px 20px}
  
  /* Sites section mobile adjustments */
  .sites-layout {
    gap: 20px;
    padding: 0 20px;
  }
  
  .sites-header {
    gap: 15px;
    flex-wrap: wrap;
    justify-content: center;
  }
  
  .sites-title {
    font-size: 36px;
  }
  
  .sites-device {
    transform: scale(0.8);
  }
  
  .sites-text {
    font-size: 16px;
    line-height: 1.5;
  }
  
  /* Fix word breaking on mobile */
  .hero-copy .subtitle {
    word-break: keep-all !important;
    overflow-wrap: normal !important;
    hyphens: none !important;
    white-space: normal;
  }
  
  .hero-copy .subtitle .animated-chars {
    word-break: keep-all !important;
    white-space: nowrap !important;
    display: inline-block !important;
  }
  
  .word-group {
    white-space: nowrap !important;
    display: inline-block !important;
    word-break: keep-all !important;
    overflow-wrap: normal !important;
    margin-right: 0.2em;
  }
  
  /* Force no breaking for titles on mobile */
  .title-xl, .subtitle-text {
    word-break: keep-all !important;
    overflow-wrap: normal !important;
    hyphens: none !important;
  }
  
  /* Specific fix for subtitle text */
  .subtitle-text {
    word-break: keep-all !important;
    overflow-wrap: normal !important;
    hyphens: none !important;
  }
  
  /* Footer mobile adjustments */
  .footer-inner{flex-direction:column;align-items:center;text-align:center;gap:32px}
  .footer-left{align-items:center;text-align:center}
  .footer-right{width:100%;max-width:100%;text-align:center}
  .footer-links{grid-template-columns:repeat(2,1fr);gap:32px;justify-items:center}
  .footer-column{align-items:center;text-align:center}
  .footer-bottom{text-align:center}
}
/* Media query duplicada removida - já está acima */

@media (max-width: 768px){
  .section{padding:60px 0}
  .section-spaced{padding:60px 0}
  .section-spaced-top{padding:60px 0}
  .section-compact{padding:60px 0}
  
  /* Padronizar padding dos textos */
  .split-text{padding:0 20px}
  .contact-copy{padding:0 20px}
  .testimonials-comments{padding:0 20px}
  .grid-2 .reveal{padding:0 20px}
}

@media (max-width: 420px){
  .section{padding:60px 0}
  .section-spaced{padding:60px 0}
  .section-spaced-top{padding:60px 0}
  .section-compact{padding:60px 0}
  
  /* Padronizar padding dos textos */
  .split-text{padding:0 15px}
  .contact-copy{padding:0 15px}
  .testimonials-comments{padding:0 15px}
  .grid-2 .reveal{padding:0 15px}
  
  .title-xl{font-size:30px;line-height:1.15;text-align:center;margin-bottom:12px}
  .subtitle-text{font-size:22px;text-align:center;margin-top:28px;line-height:1.4;word-break:keep-all;overflow-wrap:normal;hyphens:none;white-space:normal}
  .hero{padding-top:36px}
  .hero .container{text-align:center}
  .hero-copy{text-align:center;padding:0 20px}
  .hero-copy h1{text-align:center}
  .hero-copy .subtitle{text-align:center;font-size:16px;line-height:1.5;padding:0 12px;word-break:keep-all;overflow-wrap:normal;hyphens:none}
  .hero-copy .subtitle .animated-chars{word-break:keep-all;white-space:nowrap;display:inline-block}
  .cards{grid-template-columns:1fr}
  .device{width:1.6em;height:1.6em;margin-left:0}
  .responsive-text{font-size:0.5em;margin-left:6px}
  .nav-toggle{font-size:20px;min-width:50px;min-height:50px;padding:8px 12px}
  .nav-toggle svg{width:28px;height:28px}
  .responsive-column .responsive-text{font-size:0.5em}
  .sites-title-container{gap:6px;display:flex;align-items:center}
  .nav-list{min-width:180px;padding:14px 18px;gap:14px}
  .dropdown-menu{padding:10px 0 0 18px}
  .dropdown-menu a{padding:8px 0;font-size:13px}
  .parallax-content{padding:30px 15px}
  
  /* Sites section small screen adjustments */
  .sites-layout {
    gap: 16px;
    padding: 0 15px;
  }
  
  .sites-header {
    gap: 12px;
    flex-wrap: wrap;
    justify-content: center;
  }
  
  .sites-title {
    font-size: 32px;
  }
  
  .sites-device {
    transform: scale(0.6);
  }
  
  .sites-text {
    font-size: 14px;
    line-height: 1.4;
  }
  
  /* Enhanced word breaking prevention for small screens */
  .word-group {
    white-space: nowrap !important;
    display: inline-block !important;
    word-break: keep-all !important;
    overflow-wrap: normal !important;
    margin-right: 0.1em;
  }
  
  /* Force no breaking for all text elements */
  .title-xl, .subtitle-text, .hero-copy .subtitle {
    word-break: keep-all !important;
    overflow-wrap: normal !important;
    hyphens: none !important;
  }
  
  .hero-copy .subtitle .animated-chars {
    word-break: keep-all !important;
    white-space: nowrap !important;
    display: inline-block !important;
  }
  
  /* Footer mobile small screen adjustments */
  .footer-inner{flex-direction:column;align-items:center;text-align:center;gap:24px}
  .footer-left{align-items:center;text-align:center}
  .footer-right{width:100%;max-width:100%;text-align:center}
  .footer-links{grid-template-columns:1fr;gap:24px;justify-items:center}
  .footer-column{align-items:center;text-align:center;gap:8px}
  .footer-column h4{font-size:16px;margin-bottom:12px}
  .footer-column a{font-size:14px;white-space:normal;word-break:normal}
  .footer-bottom{text-align:center;margin-top:16px}
  .footer-logo{height:50px}
  .cnpj{text-align:center;font-size:13px}
}

/* Galeria de Clientes - Hovers Fluidos e Interativos */
.clients-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
  gap: 24px;
  margin-top: 48px;
}

.client-card {
  background: var(--card);
  border: 1px solid var(--stroke);
  border-radius: var(--radius);
  padding: 24px;
  position: relative;
  overflow: hidden;
  cursor: pointer;
  transition: all 0.4s cubic-bezier(0.25, 0.46, 0.45, 0.94);
  transform-origin: center;
}

.client-card::before {
  content: '';
  position: absolute;
  top: 0;
  left: -100%;
  width: 100%;
  height: 100%;
  background: linear-gradient(90deg, transparent, rgba(45, 140, 255, 0.1), transparent);
  transition: left 0.6s ease;
}

.client-card:hover {
  transform: translateY(-8px) scale(1.02);
  box-shadow: 
    0 20px 40px rgba(0, 0, 0, 0.3),
    0 0 0 1px rgba(45, 140, 255, 0.2);
  border-color: rgba(45, 140, 255, 0.4);
}

.client-card:hover::before {
  left: 100%;
}

.client-card:active {
  transform: translateY(-4px) scale(1.01);
  transition: all 0.1s ease;
}

.client-name {
  font-size: 20px;
  font-weight: 700;
  margin: 0 0 12px 0;
  line-height: 1.3;
  transition: all 0.3s ease;
}

.client-card:hover .client-name {
  transform: translateX(4px);
}

.client-description {
  color: var(--text);
  font-size: 14px;
  line-height: 1.5;
  margin: 0 0 16px 0;
  transition: all 0.3s ease;
}

.client-card:hover .client-description {
  color: var(--muted);
  transform: translateX(2px);
}

.client-link {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-size: 14px;
  font-weight: 600;
  text-decoration: none;
  transition: all 0.3s cubic-bezier(0.25, 0.46, 0.45, 0.94);
  position: relative;
}

.client-link::after {
  content: '→';
  transition: transform 0.3s ease;
}

.client-card:hover .client-link {
  transform: translateX(4px);
}

.client-card:hover .client-link::after {
  transform: translateX(4px);
}

/* Responsividade para galeria de clientes */
@media (max-width: 768px) {
  .clients-grid {
    grid-template-columns: 1fr;
    gap: 16px;
    margin-top: 32px;
  }
  
  .client-card {
    padding: 20px;
  }
  
  .client-name {
    font-size: 18px;
  }
  
  .client-description {
    font-size: 13px;
  }
}

/* Benefícios - Hovers Fluidos e Interativos */
.benefits-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  gap: 24px;
  margin-top: 48px;
}

.benefit-card {
  background: var(--card);
  border: 1px solid var(--stroke);
  border-radius: var(--radius);
  padding: 32px 24px;
  text-align: center;
  position: relative;
  overflow: hidden;
  cursor: pointer;
  transition: all 0.4s cubic-bezier(0.25, 0.46, 0.45, 0.94);
  transform-origin: center;
}

.benefit-card::before {
  content: '';
  position: absolute;
  top: 0;
  left: -100%;
  width: 100%;
  height: 100%;
  background: linear-gradient(90deg, transparent, rgba(45, 140, 255, 0.08), transparent);
  transition: left 0.6s ease;
}

.benefit-card:hover {
  transform: translateY(-10px) scale(1.03);
  box-shadow: 
    0 25px 50px rgba(0, 0, 0, 0.25),
    0 0 0 1px rgba(45, 140, 255, 0.15);
  border-color: rgba(45, 140, 255, 0.3);
}

.benefit-card:hover::before {
  left: 100%;
}

.benefit-card:active {
  transform: translateY(-6px) scale(1.02);
  transition: all 0.1s ease;
}

.benefit-icon {
  font-size: 48px;
  margin-bottom: 16px;
  display: block;
  transition: all 0.4s cubic-bezier(0.25, 0.46, 0.45, 0.94);
}

.benefit-card:hover .benefit-icon {
  transform: scale(1.1) rotate(5deg);
}

.benefit-card h3 {
  font-size: 20px;
  font-weight: 700;
  margin: 0 0 12px 0;
  color: var(--text);
  transition: all 0.3s ease;
}

.benefit-card:hover h3 {
  transform: translateY(-2px);
  color: var(--blue);
}

.benefit-card p {
  font-size: 14px;
  line-height: 1.6;
  color: var(--muted);
  margin: 0;
  transition: all 0.3s ease;
}

.benefit-card:hover p {
  color: var(--text);
  transform: translateY(-1px);
}

/* Responsividade para novas seções */
@media (max-width: 768px) {
  .benefits-grid {
    grid-template-columns: 1fr;
    gap: 20px;
    margin-top: 32px;
  }
  
  .benefit-card {
    padding: 24px 20px;
  }
  
  .benefit-icon {
    font-size: 40px;
  }
  
  .benefit-card h3 {
    font-size: 18px;
  }
  
  .benefit-card p {
    font-size: 13px;
  }
  
  .clients-grid {
    grid-template-columns: 1fr;
    gap: 16px;
    margin-top: 32px;
  }
  
  .client-card {
    padding: 20px;
  }
  
  .client-name {
    font-size: 18px;
  }
  
  .client-description {
    font-size: 13px;
  }
}

@media (max-width: 480px) {
  .benefits-grid {
    gap: 16px;
  }
  
  .benefit-card {
    padding: 20px 16px;
  }
  
  .benefit-icon {
    font-size: 36px;
  }
  
  .benefit-card h3 {
    font-size: 16px;
  }
  
  .benefit-card p {
    font-size: 12px;
  }
}

/* Estilo para palavras em destaque - Azul */
strong {
  color: var(--blue) !important;
  font-weight: 700;
}

