/* ==========================================================================
   Mavi Special Offer Slider - Frontend Styles

   نکته: این پلاگین عمداً قوانین reset/defensive (all:unset روی برخی موارد،
   box-sizing صریح، width صریح) دارد تا استایل‌های عمومی تم/پلاگین‌های
   دیگر (که معمولاً روی img، a، button، ul/li ست می‌شوند) آن را به‌هم
   نریزند، چون این پلاگین قرار است روی سایت‌های مختلف با تم‌های مختلف
   به‌درستی کار کند.
   ========================================================================== */

.mavi-sos-wrapper,
.mavi-sos-wrapper * {
	box-sizing: border-box;
}

.mavi-sos-wrapper {
	--mavi-sos-slides-desktop: 4;
	--mavi-sos-slides-tablet: 3;
	--mavi-sos-slides-mobile: 2;
	--mavi-sos-slides: var(--mavi-sos-slides-desktop);
	--mavi-sos-gap: 16px;

	display: flex !important;
	align-items: center;
	gap: 24px;
	width: 100%;
	max-width: 100%;
	overflow: hidden;
	list-style: none;
}

.mavi-sos-wrapper.mavi-sos-sidebar-left {
	flex-direction: row-reverse;
}

.mavi-sos-slider-col {
	flex: 1 1 auto;
	min-width: 0;
	width: 100%;
	display: flex;
	flex-direction: column;
}

/* ---------- Sidebar ---------- */
.mavi-sos-sidebar {
	flex: 0 0 auto;
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	text-align: center;
	gap: 6px;
	min-width: 160px;
	padding: 0 10px;
	margin: 0;
}

.mavi-sos-logo-small,
.mavi-sos-logo-large {
	margin: 0;
	padding: 0;
	max-width: 100%;
}

.mavi-sos-logo-small img,
.mavi-sos-logo-large img {
	display: block;
	margin: 0 auto;
	height: auto;
	max-width: 100%;
}

.mavi-sos-title {
	line-height: 1.5;
	white-space: pre-line;
	margin: 0;
}

.mavi-sos-view-all {
	display: inline-flex;
	align-items: center;
	gap: 6px;
	text-decoration: none;
	font-size: 14px;
	opacity: 0.95;
	white-space: nowrap;
}

.mavi-sos-view-all svg {
	flex-shrink: 0;
}

.mavi-sos-view-all-desktop {
	margin-top: 10px;
}

/* دکمه «مشاهده همه» مخصوص موبایل؛ در دسکتاپ مخفی است چون نسخه‌ی
   داخل نوار عنوان (mavi-sos-view-all-desktop) همان نقش را دارد */
.mavi-sos-view-all-mobile {
	display: none !important;
}

/* ---------- Slider ---------- */
.mavi-sos-slider {
	position: relative;
	display: flex !important;
	align-items: center;
	min-width: 0;
	width: 100%;
	margin: 0;
	padding: 0;
}

.mavi-sos-track-wrap {
	overflow: hidden;
	flex: 1 1 auto;
	min-width: 0;
	width: 100%;
	margin: 0;
	padding: 0;
}

.mavi-sos-track {
	display: flex !important;
	gap: var(--mavi-sos-gap);
	will-change: transform;
	margin: 0;
	padding: 0;
	list-style: none;
}

.mavi-sos-slide {
	flex: 0 0 calc((100% - (var(--mavi-sos-slides) - 1) * var(--mavi-sos-gap)) / var(--mavi-sos-slides));
	width: calc((100% - (var(--mavi-sos-slides) - 1) * var(--mavi-sos-gap)) / var(--mavi-sos-slides));
	max-width: calc((100% - (var(--mavi-sos-slides) - 1) * var(--mavi-sos-gap)) / var(--mavi-sos-slides));
	margin: 0;
	padding: 0;
}

/* ---------- Card ---------- */
.mavi-sos-card {
	display: block;
	text-decoration: none;
	background-color: #ffffff;
	border-radius: 12px;
	overflow: hidden;
	height: 100%;
	margin: 0;
	box-shadow: none;
	border: none;
}

.mavi-sos-card-thumb {
	position: relative;
	padding: 14px;
}

.mavi-sos-card-thumb img {
	width: 100%;
	height: auto;
	display: block;
	margin: 0 auto;
	border-radius: 7px;
	max-width: 100%;
}

.mavi-sos-badge {
	position: absolute;
	top: 10px;
	left: 10px;
	right: auto;
	background: linear-gradient(135deg, #c62828, #b71c1c);
	color: #ffffff;
	font-size: 12px;
	font-weight: 700;
	line-height: 1.3;
	padding: 5px 9px;
	border-radius: 6px;
	z-index: 4;
	margin: 0;
	box-shadow: 0 2px 6px rgba(0, 0, 0, 0.25);
	transform-origin: top left;
	white-space: nowrap;
	text-align: center;
}

.mavi-sos-card-body {
	padding: 0 12px 16px;
	text-align: center;
}

.mavi-sos-card-title {
	color: #b4982b;
	font-size: 15px;
	font-weight: 600;
	margin-bottom: 8px;
	min-height: 42px;
	display: -webkit-box;
	-webkit-line-clamp: 2;
	-webkit-box-orient: vertical;
	overflow: hidden;
}

.mavi-sos-price {
	font-size: 14px;
	line-height: 1.7;
	margin: 0;
}

.mavi-sos-price .price {
	display: block;
	margin: 0;
}

.mavi-sos-price del {
	color: #b4982b;
	opacity: 0.8;
	text-decoration: line-through;
	display: block;
}

.mavi-sos-price ins {
	color: #e2231a;
	text-decoration: none;
	display: block;
	font-weight: 600;
}

.mavi-sos-add-to-cart {
	padding: 0 12px 14px;
	text-align: center;
}

.mavi-sos-add-to-cart a {
	display: inline-block;
	width: 100%;
	background-color: #b4982b;
	color: #ffffff;
	text-decoration: none;
	padding: 8px 10px;
	border-radius: 8px;
	font-size: 13px;
	transition: opacity 0.2s ease;
	border: none;
	margin: 0;
}

.mavi-sos-add-to-cart a:hover {
	opacity: 0.85;
	color: #ffffff;
}

/* ---------- Arrows ----------
   فلش‌ها position: absolute دارند تا هیچ فضایی در چیدمان فلکس اشغال
   نکنند (نه gap، نه عرض اضافه)؛ دقیقاً روی لبه‌ی تصویر کارت‌ها سوار
   می‌شوند و فقط وقتی موس روی کل ناحیه‌ی اسلایدر باشد نمایان می‌شوند. */
.mavi-sos-arrow {
	position: absolute;
	top: 50%;
	width: 38px;
	height: 38px;
	margin: 0;
	padding: 0;
	transform: translateY(-50%);
	border-radius: 50%;
	border: none;
	background-color: #ffffff;
	color: #111111;
	display: flex !important;
	align-items: center;
	justify-content: center;
	cursor: pointer;
	z-index: 5;
	opacity: 0;
	visibility: hidden;
	box-shadow: 0 2px 8px rgba(0, 0, 0, 0.15);
	transition: background-color 0.2s ease, color 0.2s ease, opacity 0.2s ease, visibility 0.2s ease;
}

.mavi-sos-arrow-prev {
	right: 10px;
}

.mavi-sos-arrow-next {
	left: 10px;
}

/* نمایش فلش‌ها فقط وقتی موس روی ناحیه‌ی اسلایدر (کارت‌ها) باشد - فقط
   روی دستگاه‌هایی با ماوس واقعی؛ در لمسی (موبایل/تبلت) با کلاس
   mavi-sos-show-arrows-mobile کنترل می‌شود تا رفتار hover کاذب لمسی
   باعث گیر کردن دکمه‌ها نشود */
@media (hover: hover) and (pointer: fine) {
	.mavi-sos-slider:hover .mavi-sos-arrow {
		opacity: 1;
		visibility: visible;
		transform: translateY(-50%);
	}
}

.mavi-sos-arrow:hover {
	background-color: #111111;
	color: #ffffff;
}

.mavi-sos-arrow:disabled {
	opacity: 0.4 !important;
	cursor: default;
}

.mavi-sos-wrapper.mavi-sos-no-arrows .mavi-sos-arrow {
	display: none !important;
}

/* ==========================================================================
   ریسپانسیو
   نکته فنی: تعداد اسلاید با CSS variable مشخص می‌شود (مقدار آن مستقیماً
   به‌صورت inline-style از PHP تزریق می‌شود) تا کاملاً مستقل از breakpoint
   المنتور و دقیقاً صحیح باشد؛ این مقدار همان عددی است که JS هم برای
   محاسبه گام جابه‌جایی (۲ به ۲) از آن استفاده می‌کند، نه یک تخمین از
   روی عرض رندر شده.
   ========================================================================== */

@media (max-width: 1024px) {
	.mavi-sos-wrapper {
		--mavi-sos-slides: var(--mavi-sos-slides-tablet);
	}
}

@media (max-width: 767px) {
	.mavi-sos-wrapper {
		--mavi-sos-slides: var(--mavi-sos-slides-mobile);
		--mavi-sos-gap: 12px;
		flex-direction: column !important;
		align-items: stretch !important;
		gap: 14px;
	}

	.mavi-sos-wrapper.mavi-sos-sidebar-left {
		flex-direction: column !important;
	}

	/* نوار عنوان همیشه بالای اسلایدر می‌آید و دو لوگو کنار هم (افقی) قرار می‌گیرند */
	.mavi-sos-wrapper .mavi-sos-sidebar {
		order: -1 !important;
		width: 100% !important;
		min-width: 0 !important;
		padding: 0 !important;
		flex-direction: row !important;
		justify-content: center !important;
		align-items: center !important;
		gap: 14px !important;
	}

	.mavi-sos-wrapper.mavi-sos-hide-sidebar-mobile .mavi-sos-sidebar {
		display: none !important;
	}

	/* دکمه مشاهده همه داخل نوار عنوان (دسکتاپ) در موبایل پنهان می‌شود؛
	   نسخه مخصوص موبایل که زیر اسلایدر است نمایش داده می‌شود */
	.mavi-sos-view-all-desktop {
		display: none !important;
	}

	.mavi-sos-view-all-mobile {
		display: inline-flex !important;
		justify-content: center !important;
		margin: 12px auto 0 !important;
	}

	/* فلش‌ها به‌طور پیش‌فرض در موبایل پنهان هستند؛ کلاس زیر در PHP
	   بر اساس تنظیم «نمایش فلش‌ها در موبایل» اضافه می‌شود */
	.mavi-sos-wrapper .mavi-sos-arrow {
		display: none !important;
	}

	.mavi-sos-wrapper.mavi-sos-show-arrows-mobile .mavi-sos-arrow {
		display: flex !important;
		opacity: 1 !important;
		visibility: visible !important;
		width: 32px;
		height: 32px;
		min-width: 32px;
	}

	.mavi-sos-title {
		font-size: 16px !important;
	}

	.mavi-sos-logo-small img {
		width: 60px !important;
	}

	.mavi-sos-logo-large img {
		width: 110px !important;
	}

	.mavi-sos-card-title {
		font-size: 13px;
		min-height: 36px;
	}

	.mavi-sos-price {
		font-size: 13px;
	}

	/* کوچک‌سازی برچسب تخفیف در موبایل (مطابق badge.php اصلی) */
	.mavi-sos-badge {
		transform: scale(0.75);
	}
}

/* تبلت */
@media (max-width: 1024px) and (min-width: 768px) {
	.mavi-sos-badge {
		transform: scale(0.85);
	}
}
