/* ========================================
   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;
	}

	/* Reduce hero height for single pages (season/episode) on large screens */
	.hero--single,
	.hero--episode {
		min-height: 420px;
	}

	/* Reduce hero height for person pages (actor/director) on large screens */
	.hero--person {
		min-height: auto;
		padding: var(--spacing-xl) var(--spacing-lg);
	}
}

/* ========================================
   Large Desktop (1440px - 1919px)
   ======================================== */

@media (max-width: 1919px) and (min-width: 1440px) {
	:root {
		--spacing-3xl: 64px;
	}

	.container {
		max-width: clamp(1200px, 95vw, 1320px);
	}

	/* Reduce hero height for person pages on large desktop */
	.hero--person {
		min-height: auto;
		padding: var(--spacing-lg) var(--spacing-lg);
	}
}

/* ========================================
   Desktop (1280px - 1439px)
   ======================================== */

@media (max-width: 1439px) and (min-width: 1280px) {
	:root {
		--spacing-3xl: 56px;
	}

	.container {
		max-width: 100%;
	}

	/* Reduce hero height for person pages on desktop */
	.hero--person {
		min-height: auto;
		padding: var(--spacing-lg) var(--spacing-lg);
	}
}

/* ========================================
   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;
	}

	.hero {
		padding: clamp(20px, 5vw, 48px) clamp(12px, 3vw, 24px);
		min-height: 400px;
	}

	.hero--single,
	.hero--episode {
		min-height: 280px;
	}

	.hero::before {
		/* Strong dark gradient overlay to improve readability on backdrops */
		background: linear-gradient(to bottom, rgba(0,0,0,0) 20%, rgba(0,0,0,0.7) 70%, rgba(0,0,0,0.7));
		z-index: 1;
	}

	.hero__content {
		flex-direction: column;
		gap: var(--spacing-lg);
	}

	.hero__poster {
		width: clamp(100px, 15vw, 130px);
		height: auto;
		aspect-ratio: 2/3;
	}

	.hero--archive {
		min-height: 160px;
	}

	/* Make hero--person a compact horizontal strip on tablets */
	.hero--person {
		min-height: auto;
		padding: var(--spacing-lg) clamp(12px, 3vw, 24px);
	}

	.hero--person .hero__content {
		flex-direction: row;
		gap: var(--spacing-lg);
		align-items: center;
	}

	.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: var(--font-size-xxs);
	}

	.hero__content {
		flex-direction: column;
		align-items: center;
		text-align: center;
		gap: var(--spacing-md);
		padding: var(--spacing-md) 0;
	}

	.hero__poster {
		width: clamp(90px, 16vw, 110px);
		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;
	}
	
	/* Tablet hero search dropdown */
	.hero .theme-search-form .theme-search-results {
		max-width: 90vw;
		max-height: 420px;
	}
}
/* ========================================
   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);
	}
}

/* ===== RESPONSIVE NAVIGATION ===== */
@media (max-width: 1024px) {
	.nav-menu {
		gap: var(--spacing-sm);
	}

	.nav-menu a,
	.nav-button {
		padding: 8px 12px;
		font-size: var(--font-size-sm);
	}

	.nav-button--featured {
		padding: 8px 14px;
		font-size: var(--font-size-sm);
	}
}

@media (max-width: 768px) {
	.site-navigation {
		order: -1;
		flex: 0 1 auto;
		width: 100%;
		justify-content: flex-start;
		margin: 8px 0;
		gap: 0;
	}

	.nav-menu {
		width: 100%;
		gap: 0;
		flex-wrap: nowrap;
		overflow-x: auto;
		scroll-behavior: smooth;
		padding: 0 4px;
		-webkit-overflow-scrolling: touch;
	}

	.nav-menu a,
	.nav-button {
		padding: 8px 10px;
		font-size: var(--font-size-sm);
		white-space: nowrap;
		flex-shrink: 0;
		border-radius: 6px;
	}

	.nav-button--featured {
		padding: 7px 11px;
		font-size: var(--font-size-xs);
		margin-left: auto;
	}

	/* Hide menu separators on small devices */
	.nav-menu li:not(:last-child) a::after,
	.nav-menu li:not(:last-child) .nav-button::after {
		display: none;
	}

	/* Mobile dropdown menus */
	.nav-menu .sub-menu {
		display: none;
	}

	.nav-menu .sub-menu.open {
		display: block;
		position: fixed;
		width: 200px;
		max-width: calc(100vw - var(--spacing-md) * 2);
		opacity: 1;
		visibility: visible;
		transform: translateY(0);
		background: var(--color-bg-dark);
		border-radius: 8px;
		box-shadow: var(--shadow-lg);
		border: 1px solid rgba(234, 18, 23, 0.1);
		padding: var(--spacing-sm) 0;
		z-index: 120;
	}

	.nav-menu .sub-menu.open li {
		display: block;
		list-style: none;
		border-bottom: 1px solid rgba(255, 255, 255, 0.1);
	}

	.nav-menu .sub-menu.open li:last-child {
		border-bottom: none;
	}

	.nav-menu .sub-menu.open a[href="#"] {
		pointer-events: none;
		cursor: default;
		opacity: 0.6;
	}

	.nav-menu .sub-menu.open a {
		display: block;
		padding: 8px 12px;
		color: var(--color-text-primary);
		text-decoration: none;
		font-size: var(--font-size-sm);
		transition: background 0.2s ease, color 0.2s ease;
	}

	.nav-menu .sub-menu.open a:hover,
	.nav-menu .sub-menu.open a:focus {
		background: rgba(234, 18, 23, 0.08);
		color: var(--color-primary);
	}

	/* 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--single,
	.hero--episode {
		min-height: 280px;
	}

	.hero::before {
		background: linear-gradient(to bottom, rgba(0,0,0,0) 20%, rgba(0,0,0,0.75) 70%, rgba(0,0,0,0.75));
		z-index: 1;
	}

	.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;
	}

	/* Hero person (actor/director) on mobile - stacked layout */
	.hero--person {
		min-height: auto;
		padding: var(--spacing-lg) var(--spacing-md);
	}

	.hero--person .hero__content {
		flex-direction: column;
		gap: var(--spacing-lg);
		align-items: center;
		text-align: center;
	}

	.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: var(--font-size-sm);
		margin: 0 0 3px 0;
	}

	.movie-card__meta {
		font-size: var(--font-size-xxs);
		gap: 6px;
	}

	.person-card__body {
		padding: 8px 6px;
		gap: 4px;
	}

	.person-card__name {
		font-size: var(--font-size-sm);
	}

	.person-card__excerpt {
		font-size: var(--font-size-xxs);
		display: -webkit-box;
		-webkit-box-orient: vertical;
		-webkit-line-clamp: 2;
		line-clamp: 2;
		overflow: hidden;
		text-overflow: ellipsis;
	}

	.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: 0;
		font-size: var(--font-size-body);
		background: none;
		border: none;
		color: var(--color-primary);
		text-decoration: underline;
		box-shadow: none;
		min-height: auto;
	}

	.btn--primary.btn--small {
		background: var(--color-primary);
		color: var(--color-text-inverse);
		text-decoration: none;
		border: none;
	}

	.genres-grid,
	.genres-list {
		max-width: 100%;
		margin: 16px auto;
	}

	.season-chooser {
		margin: 0 0 1rem 0;
	}



	/* 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;
	}

	/* No Results Section - Tablet */
	.no-results {
		padding: var(--spacing-2xl) var(--spacing-md);
		max-width: 900px;
	}

	.no-results__icon {
		width: 100px;
		height: 100px;
	}

	.no-results .theme-search-form {
		max-width: 100%;
	}
}

/* ========================================
   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%;
	}

	/* Fix branding in left on phones */
	.site-header__inner {
		flex-wrap: nowrap;
		gap: var(--spacing-xs);
		padding: 8px 6px;
		justify-content: flex-start;
	}

	.site-header {
		overflow: visible;
	}

	/* Prevent nav menu from wrapping */
	.site-navigation {
		flex: 0 1 auto;
		overflow: visible;
		order: 2;
	}

	.nav-menu {
		flex-wrap: nowrap;
		overflow-x: auto;
		padding: 0 4px;
		gap: 6px;
	}

	.nav-menu a,
	.nav-button {
		flex-shrink: 0;
		padding: 4px 6px;
		font-size: var(--font-size-sm);
		white-space: nowrap;
		display: inline-flex;
		align-items: center;
		height: 36px;
	}

	/* Hide Estrenos button on phones only */
	.nav-button--featured {
		display: none;
	}

	/* Icons on far right */
	.header-search-toggle,
	.dark-mode-toggle {
		flex-shrink: 0;
		order: 3;
		margin-left: auto;
		width: 40px;
		height: 40px;
		display: flex;
		align-items: center;
		justify-content: center;
		padding: 6px;
	}



	.hero {
		padding: clamp(16px, 3vw, 24px) clamp(6px, 2vw, 12px);
		min-height: 240px;
	}

	.hero--single,
	.hero--episode {
		min-height: 220px;
		background-attachment: scroll;
	}

	.hero::before {
		background: linear-gradient(to bottom, rgba(0,0,0,0) 10%, rgba(0,0,0,0.75) 60%, rgba(0,0,0,0.75));
		z-index: 1;
	}

	.hero--archive {
		min-height: 120px;
	}

	.hero__content {
		gap: var(--spacing-md);
		flex-direction: column;
	}

	.hero__poster {
		width: clamp(75px, 14vw, 95px);
		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: var(--font-size-sm);
	}

	.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 {
		flex: 1;
		min-width: 0;
		padding: 8px 16px 8px 8px;
		background-position: calc(100% - 6px) center;
		font-size: var(--font-size-sm);
	}

	.theme-search-year,
	.theme-search-genre {
		flex: 1;
		min-width: 0;
		padding: 8px 16px 8px 8px;
		background-position: calc(100% - 6px) center;
	}

	.theme-search-results {
		max-width: calc(100vw - 16px);
		max-height: 360px;
		left: 50%;
		transform: translateX(-50%);
	}
	
	.search-item .thumb {
		width: 52px;
		height: 78px;
	}
	
	.search-item .meta .title {
		font-size: var(--font-size-sm);
	}

	.search-item .meta .sub {
		font-size: var(--font-size-xs);
	
	/* Hero section responsive dropdown */
	.hero .theme-search-form .theme-search-results {
		width: calc(100% + 16px);
		left: 50%;
		transform: translateX(-50%);
		max-width: calc(100vw - 16px);
		max-height: 350px;
		top: calc(100% + 12px);
	}

	.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;
		flex-direction: column;
		align-items: center;
		gap: var(--spacing-sm);
		padding: var(--spacing-sm);
		margin-bottom: var(--spacing-xs);
		text-align: center;
	}

	.person-card__link {
		display: flex;
		flex-direction: column;
		align-items: center;
		width: 100%;
		height: 100%;
		text-decoration: none;
		color: inherit;
	}

	.person-card__media {
		width: 80px;
		height: 80px;
		flex-shrink: 0;
		border-radius: 50%;
		overflow: hidden;
	}

	.person-card__name {
		font-size: var(--font-size-sm);
	}

	.person-card__excerpt {
		font-size: var(--font-size-xs);
		display: -webkit-box;
		-webkit-box-orient: vertical;
		-webkit-line-clamp: 2;
		line-clamp: 2;
		overflow: hidden;
		text-overflow: ellipsis;
	}

	.movie-card {
		border-radius: var(--radius-md);
	}

	.movie-card__content {
		padding: 8px 6px;
		gap: 4px;
	}

	.movie-card__title {
		font-size: var(--font-size-sm);
		margin: 0 0 2px 0;
	}

	.movie-card__meta {
		gap: 5px;
		font-size: var(--font-size-xxs);
	}

	.movie-card__rating {
		font-size: var(--font-size-xxs);
	}

	.movie-card:hover {
		transform: translateY(-3px);
	}

	.search-card {
		min-width: 120px;
		max-width: 100%;
	}

	.search-card__thumb img {
		max-width: 100%;
	}

	.search-card__language-badge {
		top: 6px;
		right: 6px;
		padding: 0;
	}

	.search-card__language-flag {
		font-size: 1.2rem;
	}

	.search-card__language-letter {
		font-size: 0.6rem;
		left: -2px;
	}

	.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-episode-card__cta {
		font-size: 0.75rem;
	}

	.mmp-season-buttons {
		gap: 0.25rem;
		padding: 0.15rem 0.25rem;
		flex-wrap: wrap;
	}

	.mmp-season-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: var(--font-size-sm);
	}



	.mmp-season-chooser {
		margin: 0 0 8px 0;
	}

	.mmp-season-chooser-inner {
		gap: 4px;
	}

	.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 {
		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;
		animation-iteration-count: 1;
		transition-duration: 0.01ms;
		scroll-behavior: auto;
	}
}

@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, rgba(0,0,0,0) 10%, rgba(0,0,0,0.75) 60%, rgba(0,0,0,0.75));
		z-index: 1;
	}

	.hero__content {
		gap: var(--spacing-md);
	}

	.hero__poster {
		width: clamp(70px, 12vw, 90px);
		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: var(--font-size-sm);
	}

	.person-card__excerpt {
		font-size: var(--font-size-sm);
		display: -webkit-box;
		-webkit-box-orient: vertical;
		-webkit-line-clamp: 2;
		line-clamp: 2;
		overflow: hidden;
		text-overflow: ellipsis;
	}

	.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);
	}

	.archive-layout {
		gap: var(--spacing-lg);
	}

	.single-layout {
		gap: var(--spacing-lg);
	}

	/* No Results Section - Mobile */
	.no-results {
		padding: var(--spacing-lg) var(--spacing-sm);
		gap: var(--spacing-md);
	}

	.no-results__icon {
		width: 80px;
		height: 80px;
	}

	.no-results__title {
		font-size: 1rem;
	}

	.no-results__subtitle {
		font-size: 0.9rem;
	}

	.no-results__suggestions {
		padding: var(--spacing-md);
	}

	.no-results__search-wrap {
		width: 100%;
	}

	.no-results .theme-search-form {
		flex-direction: row;
		flex-wrap: wrap;
		max-width: 100%;
		gap: 8px;
	}

	.no-results .theme-search-inner {
		flex-direction: row;
		flex-wrap: wrap;
		width: 100%;
	}

	.no-results .theme-search-input {
		min-width: auto;
		width: 100%;
		height: 40px;
		flex: 1 1 100%;
	}

	.no-results .theme-search-controls {
		flex-direction: row;
		width: 100%;
		gap: 6px;
		align-items: center;
	}

	.no-results .theme-search-type,
	.no-results .theme-search-year,
	.no-results .theme-search-genre {
		flex: 1;
		min-width: 0;
	}

	.no-results .search-submit {
		width: auto;
		flex: 0 0 auto;
	}

	.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 {
		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: var(--font-size-sm);
		margin: 0 0 2px 0;
	}

	.movie-card__meta {
		gap: 5px;
		font-size: var(--font-size-xxs);
	}

	.movie-card__rating {
		font-size: var(--font-size-xxs);
	}

	.movie-card:hover {
		transform: translateY(-3px);
	}

	.person-card {
		display: flex;
		flex-direction: column;
		align-items: center;
		gap: var(--spacing-sm);
		padding: var(--spacing-sm);
		text-align: center;
	}

	.person-card__link {
		display: flex;
		flex-direction: column;
		align-items: center;
		width: 100%;
		height: 100%;
		text-decoration: none;
		color: inherit;
	}

	.person-card__name {
		font-size: var(--font-size-sm);
	}

	.person-card__excerpt {
		font-size: var(--font-size-xs);
		display: -webkit-box;
		-webkit-box-orient: vertical;
		-webkit-line-clamp: 2;
		line-clamp: 2;
		overflow: hidden;
		text-overflow: ellipsis;
	}

	.person-card__media {
		width: 80px;
		height: 80px;
		border-radius: 50%;
		overflow: hidden;
		flex-shrink: 0;
	}
}

/* ========================================
   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;
	}

	/* Keep single hero poster/info layout on mobile overrides */
	.hero--single .hero__content {
		display: grid 
		grid-template-columns: minmax(120px, 30%) 1fr 
		column-gap: var(--spacing-lg) 
		align-items: start 
	}

	.hero--single .hero__poster {
		width: 100% 
		max-width: none 
		margin: 0 
		justify-self: start 
	}
}
}
