/* ═══════════════════════════════════════════════════════════════════════════
   Vibe Vaa Club — Estilos personalizados
   Stack: Bootstrap 5 + Inter font
   ═══════════════════════════════════════════════════════════════════════════ */

/* ─── Design Tokens ──────────────────────────────────────────────────────── */
:root {
  --vibe-navy:          #1a2c42;
  --vibe-navy-hover:    #243b55;
  --vibe-accent:        #3b9fd6;
  --vibe-accent-light:  rgba(59, 159, 214, .12);
  --vibe-body-bg:       #f3f5f8;
  --vibe-card-shadow:   0 1px 3px rgba(0,0,0,.05), 0 4px 16px rgba(0,0,0,.06);
  --vibe-card-shadow-hover: 0 2px 8px rgba(0,0,0,.08), 0 8px 28px rgba(0,0,0,.09);
  --vibe-radius:        .65rem;
  --vibe-radius-sm:     .4rem;
  --vibe-border:        #e5e9f0;
  --vibe-muted:         #6b7280;
  --vibe-text:          #1e2d3d;
  --vibe-ease:          .16s ease;
}

/* ─── Base ───────────────────────────────────────────────────────────────── */
body {
  font-family: 'Inter', system-ui, -apple-system, sans-serif;
  font-size: .875rem;
  background-color: var(--vibe-body-bg);
  color: var(--vibe-text);
  -webkit-font-smoothing: antialiased;
}

/* ─── Navbar ─────────────────────────────────────────────────────────────── */
.navbar.bg-dark {
  background-color: var(--vibe-navy) !important;
  border-bottom: 1px solid rgba(255,255,255,.06);
  height: 56px;
}

.navbar-brand {
  font-weight: 700;
  font-size: .9rem;
  letter-spacing: .03em;
  color: #fff !important;
  opacity: .95;
}

.navbar .nav-link.dropdown-toggle {
  font-size: .8rem;
  font-weight: 500;
}

/* ─── Sidebar ────────────────────────────────────────────────────────────── */
.sidebar {
  background-color: var(--vibe-navy) !important;
  min-height: calc(100vh - 56px);
  box-shadow: inset -1px 0 0 rgba(0,0,0,.15);
}

.sidebar .nav-link {
  font-size: .8rem;
  font-weight: 500;
  padding: .42rem .9rem;
  border-radius: var(--vibe-radius-sm);
  margin: .08rem .5rem;
  color: rgba(255,255,255,.68) !important;
  transition: background-color var(--vibe-ease), color var(--vibe-ease), box-shadow var(--vibe-ease);
}

.sidebar .nav-link:hover {
  background-color: rgba(255,255,255,.07);
  color: rgba(255,255,255,.95) !important;
}

.sidebar .nav-link.active {
  background-color: rgba(59,159,214,.16);
  color: #fff !important;
  box-shadow: inset 3px 0 0 var(--vibe-accent);
}

.sidebar .nav-link.active i {
  color: var(--vibe-accent);
}

.sidebar-heading {
  font-size: .6rem;
  font-weight: 600;
  letter-spacing: .1rem;
  color: rgba(255,255,255,.3) !important;
  text-transform: uppercase;
  padding: 0 1.1rem;
  margin-top: 1.2rem !important;
  margin-bottom: .25rem !important;
}

/* ─── Main content ───────────────────────────────────────────────────────── */
main {
  min-height: calc(100vh - 56px);
}

/* ─── Page header ────────────────────────────────────────────────────────── */
.border-bottom {
  border-bottom-color: var(--vibe-border) !important;
}

h1.h2, .d-flex > h1 {
  font-size: 1.25rem;
  font-weight: 700;
  color: var(--vibe-text);
  letter-spacing: -.015em;
}

/* ─── Cards ──────────────────────────────────────────────────────────────── */
.card {
  border-radius: var(--vibe-radius);
  border-color: var(--vibe-border);
  box-shadow: var(--vibe-card-shadow);
  transition: box-shadow var(--vibe-ease);
}

.card:hover {
  box-shadow: var(--vibe-card-shadow-hover);
}

.card-header {
  background-color: transparent !important;
  border-bottom-color: var(--vibe-border);
  padding: .85rem 1.1rem;
  font-size: .8rem;
  font-weight: 600;
  color: var(--vibe-text);
}

.card-body {
  padding: 1.2rem;
}

/* ─── Tables ─────────────────────────────────────────────────────────────── */
.table {
  font-size: .8rem;
}

.table th {
  font-weight: 600;
  font-size: .7rem;
  text-transform: uppercase;
  letter-spacing: .06rem;
  color: var(--vibe-muted);
  border-bottom-width: 1px;
  border-color: var(--vibe-border);
  white-space: nowrap;
  padding: .65rem .75rem;
}

.table td {
  vertical-align: middle;
  color: #374151;
  border-color: var(--vibe-border);
  padding: .6rem .75rem;
}

.table-hover > tbody > tr {
  transition: background-color var(--vibe-ease);
}

.table-hover > tbody > tr:hover > * {
  background-color: rgba(59,130,246,.03);
}

.table-light {
  --bs-table-bg: #f8fafc;
}

/* ─── Buttons ────────────────────────────────────────────────────────────── */
.btn {
  font-weight: 500;
  font-size: .78rem;
  border-radius: var(--vibe-radius-sm);
  transition: all var(--vibe-ease);
  letter-spacing: .01em;
}

.btn-dark {
  background-color: var(--vibe-navy);
  border-color: var(--vibe-navy);
}

.btn-dark:hover, .btn-dark:focus {
  background-color: var(--vibe-navy-hover);
  border-color: var(--vibe-navy-hover);
  box-shadow: 0 2px 8px rgba(26,44,66,.3);
}

.btn-sm {
  padding: .28rem .6rem;
  font-size: .72rem;
}

.btn-outline-secondary {
  border-color: #d1d5db;
  color: #4b5563;
}

.btn-outline-secondary:hover {
  background-color: #f3f4f6;
  border-color: #9ca3af;
  color: #1f2937;
}

.btn-outline-danger:hover {
  box-shadow: 0 2px 8px rgba(220,53,69,.2);
}

.btn-success {
  box-shadow: none;
}

.btn-success:hover {
  box-shadow: 0 2px 8px rgba(25,135,84,.25);
}

/* ─── Badges ─────────────────────────────────────────────────────────────── */
.badge {
  font-weight: 500;
  font-size: .65rem;
  padding: .28em .55em;
  border-radius: .3rem;
  letter-spacing: .025em;
}

/* ─── Forms ──────────────────────────────────────────────────────────────── */
.form-control,
.form-select {
  font-size: .8rem;
  border-color: #d1d5db;
  border-radius: var(--vibe-radius-sm);
  color: var(--vibe-text);
  transition: border-color var(--vibe-ease), box-shadow var(--vibe-ease);
}

.form-control:focus,
.form-select:focus {
  border-color: var(--vibe-accent);
  box-shadow: 0 0 0 3px var(--vibe-accent-light);
}

.form-control::placeholder {
  color: #9ca3af;
  font-size: .78rem;
}

.form-label {
  font-weight: 500;
  font-size: .76rem;
  color: #374151;
  margin-bottom: .28rem;
}

.required-mark::after {
  content: ' *';
  color: #ef4444;
}

.form-check-input:checked {
  background-color: var(--vibe-navy);
  border-color: var(--vibe-navy);
}

.form-check-input:focus {
  box-shadow: 0 0 0 3px var(--vibe-accent-light);
  border-color: var(--vibe-accent);
}

/* ─── Input group ────────────────────────────────────────────────────────── */
.input-group .form-control {
  border-right: 0;
}

.input-group .btn-outline-secondary {
  border-color: #d1d5db;
  border-left: 0;
}

/* ─── Alerts ─────────────────────────────────────────────────────────────── */
.alert {
  font-size: .8rem;
  border-radius: var(--vibe-radius-sm);
  border-left-width: 3px;
  border-top: none;
  border-right: none;
  border-bottom: none;
  padding: .7rem 1rem;
}

/* ─── Pagination ─────────────────────────────────────────────────────────── */
.page-link {
  font-size: .75rem;
  color: #374151;
  border-color: var(--vibe-border);
  padding: .32rem .6rem;
  border-radius: var(--vibe-radius-sm) !important;
  margin: 0 .1rem;
  transition: all var(--vibe-ease);
}

.page-link:hover {
  background-color: #eef2f7;
  border-color: #c9d3e0;
  color: var(--vibe-navy);
}

.page-item.active .page-link {
  background-color: var(--vibe-navy);
  border-color: var(--vibe-navy);
}

.page-item.disabled .page-link {
  background-color: #f8fafc;
  color: #9ca3af;
}

/* ─── Dropdown ───────────────────────────────────────────────────────────── */
.dropdown-menu {
  font-size: .8rem;
  border-color: var(--vibe-border);
  border-radius: var(--vibe-radius-sm);
  box-shadow: 0 4px 24px rgba(0,0,0,.1);
  padding: .35rem;
}

.dropdown-item {
  padding: .4rem .75rem;
  border-radius: .3rem;
  margin: .05rem 0;
  transition: background-color var(--vibe-ease);
  font-weight: 500;
}

.dropdown-divider {
  border-color: var(--vibe-border);
  margin: .3rem 0;
}

/* ─── Progress ───────────────────────────────────────────────────────────── */
.progress {
  border-radius: .5rem;
  background-color: #e9ecef;
}

/* ─── Text muted override ────────────────────────────────────────────────── */
.text-muted {
  color: var(--vibe-muted) !important;
}

small, .small {
  font-size: .75rem;
}

/* ─── Section divider (formulário público) ───────────────────────────────── */
.section-divider {
  background: linear-gradient(135deg, var(--vibe-navy) 0%, var(--vibe-navy-hover) 100%);
  color: #fff;
  padding: .65rem 1.1rem;
  border-radius: var(--vibe-radius-sm);
  margin-bottom: .75rem;
  margin-top: 1.25rem;
}

.section-divider h5 {
  color: #fff;
  font-size: .82rem;
  letter-spacing: .02em;
}

/* ─── Scrollbar refinada (webkit) ────────────────────────────────────────── */
::-webkit-scrollbar { width: 5px; height: 5px; }
::-webkit-scrollbar-track { background: transparent; }
::-webkit-scrollbar-thumb { background: #c9d1da; border-radius: 4px; }
::-webkit-scrollbar-thumb:hover { background: #9ca3af; }

/* ─── KPI cards hover interativo ─────────────────────────────────────────── */
a > .card {
  transition: box-shadow var(--vibe-ease), transform var(--vibe-ease);
}

a > .card:hover {
  transform: translateY(-2px);
  box-shadow: var(--vibe-card-shadow-hover);
}

/* ─── Ícones de KPI ──────────────────────────────────────────────────────── */
.rounded-circle.bg-primary.bg-opacity-10 { background-color: rgba(59,130,246,.1) !important; }
.rounded-circle.bg-success.bg-opacity-10 { background-color: rgba(25,135,84,.1) !important; }
.rounded-circle.bg-danger.bg-opacity-10  { background-color: rgba(220,53,69,.1) !important; }
.rounded-circle.bg-info.bg-opacity-10    { background-color: rgba(13,202,240,.1) !important; }
.rounded-circle.bg-warning.bg-opacity-10 { background-color: rgba(255,193,7,.1) !important; }

.rounded-circle {
  width: 44px;
  height: 44px;
  display: flex;
  align-items: center;
  justify-content: center;
}

/* ═══════════════════════════════════════════════════════════════════════════
   Round 2 — Refinamento de componentes
   ═══════════════════════════════════════════════════════════════════════════ */

/* ─── Definition lists em cards ──────────────────────────────────────────── */
.card-body dl.row > dt {
  font-size: .68rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: .055rem;
  color: var(--vibe-muted);
  display: flex;
  align-items: center;
  padding: .5rem .25rem;
  margin-bottom: 0;
  border-top: 1px solid var(--vibe-border);
}

.card-body dl.row > dd {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: .25rem;
  padding: .5rem .25rem;
  margin-bottom: 0;
  border-top: 1px solid var(--vibe-border);
}

/* Remove separador da primeira linha */
.card-body dl.row > dt:first-child,
.card-body dl.row > dt:first-child + dd {
  border-top: none;
  padding-top: 0;
}

/* ─── Filter bar ─────────────────────────────────────────────────────────── */
.filter-bar {
  background: #fff;
  border: 1px solid var(--vibe-border);
  border-radius: var(--vibe-radius);
  padding: .85rem 1rem;
  margin-bottom: 1rem;
  box-shadow: var(--vibe-card-shadow);
}

/* ─── Status tabs (pill shape) ───────────────────────────────────────────── */
.status-tabs .btn {
  border-radius: 2rem !important;
  padding: .3rem .95rem;
}

.status-tabs .badge {
  font-size: .58rem;
}

/* ─── Plan price ─────────────────────────────────────────────────────────── */
.plan-price {
  font-size: 1.65rem;
  font-weight: 700;
  color: var(--vibe-text);
  letter-spacing: -.025em;
  line-height: 1.2;
}

.plan-price .currency {
  font-size: .8rem;
  font-weight: 500;
  color: var(--vibe-muted);
  vertical-align: super;
  margin-right: .1rem;
}

/* ─── Ação rápida (botão ícone) ──────────────────────────────────────────── */
.btn-icon {
  width: 30px;
  height: 30px;
  padding: 0;
  display: inline-flex;
  align-items: center;
  justify-content: center;
}

/* ─── Empty state em tabelas ─────────────────────────────────────────────── */
tbody .empty-row td {
  padding: 2.5rem 1rem;
  color: var(--vibe-muted);
  font-size: .82rem;
}

tbody .empty-row i {
  opacity: .35;
}

/* ─── Page header — contagem discreta ───────────────────────────────────── */
.page-count {
  font-size: .72rem;
  color: var(--vibe-muted);
  font-weight: 400;
}

/* ─── Finance — cor dos lançamentos ─────────────────────────────────────── */
.amount-income  { color: #16a34a; font-weight: 600; }
.amount-expense { color: #dc2626; font-weight: 600; }
