/*!
 * Clinical Doctor Manager — Frontend styles (v1.0.0)
 *
 * Everything is namespaced under .cdm-* so the plugin never collides with a
 * host theme (Woodmart, Astra, GeneratePress, Kadence, Blocksy, etc.).
 * Tokens are defined once on .cdm-page so themes can override them per-page
 * without touching the plugin.
 */

/* --------------------------------------------------------------------------
 * 1. Design tokens
 * -------------------------------------------------------------------------- */

body.cdm-page,
.cdm-archive,
.cdm-single,
.cdm-shortcode,
.cdm-reviews {
	--cdm-space-1: 4px;
	--cdm-space-2: 8px;
	--cdm-space-3: 12px;
	--cdm-space-4: 16px;
	--cdm-space-5: 20px;
	--cdm-space-6: 24px;
	--cdm-space-8: 32px;

	--cdm-radius:    10px;
	--cdm-radius-sm: 6px;
	--cdm-radius-lg: 14px;

	--cdm-border:       #e6eaee;
	--cdm-border-hover: #cfd7dd;
	--cdm-muted:        #6b7680;
	--cdm-heading:      #1d2327;
	--cdm-body:         #33424f;
	--cdm-surface:      #ffffff;
	--cdm-surface-alt:  #f7f9fb;
	--cdm-primary:         #0b7285;
	--cdm-primary-hover:   #095f6f;
	--cdm-primary-contrast:#ffffff;
	--cdm-accent:          #f1b91b;
	--cdm-accent-ink:      #3a2c00;
	--cdm-success:         #157347;
	--cdm-success-bg:      #e8f4ea;
	--cdm-info:            #0c5460;
	--cdm-info-bg:         #e6f4f7;
	--cdm-danger:          #d63638;
	--cdm-danger-bg:       #f9e2e3;

	--cdm-shadow-sm: 0 1px 2px rgba(15, 23, 42, 0.05);
	--cdm-shadow:    0 1px 3px rgba(15, 23, 42, 0.06), 0 4px 12px rgba(15, 23, 42, 0.05);
	--cdm-shadow-lg: 0 2px 6px rgba(15, 23, 42, 0.08), 0 14px 30px rgba(15, 23, 42, 0.06);

	--cdm-focus: 0 0 0 3px rgba(11, 114, 133, 0.25);

	--cdm-ease: cubic-bezier(0.2, 0.8, 0.2, 1);
	--cdm-dur:  160ms;
	background: #f7f9fb;
}

body {
	background: #f4f6f8;
}

/* --------------------------------------------------------------------------
 * 2. Containers
 * -------------------------------------------------------------------------- */

.cdm-archive,
.cdm-single,
.cdm-shortcode {
	max-width: 1180px;
	margin: 0 auto;
	padding: var(--cdm-space-6) var(--cdm-space-4);
	color: var(--cdm-body);
	line-height: 1.55;
	box-sizing: border-box;
}

.cdm-archive *,
.cdm-single  *,
.cdm-shortcode *,
.cdm-reviews * { box-sizing: border-box; }

.cdm-archive__header {
	margin-bottom: var(--cdm-space-5);
}

.cdm-archive__title {
	margin: 0 0 var(--cdm-space-2);
	color: var(--cdm-heading);
	font-size: clamp(1.4rem, 1.1rem + 1vw, 2rem);
	line-height: 1.2;
}

.cdm-archive__description {
	color: var(--cdm-muted);
	max-width: 70ch;
}

.cdm-hero {
	padding: 80px 24px;
	margin-bottom: 50px;
	border-radius: calc(var(--cdm-radius-lg) + 6px);
	background: linear-gradient(to bottom, #ffffff, #eef6f5);
	border: 1px solid rgba(11, 114, 133, 0.10);
	box-shadow: var(--cdm-shadow);
	text-align: center;
}

.cdm-hero__inner {
	max-width: 760px;
	margin: 0 auto;
}

.cdm-hero__title {
	margin: 0 0 12px;
	color: var(--cdm-heading);
	font-size: 32px;
	font-weight: 600;
	line-height: 1.05;
}

.cdm-hero__subtitle {
	margin: 0;
	color: #666;
	font-size: clamp(1rem, 0.95rem + 0.35vw, 1.2rem);
}

/* --------------------------------------------------------------------------
 * 3. Buttons
 * -------------------------------------------------------------------------- */

.cdm-btn {
	--btn-bg: var(--wd-primary-color, #0f766e);
	--btn-ink: var(--cdm-heading);
	--btn-border: transparent;

	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: var(--cdm-space-2);
	padding: 10px 16px;
	border-radius: 10px;
	border: 1px solid var(--btn-border);
	background: var(--btn-bg);
	color: #fff;
	font: inherit;
	font-weight: 600;
	font-size: 14px;
	line-height: 1.2;
	text-decoration: none;
	cursor: pointer;
	transition: all 0.3s ease;
	box-shadow: 0 3px 8px rgba(0,0,0,0.1);
}
.cdm-btn:hover  { transform: translateY(-1px); box-shadow: var(--cdm-shadow-sm); }
.cdm-btn:active { transform: translateY(0);    box-shadow: none; }
.cdm-btn:focus-visible { outline: none; box-shadow: var(--cdm-focus); }
.cdm-btn[disabled], .cdm-btn.is-loading { opacity: 0.7; pointer-events: none; }

.cdm-btn--primary {
	--btn-bg: var(--wd-primary-color, #0f766e);
	--btn-ink: var(--cdm-primary-contrast);
}
.cdm-btn--primary:hover { background: #0b5f59; color: var(--cdm-primary-contrast); }

.cdm-btn--secondary {
	--btn-bg: var(--cdm-surface);
	--btn-border: var(--cdm-border);
}

.cdm-btn--ghost {
	--btn-bg: transparent;
	--btn-ink: var(--cdm-muted);
	--btn-border: var(--cdm-border);
}
.cdm-btn--ghost:hover { color: var(--cdm-heading); }

/* --------------------------------------------------------------------------
 * 4. Filter bar
 * -------------------------------------------------------------------------- */

.cdm-filters {
	background: var(--cdm-surface);
	border: 1px solid var(--cdm-border);
	border-radius: var(--cdm-radius);
	padding: var(--cdm-space-4);
	margin-bottom: var(--cdm-space-5);
	box-shadow: var(--cdm-shadow);
}

.cdm-filter-bar {
	position: sticky;
	top: 16px;
	z-index: 20;
	margin-bottom: 30px;
	background: #ffffff;
	border: 1px solid rgba(0,0,0,0.08);
	border-radius: 14px;
	box-shadow: 0 6px 16px rgba(0,0,0,0.04);
	display: flex;
	align-items: flex-end;
	gap: 15px;
	flex-wrap: wrap;
	overflow: hidden;
}

.cdm-filter-bar .cdm-filters {
	display: flex;
	flex-direction: column;
	gap: 15px;
	padding: 20px;
	border-radius: 14px;
	box-shadow: none;
	width: 100%;
}

.cdm-filter-bar > div {
	flex: 1;
	display: flex;
	flex-direction: column;
	justify-content: flex-end;
	min-width: 160px;
	position: relative;
	overflow: hidden;
	min-width: 0;
}

.cdm-filter-bar > div:first-child {
	flex: 2;
	max-width: 100%;
}

.cdm-filters__row {
	display: flex;
	flex-wrap: wrap;
	gap: var(--cdm-space-3);
	align-items: center;
}

.cdm-filters__field {
	display: flex;
	flex-direction: column;
	gap: var(--cdm-space-1);
	min-width: 0;
	flex: 0 1 auto;
}

.cdm-filters__field--search {
	position: relative;
}

.cdm-filter-bar .field,
.cdm-filter-bar .filter-group {
	display: flex;
	flex-direction: column;
	min-width: 180px;
}

.cdm-filters__field:has([data-cdm-filter="search"]) {
	flex: 2 1 280px;
}

.cdm-filter-bar .search-field {
	flex: 2;
}

.cdm-filter-bar input[type="text"] {
	width: 100%;
	box-sizing: border-box;
}

.cdm-filter-bar > div:nth-child(2) {
	flex: 1;
	min-width: 180px;
}

.cdm-filters__field:has([data-cdm-filter="orderby"]) {
	flex: 1 1 180px;
}

.cdm-filters__label {
	font-size: 12px;
	font-weight: 600;
	color: var(--cdm-muted);
	text-transform: uppercase;
	letter-spacing: 0.04em;
}

.cdm-filter-bar input,
.cdm-filter-bar select {
	width: 100%;
	max-width: 100%;
	box-sizing: border-box;
	display: block;
	flex: 1 1 auto;
	background: var(--wd-bg-color, #fff);
	border: 1px solid rgba(0,0,0,0.08);
	border-radius: 8px;
}

.cdm-filter-bar input:focus,
.cdm-filter-bar select:focus {
	border-color: var(--wd-primary-color, #0f766e);
	box-shadow: 0 0 0 2px rgba(15,118,110,0.12);
}

.cdm-filter-bar select {
	min-width: 0;
	flex-shrink: 1;
}

.cdm-filters__field input,
.cdm-filters__field select,
.cdm-review-form input[type="text"],
.cdm-review-form input[type="email"],
.cdm-review-form textarea {
	width: 100%;
	padding: 8px 12px;
	border: 1px solid var(--cdm-border);
	border-radius: 8px;
	background: var(--cdm-surface);
	color: var(--cdm-heading);
	font: inherit;
	line-height: 1.3;
	transition: border-color var(--cdm-dur) var(--cdm-ease), box-shadow var(--cdm-dur) var(--cdm-ease);
}

.cdm-filters__field input:hover,
.cdm-filters__field select:hover,
.cdm-review-form input:hover,
.cdm-review-form textarea:hover { border-color: var(--cdm-border-hover); }

.cdm-filters__field input:focus-visible,
.cdm-filters__field select:focus-visible,
.cdm-review-form input:focus-visible,
.cdm-review-form textarea:focus-visible {
	outline: none;
	border-color: var(--cdm-primary);
	box-shadow: var(--cdm-focus);
}

.cdm-search-suggestions {
	position: absolute;
	top: calc(100% + 8px);
	left: 0;
	right: 0;
	z-index: 30;
	display: flex;
	flex-direction: column;
	padding: 8px;
	background: var(--wd-bg-color, #fff);
	border: 1px solid rgba(0,0,0,0.08);
	border-radius: 12px;
	box-shadow: 0 10px 24px rgba(0,0,0,0.08);
}

.cdm-search-suggestions__item {
	display: block;
	padding: 10px 12px;
	border-radius: 10px;
	color: inherit;
	text-decoration: none;
	transition: background-color var(--cdm-dur) var(--cdm-ease);
}

.cdm-search-suggestions__item:hover,
.cdm-search-suggestions__item.is-active {
	background: rgba(15,118,110,0.12);
	box-shadow: inset 0 0 0 1px rgba(15,118,110,0.16);
}

.cdm-search-suggestions__name {
	font-size: 14px;
	font-weight: 600;
	color: var(--cdm-heading);
}

.cdm-search-suggestions__meta {
	margin-top: 4px;
	font-size: 12px;
	color: var(--cdm-muted);
}

.cdm-search-suggestions__snippet {
	margin-top: 6px;
	font-size: 13px;
	color: #555;
	line-height: 1.4;
}

.cdm-search-suggestions__empty {
	padding: 12px;
	font-size: 13px;
	color: var(--cdm-muted);
}

.cdm-search-suggestions mark {
	background: rgba(15,118,110,0.16);
	color: inherit;
	padding: 0 2px;
	border-radius: 4px;
}

.cdm-filters__field--inline {
	flex-direction: row;
	align-items: center;
	gap: var(--cdm-space-2);
	padding-bottom: 4px;
}
.cdm-filters__field--inline input[type="checkbox"] {
	width: 16px; height: 16px; margin: 0;
	accent-color: var(--cdm-primary);
}

.cdm-filters__actions { display: flex; gap: var(--cdm-space-2); align-items: center; flex-wrap: wrap; }

.cdm-filter-bar button {
	align-self: flex-end;
}

.cdm-filters__toggle {
	display: none;
	align-items: center;
	gap: var(--cdm-space-2);
	padding: 8px 12px;
	border: 1px solid var(--cdm-border);
	border-radius: var(--cdm-radius-sm);
	background: var(--cdm-surface);
	color: var(--cdm-heading);
	font: inherit;
	font-weight: 600;
	cursor: pointer;
}
.cdm-filters__toggle:focus-visible { outline: none; box-shadow: var(--cdm-focus); }

.cdm-filters__status {
	margin-top: var(--cdm-space-2);
	font-size: 0.85rem;
	color: var(--cdm-muted);
	min-height: 1.25em;
}
.cdm-filters__status.is-error   { color: var(--cdm-danger); }
.cdm-filters__status.is-success { color: var(--cdm-success); }

/* --------------------------------------------------------------------------
 * 5. Symptom assistant
 * -------------------------------------------------------------------------- */

.cdm-symptom-assistant-launcher {
	display: inline-flex;
}

.cdm-symptom-assistant {
	display: flex;
	flex-direction: column;
	gap: var(--cdm-space-4);
	padding: 24px;
	background: var(--cdm-surface);
	border: 1px solid var(--cdm-border);
	border-radius: var(--cdm-radius);
	box-shadow: var(--cdm-shadow);
}

.cdm-symptom-assistant__header {
	display: flex;
	flex-direction: column;
	gap: 6px;
}

.cdm-symptom-assistant__title {
	margin: 0;
	font-size: 1.2rem;
	color: var(--cdm-heading);
}

.cdm-symptom-assistant__disclaimer,
.cdm-symptom-assistant__result-note {
	margin: 0;
	font-size: 0.9rem;
	color: var(--cdm-muted);
}

.cdm-symptom-assistant__consent {
	display: inline-flex;
	align-items: center;
	gap: 10px;
	font-size: 0.95rem;
	color: var(--cdm-heading);
}

.cdm-symptom-assistant .cdm-symptom-assistant__step,
.cdm-symptom-assistant [data-step] {
	display: none;
	flex-direction: column;
	gap: 10px;
}

.cdm-symptom-assistant .cdm-symptom-assistant__step.is-active,
.cdm-symptom-assistant [data-step].is-active {
	display: block;
}

.cdm-symptom-assistant .cdm-symptom-assistant__step[hidden],
.cdm-symptom-assistant [data-step][hidden] {
	display: none;
}

.cdm-symptom-assistant__textarea {
	width: 100%;
	min-height: 120px;
	padding: 10px 12px;
	border: 1px solid var(--cdm-border);
	border-radius: 10px;
	background: var(--cdm-surface);
	color: var(--cdm-heading);
	font: inherit;
	resize: vertical;
}

.cdm-symptom-assistant__result {
	padding: 16px;
	border: 1px solid rgba(0,0,0,0.08);
	border-radius: 12px;
	background: var(--cdm-surface-alt);
}

.cdm-symptom-assistant__result-label {
	font-size: 12px;
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: 0.04em;
	color: var(--cdm-muted);
}

.cdm-symptom-assistant__result-value {
	margin-top: 4px;
	font-size: 1.1rem;
	font-weight: 600;
	color: var(--cdm-heading);
}

.cdm-symptom-assistant__view-doctors {
	margin-top: 12px;
}

.cdm-symptom-assistant__lead {
	display: flex;
	flex-direction: column;
	gap: 14px;
}

.cdm-symptom-assistant__lead-grid {
	display: grid;
	grid-template-columns: repeat(3, minmax(0, 1fr));
	gap: 12px;
}

.cdm-symptom-assistant__lead input {
	width: 100%;
	padding: 10px 12px;
	border: 1px solid var(--cdm-border);
	border-radius: 8px;
	background: var(--cdm-surface);
	color: var(--cdm-heading);
}

.cdm-field-error {
	border: 1px solid #e53935 !important;
	box-shadow: 0 0 0 2px rgba(229, 57, 53, 0.1);
}

.cdm-symptom-modal {
	position: fixed;
	inset: 0;
	z-index: 9999;
	display: none;
	align-items: center;
	justify-content: center;
	padding: 24px;
}

.cdm-symptom-modal[hidden] {
	display: none !important;
}

.cdm-symptom-modal__backdrop {
	position: absolute;
	inset: 0;
	background: rgba(15, 23, 42, 0.48);
}

.cdm-symptom-modal__panel {
	position: relative;
	z-index: 1;
	width: min(720px, 100%);
	max-height: calc(100vh - 48px);
	overflow: auto;
}

.cdm-symptom-modal__close {
	position: absolute;
	top: 10px;
	right: 10px;
	z-index: 2;
	width: 36px;
	height: 36px;
	border: 0;
	border-radius: 50%;
	background: rgba(15, 23, 42, 0.08);
	color: var(--cdm-heading);
	font-size: 24px;
	line-height: 1;
	cursor: pointer;
}

body.cdm-symptom-modal-open {
	overflow: hidden;
}

/* --------------------------------------------------------------------------
 * 6. Grid layout
 * -------------------------------------------------------------------------- */

.cdm-doctors {
	display: grid;
	gap: var(--cdm-space-4);
}
.cdm-grid {
	display: grid;
	grid-template-columns: repeat(3, minmax(0, 1fr));
	gap: 24px;
	margin-top: 30px;
}
.cdm-doctors--grid.cdm-columns-1 { grid-template-columns: 1fr; }
.cdm-doctors--grid.cdm-columns-2 { grid-template-columns: repeat(2, 1fr); }
.cdm-doctors--grid.cdm-columns-3 { grid-template-columns: repeat(3, 1fr); }
.cdm-doctors--grid.cdm-columns-4 { grid-template-columns: repeat(4, 1fr); }
.cdm-doctors--grid.cdm-columns-5 { grid-template-columns: repeat(5, 1fr); }
.cdm-doctors--grid.cdm-columns-6 { grid-template-columns: repeat(6, 1fr); }

.cdm-doctors--list { grid-template-columns: 1fr; }

/* --------------------------------------------------------------------------
 * 7. Card
 * -------------------------------------------------------------------------- */

.cdm-card {
	position: relative;
	display: flex;
	flex-direction: column;
	/* Fill the full grid cell so footers/buttons align across the row. */
	height: 100%;
	min-height: 320px;
	background: var(--wd-bg-color, #fff);
	border: 1px solid rgba(0,0,0,0.05);
	border-radius: 18px;
	overflow: hidden;
	box-shadow: 0 10px 30px rgba(0,0,0,0.06);
	transition: all 0.3s ease;
	color: var(--cdm-body);
	isolation: isolate;
}

/* Ensure the grid lays out rows with consistent cell heights. */
.cdm-doctors--grid { align-items: stretch; }
.cdm-card:hover { transform: translateY(-6px); border-color: var(--cdm-border-hover); box-shadow: 0 18px 40px rgba(0,0,0,0.10); }
.cdm-card:focus-within { border-color: var(--cdm-primary); box-shadow: var(--cdm-focus); }

.cdm-card--list { flex-direction: row; align-items: stretch; }

.cdm-card__media {
	padding: 0;
	height: 220px;
	border-bottom: 1px solid #eee;
}

.cdm-card__badge {
	position: absolute;
	top: 10px;
	left: 10px;
	z-index: 2;
	padding: 3px 8px;
	border-radius: 999px;
	font-size: 11px;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.05em;
	background: var(--cdm-accent);
	color: var(--cdm-accent-ink);
}

.cdm-card__photo {
	display: block;
	height: 100%;
	overflow: hidden;
	background: var(--cdm-surface-alt);
	border-radius: 0;
}
.cdm-card__photo img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
	transition: transform 400ms var(--cdm-ease);
}
.cdm-card:hover .cdm-card__photo img { transform: scale(1.04); }

.cdm-card--list .cdm-card__photo { flex: 0 0 35%; max-width: 35%; aspect-ratio: auto; }
@media (max-width: 640px) {
	.cdm-card--list { flex-direction: column; }
	.cdm-card--list .cdm-card__photo { flex: none; max-width: 100%; aspect-ratio: 4 / 3; }
}

.cdm-card__photo-placeholder {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 100%;
	height: 100%;
	font-size: 2.2rem;
	color: #c7d1da;
}

.cdm-card-body,
.cdm-card__body {
	padding: 20px;
	display: flex;
	flex-direction: column;
	gap: 8px;
	flex: 1 1 auto;
	min-width: 0;
}

.cdm-card__name {
	margin: 0;
	font-size: 18px;
	font-weight: 600;
	line-height: 1.3;
	/* Clamp long names so cards don't grow unevenly. */
	display: -webkit-box;
	-webkit-line-clamp: 2;
	-webkit-box-orient: vertical;
	overflow: hidden;
	min-height: 2.6em;
}

.cdm-card h3 {
	font-size: 18px;
	font-weight: 600;
}
.cdm-card__name a {
	color: var(--cdm-heading);
	text-decoration: none;
	transition: color var(--cdm-dur) var(--cdm-ease);
}
.cdm-card__name a:hover { color: var(--cdm-primary); }
.cdm-card__name a:focus-visible { outline: none; color: var(--cdm-primary); text-decoration: underline; text-underline-offset: 3px; }

.cdm-specialty,
.cdm-card__designation {
	margin: 0;
	color: #6b7280;
	font-size: 13px;
	display: -webkit-box;
	-webkit-line-clamp: 2;
	-webkit-box-orient: vertical;
	overflow: hidden;
}

.cdm-card__specialties {
	list-style: none;
	padding: 0;
	margin: 0;
	display: flex;
	flex-wrap: wrap;
	gap: 4px;
}
.cdm-card__specialties li a {
	display: inline-block;
	padding: 2px 10px;
	border-radius: 999px;
	background: var(--cdm-surface-alt);
	color: var(--cdm-muted);
	font-size: 12px;
	text-decoration: none;
	transition: background var(--cdm-dur) var(--cdm-ease), color var(--cdm-dur) var(--cdm-ease);
}
.cdm-card__specialties li a:hover { background: var(--cdm-primary); color: #fff; }

.cdm-card__bio {
	margin: 0;
	color: #555;
	font-size: 14px;
	line-height: 1.6;
	display: -webkit-box;
	-webkit-line-clamp: 2;
	-webkit-box-orient: vertical;
	overflow: hidden;
}

.cdm-card__location {
	margin: 2px 0 0;
	color: var(--cdm-muted);
	font-size: 0.88rem;
	display: inline-flex;
	align-items: center;
	gap: var(--cdm-space-1);
}

.cdm-card__footer {
	margin-top: auto;
	padding-top: 14px;
	display: flex;
	justify-content: space-between;
	align-items: center;
	gap: 8px;
	flex-wrap: wrap;
	min-height: 42px; /* stabilise cards with/without status labels */
}
.cdm-card__footer .cdm-btn {
	flex: 1 1 auto;       /* button grows to fill single-child footer */
	min-width: 0;
	justify-content: center;
}
.cdm-card__footer .cdm-btn + .cdm-card__status,
.cdm-card__footer .cdm-card__status + .cdm-btn {
	flex: 0 0 auto;
}

.cdm-card__status { font-size: 0.78rem; color: var(--cdm-muted); }
.cdm-card__status--closed { color: var(--cdm-danger); }
.cdm-card__id {
	font-family: ui-monospace, SFMono-Regular, Menlo, monospace;
	background: var(--cdm-surface-alt);
	padding: 2px 6px;
	border-radius: 4px;
	font-size: 11px;
}

/* --------------------------------------------------------------------------
 * 8. Stars
 * -------------------------------------------------------------------------- */

.cdm-stars {
	display: inline-flex;
	gap: 1px;
	color: var(--cdm-accent);
	font-size: 14px;
	letter-spacing: 0.5px;
	line-height: 1;
}
.cdm-star.is-empty { color: #dde2e7; }
.cdm-star.is-half {
	background: linear-gradient(90deg, var(--cdm-accent) 50%, #dde2e7 50%);
	-webkit-background-clip: text;
	-webkit-text-fill-color: transparent;
	background-clip: text;
}

.cdm-card__rating {
	display: inline-flex;
	align-items: center;
	gap: var(--cdm-space-2);
	font-size: 0.85rem;
	color: var(--cdm-muted);
	margin-top: 2px;
}
.cdm-card__rating-num { font-weight: 700; color: var(--cdm-heading); }

/* --------------------------------------------------------------------------
 * 9. Empty / loading / error states
 * -------------------------------------------------------------------------- */

.cdm-empty {
	padding: 70px;
	text-align: center;
	color: var(--cdm-muted);
	background: #ffffff;
	border: 1px dashed rgba(0,0,0,0.12);
	border-radius: calc(var(--cdm-radius-lg) + 4px);
	box-shadow: 0 4px 12px rgba(0,0,0,0.03);
}
.cdm-empty--error {
	border-color: #efc2c3;
	background: var(--cdm-danger-bg);
	color: var(--cdm-danger);
}

.cdm-filter-bar button:last-child,
.cdm-filter-bar .cdm-filters__actions .cdm-btn:last-child {
	background: transparent;
	border: 1px solid #e5e7eb;
	color: #6b7280;
}

.cdm-empty-icon,
.cdm-empty__icon {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 64px;
	height: 64px;
	margin: 0 auto 16px;
	border-radius: 50%;
	background: linear-gradient(135deg, rgba(11, 114, 133, 0.14), rgba(241, 185, 27, 0.18));
	color: var(--cdm-primary);
	font-size: 24px;
	font-weight: 700;
	transform: rotate(45deg);
}

.cdm-empty__title {
	margin: 0 0 10px;
	color: var(--cdm-heading);
	font-size: 1.35rem;
}

.cdm-empty__message {
	margin: 0 auto 18px;
	max-width: 42ch;
}

.cdm-results-wrap { position: relative; min-height: 80px; }
.cdm-results-wrap.cdm-loading { opacity: 0.65; pointer-events: none; }
.cdm-results-wrap.cdm-loading::after {
	content: "";
	position: absolute;
	inset: 0;
	background: rgba(255, 255, 255, 0.55);
	z-index: 1;
	border-radius: var(--cdm-radius);
}

.cdm-spinner {
	position: absolute;
	inset: 0;
	margin: auto;
	width: 32px;
	height: 32px;
	border: 3px solid var(--cdm-border);
	border-top-color: var(--cdm-primary);
	border-radius: 50%;
	animation: cdm-spin 0.8s linear infinite;
	z-index: 2;
}
@keyframes cdm-spin { to { transform: rotate(360deg); } }

/* Card fade-in for AJAX renders */
[data-cdm-results] > .cdm-card { animation: cdm-fade-in 220ms var(--cdm-ease) both; }
@keyframes cdm-fade-in {
	from { opacity: 0; transform: translateY(4px); }
	to   { opacity: 1; transform: translateY(0); }
}

/* --------------------------------------------------------------------------
 * 10. Pagination
 * -------------------------------------------------------------------------- */

.cdm-pagination { margin-top: var(--cdm-space-5); display: flex; justify-content: center; flex-wrap: wrap; gap: 4px; }
.cdm-pagination .page-numbers {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-width: 36px;
	height: 36px;
	padding: 0 12px;
	border-radius: var(--cdm-radius-sm);
	background: var(--cdm-surface);
	border: 1px solid var(--cdm-border);
	color: var(--cdm-heading);
	text-decoration: none;
	transition: background var(--cdm-dur) var(--cdm-ease), color var(--cdm-dur) var(--cdm-ease), border-color var(--cdm-dur) var(--cdm-ease);
}
.cdm-pagination .page-numbers:hover { border-color: var(--cdm-primary); color: var(--cdm-primary); }
.cdm-pagination .page-numbers.current { background: var(--cdm-primary); border-color: var(--cdm-primary); color: var(--cdm-primary-contrast); }
.cdm-pagination .page-numbers.dots { border: none; background: transparent; }

/* --------------------------------------------------------------------------
 * 11. Single profile
 * -------------------------------------------------------------------------- */

.cdm-profile__header {
	display: grid;
	grid-template-columns: 220px 1fr;
	gap: var(--cdm-space-6);
	padding: var(--cdm-space-6);
	background: var(--cdm-surface);
	border: 1px solid var(--cdm-border);
	border-radius: var(--cdm-radius);
	box-shadow: var(--cdm-shadow);
	margin-bottom: var(--cdm-space-5);
}
@media (max-width: 720px) {
	.cdm-profile__header { grid-template-columns: 1fr; text-align: center; }
	.cdm-profile__actions { justify-content: center; }
	.cdm-profile__specialties { justify-content: center; }
}

.cdm-doctor-image {
	width: 100%;
	aspect-ratio: 1 / 1;
	overflow: hidden;
	border-radius: var(--cdm-radius);
	background: var(--cdm-surface-alt);
}

.cdm-doctor-image img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
}

.cdm-profile__photo img {
	width: 100%;
	aspect-ratio: 1 / 1;
	object-fit: cover;
	border-radius: var(--cdm-radius);
	display: block;
}
.cdm-profile__photo-placeholder {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 100%;
	aspect-ratio: 1 / 1;
	background: var(--cdm-surface-alt);
	color: #c7d1da;
	font-size: 3.5rem;
	border-radius: var(--cdm-radius);
}

.cdm-profile__badge {
	display: inline-block;
	padding: 3px 10px;
	border-radius: 999px;
	background: var(--cdm-accent);
	color: var(--cdm-accent-ink);
	font-size: 11px;
	font-weight: 700;
	text-transform: uppercase;
	margin-bottom: 4px;
}

.cdm-profile__name { margin: 4px 0 2px; font-size: clamp(1.4rem, 1.1rem + 1vw, 1.9rem); color: var(--cdm-heading); line-height: 1.2; }
.cdm-profile__designation { margin: 0; color: var(--cdm-muted); font-size: 1rem; }
.cdm-profile__about {
	margin: var(--cdm-space-2) 0 0;
	max-width: 62ch;
	color: var(--cdm-body);
	font-size: 0.98rem;
	line-height: 1.65;
}

.cdm-profile__specialties {
	list-style: none;
	padding: 0;
	margin: var(--cdm-space-2) 0;
	display: flex;
	flex-wrap: wrap;
	gap: var(--cdm-space-1);
}
.cdm-profile__specialties li a {
	display: inline-block;
	padding: 4px 12px;
	border-radius: 999px;
	background: var(--cdm-surface-alt);
	color: var(--cdm-muted);
	font-size: 0.85rem;
	text-decoration: none;
	transition: background var(--cdm-dur) var(--cdm-ease), color var(--cdm-dur) var(--cdm-ease);
}
.cdm-profile__specialties li a:hover { background: var(--cdm-primary); color: #fff; }

.cdm-profile__rating {
	display: inline-flex;
	align-items: center;
	gap: var(--cdm-space-2);
	margin: 6px 0 10px;
	font-size: 0.92rem;
	color: var(--cdm-muted);
}
.cdm-profile__rating-num { font-weight: 700; color: var(--cdm-heading); }

.cdm-profile__actions { display: flex; gap: var(--cdm-space-2); flex-wrap: wrap; margin-top: var(--cdm-space-2); }

.cdm-profile__closed {
	margin: var(--cdm-space-3) 0 0;
	padding: 8px 12px;
	background: rgba(214, 54, 56, 0.08);
	border: 1px solid rgba(214, 54, 56, 0.2);
	color: var(--cdm-danger);
	border-radius: var(--cdm-radius-sm);
	font-size: 0.9rem;
}

.cdm-profile__layout {
	display: grid;
	grid-template-columns: 1fr 320px;
	gap: var(--cdm-space-5);
}
@media (max-width: 960px) { .cdm-profile__layout { grid-template-columns: 1fr; } }

.cdm-profile__section,
.cdm-profile__card {
	background: var(--cdm-surface);
	border: 1px solid var(--cdm-border);
	border-radius: var(--cdm-radius);
	padding: 18px 20px;
	margin-bottom: 40px;
	box-shadow: var(--cdm-shadow-sm);
}
.cdm-profile__section h2,
.cdm-profile__card h2 { margin: 0 0 10px; font-size: 1.05rem; color: var(--cdm-heading); }

.cdm-profile__list { margin: 0; padding-left: 1.2em; }
.cdm-profile__list li { margin-bottom: 4px; }

/* Dashed-list modifier: strip native bullet, prepend a muted em-dash. */
.cdm-profile__list--dashed {
	list-style: none;
	padding-left: 0;
	margin: 0;
}
.cdm-profile__list--dashed li {
	position: relative;
	padding-left: 1.25em;
	margin-bottom: 6px;
	line-height: 1.5;
}
.cdm-profile__list--dashed li::before {
	content: "—";
	position: absolute;
	left: 0;
	top: 0;
	color: var(--cdm-muted);
	font-weight: 600;
}

.cdm-profile__contact {
	list-style: none;
	padding: 0;
	margin: 0;
	display: flex;
	flex-direction: column;
	gap: var(--cdm-space-2);
}
.cdm-profile__contact li {
	display: flex;
	align-items: flex-start;
	gap: var(--cdm-space-2);
	color: var(--cdm-heading);
}
.cdm-profile__contact a { color: var(--cdm-primary); text-decoration: none; word-break: break-word; }
.cdm-profile__contact a:hover { text-decoration: underline; }

.cdm-media-grid {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(250px, 1fr));
	gap: 15px;
}

.cdm-media-grid iframe {
	width: 100%;
	height: 200px;
}

.cdm-media-embed {
	overflow: hidden;
	border-radius: var(--cdm-radius-sm);
	background: #000;
}

.cdm-media-placeholder {
	display: flex;
	align-items: center;
	justify-content: center;
	min-height: 200px;
	padding: var(--cdm-space-4);
	border: 1px dashed var(--cdm-border);
	border-radius: var(--cdm-radius-sm);
	background: var(--cdm-surface-alt);
	color: var(--cdm-muted);
	font-weight: 600;
	text-align: center;
	word-break: break-word;
}

.cdm-link-map { display: block; margin-top: 2px; font-size: 0.82rem; }

.cdm-profile__stats {
	list-style: none;
	padding: var(--cdm-space-3) 0 0;
	margin: var(--cdm-space-3) 0 0;
	border-top: 1px dashed var(--cdm-border);
	display: flex;
	flex-wrap: wrap;
	gap: 12px 18px;
}
.cdm-profile__stats li { display: flex; flex-direction: column; }
.cdm-profile__stats strong { font-size: 1.1rem; color: var(--cdm-heading); }
.cdm-profile__stats span  { font-size: 0.82rem; color: var(--cdm-muted); }

.cdm-profile__availability {
	list-style: none;
	padding: 0;
	margin: 0;
	display: flex;
	flex-direction: column;
	gap: 6px;
}
.cdm-profile__availability li {
	display: flex;
	justify-content: space-between;
	padding: 6px 0;
	border-bottom: 1px dashed var(--cdm-border);
}
.cdm-profile__availability li:last-child { border-bottom: 0; }
.cdm-profile__availability .is-closed .cdm-hours { color: var(--cdm-muted); font-style: italic; }

.cdm-profile__terms {
	list-style: none;
	padding: 0;
	margin: 0;
	display: flex;
	flex-direction: column;
	gap: 4px;
}
.cdm-profile__terms--inline { flex-direction: row; flex-wrap: wrap; gap: 6px; }
.cdm-profile__terms li a    { display: inline-block; color: var(--cdm-primary); text-decoration: none; }
.cdm-profile__terms li a:hover { text-decoration: underline; }
.cdm-profile__terms--inline li a {
	padding: 3px 10px;
	border-radius: 999px;
	background: var(--cdm-surface-alt);
	color: var(--cdm-muted);
	font-size: 0.85rem;
}

.cdm-profile__social {
	list-style: none;
	padding: 0;
	margin: 0;
	display: flex;
	gap: var(--cdm-space-2);
}
.cdm-social {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 36px;
	height: 36px;
	border-radius: 50%;
	background: var(--cdm-surface-alt);
	color: var(--cdm-muted);
	text-decoration: none;
	transition: background var(--cdm-dur) var(--cdm-ease), color var(--cdm-dur) var(--cdm-ease), transform var(--cdm-dur) var(--cdm-ease);
}
.cdm-social:hover  { background: var(--cdm-primary); color: #fff; transform: translateY(-1px); }
.cdm-social:focus-visible { outline: none; box-shadow: var(--cdm-focus); }

/* --------------------------------------------------------------------------
 * 12. Reviews block
 * -------------------------------------------------------------------------- */

.cdm-reviews {
	margin-top: var(--cdm-space-6);
	background: var(--cdm-surface);
	border: 1px solid var(--cdm-border);
	border-radius: var(--cdm-radius);
	padding: var(--cdm-space-5);
	box-shadow: var(--cdm-shadow);
	color: var(--cdm-body);
}

.cdm-reviews__header h2 { margin: 0 0 var(--cdm-space-3); color: var(--cdm-heading); font-size: 1.3rem; }

.cdm-reviews__summary {
	display: grid;
	grid-template-columns: minmax(180px, 220px) 1fr;
	gap: var(--cdm-space-5);
	align-items: center;
	padding: var(--cdm-space-3) 0 var(--cdm-space-5);
	border-bottom: 1px solid var(--cdm-border);
}
@media (max-width: 640px) { .cdm-reviews__summary { grid-template-columns: 1fr; } }

.cdm-reviews__score { display: flex; flex-direction: column; gap: 4px; align-items: flex-start; }
.cdm-reviews__avg {
	font-size: 2.4rem;
	font-weight: 700;
	line-height: 1;
	color: var(--cdm-heading);
}
.cdm-reviews__count { color: var(--cdm-muted); font-size: 0.9rem; }

.cdm-reviews__breakdown {
	list-style: none;
	padding: 0;
	margin: 0;
	display: flex;
	flex-direction: column;
	gap: 4px;
	font-size: 0.88rem;
}
.cdm-reviews__breakdown li {
	display: grid;
	grid-template-columns: 56px 1fr 40px;
	gap: var(--cdm-space-3);
	align-items: center;
}
.cdm-reviews__br-bar {
	position: relative;
	height: 8px;
	background: var(--cdm-surface-alt);
	border-radius: 999px;
	overflow: hidden;
}
.cdm-reviews__br-bar > span {
	position: absolute;
	inset: 0 auto 0 0;
	background: var(--cdm-accent);
	border-radius: 999px;
	transition: width 240ms var(--cdm-ease);
}
.cdm-reviews__br-count { color: var(--cdm-muted); text-align: right; }

.cdm-reviews__body {
	display: grid;
	grid-template-columns: 1fr 360px;
	gap: var(--cdm-space-5);
	margin-top: var(--cdm-space-5);
}
@media (max-width: 960px) { .cdm-reviews__body { grid-template-columns: 1fr; } }

.cdm-reviews__list  { display: flex; flex-direction: column; gap: var(--cdm-space-3); }
.cdm-reviews__empty {
	padding: 30px;
	text-align: center;
	color: var(--cdm-muted);
	background: var(--cdm-surface-alt);
	border-radius: var(--cdm-radius);
	margin: 0;
}

.cdm-review {
	display: grid;
	grid-template-columns: 48px 1fr;
	gap: var(--cdm-space-3);
	padding: var(--cdm-space-3);
	border: 1px solid var(--cdm-border);
	border-radius: var(--cdm-radius);
	background: var(--cdm-surface);
	transition: border-color var(--cdm-dur) var(--cdm-ease), box-shadow var(--cdm-dur) var(--cdm-ease);
}
.cdm-review:hover { border-color: var(--cdm-border-hover); box-shadow: var(--cdm-shadow-sm); }

.cdm-review__avatar img { border-radius: 50%; width: 48px; height: 48px; object-fit: cover; }

.cdm-review__head {
	display: flex;
	align-items: center;
	flex-wrap: wrap;
	gap: var(--cdm-space-2);
	margin-bottom: 4px;
}
.cdm-review__name    { color: var(--cdm-heading); }
.cdm-review__date    { color: var(--cdm-muted); font-size: 0.82rem; margin-left: auto; }
.cdm-review__title   { margin: 4px 0 6px; font-size: 1rem; color: var(--cdm-heading); }
.cdm-review__content { margin: 0; color: var(--cdm-body); }

/* --------------------------------------------------------------------------
 * 13. Review form
 * -------------------------------------------------------------------------- */

.cdm-review-form {
	background: var(--cdm-surface-alt);
	border: 1px solid var(--cdm-border);
	border-radius: var(--cdm-radius);
	padding: var(--cdm-space-5);
	display: flex;
	flex-direction: column;
	gap: var(--cdm-space-3);
}
.cdm-review-form h3 { margin: 0 0 4px; font-size: 1.05rem; color: var(--cdm-heading); }

.cdm-form-field { display: flex; flex-direction: column; gap: 4px; }
.cdm-form-field label,
.cdm-form-label { font-weight: 600; color: var(--cdm-heading); font-size: 0.92rem; }
.cdm-form-field small { color: var(--cdm-muted); font-size: 0.8rem; }

.cdm-review-form textarea { min-height: 110px; resize: vertical; }

.cdm-required { color: var(--cdm-danger); }

/* Interactive star input */
.cdm-star-input {
	display: inline-flex;
	direction: ltr;
	gap: 2px;
	font-size: 28px;
	line-height: 1;
}
.cdm-star-input label {
	position: relative;
	cursor: pointer;
	color: #dde2e7;
	transition: color 100ms var(--cdm-ease), transform 100ms var(--cdm-ease);
}
.cdm-star-input label:hover { transform: scale(1.08); }
.cdm-star-input label.is-active,
.cdm-star-input label:has(input:checked) { color: var(--cdm-accent); }
.cdm-star-input input[type="radio"] {
	position: absolute;
	opacity: 0;
	width: 1px; height: 1px;
	pointer-events: none;
}
.cdm-star-input label:focus-within {
	outline: none;
	box-shadow: var(--cdm-focus);
	border-radius: 4px;
}

.cdm-form-actions { display: flex; align-items: center; gap: var(--cdm-space-3); flex-wrap: wrap; }
.cdm-form-status  { font-size: 0.88rem; color: var(--cdm-muted); min-height: 1.2em; }
.cdm-form-status.is-error   { color: var(--cdm-danger); }
.cdm-form-status.is-success { color: var(--cdm-success); }

.cdm-notice {
	padding: 10px 14px;
	border-radius: var(--cdm-radius-sm);
	border: 1px solid transparent;
	margin: 0 0 var(--cdm-space-3);
	font-size: 0.92rem;
}
.cdm-notice--success { color: var(--cdm-success); background: var(--cdm-success-bg); border-color: #c9e3cf; }
.cdm-notice--info    { color: var(--cdm-info);    background: var(--cdm-info-bg);    border-color: #bde1ea; }
.cdm-notice--error   { color: var(--cdm-danger);  background: var(--cdm-danger-bg);  border-color: #efc2c3; }
.cdm-notice code     { display: inline-block; margin-left: 6px; background: rgba(0,0,0,0.06); padding: 1px 6px; border-radius: 3px; font-size: 0.82em; }

/* Review form login gate */
.cdm-review-form-gate {
	background: var(--cdm-surface-alt);
	border: 1px dashed var(--cdm-border);
	border-radius: var(--cdm-radius);
	padding: var(--cdm-space-5);
	text-align: center;
	color: var(--cdm-muted);
}
.cdm-review-form-gate h3 { margin: 0 0 var(--cdm-space-2); color: var(--cdm-heading); }
.cdm-review-form-gate a  { color: var(--cdm-primary); }

/* --------------------------------------------------------------------------
 * 14. Mobile filter toggle + small-screen grid collapse
 * -------------------------------------------------------------------------- */

@media (max-width: 900px) {
	.cdm-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
	.cdm-doctors--grid[class*="cdm-columns-"] { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 560px) {
	.cdm-grid { grid-template-columns: 1fr; }
	.cdm-doctors--grid[class*="cdm-columns-"] { grid-template-columns: 1fr; }
}

@media (max-width: 640px) {
	.cdm-hero {
		padding: 56px 18px;
	}

	.cdm-filter-bar {
		position: static;
	}

	.cdm-filters__toggle { display: inline-flex; }
	.cdm-filters__row {
		display: none;
		grid-template-columns: 1fr;
		padding-top: var(--cdm-space-3);
	}
	.cdm-filters.is-open .cdm-filters__row { display: grid; }
}

@media (max-width: 768px) {
	.cdm-filter-bar {
		flex-direction: column;
		align-items: stretch;
	}

	.cdm-symptom-assistant__lead-grid {
		grid-template-columns: 1fr;
	}
}

/* --------------------------------------------------------------------------
 * 15. Utilities / a11y / reduced motion / print
 * -------------------------------------------------------------------------- */

.screen-reader-text {
	border: 0;
	clip: rect(1px, 1px, 1px, 1px);
	-webkit-clip-path: inset(50%);
	clip-path: inset(50%);
	height: 1px;
	margin: -1px;
	overflow: hidden;
	padding: 0;
	position: absolute;
	width: 1px;
	word-wrap: normal !important;
}

@media (prefers-reduced-motion: reduce) {
	.cdm-card,
	.cdm-card__photo img,
	.cdm-social,
	.cdm-btn,
	.cdm-filters__field input,
	.cdm-filters__field select,
	.cdm-review-form input,
	.cdm-review-form textarea,
	.cdm-star-input label,
	.cdm-reviews__br-bar > span,
	[data-cdm-results] > .cdm-card {
		transition: none !important;
		animation: none !important;
	}
}

/* Responsive video embed (introduction-video section) */
.cdm-video-embed {
	position: relative;
	width: 100%;
	max-width: 720px;
	aspect-ratio: 16 / 9;
	border-radius: var(--cdm-radius);
	overflow: hidden;
	background: #000;
}
.cdm-video-embed iframe,
.cdm-video-embed object,
.cdm-video-embed embed,
.cdm-video-embed video {
	position: absolute;
	inset: 0;
	width: 100% !important;
	height: 100% !important;
	border: 0;
}

@media print {
	.cdm-filters,
	.cdm-profile__actions,
	.cdm-review-form,
	.cdm-pagination,
	.cdm-profile__social,
	[data-cdm-filters],
	.cdm-filters__toggle { display: none !important; }

	.cdm-card,
	.cdm-profile__header,
	.cdm-profile__section,
	.cdm-profile__card,
	.cdm-review,
	.cdm-reviews {
		box-shadow: none !important;
		border-color: #999 !important;
	}

	.cdm-archive,
	.cdm-single,
	.cdm-shortcode { max-width: none; padding: 0; }
}
