/* ========================================
   Responsive Design - Unified Breakpoint System
   
   Breakpoints: 320px(xs) | 480px(sm) | 768px(md) | 1024px(lg) | 1280px(xl) | 1440px(2xl) | 1920px(3xl) | 2560px(4xl)
   
   Note: Typography uses fluid scaling via clamp() - no media overrides needed
   ======================================== */

/* ========================================
   Extra Large Desktop (1920px+)
   ======================================== */

@media (min-width: 1920px) {
	:root {
		--spacing-4xl: 100px;
	}

	.container {
		max-width: clamp(1200px, 95vw, 1400px);
	}

	.hero {
		min-height: 600px;
	}
}

/* ========================================
   Large Desktop (1440px - 1919px)
   ======================================== */

@media (max-width: 1919px) and (min-width: 1440px) {
	:root {
		--spacing-3xl: 64px;
	}

	.container {
		max-width: clamp(1200px, 95vw, 1320px);
	}
}

/* ========================================
   Desktop (1280px - 1439px)
   ======================================== */

@media (max-width: 1439px) and (min-width: 1280px) {
	:root {
		--spacing-3xl: 56px;
	}

	.container {
		max-width: 100%;
	}
}

/* ========================================
   Tablet Landscape (1024px - 1279px)
   ======================================== */

@media (max-width: 1279px) {
	:root {
		--spacing-2xl: 40px;
		--spacing-3xl: 48px;
	}


	.container {
		padding: 0 clamp(12px, 3vw, 24px);
	}

	.single-layout {
		grid-template-columns: 1fr;
	}

	.archive-layout {
		grid-template-columns: 1fr;
	}

	.archive-filters {
		min-width: 200px;
		flex: 1;
	}

	.hero {
		padding: clamp(20px, 5vw, 48px) clamp(12px, 3vw, 24px);
		min-height: 400px;
	}

	.hero::before {
		background: linear-gradient(to bottom, transparent 20%, rgba(15, 20, 25, 0.9) 70%, var(--color-bg-dark));
	}

	.hero__content {
		flex-direction: column;
		gap: var(--spacing-lg);
	}

	.hero__poster {
		width: clamp(120px, 20vw, 150px);
		height: auto;
		aspect-ratio: 2/3;
	}

	.hero--archive {
		min-height: 160px;
	}

	.hero--single .hero__info {
		text-align: left;
	}

	.hero--home {
		min-height: 300px;
		padding: var(--spacing-lg) clamp(12px, 3vw, 24px);
	}

	.hero--home .hero__content {
		flex-direction: row;
		gap: var(--spacing-sm);
		justify-content: flex-start;
	}

	.hero--home .hero__inner {
		flex-basis: auto;
		width: 100%;
	}

	.hero--home .hero__search {
		width: 100%;
		max-width: 100%;
		margin-top: var(--spacing-sm);
	}

	.theme-search-form {
		width: 100%;
		max-width: none;
	}

	.theme-search-form input[type="search"] {
		width: 100%;
		height: 40px;
		padding: 0 12px;
	}

	.theme-search-form .btn--search {
		height: 40px;
		padding: 0 12px;
	}

	.hero__search {
		max-width: 100%;
		width: 100%;
		flex-wrap: wrap;
	}

	.hero__search-input {
		min-width: 150px;
	}

	.movies-grid,
	.tv-grid {
		grid-template-columns: repeat(4, 1fr);
		gap: var(--spacing-md);
	}

	.actors-grid,
	.directors-grid,
	.persons-grid {
		grid-template-columns: repeat(4, 1fr);
	}

	.cast-grid,
	.directors-list {
		grid-template-columns: repeat(4, 1fr);
	}

	.section {
		padding: var(--spacing-xl) 0;
	}

	.section__header {
		margin-bottom: var(--spacing-lg);
	}

	.footer-columns {
		grid-template-columns: 1fr;
		gap: var(--spacing-lg);
	}

	.footer-bottom {
		flex-direction: column;
		text-align: center;
	}

	.pagination {
		flex-wrap: wrap;
	}

	.details-grid {
		grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
		gap: var(--spacing-md);
	}

	.detail-item {
		padding: var(--spacing-md);
	}
}

/* ========================================
   Tablet (768px - 1023px)
   ======================================== */

@media (max-width: 1023px) {
	.filters-duo-container {
		gap: var(--spacing-lg);
	}

	.filters-duo-grid {
		grid-template-columns: repeat(auto-fill, minmax(90px, 1fr));
		gap: var(--spacing-xxs);
	}

	.filter-badge {
		padding: var(--spacing-xxs) var(--spacing-xs);
		font-size: 9px;
	}

	.hero__content {
		flex-direction: column;
		align-items: center;
		text-align: center;
		gap: var(--spacing-md);
		padding: var(--spacing-md) 0;
	}

	.hero__poster {
		width: clamp(100px, 18vw, 120px);
		height: auto;
		aspect-ratio: 2/3;
		margin: 0 auto;
		box-shadow: var(--shadow-md);
	}

	.hero__title {
		font-size: calc(var(--font-size-h1) * 0.65);
		line-height: 1.08;
		margin-top: var(--spacing-sm);
	}

	.hero__subtitle {
		font-size: var(--font-size-small);
		margin-bottom: var(--spacing-sm);
	}

	.hero__info {
		width: 100%;
		padding: 0 var(--spacing-sm);
	}

	.hero__meta {
		display: flex;
		flex-wrap: wrap;
		justify-content: center;
		gap: 8px;
	}

	.hero__rating {
		margin-top: 8px;
		display: flex;
		align-items: center;
		justify-content: center;
		gap: 8px;
	}

	.footer-columns {
		grid-template-columns: 1fr;
		gap: var(--spacing-md);
	}

	.footer-column {
		width: 100%;
	}

	.footer-bottom {
		flex-direction: column;
		text-align: center;
		gap: var(--spacing-sm);
	}

	.footer-bottom__links {
		flex-direction: column;
		align-items: center;
		width: 100%;
	}

	.mmp-seasons-grid,
	.mmp-episodes-list {
		grid-template-columns: repeat(4, 1fr);
	}

	.cast-grid,
	.directors-list {
		grid-template-columns: repeat(5, 1fr);
	}

	.cast-grid .people-show-more-wrapper,
	.cast-grid .people-show-less-wrapper,
	.directors-list .people-show-more-wrapper,
	.directors-list .people-show-less-wrapper {
		margin: var(--spacing-md) 0;
	}
}
/* ========================================
   Large Phones (480px - 767px)
   ======================================== */

@media (max-width: 767px) {
	:root {
		--spacing-md: 12px;
		--spacing-lg: 16px;
		--spacing-xl: 24px;
		--spacing-2xl: 32px;
	}

	.container {
		padding: 0 clamp(8px, 2.5vw, 16px);
	}

	.site-header__inner {
		gap: var(--spacing-md);
		padding: 8px clamp(8px, 2.5vw, 16px);
		justify-content: flex-start;
		width: 100%; max-width: none;
	}

	.site-navigation { flex-wrap: wrap; }

	/* Ensure ad containers collapse on small screens when empty (duplicate to avoid overrides) */
	.ad-container:empty,
	.mmp-ad-container:empty,
	.mmp-banner-ad-container:empty,
	.mmp-native-ad-container:empty,
	.mmp-video-ad-container:empty {
		display: none !important;
		margin: 0 !important;
		padding: 0 !important;
		min-height: 0 !important;
		height: 0 !important;
	}

	/* Ensure ad containers and reserved spaces collapse on small screens when empty */
	.mmp-ad-space-reserved:not([style*="height"]),
	.mmp-ad-space-reserved[style*="min-height:auto"] {
		max-height: 0 !important;
		margin: 0 !important;
		padding: 0 !important;
		overflow: hidden !important;
		visibility: hidden !important;
		min-height: 0 !important;
		height: 0 !important;
	}

/* Reduce main menu link/button size on phones */
@media (max-width: 600px) {
	.menu { gap: calc(var(--spacing-sm) / 1.2); }
	.menu a {
		font-size: 14px; /* slightly smaller text */
		padding: 6px 10px; /* reduce touch area horizontally */
	}
	.menu-btn {
		font-size: 13px;
		padding: 6px 10px;
	}
	.site-navigation { padding-left: 6px; padding-right: 6px; }
}

@media (max-width: 400px) {
	.menu { gap: 0.4rem; }
	.menu a {
		font-size: 13px;
		padding: 5px 8px;
	}
	.menu-btn {
		font-size: 12px;
		padding: 4px 8px;
	}
}

	@supports (selector(:has(*))) {
		.ad-container:not(:has(iframe,ins,ins.adsbygoogle,script,img)),
		.mmp-ad-container:not(:has(iframe,ins,ins.adsbygoogle,script,img)),
		.mmp-banner-ad-container:not(:has(iframe,ins,ins.adsbygoogle,script,img)),
		.mmp-native-ad-container:not(:has(iframe,ins,ins.adsbygoogle,script,img)),
		.mmp-video-ad-container:not(:has(iframe,ins,ins.adsbygoogle,script,img)),
		.mmp-ad-space-reserved:not(:has(ins.adsbygoogle[data-ad-client])) {
			display: none !important;
			max-height: 0 !important;
			margin: 0 !important;
			padding: 0 !important;
			min-height: 0 !important;
			height: 0 !important;
			overflow: hidden !important;
			visibility: hidden !important;
		}
	}

	/* Footer: keep About full-width and show the two link lists side-by-side with a divider */
	.site-footer .footer-columns { grid-template-columns: repeat(2, 1fr); gap: var(--spacing-lg); }
	.site-footer .footer-column--about { grid-column: 1 / -1; }
	.site-footer .footer-column--categories { padding-right: 14px; border-right: 1px solid rgba(255,255,255,0.04); }
	.site-footer .footer-column--contact { padding-left: 14px; }



	.hero {
		padding: clamp(20px, 4vw, 32px) clamp(8px, 2.5vw, 16px);
		min-height: 300px;
	}

	.hero::before {
		background: linear-gradient(to bottom, transparent 20%, rgba(15, 20, 25, 0.9) 70%, var(--color-bg-dark));
	}

	.hero--home {
		min-height: 300px;
		padding: var(--spacing-lg) var(--spacing-md);
	}

	.hero--home .hero__content {
		flex-direction: column;
		gap: var(--spacing-xs);
		justify-content: center;
		align-items: stretch;
	}

	.hero--home .hero__inner {
		flex-basis: auto;
		flex-direction: column;
		align-items: stretch;
		width: 100%;
	}

	.hero--home .hero__search {
		width: 100%;
		margin-top: var(--spacing-xs);
	}

	.hero--home .theme-search-form {
		flex-direction: column;
	}

	.theme-search-form {
		flex-direction: column;
		align-items: stretch;
		gap: 8px;
		padding: 10px;
		border-radius: 12px;
		max-width: 100%;
	}

	.hero .theme-search-form {
		flex-direction: column;
		align-items: stretch;
		gap: 8px;
		max-width: 100%;
		padding: 10px;
		border-radius: 12px;
	}

	.hero__search {
		flex-direction: column;
		gap: var(--spacing-sm);
		width: 100%;
		max-width: 100%;
		margin-top: var(--spacing-sm);
	}

	.hero__search-input,
	.hero__search input {
		width: 100%;
		min-width: auto;
	}

	.hero__meta {
		display: grid;
		grid-template-columns: repeat(2, 1fr);
		gap: var(--spacing-sm);
	}

	.meta-card {
		padding: var(--spacing-sm);
	}

	.movies-grid,
	.tv-grid {
		grid-template-columns: repeat(3, 1fr);
		gap: var(--spacing-sm);
	}

	.actors-grid,
	.directors-grid,
	.persons-grid {
		grid-template-columns: repeat(3, 1fr);
		gap: var(--spacing-sm);
	}

	.movie-card__content {
		padding: 10px 8px;
		gap: 5px;
	}

	.movie-card__title {
		font-size: 13px;
		margin: 0 0 3px 0;
	}

	.movie-card__meta {
		font-size: 10px;
		gap: 6px;
	}

	.person-card__body {
		padding: 8px 6px;
		gap: 4px;
	}

	.person-card__name {
		font-size: 12px;
	}

	.person-card__excerpt {
		font-size: 10px;
	}

	.mmp-seasons-grid,
	.mmp-episodes-list {
		grid-template-columns: repeat(3, 1fr);
	}

	.section {
		padding: var(--spacing-xl) 0;
		border-bottom-width: 1px;
	}

	.pagination {
		gap: var(--spacing-xs);
	}

	.pagination .page-numbers {
		padding: var(--spacing-xs) var(--spacing-sm);
	}

	.rating-badge {
		padding: var(--spacing-sm) var(--spacing-md);
	}

	.btn {
		padding: var(--spacing-sm) var(--spacing-md);
	}

	.btn--small {
		padding: var(--spacing-xs) var(--spacing-sm);
	}

	.genres-grid,
	.genres-list {
		max-width: 100%;
		margin: 16px auto;
	}

	.season-chooser {
		margin: 0 0 1rem 0;
	}

	.mmp-season-buttons,
	.mmp-episode-buttons {
		flex-wrap: wrap;
	}

	.mmp-watch {
		max-width: 100%;
		margin: 8px auto;
	}

	.mmp-watch__tv {
		aspect-ratio: 16/9;
		width: 100%;
	}

	/* Header search removed: no mobile toggle or header search UI */

	.cast-grid,
	.directors-list {
		grid-template-columns: repeat(4, 1fr);
	}

	.cast-member,
	.director-item {
		padding: var(--spacing-sm);
		gap: var(--spacing-xs);
	}

	.cast-grid .people-show-more-wrapper,
	.cast-grid .people-show-less-wrapper,
	.directors-list .people-show-more-wrapper,
	.directors-list .people-show-less-wrapper {
		margin: var(--spacing-sm) 0;
	}
}

/* ========================================
   Small Phones (320px - 479px)
   ======================================== */

@media (max-width: 479px) {
	:root {
		--font-size-h4: 16px;
		--spacing-xs: 3px;
		--spacing-sm: 6px;
		--spacing-md: 10px;
		--spacing-lg: 12px;
		--spacing-xl: 16px;
		--spacing-2xl: 24px;
		--spacing-3xl: 32px;
	}

	.container {
		padding: 0 clamp(6px, 2vw, 12px);
		max-width: 100%;
	}

	.site-header__inner {
		padding: 6px clamp(6px, 2vw, 12px);
		gap: var(--spacing-xs);
	}

	.site-branding {
		gap: 6px;
	}

	.site-branding img {
		max-height: 28px;
	}

	.site-title {
		font-size: clamp(9px, 4vw, 12px);
		font-weight: 800;
	}

	.hero {
		padding: clamp(16px, 3vw, 24px) clamp(6px, 2vw, 12px);
		min-height: 240px;
	}

	.hero::before {
		background: linear-gradient(to bottom, transparent 10%, rgba(15, 20, 25, 0.95) 60%, var(--color-bg-dark));
	}

	.hero--archive {
		min-height: 120px;
	}

	.hero__content {
		gap: var(--spacing-md);
		flex-direction: column;
	}

	.hero__poster {
		width: clamp(80px, 15vw, 100px);
		height: auto;
		aspect-ratio: 2/3;
	}

	.hero--home {
		min-height: 240px;
		padding: var(--spacing-md) var(--spacing-sm);
	}

	.hero--home .hero__content {
		flex-direction: column;
		gap: var(--spacing-xs);
		justify-content: center;
		align-items: stretch;
	}

	.hero--home .hero__inner {
		flex-basis: auto;
		flex-direction: column;
		align-items: stretch;
		width: 100%;
	}

	.hero--home .hero__text {
		width: 100%;
		text-align: center;
	}

	.hero__search {
		flex-direction: column;
		gap: var(--spacing-sm);
		width: 100%;
		max-width: 100%;
		margin-top: auto;
	}

	.hero__search-input,
	.theme-search-input,
	.theme-search-form input[type="search"] {
		width: 100%;
		height: auto;
		min-width: auto;
		padding: 8px 10px;
		font-size: 14px;
	}

	.theme-search-form {
		flex-direction: column;
		gap: 6px;
		padding: 8px;
	}

	.hero .theme-search-form {
		flex-direction: column;
		align-items: stretch;
		gap: 6px;
		padding: 8px;
	}

	.theme-search-type {
		width: 100%;
		padding: 8px 24px 8px 8px;
		background-position: calc(100% - 8px) center;
	}

	.theme-search-results {
		max-width: calc(100vw - 16px);
		max-height: 240px;
	}

	.hero__meta {
		display: grid;
		grid-template-columns: 1fr;
		gap: var(--spacing-sm);
	}

	.meta-card {
		padding: var(--spacing-sm);
	}

	.meta-label {
		font-size: var(--font-size-xs);
	}

	.meta-value {
		font-size: var(--font-size-small);
	}

	.btn {
		padding: var(--spacing-sm) var(--spacing-md);
		font-size: var(--font-size-small);
	}

	.btn--small {
		padding: var(--spacing-xs) var(--spacing-sm);
	}

	.btn--search {
		width: 100%;
		margin-top: 4px;
	}

	.movies-grid,
	.tv-grid {
		grid-template-columns: repeat(3, 1fr);
		gap: var(--spacing-xs);
		padding: 0 var(--spacing-xs);
	}

	.actors-grid,
	.directors-grid,
	.persons-grid {
		grid-template-columns: repeat(3, 1fr);
		gap: var(--spacing-xs);
		padding: 0 var(--spacing-xs);
	}

	.person-card {
		display: flex;
		align-items: center;
		gap: var(--spacing-sm);
		padding: var(--spacing-sm);
		margin-bottom: var(--spacing-xs);
	}

	.person-card__media {
		min-width: 60px;
		width: 60px;
		height: 60px;
		flex-shrink: 0;
	}

	.person-card__name {
		font-size: 13px;
	}

	.person-card__excerpt {
		font-size: 11px;
		max-height: 40px;
	}

	.movie-card {
		border-radius: var(--radius-md);
	}

	.movie-card__content {
		padding: 8px 6px;
		gap: 4px;
	}

	.movie-card__title {
		font-size: 12px;
		margin: 0 0 2px 0;
	}

	.movie-card__meta {
		gap: 5px;
		font-size: 10px;
	}

	.movie-card__rating {
		font-size: 10px;
	}

	.movie-card:hover {
		transform: translateY(-3px);
	}

	.search-card {
		min-width: 120px;
		max-width: 100%;
	}

	.search-card__thumb img {
		max-width: 100%;
		height: 140px;
	}

	.mmp-seasons-grid,
	.mmp-episodes-list {
		grid-template-columns: repeat(2, 1fr);
		gap: 0.25rem;
	}

	.mmp-season-card,
	.mmp-episode-card {
		padding: 0.25rem;
	}

	.mmp-season-buttons,
	.mmp-episode-buttons {
		gap: 0.25rem;
		padding: 0.15rem 0.25rem;
		flex-wrap: wrap;
	}

	.mmp-season-nav-btn,
	.mmp-episode-nav-btn {
		padding: 0.4rem;
		font-size: 0.75rem;
	}

	.section {
		padding: var(--spacing-lg) 0;
		border-bottom-width: 1px;
	}

	.section__header {
		flex-direction: column;
		align-items: flex-start;
		margin-bottom: var(--spacing-md);
		border-bottom: 1px solid rgba(255, 255, 255, 0.05);
		padding-bottom: var(--spacing-sm);
	}

	.section__header--grid {
		flex-direction: row;
		align-items: center;
		justify-content: space-between;
	}

	.section__title {
		margin-bottom: 0;
		font-size: clamp(18px, 1vw, 26px);
	}

	.pagination {
		gap: var(--spacing-xs);
	}

	.pagination .page-numbers {
		padding: var(--spacing-xs) var(--spacing-sm);
		font-size: var(--font-size-xs);
	}

	.rating-badge {
		padding: var(--spacing-sm) var(--spacing-md);
	}

	.footer-columns {
		grid-template-columns: 1fr;
		gap: var(--spacing-lg);
	}

	.footer-column h3 {
		font-size: var(--font-size-h4);
		margin-bottom: var(--spacing-md);
	}

	.footer-bottom {
		padding-top: var(--spacing-md);
		border-top-width: 1px;
		gap: var(--spacing-md);
		flex-direction: column;
	}

	.footer-bottom__links {
		flex-direction: column;
		gap: var(--spacing-sm);
		width: 100%;
		text-align: center;
	}

	.footer-bottom__copyright {
		width: 100%;
		text-align: center;
		font-size: var(--font-size-xs);
	}

	.details-grid {
		grid-template-columns: 1fr;
		gap: var(--spacing-md);
	}

	.detail-item {
		padding: var(--spacing-md);
	}

	.detail-label {
		font-size: var(--font-size-xs);
		margin-bottom: var(--spacing-xs);
	}

	.detail-value {
		font-size: var(--font-size-small);
	}

	.genres-grid,
	.genres-list {
		max-width: 100%;
		margin: 12px auto;
		padding: 0 8px;
	}

	.genre-badge {
		padding: 6px 12px;
		font-size: 12px;
	}

	.mmp-watch {
		max-width: 100%;
		margin: 8px 0;
		padding: 0 6px;
	}

	.mmp-watch__tv {
		aspect-ratio: 16/9;
		width: 100%;
		border-radius: 8px;
	}

	.mmp-watch__description {
		margin-bottom: 12px;
		padding: 0 6px;
	}

	.mmp-watch__serverbar {
		gap: 6px;
		padding: 4px 0;
		margin: 8px 6px;
	}

	.mmp-watch__ctrl {
		padding: 4px 6px;
		font-size: 11px;
		min-width: 30px;
	}

	.mmp-season-chooser {
		margin: 0 0 8px 0;
	}

	.mmp-season-chooser-inner {
		gap: 4px;
	}

	.ad-container {
		padding: var(--spacing-md);
	}

	.ad-placeholder {
		padding: var(--spacing-lg);
		font-size: var(--font-size-small);
	}

	.archive-layout {
		gap: var(--spacing-lg);
	}

	.single-layout {
		gap: var(--spacing-lg);
	}
}

/* ========================================
   Print Styles
   ======================================== */

@media print {
	body {
		background: white;
		color: black;
	}

	.site-header,
	.site-footer,
	.ad-container,
	.mmp-ad-container,
	.mmp-video-ad-container {
		display: none;
	}

	.main-content {
		max-width: 100%;
	}

	a {
		color: black;
		text-decoration: underline;
	}

	img {
		max-width: 100%;
	}
}

/* ========================================
   Accessibility
   ======================================== */

@media (prefers-reduced-motion: reduce) {
	*,
	*::before,
	*::after {
		animation-duration: 0.01ms !important;
		animation-iteration-count: 1 !important;
		transition-duration: 0.01ms !important;
		scroll-behavior: auto !important;
	}
}

@media (prefers-color-scheme: dark) {
	:root {
		color-scheme: dark;
	}
}

@media (prefers-color-scheme: light) {
	:root {
		color-scheme: light;
	}
}

/* ========================================
   Extra Small Devices (less than 480px)
   ======================================== */

@media (max-width: 479px) {
	.hero {
		padding: var(--spacing-lg) var(--spacing-md);
		min-height: 240px;
	}

	.hero--archive {
		min-height: 120px;
	}

	.hero::before {
		background: linear-gradient(to bottom, transparent 10%, rgba(15, 20, 25, 0.95) 60%, var(--color-bg-dark));
	}

	.hero__content {
		gap: var(--spacing-md);
	}

	.hero__poster {
		width: clamp(70px, 12vw, 100px);
		height: auto;
		aspect-ratio: 2/3;
	}

	/* hero--home extra small devices */
	.hero--home {
		min-height: 240px;
		padding: var(--spacing-md) var(--spacing-sm);
	}

	.hero--home .hero__content {
		flex-direction: column;
		gap: var(--spacing-xs);
		justify-content: center;
		align-items: stretch;
	}

	.hero--home .hero__inner {
		flex-basis: auto;
		flex-direction: column;
		align-items: stretch;
		width: 100%;
	}

	.hero--home .hero__text {
		width: 100%;
		text-align: center;
	}

	.hero--home .hero__title {
		font-size: var(--font-size-h2);
		line-height: 1.2;
		margin: 0 0 var(--spacing-xs) 0;
	}

	.hero--home .hero__subtitle {
		font-size: var(--font-size-h4);
		line-height: 1.3;
		margin-bottom: var(--spacing-sm);
	}

	.hero--home .hero__search {
		width: 100%;
		margin-top: var(--spacing-xs);
	}

	.hero--home .theme-search-form {
		flex-direction: column;
	}

	.hero__meta {
		display: grid;
		grid-template-columns: 1fr;
		gap: var(--spacing-sm);
	}

	.meta-card {
		padding: var(--spacing-sm);
	}

	.meta-label {
		font-size: var(--font-size-xs);
	}

	.meta-value {
		font-size: var(--font-size-small);
	}

	.hero__title {
		font-size: var(--font-size-h2);
	}

	.hero__subtitle {
		font-size: var(--font-size-h4);
	}

	.hero__search {
		flex-direction: column;
		gap: var(--spacing-sm);
	}

	.hero__search-input {
		min-width: auto;
		width: 100%;
	}

	.hero__meta {
		display: grid;
		grid-template-columns: repeat(2, 1fr);
		gap: var(--spacing-sm);
	}

	.meta-card {
		padding: var(--spacing-sm);
	}

	.meta-label {
		font-size: var(--font-size-xs);
	}

	.meta-value {
		font-size: var(--font-size-small);
	}

	.btn {
		padding: var(--spacing-sm) var(--spacing-md);
		font-size: var(--font-size-small);
	}

	.btn--small {
		padding: var(--spacing-xs) var(--spacing-sm);
	}

	.movies-grid,
	.tv-grid {
		grid-template-columns: repeat(3, 1fr);
		gap: var(--spacing-sm);
	}

	.actors-grid,
	.directors-grid,
	.persons-grid {
		grid-template-columns: repeat(3, 1fr);
		gap: var(--spacing-sm);
	}

	.cast-grid,
	.directors-list {
		grid-template-columns: repeat(3, 1fr);
	}

	.cast-member,
	.director-item {
		padding: var(--spacing-xs);
		gap: 2px;
	}

	.cast-grid .people-show-more-wrapper,
	.cast-grid .people-show-less-wrapper,
	.directors-list .people-show-more-wrapper,
	.directors-list .people-show-less-wrapper {
		margin: var(--spacing-xs) 0;
	}

	.section {
		padding: var(--spacing-lg) 0;
		border-bottom-width: 1px;
	}

	/* Improve person-card readability on very small devices (<=350px) */
	.person-card__name {
		font-size: 14px;
	}

	.person-card__excerpt {
		font-size: 12px;
		-webkit-line-clamp: 2;
		display: -webkit-box;
		-webkit-box-orient: vertical;
		overflow: hidden;
	}

	.section__header {
		flex-direction: column;
		align-items: flex-start;
		margin-bottom: var(--spacing-sm);
		border-bottom: 1px solid rgba(255,255,255,0.05);
		padding-bottom: var(--spacing-xs);
	}

	.section__header--grid {
		flex-direction: row;
		align-items: center;
		justify-content: space-between;
		margin-bottom: var(--spacing-md);
		padding-bottom: var(--spacing-sm);
	}

	.section__title {
		margin-bottom: 0;
		font-size: clamp(16px, 2.2vw, 22px);
		-webkit-background-clip: text;
		background-clip: text;
	}

	.pagination {
		gap: var(--spacing-xs);
	}

	.pagination .page-numbers {
		padding: var(--spacing-xs) var(--spacing-sm);
		font-size: var(--font-size-xs);
	}

	.rating-badge {
		padding: var(--spacing-sm) var(--spacing-md);
	}

	.ad-container {
		padding: var(--spacing-md);
	}

	.ad-placeholder {
		padding: var(--spacing-lg);
		font-size: var(--font-size-small);
	}

	.archive-layout {
		gap: var(--spacing-lg);
	}

	.single-layout {
		gap: var(--spacing-lg);
	}

	.footer-columns {
		grid-template-columns: 1fr;
		gap: var(--spacing-lg);
	}

	.footer-column h3 {
		font-size: var(--font-size-h4);
		margin-bottom: var(--spacing-md);
	}

	.footer-bottom {
		padding-top: var(--spacing-md);
		border-top-width: 1px;
		gap: var(--spacing-md);
	}

	.footer-bottom__links {
		flex-direction: column;
		gap: var(--spacing-sm);
		width: 100%;
		text-align: center;
	}

	.footer-bottom__copyright {
		width: 100%;
		text-align: center;
		font-size: var(--font-size-xs);
	}
}

/* ========================================
   Print Styles
   ======================================== */

@media print {
	body {
		background: white;
		color: black;
	}

	.site-header,
	.site-footer,
	.ad-container {
		display: none;
	}

	.main-content {
		max-width: 100%;
	}

	a {
		color: black;
		text-decoration: underline;
	}

	img {
		max-width: 100%;
	}
}

/* ========================================
   Details Grid Responsive
   ======================================== */

@media (max-width: 1023px) {
	.details-grid {
		grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
		gap: var(--spacing-md);
	}

	.detail-item {
		padding: var(--spacing-md);
	}

	.detail-label {
		font-size: var(--font-size-xs);
	}

	.detail-value {
		font-size: var(--font-size-small);
	}
}

@media (max-width: 319px) {
	.details-grid {
		grid-template-columns: 1fr;
		gap: var(--spacing-md);
	}

	.detail-item {
		padding: var(--spacing-md);
	}

	.detail-label {
		font-size: var(--font-size-xs);
		margin-bottom: var(--spacing-xs);
	}

	.detail-value {
		font-size: var(--font-size-small);
	}

	.movie-card {
		border-radius: var(--radius-md);
	}

	.movie-card__content {
		padding: 8px 6px;
		gap: 4px;
	}

	.movie-card__title {
		font-size: 12px;
		margin: 0 0 2px 0;
	}

	.movie-card__meta {
		gap: 5px;
		font-size: 10px;
	}

	.movie-card__rating {
		font-size: 10px;
	}

	.movie-card:hover {
		transform: translateY(-3px);
	}

	.person-card {
		display: flex;
		align-items: center;
		gap: var(--spacing-sm);
		padding: var(--spacing-sm);
	}

	.person-card__name {
		font-size: 13px;
	}

	.person-card__excerpt {
		font-size: 11px;
		max-height: 40px;
	}
}

/* ========================================
   Mobile tweaks for hero content
   ======================================== */

@media (max-width: 767px) {
	.hero__content {
		flex-direction: column;
		align-items: center;
		text-align: center;
		gap: var(--spacing-md);
		padding: var(--spacing-md) 0;
	}

	.hero__poster {
		width: clamp(100px, 18vw, 120px);
		height: auto;
		aspect-ratio: 2/3;
		margin: 0 auto;
		box-shadow: var(--shadow-md);
	}

	.hero__title {
		font-size: calc(var(--font-size-h1) * 0.6);
		line-height: 1.08;
		margin-top: var(--spacing-sm);
	}

	.hero__subtitle {
		font-size: var(--font-size-small);
		margin-bottom: var(--spacing-sm);
	}

	.hero__info {
		width: 100%;
		padding: 0 var(--spacing-sm);
	}

	.hero__meta {
		display: flex;
		flex-wrap: wrap;
		justify-content: center;
		gap: 8px;
	}

	.hero__rating {
		margin-top: 8px;
		display: flex;
		align-items: center;
		justify-content: center;
		gap: 8px;
	}
}

/* ========================================
   Accessibility
   ======================================== */

@media (prefers-reduced-motion: reduce) {
	*,
	*::before,
	*::after {
		animation-duration: 0.01ms !important;
		animation-iteration-count: 1 !important;
		transition-duration: 0.01ms !important;
		scroll-behavior: auto !important;
	}
}

@media (prefers-color-scheme: dark) {
	:root {
		color-scheme: dark;
	}
}

@media (prefers-color-scheme: light) {
	:root {
		color-scheme: light;
	}
}
