/**
 * Clinic Gallery Widget Styles
 *
 * "Life at the Clinic" section with image gallery and video placeholders
 *
 * @package DrYazdani
 * @since 1.0.0
 */

/* ==========================================================================
   Main Container
   ========================================================================== */

.dryazdani-clinic-gallery {
	background-color: var(--dryazdani-bg-light);
	padding-block: var(--dryazdani-space-24);
	padding-inline: var(--dryazdani-space-6);
}

/* Container styles inherited from .dryazdani-container */

/* ==========================================================================
   Header Section
   ========================================================================== */

.dryazdani-clinic-gallery__header {
	text-align: center;
	margin-block-end: var(--dryazdani-space-16);
}

.dryazdani-clinic-gallery__badge {
	display: inline-block;
	margin-block-end: var(--dryazdani-space-6);
	color: var(--dryazdani-primary);
	font-family: var(--dryazdani-font-body);
	font-size: var(--dryazdani-text-xs);
	font-weight: var(--dryazdani-font-medium);
	letter-spacing: var(--dryazdani-tracking-ultra-wide);
	text-transform: uppercase;
}

.dryazdani-clinic-gallery__heading {
	font-family: var(--dryazdani-font-heading);
	font-size: clamp(var(--dryazdani-text-4xl), 5vw, var(--dryazdani-text-6xl));
	font-weight: var(--dryazdani-font-normal);
	color: var(--dryazdani-secondary);
	line-height: var(--dryazdani-leading-tight);
	margin: 0 0 var(--dryazdani-space-8) 0;
}

.dryazdani-clinic-gallery__description {
	font-family: var(--dryazdani-font-body);
	font-size: var(--dryazdani-text-xl);
	color: var(--dryazdani-text-body);
	max-width: 768px;
	margin-inline: auto;
	line-height: var(--dryazdani-leading-normal);
}

/* ==========================================================================
   Images Grid (3 columns)
   ========================================================================== */

.dryazdani-clinic-gallery__images-grid {
	display: grid;
	grid-template-columns: 1fr;
	gap: var(--dryazdani-space-8);
	margin-block-end: var(--dryazdani-space-12);
}

@media (min-width: 768px) {
	.dryazdani-clinic-gallery__images-grid {
		grid-template-columns: repeat(3, minmax(0, 1fr));
	}
}

.dryazdani-clinic-gallery__image-item {
	display: flex;
	flex-direction: column;
	gap: var(--dryazdani-space-4);
}

.dryazdani-clinic-gallery__image-wrapper {
	position: relative;
	aspect-ratio: 4 / 3;
	overflow: hidden;
	background-color: var(--dryazdani-secondary);
}

.dryazdani-clinic-gallery__image {
	width: 100%;
	height: 100% !important;
	object-fit: cover;
	display: block;
}

.dryazdani-clinic-gallery__caption {
	font-family: var(--dryazdani-font-body);
	font-size: var(--dryazdani-text-sm);
	color: var(--dryazdani-text-body);
	text-align: center;
	line-height: var(--dryazdani-leading-normal);
	margin: 0 !important;
}

/* ==========================================================================
   Videos Grid (2 columns)
   ========================================================================== */

.dryazdani-clinic-gallery__videos-grid {
	display: grid;
	grid-template-columns: 1fr;
	gap: var(--dryazdani-space-8);
}

@media (min-width: 768px) {
	.dryazdani-clinic-gallery__videos-grid {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}
}

.dryazdani-clinic-gallery__video-item {
	display: flex;
	flex-direction: column;
	gap: var(--dryazdani-space-4);
}

.dryazdani-clinic-gallery__video-wrapper {
	position: relative;
	aspect-ratio: 16 / 9;
	overflow: hidden;
	background-color: var(--dryazdani-secondary);
}

.dryazdani-clinic-gallery__video-wrapper[data-video-url] {
	cursor: pointer;
}

.dryazdani-clinic-gallery__video-wrapper[data-video-url]:focus-visible {
	outline: 2px solid var(--dryazdani-primary);
	outline-offset: 4px;
}

.dryazdani-clinic-gallery__video-thumbnail {
	width: 100%;
	height: 100% !important;
	object-fit: cover;
	display: block;
}

/* Play Button */
.dryazdani-clinic-gallery__play-button {
	position: absolute;
	inset: 0;
	display: flex;
	align-items: center;
	justify-content: center;
	background-color: transparent;
	transition: background-color var(--dryazdani-duration-normal) var(--dryazdani-ease-out);
	pointer-events: none;
}

.dryazdani-clinic-gallery__video-wrapper[data-video-url] .dryazdani-clinic-gallery__play-button {
	pointer-events: auto;
	cursor: pointer;
}

.dryazdani-clinic-gallery__play-button--placeholder {
	cursor: default;
}

.dryazdani-clinic-gallery__play-button:hover {
	background-color: rgba(0, 0, 0, 0.2);
}

.dryazdani-clinic-gallery__play-button--placeholder:hover {
	background-color: transparent;
}

.dryazdani-clinic-gallery__play-button svg {
	width: 64px;
	height: 64px;
	color: var(--dryazdani-text-inverse);
	opacity: 0.9;
	filter: drop-shadow(0 4px 8px rgba(0, 0, 0, 0.3));
	transition: all var(--dryazdani-duration-normal) var(--dryazdani-ease-out);
}

.dryazdani-clinic-gallery__play-button:hover svg {
	opacity: 1;
	transform: scale(1.1);
}

.dryazdani-clinic-gallery__play-button--placeholder svg {
	opacity: 0.7;
}

.dryazdani-clinic-gallery__play-button--placeholder:hover svg {
	opacity: 0.7;
	transform: none;
}

.dryazdani-clinic-gallery__video-title {
	font-family: var(--dryazdani-font-body);
	font-size: var(--dryazdani-text-base);
	color: var(--dryazdani-text-primary);
	font-weight: var(--dryazdani-font-medium);
	line-height: var(--dryazdani-leading-normal);
	margin: 0 !important;
}

/* ==========================================================================
   Responsive Breakpoints
   ========================================================================== */

@media (min-width: 768px) {
	.dryazdani-clinic-gallery {
		padding-inline: var(--dryazdani-space-8);
	}
}

@media (min-width: 1024px) {
	.dryazdani-clinic-gallery {
		padding-inline: var(--dryazdani-space-12);
	}
}

/* Mobile adjustments */
@media (max-width: 767px) {
	.dryazdani-clinic-gallery {
		padding-block: var(--dryazdani-space-16);
	}

	.dryazdani-clinic-gallery__heading {
		font-size: var(--dryazdani-text-3xl);
	}

	.dryazdani-clinic-gallery__description {
		font-size: var(--dryazdani-text-base);
	}

	.dryazdani-clinic-gallery__play-button svg {
		width: 48px;
		height: 48px;
	}
}

/* ==========================================================================
   Accessibility
   ========================================================================== */

.dryazdani-clinic-gallery__play-button:focus-visible {
	outline: 2px solid var(--dryazdani-primary);
	outline-offset: -4px;
}

@media (prefers-reduced-motion: reduce) {
	.dryazdani-clinic-gallery__play-button,
	.dryazdani-clinic-gallery__play-button svg {
		transition: none;
	}

	.dryazdani-clinic-gallery__play-button:hover svg {
		transform: none;
	}
}

/* ==========================================================================
   Video Lightbox (same as Video Stories / Signature Procedure)
   ========================================================================== */

.dryazdani-video-lightbox {
	position: fixed;
	inset: 0;
	background-color: rgba(0, 0, 0, 0.95);
	z-index: var(--dryazdani-z-modal);
	display: flex;
	align-items: center;
	justify-content: center;
	padding: var(--dryazdani-space-4);
	animation: dryazdani-fade-in var(--dryazdani-duration-normal) var(--dryazdani-ease-out);
}

.dryazdani-video-lightbox__inner {
	position: relative;
	width: 100%;
	max-width: 1200px;
	aspect-ratio: 16 / 9;
}

.dryazdani-video-lightbox__iframe {
	width: 100%;
	height: 100%;
	border: none;
	border-radius: var(--dryazdani-radius-md);
}

.dryazdani-video-lightbox__close {
	position: absolute;
	top: calc(-1 * var(--dryazdani-space-12));
	inset-inline-end: 0;
	width: 48px;
	height: 48px;
	padding: 0;
	display: flex;
	align-items: center;
	justify-content: center;
	background-color: var(--dryazdani-bg-white);
	color: var(--dryazdani-secondary);
	border: none;
	border-radius: var(--dryazdani-radius-full);
	cursor: pointer;
	transition: all var(--dryazdani-duration-fast) var(--dryazdani-ease-out);
	z-index: 1;
}

.dryazdani-video-lightbox__close:hover {
	background-color: var(--dryazdani-primary);
	color: var(--dryazdani-text-inverse);
	transform: rotate(90deg);
}

.dryazdani-video-lightbox__close:focus-visible {
	outline: 2px solid var(--dryazdani-primary);
	outline-offset: 4px;
}

.dryazdani-video-lightbox__close svg {
	width: 24px;
	height: 24px;
}

body.dryazdani-video-lightbox-open {
	overflow: hidden;
}

@keyframes dryazdani-fade-in {
	from {
		opacity: 0;
	}
	to {
		opacity: 1;
	}
}
