/* =========================================================
   Base Vem Forte — styles.css refatorado
   Paleta clara: azul-marinho, verde, amarelo pontual e branco
   Ajuste: botões maiores em toda a plataforma
   ========================================================= */


/* =======================
   1) Tokens / Base
   ======================= */

:root {
  /* Cores da marca */
  --bvf-navy-950: #031427;
  --bvf-navy-900: #061b36;
  --bvf-navy-800: #08264b;
  --bvf-navy-700: #0b315f;

  --bvf-green-800: #035c29;
  --bvf-green-700: #047a32;
  --bvf-green-600: #079d3f;
  --bvf-green-500: #10b84c;
  --bvf-green-soft: #e8f8ee;

  --bvf-yellow-700: #a87900;
  --bvf-yellow-600: #d7aa00;
  --bvf-yellow-500: #f4c400;
  --bvf-yellow-soft: #fff8dc;

  --bvf-blue-soft: #eef6ff;
  --bvf-bg: #f4f7fb;
  --bvf-card: #ffffff;
  --bvf-border: #dfe6ef;
  --bvf-border-soft: #edf1f6;

  --bvf-text: #0b1728;
  --bvf-muted: #64748b;
  --bvf-muted-2: #94a3b8;

  --bvf-red: #dc2626;
  --bvf-red-soft: #fee2e2;
  --bvf-cyan: #0891b2;
  --bvf-cyan-soft: #e0f7fb;

  /* Compatibilidade com nomes antigos */
  --fa-bg: var(--bvf-bg);
  --fa-card: var(--bvf-card);
  --fa-border: var(--bvf-border);
  --fa-nav-a: #ffffff;
  --fa-nav-b: #ffffff;

  --fa-white: var(--bvf-text);
  --fa-muted: var(--bvf-muted);

  --fa-green: var(--bvf-green-600);
  --fa-red: var(--bvf-red);
  --fa-yellow: var(--bvf-yellow-500);
  --fa-cyan: var(--bvf-cyan);

  --fa-shadow-lg: 0 18px 45px rgba(3, 20, 39, .10);
  --fa-shadow-md: 0 10px 24px rgba(3, 20, 39, .08);
  --fa-shadow-sm: 0 4px 12px rgba(3, 20, 39, .06);

  /* Tipografia desktop */
  --fa-font-body: .92rem;
  --fa-font-heading: .95rem;
  --fa-font-btn: .92rem;
  --fa-font-btn-sm: .86rem;
  --fa-font-legend: .82rem;
  --fa-font-badge: .78rem;

  --fa-btn-pad-y: .72rem;
  --fa-btn-pad-x: 1.08rem;

  --fa-btn-pad-y-sm: .56rem;
  --fa-btn-pad-x-sm: .88rem;

  /* Mobile */
  --fa-font-body-m: .78rem;
  --fa-font-heading-m: .78rem;
  --fa-font-btn-m: .86rem;
  --fa-font-btn-sm-m: .80rem;
  --fa-font-legend-m: .72rem;
  --fa-font-badge-m: .70rem;

  --fa-btn-pad-y-m: .66rem;
  --fa-btn-pad-x-m: .92rem;

  --fa-btn-pad-y-sm-m: .52rem;
  --fa-btn-pad-x-sm-m: .76rem;

  --bvf-radius-xl: 28px;
  --bvf-radius-lg: 18px;
  --bvf-radius-md: 14px;
  --bvf-radius-sm: 10px;
}


/* =======================
   2) Base / Globais
   ======================= */

* {
  box-sizing: border-box;
}

html {
  scroll-behavior: smooth;
}

body {
  background:
    radial-gradient(circle at top left, rgba(7, 157, 63, .065), transparent 28%),
    radial-gradient(circle at top right, rgba(8, 38, 75, .045), transparent 25%),
    var(--bvf-bg);
  color: var(--bvf-text);
  font-size: var(--fa-font-body);
  min-height: 100vh;
}

a {
  color: var(--bvf-green-600);
  text-decoration: none;
}

a:hover {
  color: var(--bvf-navy-800);
}

h1,
h2,
h3,
h4,
h5,
h6,
.navbar-brand {
  color: var(--bvf-navy-950);
  font-weight: 800;
}

h5,
h6,
.navbar-brand {
  font-size: var(--fa-font-heading);
}

p {
  color: var(--bvf-muted);
}

hr {
  border-color: var(--bvf-border);
  opacity: 1;
}

small,
.small {
  color: var(--bvf-muted);
}

.text-muted {
  color: var(--bvf-muted) !important;
}

.text-green {
  color: var(--bvf-green-600) !important;
}

.text-navy {
  color: var(--bvf-navy-900) !important;
}

.text-yellow {
  color: var(--bvf-yellow-600) !important;
}

.bg-light-soft {
  background: #f8fafc !important;
}

.bg-green-soft {
  background: var(--bvf-green-soft) !important;
}

.bg-yellow-soft {
  background: var(--bvf-yellow-soft) !important;
}

.bg-navy {
  background: var(--bvf-navy-900) !important;
  color: #ffffff !important;
}


/* =======================
   3) Navbar / Header
   ======================= */

.navbar {
  padding-top: 5px;
  padding-bottom: 5px;
  background: #ffffff !important;
  border-bottom: 1px solid var(--bvf-border);
  box-shadow: var(--fa-shadow-sm);
}

.navbar-brand {
  color: var(--bvf-navy-950) !important;
  display: inline-flex;
  align-items: center;
  gap: 10px;
}

.navbar .logo,
.logo {
  width: 180px;
  max-height: 78px;
  object-fit: contain;
}

.navbar-dark .navbar-nav .nav-link,
.navbar-light .navbar-nav .nav-link,
.navbar-nav .nav-link {
  color: var(--bvf-navy-800) !important;
  font-weight: 700;
}

.navbar-dark .navbar-nav .nav-link:hover,
.navbar-light .navbar-nav .nav-link:hover,
.navbar-nav .nav-link:hover {
  color: var(--bvf-green-600) !important;
}

.navbar-toggler {
  border-color: var(--bvf-border) !important;
  background: #ffffff;
}

.navbar-toggler:focus {
  box-shadow: 0 0 0 .18rem rgba(7, 157, 63, .18);
}

.navbar-nav.ms-auto {
  align-items: center;
  gap: 10px;
}


/* =======================
   4) Layout / Cards
   ======================= */

.container,
.container-fluid {
  position: relative;
}

.card {
  background: var(--bvf-card);
  color: var(--bvf-text);
  border-radius: var(--bvf-radius-lg);
  border: 1px solid var(--bvf-border);
  box-shadow: var(--fa-shadow-sm);
  overflow: hidden;
}

.card-header {
  background: #ffffff;
  color: var(--bvf-navy-950);
  border-bottom: 1px solid var(--bvf-border);
  flex-flow: row wrap;
  padding: 1rem 1.15rem;
}

.card-header h1,
.card-header h2,
.card-header h3,
.card-header h4,
.card-header h5,
.card-header h6 {
  margin-bottom: 0;
}

.card-body {
  color: var(--bvf-text);
}

.card-footer {
  background: #f8fafc;
  border-top: 1px solid var(--bvf-border);
}

.shadow-bvf {
  box-shadow: var(--fa-shadow-md);
}

.rounded-bvf {
  border-radius: var(--bvf-radius-lg);
}


/* =======================
   5) Tabelas
   ======================= */

.table {
  color: var(--bvf-text);
  margin-bottom: 0;
}

.table thead th {
  background: #f8fafc;
  border-color: var(--bvf-border);
  color: var(--bvf-navy-800);
  font-size: .78rem;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: .035em;
  vertical-align: middle;
}

.table tbody td {
  border-color: var(--bvf-border-soft);
  color: var(--bvf-text);
  vertical-align: middle;
}

.table tbody tr:hover {
  background: rgba(7, 157, 63, .045);
}

.table-striped > tbody > tr:nth-of-type(odd) > * {
  --bs-table-accent-bg: #fbfdff;
  color: var(--bvf-text);
}

.table-hover > tbody > tr:hover > * {
  --bs-table-accent-bg: rgba(7, 157, 63, .065);
  color: var(--bvf-text);
}

/* Neutraliza table-dark caso ainda exista nos PHPs */
.table-dark {
  --bs-table-color: var(--bvf-text);
  --bs-table-bg: #ffffff;
  --bs-table-border-color: var(--bvf-border);
  --bs-table-striped-bg: #fbfdff;
  --bs-table-striped-color: var(--bvf-text);
  --bs-table-active-bg: var(--bvf-green-soft);
  --bs-table-active-color: var(--bvf-text);
  --bs-table-hover-bg: rgba(7, 157, 63, .065);
  --bs-table-hover-color: var(--bvf-text);
  color: var(--bvf-text) !important;
  border-color: var(--bvf-border) !important;
}

.table-dark thead th,
.table-dark tbody td {
  color: var(--bvf-text) !important;
  border-color: var(--bvf-border) !important;
}

.club-logo {
  width: 26px;
  height: 26px;
  object-fit: contain;
  margin-right: 6px;
  background: #ffffff;
  border-radius: 999px;
}


/* =======================
   6) Labels explicativas / Tooltips nas tabelas
   ======================= */

.bvf-th-label {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  white-space: nowrap;
}

.bvf-th-help {
  width: 18px;
  height: 18px;
  min-width: 18px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 999px;
  font-size: 11px;
  font-weight: 900;
  line-height: 1;
  cursor: help;
  color: var(--bvf-navy-950);
  background: var(--bvf-yellow-500);
  border: 1px solid rgba(255, 255, 255, .55);
  box-shadow: 0 4px 10px rgba(3, 20, 39, .16);
  transition: transform .15s ease, background .15s ease, color .15s ease;
}

.bvf-th-help:hover,
.bvf-th-help:focus {
  transform: translateY(-1px);
  color: #ffffff;
  background: var(--bvf-green-600);
  outline: none;
}

.table-dark thead th .bvf-th-help {
  color: var(--bvf-navy-950);
}

.tooltip {
  font-size: .82rem;
}

.tooltip-inner {
  max-width: 260px;
  padding: 9px 11px;
  text-align: left;
  border-radius: 10px;
  line-height: 1.4;
  font-weight: 500;
}


/* =======================
   7) Botões
   ======================= */

.btn {
  min-height: 44px;
  font-size: var(--fa-font-btn);
  padding: var(--fa-btn-pad-y) var(--fa-btn-pad-x);
  line-height: 1.15;
  font-weight: 900;
  border-radius: 999px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: .38rem;
  white-space: nowrap;
  transition: transform .10s ease, filter .15s ease, box-shadow .15s ease, background .15s ease, border-color .15s ease;
}

.btn:hover {
  transform: translateY(-1px);
}

.btn-sm,
.btn-group-sm > .btn {
  min-height: 38px;
  font-size: var(--fa-font-btn-sm);
  padding: var(--fa-btn-pad-y-sm) var(--fa-btn-pad-x-sm);
  line-height: 1.1;
  font-weight: 900;
  border-radius: 999px;
}

.btn-lg,
.btn-group-lg > .btn {
  min-height: 52px;
  padding: .84rem 1.35rem;
  font-size: 1rem;
  font-weight: 950;
  border-radius: 999px;
}

.navbar .btn {
  min-height: 44px;
  font-size: var(--fa-font-btn);
  padding: .68rem 1.02rem;
}

.btn-primary {
  color: #ffffff !important;
  background: linear-gradient(135deg, var(--bvf-navy-900), var(--bvf-navy-700));
  border-color: var(--bvf-navy-800);
  box-shadow: 0 8px 18px rgba(3, 20, 39, .16);
}

.btn-primary:hover,
.btn-primary:focus {
  color: #ffffff !important;
  background: linear-gradient(135deg, var(--bvf-navy-800), var(--bvf-navy-700));
  border-color: var(--bvf-navy-700);
}

.btn-success {
  color: #ffffff !important;
  background: linear-gradient(135deg, var(--bvf-green-700), var(--bvf-green-500));
  border-color: var(--bvf-green-600);
  box-shadow: 0 8px 18px rgba(7, 157, 63, .18);
}

.btn-success:hover,
.btn-success:focus {
  color: #ffffff !important;
  background: linear-gradient(135deg, var(--bvf-green-600), var(--bvf-green-500));
  border-color: var(--bvf-green-500);
  box-shadow: 0 12px 26px rgba(7, 157, 63, .24);
}

.btn-warning {
  color: var(--bvf-navy-950) !important;
  background: var(--bvf-yellow-500);
  border-color: var(--bvf-yellow-500);
  box-shadow: 0 8px 18px rgba(244, 196, 0, .18);
}

.btn-warning:hover,
.btn-warning:focus {
  color: var(--bvf-navy-950) !important;
  background: #ffd84d;
  border-color: var(--bvf-yellow-600);
}

.btn-danger {
  color: #ffffff !important;
  background: linear-gradient(135deg, #b91c1c, var(--bvf-red));
  border-color: var(--bvf-red);
}

.btn-danger:hover,
.btn-danger:focus {
  color: #ffffff !important;
  filter: brightness(1.05);
}

.btn-info {
  color: #ffffff !important;
  background: linear-gradient(135deg, #0e7490, var(--bvf-cyan));
  border-color: var(--bvf-cyan);
}

.btn-info:hover,
.btn-info:focus {
  color: #ffffff !important;
  filter: brightness(1.05);
}

.btn-light {
  color: var(--bvf-navy-900) !important;
  background: #ffffff;
  border-color: var(--bvf-border);
}

.btn-outline-primary {
  color: var(--bvf-navy-900) !important;
  border-color: var(--bvf-navy-800);
  background: #ffffff;
}

.btn-outline-primary:hover {
  color: #ffffff !important;
  background: var(--bvf-navy-800);
  border-color: var(--bvf-navy-800);
}

.btn-outline-light {
  color: var(--bvf-navy-900) !important;
  border-color: var(--bvf-navy-800);
  background: #ffffff;
}

.btn-outline-light:hover {
  color: #ffffff !important;
  background: var(--bvf-navy-800);
  border-color: var(--bvf-navy-800);
}

.btn-outline-success {
  color: var(--bvf-green-700) !important;
  border-color: var(--bvf-green-600);
  background: #ffffff;
}

.btn-outline-success:hover {
  color: #ffffff !important;
  background: var(--bvf-green-600);
  border-color: var(--bvf-green-600);
}

.btn-outline-warning {
  color: var(--bvf-yellow-700) !important;
  border-color: var(--bvf-yellow-500);
  background: #ffffff;
}

.btn-outline-warning:hover {
  color: var(--bvf-navy-950) !important;
  background: var(--bvf-yellow-500);
  border-color: var(--bvf-yellow-500);
}

/* Botão da Ficha Técnica no ranking */
.bvf-btn-ficha-tecnica,
.bvf-btn-curriculo {
  min-height: 40px;
  padding: .58rem .90rem;
  font-size: .86rem;
  font-weight: 950;
  border-radius: 999px;
  box-shadow: var(--fa-shadow-sm);
}

.bvf-btn-ficha-tecnica:hover,
.bvf-btn-curriculo:hover {
  transform: translateY(-1px);
}

/* Instagram custom */
.btn-instagram {
  color: #ffffff !important;
  border: 0;
  background: linear-gradient(45deg, #f58529, #dd2a7b, #8134af, #515bd4);
  box-shadow: var(--fa-shadow-sm);
}

.btn-instagram:hover {
  filter: brightness(1.08);
  transform: translateY(-1px);
}

/* YouTube */
.btn-youtube {
  color: #ffffff !important;
  background: linear-gradient(135deg, #ff0033 0%, #cc0000 100%);
  border: 1px solid rgba(255, 255, 255, 0.08);
  transition: all .25s ease;
  box-shadow: 0 8px 20px rgba(255, 0, 51, 0.20);
}

.btn-youtube:hover,
.btn-youtube:focus {
  color: #ffffff !important;
  background: linear-gradient(135deg, #ff1f4d 0%, #e00000 100%);
  transform: translateY(-1px);
  box-shadow: 0 12px 26px rgba(255, 0, 51, 0.28);
}

.btn-youtube svg {
  flex-shrink: 0;
}


/* =======================
   8) Badges / Métricas / Heat
   ======================= */

.badge {
  --bs-badge-padding-x: .58rem !important;
  --bs-badge-padding-y: .24rem !important;
  --bs-badge-font-size: .72rem !important;
  font-weight: 800;
  border-radius: 999px;
}

.badge-metric {
  font-size: var(--fa-font-badge);
  padding: .36rem .58rem;
  border-radius: 999px;
  font-weight: 800;
}

.badge.bg-danger {
  color: #ffffff !important;
  background: var(--bvf-red) !important;
}

.badge.bg-success {
  color: #ffffff !important;
  background: var(--bvf-green-600) !important;
}

.badge.bg-info {
  color: #ffffff !important;
  background: var(--bvf-cyan) !important;
}

.badge.bg-warning,
.bg-warning {
  background-color: var(--bvf-yellow-500) !important;
  color: var(--bvf-navy-950) !important;
}

.badge.bg-secondary {
  background: #e2e8f0 !important;
  color: var(--bvf-navy-800) !important;
}

.badge-soft {
  background: #f1f5f9;
  border: 1px solid var(--bvf-border);
  color: var(--bvf-navy-800);
}

.heat-low {
  color: #ffffff !important;
  background: var(--bvf-red) !important;
}

.heat-mid {
  color: var(--bvf-navy-950) !important;
  background: var(--bvf-yellow-500) !important;
}

.heat-high {
  color: #ffffff !important;
  background: var(--bvf-green-600) !important;
}


/* =======================
   9) Legenda Heat
   ======================= */

.legend-heat {
  width: 100%;
  color: var(--bvf-text);
  display: flex;
  gap: 7px;
  justify-content: flex-start;
  flex-wrap: wrap;
  margin: .45rem 0 .85rem;
  font-size: var(--fa-font-legend);
}

.legend-heat .item {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 7px 11px;
  border-radius: 999px;
  border: 1px solid var(--bvf-border);
  background: #ffffff;
  color: var(--bvf-muted);
  box-shadow: var(--fa-shadow-sm);
}

.legend-heat .dot {
  width: 12px;
  height: 12px;
  border-radius: 4px;
}

.legend-heat .dot.low {
  background: var(--bvf-red);
}

.legend-heat .dot.mid {
  background: var(--bvf-yellow-500);
}

.legend-heat .dot.high {
  background: var(--bvf-green-600);
}


/* =======================
   10) Forms / Inputs / Selects
   ======================= */

label {
  color: var(--bvf-navy-800);
  font-weight: 700;
}

.form-control,
.form-select {
  background-color: #ffffff;
  border: 1px solid var(--bvf-border);
  color: var(--bvf-text);
  border-radius: 12px;
  min-height: 42px;
}

.form-control::placeholder {
  color: var(--bvf-muted-2);
}

.form-control:focus,
.form-select:focus {
  color: var(--bvf-text);
  background-color: #ffffff;
  border-color: var(--bvf-green-600);
  box-shadow: 0 0 0 .22rem rgba(7, 157, 63, .14);
  outline: 0;
}

.form-control:disabled,
.form-select:disabled {
  background: #f1f5f9;
  color: var(--bvf-muted);
}

.input-group-text {
  background: #f8fafc;
  border-color: var(--bvf-border);
  color: var(--bvf-muted);
  font-weight: 700;
  border-radius: 12px;
}

/* Select2 */
.select2-container {
  z-index: 100 !important;
}

.select2-container--bootstrap4 .select2-results__option {
  color: var(--bvf-text);
}

.select2-container .select2-selection--single .select2-selection__clear {
  color: var(--bvf-text) !important;
}

.select2-container--bootstrap4 .select2-selection--single {
  background-color: #ffffff;
  border: 1px solid var(--bvf-border);
  border-radius: 12px;
  min-height: 42px;
  height: 42px;
  display: flex;
  align-items: center;
  padding: .375rem .75rem;
}

.select2-container--bootstrap4 .select2-selection--single .select2-selection__rendered {
  color: var(--bvf-text);
  padding-left: 0;
  line-height: 1.5;
}

.select2-container--bootstrap4 .select2-selection--single .select2-selection__placeholder {
  color: var(--bvf-muted-2);
}

.select2-container--bootstrap4 .select2-selection--single .select2-selection__arrow {
  height: 100%;
  right: 10px;
}

.select2-container--bootstrap4 .select2-selection--multiple {
  background-color: #ffffff;
  border: 1px solid var(--bvf-border);
  border-radius: 12px;
  min-height: 42px;
  padding: .25rem .2rem;
}

.select2-container--bootstrap4 .select2-selection--multiple .select2-selection__choice {
  background-color: var(--bvf-green-soft);
  border: 1px solid rgba(7, 157, 63, .22);
  color: var(--bvf-green-700);
  border-radius: 999px;
  font-weight: 700;
}

.select2-container--bootstrap4.select2-container--focus .select2-selection--single,
.select2-container--bootstrap4.select2-container--focus .select2-selection--multiple {
  border-color: var(--bvf-green-600);
  box-shadow: 0 0 0 .22rem rgba(7, 157, 63, .14);
  outline: 0;
}

.select2-container--bootstrap4 .select2-dropdown {
  background-color: #ffffff;
  border: 1px solid var(--bvf-border);
  box-shadow: var(--fa-shadow-md);
  overflow: hidden;
}

.select2-container--bootstrap4 .select2-results__option--highlighted {
  background-color: var(--bvf-green-600);
  color: #ffffff;
}


/* =======================
   11) DataTables
   ======================= */

.dataTables_wrapper {
  color: var(--bvf-text);
}

.dataTables_filter label,
.dataTables_length label {
  color: var(--bvf-muted) !important;
  font-weight: 700;
}

.dataTables_filter input,
.dataTables_length select {
  background: #ffffff !important;
  border: 1px solid var(--bvf-border) !important;
  color: var(--bvf-text) !important;
  border-radius: 10px !important;
  padding: .35rem .55rem !important;
}

.dataTables_info {
  color: var(--bvf-muted) !important;
  font-weight: 600;
}

.dataTables_paginate .paginate_button,
.page-link {
  border-radius: 999px !important;
}

div.dataTables_wrapper div.dataTables_paginate ul.pagination {
  margin: 20px 0 !important;
}

.page-link {
  color: var(--bvf-navy-800) !important;
  border-color: var(--bvf-border) !important;
}

.page-item.active .page-link {
  color: #ffffff !important;
  background: var(--bvf-green-600) !important;
  border-color: var(--bvf-green-600) !important;
}

.page-link:hover {
  color: var(--bvf-green-700) !important;
  background: var(--bvf-green-soft) !important;
  border-color: rgba(7, 157, 63, .22) !important;
}

/* DataTables Buttons */
.dt-buttons {
  display: flex;
  flex-wrap: wrap;
  gap: .65rem;
  margin-bottom: .85rem;
}

.dt-buttons .dt-button {
  background: #ffffff !important;
  border: 1px solid var(--bvf-border) !important;
  color: var(--bvf-navy-800) !important;
  min-height: 43px !important;
  padding: .64rem .95rem !important;
  border-radius: 999px !important;
  font-weight: 900 !important;
  font-size: .92rem !important;
  line-height: 1.15 !important;
  box-shadow: var(--fa-shadow-sm) !important;
  transition: transform .08s ease, filter .15s ease, background .15s ease, border-color .15s ease, box-shadow .15s ease;
}

.dt-buttons .dt-button:hover {
  transform: translateY(-1px) !important;
  filter: brightness(1.02) !important;
  background: var(--bvf-green-soft) !important;
  border-color: rgba(7, 157, 63, .35) !important;
  color: var(--bvf-green-700) !important;
  box-shadow: 0 10px 22px rgba(7, 157, 63, .12) !important;
}

.dt-buttons .dt-button:focus,
.dt-buttons .dt-button:active {
  outline: none !important;
  box-shadow: 0 0 0 .18rem rgba(7, 157, 63, .18) !important;
  transform: translateY(-1px);
}

.dt-buttons .dt-button.disabled,
.dt-buttons .dt-button:disabled {
  opacity: .55 !important;
  cursor: not-allowed !important;
  transform: none !important;
}

.dt-buttons .dt-button > span {
  display: inline-flex;
  align-items: center;
  gap: .42rem;
}

.dt-buttons .buttons-copy > span::before {
  content: "📋";
}

.dt-buttons .buttons-csv > span::before {
  content: "🧾";
}

.dt-buttons .buttons-excel > span::before {
  content: "📊";
}

.dt-buttons .buttons-pdf > span::before {
  content: "🧷";
}

.dt-buttons .buttons-print > span::before {
  content: "🖨️";
}

#datatables_buttons_info * {
  color: var(--bvf-text) !important;
}

/* DataTables Responsive + */
table.dataTable.dtr-column > tbody > tr > td.control,
table.dataTable.dtr-column > tbody > tr > th.control {
  position: relative;
  cursor: pointer;
}

table.dataTable.dtr-column > tbody > tr > td.control:before,
table.dataTable.dtr-column > tbody > tr > th.control:before {
  content: "+";
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 19px;
  height: 19px;
  border-radius: 999px;
  background: var(--bvf-green-600);
  border: 1px solid var(--bvf-green-600);
  color: #ffffff;
  font-weight: 900;
  line-height: 1;
}

table.dataTable.dtr-column > tbody > tr.parent > td.control:before,
table.dataTable.dtr-column > tbody > tr.parent > th.control:before {
  content: "–";
  background: var(--bvf-yellow-500);
  border-color: var(--bvf-yellow-500);
  color: var(--bvf-navy-950);
}

.dtr-details {
  width: 100%;
}

.dtr-title {
  color: var(--bvf-navy-800);
  font-weight: 800;
}


/* =======================
   12) CTA / Blocos de destaque
   ======================= */

.fa-cta-analise {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 14px;
  padding: 16px 18px;
  border-radius: var(--bvf-radius-lg);
  border: 1px solid rgba(7, 157, 63, .18);
  background:
    linear-gradient(135deg, rgba(7, 157, 63, .08), rgba(8, 38, 75, .035)),
    #ffffff;
  box-shadow: var(--fa-shadow-md);
}

.fa-cta-analise .fa-cta-title {
  font-weight: 900;
  letter-spacing: .2px;
  margin: 0;
  color: var(--bvf-navy-950);
}

.fa-cta-analise .fa-cta-sub {
  margin: 3px 0 0 0;
  color: var(--bvf-muted);
  font-size: .92rem;
}

.fa-cta-analise .btn {
  white-space: nowrap;
  border-radius: 999px;
  min-height: 48px;
  padding: .74rem 1.18rem;
  font-size: .94rem;
  font-weight: 950;
  box-shadow: var(--fa-shadow-sm);
}

.fa-cta-analise .btn:hover {
  filter: brightness(1.04);
  transform: translateY(-1px);
}


/* =======================
   13) Cards IA / Cards de ranking
   ======================= */

.ia-card {
  background: #ffffff;
  border: 1px solid var(--bvf-border);
  border-radius: var(--bvf-radius-md);
  padding: 14px;
  height: 100%;
  box-shadow: var(--fa-shadow-sm);
}

.ia-photo {
  width: 72px;
  height: 72px;
  border-radius: 50%;
  object-fit: cover;
  border: 3px solid var(--bvf-green-soft);
  background: #ffffff;
}

.bvf-ranking-card,
.ranking-card {
  background: #ffffff;
  border: 1px solid var(--bvf-border);
  border-radius: var(--bvf-radius-lg);
  box-shadow: var(--fa-shadow-sm);
}

.bvf-score,
.score-value {
  color: var(--bvf-green-600);
  font-weight: 900;
}

.bvf-score-high {
  color: var(--bvf-green-600);
}

.bvf-score-mid {
  color: var(--bvf-yellow-600);
}

.bvf-score-low {
  color: var(--bvf-red);
}


/* =======================
   14) Oferta / Landing / Vendas
   ======================= */

.fa-offer-hero {
  margin-top: 18px;
  background:
    radial-gradient(circle at top right, rgba(7, 157, 63, .12), transparent 30%),
    radial-gradient(circle at bottom left, rgba(8, 38, 75, .045), transparent 30%),
    linear-gradient(135deg, #ffffff 0%, #f8fafc 58%, #f1faf5 100%);
  border: 1px solid var(--bvf-border);
  border-radius: 24px;
  padding: 28px;
  box-shadow: var(--fa-shadow-lg);
}

.fa-offer-badge {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  background: var(--bvf-green-soft);
  border: 1px solid rgba(7, 157, 63, .22);
  color: var(--bvf-green-700);
  font-size: 12px;
  font-weight: 900;
  letter-spacing: .04em;
  text-transform: uppercase;
  border-radius: 999px;
  padding: 8px 14px;
  margin-bottom: 16px;
}

.fa-offer-title {
  color: var(--bvf-navy-950);
  font-size: 2.1rem;
  line-height: 1.15;
  font-weight: 950;
  margin-bottom: 12px;
}

.fa-offer-subtitle {
  color: var(--bvf-muted);
  font-size: 1rem;
  line-height: 1.75;
  margin-bottom: 0;
}

.fa-offer-list {
  list-style: none;
  padding: 0;
  margin: 22px 0 0;
}

.fa-offer-list li {
  position: relative;
  padding-left: 32px;
  margin-bottom: 12px;
  color: var(--bvf-text);
  line-height: 1.6;
  font-weight: 600;
}

.fa-offer-list li:before {
  content: "✔";
  position: absolute;
  left: 0;
  top: 1px;
  width: 21px;
  height: 21px;
  border-radius: 50%;
  background: #ffffff;
  color: #ffffff;
  font-size: 12px;
  font-weight: 900;
  display: flex;
  align-items: center;
  justify-content: center;
}

.fa-offer-pricing {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 18px;
  margin-top: 24px;
}

.fa-price-card-link {
  display: block;
  text-decoration: none;
  color: inherit;
  height: 100%;
}

.fa-price-card-link:hover,
.fa-price-card-link:focus,
.fa-price-card-link:active {
  text-decoration: none;
  color: inherit;
}

.fa-price-card {
  position: relative;
  overflow: hidden;
  background:
    radial-gradient(circle at top right, rgba(7, 157, 63, .10), transparent 42%),
    linear-gradient(135deg, #ffffff 0%, #fbfdff 100%);
  border: 1px solid var(--bvf-border);
  border-radius: 22px;
  padding: 24px;
  height: 100%;
  transition: all .28s ease;
  box-shadow: var(--fa-shadow-sm);
  cursor: pointer;
}

.fa-price-card.highlight {
  border-color: rgba(7, 157, 63, .28);
  box-shadow: 0 14px 34px rgba(7, 157, 63, .10);
}

.fa-price-card::before {
  content: "";
  position: absolute;
  inset: 0;
  background: radial-gradient(circle at top right, rgba(8, 145, 178, .075), transparent 45%);
  opacity: 1;
  transition: opacity .28s ease;
}

.fa-price-card > * {
  position: relative;
  z-index: 2;
}

.fa-price-label {
  color: var(--bvf-green-700);
  font-size: 12px;
  font-weight: 900;
  letter-spacing: .08em;
  text-transform: uppercase;
  margin-bottom: 10px;
  transition: color .28s ease;
}

.fa-price-value {
  color: var(--bvf-navy-950);
  font-size: 3rem;
  font-weight: 950;
  line-height: 1.05;
  margin-bottom: 4px;
  transition: color .28s ease;
}

.fa-price-period {
  color: var(--bvf-muted);
  font-size: 1rem;
  font-weight: 700;
  transition: color .28s ease;
}

.fa-price-desc {
  color: var(--bvf-muted);
  font-size: .98rem;
  line-height: 1.7;
  margin: 18px 0 0;
  transition: color .28s ease;
}

.fa-price-cta {
  display: inline-flex;
  align-items: center;
  margin-top: 18px;
  font-size: .96rem;
  font-weight: 950;
  color: var(--bvf-green-700);
  opacity: .95;
  transition: color .28s ease, opacity .28s ease;
}

.fa-price-card-link:hover .fa-price-card,
.fa-price-card-link:focus .fa-price-card {
  transform: translateY(-8px);
  background: linear-gradient(135deg, var(--bvf-green-600), var(--bvf-green-500));
  border-color: var(--bvf-green-600);
  box-shadow: 0 18px 40px rgba(7, 157, 63, .24);
}

.fa-price-card-link:hover .fa-price-card::before,
.fa-price-card-link:focus .fa-price-card::before {
  opacity: 0;
}

.fa-price-card-link:hover .fa-price-label,
.fa-price-card-link:hover .fa-price-value,
.fa-price-card-link:hover .fa-price-period,
.fa-price-card-link:hover .fa-price-desc,
.fa-price-card-link:hover .fa-price-cta,
.fa-price-card-link:focus .fa-price-label,
.fa-price-card-link:focus .fa-price-value,
.fa-price-card-link:focus .fa-price-period,
.fa-price-card-link:focus .fa-price-desc,
.fa-price-card-link:focus .fa-price-cta {
  color: #ffffff;
}

.fa-price-card-link:hover .fa-price-cta,
.fa-price-card-link:focus .fa-price-cta {
  opacity: 1;
}

.fa-offer-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  margin-top: 24px;
}

.fa-offer-actions .btn {
  min-height: 50px;
  padding: .82rem 1.32rem;
  font-size: .98rem;
  font-weight: 950;
}

.fa-offer-note {
  margin-top: 14px;
  color: var(--bvf-muted);
  font-size: .92rem;
  line-height: 1.6;
}

.fa-sales-section .card-body {
  padding: 28px;
}

.fa-sales-kicker {
  color: var(--bvf-green-700);
  font-size: 12px;
  font-weight: 900;
  letter-spacing: .05em;
  text-transform: uppercase;
  margin-bottom: 8px;
}

.fa-sales-title {
  color: var(--bvf-navy-950);
  font-size: 1.65rem;
  line-height: 1.2;
  font-weight: 900;
  margin-bottom: 10px;
}

.fa-sales-subtitle {
  color: var(--bvf-muted);
  font-size: 1rem;
  line-height: 1.7;
  margin-bottom: 0;
}

.fa-delivery-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 16px;
  margin-top: 22px;
}

.fa-delivery-card {
  background: #ffffff;
  border: 1px solid var(--bvf-border);
  border-radius: 18px;
  padding: 18px;
  height: 100%;
  box-shadow: var(--fa-shadow-sm);
}

.fa-delivery-icon {
  width: 46px;
  height: 46px;
  border-radius: 14px;
  background: var(--bvf-green-soft);
  color: var(--bvf-green-700);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 22px;
  margin-bottom: 14px;
}

.fa-delivery-title {
  color: var(--bvf-navy-950);
  font-size: 1.05rem;
  font-weight: 900;
  margin-bottom: 8px;
}

.fa-delivery-text {
  color: var(--bvf-muted);
  font-size: .95rem;
  line-height: 1.7;
  margin: 0;
}

.fa-sales-cta {
  margin-top: 24px;
  background:
    linear-gradient(135deg, rgba(7, 157, 63, .08), rgba(8, 38, 75, .025)),
    #ffffff;
  border: 1px solid rgba(7, 157, 63, .20);
  border-radius: 18px;
  padding: 20px;
}

.fa-sales-cta strong {
  color: var(--bvf-navy-950);
}

.fa-sales-cta p {
  color: var(--bvf-muted);
  margin: 8px 0 0;
  line-height: 1.7;
}

.fa-sales-cta .btn {
  margin-top: 16px;
  min-height: 50px;
  padding: .82rem 1.32rem;
  font-size: .98rem;
}

.fa-pain-points {
  color: var(--bvf-navy-950);
  font-weight: 900;
  font-size: 1.2rem;
  line-height: 1.35;
}

.fa-pain-points div + div {
  margin-top: 4px;
}


/* =======================
   15) Hero da home / imagem / provas
   ======================= */

.bvf-home-header {
  position: relative;
}

.bvf-hero-card {
  border: 0 !important;
  background: transparent !important;
  box-shadow: none !important;
}

.bvf-hero-card > .card-body {
  padding: 0 !important;
}

.bvf-landing-hero {
  position: relative;
  overflow: hidden;
  border-radius: var(--bvf-radius-xl);
  padding: 26px;
  color: var(--bvf-navy-950);
  background:
    radial-gradient(circle at 88% 12%, rgba(7, 157, 63, .10), transparent 34%),
    radial-gradient(circle at 92% 92%, rgba(8, 38, 75, .04), transparent 34%),
    linear-gradient(135deg, #ffffff 0%, #f8fbff 48%, #f3fff9 100%);
  border: 1px solid rgba(7, 27, 54, .08);
  box-shadow: 0 22px 60px rgba(7, 27, 54, .10);
}

.bvf-landing-hero::before {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  background:
    linear-gradient(90deg, rgba(255, 255, 255, .86), rgba(255, 255, 255, .25)),
    radial-gradient(circle at 10% 12%, rgba(0, 168, 89, .06), transparent 26%);
}

.bvf-landing-hero > * {
  position: relative;
  z-index: 1;
}

.bvf-hero-copy,
.bvf-hero-side {
  height: 100%;
}

.bvf-hero-copy {
  display: flex;
  flex-direction: column;
}

.bvf-hero-kicker {
  display: inline-flex;
  align-items: center;
  width: fit-content;
  gap: 8px;
  margin-bottom: 18px;
  border-radius: 999px;
  padding: 8px 14px;
  font-size: .78rem;
  font-weight: 900;
  letter-spacing: .04em;
  text-transform: uppercase;
  color: var(--bvf-green-700);
  background: var(--bvf-green-soft);
  border: 1px solid rgba(0, 168, 89, .18);
}

.bvf-landing-hero .fa-offer-title {
  margin: 0 0 14px;
  max-width: 760px;
  color: var(--bvf-navy-950);
  font-weight: 950;
  letter-spacing: -.045em;
  line-height: .98;
  font-size: clamp(2.15rem, 4.2vw, 4.85rem);
}

.bvf-landing-hero .fa-offer-subtitle {
  margin: 0 0 18px;
  max-width: 720px;
  color: var(--bvf-muted);
  font-size: clamp(1rem, 1.15vw, 1.18rem);
  line-height: 1.65;
}

.bvf-landing-hero .fa-offer-subtitle strong {
  color: var(--bvf-navy-950);
}

.bvf-landing-hero .fa-offer-list {
  display: grid;
  gap: 11px;
  margin: 0 0 18px;
  padding: 0;
  list-style: none;
}

.bvf-landing-hero .fa-offer-list li {
  position: relative;
  min-height: 28px;
  padding-left: 38px;
  color: var(--bvf-navy-950);
  font-size: .98rem;
  line-height: 1.42;
  margin-bottom: 0;
}

.bvf-landing-hero .fa-offer-list li::before {
  content: "✓";
  position: absolute;
  left: 0;
  top: -2px;
  width: 26px;
  height: 26px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 999px;
  color: #fff;
  font-weight: 900;
  background: var(--bvf-green-600);
  box-shadow: 0 8px 18px rgba(0, 168, 89, .24);
}

.bvf-landing-hero .fa-offer-list strong {
  color: var(--bvf-navy-950);
  font-weight: 900;
}

.bvf-pain-points {
  display: grid;
  gap: 7px;
  margin-top: 2px;
  color: var(--bvf-navy-950);
  font-size: clamp(1.18rem, 1.7vw, 1.55rem);
  font-weight: 950;
  letter-spacing: -.025em;
  line-height: 1.18;
}

.bvf-mini-proof-grid,
.bvf-feature-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px;
  margin-top: 24px;
}

.bvf-mini-proof,
.bvf-feature-card {
  display: flex;
  align-items: flex-start;
  gap: 12px;
  min-height: 112px;
  padding: 17px;
  border-radius: 20px;
  background: rgba(255, 255, 255, .86);
  border: 1px solid rgba(7, 27, 54, .08);
  box-shadow: 0 14px 32px rgba(7, 27, 54, .08);
  backdrop-filter: blur(8px);
}

.bvf-mini-proof {
  display: block;
  min-height: auto;
  padding: 14px;
}

.bvf-feature-icon {
  flex: 0 0 auto;
  width: 48px;
  height: 48px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 999px;
  font-size: 1.25rem;
  background: rgba(0, 168, 89, .10);
  box-shadow: inset 0 0 0 1px rgba(0, 168, 89, .10);
}

.bvf-mini-proof strong,
.bvf-feature-card strong {
  display: block;
  margin-bottom: 5px;
  color: var(--bvf-navy-950);
  font-size: .98rem;
  font-weight: 950;
  line-height: 1.2;
}

.bvf-mini-proof span,
.bvf-feature-card small {
  display: block;
  color: var(--bvf-muted);
  font-size: .78rem;
  line-height: 1.55;
}

.bvf-feature-grid-logged {
  max-width: 760px;
}

.bvf-offer-actions,
.bvf-landing-hero .fa-offer-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  margin-top: 24px;
}

.bvf-landing-hero .fa-offer-actions .btn {
  border-radius: 999px;
  min-height: 54px;
  padding: 14px 26px;
  font-size: 1.02rem;
  font-weight: 950;
  box-shadow: 0 10px 24px rgba(7, 27, 54, .10);
}

.bvf-offer-note,
.bvf-landing-hero .fa-offer-note {
  display: grid;
  gap: 5px;
  margin-top: 18px;
  color: var(--bvf-muted);
  font-size: .98rem;
  line-height: 1.45;
}

.bvf-landing-hero .fa-offer-note strong {
  color: var(--bvf-navy-950);
}

.bvf-subscriber-note {
  margin-top: 14px !important;
  padding: 16px 18px;
  border-radius: 18px;
  background: rgba(255, 255, 255, .76);
  border: 1px solid rgba(7, 27, 54, .08);
}

.bvf-hero-side {
  display: flex;
  flex-direction: column;
  gap: 22px;
}

.bvf-hero-visual {
  position: relative;
  overflow: hidden;
  border-radius: 24px;
  background: rgba(7, 16, 34, .88);
  box-shadow: 0 18px 45px rgba(7, 27, 54, .22);
}

.bvf-hero-banner {
  width: 100%;
  height: 450px;
  display: block;
  object-fit: cover;
  object-position: center 58%;
  border-radius: 24px;
}

.bvf-hero-proof {
  position: absolute;
  left: 16px;
  right: 16px;
  bottom: 16px;
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 10px;
}

.bvf-hero-proof span {
  display: inline-flex;
  align-items: center;
  min-height: 38px;
  border-radius: 999px;
  padding: 8px 14px;
  color: #ffffff;
  font-size: .82rem;
  font-weight: 900;
  white-space: nowrap;
  background: rgba(7, 16, 34, .88);
  border: 1px solid rgba(255, 255, 255, .14);
  box-shadow: 0 10px 24px rgba(0, 0, 0, .20);
  backdrop-filter: blur(8px);
}

.bvf-pricing-grid,
.bvf-landing-hero .fa-offer-pricing {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(0, .98fr);
  gap: 20px;
  align-items: stretch;
}

.bvf-landing-hero .fa-price-card-link {
  display: block;
  height: 100%;
  color: inherit;
  text-decoration: none;
}

.bvf-landing-hero .fa-price-card {
  height: 100%;
  min-height: 355px;
  padding: 30px;
  border-radius: 26px;
  background:
    radial-gradient(circle at 92% 8%, rgba(7, 157, 63, .10), transparent 36%),
    linear-gradient(140deg, rgba(255, 255, 255, .98), rgba(248, 253, 255, .94));
  border: 1px solid rgba(7, 27, 54, .08);
  box-shadow: 0 18px 42px rgba(7, 27, 54, .10);
  transition: transform .2s ease, box-shadow .2s ease, border-color .2s ease;
}

.bvf-landing-hero .fa-price-card.highlight {
  border-color: rgba(7, 157, 63, .24);
}

.bvf-landing-hero .fa-price-card-link:hover .fa-price-card {
  transform: translateY(-3px);
  border-color: rgba(0, 168, 89, .34);
  box-shadow: 0 24px 52px rgba(7, 27, 54, .14);
}

.bvf-landing-hero .fa-price-label {
  margin-bottom: 18px;
  color: var(--bvf-green-700);
  font-size: .82rem;
  font-weight: 950;
  letter-spacing: .08em;
  text-transform: uppercase;
}

.bvf-landing-hero .fa-price-value {
  margin-bottom: 8px;
  color: var(--bvf-navy-950);
  font-size: clamp(2.55rem, 4.6vw, 4.45rem);
  font-weight: 950;
  letter-spacing: -.06em;
  line-height: .95;
}

.bvf-landing-hero .fa-price-period {
  margin-bottom: 26px;
  color: var(--bvf-muted);
  font-size: 1.05rem;
  font-weight: 850;
}

.bvf-landing-hero .fa-price-desc {
  margin: 0 0 24px;
  color: var(--bvf-muted);
  font-size: 1rem;
  line-height: 1.7;
}

.bvf-landing-hero .fa-price-cta {
  display: inline-flex;
  color: var(--bvf-green-700);
  font-weight: 950;
  font-size: .96rem;
}

.bvf-section-note {
  padding: 0 20px 4px;
  color: rgba(83, 101, 126, .88);
  font-size: .95rem;
  line-height: 1.5;
}


/* =======================
   16) Footer
   ======================= */

.fa-footer {
  border-top: 1px solid var(--bvf-border);
}

.fa-footer p,
.fa-footer small,
.fa-footer .text-muted {
  color: rgba(255, 255, 255, .72) !important;
}

.fa-footer h1,
.fa-footer h2,
.fa-footer h3,
.fa-footer h4,
.fa-footer h5,
.fa-footer h6 {
  color: #ffffff;
}

.fa-footer-logo {
  width: 190px;
  max-width: 70vw;
  height: auto;
  opacity: .98;
}

.fa-footer-contact {
  font-size: .95rem;
}

.fa-footer-link {
  color: var(--bvf-navy-700);
  text-decoration: none;
  font-weight: 800;
}

.fa-footer-link:hover {
  color: var(--bvf-navy-800);
  filter: brightness(1.05);
}

.fa-footer-bottom {
  border-top: 1px dashed rgba(255, 255, 255, .16);
}


/* =======================
   17) Utilitários
   ======================= */

.whats {
  width: 60px;
  position: fixed;
  z-index: 10000;
  right: 15px;
  bottom: 15px;
  filter: drop-shadow(0 8px 18px rgba(3, 20, 39, .25));
}

.bvf-divider {
  height: 4px;
  border-radius: 999px;
  background: linear-gradient(90deg, var(--bvf-green-600), var(--bvf-navy-800));
}

.bvf-kicker {
  color: var(--bvf-green-700);
  font-size: 12px;
  font-weight: 900;
  letter-spacing: .08em;
  text-transform: uppercase;
}

.bvf-title {
  color: var(--bvf-navy-950);
  font-weight: 950;
}

.bvf-subtitle {
  color: var(--bvf-muted);
  line-height: 1.7;
}

.border-green {
  border-color: rgba(7, 157, 63, .24) !important;
}

.border-yellow {
  border-color: rgba(244, 196, 0, .38) !important;
}

.border-navy {
  border-color: rgba(3, 20, 39, .18) !important;
}


/* =======================
   18) Alertas
   ======================= */

.alert {
  border-radius: var(--bvf-radius-md);
  border-width: 1px;
  font-weight: 600;
}

.alert-success {
  background: var(--bvf-green-soft);
  border-color: rgba(7, 157, 63, .24);
  color: var(--bvf-green-700);
}

.alert-warning {
  background: var(--bvf-yellow-soft);
  border-color: rgba(244, 196, 0, .40);
  color: #7a5a00;
}

.alert-danger {
  background: var(--bvf-red-soft);
  border-color: rgba(220, 38, 38, .22);
  color: #991b1b;
}

.alert-info {
  background: var(--bvf-cyan-soft);
  border-color: rgba(8, 145, 178, .22);
  color: #155e75;
}


/* =======================
   19) Paginação / Breadcrumb / Listas
   ======================= */

.breadcrumb {
  background: transparent;
  padding-left: 0;
}

.breadcrumb-item a {
  color: var(--bvf-green-700);
  font-weight: 700;
}

.breadcrumb-item.active {
  color: var(--bvf-muted);
}

.list-group-item {
  border-color: var(--bvf-border);
  color: var(--bvf-text);
}

.list-group-item:hover {
  background: #f8fafc;
}


/* =======================
   20) Compatibilidade com classes escuras antigas
   ======================= */

.card .text-white,
.card-header .text-white,
.card-body .text-white,
.fa-offer-hero .text-white,
.fa-sales-section .text-white {
  color: var(--bvf-navy-950) !important;
}

.card .text-white-50,
.card-header .text-white-50,
.card-body .text-white-50,
.fa-offer-hero .text-white-50,
.fa-sales-section .text-white-50 {
  color: var(--bvf-muted) !important;
}

.bg-dark {
  background: var(--bvf-navy-900) !important;
}

.card.bg-dark {
  background: #ffffff !important;
  color: var(--bvf-text) !important;
}

.border-dark {
  border-color: var(--bvf-border) !important;
}


/* =======================
   21) Responsivo
   ======================= */

@media (min-width: 1200px) {
  .bvf-landing-hero {
    padding: 28px 30px;
  }

  .bvf-landing-hero .row {
    min-height: 615px;
  }

  .bvf-hero-side {
    justify-content: flex-start;
  }

  .bvf-feature-grid,
  .bvf-mini-proof-grid {
    margin-top: 22px;
  }

  .bvf-offer-actions,
  .bvf-landing-hero .fa-offer-actions {
    margin-top: 22px;
  }
}

@media (max-width: 1199px) {
  .bvf-landing-hero .fa-offer-title {
    max-width: 100%;
  }

  .bvf-hero-banner {
    height: 300px;
  }

  .bvf-pricing-grid,
  .bvf-landing-hero .fa-offer-pricing {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 1080px) {
  .card-body.table-responsive {
    padding: 0 !important;
  }

  .card-body.table-responsive #tbl_clubes_wrapper {
    padding: 0 !important;
  }

  body {
    font-size: var(--fa-font-body-m);
  }

  h5,
  h6,
  .navbar-brand {
    font-size: var(--fa-font-heading-m);
  }

  .btn {
    min-height: 42px;
    font-size: var(--fa-font-btn-m);
    padding: var(--fa-btn-pad-y-m) var(--fa-btn-pad-x-m);
  }

  .btn-sm,
  .btn-group-sm > .btn {
    min-height: 36px;
    font-size: var(--fa-font-btn-sm-m);
    padding: var(--fa-btn-pad-y-sm-m) var(--fa-btn-pad-x-sm-m);
  }

  .navbar .btn {
    min-height: 42px;
    font-size: var(--fa-font-btn-m);
    padding: .62rem .90rem;
  }

  .legend-heat {
    font-size: var(--fa-font-legend-m);
  }

  .legend-heat .item {
    padding: 7px 11px;
  }

  .badge-metric {
    font-size: var(--fa-font-badge-m);
    padding: .28rem .48rem;
  }

  .table {
    font-size: .74rem;
  }

  .logo,
  .navbar .logo {
    width: 150px;
    margin-bottom: 8px;
  }

  .dataTables_wrapper .dataTables_paginate,
  .dataTables_wrapper .dataTables_info,
  .dataTables_wrapper .dataTables_length label,
  .dataTables_wrapper .dataTables_filter label {
    font-size: .76rem;
  }

  .dataTables_wrapper .dataTables_paginate .paginate_button {
    font-size: .72rem;
  }

  .page-link {
    font-size: 10px !important;
  }

  .navbar-nav.ms-auto {
    margin-left: 0 !important;
    align-items: flex-start;
    margin-top: 12px;
  }

  .navbar-nav.ms-auto li button {
    margin: 0 10px 0 0;
  }

  .dataTables_length {
    margin-bottom: 10px;
  }

  .dataTables_filter {
    margin-bottom: 10px;
  }
}

@media (max-width: 991.98px) {
  .fa-offer-pricing,
  .fa-delivery-grid {
    grid-template-columns: 1fr;
  }

  .fa-offer-title {
    font-size: 1.65rem;
  }

  .fa-sales-title {
    font-size: 1.4rem;
  }

  .fa-price-value {
    font-size: 2.4rem;
  }

  .bvf-hero-banner {
    max-height: none;
  }

  .bvf-hero-proof {
    position: static;
    justify-content: flex-start;
    padding: 12px;
    background: rgba(7, 16, 34, .88);
  }

  .bvf-mini-proof-grid {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 768px) {
  /* Remove os gradientes grandes no mobile para evitar aspecto alaranjado/pesado */
  body {
    background: var(--bvf-bg) !important;
  }

  .fa-offer-hero,
  .bvf-landing-hero,
  .fa-cta-analise,
  .fa-sales-cta {
    background: #ffffff !important;
  }

  .bvf-landing-hero::before,
  .fa-price-card::before {
    display: none !important;
  }

  .fa-price-card,
  .bvf-landing-hero .fa-price-card {
    background: #ffffff !important;
  }

  .fa-price-card.highlight,
  .bvf-landing-hero .fa-price-card.highlight {
    border-color: rgba(7, 157, 63, .28);
    box-shadow: 0 12px 28px rgba(7, 157, 63, .08);
  }

  .fa-pain-points {
    font-size: 1.05rem;
  }

  .card-header {
    gap: 10px;
  }

  .fa-offer-hero {
    padding: 20px;
  }

  .bvf-landing-hero {
    border-radius: 22px;
    padding: 18px;
  }

  .bvf-landing-hero .fa-offer-title {
    font-size: 2.05rem;
    line-height: 1.03;
  }

  .bvf-landing-hero .fa-offer-subtitle {
    font-size: .98rem;
  }

  .bvf-landing-hero .fa-offer-list li {
    font-size: .92rem;
    padding-left: 34px;
  }

  .bvf-pain-points {
    font-size: 1.12rem;
  }

  .bvf-feature-grid,
  .bvf-feature-grid-logged,
  .bvf-pricing-grid,
  .bvf-landing-hero .fa-offer-pricing {
    grid-template-columns: 1fr;
  }

  .bvf-feature-card {
    min-height: auto;
    padding: 15px;
  }

  .bvf-hero-banner {
    height: 245px;
  }

  .bvf-hero-proof span {
    min-height: 34px;
    font-size: .76rem;
    padding: 7px 11px;
  }

  .bvf-landing-hero .fa-price-card {
    min-height: auto;
    padding: 24px;
  }

  .bvf-landing-hero .fa-price-value {
    font-size: 3rem;
  }

  .bvf-offer-actions .btn,
  .bvf-landing-hero .fa-offer-actions .btn {
    width: 100%;
    min-height: 52px;
    justify-content: center;
  }

  .bvf-section-note {
    padding: 0 4px;
    font-size: .88rem;
  }
}

@media (max-width: 576px) {
  .fa-cta-analise {
    flex-direction: column;
    align-items: flex-start;
  }

  .fa-cta-analise .btn {
    width: 100%;
  }

  .dt-buttons .dt-button {
    min-height: 42px !important;
    font-size: .86rem !important;
    padding: .60rem .88rem !important;
    border-radius: 999px !important;
  }

  .navbar .logo,
  .logo {
    width: 136px;
  }

  .whats {
    width: 54px;
    right: 12px;
    bottom: 12px;
  }
}


/* =========================================================
   22) Planos promocionais — mensal R$ 99,90 e anual R$ 990,00
   ========================================================= */

.bvf-pricing-grid-plans,
.bvf-landing-hero .fa-offer-pricing.bvf-pricing-grid-plans {
  grid-template-columns: minmax(0, .92fr) minmax(0, 1.08fr);
  align-items: stretch;
}

.fa-price-card-monthly {
  background:
    radial-gradient(circle at top right, rgba(8, 38, 75, .09), transparent 44%),
    linear-gradient(140deg, #ffffff 0%, #f8fbff 100%);
}

.fa-price-card.promo-annual,
.bvf-landing-hero .fa-price-card.promo-annual {
  background:
    radial-gradient(circle at 85% 12%, rgba(244, 196, 0, .28), transparent 34%),
    radial-gradient(circle at 92% 95%, rgba(7, 157, 63, .20), transparent 36%),
    linear-gradient(135deg, #edfff3 0%, #f8ffe6 100%);
  border: 1px solid rgba(7, 157, 63, .42);
  box-shadow: 0 18px 45px rgba(7, 157, 63, .16);
}

.fa-price-card.promo-annual::after {
  content: "";
  position: absolute;
  inset: auto -35px -55px auto;
  width: 170px;
  height: 170px;
  border-radius: 999px;
  background: rgba(7, 157, 63, .10);
  pointer-events: none;
  z-index: 1;
}

.fa-promo-badge {
  display: inline-flex;
  align-items: center;
  width: fit-content;
  gap: 7px;
  margin-bottom: 16px;
  padding: 8px 13px;
  border-radius: 999px;
  color: var(--bvf-navy-950);
  background: var(--bvf-yellow-500);
  border: 1px solid rgba(3, 20, 39, .10);
  font-size: .76rem;
  font-weight: 950;
  letter-spacing: .055em;
  text-transform: uppercase;
  box-shadow: 0 10px 22px rgba(244, 196, 0, .22);
}

.fa-price-line {
  display: flex;
  flex-wrap: wrap;
  align-items: baseline;
  gap: 12px;
  margin-bottom: 6px;
}

.fa-old-price {
  position: relative;
  display: inline-flex;
  color: rgba(100, 116, 139, .95);
  font-weight: 900;
  font-size: .98rem;
  white-space: nowrap;
}

.fa-old-price::after {
  content: "";
  position: absolute;
  left: -4px;
  right: -4px;
  top: 52%;
  height: 3px;
  border-radius: 999px;
  background: var(--bvf-red);
  transform: rotate(-7deg);
}

.fa-price-value-promo,
.bvf-landing-hero .fa-price-value.fa-price-value-promo {
  color: var(--bvf-green-700);
  font-size: clamp(2.55rem, 4.4vw, 4.15rem);
  letter-spacing: -.065em;
  margin-bottom: 0;
}

.fa-price-saving {
  display: inline-flex;
  align-items: center;
  width: fit-content;
  margin: 8px 0 18px;
  padding: 7px 12px;
  border-radius: 999px;
  color: var(--bvf-green-800);
  background: rgba(255, 255, 255, .70);
  border: 1px solid rgba(7, 157, 63, .25);
  font-size: .82rem;
  font-weight: 950;
  box-shadow: 0 8px 18px rgba(7, 157, 63, .10);
}

.fa-price-urgency {
  margin-top: 14px;
  color: var(--bvf-navy-950);
  font-weight: 950;
  line-height: 1.35;
}

.fa-price-card.promo-annual .fa-price-label,
.bvf-landing-hero .fa-price-card.promo-annual .fa-price-label {
  color: var(--bvf-navy-950);
}

.fa-price-card.promo-annual .fa-price-period,
.bvf-landing-hero .fa-price-card.promo-annual .fa-price-period {
  color: var(--bvf-navy-800);
  margin-bottom: 10px;
}

.fa-price-card.promo-annual .fa-price-desc,
.bvf-landing-hero .fa-price-card.promo-annual .fa-price-desc {
  color: #203046;
}

.fa-price-card.promo-annual .fa-price-cta,
.bvf-landing-hero .fa-price-card.promo-annual .fa-price-cta {
  color: var(--bvf-navy-950);
  font-weight: 950;
}

/* Hover forte nos cards de planos */
.fa-price-card-link:hover .fa-price-card,
.fa-price-card-link:focus .fa-price-card,
.bvf-landing-hero .fa-price-card-link:hover .fa-price-card,
.bvf-landing-hero .fa-price-card-link:focus .fa-price-card {
  transform: translateY(-8px);
  background: linear-gradient(135deg, var(--bvf-green-700), var(--bvf-green-500));
  border-color: var(--bvf-green-600);
  box-shadow: 0 22px 52px rgba(7, 157, 63, .25);
}

.fa-price-card-link:hover .fa-price-card.promo-annual,
.fa-price-card-link:focus .fa-price-card.promo-annual,
.bvf-landing-hero .fa-price-card-link:hover .fa-price-card.promo-annual,
.bvf-landing-hero .fa-price-card-link:focus .fa-price-card.promo-annual {
  transform: translateY(-10px) scale(1.015);
  background: linear-gradient(135deg, #10e660 0%, #cbff24 100%);
  border-color: rgba(7, 157, 63, .75);
  box-shadow: 0 26px 62px rgba(7, 157, 63, .34);
}

.fa-price-card-link:hover .fa-price-card.promo-annual .fa-promo-badge,
.fa-price-card-link:focus .fa-price-card.promo-annual .fa-promo-badge {
  background: var(--bvf-navy-950);
  color: #ffffff;
  border-color: rgba(255, 255, 255, .18);
}

.fa-price-card-link:hover .fa-price-card.promo-annual .fa-price-label,
.fa-price-card-link:hover .fa-price-card.promo-annual .fa-price-value,
.fa-price-card-link:hover .fa-price-card.promo-annual .fa-price-period,
.fa-price-card-link:hover .fa-price-card.promo-annual .fa-price-desc,
.fa-price-card-link:hover .fa-price-card.promo-annual .fa-price-cta,
.fa-price-card-link:hover .fa-price-card.promo-annual .fa-price-urgency,
.fa-price-card-link:focus .fa-price-card.promo-annual .fa-price-label,
.fa-price-card-link:focus .fa-price-card.promo-annual .fa-price-value,
.fa-price-card-link:focus .fa-price-card.promo-annual .fa-price-period,
.fa-price-card-link:focus .fa-price-card.promo-annual .fa-price-desc,
.fa-price-card-link:focus .fa-price-card.promo-annual .fa-price-cta,
.fa-price-card-link:focus .fa-price-card.promo-annual .fa-price-urgency {
  color: var(--bvf-navy-950) !important;
}

.fa-price-card-link:hover .fa-price-card.promo-annual .fa-old-price,
.fa-price-card-link:focus .fa-price-card.promo-annual .fa-old-price {
  color: rgba(3, 20, 39, .78) !important;
}

.fa-price-card-link:hover .fa-price-card.promo-annual .fa-price-saving,
.fa-price-card-link:focus .fa-price-card.promo-annual .fa-price-saving {
  color: var(--bvf-navy-950);
  background: rgba(255, 255, 255, .52);
  border-color: rgba(3, 20, 39, .12);
}

/* Ajuste de CTA principal do hero quando usado para promoção */
.fa-offer-actions .btn-success:hover,
.bvf-landing-hero .fa-offer-actions .btn-success:hover {
  transform: translateY(-2px);
  box-shadow: 0 16px 34px rgba(7, 157, 63, .24);
}

@media (max-width: 1199px) {
  .bvf-pricing-grid-plans,
  .bvf-landing-hero .fa-offer-pricing.bvf-pricing-grid-plans {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 991.98px) {
  .bvf-pricing-grid-plans,
  .bvf-landing-hero .fa-offer-pricing.bvf-pricing-grid-plans {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 768px) {
  .fa-price-card.promo-annual,
  .bvf-landing-hero .fa-price-card.promo-annual {
    background:
      radial-gradient(circle at 84% 10%, rgba(244, 196, 0, .32), transparent 34%),
      linear-gradient(135deg, #edfff3 0%, #f8ffe6 100%) !important;
    border-color: rgba(7, 157, 63, .42) !important;
    box-shadow: 0 14px 34px rgba(7, 157, 63, .14) !important;
  }

  .fa-price-line {
    gap: 8px;
  }

  .fa-old-price {
    font-size: .88rem;
  }

  .fa-price-value-promo,
  .bvf-landing-hero .fa-price-value.fa-price-value-promo {
    font-size: 2.85rem !important;
  }

  .fa-promo-badge {
    font-size: .70rem;
    padding: 7px 11px;
  }

  .fa-price-saving {
    font-size: .76rem;
  }
}