/**
 * ByoDirectory Premium Responsive Styles
 *
 * Mobile-first responsive breakpoints with accessibility enhancements.
 *
 * @package ByoDirectory
 * @since 2.0.0
 */

/* ==========================================================================
   Extra Large Screens (1400px+)
   ========================================================================== */
@media (min-width: 1400px) {
	.container {
		max-width: 1320px;
	}

	.hero-title {
		font-size: var(--font-size-4xl);
	}

	.grid-4 {
		grid-template-columns: repeat(4, 1fr);
	}
}

/* ==========================================================================
   Large Screens (1200px - 1399px)
   ========================================================================== */
@media (max-width: 1399px) {
	.container {
		max-width: 1140px;
	}
}

/* ==========================================================================
   Desktop (1024px - 1199px)
   ========================================================================== */
@media (max-width: 1199px) {
	.container {
		max-width: 960px;
	}

	.grid-4 {
		grid-template-columns: repeat(3, 1fr);
	}

	.hero-title {
		font-size: clamp(1.75rem, 4vw, 2.5rem);
	}
}

/* ==========================================================================
   Tablet Landscape (900px - 1023px)
   ========================================================================== */
@media (max-width: 1024px) {
	.container {
		max-width: 720px;
		padding-inline: var(--spacing-md);
	}

	.grid-4 {
		grid-template-columns: repeat(2, 1fr);
	}

	.footer-grid {
		grid-template-columns: repeat(2, 1fr);
	}

	.footer-widgets-grid {
		grid-template-columns: repeat(2, 1fr);
	}

	.footer-widgets-grid .footer-widget-area:last-child {
		grid-column: span 2;
	}

	/* Content sidebar adjustment */
	.content-sidebar-wrap.has-sidebar {
		grid-template-columns: 1fr;
		gap: var(--spacing-xl);
	}

	.sidebar {
		order: 2;
	}

	/* Hero adjustments */
	.hero {
		padding-block: var(--spacing-2xl);
	}

	.hero-title {
		font-size: clamp(1.5rem, 5vw, 2.25rem);
	}

	/* Card grid */
	.category-grid {
		grid-template-columns: repeat(2, 1fr);
	}
}

/* ==========================================================================
   Tablet Portrait (768px - 899px)
   ========================================================================== */
@media (max-width: 900px) {
	.search-card {
		grid-template-columns: 1fr;
		gap: var(--spacing-md);
	}

	.search-card .form-group {
		min-width: 100%;
	}

	.listing-grid {
		grid-template-columns: 1fr;
	}

	/* Hero search */
	.hero-search {
		padding: var(--spacing-lg);
	}

	/* Section spacing */
	.section {
		padding-block: var(--spacing-xl);
	}

	/* Listing meta */
	.listing-meta {
		flex-direction: column;
		align-items: flex-start;
		gap: var(--spacing-sm);
	}
}

/* ==========================================================================
   Mobile Landscape (600px - 767px)
   ========================================================================== */
@media (max-width: 768px) {
	/* Header layout */
	.header-inner {
		flex-direction: row;
		justify-content: space-between;
		align-items: center;
		padding-block: var(--spacing-sm);
	}

	.header-logo {
		margin-bottom: 0;
	}

	.header-logo img {
		max-height: 40px;
	}

	/* Navigation */
	.primary-nav {
		display: none;
	}

	.header-actions {
		display: flex;
		align-items: center;
		gap: var(--spacing-sm);
	}

	.menu-toggle {
		display: inline-flex;
	}

	.dark-mode-toggle {
		padding: var(--spacing-xs);
	}

	/* Mobile menu overlay */
	.mobile-nav {
		display: none;
		position: fixed;
		inset: 0;
		background: var(--color-surface);
		z-index: 1000;
		padding: var(--spacing-xl) var(--spacing-md);
		overflow-y: auto;
		transform: translateX(100%);
		transition: transform var(--transition-normal) ease;
	}

	.mobile-nav.is-open {
		display: block;
		transform: translateX(0);
	}

	.mobile-menu {
		flex-direction: column;
		gap: 0;
		list-style: none;
		padding: 0;
		margin: 0;
	}

	.mobile-menu li {
		border-bottom: 1px solid var(--color-border);
	}

	.mobile-menu a {
		display: block;
		padding: var(--spacing-md);
		font-size: var(--font-size-lg);
		font-weight: var(--font-weight-medium);
		color: var(--color-text-primary);
		text-decoration: none;
		transition: background-color var(--transition-fast);
	}

	.mobile-menu a:hover,
	.mobile-menu a:focus {
		background-color: var(--color-surface-hover);
	}

	/* Mobile close button */
	.mobile-nav-header {
		display: flex;
		justify-content: space-between;
		align-items: center;
		margin-bottom: var(--spacing-lg);
		padding-bottom: var(--spacing-md);
		border-bottom: 1px solid var(--color-border);
	}

	/* Grids */
	.grid-3,
	.grid-2 {
		grid-template-columns: 1fr;
	}

	.grid-4 {
		grid-template-columns: repeat(2, 1fr);
		gap: var(--spacing-md);
	}

	/* Hero */
	.hero {
		padding-block: var(--spacing-xl);
		min-height: auto;
	}

	.hero-content {
		text-align: center;
	}

	.hero-title {
		font-size: clamp(1.25rem, 6vw, 1.75rem);
	}

	.hero-subtitle {
		font-size: var(--font-size-base);
	}

	.hero-actions {
		justify-content: center;
	}

	/* Cards */
	.card {
		margin-inline: 0;
	}

	.card-listing .card-content {
		padding: var(--spacing-md);
	}

	/* Footer */
	.footer-widgets-grid {
		grid-template-columns: 1fr;
	}

	.footer-widgets-grid .footer-widget-area:last-child {
		grid-column: span 1;
	}

	/* Breadcrumbs */
	.breadcrumbs {
		font-size: var(--font-size-sm);
		padding-block: var(--spacing-sm);
	}

	.breadcrumbs-list {
		flex-wrap: wrap;
	}
}

/* ==========================================================================
   Mobile Portrait (max-width: 599px)
   ========================================================================== */
@media (max-width: 600px) {
	/* Container */
	.container {
		padding-inline: var(--spacing-sm);
	}

	/* Hero actions */
	.hero-actions {
		flex-direction: column;
		width: 100%;
	}

	.hero-actions .btn {
		width: 100%;
		justify-content: center;
	}

	/* Search card */
	.hero-search {
		padding: var(--spacing-md);
		margin-inline: calc(var(--spacing-sm) * -1);
		border-radius: 0;
	}

	/* Buttons */
	.btn {
		width: 100%;
		justify-content: center;
	}

	.btn-group {
		flex-direction: column;
		gap: var(--spacing-sm);
	}

	/* Cards grid */
	.grid-4 {
		grid-template-columns: 1fr;
	}

	.category-grid {
		grid-template-columns: 1fr;
	}

	/* Footer */
	.footer-grid {
		grid-template-columns: 1fr;
	}

	.footer-widget-area {
		text-align: center;
	}

	.site-footer .footer-bottom {
		flex-direction: column;
		gap: var(--spacing-sm);
		text-align: center;
	}

	/* Section titles */
	.section-title {
		font-size: var(--font-size-xl);
	}

	/* Single listing */
	.listing-header {
		flex-direction: column;
		align-items: flex-start;
		gap: var(--spacing-sm);
	}

	.listing-actions {
		width: 100%;
	}

	.listing-actions .btn {
		flex: 1;
	}

	/* Info cards */
	.info-card {
		padding: var(--spacing-md);
	}

	/* Forms */
	.form-group {
		margin-bottom: var(--spacing-md);
	}

	.form-control {
		font-size: 16px; /* Prevents zoom on iOS */
	}

	/* Modal/overlay adjustments */
	.modal-content {
		margin: var(--spacing-sm);
		max-height: calc(100vh - var(--spacing-lg));
	}
}

/* ==========================================================================
   Small Mobile (max-width: 375px)
   ========================================================================== */
@media (max-width: 375px) {
	:root {
		--spacing-xs: 0.25rem;
		--spacing-sm: 0.5rem;
		--spacing-md: 0.75rem;
	}

	.hero-title {
		font-size: 1.25rem;
	}

	.card-taxonomy .card-content {
		padding: var(--spacing-sm);
	}

	.category-badge {
		font-size: 0.625rem;
		padding: 0.125rem 0.375rem;
	}
}

/* ==========================================================================
   Height-based Media Queries
   ========================================================================== */
@media (max-height: 600px) and (orientation: landscape) {
	.hero {
		min-height: auto;
		padding-block: var(--spacing-lg);
	}

	.hero-title {
		font-size: 1.5rem;
	}

	.mobile-nav {
		padding-block: var(--spacing-sm);
	}

	.mobile-menu a {
		padding: var(--spacing-sm) var(--spacing-md);
	}
}

/* ==========================================================================
   High DPI / Retina Displays
   ========================================================================== */
@media (-webkit-min-device-pixel-ratio: 2), (min-resolution: 192dpi) {
	.card-image img {
		image-rendering: -webkit-optimize-contrast;
	}
}

/* ==========================================================================
   Hover Media Query (devices with hover capability)
   ========================================================================== */
@media (hover: hover) {
	.card:hover {
		transform: translateY(-4px);
		box-shadow: var(--shadow-lg);
	}

	.btn:hover {
		transform: translateY(-1px);
	}

	.nav-link:hover::after {
		transform: scaleX(1);
	}
}

/* ==========================================================================
   Touch Devices (no hover)
   ========================================================================== */
@media (hover: none) {
	.card:active {
		transform: scale(0.98);
	}

	.btn:active {
		transform: scale(0.98);
	}

	/* Larger touch targets */
	.btn {
		min-height: 48px;
	}

	.form-control {
		min-height: 48px;
	}

	.menu-toggle {
		min-width: 48px;
		min-height: 48px;
	}

	.dark-mode-toggle {
		min-width: 44px;
		min-height: 44px;
	}
}

/* ==========================================================================
   Reduced Motion
   ========================================================================== */
@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;
	}

	.mobile-nav {
		transition: none;
	}

	.card:hover {
		transform: none;
	}

	.btn:hover {
		transform: none;
	}

	.skeleton::after {
		animation: none;
	}
}

/* ==========================================================================
   Print Styles
   ========================================================================== */
@media print {
	/* Hide non-essential elements */
	.site-header,
	.site-footer,
	.sidebar,
	.hero-search,
	.hero-actions,
	.breadcrumbs,
	.menu-toggle,
	.dark-mode-toggle,
	.mobile-nav,
	.btn,
	.pagination,
	.share-buttons,
	.related-listings {
		display: none !important;
	}

	/* Reset colors for print */
	body {
		background: white !important;
		color: black !important;
	}

	.card {
		box-shadow: none !important;
		border: 1px solid #ddd !important;
		break-inside: avoid;
	}

	/* Links */
	a {
		color: black !important;
		text-decoration: underline !important;
	}

	a[href]::after {
		content: " (" attr(href) ")";
		font-size: 0.8em;
		color: #666;
	}

	/* Images */
	img {
		max-width: 100% !important;
	}

	/* Page breaks */
	h1, h2, h3 {
		break-after: avoid;
	}

	.card,
	.listing-content {
		break-inside: avoid;
	}

	/* Layout */
	.container {
		max-width: 100% !important;
		padding: 0 !important;
	}

	.content-sidebar-wrap {
		display: block !important;
	}

	.main-content {
		width: 100% !important;
	}
}

/* ==========================================================================
   Dark Mode Responsive Adjustments
   ========================================================================== */
@media (prefers-color-scheme: dark) {
	@media (max-width: 768px) {
		.mobile-nav {
			background: var(--color-surface);
		}

		.mobile-menu a:hover,
		.mobile-menu a:focus {
			background-color: var(--color-surface-hover);
		}
	}
}

[data-theme="dark"] {
	@media (max-width: 768px) {
		.mobile-nav {
			background: var(--color-surface);
		}
	}
}

/* ==========================================================================
   Accessibility: Focus Visible
   ========================================================================== */
@supports selector(:focus-visible) {
	.btn:focus:not(:focus-visible),
	.form-control:focus:not(:focus-visible),
	a:focus:not(:focus-visible) {
		outline: none;
		box-shadow: none;
	}
}

/* ==========================================================================
   Container Queries (Progressive Enhancement)
   ========================================================================== */
@supports (container-type: inline-size) {
	.card-container {
		container-type: inline-size;
	}

	@container (max-width: 300px) {
		.card-listing .card-content {
			padding: var(--spacing-sm);
		}

		.card-title {
			font-size: var(--font-size-base);
		}
	}
}
