/*
 * Mobile Responsive Styles
 * Optimizes Twenty Twenty-Five theme for mobile devices
 */

*,
*::before,
*::after {
	box-sizing: border-box;
}

:root {
	--mobile-padding: clamp(16px, 4vw, 28px);
	--mobile-gap: clamp(16px, 4vw, 24px);
	--mobile-font-size: clamp(15px, 3vw, 18px);
}

body {
	overflow-x: hidden;
	-webkit-text-size-adjust: 100%;
	-ms-text-size-adjust: 100%;
	font-size: var(--mobile-font-size);
	line-height: 1.6;
	text-rendering: optimizeLegibility;
	-webkit-font-smoothing: antialiased;
}

img,
video,
iframe,
embed,
object {
	max-width: 100%;
	height: auto;
	display: block;
}

.wp-site-blocks {
	overflow-x: hidden;
}

.wp-site-blocks > * {
	margin-left: auto;
	margin-right: auto;
}

@media (max-width: 1200px) {
	.wp-block-group,
	.wp-block-columns,
	.wp-block-column,
	main,
	.wp-site-blocks > * {
		padding-left: var(--mobile-padding);
		padding-right: var(--mobile-padding);
	}
}

@media (max-width: 1024px) {
	.wp-block-columns {
		gap: var(--mobile-gap);
		flex-wrap: wrap;
	}

	.wp-block-column {
		flex-basis: 100% !important;
		min-width: 0;
		margin-left: 0 !important;
		margin-right: 0 !important;
	}
}

@media (max-width: 900px) {
	h1 { font-size: clamp(1.9rem, 4vw, 2.4rem); }
	h2 { font-size: clamp(1.6rem, 3.5vw, 2rem); }
	h3 { font-size: clamp(1.4rem, 3vw, 1.75rem); }
	h4 { font-size: clamp(1.2rem, 2.5vw, 1.5rem); }

	.wp-block-cover {
		min-height: 65vh;
		padding: clamp(48px, 8vw, 96px) var(--mobile-padding);
	}

	.wp-block-cover .wp-block-cover__inner-container {
		gap: var(--mobile-gap);
	}

	.wp-block-navigation__responsive-container-open {
		min-height: 48px;
		min-width: 48px;
	}

	.wp-block-navigation__responsive-container-content {
		padding: var(--mobile-padding);
	}

	.wp-block-button__link,
	.wp-element-button {
		padding: clamp(12px, 3vw, 16px) clamp(18px, 5vw, 24px);
		font-size: 16px;
		min-height: 44px;
	}

	input[type="text"],
	input[type="email"],
	input[type="url"],
	input[type="password"],
	input[type="search"],
	textarea,
	select {
		font-size: 16px;
		padding: 12px;
		width: 100%;
		min-height: 44px;
	}

	table {
		display: block;
		width: 100%;
		overflow-x: auto;
	}
}

@media (max-width: 600px) {
	body {
		font-size: clamp(15px, 4vw, 17px);
	}

	.wp-block-cover {
		min-height: 60vh;
		padding: clamp(32px, 7vw, 64px) var(--mobile-padding);
	}
}

/* Maintenance/coming-soon overrides */
@media (max-width: 900px) {
	.background,
	.overlay {
		position: fixed;
		top: 0;
		left: 0;
		width: 100vw;
		height: 100vh;
	}

	.content {
		position: relative !important;
		top: 0 !important;
		left: 50% !important;
		transform: translateX(-50%);
		margin-top: clamp(20px, 6vw, 40px);
	}

	.frames-section {
		position: relative !important;
		top: auto !important;
		left: auto !important;
		transform: none !important;
		width: 100%;
		max-width: 520px;
		margin: clamp(24px, 8vw, 56px) auto 0;
		padding: 0 var(--mobile-padding);
		flex-direction: column !important;
		align-items: center;
		gap: clamp(12px, 4vw, 20px);
	}

	.frame-img {
		width: min(90vw, 360px) !important;
		height: auto !important;
		display: block;
	}
}

@media (max-width: 560px) {
	.frame-img {
		width: min(92vw, 320px) !important;
	}
}

/* Coming soon / overlay text */
@media (max-width: 900px) {
	.content {
		font-size: clamp(2.25rem, 6vw, 3rem) !important;
		left: 50% !important;
		top: 5% !important;
		width: min(90%, 560px) !important;
		transform: translateX(-50%);
		text-align: center !important;
		padding: clamp(8px, 2vw, 16px);
		white-space: normal !important;
		word-break: break-word;
		line-height: 1.2;
		letter-spacing: clamp(1px, 0.5vw, 3px) !important;
	}
}

@media (max-width: 560px) {
	.content {
		font-size: clamp(1.75rem, 8vw, 2.4rem) !important;
	}
}

@media (max-width: 400px) {
	.content {
		font-size: clamp(1.5rem, 9vw, 2rem) !important;
		letter-spacing: clamp(0.5px, 0.25vw, 1.5px) !important;
	}
}
