@import url('https://fonts.googleapis.com/css2?family=Nunito:wght@300;400;600;700;800;900&display=swap');

:root{
  --brand-bg:#f7f8fc; /* fundo base claro */
  --brand-bg-secondary:#eef1f6;
  --brand-primary:#7F42E1;
  --brand-accent:#FF594F;
  --brand-purple:#42317B;
  --brand-blue:#3a5fe5;
  --text:#0f172a; /* texto escuro para fundo claro */
  --text-light:#334155;
  --text-muted:#64748b;
  --card:rgba(255,255,255,0.7);
  --card-glass:rgba(255,255,255,0.75);
  --card-hover:rgba(255,255,255,0.9);
  --border:rgba(15,23,42,0.08);
  --shadow:0 8px 32px rgba(0,0,0,0.08);
  --shadow-lg:0 20px 60px rgba(0,0,0,0.12);
  --glow:0 0 40px rgba(127,66,225,0.18);
  --gradient-bg:linear-gradient(135deg, #7F42E1 0%, #3a5fe5 50%, #FF594F 100%);
  --gradient-light:linear-gradient(135deg, #A98BF4 0%, #8DB0FF 50%, #FFA6A2 100%);
}

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

html{
  scroll-behavior:smooth;
}

/* Ocultar barra de rolagem (scrollbar) mas manter scroll */
html{scrollbar-width:none}
body{-ms-overflow-style:none}
body::-webkit-scrollbar{width:0;height:0}

body{
  font-family:'Nunito',Calibri,'Segoe UI',sans-serif;
  background:linear-gradient(180deg, #f7f8fc 0%, #eef1f6 50%, #e5e8ee 100%); /* cinza claro → prata suave */
  color:var(--text);
  line-height:1.6;
  overflow-x:hidden;
  padding-top:90px;
}

body.nav-open{
  overflow:hidden;
}

.container{
  max-width:1200px;
  margin:0 auto;
  padding:0 32px;
}

/* Navigation */
.nav{
  position:fixed;
  top:0;
  left:0;
  right:0;
  width:100%;
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding:20px 0;
  background:rgba(127,66,225,0.08);
  backdrop-filter:blur(30px) saturate(180%);
  -webkit-backdrop-filter:blur(30px) saturate(180%);
  border-bottom:1px solid rgba(127,66,225,0.3);
  z-index:1000;
  transition:all 0.3s ease;
  box-shadow:0 8px 32px rgba(127,66,225,0.15),
             0 0 80px rgba(127,66,225,0.1),
             inset 0 1px 0 rgba(255,255,255,0.1);
}

.nav:before{
  content:'';
  position:absolute;
  top:0;
  left:0;
  right:0;
  bottom:0;
  background:linear-gradient(135deg,
    rgba(127,66,225,0.15) 0%,
    rgba(58,95,229,0.1) 50%,
    rgba(255,89,79,0.1) 100%
  );
  opacity:0.5;
  z-index:-1;
  transition:opacity 0.3s ease;
}

.nav.scrolled{
  padding:12px 0;
  background:rgba(127,66,225,0.12);
  box-shadow:0 8px 40px rgba(127,66,225,0.25),
             0 0 100px rgba(127,66,225,0.15),
             inset 0 1px 0 rgba(255,255,255,0.15);
  border-bottom:1px solid rgba(127,66,225,0.4);
}

.nav.scrolled:before{
  opacity:0.7;
}

.nav .container{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:28px;
  position:relative;
}

.nav-toggle{
  display:none;
  width:44px;
  height:44px;
  border-radius:14px;
  border:1px solid rgba(255,255,255,0.3);
  background:rgba(12,4,35,0.35);
  backdrop-filter:blur(10px);
  -webkit-backdrop-filter:blur(10px);
  align-items:center;
  justify-content:center;
  gap:6px;
  flex-direction:column;
  cursor:pointer;
  transition:background 0.3s ease, border-color 0.3s ease;
  margin-left:auto;
}
.nav-toggle span{
  display:block;
  width:18px;
  height:2px;
  border-radius:2px;
  background:#fff;
  transition:transform 0.3s ease, opacity 0.3s ease;
}
.nav-toggle[aria-expanded="true"] span:nth-child(1){transform:translateY(6px) rotate(45deg);}
.nav-toggle[aria-expanded="true"] span:nth-child(2){opacity:0;}
.nav-toggle[aria-expanded="true"] span:nth-child(3){transform:translateY(-6px) rotate(-45deg);}

.brand{
  display:flex;
  align-items:center;
  gap:16px;
  text-decoration:none;
  transition:transform 0.3s ease;
  position:relative;
  padding:8px 0;
}

.brand:hover{
  transform:scale(1.02);
}

.brand:after{
  content:'';
  position:absolute;
  bottom:0;
  left:0;
  width:0;
  height:3px;
  background:var(--gradient-bg);
  border-radius:2px;
  transition:width 0.3s ease;
  box-shadow:0 0 15px rgba(127,66,225,0.6);
}

.brand:hover:after{
  width:100%;
}

.brand-logo{
  width:48px;
  height:48px;
  background:var(--gradient-bg);
  border-radius:12px;
  display:flex;
  align-items:center;
  justify-content:center;
  font-size:24px;
  font-weight:900;
  color:#fff;
  letter-spacing:-2px;
  box-shadow:0 4px 20px rgba(127,66,225,0.5),
             0 0 40px rgba(127,66,225,0.3),
             inset 0 1px 0 rgba(255,255,255,0.3);
  position:relative;
  overflow:hidden;
  border:1px solid rgba(255,255,255,0.2);
}

.brand-logo:before{
  content:'';
  position:absolute;
  width:100%;
  height:100%;
  background:linear-gradient(135deg,
    rgba(255,255,255,0.4) 0%,
    transparent 50%
  );
  top:0;
  left:0;
}

.brand-logo:after{
  content:'';
  position:absolute;
  width:200%;
  height:200%;
  background:linear-gradient(45deg,
    transparent 30%,
    rgba(255,255,255,0.3) 50%,
    transparent 70%
  );
  top:-50%;
  left:-100%;
  animation:shine 3s infinite;
}

@keyframes shine{
  0%{left:-100%}
  50%,100%{left:100%}
}

.brand-text{
  display:flex;
  flex-direction:column;
  gap:2px;
}

.brand-name{
  font-size:24px;
  font-weight:800;
  letter-spacing:-0.8px;
  background:linear-gradient(135deg,#fff,var(--text-light));
  -webkit-background-clip:text;
  -webkit-text-fill-color:transparent;
  background-clip:text;
  line-height:1;
  text-shadow:0 0 30px rgba(255,255,255,0.3);
  filter:drop-shadow(0 0 10px rgba(127,66,225,0.3));
}

.badge{
  background:linear-gradient(135deg,var(--brand-primary),var(--brand-accent));
  color:#fff;
  padding:3px 10px;
  border-radius:12px;
  font-size:10px;
  font-weight:700;
  text-transform:uppercase;
  letter-spacing:0.5px;
  box-shadow:0 2px 8px rgba(127,66,225,0.25);
  width:fit-content;
}

.nav-links{
  display:flex;
  gap:32px;
  align-items:center;
}

@media (min-width: 1024px){
  .nav .container{padding-left:32px;padding-right:32px;}
  .brand{margin-right:auto;margin-left:-20%;}
  .nav-links{margin-left:auto;padding-left:60px;margin-right:-10%;}
}

.nav-links a{
  color:var(--text-light);
  text-decoration:none;
  font-weight:600;
  font-size:15px;
  transition:all 0.3s ease;
  position:relative;
  padding:8px 0;
}

.nav-links a:hover{
  color:#fff;
  text-shadow:0 0 20px rgba(127,66,225,0.6);
}

.nav-links a:after{
  content:'';
  position:absolute;
  bottom:0;
  left:0;
  width:0;
  height:3px;
  background:var(--gradient-bg);
  border-radius:2px;
  transition:width 0.3s ease;
  box-shadow:0 0 15px rgba(127,66,225,0.6);
}

.nav-links a:hover:after{
  width:100%;
}

.nav.scrolled{
  backdrop-filter:blur(18px) saturate(150%);
  -webkit-backdrop-filter:blur(18px) saturate(150%);
  box-shadow:0 10px 20px rgba(12,4,35,0.35);
}

@media (max-width: 820px){
  .nav{padding:8px 0;}
  .nav .container{flex-wrap:nowrap;gap:12px;width:100%;padding:0 16px;min-height:64px;align-items:center;}
  .brand img{height:42px;}
  .nav-toggle{display:inline-flex;}
  .nav-toggle{width:38px;height:38px;border-radius:12px;gap:5px;margin-left:auto;}
  .nav-toggle span{width:18px;}
  .nav-toggle span:nth-child(1){transform-origin:left center;}
  .nav-toggle span:nth-child(3){transform-origin:left center;}
  .nav-links{
    position:absolute;
    top:100%;
    left:0;
    right:0;
    display:none;
    flex-direction:column;
    align-items:flex-start;
    gap:12px;
    padding:20px 28px 24px;
    background:rgba(12,4,35,0.95);
    border-bottom:1px solid rgba(127,66,225,0.35);
    box-shadow:0 18px 38px rgba(12,4,35,0.45);
    width:100%;
  }
  .nav-links.is-open{display:flex;}
  .nav-links a{width:100%;padding:10px 0;font-size:16px;}
  .nav-links a:after{display:none;}
}

/* Hero Section */
.hero{
  display:grid;
  grid-template-columns:1.1fr 1fr;
  gap:60px;
  align-items:center;
  padding:60px 0 80px;
  min-height:600px;
}

.hero h1{
  font-size:64px;
  font-weight:800;
  line-height:1.1;
  margin:0 0 24px;
  letter-spacing:-2.5px;
  color:var(--text);
}

.hero h1 .highlight{
  background:var(--gradient-bg);
  -webkit-background-clip:text;
  -webkit-text-fill-color:transparent;
  background-clip:text;
  display:block;
  filter:drop-shadow(0 0 30px rgba(127,66,225,0.5));
}

.hero-chip{
  display:inline-block;
  position:relative;
  margin-bottom:12px;
  padding:14px 36px; /* Padding interno do chip */
  background:linear-gradient(#0a0a1a, #0a0a1a) padding-box, /* Fundo sólido para o chip */
             linear-gradient(135deg, #7F42E1, #3a5fe5, #FF594F) border-box; /* Borda gradiente */
  border:2px solid transparent; /* Largura da borda */
  border-radius:50px;
  transition:all 0.3s ease;
  box-shadow:0 0 15px rgba(127,66,225,0.3);
  color:transparent; /* O texto em si será transparente */
  background-clip:padding-box, border-box; /* Garante que o gradiente seja para a borda */
  background-origin:border-box; /* Origem do background para a borda */
  font-size:24px; /* Tamanho da fonte padrão */
  font-weight:600;
  white-space:nowrap; /* Garante que o texto não quebre linha */
}

.hero-chip:hover{
  box-shadow:0 0 30px rgba(127,66,225,0.6);
}

.hero-chip:before{
  content:'Conte com o app Cidapay';
  background:linear-gradient(135deg, #7F42E1, #3a5fe5, #FF594F); /* Gradiente para o texto */
  -webkit-background-clip:text;
  -webkit-text-fill-color:transparent;
  background-clip:text;
  font-weight:600;
  font-size:24px;
  position:absolute;
  top:50%;
  left:50%;
  transform:translate(-50%,-50%);
  white-space:nowrap;
}

.hero-chip:after{
  content:'';
  position:absolute;
  inset:2px;
  background:#0a0a1a;
  border-radius:48px;
  z-index:-1;
}

.hero p{
  font-size:20px;
  line-height:1.7;
  color:var(--text-light);
  margin-bottom:40px;
  max-width:540px;
}

.cta{
  display:flex;
  gap:16px;
  margin-bottom:40px;
}

.button{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding:16px 32px;
  border-radius:16px;
  font-size:16px;
  font-weight:700;
  text-decoration:none;
  transition:all 0.3s ease;
  border:none;
  cursor:pointer;
  box-shadow:var(--shadow);
}

.button.primary{
  background:var(--gradient-bg);
  color:#fff;
  transform:translateY(0);
  box-shadow:0 4px 16px rgba(127,66,225,0.3);
}

.button.primary:hover{
  transform:translateY(-3px);
  box-shadow:0 8px 24px rgba(127,66,225,0.4);
}

.button.secondary{
  background:#fff;
  color:var(--brand-purple);
  border:2px solid var(--border);
}

.button.secondary:hover{
  border-color:var(--brand-primary);
  background:var(--card-light);
  color:var(--brand-primary);
}

.hero-visual{
  position:relative;
  min-height:480px;
  border-radius:32px;
  background:linear-gradient(135deg, 
    rgba(127,66,225,0.9) 0%, 
    rgba(58,95,229,0.85) 35%,
    rgba(229,7,198,0.75) 70%,
    rgba(255,89,79,0.9) 100%
  );
  overflow:hidden;
  box-shadow:0 20px 60px rgba(127,66,225,0.25);
}

.hero-visual:before{
  content:'';
  position:absolute;
  width:400px;
  height:400px;
  background:radial-gradient(circle,rgba(255,255,255,0.25),transparent 70%);
  top:-150px;
  right:-100px;
  border-radius:50%;
  animation:float 6s ease-in-out infinite;
}

.hero-visual:after{
  content:'';
  position:absolute;
  width:350px;
  height:350px;
  background:radial-gradient(circle,rgba(255,255,255,0.2),transparent 70%);
  bottom:-120px;
  left:-80px;
  border-radius:50%;
  animation:float 8s ease-in-out infinite reverse;
}

@keyframes float{
  0%,100%{transform:translateY(0px) translateX(0px)}
  50%{transform:translateY(-20px) translateX(10px)}
}

/* Notice */
.notice{
  padding:20px 24px;
  border-radius:16px;
  background:var(--card-glass);
  backdrop-filter:blur(20px);
  -webkit-backdrop-filter:blur(20px);
  border:1px solid var(--border);
  color:var(--text-light);
  font-size:14px;
  line-height:1.6;
  box-shadow:var(--shadow);
}

.notice strong{
  color:var(--text);
  font-weight:700;
}

/* Features Section */
.features{
  padding:100px 0;
  background:transparent;
}

.section-title{
  text-align:center;
  font-size:48px;
  font-weight:800;
  margin-bottom:60px;
  letter-spacing:-1.5px;
  color:var(--text);
}

.grid{
  display:grid;
  gap:24px;
}

.grid.cols-3{
  grid-template-columns:repeat(3,1fr);
}

.grid.cols-2{
  grid-template-columns:repeat(2,1fr);
}

.card{
  background:var(--card-glass);
  backdrop-filter:blur(20px);
  -webkit-backdrop-filter:blur(20px);
  border:1px solid var(--border);
  border-radius:24px;
  padding:40px 32px;
  transition:all 0.4s ease;
  box-shadow:var(--shadow);
}

.card:hover{
  transform:translateY(-8px);
  box-shadow:var(--shadow-lg), var(--glow);
  border-color:var(--brand-primary);
  background:var(--card-hover);
}

.card h3{
  font-size:24px;
  font-weight:700;
  margin-bottom:16px;
  color:var(--text);
}

.card p{
  color:var(--text-light);
  font-size:16px;
  line-height:1.7;
}

.card-icon{
  width:64px;
  height:64px;
  border-radius:20px;
  background:var(--gradient-bg);
  display:flex;
  align-items:center;
  justify-content:center;
  font-size:32px;
  margin-bottom:24px;
  box-shadow:0 6px 20px rgba(127,66,225,0.35);
}

/* Content Sections */
.content-section{
  padding:60px 0;
}

.content-section h1{
  font-size:48px;
  font-weight:800;
  margin-bottom:16px;
  letter-spacing:-1.5px;
  color:var(--text);
}

.content-section h2{
  font-size:28px;
  font-weight:700;
  margin:40px 0 20px;
  color:var(--text);
}

.content-section p{
  color:var(--text-light);
  font-size:16px;
  line-height:1.8;
  margin-bottom:16px;
}

.content-section em{
  color:var(--text-muted);
  font-size:14px;
}

.list{
  list-style:none;
  padding:0;
  margin:20px 0;
}

.list li{
  color:var(--text-light);
  padding:12px 0 12px 32px;
  position:relative;
  line-height:1.7;
}

.list li:before{
  content:'✓';
  position:absolute;
  left:0;
  color:var(--brand-primary);
  font-weight:700;
  font-size:18px;
}

/* Key-Value pairs */
.kv{
  display:flex;
  flex-direction:column;
  gap:8px;
  padding:24px;
  background:var(--card-glass);
  backdrop-filter:blur(20px);
  -webkit-backdrop-filter:blur(20px);
  border-radius:16px;
  border:1px solid var(--border);
  box-shadow:var(--shadow);
}

.kv .k{
  color:var(--text-muted);
  font-size:13px;
  text-transform:uppercase;
  letter-spacing:0.8px;
  font-weight:600;
}

.kv .v{
  color:var(--text);
  font-weight:700;
  font-size:16px;
}

.kv .v a{
  color:var(--brand-primary);
  text-decoration:none;
  transition:color 0.3s ease;
}

.kv .v a:hover{
  color:var(--brand-accent);
  text-decoration:underline;
}

/* Stats Section - roxo profundo translúcido */
.stats{
  background:linear-gradient(135deg, rgba(19,8,85,0.94) 0%, rgba(12,4,35,0.94) 100%) !important;
  position:relative;
  backdrop-filter:blur(22px) saturate(170%);
  -webkit-backdrop-filter:blur(22px) saturate(170%);
  padding:60px 0;
  margin-top:60px;
  border-top:1px solid rgba(127,66,225,0.55) !important;
  border-bottom:1px solid rgba(127,66,225,0.55) !important;
  box-shadow:0 8px 36px rgba(10,10,26,0.55), 0 0 80px rgba(127,66,225,0.25);
}

.stats:before,
.stats:after{
  content:'';
  position:absolute;
  left:0;right:0;
  height:1px;
  pointer-events:none;
  background:linear-gradient(90deg, rgba(127,66,225,0) 0%, rgba(127,66,225,0.95) 50%, rgba(127,66,225,0) 100%);
}
.stats:before{top:0}
.stats:after{bottom:0}

.stats .stat-label{color:#e5e7eb !important}

.stats-grid{display:flex;gap:32px;justify-content:space-between;align-items:flex-start;flex-wrap:nowrap;text-align:left}
.stat-item{padding:10px;display:flex;flex-direction:column;align-items:flex-start;flex:1 1 0;min-width:0}
.stat-icon{display:flex;align-items:center;justify-content:flex-start;margin-bottom:10px}
.stat-icon svg{width:26px;height:26px;fill:none;stroke-width:2;opacity:.95}
.stat-number{font-size:44px;font-weight:800;background:var(--gradient-bg);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin-bottom:6px;letter-spacing:-1.5px}
.stat-label{font-size:16px;color:var(--text-light);font-weight:500;line-height:1.4;white-space:normal}
@media (max-width: 968px){.stats-grid{gap:20px}.stat-number{font-size:34px}.stat-label{font-size:15px}}
@media (max-width: 480px){.stats-grid{gap:14px}.stat-number{font-size:30px}}

/* About Section */
.about{
  padding:100px 0;
}

.about-content{
  max-width:900px;
  margin:0 auto;
}

.about-text p{
  font-size:18px;
  line-height:1.8;
  color:var(--text-light);
  margin-bottom:24px;
}

.values-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:24px;
  margin-top:48px;
}

.value-card{
  background:var(--card-glass);
  backdrop-filter:blur(20px);
  -webkit-backdrop-filter:blur(20px);
  border:1px solid var(--border);
  border-radius:20px;
  padding:32px;
  transition:all 0.3s ease;
  box-shadow:var(--shadow);
}

.value-card:hover{
  border-color:var(--brand-primary);
  transform:translateY(-4px);
  box-shadow:var(--shadow-lg), var(--glow);
  background:var(--card-hover);
}

.value-card h3{
  font-size:20px;
  font-weight:700;
  color:var(--text);
  margin:0 0 12px;
}

.value-card p{
  color:var(--text-light);
  margin:0;
  line-height:1.6;
}

/* Hero Subtitle */
.hero-subtitle{
  font-size:20px !important;
}

/* Card Icon Number */
.card-icon-number{
  width:56px;
  height:56px;
  border-radius:14px;
  background:linear-gradient(135deg,#42317B,#7F42E1);
  display:flex;
  align-items:center;
  justify-content:center;
  color:#fff;
  font-size:24px;
  font-weight:800;
  margin-bottom:20px;
  box-shadow:0 4px 16px rgba(127,66,225,0.3);
}

/* Services Section */
.services{
  padding:100px 0;
  background:transparent;
}

.section-subtitle{
  text-align:center;
  font-size:18px;
  color:var(--text-light);
  margin:-40px 0 60px;
  max-width:600px;
  margin-left:auto;
  margin-right:auto;
}

.services-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:32px;
  margin-top:48px;
}

.service-card{
  background:var(--card-glass);
  backdrop-filter:blur(20px);
  -webkit-backdrop-filter:blur(20px);
  border:1px solid var(--border);
  border-radius:24px;
  padding:48px 36px;
  transition:all 0.4s ease;
  position:relative;
  overflow:hidden;
  box-shadow:var(--shadow);
}

.service-card:before{
  content:'';
  position:absolute;
  top:0;
  left:0;
  width:100%;
  height:6px;
  background:var(--gradient-bg);
  transform:scaleX(0);
  transform-origin:left;
  transition:transform 0.4s ease;
}

.service-card:hover:before{
  transform:scaleX(1);
}

.service-card:hover{
  transform:translateY(-8px);
  box-shadow:var(--shadow-lg), var(--glow);
  border-color:var(--brand-primary);
  background:var(--card-hover);
}

.service-number{
  font-size:14px;
  font-weight:700;
  color:var(--brand-primary);
  margin-bottom:16px;
  letter-spacing:1px;
}

.service-card h3{
  font-size:24px;
  font-weight:700;
  color:var(--text);
  margin:0 0 16px;
}

.service-card p{
  color:var(--text-light);
  line-height:1.7;
  margin:0 0 24px;
}

.service-link{
  color:var(--brand-primary);
  font-weight:700;
  font-size:16px;
  text-decoration:none;
  transition:all 0.3s ease;
  display:inline-flex;
  align-items:center;
  gap:8px;
}

.service-link:hover{
  gap:12px;
  text-decoration:none;
}

/* CTA Section */
.cta-section{
  padding:80px 0;
}

.cta-box{
  background:linear-gradient(135deg,#2d1b5e 0%,#42317B 25%,#7F42E1 75%,#3a5fe5 100%);
  border-radius:32px;
  padding:80px 60px;
  text-align:center;
  color:#fff;
  position:relative;
  overflow:hidden;
  box-shadow:0 20px 60px rgba(66,49,123,0.4);
}

.cta-box:before{
  content:'';
  position:absolute;
  width:400px;
  height:400px;
  background:radial-gradient(circle,rgba(255,255,255,0.15),transparent 70%);
  top:-150px;
  right:-100px;
  border-radius:50%;
  animation:float 8s ease-in-out infinite;
}

.cta-box h2{
  font-size:42px;
  font-weight:800;
  margin:0 0 16px;
  letter-spacing:-1px;
  position:relative;
  z-index:1;
}

.cta-box p{
  font-size:20px;
  margin:0 0 32px;
  opacity:0.95;
  position:relative;
  z-index:1;
}
.cta-download-text{
  margin:0;
  font-size:17px;
  font-weight:800;
  letter-spacing:3px;
  text-transform:uppercase;
  color:rgba(255,255,255,0.9);
}
.cta-box .app-download-buttons{
  justify-content:center;
  position:relative;
  z-index:1;
}

.button.large{
  padding:20px 48px;
  font-size:18px;
  position:relative;
  z-index:1;
}

/* Footer */
.footer{
  position:relative;
  width:100%;
  background:linear-gradient(135deg,#190855 0%,#0c0423 50%,#3516e6 100%) !important;
  padding:70px 0 40px;
  border-top:1px solid rgba(127,66,225,0.55) !important;
  border-bottom:1px solid rgba(127,66,225,0.45) !important;
  box-shadow:0 12px 42px rgba(10,10,26,0.55), 0 0 90px rgba(53,22,230,0.25);
  overflow:hidden;
}
.footer::before{
  content:"";
  position:absolute;
  inset:0;
  background:linear-gradient(135deg,rgba(127,66,225,0.35),rgba(53,22,230,0.25));
  opacity:0.35;
  z-index:0;
}
.footer > .container{position:relative;z-index:1}

.footer-content{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:48px;
  margin-bottom:40px;
}

.footer-section h4{
  font-size:18px;
  font-weight:700;
  color:#fff;
  margin:0 0 20px;
}

.footer-section p{
  color:rgba(255,255,255,0.92);
  margin:0;
  line-height:1.6;
}

.footer-section a{
  display:block;
  color:rgba(255,255,255,0.88);
  text-decoration:none;
  margin-bottom:12px;
  transition:color 0.3s ease, opacity 0.3s ease;
}

.footer-section a:hover{
  color:#fff;
  opacity:0.95;
}

.footer-bottom{
  padding-top:32px;
  border-top:1px solid rgba(127,66,225,0.35);
  text-align:center;
  color:rgba(255,255,255,0.85);
  font-size:14px;
}

.footer-bottom p{margin:0}

.footer-disclaimer{
  margin-top:22px;
  padding-top:22px;
  border-top:1px solid rgba(127,66,225,0.35);
}

.footer-disclaimer p{
  font-size:12px;
  line-height:1.6;
  color:rgba(255,255,255,0.78);
  text-align:left;
  margin:0;
}

.app-download-buttons{
  display:flex;
  gap:16px;
  margin-top:24px;
  flex-wrap:wrap;
}

.app-download-buttons a{
  display:inline-block;
  transition:transform 0.3s ease, box-shadow 0.3s ease;
  border-radius:0;
  overflow:visible;
  box-shadow:0 8px 24px rgba(0,0,0,0.18);
}

.app-download-buttons a:hover{
  transform:translateY(-5px);
  box-shadow:0 12px 40px rgba(0,0,0,0.35), 0 0 30px rgba(127,66,225,0.4);
}

.app-download-buttons img{
  height:56px;
  width:auto;
  display:block;
  border-radius:0;
}

/* Footer Social */
.footer-social{
  margin-top:32px;
  display:flex;
  flex-direction:column;
  gap:12px;
}
.footer-social-title{
  font-size:14px;
  text-transform:uppercase;
  letter-spacing:2px;
  color:rgba(255,255,255,0.72);
  font-weight:700;
}
.footer-social-icons{
  display:flex;
  gap:14px;
}
.footer-social-icons a{
  width:40px;
  height:40px;
  border-radius:12px;
  background:rgba(255,255,255,0.12);
  display:flex;
  align-items:center;
  justify-content:center;
  transition:transform 0.3s ease, background 0.3s ease, box-shadow 0.3s ease;
}
.footer-social-icons a:hover{
  transform:translateY(-4px);
  background:rgba(255,255,255,0.22);
  box-shadow:0 12px 28px rgba(12,4,35,0.35);
}
.footer-social-icons svg{
  width:20px;
  height:20px;
  fill:none;
  stroke:currentColor;
  stroke-width:1.6;
}
.footer-social-facebook{color:#1877f2}
.footer-social-instagram{color:#ffffff}
.footer-social-instagram svg circle:nth-of-type(1){stroke:#fff}
.footer-social-instagram svg circle:nth-of-type(2){fill:#fff}

/* Responsive */
@media (max-width: 968px) {
  body{
    padding-top:120px;
  }
  
  .container{
    padding:0 20px;
  }
  
  .nav{
    padding:12px 0;
  }
  
  .nav .container{
    flex-wrap:wrap;
    align-items:center;
    justify-content:space-between;
    gap:12px;
    padding:0 20px;
  }
  .nav .container > .nav-toggle{order:2;}
  .nav .container > .nav-links{
    order:3;
    width:100%;
  }
  
  .brand-logo{
    width:40px;
    height:40px;
    font-size:20px;
  }
  
  .brand-name{
    font-size:20px;
  }
  
  .nav-links{
    width:100%;
    gap:12px;
    flex-wrap:wrap;
    margin-left:0;
  }
  
  .hero{
    grid-template-columns:1fr;
    gap:40px;
    padding:40px 0 60px;
    min-height:auto;
  }
  
  .hero h1{
    font-size:40px;
  }
  
  .hero-chip{
    padding:10px 28px;
    font-size:20px;
  }
  .hero-chip:before{
    font-size:20px;
  }
  
  .hero p{
    font-size:18px;
  }
  
  .cta{
    flex-direction:column;
  }
  
  .button{
    width:100%;
  }
  
  .stats-grid{
    grid-template-columns:repeat(2,1fr);
    gap:24px;
  }
  
  .stat-number{
    font-size:36px;
  }
  
  .values-grid{
    grid-template-columns:1fr;
    gap:20px;
  }
  
  .grid.cols-3,
  .grid.cols-2{
    grid-template-columns:1fr;
  }
  
  .services-grid{
    grid-template-columns:1fr;
    gap:24px;
  }
  
  .service-card{
    padding:36px 28px;
  }
  
  .cta-box{
    padding:60px 32px;
  }
  
  .cta-box h2{
    font-size:32px;
  }
  
  .cta-box p{
    font-size:18px;
  }
  
  .footer-content{
    grid-template-columns:repeat(2,1fr);
    gap:32px;
  }
  
  .section-title{
    font-size:32px;
  }
  
  .content-section h1{
    font-size:36px;
  }
  .app-download-buttons{
    justify-content:center;
    width:100%;
  }
  .app-download-buttons img{
    height:48px;
  }
}

@media (max-width: 480px) {
  .stats-grid{
    grid-template-columns:1fr;
  }
  
  .footer-content{
    grid-template-columns:1fr;
    gap:32px;
  }
  
  .nav-links{
    flex-direction:column;
    gap:12px;
  }
  .app-download-buttons{
    flex-direction:column;
    align-items:center;
  }
  .app-download-buttons img{
    height:44px;
  }
}

/* Capa de abertura (full-width) aplicada apenas na home */
.hero.hero-cover{
  width:100%;
  min-height:92vh;
  background-image:url('./assets/badges/capa.JPG');
  background-size:110%;
  background-position:center top;
  background-repeat:no-repeat;
  background-color:transparent;
  margin-top:0;
  padding:calc(90px + 40px) 0 140px;
  position:relative;
  display:flex;
  align-items:stretch;
  overflow:hidden;
  image-orientation:from-image;
  transform:rotateY(0deg);
}

.hero.hero-cover .hero-visual{display:none}
.hero.hero-cover .container{position:relative;flex:1;display:flex;flex-direction:column;justify-content:flex-end;min-height:inherit}
.hero.hero-cover .cover-content{color:#fff;text-align:left;max-width:min(640px,65vw);margin:0;position:absolute;left:clamp(8px,2vw,56px);top:19%;transform:none;z-index:2;padding:0}
.hero.hero-cover .cover-chip{transform:translateX(-1%);}
.hero.hero-cover .hero-subtitle{color:rgba(255,255,255,0.9)}

/* Botões da capa alinhados ao final */
.hero-cover-cta{
  position:absolute;
  left:clamp(8px,2vw,56px);
  bottom:clamp(140px,22vh,280px);
  display:flex;
  justify-content:flex-start;
  margin:0;
  z-index:2;
}
.hero-cover-cta .app-download-buttons{display:flex;gap:20px}

@media (max-width: 1280px){
  .hero.hero-cover{padding:calc(80px + 40px) 0 150px;background-size:118%;background-position:center 6%;}
  .hero.hero-cover .cover-content{top:26%;}
  .hero-cover-cta{bottom:clamp(44px,14vh,160px);}
}

@media (max-width: 992px){
  .hero.hero-cover{min-height:auto;padding:calc(80px + 40px) 0 120px;background-size:135%;background-position:center 12%;}
  .hero.hero-cover .container{align-items:flex-start;justify-content:flex-start;min-height:auto;padding:0 0 80px;}
  .hero.hero-cover .cover-content{position:relative;left:0;top:0;padding:0 24px;margin:0 0 32px;max-width:100%;display:flex;gap:20px;}
  .hero-cover-cta{position:relative;left:0;bottom:auto;padding:0 24px;transform:none;width:100%;}
  .hero-cover-cta .app-download-buttons{flex-wrap:wrap;justify-content:flex-start;gap:16px;}
}

@media (max-width: 720px){
  .hero.hero-cover{padding:70px 0 100px;background-size:115%;background-position:center top;}
  .hero.hero-cover .cover-content{display:none;}
  .hero-cover-cta{display:none;}
  .cover-chip{display:none;}
  .hero-cover-cta .app-download-buttons{display:none;}
}

@media (max-width: 520px){
  .hero.hero-cover{padding:64px 0 90px;background-size:110%;background-position:center top;}
  .hero.hero-cover .cover-content{display:none;}
  .hero-cover-cta{display:none;}
  .cover-chip{display:none;}
  .hero-cover-cta .app-download-buttons{display:none;}
}
 
/* How it works */
.how{
  padding:110px 0;
  background:rgba(255,255,255,0.02);
}
.how-layout{
  display:grid;
  grid-template-columns:minmax(0,1.1fr) minmax(0,1fr);
  gap:72px;
  align-items:center;
}
.how-left{
  display:flex;
  flex-direction:column;
  gap:20px;
  max-width:520px;
}
.how-left .section-title{margin:0;}
.how-intro{
  margin:0;
  color:var(--text-light);
  font-size:18px;
  line-height:1.7;
}
.how-carousel{
  position:relative;
  border-radius:24px;
  background:linear-gradient(135deg, rgba(19,8,85,0.92), rgba(12,4,35,0.9));
  border:1px solid rgba(127,66,225,0.3);
  padding:28px 32px;
  box-shadow:0 20px 48px rgba(10,10,26,0.45);
  display:flex;
  flex-direction:column;
  gap:18px;
  max-width:420px;
}
.how-carousel-card{
  position:relative;
  min-height:170px;
  display:flex;
  flex-direction:column;
  gap:12px;
  color:#fff;
  transition:opacity 0.4s ease, transform 0.4s ease;
  opacity:1;
  transform:translateY(0);
}
.how-carousel-card.is-active{opacity:1;transform:translateY(0);}
.how-carousel-card.is-entering{opacity:0;transform:translateY(-12px);}
.how-carousel-card.is-exiting{opacity:0;transform:translateY(12px);}
.how-carousel-step{
  width:36px;
  height:36px;
  border-radius:12px;
  background:linear-gradient(135deg,#FF594F,#FFA6A2);
  display:flex;
  align-items:center;
  justify-content:center;
  font-weight:800;
  font-size:15px;
  box-shadow:0 10px 22px rgba(255,89,79,0.35);
}
.how-carousel-title{margin:0;font-size:22px;font-weight:800;letter-spacing:-0.2px;}
.how-carousel-text{margin:0;color:rgba(255,255,255,0.82);line-height:1.6;}
.how-carousel-dots{display:flex;gap:8px;}
.how-carousel-dot{
  width:10px;
  height:10px;
  border-radius:50%;
  border:none;
  background:rgba(255,255,255,0.26);
  cursor:pointer;
  transition:transform 0.3s ease, background 0.3s ease;
}
.how-carousel-dot.active{background:#fff;transform:scale(1.3);}
.how-image{
  position:relative;
  display:flex;
  align-items:center;
  justify-content:center;
}
.how-image::before{
  content:"";
  position:absolute;
  width:70%;
  height:70%;
  max-width:360px;
  max-height:360px;
  background:radial-gradient(circle, rgba(127,66,225,0.35) 0%, rgba(12,4,35,0) 70%);
  filter:blur(32px);
  z-index:0;
  pointer-events:none;
}
.how-image img{
  position:relative;
  z-index:1;
  width:100%;
  max-width:520px;
  display:block;
  mix-blend-mode:multiply;
  filter:drop-shadow(0 26px 60px rgba(9,5,30,0.55));
  pointer-events:none;
}

@media (max-width: 1080px){
  .how-layout{grid-template-columns:1fr;gap:48px;}
  .how-image img{max-width:420px;}
}
@media (max-width: 768px){
  .how-carousel{max-width:100%;}
  .how-left{gap:16px;}
}

/* Testimonials */
.testimonials{padding:100px 0;background:rgba(255,255,255,0.02)}
.testimonials .card{min-height:160px}

@media (max-width: 968px){
  .stat-number{font-size:34px}.stat-label{font-size:14px}
}
@media (max-width: 480px){
  .stat-number{font-size:30px}
}

/* Legibilidade reforçada na faixa de estatísticas */
.stats .stat-number{
  text-shadow:0 2px 14px rgba(127,66,225,0.65), 0 0 30px rgba(58,95,229,0.45), 0 0 18px rgba(255,89,79,0.35);
}
.stats .stat-label{
  color:#f1f5f9 !important;
  font-weight:600;
  text-shadow:0 1px 8px rgba(10,10,26,0.35);
}
.stats .stat-icon svg{
  width:28px;height:28px;stroke-width:2.4;
  filter:drop-shadow(0 0 8px rgba(127,66,225,0.45));
}

/* Header - forçar dark com blur e glow no tema claro */
.nav{
  background:rgba(10,10,26,0.6) !important;
  backdrop-filter:blur(30px) saturate(180%);
  -webkit-backdrop-filter:blur(30px) saturate(180%);
  border-bottom:1px solid rgba(127,66,225,0.35) !important;
  box-shadow:0 8px 32px rgba(10,10,26,0.45), 0 0 80px rgba(127,66,225,0.18), inset 0 1px 0 rgba(255,255,255,0.06) !important;
}
.nav:before{opacity:0.6 !important}
.nav.scrolled{
  background:rgba(10,10,26,0.78) !important;
  border-bottom:1px solid rgba(127,66,225,0.5) !important;
  box-shadow:0 10px 40px rgba(10,10,26,0.6), 0 0 100px rgba(127,66,225,0.22), inset 0 1px 0 rgba(255,255,255,0.08) !important;
}
.nav a{color:#e5e7eb !important}
.nav a:hover{color:#ffffff !important}

/* Alto contraste na faixa roxa de estatísticas (gradiente da marca nos números) */
.stats .stat-number{
  font-size:56px !important;
  background:var(--gradient-bg) !important;
  -webkit-background-clip:text !important;
  background-clip:text !important;
  -webkit-text-fill-color:transparent !important;
  color:transparent !important;
  text-shadow:0 2px 14px rgba(127,66,225,0.45), 0 0 22px rgba(58,95,229,0.35);
}
.stats .stat-label{
  color:#e6eaf5 !important;
  font-weight:600;
}
/* Restaurar gradiente dos ícones (sem forçar branco) */
.stats .stat-icon svg{
  width:30px;height:30px;stroke-width:2.2;filter:drop-shadow(0 0 8px rgba(127,66,225,0.35));
}
@media (max-width: 968px){
  .stats .stat-number{font-size:40px !important}
}
@media (max-width: 480px){
  .stats .stat-number{font-size:34px !important}
}

/* Parceiros */
.partners{padding:120px 0;background:linear-gradient(180deg, rgba(12,4,35,0.05) 0%, rgba(12,4,35,0.12) 100%);}
.partners-header{text-align:center;max-width:620px;margin:0 auto 56px;}
.partners-header .section-title{margin-bottom:14px;}
.partners-header .section-subtitle{margin:0;color:var(--text-light);font-size:18px;line-height:1.7;}
.partners-grid{display:grid;grid-template-columns:repeat(5,minmax(220px,1fr));gap:26px;}
.partner-tile{
  position:relative;
  border-radius:24px;
  padding:26px 22px 24px;
  background:linear-gradient(135deg, rgba(21,14,46,0.92), rgba(53,22,230,0.68));
  border:1px solid rgba(127,66,225,0.25);
  box-shadow:0 20px 46px rgba(12,4,35,0.32);
  color:#f8f9ff;
  display:flex;
  flex-direction:column;
  gap:14px;
  transition:transform 0.35s ease, box-shadow 0.35s ease;
}
.partner-tile:hover{transform:translateY(-8px);box-shadow:0 30px 70px rgba(12,4,35,0.4);}
.partner-logo{width:58px;height:58px;border-radius:18px;padding:4px;background:rgba(255,255,255,0.12);display:flex;align-items:center;justify-content:center;box-shadow:0 12px 30px rgba(12,4,35,0.35);}
.partner-logo img{width:100%;height:100%;object-fit:contain;border-radius:12px;filter:drop-shadow(0 8px 16px rgba(0,0,0,0.18));}
.partner-tile h3{margin:0;font-size:20px;font-weight:800;letter-spacing:-0.2px;}
.partner-tile p{margin:0;color:rgba(255,255,255,0.78);font-size:15px;}
.partner-tile ul{list-style:none;margin:0;padding:14px 0 0;border-top:1px solid rgba(255,255,255,0.12);display:flex;flex-direction:column;gap:8px;}
.partner-tile li{display:flex;justify-content:space-between;font-size:14px;color:rgba(255,255,255,0.82);gap:12px;align-items:flex-start;}
.partner-tile li span:first-child{font-weight:700;color:rgba(255,255,255,0.9);white-space:nowrap;}
.partner-tile li span:last-child{text-align:right;max-width:150px;word-break:break-word;white-space:normal;}
.partner-logo.facta{background:linear-gradient(135deg,#FF9A5A,#FF5A7B);}
.partner-logo.bmg{background:linear-gradient(135deg,#7F42E1,#3a5fe5);}
.partner-logo.c6{background:linear-gradient(135deg,#60E4A5,#28B487);}
.partner-logo.presenca{background:linear-gradient(135deg,#FF594F,#FFA6A2);}
.partner-logo.quali{background:linear-gradient(135deg,#FF9A5A,#FFCF78);}

@media (max-width: 1280px){
  .partners-grid{grid-template-columns:repeat(3,minmax(220px,1fr));}
}
@media (max-width: 820px){
  .partners-grid{grid-template-columns:repeat(2,minmax(220px,1fr));}
}
@media (max-width: 540px){
  .partners-grid{grid-template-columns:1fr;}
}

/* Chip da capa (cover-chip) */
.cover-chip,
.review-badge{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding:16px 42px;
  border-radius:999px;
  position:relative;
  color:#fff;
  font-size:24px;
  font-weight:700;
  letter-spacing:-0.3px;
  background:transparent;
  border:none;
  backdrop-filter:blur(28px) saturate(200%);
  -webkit-backdrop-filter:blur(28px) saturate(200%);
  overflow:hidden;
}
.cover-chip::before,
.review-badge::before{
  content:"";
  position:absolute;
  inset:0;
  border-radius:inherit;
  padding:2px;
  background:linear-gradient(135deg,#7F42E1,#3a5fe5,#FF594F);
  mask:linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0);
  -webkit-mask:linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0);
  mask-composite:exclude;
  -webkit-mask-composite:xor;
  pointer-events:none;
}
.cover-chip span,
.review-badge span,
.review-badge{position:relative;z-index:1}
.review-badge{font-size:16px;font-weight:800;letter-spacing:0}

/* Ícones da página de contato */
.contact-icon{
  width:54px;
  height:54px;
  border-radius:16px;
  display:flex;
  align-items:center;
  justify-content:center;
  margin-bottom:16px;
  box-shadow:0 14px 34px rgba(67,49,123,0.25);
  color:#fff;
}
.contact-icon svg{
  width:26px;
  height:26px;
}
.contact-icon svg *{
  stroke:currentColor;
  fill:none;
  stroke-width:1.8;
  stroke-linecap:round;
  stroke-linejoin:round;
}
.contact-icon-support{background:linear-gradient(135deg,#3516e6,#7F42E1)}
.contact-icon-sac{background:linear-gradient(135deg,#3a5fe5,#8DB0FF)}

.contact-item{
  display:flex;
  align-items:center;
  gap:12px;
  margin-bottom:12px;
}
.contact-item:last-child{margin-bottom:0}
.contact-item-icon{
  width:38px;
  height:38px;
  border-radius:12px;
  display:flex;
  align-items:center;
  justify-content:center;
  color:#fff;
  box-shadow:0 10px 24px rgba(12,4,35,0.2);
}
.contact-item-icon svg{
  width:19px;
  height:19px;
  stroke:currentColor;
  fill:none;
  stroke-width:1.6;
  stroke-linecap:round;
  stroke-linejoin:round;
}
.contact-item-icon-mail{background:linear-gradient(135deg,#3516e6,#7F42E1)}
.contact-item-icon-phone{background:linear-gradient(135deg,#e507c6,#FF594F)}
.contact-item-icon-whatsapp{background:linear-gradient(135deg,#1f9d61,#25d366)}
.contact-item-link{
  color:var(--brand-primary);
  font-weight:700;
  font-size:16px;
  text-decoration:none;
}
.contact-item-link:hover{text-decoration:underline}
.contact-item-text{
  color:var(--text-light);
  font-weight:700;
  font-size:16px;
}

.footer-phone{
  color:#ffffff;
  font-weight:700;
  margin:8px 0 0;
}

/* Review Carousel */
.review-carousel{
  position:relative;
  padding:46px 52px 60px;
  border-radius:32px;
  background:linear-gradient(135deg, rgba(23,9,70,0.92), rgba(12,4,35,0.9));
  border:1px solid rgba(127,66,225,0.3);
  box-shadow:0 20px 58px rgba(10,10,26,0.48), inset 0 1px 0 rgba(255,255,255,0.05);
  backdrop-filter:blur(16px) saturate(180%);
  -webkit-backdrop-filter:blur(16px) saturate(180%);
  display:flex;
  flex-direction:column;
  align-items:center;
  gap:28px;
  overflow:hidden;
  --review-prev:url("");
  --review-current:url("");
  --review-next:url("");
}
.review-carousel::before,
.review-carousel::after{
  content:"";
  position:absolute;
  top:50%;
  transform:translateY(-50%);
  width:240px;
  height:240px;
  border-radius:24px;
  background-size:cover;
  background-position:center;
  background-repeat:no-repeat;
  filter:blur(26px);
  opacity:0.18;
  transition:background-image 0.6s ease, opacity 0.6s ease;
  pointer-events:none;
  z-index:0;
}
.review-carousel::before{left:-6%;background-image:var(--review-prev);}
.review-carousel::after{right:-6%;background-image:var(--review-next);}
.review-badge{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding:14px 38px;
  border-radius:999px;
  position:relative;
  color:#fff;
  font-size:15px;
  font-weight:800;
  letter-spacing:0.2px;
  background:transparent;
  border:none;
  backdrop-filter:blur(24px) saturate(200%);
  -webkit-backdrop-filter:blur(24px) saturate(200%);
  overflow:hidden;
  z-index:1;
}
.review-badge::before{
  content:"";
  position:absolute;
  inset:0;
  border-radius:inherit;
  padding:2px;
  background:linear-gradient(135deg,#7F42E1,#3a5fe5,#FF594F);
  mask:linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0);
  -webkit-mask:linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0);
  mask-composite:exclude;
  -webkit-mask-composite:xor;
  pointer-events:none;
}
.review-badge span{position:relative;z-index:1;text-transform:uppercase;letter-spacing:2.6px;color:rgba(255,255,255,0.85)}
.review-stage{
  position:relative;
  max-width:480px;
  width:100%;
  height:320px;
  border-radius:26px;
  perspective:1200px;
  z-index:1;
}
.review-stage::before{
  content:"";
  position:absolute;
  inset:-10%;
  background-image:var(--review-current);
  background-size:cover;
  background-position:center;
  background-repeat:no-repeat;
  filter:blur(28px);
  opacity:0.28;
  pointer-events:none;
}
.review-card{
  position:relative;
  width:100%;
  height:100%;
  border-radius:inherit;
  box-shadow:0 24px 60px rgba(9,5,30,0.5);
  perspective:inherit;
}
.review-card::before{
  content:"";
  position:absolute;
  inset:0;
  border-radius:inherit;
  border:1px solid rgba(255,255,255,0.08);
  pointer-events:none;
  z-index:1;
}
.review-card-inner{
  position:relative;
  width:100%;
  height:100%;
  border-radius:inherit;
  transform-style:preserve-3d;
  transition:transform 0.7s cubic-bezier(0.65,0.05,0.36,1);
}
.review-card.flip .review-card-inner{transform:rotateY(-180deg);}
.review-face{
  position:absolute;
  inset:0;
  border-radius:inherit;
  padding:18px;
  display:flex;
  align-items:center;
  justify-content:center;
  background:rgba(10,12,32,0.82);
  border:1px solid rgba(255,255,255,0.12);
  backdrop-filter:blur(14px) saturate(200%);
  -webkit-backdrop-filter:blur(14px) saturate(200%);
  box-shadow:0 20px 48px rgba(9,5,30,0.45);
  backface-visibility:hidden;
}
.review-face.review-back{transform:rotateY(180deg);}
.review-face img{
  width:100%;
  height:100%;
  object-fit:contain;
  background:rgba(255,255,255,0.05);
  border-radius:16px;
  padding:12px;
}
.review-control{
  position:absolute;
  top:50%;
  transform:translateY(-50%);
  width:42px;
  height:42px;
  border-radius:50%;
  border:1px solid rgba(255,255,255,0.35);
  background:rgba(10,12,32,0.6);
  color:#fff;
  font-size:24px;
  font-weight:700;
  display:flex;
  align-items:center;
  justify-content:center;
  cursor:pointer;
  transition:transform 0.3s ease, background 0.3s ease, box-shadow 0.3s ease;
  z-index:3;
}
.review-control.prev{left:18px}
.review-control.next{right:18px}
.review-control:hover{
  transform:translateY(-50%) scale(1.05);
  background:rgba(127,66,225,0.9);
  box-shadow:0 14px 28px rgba(127,66,225,0.35);
}
.review-dots{
  position:relative;
  z-index:1;
  display:flex;
  gap:9px;
}
.review-dot{
  width:11px;
  height:11px;
  border-radius:50%;
  border:none;
  background:rgba(255,255,255,0.25);
  cursor:pointer;
  transition:transform 0.3s ease, background 0.3s ease;
}
.review-dot.active{
  background:#fff;
  transform:scale(1.22);
}

@media (max-width: 968px){
  .review-carousel{padding:38px 32px 48px;}
  .review-stage{height:300px}
}
@media (max-width: 600px){
  .review-carousel{padding:28px 20px 40px;}
  .review-stage{height:260px;border-radius:20px}
  .review-face{padding:14px}
  .review-face img{border-radius:12px}
  .review-control{width:36px;height:36px;font-size:18px}
  .review-control.prev{left:12px}
  .review-control.next{right:12px}
}

@supports (-webkit-mask-image: linear-gradient(#000,#000)) or (mask-image: linear-gradient(#000,#000)){
  .app-cutout{
    -webkit-mask-image:linear-gradient(#000,#000);
    mask-image:linear-gradient(#000,#000);
  }
}

@keyframes whatsappPulse{
  0%{transform:scale(1);opacity:0.9;box-shadow:0 0 0 0 rgba(37,211,102,0.35);}
  70%{transform:scale(1.12);opacity:0;box-shadow:0 0 0 18px rgba(37,211,102,0);}
  100%{transform:scale(1);opacity:0;box-shadow:0 0 0 0 rgba(37,211,102,0);}
}

.whatsapp-float{
   position:fixed;
   right:32px;
   bottom:32px;
   z-index:1200;
   width:88px;
   height:88px;
   display:inline-flex;
   align-items:center;
   justify-content:center;
   border-radius:50%;
   background:linear-gradient(135deg,#3516e6 0%,#7F42E1 50%,#e507c6 100%);
   box-shadow:0 22px 56px rgba(12,4,35,0.45),0 0 48px rgba(229,7,198,0.45);
   text-decoration:none;
   transition:transform 0.25s ease,box-shadow 0.25s ease;
   isolation:isolate;
 }
 .whatsapp-float::after{
   content:"";
   position:absolute;
   inset:-12px;
   border-radius:inherit;
   border:1px solid rgba(255,255,255,0.35);
   opacity:0;
   transition:opacity 0.25s ease;
   pointer-events:none;
 }
 .whatsapp-float:hover{
   transform:translateY(-4px) scale(1.03);
   box-shadow:0 26px 60px rgba(12,4,35,0.55),0 0 52px rgba(229,7,198,0.55);
 }
 .whatsapp-float:hover::after{opacity:1;}
 .whatsapp-float::before{
   content:"";
   position:absolute;
   inset:0;
   border-radius:inherit;
   background:radial-gradient(circle,rgba(37,211,102,0.28) 0%,rgba(37,211,102,0) 70%);
   animation:whatsappPulse 2.8s ease-out infinite;
   z-index:-1;
 }
 .whatsapp-float:hover::before{animation-duration:1.8s;}
 
 .whatsapp-float-icon{
    width:72px;
    height:72px;
    border-radius:50%;
    display:flex;
    align-items:center;
    justify-content:center;
    background:radial-gradient(circle at 30% 30%,rgba(255,255,255,0.2),rgba(255,255,255,0));
    box-shadow:inset 0 2px 8px rgba(255,255,255,0.18);
 }
 .whatsapp-float-icon svg{width:68px;height:68px;display:block}
 .whatsapp-tooltip{
   position:absolute;
   right:calc(100% + 16px);
   top:50%;
   transform:translateY(-50%);
   background:rgba(12,4,35,0.92);
   color:#fff;
   font-size:14px;
   font-weight:700;
   padding:10px 16px;
   border-radius:12px;
   border:1px solid rgba(255,255,255,0.12);
   box-shadow:0 18px 36px rgba(12,4,35,0.35);
   opacity:0;
   pointer-events:none;
   transition:opacity 0.2s ease,transform 0.25s ease;
   white-space:nowrap;
 }
 .whatsapp-tooltip::after{
   content:"";
   position:absolute;
   top:50%;
   left:100%;
   transform:translateY(-50%);
   border:8px solid transparent;
   border-left-color:rgba(12,4,35,0.92);
 }
 .whatsapp-float:hover .whatsapp-tooltip,
 .whatsapp-float:focus-visible .whatsapp-tooltip{
   opacity:1;
   transform:translate(-4px,-50%);
 }
 
 @media (max-width:900px){
   .whatsapp-float{width:78px;height:78px;right:24px;bottom:24px}
   .whatsapp-float-icon{width:64px;height:64px}
   .whatsapp-float-icon svg{width:60px;height:60px}
   .whatsapp-tooltip{font-size:13px;padding:8px 14px}
 }
 @media (max-width:768px){
   .whatsapp-float{width:72px;height:72px;right:20px;bottom:20px}
   .whatsapp-float-icon{width:60px;height:60px}
   .whatsapp-float-icon svg{width:56px;height:56px}
   .whatsapp-tooltip{right:calc(100% + 12px)}
 }
 @media (max-width:620px){
   .whatsapp-float{width:66px;height:66px;right:18px;bottom:18px}
   .whatsapp-float-icon{width:52px;height:52px}
   .whatsapp-float-icon svg{width:48px;height:48px}
   .whatsapp-tooltip{display:none}
 }
