/*
Theme layer: NAJlife reset homepage
Validated direction: Moroccan premium streetwear, clean editorial white, bronze gold accents.
*/

:root {
	--najlife-white: #ffffff;
	--najlife-ivory: #fbf8f2;
	--najlife-soft: #f4efe7;
	--najlife-ink: #17120e;
	--najlife-muted: #6f6258;
	--najlife-line: rgba(105, 82, 54, 0.18);
	--najlife-gold: #b78335;
	--najlife-gold-dark: #8b5d24;
	--najlife-shadow: 0 24px 80px rgba(39, 28, 18, 0.12);
	--najlife-serif: Georgia, 'Times New Roman', serif;
	--najlife-sans: Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
}

html {
	box-sizing: border-box;
	scroll-behavior: smooth;
}

*,
*::before,
*::after {
	box-sizing: inherit;
}

body {
	margin: 0;
	background: var(--najlife-white);
	color: var(--najlife-ink);
	font-family: var(--najlife-sans);
	font-size: 16px;
	line-height: 1.6;
	-webkit-font-smoothing: antialiased;
	text-rendering: optimizeLegibility;
}

body.najlife-menu-locked {
	overflow: hidden;
}

a {
	color: inherit;
	text-decoration: none;
}

img,
svg {
	display: block;
	max-width: 100%;
}

button,
input {
	font: inherit;
}

.site {
	min-height: 100vh;
	display: flex;
	flex-direction: column;
	background: var(--najlife-white);
}

.site-main {
	flex: 1 0 auto;
}

.screen-reader-text {
	clip: rect(1px, 1px, 1px, 1px);
	clip-path: inset(50%);
	height: 1px;
	margin: -1px;
	overflow: hidden;
	padding: 0;
	position: absolute !important;
	width: 1px;
	word-wrap: normal !important;
}

.skip-link:focus {
	clip: auto !important;
	clip-path: none;
	display: block;
	font-weight: 700;
	height: auto;
	left: 16px;
	padding: 12px 16px;
	top: 16px;
	width: auto;
	z-index: 100000;
	background: var(--najlife-white);
	border: 1px solid var(--najlife-gold);
}

/* Header */
.najlife-header {
	position: fixed;
	top: 0;
	left: 0;
	right: 0;
	z-index: 1000;
	background: rgb(255 255 255 / 0%);
	backdrop-filter: blur(0px);
	-webkit-backdrop-filter: blur(0px);
	border-bottom: 1px solid transparent;
	transition: background 260ms ease, box-shadow 260ms ease, border-color 260ms ease, backdrop-filter 260ms ease;
}

.najlife-header.is-scrolled,
.najlife-header.is-menu-open {
	background: rgb(251 248 242 / 50%);
	backdrop-filter: blur(8px);
	-webkit-backdrop-filter: blur(8px);
	border-bottom-color: rgba(183, 134, 58, 0.2);
	box-shadow: 0 12px 36px rgba(28, 20, 13, 0.08);
}

.najlife-header__inner {
	height: 82px;
	max-width: 1440px;
	margin: 0 auto;
	padding: 0 clamp(24px, 4.8vw, 72px);
	display: grid;
	grid-template-columns: minmax(148px, 220px) 1fr minmax(132px, 220px);
	align-items: center;
	gap: 24px;
}

.najlife-header__brand {
	display: flex;
	align-items: center;
	justify-content: flex-start;
	min-width: 0;
}

.najlife-logo {
	display: inline-flex;
	align-items: center;
	justify-content: flex-start;
	text-decoration: none;
}

.najlife-logo img {
	display: block;
	height: clamp(52px, 4.6vw, 64px);
	width: auto;
	max-width: 178px;
	object-fit: contain;
}

.najlife-nav {
	display: flex;
	justify-content: center;
	align-items: center;
}

.najlife-nav__toggle {
	display: none;
	width: 42px;
	height: 42px;
	align-items: center;
	justify-content: center;
	flex-direction: column;
	gap: 5px;
	border: 1px solid var(--najlife-line);
	border-radius: 999px;
	background: rgba(255, 255, 255, 0.78);
	cursor: pointer;
}

.najlife-nav__toggle span:not(.screen-reader-text) {
	width: 18px;
	height: 1.5px;
	background: var(--najlife-ink);
}

.najlife-menu,
.najlife-menu ul {
	list-style: none;
	margin: 0;
	padding: 0;
}

.najlife-menu {
	display: flex;
	align-items: center;
	justify-content: center;
	gap: clamp(24px, 3vw, 44px);
}

.najlife-menu > li {
	position: relative;
}

.najlife-menu a {
	display: inline-flex;
	align-items: center;
	gap: 7px;
	padding: 30px 0;
	font-size: 15px;
	font-weight: 560;
	letter-spacing: -0.01em;
	color: var(--najlife-ink);
	transition: color 180ms ease;
}

.najlife-menu a:hover,
.najlife-menu .current-menu-item > a,
.najlife-menu .current_page_item > a {
	color: var(--najlife-gold-dark);
}

.najlife-menu > .menu-item-has-children > a::after {
	content: '';
	width: 7px;
	height: 7px;
	border-right: 1.5px solid currentColor;
	border-bottom: 1.5px solid currentColor;
	transform: rotate(45deg) translateY(-2px);
	margin-left: 2px;
}

.najlife-menu .sub-menu {
	position: absolute;
	top: 100%;
	left: 50%;
	min-width: 180px;
	padding: 14px;
	border: 1px solid rgba(130, 95, 52, 0.14);
	border-radius: 10px;
	background: rgba(255, 255, 255, 0.96);
	box-shadow: 0 22px 52px rgba(36, 24, 13, 0.14);
	transform: translate(-50%, 10px);
	opacity: 0;
	visibility: hidden;
	transition: opacity 180ms ease, transform 180ms ease, visibility 180ms ease;
}

.najlife-menu li:hover > .sub-menu,
.najlife-menu li:focus-within > .sub-menu {
	opacity: 1;
	visibility: visible;
	transform: translate(-50%, 0);
}

.najlife-menu .sub-menu a {
	width: 100%;
	padding: 8px 7px;
	font-size: 14px;
	border-radius: 7px;
	white-space: nowrap;
}

.najlife-menu .sub-menu a:hover {
	background: var(--najlife-ivory);
}

.najlife-header__actions {
	display: flex;
	align-items: center;
	justify-content: flex-end;
	gap: 17px;
}

.najlife-icon-link {
	position: relative;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 32px;
	height: 32px;
	color: var(--najlife-ink);
}

.najlife-icon-link svg {
	width: 24px;
	height: 24px;
	fill: none;
	stroke: currentColor;
	stroke-width: 1.7;
	stroke-linecap: round;
	stroke-linejoin: round;
}

.najlife-cart-count {
	position: absolute;
	top: -7px;
	right: -7px;
	min-width: 18px;
	height: 18px;
	padding: 0 5px;
	border-radius: 999px;
	background: var(--najlife-gold);
	color: #fff;
	font-size: 11px;
	font-weight: 700;
	line-height: 18px;
	text-align: center;
}

/* Home shared */
.najlife-home {
	background: #fff;
}

.section-pad {
	padding: clamp(54px, 6vw, 92px) clamp(22px, 5vw, 76px);
}

.najlife-section-heading {
	max-width: 820px;
	margin: 0 auto clamp(38px, 4vw, 58px);
	text-align: center;
}

.najlife-eyebrow {
	margin: 0 0 8px;
	color: var(--najlife-gold-dark);
	font-size: 13px;
	font-weight: 750;
	letter-spacing: 0.12em;
	text-transform: uppercase;
}

.najlife-section-heading h2,
.najlife-collections__heading h2,
.najlife-adn__content h2,
.najlife-community h2 {
	margin: 0;
	font-family: var(--najlife-serif);
	font-weight: 400;
	line-height: 1.08;
	letter-spacing: -0.045em;
	color: var(--najlife-ink);
}

.najlife-section-heading h2 {
	font-size: clamp(32px, 4.2vw, 58px);
}

.najlife-section-heading span,
.najlife-collections__heading span,
.najlife-gold-line {
	display: block;
	width: 46px;
	height: 1px;
	margin: 17px auto 0;
	background: var(--najlife-gold);
	position: relative;
}

.najlife-section-heading span::after,
.najlife-collections__heading span::after,
.najlife-gold-line::after {
	content: '';
	position: absolute;
	top: 50%;
	left: 50%;
	width: 7px;
	height: 7px;
	background: var(--najlife-gold);
	transform: translate(-50%, -50%) rotate(45deg);
}

.najlife-button {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 16px;
	min-height: 52px;
	padding: 0 28px;
	border: 1px solid rgba(139, 93, 36, 0.2);
	border-radius: 5px;
	background: linear-gradient(135deg, #c4934b 0%, #9c6527 100%);
	box-shadow: 0 12px 24px rgba(139, 93, 36, 0.18);
	color: #fff;
	font-weight: 700;
	font-size: 15px;
	transition: transform 180ms ease, box-shadow 180ms ease;
}

.najlife-button:hover {
	transform: translateY(-2px);
	box-shadow: 0 18px 34px rgba(139, 93, 36, 0.24);
}

.najlife-button--center {
	margin: 34px auto 0;
	display: flex;
	width: fit-content;
}

/* Hero */
.najlife-hero {
	position: relative;
	min-height: clamp(620px, 78vh, 820px);
	padding: 88px clamp(24px, 5vw, 76px) clamp(54px, 7vw, 96px);
	display: flex;
	align-items: center;
	overflow: hidden;
	background: #f3ede4;
}

.najlife-hero__media {
	position: absolute;
	inset: 0;
	background:
		linear-gradient(90deg, rgba(255,255,255,0.97) 0%, rgba(255,255,255,0.88) 33%, rgba(255,255,255,0.22) 58%, rgba(255,255,255,0.02) 100%),
		url('https://najlife.com/wp-content/themes/najlife/assets/img/najlife-home-hero.png');
	background-size: cover;
	background-position: center right;
	z-index: 0;
}

.najlife-hero::after {
	content: '';
	position: absolute;
	left: 0;
	right: 0;
	bottom: 0;
	height: 120px;
	background: linear-gradient(180deg, rgba(255, 255, 255, 0), #fff 94%);
	z-index: 1;
}

.najlife-hero__content {
	position: relative;
	z-index: 2;
	max-width: 680px;
	padding-top: clamp(16px, 3vw, 52px);
}

.najlife-hero h1 {
	margin: 0;
	font-family: var(--najlife-serif);
	font-size: clamp(48px, 5.2vw, 84px);
	font-weight: 400;
	line-height: 0.98;
	letter-spacing: -0.055em;
	color: var(--najlife-ink);
}

.najlife-hero p {
	max-width: 560px;
	margin: 24px 0 34px;
	font-size: clamp(16px, 1.45vw, 21px);
	font-weight: 520;
	color: #251b15;
}

/* Universe */
.najlife-universe {
	background: var(--najlife-white);
}

.najlife-values {
	max-width: 1180px;
	margin: 0 auto;
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 0;
}

.najlife-values article {
	position: relative;
	padding: 0 clamp(24px, 4vw, 70px);
	text-align: center;
}

.najlife-values article + article {
	border-left: 1px solid var(--najlife-line);
}

.najlife-value-icon {
	width: 60px;
	height: 60px;
	margin: 0 auto 20px;
	color: var(--najlife-gold);
	background: currentColor;
	mask-repeat: no-repeat;
	mask-position: center;
	mask-size: contain;
	-webkit-mask-repeat: no-repeat;
	-webkit-mask-position: center;
	-webkit-mask-size: contain;
}

.najlife-icon-zellij {
	mask-image: radial-gradient(circle, #000 0 28%, transparent 29%), conic-gradient(from 45deg, transparent 0 8%, #000 8% 17%, transparent 17% 25%, #000 25% 34%, transparent 34% 42%, #000 42% 51%, transparent 51% 59%, #000 59% 68%, transparent 68% 76%, #000 76% 85%, transparent 85% 100%);
	-webkit-mask-image: radial-gradient(circle, #000 0 28%, transparent 29%), conic-gradient(from 45deg, transparent 0 8%, #000 8% 17%, transparent 17% 25%, #000 25% 34%, transparent 34% 42%, #000 42% 51%, transparent 51% 59%, #000 59% 68%, transparent 68% 76%, #000 76% 85%, transparent 85% 100%);
}

.najlife-icon-tee {
	mask-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 64 64' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M22 10h20l12 8-7 11-6-3v28H23V26l-6 3-7-11 12-8Zm7 4c1 3 5 3 6 0' fill='none' stroke='black' stroke-width='4' stroke-linejoin='round'/%3E%3C/svg%3E");
	-webkit-mask-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 64 64' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M22 10h20l12 8-7 11-6-3v28H23V26l-6 3-7-11 12-8Zm7 4c1 3 5 3 6 0' fill='none' stroke='black' stroke-width='4' stroke-linejoin='round'/%3E%3C/svg%3E");
}

.najlife-icon-globe {
	mask-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 64 64' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='none' stroke='black' stroke-width='4'%3E%3Ccircle cx='32' cy='32' r='24'/%3E%3Cpath d='M8 32h48M32 8c8 7 12 15 12 24S40 49 32 56M32 8C24 15 20 23 20 32s4 17 12 24'/%3E%3C/g%3E%3C/svg%3E");
	-webkit-mask-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 64 64' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='none' stroke='black' stroke-width='4'%3E%3Ccircle cx='32' cy='32' r='24'/%3E%3Cpath d='M8 32h48M32 8c8 7 12 15 12 24S40 49 32 56M32 8C24 15 20 23 20 32s4 17 12 24'/%3E%3C/g%3E%3C/svg%3E");
}

.najlife-values h3 {
	margin: 0 0 10px;
	font-size: 18px;
	font-weight: 680;
}

.najlife-values p {
	max-width: 300px;
	margin: 0 auto;
	color: #2c2724;
	font-size: 15px;
}

/* Products */
.najlife-products {
	background: linear-gradient(180deg, #fff 0%, var(--najlife-ivory) 100%);
}

.najlife-product-grid {
	max-width: 1320px;
	margin: 0 auto;
	display: grid;
	grid-template-columns: repeat(4, minmax(0, 1fr));
	gap: clamp(18px, 2.5vw, 34px);
}

.najlife-product-card {
	display: block;
}

.najlife-product-card__image {
	position: relative;
	display: flex;
	align-items: center;
	justify-content: center;
	aspect-ratio: 1 / 1;
	border-radius: 7px;
	background: #eee8df center / cover no-repeat;
	overflow: hidden;
	transition: transform 220ms ease, box-shadow 220ms ease;
}

.najlife-product-card:hover .najlife-product-card__image {
	transform: translateY(-4px);
	box-shadow: var(--najlife-shadow);
}

.najlife-product-card__image.is-placeholder {
	background: linear-gradient(145deg, #eee6db, #fbf8f2);
}

.najlife-product-card__image.is-placeholder img {
	width: 44%;
	opacity: 0.72;
}

.najlife-product-card__image em {
	position: absolute;
	top: 13px;
	right: 13px;
	padding: 6px 10px;
	border-radius: 4px;
	background: var(--najlife-gold);
	color: #fff;
	font-size: 11px;
	font-style: normal;
	font-weight: 800;
	letter-spacing: 0.04em;
	text-transform: uppercase;
}

.najlife-product-card__meta {
	display: flex;
	align-items: flex-start;
	justify-content: space-between;
	gap: 16px;
	padding-top: 12px;
	font-size: 14px;
}

.najlife-product-card__meta strong {
	font-weight: 620;
}

.najlife-product-card__meta small {
	white-space: nowrap;
	color: #2f2924;
	font-size: 13px;
}

.najlife-empty-state {
	max-width: 720px;
	margin: 0 auto;
	padding: 42px 28px;
	border: 1px dashed rgba(183, 131, 53, 0.38);
	border-radius: 10px;
	background: rgba(255, 255, 255, 0.72);
	text-align: center;
}

.najlife-empty-state strong {
	display: block;
	font-family: var(--najlife-serif);
	font-size: clamp(26px, 3vw, 38px);
	font-weight: 400;
	letter-spacing: -0.035em;
}

.najlife-empty-state p {
	max-width: 500px;
	margin: 10px auto 0;
	color: var(--najlife-muted);
}

/* Collections */
.najlife-collections {
	background: var(--najlife-white);
	display: grid;
	grid-template-columns: minmax(220px, 330px) 1fr;
	gap: clamp(26px, 5vw, 78px);
	align-items: center;
}

.najlife-collections__heading {
	padding-left: clamp(0px, 1vw, 18px);
}

.najlife-collections__heading h2 {
	font-size: clamp(34px, 4.4vw, 62px);
}

.najlife-collections__heading span {
	margin-left: 0;
}

.najlife-collection-grid {
	display: grid;
	grid-template-columns: repeat(4, minmax(0, 1fr));
	gap: 18px;
}

.najlife-collection-card {
	position: relative;
	min-height: 210px;
	padding: 24px;
	display: flex;
	flex-direction: column;
	justify-content: flex-end;
	border-radius: 8px;
	overflow: hidden;
	background:
		linear-gradient(160deg, rgba(32, 22, 15, 0.05), rgba(34, 22, 13, 0.72)),
		var(--najlife-collection-image),
		linear-gradient(135deg, #d4b08b, #7b4b25);
	background-position: center;
	background-size: cover;
	color: #fff;
	box-shadow: 0 18px 48px rgba(37, 24, 14, 0.10);
	transition: transform 220ms ease, box-shadow 220ms ease;
}

.najlife-collection-card.is-empty {
	background:
		linear-gradient(160deg, rgba(32, 22, 15, 0.08), rgba(34, 22, 13, 0.70)),
		linear-gradient(135deg, #efe7db, #aa7d4b);
}

.najlife-collection-card:hover {
	transform: translateY(-4px);
	box-shadow: var(--najlife-shadow);
}

.najlife-collection-card__shade {
	position: absolute;
	inset: 0;
	background: radial-gradient(circle at 78% 20%, rgba(255, 255, 255, 0.22), transparent 32%);
}

.najlife-collection-card strong,
.najlife-collection-card small {
	position: relative;
	z-index: 1;
}

.najlife-collection-card strong {
	font-family: var(--najlife-serif);
	font-size: clamp(22px, 2vw, 30px);
	font-weight: 400;
	letter-spacing: -0.035em;
	line-height: 1.05;
}

.najlife-collection-card small {
	margin-top: 7px;
	font-size: 13px;
	font-weight: 700;
}

.najlife-collection-card__link {
	position: relative;
	z-index: 1;
	margin-top: 14px;
	font-size: 13px;
	font-weight: 780;
}

/* ADN */
.najlife-adn {
	display: grid;
	grid-template-columns: 1fr 1fr;
	min-height: 520px;
	background: var(--najlife-ivory);
}

.najlife-adn__image {
	min-height: 420px;
	background:
		linear-gradient(180deg, rgba(255,255,255,0), rgba(64,36,16,0.07)),
		url('https://najlife.com/wp-content/themes/najlife/assets/img/najlife-adn-story.png') center / cover no-repeat,
		linear-gradient(135deg, #ceb18f, #6f4423);
}

.najlife-adn__content {
	position: relative;
	padding: clamp(54px, 7vw, 110px) clamp(30px, 8vw, 130px);
	display: flex;
	flex-direction: column;
	justify-content: center;
	overflow: hidden;
}

.najlife-adn__content::after {
	content: '';
	position: absolute;
	right: -72px;
	bottom: -78px;
	width: 310px;
	height: 310px;
	border: 22px solid rgba(183, 131, 53, 0.07);
	transform: rotate(45deg);
	pointer-events: none;
}

.najlife-adn__content h2 {
	font-size: clamp(36px, 4.2vw, 64px);
}

.najlife-adn__content .najlife-gold-line {
	margin: 20px 0 26px;
}

.najlife-adn__content p:not(.najlife-eyebrow) {
	position: relative;
	z-index: 1;
	max-width: 570px;
	margin: 0 0 30px;
	color: #2a231e;
}

.najlife-adn__content .najlife-button {
	position: relative;
	z-index: 1;
	width: fit-content;
}

/* Community */
.najlife-community {
	text-align: center;
	background: #fff;
	padding-bottom: clamp(40px, 5vw, 70px);
}

.najlife-community h2 {
	font-size: clamp(32px, 4vw, 56px);
}

.najlife-community > p:not(.najlife-eyebrow) {
	max-width: 660px;
	margin: 12px auto 28px;
	color: var(--najlife-muted);
}

.najlife-newsletter {
	max-width: 560px;
	margin: 0 auto 25px;
	display: grid;
	grid-template-columns: 1fr auto;
	border: 1px solid var(--najlife-line);
	border-radius: 6px;
	overflow: hidden;
	background: var(--najlife-white);
}

.najlife-newsletter input {
	min-height: 54px;
	border: 0;
	padding: 0 20px;
	outline: none;
	background: transparent;
	color: var(--najlife-ink);
}

.najlife-newsletter button {
	min-width: 150px;
	border: 0;
	background: linear-gradient(135deg, #c4934b 0%, #9c6527 100%);
	color: #fff;
	font-weight: 750;
	cursor: pointer;
}

.najlife-community__socials {
	display: flex;
	justify-content: center;
	gap: 18px;
	flex-wrap: wrap;
}

.najlife-community__socials a {
	min-width: 132px;
	padding: 10px 18px;
	border: 1px solid rgba(183, 131, 53, 0.45);
	border-radius: 5px;
	color: var(--najlife-gold-dark);
	font-size: 14px;
	font-weight: 700;
}

/* =========================
   FOOTER — NAJLIFE
========================= */

.najlife-footer {
	position: relative;
	overflow: hidden;
	margin: 0;
	border-top: 1px solid rgba(194, 150, 91, 0.28);
	background-color: #f7f2ec;
	background-image:
		linear-gradient(90deg, rgb(247 242 236 / 56%) 0%, rgb(247 242 236 / 29%) 34%, rgb(247 242 236 / 28%) 60%, rgba(247, 242, 236, 0.52) 100%),
		url('/wp-content/themes/najlife/assets/img/najlife-footer-atelier.png');
	background-repeat: no-repeat;
	background-position: center center;
	background-size: cover;
	color: #2f241c;
}

.najlife-footer__overlay {
	position: absolute;
	inset: 0;
	background:
		linear-gradient(180deg, rgba(255,255,255,0.08), rgba(255,255,255,0.04));
	pointer-events: none;
}

.najlife-footer__inner {
	position: relative;
	z-index: 1;
	max-width: 1280px;
	margin: 0 auto;
	padding: 64px 32px 28px;
}

.najlife-footer__top {
	display: grid;
	grid-template-columns: 1.2fr 0.8fr 0.7fr;
	gap: 48px;
	align-items: center;
	padding-bottom: 36px;
	border-bottom: 1px solid rgba(194, 150, 91, 0.22);
}

.najlife-footer__brand {
	max-width: 360px;
}

.najlife-footer__logo-link {
	display: inline-block;
	text-decoration: none;
}

.najlife-footer__logo {
	display: block;
	width: 180px;
	max-width: 100%;
	height: auto;
}

.najlife-footer__brand-separator {
	width: 120px;
	height: 1px;
	margin: 20px 0 22px;
	background: linear-gradient(90deg, rgba(194,150,91,0.95), rgba(194,150,91,0.18));
	position: relative;
}

.najlife-footer__brand-separator::after {
	content: "";
	position: absolute;
	top: 50%;
	left: 58px;
	width: 8px;
	height: 8px;
	border-radius: 50%;
	background: #c2965b;
	transform: translateY(-50%);
}

.najlife-footer__tagline {
	margin: 0 0 18px;
	font-size: 0.98rem;
	line-height: 1.7;
	letter-spacing: 0.18em;
	text-transform: uppercase;
	font-weight: 700;
	color: #3a2a1f;
}

.najlife-footer__text {
	margin: 0;
	font-size: 1rem;
	line-height: 1.8;
	color: rgba(47, 36, 28, 0.88);
}

.najlife-footer__nav {
	display: flex;
	flex-direction: column;
	gap: 18px;
	padding-left: 28px;
	border-left: 1px solid rgba(194, 150, 91, 0.34);
}

.najlife-footer__nav a,
.najlife-footer__legal a,
.najlife-footer__social {
	text-decoration: none;
	transition: all 0.25s ease;
}

.najlife-footer__nav a {
	font-size: 1.1rem;
	font-weight: 500;
	color: #2f241c;
}

.najlife-footer__nav a:hover,
.najlife-footer__nav a:focus {
	color: #b8823f;
	transform: translateX(3px);
}

.najlife-footer__socials {
	display: flex;
	justify-content: flex-end;
	flex-wrap: wrap;
	gap: 16px;
}

.najlife-footer__social {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 54px;
	height: 54px;
	border-radius: 50%;
	border: 1px solid rgba(194, 150, 91, 0.78);
	background: rgba(255, 255, 255, 0.14);
	color: #b8823f;
	backdrop-filter: blur(2px);
}

.najlife-footer__social svg {
	width: 21px;
	height: 21px;
	fill: currentColor;
}

.najlife-footer__social:hover,
.najlife-footer__social:focus {
	background: rgba(194, 150, 91, 0.12);
	color: #8f622f;
	transform: translateY(-2px);
}

.najlife-footer__bottom {
	display: grid;
	grid-template-columns: 1fr auto 1fr;
	align-items: center;
	gap: 18px;
	padding-top: 22px;
}

.najlife-footer__copyright,
.najlife-footer__made {
	margin: 0;
	font-size: 0.95rem;
	color: rgba(47, 36, 28, 0.86);
}

.najlife-footer__made {
	text-align: right;
}

.najlife-footer__legal {
	display: flex;
	align-items: center;
	justify-content: center;
	flex-wrap: wrap;
	gap: 22px;
}

.najlife-footer__legal a {
	position: relative;
	font-size: 0.95rem;
	color: rgba(47, 36, 28, 0.88);
}

.najlife-footer__legal a:hover,
.najlife-footer__legal a:focus {
	color: #b8823f;
}

.najlife-footer__legal a:not(:last-child)::after {
	content: "◆";
	margin-left: 22px;
	color: rgba(194, 150, 91, 0.55);
	font-size: 0.7rem;
}

/* Responsive */
@media (max-width: 1024px) {
	.najlife-footer__top {
		grid-template-columns: 1fr;
		gap: 32px;
	}

	.najlife-footer__nav {
		padding-left: 0;
		border-left: 0;
	}

	.najlife-footer__socials {
		justify-content: flex-start;
	}

	.najlife-footer__bottom {
		grid-template-columns: 1fr;
		text-align: left;
	}

	.najlife-footer__made {
		text-align: left;
	}

	.najlife-footer__legal {
		justify-content: flex-start;
	}
}

@media (max-width: 767px) {
	.najlife-footer {
		background-position: center center;
	}

	.najlife-footer__inner {
		padding: 48px 20px 24px;
	}

	.najlife-footer__logo {
		width: 150px;
	}

	.najlife-footer__tagline {
		font-size: 0.9rem;
		letter-spacing: 0.14em;
	}

	.najlife-footer__text,
	.najlife-footer__nav a,
	.najlife-footer__copyright,
	.najlife-footer__made,
	.najlife-footer__legal a {
		font-size: 0.95rem;
	}

	.najlife-footer__social {
		width: 48px;
		height: 48px;
	}

	.najlife-footer__legal {
		gap: 12px 18px;
	}

	.najlife-footer__legal a:not(:last-child)::after {
		display: none;
	}
}
/* Responsive */
@media (max-width: 1100px) {
	.najlife-header__inner {
		grid-template-columns: auto 1fr auto;
	}

	.najlife-menu {
		gap: 24px;
	}

	.najlife-hero {
		min-height: 670px;
		align-items: flex-start;
		padding-top: 170px;
	}

	.najlife-hero__media {
		background-position: 62% center;
	}

	.najlife-product-grid,
	.najlife-collection-grid {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}

	.najlife-collections {
		grid-template-columns: 1fr;
	}
}

@media (max-width: 820px) {
	.najlife-header__inner {
		height: 78px;
		padding-inline: 18px;
	}

	.najlife-logo img {
		height: 62px;
		max-width: 106px;
	}

	.najlife-nav {
		order: 3;
		justify-content: flex-end;
	}

	.najlife-nav__toggle {
		display: inline-flex;
	}

	.najlife-header__actions {
		gap: 10px;
	}

	.najlife-icon-link {
		width: 29px;
		height: 29px;
	}

	.najlife-icon-link svg {
		width: 22px;
		height: 22px;
	}

	.najlife-menu {
		position: absolute;
		top: 78px;
		left: 18px;
		right: 18px;
		display: none;
		padding: 18px;
		border: 1px solid var(--najlife-line);
		border-radius: 14px;
		background: rgba(255,255,255,.96);
		box-shadow: var(--najlife-shadow);
		flex-direction: column;
		align-items: stretch;
		gap: 0;
	}

	.najlife-header.is-menu-open .najlife-menu {
		display: flex;
	}

	.najlife-menu a {
		padding: 11px 4px;
	}

	.najlife-menu .sub-menu {
		position: static;
		min-width: 0;
		padding: 4px 0 8px 16px;
		border: 0;
		border-left: 1px solid var(--najlife-line);
		border-radius: 0;
		box-shadow: none;
		opacity: 1;
		visibility: visible;
		transform: none;
		background: transparent;
	}

	.najlife-hero {
		min-height: 720px;
		padding: 130px 22px 54px;
		align-items: flex-start;
		background: linear-gradient(180deg, rgba(255,255,255,.84), rgba(255,255,255,.28)), #efe6da;
	}

	.najlife-hero__media {
		background-position: 65% center;
	}

	.najlife-hero__content {
		max-width: 92%;
	}

	.najlife-values {
		grid-template-columns: 1fr;
		gap: 32px;
	}

	.najlife-values article {
		padding: 0;
	}

	.najlife-values article + article {
		border-left: 0;
		border-top: 1px solid var(--najlife-line);
		padding-top: 32px;
	}

	.najlife-adn {
		grid-template-columns: 1fr;
	}

	.najlife-footer__inner {
		grid-template-columns: 1fr;
		text-align: center;
	}

	.najlife-footer__logo img {
		margin: 0 auto;
	}

	.najlife-footer__nav {
		grid-template-columns: repeat(2, auto);
	}

	.najlife-footer__socials {
		justify-content: center;
	}
}

@media (max-width: 560px) {
	.najlife-header__inner {
		grid-template-columns: 1fr auto auto;
		gap: 12px;
	}

	.najlife-logo img {
		height: 56px;
		max-width: 96px;
	}

	.najlife-header__actions .najlife-icon-link:first-child {
		display: none;
	}

	.najlife-hero h1 {
		font-size: clamp(40px, 14vw, 60px);
	}

	.najlife-hero p {
		font-size: 16px;
	}

	.section-pad {
		padding-inline: 20px;
	}

	.najlife-product-grid,
	.najlife-collection-grid {
		grid-template-columns: 1fr;
	}

	.najlife-product-card__meta {
		font-size: 13px;
	}

	.najlife-newsletter {
		grid-template-columns: 1fr;
	}

	.najlife-newsletter button {
		min-height: 52px;
	}
}

/* Header/logo correction — compact validated layout */
@media (min-width: 821px) {
	.admin-bar .najlife-header { top: 32px; }
}

@media (max-width: 1100px) {
	.najlife-header__inner {
		grid-template-columns: minmax(130px, 180px) 1fr minmax(112px, 170px);
		height: 78px;
	}
	.najlife-logo img {
		height: 54px;
		max-width: 150px;
	}
	.najlife-menu { gap: 24px; }
	.najlife-hero {
		min-height: 660px;
		padding-top: 120px;
	}
	.najlife-hero__media { background-position: 64% center; }
}

@media (max-width: 820px) {
	.najlife-header__inner {
		height: 74px;
		padding-inline: 18px;
		grid-template-columns: auto 1fr auto;
	}
	.najlife-logo img {
		height: 48px;
		max-width: 132px;
	}
	.najlife-menu { top: 74px; }
	.najlife-hero {
		min-height: 700px;
		padding: 118px 22px 54px;
	}
	.najlife-hero__media {
		background:
			linear-gradient(180deg, rgba(255,255,255,.92), rgba(255,255,255,.30)),
			url('https://najlife.com/wp-content/themes/najlife/assets/img/najlife-home-hero.png');
		background-size: cover;
		background-position: 66% center;
	}
}

@media (max-width: 560px) {
	.najlife-header__inner {
		grid-template-columns: 1fr auto auto;
		gap: 12px;
	}
	.najlife-logo img {
		height: 44px;
		max-width: 120px;
	}
	.najlife-hero h1 { font-size: clamp(40px, 13vw, 58px); }
}

/* =========================
   E-SOUK — Collections carousel + boutique
   Connected to WooCommerce categories/products.
========================= */


/* E-Souk header: same logic as homepage, transparent over hero then ivory glass on scroll. */
body.page-template-page-e-souk .najlife-header:not(.is-scrolled):not(.is-menu-open) {
	background: linear-gradient(180deg, rgba(255,255,255,0.12) 0%, rgba(255,255,255,0.04) 58%, rgba(255,255,255,0) 100%);
	border-bottom-color: transparent;
	box-shadow: none;
	backdrop-filter: blur(0);
	-webkit-backdrop-filter: blur(0);
}

.najlife-esouk {
	--esouk-max: 1320px;
	--esouk-radius: 10px;
	background: #fff;
	color: var(--najlife-ink);
	padding-top: 0;
}

.najlife-esouk-hero {
	position: relative;
	width: 100%;
	margin: 0;
	padding: 0 0 clamp(42px, 5vw, 68px);
	overflow: visible;
	background: #fff;
}

.najlife-esouk-hero__track {
	position: relative;
	width: 100%;
	aspect-ratio: 1792 / 768;
	min-height: clamp(620px, 76vh, 760px);
	max-height: auto;
	height: auto;
	margin: 0;
	overflow: hidden;
	background: #f4efe7;
	box-shadow: 0 28px 84px rgba(30, 20, 12, 0.16);
}


.najlife-esouk-hero__track::after {
	content: '';
	position: absolute;
	left: 0;
	right: 0;
	bottom: 0;
	height: 140px;
	background: linear-gradient(180deg, rgba(255, 255, 255, 0), #fff 92%);
	z-index: 2;
	pointer-events: none;
}

.najlife-esouk-slide::before {
	content: '';
	position: absolute;
	inset: 0;
	z-index: 1;
	background: linear-gradient(180deg, rgba(255,255,255,0) 0%, rgba(255,255,255,0) 70%, rgba(255,255,255,0.14) 100%);
	pointer-events: none;
}

.najlife-esouk-slide__content > * {
	position: relative;
	z-index: 2;
}

.najlife-esouk-slide__count {
	color: #d7a657;
}

@media (max-width: 991px) {
	.najlife-esouk-hero {
		padding-bottom: 46px;
	}

	.najlife-esouk-hero__track {
		min-height: 640px;
		height: 640px;
		aspect-ratio: auto;
	}

	.najlife-esouk-hero__track::after {
		height: 110px;
	}

	.najlife-esouk-slide__visual {
		background:
			linear-gradient(90deg, rgba(255, 255, 255, 0.95) 0%, rgba(255, 255, 255, 0.90) 18%, rgba(255, 255, 255, 0.58) 34%, rgba(255, 255, 255, 0.16) 52%, rgba(255, 255, 255, 0) 70%),
			var(--esouk-image) center left / cover no-repeat;
		transform: scale(1);
	}	
}

.najlife-esouk-slide {
	position: absolute;
	inset: 0;
	display: grid;
	grid-template-columns: minmax(0, 1fr);
	background: #f4efe7;
	overflow: hidden;
	border-radius: inherit;
	opacity: 0;
	visibility: hidden;
	transform: translate3d(100%, 0, 0);
	transition:
		opacity 900ms ease,
		transform 1200ms cubic-bezier(.16,1,.3,1),
		visibility 900ms ease;
	will-change: transform, opacity;
}

.najlife-esouk-slide.is-active {
	z-index: 3;
	opacity: 1;
	visibility: visible;
	transform: translate3d(0, 0, 0);
}

.najlife-esouk-slide.is-before {
	z-index: 2;
	opacity: 0;
	visibility: visible;
	transform: translate3d(-100%, 0, 0);
}

.najlife-esouk-slide.is-after {
	z-index: 1;
	opacity: 0;
	visibility: visible;
	transform: translate3d(100%, 0, 0);
}

.najlife-esouk-slide__visual {
	position: absolute;
	inset: 0;
	background:
		linear-gradient(90deg, rgba(255, 255, 255, 0.95) 0%, rgba(255, 255, 255, 0.90) 18%, rgba(255, 255, 255, 0.58) 34%, rgba(255, 255, 255, 0.16) 52%, rgba(255, 255, 255, 0) 70%),
		var(--esouk-image) center center / cover no-repeat;
	transform: scale(1);
	transition: transform 5600ms linear;
}

.najlife-esouk-slide.is-active .najlife-esouk-slide__visual {
	transform: scale(1.015);
}

.najlife-esouk-slide__content {
	position: relative;
	z-index: 5;
	align-self: center;
	width: min(560px, calc(100% - 48px));
	margin-left: max(24px, calc((100vw - var(--esouk-max)) / 2 + 24px));
	padding: clamp(32px, 4vw, 58px);
	color: #ffffff;
	text-shadow:
		0 2px 8px rgba(0, 0, 0, 0.42),
		0 8px 24px rgba(0, 0, 0, 0.28);
	opacity: 0;
	transform: translateY(18px);
	transition: opacity 560ms ease 170ms, transform 720ms cubic-bezier(.19,1,.22,1) 170ms;
}

.najlife-esouk-slide.is-active .najlife-esouk-slide__content {
	opacity: 1;
	transform: translateY(0);
}

.najlife-esouk-slide__count {
	margin: 0 0 14px;
	color: #d7a657;
	font-size: 13px;
	font-weight: 800;
	letter-spacing: 0.16em;
	text-transform: uppercase;
}

.najlife-esouk-slide h1 {
	margin: 0;
	font-family: var(--najlife-serif);
	font-size: clamp(54px, 6vw, 92px);
	font-weight: 400;
	line-height: 0.92;
	letter-spacing: -0.06em;
}

.najlife-esouk-slide strong {
	display: block;
	margin: 10px 0 20px;
	font-family: var(--najlife-serif);
	font-size: clamp(28px, 3.1vw, 48px);
	font-weight: 400;
	line-height: 1.02;
	letter-spacing: -0.04em;
	color: #d7a657;
}

.najlife-esouk-slide p:not(.najlife-esouk-slide__count) {
	max-width: 440px;
	margin: 0 0 30px;
	color: rgba(255, 255, 255, 0.91);
	font-size: clamp(15px, 1.15vw, 18px);
	line-height: 1.72;
}

.najlife-esouk-cta {
	display: inline-grid;
	grid-template-columns: 1fr 56px;
	align-items: center;
	min-height: 58px;
	padding-left: 24px;
	border-radius: 10px;
	background: linear-gradient(135deg, #c4934b 0%, #9c6527 100%);
	color: #fff;
	font-size: 15px;
	font-weight: 760;
	box-shadow: 0 16px 32px rgba(0, 0, 0, 0.18);
	transition: transform 220ms ease, box-shadow 220ms ease, filter 220ms ease;
}

.najlife-esouk-cta:hover {
	transform: translateY(-2px);
	box-shadow: 0 22px 48px rgba(0, 0, 0, 0.24);
	filter: saturate(1.05);
}

.najlife-esouk-cta span {
	display: grid;
	place-items: center;
	height: 100%;
	font-size: 24px;
	transition: transform 220ms ease;
}

.najlife-esouk-cta:hover span {
	transform: translateX(3px);
}

/* Navigation premium verticale du hero E-Souk */
.najlife-esouk-control {
	position: absolute;
	right: clamp(22px, 3.8vw, 70px);
	top: 50%;
	z-index: 8;
	display: grid;
	justify-items: center;
	gap: 14px;
	transform: translateY(-50%);
	padding: 14px 10px;
	border-radius: 999px;
	background: rgb(255 255 255 / 37%);
	backdrop-filter: blur(2px);
	-webkit-backdrop-filter: blur(2px);
	box-shadow: 0 18px 46px rgba(30, 20, 12, 0.10);
}

.najlife-esouk-control__btn {
	width: 34px;
	height: 34px;
	display: grid;
	place-items: center;
	border: 0;
	border-radius: 999px;
	background: rgba(255, 255, 255, 0.62);
	color: var(--najlife-gold);
	cursor: pointer;
	transition:
		background 180ms ease,
		color 180ms ease,
		transform 180ms ease;
}

.najlife-esouk-control__btn span {
	display: block;
	font-size: 18px;
	line-height: 1;
	transform: translateY(-1px) translateX(-8px);
}

.najlife-esouk-control__btn:hover {
	background: var(--najlife-gold-dark);
	color: #fff;
	transform: scale(1.06);
}

.najlife-esouk-control__index {
	display: grid;
	justify-items: center;
	gap: 7px;
	color: var(--najlife-ivory);
	font-family: var(--najlife-sans);
}

.najlife-esouk-control__index strong,
.najlife-esouk-control__index small {
	font-size: 11px;
	font-weight: 800;
	letter-spacing: 0.12em;
	line-height: 1;
}

.najlife-esouk-control__index i {
	display: block;
	width: 1px;
	height: 42px;
	background: linear-gradient(
		180deg,
		rgba(139, 93, 36, 0.10),
		rgb(224 184 135),
		rgba(139, 93, 36, 0.10)
	);
}
.najlife-esouk-collections,
.najlife-esouk-shop {
	max-width: var(--esouk-max);
	margin: 0 auto;
	padding-inline: clamp(18px, 4vw, 0px);
}

.najlife-esouk-heading {
	position: relative;
	margin: clamp(10px, 2vw, 22px) 0 30px;
	text-align: center;
}

.najlife-esouk-heading::before,
.najlife-esouk-heading::after {
	content: '';
	position: absolute;
	top: 50%;
	width: calc(50% - 175px);
	height: 1px;
	background: rgba(183, 131, 53, 0.35);
}

.najlife-esouk-heading::before { left: 0; }
.najlife-esouk-heading::after { right: 0; }

.najlife-esouk-heading h2,
.najlife-esouk-shop h2 {
	margin: 0;
	font-family: var(--najlife-serif);
	font-size: clamp(30px, 3vw, 42px);
	font-weight: 400;
	line-height: 1;
	letter-spacing: -0.04em;
}

.najlife-esouk-heading span,
.najlife-esouk-shop__bar > div > span {
	display: block;
	width: 44px;
	height: 1px;
	margin: 14px auto 0;
	background: var(--najlife-gold);
	position: relative;
}

.najlife-esouk-heading span::after {
	content: '✦';
	position: absolute;
	left: 50%;
	top: 50%;
	transform: translate(-50%, -50%);
	color: var(--najlife-gold);
	background: #fff;
	font-size: 13px;
	line-height: 1;
}

.najlife-esouk-grid {
	display: grid;
	grid-template-columns: repeat(4, minmax(0, 1fr));
	gap: 20px;
}

.najlife-esouk-card {
	display: grid;
	grid-template-rows: minmax(188px, 1fr) auto;
	border: 1px solid rgba(139, 93, 36, 0.16);
	border-radius: var(--esouk-radius);
	background: #fff;
	overflow: hidden;
	box-shadow: 0 10px 34px rgba(40, 28, 17, 0.06);
	transition: transform 220ms ease, box-shadow 220ms ease, border-color 220ms ease;
}

.najlife-esouk-card:hover {
	transform: translateY(-5px);
	border-color: rgba(183, 131, 53, 0.55);
	box-shadow: 0 22px 54px rgba(40, 28, 17, 0.13);
}

.najlife-esouk-card__image {
	display: block;
	min-height: 196px;
	background-color: #efe8dd;
	overflow: hidden;
	filter: saturate(0.96) contrast(1.03);
}

.najlife-esouk-card__image img {
	width: 100%;
	height: 100%;
	min-height: 196px;
	object-fit: cover;
	object-position: center;
	transition: transform 760ms cubic-bezier(.19,1,.22,1);
}

.najlife-esouk-card:hover .najlife-esouk-card__image img { transform: scale(1.045); }

.najlife-esouk-card__body {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 18px;
	padding: 18px 20px;
	background: #fff;
}

.najlife-esouk-card strong {
	display: block;
	font-family: var(--najlife-serif);
	font-size: 22px;
	font-weight: 400;
	letter-spacing: -0.035em;
	line-height: 1;
}

.najlife-esouk-card small {
	display: block;
	margin-top: 6px;
	color: var(--najlife-muted);
	font-size: 13px;
}

.najlife-esouk-card em {
	display: grid;
	place-items: center;
	width: 40px;
	height: 40px;
	border-radius: 50%;
	background: linear-gradient(135deg, #c4934b 0%, #9c6527 100%);
	color: #fff;
	font-style: normal;
	font-size: 22px;
	line-height: 1;
	transition: transform 220ms ease;
}

.najlife-esouk-card:hover em { transform: translateX(3px); }

.najlife-esouk-shop {
	padding-top: 34px;
	padding-bottom: clamp(52px, 6vw, 86px);
}

.najlife-esouk-shop__bar {
	display: flex;
	align-items: end;
	justify-content: space-between;
	gap: 24px;
	margin-bottom: 18px;
}

.najlife-esouk-shop__bar > div > span { margin-left: 0; }

.najlife-esouk-order {
	display: flex;
	align-items: center;
	gap: 14px;
}

.najlife-esouk-order select,
.najlife-esouk-order a {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-width: 172px;
	min-height: 46px;
	padding: 0 16px;
	border: 1px solid rgba(139, 93, 36, 0.18);
	border-radius: 999px;
	background: #fff;
	color: #2a211b;
	font-size: 14px;
	font-weight: 640;
	outline: none;
}

.najlife-esouk-order a {
	min-width: 120px;
	gap: 10px;
}

.najlife-esouk-empty {
	display: grid;
	grid-template-columns: 170px 1fr;
	align-items: center;
	min-height: 132px;
	border: 1px solid rgba(139, 93, 36, 0.16);
	border-radius: var(--esouk-radius);
	background: linear-gradient(180deg, #fff 0%, #fffaf4 100%);
	overflow: hidden;
}

.najlife-esouk-empty__icon {
	display: grid;
	place-items: center;
	height: 100%;
	border-right: 1px solid rgba(139, 93, 36, 0.12);
}

.najlife-esouk-empty__icon svg {
	width: 54px;
	height: 54px;
	fill: none;
	stroke: var(--najlife-gold);
	stroke-width: 1.6;
	stroke-linecap: round;
	stroke-linejoin: round;
}

.najlife-esouk-empty strong {
	display: block;
	font-family: var(--najlife-serif);
	font-size: clamp(24px, 2.3vw, 34px);
	font-weight: 400;
	letter-spacing: -0.04em;
}

.najlife-esouk-empty p {
	margin: 5px 0 0;
	color: var(--najlife-muted);
}

.najlife-esouk-skeleton,
.najlife-esouk-products {
	display: grid;
	grid-template-columns: repeat(4, minmax(0, 1fr));
	gap: 16px;
	margin-top: 16px;
}

.najlife-esouk-skeleton div {
	min-height: 182px;
	padding: 20px;
	border: 1px solid rgba(139, 93, 36, 0.12);
	border-radius: 18px;
	background: #fff;
	overflow: hidden;
}

.najlife-esouk-skeleton span,
.najlife-esouk-skeleton i {
	display: block;
	position: relative;
	overflow: hidden;
	border-radius: 12px;
	background: #f1ede7;
}

.najlife-esouk-skeleton span::after,
.najlife-esouk-skeleton i::after {
	content: '';
	position: absolute;
	inset: 0;
	background: linear-gradient(90deg, transparent, rgba(255,255,255,.78), transparent);
	transform: translateX(-100%);
	animation: najlifeEsoukShimmer 1800ms ease-in-out infinite;
}

.najlife-esouk-skeleton span { height: 86px; margin-bottom: 18px; }
.najlife-esouk-skeleton i { height: 10px; margin-top: 9px; }
.najlife-esouk-skeleton i:nth-child(2) { width: 72%; }
.najlife-esouk-skeleton i:nth-child(3) { width: 42%; }

.najlife-esouk-product {
	display: block;
	border: 1px solid rgba(139, 93, 36, 0.12);
	border-radius: 18px;
	background: #fff;
	overflow: hidden;
	transition: transform 220ms ease, box-shadow 220ms ease;
}

.najlife-esouk-product:hover {
	transform: translateY(-3px);
	box-shadow: 0 18px 42px rgba(40, 28, 17, 0.10);
}

.najlife-esouk-product__image {
	display: grid;
	place-items: center;
	aspect-ratio: 1 / 0.72;
	background-color: #f0ebe4;
	background-position: center;
	background-size: cover;
}

.najlife-esouk-product__image.is-placeholder img { width: 84px; opacity: 0.28; }

.najlife-esouk-product__body {
	display: flex;
	align-items: flex-start;
	justify-content: space-between;
	gap: 14px;
	padding: 16px 18px 18px;
}

.najlife-esouk-product__body strong {
	font-size: 15px;
	font-weight: 650;
	line-height: 1.3;
}

.najlife-esouk-product__body small {
	color: var(--najlife-gold-dark);
	font-size: 13px;
	font-weight: 750;
	white-space: nowrap;
}

@keyframes najlifeEsoukShimmer {
	100% { transform: translateX(100%); }
}

@media (max-width: 1180px) {
	.najlife-esouk-slide__content {
		max-width: 560px;
	}

	.najlife-esouk-grid,
	.najlife-esouk-skeleton,
	.najlife-esouk-products {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}
}

@media (max-width: 820px) {
	.najlife-esouk { padding-top: 0; }

	.najlife-esouk-hero { padding-bottom: 34px; }

	.najlife-esouk-hero__track {
		aspect-ratio: auto;
		height: 690px;
		min-height: 690px;
		border-radius: 0 0 0 0;
	}

	.najlife-esouk-slide__visual {
		background:
			linear-gradient(90deg, rgba(255, 255, 255, 0.95) 0%, rgba(255, 255, 255, 0.90) 18%, rgba(255, 255, 255, 0.58) 34%, rgba(255, 255, 255, 0.16) 52%, rgba(255, 255, 255, 0) 70%),
			var(--esouk-image) 70% center / cover no-repeat;
		transform: scale(1);
	}

	.najlife-esouk-slide__content {
		align-self: end;
		width: calc(100% - 36px);
		margin: 0 auto 34px;
		padding: 30px 24px;
		border-radius: 10px;
	}

	.najlife-esouk-heading::before,
	.najlife-esouk-heading::after { display: none; }

	.najlife-esouk-shop__bar {
		align-items: flex-start;
		flex-direction: column;
	}

	.najlife-esouk-order {
		width: 100%;
		display: grid;
		grid-template-columns: 1fr 120px;
	}

	.najlife-esouk-order select,
	.najlife-esouk-order a {
		min-width: 0;
		width: 100%;
	}

	.najlife-esouk-empty {
		grid-template-columns: 1fr;
		padding: 28px 22px;
		text-align: center;
	}

	.najlife-esouk-empty__icon {
		border-right: 0;
		margin-bottom: 12px;
	}
}

@media (max-width: 560px) {
	.najlife-esouk-slide h1 { font-size: clamp(44px, 15vw, 60px); }
	.najlife-esouk-slide strong { font-size: clamp(25px, 9vw, 34px); }

	.najlife-esouk-cta {
		width: 100%;
		grid-template-columns: 1fr 52px;
	}

	.najlife-esouk-tabs,
	.najlife-esouk-grid,
	.najlife-esouk-skeleton,
	.najlife-esouk-products {
		grid-template-columns: 1fr;
	}

	.najlife-esouk-card { grid-template-rows: minmax(230px, 1fr) auto; }
}










/* =========================================
   E-SOUK — Sous-pages collections premium
   Menu conservé : Collections, T-shirts, Totes, Sweats, Hoodies, Nouveauté, Bons Plans.
========================================= */
.najlife-esouk-archive {
	--archive-max: 1320px;
	--archive-radius: 18px;
	background: #fff;
	color: var(--najlife-ink);
	padding-top: 0;
}

.najlife-esouk-archive-hero {
	position: relative;
	min-height: clamp(420px, 52vw, 610px);
	display: flex;
	align-items: flex-end;
	padding: 132px clamp(18px, 5vw, 64px) clamp(44px, 6vw, 82px);
	overflow: hidden;
	background:
		linear-gradient(90deg, rgba(255, 255, 255, 0.96) 0%, rgba(255, 255, 255, 0.82) 34%, rgba(255, 255, 255, 0.22) 64%, rgba(255, 255, 255, 0.05) 100%),
		var(--archive-hero) center center / cover no-repeat,
		#f4efe7;
}

.najlife-esouk-archive-hero::after {
	content: '';
	position: absolute;
	left: 0;
	right: 0;
	bottom: 0;
	height: 118px;
	background: linear-gradient(180deg, rgba(255,255,255,0), #fff 86%);
	pointer-events: none;
}

.najlife-esouk-archive-hero__inner {
	position: relative;
	z-index: 2;
	width: min(650px, 100%);
	margin: 0 auto;
	max-width: var(--archive-max);
}

.najlife-esouk-archive-breadcrumb {
	display: flex;
	align-items: center;
	flex-wrap: wrap;
	gap: 9px;
	margin-bottom: 34px;
	color: rgba(23, 18, 14, 0.66);
	font-size: 13px;
	font-weight: 650;
}

.najlife-esouk-archive-breadcrumb a {
	transition: color 180ms ease;
}

.najlife-esouk-archive-breadcrumb a:hover {
	color: var(--najlife-gold-dark);
}

.najlife-esouk-archive-breadcrumb strong {
	color: var(--najlife-ink);
}

.najlife-esouk-archive-hero p {
	margin: 0 0 12px;
	color: var(--najlife-gold-dark);
	font-size: 13px;
	font-weight: 820;
	letter-spacing: 0.18em;
	text-transform: uppercase;
}

.najlife-esouk-archive-hero h1 {
	margin: 0;
	font-family: var(--najlife-serif);
	font-size: clamp(54px, 8vw, 112px);
	font-weight: 400;
	line-height: 0.92;
	letter-spacing: -0.07em;
}

.najlife-esouk-archive-hero__inner > span {
	display: block;
	max-width: 540px;
	margin-top: 20px;
	color: rgba(23, 18, 14, 0.74);
	font-size: clamp(16px, 1.3vw, 19px);
	line-height: 1.72;
}

.najlife-esouk-archive-nav {
	position: relative;
	z-index: 4;
	display: grid;
	grid-template-columns: repeat(7, minmax(0, 1fr));
	gap: 10px;
	width: min(var(--archive-max), calc(100% - 36px));
	margin: -28px auto 0;
	padding: 12px;
	border: 1px solid rgba(139, 93, 36, 0.14);
	border-radius: 999px;
	background: rgba(255, 255, 255, 0.82);
	backdrop-filter: blur(16px);
	-webkit-backdrop-filter: blur(16px);
	box-shadow: 0 24px 70px rgba(40, 28, 17, 0.10);
}

.najlife-esouk-archive-nav__item {
	display: grid;
	align-content: center;
	min-height: 58px;
	padding: 10px 16px;
	border-radius: 999px;
	color: rgba(23, 18, 14, 0.72);
	text-align: center;
	transition: background 200ms ease, color 200ms ease, transform 200ms ease;
}

.najlife-esouk-archive-nav__item:hover,
.najlife-esouk-archive-nav__item.is-active {
	background: linear-gradient(135deg, #c4934b 0%, #9c6527 100%);
	color: #fff;
	transform: translateY(-1px);
}

.najlife-esouk-archive-nav__item strong {
	font-size: 13px;
	font-weight: 820;
	line-height: 1.1;
}

.najlife-esouk-archive-nav__item small {
	margin-top: 5px;
	font-size: 11px;
	font-weight: 650;
	opacity: 0.78;
}

.najlife-esouk-archive-collections,
.najlife-esouk-archive-shop {
	width: min(var(--archive-max), calc(100% - 36px));
	margin: 0 auto;
}

.najlife-esouk-archive-collections {
	padding-top: clamp(54px, 7vw, 96px);
}

.najlife-esouk-archive-heading {
	max-width: 620px;
	margin-bottom: 28px;
}

.najlife-esouk-archive-heading p,
.najlife-esouk-archive-shop__bar p {
	margin: 0 0 8px;
	color: var(--najlife-gold-dark);
	font-size: 12px;
	font-weight: 820;
	letter-spacing: 0.16em;
	text-transform: uppercase;
}

.najlife-esouk-archive-heading h2,
.najlife-esouk-archive-shop__bar h2 {
	margin: 0;
	font-family: var(--najlife-serif);
	font-size: clamp(34px, 4vw, 54px);
	font-weight: 400;
	line-height: 1;
	letter-spacing: -0.055em;
}

.najlife-esouk-archive-collection-grid {
	display: grid;
	grid-template-columns: repeat(3, minmax(0, 1fr));
	gap: 18px;
}

.najlife-esouk-archive-collection-card {
	position: relative;
	display: grid;
	min-height: 300px;
	border: 1px solid rgba(139, 93, 36, 0.14);
	border-radius: var(--archive-radius);
	background: #f4efe7;
	overflow: hidden;
	box-shadow: 0 18px 48px rgba(40, 28, 17, 0.08);
	transition: transform 220ms ease, box-shadow 220ms ease, border-color 220ms ease;
}

.najlife-esouk-archive-collection-card:hover {
	transform: translateY(-5px);
	border-color: rgba(183, 131, 53, 0.52);
	box-shadow: 0 26px 70px rgba(40, 28, 17, 0.14);
}

.najlife-esouk-archive-collection-card__image {
	position: absolute;
	inset: 0;
	background-position: center;
	background-size: cover;
	filter: saturate(0.94) contrast(1.02);
	transition: transform 760ms cubic-bezier(.19,1,.22,1);
}

.najlife-esouk-archive-collection-card:hover .najlife-esouk-archive-collection-card__image {
	transform: scale(1.045);
}

.najlife-esouk-archive-collection-card__body {
	position: relative;
	z-index: 2;
	display: grid;
	align-content: end;
	min-height: inherit;
	padding: 24px;
	background: linear-gradient(180deg, rgba(23,18,14,0.04) 0%, rgba(23,18,14,0.76) 100%);
	color: #fff;
}

.najlife-esouk-archive-collection-card__body strong {
	font-family: var(--najlife-serif);
	font-size: clamp(28px, 2.6vw, 38px);
	font-weight: 400;
	letter-spacing: -0.05em;
	line-height: 1;
}

.najlife-esouk-archive-collection-card__body small {
	max-width: 360px;
	margin-top: 12px;
	color: rgba(255, 255, 255, 0.82);
	font-size: 14px;
	line-height: 1.55;
}

.najlife-esouk-archive-collection-card__body em {
	display: grid;
	place-items: center;
	width: 42px;
	height: 42px;
	margin-top: 20px;
	border-radius: 999px;
	background: #fff;
	color: var(--najlife-gold-dark);
	font-style: normal;
	font-size: 22px;
	transition: transform 220ms ease;
}

.najlife-esouk-archive-collection-card:hover .najlife-esouk-archive-collection-card__body em {
	transform: translateX(4px);
}

.najlife-esouk-archive-shop {
	padding-top: clamp(48px, 6vw, 86px);
	padding-bottom: clamp(64px, 8vw, 110px);
}

.najlife-esouk-archive-shop__bar {
	display: flex;
	align-items: end;
	justify-content: space-between;
	gap: 24px;
	margin-bottom: 24px;
}

.najlife-esouk-archive-order select {
	min-width: 190px;
	min-height: 46px;
	padding: 0 18px;
	border: 1px solid rgba(139, 93, 36, 0.18);
	border-radius: 999px;
	background: #fff;
	color: #2a211b;
	font-size: 14px;
	font-weight: 680;
	outline: none;
}

.najlife-esouk-archive-products {
	display: grid;
	grid-template-columns: repeat(4, minmax(0, 1fr));
	gap: 18px;
}

.najlife-esouk-archive-product {
	display: block;
	border: 1px solid rgba(139, 93, 36, 0.12);
	border-radius: 18px;
	background: #fff;
	overflow: hidden;
	box-shadow: 0 12px 38px rgba(40, 28, 17, 0.06);
	transition: transform 220ms ease, box-shadow 220ms ease, border-color 220ms ease;
}

.najlife-esouk-archive-product:hover {
	transform: translateY(-4px);
	border-color: rgba(183, 131, 53, 0.44);
	box-shadow: 0 22px 56px rgba(40, 28, 17, 0.13);
}

.najlife-esouk-archive-product__image {
	position: relative;
	display: grid;
	place-items: center;
	aspect-ratio: 1 / 0.78;
	background-color: #f0ebe4;
	background-position: center;
	background-size: cover;
}

.najlife-esouk-archive-product__image em {
	position: absolute;
	left: 14px;
	top: 14px;
	padding: 7px 11px;
	border-radius: 999px;
	background: #17120e;
	color: #fff;
	font-size: 11px;
	font-style: normal;
	font-weight: 820;
	letter-spacing: 0.08em;
	text-transform: uppercase;
}

.najlife-esouk-archive-product__image.is-placeholder img {
	width: 92px;
	opacity: 0.26;
}

.najlife-esouk-archive-product__body {
	display: flex;
	align-items: flex-start;
	justify-content: space-between;
	gap: 16px;
	padding: 18px 18px 20px;
}

.najlife-esouk-archive-product__body strong {
	display: block;
	font-size: 15px;
	font-weight: 720;
	line-height: 1.32;
}

.najlife-esouk-archive-product__body small {
	display: block;
	margin-top: 7px;
	color: var(--najlife-muted);
	font-size: 13px;
	line-height: 1.45;
}

.najlife-esouk-archive-product__body b {
	color: var(--najlife-gold-dark);
	font-size: 14px;
	font-weight: 820;
	line-height: 1.2;
	white-space: nowrap;
}

.najlife-esouk-archive-product__body b del {
	display: block;
	color: rgba(23, 18, 14, 0.42);
	font-size: 12px;
	font-weight: 600;
}

.najlife-esouk-archive-product__body b ins {
	background: transparent;
	text-decoration: none;
}

.najlife-esouk-archive-empty {
	display: grid;
	justify-items: start;
	padding: clamp(30px, 5vw, 54px);
	border: 1px solid rgba(139, 93, 36, 0.16);
	border-radius: var(--archive-radius);
	background:
		radial-gradient(circle at 8% 0%, rgba(183, 131, 53, 0.12), transparent 34%),
		linear-gradient(180deg, #fff 0%, #fffaf4 100%);
}

.najlife-esouk-archive-empty strong {
	font-family: var(--najlife-serif);
	font-size: clamp(28px, 3.8vw, 48px);
	font-weight: 400;
	line-height: 1;
	letter-spacing: -0.055em;
}

.najlife-esouk-archive-empty p {
	max-width: 620px;
	margin: 12px 0 24px;
	color: var(--najlife-muted);
}

.najlife-esouk-archive-empty a {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-height: 48px;
	padding: 0 20px;
	border-radius: 999px;
	background: linear-gradient(135deg, #c4934b 0%, #9c6527 100%);
	color: #fff;
	font-size: 14px;
	font-weight: 760;
}

@media (max-width: 1180px) {
	.najlife-esouk-archive-nav {
		grid-template-columns: repeat(4, minmax(0, 1fr));
		border-radius: 26px;
	}

	.najlife-esouk-archive-collection-grid,
	.najlife-esouk-archive-products {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}
}

@media (max-width: 760px) {
	.najlife-esouk-archive-hero {
		min-height: 520px;
		padding-top: 116px;
		background:
			linear-gradient(180deg, rgba(255,255,255,0.94) 0%, rgba(255,255,255,0.76) 44%, rgba(255,255,255,0.32) 100%),
			var(--archive-hero) center center / cover no-repeat,
			#f4efe7;
	}

	.najlife-esouk-archive-breadcrumb {
		margin-bottom: 24px;
	}

	.najlife-esouk-archive-nav {
		grid-template-columns: repeat(2, minmax(0, 1fr));
		width: calc(100% - 28px);
		margin-top: -18px;
		border-radius: 22px;
	}

	.najlife-esouk-archive-nav__item {
		border-radius: 16px;
	}

	.najlife-esouk-archive-collections,
	.najlife-esouk-archive-shop {
		width: calc(100% - 28px);
	}

	.najlife-esouk-archive-shop__bar {
		align-items: stretch;
		flex-direction: column;
	}

	.najlife-esouk-archive-order select {
		width: 100%;
	}

	.najlife-esouk-archive-collection-grid,
	.najlife-esouk-archive-products {
		grid-template-columns: 1fr;
	}

	.najlife-esouk-archive-product__body {
		flex-direction: column;
	}
}


/* =========================================
   EL-KISSA — Timeline premium validée
========================================= */
body.page-template-page-el-kissa .najlife-header {
	background: rgba(249, 241, 228, 0.82);
	border-bottom: 1px solid rgba(68, 47, 24, 0.12);
	box-shadow: 0 10px 30px rgba(64, 42, 20, 0.08);
	backdrop-filter: blur(16px);
	-webkit-backdrop-filter: blur(16px);
}

.najlife-kissa-timeline {
	--kissa-ink: #17120d;
	--kissa-soft: rgba(23, 18, 13, 0.72);
	--kissa-gold: #b47e35;
	--kissa-border: rgba(88, 62, 33, 0.15);
	--kissa-width: 1320px;
	background: radial-gradient(circle at 50% 0%, rgba(180, 126, 53, 0.13), transparent 32%), linear-gradient(180deg, #f8ecda 0%, #f2e5cf 42%, #efe0c7 100%);
	color: var(--kissa-ink);
	overflow-x: clip;
}

.kissa-timeline-hero {
	position: relative;
	min-height: 460px;
	padding: 108px clamp(18px, 4vw, 56px) 56px;
	display: flex;
	align-items: center;
	overflow: hidden;
	background: #120e0b;
}

.kissa-timeline-hero__image {
	position: absolute;
	inset: 0;
	width: 100%;
	height: 100%;
	object-fit: cover;
	object-position: center center;
	transform-origin: center;
	will-change: transform;
}

.kissa-timeline-hero__veil {
	position: absolute;
	inset: 0;
	background: linear-gradient(180deg, rgba(255, 244, 225, 0.72) 0%, rgba(255, 244, 225, 0.32) 48%, rgba(255, 244, 225, 0.88) 100%), linear-gradient(90deg, rgba(249, 236, 214, 0.28), rgba(249, 236, 214, 0.08));
}

.kissa-timeline-hero__inner {
	position: relative;
	z-index: 2;
	width: min(var(--kissa-width), 100%);
	margin: 0 auto;
	display: grid;
	grid-template-columns: minmax(170px, 0.22fr) minmax(0, 1fr) minmax(170px, 0.22fr);
	align-items: center;
	gap: 24px;
	text-align: center;
}

.kissa-timeline-hero__logo {
	justify-self: start;
	width: clamp(100px, 10vw, 160px);
	height: auto;
	filter: drop-shadow(0 12px 24px rgba(55, 35, 16, 0.14));
}

.kissa-timeline-hero__copy {
	justify-self: center;
}

.kissa-timeline-hero__diamond {
	display: block;
	width: 18px;
	height: 18px;
	margin: 0 auto 24px;
	border: 2px solid var(--kissa-gold);
	transform: rotate(45deg);
	background: rgba(255, 246, 231, 0.4);
}

.kissa-timeline-hero h1 {
	margin: 0;
	font-family: 'Cormorant Garamond', Georgia, serif;
	font-size: clamp(64px, 7vw, 112px);
	line-height: 0.9;
	font-weight: 700;
	letter-spacing: -0.035em;
	color: #17120d;
	text-shadow: 0 1px 0 rgba(255,255,255,.28), 0 14px 34px rgba(74, 45, 20, 0.16);
}

.kissa-timeline-hero p {
	margin: 10px 0 0;
	font-family: 'Cormorant Garamond', Georgia, serif;
	font-size: clamp(28px, 3vw, 46px);
	line-height: 1.05;
}

.kissa-timeline-hero i {
	display: block;
	width: 64px;
	height: 2px;
	margin: 18px auto 16px;
	background: var(--kissa-gold);
}

.kissa-timeline-hero small {
	display: block;
	font-size: clamp(14px, 1.3vw, 18px);
	font-weight: 600;
}

.kissa-timeline-story {
	position: relative;
	width: min(var(--kissa-width), calc(100% - clamp(18px, 5vw, 92px)));
	margin: 0 auto;
	padding: 28px 0 40px;
}

.kissa-timeline-track {
	position: absolute;
	top: 28px;
	bottom: 40px;
	left: 50%;
	width: 2px;
	background: linear-gradient(180deg, transparent, var(--kissa-gold) 7%, var(--kissa-gold) 93%, transparent);
	transform: translateX(-50%);
}

.kissa-timeline-item {
	position: relative;
	display: grid;
	grid-template-columns: minmax(0, 1fr) 64px minmax(0, 1fr);
	align-items: stretch;
	min-height: 220px;
}

.kissa-timeline-media,
.kissa-timeline-text {
	position: relative;
	margin: 0;
	min-height: 220px;
	border: 1px solid var(--kissa-border);
	background: rgba(255, 248, 236, 0.58);
	box-shadow: 0 8px 22px rgba(71, 46, 22, 0.06);
	overflow: hidden;
}

.kissa-timeline-media img {
	width: 100%;
	height: 100%;
	display: block;
	object-fit: cover;
	object-position: center center;
	filter: saturate(.92) contrast(1.03) brightness(.96);
	transition: transform 900ms ease;
}

.kissa-timeline-item.is-visible .kissa-timeline-media img {
	transform: scale(1.035);
}

.kissa-timeline-text {
	display: flex;
	flex-direction: column;
	justify-content: center;
	padding: clamp(28px, 4vw, 52px) clamp(28px, 4vw, 64px);
}

.kissa-timeline-text h2 {
	margin: 0 0 18px;
	font-family: 'Cormorant Garamond', Georgia, serif;
	font-size: clamp(30px, 2.8vw, 46px);
	line-height: 1.05;
	font-weight: 500;
	color: var(--kissa-ink);
}

.kissa-timeline-text p {
	margin: 0;
	max-width: 520px;
	font-size: clamp(15px, 1.15vw, 18px);
	line-height: 1.7;
	color: var(--kissa-soft);
	font-weight: 500;
}

.kissa-timeline-node {
	position: relative;
	z-index: 3;
	align-self: center;
	justify-self: center;
	width: 42px;
	height: 42px;
	border: 2px solid var(--kissa-gold);
	border-radius: 50%;
	background: #fbf2e2;
	box-shadow: 0 0 0 8px #f2e5cf;
}

.kissa-timeline-node::before {
	content: '';
	position: absolute;
	left: 50%;
	top: 50%;
	width: 14px;
	height: 14px;
	border: 2px solid var(--kissa-gold);
	transform: translate(-50%, -50%) rotate(45deg);
	background: #fbf2e2;
}

/* El-Kissa CTA — font arabe + arrière-plan */
.kissa-timeline-cta {
	position: relative;
	min-height: clamp(360px, 54vh, 620px);
	display: flex;
	align-items: center;
	padding: clamp(54px, 7vw, 110px) clamp(24px, 6vw, 96px);
	overflow: hidden;
	background:
		linear-gradient(90deg, rgba(8, 6, 4, 0.86), rgba(8, 6, 4, 0.52) 48%, rgba(8, 6, 4, 0.82)),
		linear-gradient(180deg, rgba(8, 6, 4, 0.18), rgba(8, 6, 4, 0.78)),
		var(--kissa-cta-bg);
	background-size: cover;
	background-position: center center;
	background-repeat: no-repeat;
	color: #f3dfbd;
}

.kissa-timeline-cta::before {
	content: '';
	position: absolute;
	inset: 0;
	z-index: 0;
	background:
		radial-gradient(circle at 24% 46%, rgba(180, 126, 53, 0.22), transparent 34%),
		repeating-linear-gradient(105deg, rgba(255, 255, 255, 0.035) 0 1px, transparent 1px 18px);
	pointer-events: none;
}

.kissa-timeline-continue {
	position: relative;
	z-index: 1;
	width: min(1320px, 100%);
	margin: 0 auto;
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: clamp(28px, 6vw, 110px);
	text-align: left;
}

.kissa-timeline-continue h2 {
	margin: 0;
	font-family: "Ink Free", Georgia, serif;
	font-size: clamp(46px, 5.8vw, 96px);
	line-height: 0.95;
	font-weight: 600;
	color: #f4dfba;
	text-shadow: 0 14px 34px rgba(0, 0, 0, 0.48);
}

.kissa-timeline-continue a {
	flex: 0 0 auto;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-width: 240px;
	min-height: 58px;
	padding: 0 34px;
	border: 1px solid #d8ad68;
	background: rgba(12, 8, 5, 0.48);
	color: #f5e3c0;
	backdrop-filter: blur(10px);
	-webkit-backdrop-filter: blur(10px);
	font-size: 13px;
	font-weight: 800;
	letter-spacing: 0.08em;
	text-transform: uppercase;
	transition: background-color 220ms ease, color 220ms ease, transform 220ms ease;
}

.kissa-timeline-continue a:hover {
	background: #d8ad68;
	color: #120d08;
	transform: translateY(-2px);
}

@media (max-width: 760px) {
	.kissa-timeline-cta {
		min-height: 520px;
		padding: 48px 20px;
		background-position: 58% center;
	}

	.kissa-timeline-continue {
		flex-direction: column;
		align-items: flex-start;
		gap: 28px;
	}

	.kissa-timeline-continue__eyebrow {
		font-size: clamp(34px, 13vw, 62px);
	}

	.kissa-timeline-continue h2 {
		font-size: clamp(42px, 13vw, 68px);
	}

	.kissa-timeline-continue a {
		width: 100%;
	}
}

[data-kissa-reveal].is-pending {
	opacity: 0;
	transform: translate3d(0, 34px, 0);
	transition: opacity 720ms ease, transform 720ms ease;
}

[data-kissa-reveal].is-pending.is-visible,
[data-kissa-reveal].is-visible {
	opacity: 1;
	transform: translate3d(0, 0, 0);
}

.kissa-timeline-item:nth-child(odd)[data-kissa-reveal].is-pending {
	transform: translate3d(-28px, 30px, 0);
}

.kissa-timeline-item:nth-child(even)[data-kissa-reveal].is-pending {
	transform: translate3d(28px, 30px, 0);
}

.kissa-timeline-item.is-visible {
	transform: translate3d(0, 0, 0) !important;
}

@media (prefers-reduced-motion: reduce) {
	[data-kissa-reveal].is-pending,
	.kissa-timeline-item:nth-child(odd)[data-kissa-reveal].is-pending,
	.kissa-timeline-item:nth-child(even)[data-kissa-reveal].is-pending {
		opacity: 1;
		transform: none;
		transition: none;
	}

	.kissa-timeline-hero__image,
	[data-kissa-parallax] {
		transform: none !important;
	}
}

@media (max-width: 980px) {
	.kissa-timeline-hero__inner {
		grid-template-columns: 1fr;
	}

	.kissa-timeline-hero__logo {
		justify-self: center;
	}

	.kissa-timeline-story {
		width: calc(100% - 24px);
	}

	.kissa-timeline-track {
		left: 26px;
	}

	.kissa-timeline-item {
		grid-template-columns: 52px 1fr;
		min-height: auto;
	}

	.kissa-timeline-item > .kissa-timeline-media,
	.kissa-timeline-item > .kissa-timeline-text {
		grid-column: 2 / 3;
	}

	.kissa-timeline-item > .kissa-timeline-node {
		grid-column: 1 / 2;
		grid-row: 1 / span 2;
		align-self: start;
		margin-top: 28px;
	}

	.kissa-timeline-media,
	.kissa-timeline-text {
		min-height: 240px;
	}

	.kissa-timeline-item:nth-child(even) .kissa-timeline-text {
		grid-row: 2;
	}

	.kissa-timeline-cta {
		grid-template-columns: 1fr;
	}
}

@media (max-width: 640px) {
	.kissa-timeline-hero {
		min-height: 420px;
		padding: 110px 14px 42px;
	}

	.kissa-timeline-hero__logo {
		width: 120px;
	}

	.kissa-timeline-hero h1 {
		font-size: clamp(54px, 16vw, 78px);
	}

	.kissa-timeline-hero p {
		font-size: clamp(24px, 8vw, 34px);
	}

	.kissa-timeline-media,
	.kissa-timeline-text {
		min-height: 210px;
	}

	.kissa-timeline-text {
		padding: 28px 22px;
	}

	.kissa-timeline-node {
		width: 34px;
		height: 34px;
	}

	.kissa-timeline-node::before {
		width: 11px;
		height: 11px;
	}

	.kissa-timeline-cta {
		padding: 34px 18px;
	}
}


/* Timeline scroll progress — line advances with scroll */
.kissa-timeline-track {
	overflow: hidden;
	background: linear-gradient(180deg, transparent, rgba(180, 126, 53, 0.22) 7%, rgba(180, 126, 53, 0.22) 93%, transparent);
}

.kissa-timeline-track::before {
	content: '';
	position: absolute;
	left: 0;
	top: 0;
	width: 100%;
	height: calc(var(--kissa-timeline-progress, 0) * 100%);
	background: linear-gradient(180deg, transparent 0%, var(--kissa-gold) 8%, var(--kissa-gold) 94%, transparent 100%);
	transform-origin: top center;
	transition: height 120ms linear;
}

.kissa-timeline-node {
	transition: background-color 240ms ease, border-color 240ms ease, box-shadow 240ms ease, transform 240ms ease;
}

.kissa-timeline-node::before {
	transition: background-color 240ms ease, border-color 240ms ease;
}

.kissa-timeline-item.is-timeline-active .kissa-timeline-node {
	background: var(--kissa-gold);
	border-color: var(--kissa-gold);
	box-shadow: 0 0 0 8px #f2e5cf, 0 0 0 13px rgba(180, 126, 53, 0.16);
	transform: scale(1.08);
}

.kissa-timeline-item.is-timeline-active .kissa-timeline-node::before {
	background: #fff6e6;
	border-color: #fff6e6;
}

.kissa-timeline-item.is-timeline-active .kissa-timeline-text {
	border-color: rgba(180, 126, 53, 0.32);
}

@media (prefers-reduced-motion: reduce) {
	.kissa-timeline-track::before {
		height: 100%;
		transition: none;
	}

	.kissa-timeline-node,
	.kissa-timeline-node::before {
		transition: none;
	}
}


/* Timeline step mode — only the concerned section is displayed per scroll step */
.kissa-timeline-story {
	padding: 0;
}

.kissa-timeline-track {
	top: 0;
	bottom: 0;
}

.kissa-timeline-item {
	min-height: 100svh;
	padding: clamp(72px, 8vw, 116px) 0;
	align-items: center;
}

.kissa-timeline-media,
.kissa-timeline-text {
	min-height: clamp(360px, 58vh, 620px);
}

.kissa-timeline-item + .kissa-timeline-item {
	border-top: 1px solid rgba(180, 126, 53, 0.08);
}

/* While the user is inside one chapter, visually keep the next/previous chapters quiet */
.kissa-timeline-item:not(.is-timeline-current) .kissa-timeline-media,
.kissa-timeline-item:not(.is-timeline-current) .kissa-timeline-text {
	opacity: 0.16;
	filter: blur(1px);
	transform: scale(0.985);
	transition: opacity 360ms ease, filter 360ms ease, transform 360ms ease;
}

.kissa-timeline-item.is-timeline-current .kissa-timeline-media,
.kissa-timeline-item.is-timeline-current .kissa-timeline-text {
	opacity: 1;
	filter: blur(0);
	transform: scale(1);
	transition: opacity 360ms ease, filter 360ms ease, transform 360ms ease;
}

.kissa-timeline-item.is-timeline-current {
	z-index: 4;
}

/* Desktop: make each chapter read as one clean screen */
@media (min-width: 981px) {
	.kissa-timeline-story {
		width: min(var(--kissa-width), calc(100% - clamp(18px, 5vw, 92px)));
	}

	.kissa-timeline-item {
		scroll-snap-align: start;
	}

	.najlife-kissa-timeline {
		scroll-behavior: smooth;
	}

	.kissa-timeline-story {
		scroll-snap-type: y proximity;
	}
}

@media (max-width: 980px) {
	.kissa-timeline-item {
		min-height: 100svh;
		padding: 56px 0;
		align-content: center;
	}

	.kissa-timeline-media,
	.kissa-timeline-text {
		min-height: 280px;
	}

	.kissa-timeline-item:not(.is-timeline-current) .kissa-timeline-media,
	.kissa-timeline-item:not(.is-timeline-current) .kissa-timeline-text {
		opacity: 0.22;
		filter: none;
		transform: none;
	}
}

@media (max-width: 640px) {
	.kissa-timeline-item {
		padding: 42px 0;
	}
}


/* Timeline fixed-scene mode — page stays fixed, chapters advance with scroll */
.kissa-timeline-story {
	--kissa-fixed-steps: 7;
	position: relative;
	height: calc(var(--kissa-fixed-steps) * 100svh);
	width: 100%;
	max-width: none;
	margin: 0;
	padding: 0;
}

.kissa-timeline-story::before {
	content: '';
	position: absolute;
	inset: 0;
	background:
		radial-gradient(circle at 50% 16%, rgba(180, 126, 53, 0.12), transparent 32%),
		linear-gradient(180deg, #f8ecda 0%, #efe0c7 100%);
	pointer-events: none;
}

.kissa-timeline-story.is-fixed-active .kissa-timeline-track {
	position: fixed;
}

.kissa-timeline-fixed-stage {
	position: sticky;
	top: 0;
	z-index: 5;
	height: 100svh;
	width: min(var(--kissa-width), calc(100% - clamp(18px, 5vw, 92px)));
	margin: 0 auto;
	display: grid;
	grid-template-columns: minmax(0, 1fr) 64px minmax(0, 1fr);
	align-items: center;
	pointer-events: none;
}

.kissa-timeline-track {
	position: absolute;
	z-index: 6;
	top: clamp(72px, 10vh, 110px);
	bottom: clamp(72px, 10vh, 110px);
	left: 50%;
	width: 2px;
	transform: translateX(-50%);
}

.kissa-timeline-item {
	position: absolute;
	inset: clamp(86px, 11vh, 124px) 0 clamp(74px, 9vh, 104px);
	display: grid;
	grid-template-columns: minmax(0, 1fr) 64px minmax(0, 1fr);
	align-items: stretch;
	min-height: auto;
	padding: 0;
	opacity: 0;
	visibility: hidden;
	pointer-events: none;
	transform: translate3d(0, 22px, 0) scale(0.985);
	transition:
		opacity 420ms ease,
		visibility 420ms ease,
		transform 420ms ease;
}

.kissa-timeline-item.is-timeline-current {
	opacity: 1;
	visibility: visible;
	pointer-events: auto;
	transform: translate3d(0, 0, 0) scale(1);
}

.kissa-timeline-item.is-timeline-current .kissa-timeline-media,
.kissa-timeline-item.is-timeline-current .kissa-timeline-text {
	opacity: 1;
	filter: none;
	transform: none;
}

.kissa-timeline-item:not(.is-timeline-current) .kissa-timeline-media,
.kissa-timeline-item:not(.is-timeline-current) .kissa-timeline-text {
	opacity: 1;
	filter: none;
	transform: none;
}

.kissa-timeline-media,
.kissa-timeline-text {
	min-height: auto;
	height: 100%;
}

.kissa-timeline-node {
	align-self: center;
}

.kissa-timeline-cta {
	margin-top: 0;
}

@media (min-width: 981px) {
	.kissa-timeline-story {
		scroll-snap-type: none;
	}

	.kissa-timeline-item {
		scroll-snap-align: none;
	}
}

@media (max-width: 980px) {
	.kissa-timeline-fixed-stage {
		width: calc(100% - 24px);
		grid-template-columns: 52px minmax(0, 1fr);
	}

	.kissa-timeline-track {
		left: 26px;
		top: 56px;
		bottom: 56px;
	}

	.kissa-timeline-item {
		inset: 54px 0 54px;
		grid-template-columns: 52px minmax(0, 1fr);
	}

	.kissa-timeline-item > .kissa-timeline-media,
	.kissa-timeline-item > .kissa-timeline-text {
		grid-column: 2 / 3;
	}

	.kissa-timeline-item > .kissa-timeline-node {
		grid-column: 1 / 2;
		grid-row: 1 / span 2;
		align-self: center;
		margin-top: 0;
	}
}

@media (max-width: 640px) {
	.kissa-timeline-story {
		height: calc(var(--kissa-fixed-steps) * 115svh);
	}

	.kissa-timeline-fixed-stage {
		width: calc(100% - 16px);
	}

	.kissa-timeline-item {
		inset: 44px 0 44px;
		align-content: center;
	}

	.kissa-timeline-media,
	.kissa-timeline-text {
		min-height: 0;
		height: auto;
	}

	.kissa-timeline-media {
		height: 32svh;
	}

	.kissa-timeline-text {
		min-height: 32svh;
	}
}

@media (prefers-reduced-motion: reduce) {
	.kissa-timeline-item {
		transition: none;
		transform: none;
	}
}


/* =========================
   Contact — NAJlife editorial page
   ========================= */
.najlife-contact {
	background: var(--najlife-white);
	color: var(--najlife-ink);
}

.najlife-contact-hero {
	position: relative;
	padding: clamp(132px, 13vw, 178px) clamp(22px, 5vw, 76px) clamp(54px, 7vw, 96px);
	overflow: hidden;
	background:
		linear-gradient(180deg, rgba(251, 248, 242, 0.94) 0%, rgba(255, 255, 255, 1) 96%),
		var(--najlife-ivory);
}

.najlife-contact-hero::before {
	content: '';
	position: absolute;
	top: clamp(124px, 14vw, 186px);
	right: clamp(18px, 7vw, 120px);
	width: clamp(110px, 15vw, 220px);
	height: clamp(110px, 15vw, 220px);
	border: 1px solid rgba(183, 131, 53, 0.16);
	transform: rotate(45deg);
	pointer-events: none;
}

.najlife-contact-hero::after {
	content: '';
	position: absolute;
	left: 0;
	right: 0;
	bottom: 0;
	height: 110px;
	background: linear-gradient(180deg, rgba(255, 255, 255, 0), #fff 92%);
	pointer-events: none;
}

.najlife-contact-hero__inner {
	position: relative;
	z-index: 1;
	max-width: 1320px;
	margin: 0 auto;
	display: grid;
	grid-template-columns: minmax(0, 0.86fr) minmax(320px, 0.72fr);
	gap: clamp(36px, 6vw, 92px);
	align-items: end;
}

.najlife-contact-hero__copy h1 {
	max-width: 760px;
	margin: 0;
	font-family: var(--najlife-serif);
	font-size: clamp(52px, 7vw, 106px);
	font-weight: 400;
	line-height: 0.95;
	letter-spacing: -0.065em;
	color: var(--najlife-ink);
}

.najlife-contact-line {
	width: 86px;
	height: 1px;
	margin: 28px 0 0;
	background: var(--najlife-gold);
}

.najlife-contact-hero__copy p:not(.najlife-eyebrow) {
	max-width: 560px;
	margin: 28px 0 0;
	color: #2b221b;
	font-size: clamp(16px, 1.35vw, 20px);
	font-weight: 500;
	line-height: 1.74;
}

.najlife-contact-hero__links {
	display: flex;
	flex-wrap: wrap;
	gap: 14px;
	margin-top: 34px;
}

.najlife-contact-hero__links a {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-height: 48px;
	padding: 0 22px;
	border: 1px solid rgba(183, 131, 53, 0.28);
	background: rgba(255, 255, 255, 0.58);
	color: var(--najlife-ink);
	font-size: 13px;
	font-weight: 780;
	letter-spacing: 0.06em;
	text-transform: uppercase;
	transition: border-color 180ms ease, background 180ms ease, color 180ms ease, transform 180ms ease;
}

.najlife-contact-hero__links a:first-child {
	background: var(--najlife-ink);
	border-color: var(--najlife-ink);
	color: #fff;
}

.najlife-contact-hero__links a:hover {
	border-color: var(--najlife-gold);
	background: var(--najlife-gold);
	color: #fff;
	transform: translateY(-1px);
}

.najlife-contact-hero__figure {
	position: relative;
	margin: 0;
	padding: clamp(10px, 1.4vw, 18px);
	background: rgba(255, 255, 255, 0.58);
	border: 1px solid rgba(183, 131, 53, 0.18);
	box-shadow: 0 22px 72px rgba(39, 28, 18, 0.1);
}

.najlife-contact-hero__figure img {
	width: 100%;
	aspect-ratio: 4 / 5;
	object-fit: cover;
	object-position: center;
	filter: saturate(0.94) contrast(1.02);
}

.najlife-contact-hero__figure figcaption {
	position: absolute;
	left: clamp(22px, 2vw, 34px);
	right: clamp(22px, 2vw, 34px);
	bottom: clamp(22px, 2vw, 34px);
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 18px;
	padding: 16px 18px;
	background: rgba(255, 255, 255, 0.8);
	border: 1px solid rgba(183, 131, 53, 0.2);
	backdrop-filter: blur(12px);
	-webkit-backdrop-filter: blur(12px);
}

.najlife-contact-hero__figure strong {
	color: var(--najlife-gold-dark);
	font-size: 12px;
	font-weight: 800;
	letter-spacing: 0.12em;
	text-transform: uppercase;
}

.najlife-contact-hero__figure em {
	color: var(--najlife-ink);
	font-size: 14px;
	font-style: normal;
	font-weight: 650;
	text-align: right;
}

.najlife-contact-intentions {
	background: var(--najlife-white);
}

.najlife-contact-intentions__grid {
	max-width: 1180px;
	margin: 0 auto;
	display: grid;
	grid-template-columns: repeat(3, minmax(0, 1fr));
	gap: 0;
	border-top: 1px solid var(--najlife-line);
	border-bottom: 1px solid var(--najlife-line);
}

.najlife-contact-intentions__grid article {
	position: relative;
	min-height: 260px;
	padding: clamp(30px, 4vw, 54px) clamp(24px, 4vw, 46px);
	display: flex;
	flex-direction: column;
	justify-content: space-between;
	background: #fff;
}

.najlife-contact-intentions__grid article + article {
	border-left: 1px solid var(--najlife-line);
}

.najlife-contact-intentions__grid article::before {
	content: '';
	position: absolute;
	top: clamp(24px, 3vw, 36px);
	right: clamp(24px, 3vw, 36px);
	width: 34px;
	height: 34px;
	border: 1px solid rgba(183, 131, 53, 0.34);
	transform: rotate(45deg);
}

.najlife-contact-intentions__grid p {
	margin: 0;
	color: var(--najlife-gold-dark);
	font-size: 12px;
	font-weight: 800;
	letter-spacing: 0.12em;
	text-transform: uppercase;
}

.najlife-contact-intentions__grid h3 {
	max-width: 300px;
	margin: 34px 0 24px;
	font-family: var(--najlife-serif);
	font-size: clamp(25px, 2.6vw, 36px);
	font-weight: 400;
	line-height: 1.08;
	letter-spacing: -0.045em;
}

.najlife-contact-intentions__grid a {
	align-self: flex-start;
	color: var(--najlife-ink);
	font-size: 13px;
	font-weight: 800;
	letter-spacing: 0.08em;
	text-transform: uppercase;
}

.najlife-contact-intentions__grid a::after {
	content: '→';
	margin-left: 10px;
	color: var(--najlife-gold-dark);
}

.najlife-contact-form-section {
	background:
		linear-gradient(180deg, var(--najlife-ivory) 0%, #fff 100%);
}

.najlife-contact-form-layout {
	max-width: 1220px;
	margin: 0 auto;
	display: grid;
	grid-template-columns: minmax(260px, 0.62fr) minmax(340px, 1fr);
	gap: clamp(34px, 6vw, 88px);
	align-items: start;
}

.najlife-contact-form-heading {
	position: sticky;
	top: 118px;
}

.najlife-contact-form-heading h2 {
	max-width: 520px;
	margin: 0;
	font-family: var(--najlife-serif);
	font-size: clamp(36px, 4.6vw, 66px);
	font-weight: 400;
	line-height: 1.04;
	letter-spacing: -0.05em;
}

.najlife-contact-form-heading p:not(.najlife-eyebrow) {
	max-width: 460px;
	margin: 24px 0 0;
	color: var(--najlife-muted);
	font-size: 16px;
	line-height: 1.76;
}

.najlife-contact-form-card {
	position: relative;
	padding: clamp(24px, 4vw, 48px);
	background: rgba(255, 255, 255, 0.86);
	border: 1px solid rgba(183, 131, 53, 0.18);
	box-shadow: 0 22px 72px rgba(39, 28, 18, 0.08);
}

.najlife-contact-form-card::before {
	content: '';
	position: absolute;
	top: -1px;
	left: clamp(24px, 4vw, 56px);
	width: 96px;
	height: 1px;
	background: var(--najlife-gold);
}

.najlife-contact-native-form {
	display: grid;
	grid-template-columns: repeat(2, minmax(0, 1fr));
	gap: 22px;
}

.najlife-contact-field {
	display: flex;
	flex-direction: column;
	gap: 8px;
}

.najlife-contact-field--wide {
	grid-column: 1 / -1;
}

.najlife-contact-native-form label {
	color: var(--najlife-ink);
	font-size: 12px;
	font-weight: 800;
	letter-spacing: 0.1em;
	text-transform: uppercase;
}

.najlife-contact-native-form input,
.najlife-contact-native-form textarea,
.najlife-contact-native-form select {
	width: 100%;
	min-height: 54px;
	padding: 13px 16px;
	border: 1px solid rgba(105, 82, 54, 0.2);
	border-radius: 0;
	background: rgba(251, 248, 242, 0.64);
	color: var(--najlife-ink);
	outline: none;
	transition: border-color 180ms ease, background 180ms ease, box-shadow 180ms ease;
}

.najlife-contact-native-form textarea {
	min-height: 170px;
	resize: vertical;
}

.najlife-contact-native-form input:focus,
.najlife-contact-native-form textarea:focus,
.najlife-contact-native-form select:focus {
	border-color: rgba(183, 131, 53, 0.58);
	background: #fff;
	box-shadow: 0 0 0 4px rgba(183, 131, 53, 0.08);
}

.najlife-contact-native-form button {
	grid-column: 1 / -1;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-height: 54px;
	padding: 0 30px;
	border: 1px solid var(--najlife-ink);
	border-radius: 0;
	background: var(--najlife-ink);
	color: #fff;
	font-size: 13px;
	font-weight: 820;
	letter-spacing: 0.08em;
	text-transform: uppercase;
	cursor: pointer;
	transition: background 180ms ease, border-color 180ms ease, transform 180ms ease;
}

.najlife-contact-native-form button:hover {
	background: var(--najlife-gold-dark);
	border-color: var(--najlife-gold-dark);
	transform: translateY(-1px);
}

.najlife-contact-hp {
	position: absolute;
	left: -9999px;
	width: 1px;
	height: 1px;
	overflow: hidden;
}

.najlife-contact-alert {
	margin-bottom: 24px;
	padding: 18px 20px;
	border: 1px solid rgba(183, 131, 53, 0.24);
	background: rgba(251, 248, 242, 0.84);
}

.najlife-contact-alert strong {
	display: block;
	margin-bottom: 6px;
	font-family: var(--najlife-serif);
	font-size: 24px;
	font-weight: 400;
	letter-spacing: -0.03em;
}

.najlife-contact-alert p {
	margin: 0;
	color: var(--najlife-muted);
}

.najlife-contact-alert--success {
	border-color: rgba(78, 119, 78, 0.24);
	background: rgba(244, 248, 242, 0.94);
}

.najlife-contact-alert--error {
	border-color: rgba(147, 62, 45, 0.24);
	background: rgba(252, 244, 241, 0.94);
}

.najlife-contact-note {
	padding: 0 clamp(22px, 5vw, 76px) clamp(64px, 7vw, 104px);
	background: #fff;
}

.najlife-contact-note__inner {
	max-width: 980px;
	margin: 0 auto;
	padding-top: 30px;
	border-top: 1px solid var(--najlife-line);
	text-align: center;
}

.najlife-contact-note p {
	max-width: 760px;
	margin: 0 auto;
	color: var(--najlife-muted);
	font-size: 15px;
}

@media (max-width: 980px) {
	.najlife-contact-hero__inner,
	.najlife-contact-form-layout {
		grid-template-columns: 1fr;
	}

	.najlife-contact-hero__copy h1 {
		max-width: 760px;
	}

	.najlife-contact-form-heading {
		position: static;
	}

	.najlife-contact-intentions__grid {
		grid-template-columns: 1fr;
	}

	.najlife-contact-intentions__grid article + article {
		border-left: 0;
		border-top: 1px solid var(--najlife-line);
	}
}

@media (max-width: 640px) {
	.najlife-contact-hero {
		padding-top: 116px;
	}

	.najlife-contact-hero__figure figcaption {
		position: static;
		margin-top: 12px;
		align-items: flex-start;
		flex-direction: column;
	}

	.najlife-contact-hero__figure em {
		text-align: left;
	}

	.najlife-contact-hero__links a,
	.najlife-contact-native-form button {
		width: 100%;
	}

	.najlife-contact-native-form {
		grid-template-columns: 1fr;
	}

	.najlife-contact-form-card {
		padding: 20px;
	}
}

/* --------------------------------------------------------------------------
   WooCommerce Single Product — NAJlife Product V1
   Scope volontairement limité à .najlife-product-page pour préserver les pages validées.
---------------------------------------------------------------------------- */
.najlife-product-page {
	background:
		radial-gradient(circle at 10% 4%, rgba(183, 131, 53, 0.08), transparent 28%),
		linear-gradient(180deg, var(--najlife-white) 0%, var(--najlife-ivory) 100%);
	padding: 118px clamp(18px, 4.6vw, 72px) 80px;
}

.najlife-single-product {
	max-width: 1420px;
	margin: 0 auto;
}

.najlife-product-breadcrumb {
	display: flex;
	align-items: center;
	flex-wrap: wrap;
	gap: 10px;
	margin: 0 0 24px;
	color: rgba(23, 18, 14, 0.58);
	font-size: 12px;
	font-weight: 720;
	letter-spacing: 0.11em;
	line-height: 1.4;
	text-transform: uppercase;
}

.najlife-product-breadcrumb a,
.najlife-product-breadcrumb strong {
	color: var(--najlife-ink);
}

.najlife-product-breadcrumb a {
	transition: color 180ms ease;
}

.najlife-product-breadcrumb a:hover {
	color: var(--najlife-gold-dark);
}

.najlife-product-breadcrumb span {
	color: rgba(105, 82, 54, 0.42);
}

.najlife-product-hero {
	display: grid;
	grid-template-columns: minmax(0, 1.14fr) minmax(360px, 0.86fr);
	align-items: start;
	gap: clamp(36px, 6vw, 92px);
}

.najlife-product-gallery {
	min-width: 0;
}

.najlife-product-gallery__main {
	position: relative;
	min-height: clamp(420px, 52vw, 720px);
	display: flex;
	align-items: center;
	justify-content: center;
	overflow: hidden;
	background:
		linear-gradient(135deg, rgba(255, 255, 255, 0.28), transparent 46%),
		var(--najlife-soft);
	border: 1px solid rgba(105, 82, 54, 0.13);
	box-shadow: 0 28px 72px rgba(39, 28, 18, 0.08);
}

.najlife-product-gallery__main::before {
	content: '';
	position: absolute;
	inset: 0;
	pointer-events: none;
	background-image:
		linear-gradient(90deg, rgba(105, 82, 54, 0.035) 1px, transparent 1px),
		linear-gradient(0deg, rgba(105, 82, 54, 0.03) 1px, transparent 1px);
	background-size: 62px 62px;
	mask-image: radial-gradient(circle at 50% 42%, black 0%, transparent 74%);
	opacity: 0.58;
}

.najlife-product-gallery__zoom,
.najlife-product-gallery__placeholder {
	position: relative;
	z-index: 1;
	display: flex;
	align-items: center;
	justify-content: center;
	width: 100%;
	height: 100%;
	padding: clamp(24px, 5vw, 72px);
}

.najlife-product-gallery__zoom::after {
	content: '+';
	position: absolute;
	top: 18px;
	right: 18px;
	width: 42px;
	height: 42px;
	display: grid;
	place-items: center;
	border: 1px solid rgba(105, 82, 54, 0.2);
	border-radius: 999px;
	background: rgba(255, 255, 255, 0.74);
	color: var(--najlife-ink);
	font-family: var(--najlife-serif);
	font-size: 28px;
	line-height: 1;
	box-shadow: 0 12px 28px rgba(39, 28, 18, 0.08);
}

.najlife-product-gallery__image,
.najlife-product-gallery__placeholder img {
	width: auto;
	max-width: 100%;
	max-height: min(620px, 68vh);
	object-fit: contain;
	filter: drop-shadow(0 28px 28px rgba(25, 20, 16, 0.12));
}

.najlife-product-gallery__thumbs {
	display: grid;
	grid-template-columns: repeat(5, minmax(0, 1fr));
	gap: 14px;
	margin-top: 16px;
}

.najlife-product-gallery__thumb {
	aspect-ratio: 1 / 1;
	display: flex;
	align-items: center;
	justify-content: center;
	overflow: hidden;
	background: rgba(244, 239, 231, 0.78);
	border: 1px solid rgba(105, 82, 54, 0.14);
	transition: border-color 180ms ease, transform 180ms ease, box-shadow 180ms ease;
}

.najlife-product-gallery__thumb:hover,
.najlife-product-gallery__thumb.is-active {
	border-color: rgba(183, 131, 53, 0.72);
	box-shadow: 0 16px 30px rgba(39, 28, 18, 0.08);
	transform: translateY(-1px);
}

.najlife-product-gallery__thumb img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}

.najlife-product-summary {
	position: sticky;
	top: 112px;
	min-width: 0;
	padding-top: 6px;
}

.najlife-product-summary__eyebrow {
	margin: 0 0 8px;
	color: var(--najlife-gold-dark);
	font-size: 14px;
	font-weight: 650;
	letter-spacing: 0.2em;
	line-height: 1.4;
	text-transform: uppercase;
}

.najlife-product-summary .product_title {
	margin: 0;
	max-width: 680px;
	font-family: var(--najlife-serif);
	font-size: clamp(40px, 4vw, 70px);
	font-weight: 400;
	letter-spacing: -0.055em;
	line-height: 0.96;
	color: var(--najlife-ink);
}

.najlife-product-summary .price {
	display: block;
	margin: 22px 0 0;
	color: var(--najlife-gold-dark);
	font-family: var(--najlife-sans);
	font-size: clamp(22px, 2vw, 30px);
	font-weight: 520;
	letter-spacing: 0.01em;
}

.najlife-product-summary .price del {
	margin-right: 9px;
	color: rgba(111, 98, 88, 0.62);
	font-size: 0.78em;
}

.najlife-product-summary .price ins {
	background: transparent;
	text-decoration: none;
}

.najlife-product-summary__excerpt {
	max-width: 590px;
	margin-top: 18px;
	color: var(--najlife-muted);
	font-size: 16px;
	line-height: 1.78;
}

.najlife-product-summary__excerpt p {
	margin: 0;
}

.najlife-product-summary__divider {
	width: 100%;
	height: 1px;
	margin: 26px 0;
	background: rgba(105, 82, 54, 0.18);
}

.najlife-product-summary__cart .stock {
	margin: 0 0 16px;
	font-size: 13px;
	font-weight: 720;
	letter-spacing: 0.08em;
	text-transform: uppercase;
}

.najlife-product-summary__cart .stock.in-stock {
	color: #3e6f3b;
}

.najlife-product-summary__cart .stock.out-of-stock {
	color: #9b2f24;
}

.najlife-product-summary__cart form.cart,
.najlife-product-summary__cart .variations_form.cart {
	margin: 0;
}

.najlife-product-summary__cart table.variations {
	width: 100%;
	margin: 0 0 18px;
	border: 0;
	border-collapse: collapse;
}

.najlife-product-summary__cart table.variations tr {
	display: grid;
	grid-template-columns: 104px minmax(0, 1fr);
	align-items: center;
	gap: 16px;
	margin-bottom: 14px;
}

.najlife-product-summary__cart table.variations th,
.najlife-product-summary__cart table.variations td {
	display: block;
	padding: 0;
	border: 0;
	text-align: left;
	vertical-align: middle;
}

.najlife-product-summary__cart table.variations label {
	color: var(--najlife-ink);
	font-size: 12px;
	font-weight: 780;
	letter-spacing: 0.1em;
	line-height: 1.35;
	text-transform: uppercase;
}

.najlife-product-summary__cart table.variations select {
	width: min(100%, 320px);
	min-height: 48px;
	padding: 0 44px 0 14px;
	border: 1px solid rgba(105, 82, 54, 0.2);
	border-radius: 0;
	background: rgba(255, 255, 255, 0.72);
	color: var(--najlife-ink);
	font-size: 14px;
	outline: none;
	transition: border-color 180ms ease, box-shadow 180ms ease, background 180ms ease;
}

.najlife-product-summary__cart table.variations select:focus {
	border-color: rgba(183, 131, 53, 0.72);
	box-shadow: 0 0 0 3px rgba(183, 131, 53, 0.12);
	background: var(--najlife-white);
}

.najlife-product-summary__cart .reset_variations {
	display: inline-flex;
	margin-top: 8px;
	color: var(--najlife-muted);
	font-size: 12px;
	font-weight: 650;
	text-decoration: underline;
	text-underline-offset: 3px;
}

.najlife-product-summary__cart .single_variation_wrap {
	margin-top: 18px;
}

.najlife-product-summary__cart .woocommerce-variation-price .price {
	margin: 0 0 14px;
	font-size: 20px;
}

.najlife-product-summary__cart .woocommerce-variation-description {
	margin-bottom: 14px;
	color: var(--najlife-muted);
}

.najlife-product-summary__cart .quantity {
	display: inline-flex;
	align-items: center;
	min-height: 48px;
	margin: 0 14px 0 0;
	border: 1px solid rgba(105, 82, 54, 0.2);
	background: rgba(255, 255, 255, 0.68);
	vertical-align: middle;
}

.najlife-product-summary__cart .quantity input.qty {
	width: 76px;
	height: 48px;
	padding: 0 10px;
	border: 0;
	background: transparent;
	color: var(--najlife-ink);
	font-size: 15px;
	font-weight: 650;
	text-align: center;
	-moz-appearance: textfield;
}

.najlife-product-summary__cart .quantity input.qty::-webkit-outer-spin-button,
.najlife-product-summary__cart .quantity input.qty::-webkit-inner-spin-button {
	margin: 0;
	-webkit-appearance: none;
}

.najlife-product-summary__cart .single_add_to_cart_button,
.najlife-product-summary__cart .button.single_add_to_cart_button {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-height: 56px;
	min-width: min(100%, 360px);
	padding: 0 34px;
	border: 1px solid rgba(139, 93, 36, 0.22);
	border-radius: 0;
	background: linear-gradient(135deg, #c18a42, var(--najlife-gold-dark));
	color: var(--najlife-white);
	box-shadow: 0 18px 42px rgba(139, 93, 36, 0.18);
	cursor: pointer;
	font-size: 14px;
	font-weight: 760;
	letter-spacing: 0.13em;
	line-height: 1.2;
	text-align: center;
	text-transform: uppercase;
	transition: transform 180ms ease, box-shadow 180ms ease, opacity 180ms ease;
}

.najlife-product-summary__cart .single_add_to_cart_button:hover,
.najlife-product-summary__cart .button.single_add_to_cart_button:hover {
	box-shadow: 0 22px 52px rgba(139, 93, 36, 0.24);
	transform: translateY(-1px);
}

.najlife-product-summary__cart .single_add_to_cart_button.disabled,
.najlife-product-summary__cart .single_add_to_cart_button:disabled {
	cursor: not-allowed;
	opacity: 0.52;
	transform: none;
}

.najlife-product-summary__cart .added_to_cart {
	display: inline-flex;
	margin-left: 14px;
	color: var(--najlife-gold-dark);
	font-size: 13px;
	font-weight: 760;
	letter-spacing: 0.08em;
	text-transform: uppercase;
}

.najlife-product-assurance {
	display: grid;
	grid-template-columns: repeat(3, minmax(0, 1fr));
	gap: 14px;
	margin-top: 28px;
	padding-top: 22px;
	border-top: 1px solid rgba(105, 82, 54, 0.16);
}

.najlife-product-assurance__item {
	display: grid;
	grid-template-columns: 34px minmax(0, 1fr);
	grid-template-areas:
		'icon title'
		'icon text';
	align-items: center;
	column-gap: 10px;
	min-width: 0;
}

.najlife-product-assurance__item span {
	grid-area: icon;
	display: grid;
	place-items: center;
	width: 34px;
	height: 34px;
	color: var(--najlife-gold-dark);
}

.najlife-product-assurance__item svg {
	width: 30px;
	height: 30px;
	fill: none;
	stroke: currentColor;
	stroke-linecap: round;
	stroke-linejoin: round;
	stroke-width: 1.35;
}

.najlife-product-assurance__item strong {
	grid-area: title;
	color: var(--najlife-ink);
	font-size: 11px;
	font-weight: 820;
	letter-spacing: 0.06em;
	line-height: 1.25;
	text-transform: uppercase;
}

.najlife-product-assurance__item small {
	grid-area: text;
	color: var(--najlife-muted);
	font-size: 12px;
	line-height: 1.35;
}

.najlife-product-details {
	margin-top: clamp(32px, 5vw, 68px);
	border: 1px solid rgba(105, 82, 54, 0.16);
	background: rgba(255, 255, 255, 0.46);
	box-shadow: 0 20px 60px rgba(39, 28, 18, 0.05);
}

.najlife-product-detail + .najlife-product-detail {
	border-top: 1px solid rgba(105, 82, 54, 0.14);
}

.najlife-product-detail summary {
	position: relative;
	display: grid;
	grid-template-columns: 42px minmax(180px, 220px) minmax(0, 1fr) 24px;
	align-items: center;
	gap: 20px;
	min-height: 68px;
	padding: 0 clamp(18px, 3vw, 36px);
	color: var(--najlife-ink);
	cursor: pointer;
	list-style: none;
}

.najlife-product-detail summary::-webkit-details-marker {
	display: none;
}

.najlife-product-detail summary::after {
	content: '';
	justify-self: end;
	width: 10px;
	height: 10px;
	border-right: 1.5px solid var(--najlife-ink);
	border-bottom: 1.5px solid var(--najlife-ink);
	transform: rotate(45deg) translateY(-3px);
	transition: transform 180ms ease;
}

.najlife-product-detail[open] summary::after {
	transform: rotate(225deg) translateY(-3px);
}

.najlife-product-detail__icon {
	display: grid;
	place-items: center;
	width: 34px;
	height: 34px;
	color: var(--najlife-gold-dark);
}

.najlife-product-detail__icon svg {
	width: 24px;
	height: 24px;
	fill: none;
	stroke: currentColor;
	stroke-linecap: round;
	stroke-linejoin: round;
	stroke-width: 1.4;
}

.najlife-product-detail summary strong {
	font-size: 12px;
	font-weight: 820;
	letter-spacing: 0.1em;
	text-transform: uppercase;
}

.najlife-product-detail__content {
	max-width: 900px;
	margin: -8px 0 0 calc(clamp(18px, 3vw, 36px) + 62px + min(220px, 22vw));
	padding: 0 clamp(18px, 3vw, 36px) 24px 0;
	color: var(--najlife-muted);
	font-size: 14px;
	line-height: 1.78;
}

.najlife-product-detail__content p {
	margin: 0 0 12px;
}

.najlife-product-detail__content p:last-child {
	margin-bottom: 0;
}

.najlife-product-detail__attributes table,
.najlife-product-detail__attributes .woocommerce-product-attributes {
	width: 100%;
	border: 0;
	border-collapse: collapse;
}

.najlife-product-detail__attributes th,
.najlife-product-detail__attributes td {
	padding: 10px 0;
	border: 0;
	border-bottom: 1px solid rgba(105, 82, 54, 0.1);
	text-align: left;
	vertical-align: top;
}

.najlife-product-detail__attributes th {
	width: 32%;
	color: var(--najlife-ink);
	font-size: 12px;
	font-weight: 760;
	letter-spacing: 0.08em;
	text-transform: uppercase;
}

.najlife-product-detail__attributes td p {
	margin: 0;
}

.najlife-product-related {
	margin-top: clamp(42px, 7vw, 90px);
}

.najlife-product-related .related > h2 {
	display: flex;
	align-items: center;
	gap: 24px;
	margin: 0 0 28px;
	font-family: var(--najlife-serif);
	font-size: clamp(32px, 3vw, 48px);
	font-weight: 400;
	letter-spacing: -0.045em;
	line-height: 1;
	text-align: center;
}

.najlife-product-related .related > h2::before,
.najlife-product-related .related > h2::after {
	content: '';
	flex: 1;
	height: 1px;
	background: rgba(105, 82, 54, 0.16);
}

.najlife-product-related ul.products {
	display: grid;
	grid-template-columns: repeat(4, minmax(0, 1fr));
	gap: clamp(16px, 2.4vw, 28px);
	margin: 0;
	padding: 0;
	list-style: none;
}

.najlife-product-related ul.products li.product {
	float: none;
	width: auto;
	margin: 0;
	padding: 0;
	background: rgba(255, 255, 255, 0.52);
	border: 1px solid rgba(105, 82, 54, 0.12);
	transition: transform 180ms ease, box-shadow 180ms ease, border-color 180ms ease;
}

.najlife-product-related ul.products li.product:hover {
	border-color: rgba(183, 131, 53, 0.3);
	box-shadow: 0 22px 52px rgba(39, 28, 18, 0.08);
	transform: translateY(-2px);
}

.najlife-product-related ul.products li.product a.woocommerce-LoopProduct-link {
	display: block;
}

.najlife-product-related ul.products li.product img {
	width: 100%;
	aspect-ratio: 4 / 5;
	height: auto;
	margin: 0;
	object-fit: cover;
	background: var(--najlife-soft);
}

.najlife-product-related ul.products li.product .woocommerce-loop-product__title {
	margin: 16px 16px 4px;
	padding: 0;
	color: var(--najlife-ink);
	font-family: var(--najlife-serif);
	font-size: 22px;
	font-weight: 400;
	letter-spacing: -0.03em;
	line-height: 1.12;
}

.najlife-product-related ul.products li.product .price {
	display: block;
	margin: 0 16px 14px;
	color: var(--najlife-gold-dark);
	font-size: 14px;
	font-weight: 650;
}

.najlife-product-related ul.products li.product .button {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	margin: 0 16px 18px;
	padding: 12px 16px;
	border: 1px solid rgba(105, 82, 54, 0.16);
	background: transparent;
	color: var(--najlife-ink);
	font-size: 11px;
	font-weight: 760;
	letter-spacing: 0.1em;
	line-height: 1.2;
	text-transform: uppercase;
	transition: background 180ms ease, color 180ms ease, border-color 180ms ease;
}

.najlife-product-related ul.products li.product .button:hover {
	border-color: var(--najlife-ink);
	background: var(--najlife-ink);
	color: var(--najlife-white);
}

@media (max-width: 1180px) {
	.najlife-product-hero {
		grid-template-columns: minmax(0, 1fr) minmax(330px, 0.78fr);
		gap: 38px;
	}

	.najlife-product-assurance {
		grid-template-columns: 1fr;
	}

	.najlife-product-related ul.products {
		grid-template-columns: repeat(3, minmax(0, 1fr));
	}
}

@media (max-width: 900px) {
	.najlife-product-page {
		padding-top: 108px;
	}

	.najlife-product-hero {
		grid-template-columns: 1fr;
		gap: 30px;
	}

	.najlife-product-summary {
		position: static;
		padding-top: 0;
	}

	.najlife-product-gallery__main {
		min-height: 420px;
	}

	.najlife-product-detail summary {
		grid-template-columns: 36px minmax(0, 1fr) 22px;
		gap: 14px;
		padding-block: 16px;
	}

	.najlife-product-detail__content {
		margin: 0;
		padding: 0 clamp(18px, 3vw, 36px) 22px calc(clamp(18px, 3vw, 36px) + 50px);
	}

	.najlife-product-related ul.products {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}
}

@media (max-width: 640px) {
	.najlife-product-page {
		padding: 98px 16px 58px;
	}

	.najlife-product-breadcrumb {
		font-size: 10px;
		gap: 7px;
	}

	.najlife-product-gallery__main {
		min-height: 330px;
	}

	.najlife-product-gallery__zoom,
	.najlife-product-gallery__placeholder {
		padding: 22px;
	}

	.najlife-product-gallery__zoom::after {
		top: 12px;
		right: 12px;
		width: 36px;
		height: 36px;
		font-size: 24px;
	}

	.najlife-product-gallery__thumbs {
		grid-template-columns: repeat(4, minmax(0, 1fr));
		gap: 10px;
	}

	.najlife-product-summary .product_title {
		font-size: clamp(36px, 11vw, 50px);
	}

	.najlife-product-summary__cart table.variations tr {
		grid-template-columns: 1fr;
		gap: 8px;
	}

	.najlife-product-summary__cart table.variations select {
		width: 100%;
	}

	.najlife-product-summary__cart .quantity {
		width: 100%;
		margin: 0 0 12px;
		justify-content: center;
	}

	.najlife-product-summary__cart .quantity input.qty {
		width: 100%;
	}

	.najlife-product-summary__cart .single_add_to_cart_button,
	.najlife-product-summary__cart .button.single_add_to_cart_button {
		width: 100%;
		min-width: 0;
	}

	.najlife-product-summary__cart .added_to_cart {
		margin: 12px 0 0;
	}

	.najlife-product-assurance {
		gap: 16px;
	}

	.najlife-product-detail summary {
		min-height: 60px;
	}

	.najlife-product-detail__content {
		padding-left: 18px;
	}

	.najlife-product-detail__attributes th,
	.najlife-product-detail__attributes td {
		display: block;
		width: 100%;
	}

	.najlife-product-detail__attributes th {
		padding-bottom: 0;
		border-bottom: 0;
	}

	.najlife-product-related .related > h2 {
		gap: 14px;
		font-size: 32px;
	}

	.najlife-product-related ul.products {
		grid-template-columns: 1fr;
	}
}

/* --------------------------------------------------------------------------
   V44 — Corrections produit + sous-pages E-Souk
   Scope limité aux routes E-Souk virtuelles et à la fiche produit WooCommerce.
---------------------------------------------------------------------------- */
.najlife-esouk-subpage .najlife-site-header,
.tax-product_cat .najlife-site-header,
.single-product .najlife-site-header {
	z-index: 1000;
}

.najlife-product-page {
	background:
		radial-gradient(circle at 12% 0%, rgba(183, 131, 53, 0.10), transparent 30%),
		linear-gradient(180deg, #fffaf1 0%, #f7f0e5 46%, #ffffff 100%);
	padding-top: clamp(112px, 9vw, 148px);
}

.najlife-single-product {
	max-width: 1320px;
}

.najlife-product-hero {
	grid-template-columns: minmax(0, 1.02fr) minmax(380px, 0.82fr);
	gap: clamp(30px, 5vw, 74px);
}

.najlife-product-gallery__main {
	min-height: clamp(440px, 48vw, 660px);
	border-radius: 30px;
	background:
		linear-gradient(145deg, rgba(255, 255, 255, 0.42), rgba(255, 255, 255, 0.04) 48%),
		linear-gradient(135deg, #f7efe2, #fffaf1);
	border-color: rgba(183, 131, 53, 0.18);
	box-shadow: 0 32px 82px rgba(39, 28, 18, 0.10);
}

.najlife-product-gallery__zoom,
.najlife-product-gallery__placeholder {
	padding: clamp(22px, 4.2vw, 58px);
}

.najlife-product-gallery__thumb {
	border-radius: 18px;
	background: rgba(255, 250, 241, 0.82);
}

.najlife-product-summary {
	padding: clamp(28px, 3.6vw, 46px);
	border: 1px solid rgba(183, 131, 53, 0.18);
	border-radius: 30px;
	background: rgba(255, 255, 255, 0.72);
	box-shadow: 0 28px 72px rgba(39, 28, 18, 0.08);
	backdrop-filter: blur(14px);
}

.najlife-product-summary .product_title {
	font-size: clamp(36px, 3.55vw, 58px);
	letter-spacing: -0.045em;
}

.najlife-product-summary__excerpt {
	font-size: 15px;
	line-height: 1.72;
}

.najlife-product-summary__cart table.variations tr {
	grid-template-columns: 1fr;
	gap: 10px;
	margin-bottom: 18px;
}

.najlife-product-summary__cart table.variations label {
	display: inline-flex;
	align-items: center;
	gap: 8px;
}

.najlife-product-summary__cart table.variations label::after {
	content: '';
	width: 26px;
	height: 1px;
	background: rgba(183, 131, 53, 0.42);
}

.najlife-product-summary__cart table.variations select.najlife-variation-select {
	position: absolute !important;
	width: 1px !important;
	height: 1px !important;
	padding: 0 !important;
	margin: -1px !important;
	overflow: hidden !important;
	clip: rect(0 0 0 0) !important;
	white-space: nowrap !important;
	border: 0 !important;
}

.najlife-variation-buttons {
	display: flex;
	flex-wrap: wrap;
	gap: 10px;
	margin-top: 2px;
}

.najlife-variation-button {
	min-height: 44px;
	min-width: 48px;
	padding: 0 18px;
	border: 1px solid rgba(105, 82, 54, 0.18);
	border-radius: 999px;
	background: rgba(255, 250, 241, 0.76);
	color: var(--najlife-ink);
	cursor: pointer;
	font-size: 12px;
	font-weight: 760;
	letter-spacing: 0.08em;
	line-height: 1;
	text-transform: uppercase;
	transition: transform 180ms ease, border-color 180ms ease, background 180ms ease, color 180ms ease, box-shadow 180ms ease, opacity 180ms ease;
}

.najlife-variation-button:hover,
.najlife-variation-button:focus-visible {
	border-color: rgba(183, 131, 53, 0.62);
	box-shadow: 0 12px 28px rgba(139, 93, 36, 0.10);
	outline: none;
	transform: translateY(-1px);
}

.najlife-variation-button.is-active {
	border-color: var(--najlife-gold-dark);
	background: var(--najlife-ink);
	color: var(--najlife-white);
	box-shadow: 0 14px 34px rgba(39, 28, 18, 0.14);
}

.najlife-variation-button:disabled {
	cursor: not-allowed;
	opacity: 0.32;
	transform: none;
}

.najlife-product-summary__cart .single_variation_wrap {
	margin-top: 22px;
}

.najlife-product-summary__cart .quantity {
	border-radius: 999px;
	background: rgba(255, 250, 241, 0.74);
}

.najlife-product-summary__cart .single_add_to_cart_button,
.najlife-product-summary__cart .button.single_add_to_cart_button {
	border-radius: 999px;
	background: linear-gradient(135deg, #c18a42, #9b6a2f);
}

.najlife-product-assurance {
	grid-template-columns: 1fr;
	gap: 12px;
}

.najlife-product-assurance__item {
	padding: 12px 0;
	border-bottom: 1px solid rgba(105, 82, 54, 0.10);
}

.najlife-product-assurance__item:last-child {
	border-bottom: 0;
}

.najlife-product-details {
	border-radius: 30px;
	overflow: hidden;
	background: rgba(255, 255, 255, 0.62);
}

.najlife-product-related {
	clear: both;
	max-width: 1320px;
	margin-right: auto;
	margin-left: auto;
}

.najlife-product-related .related {
	width: 100%;
}

.najlife-product-related ul.products,
.najlife-product-related ul.products.columns-2,
.najlife-product-related ul.products.columns-3,
.najlife-product-related ul.products.columns-4 {
	display: grid !important;
	grid-template-columns: repeat(4, minmax(0, 1fr)) !important;
	gap: clamp(18px, 2vw, 28px) !important;
	align-items: stretch;
	margin: 0 !important;
	padding: 0 !important;
}

.najlife-product-related ul.products::before,
.najlife-product-related ul.products::after {
	display: none !important;
	content: none !important;
}

.najlife-product-related ul.products li.product,
.woocommerce .najlife-product-related ul.products li.product,
.woocommerce-page .najlife-product-related ul.products li.product {
	float: none !important;
	width: auto !important;
	min-width: 0;
	height: 100%;
	margin: 0 !important;
	padding: 0 !important;
	border-radius: 22px;
	overflow: hidden;
	background: rgba(255, 255, 255, 0.72);
}

.najlife-product-related ul.products li.product a.woocommerce-LoopProduct-link {
	display: flex;
	min-height: 100%;
	flex-direction: column;
}

.najlife-product-related ul.products li.product img {
	display: block;
	width: 100% !important;
	height: auto !important;
	aspect-ratio: 4 / 5;
	object-fit: cover;
}

.najlife-product-related ul.products li.product .woocommerce-loop-product__title {
	min-height: 52px;
}

.najlife-product-related ul.products li.product .button {
	border-radius: 999px;
}

@media (max-width: 1180px) {
	.najlife-product-hero {
		grid-template-columns: 1fr;
	}

	.najlife-product-summary {
		position: static;
	}

	.najlife-product-related ul.products,
	.najlife-product-related ul.products.columns-2,
	.najlife-product-related ul.products.columns-3,
	.najlife-product-related ul.products.columns-4 {
		grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
	}
}

@media (max-width: 760px) {
	.najlife-product-page {
		padding: 98px 16px 58px;
	}

	.najlife-product-summary,
	.najlife-product-gallery__main,
	.najlife-product-details {
		border-radius: 22px;
	}

	.najlife-product-related ul.products,
	.najlife-product-related ul.products.columns-2,
	.najlife-product-related ul.products.columns-3,
	.najlife-product-related ul.products.columns-4 {
		grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
	}
}

@media (max-width: 520px) {
	.najlife-variation-button {
		min-height: 42px;
		padding: 0 14px;
		font-size: 11px;
	}

	.najlife-product-related ul.products,
	.najlife-product-related ul.products.columns-2,
	.najlife-product-related ul.products.columns-3,
	.najlife-product-related ul.products.columns-4 {
		grid-template-columns: 1fr !important;
	}
}
