/* ============================================================
   INTERFALA — css/pages/sobre.css
   Página Sobre — editorial, humana, conectiva.
   ============================================================ */

/* ════════════════════════════════════════════════════════════
   1. HERO EDITORIAL (assimétrico)
   ════════════════════════════════════════════════════════════ */
.sb-hero {
  background: var(--color-lavender);
  padding: 96px 0 88px;
  position: relative;
  overflow: hidden;
}
.sb-hero::before {
  content: '';
  position: absolute;
  top: -30%; left: -10%;
  width: 60%; height: 160%;
  background: radial-gradient(ellipse at center, rgba(174,98,255,0.18), transparent 70%);
  pointer-events: none;
}
.sb-hero::after {
  content: '';
  position: absolute;
  bottom: -20%; right: -5%;
  width: 45%; height: 100%;
  background: radial-gradient(ellipse, rgba(0,255,210,0.14), transparent 70%);
  pointer-events: none;
}
.sb-hero-grid {
  display: grid;
  grid-template-columns: 60% 40%;
  gap: 64px;
  align-items: center;
  position: relative;
  z-index: 1;
}
.sb-hero h1 {
  font-family: var(--font-display);
  font-size: clamp(2.4rem, 5.2vw, 4rem);
  font-weight: 800;
  letter-spacing: -0.045em;
  line-height: 1.05;
  color: var(--color-gray-900);
  margin: 14px 0 24px;
}
.sb-hero h1 .line {
  display: block;
  opacity: 0;
  transform: translateY(30px);
  animation: sb-line-in 0.9s cubic-bezier(0.16,1,0.3,1) forwards;
}
.sb-hero h1 .line:nth-child(1) { animation-delay: 0.1s; }
.sb-hero h1 .line:nth-child(2) { animation-delay: 0.32s; }
@keyframes sb-line-in {
  to { opacity: 1; transform: translateY(0); }
}
.sb-hero h1 .grad {
  background: linear-gradient(135deg, var(--color-purple), var(--color-purple-light));
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}
.sb-hero h1 .grad-cy {
  background: linear-gradient(135deg, var(--color-purple), #00ccaa);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}
.sb-hero-intro {
  font-size: 19px;
  line-height: 1.65;
  color: var(--color-gray-700);
  max-width: 540px;
  margin-top: 8px;
}

/* Visual card */
.sb-hero-visual {
  position: relative;
  height: 360px;
  display: flex;
  align-items: center;
  justify-content: center;
}
.sb-card-brasil {
  position: relative;
  width: 280px;
  padding: 40px 32px;
  background: linear-gradient(135deg, var(--color-purple-dark), var(--color-purple));
  border-radius: 24px;
  text-align: center;
  color: #fff;
  box-shadow: 0 30px 80px rgba(113,48,240,0.35);
  z-index: 2;
  transform: rotate(-2deg);
}
.sb-card-brasil::before {
  content: '';
  position: absolute;
  inset: -2px;
  border-radius: 26px;
  background: linear-gradient(135deg, var(--color-cyan), var(--color-purple-light));
  z-index: -1;
  opacity: 0.4;
  filter: blur(20px);
}
.sb-card-brasil-flag {
  font-size: 44px;
  margin-bottom: 14px;
  filter: drop-shadow(0 4px 12px rgba(0,0,0,0.2));
}
.sb-card-brasil-title {
  font-family: var(--font-display);
  font-size: 22px;
  font-weight: 800;
  letter-spacing: -0.02em;
  margin-bottom: 8px;
}
.sb-card-brasil-sub {
  font-size: 14px;
  opacity: 0.8;
  font-family: var(--font-body);
  letter-spacing: 0.04em;
}

/* Floating shapes */
.sb-shape {
  position: absolute;
  border-radius: 12px;
  animation: sb-float 6s ease-in-out infinite;
}
.sb-shape.s1 { top: 8%; left: 5%; width: 38px; height: 38px; background: var(--color-cyan); border-radius: 50%; animation-delay: 0s; }
.sb-shape.s2 { top: 20%; right: 8%; width: 28px; height: 28px; background: var(--color-purple-light); transform: rotate(45deg); animation-delay: 1s; }
.sb-shape.s3 { bottom: 16%; left: 12%; width: 22px; height: 22px; background: var(--color-purple); border-radius: 6px; animation-delay: 2s; }
.sb-shape.s4 { bottom: 8%; right: 12%; width: 44px; height: 44px; background: rgba(0,255,210,0.5); border-radius: 50%; animation-delay: 1.5s; }
.sb-shape.s5 { top: 50%; left: 0%; width: 16px; height: 16px; background: #ff8a3d; border-radius: 50%; animation-delay: 0.8s; }
.sb-shape.s6 { top: 38%; right: 0%; width: 30px; height: 30px; border: 2px solid var(--color-purple); border-radius: 8px; transform: rotate(20deg); animation-delay: 2.5s; }

@keyframes sb-float {
  0%,100% { transform: translateY(0) rotate(0deg); }
  50%     { transform: translateY(-14px) rotate(8deg); }
}

/* ════════════════════════════════════════════════════════════
   2. NÚMEROS DEMONSTRATIVOS
   ════════════════════════════════════════════════════════════ */
.sb-stats {
  background: #fff;
  border-top: 1px solid rgba(16,10,60,0.06);
  padding: 60px 0;
}
.sb-stats-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
}
.sb-stat {
  text-align: center;
  padding: 0 12px;
  position: relative;
  transition: transform 0.25s var(--ease-out);
}
.sb-stat:not(:last-child)::after {
  content: '';
  position: absolute;
  right: 0; top: 18%;
  width: 1px; height: 64%;
  background: rgba(16,10,60,0.08);
}
.sb-stat:hover { transform: translateY(-2px); }
.sb-stat:hover .sb-stat-num { transform: scale(1.05); }
.sb-stat-num {
  display: block;
  font-family: var(--font-display);
  font-size: clamp(2rem, 4vw, 3.4rem);
  font-weight: 800;
  letter-spacing: -0.04em;
  line-height: 1;
  background: linear-gradient(135deg, var(--color-purple), #00ccaa);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  margin-bottom: 10px;
  transition: transform 0.25s var(--ease-out);
}
.sb-stat-label {
  font-size: 13.5px;
  color: var(--color-gray-500);
  font-weight: 500;
  line-height: 1.45;
}

/* ════════════════════════════════════════════════════════════
   3. PROPÓSITO MANIFESTO (DARK)
   ════════════════════════════════════════════════════════════ */
.sb-manifesto {
  background: var(--color-ink);
  padding: 130px 0;
  text-align: center;
  position: relative;
  overflow: hidden;
}
.sb-manifesto::before {
  content: '';
  position: absolute;
  top: 0; left: 50%;
  width: 80%; height: 100%;
  transform: translateX(-50%);
  background:
    radial-gradient(ellipse at 30% 30%, rgba(174,98,255,0.22), transparent 60%),
    radial-gradient(ellipse at 70% 70%, rgba(0,255,210,0.12), transparent 60%);
  pointer-events: none;
}
.sb-manifesto-inner {
  position: relative;
  z-index: 1;
  max-width: 800px;
  margin: 0 auto;
  padding: 0 24px;
}
.sb-manifesto h2 {
  font-family: var(--font-display);
  font-size: clamp(2.2rem, 4.4vw, 3rem);
  font-weight: 800;
  letter-spacing: -0.04em;
  line-height: 1.1;
  color: #fff;
  margin: 18px 0 28px;
}
.sb-manifesto-text {
  font-family: var(--font-display);
  font-size: 22px;
  line-height: 1.7;
  color: rgba(255,255,255,0.82);
  font-weight: 400;
  margin-bottom: 36px;
}
.sb-manifesto-text strong {
  color: #fff;
  font-weight: 600;
}
.sb-manifesto-line {
  width: 80px;
  height: 2px;
  margin: 0 auto 24px;
  background: linear-gradient(90deg, transparent, var(--color-cyan), transparent);
  border-radius: 99px;
}
.sb-manifesto-quote {
  font-family: var(--font-display);
  font-size: 17px;
  color: rgba(255,255,255,0.62);
  font-style: italic;
  letter-spacing: -0.01em;
}

.sb-manifesto .section-badge {
  background: rgba(0,255,210,0.1);
  border-color: rgba(0,255,210,0.22);
  color: var(--color-cyan);
}

/* ════════════════════════════════════════════════════════════
   4. TIMELINE
   ════════════════════════════════════════════════════════════ */
.sb-section {
  padding: 110px 0;
  position: relative;
}
.sb-section.alt { background: var(--color-lavender); }
.sb-section.gray { background: var(--color-gray-100); }

.sb-section-head {
  text-align: center;
  max-width: 720px;
  margin: 0 auto 64px;
}
.sb-section-head h2 {
  font-family: var(--font-display);
  font-size: clamp(2rem, 3.8vw, 2.8rem);
  font-weight: 800;
  letter-spacing: -0.035em;
  line-height: 1.12;
  margin: 12px 0 16px;
}
.sb-section-head h2 .grad {
  background: linear-gradient(135deg, var(--color-purple), var(--color-purple-light));
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
}
.sb-section-head p {
  font-size: 17px;
  color: var(--color-gray-700);
  line-height: 1.65;
}

/* Timeline horizontal */
.sb-timeline {
  position: relative;
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 28px;
  margin-top: 40px;
}
.sb-timeline::before {
  content: '';
  position: absolute;
  top: 44px;
  left: 12.5%;
  right: 12.5%;
  height: 3px;
  background: linear-gradient(90deg, rgba(174,98,255,0.35) 0%, var(--color-purple) 50%, var(--color-cyan) 100%);
  border-radius: 99px;
  z-index: 0;
  transform-origin: left;
  transform: scaleX(0);
  transition: transform 1.6s cubic-bezier(0.65,0,0.35,1);
}
.sb-timeline.in-view::before { transform: scaleX(1); }

.sb-tl-card {
  background: #fff;
  border: 1px solid var(--color-gray-300);
  border-radius: 18px;
  padding: 28px 22px 24px;
  text-align: center;
  position: relative;
  z-index: 1;
  transition: transform 0.25s var(--ease-out), box-shadow 0.25s, border-color 0.25s;
}
.sb-tl-card:hover {
  transform: translateY(-4px);
  border-color: rgba(113,48,240,0.25);
  box-shadow: 0 18px 48px rgba(113,48,240,0.14);
}
.sb-tl-icon {
  width: 88px; height: 88px;
  margin: 0 auto 18px;
  background: #fff;
  border-radius: 50%;
  border: 3px solid;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 36px;
  position: relative;
  z-index: 2;
  transition: transform 0.3s var(--ease-out);
}
.sb-tl-card:hover .sb-tl-icon { transform: scale(1.06) rotate(-4deg); }

.sb-tl-card.c1 .sb-tl-icon { border-color: var(--color-purple-light); box-shadow: 0 0 0 6px rgba(174,98,255,0.12); }
.sb-tl-card.c2 .sb-tl-icon { border-color: var(--color-purple); box-shadow: 0 0 0 6px rgba(113,48,240,0.14); }
.sb-tl-card.c3 .sb-tl-icon { border-color: var(--color-purple); box-shadow: 0 0 0 8px rgba(113,48,240,0.2), 0 12px 30px rgba(113,48,240,0.25); }
.sb-tl-card.c4 .sb-tl-icon { border-color: var(--color-cyan); box-shadow: 0 0 0 6px rgba(0,255,210,0.18); }

.sb-tl-year {
  font-family: var(--font-display);
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--color-purple);
  margin-bottom: 6px;
}
.sb-tl-card.c4 .sb-tl-year { color: var(--color-cyan); }
.sb-tl-title {
  font-family: var(--font-display);
  font-size: 17px;
  font-weight: 700;
  letter-spacing: -0.02em;
  color: var(--color-gray-900);
  margin-bottom: 10px;
}
.sb-tl-desc {
  font-size: 13.5px;
  color: var(--color-gray-700);
  line-height: 1.55;
}

/* ════════════════════════════════════════════════════════════
   5. MISSÃO / VISÃO / VALORES
   ════════════════════════════════════════════════════════════ */
.sb-mv-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 24px;
  margin-bottom: 80px;
}
.sb-mv-card {
  background: #fff;
  border-radius: 20px;
  padding: 44px 40px 40px 56px;
  position: relative;
  box-shadow: 0 14px 50px rgba(16,10,60,0.06);
  overflow: hidden;
  transition: transform 0.25s var(--ease-out), box-shadow 0.25s;
}
.sb-mv-card:hover {
  transform: translateY(-4px);
  box-shadow: 0 24px 60px rgba(16,10,60,0.1);
}
.sb-mv-card::before {
  content: '';
  position: absolute;
  left: 0; top: 0; bottom: 0;
  width: 4px;
}
.sb-mv-card.miss::before { background: linear-gradient(180deg, var(--color-purple), var(--color-purple-light)); }
.sb-mv-card.vis::before { background: linear-gradient(180deg, var(--color-cyan), #00ccaa); }
.sb-mv-eyebrow {
  font-family: var(--font-display);
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  margin-bottom: 14px;
}
.sb-mv-card.miss .sb-mv-eyebrow { color: var(--color-purple); }
.sb-mv-card.vis .sb-mv-eyebrow { color: var(--color-cyan); }
.sb-mv-title {
  font-family: var(--font-display);
  font-size: 22px;
  font-weight: 700;
  letter-spacing: -0.025em;
  color: var(--color-gray-900);
  margin-bottom: 14px;
}
.sb-mv-text {
  font-size: 15.5px;
  color: var(--color-gray-700);
  line-height: 1.7;
}

/* Valores */
.sb-values-head {
  text-align: center;
  margin-bottom: 36px;
}
.sb-values-head h3 {
  font-family: var(--font-display);
  font-size: clamp(1.5rem, 2.6vw, 2rem);
  font-weight: 700;
  letter-spacing: -0.03em;
  color: var(--color-gray-900);
  margin-bottom: 6px;
}
.sb-values-head p {
  font-size: 15px;
  color: var(--color-gray-500);
}

.sb-values {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 20px;
}
.sb-value {
  background: #fff;
  border: 1px solid var(--color-gray-300);
  border-radius: 18px;
  padding: 28px;
  position: relative;
  transition: transform 0.25s var(--ease-out), border-color 0.25s, box-shadow 0.25s;
}
.sb-value:hover {
  transform: translateY(-4px);
  border-color: var(--color-purple);
  box-shadow: 0 18px 50px rgba(113,48,240,0.14);
}
.sb-value:hover .sb-value-ico {
  transform: scale(1.08) rotate(-4deg);
}
.sb-value-num {
  font-family: var(--font-display);
  font-size: 48px;
  font-weight: 800;
  letter-spacing: -0.04em;
  line-height: 1;
  background: linear-gradient(135deg, var(--color-purple), var(--color-purple-light));
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  position: absolute;
  top: 18px;
  right: 22px;
  opacity: 0.35;
}
.sb-value-ico {
  width: 44px; height: 44px;
  border-radius: 12px;
  background: rgba(113,48,240,0.1);
  color: var(--color-purple);
  display: flex; align-items: center; justify-content: center;
  margin-bottom: 18px;
  transition: transform 0.3s var(--ease-out);
}
.sb-value-ico svg { width: 22px; height: 22px; }
.sb-value-title {
  font-family: var(--font-display);
  font-size: 15px;
  font-weight: 700;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--color-gray-900);
  margin-bottom: 8px;
}
.sb-value-desc {
  font-size: 14.5px;
  color: var(--color-gray-700);
  line-height: 1.55;
}

/* ════════════════════════════════════════════════════════════
   6. EQUIPE
   ════════════════════════════════════════════════════════════ */
.sb-team {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 80px;
  align-items: center;
}
.sb-team-text h2 {
  font-family: var(--font-display);
  font-size: clamp(2rem, 3.6vw, 2.6rem);
  font-weight: 800;
  letter-spacing: -0.035em;
  line-height: 1.15;
  margin: 12px 0 22px;
}
.sb-team-text h2 .grad {
  background: linear-gradient(135deg, var(--color-purple), var(--color-purple-light));
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
}
.sb-team-text p {
  font-size: 16px;
  line-height: 1.75;
  color: var(--color-gray-700);
  margin-bottom: 18px;
}
.sb-team-text p:last-child { margin-bottom: 0; }

/* Avatar grid abstrato */
.sb-team-visual {
  position: relative;
  width: 100%;
  aspect-ratio: 1 / 1;
  max-width: 460px;
  margin: 0 auto;
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  grid-template-rows: repeat(3, 1fr);
  gap: 16px;
  padding: 12px;
}
.sb-av {
  border-radius: 50%;
  position: relative;
  align-self: center;
  justify-self: center;
  animation: sb-pulse-soft 4s ease-in-out infinite;
  box-shadow: 0 12px 30px rgba(113,48,240,0.18);
}
.sb-av::after {
  content: '';
  position: absolute;
  inset: -3px;
  border-radius: 50%;
  border: 1.5px solid rgba(255,255,255,0.6);
  pointer-events: none;
}

/* Sizes - varied for rhythm */
.sb-av:nth-child(1) { width: 80%; height: 80%; }
.sb-av:nth-child(2) { width: 95%; height: 95%; transform: rotate(4deg); }
.sb-av:nth-child(3) { width: 70%; height: 70%; transform: rotate(-6deg); }
.sb-av:nth-child(4) { width: 92%; height: 92%; transform: rotate(-3deg); }
.sb-av:nth-child(5) { width: 100%; height: 100%; transform: rotate(2deg); }
.sb-av:nth-child(6) { width: 78%; height: 78%; transform: rotate(8deg); }
.sb-av:nth-child(7) { width: 72%; height: 72%; transform: rotate(-5deg); }
.sb-av:nth-child(8) { width: 90%; height: 90%; transform: rotate(3deg); }
.sb-av:nth-child(9) { width: 84%; height: 84%; transform: rotate(-7deg); }

/* Gradients */
.sb-av.g1 { background: linear-gradient(135deg, #7130f0, #ae62ff); animation-delay: 0s; }
.sb-av.g2 { background: linear-gradient(135deg, #00ffd2, #00ccaa); animation-delay: 0.4s; }
.sb-av.g3 { background: linear-gradient(135deg, #ec4899, #f59e0b); animation-delay: 0.8s; }
.sb-av.g4 { background: linear-gradient(135deg, #ae62ff, #ec4899); animation-delay: 0.2s; }
.sb-av.g5 { background: linear-gradient(135deg, #7130f0, #00ccaa); animation-delay: 0.6s; }
.sb-av.g6 { background: linear-gradient(135deg, #f59e0b, #ec4899); animation-delay: 1s; }
.sb-av.g7 { background: linear-gradient(135deg, #00ccaa, #7130f0); animation-delay: 0.3s; }
.sb-av.g8 { background: linear-gradient(135deg, #ae62ff, #00ffd2); animation-delay: 0.9s; }
.sb-av.g9 { background: linear-gradient(135deg, #7130f0, #ec4899); animation-delay: 0.5s; }

@keyframes sb-pulse-soft {
  0%,100% { box-shadow: 0 12px 30px rgba(113,48,240,0.18); }
  50%     { box-shadow: 0 16px 40px rgba(113,48,240,0.32); }
}

/* connecting net */
.sb-team-visual::before {
  content: '';
  position: absolute;
  inset: 0;
  background-image:
    radial-gradient(circle at 50% 50%, rgba(113,48,240,0.06) 0%, transparent 60%);
  pointer-events: none;
  z-index: -1;
}

/* ════════════════════════════════════════════════════════════
   7. STACK TECNOLÓGICA (DARK)
   ════════════════════════════════════════════════════════════ */
.sb-tech {
  background: var(--color-ink-soft);
  padding: 110px 0;
  position: relative;
  overflow: hidden;
}
.sb-tech::before {
  content: '';
  position: absolute;
  top: -20%; left: -10%;
  width: 50%; height: 80%;
  background: radial-gradient(ellipse, rgba(113,48,240,0.28), transparent 70%);
  pointer-events: none;
}
.sb-tech::after {
  content: '';
  position: absolute;
  bottom: -20%; right: -10%;
  width: 50%; height: 80%;
  background: radial-gradient(ellipse, rgba(0,255,210,0.16), transparent 70%);
  pointer-events: none;
}
.sb-tech .container {
  position: relative;
  z-index: 1;
}
.sb-tech .sb-section-head h2 { color: #fff; }
.sb-tech .sb-section-head h2 .grad {
  background: linear-gradient(135deg, var(--color-cyan), #b8a4ff);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
}
.sb-tech .sb-section-head p { color: rgba(255,255,255,0.7); }
.sb-tech .section-badge {
  background: rgba(0,255,210,0.1);
  border-color: rgba(0,255,210,0.22);
  color: var(--color-cyan);
}

.sb-tech-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 20px;
}
.sb-tech-card {
  background: rgba(255,255,255,0.04);
  border: 1px solid rgba(255,255,255,0.1);
  border-radius: 18px;
  padding: 32px 26px;
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  transition: transform 0.25s var(--ease-out), border-color 0.25s, background 0.25s;
}
.sb-tech-card:hover {
  transform: translateY(-4px);
  border-color: rgba(0,255,210,0.4);
  background: rgba(255,255,255,0.06);
}
.sb-tech-icon {
  font-size: 32px;
  margin-bottom: 16px;
  display: inline-block;
  filter: drop-shadow(0 4px 10px rgba(0,255,210,0.3));
}
.sb-tech-title {
  font-family: var(--font-display);
  font-size: 17px;
  font-weight: 700;
  letter-spacing: -0.02em;
  color: #fff;
  margin-bottom: 10px;
}
.sb-tech-desc {
  font-size: 14px;
  color: rgba(255,255,255,0.7);
  line-height: 1.6;
}

/* ════════════════════════════════════════════════════════════
   8. CITAÇÃO
   ════════════════════════════════════════════════════════════ */
.sb-quote {
  background: #fff;
  padding: 110px 0;
  text-align: center;
  position: relative;
  overflow: hidden;
}
.sb-quote::before {
  content: '';
  position: absolute;
  top: 0; left: 50%;
  transform: translateX(-50%);
  width: 80%; max-width: 700px; height: 100%;
  background: radial-gradient(ellipse at center, rgba(0,255,210,0.06), transparent 70%);
  pointer-events: none;
}
.sb-quote-inner {
  max-width: 800px;
  margin: 0 auto;
  padding: 0 24px;
  position: relative;
}
.sb-quote-mark {
  font-family: 'Sora', serif;
  font-size: 200px;
  font-weight: 800;
  line-height: 0.8;
  color: var(--color-cyan);
  opacity: 0.18;
  position: absolute;
  top: -20px;
  left: -10px;
  user-select: none;
  animation: sb-quote-rot 8s ease-in-out infinite;
}
.sb-quote-mark.r {
  left: auto;
  right: -10px;
  top: auto;
  bottom: 80px;
  transform: scaleX(-1);
  animation-delay: 4s;
}
@keyframes sb-quote-rot {
  0%,100% { transform: rotate(-2deg); }
  50%     { transform: rotate(2deg); }
}
.sb-quote-text {
  font-family: var(--font-display);
  font-size: clamp(1.5rem, 2.6vw, 2rem);
  font-weight: 400;
  font-style: italic;
  line-height: 1.45;
  letter-spacing: -0.02em;
  color: var(--color-gray-900);
  margin: 24px 0 28px;
  position: relative;
  z-index: 1;
}
.sb-quote-attr {
  font-family: var(--font-display);
  font-size: 14px;
  color: var(--color-gray-500);
  font-weight: 500;
  margin-bottom: 24px;
}
.sb-quote-line {
  width: 60px; height: 2px;
  margin: 0 auto;
  background: linear-gradient(90deg, transparent, var(--color-cyan), transparent);
  border-radius: 99px;
}

/* ════════════════════════════════════════════════════════════
   9. PARCEIROS
   ════════════════════════════════════════════════════════════ */
.sb-partners {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: 16px;
}
.sb-partner {
  background: #fff;
  border: 1px solid var(--color-gray-300);
  border-radius: 14px;
  padding: 28px 20px;
  text-align: center;
  transition: transform 0.25s var(--ease-out), border-color 0.25s, box-shadow 0.25s;
}
.sb-partner:hover {
  transform: translateY(-4px);
  border-color: var(--color-purple);
  box-shadow: 0 14px 36px rgba(113,48,240,0.12);
}
.sb-partner-ico {
  width: 56px; height: 56px;
  margin: 0 auto 14px;
  border-radius: 14px;
  background: linear-gradient(135deg, rgba(113,48,240,0.1), rgba(174,98,255,0.16));
  display: flex; align-items: center; justify-content: center;
  color: var(--color-purple);
  transition: background 0.25s;
}
.sb-partner:hover .sb-partner-ico {
  background: linear-gradient(135deg, var(--color-purple), var(--color-purple-light));
  color: #fff;
}
.sb-partner-ico svg { width: 26px; height: 26px; }
.sb-partner-title {
  font-family: var(--font-display);
  font-size: 14px;
  font-weight: 700;
  letter-spacing: -0.01em;
  color: var(--color-gray-900);
  margin-bottom: 4px;
  line-height: 1.3;
}
.sb-partner-desc {
  font-size: 12.5px;
  color: var(--color-gray-500);
  line-height: 1.4;
}

/* ════════════════════════════════════════════════════════════
   10. CTA FINAL
   ════════════════════════════════════════════════════════════ */
.sb-cta {
  padding: 130px 0;
  background: linear-gradient(135deg, var(--color-purple-dark) 0%, #4d387d 60%, var(--color-purple) 100%);
  color: #fff;
  text-align: center;
  position: relative;
  overflow: hidden;
}
.sb-cta::before {
  content: '';
  position: absolute;
  top: -50%; left: -10%;
  width: 60%; height: 200%;
  background: radial-gradient(ellipse, rgba(174,98,255,0.4), transparent 60%);
  pointer-events: none;
}
.sb-cta::after {
  content: '';
  position: absolute;
  bottom: -50%; right: -10%;
  width: 60%; height: 200%;
  background: radial-gradient(ellipse, rgba(0,255,210,0.18), transparent 60%);
  pointer-events: none;
}
.sb-cta-inner {
  max-width: 720px;
  margin: 0 auto;
  padding: 0 24px;
  position: relative;
  z-index: 1;
}
.sb-cta .section-badge {
  background: rgba(0,255,210,0.12);
  border-color: rgba(0,255,210,0.3);
  color: var(--color-cyan);
  margin-bottom: 24px;
}
.sb-cta h2 {
  font-family: var(--font-display);
  font-size: clamp(2rem, 4.4vw, 3rem);
  font-weight: 800;
  letter-spacing: -0.04em;
  color: #fff;
  margin-bottom: 18px;
  line-height: 1.1;
}
.sb-cta h2 .grad {
  background: linear-gradient(135deg, var(--color-cyan), #b8a4ff);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
}
.sb-cta p {
  font-size: 18px;
  color: rgba(255,255,255,0.82);
  line-height: 1.6;
  max-width: 560px;
  margin: 0 auto 36px;
}
.sb-cta-btns {
  display: flex; gap: 14px; justify-content: center; flex-wrap: wrap;
}
.sb-cta .btn-cta-white,
.sb-cta .btn-cta-outline {
  display: inline-flex; align-items: center; gap: 8px;
  font-family: var(--font-display);
  font-weight: 600;
  font-size: 16px;
  padding: 16px 32px;
  border-radius: 12px;
  text-decoration: none;
  transition: all 0.2s var(--ease-out);
  letter-spacing: -0.01em;
}
.sb-cta .btn-cta-white {
  background: #fff;
  color: var(--color-purple);
  box-shadow: 0 12px 32px rgba(0,0,0,0.2);
}
.sb-cta .btn-cta-white:hover {
  transform: translateY(-3px);
  box-shadow: 0 18px 44px rgba(255,255,255,0.25);
}
.sb-cta .btn-cta-outline {
  background: transparent;
  color: #fff;
  border: 1.5px solid rgba(255,255,255,0.4);
}
.sb-cta .btn-cta-outline:hover {
  background: rgba(255,255,255,0.08);
  border-color: #fff;
}

/* ════════════════════════════════════════════════════════════
   FADE-UP
   ════════════════════════════════════════════════════════════ */
.fade-up {
  opacity: 0;
  transform: translateY(30px);
  transition: opacity 0.8s cubic-bezier(0.16,1,0.3,1), transform 0.8s cubic-bezier(0.16,1,0.3,1);
}
.fade-up.visible { opacity: 1; transform: translateY(0); }
.fade-up.d1 { transition-delay: 0.1s; }
.fade-up.d2 { transition-delay: 0.2s; }
.fade-up.d3 { transition-delay: 0.3s; }
.fade-up.d4 { transition-delay: 0.4s; }
.fade-up.d5 { transition-delay: 0.5s; }
.fade-up.d6 { transition-delay: 0.6s; }

/* ════════════════════════════════════════════════════════════
   RESPONSIVE
   ════════════════════════════════════════════════════════════ */
@media (max-width: 1023px) {
  .sb-hero-grid { grid-template-columns: 1fr; gap: 48px; }
  .sb-hero-visual { height: 320px; order: -1; }
  .sb-stats-grid { grid-template-columns: repeat(2, 1fr); gap: 32px 0; }
  .sb-stat:nth-child(2)::after { display: none; }
  .sb-timeline { grid-template-columns: repeat(2, 1fr); gap: 32px; }
  .sb-timeline::before { display: none; }
  .sb-mv-grid { grid-template-columns: 1fr; }
  .sb-values { grid-template-columns: repeat(2, 1fr); }
  .sb-team { grid-template-columns: 1fr; gap: 56px; }
  .sb-tech-grid { grid-template-columns: repeat(2, 1fr); }
  .sb-partners { grid-template-columns: repeat(3, 1fr); }
  .sb-section { padding: 80px 0; }
}
@media (max-width: 640px) {
  .sb-hero { padding: 64px 0; }
  .sb-stats { padding: 40px 0; }
  .sb-stats-grid { grid-template-columns: 1fr 1fr; }
  .sb-manifesto { padding: 90px 0; }
  .sb-timeline { grid-template-columns: 1fr; }
  .sb-values { grid-template-columns: 1fr; }
  .sb-tech-grid { grid-template-columns: 1fr; }
  .sb-partners { grid-template-columns: repeat(2, 1fr); }
  .sb-partners .sb-partner:last-child { grid-column: 1 / -1; }
  .sb-mv-card { padding: 32px 28px 28px 40px; }
  .sb-cta { padding: 90px 0; }
  .sb-quote { padding: 80px 0; }
  .sb-quote-mark { font-size: 140px; }
}
