/* ==========================================================================
   VIVA MIND — styles.css
   Organizado por: variáveis, reset, componentes, seções, responsividade
   ========================================================================== */

/* --------------------------------------------------------------------------
   1. VARIÁVEIS GLOBAIS
   -------------------------------------------------------------------------- */
:root {
  /* Paleta principal */
  --vm-dark-900:        #07263A;
  --vm-dark-800:        #0A2B3C;
  --vm-dark-700:        #0D3347;
  --vm-dark-600:        #123B45;
  --vm-teal-500:        #2ED3C6;
  --vm-teal-400:        #4EDDD2;
  --vm-teal-300:        #A8F0EC;
  --vm-teal-900:        #0A3D3A;

  /* Neutros */
  --vm-white:           #FFFFFF;
  --vm-gray-50:         #F5F6F7;
  --vm-gray-100:        #EDEDED;
  --vm-gray-200:        #D9D9D9;
  --vm-gray-400:        #A0A0A8;
  --vm-gray-600:        #6E6E73;
  --vm-gray-900:        #111111;

  /* Tipografia */
  --vm-font-display:    'DM Serif Display', Georgia, serif;
  --vm-font-body:       'Plus Jakarta Sans', system-ui, -apple-system, sans-serif;

  /* Tamanhos */
  --vm-text-xs:         0.75rem;
  --vm-text-sm:         0.875rem;
  --vm-text-base:       1rem;
  --vm-text-lg:         1.125rem;
  --vm-text-xl:         1.25rem;
  --vm-text-2xl:        1.5rem;
  --vm-text-3xl:        1.875rem;
  --vm-text-4xl:        2.25rem;
  --vm-text-5xl:        3rem;
  --vm-text-6xl:        3.75rem;
  --vm-text-hero:       clamp(3.5rem, 10vw, 7rem);

  /* Espaçamentos */
  --vm-space-section:   clamp(5rem, 8vw, 8rem);
  --vm-radius-sm:       0.5rem;
  --vm-radius-md:       0.875rem;
  --vm-radius-lg:       1.25rem;
  --vm-radius-xl:       1.75rem;
  --vm-radius-pill:     999px;

  /* Sombras */
  --vm-shadow-sm:       0 1px 3px rgba(0,0,0,.08), 0 1px 2px rgba(0,0,0,.06);
  --vm-shadow-md:       0 4px 16px rgba(0,0,0,.1);
  --vm-shadow-lg:       0 12px 40px rgba(0,0,0,.14);
  --vm-shadow-teal:     0 4px 24px rgba(46,211,198,.25);

  /* Transições */
  --vm-transition:      0.22s cubic-bezier(.4,0,.2,1);
  --vm-transition-slow: 0.4s cubic-bezier(.4,0,.2,1);

  /* Header height */
  --vm-header-h:        72px;
}

/* --------------------------------------------------------------------------
   2. RESET & BASE
   -------------------------------------------------------------------------- */
*, *::before, *::after { box-sizing: border-box; }

html {
  scroll-behavior: smooth;
  scroll-padding-top: var(--vm-header-h);
  -webkit-text-size-adjust: 100%;
}

body {
  font-family: var(--vm-font-body);
  font-size: var(--vm-text-base);
  line-height: 1.7;
  color: var(--vm-gray-900);
  background-color: var(--vm-white);
  overflow-x: hidden;
  -webkit-font-smoothing: antialiased;
}

img { max-width: 100%; height: auto; display: block; }

a { text-decoration: none; color: inherit; }

ul, ol { margin: 0; padding: 0; list-style: none; }

p { margin: 0 0 1rem; }
p:last-child { margin-bottom: 0; }

address { font-style: normal; }

/* Focus visível (acessibilidade) */
:focus-visible {
  outline: 2.5px solid var(--vm-teal-500);
  outline-offset: 3px;
  border-radius: var(--vm-radius-sm);
}

/* --------------------------------------------------------------------------
   3. TIPOGRAFIA
   -------------------------------------------------------------------------- */
.vm-section-header { text-align: center; margin-bottom: 3.5rem; }

.vm-section-header__title {
  font-family: var(--vm-font-display);
  font-size: clamp(var(--vm-text-3xl), 4.5vw, var(--vm-text-5xl));
  line-height: 1.2;
  color: var(--vm-gray-900);
  margin: 0 0 .5rem;
}

.vm-section-header__title--xl {
  font-size: clamp(var(--vm-text-5xl), 8vw, 6rem);
  letter-spacing: -.02em;
  color: var(--vm-dark-800);
}

.vm-section-header__accent {
  display: block;
  color: var(--vm-dark-700);
  font-style: italic;
}
.vm-section-header__accent--teal { display: block; color: var(--vm-teal-500); font-style: italic; }
.vm-section-header__accent--white { display: block; color: var(--vm-white); font-style: italic; }

.vm-section-header__subtitle {
  font-size: var(--vm-text-lg);
  color: var(--vm-gray-600);
  max-width: 680px;
  margin: 1rem auto 0;
  line-height: 1.7;
}
.vm-section-header__subtitle--dark { color: var(--vm-gray-600); }

.vm-section-header--light .vm-section-header__title { color: var(--vm-white); }
.vm-section-header--light .vm-section-header__subtitle { color: rgba(255,255,255,.7); }

.vm-label {
  display: inline-block;
  font-size: var(--vm-text-xs);
  font-weight: 700;
  letter-spacing: .2em;
  text-transform: uppercase;
  color: var(--vm-teal-500);
  margin-bottom: .75rem;
}

.vm-text-body {
  font-size: var(--vm-text-base);
  color: var(--vm-gray-600);
  line-height: 1.8;
  margin-bottom: 1.25rem;
}
.vm-text-body strong { color: var(--vm-gray-900); font-weight: 700; }

/* --------------------------------------------------------------------------
   4. BOTÕES
   -------------------------------------------------------------------------- */
.vm-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: .5rem;
  font-family: var(--vm-font-body);
  font-weight: 700;
  border-radius: var(--vm-radius-pill);
  border: 2px solid transparent;
  cursor: pointer;
  transition: all var(--vm-transition);
  white-space: nowrap;
  position: relative;
  overflow: hidden;
  text-decoration: none;
}

/* Tamanhos */
.vm-btn--sm  { font-size: var(--vm-text-sm);  padding: .45rem 1.1rem; }
.vm-btn--md  { font-size: var(--vm-text-base); padding: .75rem 1.75rem; }
.vm-btn--lg  { font-size: var(--vm-text-base); padding: .9rem 2rem; }
.vm-btn--xl  { font-size: var(--vm-text-lg);   padding: 1.1rem 2.75rem; }

/* Variantes */
.vm-btn--primary {
  background: var(--vm-teal-500);
  color: var(--vm-dark-900);
  border-color: var(--vm-teal-500);
}
.vm-btn--primary:hover, .vm-btn--primary:focus-visible {
  background: var(--vm-teal-400);
  border-color: var(--vm-teal-400);
  transform: translateY(-1px);
  box-shadow: var(--vm-shadow-teal);
}
.vm-btn--primary:active { transform: translateY(0); }

.vm-btn--accent {
  background: var(--vm-teal-500);
  color: var(--vm-dark-900);
  font-size: var(--vm-text-base);
  font-weight: 800;
  padding: 1rem 2.25rem;
  box-shadow: 0 6px 32px rgba(46,211,198,.35);
}
.vm-btn--accent:hover, .vm-btn--accent:focus-visible {
  background: var(--vm-teal-400);
  transform: translateY(-2px);
  box-shadow: 0 8px 40px rgba(46,211,198,.45);
}

.vm-btn--outline-light {
  background: transparent;
  color: var(--vm-white);
  border-color: rgba(255,255,255,.45);
}
.vm-btn--outline-light:hover, .vm-btn--outline-light:focus-visible {
  background: rgba(255,255,255,.1);
  border-color: rgba(255,255,255,.8);
  transform: translateY(-1px);
}

/* --------------------------------------------------------------------------
   5. BADGES
   -------------------------------------------------------------------------- */
.vm-badge {
  display: inline-flex;
  align-items: center;
  gap: .4rem;
  font-size: var(--vm-text-xs);
  font-weight: 700;
  letter-spacing: .12em;
  text-transform: uppercase;
  border-radius: var(--vm-radius-pill);
  padding: .35rem 1rem;
  margin-bottom: 1.5rem;
}

.vm-badge--light {
  background: rgba(255,255,255,.12);
  color: rgba(255,255,255,.9);
  border: 1px solid rgba(255,255,255,.2);
  backdrop-filter: blur(8px);
}

.vm-badge--teal {
  background: rgba(46,211,198,.15);
  color: var(--vm-teal-400);
  border: 1px solid rgba(46,211,198,.3);
}

/* --------------------------------------------------------------------------
   6. CALLOUTS
   -------------------------------------------------------------------------- */
.vm-callout {
  border-radius: var(--vm-radius-lg);
  padding: 1.75rem 2rem;
  margin-top: 2.5rem;
  font-size: var(--vm-text-xl);
  font-family: var(--vm-font-display);
  text-align: center;
  font-style: italic;
}
.vm-callout p { margin: 0; line-height: 1.45; }

.vm-callout--danger {
  background: #fff5f5;
  color: #b91c1c;
  border-left: 4px solid #ef4444;
}
.vm-callout--teal {
  background: rgba(46,211,198,.07);
  color: var(--vm-dark-800);
  border-left: 4px solid var(--vm-teal-500);
}
.vm-callout--teal-light {
  background: rgba(255,255,255,.1);
  color: var(--vm-white);
  border-left: 4px solid var(--vm-teal-500);
}
.vm-callout--dark-border {
  background: rgba(46,211,198,.05);
  color: var(--vm-white);
  border-left: 4px solid var(--vm-teal-500);
}

/* --------------------------------------------------------------------------
   7. SEÇÕES BASE
   -------------------------------------------------------------------------- */
.vm-section {
  padding: var(--vm-space-section) 0;
  position: relative;
}

.vm-section--light { background-color: var(--vm-gray-50); }

.vm-section--dark {
  background-color: var(--vm-dark-800);
  color: var(--vm-white);
}

.vm-section--teal {
  background: linear-gradient(135deg, var(--vm-dark-900) 0%, var(--vm-teal-900) 60%, var(--vm-dark-600) 100%);
  color: var(--vm-white);
}

/* --------------------------------------------------------------------------
   8. HEADER / NAVBAR
   -------------------------------------------------------------------------- */
.vm-header {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  z-index: 1000;
  height: var(--vm-header-h);
  background: rgba(255, 255, 255, 0.95);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  border-bottom: 1px solid var(--vm-gray-100);
  transition: box-shadow var(--vm-transition), background var(--vm-transition);
}

.vm-header.is-scrolled {
  box-shadow: 0 4px 24px rgba(0,0,0,.09);
  background: rgba(255,255,255,.98);
}

.vm-nav {
  display: flex;
  align-items: center;
  height: var(--vm-header-h);
  gap: 1.5rem;
}

/* Logo */
.vm-nav__logo {
  display: flex;
  align-items: center;
  gap: .6rem;
  text-decoration: none;
  flex-shrink: 0;
}
.vm-nav__logo-mark {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 38px;
  height: 38px;
  border-radius: var(--vm-radius-sm);
  background: var(--vm-dark-800);
  color: var(--vm-teal-500);
  font-family: var(--vm-font-display);
  font-size: 1rem;
  font-weight: 700;
  flex-shrink: 0;
}
.vm-nav__logo-text {
  font-family: var(--vm-font-display);
  font-size: var(--vm-text-xl);
  color: var(--vm-dark-800);
  letter-spacing: -.02em;
}

/* Links */
.vm-nav__links {
  display: flex;
  align-items: center;
  gap: 2rem;
  margin: 0 auto;
}

.vm-nav__link {
  font-size: var(--vm-text-sm);
  font-weight: 600;
  color: var(--vm-gray-600);
  text-decoration: none;
  transition: color var(--vm-transition);
  position: relative;
}
.vm-nav__link::after {
  content: '';
  position: absolute;
  bottom: -3px;
  left: 0;
  width: 0;
  height: 2px;
  background: var(--vm-teal-500);
  border-radius: 2px;
  transition: width var(--vm-transition);
}
.vm-nav__link:hover,
.vm-nav__link.is-active { color: var(--vm-dark-800); }
.vm-nav__link:hover::after,
.vm-nav__link.is-active::after { width: 100%; }

/* Actions */
.vm-nav__actions { display: flex; align-items: center; gap: .75rem; margin-left: auto; }

/* Hambúrguer */
.vm-nav__hamburger {
  display: none;
  flex-direction: column;
  gap: 5px;
  background: none;
  border: none;
  cursor: pointer;
  padding: .4rem;
  border-radius: var(--vm-radius-sm);
}
.vm-nav__hamburger span {
  display: block;
  width: 24px;
  height: 2px;
  background: var(--vm-dark-800);
  border-radius: 2px;
  transition: all var(--vm-transition);
}
.vm-nav__hamburger.is-open span:nth-child(1) { transform: translateY(7px) rotate(45deg); }
.vm-nav__hamburger.is-open span:nth-child(2) { opacity: 0; transform: scaleX(0); }
.vm-nav__hamburger.is-open span:nth-child(3) { transform: translateY(-7px) rotate(-45deg); }

/* Mobile menu */
.vm-mobile-menu {
  position: absolute;
  top: 100%;
  left: 0;
  right: 0;
  background: rgba(255,255,255,.98);
  backdrop-filter: blur(16px);
  border-bottom: 1px solid var(--vm-gray-100);
  padding: 1.5rem 1.5rem 2rem;
  box-shadow: var(--vm-shadow-lg);
  animation: slideDown .2s ease-out;
}
.vm-mobile-menu ul { display: flex; flex-direction: column; gap: .25rem; }
.vm-mobile-menu__link {
  display: block;
  padding: .75rem 1rem;
  font-weight: 600;
  font-size: var(--vm-text-base);
  color: var(--vm-gray-900);
  border-radius: var(--vm-radius-sm);
  transition: background var(--vm-transition);
}
.vm-mobile-menu__link:hover { background: var(--vm-gray-50); }

@keyframes slideDown {
  from { opacity: 0; transform: translateY(-8px); }
  to   { opacity: 1; transform: translateY(0); }
}

/* --------------------------------------------------------------------------
   9. HERO
   -------------------------------------------------------------------------- */
.vm-hero {
  min-height: 100vh;
  display: flex;
  align-items: center;
  padding: calc(var(--vm-header-h) + 5rem) 0 6rem;
  position: relative;
  background: linear-gradient(
    135deg,
    #071C2C 0%,
    #07263A 25%,
    #0D3347 45%,
    #0F3D40 65%,
    #123B45 80%,
    #0C4040 100%
  );
  overflow: hidden;
}

/* Ruído de textura */
.vm-hero__noise {
  position: absolute;
  inset: 0;
  background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.04'/%3E%3C/svg%3E");
  pointer-events: none;
  opacity: .35;
}

/* Orbs decorativos */
.vm-hero__orb {
  position: absolute;
  border-radius: 50%;
  pointer-events: none;
  filter: blur(80px);
  opacity: .18;
}
.vm-hero__orb--1 {
  width: 600px; height: 600px;
  background: var(--vm-teal-500);
  top: -200px; right: -150px;
}
.vm-hero__orb--2 {
  width: 400px; height: 400px;
  background: #1a6b7a;
  bottom: -100px; left: -50px;
}

.vm-hero__inner {
  position: relative;
  z-index: 2;
  text-align: center;
  max-width: 860px;
  margin: 0 auto;
}

/* Título hero */
.vm-hero__title {
  font-family: var(--vm-font-display);
  font-size: var(--vm-text-hero);
  line-height: .95;
  letter-spacing: -.03em;
  color: var(--vm-white);
  margin: 0 0 1.5rem;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: .05em;
}
.vm-hero__title-line { display: block; }
.vm-hero__title-line--accent {
  color: var(--vm-teal-500);
  text-shadow: 0 0 80px rgba(46,211,198,.4);
}

.vm-hero__subtitle {
  font-size: clamp(var(--vm-text-base), 2.2vw, var(--vm-text-xl));
  color: rgba(255,255,255,.75);
  line-height: 1.7;
  max-width: 640px;
  margin: 0 auto 2.5rem;
}
.vm-hero__subtitle strong { color: rgba(255,255,255,.95); }

.vm-hero__ctas {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 1rem;
  flex-wrap: wrap;
  margin-bottom: 4rem;
}

/* Stats row */
.vm-hero__stats {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0;
  background: rgba(255,255,255,.06);
  backdrop-filter: blur(12px);
  border: 1px solid rgba(255,255,255,.1);
  border-radius: var(--vm-radius-xl);
  padding: 1.5rem 2.5rem;
  flex-wrap: wrap;
  row-gap: 1rem;
}
.vm-hero__stat {
  display: flex;
  flex-direction: column;
  align-items: center;
  padding: 0 2.5rem;
}
.vm-hero__stat strong {
  font-family: var(--vm-font-display);
  font-size: var(--vm-text-2xl);
  color: var(--vm-teal-500);
  line-height: 1.1;
}
.vm-hero__stat span {
  font-size: var(--vm-text-xs);
  color: rgba(255,255,255,.55);
  text-align: center;
  margin-top: .25rem;
  max-width: 130px;
  line-height: 1.4;
}
.vm-hero__stat-divider {
  width: 1px;
  height: 40px;
  background: rgba(255,255,255,.15);
  flex-shrink: 0;
}

/* Scroll indicator */
.vm-hero__scroll {
  position: absolute;
  bottom: 2.5rem;
  left: 50%;
  transform: translateX(-50%);
  width: 28px; height: 46px;
  border: 2px solid rgba(255,255,255,.2);
  border-radius: 14px;
  display: flex;
  justify-content: center;
  padding-top: 8px;
}
.vm-hero__scroll span {
  display: block;
  width: 4px; height: 8px;
  background: var(--vm-teal-500);
  border-radius: 2px;
  animation: scrollBounce 1.6s infinite;
}
@keyframes scrollBounce {
  0%, 100% { transform: translateY(0); opacity: 1; }
  50%       { transform: translateY(12px); opacity: .3; }
}

/* --------------------------------------------------------------------------
   10. CARDS DE PROBLEMA
   -------------------------------------------------------------------------- */
.vm-problem-card {
  background: var(--vm-white);
  border: 1.5px solid var(--vm-gray-100);
  border-radius: var(--vm-radius-lg);
  padding: 1.75rem 1.5rem;
  height: 100%;
  transition: all var(--vm-transition);
  position: relative;
  overflow: hidden;
}
.vm-problem-card::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 3px;
  background: linear-gradient(90deg, var(--vm-teal-500), var(--vm-teal-300));
  opacity: 0;
  transition: opacity var(--vm-transition);
}
.vm-problem-card:hover {
  border-color: var(--vm-teal-300);
  box-shadow: var(--vm-shadow-md);
  transform: translateY(-3px);
}
.vm-problem-card:hover::before { opacity: 1; }

.vm-problem-card__icon {
  color: var(--vm-teal-500);
  margin-bottom: 1rem;
}
.vm-problem-card__title {
  font-size: var(--vm-text-sm);
  font-weight: 700;
  color: var(--vm-dark-800);
  line-height: 1.45;
  margin: 0;
}

/* --------------------------------------------------------------------------
   11. STAT CARDS (URGÊNCIA)
   -------------------------------------------------------------------------- */
.vm-stat-card {
  background: rgba(255,255,255,.06);
  border: 1px solid rgba(255,255,255,.1);
  border-radius: var(--vm-radius-lg);
  padding: 2.25rem 1.75rem;
  text-align: center;
  backdrop-filter: blur(8px);
  transition: all var(--vm-transition);
}
.vm-stat-card:hover {
  background: rgba(255,255,255,.1);
  border-color: rgba(46,211,198,.3);
  transform: translateY(-3px);
}
.vm-stat-card__number {
  font-family: var(--vm-font-display);
  font-size: var(--vm-text-5xl);
  color: var(--vm-teal-500);
  line-height: 1;
  margin-bottom: .75rem;
}
.vm-stat-card__label {
  font-size: var(--vm-text-sm);
  color: rgba(255,255,255,.65);
  line-height: 1.5;
}

/* Texto urgência */
.vm-urgency-text {
  max-width: 800px;
  margin: 3rem auto 0;
}
.vm-urgency-text p {
  font-size: var(--vm-text-base);
  color: rgba(255,255,255,.72);
  line-height: 1.85;
  margin-bottom: 1.25rem;
}
.vm-urgency-text strong { color: var(--vm-white); font-weight: 700; }
.vm-urgency-text__highlight {
  font-size: var(--vm-text-lg) !important;
  color: rgba(255,255,255,.9) !important;
  border-left: 3px solid var(--vm-teal-500);
  padding-left: 1.25rem;
  font-weight: 600 !important;
}

/* --------------------------------------------------------------------------
   12. IMPACT PHRASE
   -------------------------------------------------------------------------- */
.vm-impact-phrase {
  text-align: center;
  margin-bottom: 4rem;
}
.vm-impact-phrase__text {
  font-family: var(--vm-font-display);
  font-size: clamp(var(--vm-text-3xl), 5vw, var(--vm-text-5xl));
  color: var(--vm-dark-800);
  line-height: 1.2;
  margin: 0;
}

/* --------------------------------------------------------------------------
   13. LIMITATION CARDS (SEM EDUCAÇÃO)
   -------------------------------------------------------------------------- */
.vm-limitation-card {
  background: var(--vm-white);
  border: 1.5px solid var(--vm-gray-100);
  border-radius: var(--vm-radius-lg);
  padding: 2.25rem 2rem;
  height: 100%;
  text-align: center;
  transition: all var(--vm-transition);
  position: relative;
  overflow: hidden;
}
.vm-limitation-card::after {
  content: '';
  position: absolute;
  bottom: 0; left: 0; right: 0;
  height: 3px;
  background: linear-gradient(90deg, var(--vm-teal-500), transparent);
  transform: scaleX(0);
  transform-origin: left;
  transition: transform var(--vm-transition);
}
.vm-limitation-card:hover {
  box-shadow: var(--vm-shadow-lg);
  transform: translateY(-4px);
  border-color: var(--vm-teal-300);
}
.vm-limitation-card:hover::after { transform: scaleX(1); }

.vm-limitation-card__icon {
  color: var(--vm-teal-500);
  margin-bottom: 1.25rem;
  display: inline-block;
}
.vm-limitation-card__title {
  font-family: var(--vm-font-display);
  font-size: var(--vm-text-xl);
  color: var(--vm-dark-800);
  margin-bottom: .75rem;
  line-height: 1.3;
}
.vm-limitation-card__text {
  font-size: var(--vm-text-sm);
  color: var(--vm-gray-600);
  line-height: 1.7;
  margin: 0;
}

/* --------------------------------------------------------------------------
   14. LAW CARDS (LEGISLAÇÃO)
   -------------------------------------------------------------------------- */
.vm-law-card {
  background: rgba(255,255,255,.07);
  border: 1px solid rgba(255,255,255,.12);
  border-radius: var(--vm-radius-md);
  padding: 1.5rem 1.75rem;
  display: flex;
  align-items: center;
  gap: 1.25rem;
  transition: all var(--vm-transition);
  height: 100%;
}
.vm-law-card:hover {
  background: rgba(255,255,255,.12);
  border-color: rgba(46,211,198,.35);
  transform: translateX(4px);
}
.vm-law-card__number {
  font-family: var(--vm-font-display);
  font-size: var(--vm-text-2xl);
  color: var(--vm-teal-500);
  min-width: 40px;
  font-style: italic;
}
.vm-law-card p {
  font-size: var(--vm-text-sm);
  color: rgba(255,255,255,.82);
  font-weight: 500;
  margin: 0;
  line-height: 1.5;
}

/* --------------------------------------------------------------------------
   15. FILTER BADGES (SOLUÇÃO)
   -------------------------------------------------------------------------- */
.vm-badges-group {
  display: flex;
  flex-wrap: wrap;
  gap: .75rem;
  justify-content: center;
  margin-bottom: 2rem;
}
.vm-filter-badge {
  font-size: var(--vm-text-sm);
  font-weight: 700;
  padding: .5rem 1.25rem;
  border-radius: var(--vm-radius-pill);
  border: 1.5px solid var(--vm-gray-200);
  color: var(--vm-gray-600);
  background: var(--vm-white);
  cursor: default;
  transition: all var(--vm-transition);
  user-select: none;
}
.vm-filter-badge--active,
.vm-filter-badge:hover {
  background: var(--vm-dark-800);
  color: var(--vm-teal-500);
  border-color: var(--vm-dark-800);
}

/* --------------------------------------------------------------------------
   16. SOLUTION CARDS
   -------------------------------------------------------------------------- */
.vm-solution-card {
  background: var(--vm-white);
  border: 1.5px solid var(--vm-gray-100);
  border-radius: var(--vm-radius-lg);
  padding: 2rem;
  height: 100%;
  transition: all var(--vm-transition);
  position: relative;
}
.vm-solution-card::before {
  content: '';
  position: absolute;
  inset: 0;
  border-radius: var(--vm-radius-lg);
  background: linear-gradient(135deg, rgba(46,211,198,.04), transparent);
  opacity: 0;
  transition: opacity var(--vm-transition);
}
.vm-solution-card:hover {
  border-color: var(--vm-teal-300);
  box-shadow: var(--vm-shadow-md);
  transform: translateY(-3px);
}
.vm-solution-card:hover::before { opacity: 1; }

.vm-solution-card--featured {
  border-color: rgba(46,211,198,.25);
  background: linear-gradient(135deg, rgba(46,211,198,.03), var(--vm-white) 50%);
}

.vm-solution-card__icon {
  color: var(--vm-teal-500);
  margin-bottom: 1.25rem;
}
.vm-solution-card__title {
  font-size: var(--vm-text-base);
  font-weight: 800;
  color: var(--vm-dark-800);
  margin-bottom: .75rem;
  line-height: 1.35;
}
.vm-solution-card__text {
  font-size: var(--vm-text-sm);
  color: var(--vm-gray-600);
  line-height: 1.75;
  margin: 0;
}

/* Footer da solução */
.vm-solution-footer {
  text-align: center;
  margin-top: 4rem;
}
.vm-solution-footer__phrase {
  font-family: var(--vm-font-display);
  font-size: clamp(var(--vm-text-lg), 2.5vw, var(--vm-text-2xl));
  color: var(--vm-dark-800);
  margin-bottom: 2rem;
  font-style: italic;
  line-height: 1.4;
}
.vm-solution-footer__phrase strong { font-style: normal; color: var(--vm-teal-500); }

/* --------------------------------------------------------------------------
   17. DIFERENCIAIS
   -------------------------------------------------------------------------- */
.vm-differentials-list { margin-top: 2rem; }
.vm-differentials-list__item {
  display: flex;
  align-items: center;
  gap: 1rem;
  padding: 1rem 1.25rem;
  border-radius: var(--vm-radius-md);
  color: rgba(255,255,255,.82);
  font-size: var(--vm-text-base);
  font-weight: 500;
  transition: all var(--vm-transition);
  cursor: default;
  border: 1px solid transparent;
}
.vm-differentials-list__item + .vm-differentials-list__item { margin-top: .5rem; }
.vm-differentials-list__item:hover {
  background: rgba(255,255,255,.06);
  border-color: rgba(46,211,198,.2);
  color: var(--vm-white);
  transform: translateX(4px);
}
.vm-differentials-list__check {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 30px; height: 30px;
  background: rgba(46,211,198,.15);
  border-radius: var(--vm-radius-sm);
  color: var(--vm-teal-500);
  flex-shrink: 0;
}

/* Para quem é */
.vm-for-who {
  background: rgba(255,255,255,.05);
  border: 1px solid rgba(255,255,255,.1);
  border-radius: var(--vm-radius-xl);
  padding: 2.5rem;
}
.vm-for-who__title {
  font-family: var(--vm-font-display);
  font-size: clamp(var(--vm-text-2xl), 3vw, var(--vm-text-3xl));
  color: var(--vm-white);
  line-height: 1.25;
  margin-bottom: 2rem;
}
.vm-for-who__title-accent { color: var(--vm-teal-500); font-style: italic; }

.vm-for-who__list { display: flex; flex-direction: column; gap: 1rem; }
.vm-for-who__item {
  display: flex;
  align-items: flex-start;
  gap: .75rem;
  color: rgba(255,255,255,.75);
  font-size: var(--vm-text-sm);
  line-height: 1.6;
}
.vm-for-who__bullet {
  color: var(--vm-teal-500);
  font-weight: 700;
  font-size: 1.1em;
  flex-shrink: 0;
  line-height: 1.6;
}

/* --------------------------------------------------------------------------
   18. FUNDADORA
   -------------------------------------------------------------------------- */
.vm-founder-photo-block { display: flex; flex-direction: column; gap: 1.5rem; }

/* Placeholder da foto */
.vm-founder-photo {
  width: 100%;
  aspect-ratio: 3/4;
  border-radius: var(--vm-radius-xl);
  overflow: hidden;
  background: linear-gradient(135deg, var(--vm-gray-100), var(--vm-gray-200));
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: .75rem;
  color: var(--vm-gray-400);
  font-size: var(--vm-text-xs);
  border: 2px dashed var(--vm-gray-200);
}
/* Para foto real: remova a classe --placeholder e use uma <img> normal */
.vm-founder-photo--placeholder svg { opacity: .4; }

.vm-founder-identity { }
.vm-founder-identity__name {
  font-family: var(--vm-font-display);
  font-size: var(--vm-text-3xl);
  color: var(--vm-dark-800);
  margin-bottom: .25rem;
  line-height: 1.1;
}
.vm-founder-identity__role {
  font-size: var(--vm-text-sm);
  color: var(--vm-gray-600);
  font-weight: 500;
  margin-bottom: .75rem;
}
.vm-founder-identity__instagram {
  display: inline-flex;
  align-items: center;
  gap: .5rem;
  font-size: var(--vm-text-sm);
  font-weight: 700;
  color: var(--vm-teal-500);
  text-decoration: none;
  transition: opacity var(--vm-transition);
}
.vm-founder-identity__instagram:hover { opacity: .75; }

.vm-founder-quote {
  background: var(--vm-gray-50);
  border-left: 3px solid var(--vm-teal-500);
  border-radius: 0 var(--vm-radius-md) var(--vm-radius-md) 0;
  padding: 1.25rem 1.5rem;
  font-family: var(--vm-font-display);
  font-style: italic;
  font-size: var(--vm-text-base);
  color: var(--vm-dark-700);
  margin: 0;
  line-height: 1.55;
}

/* Credential cards */
.vm-credential-card {
  background: var(--vm-white);
  border: 1.5px solid var(--vm-gray-100);
  border-radius: var(--vm-radius-md);
  padding: 1.5rem;
  height: 100%;
  transition: all var(--vm-transition);
}
.vm-credential-card:hover {
  border-color: var(--vm-teal-300);
  box-shadow: var(--vm-shadow-sm);
  transform: translateY(-2px);
}
.vm-credential-card__title {
  font-size: var(--vm-text-sm);
  font-weight: 800;
  color: var(--vm-dark-800);
  margin-bottom: .4rem;
  line-height: 1.4;
}
.vm-credential-card__text {
  font-size: var(--vm-text-xs);
  color: var(--vm-gray-600);
  line-height: 1.65;
  margin: 0;
}

/* Temas de palestra */
.vm-talk-topics { margin-top: 1.5rem; }
.vm-talk-topics__title {
  font-size: var(--vm-text-xs);
  font-weight: 800;
  letter-spacing: .15em;
  text-transform: uppercase;
  color: var(--vm-gray-600);
  margin-bottom: .75rem;
}
.vm-talk-topics__tags { display: flex; flex-wrap: wrap; gap: .5rem; }
.vm-topic-tag {
  font-size: var(--vm-text-xs);
  font-weight: 600;
  padding: .35rem .9rem;
  border-radius: var(--vm-radius-pill);
  background: var(--vm-gray-50);
  color: var(--vm-dark-700);
  border: 1px solid var(--vm-gray-200);
  transition: all var(--vm-transition);
  cursor: default;
}
.vm-topic-tag:hover {
  background: var(--vm-dark-800);
  color: var(--vm-teal-500);
  border-color: var(--vm-dark-800);
}

/* --------------------------------------------------------------------------
   19. CTA FINAL
   -------------------------------------------------------------------------- */
.vm-cta-section {
  padding: var(--vm-space-section) 0;
  background: linear-gradient(135deg,
    #051520 0%,
    #07263A 30%,
    #0D3347 55%,
    #0A3A3A 75%,
    #0C2E1E 100%
  );
  position: relative;
  overflow: hidden;
  text-align: center;
}
.vm-cta-section__noise {
  position: absolute; inset: 0;
  background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.04'/%3E%3C/svg%3E");
  opacity: .25; pointer-events: none;
}
.vm-cta-section__orb {
  position: absolute;
  width: 700px; height: 700px;
  background: radial-gradient(circle, rgba(46,211,198,.15), transparent 65%);
  top: 50%; left: 50%;
  transform: translate(-50%,-50%);
  pointer-events: none;
}
.vm-cta-section__inner {
  position: relative; z-index: 2;
  max-width: 680px; margin: 0 auto;
}
.vm-cta-section__title {
  font-family: var(--vm-font-display);
  font-size: clamp(var(--vm-text-4xl), 6vw, 5rem);
  color: var(--vm-white);
  line-height: 1.1;
  margin: 0 0 1.5rem;
  letter-spacing: -.02em;
}
.vm-cta-section__text {
  font-size: var(--vm-text-lg);
  color: rgba(255,255,255,.72);
  line-height: 1.75;
  margin-bottom: 2.5rem;
}
.vm-cta-section__text strong { color: rgba(255,255,255,.95); }
.vm-cta-section__actions { margin-bottom: 2.5rem; }
.vm-cta-section__tagline {
  font-size: var(--vm-text-sm);
  color: rgba(255,255,255,.45);
  line-height: 1.7;
  margin: 0;
}
.vm-cta-section__tagline em { font-style: italic; }

/* --------------------------------------------------------------------------
   20. FOOTER
   -------------------------------------------------------------------------- */
.vm-footer {
  background: var(--vm-dark-900);
  padding: 3rem 0 2rem;
  border-top: 1px solid rgba(255,255,255,.07);
}
.vm-footer__brand {
  display: inline-flex;
  align-items: center;
  gap: .6rem;
  margin-bottom: .5rem;
}
.vm-footer__brand-name {
  font-family: var(--vm-font-display);
  font-size: var(--vm-text-xl);
  color: var(--vm-white);
}
.vm-footer__tagline {
  font-size: var(--vm-text-xs);
  color: rgba(255,255,255,.35);
  letter-spacing: .1em;
  text-transform: uppercase;
  margin: 0;
}
.vm-footer__address {
  font-size: var(--vm-text-sm);
  color: rgba(255,255,255,.55);
  line-height: 1.7;
  display: flex;
  flex-direction: column;
  gap: .35rem;
}
.vm-footer__address svg {
  display: inline; vertical-align: middle;
  margin-right: .35rem; margin-top: -2px;
  color: var(--vm-teal-500);
}
.vm-footer__phone {
  display: inline-flex;
  align-items: center;
  gap: .5rem;
  font-size: var(--vm-text-base);
  font-weight: 700;
  color: rgba(255,255,255,.75);
  transition: color var(--vm-transition);
}
.vm-footer__phone svg { color: var(--vm-teal-500); }
.vm-footer__phone:hover { color: var(--vm-teal-500); }
.vm-footer__bottom {
  margin-top: 2.5rem;
  padding-top: 1.5rem;
  border-top: 1px solid rgba(255,255,255,.07);
  text-align: center;
}
.vm-footer__bottom p {
  font-size: var(--vm-text-xs);
  color: rgba(255,255,255,.28);
  margin: 0;
}

/* --------------------------------------------------------------------------
   21. ANIMAÇÕES DE ENTRADA (IntersectionObserver)
   -------------------------------------------------------------------------- */
.vm-reveal {
  opacity: 0;
  transform: translateY(28px);
  transition: opacity .65s cubic-bezier(.4,0,.2,1), transform .65s cubic-bezier(.4,0,.2,1);
}
.vm-reveal.is-visible {
  opacity: 1;
  transform: translateY(0);
}
.vm-reveal--delay-1 { transition-delay: .1s; }
.vm-reveal--delay-2 { transition-delay: .2s; }
.vm-reveal--delay-3 { transition-delay: .3s; }
.vm-reveal--delay-4 { transition-delay: .4s; }
.vm-reveal--delay-5 { transition-delay: .5s; }

/* --------------------------------------------------------------------------
   22. RESPONSIVIDADE
   -------------------------------------------------------------------------- */

/* Tablet landscape (< 992px) */
@media (max-width: 991.98px) {
  :root { --vm-space-section: clamp(4rem, 7vw, 6rem); }

  .vm-nav__links { display: none; }
  .vm-nav__hamburger { display: flex; }
  .vm-nav__actions .vm-btn--primary { display: none; }

  .vm-hero__stats { padding: 1.25rem 1.5rem; }
  .vm-hero__stat { padding: 0 1.25rem; }

  .vm-for-who { margin-top: 0; }
}

/* Tablet portrait (< 768px) */
@media (max-width: 767.98px) {
  .vm-hero { padding-top: calc(var(--vm-header-h) + 3.5rem); padding-bottom: 5rem; }
  .vm-hero__stats { flex-direction: column; gap: 1rem; }
  .vm-hero__stat { padding: .5rem 0; }
  .vm-hero__stat-divider { width: 60px; height: 1px; }
  .vm-hero__ctas { flex-direction: column; align-items: stretch; }
  .vm-hero__ctas .vm-btn { text-align: center; }

  .vm-callout { padding: 1.25rem 1.25rem; font-size: var(--vm-text-base); }

  .vm-section-header { margin-bottom: 2.5rem; }

  .vm-solution-footer__phrase { font-size: var(--vm-text-lg); }

  .vm-cta-section__text { font-size: var(--vm-text-base); }

  .vm-footer .text-md-center,
  .vm-footer .text-md-end { text-align: left !important; }
}

/* Mobile (< 576px) */
@media (max-width: 575.98px) {
  .vm-hero__title { gap: 0; }
  .vm-law-card { flex-direction: column; gap: .5rem; align-items: flex-start; }
  .vm-founder-photo { aspect-ratio: 1/1; }
  .vm-for-who { padding: 1.75rem; }
  .vm-section-header__title--xl { font-size: clamp(3rem, 12vw, 5rem); }
}

/* Print */
@media print {
  .vm-header, .vm-hero__scroll, .vm-nav__hamburger { display: none; }
  body { font-size: 12pt; }
}
