/**
 * GNP-Core - Mobile Responsive Enhancements
 * Version: 1.0.0
 * Renforce la stabilité CSS mobile des composants du plugin core
 * 
 * Breakpoints cohérents:
 * - 320px - 479px: Ultra-small phones
 * - 480px - 639px: Small phones  
 * - 640px - 767px: Tablets verticaux
 * - 768px - 1023px: Tablets horizontaux
 * - 1024px+: Desktop
 */

/* ============================================
   0. FOUNDATION - Reset mobile-first
   ============================================ */

@media (max-width: 479px) {
	html {
		font-size: 15px;
	}
	
	body {
		overflow-x: hidden;
	}
}

/* ============================================
   1. HOME SECTION - Responsive robuste
   ============================================ */

@media (max-width: 639px) {
	.gnp-home-section {
		margin: 0 -0.5rem;
		padding: 1rem;
		border-radius: 12px;
		box-shadow: 0 4px 12px rgba(0,0,0,0.1);
	}
	
	.gnp-home-section__header {
		gap: 0.75rem;
		margin-bottom: 1rem;
		flex-wrap: wrap;
	}
	
	.gnp-home-section__title {
		font-size: clamp(1.1rem, 5vw, 1.4rem);
		line-height: 1.15;
		margin: 0;
	}
	
	.gnp-home-section__intro {
		font-size: 0.9rem;
		max-width: 100%;
		margin-top: 0.5rem;
		line-height: 1.55;
	}
	
	.gnp-home-section__link {
		padding: 0.6rem 0.9rem;
		font-size: 0.85rem;
		align-self: flex-start;
	}
}

@media (max-width: 479px) {
	.gnp-home-section {
		margin: 0;
		padding: 0.75rem;
		border-radius: 10px;
	}
	
	.gnp-home-section__heading {
		min-width: 0;
	}
	
	.gnp-home-section__title {
		font-size: clamp(1rem, 4vw, 1.2rem);
	}
}

/* ============================================
   2. HOME GRID - Grilles fluides et stables
   ============================================ */

/* Ultra-petits: 320px - 479px */
@media (max-width: 479px) {
	.gnp-home-grid {
		display: grid;
		grid-template-columns: 1fr;
		gap: 0.75rem;
	}
	
	.gnp-home-grid .gnp-card {
		height: auto;
		min-height: 280px;
		display: flex;
		flex-direction: column;
		border-radius: 12px;
		overflow: hidden;
		padding: 0;
	}
	
	.gnp-home-grid .gnp-card__media {
		aspect-ratio: 16 / 9;
		min-height: 150px;
		overflow: hidden;
		background: var(--gnp-color-media-bg);
	}
	
	.gnp-home-grid .gnp-card__media img {
		width: 100%;
		height: 100%;
		object-fit: cover;
		display: block;
	}
	
	.gnp-home-grid .gnp-card__body {
		padding: 0.75rem;
		display: flex;
		flex-direction: column;
		gap: 0.5rem;
	}
	
	.gnp-home-grid .gnp-card__title {
		font-size: 0.95rem;
		line-height: 1.2;
		margin: 0;
		display: -webkit-box;
		-webkit-line-clamp: 2;
		line-clamp: 2;
		-webkit-box-orient: vertical;
		overflow: hidden;
	}
	
	.gnp-home-grid .gnp-card__excerpt {
		font-size: 0.85rem;
		display: -webkit-box;
		-webkit-line-clamp: 2;
		line-clamp: 2;
		-webkit-box-orient: vertical;
		overflow: hidden;
	}
}

/* Petits phones: 480px - 639px */
@media (min-width: 480px) and (max-width: 639px) {
	.gnp-home-grid {
		grid-template-columns: repeat(2, 1fr);
		gap: 0.75rem;
	}
	
	.gnp-home-grid .gnp-card {
		height: auto;
		min-height: 260px;
	}
	
	.gnp-home-grid .gnp-card__media {
		min-height: 130px;
	}
	
	.gnp-home-grid .gnp-card__title {
		font-size: 0.95rem;
	}
	
	.gnp-home-grid .gnp-card__excerpt {
		font-size: 0.85rem;
	}
}

/* Tablets: 640px - 767px */
@media (min-width: 640px) and (max-width: 767px) {
	.gnp-home-grid {
		grid-template-columns: repeat(3, 1fr);
		gap: 1rem;
	}
	
	.gnp-home-grid .gnp-card {
		height: auto;
		min-height: 280px;
	}
}

/* ============================================
   3. HOME LIST - Responsive responsable
   ============================================ */

@media (max-width: 639px) {
	.gnp-home-list {
		gap: 0.75rem;
	}
	
	.gnp-home-list__item .gnp-card {
		display: flex;
		flex-direction: column;
		padding: 0;
		gap: 0;
		border-radius: 12px;
		overflow: hidden;
		min-height: auto;
	}
	
	.gnp-home-list__item .gnp-card__media {
		flex: 0 0 auto;
		width: 100%;
		aspect-ratio: 16 / 9;
		min-height: 180px;
		background: var(--gnp-color-media-bg);
		border-radius: 0;
		overflow: hidden;
	}
	
	.gnp-home-list__item .gnp-card__media img {
		width: 100%;
		height: 100%;
		object-fit: cover;
		display: block;
	}
	
	.gnp-home-list__item .gnp-card__body {
		padding: 0.75rem;
		flex: 1;
	}
	
	.gnp-home-list__item .gnp-card__title {
		font-size: 0.95rem;
		margin: 0 0 0.4rem 0;
		display: -webkit-box;
		-webkit-line-clamp: 2;
		line-clamp: 2;
		-webkit-box-orient: vertical;
	}
	
	.gnp-home-list__item .gnp-card__excerpt {
		font-size: 0.85rem;
		display: -webkit-box;
		-webkit-line-clamp: 1;
		line-clamp: 1;
		-webkit-box-orient: vertical;
	}
}

@media (max-width: 479px) {
	.gnp-home-list__item .gnp-card {
		margin-bottom: 0.75rem;
	}
	
	.gnp-home-list__item .gnp-card__media {
		min-height: 150px;
	}
	
	.gnp-home-list__item .gnp-card__body {
		padding: 0.6rem;
	}
}

/* ============================================
   4. FEATURED GRID LAYOUT
   ============================================ */

@media (max-width: 639px) {
	.gnp-home-section__grid {
		display: grid;
		grid-template-columns: 1fr;
		gap: 0.75rem;
	}
	
	.gnp-home-section__grid > .gnp-card--featured {
		grid-row: auto;
		grid-column: auto;
		min-height: 280px;
	}
	
	.gnp-home-section__grid > .gnp-card {
		min-height: 240px;
	}
}

/* ============================================
   5. COMPACT CARDS - Inline layout
   ============================================ */

@media (max-width: 639px) {
	.gnp-home-list__item .gnp-card--compact {
		grid-template-columns: 1fr;
	}
	
	.gnp-card--compact {
		display: grid;
		grid-template-columns: 1fr;
		gap: 0;
	}
	
	.gnp-card--compact .gnp-card__media {
		flex: 0 0 auto;
		width: 100%;
		aspect-ratio: 16 / 9;
		min-height: 140px;
	}
}

/* ============================================
   6. FEATURED CARD - Large + responsive
   ============================================ */

@media (max-width: 479px) {
	.gnp-card--featured {
		aspect-ratio: auto;
		min-height: 320px;
	}
	
	.gnp-card--featured .gnp-card__media {
		aspect-ratio: 16 / 9;
		min-height: 180px;
	}
	
	.gnp-card--featured .gnp-card__title {
		font-size: 1.1rem;
		line-height: 1.2;
	}
	
	.gnp-card--featured .gnp-card__body {
		padding: 1rem;
	}
}

/* ============================================
   7. CARD BASE STYLES - Stability
   ============================================ */

@media (max-width: 767px) {
	.gnp-card {
		background: var(--gnp-color-surface);
		border: 1px solid var(--gnp-color-border);
		border-radius: 12px;
		overflow: hidden;
		box-shadow: 0 2px 8px rgba(0,0,0,0.08);
		transition: box-shadow 180ms ease, transform 180ms ease;
		display: flex;
		flex-direction: column;
		height: 100%;
	}
	
	.gnp-card:active {
		transform: translateY(-2px);
		box-shadow: 0 6px 16px rgba(0,0,0,0.12);
	}
	
	/* Disable 3D transforms on touch devices for better perf */
	@media (hover: none) and (pointer: coarse) {
		.gnp-card {
			will-change: auto;
		}
		
		.gnp-card:active {
			transform: scale(0.98);
		}
	}
}

/* ============================================
   8. PAGINATION - Responsive et accessible
   ============================================ */

@media (max-width: 767px) {
	.pagination {
		display: flex;
		gap: 0.4rem;
		flex-wrap: wrap;
		justify-content: center;
		margin-top: 1.5rem;
	}
	
	.page-numbers {
		display: inline-flex;
		align-items: center;
		justify-content: center;
		min-width: 36px;
		height: 36px;
		padding-inline: 0.6rem;
		border-radius: 999px;
		border: 1px solid var(--gnp-color-border);
		background: var(--gnp-color-surface);
		color: var(--gnp-color-text);
		font-size: 0.9rem;
		transition: all 180ms ease;
		text-decoration: none;
	}
	
	.page-numbers.current {
		background: var(--gnp-color-primary);
		color: #fff;
		border-color: var(--gnp-color-primary);
	}
}

@media (max-width: 479px) {
	.pagination {
		gap: 0.3rem;
	}
	
	.page-numbers {
		min-width: 32px;
		height: 32px;
		padding-inline: 0.5rem;
		font-size: 0.85rem;
	}
}

/* ============================================
   9. ARCHIVE SECTION - Stable & fluid
   ============================================ */

@media (max-width: 767px) {
	.gnp-archive-section {
		margin: 0;
		padding: 0;
	}
	
	.gnp-archive-grid {
		display: grid;
		grid-template-columns: 1fr;
		gap: 1rem;
	}
	
	.gnp-archive-grid .premium-card {
		border-radius: 12px;
		overflow: hidden;
		box-shadow: 0 4px 12px rgba(0,0,0,0.1);
	}
	
	.gnp-archive-grid .premium-card--featured {
		grid-column: auto;
		grid-row: auto;
	}
}

@media (min-width: 640px) and (max-width: 767px) {
	.gnp-archive-grid {
		grid-template-columns: repeat(2, 1fr);
		gap: 1rem;
	}
	
	.gnp-archive-grid .premium-card--featured {
		grid-column: 1 / -1;
	}
}

/* ============================================
   10. IMAGE SIZING - Consistent & fluid
   ============================================ */

@media (max-width: 767px) {
	.gnp-card__media,
	.gnp-home-grid__item .gnp-card__media,
	.gnp-home-list__item .gnp-card__media {
		aspect-ratio: 16 / 9;
		width: 100%;
		overflow: hidden;
		background: var(--gnp-color-media-bg);
		position: relative;
	}
	
	.gnp-card__media img,
	.gnp-home-grid__item .gnp-card__media img,
	.gnp-home-list__item .gnp-card__media img {
		width: 100%;
		height: 100%;
		object-fit: cover;
		display: block;
	}
}

/* ============================================
   11. TOUCH OPTIMIZATIONS
   ============================================ */

@media (max-width: 767px) and (hover: none) and (pointer: coarse) {
	/* Increase touch targets */
	.gnp-home-section__link,
	.button-primary,
	.page-numbers {
		min-height: 44px;
		min-width: 44px;
		padding: 0.7rem 1.2rem;
	}
	
	/* Remove hover transforms on touch */
	.gnp-card:hover {
		transform: none;
	}
	
	.gnp-card:active {
		transform: scale(0.98);
		box-shadow: 0 6px 16px rgba(0,0,0,0.12);
	}
	
	/* Increase spacing between clickable elements */
	.gnp-home-grid {
		gap: 1rem;
	}
	
	.gnp-home-list {
		gap: 1rem;
	}
}

/* ============================================
   12. PERFORMANCE - Reduced animations
   ============================================ */

@media (prefers-reduced-motion: reduce) {
	.gnp-card,
	.gnp-home-grid__item .gnp-card,
	.gnp-card__media img,
	.page-numbers {
		transition: none !important;
		animation: none !important;
	}
	
	.gnp-card:hover,
	.gnp-card:active {
		transform: none !important;
	}
}

/* Light animations only on high-end mobile */
@media (max-width: 767px) and (prefers-reduced-motion: no-preference) {
	.gnp-card {
		transition: box-shadow 150ms ease, transform 150ms ease-out;
	}
	
	.gnp-card:active {
		transition: box-shadow 100ms ease, transform 100ms ease-out;
	}
}

/* ============================================
   13. OVERFLOW PREVENTION
   ============================================ */

@media (max-width: 767px) {
	/* Prevent any element from causing horizontal scroll */
	.site-main,
	.gnp-container,
	.gnp-home-section,
	.gnp-archive-grid {
		overflow-x: hidden;
		max-width: 100%;
	}
	
	/* Ensure images don't overflow */
	img {
		max-width: 100%;
		height: auto;
		display: block;
	}
	
	/* Fix for nested grids */
	.gnp-home-grid,
	.gnp-home-list {
		max-width: 100%;
		overflow-x: hidden;
	}
}

/* ============================================
   14. TEXT & TYPOGRAPHY - Mobile optimized
   ============================================ */

@media (max-width: 479px) {
	body {
		line-height: 1.6;
		word-break: break-word;
		hyphens: auto;
	}
	
	h1, h2, h3, h4, h5, h6 {
		word-break: break-word;
		hyphens: auto;
	}
	
	.gnp-home-section__title {
		word-break: break-word;
	}
	
	.gnp-card__title,
	.gnp-home-grid__item .gnp-card__title {
		overflow: hidden;
		display: -webkit-box;
		-webkit-line-clamp: 2;
		line-clamp: 2;
		-webkit-box-orient: vertical;
	}
	
	.gnp-card__excerpt,
	.gnp-home-grid__item .gnp-card__excerpt {
		display: -webkit-box;
		-webkit-line-clamp: 1;
		line-clamp: 1;
		-webkit-box-orient: vertical;
	}
}

/* ============================================
   15. SPACING CONSISTENCY - Mobile-first
   ============================================ */

@media (max-width: 639px) {
	.gnp-stack {
		padding-block: 1rem 1.5rem;
	}
	
	.gnp-home-section {
		margin-bottom: 1rem;
	}
	
	.gnp-home-grid,
	.gnp-home-list {
		margin: 1rem 0;
	}
}

@media (max-width: 479px) {
	.gnp-stack {
		padding-block: 0.75rem 1rem;
	}
	
	.gnp-home-section {
		margin-bottom: 0.75rem;
	}
	
	.gnp-home-grid,
	.gnp-home-list {
		margin: 0.75rem 0;
		gap: 0.5rem;
	}
}

/* ============================================
   UTILITY CLASSES
   ============================================ */

.gnp-hide-mobile {
	display: none !important;
}

.gnp-show-mobile {
	display: block !important;
}

@media (min-width: 768px) {
	.gnp-hide-mobile {
		display: block !important;
	}
	
	.gnp-show-mobile {
		display: none !important;
	}
}

/* Prevent layout shift */
@media (max-width: 767px) {
	html {
		scrollbar-gutter: stable;
	}
}
