/**
 * Archive Common — Shared styles for all custom archive pages.
 *
 * Includes:
 * - Mega title full-width breakout
 * - Pagination (desktop + mobile prev/current/next)
 * - Search bar centered
 * - No sidebar enforcement
 *
 * Used by: archive-fotogallery, archive-videogallery, taxonomy-video_playlist,
 *          taxonomy-fotogallery_tag, and any future archive templates.
 *
 * Body class requirement: .mega-title (added by template before get_header)
 */

/* =====================================================
   MEGA TITLE — full-width breakout from .content_wrap
   ===================================================== */
body.mega-title .olimpia-mega-title {
	width: 100vw;
	margin-left: calc(-50vw + 50%);
	max-width: none;
}

/* =====================================================
   NO SIDEBAR — generic enforcement
   Applies to archive pages with mega-title. Singular pages
   (e.g. Elementor-built pages) are excluded to avoid
   breaking Elementor container widths.
   ===================================================== */
body.mega-title:not(.single):not(.page) .sidebar,
body.mega-title:not(.single):not(.page) .widget-area,
body.mega-title:not(.single):not(.page) .sidebar_inner,
body.mega-title:not(.single):not(.page) aside.sidebar {
	display: none !important;
	width: 0 !important;
}

body.mega-title:not(.single):not(.page) .content_wrap > .content,
body.mega-title:not(.single):not(.page) .content_wrap .content {
	width: 100% !important;
	float: none !important;
	max-width: 100% !important;
	margin-right: 0 !important;
	padding-right: 0 !important;
}

/* =====================================================
   SEARCH BAR — centered, pill style
   ===================================================== */
.olimpia-archive-search {
	display: flex;
	justify-content: center;
	margin-bottom: 2rem;
	padding-top: 1.5rem;
}

.olimpia-archive-search__form {
	position: relative;
	width: 100%;
	max-width: 400px;
}

.olimpia-archive-search__icon {
	position: absolute;
	left: 14px;
	top: 50%;
	transform: translateY(-50%);
	color: #999;
	pointer-events: none;
}

.olimpia-archive-search__input {
	width: 100%;
	padding: 10px 14px 10px 42px;
	border: 1px solid var(--color-gray-200, #ccc);
	border-radius: var(--radius-pill, 50px);
	font-size: 14px;
	outline: none;
	transition: border-color 0.2s;
	background: var(--background-grey, #f5f5f5);
}

.olimpia-archive-search__input:focus {
	border-color: var(--color-primary, #AA1A2D);
	background: #fff;
}

.olimpia-archive-search__results {
	text-align: center;
	font-size: 14px;
	color: var(--color-gray-700, #555);
	margin-bottom: 1.5rem;
}

.olimpia-archive-search__clear {
	margin-left: 8px;
	color: var(--color-primary, #AA1A2D);
	text-decoration: none;
	font-weight: 600;
}

/* =====================================================
   PAGINATION — generic (any .olimpia-pagination nav)
   ===================================================== */
.olimpia-pagination {
	margin-top: 2.5rem;
	text-align: center;
}

.olimpia-pagination .page-numbers {
	list-style: none;
	display: flex;
	justify-content: center;
	align-items: center;
	gap: 6px;
	padding: 0;
	margin: 0;
}

.olimpia-pagination .page-numbers li {
	display: inline-block;
}

.olimpia-pagination .page-numbers a,
.olimpia-pagination .page-numbers span {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-width: 36px;
	height: 36px;
	padding: 0 10px;
	border-radius: 6px;
	font-size: 14px;
	font-weight: 600;
	text-decoration: none;
	color: var(--color-gray-700, #555);
	background: #fff;
	border: 1px solid var(--color-gray-200, #ccc);
	transition: all 0.2s ease;
}

.olimpia-pagination .page-numbers a:hover {
	background: var(--color-primary, #AA1A2D);
	color: #fff;
	border-color: var(--color-primary, #AA1A2D);
}

.olimpia-pagination .page-numbers .current {
	background: var(--color-primary, #AA1A2D);
	color: #fff;
	border-color: var(--color-primary, #AA1A2D);
}

.olimpia-pagination .page-numbers .dots {
	border: none;
	background: none;
	color: #999;
}

/* =====================================================
   PAGINATION MOBILE — prev / current / next only
   ===================================================== */
@media (max-width: 575px) {
	.olimpia-pagination .page-numbers li {
		display: none;
	}

	.olimpia-pagination .page-numbers li:has(.prev),
	.olimpia-pagination .page-numbers li:has(.next),
	.olimpia-pagination .page-numbers li:has(.current) {
		display: inline-block;
	}

	.olimpia-pagination .page-numbers li .prev,
	.olimpia-pagination .page-numbers li .next,
	.olimpia-pagination .page-numbers li .current {
		display: inline-flex;
	}
}
