/* ================================================================
   HERO CENTRALIZADO + MOCKUP DE PRODUTO
   Substitui o split antigo por layout central com carrossel de frentes.
   ================================================================ */

.v-hero--center {
  min-height: 0;
  padding: 140px 32px 80px;
  text-align: center;
  overflow: hidden;
}

.v-hero-c__inner {
  position: relative; z-index: 2;
  max-width: 1280px;
  margin: 0 auto;
  display: flex; flex-direction: column; align-items: center;
}

/* pill no topo, fundo translúcido */
.v-hero-c__pin {
  display: inline-flex; align-items: center; gap: 10px;
  padding: 8px 16px;
  background: rgba(255,255,255,.08);
  border: 1px solid rgba(255,255,255,.12);
  border-radius: 999px;
  color: rgba(255,255,255,.9);
  font-family: var(--font-mono);
  font-size: 12px; letter-spacing: .04em;
  transition: background .2s var(--ease-out);
}
.v-hero-c__pin:hover { background: rgba(255,255,255,.14); }
.v-hero-c__pin-dot {
  width: 7px; height: 7px; border-radius: 50%;
  background: var(--vaas-lime);
  box-shadow: 0 0 8px var(--vaas-lime);
}
.v-hero-c__pin-arrow { color: var(--vaas-lime); }

.v-hero-c__title {
  font-family: var(--font-display);
  font-weight: 700;
  font-size: clamp(48px, 6.6vw, 96px);
  line-height: 0.98;
  letter-spacing: -.025em;
  color: #fff;
  margin: 32px 0 0;
  text-wrap: balance;
  max-width: 16ch;
}
.v-hero-c__title em { font-style: normal; color: var(--vaas-lime); }

.v-hero-c__sub {
  font-size: 19px;
  line-height: 1.55;
  color: rgba(255,255,255,.78);
  max-width: 720px;
  margin: 28px 0 0;
  text-wrap: pretty;
}

.v-hero-c__cta-row {
  display: flex; gap: 12px; flex-wrap: wrap; justify-content: center;
  margin-top: 36px;
}

.v-hero-c__proof {
  display: inline-flex; align-items: center; gap: 12px;
  margin-top: 22px;
  font-size: 13px;
  color: rgba(255,255,255,.7);
}
.v-hero-c__proof-stars {
  color: var(--vaas-lime);
  letter-spacing: 2px;
  font-size: 14px;
}
.v-hero-c__proof-txt b { color: #fff; font-weight: 600; }

/* ---------- Tabs (carrossel de frentes) ---------- */

.v-hero-c__tabs-wrap {
  display: flex; align-items: center; gap: 16px;
  margin-top: 64px;
  width: 100%;
  max-width: 720px;
}
.v-hero-c__tabs {
  flex: 1;
  display: flex; gap: 6px;
  background: rgba(255,255,255,.05);
  border: 1px solid rgba(255,255,255,.1);
  border-radius: 999px;
  padding: 6px;
}
.v-hero-c__tab {
  flex: 1;
  display: inline-flex; align-items: center; justify-content: center; gap: 8px;
  padding: 10px 14px;
  border: 0;
  background: transparent;
  color: rgba(255,255,255,.65);
  font-family: var(--font-mono);
  font-size: 12px; letter-spacing: .06em; text-transform: uppercase;
  border-radius: 999px;
  cursor: pointer;
  transition: all .18s var(--ease-out);
  white-space: nowrap;
}
.v-hero-c__tab:hover { color: #fff; }
.v-hero-c__tab--active {
  background: var(--vaas-blue);
  color: #fff;
  box-shadow: 0 4px 12px rgba(0,0,0,.25);
}
.v-hero-c__tab-icon {
  width: 16px; height: 16px;
  filter: brightness(0) invert(1);
  opacity: .8;
}
.v-hero-c__tab--active .v-hero-c__tab-icon { opacity: 1; }

.v-hero-c__nav {
  width: 44px; height: 44px;
  display: inline-flex; align-items: center; justify-content: center;
  border-radius: 50%;
  background: rgba(255,255,255,.06);
  border: 1px solid rgba(255,255,255,.12);
  color: #fff;
  font-size: 18px;
  cursor: pointer;
  transition: all .18s var(--ease-out);
  flex-shrink: 0;
}
.v-hero-c__nav:hover {
  background: var(--vaas-lime);
  color: var(--vaas-blue-deep);
  border-color: var(--vaas-lime);
}

/* ---------- Mockup wrapper ---------- */

.v-hero-c__mock-wrap {
  width: 100%;
  max-width: 1280px;
  margin-top: 36px;
  border-radius: 16px;
  overflow: hidden;
  box-shadow:
    0 60px 120px -30px rgba(0,0,0,.5),
    0 30px 60px -20px rgba(0,0,0,.3),
    0 0 0 1px rgba(255,255,255,.06);
  animation: v-hero-mock-fade 420ms var(--ease-out);
}
@keyframes v-hero-mock-fade {
  from { opacity: 0; transform: translateY(12px) scale(.985); }
  to   { opacity: 1; transform: none; }
}

/* ================================================================
   MOCKUP DO PRODUTO (.v-mock)
   Estilo limpo, claro, dentro da identidade VAAS.
   ================================================================ */

.v-mock {
  background: #f5f7fb;
  color: var(--vaas-blue-deep);
  font-family: var(--font-sans);
  display: flex; flex-direction: column;
  height: 620px;
}

/* topbar */
.v-mock__top {
  display: flex; align-items: center; justify-content: space-between;
  padding: 14px 20px;
  background: #fff;
  border-bottom: 1px solid var(--border);
  flex-shrink: 0;
}
.v-mock__brand { display: flex; align-items: center; gap: 16px; }
.v-mock__logo {
  font-family: var(--font-display);
  font-weight: 800; font-size: 14px;
  letter-spacing: -.02em;
  color: var(--vaas-blue);
  background: var(--vaas-blue);
  color: #fff;
  padding: 6px 10px;
  border-radius: 6px;
  letter-spacing: .04em;
}
.v-mock__crumbs {
  font-size: 13px;
  color: var(--vaas-gray-700);
}
.v-mock__crumbs b { color: var(--vaas-blue-deep); font-weight: 600; }
.v-mock__top-right { display: flex; align-items: center; gap: 12px; }
.v-mock__pill {
  display: inline-flex; align-items: center; gap: 6px;
  padding: 5px 12px;
  font-family: var(--font-mono);
  font-size: 11px; font-weight: 500;
  border-radius: 999px;
  background: var(--vaas-gray-100);
  color: var(--vaas-blue-deep);
}
.v-mock__pill--ok { background: rgba(132,196,26,.12); color: #4f7a0e; }
.v-mock__pill--live {
  background: rgba(0, 87, 255, .08);
  color: var(--vaas-blue);
}
.v-mock__live-dot {
  width: 6px; height: 6px; border-radius: 50%;
  background: var(--vaas-blue);
  animation: v-mock-pulse 1.4s ease-in-out infinite;
}
@keyframes v-mock-pulse {
  0%, 100% { opacity: .35; }
  50%      { opacity: 1; }
}
.v-mock__avatar {
  width: 30px; height: 30px;
  border-radius: 50%;
  display: inline-flex; align-items: center; justify-content: center;
  background: var(--vaas-blue-deep);
  color: var(--vaas-lime);
  font-size: 11px; font-weight: 700;
  font-family: var(--font-mono);
}

/* layout 3 colunas */
.v-mock__body {
  flex: 1;
  display: grid;
  grid-template-columns: 200px 1fr 280px;
  min-height: 0;
}

/* nav esquerdo */
.v-mock__nav {
  background: #fff;
  border-right: 1px solid var(--border);
  padding: 16px 12px;
  display: flex; flex-direction: column; gap: 2px;
  overflow-y: auto;
}
.v-mock__nav-section {
  font-family: var(--font-mono);
  font-size: 10.5px; letter-spacing: .12em; text-transform: uppercase;
  color: var(--vaas-gray-700);
  padding: 14px 10px 6px;
}
.v-mock__nav-section:first-child { padding-top: 4px; }
.v-mock__nav-item {
  font-size: 13px;
  color: var(--vaas-blue-deep);
  padding: 7px 10px;
  border-radius: 6px;
  cursor: default;
}
.v-mock__nav-item--active {
  background: rgba(0, 87, 255, .08);
  color: var(--vaas-blue);
  font-weight: 600;
}

/* main central */
.v-mock__main {
  padding: 20px;
  overflow-y: auto;
  background: #f5f7fb;
}
.v-mock__panel {
  background: #fff;
  border: 1px solid var(--border);
  border-radius: 10px;
  padding: 22px;
  display: flex; flex-direction: column; gap: 18px;
}
.v-mock__panel-h {
  display: flex; justify-content: space-between; align-items: flex-start;
  gap: 12px;
  padding-bottom: 16px;
  border-bottom: 1px solid var(--border);
}
.v-mock__h-eyebrow {
  font-family: var(--font-mono);
  font-size: 11px; letter-spacing: .08em;
  color: var(--vaas-gray-700);
  margin-bottom: 4px;
}
.v-mock__h-title {
  font-family: var(--font-display);
  font-size: 18px; font-weight: 700;
  color: var(--vaas-blue-deep);
  letter-spacing: -.01em;
}
.v-mock__h-meta { display: flex; gap: 6px; flex-wrap: wrap; }
.v-mock__chip {
  font-family: var(--font-mono);
  font-size: 10.5px; letter-spacing: .04em;
  padding: 4px 9px;
  border-radius: 4px;
  background: var(--vaas-gray-100);
  color: var(--vaas-blue-deep);
}
.v-mock__chip--blue { background: rgba(0,87,255,.1); color: var(--vaas-blue); }

/* ---------- COMPLIANCE: checklist ---------- */
.v-mock__check-list { display: flex; flex-direction: column; gap: 1px; background: var(--border); border-radius: 8px; overflow: hidden; }
.v-mock__check {
  display: grid;
  grid-template-columns: 14px 1fr auto;
  gap: 12px; align-items: center;
  background: #fff;
  padding: 12px 14px;
}
.v-mock__check-dot {
  width: 10px; height: 10px; border-radius: 50%;
  background: var(--border-strong);
}
.v-mock__check-dot--ok { background: #84c41a; box-shadow: 0 0 0 3px rgba(132,196,26,.15); }
.v-mock__check-dot--warn { background: #ffc53d; box-shadow: 0 0 0 3px rgba(255,197,61,.18); }
.v-mock__check-l {
  font-size: 13.5px;
  color: var(--vaas-blue-deep);
  font-weight: 500;
}
.v-mock__check-r {
  font-family: var(--font-mono);
  font-size: 11.5px;
  color: var(--vaas-gray-700);
}

/* ---------- FRAUDE: métricas + tabela ---------- */
.v-mock__metrics {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 12px;
  margin-bottom: 4px;
}
.v-mock__metric {
  background: var(--vaas-gray-50);
  border: 1px solid var(--border);
  border-radius: 8px;
  padding: 12px 14px;
}
.v-mock__metric-k {
  font-family: var(--font-display);
  font-size: 22px; font-weight: 700;
  color: var(--vaas-blue);
  letter-spacing: -.01em;
  font-variant-numeric: tabular-nums;
}
.v-mock__metric-l {
  font-family: var(--font-mono);
  font-size: 10.5px; letter-spacing: .04em;
  color: var(--vaas-gray-700);
  margin-top: 2px;
}

.v-mock__table {
  width: 100%;
  border-collapse: collapse;
  font-size: 12.5px;
}
.v-mock__table thead th {
  text-align: left;
  font-family: var(--font-mono);
  font-size: 10.5px; letter-spacing: .08em; text-transform: uppercase;
  color: var(--vaas-gray-700);
  font-weight: 500;
  padding: 8px 10px;
  border-bottom: 1px solid var(--border);
}
.v-mock__table tbody td {
  padding: 10px;
  border-bottom: 1px solid var(--border);
  color: var(--vaas-blue-deep);
}
.v-mock__table tbody tr:last-child td { border-bottom: 0; }
.v-mock__td-mono { font-family: var(--font-mono); font-size: 11.5px; font-variant-numeric: tabular-nums; }
.v-mock__td-muted { color: var(--vaas-gray-700); font-size: 12px; }
.v-mock__score-bar {
  display: inline-block;
  padding: 3px 7px;
  border-radius: 4px;
  background: linear-gradient(to right, currentColor var(--w, 0%), rgba(0,0,0,.04) var(--w, 0%));
  color: var(--vaas-blue);
  background-color: rgba(0,87,255,.06);
  font-weight: 600;
}
.v-mock__score-bar--block { color: #d04848; background-color: rgba(208,72,72,.08); }
.v-mock__score-bar--review { color: #c08a00; background-color: rgba(255,197,61,.12); }
.v-mock__score-bar--pass { color: #4f7a0e; background-color: rgba(132,196,26,.12); }

.v-mock__verdict {
  font-family: var(--font-mono);
  font-size: 10.5px; letter-spacing: .04em;
  padding: 3px 8px;
  border-radius: 4px;
  font-weight: 600;
}
.v-mock__verdict--pass { background: rgba(132,196,26,.14); color: #4f7a0e; }
.v-mock__verdict--review { background: rgba(255,197,61,.18); color: #a16d00; }
.v-mock__verdict--block { background: rgba(208,72,72,.12); color: #b13838; }

/* ---------- CRÉDITO: grid de números + bureaus ---------- */
.v-mock__cred-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 1px;
  background: var(--border);
  border-radius: 8px;
  overflow: hidden;
}
.v-mock__cred-cell {
  background: #fff;
  padding: 14px 16px;
}
.v-mock__cred-l {
  font-family: var(--font-mono);
  font-size: 10.5px; letter-spacing: .08em; text-transform: uppercase;
  color: var(--vaas-gray-700);
  margin-bottom: 6px;
}
.v-mock__cred-v {
  font-family: var(--font-display);
  font-size: 22px; font-weight: 700;
  color: var(--vaas-blue);
  letter-spacing: -.01em;
  font-variant-numeric: tabular-nums;
}
.v-mock__cred-unit { font-size: 12px; font-weight: 500; color: var(--vaas-gray-700); }
.v-mock__cred-meta {
  font-family: var(--font-mono);
  font-size: 10.5px;
  color: var(--vaas-gray-700);
  margin-top: 4px;
}

.v-mock__bureaus-h {
  font-family: var(--font-mono);
  font-size: 11px; letter-spacing: .08em; text-transform: uppercase;
  color: var(--vaas-gray-700);
  margin-bottom: 10px;
}
.v-mock__bureaus-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 8px;
}
.v-mock__bureau {
  background: var(--vaas-gray-50);
  border: 1px solid var(--border);
  border-radius: 6px;
  padding: 10px 12px;
  display: flex; flex-direction: column; gap: 2px;
}
.v-mock__bureau b {
  font-family: var(--font-display);
  font-size: 12.5px; font-weight: 700;
  color: var(--vaas-blue-deep);
}
.v-mock__bureau span {
  font-size: 11.5px;
  color: var(--vaas-gray-700);
}

/* ---------- side direito ---------- */
.v-mock__side {
  background: #fff;
  border-left: 1px solid var(--border);
  padding: 18px;
  display: flex; flex-direction: column; gap: 14px;
  overflow-y: auto;
}
.v-mock__side-h {
  font-family: var(--font-mono);
  font-size: 10.5px; letter-spacing: .12em; text-transform: uppercase;
  color: var(--vaas-gray-700);
}

.v-mock__score {
  display: flex; align-items: center; gap: 14px;
}
.v-mock__score-ring {
  width: 76px; height: 76px;
  position: relative;
  flex-shrink: 0;
}
.v-mock__score-ring svg { width: 100%; height: 100%; }
.v-mock__score-v {
  position: absolute; inset: 0;
  display: flex; align-items: center; justify-content: center;
  font-family: var(--font-display);
  font-size: 22px; font-weight: 700;
  color: var(--vaas-blue);
  font-variant-numeric: tabular-nums;
}
.v-mock__score-meta { display: flex; flex-direction: column; gap: 2px; }
.v-mock__score-tier {
  font-family: var(--font-display);
  font-size: 14px; font-weight: 700;
  color: var(--vaas-blue-deep);
}
.v-mock__score-rec {
  font-size: 11.5px;
  color: var(--vaas-gray-700);
}

.v-mock__side-list { display: flex; flex-direction: column; gap: 1px; background: var(--border); border-radius: 6px; overflow: hidden; }
.v-mock__side-item {
  display: flex; justify-content: space-between; align-items: center;
  background: #fff;
  padding: 9px 12px;
  font-size: 12px;
  color: var(--vaas-gray-700);
}
.v-mock__side-item b { color: var(--vaas-blue-deep); font-weight: 600; }
.v-mock__warn { color: #a16d00 !important; }

.v-mock__cta {
  margin-top: auto;
  background: var(--vaas-blue);
  color: #fff;
  border: 0;
  padding: 12px 16px;
  border-radius: 8px;
  font-weight: 600; font-size: 13.5px;
  cursor: pointer;
  font-family: inherit;
  transition: background .18s var(--ease-out);
}
.v-mock__cta:hover { background: var(--vaas-blue-deep); }

/* signals (fraude) */
.v-mock__signals { display: flex; flex-direction: column; gap: 8px; }
.v-mock__signal {
  background: var(--vaas-gray-50);
  border: 1px solid var(--border);
  border-radius: 6px;
  padding: 9px 11px;
  display: flex; flex-direction: column; gap: 2px;
}
.v-mock__signal b {
  font-family: var(--font-mono);
  font-size: 10.5px; letter-spacing: .06em; text-transform: uppercase;
  color: var(--vaas-blue);
  font-weight: 600;
}
.v-mock__signal span {
  font-size: 12px;
  color: var(--vaas-blue-deep);
}

.v-mock__last {
  background: var(--vaas-gray-50);
  border: 1px solid var(--border);
  border-radius: 6px;
  padding: 11px 12px;
}
.v-mock__last-row {
  display: flex; justify-content: space-between; align-items: center;
  font-size: 12.5px;
  color: var(--vaas-blue-deep);
  font-weight: 500;
  margin-bottom: 4px;
}
.v-mock__last-meta {
  font-family: var(--font-mono);
  font-size: 10.5px;
  color: var(--vaas-gray-700);
}

/* ================================================================
   RESPONSIVO
   ================================================================ */

@media (max-width: 1024px) {
  .v-hero--center { padding: 120px 24px 64px; }
  .v-mock__body { grid-template-columns: 160px 1fr 220px; }
  .v-mock__metrics { grid-template-columns: repeat(2, 1fr); }
  .v-mock__cred-grid { grid-template-columns: repeat(2, 1fr); }
  .v-mock__bureaus-grid { grid-template-columns: repeat(2, 1fr); }
}

@media (max-width: 760px) {
  .v-hero--center { padding: 96px 18px 48px; }
  .v-hero-c__pin {
    font-size: 11px; padding: 6px 12px;
    text-align: left;
    line-height: 1.3;
  }
  .v-hero-c__title { font-size: clamp(36px, 11vw, 56px); margin-top: 24px; }
  .v-hero-c__sub { font-size: 16px; margin-top: 20px; }
  .v-hero-c__cta-row .v-btn { width: 100%; justify-content: center; }
  .v-hero-c__cta-row { width: 100%; }
  .v-hero-c__proof { flex-direction: column; gap: 4px; text-align: center; }
  .v-hero-c__tabs-wrap { margin-top: 40px; gap: 8px; max-width: 100%; }
  .v-hero-c__nav { width: 38px; height: 38px; font-size: 16px; }
  .v-hero-c__tab { padding: 9px 10px; font-size: 11px; }
  .v-hero-c__tab span { display: none; }   /* mobile: só ícone */
  .v-hero-c__tab--active span { display: inline; }  /* salvo o ativo */

  .v-hero-c__mock-wrap { margin-top: 28px; border-radius: 12px; }
  .v-mock { height: 480px; }
  .v-mock__nav { display: none; }
  .v-mock__side { display: none; }
  .v-mock__body { grid-template-columns: 1fr; }
  .v-mock__crumbs { font-size: 11px; }
  .v-mock__panel { padding: 14px; }
  .v-mock__panel-h { flex-direction: column; gap: 10px; }
  .v-mock__h-title { font-size: 15px; }
  .v-mock__metrics { grid-template-columns: 1fr 1fr; gap: 8px; }
  .v-mock__metric-k { font-size: 18px; }
  .v-mock__cred-grid { grid-template-columns: 1fr 1fr; }
  .v-mock__cred-v { font-size: 18px; }
  .v-mock__bureaus-grid { grid-template-columns: 1fr; }
  .v-mock__table thead { display: none; }
  .v-mock__table, .v-mock__table tbody, .v-mock__table tr, .v-mock__table td { display: block; }
  .v-mock__table tr {
    border: 1px solid var(--border);
    border-radius: 8px;
    padding: 10px;
    margin-bottom: 8px;
  }
  .v-mock__table tbody td { border: 0; padding: 3px 0; }
}
