/**
 * Clinic Location Widget Styles
 * 
 * Comprehensive clinic location display with header, repeatable cards, map, and contact info
 * Supports dark theme, map toggle, and "Getting Here" section
 * Uses logical CSS properties for full RTL support
 * 
 * @package DrYazdani
 * @since 2.0.0
 */

/* Widget Container */
.dryazdani-clinic-location {
	padding: var(--spacing-3xl, 4rem) 0;
}

/* Container - Max Width & Centering */
.dryazdani-clinic-location__container {
	max-width: 1400px;
	margin-inline: auto;
	padding-inline: var(--spacing-md, 1.5rem);
}

@media (min-width: 1024px) {
	.dryazdani-clinic-location__container {
		padding-inline: var(--spacing-2xl, 3rem);
	}
}

/* Header Section */
.dryazdani-clinic-location__header {
	text-align: center;
	margin-block-end: var(--spacing-3xl, 4rem);
}

/* Badge */
.dryazdani-clinic-location__badge {
	color: var(--color-primary, #D4AF37);
	font-size: var(--text-xs, 0.75rem);
	text-transform: uppercase;
	letter-spacing: 0.3em;
	margin-block-end: var(--spacing-md, 1.5rem);
}

/* Section Title */
.dryazdani-clinic-location__title {
	font-family: var(--font-heading, 'Playfair Display', serif);
	font-size: var(--text-4xl, 2.25rem);
	color: var(--color-text-primary, #2C2C2C);
	margin-block-end: var(--spacing-lg, 2rem);
	line-height: 1.2;
}

@media (min-width: 768px) {
	.dryazdani-clinic-location__title {
		font-size: 3.75rem; /* 60px */
	}
}

/* Description */
.dryazdani-clinic-location__description {
	font-size: var(--text-xl, 1.25rem);
	color: var(--color-text-body, #717171);
	line-height: 1.6;
	max-width: 48rem;
	margin-inline: auto;
}

/* Location Cards Container */
.dryazdani-clinic-location__cards {
	display: flex;
	flex-direction: column;
	gap: var(--spacing-3xl, 6rem);
}

/* Individual Location Card */
.dryazdani-clinic-location__card {
	width: 100%;
}

/* Card Grid Layout */
.dryazdani-clinic-location__card-grid {
	display: grid;
	grid-template-columns: 1fr;
	gap: var(--spacing-2xl, 4rem);
	align-items: start;
}

@media (min-width: 1024px) {
	.dryazdani-clinic-location__card-grid {
		grid-template-columns: 1fr 1fr;
		gap: var(--spacing-3xl, 4rem);
	}
}

/* Map Column */
.dryazdani-clinic-location__map-column {
	display: flex;
	flex-direction: column;
	gap: var(--spacing-md, 1.5rem);
}

/* Map Section */
.dryazdani-clinic-location__map {
	position: relative;
	width: 100%;
	aspect-ratio: 4 / 3;
	overflow: hidden;
	border-radius: var(--radius-small, 4px);
	background-color: var(--color-background-alt, #FAFAFA);
}

.dryazdani-clinic-location__map-iframe {
	position: absolute;
	inset-block-start: 0;
	inset-inline-start: 0;
	width: 100%;
	height: 100%;
	border: none;
}

/* Getting Here Section */
.dryazdani-clinic-location__getting-here {
	background-color: var(--color-background-alt, #FAFAFA);
	padding: var(--spacing-lg, 2rem);
}

.dryazdani-clinic-location__getting-here-title {
	font-family: var(--font-heading, 'Playfair Display', serif);
	font-size: var(--text-xl, 1.25rem);
	color: var(--color-text-primary, #2C2C2C);
	margin-block-end: var(--spacing-lg, 1.5rem);
}

.dryazdani-clinic-location__transport-options {
	display: flex;
	flex-direction: column;
	gap: var(--spacing-xl, 2rem);
}

.dryazdani-clinic-location__transport-item {
	display: flex;
	align-items: flex-start;
	gap: var(--spacing-sm, 1rem);
	text-align: start;
}

/* Info Column */
.dryazdani-clinic-location__info-column {
	display: flex;
	flex-direction: column;
	gap: var(--spacing-lg, 2rem);
}

/* Info Box */
.dryazdani-clinic-location__info {
	background-color: var(--color-background, #FFFFFF);
	padding: var(--spacing-xl, 2.5rem);
}

/* Dark Theme Info Box */
.dryazdani-clinic-location__info--dark {
	background-color: var(--color-dark, #2C2C2C);
	color: var(--dryazdani-text-inverse, #FFFFFF);
}

.dryazdani-clinic-location__info--dark .dryazdani-clinic-location__info-title {
	color: var(--dryazdani-text-inverse, #FFFFFF);
}

.dryazdani-clinic-location__info--dark .dryazdani-clinic-location__label {
	color: var(--dryazdani-text-inverse, #FFFFFF);
}

.dryazdani-clinic-location__info--dark .dryazdani-clinic-location__detail {
	color: rgba(255, 255, 255, 0.8);
}

.dryazdani-clinic-location__info--dark .dryazdani-clinic-location__icon {
	color: var(--color-primary, #D4AF37);
}

/* Info Box Title */
.dryazdani-clinic-location__info-title {
	font-family: var(--font-heading, 'Playfair Display', serif);
	font-size: var(--text-3xl, 1.875rem);
	color: var(--color-text-primary, #2C2C2C);
	margin-block-end: var(--spacing-lg, 2rem);
}

/* Info Items */
.dryazdani-clinic-location__info-items {
	display: flex;
	flex-direction: column;
	gap: var(--spacing-xl, 2rem);
}

.dryazdani-clinic-location__detail-item {
	display: flex;
	align-items: flex-start;
	gap: var(--spacing-sm, 1rem);
	text-align: start;
}

.dryazdani-clinic-location__icon {
	width: 24px;
	height: 24px;
	flex-shrink: 0;
	color: var(--color-primary, #D4AF37);
	margin-block-start: 0.12rem;
	margin-inline-end: 0.35rem;
}

.dryazdani-clinic-location__detail-content {
	flex: 1;
	display: flex;
	flex-direction: column;
	gap: 0.5rem;
}

.dryazdani-clinic-location__label {
	font-size: 1.125rem;
	line-height: 1.5;
	font-weight: 600;
	color: var(--color-text-primary, #2C2C2C);
	margin: 0 0 0.25rem !important;
}

.dryazdani-clinic-location__detail {
	font-size: 1.125rem;
	line-height: 1.6;
	color: var(--color-text-body, #717171);
	margin: 0 0 -0.1rem !important;
}

.dryazdani-clinic-location__getting-here .dryazdani-clinic-location__detail {
    font-size: 1rem;
}

/* Buttons */
.dryazdani-clinic-location__buttons {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: var(--spacing-sm, 1rem);
}

.dryazdani-clinic-location__button {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 0.5rem;
	padding-block: var(--spacing-md, 1rem);
	padding-inline: var(--spacing-md, 1rem);
	font-size: 0.875rem;
	font-weight: 500;
	text-transform: uppercase;
	letter-spacing: 0.1em;
	text-decoration: none;
	text-align: center;
	border: none;
	border-radius: 0;
	cursor: pointer;
	transition: all 0.3s ease-out;
}

.dryazdani-clinic-location__button--primary {
	background-color: var(--color-primary, #D4AF37);
	color: var(--color-text-primary, #2C2C2C);
}

.dryazdani-clinic-location__button--primary:hover {
	background-color: var(--color-primary-dark, #B8941F);
	color: var(--color-text-primary, #2C2C2C);
}

.dryazdani-clinic-location__button--secondary {
	background-color: transparent;
	color: var(--color-text-primary, #2C2C2C);
	border: 2px solid var(--color-text-primary, #2C2C2C);
}

.dryazdani-clinic-location__button--secondary:hover {
	background-color: var(--color-text-primary, #2C2C2C);
	color: var(--color-background, #FFFFFF);
}

.dryazdani-clinic-location__button-icon {
	width: 16px;
	height: 16px;
	flex-shrink: 0;
	transition: color 0.3s ease-out;
}

/* RTL Support - Using logical properties eliminates most RTL-specific overrides */
[dir="rtl"] .dryazdani-clinic-location__detail-item,
[dir="rtl"] .dryazdani-clinic-location__transport-item {
	text-align: start; /* Ensures text aligns to the right in RTL */
}

/* Responsive Design - Mobile First */
@media (max-width: 767px) {
	.dryazdani-clinic-location {
		padding: var(--spacing-2xl, 3rem) 0;
	}
	
	.dryazdani-clinic-location__header {
		margin-block-end: var(--spacing-2xl, 3rem);
	}
	
	.dryazdani-clinic-location__title {
		font-size: var(--text-3xl, 1.875rem);
	}
	
	.dryazdani-clinic-location__description {
		font-size: var(--text-lg, 1.125rem);
	}
	
	.dryazdani-clinic-location__cards {
		gap: var(--spacing-2xl, 3rem);
	}
	
	.dryazdani-clinic-location__card-grid {
		gap: var(--spacing-lg, 2rem);
	}
	
	.dryazdani-clinic-location__info {
		padding: var(--spacing-lg, 1.5rem);
	}
	
	.dryazdani-clinic-location__info-title {
		font-size: var(--text-2xl, 1.5rem);
	}
	
	.dryazdani-clinic-location__getting-here {
		padding: var(--spacing-md, 1.25rem);
	}
	
	.dryazdani-clinic-location__buttons {
		grid-template-columns: 1fr;
	}
	
	.dryazdani-clinic-location__button {
		inline-size: 100%;
	}
}

@media (min-width: 768px) and (max-width: 1023px) {
	.dryazdani-clinic-location__title {
		font-size: 3rem;
	}
	
	.dryazdani-clinic-location__card-grid {
		gap: var(--spacing-xl, 2.5rem);
	}
}

/* Accessibility */
@media (prefers-reduced-motion: reduce) {
	.dryazdani-clinic-location__button {
		transition: none;
	}
}

/* Focus States - Accessibility */
.dryazdani-clinic-location__button:focus-visible {
	outline: 2px solid var(--color-primary, #D4AF37);
	outline-offset: 2px;
}

/* High Contrast Mode Support */
@media (prefers-contrast: high) {
	.dryazdani-clinic-location__button:focus-visible {
		outline-width: 3px;
	}
	
	.dryazdani-clinic-location__button--secondary {
		border-width: 3px;
	}
}
