/**
 * GeekNPlay - Mobile Responsive Enhancements
 * Version: 1.0.0
 * Renforce la stabilité CSS mobile et corrige les points fragiles
 * 
 * Hiérarchie des breakpoints:
 * - 320px - 479px: Ultra-small phones
 * - 480px - 639px: Small phones  
 * - 640px - 767px: Tablets verticaux
 * - 768px - 1023px: Tablets horizontaux
 * - 1024px+: Desktop
 */

/* ============================================
   0. FOUNDATION - Reset et normes mobiles
   ============================================ */

/* Assure que tout reste dans le viewport */
@media (max-width: 479px) {
	html {
		font-size: 15px;
	}
	
	body {
		overflow-x: hidden;
		overflow-y: auto;
	}
	
	* {
		max-width: 100vw;
	}
}

/* Fix pour containers qui débordent */
@media (max-width: 767px) {
	.gnp-container {
		width: min(100% - 1rem, var(--geeknplay-theme-container));
		margin-inline: auto;
	}
	
	/* Assure pas de débordement horizontal */
	body,
	html,
	.site-header,
	.site-main,
	.site-footer {
		overflow-x: hidden;
	}
	
	/* Désactif overflow sur les éléments positionnés */
	.site-header {
		width: 100vw;
		box-sizing: border-box;
	}
}

/* ============================================
   1. HEADER & NAVIGATION - Stabilité mobile
   ============================================ */

/* Ultra-petits écrans: 320px - 479px */
@media (max-width: 479px) {
	.site-branding {
		flex: 0 0 auto;
		min-width: 0;
	}
	
	.site-branding__link {
		font-size: 1rem;
		font-weight: 800;
	}
	
	.site-logo {
		max-height: 32px;
		width: auto;
	}
	
	.primary-menu {
		gap: 0.1rem 0.2rem;
		flex-wrap: wrap;
		justify-content: flex-start;
		padding: 0.2rem 0;
	}
	
	.primary-menu a {
		padding: 0.15rem 0.25rem;
		font-size: 0.6rem;
		font-weight: 600;
		white-space: nowrap;
		flex-shrink: 0;
	}
	
	.site-topbar__meta,
	.site-topbar__social {
		gap: 4px;
	}
	
	.site-topbar__social svg,
	.site-topbar__social a {
		width: 12px;
		height: 12px;
		min-width: 12px;
		min-height: 12px;
	}
	
	.site-topbar__inner {
		gap: 6px;
		padding: 0.4rem;
		flex-wrap: wrap;
	}
	
	.gnp-releases-compact__date,
	.gnp-releases-compact__title {
		font-size: 8px;
		padding: 0px 2px;
	}
	
	.search-toggle {
		padding: 4px;
		flex-shrink: 0;
	}
	
	.search-toggle svg {
		width: 16px;
		height: 16px;
	}
}

/* Petits téléphones: 480px - 639px */
@media (min-width: 480px) and (max-width: 639px) {
	.site-logo {
		max-height: 36px;
	}
	
	.primary-menu a {
		font-size: 0.65rem;
		padding: 0.2rem 0.3rem;
	}
	
	.site-topbar__meta {
		font-size: 0.7rem;
	}
}

/* Tablets verticaux: 640px - 767px */
@media (min-width: 640px) and (max-width: 767px) {
	.site-logo {
		max-height: 40px;
	}
	
	.primary-menu a {
		font-size: 0.75rem;
		padding: 0.25rem 0.35rem;
	}
	
	.site-topbar__meta {
		font-size: 0.8rem;
	}
}

/* ============================================
   2. ARCHIVE/GRID LAYOUTS - Grilles fluides
   ============================================ */

/* Ultra-petits: 1 colonne stricte */
@media (max-width: 479px) {
	.archive-grid {
		display: block;
		padding: 0;
		margin: 0;
	}
	
	.archive-grid > * {
		margin-bottom: 1rem;
	}
	
	.premium-grid {
		display: block;
		gap: 0;
		margin-top: 1rem;
	}
	
	.premium-grid > * {
		margin-bottom: 1rem;
	}
	
	.gnp-archive-grid {
		display: block;
		gap: 0;
	}
	
	.gnp-archive-grid > * {
		margin-bottom: 1rem;
	}
	
	.premium-card {
		border-radius: 12px;
		padding: 0;
		overflow: hidden;
	}
	
	.premium-card__image {
		padding-top: 56.25%;
		min-height: 180px;
	}
	
	.premium-card__content {
		padding: 12px;
	}
	
	.premium-card__title {
		font-size: 1rem;
		line-height: 1.2;
	}
	
	.premium-card__excerpt {
		font-size: 0.9rem;
		display: -webkit-box;
		-webkit-line-clamp: 2;
		line-clamp: 2;
		-webkit-box-orient: vertical;
	}
}

/* Petits phones: 480px - 639px */
@media (min-width: 480px) and (max-width: 639px) {
	.archive-grid {
		display: grid;
		grid-template-columns: 1fr;
		gap: 1rem;
	}
	
	.premium-grid {
		grid-template-columns: 1fr;
		gap: 1rem;
	}
	
	.gnp-archive-grid {
		display: grid;
		grid-template-columns: 1fr;
		gap: 1rem;
	}
}

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

/* ============================================
   3. CARDS & CONTENT - Aspect ratio stable
   ============================================ */

@media (max-width: 767px) {
	.premium-card {
		border-radius: 12px;
		overflow: hidden;
		box-shadow: 0 4px 12px rgba(0,0,0,0.1);
	}
	
	.premium-card__image {
		padding-top: 56.25%;
		position: relative;
		overflow: hidden;
		background: var(--geeknplay-theme-surface-alt);
	}
	
	.premium-card__image img {
		position: absolute;
		top: 0;
		left: 0;
		width: 100%;
		height: 100%;
		object-fit: cover;
		display: block;
	}
	
	.premium-card__content {
		padding: 12px;
		display: flex;
		flex-direction: column;
		min-height: auto;
	}
	
	.premium-card__title {
		font-size: 1rem;
		line-height: 1.2;
		margin: 0 0 6px 0;
		font-weight: 700;
	}
	
	.premium-card__excerpt {
		font-size: 0.9rem;
		display: -webkit-box;
		-webkit-line-clamp: 2;
		line-clamp: 2;
		-webkit-box-orient: vertical;
		overflow: hidden;
		color: var(--geeknplay-theme-muted);
	}
}

/* ============================================
   4. SINGLE ARTICLE - Responsif robuste
   ============================================ */

@media (max-width: 639px) {
	.single-article {
		padding: 1rem;
		border-radius: 12px;
		margin: 1rem 0;
	}
	
	.single-article__title {
		font-size: clamp(1.4rem, 8vw, 2rem);
		line-height: 1.15;
		margin-bottom: 0.75rem;
	}
	
	.single-article__excerpt {
		font-size: 0.95rem;
		line-height: 1.55;
		margin-bottom: 1rem;
	}
	
	.single-article__layout {
		grid-template-columns: 1fr;
		gap: 1rem;
	}
	
	.single-article__sidebar {
		position: static;
		top: auto;
	}
	
	.single-share-bar {
		display: none !important;
	}
	
	.entry-content {
		font-size: 1rem;
		line-height: 1.65;
	}
	
	.entry-content > * + * {
		margin-top: 1rem;
	}
}

@media (max-width: 479px) {
	.single-article {
		padding: 0.75rem;
		border-radius: 10px;
	}
	
	.single-article__title {
		font-size: clamp(1.2rem, 7vw, 1.8rem);
	}
	
	.entry-content {
		font-size: 0.95rem;
	}
}

/* ============================================
   5. HERO SECTION - Hauteur adaptée mobile
   ============================================ */

@media (max-width: 767px) {
	.single-hero {
		min-height: 280px;
		max-height: 50vh;
		border-radius: 10px;
		overflow: hidden;
		margin-bottom: 1rem;
	}
	
	.single-hero__inner {
		padding: 1.5rem 1rem;
		flex-direction: column;
		align-items: flex-start;
		justify-content: flex-end;
		gap: 0.75rem;
		min-height: 280px;
	}
	
	.single-hero__content {
		max-width: 100%;
		text-align: left;
	}
	
	.single-hero__title {
		font-size: clamp(1.2rem, 5vw, 1.8rem);
		line-height: 1.1;
		text-shadow: 0 4px 12px rgba(0,0,0,0.4);
		font-weight: 800;
	}
	
	.single-hero__meta {
		font-size: 0.9rem;
		gap: 0.4rem;
		justify-content: flex-start;
	}
	
	.single-hero::before {
		background: linear-gradient(180deg, rgba(0,0,0,0.1) 0%, rgba(0,0,0,0.35) 100%);
	}
}

@media (max-width: 479px) {
	.single-hero {
		min-height: 240px;
		margin-bottom: 0.75rem;
	}
	
	.single-hero__inner {
		padding: 1rem 0.75rem;
		min-height: 240px;
	}
}

/* ============================================
   6. PAGINATION - Compacte et accessible
   ============================================ */

@media (max-width: 767px) {
	.pagination {
		gap: 0.4rem;
		justify-content: center;
		flex-wrap: wrap;
	}
	
	.page-numbers {
		min-width: 36px;
		height: 36px;
		padding-inline: 0.6rem;
		font-size: 0.85rem;
	}
}

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

/* ============================================
   7. FOOTER - Adapté mobile
   ============================================ */

@media (max-width: 767px) {
	.site-footer__top {
		flex-direction: column;
		align-items: center;
		gap: 1.5rem;
		text-align: center;
	}
	
	.site-footer__nav {
		width: 100%;
		justify-content: center;
	}
	
	.footer-menu {
		flex-direction: column;
		gap: 0.75rem;
		align-items: center;
	}
	
	.site-footer__branding img {
		max-height: 32px;
	}
	
	.site-footer__social-bottom {
		gap: 10px;
	}
	
	.site-footer__social-bottom svg {
		width: 20px;
		height: 20px;
	}
}

/* ============================================
   8. AUTHOR BOX - Compact mobile
   ============================================ */

@media (max-width: 767px) {
	.single-author-box__inner {
		grid-template-columns: 1fr;
		gap: 1rem;
		padding: 1.25rem;
	}
	
	.single-author-box__avatar {
		width: 80px;
		justify-self: center;
	}
	
	.single-author-box__name {
		font-size: 1.15rem;
		text-align: center;
	}
	
	.single-author-box__bio {
		text-align: center;
		font-size: 0.9rem;
	}
	
	.single-author-box__social {
		justify-content: center;
	}
	
	.single-author-box__cta {
		align-self: center;
		width: 100%;
		justify-content: center;
	}
}

@media (max-width: 479px) {
	.single-author-box {
		margin: 1.5rem 0;
	}
	
	.single-author-box__avatar {
		width: 70px;
	}
	
	.single-author-box__avatar img {
		border-width: 2px;
	}
	
	.single-author-box__name {
		font-size: 1rem;
	}
}

/* ============================================
   9. RELATED ARTICLES - Responsive
   ============================================ */

@media (max-width: 767px) {
	.gnp-related__list {
		grid-template-columns: 1fr;
		gap: 1rem;
	}
	
	.gnp-related__item {
		display: flex;
		gap: 12px;
		align-items: flex-start;
	}
	
	.gnp-related__thumb {
		flex: 0 0 35%;
		padding-top: 0;
		padding-bottom: 62.5%;
		min-height: auto;
		border-radius: 8px;
		overflow: hidden;
	}
	
	.gnp-related__title {
		padding: 0.5rem 0;
		font-size: 0.95rem;
		flex: 1;
	}
}

@media (max-width: 479px) {
	.gnp-related {
		margin-top: 1.5rem;
	}
	
	.gnp-related__heading {
		font-size: 1rem;
		margin-bottom: 0.75rem;
	}
	
	.gnp-related__item {
		gap: 10px;
	}
	
	.gnp-related__thumb {
		flex: 0 0 30%;
	}
	
	.gnp-related__title {
		font-size: 0.9rem;
	}
}

/* ============================================
   10. COMMENTS - Adapté mobile
   ============================================ */

@media (max-width: 767px) {
	.single-comments {
		margin: 1.5rem 0;
		padding: 0;
	}
	
	.single-comments h2 {
		padding: 1.25rem 1rem 0.75rem 1rem;
		font-size: 1.25rem;
	}
	
	.comment-form {
		padding: 0 1rem 1.25rem 1rem;
	}
	
	.comment {
		padding: 1rem;
		margin-bottom: 1rem;
	}
	
	.children {
		padding-left: 1rem;
		margin-top: 1rem;
	}
	
	.comment-form textarea {
		min-height: 100px;
	}
}

@media (max-width: 479px) {
	.single-comments h2 {
		font-size: 1.1rem;
		padding: 1rem 0.75rem 0.5rem 0.75rem;
	}
	
	.comment-form,
	.comment-form input[type="text"],
	.comment-form input[type="email"],
	.comment-form input[type="url"],
	.comment-form textarea {
		padding: 0.75rem;
	}
	
	.comment {
		padding: 0.75rem;
	}
}

/* ============================================
   11. IMAGES & MEDIA - Optimisées mobile
   ============================================ */

@media (max-width: 767px) {
	.entry-content .wp-block-image.alignleft,
	.entry-content figure.alignleft,
	.entry-content img.alignleft {
		float: none !important;
		display: block !important;
		margin: 0 0 1rem 0 !important;
		max-width: 100% !important;
		width: 100% !important;
		aspect-ratio: 16 / 9;
	}
	
	.single-article__content .wp-block-image,
	.single-article__content figure,
	.single-article__content .article-image {
		position: static;
		width: 100%;
		margin: 1rem 0;
	}
	
	.single-article__content .wp-block-image img,
	.single-article__content figure img,
	.single-article__content .article-image img {
		position: static;
		width: 100%;
		height: auto;
		object-fit: contain;
	}
	
	.single-media-box {
		display: none;
	}
}

/* ============================================
   12. PERFORMANCE - Reduce animations on mobile
   ============================================ */

@media (max-width: 767px) and (prefers-reduced-motion: no-preference) {
	.premium-card,
	.gnp-home-grid__item .gnp-card,
	.gnp-related__item {
		transition: transform 180ms ease-out, box-shadow 180ms ease-out;
	}
	
	.premium-card:hover,
	.gnp-home-grid__item .gnp-card:hover,
	.gnp-related__item:hover {
		transform: translateY(-3px);
	}
}

@media (prefers-reduced-motion: reduce) {
	.premium-card,
	.gnp-home-grid__item .gnp-card,
	.gnp-related__item,
	.single-hero,
	.single-author-box {
		transition: none !important;
		animation: none !important;
	}
	
	.premium-card:hover,
	.gnp-home-grid__item .gnp-card:hover,
	.gnp-related__item:hover {
		transform: none !important;
	}
}

/* ============================================
   13. TOUCH-FRIENDLY ELEMENTS
   ============================================ */

@media (max-width: 767px) and (hover: none) and (pointer: coarse) {
	/* Augmente les zones clickables sur touch */
	.button-primary,
	.page-numbers,
	.single-author-box__cta,
	.comment-reply-link {
		padding: 0.75rem 1.25rem;
		min-height: 44px;
		display: inline-flex;
		align-items: center;
	}
	
	.single-author-box__social-link,
	.single-share-bar__link {
		min-width: 48px;
		min-height: 48px;
	}
	
	/* Désactif hover sur touch, activate sur click */
	.premium-card:hover {
		transform: none;
	}
}

/* ============================================
   14. SEARCH - Mobile overlay
   ============================================ */

@media (max-width: 767px) {
	.search-form {
		position: fixed;
		top: 50%;
		left: 50%;
		transform: translate(-50%, -50%) scale(0.95);
		opacity: 0;
		pointer-events: none;
		background: var(--geeknplay-theme-surface);
		padding: 1.25rem;
		border-radius: 12px;
		border: 1px solid var(--geeknplay-theme-border);
		z-index: 1000;
		box-shadow: 0 10px 40px rgba(0,0,0,0.2);
		width: 90vw;
		max-width: 400px;
	}
	
	.search-container.active .search-form {
		opacity: 1;
		pointer-events: auto;
		transform: translate(-50%, -50%) scale(1);
	}
	
	.search-field {
		width: 100%;
		padding: 0.75rem 1rem;
		font-size: 16px;
		border: 1px solid var(--geeknplay-theme-border);
		background: var(--geeknplay-theme-surface-alt);
		color: var(--geeknplay-theme-text);
		border-radius: 8px;
	}
}

/* ============================================
   15. TEXT CONTENT - Lisibilité mobile
   ============================================ */

@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;
		line-height: 1.15;
	}
	
	.entry-content p {
		font-size: 0.95rem;
		line-height: 1.65;
	}
}

/* ============================================
   UTILITY CLASSES - Helper responsive
   ============================================ */

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

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

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

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