/**
 * Maya Recipes Posts Widget Styles
 *
 * Responsive grid layout with AJAX pagination.
 * Card design: Image on top, title on right + button on left (RTL).
 *
 * @package MayaPlugin
 */

/* ==========================================================================
   CSS Variables
   ========================================================================== */

.mw-rp-wrapper {
	--mw-rp-gap: 24px;
	--mw-rp-button-color: #CD9C71;
	--mw-rp-text-color: #000000;
	--mw-rp-loader-color: #CD9C71;
	--mw-rp-loader-size: 80px;
	position: relative;
}

/* ==========================================================================
   Grid Layout
   ========================================================================== */

.mw-rp-grid {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: var(--mw-rp-gap);
	width: 100%;
}

/* Center last row when not full */
.mw-rp-grid--center-last {
	justify-items: center;
}

.mw-rp-grid--center-last > .mw-rp-card {
	width: 100%;
	max-width: 100%;
}

/* ==========================================================================
   Card Styles
   ========================================================================== */

.mw-rp-card {
	display: flex;
	flex-direction: column;
	gap: 12px;
}

.mw-rp-card__link {
	display: block;
	text-decoration: none;
	width: 100%;
}

.mw-rp-card__image-wrapper {
	width: 100%;
	height: 200px;
	border-radius: 20px;
	overflow: hidden;
	background-color: #f5f5f5;
}

.mw-rp-card__image {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
	transition: transform 0.3s ease;
}

.mw-rp-card__link:hover .mw-rp-card__image {
	transform: scale(1.05);
}

.mw-rp-card__link:focus {
	outline: none;
}

.mw-rp-card__link:focus-visible .mw-rp-card__image-wrapper {
	outline: 2px solid var(--mw-rp-button-color);
	outline-offset: 2px;
}

/* Editor placeholder */
.mw-rp-card__image-placeholder {
	width: 100%;
	height: 100%;
	background: linear-gradient(135deg, #f5f5f5 0%, #e0e0e0 100%);
}

/* Content area - RTL: title on right, button on left */
.mw-rp-card__content {
	display: flex;
	flex-direction: row;
	align-items: center;
	justify-content: space-between;
	gap: 12px;
}

/* Title comes first in DOM, appears on right in RTL */
.mw-rp-card__title {
	font-size: 18px;
	font-weight: 400;
	line-height: 1.4;
	color: var(--mw-rp-text-color);
	margin: 0;
	flex: 1;
	text-align: right;
	order: 1;
}

/* Button comes second in DOM, appears on left in RTL */
.mw-rp-button {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	padding: 8px 30px;
	background-color: var(--mw-rp-button-color);
	color: #FFFFFF;
	font-size: 14px;
	font-weight: 500;
	text-decoration: none;
	border-radius: 38px;
	transition: background-color 0.2s ease, transform 0.2s ease;
	white-space: nowrap;
	box-shadow: 0 8px 20px rgba(48, 38, 34, 0.15);
	flex-shrink: 0;
	order: 2;
}

.mw-rp-button:hover {
	background-color: #B8885C;
}

.mw-rp-button:focus {
	outline: none;
}

.mw-rp-button:focus-visible {
	outline: 2px solid var(--mw-rp-button-color);
	outline-offset: 2px;
}

.mw-rp-button:active {
	transform: scale(0.98);
}

/* ==========================================================================
   Pagination Styles - Dots with Arrows (Elementor-style approach)
   ========================================================================== */

.mw-rp-pagination {
	position: relative;
	text-align: center;
	margin-top: 40px;
	direction: rtl;
}

/* Dots container */
.mw-rp-pagination__dots {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	vertical-align: middle;
}

/* Pagination dot - Elementor/Swiper style: inline-block with direct sizing */
.mw-rp-pagination__dot {
	width: 26px;
	height: 26px;
	display: inline-block;
	border-radius: 50%;
	background-color: rgba(0, 0, 0, 0.1);
	opacity: 1;
	cursor: pointer;
	transition: background-color 0.2s ease, transform 0.2s ease;
}

/* Button element reset - critical for preventing stretch */
button.mw-rp-pagination__dot {
	border: none;
	margin: 0;
	padding: 0;
	box-shadow: none;
	-webkit-appearance: none;
	appearance: none;
}

.mw-rp-pagination__dot:hover:not(:disabled):not(.is-active) {
	background-color: rgba(0, 0, 0, 0.2);
}

.mw-rp-pagination__dot:focus {
	outline: none;
}

.mw-rp-pagination__dot:focus-visible {
	outline: 2px solid var(--mw-rp-button-color);
	outline-offset: 2px;
}

.mw-rp-pagination__dot.is-active {
	background-color: var(--mw-rp-button-color);
	transform: scale(1.15);
	cursor: default;
}

.mw-rp-pagination__dot:disabled {
	cursor: default;
}

/* Arrow buttons - Elementor style: inline-flex with font-size based icon scaling */
.mw-rp-pagination__arrow {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 58px;
	height: 58px;
	border-radius: 50%;
	background-color: #FFFFFF;
	cursor: pointer;
	font-size: 20px;
	color: #302622;
	vertical-align: middle;
	transition: background-color 0.2s ease, opacity 0.2s ease, box-shadow 0.2s ease;
}

/* Button element reset for arrows */
button.mw-rp-pagination__arrow {
	border: none;
	margin: 0;
	padding: 0;
	-webkit-appearance: none;
	appearance: none;
}

.mw-rp-pagination__arrow:hover:not(:disabled) {
	background-color: #F5F5F5;
}

.mw-rp-pagination__arrow:disabled {
	opacity: 0.4;
	cursor: not-allowed;
}

.mw-rp-pagination__arrow:focus {
	outline: none;
}

.mw-rp-pagination__arrow:focus-visible {
	outline: 2px solid var(--mw-rp-button-color);
	outline-offset: 2px;
}

/* Arrow icon styling - scales with font-size (1em = parent font-size) */
.mw-rp-pagination__arrow i {
	line-height: 1;
}

.mw-rp-pagination__arrow svg {
	fill: currentColor;
	height: 1em;
	width: 1em;
}

.mw-rp-pagination__arrow:disabled {
	color: #999999;
}

.mw-rp-pagination__arrow:disabled svg {
	fill: #999999;
}

/* ==========================================================================
   Loading State - Bouncing Balls Animation
   ========================================================================== */

.mw-rp-loading {
	position: absolute;
	inset: 0;
	display: flex;
	align-items: center;
	justify-content: center;
	background-color: rgba(255, 255, 255, 0.8);
	z-index: 100;
}

.mw-rp-loading__spinner {
	display: flex;
	align-items: center;
	justify-content: center;
	color: var(--mw-rp-loader-color);
}

.mw-rp-loading__svg {
	width: var(--mw-rp-loader-size);
	height: var(--mw-rp-loader-size);
}

/* ==========================================================================
   Empty State
   ========================================================================== */

.mw-rp-empty {
	padding: 60px 20px;
	text-align: center;
	background: #f9f9f9;
	border-radius: 12px;
}

.mw-rp-empty p {
	margin: 0;
	color: #666;
	font-size: 16px;
}

/* ==========================================================================
   Tablet Styles (768px - 1024px)
   ========================================================================== */

@media screen and (max-width: 1024px) {
	.mw-rp-grid {
		grid-template-columns: repeat(2, 1fr);
		gap: 20px;
	}

	.mw-rp-card__image-wrapper {
		height: 180px;
	}

	.mw-rp-card__title {
		font-size: 16px;
	}

	.mw-rp-button {
		padding: 7px 24px;
		font-size: 13px;
	}
}

/* ==========================================================================
   Mobile Styles (< 768px)
   ========================================================================== */

@media screen and (max-width: 767px) {
	.mw-rp-grid {
		grid-template-columns: 1fr;
		gap: 16px;
	}

	.mw-rp-card__image-wrapper {
		height: 200px;
	}

	.mw-rp-card__title {
		font-size: 16px;
	}

	.mw-rp-button {
		padding: 7px 20px;
		font-size: 13px;
	}

	/* Pagination mobile: arrows only, hide dots */
	.mw-rp-pagination {
		margin-top: 30px;
	}

	.mw-rp-pagination__dots {
		display: none;
	}

	/* Reduce arrow gap on mobile since dots are hidden */
	.mw-rp-pagination__arrow {
		margin-left: 20px;
		margin-right: 20px;
	}
}

/* ==========================================================================
   Accessibility - Reduced Motion
   ========================================================================== */

@media (prefers-reduced-motion: reduce) {
	.mw-rp-card__image,
	.mw-rp-button,
	.mw-rp-pagination__dot,
	.mw-rp-pagination__arrow {
		transition: none;
	}

	.mw-rp-card__link:hover .mw-rp-card__image {
		transform: none;
	}

	.mw-rp-pagination__dot.is-active {
		transform: none;
	}

	/* Disable bouncing animation for reduced motion */
	.mw-rp-loading__svg circle animate {
		animation: none;
	}
}

/* ==========================================================================
   Print Styles
   ========================================================================== */

@media print {
	.mw-rp-pagination {
		display: none;
	}

	.mw-rp-button {
		display: none;
	}

	.mw-rp-loading {
		display: none !important;
	}
}
