/* ============================================
   POKE BYTE - Responsive Design
   Mobile-First Approach
   ============================================ */

/* ============================================
   TABLET LANDSCAPE (1300px)
   ============================================ */
@media screen and (max-width: 1300px) {
	.main {
		max-width: 1100px;
		width: 95%;
	}

	.banner {
		height: 240px;
	}

	.rightPane {
		width: 320px;
	}

	nav .container > div > ul > li > a {
		padding: 1rem 1rem;
		font-size: 0.875rem;
	}

	h1 { font-size: 2.25rem; }
	h2 { font-size: 1.875rem; }
	h3 { font-size: 1.5rem; }
}

/* ============================================
   TABLET PORTRAIT (1024px)
   ============================================ */
@media screen and (max-width: 1024px) {
	.main {
		max-width: 960px;
	}

	.banner {
		height: 200px;
	}

	.feedContainer {
		flex-direction: column;
	}

	.leftPane {
		width: 100%;
	}

	.rightPane {
		width: 100%;
		display: grid;
		grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
		gap: var(--spacing-lg);
	}

	nav .container {
		padding: 0 var(--spacing-md);
	}

	nav .container > div > ul {
		gap: 0;
	}

	nav .container > div > ul > li > a {
		padding: 1rem 0.875rem;
		font-size: 0.8125rem;
	}

	nav .container > div > ul > li > a i {
		font-size: 1rem;
	}
}

/* ============================================
   MOBILE LANDSCAPE (768px)
   ============================================ */
@media screen and (max-width: 768px) {
	:root {
		--spacing-lg: 1rem;
		--spacing-xl: 1.5rem;
		--spacing-2xl: 2rem;
	}

	.main {
		max-width: 100%;
		width: 92%;
		margin: 1rem auto;
	}

	.banner {
		height: 160px;
		border-radius: var(--radius-lg);
	}

	nav {
		border-radius: var(--radius-lg);
		margin-bottom: var(--spacing-md);
	}

	nav .container {
		flex-direction: column;
		gap: 0;
		padding: var(--spacing-sm);
	}

	nav .container > div {
		width: 100%;
		justify-content: center;
	}

	nav .container > div > ul {
		flex-wrap: wrap;
		justify-content: center;
		gap: var(--spacing-xs);
	}

	nav .container > div > ul > li > a {
		padding: 0.75rem 0.875rem;
		font-size: 0.8125rem;
	}

	nav .container > div > ul > li > ul {
		left: 50%;
		transform: translateX(-50%);
		width: 90vw;
		max-width: 320px;
	}

	.topPane {
		flex-direction: column;
		padding: var(--spacing-md);
		text-align: center;
	}

	.topPane > div {
		width: 100%;
		justify-content: center;
	}

	.topDownloadButton {
		width: 100%;
		max-width: 280px;
	}

	.topPane a img {
		width: 40px;
		height: 40px;
	}

	.feedContainer {
		gap: var(--spacing-md);
	}

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

	.well {
		padding: var(--spacing-md);
		border-radius: var(--radius-lg);
		margin-bottom: var(--spacing-md);
	}

	.header {
		font-size: 1rem;
		padding: var(--spacing-md);
		margin: calc(var(--spacing-md) * -1);
		margin-bottom: var(--spacing-md);
	}

	table {
		font-size: 0.875rem;
		display: block;
		overflow-x: auto;
		white-space: nowrap;
		-webkit-overflow-scrolling: touch;
	}

	table td,
	table th {
		padding: var(--spacing-sm);
	}

	ul.linkbuttons {
		grid-template-columns: 1fr;
		gap: var(--spacing-sm);
	}

	ul.linkbuttons li a {
		padding: var(--spacing-md);
	}

	h1 { font-size: 1.875rem; }
	h2 { font-size: 1.5rem; }
	h3 { font-size: 1.25rem; }
	h4 { font-size: 1.125rem; }

	footer {
		padding: var(--spacing-lg);
		border-radius: var(--radius-lg);
	}

	footer p {
		font-size: 0.8125rem;
	}
}

/* ============================================
   MOBILE PORTRAIT (480px)
   ============================================ */
@media screen and (max-width: 480px) {
	.main {
		width: 95%;
		margin: 0.75rem auto;
	}

	.banner {
		height: 120px;
	}

	nav .container > div > ul > li > a {
		padding: 0.625rem 0.625rem;
		font-size: 0.75rem;
		gap: 0.25rem;
	}

	nav .container > div > ul > li > a i {
		font-size: 0.875rem;
	}

	.topPane {
		padding: var(--spacing-sm);
	}

	.topDownloadButton {
		padding: 0.625rem 1.5rem;
		font-size: 0.8125rem;
	}

	#countDownTimer {
		font-size: 1rem;
		padding: var(--spacing-xs) var(--spacing-md);
	}

	.well {
		padding: var(--spacing-sm);
		border-radius: var(--radius-md);
	}

	.header {
		font-size: 0.9375rem;
		padding: var(--spacing-sm);
		margin: calc(var(--spacing-sm) * -1);
		margin-bottom: var(--spacing-sm);
	}

	table {
		font-size: 0.8125rem;
	}

	table td,
	table th {
		padding: var(--spacing-xs) var(--spacing-sm);
	}

	input[type="text"],
	input[type="password"],
	input[type="email"],
	input[type="number"],
	textarea,
	select {
		padding: 0.75rem 0.875rem;
		font-size: 0.875rem;
	}

	button,
	input[type="submit"],
	input[type="button"],
	.submitButton {
		padding: 0.75rem 1.25rem;
		font-size: 0.875rem;
	}

	h1 { font-size: 1.5rem; }
	h2 { font-size: 1.25rem; }
	h3 { font-size: 1.125rem; }

	footer {
		padding: var(--spacing-md);
	}

	/* Recaptcha scaling */
	.g-recaptcha {
		transform: scale(0.85);
		transform-origin: 0 0;
	}
}

/* ============================================
   MOBILE SMALL (360px)
   ============================================ */
@media screen and (max-width: 360px) {
	.main {
		width: 98%;
	}

	.banner {
		height: 100px;
	}

	nav .container > div > ul {
		gap: 0;
	}

	nav .container > div > ul > li > a {
		padding: 0.5rem 0.5rem;
		font-size: 0.7rem;
	}

	.topPane a img {
		width: 32px;
		height: 32px;
	}

	.g-recaptcha {
		transform: scale(0.75);
		transform-origin: 0 0;
	}
}

/* ============================================
   LANDSCAPE MOBILE OPTIMIZATION
   ============================================ */
@media screen and (max-height: 500px) and (orientation: landscape) {
	.banner {
		height: 80px;
	}

	nav .container > div > ul > li > a {
		padding: 0.5rem 0.75rem;
	}

	.topPane {
		padding: var(--spacing-sm);
	}

	.well {
		margin-bottom: var(--spacing-sm);
	}
}

/* ============================================
   PRINT STYLES
   ============================================ */
@media print {
	body {
		background: white;
		color: black;
	}

	.banner,
	nav,
	.topPane,
	.rightPane,
	footer,
	.topDownloadButton {
		display: none;
	}

	.leftPane {
		width: 100%;
	}

	.well {
		border: 1px solid #ccc;
		box-shadow: none;
		page-break-inside: avoid;
	}

	a {
		color: black;
		text-decoration: underline;
	}
}

/* ============================================
   ACCESSIBILITY - 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;
	}

	.banner::before,
	.banner::after {
		animation: none !important;
	}
}

/* ============================================
   HIGH CONTRAST MODE
   ============================================ */
@media (prefers-contrast: high) {
	:root {
		--border-primary: rgba(59, 130, 246, 0.5);
		--border-secondary: rgba(255, 255, 255, 0.2);
		--glass-border: rgba(255, 255, 255, 0.3);
	}

	.well {
		border-width: 2px;
	}

	button,
	input[type="submit"],
	input[type="button"] {
		border-width: 3px;
	}
}

/* ============================================
   DARK MODE OPTIMIZATION (system preference)
   ============================================ */
@media (prefers-color-scheme: dark) {
	/* O tema já é dark por padrão, mas podemos intensificar */
	:root {
		--bg-primary: #000000;
		--bg-secondary: #0a0e1a;
	}
}

/* ============================================
   UTILITIES RESPONSIVAS
   ============================================ */

/* Hide on mobile */
@media screen and (max-width: 768px) {
	.hide-mobile {
		display: none !important;
	}
}

/* Hide on desktop */
@media screen and (min-width: 769px) {
	.hide-desktop {
		display: none !important;
	}
}

/* Text alignment responsivo */
@media screen and (max-width: 768px) {
	.text-center-mobile {
		text-align: center !important;
	}
}

/* Stack on mobile */
@media screen and (max-width: 768px) {
	.stack-mobile {
		flex-direction: column !important;
	}
	
	.stack-mobile > * {
		width: 100% !important;
		margin-left: 0 !important;
		margin-right: 0 !important;
	}
}
