/* =========================================================
   CEDADI — main stylesheet
   Centro de Endoscopia Digestiva
   Paleta: azul navy quente + bronze
   Tipografia: Century Gothic (display) + Century Schoolbook (serif) + Inter (body)
   ========================================================= */

:root {
	/* Cores — sobrescritas em runtime pelo customizer */
	--cdd-azul:           #1e3a5f;
	--cdd-azul-deep:      #142944;
	--cdd-azul-soft:      #3d5a80;
	--cdd-azul-overlay:   rgba(20, 41, 68, 0.85);

	--cdd-bronze:         #b08d57;
	--cdd-bronze-deep:    #8a6b3e;
	--cdd-bronze-soft:    #d4b896;
	--cdd-bronze-tint:    rgba(176, 141, 87, 0.08);

	--cdd-cream:          #fdfcfa;
	--cdd-bg-soft:        #f5f1ea;
	--cdd-bg-warm:        #faf6ef;

	--cdd-fg:             #1a1f2e;
	--cdd-fg-soft:        #4a5365;
	--cdd-muted:          #8a93a5;
	--cdd-line:           #e5dfd4;
	--cdd-line-soft:      #efeae0;

	/* Bordas e sombras — bordas sutis, quase sem sombra (oposto a HEO/Prontocor) */
	--cdd-radius-sm:      4px;
	--cdd-radius:         8px;
	--cdd-radius-lg:      14px;
	--cdd-shadow:         0 2px 8px rgba(20, 41, 68, 0.04);
	--cdd-shadow-lg:      0 8px 32px rgba(20, 41, 68, 0.08);

	/* Tipografia */
	--cdd-font-display:   "Century Gothic", "URW Gothic", "Avant Garde", "Trebuchet MS", sans-serif;
	--cdd-font-serif:     "Century 751 BT", "Century Schoolbook", "Bookman Old Style", Georgia, serif;
	--cdd-font-body:      "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;

	--cdd-container:      1280px;
	--cdd-gutter:         clamp(24px, 5vw, 40px);
	--cdd-header-h:       92px;
}

@media (max-width: 720px) {
	:root { --cdd-header-h: 76px; }
}

/* =========================================================
   Base
   ========================================================= */
* { box-sizing: border-box; }

html {
	-webkit-text-size-adjust: 100%;
	scroll-behavior: smooth;
	overflow-x: hidden;
}

body {
	margin: 0;
	font-family: var(--cdd-font-body);
	font-size: 16px;
	line-height: 1.65;
	color: var(--cdd-fg);
	background: var(--cdd-cream);
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
	overflow-x: hidden;
}

img, svg, video { max-width: 100%; height: auto; display: block; }

a {
	color: var(--cdd-azul);
	text-decoration: none;
	transition: color .2s ease, opacity .2s ease;
}
a:hover { color: var(--cdd-bronze-deep); }

ul, ol { list-style: none; padding: 0; margin: 0; }
p { margin: 0 0 1em; }

/* Tipografia — display geométrica (Century Gothic) pros títulos grandes,
   serif pros médios, body pros pequenos */
h1, h2 {
	font-family: var(--cdd-font-display);
	font-weight: 400;
	line-height: 1.1;
	letter-spacing: -0.01em;
	color: var(--cdd-azul-deep);
	margin: 0 0 0.4em;
}

h3, h4, h5 {
	font-family: var(--cdd-font-serif);
	font-weight: 400;
	line-height: 1.25;
	color: var(--cdd-azul-deep);
	margin: 0 0 0.5em;
}

h1 { font-size: clamp(2.4rem, 5vw, 3.8rem); }
h2 { font-size: clamp(1.9rem, 3.5vw, 2.6rem); }
h3 { font-size: clamp(1.3rem, 2vw, 1.6rem); }
h4 { font-size: 1.15rem; }

.cdd-skip {
	position: absolute; left: -9999px; top: -9999px;
	background: var(--cdd-azul-deep); color: #fff;
	padding: 12px 16px; z-index: 9999;
}
.cdd-skip:focus { left: 12px; top: 12px; }

/* =========================================================
   Layout
   ========================================================= */
.cdd-container {
	max-width: var(--cdd-container);
	margin: 0 auto;
	padding: 0 var(--cdd-gutter);
}

.cdd-section {
	padding-top: clamp(60px, 9vw, 110px);
	padding-bottom: clamp(60px, 9vw, 110px);
}
.cdd-section--soft { background: var(--cdd-bg-soft); }
.cdd-section--warm { background: var(--cdd-bg-warm); }
.cdd-section--azul { background: var(--cdd-azul-deep); color: #fff; }
.cdd-section--azul h1, .cdd-section--azul h2, .cdd-section--azul h3 { color: #fff; }

.cdd-kicker {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	font-family: var(--cdd-font-serif);
	font-style: italic;
	font-size: 0.95rem;
	color: var(--cdd-bronze-deep);
	margin-bottom: 14px;
	letter-spacing: 0.02em;
}
.cdd-kicker::before {
	content: "";
	width: 32px;
	height: 1px;
	background: var(--cdd-bronze);
}

.cdd-section__head {
	max-width: 720px;
	margin-bottom: clamp(32px, 5vw, 56px);
}
.cdd-section__head--center {
	margin-left: auto;
	margin-right: auto;
	text-align: center;
}
.cdd-section__head--center .cdd-kicker { justify-content: center; }
.cdd-section__head--center .cdd-kicker::before { display: none; }

.cdd-lead {
	font-size: 1.125rem;
	color: var(--cdd-fg-soft);
	line-height: 1.65;
}

/* =========================================================
   Botões
   Quadrados (não pill como Prontocor), bronze como CTA principal
   ========================================================= */
.cdd-btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 10px;
	padding: 14px 28px;
	font-family: var(--cdd-font-body);
	font-size: 0.95rem;
	font-weight: 600;
	letter-spacing: 0.02em;
	border-radius: var(--cdd-radius-sm);
	border: 1px solid transparent;
	cursor: pointer;
	transition: all .25s ease;
	text-decoration: none !important;
	line-height: 1;
}

.cdd-btn--primary {
	background: var(--cdd-bronze);
	color: #fff;
	border-color: var(--cdd-bronze);
}
.cdd-btn--primary:hover {
	background: var(--cdd-bronze-deep);
	border-color: var(--cdd-bronze-deep);
	color: #fff;
}

.cdd-btn--secondary {
	background: var(--cdd-azul-deep);
	color: #fff;
	border-color: var(--cdd-azul-deep);
}
.cdd-btn--secondary:hover {
	background: var(--cdd-azul);
	border-color: var(--cdd-azul);
	color: #fff;
}

.cdd-btn--ghost {
	background: transparent;
	color: var(--cdd-azul-deep);
	border-color: var(--cdd-azul-deep);
}
.cdd-btn--ghost:hover {
	background: var(--cdd-azul-deep);
	color: #fff;
}

.cdd-btn--ghost-light {
	background: transparent;
	color: #fff;
	border-color: rgba(255,255,255,0.4);
}
.cdd-btn--ghost-light:hover { background: #fff; color: var(--cdd-azul-deep); }

.cdd-btn--big { padding: 18px 36px; font-size: 1rem; }

.cdd-btn svg { width: 18px; height: 18px; flex-shrink: 0; }

/* =========================================================
   Header
   ========================================================= */
.cdd-header {
	background: var(--cdd-cream);
	border-bottom: 1px solid var(--cdd-line);
	position: sticky; top: 0;
	z-index: 100;
}
.cdd-header__inner {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 16px;
	padding: 16px var(--cdd-gutter);
	max-width: var(--cdd-container);
	margin: 0 auto;
}
@media (min-width: 721px) {
	.cdd-header__inner { padding: 18px var(--cdd-gutter); gap: 24px; }
}
.cdd-header__brand {
	display: inline-flex;
	align-items: center;
	flex-shrink: 0;
}
.cdd-header__brand img,
.cdd-header__brand .custom-logo {
	max-height: 56px !important;
	width: auto !important;
	height: auto !important;
	max-width: 200px !important;
	object-fit: contain !important;
	display: block;
}
.cdd-header__brand-text {
	font-family: var(--cdd-font-display);
	font-size: 1.6rem;
	color: var(--cdd-azul-deep);
	letter-spacing: 0.04em;
}

.cdd-header__nav {
	display: flex;
	align-items: center;
	gap: 4px;
}
.cdd-header__menu {
	display: flex;
	gap: 4px;
}
.cdd-header__menu a {
	display: inline-block;
	padding: 10px 14px;
	color: var(--cdd-fg);
	font-size: 0.95rem;
	font-weight: 500;
	border-radius: var(--cdd-radius-sm);
	transition: all .2s ease;
}
.cdd-header__menu a:hover {
	color: var(--cdd-bronze-deep);
	background: var(--cdd-bronze-tint);
}
.cdd-header__menu .current-menu-item > a,
.cdd-header__menu .current_page_item > a {
	color: var(--cdd-bronze-deep);
}

.cdd-header__actions {
	display: flex;
	align-items: center;
	gap: 12px;
}

.cdd-header__phone {
	display: none;
	align-items: center;
	gap: 8px;
	font-weight: 600;
	color: var(--cdd-azul-deep);
	font-size: 0.95rem;
}
.cdd-header__phone svg { width: 16px; height: 16px; color: var(--cdd-bronze); }
@media (min-width: 1024px) {
	.cdd-header__phone { display: inline-flex; }
}

.cdd-header__menu-toggle {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 44px;
	height: 44px;
	background: transparent;
	border: 1px solid var(--cdd-line);
	border-radius: var(--cdd-radius-sm);
	color: var(--cdd-azul-deep);
	cursor: pointer;
}
.cdd-header__menu-toggle svg { width: 22px; height: 22px; }

.cdd-header__backdrop {
	position: fixed;
	inset: var(--cdd-header-h) 0 0 0;
	background: rgba(20, 41, 68, 0.55);
	backdrop-filter: blur(2px);
	-webkit-backdrop-filter: blur(2px);
	z-index: 95;
	opacity: 0;
	visibility: hidden;
	transition: opacity .25s ease, visibility .25s ease;
}
body.cdd-menu-open .cdd-header__backdrop {
	opacity: 1;
	visibility: visible;
}
body.cdd-menu-open { overflow: hidden; }

@media (min-width: 961px) {
	.cdd-header__backdrop { display: none; }
}

@media (max-width: 960px) {
	.cdd-header__nav { display: none; }
	.cdd-header__nav.is-open {
		display: flex;
		position: absolute;
		top: 100%; left: 0; right: 0;
		flex-direction: column;
		align-items: stretch;
		background: var(--cdd-cream);
		border-bottom: 1px solid var(--cdd-line);
		box-shadow: 0 12px 24px rgba(20, 41, 68, 0.12);
		padding: 8px var(--cdd-gutter) 20px;
		gap: 0;
		max-height: calc(100vh - var(--cdd-header-h));
		overflow-y: auto;
		z-index: 96;
	}
	.cdd-header__nav.is-open .cdd-header__menu {
		flex-direction: column;
		gap: 0;
	}
	.cdd-header__nav.is-open .cdd-header__menu a {
		padding: 16px 4px;
		border-bottom: 1px solid var(--cdd-line-soft);
		font-size: 1rem;
		font-family: var(--cdd-font-serif);
		color: var(--cdd-azul-deep);
		border-radius: 0;
	}
	.cdd-header__nav.is-open .cdd-header__menu a:hover,
	.cdd-header__nav.is-open .cdd-header__menu .current-menu-item > a {
		background: transparent;
		color: var(--cdd-bronze-deep);
		padding-left: 8px;
	}
	.cdd-header__nav.is-open .cdd-header__actions {
		flex-direction: column;
		align-items: stretch;
		gap: 12px;
		padding-top: 18px;
	}
	.cdd-header__nav.is-open .cdd-header__actions .cdd-btn {
		width: 100%;
		padding: 16px 24px;
	}
	.cdd-header__nav.is-open .cdd-header__phone {
		display: inline-flex;
		justify-content: center;
		padding: 12px;
		border: 1px solid var(--cdd-line);
		border-radius: var(--cdd-radius-sm);
	}
}
@media (min-width: 961px) {
	.cdd-header__menu-toggle { display: none; }
}

/* =========================================================
   Hero da home
   ========================================================= */
.cdd-hero {
	position: relative;
	padding: clamp(70px, 12vw, 130px) 0 clamp(70px, 11vw, 120px);
	background: var(--cdd-cream);
	overflow: hidden;
}
.cdd-hero::before {
	content: "";
	position: absolute;
	top: 0; right: 0;
	width: 45%;
	height: 100%;
	background: var(--cdd-bg-soft);
	clip-path: polygon(20% 0, 100% 0, 100% 100%, 0 100%);
	z-index: 0;
}
.cdd-hero__inner {
	position: relative;
	z-index: 1;
	display: grid;
	grid-template-columns: 1.3fr 1fr;
	gap: 60px;
	align-items: center;
}
@media (max-width: 880px) {
	.cdd-hero::before { display: none; }
	.cdd-hero__inner { grid-template-columns: 1fr; gap: 40px; }
}

.cdd-hero__title {
	font-size: clamp(2.6rem, 5.5vw, 4.4rem);
	font-weight: 400;
	color: var(--cdd-azul-deep);
	margin-bottom: 24px;
}
.cdd-hero__title em {
	font-family: var(--cdd-font-serif);
	font-style: italic;
	color: var(--cdd-bronze-deep);
}
.cdd-hero__lead {
	font-size: 1.15rem;
	color: var(--cdd-fg-soft);
	max-width: 520px;
	margin-bottom: 36px;
}
.cdd-hero__actions {
	display: flex; flex-wrap: wrap; gap: 14px;
}

.cdd-hero__media {
	position: relative;
	aspect-ratio: 4/5;
	border-radius: var(--cdd-radius-lg);
	overflow: hidden;
	background: var(--cdd-bronze-tint);
	border: 1px solid var(--cdd-bronze-soft);
}
.cdd-hero__media img {
	width: 100%; height: 100%; object-fit: cover;
}
.cdd-hero__media-placeholder {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 100%; height: 100%;
	color: var(--cdd-bronze-deep);
	font-family: var(--cdd-font-serif);
	font-style: italic;
	opacity: 0.5;
}

/* =========================================================
   Page hero (subpáginas)
   ========================================================= */
.cdd-pagehero {
	background: var(--cdd-bg-soft);
	padding: clamp(60px, 9vw, 100px) 0 clamp(40px, 6vw, 70px);
	border-bottom: 1px solid var(--cdd-line);
}
.cdd-pagehero__title {
	font-size: clamp(2.2rem, 4.5vw, 3.4rem);
	margin-bottom: 16px;
}
.cdd-pagehero__lead {
	font-size: 1.1rem;
	color: var(--cdd-fg-soft);
	max-width: 720px;
}

.cdd-breadcrumb {
	display: flex;
	flex-wrap: wrap;
	gap: 8px;
	font-size: 0.85rem;
	color: var(--cdd-muted);
	margin-bottom: 18px;
	font-family: var(--cdd-font-body);
}
.cdd-breadcrumb a { color: var(--cdd-muted); }
.cdd-breadcrumb a:hover { color: var(--cdd-bronze-deep); }
.cdd-breadcrumb__sep { color: var(--cdd-line); }
.cdd-breadcrumb__current { color: var(--cdd-azul-deep); font-weight: 500; }

/* =========================================================
   Cards de procedimento (grid)
   ========================================================= */
.cdd-grid {
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
	gap: 24px;
}
.cdd-grid--3 { grid-template-columns: repeat(auto-fill, minmax(320px, 1fr)); }
.cdd-grid--4 {
	grid-template-columns: repeat(4, 1fr);
	gap: 20px;
}
@media (max-width: 1100px) {
	.cdd-grid--4 { grid-template-columns: repeat(3, 1fr); }
}
@media (max-width: 820px) {
	.cdd-grid--4 { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 520px) {
	.cdd-grid--4 { grid-template-columns: 1fr; }
}

.cdd-card {
	display: flex;
	flex-direction: column;
	background: #fff;
	border: 1px solid var(--cdd-line);
	border-radius: var(--cdd-radius);
	overflow: hidden;
	transition: border-color .25s ease, transform .25s ease;
}
.cdd-card:hover {
	border-color: var(--cdd-bronze);
	transform: translateY(-2px);
}
.cdd-card__link {
	display: flex;
	flex-direction: column;
	height: 100%;
	color: inherit;
	text-decoration: none !important;
}
.cdd-card__media {
	aspect-ratio: 4/3;
	background: var(--cdd-bg-soft);
	overflow: hidden;
}
.cdd-card__media img {
	width: 100%; height: 100%; object-fit: cover;
	transition: transform .4s ease;
}
.cdd-card:hover .cdd-card__media img { transform: scale(1.04); }
.cdd-card__placeholder {
	display: flex; align-items: center; justify-content: center;
	width: 100%; height: 100%;
	font-size: 3rem; color: var(--cdd-bronze);
	background: var(--cdd-bronze-tint);
}
.cdd-card__body {
	padding: 24px;
	display: flex;
	flex-direction: column;
	gap: 8px;
	flex: 1;
}
.cdd-card__title {
	font-family: var(--cdd-font-serif);
	font-size: 1.25rem;
	color: var(--cdd-azul-deep);
	margin: 0;
}
.cdd-card__excerpt {
	color: var(--cdd-fg-soft);
	font-size: 0.95rem;
	line-height: 1.6;
	margin: 0;
}
.cdd-card__cta {
	margin-top: auto;
	padding-top: 16px;
	color: var(--cdd-bronze-deep);
	font-weight: 600;
	font-size: 0.9rem;
	display: inline-flex;
	align-items: center;
	gap: 6px;
}
.cdd-card__cta svg { width: 14px; height: 14px; transition: transform .2s ease; }
.cdd-card:hover .cdd-card__cta svg { transform: translateX(4px); }

/* =========================================================
   Carrossel (procedimentos + valores)
   Scroll-snap nativo + setas de navegação
   ========================================================= */
.cdd-carousel {
	position: relative;
}
.cdd-carousel__track {
	display: flex;
	gap: 20px;
	overflow-x: auto;
	scroll-snap-type: x mandatory;
	padding: 4px 0 24px;
	scrollbar-width: thin;
	scrollbar-color: var(--cdd-bronze-soft) transparent;
}
.cdd-carousel__track::-webkit-scrollbar { height: 6px; }
.cdd-carousel__track::-webkit-scrollbar-track { background: transparent; }
.cdd-carousel__track::-webkit-scrollbar-thumb {
	background: var(--cdd-bronze-soft);
	border-radius: 3px;
}
.cdd-carousel__item {
	flex: 0 0 calc(33.333% - 14px);
	min-width: 0;
	scroll-snap-align: start;
}
@media (max-width: 980px) {
	.cdd-carousel__item { flex: 0 0 calc(50% - 10px); }
}
@media (max-width: 640px) {
	.cdd-carousel__item { flex: 0 0 calc(100% - 32px); }
}

.cdd-carousel__nav {
	position: absolute;
	top: 38%;
	transform: translateY(-50%);
	z-index: 5;
	width: 48px;
	height: 48px;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	background: #fff;
	border: 1px solid var(--cdd-line);
	border-radius: 50%;
	cursor: pointer;
	color: var(--cdd-azul-deep);
	box-shadow: var(--cdd-shadow-lg);
	transition: all .2s ease;
}
.cdd-carousel__nav:hover {
	background: var(--cdd-bronze);
	border-color: var(--cdd-bronze);
	color: #fff;
	transform: translateY(-50%) scale(1.05);
}
.cdd-carousel__nav:disabled {
	opacity: 0.35;
	cursor: not-allowed;
	transform: translateY(-50%);
}
.cdd-carousel__nav:disabled:hover {
	background: #fff;
	border-color: var(--cdd-line);
	color: var(--cdd-azul-deep);
}
.cdd-carousel__nav svg { width: 20px; height: 20px; }
.cdd-carousel__nav--prev { left: -24px; }
.cdd-carousel__nav--next { right: -24px; }
@media (max-width: 720px) {
	.cdd-carousel__nav { display: none; }
}

/* Cards de valor (Por que CEDADI) */
.cdd-valor {
	background: #fff;
	border: 1px solid var(--cdd-line);
	border-radius: var(--cdd-radius);
	padding: 32px 28px;
	display: flex;
	flex-direction: column;
	gap: 14px;
	transition: all .25s ease;
	height: 100%;
}
.cdd-valor:hover {
	border-color: var(--cdd-bronze);
	transform: translateY(-2px);
}
.cdd-valor__icon {
	font-size: 1.6rem;
	width: 56px; height: 56px;
	display: inline-flex; align-items: center; justify-content: center;
	background: var(--cdd-bronze-tint);
	border-radius: var(--cdd-radius-sm);
	color: var(--cdd-bronze-deep);
}
.cdd-valor__title {
	font-family: var(--cdd-font-serif);
	font-size: 1.25rem;
	color: var(--cdd-azul-deep);
	margin: 0;
}
.cdd-valor__text {
	color: var(--cdd-fg-soft);
	font-size: 0.95rem;
	line-height: 1.6;
	margin: 0;
}

/* =========================================================
   Glossário (archive doenças) — A-Z + busca
   ========================================================= */
.cdd-glossario__filters {
	background: var(--cdd-cream);
	border-bottom: 1px solid var(--cdd-line);
	padding: 20px 0;
	position: sticky;
	top: var(--cdd-header-h);
	z-index: 50;
}
.cdd-glossario__filters-inner {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: 20px;
}
.cdd-glossario__search {
	position: relative;
	flex: 1;
	min-width: 240px;
	max-width: 380px;
}
.cdd-glossario__search input {
	width: 100%;
	padding: 12px 16px 12px 44px;
	border: 1px solid var(--cdd-line);
	border-radius: var(--cdd-radius-sm);
	font-family: var(--cdd-font-body);
	font-size: 0.95rem;
	background: var(--cdd-bg-warm);
	color: var(--cdd-fg);
}
.cdd-glossario__search input:focus {
	outline: none;
	border-color: var(--cdd-bronze);
	background: #fff;
}
.cdd-glossario__search-icon {
	position: absolute;
	left: 14px; top: 50%;
	transform: translateY(-50%);
	color: var(--cdd-muted);
}
.cdd-glossario__search-icon svg { width: 18px; height: 18px; }

.cdd-glossario__alfabeto {
	display: flex;
	flex-wrap: wrap;
	gap: 4px;
}
.cdd-glossario__letra {
	min-width: 32px;
	height: 32px;
	padding: 0 8px;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	background: transparent;
	border: 1px solid var(--cdd-line);
	border-radius: var(--cdd-radius-sm);
	font-family: var(--cdd-font-display);
	font-size: 0.85rem;
	color: var(--cdd-azul-deep);
	cursor: pointer;
	transition: all .15s ease;
}
.cdd-glossario__letra:hover { border-color: var(--cdd-bronze); color: var(--cdd-bronze-deep); }
.cdd-glossario__letra.is-active {
	background: var(--cdd-azul-deep);
	border-color: var(--cdd-azul-deep);
	color: #fff;
}
.cdd-glossario__letra.is-empty {
	color: var(--cdd-line);
	cursor: not-allowed;
}

.cdd-glossario__grid {
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
	gap: 16px;
}
.cdd-glossario__card {
	border: 1px solid var(--cdd-line);
	border-radius: var(--cdd-radius);
	background: #fff;
	transition: all .2s ease;
}
.cdd-glossario__card:hover {
	border-color: var(--cdd-bronze);
	transform: translateY(-2px);
}
.cdd-glossario__card-link {
	display: flex;
	gap: 16px;
	padding: 18px;
	color: inherit;
	text-decoration: none !important;
	align-items: flex-start;
}
.cdd-glossario__card-emoji {
	font-size: 1.6rem;
	flex-shrink: 0;
	width: 44px;
	height: 44px;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	background: var(--cdd-bronze-tint);
	border-radius: var(--cdd-radius-sm);
}
.cdd-glossario__card-body { flex: 1; min-width: 0; }
.cdd-glossario__card-nome {
	font-family: var(--cdd-font-serif);
	font-size: 1.1rem;
	color: var(--cdd-azul-deep);
	margin: 0 0 4px;
}
.cdd-glossario__card-desc {
	color: var(--cdd-fg-soft);
	font-size: 0.88rem;
	line-height: 1.5;
	margin: 0;
}
.cdd-glossario__empty {
	text-align: center;
	color: var(--cdd-muted);
	padding: 60px 20px;
}

/* =========================================================
   Single — doença / procedimento (prose)
   ========================================================= */
.cdd-prose {
	font-size: 1rem;
	line-height: 1.75;
	color: var(--cdd-fg-soft);
}
.cdd-prose h2 { font-size: 1.6rem; margin: 2em 0 0.6em; }
.cdd-prose h3 { font-size: 1.3rem; margin: 1.6em 0 0.5em; }
.cdd-prose p, .cdd-prose ul, .cdd-prose ol { margin-bottom: 1.2em; }
.cdd-prose ul, .cdd-prose ol {
	padding-left: 0;
}
.cdd-prose ul li {
	position: relative;
	padding-left: 24px;
	margin-bottom: 0.5em;
}
.cdd-prose ul li::before {
	content: "";
	position: absolute;
	left: 0; top: 12px;
	width: 8px; height: 1px;
	background: var(--cdd-bronze);
}
.cdd-prose ol { padding-left: 24px; list-style: decimal; }
.cdd-prose strong { color: var(--cdd-azul-deep); font-weight: 600; }
.cdd-prose a { color: var(--cdd-bronze-deep); text-decoration: underline; }

.cdd-bloco {
	background: #fff;
	border: 1px solid var(--cdd-line);
	border-radius: var(--cdd-radius);
	padding: 32px;
	margin-bottom: 20px;
}
.cdd-bloco--alarme {
	background: #fef9f4;
	border-color: var(--cdd-bronze-soft);
	border-left: 4px solid var(--cdd-bronze);
}
.cdd-bloco__head {
	display: flex;
	align-items: center;
	gap: 14px;
	margin-bottom: 20px;
	padding-bottom: 16px;
	border-bottom: 1px solid var(--cdd-line-soft);
}
.cdd-bloco__icon {
	font-size: 1.4rem;
	width: 40px; height: 40px;
	display: inline-flex; align-items: center; justify-content: center;
	background: var(--cdd-bronze-tint);
	border-radius: var(--cdd-radius-sm);
	color: var(--cdd-bronze-deep);
}
.cdd-bloco__title {
	font-family: var(--cdd-font-serif);
	font-size: 1.3rem;
	color: var(--cdd-azul-deep);
	margin: 0;
}

/* Sidebar/aside com procedimentos relacionados */
.cdd-doenca__layout {
	display: grid;
	grid-template-columns: 1fr 320px;
	gap: 48px;
	align-items: start;
}
@media (max-width: 960px) {
	.cdd-doenca__layout { grid-template-columns: 1fr; }
}
.cdd-doenca__aside {
	position: sticky;
	top: calc(var(--cdd-header-h) + 24px);
}
@media (max-width: 960px) {
	.cdd-doenca__aside { position: static; top: auto; }
}
.cdd-aside-card {
	background: var(--cdd-azul-deep);
	color: #fff;
	border-radius: var(--cdd-radius);
	padding: 28px;
	margin-bottom: 16px;
}
.cdd-aside-card h3 { color: #fff; font-family: var(--cdd-font-serif); font-size: 1.2rem; margin-bottom: 16px; }
.cdd-aside-card ul li {
	padding: 12px 0;
	border-bottom: 1px solid rgba(255,255,255,0.1);
}
.cdd-aside-card ul li:last-child { border-bottom: 0; }
.cdd-aside-card ul li a {
	color: #fff;
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 8px;
}
.cdd-aside-card ul li a:hover { color: var(--cdd-bronze-soft); }
.cdd-aside-card ul li a svg { width: 14px; height: 14px; }

/* =========================================================
   Equipe (2 médicos inline) — layout horizontal compacto
   ========================================================= */
.cdd-equipe {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(380px, 1fr));
	gap: 24px;
	max-width: 980px;
	margin: 0 auto;
}
.cdd-medico {
	display: grid;
	grid-template-columns: 140px 1fr;
	background: #fff;
	border: 1px solid var(--cdd-line);
	border-radius: var(--cdd-radius);
	overflow: hidden;
	transition: border-color .25s ease;
}
.cdd-medico:hover { border-color: var(--cdd-bronze-soft); }
.cdd-medico__foto {
	background: var(--cdd-bronze-tint);
	overflow: hidden;
}
.cdd-medico__foto img { width: 100%; height: 100%; object-fit: cover; }
.cdd-medico__placeholder {
	width: 100%; height: 100%;
	display: flex; align-items: center; justify-content: center;
	color: var(--cdd-bronze);
	font-family: var(--cdd-font-serif);
	font-size: 2.4rem;
	opacity: 0.4;
}
.cdd-medico__body {
	padding: 20px 22px;
	display: flex;
	flex-direction: column;
	justify-content: center;
}
.cdd-medico__nome {
	font-family: var(--cdd-font-serif);
	font-size: 1.2rem;
	color: var(--cdd-azul-deep);
	margin: 0 0 2px;
	line-height: 1.2;
}
.cdd-medico__crm {
	font-size: 0.78rem;
	color: var(--cdd-muted);
	margin-bottom: 8px;
}
.cdd-medico__esp {
	color: var(--cdd-bronze-deep);
	font-style: italic;
	font-family: var(--cdd-font-serif);
	font-size: 0.92rem;
	margin: 0 0 10px;
	line-height: 1.3;
}
.cdd-medico__resumo {
	color: var(--cdd-fg-soft);
	font-size: 0.88rem;
	line-height: 1.5;
	margin: 0;
}
@media (max-width: 480px) {
	.cdd-medico { grid-template-columns: 110px 1fr; }
	.cdd-medico__body { padding: 16px 18px; }
}

/* =========================================================
   Equipe — page-equipe.php (médicos com bio expandida)
   Layout horizontal alternado, foto ~280px à esquerda
   ========================================================= */
.cdd-medico-full {
	display: grid;
	grid-template-columns: 280px 1fr;
	gap: 40px;
	align-items: start;
	background: #fff;
	border: 1px solid var(--cdd-line);
	border-radius: var(--cdd-radius);
	overflow: hidden;
	margin-bottom: 32px;
}
.cdd-medico-full__foto {
	background: var(--cdd-bronze-tint);
	aspect-ratio: 4/5;
	overflow: hidden;
}
.cdd-medico-full__foto img { width: 100%; height: 100%; object-fit: cover; }
.cdd-medico-full__placeholder {
	width: 100%; height: 100%;
	display: flex; align-items: center; justify-content: center;
	color: var(--cdd-bronze);
	font-family: var(--cdd-font-serif);
	font-size: 5rem;
	opacity: 0.3;
}
.cdd-medico-full__body {
	padding: 36px 36px 36px 0;
}
.cdd-medico-full__nome {
	font-family: var(--cdd-font-display);
	font-size: clamp(1.6rem, 3vw, 2.2rem);
	color: var(--cdd-azul-deep);
	margin: 8px 0 4px;
	font-weight: 400;
	letter-spacing: -0.01em;
}
.cdd-medico-full__crm {
	font-size: 0.9rem;
	color: var(--cdd-muted);
	margin-bottom: 16px;
}
.cdd-medico-full__esp {
	color: var(--cdd-bronze-deep);
	font-style: italic;
	font-family: var(--cdd-font-serif);
	font-size: 1.1rem;
	margin: 0 0 18px;
}
.cdd-medico-full__resumo {
	color: var(--cdd-fg-soft);
	font-size: 1.02rem;
	line-height: 1.7;
	margin: 0 0 24px;
}
.cdd-medico-full__formacao { font-size: 0.95rem; }
.cdd-medico-full__formacao h3 {
	font-size: 1.05rem;
	color: var(--cdd-azul-deep);
	margin: 0 0 12px;
	font-family: var(--cdd-font-serif);
}

@media (max-width: 760px) {
	.cdd-medico-full {
		grid-template-columns: 1fr;
		gap: 0;
	}
	.cdd-medico-full__foto {
		aspect-ratio: 16/10;
		max-height: 360px;
	}
	.cdd-medico-full__body { padding: 28px 24px 32px; }
}

/* =========================================================
   Contato — page-contato.php
   ========================================================= */
.cdd-contato-grid {
	display: grid;
	grid-template-columns: 1fr 1.3fr;
	gap: 48px;
	align-items: stretch;
}
@media (max-width: 880px) {
	.cdd-contato-grid { grid-template-columns: 1fr; gap: 32px; }
}

.cdd-contato-info {
	background: var(--cdd-bg-soft);
	border-radius: var(--cdd-radius);
	padding: 36px;
}
.cdd-contato-item {
	display: flex;
	gap: 16px;
	padding: 16px 0;
	border-bottom: 1px solid var(--cdd-line);
	color: var(--cdd-fg);
	text-decoration: none !important;
	align-items: flex-start;
}
.cdd-contato-item:last-of-type { border-bottom: 0; }
.cdd-contato-item__icon {
	width: 40px; height: 40px;
	display: inline-flex; align-items: center; justify-content: center;
	flex-shrink: 0;
	background: #fff;
	border-radius: var(--cdd-radius-sm);
	color: var(--cdd-bronze-deep);
}
.cdd-contato-item__icon svg { width: 18px; height: 18px; }
.cdd-contato-item__label {
	font-size: 0.78rem;
	color: var(--cdd-muted);
	text-transform: uppercase;
	letter-spacing: 0.05em;
	margin: 0 0 2px;
	font-weight: 600;
}
.cdd-contato-item__value {
	color: var(--cdd-azul-deep);
	font-weight: 500;
	font-size: 1rem;
	margin: 0;
	line-height: 1.5;
	display: block;
}
.cdd-contato-item--link { transition: background .2s ease; padding-left: 12px; padding-right: 12px; margin-left: -12px; margin-right: -12px; border-radius: var(--cdd-radius-sm); border-bottom-color: transparent; }
.cdd-contato-item--link + .cdd-contato-item--link,
.cdd-contato-item + .cdd-contato-item--link { border-top: 1px solid var(--cdd-line); border-radius: 0; padding-top: 16px; padding-bottom: 16px; }
.cdd-contato-item--link:hover { background: #fff; color: var(--cdd-azul-deep); }
.cdd-contato-item--link:hover .cdd-contato-item__icon { background: var(--cdd-bronze); color: #fff; }
.cdd-contato-item--whats:hover .cdd-contato-item__icon { background: #25d366; color: #fff; }

.cdd-contato-mapa {
	border-radius: var(--cdd-radius);
	overflow: hidden;
	min-height: 480px;
	border: 1px solid var(--cdd-line);
	background: var(--cdd-bg-soft);
}
.cdd-contato-mapa iframe {
	display: block;
	width: 100%;
	height: 100%;
	min-height: 480px;
}
@media (max-width: 880px) {
	.cdd-contato-mapa, .cdd-contato-mapa iframe { min-height: 360px; }
}

/* =========================================================
   Convênios (grid simples de logos)
   ========================================================= */
.cdd-convenios {
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(160px, 1fr));
	gap: 16px;
}
.cdd-convenio {
	aspect-ratio: 16/9;
	background: #fff;
	border: 1px solid var(--cdd-line);
	border-radius: var(--cdd-radius-sm);
	display: flex; align-items: center; justify-content: center;
	padding: 20px;
}
.cdd-convenio img {
	max-width: 100%;
	max-height: 100%;
	object-fit: contain;
	filter: grayscale(1);
	opacity: 0.7;
	transition: all .25s ease;
}
.cdd-convenio:hover img {
	filter: none;
	opacity: 1;
}
.cdd-convenio__nome {
	font-family: var(--cdd-font-serif);
	font-size: 0.95rem;
	color: var(--cdd-azul-deep);
	text-align: center;
}

/* =========================================================
   FAQ accordion
   ========================================================= */
.cdd-faq {
	max-width: 820px;
	margin: 0 auto;
}
.cdd-faq__item {
	border-bottom: 1px solid var(--cdd-line);
}
.cdd-faq__item:first-child { border-top: 1px solid var(--cdd-line); }
.cdd-faq__q {
	width: 100%;
	background: transparent;
	border: 0;
	padding: 22px 0;
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 16px;
	cursor: pointer;
	font-family: var(--cdd-font-serif);
	font-size: 1.1rem;
	color: var(--cdd-azul-deep);
	text-align: left;
	line-height: 1.4;
}
.cdd-faq__q:hover { color: var(--cdd-bronze-deep); }
.cdd-faq__icon {
	flex-shrink: 0;
	width: 32px; height: 32px;
	border: 1px solid var(--cdd-line);
	border-radius: var(--cdd-radius-sm);
	display: inline-flex; align-items: center; justify-content: center;
	color: var(--cdd-bronze-deep);
	transition: transform .25s ease;
}
.cdd-faq__icon svg { width: 14px; height: 14px; }
.cdd-faq__item.is-open .cdd-faq__icon { transform: rotate(45deg); }
.cdd-faq__a {
	max-height: 0;
	overflow: hidden;
	transition: max-height .35s ease;
	color: var(--cdd-fg-soft);
	font-size: 0.98rem;
	line-height: 1.7;
}
.cdd-faq__item.is-open .cdd-faq__a {
	max-height: 800px;
	padding-bottom: 22px;
}

/* =========================================================
   CTA bar (rodapé das páginas)
   ========================================================= */
.cdd-cta-bar {
	background: var(--cdd-azul-deep);
	color: #fff;
	padding: clamp(50px, 7vw, 80px) 0;
	position: relative;
	overflow: hidden;
}
.cdd-cta-bar::after {
	content: "";
	position: absolute;
	right: -100px; bottom: -100px;
	width: 320px; height: 320px;
	background: var(--cdd-bronze);
	border-radius: 50%;
	opacity: 0.1;
}
.cdd-cta-bar__inner {
	position: relative;
	z-index: 1;
	display: grid;
	grid-template-columns: 1fr auto;
	align-items: center;
	gap: 32px;
}
@media (max-width: 720px) {
	.cdd-cta-bar__inner { grid-template-columns: 1fr; }
}
.cdd-cta-bar__title {
	color: #fff;
	font-size: clamp(1.6rem, 3vw, 2.2rem);
	margin: 0 0 8px;
}
.cdd-cta-bar__text { color: rgba(255,255,255,0.85); margin: 0; max-width: 580px; }
.cdd-cta-bar__actions {
	display: flex; flex-wrap: wrap; gap: 12px;
}

/* =========================================================
   Footer
   ========================================================= */
.cdd-footer {
	background: var(--cdd-azul-deep);
	color: rgba(255,255,255,0.85);
	padding: clamp(50px, 7vw, 70px) 0 24px;
	font-size: 0.92rem;
}
.cdd-footer__grid {
	display: grid;
	grid-template-columns: 1.4fr 1fr 1fr 1fr;
	gap: 40px;
	padding-bottom: 40px;
	border-bottom: 1px solid rgba(255,255,255,0.12);
}
@media (max-width: 880px) {
	.cdd-footer__grid { grid-template-columns: 1fr 1fr; }
}
@media (max-width: 540px) {
	.cdd-footer__grid { grid-template-columns: 1fr; }
}
.cdd-footer h4 {
	font-family: var(--cdd-font-display);
	font-size: 1rem;
	color: #fff;
	margin: 0 0 18px;
	letter-spacing: 0.04em;
}
.cdd-footer__brand {
	font-family: var(--cdd-font-display);
	font-size: 1.5rem;
	color: #fff;
	margin-bottom: 14px;
	letter-spacing: 0.04em;
}
.cdd-footer__sobre { color: rgba(255,255,255,0.65); line-height: 1.6; max-width: 320px; }
.cdd-footer ul li { padding: 6px 0; }
.cdd-footer a { color: rgba(255,255,255,0.85); }
.cdd-footer a:hover { color: var(--cdd-bronze-soft); }

.cdd-footer__contato-item {
	display: flex;
	gap: 10px;
	margin-bottom: 12px;
	color: rgba(255,255,255,0.85);
}
.cdd-footer__contato-item svg {
	width: 16px; height: 16px;
	color: var(--cdd-bronze-soft);
	flex-shrink: 0;
	margin-top: 4px;
}
.cdd-footer__bottom {
	padding-top: 24px;
	display: flex;
	justify-content: space-between;
	flex-wrap: wrap;
	gap: 12px;
	color: rgba(255,255,255,0.55);
	font-size: 0.85rem;
}

/* =========================================================
   FAB WhatsApp (floating action button)
   ========================================================= */
.cdd-fab-whats {
	position: fixed;
	right: 20px;
	bottom: 20px;
	z-index: 90;
	display: inline-flex;
	align-items: center;
	gap: 10px;
	padding: 14px 22px 14px 16px;
	background: #25d366;
	color: #fff !important;
	font-family: var(--cdd-font-body);
	font-weight: 600;
	font-size: 0.95rem;
	border-radius: 999px;
	box-shadow: 0 6px 20px rgba(37, 211, 102, 0.35), 0 2px 6px rgba(0, 0, 0, 0.12);
	text-decoration: none !important;
	transition: transform .25s ease, box-shadow .25s ease, background .25s ease;
	animation: cdd-fab-in 0.5s cubic-bezier(0.2, 0.7, 0.2, 1) 1.2s both;
}
.cdd-fab-whats:hover {
	background: #128c7e;
	color: #fff !important;
	transform: translateY(-2px) scale(1.02);
	box-shadow: 0 10px 28px rgba(37, 211, 102, 0.45), 0 4px 10px rgba(0, 0, 0, 0.15);
}
.cdd-fab-whats__icon {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 28px;
	height: 28px;
	flex-shrink: 0;
}
.cdd-fab-whats__icon svg { width: 26px; height: 26px; }
.cdd-fab-whats__icon::before {
	content: "";
	position: absolute;
	width: 100%;
	height: 100%;
	border-radius: 50%;
	background: #25d366;
	opacity: 0.6;
	animation: cdd-fab-pulse 2.4s ease-out infinite;
	z-index: -1;
}
.cdd-fab-whats__icon { position: relative; }

@keyframes cdd-fab-in {
	from { opacity: 0; transform: translateY(20px) scale(0.85); }
	to   { opacity: 1; transform: translateY(0) scale(1); }
}
@keyframes cdd-fab-pulse {
	0%   { transform: scale(1);   opacity: 0.6; }
	70%  { transform: scale(1.6); opacity: 0; }
	100% { transform: scale(1.6); opacity: 0; }
}

@media (max-width: 720px) {
	.cdd-fab-whats {
		right: 16px;
		bottom: 16px;
		padding: 14px;
		gap: 0;
	}
	.cdd-fab-whats__label { display: none; }
	.cdd-fab-whats__icon { width: 24px; height: 24px; }
	.cdd-fab-whats__icon svg { width: 24px; height: 24px; }
}

/* =========================================================
   Reveal on scroll
   ========================================================= */
.cdd-reveal {
	opacity: 0;
	transform: translateY(24px);
	transition: opacity .8s cubic-bezier(0.2, 0.7, 0.2, 1), transform .8s cubic-bezier(0.2, 0.7, 0.2, 1);
}
.cdd-reveal.is-visible {
	opacity: 1;
	transform: translateY(0);
}

/* =========================================================
   Utilities
   ========================================================= */
.cdd-text-center { text-align: center; }
.cdd-mt-0 { margin-top: 0; }
.cdd-mb-0 { margin-bottom: 0; }
.cdd-only-mobile { display: block; }
.cdd-only-desktop { display: none; }
@media (min-width: 720px) {
	.cdd-only-mobile { display: none; }
	.cdd-only-desktop { display: block; }
}
