/**
 * Páris + Saúde — Convênio (front)
 */

.paris-saude-wrap {
	--ps-teal: #0a5f5a;
	--ps-teal-dark: #06403c;
	--ps-paris-red: #c41e3a;
	--ps-paris-red-soft: #fdf2f4;
	--ps-paris-red-border: #e8b4bd;
	--ps-paris-red-text: #a61e35;
	--ps-paris-red-hover-bg: #fce8ec;
	--ps-bg: #f4fbfb;
	--ps-card: #ffffff;
	--ps-border: #e2efee;
	--ps-text: #1a2b2a;
	--ps-muted: #5c6f6e;
	--ps-heading: #293b7f;
	max-width: 960px;
	margin: 0 auto;
	padding: 1.5rem 1rem 3rem;
	color: var(--ps-text);
	font-family: system-ui, -apple-system, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;
	line-height: 1.5;
}

/* Títulos no azul do tema (#293b7f); reforça contra tema / Elementor */
.paris-saude-wrap h1,
.paris-saude-wrap h2,
.paris-saude-wrap h3,
.paris-saude-wrap h4 {
	color: var(--ps-heading) !important;
}

/* Placeholder some ao focar (ex.: % desconto “10”) — evita texto de exemplo visível enquanto digita */
.paris-saude-wrap input:focus::placeholder,
.paris-saude-wrap textarea:focus::placeholder {
	opacity: 0;
	color: transparent;
}
.paris-saude-wrap input:focus::-webkit-input-placeholder,
.paris-saude-wrap textarea:focus::-webkit-input-placeholder {
	opacity: 0;
	color: transparent;
}
.paris-saude-wrap input:focus::-moz-placeholder,
.paris-saude-wrap textarea:focus::-moz-placeholder {
	opacity: 0;
	color: transparent;
}

.paris-saude-brand {
	text-align: center;
	margin-bottom: 1.75rem;
}

.paris-saude-brand__title {
	display: block;
	font-size: 1.75rem;
	font-weight: 700;
	color: var(--ps-heading);
	letter-spacing: -0.02em;
}

.paris-saude-brand__sub {
	display: block;
	font-size: 0.95rem;
	color: var(--ps-muted);
	margin-top: 0.25rem;
}

.paris-saude-wrap--login #loginform,
.paris-saude-wrap--login form {
	background: var(--ps-card);
	border: 1px solid var(--ps-border);
	border-radius: 12px;
	padding: 1.5rem;
	box-shadow: 0 8px 28px rgba(10, 95, 90, 0.07);
}

.paris-saude-wrap--login label {
	display: block;
	margin-bottom: 0.75rem;
	font-weight: 600;
	color: var(--ps-text);
}

.paris-saude-wrap--login input[type="text"],
.paris-saude-wrap--login input[type="password"] {
	width: 100%;
	max-width: 100%;
	box-sizing: border-box;
	padding: 0.65rem 0.75rem;
	border: 1px solid var(--ps-border);
	border-radius: 8px;
	margin-top: 0.35rem;
}

.paris-saude-wrap--login .login-remember {
	margin-top: 0.75rem;
}

.paris-saude-wrap--login .submit input.button {
	background: var(--ps-teal);
	border: none;
	color: #fff;
	padding: 0.65rem 1.25rem;
	border-radius: 8px;
	font-weight: 600;
	cursor: pointer;
}

.paris-saude-wrap--login .submit input.button:hover {
	background: var(--ps-teal-dark);
}

.paris-saude-lost {
	text-align: center;
	margin-top: 1rem;
}

.paris-saude-header {
	margin-bottom: 1.5rem;
}

.paris-saude-header__title {
	margin: 0 0 0.35rem;
	font-size: 1.5rem;
	color: var(--ps-heading);
}

.paris-saude-header__meta {
	margin: 0;
	font-size: 0.9rem;
	color: var(--ps-muted);
}

.paris-saude-header__meta a {
	color: var(--ps-teal);
}

.paris-saude-header--toolbar {
	margin-bottom: 0.65rem;
}

.paris-saude-header--toolbar .paris-saude-header__meta {
	margin: 0;
}

/* Barra tipo app: logo à esquerda, usuário à direita (modelo cabeçalho corporativo) */
.paris-saude-header--appbar {
	margin: -0.25rem -1rem 1rem;
	padding: 0.55rem 1rem;
	background: #fff;
	border-bottom: 1px solid var(--ps-border);
	box-shadow: 0 1px 0 rgba(15, 23, 42, 0.04);
}

.paris-saude-header__bar {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	justify-content: space-between;
	gap: 0.75rem 1.25rem;
	min-height: 3.25rem;
	box-sizing: border-box;
}

.paris-saude-header__brand {
	display: inline-flex;
	align-items: center;
	flex-shrink: 0;
	text-decoration: none;
	line-height: 0;
}

.paris-saude-header__brand--text {
	font-size: 1.15rem;
	font-weight: 700;
	color: var(--ps-heading);
	line-height: 1.2;
}

.paris-saude-header__logo {
	display: block;
	height: 40px;
	width: auto;
	max-width: min(280px, 58vw);
	object-fit: contain;
	object-position: left center;
}

/* Faixa horizontal (paris2.png + Saúde): mais largura, altura contida na barra */
.paris-saude-header__logo--banner {
	height: 44px;
	max-width: min(520px, 82vw);
}

.paris-saude-header__userzone {
	display: inline-flex;
	align-items: center;
	gap: 0.55rem;
	margin-left: auto;
}

.paris-saude-header__avatar {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 2.25rem;
	height: 2.25rem;
	border-radius: 50%;
	background: linear-gradient(145deg, #e2e8f0 0%, #cbd5e1 100%);
	color: #334155;
	font-size: 0.95rem;
	font-weight: 700;
	flex-shrink: 0;
}

.paris-saude-header__usermeta {
	display: flex;
	flex-direction: column;
	align-items: flex-start;
	gap: 0.1rem;
	min-width: 0;
}

.paris-saude-header__username {
	font-size: 0.88rem;
	font-weight: 600;
	color: var(--ps-text);
	max-width: 200px;
	overflow: hidden;
	text-overflow: ellipsis;
	white-space: nowrap;
}

.paris-saude-header__logout {
	font-size: 0.78rem;
	font-weight: 600;
	color: var(--ps-teal);
	text-decoration: none;
}

.paris-saude-header__logout:hover {
	text-decoration: underline;
	color: var(--ps-teal-dark);
}

/* Painel gestão / balcão: layout com menu lateral + área principal mais larga */
.paris-saude-wrap--gestao,
.paris-saude-wrap--consulta,
.paris-saude-wrap--dashboard,
.paris-saude-wrap--logs {
	max-width: min(1180px, 100%);
}

.paris-saude-wrap--kanban {
	max-width: min(1420px, 100%);
}

.paris-saude-app {
	display: flex;
	flex-wrap: nowrap;
	align-items: flex-start;
	gap: 1.25rem;
	width: 100%;
	box-sizing: border-box;
}

.paris-saude-app__sidebar {
	--ps-nav-bg-row: #f8fafc;
	--ps-nav-bg-row-hover: #f1f5f9;
	--ps-nav-bg-active: #e2e8f0;
	--ps-nav-border: #e5e7eb;
	flex: 0 0 252px;
	position: sticky;
	top: 1rem;
	align-self: flex-start;
	padding: 0.65rem 0.5rem 0.85rem;
	background: #fff;
	border: 1px solid var(--ps-nav-border);
	border-radius: 10px;
	box-shadow: 0 1px 3px rgba(15, 23, 42, 0.06);
	box-sizing: border-box;
}

.paris-saude-app__main {
	flex: 1 1 0;
	min-width: 0;
}

/* Linha do menu: ícone | texto | chevron (modelo app corporativo) */
.paris-saude-nav-row {
	display: flex;
	align-items: center;
	gap: 0.55rem;
	width: 100%;
	box-sizing: border-box;
	padding: 0.7rem 0.5rem;
	margin: 0 0 0.35rem;
	font-weight: 600;
	font-size: 0.9rem;
	color: #334155;
	text-decoration: none;
	border-radius: 8px;
	background: var(--ps-nav-bg-row);
	border: none;
	cursor: pointer;
	transition: background 0.12s ease, color 0.12s ease;
}

.paris-saude-nav-row:hover {
	background: var(--ps-nav-bg-row-hover);
	color: #0f172a;
}

.paris-saude-nav-row.is-active {
	background: var(--ps-nav-bg-active);
	color: #0d2462;
	box-shadow: inset 0 0 0 1px rgba(148, 163, 184, 0.35);
}

/* Início / Balcão são <a>: tema costuma aplicar sublinhado e cor de link — alinhar ao bloco Cadastro (summary). */
.paris-saude-app__sidebar a.paris-saude-app__nav-link.paris-saude-nav-row {
	text-decoration: none !important;
	color: #334155 !important;
}

.paris-saude-app__sidebar a.paris-saude-app__nav-link.paris-saude-nav-row:hover {
	color: #0f172a !important;
	text-decoration: none !important;
}

.paris-saude-app__sidebar a.paris-saude-app__nav-link.paris-saude-nav-row:visited {
	color: #334155 !important;
}

.paris-saude-app__sidebar a.paris-saude-app__nav-link.paris-saude-nav-row.is-active,
.paris-saude-app__sidebar a.paris-saude-app__nav-link.paris-saude-nav-row.is-active:visited {
	color: #0d2462 !important;
	text-decoration: none !important;
}

.paris-saude-app__sidebar a.paris-saude-app__nav-link.paris-saude-nav-row.is-active:hover {
	color: #0d2462 !important;
	text-decoration: none !important;
}

.paris-saude-nav-row__icon {
	display: inline-flex;
	flex-shrink: 0;
	width: 1.25rem;
	height: 1.25rem;
	align-items: center;
	justify-content: center;
	color: #64748b;
}

.paris-saude-nav-row.is-active .paris-saude-nav-row__icon,
.paris-saude-nav-sub.is-active .paris-saude-nav-row__icon {
	color: #0d2462;
}

.paris-saude-nav-row__svg {
	display: block;
	width: 20px;
	height: 20px;
}

.paris-saude-nav-row__label {
	flex: 1 1 auto;
	min-width: 0;
	text-align: left;
	line-height: 1.25;
}

.paris-saude-nav-row__chevron {
	display: inline-flex;
	flex-shrink: 0;
	color: #94a3b8;
	margin-left: auto;
}

.paris-saude-nav-row__chevron svg {
	display: block;
}

.paris-saude-nav-details__chevron {
	transition: transform 0.2s ease;
}

.paris-saude-nav-details[open] .paris-saude-nav-details__chevron {
	transform: rotate(90deg);
}

/* Grupo Cadastro (details/summary) */
.paris-saude-nav-details {
	margin: 0 0 0.35rem;
	border-radius: 8px;
	background: var(--ps-nav-bg-row);
}

.paris-saude-nav-details__summary {
	display: flex;
	align-items: center;
	gap: 0.55rem;
	list-style: none;
	padding: 0.7rem 0.5rem;
	margin: 0;
	font-weight: 600;
	font-size: 0.9rem;
	color: #334155;
	cursor: pointer;
	border-radius: 8px;
	user-select: none;
	transition: background 0.12s ease;
}

.paris-saude-nav-details__summary::-webkit-details-marker {
	display: none;
}

.paris-saude-nav-details__summary:hover {
	background: var(--ps-nav-bg-row-hover);
}

.paris-saude-nav-details--child-active > .paris-saude-nav-details__summary {
	color: #0d2462;
}

.paris-saude-nav-details--child-active > .paris-saude-nav-details__summary .paris-saude-nav-row__icon {
	color: #0d2462;
}

.paris-saude-nav-details[open] > .paris-saude-nav-details__summary {
	border-radius: 8px 8px 0 0;
}

.paris-saude-nav-details__subs {
	display: flex;
	flex-direction: column;
	gap: 0.2rem;
	padding: 0.15rem 0.35rem 0.55rem 0.25rem;
	background: #fff;
	border-radius: 0 0 8px 8px;
}

.paris-saude-app__nav-sublink.paris-saude-nav-sub {
	display: flex;
	align-items: center;
	gap: 0.5rem;
	padding: 0.55rem 0.45rem 0.55rem 1.85rem;
	margin: 0;
	font-size: 0.88rem;
	font-weight: 500;
	color: #64748b;
	text-decoration: none;
	border-radius: 6px;
	background: transparent;
	transition: background 0.12s ease, color 0.12s ease;
}

.paris-saude-nav-sub__icon {
	width: 1.1rem;
	height: 1.1rem;
	opacity: 0.9;
}

.paris-saude-nav-sub__icon .paris-saude-nav-row__svg {
	width: 18px;
	height: 18px;
}

.paris-saude-app__nav-sublink.paris-saude-nav-sub:hover {
	background: var(--ps-nav-bg-row-hover);
	color: #0f172a;
}

.paris-saude-app__nav-sublink.paris-saude-nav-sub.is-active {
	background: var(--ps-nav-bg-active);
	color: #0d2462;
	font-weight: 600;
	box-shadow: inset 2px 0 0 #0d2462;
}


.paris-saude-grid-search__fields {
	display: grid;
	grid-template-columns: 1fr;
	gap: 0.5rem 0.85rem;
	margin-bottom: 0.85rem;
}

@media (min-width: 640px) {
	.paris-saude-grid-search__fields {
		grid-template-columns: 1fr 1fr;
	}
}

@media (min-width: 900px) {
	.paris-saude-grid-search__fields {
		grid-template-columns: 1fr 1fr 1fr 1fr;
	}
}

.paris-saude-grid-search__actions {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: 0.65rem;
}

/* Filtro data: dia específico OU mês+ano */
.paris-saude-reg-mode {
	grid-column: 1 / -1;
	margin: 0;
	padding: 0.75rem 0 0;
	border: 0;
	border-top: 1px solid var(--ps-border);
}

.paris-saude-grid-search__fields > .paris-saude-reg-mode:first-child {
	border-top: 0;
	padding-top: 0;
	padding-bottom: 0.75rem;
	margin-bottom: 0.15rem;
	border-bottom: 1px solid var(--ps-border);
}

.paris-saude-reg-mode__legend {
	display: block;
	width: 100%;
	padding: 0;
	margin: 0 0 0.35rem;
	font-size: 0.72rem;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.04em;
	color: var(--ps-muted);
}

.paris-saude-reg-mode__lines {
	display: flex;
	flex-direction: column;
	gap: 0.35rem;
}

.paris-saude-reg-mode__line--cols3 {
	display: grid;
	grid-template-columns: minmax(0, 1fr) minmax(0, 1fr) minmax(0, 1fr);
	gap: 0.5rem 0.75rem;
	align-items: center;
}

@media (max-width: 560px) {
	.paris-saude-reg-mode__line--cols3 {
		grid-template-columns: 1fr;
	}

	.paris-saude-reg-mode__col--spacer {
		display: none;
	}
}

.paris-saude-reg-mode__col {
	min-width: 0;
}

.paris-saude-reg-mode__col--spacer {
	pointer-events: none;
}

.paris-saude-reg-mode__col--input .paris-saude-reg-mode--day,
.paris-saude-reg-mode__col--input .paris-saude-reg-mode--period {
	width: 100%;
}

.paris-saude-reg-mode__col--input input[type="date"],
.paris-saude-reg-mode__col--input select,
.paris-saude-reg-mode__col--input input[type="number"] {
	width: 100%;
	max-width: 100%;
	box-sizing: border-box;
}

.paris-saude-reg-mode__choice {
	display: inline-flex;
	align-items: center;
	gap: 0.35rem;
	font-size: 0.92rem;
	cursor: pointer;
	color: var(--ps-text);
}

.paris-saude-reg-mode__choice input {
	margin: 0;
	flex-shrink: 0;
}

.paris-saude-grid-search__fields--empresas-filter {
	grid-template-columns: 1fr;
}

/* Botões ícone na coluna Ações */
.paris-saude-action-icon {
	display: block;
	vertical-align: middle;
}

.paris-saude-icon-btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	box-sizing: border-box;
	width: 2.25rem;
	height: 2.25rem;
	margin: 0;
	padding: 0;
	border: none;
	border-radius: 8px;
	background: transparent;
	color: var(--ps-teal);
	cursor: pointer;
	font: inherit;
	line-height: 0;
	transition: background 0.12s ease, color 0.12s ease;
}

.paris-saude-icon-btn:hover {
	background: rgba(10, 95, 90, 0.1);
	color: var(--ps-teal-dark);
}

.paris-saude-icon-btn:focus-visible {
	outline: 2px solid var(--ps-teal);
	outline-offset: 2px;
}

.paris-saude-table__delete {
	color: #b42318;
}

.paris-saude-table__delete:hover {
	background: rgba(180, 35, 24, 0.08);
	color: #991b1b;
}

.paris-saude-dialog {
	position: relative;
	border: none;
	border-radius: 0;
	padding: 0;
	max-width: min(560px, 96vw);
	background: transparent;
	box-shadow: none;
}

.paris-saude-dialog--gestao {
	max-width: min(580px, 96vw);
}

.paris-saude-dialog::backdrop {
	background: rgba(15, 23, 42, 0.5);
	backdrop-filter: blur(2px);
}

.paris-saude-dialog__inner {
	padding: 0;
	box-sizing: border-box;
	background: var(--ps-card);
	border: 1px solid var(--ps-border);
	border-radius: 12px;
	box-shadow: 0 24px 64px rgba(15, 23, 42, 0.22);
	overflow: hidden;
}

.paris-saude-dialog__head {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 0.75rem;
	padding: 1rem 1rem 1rem 1.25rem;
	margin: 0;
	border-bottom: 1px solid var(--ps-border);
	background: #fff;
}

.paris-saude-dialog__title {
	margin: 0;
	flex: 1 1 auto;
	min-width: 0;
	font-size: 1.1rem;
	font-weight: 700;
	letter-spacing: -0.02em;
	color: var(--ps-heading);
	line-height: 1.3;
}

.paris-saude-dialog__body {
	padding: 1.15rem 1.25rem 1.25rem;
	background: #fafcfd;
}

.paris-saude-dialog__audit {
	margin: 0;
	padding: 0.65rem 1.25rem 1rem;
	border-top: 1px solid var(--ps-border);
	font-size: 0.72rem;
	line-height: 1.5;
	color: var(--ps-muted);
	white-space: pre-line;
	background: #fafcfd;
}

.paris-saude-dialog__close {
	flex-shrink: 0;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 2.25rem;
	height: 2.25rem;
	border: 0;
	background: transparent;
	padding: 0;
	cursor: pointer;
	color: #64748b;
	border-radius: 8px;
	line-height: 0;
	transition: background 0.12s ease, color 0.12s ease;
}

.paris-saude-dialog__close:hover {
	background: rgba(13, 36, 98, 0.08);
	color: #0d2462;
}

.paris-saude-dialog__close:focus-visible {
	outline: 2px solid #0d2462;
	outline-offset: 2px;
}

.paris-saude-form--dialog .paris-saude-form__grid--dialog {
	display: grid;
	grid-template-columns: 1fr;
	gap: 0.4rem 0.85rem;
	margin: 0;
}

@media (min-width: 520px) {
	.paris-saude-form--dialog .paris-saude-form__grid--dialog {
		grid-template-columns: 1fr 1fr;
	}

	/* Data de cadastro (último campo): largura total — evita célula vazia na grade */
	.paris-saude-form--dialog .paris-saude-form__grid--dialog > label:last-child {
		grid-column: 1 / -1;
	}
}

.paris-saude-form--dialog .paris-saude-form__grid--dialog > label {
	margin-bottom: 0;
}

.paris-saude-dialog--gestao .paris-saude-form--dialog label span {
	margin-bottom: 0.12rem;
}

/* Modais: neutralizar Elementor/tema em botões e fechar (fundo roxo, texto verde, etc.) */
.paris-saude-dialog--gestao .paris-saude-dialog__close {
	background: transparent !important;
	background-image: none !important;
	color: #64748b !important;
	border: none !important;
	box-shadow: none !important;
	text-shadow: none !important;
	filter: none !important;
	-webkit-appearance: none !important;
	appearance: none !important;
}

.paris-saude-dialog--gestao .paris-saude-dialog__close:hover {
	background: rgba(13, 36, 98, 0.08) !important;
	background-image: none !important;
	color: #0d2462 !important;
}

/* Mesmo padrão visual do botão “Pesquisar” (grid) + rótulo em uma palavra maiúscula */
.paris-saude-dialog--gestao .paris-saude-dialog__actions .paris-saude-btn--primary,
.paris-saude-dialog--gestao .paris-saude-dialog__actions .paris-saude-btn:not(.paris-saude-btn--ghost) {
	display: inline-flex !important;
	align-items: center !important;
	justify-content: center !important;
	min-height: 38px !important;
	height: auto !important;
	padding: 0.5rem 1rem !important;
	font-size: 0.9rem !important;
	font-weight: 600 !important;
	background: #0d2462 !important;
	background-image: none !important;
	color: #fff !important;
	border: none !important;
	border-radius: 8px !important;
	box-shadow: 0 2px 8px rgba(13, 36, 98, 0.22) !important;
	text-transform: uppercase !important;
	letter-spacing: 0.04em !important;
	text-decoration: none !important;
	line-height: 1.25 !important;
	filter: none !important;
}

.paris-saude-dialog--gestao .paris-saude-dialog__actions .paris-saude-btn--primary:hover,
.paris-saude-dialog--gestao .paris-saude-dialog__actions .paris-saude-btn:not(.paris-saude-btn--ghost):hover {
	background: #0a1d4f !important;
	background-image: none !important;
	color: #fff !important;
	box-shadow: 0 3px 10px rgba(13, 36, 98, 0.28) !important;
}

.paris-saude-dialog--gestao .paris-saude-dialog__actions .paris-saude-btn--ghost {
	display: inline-flex !important;
	align-items: center !important;
	justify-content: center !important;
	min-height: 36px !important;
	height: auto !important;
	padding: 0.45rem 0.95rem !important;
	font-size: 0.88rem !important;
	font-weight: 600 !important;
	background: #fff !important;
	background-image: none !important;
	color: #0d2462 !important;
	border: 1px solid #cbd5e1 !important;
	border-radius: 8px !important;
	box-shadow: none !important;
	text-transform: uppercase !important;
	letter-spacing: 0.04em !important;
	text-decoration: none !important;
	line-height: 1.25 !important;
	filter: none !important;
}

.paris-saude-dialog--gestao .paris-saude-dialog__actions .paris-saude-btn--ghost:hover {
	background: #f1f5f9 !important;
	background-image: none !important;
	color: #0a1d4f !important;
	border-color: #94a3b8 !important;
}

/* Elementor: span interno com cor própria no rótulo do botão */
.paris-saude-dialog--gestao .paris-saude-dialog__actions .paris-saude-btn:not(.paris-saude-btn--ghost) *,
.paris-saude-dialog--gestao .paris-saude-dialog__actions .paris-saude-btn:not(.paris-saude-btn--ghost)::after,
.paris-saude-dialog--gestao .paris-saude-dialog__actions .paris-saude-btn:not(.paris-saude-btn--ghost)::before {
	color: #fff !important;
}

.paris-saude-dialog--gestao .paris-saude-dialog__actions .paris-saude-btn--ghost *,
.paris-saude-dialog--gestao .paris-saude-dialog__actions .paris-saude-btn--ghost::after,
.paris-saude-dialog--gestao .paris-saude-dialog__actions .paris-saude-btn--ghost::before {
	color: #0d2462 !important;
}

.paris-saude-dialog--gestao .paris-saude-dialog__actions .paris-saude-btn--ghost:hover *,
.paris-saude-dialog--gestao .paris-saude-dialog__actions .paris-saude-btn--ghost:hover::after,
.paris-saude-dialog--gestao .paris-saude-dialog__actions .paris-saude-btn--ghost:hover::before {
	color: #0a1d4f !important;
}

.paris-saude-dialog__actions {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: 0.75rem;
	margin-top: 1.15rem;
	padding-top: 1.1rem;
	border-top: 1px solid var(--ps-border);
}

.paris-saude-card--grid {
	scroll-margin-top: 1.25rem;
	overflow-x: auto;
	-webkit-overflow-scrolling: touch;
}

#paris-saude-cadastro-empresa,
#paris-saude-cadastro-funcionario {
	scroll-margin-top: 1.25rem;
}

@media (max-width: 782px) {
	.paris-saude-app {
		flex-direction: column;
	}

	.paris-saude-app__sidebar {
		position: relative;
		top: 0;
		flex: 0 0 auto;
		width: 100%;
		display: flex;
		flex-wrap: wrap;
		gap: 0.35rem 1rem;
		align-items: center;
	}

	.paris-saude-app__nav-group {
		margin: 0;
		padding: 0;
		border: 0;
		display: contents;
	}

	.paris-saude-app__nav-label {
		width: 100%;
		margin-bottom: 0;
	}

	.paris-saude-app__nav-sublink {
		display: inline-block;
		padding: 0.35rem 0.5rem;
	}
}

.paris-saude-card {
	background: var(--ps-card);
	border: 1px solid var(--ps-border);
	border-radius: 12px;
	padding: 1.25rem 1.25rem 1.5rem;
	margin-bottom: 1.5rem;
	box-shadow: 0 4px 18px rgba(10, 95, 90, 0.05);
}

.paris-saude-card h2 {
	margin: 0 0 1rem;
	font-size: 1.15rem;
	color: var(--ps-heading);
}

.paris-saude-card__lead {
	margin: -0.35rem 0 1rem;
	font-size: 0.95rem;
	color: var(--ps-muted);
	line-height: 1.45;
}

.paris-saude-card__hint {
	padding: 1rem 1.1rem;
	margin-bottom: 1rem;
	background: #fff8e6;
	border: 1px solid #f0e0b2;
	border-radius: 10px;
	color: #5c4a00;
	font-size: 0.95rem;
}

.paris-saude-card__hint--below-title {
	margin: -0.5rem 0 1rem;
	padding: 0.65rem 0.85rem;
	font-size: 0.88rem;
}

.paris-saude-card__sub {
	margin: 0 0 0.85rem;
	font-size: 1.05rem;
	font-weight: 700;
	color: var(--ps-teal);
}

.paris-saude-card__sub--list {
	margin-top: 1.35rem;
	padding-top: 1rem;
	border-top: 1px solid var(--ps-border);
}

.paris-saude-card--funcionarios .paris-saude-form__grid {
	display: grid;
	grid-template-columns: 1fr;
	gap: 0.55rem 1rem;
	margin-bottom: 0.5rem;
}

@media (min-width: 640px) {
	.paris-saude-card--funcionarios .paris-saude-form__grid {
		grid-template-columns: 1fr 1fr;
	}
}

.paris-saude-label-hint {
	font-weight: 500;
	opacity: 0.88;
}

/* Celular + ícone WhatsApp + checkbox (wrapper não é <label>, evita roubar clique do link). */
.paris-saude-field--mobile-wa {
	display: block;
	margin-bottom: 0.55rem;
}

.paris-saude-field--mobile-wa__caption {
	display: block;
	margin-bottom: 0.18rem;
	cursor: default;
}

.paris-saude-field--mobile-wa__caption span {
	display: block;
	color: var(--ps-muted);
	font-weight: 600;
}

.paris-saude-field--mobile-wa .paris-saude-mobile-wa__row {
	display: flex;
	flex-wrap: nowrap;
	align-items: center;
	gap: 0.45rem;
	width: 100%;
	max-width: 420px;
	box-sizing: border-box;
}

.paris-saude-mobile-wa__input {
	flex: 1 1 auto;
	min-width: 0;
	max-width: none !important;
	width: auto !important;
}

/* Base: alinhado a .paris-saude-icon-btn (tema/Elementor sobrescrevem no bloco !important abaixo). */
.paris-saude-mobile-wa__wa-link {
	flex: 0 0 auto;
	position: relative;
	z-index: 2;
}

.paris-saude-mobile-wa__check {
	flex: 0 0 auto;
	width: 1.05rem !important;
	height: 1.05rem;
	margin: 0 !important;
	max-width: none !important;
	accent-color: var(--ps-teal, #14b8a6);
	cursor: pointer;
}

.paris-saude-sr-only {
	position: absolute;
	width: 1px;
	height: 1px;
	padding: 0;
	margin: -1px;
	overflow: hidden;
	clip: rect(0, 0, 0, 0);
	white-space: nowrap;
	border: 0;
}

.paris-saude-table__th-wa,
.paris-saude-table__wa {
	text-align: center;
}

.paris-saude-wa-grid-row {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	flex-wrap: wrap;
	gap: 0.35rem 0.5rem;
	max-width: 14rem;
	margin: 0 auto;
}

.paris-saude-wa-grid-phone {
	font-size: 0.8rem;
	font-weight: 600;
	color: var(--ps-text);
	white-space: nowrap;
}

.paris-saude-wa-grid-web {
	font-size: 0.8rem;
	font-weight: 600;
	color: var(--ps-teal-dark, #06403c);
	text-decoration: underline;
	text-underline-offset: 2px;
	white-space: nowrap;
}

.paris-saude-wa-grid-web:hover {
	color: var(--ps-teal, #0a5f5a);
}

.paris-saude-table__th-wa {
	vertical-align: middle;
}

.paris-saude-table__th-wa-icon {
	display: inline-flex;
	color: var(--ps-teal);
	align-items: center;
	justify-content: center;
	line-height: 0;
}

.paris-saude-table__wa {
	vertical-align: middle;
	white-space: normal;
}

.paris-saude-wa-cell {
	display: inline-flex;
	color: var(--ps-teal);
	vertical-align: middle;
	align-items: center;
	justify-content: center;
}

.paris-saude-wa-cell--muted {
	opacity: 0.45;
	filter: grayscale(0.25);
	cursor: default;
}

.paris-saude-wa-cell-empty {
	color: var(--ps-muted);
	font-size: 0.9rem;
	font-weight: 600;
}

.paris-saude-wrap span.paris-saude-table__phone-icon-cell {
	display: inline-flex !important;
	align-items: center !important;
	justify-content: center !important;
	width: 2.25rem !important;
	height: 2.25rem !important;
	min-width: 2.25rem !important;
	min-height: 2.25rem !important;
	padding: 0 !important;
	margin: 0 !important;
	border: none !important;
	border-radius: 8px !important;
	background: transparent !important;
	color: var(--ps-teal) !important;
	line-height: 0 !important;
	cursor: default !important;
	flex-shrink: 0 !important;
}

.paris-saude-wrap span.paris-saude-table__phone-icon-cell svg {
	display: block;
	width: 1.125rem;
	height: 1.125rem;
}

/*
 * Ícones utilitários (WhatsApp na coluna da grid / Kanban): mesmo padrão visual dos
 * botões de ação da tabela — teal, quadrado 2.25rem, canto 8px. Resets fortes para tema/Elementor
 * (evita “balão” roxo, fundo de botão primário, etc.).
 */
.paris-saude-wrap button.paris-saude-mobile-wa__wa-link,
.paris-saude-wrap a.paris-saude-wa-grid-btn,
.paris-saude-wrap button.paris-saude-wa-grid-btn {
	display: inline-flex !important;
	align-items: center !important;
	justify-content: center !important;
	width: 2.25rem !important;
	height: 2.25rem !important;
	min-width: 2.25rem !important;
	min-height: 2.25rem !important;
	max-width: none !important;
	padding: 0 !important;
	margin: 0 !important;
	border: none !important;
	border-radius: 8px !important;
	background: transparent !important;
	background-color: transparent !important;
	background-image: none !important;
	box-shadow: none !important;
	color: var(--ps-teal) !important;
	line-height: 0 !important;
	font-size: 0 !important;
	font-weight: 600 !important;
	font-family: inherit !important;
	text-decoration: none !important;
	text-transform: none !important;
	letter-spacing: normal !important;
	cursor: pointer !important;
	-webkit-appearance: none !important;
	appearance: none !important;
	vertical-align: middle !important;
	flex-shrink: 0 !important;
	opacity: 1 !important;
	visibility: visible !important;
	-webkit-tap-highlight-color: transparent;
}

.paris-saude-wrap button.paris-saude-mobile-wa__wa-link svg,
.paris-saude-wrap a.paris-saude-wa-grid-btn svg,
.paris-saude-wrap button.paris-saude-wa-grid-btn svg {
	pointer-events: none;
	display: block;
	width: 1.125rem;
	height: 1.125rem;
}

.paris-saude-wrap button.paris-saude-mobile-wa__wa-link:hover,
.paris-saude-wrap a.paris-saude-wa-grid-btn:hover,
.paris-saude-wrap button.paris-saude-wa-grid-btn:hover {
	background: rgba(10, 95, 90, 0.1) !important;
	color: var(--ps-teal-dark) !important;
	opacity: 1 !important;
}

.paris-saude-wrap button.paris-saude-mobile-wa__wa-link:focus-visible,
.paris-saude-wrap a.paris-saude-wa-grid-btn:focus-visible,
.paris-saude-wrap button.paris-saude-wa-grid-btn:focus-visible {
	outline: 2px solid var(--ps-teal) !important;
	outline-offset: 2px !important;
}

.paris-saude-grid-footer {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: 0.75rem 1.25rem;
	margin-top: 1rem;
	padding-top: 1rem;
	border-top: 1px solid var(--ps-border);
	font-size: 0.9rem;
	color: var(--ps-muted);
}

.paris-saude-grid-footer__meta {
	flex: 1 1 auto;
	min-width: 0;
}

.paris-saude-grid-pager {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: 0.5rem 0.75rem;
}

.paris-saude-grid-pager__pages {
	display: inline-flex;
	flex-wrap: wrap;
	align-items: center;
	gap: 0.35rem;
}

.paris-saude-grid-pager__current {
	font-weight: 700;
	color: var(--ps-text);
	padding: 0 0.2rem;
}

.paris-saude-grid-pager__num {
	color: var(--ps-teal-dark, #0f766e);
	text-decoration: none;
	font-weight: 600;
}

.paris-saude-grid-pager__num:hover {
	text-decoration: underline;
}

.paris-saude-grid-pager__ellipsis {
	padding: 0 0.15rem;
	color: var(--ps-muted);
	user-select: none;
}

.paris-saude-grid-pager__prev.is-disabled,
.paris-saude-grid-pager__next.is-disabled {
	pointer-events: none;
	opacity: 0.45;
	cursor: not-allowed;
}

/* Exportar CSV: ícone só — mesmo porte do botão Limpar; cores como o menu (cinza, sem teal). */
.paris-saude-wrap--gestao .paris-saude-grid-footer__export .paris-saude-btn--export-csv {
	display: inline-flex !important;
	align-items: center !important;
	justify-content: center !important;
	min-height: 38px !important;
	height: auto !important;
	padding: 0.5rem 1rem !important;
	font-size: 0.9rem !important;
	font-weight: 600 !important;
	line-height: 1.25 !important;
	border-radius: 8px !important;
	text-decoration: none !important;
	box-sizing: border-box;
	background: #f8fafc !important;
	background-color: #f8fafc !important;
	color: #334155 !important;
	border: 1px solid #e5e7eb !important;
	box-shadow: none !important;
}

.paris-saude-wrap--gestao .paris-saude-grid-footer__export .paris-saude-btn--export-csv:hover {
	background: #f1f5f9 !important;
	background-color: #f1f5f9 !important;
	color: #0f172a !important;
	border-color: #e2e8f0 !important;
}

.paris-saude-wrap--gestao .paris-saude-grid-footer__export .paris-saude-btn--export-csv:active {
	background: #e2e8f0 !important;
	background-color: #e2e8f0 !important;
	color: #0d2462 !important;
	border-color: #cbd5e1 !important;
	box-shadow: inset 0 0 0 1px rgba(148, 163, 184, 0.35) !important;
}

.paris-saude-wrap--gestao .paris-saude-grid-footer__export .paris-saude-btn--export-csv:focus-visible {
	outline: 2px solid #94a3b8 !important;
	outline-offset: 2px !important;
}

.paris-saude-wrap--gestao .paris-saude-grid-footer__export .paris-saude-btn--export-csv .paris-saude-export-icon {
	display: block;
	width: 1.15rem;
	height: 1.15rem;
	flex-shrink: 0;
	pointer-events: none;
	color: inherit;
}

/* Gestão: botões ghost (exceto Limpar) — clique como item ativo do menu lateral (cinza). */
.paris-saude-wrap--gestao a.paris-saude-btn--ghost:not(.paris-saude-btn--clear):active,
.paris-saude-wrap--gestao button.paris-saude-btn--ghost:not(.paris-saude-btn--clear):active {
	background: #e2e8f0 !important;
	background-color: #e2e8f0 !important;
	color: #0d2462 !important;
	border-color: #cbd5e1 !important;
	box-shadow: inset 0 0 0 1px rgba(148, 163, 184, 0.35) !important;
}

.paris-saude-result__wa {
	display: inline-flex;
	vertical-align: middle;
	color: var(--ps-teal);
	margin-left: 0.35rem;
}

.paris-saude-form--employee .paris-saude-form__grid input[type="text"],
.paris-saude-form--employee .paris-saude-form__grid select {
	max-width: 100%;
}

.paris-saude-form__submit-row {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: 0.75rem;
	margin-top: 1rem;
	padding-top: 1.1rem;
	border-top: 1px solid var(--ps-border);
}

/* Garantir botões visíveis dentro de conteúdo Elementor / temas */
.paris-saude-wrap--gestao button.paris-saude-btn,
.paris-saude-wrap--gestao .paris-saude-btn,
.paris-saude-wrap--consulta button.paris-saude-btn,
.paris-saude-wrap--consulta .paris-saude-btn {
	opacity: 1 !important;
	visibility: visible !important;
	display: inline-block !important;
	-webkit-appearance: none;
	appearance: none;
}

.paris-saude-btn--primary {
	background: var(--ps-teal);
	color: #fff !important;
}

.paris-saude-form label {
	display: block;
	margin-bottom: 0.55rem;
	font-weight: 600;
	font-size: 0.9rem;
}

.paris-saude-form label span {
	display: block;
	margin-bottom: 0.18rem;
	color: var(--ps-muted);
	font-weight: 600;
}

.paris-saude-form input[type="text"],
.paris-saude-form input[type="password"],
.paris-saude-form select {
	width: 100%;
	max-width: 420px;
	box-sizing: border-box;
	padding: 0.55rem 0.65rem;
	border: 1px solid var(--ps-border);
	border-radius: 8px;
}

.paris-saude-form--inline {
	display: flex;
	flex-wrap: wrap;
	gap: 0.75rem 1rem;
	align-items: flex-end;
}

.paris-saude-form--inline label {
	margin-bottom: 0;
}

.paris-saude-form--search {
	display: flex;
	flex-wrap: wrap;
	gap: 0.75rem 1rem;
	align-items: flex-end;
}

/* Label + botão na mesma linha: sem margem extra abaixo do campo (evita botão “descido”). */
.paris-saude-form--search > label {
	margin-bottom: 0;
}

.paris-saude-form--balcao-search .paris-saude-form__hint--balcao {
	flex-basis: 100%;
	margin: -0.15rem 0 0;
	font-size: 0.82rem;
	color: var(--ps-muted);
	line-height: 1.4;
}

.paris-saude-wrap--consulta .paris-saude-form--balcao-search > label {
	flex: 1 1 11rem;
	min-width: 10rem;
	max-width: 16rem;
}

.paris-saude-btn {
	display: inline-block;
	background: var(--ps-teal);
	color: #fff !important;
	border: none;
	padding: 0.6rem 1.1rem;
	border-radius: 8px;
	font-weight: 600;
	cursor: pointer;
	text-decoration: none;
	font-size: 0.95rem;
}

.paris-saude-btn:hover {
	background: var(--ps-teal-dark);
}

.paris-saude-btn--ghost {
	background: transparent;
	color: var(--ps-teal) !important;
	border: 1px solid var(--ps-border);
}

/* Gestão e consulta: mesmos padrões do formulário de login (campos altos, botão primário #0d2462). */
.paris-saude-wrap--gestao .paris-saude-form label span,
.paris-saude-wrap--consulta .paris-saude-form label span {
	font-size: 0.85rem;
	font-weight: 600;
}

.paris-saude-wrap--gestao .paris-saude-form input[type="text"],
.paris-saude-wrap--gestao .paris-saude-form input[type="password"],
.paris-saude-wrap--gestao .paris-saude-form input[type="date"],
.paris-saude-wrap--gestao .paris-saude-form select,
.paris-saude-wrap--consulta .paris-saude-form input[type="text"],
.paris-saude-wrap--consulta .paris-saude-form input[type="password"],
.paris-saude-wrap--consulta .paris-saude-form input[type="date"],
.paris-saude-wrap--consulta .paris-saude-form select {
	max-width: 100%;
	padding: 0.75rem 0.9rem;
	border-radius: 10px;
	font-size: 1rem;
	border: 1px solid #e2e8f0;
	background: #fff;
	transition: border-color 0.15s ease, box-shadow 0.15s ease;
}

.paris-saude-wrap--gestao .paris-saude-form input:focus,
.paris-saude-wrap--gestao .paris-saude-form select:focus,
.paris-saude-wrap--consulta .paris-saude-form input:focus,
.paris-saude-wrap--consulta .paris-saude-form select:focus {
	outline: none;
	border-color: #14b8a6;
	box-shadow: 0 0 0 3px rgba(20, 184, 166, 0.2);
}

/* Balcão: campo CPF um pouco mais compacto, alinhado ao botão Consultar. */
.paris-saude-wrap--consulta .paris-saude-form--search input[type="text"] {
	padding: 0.6rem 0.8rem !important;
	font-size: 0.95rem !important;
}

/* Botão “grande” só no formulário de cadastro de beneficiário (modais usam o padrão “Pesquisar”). */
.paris-saude-wrap--gestao #paris-saude-employee-form .paris-saude-btn--primary {
	min-height: 48px;
	padding: 0.8rem 1.1rem;
	border-radius: 10px;
	font-size: 1rem;
	font-weight: 700;
	background: #0d2462 !important;
	box-shadow: 0 4px 14px rgba(13, 36, 98, 0.35);
}

.paris-saude-wrap--gestao #paris-saude-employee-form .paris-saude-btn--primary:hover {
	background: #0a1d4f !important;
	box-shadow: 0 6px 18px rgba(13, 36, 98, 0.42);
}

/* Grid de pesquisa, formulário inline (nova empresa) e balcão: botões menores (Elementor costuma inflar <button>). */
.paris-saude-wrap--gestao .paris-saude-grid-search .paris-saude-btn:not(.paris-saude-btn--ghost),
.paris-saude-wrap--gestao .paris-saude-form--inline .paris-saude-btn:not(.paris-saude-btn--ghost),
.paris-saude-wrap--consulta .paris-saude-form--search .paris-saude-btn:not(.paris-saude-btn--ghost) {
	display: inline-flex !important;
	align-items: center !important;
	justify-content: center !important;
	min-height: 34px !important;
	height: auto !important;
	padding: 0.4rem 0.85rem !important;
	font-size: 0.8125rem !important;
	font-weight: 600 !important;
	line-height: 1.25 !important;
	border-radius: 8px !important;
	background: #0d2462 !important;
	box-shadow: 0 2px 8px rgba(13, 36, 98, 0.22) !important;
	text-transform: uppercase !important;
	letter-spacing: 0.04em !important;
	align-self: flex-end;
}

.paris-saude-wrap--gestao .paris-saude-grid-search .paris-saude-btn:not(.paris-saude-btn--ghost):hover,
.paris-saude-wrap--gestao .paris-saude-form--inline .paris-saude-btn:not(.paris-saude-btn--ghost):hover,
.paris-saude-wrap--consulta .paris-saude-form--search .paris-saude-btn:not(.paris-saude-btn--ghost):hover {
	background: #0a1d4f !important;
	box-shadow: 0 3px 10px rgba(13, 36, 98, 0.28) !important;
}

/* Limpar: mesmo porte do Pesquisar + vermelho suave (identidade Páris) */
.paris-saude-wrap--gestao .paris-saude-grid-search .paris-saude-btn--ghost.paris-saude-btn--clear {
	display: inline-flex !important;
	align-items: center !important;
	justify-content: center !important;
	min-height: 38px !important;
	height: auto !important;
	padding: 0.5rem 1rem !important;
	font-size: 0.9rem !important;
	font-weight: 600 !important;
	line-height: 1.25 !important;
	border-radius: 8px !important;
	text-transform: uppercase !important;
	letter-spacing: 0.04em !important;
	background: var(--ps-paris-red-soft) !important;
	background-image: none !important;
	color: var(--ps-paris-red-text) !important;
	border: 1px solid var(--ps-paris-red-border) !important;
	box-shadow: 0 2px 8px rgba(166, 30, 53, 0.12) !important;
	text-decoration: none !important;
}

.paris-saude-wrap--gestao .paris-saude-grid-search .paris-saude-btn--ghost.paris-saude-btn--clear:hover {
	background: var(--ps-paris-red-hover-bg) !important;
	color: var(--ps-paris-red) !important;
	border-color: rgba(196, 30, 58, 0.45) !important;
	box-shadow: 0 3px 10px rgba(166, 30, 53, 0.18) !important;
}

.paris-saude-wrap--gestao .paris-saude-grid-search .paris-saude-btn--ghost.paris-saude-btn--clear *,
.paris-saude-wrap--gestao .paris-saude-grid-search .paris-saude-btn--ghost.paris-saude-btn--clear::before,
.paris-saude-wrap--gestao .paris-saude-grid-search .paris-saude-btn--ghost.paris-saude-btn--clear::after {
	color: inherit !important;
}

.paris-saude-wrap--gestao .paris-saude-grid-search .paris-saude-btn--ghost.paris-saude-btn--clear:hover * {
	color: inherit !important;
}

.paris-saude-wrap--gestao .paris-saude-form--inline .paris-saude-btn--ghost {
	min-height: 36px !important;
	height: auto !important;
	padding: 0.45rem 0.95rem !important;
	font-size: 0.88rem !important;
	font-weight: 600 !important;
	line-height: 1.25 !important;
	border-radius: 8px !important;
	text-transform: uppercase !important;
	letter-spacing: 0.04em !important;
}

/* Ações da tabela: ícones — impedir tema/Elementor de estourar tamanho */
.paris-saude-wrap--gestao .paris-saude-table button.paris-saude-icon-btn,
.paris-saude-wrap--gestao .paris-saude-inline-form--icon button.paris-saude-icon-btn {
	display: inline-flex !important;
	align-items: center !important;
	justify-content: center !important;
	width: 2.25rem !important;
	height: 2.25rem !important;
	min-width: 2.25rem !important;
	min-height: 2.25rem !important;
	max-width: none !important;
	padding: 0 !important;
	margin: 0 !important;
	line-height: 0 !important;
	font-size: 0 !important;
	font-weight: 600 !important;
	font-family: inherit !important;
	border: none !important;
	border-radius: 8px !important;
	background: transparent !important;
	background-color: transparent !important;
	box-shadow: none !important;
	text-decoration: none !important;
	text-transform: none !important;
	letter-spacing: normal !important;
	vertical-align: middle !important;
	cursor: pointer !important;
	-webkit-appearance: none !important;
	appearance: none !important;
}

.paris-saude-wrap--gestao .paris-saude-table button.paris-saude-table__edit.paris-saude-icon-btn {
	color: var(--ps-teal) !important;
}

.paris-saude-wrap--gestao .paris-saude-table button.paris-saude-table__delete.paris-saude-icon-btn,
.paris-saude-wrap--gestao .paris-saude-inline-form--icon button.paris-saude-table__delete.paris-saude-icon-btn {
	color: #b42318 !important;
}

.paris-saude-wrap--gestao .paris-saude-table button.paris-saude-icon-btn.paris-saude-table__edit:hover {
	background: rgba(10, 95, 90, 0.1) !important;
	color: var(--ps-teal-dark) !important;
}

.paris-saude-wrap--gestao .paris-saude-table button.paris-saude-icon-btn.paris-saude-table__delete:hover,
.paris-saude-wrap--gestao .paris-saude-inline-form--icon button.paris-saude-icon-btn.paris-saude-table__delete:hover {
	background: rgba(180, 35, 24, 0.08) !important;
	color: #991b1b !important;
}

/* Ícone cartão: azul do convênio; ao clicar, cinza claro (estado :active). */
.paris-saude-wrap--gestao .paris-saude-table button.paris-saude-icon-btn.paris-saude-table__card {
	color: #293b7f !important;
}

.paris-saude-wrap--gestao .paris-saude-table button.paris-saude-icon-btn.paris-saude-table__card:hover {
	color: #1f2f66 !important;
	background: rgba(41, 59, 127, 0.08) !important;
}

.paris-saude-wrap--gestao .paris-saude-table button.paris-saude-icon-btn.paris-saude-table__card:active {
	color: #94a3b8 !important;
	background: rgba(148, 163, 184, 0.28) !important;
}

.paris-saude-dialog--card-dl .paris-saude-dialog__hint {
	margin: 0 0 0.75rem;
	font-size: 0.92rem;
	color: var(--ps-muted, #64748b);
}

.paris-saude-card-dl-options {
	display: flex;
	flex-direction: column;
	gap: 0.65rem;
	margin: 0 0 1.25rem;
}

.paris-saude-card-dl-option {
	display: flex;
	align-items: center;
	gap: 0.55rem;
	font-size: 0.95rem;
	font-weight: 500;
	cursor: pointer;
	color: var(--ps-text, #1e293b);
}

.paris-saude-card-dl-option input[type="radio"] {
	width: 1.05rem;
	height: 1.05rem;
	accent-color: var(--ps-teal, #0a5f5a);
}

.paris-saude-dialog__actions--card-dl {
	margin-top: 0.25rem;
}

@media (max-width: 520px) {
	.paris-saude-wrap--gestao .paris-saude-form__submit-row .paris-saude-btn--primary {
		width: 100%;
		text-align: center;
		box-sizing: border-box;
	}
}

.paris-saude-table {
	width: 100%;
	border-collapse: collapse;
	font-size: 0.9rem;
	margin-top: 1rem;
}

.paris-saude-table-scroll-y {
	height: min(58vh, 640px);
	max-height: min(58vh, 640px);
	overflow-y: scroll;
	overflow-x: auto;
	scrollbar-gutter: stable both-edges;
}

.paris-saude-table th,
.paris-saude-table td {
	border-bottom: 1px solid var(--ps-border);
	padding: 0.55rem 0.4rem;
	text-align: left;
	vertical-align: middle;
	white-space: nowrap;
}

.paris-saude-table-scroll-y .paris-saude-table thead th {
	position: sticky;
	top: 0;
	z-index: 1;
	background: #fff;
}

.paris-saude-table-scroll-y .paris-saude-table {
	min-width: 1120px;
}

.paris-saude-table th {
	color: var(--ps-muted);
	font-weight: 600;
}

.paris-saude-table td.paris-saude-table__actions {
	vertical-align: middle;
}

.paris-saude-table__actions {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: 0.2rem 0.35rem;
	white-space: normal;
}

.paris-saude-table__actions a {
	margin-right: 0.75rem;
	color: var(--ps-teal);
}

.paris-saude-inline-form {
	display: inline;
	margin: 0;
}

.paris-saude-inline-form--icon {
	display: inline-flex;
	vertical-align: middle;
	margin: 0;
}

.paris-saude-table__actions-links {
	display: inline-flex;
	align-items: center;
	gap: 0.35rem;
	margin-left: 0.1rem;
}

.paris-saude-table__mini-link {
	font-size: 0.72rem;
	font-weight: 700;
	letter-spacing: 0.03em;
	color: var(--ps-teal);
	text-decoration: none;
	border: 1px solid var(--ps-border);
	border-radius: 6px;
	padding: 0.1rem 0.35rem;
	line-height: 1.2;
}

.paris-saude-table__mini-link:hover {
	text-decoration: none;
	color: var(--ps-teal-dark);
	background: rgba(10, 95, 90, 0.06);
}

.paris-saude-link {
	background: none;
	border: none;
	color: #b42318;
	cursor: pointer;
	text-decoration: underline;
	padding: 0;
	font: inherit;
}

.paris-saude-filter {
	margin-bottom: 1rem;
}

.paris-saude-notice {
	padding: 0.75rem 1rem;
	border-radius: 8px;
	margin-bottom: 1rem;
	font-size: 0.95rem;
}

.paris-saude-notice--ok {
	background: #e8f5f0;
	border: 1px solid #b8e2d3;
	color: #0d4f3c;
}

.paris-saude-notice--err {
	background: #fdecea;
	border: 1px solid #f5c2be;
	color: #7f1d1d;
}

.paris-saude-notice--warn {
	background: #fff8e6;
	border: 1px solid #f0e0b2;
	color: #7a5a00;
}

.paris-saude-result {
	margin-top: 1rem;
	padding: 1rem;
	background: var(--ps-bg);
	border-radius: 10px;
	border: 1px solid var(--ps-border);
}

.paris-saude-result__discount {
	text-align: center;
	margin: 0 0 1rem;
}

.paris-saude-result__discount-main {
	margin: 0;
}

/* Só o percentual em destaque; CPF/EMPRESA ficam na linha abaixo com tamanho de texto normal. */
.paris-saude-result__discount-main > strong:first-of-type {
	display: block;
	font-size: 2.25rem;
	line-height: 1.1;
	color: var(--ps-teal);
}

.paris-saude-result__discount-line {
	display: block;
	font-size: 0.95rem;
	color: var(--ps-muted);
	margin-top: 0.35rem;
}

.paris-saude-result__discount-who {
	display: inline;
	font-size: 1.1em;
	font-weight: 800;
	letter-spacing: 0.05em;
	margin-left: 0.25rem;
}

.paris-saude-result__discount-who--empresa {
	color: #0a5f5a !important;
}

.paris-saude-result__discount-who--cpf {
	color: #8a5a00 !important;
}

.paris-saude-result__list {
	list-style: none;
	margin: 0;
	padding: 0;
}

.paris-saude-result__list li {
	display: flex;
	justify-content: space-between;
	gap: 1rem;
	padding: 0.4rem 0;
	border-bottom: 1px solid var(--ps-border);
	font-size: 0.95rem;
}

.paris-saude-result__list li:last-child {
	border-bottom: none;
}

.paris-saude-result__list span {
	color: var(--ps-muted);
}

.paris-saude-result__actions {
	display: flex;
	flex-wrap: wrap;
	gap: 0.5rem 0.65rem;
	margin-top: 0.9rem;
	padding-top: 0.9rem;
	border-top: 1px solid var(--ps-border);
}

.paris-saude-wrap--consulta .paris-saude-result__actions .paris-saude-btn {
	min-height: 34px !important;
	padding: 0.4rem 0.8rem !important;
	font-size: 0.8rem !important;
	letter-spacing: 0.03em !important;
}

.paris-saude-footer-link {
	text-align: center;
	margin-top: 0.5rem;
}

.paris-saude-footer-link a {
	color: var(--ps-teal);
	font-weight: 600;
}

.paris-saude-marketing {
	background: linear-gradient(160deg, #f0faf9 0%, #ffffff 100%);
	padding: 2rem 1rem;
	border-radius: 12px;
	margin: 1rem 0;
	text-align: center;
	border: 1px solid var(--ps-border);
}

.paris-saude-marketing__inner {
	max-width: 640px;
	margin: 0 auto;
}

.paris-saude-marketing h2 {
	color: var(--ps-heading);
	margin-top: 0;
}

.paris-saude-marketing .paris-saude-btn {
	min-height: 48px;
	padding: 0.8rem 1.25rem;
	border-radius: 10px;
	font-size: 1rem;
	font-weight: 700;
	background: #0d2462 !important;
	color: #fff !important;
	border: none !important;
	box-shadow: 0 4px 14px rgba(13, 36, 98, 0.35);
	text-decoration: none;
	display: inline-block;
	-webkit-appearance: none;
	appearance: none;
}

.paris-saude-marketing .paris-saude-btn:hover {
	background: #0a1d4f !important;
	box-shadow: 0 6px 18px rgba(13, 36, 98, 0.42);
	color: #fff !important;
}

/* --- Login em duas colunas (referência visual tipo Garupa Empresas) --- */
.paris-saude-wrap--login-split {
	display: flex;
	flex-direction: column;
	max-width: 100%;
	width: 100%;
	margin: 0;
	padding: 0;
	box-sizing: border-box;
	min-height: 100vh;
	min-height: 100dvh;
	height: 100vh;
	height: 100dvh;
	max-height: 100vh;
	max-height: 100dvh;
	overflow: hidden;
	font-family: system-ui, -apple-system, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;
	--ps-login-green: #0d9488;
	--ps-login-green-dark: #0f766e;
	--ps-login-green-muted: #14b8a6;
	--ps-login-panel-border: #e2e8f0;
	--ps-login-text: #1e293b;
	--ps-login-muted: #64748b;
}

.paris-saude-login-split {
	display: grid;
	grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
	grid-template-rows: minmax(0, 1fr);
	align-items: stretch;
	justify-items: stretch;
	flex: 1 1 0;
	min-height: 0;
	height: 100%;
	max-height: 100%;
	width: 100%;
	max-width: 100%;
	min-width: 0;
	overflow: hidden;
	box-sizing: border-box;
}

.paris-saude-login-split__brand {
	width: 100%;
	max-width: 100%;
	min-width: 0;
	min-height: 0;
	height: 100%;
	max-height: 100%;
	background: linear-gradient(165deg, #ecfdf5 0%, #f0fdfa 38%, #f8fafc 100%);
	display: flex;
	flex-direction: column;
	align-items: stretch;
	justify-content: center;
	padding: 2rem clamp(1rem, 3vw, 2rem);
	box-sizing: border-box;
	border-right: 1px solid rgba(148, 163, 184, 0.25);
	overflow: hidden;
}

.paris-saude-login-split__brand-inner {
	width: 100%;
	max-width: none;
	margin: 0 auto;
	display: flex;
	flex-direction: column;
	align-items: stretch;
	gap: 1.75rem;
	height: 100%;
	min-height: 0;
	justify-content: center;
}

.paris-saude-login-split__brand-hero {
	width: 100%;
	min-width: 0;
}

.paris-saude-login-split__brand-hero-img {
	display: block;
	width: 100%;
	max-width: 100%;
	height: auto;
	max-height: min(92vh, 900px);
	object-fit: contain;
	object-position: center center;
	border-radius: 10px;
}

/* Painel promocional: ocupa metade da altura útil; imagem escala dentro do espaço (sem scroll na página). */
.paris-saude-login-split__brand--hero-panel {
	background: #0a1f33;
	padding: 0;
	border-right: none;
	align-self: stretch;
	min-height: 0;
	height: 100%;
	max-height: 100%;
	justify-content: stretch;
}

/* Mesmo branco do painel de login: faixas do object-fit: contain não ficam azul escuro. */
.paris-saude-login-split__brand--hero-panel:not(.paris-saude-login-split__brand--hero-panel-with-apps) {
	background: #fff;
}

.paris-saude-login-split__brand--hero-panel .paris-saude-login-split__brand-inner {
	flex: 1 1 0;
	display: flex;
	flex-direction: column;
	min-height: 0;
	height: 100%;
	max-height: 100%;
	width: 100%;
	gap: 0;
	justify-content: stretch;
	align-items: stretch;
}

.paris-saude-login-split__brand--hero-panel:not(.paris-saude-login-split__brand--hero-panel-with-apps) .paris-saude-login-split__brand-hero {
	flex: 1 1 0;
	min-height: 0;
	align-self: stretch;
	position: relative;
	overflow: hidden;
	line-height: 0;
	background: #fff;
}

/* Imagem inteira na proporção do arquivo (ex.: 960×1080); letterbox com o fundo do painel — sem crop. */
.paris-saude-login-split__brand--hero-panel:not(.paris-saude-login-split__brand--hero-panel-with-apps) .paris-saude-login-split__brand-hero-img {
	position: absolute;
	inset: 0;
	width: 100%;
	height: 100%;
	object-fit: contain;
	object-position: center center;
	border-radius: 0;
}

.paris-saude-login-split__brand--hero-panel-with-apps .paris-saude-login-split__brand-inner {
	min-height: 0;
	height: 100%;
	max-height: 100%;
	padding: 1rem clamp(0.75rem, 2vw, 1.25rem) 1.25rem;
	gap: 1rem;
}

.paris-saude-login-split__brand--hero-panel-with-apps .paris-saude-login-split__brand-hero {
	flex: 1 1 auto;
	min-height: 0;
	display: flex;
	align-items: center;
	justify-content: center;
}

.paris-saude-login-split__brand--hero-panel-with-apps .paris-saude-login-split__brand-hero-img {
	width: 100%;
	height: auto;
	max-height: none;
	min-height: 0;
	object-fit: contain;
	border-radius: 8px;
}

.paris-saude-login-split__brand--hero-panel-with-apps .paris-saude-login-split__visual {
	margin-top: 0;
	padding-top: 0;
}

.paris-saude-login-split__brand-top {
	width: 100%;
}

.paris-saude-login-split__logoimg {
	max-width: min(320px, 92%);
	height: auto;
	object-fit: contain;
	display: block;
}

.paris-saude-login-split__logotext {
	font-size: clamp(1.75rem, 4vw, 2.35rem);
	font-weight: 800;
	color: var(--ps-login-green-dark);
	letter-spacing: -0.03em;
	line-height: 1.15;
	display: block;
}

.paris-saude-login-split__tagline {
	display: block;
	margin-top: 0.4rem;
	font-size: 1rem;
	color: var(--ps-login-muted);
	font-weight: 500;
}

.paris-saude-login-split__hero-title {
	margin: 0;
	font-size: clamp(1.15rem, 2.2vw, 1.35rem);
	font-weight: 700;
	color: var(--ps-heading);
	line-height: 1.35;
	letter-spacing: -0.02em;
}

.paris-saude-login-split__features {
	margin: 0;
	padding: 0 0 0 1.15rem;
	color: var(--ps-login-muted);
	font-size: 0.95rem;
	line-height: 1.55;
}

.paris-saude-login-split__features li {
	margin: 0.5rem 0;
	padding-left: 0.15rem;
}

.paris-saude-login-split__features li::marker {
	color: var(--ps-login-green);
}

.paris-saude-login-split__visual {
	width: 100%;
	margin-top: auto;
	padding-top: 1rem;
}

.paris-saude-login-split__appsimg {
	width: 100%;
	max-width: 100%;
	height: auto;
	display: block;
	border-radius: 12px;
	filter: drop-shadow(0 18px 40px rgba(15, 118, 110, 0.12));
}

.paris-saude-login-split__brand--no-side-img .paris-saude-login-split__hero {
	margin-bottom: 0;
}

.paris-saude-login-split__panel {
	width: 100%;
	max-width: 100%;
	min-width: 0;
	min-height: 0;
	height: 100%;
	max-height: 100%;
	background: #fff;
	display: flex;
	align-items: center;
	justify-content: center;
	padding: 2.5rem clamp(1.25rem, 3vw, 2.5rem);
	box-sizing: border-box;
	overflow-x: hidden;
	overflow-y: auto;
}

.paris-saude-login-split__panel-inner {
	width: 100%;
	max-width: min(400px, 100%);
	min-width: 0;
	box-sizing: border-box;
}

.paris-saude-loginform {
	margin: 0;
	padding: 0;
	background: transparent;
	border: none;
	box-shadow: none;
}

.paris-saude-loginform__field {
	margin: 0 0 1rem;
}

.paris-saude-loginform__field label {
	display: block;
	font-size: 0.85rem;
	font-weight: 600;
	color: var(--ps-muted);
	margin-bottom: 0.35rem;
}

.paris-saude-loginform .input {
	width: 100%;
	box-sizing: border-box;
	padding: 0.75rem 0.9rem;
	border: 1px solid var(--ps-login-panel-border, #e2e8f0);
	border-radius: 10px;
	background: #fff;
	font-size: 1rem;
	color: var(--ps-login-text, #1e293b);
	transition: border-color 0.15s ease, box-shadow 0.15s ease;
}

.paris-saude-wrap--login-split .paris-saude-loginform .input:focus {
	outline: none;
	border-color: var(--ps-login-green-muted, #14b8a6);
	box-shadow: 0 0 0 3px rgba(20, 184, 166, 0.2);
}

.paris-saude-password-wrap {
	position: relative;
	display: block;
}

.paris-saude-password-wrap .input {
	padding-right: 2.125rem;
}

/* <span role="button">: evita estilos globais de <button> (Elementor / tema). */
.paris-saude-password-wrap .paris-saude-toggle-pw {
	position: absolute;
	right: 0.12rem;
	top: 50%;
	transform: translateY(-50%);
	display: inline-flex;
	align-items: center;
	justify-content: center;
	box-sizing: border-box;
	width: 24px;
	height: 24px;
	min-width: 24px;
	max-width: 24px;
	min-height: 24px;
	max-height: 24px;
	padding: 0;
	margin: 0;
	border: 0;
	background: transparent !important;
	background-color: transparent !important;
	box-shadow: none !important;
	cursor: pointer;
	line-height: 0;
	font-size: 0;
	color: var(--ps-muted);
	border-radius: 4px;
	user-select: none;
	-webkit-tap-highlight-color: transparent;
}

.paris-saude-password-wrap .paris-saude-toggle-pw:focus {
	outline: none;
}

.paris-saude-password-wrap .paris-saude-toggle-pw:focus-visible {
	outline: 2px solid var(--ps-login-green-muted, #14b8a6);
	outline-offset: 1px;
}

.paris-saude-password-wrap .paris-saude-toggle-pw:hover {
	color: var(--ps-teal);
	background: rgba(10, 95, 90, 0.06) !important;
}

.paris-saude-password-wrap .paris-saude-toggle-pw__icon {
	display: block;
	width: 14px;
	height: 14px;
	flex-shrink: 0;
	pointer-events: none;
}

.paris-saude-loginform__row {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 0.75rem;
	flex-wrap: wrap;
	margin: 0 0 1.25rem;
	font-size: 0.88rem;
}

.paris-saude-loginform__remember {
	display: flex;
	align-items: center;
	gap: 0.4rem;
	font-weight: 500;
	color: var(--ps-text);
	cursor: pointer;
	margin: 0;
}

.paris-saude-loginform__remember input {
	margin: 0;
}

.paris-saude-loginform__forgot {
	color: var(--ps-login-green, #0d9488);
	font-weight: 600;
	text-decoration: none;
	white-space: nowrap;
}

.paris-saude-loginform__forgot:hover {
	text-decoration: underline;
	color: var(--ps-login-green-dark, #0f766e);
}

.paris-saude-loginform__submit {
	margin: 0;
}

.paris-saude-loginform__submit .button-primary {
	width: 100%;
	background: #0d2462 !important;
	border: none !important;
	border-radius: 10px !important;
	padding: 0.8rem 1rem !important;
	font-size: 1rem !important;
	font-weight: 700 !important;
	box-shadow: 0 4px 14px rgba(13, 36, 98, 0.35) !important;
	text-shadow: none !important;
	height: auto !important;
	line-height: 1.3 !important;
	color: #fff !important;
}

.paris-saude-loginform__submit .button-primary:hover {
	background: #0a1d4f !important;
	box-shadow: 0 6px 18px rgba(13, 36, 98, 0.42) !important;
	color: #fff !important;
}

.paris-saude-login-split__version {
	margin: 1.25rem 0 0;
	text-align: right;
	font-size: 0.75rem;
	color: #9aa9a8;
}

.paris-saude-login-agency-footer {
	flex-shrink: 0;
	position: relative;
	z-index: 2;
	margin: 0;
	padding: 0.5rem max(1rem, env(safe-area-inset-right, 0)) calc(0.5rem + env(safe-area-inset-bottom, 0)) max(1rem, env(safe-area-inset-left, 0));
	text-align: right;
	font-size: 0.75rem;
	line-height: 1.4;
	color: #64748b;
	background: rgba(248, 250, 252, 0.98);
	border-top: 1px solid rgba(148, 163, 184, 0.25);
	box-sizing: border-box;
}

.paris-saude-login-agency-footer__link {
	color: #0d2462;
	font-weight: 600;
	text-decoration: none;
}

.paris-saude-login-agency-footer__link:hover {
	text-decoration: underline;
	color: #0a1d4f;
}

body.paris-saude-acesso-body {
	overflow-x: hidden;
}

@media (min-width: 1181px) {
	body.paris-saude-acesso-body {
		overflow-y: hidden;
	}

	body.admin-bar.paris-saude-acesso-body .paris-saude-wrap--login-split {
		height: calc(100dvh - 32px);
		max-height: calc(100dvh - 32px);
		min-height: calc(100dvh - 32px);
	}
}

@media screen and (max-width: 782px) {
	body.admin-bar.paris-saude-acesso-body .paris-saude-wrap--login-split {
		height: calc(100dvh - 46px);
		max-height: calc(100dvh - 46px);
		min-height: calc(100dvh - 46px);
	}
}

body.paris-saude-acesso-body #page,
body.paris-saude-acesso-body .site,
body.paris-saude-acesso-body .site-content {
	max-width: 100% !important;
	width: 100%;
	overflow-x: hidden;
	box-sizing: border-box;
}

body.paris-saude-acesso-body #content,
body.paris-saude-acesso-body .site-main {
	max-width: 100%;
	overflow-x: hidden;
	box-sizing: border-box;
}

/* Tela inicial (login): sem cabeçalho do tema (menus Início / Acesso ao convênio etc.). */
body.paris-saude-acesso-body #site-header,
body.paris-saude-acesso-body header#site-header,
body.paris-saude-acesso-body .elementor-location-header {
	display: none !important;
}

/* Sem rodapé do tema/Elementor (tagline, copyright “All rights reserved” no miolo da página). */
body.paris-saude-acesso-body #site-footer,
body.paris-saude-acesso-body footer#site-footer,
body.paris-saude-acesso-body .elementor-location-footer,
body.paris-saude-acesso-body .site-info {
	display: none !important;
}

body.paris-saude-acesso-body .entry-header,
body.paris-saude-acesso-body .page-header,
body.paris-saude-acesso-body #content > .page-header,
body.paris-saude-acesso-body .site-main > .page-header {
	display: none !important;
}

/* Gestão e painel (balcão, dashboard, atendimento): sem cabeçalho do tema nem título duplicado da página. */
body.paris-saude-gestao-body #site-header,
body.paris-saude-gestao-body header#site-header,
body.paris-saude-gestao-body #masthead,
body.paris-saude-gestao-body .site-header,
body.paris-saude-gestao-body header.site-header,
body.paris-saude-gestao-body .elementor-location-header,
body.paris-saude-app-shell-body #site-header,
body.paris-saude-app-shell-body header#site-header,
body.paris-saude-app-shell-body #masthead,
body.paris-saude-app-shell-body .site-header,
body.paris-saude-app-shell-body header.site-header,
body.paris-saude-app-shell-body .elementor-location-header,
body.paris-saude-app-shell-body header.wp-block-template-part,
body.paris-saude-app-shell-body .wp-site-blocks > header:first-child {
	display: none !important;
}

body.paris-saude-gestao-body #site-footer,
body.paris-saude-gestao-body footer#site-footer,
body.paris-saude-gestao-body .elementor-location-footer,
body.paris-saude-gestao-body .site-info,
body.paris-saude-app-shell-body #site-footer,
body.paris-saude-app-shell-body footer#site-footer,
body.paris-saude-app-shell-body .elementor-location-footer,
body.paris-saude-app-shell-body .site-info {
	display: none !important;
}

body.paris-saude-gestao-body .entry-header,
body.paris-saude-gestao-body .page-header,
body.paris-saude-gestao-body #content > .page-header,
body.paris-saude-gestao-body .site-main > .page-header,
body.paris-saude-app-shell-body .entry-header,
body.paris-saude-app-shell-body .page-header,
body.paris-saude-app-shell-body #content > .page-header,
body.paris-saude-app-shell-body .site-main > .page-header {
	display: none !important;
}

body.paris-saude-gestao-body .elementor-widget-theme-post-title,
body.paris-saude-app-shell-body .elementor-widget-theme-post-title {
	display: none !important;
}

@media (max-width: 1180px) {
	.paris-saude-wrap--login-split {
		height: auto;
		max-height: none;
		min-height: 100vh;
		min-height: 100dvh;
		overflow-y: auto;
		overflow-x: hidden;
	}

	body.paris-saude-acesso-body {
		overflow-y: auto;
	}

	.paris-saude-login-split {
		display: flex;
		flex-direction: column;
		flex-wrap: nowrap;
		flex: 1 1 auto;
		min-height: unset;
		max-height: none;
		height: auto;
		overflow: visible;
		grid-template-columns: none;
		grid-template-rows: none;
	}
	.paris-saude-login-split__brand {
		flex: 0 0 auto;
		width: 100%;
		max-width: 100%;
		min-height: unset;
		padding: 1.5rem 1rem 1.25rem;
		border-right: none;
		border-bottom: 1px solid rgba(148, 163, 184, 0.2);
	}
	.paris-saude-login-split__brand-inner {
		max-width: min(440px, 100%);
		align-items: flex-start;
	}
	.paris-saude-login-split__brand-hero-img {
		max-height: none;
	}

	.paris-saude-login-split__brand--hero-panel {
		min-height: unset;
		align-self: auto;
	}

	.paris-saude-login-split__brand--hero-panel .paris-saude-login-split__brand-inner {
		min-height: unset;
	}

	.paris-saude-login-split__brand--hero-panel:not(.paris-saude-login-split__brand--hero-panel-with-apps) .paris-saude-login-split__brand-hero {
		min-height: unset;
	}

	.paris-saude-login-split__brand--hero-panel:not(.paris-saude-login-split__brand--hero-panel-with-apps) .paris-saude-login-split__brand-hero-img {
		position: static;
		top: auto;
		left: auto;
		right: auto;
		min-height: unset;
		width: 100%;
		height: auto;
		max-width: 100%;
		object-fit: contain;
		border-radius: 10px;
	}

	.paris-saude-login-split__brand--hero-panel-with-apps .paris-saude-login-split__brand-inner {
		min-height: unset;
	}
	.paris-saude-login-split__visual {
		margin-top: 0.5rem;
	}
	.paris-saude-login-split__panel {
		flex: 0 0 auto;
		width: 100%;
		max-width: 100%;
		height: auto;
		padding: 1.5rem 1rem 2.5rem;
	}
}

@media (max-width: 600px) {
	.paris-saude-form--inline,
	.paris-saude-form--search {
		flex-direction: column;
		align-items: stretch;
	}
	.paris-saude-form input[type="text"],
	.paris-saude-form select {
		max-width: 100%;
	}
}

/* Dashboard */
.paris-saude-dashboard__head {
	display: flex;
	align-items: flex-start;
	justify-content: space-between;
	gap: 1rem 1.25rem;
	margin-bottom: 0.25rem;
}

.paris-saude-dashboard__head-text {
	flex: 1;
	min-width: 0;
}

.paris-saude-dashboard__title {
	margin: 0 0 0.25rem;
	font-size: 1.35rem;
	color: var(--ps-heading);
}

.paris-saude-wrap--dashboard .paris-saude-dashboard__refresh,
.paris-saude-card.paris-saude-dashboard .paris-saude-dashboard__refresh {
	flex-shrink: 0;
	align-self: flex-start;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 0.35rem;
	min-width: 2.5rem;
	min-height: 2.5rem;
	margin: 0;
	padding: 0.45rem 0.65rem;
	box-sizing: border-box;
	font: inherit;
	line-height: 1;
	-webkit-appearance: none;
	appearance: none;
	border: 1px solid rgba(41, 59, 127, 0.22);
	border-radius: 10px;
	background: var(--ps-card, #fff);
	color: var(--ps-heading);
	box-shadow: 0 1px 2px rgba(15, 23, 42, 0.04);
	cursor: pointer;
	transition: background 0.18s ease, border-color 0.18s ease, color 0.18s ease, box-shadow 0.18s ease;
}

.paris-saude-dashboard__refresh:hover:not(:disabled) {
	background: rgba(41, 59, 127, 0.06);
	border-color: rgba(41, 59, 127, 0.35);
	color: var(--ps-heading);
	box-shadow: 0 2px 6px rgba(41, 59, 127, 0.08);
}

.paris-saude-dashboard__refresh:active:not(:disabled) {
	background: rgba(10, 95, 90, 0.07);
	border-color: rgba(10, 95, 90, 0.28);
	color: var(--ps-teal-dark);
}

.paris-saude-dashboard__refresh:focus-visible {
	outline: 2px solid rgba(41, 59, 127, 0.45);
	outline-offset: 2px;
}

.paris-saude-dashboard__refresh .paris-saude-dashboard-refresh__svg {
	display: block;
	flex-shrink: 0;
	width: 1.15rem;
	height: 1.15rem;
}

.paris-saude-dashboard__refresh:disabled {
	opacity: 0.65;
	cursor: wait;
}

.paris-saude-dashboard__refresh.is-loading .paris-saude-dashboard-refresh__svg {
	display: block;
	transform-origin: 50% 50%;
	animation: paris-saude-spin 0.75s linear infinite;
}

@keyframes paris-saude-spin {
	to {
		transform: rotate(360deg);
	}
}

.paris-saude-dashboard__subtitle {
	margin: 0 0 1.25rem;
	color: var(--ps-muted);
	font-size: 0.95rem;
}

.paris-saude-dashboard__metrics {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(140px, 1fr));
	gap: 0.75rem;
	margin-bottom: 1.5rem;
}

.paris-saude-metric {
	background: linear-gradient(145deg, #f8fafc 0%, #fff 100%);
	border: 1px solid var(--ps-border);
	border-radius: 10px;
	padding: 0.85rem 1rem;
	display: flex;
	flex-direction: column;
	gap: 0.2rem;
}

.paris-saude-metric__value {
	font-size: 1.65rem;
	font-weight: 700;
	color: var(--ps-teal);
	line-height: 1.1;
}

.paris-saude-metric__label {
	font-size: 0.82rem;
	color: var(--ps-muted);
	font-weight: 600;
}

.paris-saude-dashboard__grid2 {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
	gap: 1.25rem;
	align-items: start;
}

.paris-saude-dashboard__panel {
	background: var(--ps-card);
	border: 1px solid var(--ps-border);
	border-radius: 10px;
	padding: 1rem 1.1rem;
}

.paris-saude-dashboard__panel h3 {
	margin: 0 0 0.75rem;
	font-size: 1rem;
	color: var(--ps-heading);
}

.paris-saude-dashboard__empty {
	margin: 0;
	color: var(--ps-muted);
	font-size: 0.92rem;
}

.paris-saude-dashboard__rank {
	margin: 0;
	padding-left: 1.2rem;
}

.paris-saude-dashboard__rank li {
	display: flex;
	justify-content: space-between;
	align-items: baseline;
	gap: 0.5rem;
	margin-bottom: 0.45rem;
}

.paris-saude-dashboard__rank-name {
	font-size: 0.92rem;
}

.paris-saude-dashboard__rank-cnt {
	color: var(--ps-teal);
	font-size: 0.95rem;
}

.paris-saude-dashboard__recent {
	list-style: none;
	margin: 0;
	padding: 0;
	display: flex;
	flex-direction: column;
	gap: 0.65rem;
}

.paris-saude-dashboard__recent li {
	display: grid;
	grid-template-columns: 1fr auto;
	grid-template-rows: auto auto;
	gap: 0.15rem 0.75rem;
	padding-bottom: 0.65rem;
	border-bottom: 1px solid var(--ps-border);
	font-size: 0.88rem;
}

.paris-saude-dashboard__recent li:last-child {
	border-bottom: none;
	padding-bottom: 0;
}

.paris-saude-dashboard__recent-main {
	grid-column: 1 / -1;
	display: flex;
	flex-direction: column;
	gap: 0.1rem;
}

.paris-saude-dashboard__recent-meta {
	color: var(--ps-muted);
	font-size: 0.82rem;
}

.paris-saude-dashboard__recent-status {
	grid-column: 1;
	font-size: 0.78rem;
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: 0.02em;
}

.paris-saude-dashboard__recent-status--novo {
	color: #0369a1;
}
.paris-saude-dashboard__recent-status--aguardando {
	color: #0369a1;
}
.paris-saude-dashboard__recent-status--em_atendimento {
	color: #b45309;
}
.paris-saude-dashboard__recent-status--validado {
	color: #15803d;
}
.paris-saude-dashboard__recent-status--finalizado {
	color: #64748b;
}

.paris-saude-dashboard__recent-when {
	grid-column: 2;
	grid-row: 2;
	text-align: right;
	color: var(--ps-muted);
	font-size: 0.78rem;
	white-space: nowrap;
}

.paris-saude-dashboard__recent-footer {
	margin-top: 0.75rem;
	padding-top: 0.65rem;
	border-top: 1px solid var(--ps-border);
}

.paris-saude-dashboard__recent-meta-text {
	margin: 0 0 0.5rem;
	font-size: 0.82rem;
	color: var(--ps-muted);
	line-height: 1.4;
}

.paris-saude-dashboard__recent-pager {
	margin-top: 0.15rem;
	flex-wrap: wrap;
}

/* Kanban */
.paris-saude-kanban__title {
	margin: 0 0 0.25rem;
	font-size: 1.35rem;
	color: var(--ps-heading);
}

.paris-saude-kanban__hint {
	margin: 0 0 1rem;
	color: var(--ps-muted);
	font-size: 0.9rem;
}

.paris-saude-kanban__board {
	display: grid;
	grid-template-columns: repeat(3, minmax(0, 1fr));
	gap: 1rem;
	align-items: start;
}

@media (max-width: 900px) {
	.paris-saude-kanban__board {
		grid-template-columns: 1fr;
	}
}

.paris-saude-kanban__col {
	background: #f8fafc;
	border: 1px solid var(--ps-border);
	border-radius: 10px;
	min-height: 120px;
	display: flex;
	flex-direction: column;
	max-height: min(70vh, 620px);
	min-width: 0;
}

.paris-saude-kanban__col-head {
	display: flex;
	justify-content: space-between;
	align-items: center;
	padding: 0.55rem 0.65rem;
	border-bottom: 1px solid var(--ps-border);
	background: #fff;
	border-radius: 10px 10px 0 0;
}

.paris-saude-kanban__col-head h3 {
	margin: 0;
	font-size: 0.82rem;
	font-weight: 700;
	color: var(--ps-heading);
}

.paris-saude-kanban__count {
	font-size: 0.75rem;
	font-weight: 700;
	color: var(--ps-muted);
	background: #f1f5f9;
	padding: 0.15rem 0.45rem;
	border-radius: 999px;
}

.paris-saude-kanban__list {
	flex: 1;
	overflow-y: auto;
	padding: 0.45rem;
	min-height: 72px;
	transition: background 0.15s ease;
}

.paris-saude-kanban__list.paris-saude-kanban__list--drag-over {
	background: rgba(13, 148, 136, 0.08);
	outline: 2px dashed var(--ps-teal);
	outline-offset: -2px;
	border-radius: 8px;
}

.paris-saude-kanban__card {
	background: #fff;
	border: 1px solid #e2e8f0;
	border-radius: 8px;
	padding: 0.65rem 0.75rem;
	margin-bottom: 0.45rem;
	cursor: grab;
	box-shadow: 0 1px 2px rgba(15, 23, 42, 0.05);
	min-width: 0;
}

.paris-saude-kanban__card:active {
	cursor: grabbing;
}

.paris-saude-kanban__card.paris-saude-kanban__card--dragging {
	opacity: 0.55;
}

.paris-saude-kanban__card-name {
	display: block;
	font-size: 0.88rem;
	margin-bottom: 0.2rem;
}

.paris-saude-kanban__card-code {
	display: block;
	font-size: 0.75rem;
	font-weight: 700;
	color: var(--ps-teal);
}

.paris-saude-kanban__card-co {
	display: block;
	font-size: 0.72rem;
	color: var(--ps-muted);
	margin-top: 0.15rem;
}

.paris-saude-kanban__card--rich {
	padding: 0.7rem 0.85rem 0.6rem;
}

.paris-saude-kanban__card-head {
	margin-bottom: 0.15rem;
}

.paris-saude-kanban__card-sub {
	display: block;
	font-size: 0.72rem;
	color: var(--ps-text);
	line-height: 1.35;
	margin-top: 0.12rem;
}

.paris-saude-kanban__card-empresa-label,
.paris-saude-kanban__card-cliente-label {
	font-weight: 600;
	color: var(--ps-muted);
	margin-right: 0.2rem;
}

.paris-saude-kanban__card-contact {
	margin-top: 0.35rem;
	display: flex;
	align-items: center;
	min-height: 2.25rem;
}

.paris-saude-kanban__card-meta {
	display: flex;
	align-items: flex-start;
	gap: 0.5rem;
	margin: 0.45rem 0 0.35rem;
	padding-top: 0.45rem;
	border-top: 1px solid #e2e8f0;
}

.paris-saude-kanban__card-meta-text {
	display: flex;
	flex-direction: column;
	gap: 0.1rem;
	min-width: 0;
}

.paris-saude-kanban__card-op {
	font-size: 0.78rem;
	font-weight: 600;
	color: var(--ps-text);
}

.paris-saude-kanban__card-date {
	font-size: 0.72rem;
	color: var(--ps-muted);
}

.paris-saude-kanban__card-created-foot {
	display: block;
	text-align: right;
	font-size: 0.62rem;
	font-variant-numeric: tabular-nums;
	color: var(--ps-muted);
	opacity: 0.88;
	margin-top: 0.35rem;
	line-height: 1.25;
	letter-spacing: 0.01em;
}

.paris-saude-kanban__card-next-wrap {
	display: block;
	margin-top: 0.45rem;
}

.paris-saude-kanban__card-next {
	width: 100%;
	margin-top: 0.1rem;
	font-size: 0.78rem;
	font-weight: 600;
	padding: 0.38rem 0.5rem;
	border-radius: 8px;
	border: 1px solid rgba(10, 95, 90, 0.22);
	background: linear-gradient(180deg, #f0fdfa 0%, #e0f2f1 100%);
	color: var(--ps-teal-dark, #06403c);
	cursor: pointer;
}

.paris-saude-kanban__card-next:hover {
	border-color: rgba(10, 95, 90, 0.38);
	background: linear-gradient(180deg, #ecfdf5 0%, #ccfbf1 100%);
	color: var(--ps-teal, #0a5f5a);
}

.paris-saude-kanban__card-next:focus {
	outline: 2px solid rgba(10, 95, 90, 0.35);
	outline-offset: 1px;
}

.paris-saude-wa-grid-start-form {
	display: inline;
	margin: 0;
	padding: 0;
	vertical-align: middle;
}

.paris-saude-result__attendance-form {
	display: inline;
	margin: 0;
	padding: 0;
}

.paris-saude-result__attendance-form .paris-saude-btn {
	margin-right: 0.35rem;
	margin-bottom: 0.35rem;
}

.paris-saude-result__attendance-form--block {
	display: flex;
	flex-direction: column;
	align-items: flex-start;
	gap: 0.5rem;
	width: 100%;
}

.paris-saude-result__wa-opt {
	display: flex;
	align-items: flex-start;
	gap: 0.45rem;
	font-size: 0.9rem;
	color: var(--ps-muted);
	font-weight: 500;
	max-width: 28rem;
}

.paris-saude-result__wa-opt input[type="checkbox"] {
	margin-top: 0.2rem;
	flex-shrink: 0;
}

.paris-saude-logs__title {
	margin: 0 0 0.35rem;
	font-size: 1.35rem;
	color: var(--ps-heading);
}

.paris-saude-logs__hint {
	margin: 0 0 1rem;
	color: var(--ps-muted);
	font-size: 0.92rem;
}

.paris-saude-table--logs td {
	font-size: 0.88rem;
	vertical-align: top;
}

.paris-saude-muted {
	color: var(--ps-muted);
	font-weight: 500;
}

.paris-saude-logs__pager {
	margin-top: 1rem;
}
