/**
 * Design system — tokens estáticos + componentes base (site público / painel cliente).
 * Cores de marca vêm do tema inline (#site-palette-theme); aqui usamos var(--color-*).
 */
:root {
	--ds-font-sans: "Segoe UI", system-ui, -apple-system, BlinkMacSystemFont, "Roboto", sans-serif;
	--ds-radius-sm: 10px;
	--ds-radius-md: 14px;
	--ds-radius-lg: 18px;
	--ds-transition: 0.2s ease;
	--ds-border: #e2e8f0;
	--ds-text: #1f2d3d;
	--ds-text-soft: #5f6b7a;
	--ds-success: #1f8f5f;
	--ds-danger: #c94b4b;
	--ds-warning: #d6a12c;
	--ds-shadow-sm: 0 2px 8px rgba(13, 46, 74, 0.06);
	--ds-shadow-md: 0 8px 24px rgba(13, 46, 74, 0.08);
	--ds-shadow-lg: 0 16px 48px rgba(13, 46, 74, 0.1);
	--ds-focus-ring: 0 0 0 3px rgba(18, 62, 99, 0.22);
}

/* ---------- Base ---------- */
.site-body.premium-ui {
	font-family: var(--ds-font-sans);
	color: var(--color-gray-700, var(--ds-text));
	-webkit-font-smoothing: antialiased;
}

.site-body.premium-ui .site-main {
	min-height: 42vh;
}

.site-body.premium-ui a:not(.btn):not(.nav-link):not(.dropdown-item):not(.page-link):not(.breadcrumb-item a):not(.text-secondary-custom):not(.nav-link-custom) {
	color: var(--cor-primaria, var(--color-dark-soft));
	text-decoration-color: rgba(var(--color-dark-soft-rgb), 0.35);
	transition: color var(--ds-transition), text-decoration-color var(--ds-transition);
}

.site-body.premium-ui a:not(.btn):not(.nav-link):not(.dropdown-item):not(.page-link):not(.breadcrumb-item a):not(.text-secondary-custom):not(.nav-link-custom):hover {
	color: var(--color-primary, #1e5a8a);
	text-decoration-color: rgba(var(--color-primary-rgb), 0.5);
}

/* ---------- Títulos de seção ---------- */
.site-body.premium-ui .section-title {
	font-weight: 800;
	letter-spacing: -0.02em;
	color: var(--ds-text);
	font-size: clamp(1.35rem, 2.5vw, 1.65rem);
	line-height: 1.25;
	margin-bottom: 0.5rem;
	position: relative;
	padding-bottom: 0.35rem;
}

.site-body.premium-ui .section-title::after {
	content: "";
	position: absolute;
	left: 0;
	bottom: 0;
	width: 48px;
	height: 3px;
	border-radius: 3px;
	background: linear-gradient(90deg, var(--color-accent), rgba(var(--color-accent-rgb), 0.35));
}

.site-body.premium-ui .text-center .section-title::after {
	left: 50%;
	transform: translateX(-50%);
}

/* ---------- Formulários ---------- */
.site-body.premium-ui .form-label {
	font-weight: 600;
	color: var(--ds-text);
	font-size: 0.875rem;
	margin-bottom: 0.35rem;
}

.site-body.premium-ui .form-control,
.site-body.premium-ui .form-select {
	border-radius: var(--ds-radius-sm);
	border-color: var(--ds-border);
	padding: 0.55rem 0.9rem;
	font-size: 0.95rem;
	transition: border-color var(--ds-transition), box-shadow var(--ds-transition), background var(--ds-transition);
	background-color: #fff;
}

.site-body.premium-ui .form-control:hover,
.site-body.premium-ui .form-select:hover {
	border-color: rgba(var(--color-dark-soft-rgb), 0.22);
}

.site-body.premium-ui .form-control:focus,
.site-body.premium-ui .form-select:focus {
	border-color: var(--color-primary, #1e5a8a);
	box-shadow: var(--ds-focus-ring);
	outline: none;
}

.site-body.premium-ui .form-control::placeholder {
	color: var(--ds-text-soft);
	opacity: 0.85;
}

.site-body.premium-ui .form-control:disabled,
.site-body.premium-ui .form-select:disabled {
	background: #f1f4f8;
	opacity: 0.85;
}

.site-body.premium-ui .form-check-input:focus {
	box-shadow: 0 0 0 3px rgba(var(--color-accent-rgb), 0.25);
	border-color: var(--color-accent);
}

.site-body.premium-ui .form-check-input:checked {
	background-color: var(--color-dark);
	border-color: var(--color-dark);
}

/* ---------- Botões Bootstrap alinhados à marca ---------- */
.site-body.premium-ui .btn {
	border-radius: var(--ds-radius-sm);
	font-weight: 600;
	transition: transform 0.15s ease, box-shadow var(--ds-transition), background var(--ds-transition), border-color var(--ds-transition), color var(--ds-transition);
}

.site-body.premium-ui .btn:active:not(:disabled) {
	transform: translateY(1px);
}

.site-body.premium-ui .btn-primary {
	background: var(--color-dark);
	border-color: var(--color-dark);
	color: #fff;
}

.site-body.premium-ui .btn-primary:hover,
.site-body.premium-ui .btn-primary:focus {
	background: var(--cor-primaria, var(--color-dark-soft));
	border-color: var(--cor-primaria, var(--color-dark-soft));
	color: #fff;
	box-shadow: 0 4px 14px rgba(var(--color-dark-rgb), 0.28);
}

.site-body.premium-ui .btn-secondary {
	background: var(--ds-text-soft);
	border-color: var(--ds-text-soft);
}

.site-body.premium-ui .btn-outline-secondary {
	color: var(--ds-text);
	border-color: var(--ds-border);
	font-weight: 600;
}

.site-body.premium-ui .btn-outline-secondary:hover {
	background: var(--color-gray-100, #f5f7fa);
	border-color: rgba(var(--color-dark-soft-rgb), 0.25);
	color: var(--color-dark);
}

.site-body.premium-ui .btn-outline-dark {
	border-radius: var(--ds-radius-sm);
	font-weight: 600;
}

.site-body.premium-ui .btn-accent {
	border-radius: var(--ds-radius-sm);
	box-shadow: 0 4px 14px rgba(var(--color-accent-rgb), 0.28);
}

.site-body.premium-ui .btn-accent:hover {
	box-shadow: 0 6px 20px rgba(var(--color-accent-rgb), 0.35);
}

.site-body.premium-ui .btn-sm {
	padding: 0.4rem 0.75rem;
	font-size: 0.875rem;
}

.site-body.premium-ui .btn-lg {
	padding: 0.65rem 1.35rem;
	font-size: 1.05rem;
	border-radius: var(--ds-radius-md);
}

/* ---------- Cards genéricos ---------- */
.site-body.premium-ui .card {
	border-radius: var(--ds-radius-md);
	border-color: var(--ds-border);
	box-shadow: var(--ds-shadow-sm);
	overflow: hidden;
}

.site-body.premium-ui .card.card-custom {
	border: 1px solid var(--ds-border);
	box-shadow: var(--ds-shadow-sm);
	border-radius: var(--ds-radius-md);
}

/* ---------- Modais ---------- */
.site-body.premium-ui .modal-content {
	border: none;
	border-radius: var(--ds-radius-lg);
	box-shadow: var(--ds-shadow-lg);
}

.site-body.premium-ui .modal-header {
	border-bottom-color: var(--ds-border);
	padding: 1.1rem 1.25rem;
}

.site-body.premium-ui .modal-footer {
	border-top-color: var(--ds-border);
	padding: 0.85rem 1.25rem;
}

.site-body.premium-ui .modal-title {
	font-weight: 800;
	color: var(--ds-text);
	letter-spacing: -0.02em;
}

/* ---------- Paginação ---------- */
.site-body.premium-ui .pagination .page-link {
	border-radius: var(--ds-radius-sm);
	margin: 0 0.15rem;
	border-color: var(--ds-border);
	color: var(--color-dark);
	font-weight: 600;
	padding: 0.45rem 0.75rem;
	transition: background var(--ds-transition), color var(--ds-transition), border-color var(--ds-transition);
}

.site-body.premium-ui .pagination .page-item.active .page-link {
	background: var(--color-dark);
	border-color: var(--color-dark);
	color: #fff;
}

.site-body.premium-ui .pagination .page-link:hover {
	background: var(--color-gray-100, #eef3f8);
	border-color: rgba(var(--color-dark-soft-rgb), 0.2);
	color: var(--color-dark);
}

/* ---------- Tabelas ---------- */
.site-body.premium-ui .table {
	--bs-table-hover-bg: rgba(var(--color-primary-rgb), 0.06);
}

.site-body.premium-ui .table thead th {
	font-size: 0.78rem;
	text-transform: uppercase;
	letter-spacing: 0.06em;
	font-weight: 700;
	color: var(--ds-text-soft);
	border-bottom-width: 1px;
	border-color: var(--ds-border);
	background: #fafbfc;
}

.site-body.premium-ui .table td {
	vertical-align: middle;
	border-color: var(--ds-border);
}

/* ---------- Alertas ---------- */
.site-body.premium-ui .alert {
	border: none;
	border-radius: var(--ds-radius-md);
	font-weight: 500;
	border-left: 4px solid transparent;
}

.site-body.premium-ui .alert-success {
	background: rgba(31, 143, 95, 0.1);
	color: #0d4a32;
	border-left-color: var(--ds-success);
}

.site-body.premium-ui .alert-danger {
	background: rgba(201, 75, 75, 0.1);
	color: #6b1f1f;
	border-left-color: var(--ds-danger);
}

.site-body.premium-ui .alert-warning {
	background: rgba(214, 161, 44, 0.12);
	color: #5c4510;
	border-left-color: var(--ds-warning);
}

.site-body.premium-ui .alert-info {
	background: rgba(var(--color-primary-rgb), 0.08);
	color: var(--ds-text);
	border-left-color: var(--color-primary);
}

/* ---------- Abas ---------- */
.site-body.premium-ui .nav-tabs .nav-link {
	border-radius: var(--ds-radius-sm) var(--ds-radius-sm) 0 0;
	font-weight: 600;
	color: var(--ds-text-soft);
	border-color: transparent;
}

.site-body.premium-ui .nav-tabs .nav-link:hover {
	border-color: var(--ds-border);
	color: var(--color-dark);
}

.site-body.premium-ui .nav-tabs .nav-link.active {
	color: var(--color-dark);
	font-weight: 700;
	border-color: var(--ds-border) var(--ds-border) #fff;
}

/* ---------- Accordion (FAQ etc.) ---------- */
.site-body.premium-ui .accordion-item {
	border-color: var(--ds-border);
	border-radius: var(--ds-radius-md) !important;
	overflow: hidden;
	margin-bottom: 0.5rem;
}

.site-body.premium-ui .accordion-button {
	font-weight: 600;
	color: var(--ds-text);
}

.site-body.premium-ui .accordion-button:not(.collapsed) {
	background: rgba(var(--color-primary-rgb), 0.06);
	color: var(--color-dark);
	box-shadow: none;
}

.site-body.premium-ui .accordion-button:focus {
	box-shadow: var(--ds-focus-ring);
	border-color: transparent;
}

/* ---------- Utilitários ---------- */
.site-body.premium-ui .shadow-soft {
	box-shadow: var(--ds-shadow-md) !important;
}

.site-body.premium-ui .radius-lg {
	border-radius: var(--ds-radius-lg) !important;
}
