/**
 * Find a Doctor Archive Styles
 *
 * Styles for the /find-a-doctor/ archive page including map, search form, and results.
 *
 * @package TMW_FindADoctor
 * @since 1.0.0
 */

/* ==========================================================================
   Archive Container
   ========================================================================== */

.find-a-doctor-archive {
	padding-block: var(--space-2xl);
}

/* Container uses site's .container class for consistent padding/max-width.
   No custom styles needed - inherits from .container class in template. */

/* ==========================================================================
   Archive Header
   ========================================================================== */

.archive-header {
	margin-block-end: var(--space-xl);
	text-align: center;
}

.archive-title {
	margin-block-end: var(--space-sm);
}

.archive-description {
	font-size: var(--font-size-lead);
	max-width: 65ch;
	margin-inline: auto;
}

/* ==========================================================================
   Search Form Section
   ========================================================================== */

.search-form-section {
	margin-block-end: var(--space-2xl);
	padding: var(--space-lg);
	background-color: var(--color-bg);
	border-radius: var(--radius-card);
	border: 1px solid var(--color-border);
}

.search-form-placeholder {
	padding: var(--space-lg);
	background-color: var(--color-white);
	border: 2px dashed var(--color-border);
	border-radius: var(--radius-card);
	text-align: center;
}

.search-form-placeholder p {
	margin-block: var(--space-xs);
}

/* Gravity Forms styling for search form */
.search-form-section .gform_wrapper {
	margin: 0;
}

/* ==========================================================================
   Custom Search Form
   ========================================================================== */

.doctor-search-form {
	position: relative;
}

/* Form Rows */
.form-row {
	margin-block-end: var(--space-lg);
}

.form-row--contact {
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	gap: var(--space-md);
}

.form-row--consent {
	margin-block-end: var(--space-lg);
}

.form-row--submit {
	display: flex;
	align-items: center;
	gap: var(--space-lg);
	margin-block-end: 0;
}

/* Form Fields */
.form-field {
	display: flex;
	flex-direction: column;
}

.form-label {
	display: block;
	margin-block-end: var(--space-xs);
	font-weight: 600;
}

.form-label .required,
.form-checkbox-item--consent .required {
	color: var(--color-error);
	margin-inline-start: 0.125em;
}

.form-input {
	width: 100%;
	padding: var(--space-sm) var(--space-md);
	border: 1px solid var(--color-border);
	border-radius: var(--radius-card);
	font-family: inherit;
	transition: border-color 0.2s ease, box-shadow 0.2s ease;
}

.form-input:focus {
	outline: none;
	border-color: var(--color-primary);
	box-shadow: 0 0 0 3px rgb(0 102 204 / 15%);
}

.form-input.has-error {
	border-color: var(--color-error);
}

/* Field-level error messages */
.form-field-error {
	display: none;
	margin-block-start: var(--space-xs);
	font-size: var(--font-size-small);
	color: var(--color-error);
}

.form-field--error .form-label {
	color: var(--color-error);
}

/* Fieldset */
.form-fieldset {
	margin: 0;
	padding: 0;
	border: none;
	margin-block-end: var(--space-lg);
}

.form-legend {
	display: block;
	margin-block-end: var(--space-sm);
	font-weight: 600;
}

.form-legend .required {
	color: var(--color-error);
	margin-inline-start: 0.125em;
}

/* ==========================================================================
   Specialty Pill Checkboxes (shared between search form and refinement)
   ========================================================================== */

.specialty-pill-list {
	display: flex;
	flex-wrap: wrap;
	gap: var(--space-sm);
	list-style: none;
	padding: 0;
	margin: 0;
}

.specialty-pill-item {
	margin: 0;
}

.specialty-pill-input {
	position: absolute;
	opacity: 0;
	width: 1px;
	height: 1px;
}

.specialty-pill-label {
	display: inline-flex;
	align-items: center;
	padding: var(--space-xs) var(--space-md);
	background: var(--btn-secondary-bg);
	color: var(--btn-secondary-text-color);
	border-color: var(--btn-secondary-border-color);
	border-width: var(--btn-secondary-border-width);
	border-style: var(--btn-secondary-border-style);
	border-radius: var(--radius-button);
	cursor: pointer;
	transition: all 0.2s ease;
	box-sizing: border-box;
}

.specialty-pill-label:hover {
	background: var(--btn-secondary-hover-bg);
	color: var(--btn-secondary-hover-text-color);
	border-color: var(--btn-secondary-hover-border-color);
}

.specialty-pill-input:checked + .specialty-pill-label {
	background: var(--btn-primary-bg);
	color: var(--btn-primary-text-color);
	border-color: var(--btn-primary-border-color);
}

.specialty-pill-input:focus + .specialty-pill-label {
	box-shadow: 0 0 0 3px var(--btn-secondary-border-color, rgb(0 102 204 / 15%));
}

/* Checkbox Group (legacy - for consent checkbox) */
.form-checkbox-group {
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
	gap: var(--space-sm);
}

.form-checkbox-item {
	display: flex;
	align-items: flex-start;
	gap: var(--space-xs);
}

.form-checkbox {
	width: 18px;
	height: 18px;
	margin: 0;
	margin-block-start: 2px;
	flex-shrink: 0;
	accent-color: var(--color-primary);
}

.form-checkbox-label {
	cursor: pointer;
	user-select: none;
}

/* Consent checkbox (single line) */
.form-checkbox-item--consent {
	align-items: flex-start;
}

.form-checkbox-label--consent {
	font-size: var(--font-size-small);
}

.form-checkbox-label--consent a {
	text-decoration: underline;
}

.form-checkbox-label--consent a:hover {
	text-decoration: none;
}

/* Honeypot (hidden from users) */
.form-field--honeypot {
	position: absolute;
	left: -9999px;
	opacity: 0;
	pointer-events: none;
}

/* Form Messages */
.form-messages {
	margin-block-end: var(--space-md);
}

.form-error {
	margin: 0;
	padding: var(--space-sm) var(--space-md);
	background-color: rgb(221 0 0 / 10%);
	border: 1px solid var(--color-error);
	border-radius: var(--radius-card);
	color: var(--color-error);
	font-size: var(--font-size-small);
}

.form-error--specialty {
	margin-block-start: var(--space-sm);
	background: none;
	border: none;
	padding: 0;
}

/* Submit Button */
.form-submit {
	flex-shrink: 0;
}

.form-submit:disabled {
	opacity: 0.6;
	cursor: not-allowed;
}

/* Required Note */
.form-required-note {
	margin: 0;
	font-size: var(--font-size-small);
}

.form-required-note .required {
	color: var(--color-error);
}

/* Form Loading Overlay */
.form-loading-overlay {
	position: absolute;
	inset: 0;
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	background-color: rgb(255 255 255 / 90%);
	border-radius: var(--radius-card);
	z-index: 10;
}

.form-loading-overlay .spinner {
	width: 48px;
	height: 48px;
	border: 4px solid var(--color-border);
	border-top-color: var(--color-primary);
	border-radius: 50%;
	animation: spinner 0.8s linear infinite;
}

.form-loading-overlay p {
	margin-block-start: var(--space-md);
}

/* Tablet: 2 columns for contact fields */
@media (width <= 991px) {
	.form-row--contact {
		grid-template-columns: repeat(2, 1fr);
	}
}

/* Mobile: Stack contact fields */
@media (width <= 767px) {
	.form-row--contact {
		grid-template-columns: 1fr;
	}

	.form-checkbox-group {
		grid-template-columns: 1fr;
	}

	.form-row--submit {
		flex-direction: column;
		align-items: stretch;
		gap: var(--space-md);
	}

	.form-required-note {
		text-align: center;
	}
}

/* ==========================================================================
   Map & Results Wrapper
   ========================================================================== */

/* Hidden initially - shown via JS after search */
.map-results-wrapper {
	display: none;
	grid-template-columns: 35fr 65fr;
	gap: var(--space-lg);
	min-height: 600px;
	margin-block-end: var(--space-2xl);
}

/* Show when search has been performed */
.map-results-wrapper.is-active {
	display: grid;
}

/* Mobile: Stack vertically */
@media (width <= 991px) {
	.map-results-wrapper.is-active {
		grid-template-columns: 1fr;
		gap: var(--space-md);
	}
}

/* ==========================================================================
   Search Refinement Header
   ========================================================================== */

.search-refinement-header {
	grid-column: 1 / -1;
	padding: var(--space-lg);
	margin-block-end: var(--space-md);
	background-color: var(--color-bg);
	border-radius: var(--radius-card);
	border: 1px solid var(--color-border);
}

.search-refinement-form {
	display: flex;
	flex-wrap: wrap;
	gap: var(--space-lg);
	align-items: flex-end;
}

.search-refinement-location {
	flex: 0 0 auto;
}

.search-refinement-label {
	display: block;
	margin-block-end: var(--space-xs);
	font-weight: 700;
}

.search-refinement-zip-wrapper {
	display: flex;
	gap: var(--space-xs);
}

.search-refinement-zip {
	width: 120px;
	padding: var(--space-sm) var(--space-md);
	border: 1px solid var(--color-border);
	border-radius: var(--radius-card);
	font-family: inherit;
}

.search-refinement-zip:focus {
	outline: none;
	border-color: var(--color-primary);
	box-shadow: 0 0 0 3px rgb(0 102 204 / 15%);
}

.search-refinement-submit {
	padding: var(--space-sm) var(--space-md);
	font-size: var(--font-size-small);
}

/* Radius Slider Toggle */
.search-refinement-radius {
	flex: 0 0 auto;
}

.radius-slider-toggle {
	display: inline-flex;
	background-color: var(--color-bg-secondary);
	border-radius: var(--radius-card);
	padding: 4px;
	gap: 2px;
}

.radius-option {
	position: relative;
	cursor: pointer;
}

.radius-option-input {
	position: absolute;
	opacity: 0;
	width: 0;
	height: 0;
}

.radius-option-label {
	display: block;
	padding: var(--space-xs) var(--space-sm);
	border-radius: calc(var(--radius-card) - 2px);
	font-size: var(--font-size-small);
	font-weight: 500;
	transition: background-color 0.2s ease, color 0.2s ease;
	white-space: nowrap;
}

.radius-option:hover .radius-option-label {
	color: var(--color-text-primary);
}

.radius-option.is-active .radius-option-label,
.radius-option-input:checked + .radius-option-label {
	background-color: var(--color-white);
	color: var(--color-primary);
	box-shadow: var(--shadow-sm);
}

.radius-option-input:focus-visible + .radius-option-label {
	outline: 2px solid var(--color-primary);
	outline-offset: 2px;
}

.search-refinement-specialties {
	flex: 1 1 auto;
}

/* Results count row - separate row below the filter fields */
.results-count-row {
	display: flex;
	align-items: center;
	gap: var(--space-xs);
	margin-block-start: var(--space-md);
}

#results-count-number {
	font-weight: 700;
	color: var(--color-primary);
	font-size: var(--font-size-lead);
}

/* Tablet refinement layout */
@media (width <= 991px) {
	.search-refinement-form {
		flex-direction: column;
		gap: var(--space-md);
		align-items: stretch;
	}

	.search-refinement-location {
		width: 100%;
	}

	.search-refinement-radius {
		width: 100%;
	}

	.radius-slider-toggle {
		width: 100%;
		justify-content: center;
	}

	.search-refinement-specialties {
		width: 100%;
	}
}

/* Mobile refinement layout */
@media (width <= 767px) {
	.search-refinement-header {
		padding: var(--space-md);
	}

	.search-refinement-header .specialty-pill-list {
		gap: var(--space-xs);
	}

	.radius-slider-toggle {
		flex-wrap: wrap;
	}

	.radius-option {
		flex: 1 1 auto;
		text-align: center;
	}
}

/* ==========================================================================
   Map Column
   ========================================================================== */

.map-column {
	position: relative;
}

.doctor-map {
	height: 600px;
	min-height: 500px;
	border-radius: var(--radius-card);
	overflow: hidden;
	box-shadow: var(--shadow-md);
}

.map-placeholder {
	display: flex;
	align-items: center;
	justify-content: center;
	height: 100%;
	background-color: var(--color-bg-secondary);
	color: var(--color-text-muted);
	text-align: center;
	padding: var(--space-lg);
}

/* Map Markers (background-image set dynamically via JS for theme color) */
.doctor-marker {
	width: 30px;
	height: 30px;
	background-size: cover;
	cursor: pointer;
}

.search-marker {
	width: 20px;
	height: 20px;
	background-size: cover;
}

.map-loading-overlay {
	position: absolute;
	inset: 0;
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	background-color: rgb(255 255 255 / 90%);
	border-radius: var(--radius-card);
	z-index: 10;
}

.map-loading-overlay .spinner {
	width: 48px;
	height: 48px;
	border: 4px solid var(--color-border);
	border-top-color: var(--color-primary);
	border-radius: 50%;
	animation: spinner 0.8s linear infinite;
}

.map-loading-overlay p {
	margin-block-start: var(--space-md);
}

@keyframes spinner {
	to {
		transform: rotate(360deg);
	}
}

/* Mobile: Reduce map height */
@media (width <= 991px) {
	.doctor-map {
		height: 400px;
		min-height: 300px;
	}
}

/* ==========================================================================
   Results Column
   ========================================================================== */

.results-column {
	display: flex;
	flex-direction: column;
	max-height: 600px;
	overflow-y: auto;
	border-radius: var(--radius-card);
	background-color: var(--color-white);
	box-shadow: var(--shadow-sm);
}

.results-header {
	grid-column: 1 / -1;
	display: flex;
	justify-content: space-between;
	align-items: center;
	padding-block-end: var(--space-md);
}

.results-title {
	font-size: var(--font-size-h4);
	margin: 0;
}

/* ==========================================================================
   Doctor Listings
   ========================================================================== */

.doctor-listings {
	flex: 1;
	overflow-y: auto;
	position: relative;
	min-height: 400px;
}

.no-results-message {
	padding: var(--space-xl);
	text-align: center;
}

.doctor-list {
	list-style: none;
	padding: 0;
	margin: 0;
}

.results-loading-overlay {
	position: absolute;
	inset: 0;
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	background-color: rgb(255 255 255 / 95%);
	z-index: 10;
}

.results-loading-overlay .spinner {
	width: 48px;
	height: 48px;
	border: 4px solid var(--color-border);
	border-top-color: var(--color-primary);
	border-radius: 50%;
	animation: spinner 0.8s linear infinite;
}

.results-loading-overlay p {
	margin-block-start: var(--space-md);
}

/* ==========================================================================
   Doctor Card
   ========================================================================== */

.doctor-card {
	position: relative;
	padding: var(--space-lg);
	background-color: var(--color-bg);
	border-block-end: 1px solid var(--color-border);
	transition: background-color 0.2s ease;
	border-radius: var(--radius-card);
}

.doctor-card:hover {
	background-color: var(--color-bg);
}

.doctor-card:last-child {
	border-block-end: none;
}

/* Distance Badge */
.doctor-card__distance-badge {
	position: absolute;
	top: var(--space-md);
	right: var(--space-md);
	display: flex;
	flex-direction: column;
	align-items: center;
	padding: var(--space-xs) var(--space-sm);
	background-color: var(--color-primary);
	color: var(--color-white);
	border-radius: var(--radius-full);
	font-weight: 700;
	line-height: 1.2;
}

.distance-number {
	font-size: var(--font-size-lead);
}

.distance-unit {
	font-size: var(--font-size-small);
	text-transform: uppercase;
	opacity: 0.9;
}

/* Doctor Header */
.doctor-card__header {
	margin-block-end: var(--space-md);
	padding-inline-end: var(--space-2xl); /* Space for distance badge */
}

.doctor-card__name {
	font-size: var(--font-size-h6);
	margin-block-end: var(--space-xs);
}

.doctor-card__credentials {
	font-weight: 400;
	color: var(--color-text-secondary);
}

/* Specialties - hidden per design */
.doctor-card__specialties {
	display: none;
}

.specialty-badge {
	display: inline-block;
	padding: var(--space-2xs) var(--space-sm);
	background-color: var(--color-bg-secondary);
	color: var(--color-primary);
	font-size: var(--font-size-small);
	font-weight: 600;
	border-radius: var(--radius-full);
}

/* Subspecialties */
.doctor-card__subspecialties {
	margin-block-end: var(--space-sm);
}

/* Location Info */
.doctor-card__location {
	margin-block-end: var(--space-md);
	padding: var(--space-md);
	background-color: var(--color-white);
	border-radius: var(--radius-card);
}

.location-name {
	font-weight: 700;
	margin-block-end: var(--space-xs);
	font-size: var(--font-size-body);
}

.location-link--primary {
	background: none;
	border: none;
	padding: 0;
	font: inherit;
	font-weight: 700;
	color: inherit;
	cursor: pointer;
	text-align: left;
}

.location-link--primary:hover {
	color: var(--color-primary);
	text-decoration: underline;
}

.location-link--primary:focus-visible {
	outline: 2px solid var(--color-primary);
	outline-offset: 2px;
}

.location-address {
	font-style: normal;
}

.address-line:last-child {
	margin-bottom: 0;
}

.location-phone {
	margin-block-start: var(--space-sm);
}

.phone-link {
	display: inline-flex;
	align-items: center;
	gap: var(--space-xs);
	color: var(--color-primary);
	text-decoration: none;
	font-weight: 600;
	transition: color 0.2s ease;
}

.phone-link:hover {
	color: var(--color-primary-dark);
}

/* Actions */
.doctor-card__actions {
	margin-block-end: var(--space-sm);
}

.doctor-card__actions .btn {
	width: 100%;
}

/* Also Works At Section */
.doctor-card__also-works-at {
	margin-block-start: var(--space-md);
	padding-block-start: var(--space-md);
	border-block-start: 1px solid var(--color-border);
}

.also-works-toggle {
	display: flex;
	align-items: center;
	justify-content: space-between;
	width: 100%;
	padding: var(--space-sm);
	background: none;
	border: none;
	font-weight: 600;
	color: var(--color-primary);
	cursor: pointer;
	transition: color 0.2s ease;
}

.also-works-toggle:hover {
	color: var(--color-primary-dark);
}

.also-works-toggle::after {
	content: '+';
	font-size: var(--font-size-lead);
	font-weight: 700;
	transition: transform 0.2s ease;
}

.also-works-toggle[aria-expanded="true"]::after {
	transform: rotate(45deg);
}

.also-works-content {
	padding: var(--space-sm) var(--space-2xs);
}

.other-locations-list {
	list-style: none;
	padding: 0;
	margin: 0;
}

.other-location-item {
	margin-block-end: var(--space-md);
  	padding: var(--space-md);
	background-color: var(--color-white);
	border-radius: var(--radius-card);
}

.other-location-item:last-child {
	margin-block-end: 0;
}

.location-link {
	background: none;
	border: none;
	padding: 0;
	font: inherit;
	display: flex;
	flex-direction: column;
	align-items: flex-start;
	gap: 0;
	width: 100%;
	text-align: left;
	color: inherit;
	cursor: pointer;
	font-size: var(--font-size-body);
	line-height: 1.2em;
}

.location-link:hover .other-location-name {
	text-decoration: underline;
	color: var(--color-primary);
}

.other-location-address {
	font-style: normal;
}

/* ==========================================================================
   Results Footer
   ========================================================================== */

.results-footer {
	padding: var(--space-md);
	border-block-start: 1px solid var(--color-border);
	text-align: center;
}

.results-capped-message {
	margin: 0;
	font-size: var(--font-size-small);
}

/* ==========================================================================
   Results Disclaimer
   ========================================================================== */

/* Hidden initially - shown via JS after search */
.results-disclaimer {
	display: none;
	margin-block-end: var(--space-2xl);
	padding: var(--space-lg);
	background-color: var(--color-bg-secondary);
	border-radius: var(--radius-card);
	text-align: center;
}

/* Show when search has been performed */
.results-disclaimer.is-active {
	display: block;
}

.results-disclaimer p {
	margin: 0;
	font-size: var(--font-size-small);
}

/* ==========================================================================
   Help Button Trigger (in refinement header)
   ========================================================================== */

.search-refinement-help {
	flex-shrink: 0;
	margin-inline-start: auto;
}

.help-modal-trigger {
	display: inline-flex;
	align-items: center;
	gap: var(--space-sm);
	padding: var(--space-sm) var(--space-md);
	background: var(--btn-primary-bg);
	color: var(--btn-primary-text-color);
	border-color: var(--btn-primary-border-color);
	border-width: var(--btn-primary-border-width);
	border-style: var(--btn-primary-border-style);
	border-radius: var(--radius-card);
	font-size: var(--font-size-small);
	font-weight: var(--btn-font-weight, 600);
	font-family: inherit;
	cursor: pointer;
	transition: background-color 0.2s ease, color 0.2s ease, border-color 0.2s ease;
	white-space: nowrap;
	text-decoration: none;
}

.help-modal-trigger:hover {
	background: var(--btn-primary-hover-bg);
	color: var(--btn-primary-hover-text-color);
	border-color: var(--btn-primary-hover-border-color);
}

.help-modal-trigger:focus-visible {
	outline: 2px solid var(--btn-primary-bg);
	outline-offset: 2px;
}

.help-modal-trigger-icon {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 24px;
	height: 24px;
	background-color: rgb(255 255 255 / 20%);
	border: 2px solid var(--color-white);
	border-radius: 50%;
	font-size: var(--font-size-small);
	font-weight: 700;
	line-height: 1;
}

.help-modal-trigger:hover .help-modal-trigger-icon {
	color: var(--color-white);
	background: var(--btn-primary-bg);

}

/* Tablet: Stack help button below pills */
@media (width <= 991px) {
	.search-refinement-help {
		width: 100%;
		margin-inline-start: 0;
		margin-block-start: var(--space-md);
	}

	.help-modal-trigger {
		width: 100%;
		justify-content: center;
	}
}

/* ==========================================================================
   Help Modal
   ========================================================================== */

.help-modal {
	position: fixed;
	inset: 0;
	z-index: 9999;
	display: flex;
	align-items: center;
	justify-content: center;
	padding: var(--space-lg);
}

.help-modal-backdrop {
	position: absolute;
	inset: 0;
	background-color: rgb(0 0 0 / 60%);
}

.help-modal-container {
	position: relative;
	width: 100%;
	max-width: 600px;
	max-height: 90vh;
	overflow: hidden;
	border-radius: var(--radius-card);
	background-color: var(--color-white);
	box-shadow: var(--shadow-lg);
}

/* Only animate when modal is intentionally opened */
.help-modal.is-open .help-modal-backdrop {
	animation: fade-in 0.2s ease;
}

.help-modal.is-open .help-modal-container {
	animation: slide-in 0.3s ease;
}

.help-modal-content {
	max-height: 90vh;
	overflow-y: auto;
	padding: var(--space-xl);
}

.help-modal-close {
	position: absolute;
	top: var(--space-md);
	right: var(--space-md);
	display: flex;
	align-items: center;
	justify-content: center;
	width: 36px;
	height: 36px;
	padding: 0;
	background: var(--btn-primary-bg);
	color: var(--btn-primary-text-color);
	border-color: var(--btn-primary-border-color);
	border-width: var(--btn-primary-border-width);
	border-style: var(--btn-primary-border-style);
	border-radius: 50%;
	font-size: 24px;
	font-weight: var(--btn-font-weight, 600);
	line-height: 1;
	cursor: pointer;
	transition: background-color 0.2s ease, color 0.2s ease, border-color 0.2s ease;
}

.help-modal-close:hover {
	background: var(--btn-primary-hover-bg);
	color: var(--btn-primary-hover-text-color);
	border-color: var(--btn-primary-hover-border-color);
}

.help-modal-close:focus-visible {
	outline: 2px solid var(--btn-primary-bg);
	outline-offset: 2px;
}

.help-modal-title {
	margin: 0 0 var(--space-sm) 0;
	padding-inline-end: var(--space-xl);
	font-size: var(--font-size-h3);
	font-weight: 600;
}

.help-modal-description {
	margin: 0 0 var(--space-md) 0;
	color: var(--color-text-primary);
}

.help-modal-form .gform_wrapper {
	margin: 0;
}

.help-form-placeholder {
	padding: var(--space-lg);
	background-color: var(--color-bg-secondary);
	border: 2px dashed var(--color-border);
	border-radius: var(--radius-card);
	text-align: center;
}

/* Modal animations */
@keyframes fade-in {
	from {
		opacity: 0;
	}

	to {
		opacity: 1;
	}
}

@keyframes slide-in {
	from {
		opacity: 0;
		transform: translateY(-20px) scale(0.95);
	}

	to {
		opacity: 1;
		transform: translateY(0) scale(1);
	}
}

/* Prevent body scroll when modal is open */
body.help-modal-open {
	overflow: hidden;
}

/* Mobile modal adjustments */
@media (width <= 767px) {
	.help-modal {
		padding: var(--space-md);
	}

	.help-modal-content {
		padding: var(--space-lg);
	}

	.help-modal-title {
		font-size: var(--font-size-h4);
	}
}

/* ==========================================================================
   Location Info Partial
   ========================================================================== */

.location-info {
	padding: var(--space-md);
}

.location-info__name {
	font-weight: 700;
	margin-block-end: var(--space-xs);
}

.location-info__address {
	font-style: normal;
	margin-block-end: var(--space-sm);
}

.location-info__phone {
	margin-block-start: var(--space-sm);
}

.location-info__phone .phone-link {
	display: inline-flex;
	align-items: center;
	gap: var(--space-xs);
	color: var(--color-primary);
	text-decoration: none;
	font-weight: 600;
}

.phone-icon {
	font-size: var(--font-size-lead);
}

/* ==========================================================================
   MapBox Popup Customization
   ========================================================================== */

.mapboxgl-popup-content {
	padding: 0;
	border-radius: var(--radius-card);
	box-shadow: var(--shadow-lg);
}

.mapboxgl-popup-close-button {
	font-size: var(--font-size-lead);
	padding: var(--space-sm);
}

.mapboxgl-popup-close-button:hover {
	background-color: var(--color-bg-secondary);
	color: var(--color-text-primary);
}

/* Doctor Popup Content */
.doctor-popup {
	min-width: 250px;
	padding: var(--space-md);
}

.doctor-popup__distance {
	margin-block-end: var(--space-sm);
}

.doctor-popup__distance-badge {
	display: inline-block;
	padding: var(--space-2xs) var(--space-sm);
	background-color: var(--color-primary);
	color: var(--color-white);
	border-radius: var(--radius-full);
	font-size: var(--font-size-small);
	font-weight: 700;
	text-transform: uppercase;
}

.doctor-popup__name {
	margin: 0 0 var(--space-sm) 0;
	font-size: var(--font-size-h6);
}

.doctor-popup__credentials {
	font-weight: 400;
	color: var(--color-text-primary);
}

.doctor-popup__location-name {
	margin: 0 0 var(--space-sm) 0;
	font-size: var(--font-size-body);
}

.doctor-popup__address {
	margin-block-end: var(--space-2xs);
	font-style: normal;
	color: var(--color-text-primary);
}

.doctor-popup__phone {
	margin-block-end: var(--space-sm);
}

.doctor-popup__phone-link {
	display: inline-flex;
	align-items: center;
	gap: var(--space-xs);
	color: var(--color-primary);
	text-decoration: none;
	font-weight: 600;
}

.doctor-popup__phone-link:hover {
	color: var(--color-primary-dark);
}

.doctor-popup__website {
	margin-block-start: var(--space-xs);
}

.doctor-popup__website-link {
	display: inline-flex;
	align-items: center;
	gap: var(--space-xs);
	color: var(--color-primary);
	text-decoration: underline;
	font-weight: 600;
}

.doctor-popup__website-link:hover {
	color: var(--color-primary-dark);
	text-decoration: none;
}

.doctor-popup__website-link:focus-visible {
	outline: 2px solid var(--color-primary);
	outline-offset: 2px;
}

/* ==========================================================================
   Responsive Utilities
   ========================================================================== */

/* Tablet */
@media (width <= 991px) {
	.find-a-doctor-archive {
		padding-block: var(--space-xl);
	}

	.archive-header {
		margin-block-end: var(--space-lg);
	}

	.search-form-section {
		margin-block-end: var(--space-xl);
		padding: var(--space-md);
	}

	.results-column {
		max-height: 100%;
		min-height: 400px;
	}

	.doctor-card {
		padding: var(--space-md);
	}
}

/* Mobile */
@media (width <= 767px) {
	.find-a-doctor-container {
		padding-inline: var(--space-sm);
	}

	.search-form-section .gfield_checkbox {
		grid-template-columns: 1fr;
	}

	.results-header {
		flex-direction: column;
		align-items: flex-start;
		gap: var(--space-xs);
	}

	.doctor-card__header {
		padding-inline-end: var(--space-xl);
	}

	.doctor-card__distance-badge {
		width: fit-content;
	}
}

/* ==========================================================================
   Mobile View Toggle
   ========================================================================== */

.mobile-view-toggle {
	display: none; /* Hidden on desktop */
	gap: var(--space-xs);
	margin-block-start: var(--space-md);
	padding: var(--space-2xs);
	border-radius: var(--radius-card);
	border: 1px solid var(--color-border);
}

.mobile-view-toggle__btn {
	display: flex;
	align-items: center;
	justify-content: center;
	gap: var(--space-xs);
	flex: 1;
	padding: var(--space-sm) var(--space-md);
	background: none;
	border: none;
	border-radius: var(--radius-button);
	font-family: inherit;
	font-size: var(--font-size-small);
	font-weight: 600;
	cursor: pointer;
	transition: all 0.2s ease;
}

.mobile-view-toggle__btn:hover {
	color: var(--color-text-primary);
}

.mobile-view-toggle__btn.is-active {
	background-color: var(--color-white);
	color: var(--color-primary);
	box-shadow: var(--shadow-sm);
}

.mobile-view-toggle__icon {
	flex-shrink: 0;
}

/* Show toggle on mobile only */
@media (width <= 991px) {
	.mobile-view-toggle {
		display: flex;
	}

	/* Mobile view states - controlled by JS */
	.map-results-wrapper.mobile-view-list .map-column {
		display: none;
	}

	.map-results-wrapper.mobile-view-list .results-column {
		display: flex;
	}

	.map-results-wrapper.mobile-view-map .results-column {
		display: none;
	}

	.map-results-wrapper.mobile-view-map .map-column {
		display: block;
	}

	/* Make map full height when in map view */
	.map-results-wrapper.mobile-view-map .doctor-map {
		height: calc(100vh - 350px);
		min-height: 400px;
	}
}

/* ==========================================================================
   Form Collapse Behavior
   ========================================================================== */

/* Collapsed state for search form after initial search */
.search-form-section.is-collapsed {
	display: none;
}

/* Description toggle between form and results views */
.archive-description--form {
	display: block;
}

.archive-description--results {
	display: none;
}

/* When results are showing */
.find-a-doctor-archive.has-results .archive-description--form {
	display: none;
}

.find-a-doctor-archive.has-results .archive-description--results {
	display: block;
}

/* ==========================================================================
   Print Styles
   ========================================================================== */

@media print {
	.map-column,
	.search-form-section,
	.help-modal,
	.help-modal-trigger,
	.doctor-card__actions,
	.also-works-toggle {
		display: none;
	}

	.map-results-wrapper {
		grid-template-columns: 1fr;
	}

	.doctor-card {
		page-break-inside: avoid;
	}
}
