/* ═══════════════════════════════════════════════════════════════
   Souq Aarsal v4.0 — Premium RTL-first supermarket theme
   ═══════════════════════════════════════════════════════════════ */

:root {
	/* Brand — fresh grocery green */
	--sa-emerald: #3bb77e;
	--sa-emerald-dark: #2a9d68;
	--sa-emerald-deep: #1f8a59;
	--sa-forest: #14663f;
	--sa-lime: #a7e34f;
	--sa-emerald-glow: rgba(59, 183, 126, 0.35);

	/* Action yellow (Bacola-style add-to-cart) */
	--sa-yellow: #f7a900;
	--sa-yellow-dark: #e09600;

	--sa-gold: #f7a900;
	--sa-coral: #f43f5e;
	--sa-sale: #e8453c;
	--sa-blue: #2f8be8;
	--sa-indigo: #6366f1;
	--sa-navy: #0c1a26;
	--sa-navy-soft: #14303f;
	--sa-ink: #1a2b3a;

	/* Surfaces & text */
	--sa-surface: #ffffff;
	--sa-surface-2: #f6f8f9;
	--sa-bg: #f6f7f9;
	--sa-bg-warm: #f7f8f6;
	--sa-text: #4a5568;
	--sa-heading: #21343f;
	--sa-muted: #8b95a1;
	--sa-border: rgba(33, 52, 63, 0.10);
	--sa-border-strong: rgba(33, 52, 63, 0.16);
	--sa-glass: rgba(255, 255, 255, 0.78);

	/* Radii */
	--sa-radius: 18px;
	--sa-radius-sm: 12px;
	--sa-radius-lg: 26px;
	--sa-radius-xl: 34px;
	--sa-radius-pill: 999px;

	/* Layered shadows */
	--sa-shadow-xs: 0 1px 2px rgba(16, 24, 40, 0.06);
	--sa-shadow-sm: 0 6px 18px -6px rgba(16, 24, 40, 0.10);
	--sa-shadow: 0 18px 44px -16px rgba(16, 24, 40, 0.18);
	--sa-shadow-md: 0 14px 32px -10px rgba(16, 24, 40, 0.14);
	--sa-shadow-lg: 0 34px 70px -22px rgba(16, 24, 40, 0.26);
	--sa-shadow-emerald: 0 18px 40px -14px rgba(16, 185, 129, 0.5);

	/* Typography */
	--sa-font: 'Tajawal', 'Readex Pro', system-ui, -apple-system, 'Segoe UI', sans-serif;
	--sa-font-display: 'Tajawal', 'Readex Pro', system-ui, sans-serif;

	/* Fluid type scale */
	--fs-300: clamp(0.78rem, 0.74rem + 0.18vw, 0.85rem);
	--fs-400: clamp(0.92rem, 0.88rem + 0.22vw, 1rem);
	--fs-500: clamp(1.05rem, 0.98rem + 0.4vw, 1.2rem);
	--fs-600: clamp(1.25rem, 1.1rem + 0.7vw, 1.6rem);
	--fs-700: clamp(1.6rem, 1.3rem + 1.4vw, 2.35rem);
	--fs-800: clamp(2.1rem, 1.6rem + 2.4vw, 3.4rem);

	/* Spacing rhythm */
	--sa-section-y: clamp(2.75rem, 2rem + 3vw, 5rem);

	--sa-container: 1240px;
	--sa-ease: cubic-bezier(0.22, 1, 0.36, 1);
	--sa-ease-out: cubic-bezier(0.16, 1, 0.3, 1);
}

*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html {
	scroll-behavior: smooth;
	-webkit-text-size-adjust: 100%;
	overscroll-behavior-y: none;
}
body {
	font-family: var(--sa-font);
	font-size: 16px;
	line-height: 1.7;
	color: var(--sa-text);
	background: var(--sa-bg);
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
	text-rendering: optimizeLegibility;
	font-feature-settings: 'kern' 1, 'liga' 1, 'calt' 1;
	text-align: start;
	position: relative;
	overflow-x: hidden;
}
img { max-width: 100%; height: auto; display: block; }
a { color: inherit; text-decoration: none; }
ul { list-style: none; }

/* Headings — display font, no letter-spacing (preserves Arabic shaping) */
h1, h2, h3, h4, h5, h6 {
	font-family: var(--sa-font-display);
	color: var(--sa-heading);
	line-height: 1.25;
	letter-spacing: normal;
	text-wrap: balance;
}
p { text-wrap: pretty; }

/* Arabic must never be letter-spaced — it breaks glyph joining */
html[dir="rtl"],
html[dir="rtl"] h1, html[dir="rtl"] h2, html[dir="rtl"] h3,
html[dir="rtl"] h4, html[dir="rtl"] h5, html[dir="rtl"] h6,
html[dir="rtl"] .sa-btn, html[dir="rtl"] .btn,
html[dir="rtl"] .souq-section__title,
html[dir="rtl"] .sa-hero__title,
html[dir="rtl"] .souq-section__eyebrow {
	letter-spacing: normal !important;
}

::selection { background: rgba(16, 185, 129, 0.22); color: var(--sa-ink); }

:focus-visible {
	outline: 2px solid var(--sa-emerald);
	outline-offset: 2px;
	border-radius: 4px;
}

.container {
	width: min(100% - 2rem, var(--sa-container));
	margin-inline: auto;
}

.screen-reader-text {
	position: absolute; width: 1px; height: 1px;
	padding: 0; margin: -1px; overflow: hidden;
	clip: rect(0,0,0,0); border: 0;
}

/* ── Buttons ── */
.sa-btn, .btn {
	display: inline-flex; align-items: center; justify-content: center;
	gap: 0.5rem; padding: 0.8rem 1.6rem;
	border-radius: 999px; font-weight: 700; font-size: 0.9rem;
	border: none; cursor: pointer; font-family: inherit;
	transition: all 0.3s var(--sa-ease);
}
.sa-btn--primary, .btn--primary {
	background: linear-gradient(135deg, var(--sa-emerald), var(--sa-emerald-dark));
	color: #fff;
}
.sa-btn--primary:hover, .btn--primary:hover {
	transform: translateY(-2px);
	box-shadow: 0 12px 28px rgba(16, 185, 129, 0.35);
	color: #fff;
}
.sa-btn--glass, .btn--outline {
	background: var(--sa-glass);
	backdrop-filter: blur(12px);
	border: 1px solid rgba(255,255,255,0.4);
	color: #fff;
}
.sa-btn--whatsapp, .btn--whatsapp { background: #25d366; color: #fff; }
.btn--view-all, .btn--cart {
	background: var(--sa-surface);
	border: 1.5px solid var(--sa-border);
	color: var(--sa-text);
	padding: 0.6rem 1.2rem; font-size: 0.85rem;
	border-radius: 999px;
}
.btn--view-all:hover { border-color: var(--sa-emerald); color: var(--sa-emerald); }
.btn--cart { background: var(--sa-emerald); color: #fff; border: none; width: 100%; }
.btn--cart:disabled { opacity: 0.45; }

/* ── Header ── */
.sa-header {
	position: sticky; top: 0; z-index: 300;
	background: #fff;
	border-block-end: 1px solid var(--sa-border);
	box-shadow: 0 1px 0 rgba(15, 23, 42, 0.04);
	transition: box-shadow 0.35s var(--sa-ease);
}
.sa-header.is-scrolled {
	box-shadow: 0 8px 24px rgba(15, 23, 42, 0.08);
}

.sa-header__top {
	background: var(--sa-navy);
	color: #fff;
	font-size: 0.78rem;
	overflow: hidden;
}
.sa-header__top-inner {
	display: flex;
	justify-content: space-between;
	align-items: center;
	padding: 0.5rem 0;
	gap: 1rem;
}
.sa-header__top-links {
	display: flex; gap: 1rem; align-items: center; flex-shrink: 0;
}
.sa-header__top a { color: rgba(255,255,255,0.9); }
.sa-header__top a:hover { color: var(--sa-gold); }

.sa-header__main {
	padding: 0.85rem 0;
}
.sa-header__main-inner {
	display: grid;
	grid-template-columns: 200px 1fr auto;
	align-items: center;
	gap: 1.5rem;
}

.site-title {
	font-size: 1.55rem;
	font-weight: 800;
	background: linear-gradient(135deg, var(--sa-emerald), var(--sa-emerald-deep));
	-webkit-background-clip: text;
	-webkit-text-fill-color: transparent;
	background-clip: text;
}
/* Logo sizing lives in modern-2026.css — do not cap height here */

.sa-header__search .souq-search-form {
	display: flex;
	align-items: stretch;
	flex-direction: row;
	background: var(--sa-bg);
	border: 2px solid transparent;
	border-radius: 999px;
	box-shadow: inset 0 2px 4px rgba(0,0,0,0.04);
	transition: all 0.3s var(--sa-ease);
	overflow: hidden;
}
.sa-header__search .souq-search-form:focus-within {
	border-color: var(--sa-emerald);
	box-shadow: 0 0 0 4px rgba(16, 185, 129, 0.12);
}
.souq-search-field {
	flex: 1; border: none; background: transparent;
	padding: 0.8rem 1.2rem; font-family: inherit;
	font-size: 0.9rem; outline: none;
}
.souq-search-submit {
	background: linear-gradient(135deg, var(--sa-emerald), var(--sa-emerald-dark));
	color: #fff; border: none;
	padding: 0 1.25rem; cursor: pointer;
	border-radius: 0;
	display: flex; align-items: center;
	flex-shrink: 0;
	transition: filter 0.25s;
}
.souq-search-submit:hover { filter: brightness(1.08); }

.sa-header__actions { display: flex; align-items: center; gap: 0.6rem; }
.sa-header__wa {
	width: 42px; height: 42px; border-radius: 50%;
	background: #25d366; color: #fff;
	display: flex; align-items: center; justify-content: center;
	transition: transform 0.3s var(--sa-ease);
}
.sa-header__wa:hover { transform: scale(1.08); color: #fff; }

.sa-header__burger {
	display: none; flex-direction: column; gap: 5px;
	width: 42px; height: 42px; border-radius: var(--sa-radius-sm);
	background: var(--sa-bg); border: none; cursor: pointer;
	align-items: center; justify-content: center;
}
.sa-header__burger span {
	display: block; width: 20px; height: 2px;
	background: var(--sa-text); border-radius: 2px;
	transition: 0.3s;
}

/* Category strip — below main menu */
.souq-cat-strip {
	background: var(--sa-bg-warm);
	border-block-end: 1px solid var(--sa-border);
	overflow-x: auto;
	scrollbar-width: none;
	-webkit-overflow-scrolling: touch;
}
.souq-cat-strip::-webkit-scrollbar { display: none; }
.souq-cat-strip__inner { display: flex; gap: 0.35rem; padding: 0.55rem 0; }
.souq-cat-strip__item {
	display: flex; align-items: center; gap: 0.45rem;
	padding: 0.5rem 0.95rem; white-space: nowrap;
	font-size: 0.8rem; font-weight: 600;
	border-radius: 999px;
	background: var(--sa-surface);
	border: 1px solid var(--sa-border);
	transition: all 0.25s var(--sa-ease);
}
.souq-cat-strip__item:hover {
	background: var(--sa-emerald);
	color: #fff;
	border-color: var(--sa-emerald);
}

/* Header category row — photo pills (checkout, auth, cart, etc.) */
.souq-cat-strip--visual {
	background: var(--sa-surface);
	border-block-end: 1px solid var(--sa-border);
	overflow-x: auto;
	scrollbar-width: none;
	-webkit-overflow-scrolling: touch;
}
.souq-cat-strip--visual::-webkit-scrollbar { display: none; }
.souq-cat-strip--visual .souq-cat-strip__inner {
	display: flex;
	flex-wrap: nowrap;
	gap: 0.5rem;
	padding: 0.65rem 0;
	overflow-x: auto;
	scrollbar-width: none;
}
.souq-cat-strip--visual .souq-filter-pill {
	flex-shrink: 0;
	text-decoration: none;
	color: inherit;
}
.souq-cat-strip--visual .souq-filter-pill:hover {
	background: var(--sa-emerald);
	color: #fff;
	border-color: var(--sa-emerald);
	box-shadow: 0 4px 14px rgba(16, 185, 129, 0.25);
}
.souq-cat-strip--visual .souq-filter-pill:hover .souq-filter-pill__thumb {
	border-color: rgba(255, 255, 255, 0.45);
}

.sa-header__nav-area {
	background: var(--sa-surface);
	border-block-end: 1px solid var(--sa-border);
}

.sa-nav {
	background: var(--sa-surface);
	border-block-end: 1px solid var(--sa-border);
}
.sa-nav .container { padding-block: 0; }
.primary-menu {
	display: flex;
	gap: 0.25rem;
	justify-content: flex-start;
	flex-wrap: nowrap;
	padding: 0.5rem 0;
	overflow-x: auto;
	scrollbar-width: none;
	-webkit-overflow-scrolling: touch;
}
.primary-menu::-webkit-scrollbar { display: none; }
.primary-menu li { flex-shrink: 0; }
.primary-menu a {
	padding: 0.55rem 1.15rem;
	font-weight: 700;
	font-size: 0.88rem;
	color: var(--sa-text);
	transition: all 0.2s var(--sa-ease);
	border-radius: 999px;
	white-space: nowrap;
}
.primary-menu a:hover,
.primary-menu .current-menu-item a,
.primary-menu .current_page_item a {
	color: var(--sa-emerald);
	background: rgba(16, 185, 129, 0.1);
}

.sa-mobile-nav {
	position: fixed;
	inset: 0;
	z-index: 500;
	padding-top: var(--sa-header-h, 118px);
	background: rgba(15, 23, 42, 0.55);
	overflow-y: auto;
	-webkit-overflow-scrolling: touch;
}
.sa-mobile-nav[hidden] {
	display: none !important;
}
.sa-mobile-nav__panel {
	background: #fff;
	border-radius: 0 0 16px 16px;
	box-shadow: 0 16px 48px rgba(15, 23, 42, 0.2);
}
.sa-mobile-nav__panel .container {
	padding: 0.35rem 1rem 1rem;
}
.mobile-menu {
	list-style: none;
	margin: 0;
	padding: 0;
}
.mobile-menu li {
	margin: 0;
}
.mobile-menu a {
	display: block;
	padding: 0.9rem 0.5rem;
	font-weight: 700;
	font-size: 1rem;
	color: var(--sa-text);
	border-block-end: 1px solid var(--sa-border);
	border-radius: 8px;
	transition: background 0.2s ease, color 0.2s ease;
}
.mobile-menu a:hover,
.mobile-menu .current-menu-item > a,
.mobile-menu .current_page_item > a {
	color: var(--sa-emerald);
	background: rgba(16, 185, 129, 0.06);
}
body.sa-menu-open {
	overflow: hidden;
}
body.sa-menu-open .sa-header {
	z-index: 501;
}

/* ── Trust bar ── */
.souq-trust {
	background: var(--sa-surface);
	padding: 1rem 0;
	border-block-end: 1px solid var(--sa-border);
}
.souq-trust__grid {
	display: grid; grid-template-columns: repeat(4, 1fr); gap: 1rem;
}
.souq-trust__item {
	display: flex; align-items: center; gap: 0.85rem;
	padding: 0.75rem; border-radius: var(--sa-radius-sm);
	background: var(--sa-bg-warm);
	transition: transform 0.3s var(--sa-ease);
}
.souq-trust__item:hover { transform: translateY(-3px); }
.souq-trust__icon { font-size: 1.6rem; }
.souq-trust__item strong { display: block; font-size: 0.85rem; }
.souq-trust__item p { font-size: 0.72rem; color: var(--sa-muted); margin: 0; }

/* ── Hero ── */
.sa-hero {
	position: relative;
	padding: 2rem 0 1rem;
	overflow: hidden;
}
.sa-hero__mesh {
	position: absolute; inset: 0;
	background: linear-gradient(135deg, #ecfdf5 0%, #f0f9ff 40%, #faf8f5 100%);
	z-index: 0;
}
.sa-hero__blob {
	position: absolute; border-radius: 50%;
	filter: blur(60px); opacity: 0.5;
}
.sa-hero__blob--1 {
	width: 400px; height: 400px;
	background: var(--sa-emerald);
	top: -100px; inset-inline-end: -100px;
}
.sa-hero__blob--2 {
	width: 300px; height: 300px;
	background: #6366f1;
	bottom: -50px; inset-inline-start: 10%;
	opacity: 0.3;
}
.sa-hero__blob--3 {
	width: 250px; height: 250px;
	background: var(--sa-gold);
	top: 40%; inset-inline-start: 40%;
	opacity: 0.25;
}

.sa-hero__grid {
	position: relative; z-index: 1;
	display: grid;
	grid-template-columns: 270px 1fr;
	gap: 1.25rem;
	align-items: stretch;
}

.sa-hero__sidebar {
	background: var(--sa-glass);
	backdrop-filter: blur(20px);
	border: 1px solid rgba(255,255,255,0.6);
	border-radius: var(--sa-radius-lg);
	overflow: hidden;
	box-shadow: var(--sa-shadow);
}
.sa-hero__sidebar-head {
	display: flex; align-items: center; gap: 0.6rem;
	padding: 1rem 1.15rem;
	background: linear-gradient(135deg, var(--sa-navy), var(--sa-navy-soft));
	color: #fff; font-weight: 700; font-size: 0.9rem;
}
.sa-hero__cat-list a {
	display: flex; align-items: center; gap: 0.7rem;
	padding: 0.75rem 1.15rem;
	font-size: 0.86rem; font-weight: 500;
	border-block-end: 1px solid var(--sa-border);
	transition: all 0.25s var(--sa-ease);
}
.sa-hero__cat-list a:hover {
	background: rgba(16, 185, 129, 0.08);
	color: var(--sa-emerald-dark);
	padding-inline-start: 1.4rem;
}
.sa-hero__cat-emoji { font-size: 1.2rem; }
.sa-hero__cat-arrow {
	margin-inline-start: auto;
	color: var(--sa-muted); font-size: 1.2rem;
}

.sa-hero__stage {
	background: linear-gradient(145deg, var(--sa-navy) 0%, #1e3a5f 45%, var(--sa-emerald-deep) 100%);
	border-radius: var(--sa-radius-lg);
	padding: 2.5rem;
	min-height: 400px;
	position: relative;
	overflow: hidden;
	box-shadow: var(--sa-shadow), inset 0 1px 0 rgba(255,255,255,0.08);
	color: #fff;
}
.sa-hero__stage::before {
	content: '';
	position: absolute; inset: 0;
	background: radial-gradient(circle at 80% 20%, rgba(16,185,129,0.25), transparent 50%),
	            radial-gradient(circle at 20% 80%, rgba(99,102,241,0.2), transparent 45%);
	pointer-events: none;
}

.sa-hero__slides { position: relative; min-height: 280px; }
.sa-hero-slide {
	position: absolute; inset: 0;
	opacity: 0; visibility: hidden;
	transition: opacity 0.6s var(--sa-ease), visibility 0.6s;
}
.sa-hero-slide.is-active {
	opacity: 1; visibility: visible;
	position: relative;
}

.sa-pill {
	display: inline-block;
	padding: 0.35rem 0.9rem;
	border-radius: 999px;
	font-size: 0.72rem; font-weight: 800;
	background: rgba(255,255,255,0.15);
	margin-bottom: 1rem;
	letter-spacing: 0.04em;
}
.sa-pill--gold { background: rgba(251, 191, 36, 0.25); color: var(--sa-gold); }
.sa-pill--sale { background: rgba(244, 63, 94, 0.25); color: #fda4af; }

.sa-hero__title {
	font-size: clamp(1.5rem, 3vw, 2.2rem);
	font-weight: 800; line-height: 1.35;
	margin-bottom: 0.75rem;
	max-width: 480px;
}
.sa-hero__desc {
	font-size: 0.95rem; opacity: 0.88;
	margin-bottom: 1.5rem; max-width: 420px; line-height: 1.7;
}
.sa-hero__cta { display: flex; gap: 0.75rem; flex-wrap: wrap; }

.sa-hero__floats { position: absolute; inset: 0; pointer-events: none; }
.sa-float {
	position: absolute; font-size: 3rem;
	opacity: 0.15;
}
.sa-float--1 { top: 15%; inset-inline-end: 15%; }
.sa-float--2 { bottom: 25%; inset-inline-end: 25%; font-size: 2.5rem; }
.sa-float--3 { top: 40%; inset-inline-end: 8%; font-size: 2rem; }

.sa-hero__dots {
	display: flex; gap: 0.5rem; margin-top: 1.25rem;
}
.sa-hero__dots button {
	width: 8px; height: 8px; border-radius: 50%;
	background: rgba(255,255,255,0.3); border: none;
	cursor: pointer; padding: 0;
	transition: all 0.3s var(--sa-ease);
}
.sa-hero__dots button.is-active {
	background: #fff; width: 28px; border-radius: 4px;
}

/* ── Stats ── */
.sa-stats {
	padding: 1.5rem 0 2rem;
}
.sa-stats__grid {
	display: grid; grid-template-columns: repeat(4, 1fr); gap: 1rem;
}
.sa-stats__item {
	text-align: center;
	padding: 1.5rem 1rem;
	background: var(--sa-surface);
	border-radius: var(--sa-radius);
	border: 1px solid var(--sa-border);
	box-shadow: var(--sa-shadow-sm);
	transition: transform 0.3s var(--sa-ease);
}
.sa-stats__item:hover {
	transform: translateY(-6px);
	box-shadow: var(--sa-shadow);
}
.sa-stats__num {
	display: block; font-size: 1.75rem; font-weight: 800;
	background: linear-gradient(135deg, var(--sa-emerald), var(--sa-emerald-deep));
	-webkit-background-clip: text;
	-webkit-text-fill-color: transparent;
	background-clip: text;
}
.sa-stats__item span { font-size: 0.82rem; color: var(--sa-muted); font-weight: 500; }

/* ── Flash deals ── */
.sa-flash { padding: 0 0 1.5rem; }
.sa-flash__inner {
	display: grid;
	grid-template-columns: 1fr auto auto;
	align-items: center;
	gap: 2rem;
	padding: 1.75rem 2rem;
	border-radius: var(--sa-radius-lg);
	background: linear-gradient(135deg, var(--sa-navy) 0%, #1a365d 55%, var(--sa-emerald-deep) 100%);
	color: #fff;
	box-shadow: var(--sa-shadow);
	position: relative;
	overflow: hidden;
}
.sa-flash__inner::after {
	content: '';
	position: absolute;
	inset-inline-end: -20%;
	top: -50%;
	width: 50%;
	height: 200%;
	background: radial-gradient(circle, rgba(251,191,36,0.15), transparent 65%);
	pointer-events: none;
}
.sa-flash__badge {
	display: inline-block;
	padding: 0.3rem 0.85rem;
	border-radius: 999px;
	font-size: 0.72rem;
	font-weight: 800;
	background: rgba(251, 191, 36, 0.2);
	color: var(--sa-gold);
	margin-bottom: 0.5rem;
}
.sa-flash__title { font-size: 1.35rem; font-weight: 800; margin-bottom: 0.35rem; }
.sa-flash__desc { font-size: 0.88rem; opacity: 0.85; max-width: 380px; }
.sa-flash__timer {
	display: flex;
	align-items: center;
	gap: 0.5rem;
	position: relative;
	z-index: 1;
}
.sa-flash__unit {
	text-align: center;
	background: rgba(255,255,255,0.1);
	backdrop-filter: blur(8px);
	border: 1px solid rgba(255,255,255,0.15);
	border-radius: var(--sa-radius-sm);
	padding: 0.65rem 0.85rem;
	min-width: 64px;
}
.sa-flash__digit {
	display: block;
	font-size: 1.5rem;
	font-weight: 800;
	font-variant-numeric: tabular-nums;
	line-height: 1;
}
.sa-flash__unit small { font-size: 0.65rem; opacity: 0.75; }
.sa-flash__sep { font-size: 1.25rem; font-weight: 700; opacity: 0.5; }
.sa-flash__cta { position: relative; z-index: 1; white-space: nowrap; }

/* ── Promo row ── */
.souq-promo-row { padding: 0.5rem 0 1.5rem; }
.souq-promo-row__grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1rem; }
.souq-promo-card {
	display: flex; justify-content: space-between; align-items: center;
	padding: 1.5rem; border-radius: var(--sa-radius);
	color: #fff; min-height: 110px;
	transition: transform 0.35s var(--sa-ease), box-shadow 0.35s;
}
.souq-promo-card:hover {
	transform: translateY(-6px) scale(1.02);
	box-shadow: var(--sa-shadow);
}
.souq-promo-card--green { background: linear-gradient(135deg, #10b981, #047857); }
.souq-promo-card--orange { background: linear-gradient(135deg, #f59e0b, #d97706); }
.souq-promo-card--purple { background: linear-gradient(135deg, #8b5cf6, #6d28d9); }
.souq-promo-card__label { font-size: 0.75rem; opacity: 0.85; }
.souq-promo-card__text strong { font-size: 1.1rem; font-weight: 800; }
.souq-promo-card__emoji { font-size: 2.8rem; }

/* ── Sections ── */
.souq-section {
	padding: 3rem 0;
	position: relative;
}
.souq-section:nth-child(even) { background: var(--sa-surface); }

.souq-section__eyebrow {
	display: inline-block;
	font-size: 0.72rem; font-weight: 800;
	color: var(--sa-emerald);
	text-transform: uppercase;
	letter-spacing: 0.08em;
	margin-bottom: 0.4rem;
	padding: 0.25rem 0.75rem;
	background: rgba(16, 185, 129, 0.1);
	border-radius: 999px;
}
.souq-section__header { margin-bottom: 2rem; }
.souq-section__header--row {
	display: flex; justify-content: space-between;
	align-items: flex-end; gap: 1rem; flex-wrap: wrap;
}
.souq-section__title {
	font-size: clamp(1.35rem, 2.5vw, 1.75rem);
	font-weight: 800; letter-spacing: -0.02em;
	position: relative; padding-block-end: 0.5rem;
}
.souq-section__title::after {
	content: '';
	position: absolute;
	bottom: 0; inset-inline-start: 0;
	width: 48px; height: 4px;
	background: linear-gradient(90deg, var(--sa-emerald), var(--sa-gold));
	border-radius: 2px;
}
.souq-section__desc { color: var(--sa-muted); font-size: 0.9rem; margin-top: 0.5rem; }
.souq-section__placeholder-note {
	text-align: center; margin-top: 1.25rem;
	padding: 0.85rem; border-radius: var(--sa-radius-sm);
	background: rgba(16, 185, 129, 0.08);
	color: var(--sa-emerald-deep); font-size: 0.82rem; font-weight: 500;
}

/* ── Categories (bento grid) ── */
.souq-category-grid {
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	gap: 1rem;
}
.souq-category-card {
	display: flex; flex-direction: column; align-items: center;
	gap: 0.75rem; padding: 1.5rem 1rem;
	background: var(--sa-surface);
	border-radius: var(--sa-radius);
	border: 1px solid var(--sa-border);
	text-align: center;
	position: relative; overflow: hidden;
}
.souq-category-card--wide { grid-column: span 2; }
.souq-category-card--tall { grid-row: span 2; padding: 2rem 1.25rem; }
.souq-category-card--tall .souq-category-card__visual { width: 100px; height: 100px; }
.souq-category-card--tall .souq-category-card__emoji { font-size: 2.8rem; }
.souq-category-card::before {
	content: '';
	position: absolute; inset: 0;
	background: linear-gradient(135deg, var(--cat-accent, var(--sa-emerald)), transparent);
	opacity: 0;
	transition: opacity 0.35s;
}
.souq-category-card:hover {
	transform: translateY(-8px);
	box-shadow: var(--sa-shadow);
	border-color: transparent;
}
.souq-category-card:hover::before { opacity: 0.06; }
.souq-category-card__visual {
	width: 80px; height: 80px; border-radius: 50%;
	background: linear-gradient(135deg, var(--cat-accent, #10b981) 22%, transparent 120%);
	display: flex; align-items: center; justify-content: center;
	position: relative; z-index: 1;
	transition: transform 0.35s var(--sa-ease);
}
.souq-category-card:hover .souq-category-card__visual { transform: scale(1.1) rotate(5deg); }
.souq-category-card__emoji { font-size: 2.2rem; }
.souq-category-card__name { font-weight: 700; font-size: 0.88rem; position: relative; z-index: 1; }
.souq-category-card__cta { font-size: 0.75rem; color: var(--sa-emerald); font-weight: 700; z-index: 1; }

/* ── Product grid ── */
.souq-product-grid,
.woocommerce ul.products {
	display: grid !important;
	grid-template-columns: repeat(4, minmax(0, 1fr));
	gap: 1.25rem;
	align-items: stretch;
	list-style: none;
	margin: 0 !important;
	padding: 0 !important;
	width: 100%;
	clear: both;
	float: none;
}

.woocommerce ul.products::before,
.woocommerce ul.products::after {
	display: none !important;
	content: none !important;
}

.souq-product-grid > li,
.woocommerce ul.products li.product {
	display: flex !important;
	flex-direction: column;
	width: 100% !important;
	max-width: none !important;
	float: none !important;
	margin: 0 !important;
	padding: 0 !important;
	clear: none !important;
}

.souq-product-card { margin: 0 !important; width: 100% !important; flex: 1; }

.souq-product-card__inner {
	background: var(--sa-surface);
	border-radius: var(--sa-radius-sm);
	border: 1px solid var(--sa-border);
	overflow: hidden;
	height: 100%;
	width: 100%;
	display: flex;
	flex-direction: column;
	position: relative;
	box-shadow: 0 2px 8px rgba(15, 23, 42, 0.04);
	transition: box-shadow 0.25s var(--sa-ease), transform 0.25s var(--sa-ease);
}
.souq-product-card__inner:hover {
	box-shadow: 0 12px 28px rgba(15, 23, 42, 0.1);
	transform: translateY(-4px);
}
.souq-product-card__inner::before {
	display: none;
}

.souq-product-card__media {
	position: relative;
	flex-shrink: 0;
	height: 168px;
	padding: 1rem;
	background: linear-gradient(180deg, #fafbfc, #fff);
	display: flex;
	align-items: center;
	justify-content: center;
}

.souq-product-card__badges {
	position: absolute; top: 0.75rem; inset-inline-start: 0.75rem;
	display: flex; flex-direction: column; gap: 0.3rem; z-index: 2;
}

.souq-badge {
	padding: 0.25rem 0.55rem; border-radius: 6px;
	font-size: 0.68rem; font-weight: 800;
}
.souq-badge--pct { background: #3b82f6; color: #fff; }
.souq-badge--featured { background: var(--sa-navy); color: #fff; }
.souq-badge--demo { background: var(--sa-gold); color: var(--sa-navy); }

.souq-product-card__image-link,
.souq-placeholder-img {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 100%;
	height: 100%;
	min-height: 0;
}
.souq-product-card__image-link img {
	max-height: 130px;
	max-width: 100%;
	width: auto;
	height: auto;
	object-fit: contain;
	transition: transform 0.4s var(--sa-ease);
}
.souq-placeholder-img { border-radius: var(--sa-radius-sm); }
.souq-placeholder-img span { font-size: 4rem; }

.souq-product-card__hover-actions {
	position: absolute; bottom: 0.75rem; inset-inline-end: 0.75rem;
	display: flex; gap: 0.4rem;
	opacity: 0; transform: translateY(8px);
	transition: all 0.3s var(--sa-ease);
}
.souq-product-card:hover .souq-product-card__hover-actions {
	opacity: 1; transform: translateY(0);
}
.souq-quick-view-btn, .souq-add-icon {
	width: 38px; height: 38px; border-radius: 50%;
	background: #fff; border: none;
	display: flex; align-items: center; justify-content: center;
	cursor: pointer; box-shadow: var(--sa-shadow-sm);
	transition: all 0.25s;
}
.souq-add-icon:hover, .souq-quick-view-btn:hover {
	background: var(--sa-emerald); color: #fff;
}

.souq-product-card__body {
	padding: 1rem 1.15rem 1.25rem;
	flex: 1;
	display: flex;
	flex-direction: column;
	text-align: center;
	min-height: 0;
}
.souq-product-card__title {
	font-size: 0.88rem;
	font-weight: 600;
	line-height: 1.5;
	margin-bottom: 0.35rem;
	min-height: 2.7em;
	display: -webkit-box;
	-webkit-box-orient: vertical;
	-webkit-line-clamp: 2;
	overflow: hidden;
}
.souq-product-card__title a:hover { color: var(--sa-emerald); }
.souq-product-card__stock {
	font-size: 0.68rem; font-weight: 800;
	color: var(--sa-emerald); text-transform: uppercase;
	letter-spacing: 0.05em;
}
.souq-product-card__stock--out { color: var(--sa-coral); }
.souq-product-card__price {
	font-weight: 800; font-size: 1.05rem; margin: 0.5rem 0 0.75rem;
}
.souq-product-card__price ins { text-decoration: none; color: var(--sa-coral); }
.souq-product-card__price del { color: var(--sa-muted); font-size: 0.82rem; font-weight: 400; }

.souq-product-card__actions {
	margin-top: auto;
	min-height: 44px;
	display: flex;
	align-items: flex-end;
	justify-content: center;
}
.souq-product-card__actions .btn--cart {
	width: 100%;
}
.souq-product-card__actions .souq-qty-wrap { display: none; }

/* ── Why us ── */
.souq-why {
	padding: 4rem 0;
	background: linear-gradient(180deg, var(--sa-bg-warm), var(--sa-bg));
}
.souq-why__inner {
	display: grid; grid-template-columns: 1fr 1fr;
	gap: 3rem; align-items: center;
}
.souq-why__title { font-size: 1.65rem; font-weight: 800; margin: 0.5rem 0 1rem; line-height: 1.35; }
.souq-why__desc { color: var(--sa-muted); margin-bottom: 1.25rem; }
.souq-why__list { margin-bottom: 1.5rem; }
.souq-why__list li {
	padding: 0.5rem 0; padding-inline-start: 1.75rem;
	position: relative; font-weight: 500;
}
.souq-why__list li::before {
	content: '✓'; position: absolute; inset-inline-start: 0;
	color: var(--sa-emerald); font-weight: 800; font-size: 1.1rem;
}
.souq-why__cards { display: grid; gap: 1rem; }
.souq-why__card {
	background: var(--sa-surface); padding: 1.35rem 1.5rem;
	border-radius: var(--sa-radius);
	border: 1px solid var(--sa-border);
	transition: all 0.35s var(--sa-ease);
}
.souq-why__card:hover {
	box-shadow: var(--sa-shadow);
	border-color: var(--sa-emerald);
}
.souq-why__card span { font-size: 1.6rem; }
.souq-why__card strong { font-size: 0.95rem; display: block; margin: 0.25rem 0; }
.souq-why__card p { color: var(--sa-muted); font-size: 0.82rem; margin: 0; }

/* ── Delivery CTA ── */
.souq-delivery-cta { padding: 3rem 0 4rem; }
.souq-delivery-cta__grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1.25rem; }
.souq-delivery-cta__item {
	background: var(--sa-surface); padding: 2rem 1.5rem;
	border-radius: var(--sa-radius-lg);
	border: 1px solid var(--sa-border);
	text-align: center;
	transition: all 0.35s var(--sa-ease);
}
.souq-delivery-cta__item:hover {
	transform: translateY(-8px);
	box-shadow: var(--sa-shadow);
}
.souq-delivery-cta__icon { font-size: 2.5rem; margin-bottom: 1rem; }
.souq-delivery-cta__item h3 { font-size: 1.1rem; margin-bottom: 0.5rem; }
.souq-delivery-cta__item p { color: var(--sa-muted); font-size: 0.88rem; margin-bottom: 1rem; }
.souq-delivery-cta__item--whatsapp {
	border-color: rgba(37, 211, 102, 0.3);
	background: linear-gradient(180deg, #f0fdf4, #fff);
}

/* ── Footer ── */
.site-footer {
	background: linear-gradient(180deg, var(--sa-navy-soft) 0%, var(--sa-navy) 100%);
	color: #94a3b8;
	padding: 4rem 0 1.5rem;
	position: relative;
}
.site-footer::before {
	content: '';
	position: absolute;
	top: 0; left: 0; right: 0;
	height: 3px;
	background: linear-gradient(90deg, var(--sa-emerald), var(--sa-gold), var(--sa-indigo));
}
.footer-grid {
	display: grid; grid-template-columns: 1.5fr 1fr 1fr 1fr;
	gap: 2.5rem; margin-bottom: 2.5rem;
}
.site-footer h3 { color: #fff; font-size: 0.95rem; margin-bottom: 1.25rem; }
.site-footer a { color: #94a3b8; transition: color 0.2s; }
.site-footer a:hover { color: var(--sa-emerald); }
.site-footer .site-title {
	-webkit-text-fill-color: #fff;
	color: #fff;
}
.footer-desc { font-size: 0.88rem; line-height: 1.8; }
.footer-menu a { display: block; padding: 0.35rem 0; font-size: 0.88rem; }
.footer-bottom {
	border-block-start: 1px solid rgba(255,255,255,0.08);
	padding-top: 1.5rem; text-align: center; font-size: 0.82rem;
}

/* ── Shop / misc ── */
.souq-qty-wrap {
	display: inline-flex; align-items: center;
	border: 1px solid var(--sa-border); border-radius: var(--sa-radius-sm);
}
.souq-qty-btn {
	width: 32px; height: 32px; border: none;
	background: var(--sa-bg); cursor: pointer; font-family: inherit;
}
.souq-qty-input {
	width: 38px; height: 32px; border: none;
	text-align: center; font-family: inherit; background: #fff;
}

.souq-shop-main { padding: 1.25rem 0 3rem; background: var(--sa-bg); }

/* ── Shop header ── */
.souq-shop-header {
	margin-bottom: 1.25rem;
	background: var(--sa-surface);
	border: 1px solid var(--sa-border);
	border-radius: var(--sa-radius);
	padding: 1.25rem 1.35rem;
	box-shadow: var(--sa-shadow-sm);
}
.souq-shop-header__top {
	margin-bottom: 1rem;
	padding-bottom: 0.85rem;
	border-bottom: 1px solid var(--sa-border);
}
.souq-shop-title {
	font-size: clamp(1.35rem, 3vw, 1.75rem);
	font-weight: 800;
	margin-bottom: 0.25rem;
}
.souq-shop-meta {
	font-size: 0.85rem;
	color: var(--sa-muted);
	margin: 0;
}

.souq-shop-controls {
	display: grid;
	grid-template-columns: 1fr auto;
	gap: 0.75rem;
	align-items: center;
	margin-bottom: 1rem;
}
.souq-shop-controls__search .souq-search-form {
	border-radius: 999px;
	background: var(--sa-bg);
	border: 1.5px solid var(--sa-border);
}
.souq-shop-controls__search .souq-search-form:focus-within {
	border-color: var(--sa-emerald);
	box-shadow: 0 0 0 3px rgba(16, 185, 129, 0.12);
}
.souq-shop-controls__sort .woocommerce-ordering { margin: 0; }
.souq-shop-controls__sort .woocommerce-ordering select {
	appearance: none;
	border: 1.5px solid var(--sa-border);
	border-radius: 999px;
	padding: 0.7rem 2.25rem 0.7rem 1rem;
	font-family: inherit;
	font-size: 0.85rem;
	font-weight: 600;
	background: var(--sa-bg) url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%2364748b' stroke-width='2'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E") no-repeat;
	background-position: calc(100% - 12px) 50%;
	cursor: pointer;
	min-width: 160px;
}
html[dir="rtl"] .souq-shop-controls__sort .woocommerce-ordering select {
	padding: 0.7rem 1rem 0.7rem 2.25rem;
	background-position: 12px 50%;
}

.souq-shop-results {
	margin-bottom: 1rem;
}
.souq-shop-results .woocommerce-result-count {
	font-size: 0.85rem;
	color: var(--sa-muted);
	margin: 0;
}

/* ── Shop filters ── */
.souq-shop-filters { position: relative; }
.souq-filter-toggle {
	display: none;
	align-items: center;
	gap: 0.45rem;
	padding: 0.7rem 1.1rem;
	border-radius: 999px;
	border: 1.5px solid var(--sa-border);
	background: var(--sa-bg);
	font-family: inherit;
	font-weight: 700;
	font-size: 0.85rem;
	cursor: pointer;
	width: 100%;
	justify-content: center;
}
.souq-filter-panel {
	display: block;
}
.souq-filter-panel__head {
	display: none;
}
.souq-filter-pills {
	display: flex;
	flex-wrap: wrap;
	gap: 0.5rem;
}
.souq-filter-pill {
	display: inline-flex;
	align-items: center;
	gap: 0.55rem;
	padding: 0.4rem 0.95rem 0.4rem 0.4rem;
	border-radius: 999px;
	font-size: 0.82rem;
	font-weight: 600;
	background: var(--sa-bg);
	border: 1.5px solid var(--sa-border);
	color: var(--sa-text);
	transition: all 0.2s var(--sa-ease);
	white-space: nowrap;
}
.souq-filter-pill__thumb {
	flex: 0 0 38px;
	width: 38px;
	height: 38px;
	border-radius: 50%;
	overflow: hidden;
	background: #fff;
	display: grid;
	place-items: center;
	border: 2px solid rgba(15, 23, 42, 0.06);
	flex-shrink: 0;
}
.souq-filter-pill__img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
}
.souq-filter-pill__icon {
	font-size: 1rem;
	line-height: 1;
}
.souq-filter-pill:hover,
.souq-filter-pill.is-active {
	background: var(--sa-emerald);
	color: #fff;
	border-color: var(--sa-emerald);
	box-shadow: 0 4px 14px rgba(16, 185, 129, 0.25);
}

@media (min-width: 901px) {
	.sa-header__burger {
		display: none !important;
	}

	.sa-mobile-nav {
		display: none !important;
	}

	.souq-filter-panel { display: block !important; }
	.souq-filter-pills { flex-wrap: wrap; }
}

/* ── Navigation highlights ── */
.primary-menu a {
	position: relative;
}
.primary-menu .current-menu-item a,
.primary-menu .current_page_item a {
	color: var(--sa-emerald);
	background: rgba(16, 185, 129, 0.1);
	border-radius: 999px;
}
.sa-header__actions { gap: 0.5rem; }

/* ── LBP price display ── */
.souq-product-card__price,
.woocommerce-Price-amount {
	font-variant-numeric: tabular-nums;
	letter-spacing: -0.01em;
}
.souq-product-card__price {
	font-size: 0.95rem;
	line-height: 1.4;
}
.souq-product-card__price .woocommerce-Price-currencySymbol {
	font-size: 0.78em;
	opacity: 0.85;
}
.souq-product-card__image-link img,
.souq-placeholder-thumb {
	max-height: 140px;
	width: auto;
	height: auto;
	object-fit: contain;
	border-radius: var(--sa-radius-sm);
}

/* ── Product card mobile polish ── */
.souq-product-card__actions .souq-qty-wrap--card {
	display: inline-flex;
	margin-bottom: 0.5rem;
}
@media (min-width: 601px) {
	.souq-product-card__actions .souq-qty-wrap--card { display: none; }
}
.souq-single-product__grid {
	display: grid; grid-template-columns: 1fr 1fr; gap: 2.5rem;
	background: var(--sa-surface); padding: 2rem;
	border-radius: var(--sa-radius-lg);
	margin: 1.5rem 0; box-shadow: var(--sa-shadow-sm);
}

.souq-cart-page, .woocommerce-checkout {
	background: var(--sa-surface); border-radius: var(--sa-radius);
	padding: 2rem; margin: 1.5rem 0;
	box-shadow: var(--sa-shadow-sm);
}

#place_order { background: var(--sa-emerald) !important; width: 100%; padding: 1rem !important; font-weight: 700 !important; }

.souq-lang-switcher { display: flex; gap: 0.3rem; }
.souq-lang-switcher__item {
	padding: 0.2rem 0.5rem; border-radius: 4px; font-size: 0.7rem;
	font-weight: 800; border: 1px solid rgba(255,255,255,0.25); color: #fff;
}
.souq-lang-switcher__item.is-active { background: rgba(255,255,255,0.15); }

.souq-empty-state, .souq-404 { text-align: center; padding: 4rem 1rem; }

/* ── Responsive ── */
@media (max-width: 1100px) {
	.souq-product-grid, .woocommerce ul.products { grid-template-columns: repeat(3, minmax(0, 1fr)); }
	.footer-grid { grid-template-columns: repeat(2, 1fr); }
}

@media (max-width: 900px) {
	.sa-header__main-inner { grid-template-columns: 1fr auto; }
	.sa-header__burger { display: flex; }
	.sa-nav,
	.sa-header__nav-area { display: none; }
	.sa-hero__grid { grid-template-columns: 1fr; }
	.sa-hero__sidebar { display: none; }
	.sa-hero__stage { padding: 1.75rem; min-height: 320px; }
	.sa-flash__inner { grid-template-columns: 1fr; text-align: center; gap: 1.25rem; }
	.sa-flash__timer { justify-content: center; }
	.sa-flash__desc { margin-inline: auto; }
	.souq-category-grid { grid-template-columns: repeat(2, 1fr); }
	.souq-category-card--wide, .souq-category-card--tall { grid-column: span 1; grid-row: span 1; }
	.souq-why__inner { grid-template-columns: 1fr; }
	.souq-trust__grid { grid-template-columns: repeat(2, 1fr); }
	.sa-stats__grid { grid-template-columns: repeat(2, 1fr); }
	.souq-shop-controls {
		grid-template-columns: 1fr;
	}
	.souq-shop-controls__sort .woocommerce-ordering select { width: 100%; min-width: 0; }
}

@media (max-width: 600px) {
	.souq-product-grid, .woocommerce ul.products { grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 0.75rem; }
	.souq-product-card__title { font-size: 0.8rem; min-height: 2.4em; }
	.souq-product-card__price { font-size: 0.82rem; }
	.souq-product-card__media { height: 148px; padding: 0.85rem; }
	.souq-product-card__image-link img,
	.souq-placeholder-thumb { max-height: 120px; }
	.btn--cart { padding: 0.55rem 0.75rem; font-size: 0.78rem; }
	.souq-promo-row__grid { grid-template-columns: 1fr; }
	.souq-delivery-cta__grid { grid-template-columns: 1fr; }
	.souq-single-product__grid { grid-template-columns: 1fr; }
	.footer-grid { grid-template-columns: 1fr; }
	.souq-trust__grid, .sa-stats__grid { grid-template-columns: 1fr; }
}
