/* =========================================================
   Matjari — Hanout-style COD WooCommerce theme
   Uses CSS logical properties → works in RTL and LTR.
   ========================================================= */

:root {
	--mj-primary: #f97316;
	--mj-accent: #c2185b;
	--mj-accent-light: #e91e7a;
	--mj-green: #22c55e;
	--mj-dark: #0f172a;
	--mj-darker: #0b1120;
	--mj-bg: #f8f9fa;
	--mj-card: #ffffff;
	--mj-text: #1f2937;
	--mj-muted: #6b7280;
	--mj-border: #e5e7eb;
	--mj-radius: 16px;
	--mj-btn-radius: 12px;
	--mj-shadow: 0 2px 8px rgba(0, 0, 0, .06), 0 8px 24px rgba(0, 0, 0, .04);
	--mj-shadow-lg: 0 8px 32px rgba(0, 0, 0, .12);
	--mj-price: var(--mj-primary);
	--mj-sale: #dc2626;
	--mj-topbar-bg: var(--mj-dark);
	--mj-header-bg: #ffffff;
	--mj-footer-bg: var(--mj-accent);
	--mj-whatsapp: #25d366;
	--mj-font: 'Cairo', 'Tajawal', Tahoma, Arial, sans-serif;
	--mj-font-heading: inherit;
	--mj-font-size: 15px;
	--mj-heading-weight: 800;
	--mj-container: 1240px;
	--mj-logo-w: 160px;
	--mj-logo-w-mobile: 120px;
}

html { overflow-x: hidden; }
* { box-sizing: border-box; }

body {
	margin: 0;
	font-family: var(--mj-font);
	background: var(--mj-bg);
	color: var(--mj-text);
	font-size: var(--mj-font-size);
	line-height: 1.7;
	overflow-x: hidden;
}

h1, h2, h3, h4, h5, h6 {
	font-family: var(--mj-font-heading);
	font-weight: var(--mj-heading-weight);
}

img { max-width: 100%; height: auto; }
a { color: var(--mj-primary); text-decoration: none; }
a:hover { opacity: .9; }

.mj-container { max-width: var(--mj-container); margin-inline: auto; padding-inline: 16px; }
.mj-center { text-align: center; }

/* ---------------- Icons */
.mj-icon { vertical-align: middle; flex-shrink: 0; }

/* ---------------- Top info bar */
.mj-topinfo {
	background: var(--mj-dark);
	color: #cbd5e1;
	font-size: 13px;
	border-bottom: 1px solid rgba(255, 255, 255, .06);
	overflow: hidden;
}
.mj-topinfo-inner {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 16px;
	min-height: 36px;
}
.mj-topinfo-items { display: flex; align-items: center; gap: 22px; flex-wrap: wrap; }
.mj-topinfo-item {
	display: inline-flex;
	align-items: center;
	gap: 6px;
	color: #cbd5e1;
	font-weight: 600;
}
.mj-topinfo-item .mj-icon { color: var(--mj-primary); }
.mj-topinfo-item:hover { color: #fff; opacity: 1; }
.mj-topinfo-social { display: flex; align-items: center; gap: 4px; }
.mj-topinfo-social a {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 28px;
	height: 28px;
	border-radius: 6px;
	color: #94a3b8;
	transition: .15s;
}
.mj-topinfo-social a:hover { color: #fff; background: rgba(255, 255, 255, .1); opacity: 1; }

/* ---------------- Topbar (announcement) */
.mj-topbar {
	background: linear-gradient(90deg, var(--mj-dark) 0%, var(--mj-darker) 100%);
	color: #e2e8f0;
	font-size: 13.5px;
	font-weight: 600;
	padding: 8px 0;
	border-bottom: 1px solid rgba(255, 255, 255, .05);
	overflow: hidden;
	white-space: nowrap;
}
.mj-topbar-track {
	display: inline-flex;
	animation: mj-marquee 20s linear infinite;
	will-change: transform;
}
.mj-topbar-item {
	display: inline-flex;
	align-items: center;
	gap: 6px;
	padding-inline: 40px;
	white-space: nowrap;
	flex-shrink: 0;
}
.mj-topbar-item .mj-icon { color: var(--mj-primary); }
@keyframes mj-marquee {
	0% { transform: translateX(-50%); }
	100% { transform: translateX(0); }
}
.mj-topbar strong { color: #4caf50; }

/* ---------------- Header */
.mj-header { background: var(--mj-header-bg); border-bottom: 1px solid var(--mj-border); position: relative; z-index: 50; }
.mj-header-inner {
	display: flex;
	align-items: center;
	gap: 28px;
	padding-block: 16px;
}
.mj-logo { flex-shrink: 0; display: flex; align-items: center; }
.mj-logo-text { font-size: 22px; font-weight: 800; color: #fff; text-decoration: none; }
.mj-logo img { max-width: 48px; height: auto; }
.mj-navwrap .mj-logo { margin-inline-end: 8px; }
.mj-navwrap .mj-logo img { max-height: 40px; width: auto; filter: brightness(0) invert(1); }
.mj-navwrap .custom-logo-link { display: flex; align-items: center; }

/* Support block (right side of header) */
.mj-header-support {
	display: flex;
	align-items: center;
	gap: 10px;
	color: var(--mj-dark);
}
.mj-header-support-icon {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 44px;
	height: 44px;
	border-radius: 50%;
	background: rgba(194, 24, 91, .08);
	color: var(--mj-primary);
	flex-shrink: 0;
}
.mj-header-support-text { display: flex; flex-direction: column; line-height: 1.3; }
.mj-header-support-text small { color: var(--mj-muted); font-size: 12px; }
.mj-header-support-text strong { font-size: 16px; font-weight: 800; }

.mj-search {
	flex: 1;
	display: flex;
	border: 2px solid var(--mj-primary);
	border-radius: 999px;
	overflow: hidden;
	background: #fff;
	max-width: 560px;
}
.mj-search select {
	border: 0;
	background: #f8f9fa;
	padding-inline: 12px;
	font-family: inherit;
	font-size: 14px;
	max-width: 150px;
	cursor: pointer;
	border-inline-end: 1px solid var(--mj-border);
}
.mj-search input[type="search"] {
	flex: 1;
	border: 0;
	padding: 11px 14px;
	font-family: inherit;
	font-size: 15px;
	outline: none;
	min-width: 0;
}
.mj-search button {
	border: 0;
	background: var(--mj-primary);
	color: #fff;
	padding-inline: 22px;
	cursor: pointer;
	display: flex;
	align-items: center;
	transition: background .15s;
}
.mj-search button:hover { background: #ea580c; }

.mj-header-contact { display: flex; align-items: center; gap: 14px; }

/* Mobile menu toggle */
.mj-menu-toggle {
	display: none;
	flex-direction: column;
	gap: 5px;
	background: none;
	border: 0;
	cursor: pointer;
	padding: 8px;
	border-radius: 8px;
	transition: background .15s;
}
.mj-menu-toggle:hover { background: rgba(255,255,255,.15); }
.mj-menu-toggle span { width: 22px; height: 3px; background: #fff; border-radius: 2px; transition: transform .2s; }

/* ---------------- Navigation bar (sticky) */
.mj-navwrap { background: var(--mj-accent); position: relative; z-index: 49; }
.mj-navwrap.mj-stuck {
	position: fixed;
	top: 0;
	left: 0;
	right: 0;
	max-width: 100vw;
	box-shadow: 0 4px 20px rgba(0, 0, 0, .3);
	animation: mj-slide-down .25s ease;
}
@keyframes mj-slide-down {
	from { transform: translateY(-100%); }
	to { transform: translateY(0); }
}
.mj-navwrap-inner { display: flex; align-items: stretch; gap: 8px; }

/* All-categories dropdown */
.mj-allcats { position: relative; flex-shrink: 0; }
.mj-allcats-btn {
	display: flex;
	align-items: center;
	gap: 10px;
	height: 100%;
	min-height: 52px;
	border: 0;
	background: #fff;
	color: var(--mj-accent);
	font-family: inherit;
	font-size: 15px;
	font-weight: 700;
	padding-inline: 22px;
	cursor: pointer;
	transition: background .15s;
	border-radius: 0;
}
.mj-allcats-btn:hover { background: #fff5f8; }
.mj-allcats-btn .mj-icon-chevron-down { transition: transform .2s; }
.mj-allcats.open .mj-allcats-btn .mj-icon-chevron-down { transform: rotate(180deg); }
.mj-allcats-menu {
	display: none;
	position: absolute;
	top: 100%;
	inset-inline-start: 0;
	min-width: 260px;
	background: #fff;
	border: 1px solid var(--mj-border);
	border-radius: 0 0 12px 12px;
	box-shadow: 0 16px 40px rgba(0, 0, 0, .15);
	list-style: none;
	margin: 0;
	padding: 6px 0;
	z-index: 70;
}
.mj-allcats.open .mj-allcats-menu { display: block; }
.mj-allcats-menu li a {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 10px;
	padding: 11px 18px;
	color: var(--mj-text);
	font-weight: 600;
	font-size: 14px;
	border-bottom: 1px solid #f1f5f9;
	transition: background .1s;
}
.mj-allcats-menu li:last-child a { border-bottom: 0; }
.mj-allcats-menu li a:hover { background: rgba(194, 24, 91, .04); color: var(--mj-primary); opacity: 1; }
.mj-allcats-menu li a em {
	font-style: normal;
	background: #f1f5f9;
	color: var(--mj-muted);
	font-size: 12px;
	font-weight: 700;
	border-radius: 999px;
	padding: 1px 9px;
}
.mj-allcats-empty { padding: 12px 18px; color: var(--mj-muted); font-size: 14px; }

/* Menu links */
.mj-nav { flex: 1; min-width: 0; }
.mj-nav-list {
	list-style: none;
	margin: 0;
	padding: 0;
	display: flex;
	flex-wrap: wrap;
	gap: 2px;
	height: 100%;
}
.mj-nav-list li { position: relative; display: flex; }
.mj-nav-list li a {
	display: flex;
	align-items: center;
	color: #e2e8f0;
	padding: 14px 20px;
	font-weight: 600;
	font-size: 15px;
	position: relative;
	transition: color .15s;
}
.mj-nav-list > li > a::after {
	content: "";
	position: absolute;
	bottom: 0;
	inset-inline: 20px;
	height: 3px;
	border-radius: 3px 3px 0 0;
	background: var(--mj-primary);
	transform: scaleX(0);
	transition: transform .2s;
}
.mj-nav-list > li > a:hover::after,
.mj-nav-list > li.current-menu-item > a::after { transform: scaleX(1); }
.mj-nav-list li a:hover,
.mj-nav-list li.current-menu-item > a { color: #fff; opacity: 1; }
.mj-nav-list .sub-menu {
	display: none;
	position: absolute;
	top: 100%;
	inset-inline-start: 0;
	background: #fff;
	border: 1px solid var(--mj-border);
	border-radius: 0 0 12px 12px;
	box-shadow: 0 16px 40px rgba(0, 0, 0, .15);
	list-style: none;
	margin: 0;
	padding: 6px 0;
	min-width: 210px;
	z-index: 70;
}
.mj-nav-list .sub-menu li a { color: var(--mj-text); padding: 10px 18px; width: 100%; }
.mj-nav-list .sub-menu li a:hover { background: rgba(194, 24, 91, .04); color: var(--mj-primary); }
.mj-nav-list li:hover > .sub-menu { display: block; }

/* COD badge in nav */
.mj-nav-badge {
	display: flex;
	align-items: center;
	gap: 8px;
	color: var(--mj-accent);
	font-size: 13.5px;
	font-weight: 700;
	white-space: nowrap;
	padding-inline: 14px;
}

/* Track order link in nav */
.mj-nav-track {
	display: flex;
	align-items: center;
	gap: 7px;
	color: #fff;
	font-size: 13.5px;
	font-weight: 700;
	white-space: nowrap;
	padding: 8px 14px;
	background: rgba(255,255,255,.12);
	border-radius: 8px;
	transition: background .2s;
	text-decoration: none;
	margin-inline: 6px;
}
.mj-nav-track:hover { background: rgba(255,255,255,.22); color: #fff; }
.mj-nav-track-mobile { display: none; }

/* ---------------- Hero */
.mj-hero {
	background: linear-gradient(135deg, #e8dff5 0%, #f0e6fa 40%, #ede4f7 100%);
	backdrop-filter: blur(20px) saturate(1.2);
	-webkit-backdrop-filter: blur(20px) saturate(1.2);
	color: var(--mj-dark);
	padding: 50px 40px;
	margin: 20px auto;
	max-width: var(--mj-container);
	border-radius: 28px;
	border: 1px solid rgba(255, 255, 255, .6);
	box-shadow: 0 8px 32px rgba(120, 80, 180, .12), inset 0 1px 0 rgba(255, 255, 255, .8);
	overflow: hidden;
	position: relative;
}
.mj-hero-deco { position: absolute; inset: 0; pointer-events: none; }
.mj-hero-blob {
	position: absolute;
	border-radius: 50%;
	filter: blur(80px);
	opacity: .25;
}
.mj-hero-blob-1 { width: 400px; height: 400px; background: var(--mj-accent); top: -150px; inset-inline-end: -100px; opacity: .12; }
.mj-hero-blob-2 { width: 300px; height: 300px; background: var(--mj-primary); bottom: -160px; inset-inline-start: -80px; opacity: .1; }
.mj-hero-grid {
	position: absolute;
	inset: 0;
	background-image:
		linear-gradient(rgba(120, 80, 180, .03) 1px, transparent 1px),
		linear-gradient(90deg, rgba(120, 80, 180, .03) 1px, transparent 1px);
	background-size: 50px 50px;
	mask-image: radial-gradient(ellipse 70% 70% at 50% 40%, #000, transparent);
	-webkit-mask-image: radial-gradient(ellipse 70% 70% at 50% 40%, #000, transparent);
}
.mj-hero-inner {
	display: grid;
	grid-template-columns: 1fr 1.1fr;
	gap: 40px;
	align-items: center;
	position: relative;
}
.mj-hero-text {
	display: flex;
	flex-direction: column;
	justify-content: center;
}
.mj-hero-text h1 {
	font-size: 40px;
	font-weight: var(--mj-heading-weight);
	margin: 0 0 18px;
	line-height: 1.25;
	letter-spacing: -.5px;
	color: var(--mj-dark);
}
.mj-hero-text p { color: #555; margin: 0 0 30px; font-size: 17px; max-width: 500px; line-height: 1.7; }

.mj-hero-actions { display: flex; align-items: center; gap: 16px; flex-wrap: wrap; }
.mj-hero-cta {
	display: inline-flex;
	align-items: center;
	gap: 10px;
	background: var(--mj-accent);
	color: #fff;
	font-weight: 800;
	font-size: 17px;
	border-radius: var(--mj-btn-radius);
	padding: 15px 38px;
	transition: .2s;
	box-shadow: 0 4px 20px rgba(194, 24, 91, .35);
}
.mj-hero-cta:hover { transform: translateY(-2px); opacity: 1; box-shadow: 0 6px 28px rgba(194, 24, 91, .45); }
.mj-hero-cta-ghost {
	display: inline-flex;
	align-items: center;
	border: 2px solid rgba(31, 41, 55, .3);
	color: var(--mj-dark);
	font-weight: 700;
	font-size: 16px;
	border-radius: var(--mj-btn-radius);
	padding: 13px 30px;
	transition: .2s;
}
.mj-hero-cta-ghost:hover { background: rgba(31, 41, 55, .06); border-color: rgba(31, 41, 55, .5); opacity: 1; }

/* Hero right side: cards + product */
.mj-hero-right {
	position: relative;
	display: grid;
	grid-template-columns: 1fr auto;
	gap: 20px;
	align-items: center;
	min-height: 380px;
}
.mj-hero-cards {
	display: flex;
	flex-direction: column;
	gap: 12px;
	z-index: 3;
}
.mj-hero-card {
	display: flex;
	align-items: center;
	gap: 12px;
	background: rgba(255, 255, 255, .65);
	backdrop-filter: blur(16px);
	-webkit-backdrop-filter: blur(16px);
	color: var(--mj-dark);
	border: 1px solid rgba(255, 255, 255, .7);
	border-radius: 16px;
	padding: 14px 18px;
	box-shadow: 0 4px 16px rgba(120, 80, 180, .08);
	min-width: 210px;
	transition: transform .2s, background .2s;
}
.mj-hero-card:hover {
	background: rgba(255, 255, 255, .85);
	transform: translateY(-2px);
}
.mj-hero-card-ic {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 44px;
	height: 44px;
	border-radius: 50%;
	background: #8b5cf6;
	color: #fff;
	flex-shrink: 0;
}
.mj-hero-card-ic-purple { background: #8b5cf6; }
.mj-hero-card-ic-green { background: #22c55e; }
.mj-hero-card-ic-pink { background: var(--mj-accent); }
.mj-hero-card-text strong {
	display: block;
	font-size: 13.5px;
	font-weight: 800;
	margin-bottom: 1px;
	color: var(--mj-dark);
}
.mj-hero-card-text small {
	color: #666;
	font-size: 11.5px;
}
.mj-hero-product {
	position: relative;
	display: flex;
	align-items: center;
	justify-content: center;
	z-index: 2;
}
.mj-hero-pedestal {
	position: absolute;
	bottom: -20px;
	left: 50%;
	transform: translateX(-50%);
	width: 320px;
	height: 320px;
	border-radius: 50%;
	background: linear-gradient(135deg, rgba(255, 255, 255, .7), rgba(230, 220, 250, .4));
	border: 1px solid rgba(255, 255, 255, .8);
	box-shadow: 0 8px 32px rgba(120, 80, 180, .1);
}
.mj-hero-product img {
	max-height: 300px;
	width: auto;
	position: relative;
	filter: drop-shadow(0 12px 30px rgba(120, 80, 180, .25));
	z-index: 2;
	object-fit: contain;
	border-radius: 16px;
	background: rgba(255, 255, 255, .6);
	padding: 12px;
	backdrop-filter: blur(4px);
}
.mj-hero-icon { color: rgba(120, 80, 180, .2); position: relative; z-index: 2; }

/* ---------------- Trust badges (below hero) */
.mj-trust-badges {
	background: #fff;
	border-radius: var(--mj-radius);
	box-shadow: 0 4px 20px rgba(0, 0, 0, .06);
	padding: 26px 36px;
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 28px;
	margin-top: -20px;
	position: relative;
	z-index: 10;
	max-width: var(--mj-container);
	margin-inline: auto;
}
.mj-trust-badge {
	display: flex;
	align-items: center;
	gap: 16px;
}
.mj-trust-badge-ic {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 50px;
	height: 50px;
	border-radius: 50%;
	background: var(--mj-accent);
	color: #fff;
	flex-shrink: 0;
}
.mj-trust-badge-text strong {
	display: block;
	font-size: 15px;
	font-weight: 800;
	color: var(--mj-accent);
	margin-bottom: 2px;
}
.mj-trust-badge-text small {
	color: var(--mj-muted);
	font-size: 13px;
}

/* ---------------- Landing pages grid */
.mj-landing-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 18px; }
.mj-landing-card {
	background: #fff;
	border-radius: var(--mj-radius);
	box-shadow: var(--mj-shadow);
	overflow: hidden;
	text-align: center;
	display: flex;
	flex-direction: column;
	transition: transform .15s;
	color: var(--mj-text);
}
.mj-landing-card:hover { transform: translateY(-4px); opacity: 1; }
.mj-landing-card img { aspect-ratio: 4 / 3; object-fit: cover; width: 100%; }
.mj-landing-ph {
	aspect-ratio: 4 / 3;
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 64px;
	background: linear-gradient(135deg, #fff7ed, #ffedd5);
}
.mj-landing-name { font-weight: 700; padding: 12px; font-size: 15px; }

/* ---------------- Sections */
.mj-home-section { padding-block: 48px; }
.mj-home-section-alt { background: #fff; }
.mj-section-head { text-align: center; margin-bottom: 36px; }
.mj-section-head h2 {
	font-size: 28px;
	font-weight: 800;
	margin: 0 0 8px;
	color: var(--mj-dark);
	position: relative;
	display: inline-block;
	padding-bottom: 12px;
}
.mj-section-head h2::after {
	content: "";
	position: absolute;
	left: 50%;
	transform: translateX(-50%);
	bottom: 0;
	width: 60px;
	height: 4px;
	border-radius: 4px;
	background: var(--mj-primary);
}
.mj-section-head p { margin: 8px 0 0; color: var(--mj-muted); font-size: 15px; }

.mj-btn-outline {
	display: inline-block;
	margin-top: 24px;
	border: 2px solid var(--mj-primary);
	color: var(--mj-primary);
	border-radius: var(--mj-btn-radius);
	padding: 11px 34px;
	font-weight: 700;
	transition: .2s;
}
.mj-btn-outline:hover { background: var(--mj-primary); color: #fff; opacity: 1; }

/* ---------------- Category cards */
.mj-cats-grid {
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	gap: 20px;
}
.mj-cat-card {
	position: relative;
	border-radius: var(--mj-radius);
	overflow: hidden;
	background-size: cover;
	background-position: center;
	min-height: 200px;
	display: flex;
	box-shadow: var(--mj-shadow);
	transition: transform .2s, box-shadow .2s;
}
.mj-cat-card:hover { transform: translateY(-4px); box-shadow: var(--mj-shadow-lg); }
.mj-cat-overlay {
	margin-top: auto;
	width: 100%;
	padding: 44px 18px 18px;
	background: linear-gradient(to top, rgba(26, 26, 46, .9), transparent);
	display: flex;
	flex-direction: column;
	gap: 8px;
}
.mj-cat-name { color: #fff; font-weight: 800; font-size: 18px; }
.mj-cat-btn {
	align-self: flex-start;
	background: var(--mj-primary);
	color: #fff;
	border-radius: var(--mj-btn-radius);
	padding: 5px 18px;
	font-size: 13px;
	font-weight: 700;
	transition: .15s;
}
.mj-cat-btn:hover { filter: brightness(1.1); }

/* ---------------- Features strip */
.mj-features-strip { background: #fff; color: var(--mj-text); padding-block: 24px; border-bottom: 1px solid var(--mj-border); }
.mj-features-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 16px; text-align: center; }
.mj-feature { display: flex; flex-direction: column; gap: 6px; align-items: center; padding: 12px; border-radius: var(--mj-radius); transition: background .15s; }
.mj-feature:hover { background: rgba(249, 115, 22, .04); }
.mj-feature-ic {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 52px;
	height: 52px;
	border-radius: 14px;
	background: rgba(249, 115, 22, .08);
	color: var(--mj-primary);
	margin-bottom: 4px;
}
.mj-feature small { color: var(--mj-muted); font-size: 13px; }

/* =========================================================
   WooCommerce
   ========================================================= */
.mj-shop { padding-block: 32px; }

.woocommerce ul.products {
	display: grid !important;
	grid-template-columns: repeat(4, 1fr);
	gap: 20px;
	margin: 0 0 32px !important;
	padding: 0;
	list-style: none;
}
.woocommerce ul.products::before,
.woocommerce ul.products::after { display: none; }
.woocommerce ul.products li.product {
	width: auto !important;
	float: none !important;
	margin: 0 !important;
	background: var(--mj-card);
	border-radius: var(--mj-radius);
	box-shadow: var(--mj-shadow);
	overflow: hidden;
	display: flex;
	flex-direction: column;
	text-align: center;
	transition: transform .2s, box-shadow .2s;
	position: relative;
	padding-bottom: 18px !important;
}
.woocommerce ul.products li.product:hover {
	transform: translateY(-6px);
	box-shadow: var(--mj-shadow-lg);
}
.woocommerce ul.products li.product img { margin: 0 !important; aspect-ratio: 1; object-fit: contain; padding: 16px; }
.mj-loop-cat {
	display: block;
	font-size: 12px;
	color: var(--mj-muted);
	margin-top: 8px;
	font-weight: 600;
}
.woocommerce ul.products li.product .woocommerce-loop-product__title {
	font-size: 15px !important;
	font-weight: 700;
	padding: 4px 14px !important;
	color: var(--mj-text);
	min-height: 48px;
}
.woocommerce ul.products li.product .price {
	color: var(--mj-price) !important;
	font-weight: 800;
	font-size: 18px !important;
	margin-bottom: 12px !important;
}
.woocommerce ul.products li.product .price del { color: var(--mj-muted); font-weight: 400; font-size: 14px; }
.woocommerce ul.products li.product .star-rating { margin: 4px auto 6px !important; }

.woocommerce ul.products li.product .button.mj-loop-buy,
.mj-loop-buy {
	margin: 4px auto 0 !important;
	background: var(--mj-primary) !important;
	color: #fff !important;
	border-radius: var(--mj-btn-radius) !important;
	font-weight: 700 !important;
	padding: 10px 30px !important;
	transition: .2s;
}
.mj-loop-buy:hover { filter: brightness(1.08); }

.woocommerce span.onsale {
	background: var(--mj-primary) !important;
	border-radius: 8px !important;
	font-weight: 800;
	min-height: 0 !important;
	min-width: 0 !important;
	line-height: 1 !important;
	padding: 6px 12px !important;
	inset-inline-start: 12px;
	inset-inline-end: auto;
	top: 12px !important;
	z-index: 5;
	font-size: 13px !important;
}

/* ---------------- Single product */
.woocommerce div.product div.summary { margin-bottom: 32px; }
.woocommerce div.product .product_title { font-size: 26px; font-weight: 800; color: var(--mj-dark); }
.woocommerce div.product p.price { color: var(--mj-price) !important; font-size: 26px !important; font-weight: 800; }
.woocommerce div.product p.price del { font-size: 18px; color: var(--mj-muted); }

/* ---------------- Product page grid */
.mj-product-grid {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 40px;
	align-items: start;
}
.mj-product-main { display: contents; }

/* Gallery */
.mj-product-gallery { position: sticky; top: 90px; }
.mj-gallery-main {
	border-radius: var(--mj-radius);
	overflow: hidden;
	background: #fff;
	margin-bottom: 10px;
}
.mj-gallery-main-img {
	width: 100%;
	aspect-ratio: 1;
	object-fit: contain;
	display: block;
}
.mj-gallery-strip {
	display: flex;
	flex-wrap: nowrap;
	gap: 8px;
	overflow-x: auto;
	scroll-snap-type: x mandatory;
	-webkit-overflow-scrolling: touch;
	scrollbar-width: none;
	padding-bottom: 4px;
}
.mj-gallery-strip::-webkit-scrollbar { display: none; }
.mj-gallery-thumb {
	width: 64px;
	height: 64px;
	object-fit: cover;
	border-radius: 10px;
	border: 2px solid var(--mj-border, #e5e7eb);
	cursor: pointer;
	flex-shrink: 0;
	scroll-snap-align: start;
	transition: border-color .2s, transform .15s;
}
.mj-gallery-thumb:hover { border-color: var(--mj-primary); transform: scale(1.05); }
.mj-gallery-thumb.active { border-color: var(--mj-primary); box-shadow: 0 0 0 2px rgba(194, 24, 91, .2); }

/* Summary */
.mj-product-summary { padding-top: 8px; }
.mj-product-price {
	display: inline-flex;
	align-items: center;
	gap: 10px;
	margin-bottom: 12px;
	line-height: 1;
	font-size: 24px;
	font-weight: 800;
	color: var(--mj-price);
}
.mj-product-price del {
	font-size: 16px;
	color: var(--mj-muted);
	font-weight: 400;
	text-decoration: line-through;
}
.mj-product-discount {
	background: var(--mj-primary);
	color: #fff;
	font-size: 13px;
	font-weight: 800;
	padding: 3px 8px;
	border-radius: 6px;
	line-height: 1;
	vertical-align: middle;
}
.mj-product-description { color: var(--mj-muted); font-size: 15px; line-height: 1.7; margin-bottom: 20px; overflow-wrap: break-word; word-wrap: break-word; }
.mj-product-description img { max-width: 100% !important; height: auto !important; }
.mj-product-description table { width: 100%; display: block; overflow-x: auto; }

/* ---------------- COD order form */
.mj-order-box {
	background: #fff;
	border: 2px solid var(--mj-primary);
	border-radius: var(--mj-radius);
	padding: 22px;
	margin-block: 20px;
	box-shadow: var(--mj-shadow);
}
.mj-order-title {
	display: flex;
	align-items: center;
	gap: 10px;
	margin: -22px -22px 18px;
	padding: 14px 22px;
	background: var(--mj-primary);
	color: #fff;
	font-size: 17px;
	font-weight: 800;
	border-radius: 12px 12px 0 0;
}
.mj-field { margin-bottom: 14px; }
.mj-field label { display: block; font-weight: 700; font-size: 14px; margin-bottom: 5px; }
.mj-field .req { color: #dc2626; }
.mj-field input,
.mj-field select {
	width: 100%;
	border: 1.5px solid var(--mj-border);
	border-radius: 8px;
	padding: 11px 12px;
	font-family: inherit;
	font-size: 15px;
	background: #fafafa;
	transition: border-color .15s;
}
.mj-field input:focus,
.mj-field select:focus { outline: none; border-color: var(--mj-primary); background: #fff; }
.mj-field--error input,
.mj-field--error select { border-color: #dc2626 !important; background: #fef2f2 !important; }
.mj-field--error label { color: #dc2626; }
.mj-radio-options--error { outline: 2px solid #dc2626; outline-offset: 4px; border-radius: 12px; }
.mj-field-row { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; }
.mj-hp { position: absolute !important; inset-inline-start: -9999px; }

/* Quantity stepper */
.mj-qty { display: inline-flex; border: 1.5px solid var(--mj-border); border-radius: 8px; overflow: hidden; }
.mj-qty button {
	width: 42px;
	border: 0;
	background: #f3f4f6;
	font-size: 20px;
	cursor: pointer;
	font-family: inherit;
}
.mj-qty input {
	width: 64px;
	border: 0;
	text-align: center;
	font-size: 16px;
	font-weight: 700;
	font-family: inherit;
	-moz-appearance: textfield;
}
.mj-qty input::-webkit-inner-spin-button { -webkit-appearance: none; }

/* Quantity offers */
.mj-offers { margin-bottom: 14px; }
.mj-offers-title { font-weight: 800; margin: 0 0 8px; }
.mj-offer {
	display: flex;
	align-items: center;
	gap: 10px;
	border: 1.5px solid var(--mj-border);
	border-radius: 8px;
	padding: 10px 12px;
	margin-bottom: 8px;
	cursor: pointer;
	transition: .15s;
	background: #fafafa;
}
.mj-offer.selected { border-color: var(--mj-buy); background: #f0fdf4; box-shadow: 0 0 0 1px var(--mj-buy); }
.mj-offer-label { flex: 1; font-weight: 600; font-size: 14px; }
.mj-offer-price { font-weight: 800; color: var(--mj-buy); }

/* Order summary */
.mj-summary { width: 100%; border-collapse: collapse; margin-bottom: 14px; font-size: 15px; }
.mj-summary td { padding: 7px 4px; border-bottom: 1px dashed var(--mj-border); }
.mj-summary td:last-child { text-align: end; font-weight: 700; }
.mj-sum-total-row td { font-size: 18px; font-weight: 800; color: var(--mj-primary); border-bottom: 0; }

/* Submit */
.mj-submit-btn {
	width: 100%;
	border: 0;
	background: var(--mj-primary);
	color: #fff;
	font-family: inherit;
	font-size: 18px;
	font-weight: 800;
	border-radius: var(--mj-btn-radius);
	padding: 16px;
	cursor: pointer;
	transition: .2s;
	box-shadow: 0 4px 20px rgba(249, 115, 22, .3);
}
.mj-submit-btn:hover { filter: brightness(1.08); box-shadow: 0 6px 28px rgba(249, 115, 22, .4); }
.mj-submit-btn:disabled { opacity: .6; cursor: wait; animation: none; box-shadow: none; }
@keyframes mj-pulse {
	0% { box-shadow: 0 0 0 0 rgba(249, 115, 22, .5); }
	70% { box-shadow: 0 0 0 14px rgba(249, 115, 22, 0); }
	100% { box-shadow: 0 0 0 0 rgba(249, 115, 22, 0); }
}
.mj-cod-note { text-align: center; font-size: 13px; color: var(--mj-muted); margin: 10px 0 0; }
.mj-form-msg { display: none; margin-top: 12px; padding: 10px 14px; border-radius: 8px; font-weight: 600; font-size: 14px; }
.mj-form-msg.error { display: block; background: #fef2f2; color: #b91c1c; border: 1px solid #fecaca; }

/* Trust badges */
.mj-trust { display: grid; grid-template-columns: 1fr 1fr; gap: 10px; margin-top: 16px; }
.mj-trust-item {
	display: flex;
	align-items: center;
	gap: 10px;
	background: #fff;
	border: 1px solid var(--mj-border);
	border-radius: 10px;
	padding: 10px 14px;
	font-size: 13px;
	font-weight: 600;
	transition: border-color .15s;
}
.mj-trust-item:hover { border-color: var(--mj-primary); }
.mj-trust-ic {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 34px;
	height: 34px;
	border-radius: 10px;
	background: rgba(249, 115, 22, .08);
	color: var(--mj-primary);
	flex-shrink: 0;
}

/* ---------------- Success modal */
.mj-modal {
	position: fixed;
	inset: 0;
	background: rgba(15, 23, 42, .6);
	display: flex;
	align-items: center;
	justify-content: center;
	z-index: 1000;
	padding: 16px;
}
.mj-modal[hidden] { display: none; }
.mj-modal-card {
	background: #fff;
	border-radius: 16px;
	max-width: 420px;
	width: 100%;
	padding: 32px 24px;
	text-align: center;
	box-shadow: 0 24px 64px rgba(0, 0, 0, .25);
}
.mj-modal-check {
	width: 70px;
	height: 70px;
	margin: 0 auto 16px;
	border-radius: 50%;
	background: var(--mj-buy);
	color: #fff;
	font-size: 38px;
	display: flex;
	align-items: center;
	justify-content: center;
}
.mj-modal-card h3 { margin: 0 0 8px; font-size: 22px; color: var(--mj-dark); }
.mj-modal-card p { color: var(--mj-muted); margin: 0 0 12px; }
.mj-modal-summary { background: #f8fafc; border-radius: 8px; padding: 10px; font-weight: 700; margin-bottom: 16px; }
.mj-modal-summary:empty { display: none; }
.mj-modal-close {
	border: 0;
	background: var(--mj-dark);
	color: #fff;
	border-radius: var(--mj-btn-radius);
	padding: 10px 36px;
	font-family: inherit;
	font-weight: 700;
	cursor: pointer;
}

/* ---------------- Sticky buy bar */
.mj-sticky-buy {
	position: fixed;
	bottom: 0;
	left: 0;
	right: 0;
	max-width: 100vw;
	background: #fff;
	box-shadow: 0 -4px 16px rgba(15, 23, 42, .12);
	display: flex;
	align-items: center;
	gap: 16px;
	padding: 10px 16px;
	z-index: 900;
}
.mj-sticky-buy[hidden] { display: none; }
.mj-sticky-info { display: flex; flex-direction: column; min-width: 0; }
.mj-sticky-name { font-weight: 700; font-size: 14px; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.mj-sticky-price { color: var(--mj-price); font-weight: 800; }
.mj-sticky-price del { color: var(--mj-muted); font-weight: 400; font-size: 13px; }
.mj-sticky-btn {
	margin-inline-start: auto;
	border: 0;
	background: var(--mj-buy);
	color: #fff;
	font-family: inherit;
	font-weight: 800;
	font-size: 16px;
	border-radius: var(--mj-btn-radius);
	padding: 12px 28px;
	cursor: pointer;
	white-space: nowrap;
	max-width: 50%;
	text-align: center;
	flex-shrink: 0;
}

/* ---------------- Countdown timer */
.mj-countdown {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: 12px;
}
.mj-countdown-box {
	background: #fff7ed;
	border: 1.5px dashed var(--mj-primary);
	border-radius: var(--mj-radius);
	padding: 14px 18px;
	margin-block: 14px;
	justify-content: center;
}
.mj-countdown-title { font-weight: 800; color: #c2410c; font-size: 15px; }
.mj-countdown-units { display: flex; align-items: center; gap: 6px; direction: ltr; }
.mj-cd-unit {
	display: flex;
	flex-direction: column;
	align-items: center;
	min-width: 54px;
	background: var(--mj-dark);
	color: #fff;
	border-radius: 10px;
	padding: 8px 10px 6px;
}
.mj-cd-unit b { font-size: 22px; line-height: 1.1; font-variant-numeric: tabular-nums; }
.mj-cd-unit small { font-size: 10px; color: #78909c; font-weight: 600; }
.mj-cd-sep { font-weight: 800; font-size: 18px; color: var(--mj-primary); }

/* Flash sale strip (homepage) */
.mj-flash-strip {
	background: linear-gradient(120deg, #b91c1c, #ea580c);
	color: #fff;
	padding-block: 18px;
}
.mj-flash-inner {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	justify-content: space-between;
	gap: 16px;
}
.mj-flash-text { display: flex; align-items: center; gap: 12px; flex-wrap: wrap; }
.mj-flash-badge {
	background: rgba(255, 255, 255, .18);
	border: 1px solid rgba(255, 255, 255, .35);
	border-radius: 999px;
	padding: 4px 14px;
	font-weight: 800;
	font-size: 14px;
	white-space: nowrap;
}
.mj-flash-text strong { font-size: 18px; }
.mj-countdown-strip .mj-cd-unit { background: rgba(0, 0, 0, .35); }
.mj-flash-btn {
	background: #fff;
	color: #b91c1c;
	font-weight: 800;
	border-radius: var(--mj-btn-radius);
	padding: 10px 28px;
	white-space: nowrap;
	transition: .15s;
}
.mj-flash-btn:hover { transform: scale(1.04); opacity: 1; }

/* ---------------- Testimonials */
.mj-testimonials-section { background: #fff; }
.mj-testimonials-grid {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 18px;
}
.mj-testimonial {
	background: var(--mj-bg);
	border: 1px solid var(--mj-border);
	border-radius: var(--mj-radius);
	padding: 22px;
	display: flex;
	flex-direction: column;
	gap: 10px;
}
.mj-testimonial-stars { color: #f59e0b; font-size: 17px; letter-spacing: 2px; }
.mj-testimonial-text { margin: 0; font-size: 15px; color: var(--mj-text); flex: 1; }
.mj-testimonial-author { display: flex; align-items: center; gap: 10px; }
.mj-testimonial-author img,
.mj-testimonial-avatar {
	width: 42px;
	height: 42px;
	border-radius: 50%;
	object-fit: cover;
	flex-shrink: 0;
}
.mj-testimonial-avatar {
	background: var(--mj-primary);
	color: #fff;
	display: flex;
	align-items: center;
	justify-content: center;
	font-weight: 800;
	font-size: 18px;
}
.mj-testimonial-author span strong { display: block; font-size: 14px; }
.mj-testimonial-author span small { color: var(--mj-muted); font-size: 12px; }
.mj-testimonial-verified {
	margin-inline-start: auto;
	width: 22px;
	height: 22px;
	border-radius: 50%;
	background: var(--mj-buy);
	color: #fff;
	font-size: 12px;
	display: flex;
	align-items: center;
	justify-content: center;
	flex-shrink: 0;
}

/* ---------------- WhatsApp button */
.mj-whatsapp {
	position: fixed;
	bottom: 84px;
	inset-inline-end: 18px;
	width: 54px;
	height: 54px;
	border-radius: 50%;
	background: var(--mj-whatsapp);
	display: flex;
	align-items: center;
	justify-content: center;
	box-shadow: 0 4px 16px rgba(0, 0, 0, .25);
	z-index: 901;
}

/* ---------------- Footer */
.mj-footer { background: var(--mj-accent); color: rgba(255, 255, 255, .85); margin-top: 56px; font-size: 14.5px; }
.mj-footer a { color: rgba(255, 255, 255, .8); transition: color .15s; }
.mj-footer a:hover { color: #fff; opacity: 1; }

.mj-footer-main {
	display: grid;
	grid-template-columns: 1.4fr 1fr 1.1fr 1.1fr;
	gap: 36px;
	padding-block: 48px 36px;
}
.mj-footer-brand { font-size: 24px; font-weight: 800; color: #fff; display: inline-block; margin-bottom: 10px; }
.mj-footer-logo img { max-width: 150px; height: auto; margin-bottom: 10px; filter: brightness(0) invert(1); }
.mj-footer-about p { margin: 0 0 16px; line-height: 1.8; color: rgba(255, 255, 255, .7); }

.mj-footer-social { display: flex; gap: 8px; }
.mj-footer-social a {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 40px;
	height: 40px;
	border-radius: 10px;
	background: rgba(255, 255, 255, .15);
	border: 1px solid rgba(255, 255, 255, .2);
	color: #fff;
	transition: .2s;
}
.mj-footer-social a:hover { background: rgba(255, 255, 255, .3); border-color: rgba(255, 255, 255, .4); color: #fff; transform: translateY(-2px); }

.mj-footer-title {
	color: #fff;
	font-size: 16px;
	font-weight: 800;
	margin: 0 0 18px;
	position: relative;
	padding-bottom: 10px;
}
.mj-footer-title::after {
	content: "";
	position: absolute;
	bottom: 0;
	inset-inline-start: 0;
	width: 34px;
	height: 3px;
	border-radius: 3px;
	background: rgba(255, 255, 255, .5);
}

.mj-footer-links,
.mj-footer-contact,
.mj-footer-trust { list-style: none; margin: 0; padding: 0; }
.mj-footer-links li { margin-bottom: 9px; }
.mj-footer-links li a {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	color: rgba(255, 255, 255, .75);
}
.mj-footer-links li a::before {
	content: "";
	width: 6px;
	height: 6px;
	border-radius: 50%;
	background: rgba(255, 255, 255, .5);
	opacity: .6;
	flex-shrink: 0;
	transition: opacity .15s;
}
.mj-footer-links li a:hover { color: #fff; }
.mj-footer-links li a:hover::before { opacity: 1; }

.mj-footer-contact li,
.mj-footer-trust li {
	display: flex;
	align-items: center;
	gap: 10px;
	margin-bottom: 12px;
	color: rgba(255, 255, 255, .7);
}
.mj-footer-ic {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 32px;
	height: 32px;
	border-radius: 8px;
	background: rgba(255, 255, 255, .15);
	color: #fff;
	flex-shrink: 0;
}

.mj-footer-widgets {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
	gap: 24px;
	padding-block: 0 28px;
}
.footer-widget-title { color: #fff; font-size: 16px; margin: 0 0 12px; }

.mj-footer-bottom { border-top: 1px solid rgba(255, 255, 255, .2); padding-block: 16px; font-size: 13.5px; }
.mj-footer-bottom-inner {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 12px;
	flex-wrap: wrap;
}
.mj-footer-cod-badge {
	display: inline-flex;
	align-items: center;
	gap: 7px;
	color: #fff;
	font-weight: 600;
}

/* ---------------- Pages & posts */
.mj-page { padding-block: 32px; }
.mj-article { background: #fff; border-radius: var(--mj-radius); box-shadow: var(--mj-shadow); padding: 28px; margin-bottom: 24px; }
.mj-page-title { margin-top: 0; color: var(--mj-dark); }

/* ---------------- Landing template */
body.mj-landing { background: #fff; }
.mj-landing-main { max-width: 100%; }


/* =========================================================
   WooCommerce widgets, filters & toolbar (professional look)
   ========================================================= */

/* Shop toolbar: result count + sorting */
.woocommerce .woocommerce-result-count { color: var(--mj-muted); font-size: 14px; margin-top: 10px; }
.woocommerce .woocommerce-ordering { margin-bottom: 22px; }
.woocommerce .woocommerce-ordering select,
.woocommerce select.orderby {
	-webkit-appearance: none;
	appearance: none;
	border: 1.5px solid var(--mj-border);
	border-radius: var(--mj-btn-radius);
	background: #fff;
	padding: 9px 38px 9px 18px;
	font-family: inherit;
	font-size: 14px;
	font-weight: 600;
	color: var(--mj-text);
	cursor: pointer;
	background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 24 24' fill='none' stroke='%236b7280' stroke-width='2'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");
	background-repeat: no-repeat;
	background-position: right 14px center;
}
html[dir="rtl"] .woocommerce .woocommerce-ordering select,
html[dir="rtl"] .woocommerce select.orderby {
	padding: 9px 18px 9px 38px;
	background-position: left 14px center;
}
.woocommerce .woocommerce-ordering select:focus { outline: none; border-color: var(--mj-primary); }

/* Pagination */
.woocommerce nav.woocommerce-pagination { margin-top: 10px; }
.woocommerce nav.woocommerce-pagination ul {
	border: 0 !important;
	display: flex;
	justify-content: center;
	gap: 8px;
	flex-wrap: wrap;
}
.woocommerce nav.woocommerce-pagination ul li { border: 0 !important; overflow: visible; }
.woocommerce nav.woocommerce-pagination ul li a,
.woocommerce nav.woocommerce-pagination ul li span {
	display: flex !important;
	align-items: center;
	justify-content: center;
	min-width: 42px;
	height: 42px;
	border-radius: 10px !important;
	border: 1.5px solid var(--mj-border) !important;
	background: #fff !important;
	color: var(--mj-text) !important;
	font-weight: 700;
	font-size: 14px;
	padding: 0 12px !important;
	transition: .15s;
}
.woocommerce nav.woocommerce-pagination ul li a:hover {
	border-color: var(--mj-primary) !important;
	color: var(--mj-primary) !important;
}
.woocommerce nav.woocommerce-pagination ul li span.current {
	background: var(--mj-primary) !important;
	border-color: var(--mj-primary) !important;
	color: #fff !important;
}
.mj-page .page-numbers { display: flex; justify-content: center; gap: 8px; list-style: none; padding: 0; }
.mj-page .page-numbers a, .mj-page .page-numbers span {
	display: flex; align-items: center; justify-content: center;
	min-width: 42px; height: 42px; border-radius: 10px;
	border: 1.5px solid var(--mj-border); background: #fff; font-weight: 700;
}
.mj-page .page-numbers span.current { background: var(--mj-primary); border-color: var(--mj-primary); color: #fff; }

/* Sidebar widgets (generic card look) */
.widget {
	background: #fff;
	border: 1px solid var(--mj-border);
	border-radius: var(--mj-radius);
	padding: 20px;
	margin-bottom: 20px;
}
.widget-title {
	font-size: 16px;
	font-weight: 800;
	margin: 0 0 16px;
	padding-bottom: 10px;
	position: relative;
	color: var(--mj-dark);
}
.widget-title::after {
	content: "";
	position: absolute;
	bottom: 0;
	inset-inline-start: 0;
	width: 34px;
	height: 3px;
	border-radius: 3px;
	background: var(--mj-primary);
}
.widget ul { list-style: none; margin: 0; padding: 0; }
.widget ul li { padding-block: 8px; border-bottom: 1px solid #f1f5f9; font-size: 14px; }
.widget ul li:last-child { border-bottom: 0; }
.widget ul li a { color: var(--mj-text); font-weight: 600; }
.widget ul li a:hover { color: var(--mj-primary); }

/* Product categories widget: counts as pills */
.widget_product_categories li,
.wc-block-product-categories-list li {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 8px;
}
.widget_product_categories li .count,
.wc-block-product-categories-list-item-count {
	background: #f1f5f9;
	color: var(--mj-muted);
	font-size: 12px;
	font-weight: 700;
	border-radius: 999px;
	padding: 1px 10px;
}

/* Price filter widget */
.widget_price_filter .price_slider_wrapper { margin-top: 6px; }
.widget_price_filter .ui-slider { height: 6px !important; background: #e5e7eb !important; border-radius: 999px; margin-bottom: 18px; }
.widget_price_filter .ui-slider .ui-slider-range { background: var(--mj-primary) !important; border-radius: 999px; }
.widget_price_filter .ui-slider .ui-slider-handle {
	background: #fff !important;
	border: 3px solid var(--mj-primary) !important;
	width: 18px !important;
	height: 18px !important;
	top: -6px !important;
	border-radius: 50%;
	box-shadow: 0 2px 6px rgba(15, 23, 42, .18);
	cursor: grab;
}
.widget_price_filter .price_slider_amount { display: flex; align-items: center; justify-content: space-between; gap: 10px; }
.widget_price_filter .price_slider_amount .price_label { font-size: 13.5px; font-weight: 700; color: var(--mj-text); }
.widget_price_filter .price_slider_amount .button {
	background: var(--mj-dark) !important;
	color: #fff !important;
	border-radius: var(--mj-btn-radius) !important;
	font-weight: 700 !important;
	padding: 8px 22px !important;
	font-size: 13px !important;
	border: 0;
	cursor: pointer;
}
.widget_price_filter .price_slider_amount .button:hover { background: var(--mj-primary) !important; }

/* Active filters widget */
.widget_layered_nav_filters ul { display: flex; flex-wrap: wrap; gap: 8px; }
.widget_layered_nav_filters ul li { border: 0; padding: 0; }
.widget_layered_nav_filters ul li a {
	display: inline-flex;
	align-items: center;
	gap: 6px;
	background: color-mix(in srgb, var(--mj-primary) 10%, #fff);
	border: 1px solid color-mix(in srgb, var(--mj-primary) 35%, #fff);
	color: var(--mj-primary);
	border-radius: 999px;
	padding: 5px 14px;
	font-size: 13px;
	font-weight: 700;
}

/* Search widgets */
.widget_search form, .widget_product_search form { display: flex; border: 1.5px solid var(--mj-border); border-radius: var(--mj-btn-radius); overflow: hidden; }
.widget_search input[type="search"], .widget_product_search input[type="search"] { flex: 1; border: 0; padding: 10px 14px; font-family: inherit; outline: none; min-width: 0; }
.widget_search button, .widget_product_search button {
	border: 0; background: var(--mj-primary); color: #fff; padding-inline: 18px;
	font-family: inherit; font-weight: 700; cursor: pointer;
}

/* Breadcrumb */
.woocommerce .woocommerce-breadcrumb { font-size: 13.5px; color: var(--mj-muted); margin-bottom: 18px; }
.woocommerce .woocommerce-breadcrumb a { color: var(--mj-muted); }
.woocommerce .woocommerce-breadcrumb a:hover { color: var(--mj-primary); }

/* Notices */
.woocommerce-message, .woocommerce-info, .woocommerce-error {
	border-radius: var(--mj-radius) !important;
	background: #fff !important;
	box-shadow: var(--mj-shadow);
	border-top-width: 3px !important;
}
.woocommerce-message { border-top-color: var(--mj-buy) !important; }
.woocommerce-info { border-top-color: var(--mj-primary) !important; }
.woocommerce-info::before { color: var(--mj-primary) !important; }
.woocommerce-message::before { color: var(--mj-buy) !important; }

/* Reviews / tabs on single product */
.woocommerce div.product .woocommerce-tabs ul.tabs {
	padding: 0 !important;
	margin-bottom: 0 !important;
	border-bottom: 2px solid var(--mj-border);
	display: flex;
	gap: 4px;
}
.woocommerce div.product .woocommerce-tabs ul.tabs::before { display: none !important; }
.woocommerce div.product .woocommerce-tabs ul.tabs li {
	background: transparent !important;
	border: 0 !important;
	border-radius: 0 !important;
	margin: 0 !important;
	padding: 0 !important;
}
.woocommerce div.product .woocommerce-tabs ul.tabs li::before,
.woocommerce div.product .woocommerce-tabs ul.tabs li::after { display: none !important; }
.woocommerce div.product .woocommerce-tabs ul.tabs li a {
	padding: 12px 20px !important;
	font-weight: 700 !important;
	color: var(--mj-muted) !important;
	position: relative;
}
.woocommerce div.product .woocommerce-tabs ul.tabs li.active a { color: var(--mj-primary) !important; }
.woocommerce div.product .woocommerce-tabs ul.tabs li.active a::after {
	content: "";
	position: absolute;
	bottom: -2px;
	inset-inline: 0;
	height: 2.5px;
	background: var(--mj-primary);
}
.woocommerce div.product .woocommerce-tabs .panel {
	background: #fff;
	border: 1px solid var(--mj-border);
	border-top: 0;
	border-radius: 0 0 var(--mj-radius) var(--mj-radius);
	padding: 24px !important;
	margin-bottom: 30px;
}

/* Star ratings color */
.woocommerce .star-rating span::before, .woocommerce .star-rating::before { color: #f59e0b !important; }

/* Forms (comments, reviews, contact) */
.mj-page input[type="text"], .mj-page input[type="email"], .mj-page input[type="url"],
.mj-page input[type="tel"], .mj-page textarea, .comment-form input, .comment-form textarea {
	border: 1.5px solid var(--mj-border);
	border-radius: 8px;
	padding: 10px 12px;
	font-family: inherit;
	font-size: 15px;
	background: #fafafa;
	max-width: 100%;
}
.mj-page input:focus, .mj-page textarea:focus { outline: none; border-color: var(--mj-primary); background: #fff; }
.comment-form .submit, .mj-page input[type="submit"] {
	background: var(--mj-primary);
	color: #fff;
	border: 0;
	border-radius: var(--mj-btn-radius);
	font-weight: 700;
	padding: 11px 30px;
	cursor: pointer;
	font-family: inherit;
}

/* =========================================================
   Responsive
   ========================================================= */
@media (max-width: 1024px) {
	.woocommerce ul.products { grid-template-columns: repeat(3, 1fr); }
	.mj-cats-grid { grid-template-columns: repeat(2, 1fr); }
	.mj-landing-grid { grid-template-columns: repeat(2, 1fr); }
}

@media (max-width: 900px) {
	.mj-footer-main { grid-template-columns: 1fr 1fr; gap: 28px; }
	.mj-footer-bottom-inner { justify-content: center; text-align: center; }
	.mj-hero { padding: 30px 20px; margin: 14px; border-radius: 22px; }
	.mj-hero-inner { grid-template-columns: 1fr; gap: 24px; }
	.mj-hero-right { grid-template-columns: 1fr; min-height: auto; }
	.mj-hero-cards { flex-direction: row; flex-wrap: wrap; justify-content: center; gap: 10px; }
	.mj-hero-card { min-width: auto; padding: 10px 14px; flex: 1; min-width: 140px; }
	.mj-hero-card-text small { display: none; }
	.mj-hero-product { margin-top: 16px; }
	.mj-hero-pedestal { width: 180px; height: 180px; }
	.mj-hero-product img { max-height: 160px; }
	.mj-hero-text h1 { font-size: 26px; color: var(--mj-dark); }
	.mj-hero-text p { color: #555; font-size: 15px; }
	.mj-hero-cta, .mj-hero-cta-ghost { width: 100%; justify-content: center; }
	.mj-trust-badges { grid-template-columns: 1fr; gap: 16px; margin-top: 10px; padding: 20px; }
	.mj-testimonials-grid { grid-template-columns: 1fr; }
	.mj-flash-inner { justify-content: center; text-align: center; }
}

@media (max-width: 768px) {
	.mj-topinfo-items { gap: 12px; }
	.mj-topinfo .mj-topinfo-item:nth-child(n+3) { display: none; }

	.mj-menu-toggle { display: flex; }

	/* Compact single-row nav on mobile */
	.mj-navwrap-inner { flex-direction: row; gap: 8px; align-items: center; min-height: 52px; padding-inline: 12px; }
	.mj-logo { margin-inline-end: auto; }
	.mj-logo img { max-height: 36px; }
	.mj-allcats { display: none; }
	.mj-nav-track { margin: 0 auto; padding: 6px 12px; font-size: 13px; gap: 6px; }
	.mj-menu-toggle { padding: 8px; margin-inline-start: 4px; }
	.mj-nav { display: none; }
	.mj-navwrap.open .mj-nav { display: block; position: absolute; top: 100%; left: 0; right: 0; background: var(--mj-accent); z-index: 75; box-shadow: 0 8px 24px rgba(0,0,0,.2); }
	.mj-nav-list { flex-direction: column; gap: 0; }
	.mj-nav-list li { display: block; }
	.mj-nav-list > li > a { padding: 14px 20px; }
	.mj-nav-list > li > a::after { display: none; }
	.mj-nav-list .sub-menu { position: static; display: block; box-shadow: none; border: 0; border-radius: 0; background: rgba(255, 255, 255, .04); }
	.mj-nav-list .sub-menu li a { color: #cbd5e1; }
	.mj-nav-badge { display: none; }
	.mj-navwrap.mj-stuck { position: relative; animation: none; }
	/* Hide sticky placeholder on mobile */
	.mj-navwrap + div:not([class]) { display: none !important; }

	/* Hero compact mobile */
	.mj-hero { padding: 24px 16px; margin: 10px; border-radius: 18px; }
	.mj-hero-inner { gap: 20px; }
	.mj-hero-text h1 { font-size: 22px; }
	.mj-hero-text p { font-size: 14px; margin-bottom: 20px; }
	.mj-hero-actions { flex-direction: column; gap: 10px; }
	.mj-hero-cta { padding: 12px 24px; font-size: 15px; }
	.mj-hero-cta-ghost { padding: 10px 20px; font-size: 14px; }
	.mj-hero-right { display: none; }

	/* Trust badges hidden on mobile */
	.mj-trust-badges { display: none; }

	/* Products grid: 2 columns on mobile */
	.woocommerce ul.products { grid-template-columns: repeat(2, 1fr) !important; gap: 10px; }
	.woocommerce ul.products li.product { padding-bottom: 12px !important; }
	.woocommerce ul.products li.product img { padding: 10px; }
	.woocommerce ul.products li.product .woocommerce-loop-product__title { font-size: 13px !important; padding: 2px 8px !important; min-height: 40px; }
	.woocommerce ul.products li.product .price { font-size: 15px !important; margin-bottom: 8px !important; }
	.woocommerce ul.products li.product .button.mj-loop-buy { padding: 8px 20px !important; font-size: 13px !important; }

	/* Flash strip mobile */
	.mj-flash-inner { justify-content: center; text-align: center; }
	.mj-flash-strip { padding-block: 14px; }
	.mj-flash-text strong { font-size: 15px; }
	.mj-flash-btn { padding: 8px 20px; font-size: 13px; }

	/* Sections */
	.mj-section-head h2 { font-size: 20px; }
	.mj-home-section { padding-block: 24px; }

	/* Features strip */
	.mj-features-grid { grid-template-columns: repeat(2, 1fr); }

	/* Single product page spacing */
	.mj-single-product { padding-top: 16px; padding-bottom: 80px; overflow: hidden; }
	.mj-product-gallery { position: static; overflow: hidden; }
	.mj-gallery-main { border-radius: 12px; overflow: hidden; }
	.mj-gallery-main-img { aspect-ratio: 1; }
	.mj-product-grid { grid-template-columns: 1fr; gap: 24px; overflow: hidden; }
	.mj-gallery-thumb { width: 56px; height: 56px; }
	.mj-product-price { font-size: 20px; }
	.mj-gallery-strip { justify-content: center; gap: 6px; overflow-x: auto; }

	.mj-topbar { font-size: 11px; padding: 5px 12px; }
	.mj-field-row { grid-template-columns: 1fr; }

	.mj-sticky-info { display: none; }
	.mj-sticky-btn { flex: 1; max-width: 100%; padding: 12px 20px; font-size: 15px; }

	.mj-cats-grid { grid-template-columns: repeat(2, 1fr); gap: 10px; }
	.mj-cat-card { min-height: 140px; }
	.mj-cat-name { font-size: 15px; }
}

@media (max-width: 560px) {
	.mj-footer-main { grid-template-columns: 1fr; }
}

@media (max-width: 420px) {
	.mj-cats-grid { grid-template-columns: 1fr; }
	.woocommerce ul.products { grid-template-columns: repeat(2, 1fr) !important; gap: 8px; }
	.mj-hero { padding: 20px 14px; margin: 8px; border-radius: 16px; }
	.mj-hero-text h1 { font-size: 20px; }
	.mj-hero-pedestal { width: 120px; height: 120px; }
	.mj-hero-product img { max-height: 100px; }
	.mj-flash-text { font-size: 13px; }
}

/* =========================================================
   Landing Page — Beauty template (.mj-landing-beauty)
   ========================================================= */
.mj-landing-beauty { background: #fbf7f5; }
.mjb-container { max-width: 1060px; margin-inline: auto; padding-inline: 18px; }

.mjb-topbar {
	background: linear-gradient(90deg, color-mix(in srgb, var(--mj-primary) 85%, #000), var(--mj-primary));
	color: #fff;
	text-align: center;
	font-size: 13.5px;
	font-weight: 700;
	padding: 8px 14px;
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 8px;
}
.mjb-header { background: #fff; border-bottom: 1px solid var(--mj-border); position: sticky; top: 0; z-index: 50; }
.mjb-header .mjb-container { display: flex; align-items: center; justify-content: space-between; gap: 16px; padding-block: 12px; }
.mjb-logo-text { font-size: 21px; font-weight: 800; color: var(--mj-dark); }
.mjb-logo img { max-height: 46px; width: auto; }
.mjb-call {
	display: flex;
	align-items: center;
	gap: 8px;
	background: color-mix(in srgb, var(--mj-primary) 10%, #fff);
	border: 1px solid color-mix(in srgb, var(--mj-primary) 25%, #fff);
	border-radius: 999px;
	padding: 8px 18px;
	font-weight: 800;
	color: var(--mj-primary);
	font-size: 15px;
}

/* Hero */
.mjb-hero { padding-block: 44px; background: linear-gradient(160deg, #fff 0%, color-mix(in srgb, var(--mj-primary) 7%, #fff) 100%); }
.mjb-hero-inner { display: grid; grid-template-columns: 1fr 1fr; gap: 38px; align-items: center; }
.mjb-kicker {
	display: inline-flex;
	align-items: center;
	gap: 7px;
	background: #fff;
	border: 1px solid var(--mj-border);
	color: var(--mj-primary);
	border-radius: 999px;
	padding: 6px 16px;
	font-size: 13px;
	font-weight: 800;
	box-shadow: var(--mj-shadow);
	margin-bottom: 14px;
}
.mjb-hero-text h1 { font-size: 30px; color: var(--mj-dark); margin: 0 0 12px; line-height: 1.4; }
.mjb-hero-price { display: flex; align-items: center; gap: 12px; margin-bottom: 14px; flex-wrap: wrap; }
.mjb-hero-price strong { font-size: 30px; color: var(--mj-price); font-weight: 800; }
.mjb-hero-price del { color: var(--mj-muted); font-size: 19px; }
.mjb-pct { background: var(--mj-sale); color: #fff; font-weight: 800; font-size: 13.5px; border-radius: 8px; padding: 4px 11px; }
.mjb-hero-desc { color: var(--mj-muted); margin-bottom: 20px; max-width: 480px; }
.mjb-cta {
	display: inline-flex;
	align-items: center;
	gap: 10px;
	background: var(--mj-buy);
	color: #fff;
	font-size: 17px;
	font-weight: 800;
	border-radius: var(--mj-btn-radius);
	padding: 14px 36px;
	animation: mj-pulse 2s infinite;
}
.mjb-hero-trust { display: flex; gap: 16px; margin-top: 20px; flex-wrap: wrap; }
.mjb-hero-trust span { display: inline-flex; align-items: center; gap: 6px; font-size: 13px; font-weight: 700; color: var(--mj-text); }
.mjb-hero-trust .mj-icon { color: var(--mj-primary); }

/* Gallery */
.mjb-gallery-main { position: relative; background: #fff; border-radius: var(--mj-radius); box-shadow: 0 18px 50px rgba(15, 23, 42, .12); overflow: hidden; }
.mjb-gallery-main img { width: 100%; height: auto; display: block; aspect-ratio: 1; object-fit: contain; }
.mjb-sale-badge { position: absolute; top: 14px; inset-inline-start: 14px; background: var(--mj-sale); color: #fff; font-weight: 800; border-radius: 8px; padding: 6px 12px; font-size: 14px; }
.mjb-gallery-thumbs { display: flex; gap: 10px; margin-top: 12px; flex-wrap: wrap; }
.mjb-thumb {
	border: 2px solid transparent;
	border-radius: 10px;
	overflow: hidden;
	padding: 0;
	background: #fff;
	cursor: pointer;
	width: 64px;
	height: 64px;
}
.mjb-thumb img { width: 100%; height: 100%; object-fit: cover; display: block; }
.mjb-thumb.active { border-color: var(--mj-primary); }

/* Strip */
.mjb-strip { background: var(--mj-dark); color: #e2e8f0; padding-block: 13px; font-size: 13.5px; }
.mjb-strip .mjb-container { display: flex; justify-content: center; gap: 30px; flex-wrap: wrap; }
.mjb-strip span { display: inline-flex; align-items: center; gap: 8px; font-weight: 700; }
.mjb-strip .mj-icon { color: var(--mj-primary); }

/* Sections */
.mjb-section { padding-block: 44px; }
.mjb-alt { background: #fff; }
.mjb-head { text-align: center; margin-bottom: 28px; }
.mjb-head h2 { font-size: 25px; color: var(--mj-dark); margin: 0; position: relative; display: inline-block; padding-bottom: 10px; }
.mjb-head h2::after { content: ""; position: absolute; left: 50%; transform: translateX(-50%); bottom: 0; width: 54px; height: 4px; border-radius: 4px; background: var(--mj-primary); }
.mjb-desc { max-width: 760px; }
.mjb-desc img { border-radius: var(--mj-radius); }

/* Order section */
.mjb-order-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 34px; align-items: start; }
.mjb-order-side h2 { font-size: 24px; color: var(--mj-dark); margin: 14px 0 14px; }
.mjb-checklist { list-style: none; margin: 0 0 20px; padding: 0; }
.mjb-checklist li { display: flex; align-items: center; gap: 10px; margin-bottom: 11px; font-weight: 600; font-size: 15px; }
.mjb-checklist li span {
	width: 25px; height: 25px; border-radius: 50%;
	background: color-mix(in srgb, var(--mj-buy) 12%, #fff);
	color: var(--mj-buy);
	display: flex; align-items: center; justify-content: center; flex-shrink: 0;
}
.mjb-phone-card {
	display: flex; align-items: center; gap: 14px;
	background: #fff; border: 1px solid var(--mj-border); border-radius: var(--mj-radius);
	padding: 16px 18px;
}
.mjb-phone-ic {
	width: 44px; height: 44px; border-radius: 50%;
	background: color-mix(in srgb, var(--mj-primary) 12%, #fff);
	color: var(--mj-primary);
	display: flex; align-items: center; justify-content: center; flex-shrink: 0;
}
.mjb-phone-card strong { display: block; font-size: 14px; color: var(--mj-dark); }
.mjb-phone-card a { font-weight: 800; color: var(--mj-primary); font-size: 17px; }

/* Steps */
.mjb-steps { display: grid; grid-template-columns: repeat(3, 1fr); gap: 18px; }
.mjb-step { background: var(--mj-bg); border: 1px solid var(--mj-border); border-radius: var(--mj-radius); padding: 26px 22px; text-align: center; }
.mjb-step-n {
	width: 44px; height: 44px; border-radius: 50%;
	background: linear-gradient(135deg, var(--mj-primary), color-mix(in srgb, var(--mj-primary) 70%, #000));
	color: #fff; font-weight: 800; font-size: 19px;
	display: flex; align-items: center; justify-content: center; margin: 0 auto 13px;
}
.mjb-step strong { display: block; color: var(--mj-dark); margin-bottom: 6px; }
.mjb-step small { color: var(--mj-muted); font-size: 13.5px; }

/* FAQ */
.mjb-faq { max-width: 640px; margin-inline: auto; }
.mjb-faq details { background: var(--mj-bg); border: 1px solid var(--mj-border); border-radius: 12px; margin-bottom: 10px; overflow: hidden; }
.mjb-faq summary { padding: 14px 20px; font-weight: 800; color: var(--mj-dark); cursor: pointer; list-style: none; display: flex; justify-content: space-between; align-items: center; font-size: 15px; }
.mjb-faq summary::-webkit-details-marker { display: none; }
.mjb-faq summary::after { content: "+"; font-size: 20px; color: var(--mj-primary); }
.mjb-faq details[open] summary::after { content: "−"; }
.mjb-faq details div { padding: 0 20px 15px; color: var(--mj-muted); font-size: 14px; }

/* Footer */
.mjb-footer { background: var(--mj-dark); color: #94a3b8; text-align: center; padding-block: 26px; font-size: 13.5px; }
.mjb-footer-social { display: flex; justify-content: center; gap: 10px; margin-bottom: 12px; }
.mjb-footer-social a {
	width: 36px; height: 36px; border-radius: 10px;
	background: rgba(255, 255, 255, .07);
	display: flex; align-items: center; justify-content: center; color: #cbd5e1;
}
.mjb-footer-social a:hover { background: var(--mj-primary); color: #fff; }

/* Sticky */
.mjb-sticky {
	position: fixed; bottom: 0; inset-inline: 0;
	background: #fff; box-shadow: 0 -6px 22px rgba(15, 23, 42, .14);
	display: flex; align-items: center; gap: 14px;
	padding: 10px 16px; z-index: 900;
}
.mjb-sticky[hidden] { display: none; }
.mjb-sticky-info { display: flex; flex-direction: column; min-width: 0; }
.mjb-sticky-name { font-weight: 700; font-size: 13.5px; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.mjb-sticky-price { color: var(--mj-price); font-weight: 800; }
.mjb-sticky-btn {
	margin-inline-start: auto;
	background: var(--mj-buy); color: #fff;
	font-weight: 800; font-size: 15px;
	border-radius: var(--mj-btn-radius); padding: 12px 26px; white-space: nowrap;
}

@media (max-width: 880px) {
	.mjb-hero-inner, .mjb-order-grid { grid-template-columns: 1fr; }
	.mjb-hero-text h1 { font-size: 24px; }
	.mjb-steps { grid-template-columns: 1fr; }
	.mjb-sticky-info { display: none; }
	.mjb-sticky-btn { flex: 1; text-align: center; }
}

/* =========================================================
   Thank You page (template-thankyou.php)
   ========================================================= */
.mjty { padding-block: 48px; max-width: 860px; }
.mjty-card {
	position: relative;
	background: #fff;
	border: 1px solid var(--mj-border);
	border-radius: 22px;
	box-shadow: 0 20px 60px rgba(15, 23, 42, .1);
	padding: clamp(32px, 5vw, 52px);
	text-align: center;
	overflow: hidden;
}
.mjty-check {
	width: 86px;
	height: 86px;
	margin: 0 auto 20px;
	border-radius: 50%;
	background: radial-gradient(circle at 32% 28%, #34c97a, var(--mj-buy));
	color: #fff;
	display: flex;
	align-items: center;
	justify-content: center;
	box-shadow: 0 16px 40px rgba(22, 163, 74, .35);
	animation: mjty-pop .5s cubic-bezier(.22,1,.36,1);
}
@keyframes mjty-pop { from { transform: scale(.4); opacity: 0; } to { transform: scale(1); opacity: 1; } }
.mjty-title { font-size: clamp(24px, 4vw, 32px); color: var(--mj-dark); margin: 0 0 8px; }
.mjty-sub { color: var(--mj-muted); margin: 0 0 28px; font-size: 16px; }

/* confetti */
.mjty-confetti { position: absolute; inset: 0; pointer-events: none; }
.mjty-confetti span {
	position: absolute;
	top: -12px;
	width: 9px;
	height: 14px;
	border-radius: 2px;
	opacity: .85;
	animation: mjty-fall 3.2s linear infinite;
}
.mjty-confetti span:nth-child(1)  { left: 6%;  background: #f97316; animation-delay: 0s; }
.mjty-confetti span:nth-child(2)  { left: 14%; background: #16a34a; animation-delay: .4s; }
.mjty-confetti span:nth-child(3)  { left: 24%; background: #eab308; animation-delay: .9s; }
.mjty-confetti span:nth-child(4)  { left: 32%; background: #3b82f6; animation-delay: .2s; }
.mjty-confetti span:nth-child(5)  { left: 42%; background: #ec4899; animation-delay: 1.3s; }
.mjty-confetti span:nth-child(6)  { left: 52%; background: #f97316; animation-delay: .7s; }
.mjty-confetti span:nth-child(7)  { left: 60%; background: #16a34a; animation-delay: 1.6s; }
.mjty-confetti span:nth-child(8)  { left: 68%; background: #3b82f6; animation-delay: .5s; }
.mjty-confetti span:nth-child(9)  { left: 76%; background: #eab308; animation-delay: 1.1s; }
.mjty-confetti span:nth-child(10) { left: 84%; background: #ec4899; animation-delay: .3s; }
.mjty-confetti span:nth-child(11) { left: 92%; background: #f97316; animation-delay: 1.4s; }
.mjty-confetti span:nth-child(12) { left: 97%; background: #16a34a; animation-delay: .8s; }
@keyframes mjty-fall {
	0%   { transform: translateY(0) rotate(0deg); opacity: .9; }
	100% { transform: translateY(340px) rotate(340deg); opacity: 0; }
}

/* order summary */
.mjty-summary {
	background: var(--mj-bg);
	border: 1px solid var(--mj-border);
	border-radius: 16px;
	padding: 20px 22px;
	margin: 0 auto 28px;
	max-width: 480px;
	text-align: start;
}
.mjty-summary-head {
	display: flex;
	justify-content: space-between;
	align-items: center;
	padding-bottom: 12px;
	border-bottom: 1px dashed var(--mj-border);
	margin-bottom: 6px;
	font-size: 14px;
	color: var(--mj-muted);
}
.mjty-summary-head strong { color: var(--mj-dark); font-size: 17px; }
.mjty-table { width: 100%; border-collapse: collapse; font-size: 14.5px; }
.mjty-table td { padding: 9px 0; border-bottom: 1px dashed var(--mj-border); }
.mjty-table td:last-child { text-align: end; font-weight: 700; white-space: nowrap; }
.mjty-qty { color: var(--mj-muted); font-size: 13px; }
.mjty-table .mjty-total td { border-bottom: 0; font-weight: 800; color: var(--mj-primary); font-size: 16px; padding-top: 12px; }
.mjty-meta { display: flex; gap: 18px; flex-wrap: wrap; margin-top: 12px; font-size: 13px; color: var(--mj-muted); }
.mjty-meta span { display: inline-flex; align-items: center; gap: 6px; }
.mjty-meta .mj-icon { color: var(--mj-primary); }

/* steps */
.mjty-steps { display: grid; grid-template-columns: repeat(3, 1fr); gap: 14px; margin-bottom: 28px; }
.mjty-step {
	background: var(--mj-bg);
	border: 1px solid var(--mj-border);
	border-radius: 14px;
	padding: 18px 14px;
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 4px;
}
.mjty-step-ic {
	width: 44px;
	height: 44px;
	border-radius: 50%;
	background: color-mix(in srgb, var(--mj-primary) 12%, #fff);
	color: var(--mj-primary);
	display: flex;
	align-items: center;
	justify-content: center;
	margin-bottom: 6px;
}
.mjty-step strong { font-size: 14px; color: var(--mj-dark); }
.mjty-step small { font-size: 12.5px; color: var(--mj-muted); line-height: 1.5; }

/* ADEX tracking block on thank-you */
.mjty-adex {
	margin-bottom: 28px;
	background: linear-gradient(135deg, #f5f3ff 0%, #ede9fe 100%);
	border: 2px solid #c4b5fd;
	border-radius: 16px;
	padding: 22px 20px;
}
.mjty-adex-pending {
	background: linear-gradient(135deg, #fffbeb 0%, #fef3c7 100%);
	border-color: #fcd34d;
}
.mjty-adex-header {
	display: flex;
	align-items: center;
	gap: 12px;
	margin-bottom: 14px;
}
.mjty-adex-header strong { font-size: 17px; color: #1e1b4b; }
.mjty-adex-header small { display: block; color: #6b7280; font-size: 13px; margin-top: 2px; }
.mjty-adex-icon {
	font-size: 28px;
	background: #fff;
	border-radius: 50%;
	width: 48px;
	height: 48px;
	display: flex;
	align-items: center;
	justify-content: center;
	flex-shrink: 0;
	box-shadow: 0 2px 8px rgba(124,58,237,0.15);
}
.mjty-adex-tracking {
	display: flex;
	align-items: center;
	gap: 8px;
	background: #fff;
	border-radius: 10px;
	padding: 10px 14px;
	margin-bottom: 16px;
	font-size: 14px;
	color: #4b5563;
}
.mjty-adex-tracking code {
	background: #7c3aed;
	color: #fff;
	font-weight: 700;
	font-size: 15px;
	padding: 3px 10px;
	border-radius: 6px;
	letter-spacing: 0.5px;
}
.mjty-adex-date {
	margin-left: auto;
	font-size: 12px;
	color: #9ca3af;
}
.mjty-adex-steps {
	display: flex;
	gap: 0;
	margin-bottom: 18px;
}
.mjty-adex-step {
	flex: 1;
	text-align: center;
	position: relative;
}
.mjty-adex-step:not(:last-child)::after {
	content: '';
	position: absolute;
	top: 12px;
	left: 55%;
	width: 90%;
	height: 2px;
	background: #d1d5db;
	z-index: 0;
}
.mjty-adex-step.active:not(:last-child)::after {
	background: #7c3aed;
}
.mjty-adex-dot {
	width: 24px;
	height: 24px;
	border-radius: 50%;
	background: #e5e7eb;
	color: #9ca3af;
	font-size: 12px;
	font-weight: 700;
	display: flex;
	align-items: center;
	justify-content: center;
	margin: 0 auto 5px;
	position: relative;
	z-index: 1;
	border: 2px solid #fff;
}
.mjty-adex-step.active .mjty-adex-dot {
	background: #7c3aed;
	color: #fff;
	box-shadow: 0 0 0 3px rgba(124,58,237,0.2);
}
.mjty-adex-step span {
	font-size: 11px;
	color: #9ca3af;
	font-weight: 500;
}
.mjty-adex-step.active span {
	color: #7c3aed;
	font-weight: 700;
}
.mjty-adex-btn {
	display: block;
	text-align: center;
	background: #7c3aed;
	color: #fff;
	font-weight: 700;
	font-size: 15px;
	padding: 12px 20px;
	border-radius: 10px;
	text-decoration: none;
	transition: background 0.2s;
}
.mjty-adex-btn:hover { background: #6d28d9; color: #fff; }
.mjty-adex-btn-secondary {
	background: #fff;
	color: #7c3aed;
	border: 2px solid #7c3aed;
}
.mjty-adex-btn-secondary:hover { background: #f5f3ff; color: #7c3aed; }

/* actions */
.mjty-actions { display: flex; justify-content: center; gap: 12px; flex-wrap: wrap; margin-bottom: 18px; }
.mjty-btn-main {
	background: var(--mj-buy);
	color: #fff;
	font-weight: 800;
	border-radius: var(--mj-btn-radius);
	padding: 13px 34px;
	font-size: 16px;
}
.mjty-btn-ghost {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	border: 1.5px solid var(--mj-border);
	color: var(--mj-dark);
	font-weight: 700;
	border-radius: var(--mj-btn-radius);
	padding: 12px 26px;
	background: #fff;
}
.mjty-btn-wa {
	display: inline-flex;
	align-items: center;
	background: var(--mj-whatsapp);
	color: #fff;
	font-weight: 800;
	border-radius: var(--mj-btn-radius);
	padding: 13px 28px;
}
.mjty-note {
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 7px;
	color: var(--mj-muted);
	font-size: 13px;
	margin: 0;
}
.mjty-note .mj-icon { color: var(--mj-primary); }
.mjty-extra { margin-top: 28px; background: #fff; border: 1px solid var(--mj-border); border-radius: 16px; padding: 24px; }
.mjty-crosssell { margin-top: 40px; }
.mjty-crosssell h2 {
	text-align: center;
	font-size: 22px;
	color: var(--mj-dark);
	margin-bottom: 22px;
}

@media (max-width: 640px) {
	.mjty-steps { grid-template-columns: 1fr; }
	.mjty-actions { flex-direction: column; }
	.mjty-btn-main, .mjty-btn-ghost, .mjty-btn-wa { justify-content: center; text-align: center; }
	.mjty-adex-steps { flex-wrap: wrap; gap: 8px; }
	.mjty-adex-step { flex: 0 0 calc(33% - 6px); }
	.mjty-adex-step:not(:last-child)::after { display: none; }
	.mjty-adex-tracking { flex-wrap: wrap; }
	.mjty-adex-date { width: 100%; margin-left: 0; margin-top: 4px; }
}

/* ---------------- Thank-you upsell */
.mjty-upsell {
	position: relative;
	display: grid;
	grid-template-columns: 170px 1fr;
	gap: 20px;
	align-items: center;
	background: linear-gradient(135deg, #fff7ed, #ffedd5);
	border: 2px dashed var(--mj-primary);
	border-radius: 18px;
	padding: 20px;
	margin: 0 auto 28px;
	max-width: 560px;
	text-align: start;
}
.mjty-upsell-badge {
	position: absolute;
	top: -13px;
	inset-inline-start: 18px;
	background: var(--mj-sale);
	color: #fff;
	font-weight: 800;
	font-size: 14px;
	border-radius: 999px;
	padding: 4px 16px;
	box-shadow: 0 6px 16px rgba(220, 38, 38, .35);
}
.mjty-upsell-img img { border-radius: 12px; width: 100%; height: auto; }
.mjty-upsell-kicker {
	display: inline-block;
	color: var(--mj-primary);
	font-weight: 800;
	font-size: 12.5px;
	letter-spacing: .5px;
	text-transform: uppercase;
	margin-bottom: 4px;
}
.mjty-upsell-body h3 { margin: 0 0 6px; font-size: 18px; color: var(--mj-dark); }
.mjty-upsell-body p { margin: 0 0 10px; font-size: 13.5px; color: var(--mj-muted); }
.mjty-upsell-price { display: flex; align-items: center; gap: 10px; margin-bottom: 14px; }
.mjty-upsell-price strong { font-size: 22px; color: var(--mj-price); font-weight: 800; }
.mjty-upsell-price del { color: var(--mj-muted); font-size: 15px; }
.mjty-upsell-actions { display: flex; gap: 10px; flex-wrap: wrap; }
.mjty-upsell-yes {
	background: var(--mj-buy);
	color: #fff;
	border: 0;
	border-radius: var(--mj-btn-radius);
	font-family: inherit;
	font-weight: 800;
	font-size: 15px;
	padding: 12px 26px;
	cursor: pointer;
	animation: mj-pulse 2s infinite;
}
.mjty-upsell-yes:disabled { opacity: .6; cursor: wait; animation: none; }
.mjty-upsell-no {
	background: none;
	border: 0;
	color: var(--mj-muted);
	font-family: inherit;
	font-size: 13.5px;
	cursor: pointer;
	text-decoration: underline;
}
.mjty-upsell-result { margin: 10px 0 0; font-weight: 700; font-size: 14px; }
.mjty-upsell-result:empty { display: none; }
.mjty-upsell-done { border-style: solid; border-color: var(--mj-buy); background: #f0fdf4; }

@media (max-width: 560px) {
	.mjty-upsell { grid-template-columns: 1fr; text-align: center; }
	.mjty-upsell-img { max-width: 200px; margin-inline: auto; }
	.mjty-upsell-actions { justify-content: center; }
	.mjty-upsell-price { justify-content: center; }
}
