/* ============================================================================
   FIN7 — Design System (camada única, aditiva sobre Bootstrap 4.6 + SB-Admin-2).
   Carregada DEPOIS de style.min.css. NÃO altera estrutura/lógica — só tokens,
   cores, tipografia, espaçamento, componentes.

   ETAPA 0 (Fundação): consolida o antigo fin7-theme.css + o bloco inline de
   layout-tabela.ejs num contrato ÚNICO. Resolve o conflito gold×azul:
     • ACENTO ÚNICO = gold (foco, item ativo, paginação ativa, destaques).
     • PRIMÁRIO (botão sólido) = navy.
     • Azul = só semântica info/edit.  Verde/vermelho = success/erro.
   Direção: Swiss corporativo financeiro — superfície branca/neutra, hairlines,
   tabela de header claro (estilo Stripe/Linear), numerais tabulares.
   ========================================================================== */

:root {
	/* estrutura */
	--fin7-navy: #0f1f35;
	--fin7-navy-2: #16294a;
	--fin7-ink: #1e293b;
	--fin7-muted: #64748b;
	--fin7-line: #e6eaf0;
	--fin7-line-2: #f1f5f9;
	--fin7-surface: #ffffff;
	--fin7-surface-2: #f8fafc;
	--fin7-bg: #f4f6f9;

	/* acento único */
	--fin7-gold: #c9a227;
	--fin7-gold-soft: #e6c659;
	--fin7-gold-tint: #faf6e8;

	/* semânticas (NÃO são acento) */
	--fin7-ok: #16a34a;   --fin7-ok-tint: #f0fdf4;   --fin7-ok-line: #86efac;
	--fin7-warn: #d97706; --fin7-warn-tint: #fffbeb;
	--fin7-err: #dc2626;  --fin7-err-tint: #fef2f2;  --fin7-err-line: #fecaca;
	--fin7-info: #2563eb; --fin7-info-tint: #eff6ff; --fin7-info-line: #bfdbfe;

	/* raio ÚNICO (mata 12/10/8/6/5 conflitantes) */
	--fin7-radius: 10px;
	--fin7-radius-sm: 6px;

	/* espaçamento */
	--fin7-sp-1: 4px; --fin7-sp-2: 8px; --fin7-sp-3: 12px;
	--fin7-sp-4: 16px; --fin7-sp-5: 20px; --fin7-sp-6: 24px; --fin7-sp-8: 32px;

	/* elevação */
	--fin7-sh-1: 0 1px 2px rgba(15,31,53,.06), 0 1px 3px rgba(15,31,53,.05);
	--fin7-sh-2: 0 2px 6px rgba(15,31,53,.07), 0 6px 16px rgba(15,31,53,.06);
	--fin7-sh-3: 0 8px 18px rgba(15,31,53,.10), 0 18px 40px rgba(15,31,53,.10);
	--fin7-ring: 0 0 0 3px rgba(201,162,39,.28);

	--fin7-ease: cubic-bezier(.4, 0, .2, 1);
	--fin7-t: 160ms;
}

/* ---- base ---- */
body { background-color: var(--fin7-bg); color: var(--fin7-ink); }
h1, .h1 { color: var(--fin7-ink); font-weight: 700; letter-spacing: -.02em; }

.btn, .nav-link, .page-link, .dropdown-item, .form-control,
.custom-control-label, .badge, a.list-group-item, .dt-button {
	transition: background-color var(--fin7-t) var(--fin7-ease),
		border-color var(--fin7-t) var(--fin7-ease),
		color var(--fin7-t) var(--fin7-ease),
		box-shadow var(--fin7-t) var(--fin7-ease);
}

/* ---- cards ---- */
.card {
	border: 1px solid var(--fin7-line);
	border-radius: var(--fin7-radius);
	box-shadow: var(--fin7-sh-1);
	background: var(--fin7-surface);
}
/* elevação suave no hover só de sombra (sem translateY que "pula" em telas densas) */
.card:hover { box-shadow: var(--fin7-sh-2); }
.card .card-header {
	background: var(--fin7-surface-2);
	border-bottom: 1px solid var(--fin7-line);
	font-weight: 700; color: var(--fin7-navy);
}
.card-footer {
	background: var(--fin7-surface-2);
	border-top: 1px solid var(--fin7-line);
	border-radius: 0 0 var(--fin7-radius) var(--fin7-radius);
}
.card.border-left-primary, .card.border-left-success,
.card.border-left-info, .card.border-left-warning { border-left-width: .25rem; }

/* slot de ações no topo do card (padrão dos módulos) */
.fin7-card-header {
	display: flex; align-items: center; justify-content: flex-end;
	padding: 12px 20px; background: var(--fin7-surface);
	border-bottom: 1px solid var(--fin7-line);
	border-radius: var(--fin7-radius) var(--fin7-radius) 0 0;
	min-height: 52px; gap: 8px;
}
.fin7-card-header:empty { display: none; }

/* ---- botões (sistema único: primário navy, acento gold no foco) ---- */
.btn { border-radius: var(--fin7-radius-sm); font-weight: 600; letter-spacing: .01em; }
.btn:hover { box-shadow: var(--fin7-sh-1); }
.btn:active { transform: translateY(0) scale(.98); }
.btn-primary {
	background: linear-gradient(180deg, var(--fin7-navy-2), var(--fin7-navy));
	border-color: var(--fin7-navy); color: #fff;
}
.btn-primary:hover { background: linear-gradient(180deg, #1d335c, #0c1a30); border-color: var(--fin7-navy); }
.btn:focus, .btn:focus-visible { box-shadow: var(--fin7-ring) !important; outline: none; }

.card-footer .btn-light {
	background: var(--fin7-surface); border: 1px solid var(--fin7-line);
	color: var(--fin7-muted); border-radius: var(--fin7-radius-sm);
}
.card-footer .btn-light:hover { background: var(--fin7-line-2); border-color: #cbd5e1; color: var(--fin7-ink); }

/* botões utilitários de linha/módulo (unificados) */
.btn-fin7-primary {
	display: inline-flex; align-items: center; gap: 6px;
	background: linear-gradient(180deg, var(--fin7-navy-2), var(--fin7-navy));
	border: none; color: #fff; padding: 8px 18px;
	border-radius: var(--fin7-radius-sm); font-size: 13px; font-weight: 600;
	cursor: pointer; text-decoration: none;
}
.btn-fin7-primary:hover { filter: brightness(1.08); color: #fff; }
.btn-fin7-edit {
	display: inline-flex; align-items: center; gap: 4px;
	background: transparent; border: 1px solid var(--fin7-info-line);
	color: var(--fin7-info); padding: 4px 9px; border-radius: var(--fin7-radius-sm);
	font-size: 12px; cursor: pointer; line-height: 1.4; text-decoration: none;
}
.btn-fin7-edit:hover { background: var(--fin7-info-tint); border-color: var(--fin7-info); color: #1d4ed8; }
.btn-fin7-delete {
	display: inline-flex; align-items: center; gap: 4px;
	background: transparent; border: 1px solid var(--fin7-err-line);
	color: var(--fin7-err); padding: 4px 9px; border-radius: var(--fin7-radius-sm);
	font-size: 12px; cursor: pointer; line-height: 1.4; margin-left: 5px;
}
.btn-fin7-delete:hover { background: var(--fin7-err-tint); border-color: var(--fin7-err); color: #b91c1c; }

/* ---- tabelas: header CLARO (Stripe/Linear), hover com hairline gold ---- */
.table thead th, table.dataTable thead th, table.dataTable thead td {
	background: var(--fin7-surface-2) !important;
	color: var(--fin7-muted) !important;
	border-top: none !important;
	border-bottom: 1px solid var(--fin7-line) !important;
	font-size: 11px; font-weight: 600; letter-spacing: .05em;
	text-transform: uppercase; padding: 11px 14px !important; white-space: nowrap;
}
.table tbody tr, table.dataTable tbody tr,
table.dataTable.table-striped tbody tr:nth-of-type(odd),
table.dataTable.table-striped tbody tr:nth-of-type(even) {
	background: var(--fin7-surface) !important;
	border-bottom: 1px solid var(--fin7-line-2) !important;
	transition: background var(--fin7-t) var(--fin7-ease), box-shadow var(--fin7-t) var(--fin7-ease);
}
.table tbody tr:hover, table.dataTable tbody tr:hover, .table-hover tbody tr:hover {
	background: var(--fin7-gold-tint) !important;
	box-shadow: inset 3px 0 0 var(--fin7-gold);
}
.table td, table.dataTable tbody td {
	color: var(--fin7-ink) !important; border-top: none !important;
	padding: 10px 14px !important; font-size: 13.5px; vertical-align: middle !important;
}
table.dataTable { border-collapse: collapse !important; width: 100% !important; }
td.text-right, th.text-right, td.num, th.num { font-variant-numeric: tabular-nums; }

/* ---- DataTables: controles com acento GOLD ---- */
.dataTables_wrapper { padding: 0 !important; }
.dataTables_wrapper > .row { padding: 12px 20px; margin: 0; }
.dataTables_length label, .dataTables_filter label, .dataTables_info {
	color: var(--fin7-muted) !important; font-size: 12.5px;
}
.dataTables_wrapper .dataTables_filter input,
.dataTables_wrapper .dataTables_length select {
	background: var(--fin7-surface) !important; border: 1px solid #cbd5e1 !important;
	color: var(--fin7-ink) !important; border-radius: var(--fin7-radius-sm);
	padding: .35rem .6rem;
}
.dataTables_wrapper .dataTables_filter input:focus,
.dataTables_wrapper .dataTables_length select:focus {
	border-color: var(--fin7-gold) !important; box-shadow: var(--fin7-ring) !important; outline: none;
}
.dataTables_paginate .paginate_button, .dataTables_wrapper .dataTables_paginate .page-link {
	color: var(--fin7-muted) !important; background: var(--fin7-surface) !important;
	border: 1px solid var(--fin7-line) !important; border-radius: var(--fin7-radius-sm) !important;
	padding: 4px 11px !important; margin: 0 2px !important;
}
.dataTables_paginate .paginate_button.current,
.dataTables_paginate .paginate_button.current:hover,
.dataTables_wrapper .dataTables_paginate .page-item.active .page-link {
	background: var(--fin7-gold) !important; border-color: var(--fin7-gold) !important; color: #fff !important;
}
.dataTables_paginate .paginate_button:hover:not(.disabled):not(.current) {
	background: var(--fin7-gold-tint) !important; border-color: var(--fin7-gold) !important; color: #96751a !important;
}
.dt-buttons .btn, .dt-buttons .btn:focus, .dt-button {
	background: var(--fin7-surface) !important; border: 1px solid #cbd5e1 !important;
	color: var(--fin7-muted) !important; border-radius: var(--fin7-radius-sm) !important; box-shadow: none !important;
}
.dt-buttons .btn:hover { background: var(--fin7-gold-tint) !important; color: #96751a !important; border-color: var(--fin7-gold) !important; }

/* ---- badges / tags ---- */
.badge { border-radius: 999px; padding: .35em .7em; font-weight: 600; }
.badge-fin7-on {
	background: var(--fin7-ok-tint); color: var(--fin7-ok); border: 1px solid var(--fin7-ok-line);
	padding: 2px 9px; border-radius: 999px; font-size: 11.5px; font-weight: 600; white-space: nowrap;
}
.badge-fin7-off {
	background: var(--fin7-err-tint); color: #b91c1c; border: 1px solid var(--fin7-err-line);
	padding: 2px 9px; border-radius: 999px; font-size: 11.5px; font-weight: 600; white-space: nowrap;
}

/* ---- formulários (global — aplica em toda tela, sem tocar a view) ---- */
.form-group label { color: var(--fin7-ink); font-weight: 600; font-size: 12.5px; margin-bottom: 6px; }
.form-control { border-radius: var(--fin7-radius-sm); border-color: #cbd5e1; color: var(--fin7-ink); }
.form-control::placeholder { color: #9aa7bd; }
.form-control:focus { border-color: var(--fin7-gold); box-shadow: var(--fin7-ring); }
select.form-control:focus { border-color: var(--fin7-gold); }
textarea.form-control { min-height: 92px; }

/* checkbox / radio / switch → acento gold (nativo + Bootstrap custom-control) */
input[type="checkbox"], input[type="radio"] { accent-color: var(--fin7-gold); }
.custom-control-input:checked ~ .custom-control-label::before { background-color: var(--fin7-gold) !important; border-color: var(--fin7-gold) !important; }
.custom-control-input:focus ~ .custom-control-label::before { box-shadow: var(--fin7-ring) !important; }

/* validação (jquery-validate: label.error injetada; .error/.is-invalid no campo) */
label.error { color: var(--fin7-err); font-size: 11.5px; font-weight: 400; margin-top: 4px; display: block; }
.form-control.error, .form-control.is-invalid { border-color: #fca5a5 !important; }
.form-control.error:focus, .form-control.is-invalid:focus { box-shadow: 0 0 0 3px rgba(220,38,38,.14) !important; }
.form-control.valid { border-color: var(--fin7-ok-line); }

/* divisor de seção */
#content hr { border-color: var(--fin7-line); opacity: 1; }

/* marcador de obrigatório + seção de formulário (classes adotáveis nas views) */
label.required::after, .form-group.required > label::after { content: " *"; color: var(--fin7-gold); font-weight: 700; }
.fin7-form-section { font-size: 12px; font-weight: 700; text-transform: uppercase; letter-spacing: .06em; color: var(--fin7-navy); padding-bottom: 8px; margin: 6px 0 18px; border-bottom: 2px solid var(--fin7-gold); }

/* ---- sidebar (item ativo GOLD) ---- */
.sidebar, #accordionSidebar { box-shadow: var(--fin7-sh-2); }
.sidebar .nav-item .nav-link { border-radius: var(--fin7-radius-sm); margin: 1px 10px; }
.sidebar .nav-item .nav-link:hover { background: rgba(255,255,255,.08); }
.sidebar .nav-item .nav-link.active, .sidebar .nav-item.active .nav-link {
	background: rgba(201,162,39,.16); box-shadow: inset 3px 0 0 var(--fin7-gold);
}
.sidebar .nav-item .nav-link i { transition: transform var(--fin7-t) var(--fin7-ease); display: inline-block; }
.sidebar .nav-item .nav-link:hover i { transform: scale(1.12); }

/* ---- topbar ---- */
.topbar { box-shadow: var(--fin7-sh-1) !important; position: relative; z-index: 1040; }
.topbar .nav-item .nav-link:hover { color: var(--fin7-gold); }
.topbar .dropdown-menu { z-index: 1055 !important; }

/* HUD toggle + seletor de clínicas (pill) — tokenizado, era estilo inline na topbar */
.fin7-hud-toggle { color: var(--fin7-muted); font-size: 18px; text-decoration: none; padding: 6px 10px; }
.fin7-hud-toggle:hover { color: var(--fin7-gold); text-decoration: none; }
.fin7-clinic-pill {
	display: flex; align-items: center; gap: 6px;
	border-radius: 999px; font-weight: 600; font-size: 13px;
	background: var(--fin7-surface); color: var(--fin7-navy);
	border: 1px solid var(--fin7-line);
}
.fin7-clinic-pill:hover, .fin7-clinic-pill:focus {
	border-color: var(--fin7-gold); color: var(--fin7-navy); box-shadow: var(--fin7-ring);
}
.fin7-clinic-pill .ph { font-size: 14px; color: var(--fin7-gold); }

/* ---- dropdowns ---- */
.dropdown-menu.show { animation: fin7DropIn .16s var(--fin7-ease) both; }
@keyframes fin7DropIn { from { opacity: 0; transform: translateY(-6px) scale(.98); } to { opacity: 1; transform: none; } }

/* ---- modal padrão único (.modal-fin7) ---- */
.modal-fin7 .modal-dialog { display: flex; align-items: center; min-height: calc(100% - 3.5rem); }
.modal-fin7 .modal-content {
	background: var(--fin7-surface); border: 1px solid var(--fin7-line);
	border-radius: var(--fin7-radius); box-shadow: var(--fin7-sh-3); width: 100%;
}
.modal-fin7 .modal-header {
	background: var(--fin7-surface-2); border-bottom: 1px solid var(--fin7-line);
	border-radius: var(--fin7-radius) var(--fin7-radius) 0 0; padding: 16px 24px;
}
.modal-fin7 .modal-title { color: var(--fin7-ink); font-size: 15px; font-weight: 700; }
.modal-fin7 .modal-body { background: var(--fin7-surface); padding: 24px 28px; }
.modal-fin7 .modal-footer {
	background: var(--fin7-surface-2); border-top: 1px solid var(--fin7-line);
	border-radius: 0 0 var(--fin7-radius) var(--fin7-radius); padding: 12px 24px; gap: 8px; justify-content: center;
}
.modal-fin7 label { color: var(--fin7-muted); font-size: 12px; font-weight: 600; margin-bottom: 5px; display: block; }
.modal-fin7 .form-control, .modal-fin7 select.form-control {
	background: var(--fin7-surface) !important; border: 1px solid #cbd5e1 !important; color: var(--fin7-ink) !important;
	border-radius: var(--fin7-radius-sm); font-size: 13.5px; padding: 8px 12px;
}
.modal-fin7 .form-control:focus, .modal-fin7 select.form-control:focus {
	border-color: var(--fin7-gold) !important; box-shadow: var(--fin7-ring) !important; outline: none;
}
.modal-fin7 .form-group { margin-bottom: 18px; }
.modal-fin7 .form-group:last-child { margin-bottom: 0; }
.modal-fin7 label.error { color: var(--fin7-err); font-size: 11px; margin-top: 3px; font-weight: 400; }
.modal-fin7 .form-control.error { border-color: #fca5a5 !important; }
/* header premium: ícone + subtítulo (classes adotáveis; não altera layout do header padrão) */
.fin7-modal-ico { width: 40px; height: 40px; border-radius: 10px; background: var(--fin7-gold-tint); color: var(--fin7-gold); display: inline-flex; align-items: center; justify-content: center; font-size: 22px; flex-shrink: 0; }
.fin7-modal-sub { color: var(--fin7-muted); font-size: 12px; font-weight: 400; margin-top: 2px; }
.modal-fin7 .modal-body .fin7-form-section:first-child { margin-top: 0; }

/* ---- scrollbar ---- */
* { scrollbar-width: thin; scrollbar-color: #c3ccdb transparent; }
*::-webkit-scrollbar { width: 10px; height: 10px; }
*::-webkit-scrollbar-thumb { background: #c3ccdb; border-radius: 999px; border: 2px solid transparent; background-clip: content-box; }
*::-webkit-scrollbar-thumb:hover { background: #9aa7bd; background-clip: content-box; }

/* ---- entrada de conteúdo (fade suave, sem stagger exagerado) ---- */
@keyframes fin7FadeUp { from { opacity: 0; transform: translateY(8px); } to { opacity: 1; transform: none; } }
#content .container-fluid > .card, #content .container-fluid > .row { animation: fin7FadeUp .34s var(--fin7-ease) both; }

/* ---- acessibilidade ---- */
a { transition: color var(--fin7-t) var(--fin7-ease); }
a:focus-visible, button:focus-visible { outline: 2px solid var(--fin7-gold); outline-offset: 2px; }
.spinner-border { animation-duration: .7s; }

/* ---- empty-state / loading (tabelas DataTables + geral) ---- */
.fin7-empty { display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 10px; padding: 40px 16px; color: var(--fin7-muted); text-align: center; }
.fin7-empty .ph { font-size: 34px; color: #c3ccdb; }
.fin7-empty span { font-size: 13px; }
.fin7-empty-sm { flex-direction: row; padding: 24px 16px; gap: 10px; }
.fin7-spin { width: 16px; height: 16px; border-radius: 50%; border: 2px solid var(--fin7-line); border-top-color: var(--fin7-gold); display: inline-block; animation: fin7Spin .7s linear infinite; }
@keyframes fin7Spin { to { transform: rotate(360deg); } }
table.dataTable td.dataTables_empty { padding: 0 !important; }

/* ---- skeleton (telas shell+async) ---- */
.fin7-skeleton { background: linear-gradient(90deg, #eef2f7 25%, #f6f8fb 37%, #eef2f7 63%); background-size: 400% 100%; border-radius: 6px; animation: fin7Shimmer 1.3s ease infinite; }
@keyframes fin7Shimmer { 0% { background-position: 100% 0; } 100% { background-position: 0 0; } }
.fin7-skel-row { height: 16px; margin: 12px 20px; }
.fin7-skel-card { height: 96px; border-radius: var(--fin7-radius); margin-bottom: 18px; }
.fin7-skel-wrap { padding: 8px 0; }
.fin7-spin-lg { width: 26px; height: 26px; border-width: 3px; }

/* ---- estado (partial _estado.ejs) ---- */
.fin7-estado { display: flex; flex-direction: column; align-items: center; justify-content: center; text-align: center; gap: 10px; padding: 48px 20px; color: var(--fin7-muted); }
.fin7-estado > .ph { font-size: 42px; color: #c3ccdb; }
.fin7-estado-erro > .ph { color: #fca5a5; }
.fin7-estado-permissao > .ph { color: #fcd34d; }
.fin7-estado-sucesso > .ph { color: #86efac; }
.fin7-estado-offline > .ph { color: #cbd5e1; }
.fin7-estado-titulo { font-size: 15px; font-weight: 700; color: var(--fin7-ink); }
.fin7-estado-msg { font-size: 13px; max-width: 360px; line-height: 1.55; }
.fin7-estado-cta { margin-top: 8px; }

/* ---- toast (fin7-ui.js) ---- */
.fin7-toasts { position: fixed; top: 16px; right: 16px; z-index: 3000; display: flex; flex-direction: column; gap: 10px; max-width: 360px; }
.fin7-toast { display: flex; align-items: center; gap: 10px; background: #fff; border: 1px solid var(--fin7-line); border-left: 4px solid var(--fin7-muted); border-radius: 10px; box-shadow: var(--fin7-sh-3); padding: 12px 14px; font-size: 13px; color: var(--fin7-ink); opacity: 0; transform: translateX(16px); transition: opacity .22s var(--fin7-ease), transform .22s var(--fin7-ease); }
.fin7-toast.show { opacity: 1; transform: none; }
.fin7-toast .ph { font-size: 20px; flex-shrink: 0; }
.fin7-toast > span { flex: 1; }
.fin7-toast-x { background: none; border: none; color: #94a3b8; font-size: 18px; line-height: 1; cursor: pointer; padding: 0 2px; }
.fin7-toast-x:hover { color: var(--fin7-ink); }
.fin7-toast-ok { border-left-color: var(--fin7-ok); }   .fin7-toast-ok .ph { color: var(--fin7-ok); }
.fin7-toast-erro { border-left-color: var(--fin7-err); } .fin7-toast-erro .ph { color: var(--fin7-err); }
.fin7-toast-info { border-left-color: var(--fin7-info); } .fin7-toast-info .ph { color: var(--fin7-info); }
.fin7-toast-warn { border-left-color: var(--fin7-warn); } .fin7-toast-warn .ph { color: var(--fin7-warn); }

/* respeita quem pede menos movimento */
@media (prefers-reduced-motion: reduce) {
	*, .card:hover, .btn:hover { animation: none !important; transition: none !important; transform: none !important; }
}
