/* =============================================================================
   SANJAI ANNA — HERITAGE ELEGANCE DESIGN SYSTEM
   assets/css/homepage.css

   A Minangkabau-rooted premium system: songket ivory, ceremonial maroon,
   champagne gold, with a gonjong (Rumah Gadang roofline) line motif as the
   single signature device. Mobile-first. Reduced-motion respected.
   Scoped tightly so it never leaks into wp-admin or the parent theme chrome.
   ========================================================================== */

:root {
	/* Palette — 6 named values, derived from Minang ceremonial textile + spice */
	--sa-ivory:       #FBF8F2;
	--sa-cream:       #F3EADB;
	--sa-maroon:      #7A1F2B;
	--sa-maroon-deep: #571019;
	--sa-gold:        #BE9540;
	--sa-gold-soft:   #E6CE94;
	--sa-green:       #3E6B4F;
	--sa-ink:         #2A211C;
	--sa-ink-soft:    #6E6055;
	--sa-line:        rgba(42, 33, 28, .12);

	/* Type */
	--sa-display: "Fraunces", Georgia, "Times New Roman", serif;
	--sa-body:    "Plus Jakarta Sans", system-ui, -apple-system, "Segoe UI", sans-serif;

	/* Rhythm */
	--sa-maxw:    1200px;
	--sa-gutter:  clamp(1.1rem, 4vw, 2.5rem);
	--sa-section: clamp(3.5rem, 9vw, 7rem);
	--sa-radius:  18px;
	--sa-shadow:  0 18px 50px -28px rgba(87, 16, 25, .45);
	--sa-shadow-sm: 0 8px 24px -16px rgba(42, 33, 28, .4);
}

/* ── Base, scoped to the homepage + WC body class so admin stays untouched ── */
.sa-heritage {
	background: var(--sa-ivory);
	color: var(--sa-ink);
	font-family: var(--sa-body);
	-webkit-font-smoothing: antialiased;
	text-rendering: optimizeLegibility;
}
.sa-heritage img { max-width: 100%; height: auto; }  /* no global display:block — avoids shifting inline icons (e.g. checkout payment icons) */

/* ── Reveal animation ── */
[data-reveal] {
	opacity: 0;
	transform: translateY(24px);
	transition: opacity .7s cubic-bezier(.22,.61,.36,1), transform .7s cubic-bezier(.22,.61,.36,1);
	will-change: opacity, transform;
}
[data-reveal].is-revealed { opacity: 1; transform: none; }
[data-reveal-delay="1"] { transition-delay: .08s; }
[data-reveal-delay="2"] { transition-delay: .16s; }
[data-reveal-delay="3"] { transition-delay: .24s; }
[data-reveal-delay="4"] { transition-delay: .32s; }
@media (prefers-reduced-motion: reduce) {
	[data-reveal] { opacity: 1 !important; transform: none !important; transition: none !important; }
}

/* ── Section header ── */
.sa-sec-header { max-width: 640px; }
.sa-sec-header__eyebrow {
	display: inline-flex; align-items: center; gap: .5em;
	font-size: .72rem; font-weight: 700; letter-spacing: .22em; text-transform: uppercase;
	color: var(--sa-maroon);
}
.sa-sec-header__eyebrow::before {
	content: ""; width: 28px; height: 10px; flex: none;
	background: no-repeat center / contain
		url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 28 10'><path d='M1 9C5 9 5 1 9 1s4 8 8 8M11 9c4 0 4-8 8-8s4 8 8 8' fill='none' stroke='%23BE9540' stroke-width='1.4' stroke-linecap='round'/></svg>");
}
.sa-sec-header__title {
	font-family: var(--sa-display);
	font-weight: 600;
	font-size: clamp(1.9rem, 5vw, 3rem);
	line-height: 1.08;
	letter-spacing: -.01em;
	margin: .5rem 0 0;
	color: var(--sa-ink);
}
.sa-sec-header__title em { font-style: italic; color: var(--sa-maroon); }
.sa-sec-header__lead {
	margin: 1rem 0 0; max-width: 52ch;
	font-size: 1.02rem; line-height: 1.7; color: var(--sa-ink-soft);
}

/* ── Buttons ── */
.sa-btn {
	display: inline-flex; align-items: center; justify-content: center; gap: .55em;
	font-family: var(--sa-body); font-weight: 600; font-size: .96rem;
	padding: .85em 1.6em; border-radius: 100px; border: 1.5px solid transparent;
	cursor: pointer; text-decoration: none; line-height: 1;
	transition: transform .25s, box-shadow .25s, background .25s, color .25s;
}
.sa-btn svg { transition: transform .25s; }
.sa-btn:hover svg { transform: translateX(3px); }
.sa-btn--lg { padding: 1.05em 2.1em; font-size: 1.02rem; }
.sa-btn--sm { padding: .6em 1.15em; font-size: .85rem; }
.sa-btn--primary { background: var(--sa-maroon); color: #fff; box-shadow: var(--sa-shadow); }
.sa-btn--primary:hover { background: var(--sa-maroon-deep); transform: translateY(-2px); }
.sa-btn--secondary { background: transparent; color: var(--sa-maroon); border-color: var(--sa-maroon); }
.sa-btn--secondary:hover { background: var(--sa-maroon); color: #fff; transform: translateY(-2px); }
.sa-btn--whatsapp { background: #128C7E; color: #fff; }
.sa-btn--whatsapp:hover { background: #0e6f63; transform: translateY(-2px); }
.sa-btn:focus-visible { outline: 3px solid var(--sa-gold); outline-offset: 3px; }

/* ── Gonjong divider (signature) ── */
.sa-gonjong {
	height: 26px; margin: 0 auto;
	background: no-repeat center / 240px
		url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 240 26'><path d='M2 24C40 24 40 4 60 4s20 20 60 20 40-20 60-20 20 20 58 20' fill='none' stroke='%23BE9540' stroke-width='1.3' stroke-linecap='round' opacity='.7'/></svg>");
}

/* ============================ HERO ====================================== */
.sa-hero {
	position: relative; overflow: hidden;
	background:
		radial-gradient(120% 90% at 85% -10%, rgba(190,149,64,.18), transparent 60%),
		linear-gradient(180deg, var(--sa-cream), var(--sa-ivory));
	padding: clamp(2.5rem, 7vw, 5rem) var(--sa-gutter) var(--sa-section);
}
.sa-hero__inner {
	max-width: var(--sa-maxw); margin: 0 auto;
	display: grid; gap: clamp(2rem, 5vw, 4rem);
	grid-template-columns: 1fr;
}
.sa-hero__eyebrow {
	display: inline-flex; align-items: center; gap: .6em;
	font-size: .74rem; font-weight: 700; letter-spacing: .2em; text-transform: uppercase;
	color: var(--sa-maroon); margin-bottom: 1.1rem;
}
.sa-hero__title {
	font-family: var(--sa-display); font-weight: 600;
	font-size: clamp(2.6rem, 8vw, 4.6rem); line-height: 1.02; letter-spacing: -.02em;
	margin: 0; color: var(--sa-ink);
}
.sa-hero__title em { font-style: italic; color: var(--sa-maroon); }
.sa-hero__sub {
	margin: 1.4rem 0 0; max-width: 46ch;
	font-size: 1.1rem; line-height: 1.7; color: var(--sa-ink-soft);
}
.sa-hero__actions { display: flex; flex-wrap: wrap; gap: .85rem; margin-top: 2rem; }
.sa-hero__trust { display: flex; flex-wrap: wrap; gap: 1.4rem 2rem; margin-top: 2.4rem; }
.sa-hero__trust-item { display: flex; flex-direction: column; }
.sa-hero__trust-num { font-family: var(--sa-display); font-size: 1.5rem; font-weight: 600; color: var(--sa-maroon); }
.sa-hero__trust-label { font-size: .8rem; color: var(--sa-ink-soft); letter-spacing: .02em; }

.sa-hero__media { position: relative; }
.sa-hero__media-main {
	border-radius: var(--sa-radius); overflow: hidden; box-shadow: var(--sa-shadow);
	aspect-ratio: 4 / 5; background: var(--sa-cream);
}
.sa-hero__media-main img { width: 100%; height: 100%; object-fit: cover; }
.sa-hero__badge {
	position: absolute; left: -8px; bottom: 22px;
	background: var(--sa-ivory); border: 1px solid var(--sa-line);
	border-radius: 14px; padding: .8rem 1.05rem; box-shadow: var(--sa-shadow-sm);
	display: flex; align-items: center; gap: .65rem; max-width: 230px;
}
.sa-hero__badge-emoji { font-size: 1.5rem; }
.sa-hero__badge-text { font-size: .82rem; line-height: 1.35; color: var(--sa-ink); }
.sa-hero__badge-text strong { display: block; color: var(--sa-maroon); }

@media (min-width: 880px) {
	.sa-hero__inner { grid-template-columns: 1.05fr .95fr; align-items: center; }
}

/* ========================== CATEGORY =================================== */
.sa-category { padding: var(--sa-section) var(--sa-gutter); }
.sa-category__inner { max-width: var(--sa-maxw); margin: 0 auto; }
.sa-category__grid {
	margin-top: clamp(2rem, 5vw, 3rem);
	display: grid; gap: clamp(.8rem, 2vw, 1.3rem);
	grid-template-columns: repeat(2, 1fr);
}
.sa-cat-card {
	position: relative; display: flex; flex-direction: column; align-items: center;
	gap: .9rem; text-align: center; text-decoration: none;
	padding: clamp(1.4rem, 4vw, 2.2rem) 1rem;
	background: #fff; border: 1px solid var(--sa-line); border-radius: var(--sa-radius);
	transition: transform .3s, box-shadow .3s, border-color .3s;
}
.sa-cat-card:hover { transform: translateY(-6px); box-shadow: var(--sa-shadow); border-color: transparent; }
.sa-cat-card__img {
	width: clamp(64px, 16vw, 92px); height: clamp(64px, 16vw, 92px);
	object-fit: contain; transition: transform .4s;
}
.sa-cat-card:hover .sa-cat-card__img { transform: scale(1.08) rotate(-3deg); }
.sa-cat-card__name { font-family: var(--sa-display); font-size: 1.05rem; font-weight: 600; color: var(--sa-ink); }
.sa-cat-card__count { font-size: .78rem; color: var(--sa-ink-soft); }
@media (min-width: 600px) { .sa-category__grid { grid-template-columns: repeat(3, 1fr); } }
@media (min-width: 900px) { .sa-category__grid { grid-template-columns: repeat(6, 1fr); } }

/* ========================= BEST SELLERS =============================== */
.sa-bestsellers {
	padding: var(--sa-section) 0;
	background: linear-gradient(180deg, var(--sa-ivory), var(--sa-cream));
}
.sa-bestsellers__head {
	max-width: var(--sa-maxw); margin: 0 auto; padding: 0 var(--sa-gutter);
	display: flex; flex-wrap: wrap; gap: 1.2rem; align-items: flex-end; justify-content: space-between;
}
.sa-bestsellers__nav-group { display: flex; gap: .6rem; }
.sa-bestsellers__nav {
	width: 46px; height: 46px; border-radius: 50%;
	border: 1.5px solid var(--sa-maroon); background: transparent; color: var(--sa-maroon);
	display: grid; place-items: center; cursor: pointer; transition: background .2s, color .2s, opacity .2s;
}
.sa-bestsellers__nav:hover:not([disabled]) { background: var(--sa-maroon); color: #fff; }
.sa-bestsellers__nav[disabled] { opacity: .3; cursor: default; }
.sa-bestsellers__rail {
	display: flex; gap: clamp(.9rem, 2vw, 1.4rem); margin-top: clamp(1.8rem, 4vw, 2.6rem);
	padding: .5rem var(--sa-gutter) 1.5rem;
	overflow-x: auto; scroll-snap-type: x mandatory; scrollbar-width: none;
	-webkit-overflow-scrolling: touch;
}
.sa-bestsellers__rail::-webkit-scrollbar { display: none; }
.sa-bestsellers__rail > * { scroll-snap-align: start; }

/* ── Shared product card (best sellers + discovery) ── */
.sa-pcard {
	flex: 0 0 clamp(220px, 70vw, 280px);
	display: flex; flex-direction: column;
	background: #fff; border: 1px solid var(--sa-line); border-radius: var(--sa-radius);
	overflow: hidden; transition: transform .3s, box-shadow .3s;
}
.sa-pcard:hover { transform: translateY(-6px); box-shadow: var(--sa-shadow); }
.sa-pcard__media { position: relative; aspect-ratio: 1; overflow: hidden; background: var(--sa-cream); }
.sa-pcard__media img { width: 100%; height: 100%; object-fit: cover; transition: transform .5s; }
.sa-pcard:hover .sa-pcard__media img { transform: scale(1.06); }
.sa-pcard__rank {
	position: absolute; top: 10px; left: 10px;
	font-family: var(--sa-display); font-weight: 600; font-size: .8rem;
	background: var(--sa-maroon); color: #fff; border-radius: 100px; padding: .3em .7em;
	display: inline-flex; align-items: center; gap: .3em;
}
.sa-pcard__body { padding: 1rem 1.1rem 1.2rem; display: flex; flex-direction: column; gap: .35rem; flex: 1; }
.sa-pcard__cat { font-size: .72rem; letter-spacing: .12em; text-transform: uppercase; color: var(--sa-gold); font-weight: 700; text-decoration: none; }
.sa-pcard__title { font-family: var(--sa-display); font-size: 1.06rem; font-weight: 600; line-height: 1.25; margin: 0; }
.sa-pcard__title a { color: var(--sa-ink); text-decoration: none; }
.sa-pcard__title a:hover { color: var(--sa-maroon); }
.sa-pcard__price { margin-top: auto; padding-top: .5rem; font-weight: 700; color: var(--sa-maroon); font-size: 1.05rem; }
.sa-pcard__price .woocommerce-Price-amount,
.sa-pcard__price bdi { color: inherit; }
.sa-pcard__add {
	margin-top: .7rem; display: inline-flex; align-items: center; justify-content: center; gap: .45em;
	width: 100%; padding: .7em 1em; border-radius: 100px; border: 1.5px solid var(--sa-maroon);
	background: transparent; color: var(--sa-maroon); font-weight: 600; font-size: .88rem;
	text-decoration: none; cursor: pointer; transition: background .2s, color .2s;
}
.sa-pcard__add:hover { background: var(--sa-maroon); color: #fff; }
.sa-pcard__add.loading { opacity: .6; pointer-events: none; }
.sa-pcard__add.added { background: var(--sa-green); border-color: var(--sa-green); color: #fff; }

/* ======================== PRODUCT DISCOVERY =========================== */
.sa-products { padding: var(--sa-section) var(--sa-gutter); }
.sa-products__inner { max-width: var(--sa-maxw); margin: 0 auto; }
.sa-products__grid {
	margin-top: clamp(2rem, 5vw, 3rem);
	display: grid; gap: clamp(.9rem, 2vw, 1.4rem);
	grid-template-columns: repeat(2, 1fr);
}
.sa-products__grid .sa-pcard { flex: initial; }
.sa-products__footer { text-align: center; margin-top: clamp(2rem, 5vw, 3rem); }
@media (min-width: 720px) { .sa-products__grid { grid-template-columns: repeat(3, 1fr); } }
@media (min-width: 1000px) { .sa-products__grid { grid-template-columns: repeat(4, 1fr); } }

/* =========================== BRAND STORY ============================== */
.sa-story {
	padding: var(--sa-section) var(--sa-gutter);
	background: var(--sa-maroon-deep); color: #fff;
	position: relative; overflow: hidden;
}
.sa-story::before {
	content: ""; position: absolute; inset: 0; opacity: .12; pointer-events: none;
	background: repeating-linear-gradient(135deg, transparent 0 22px, var(--sa-gold-soft) 22px 23px);
}
.sa-story__inner {
	position: relative; max-width: var(--sa-maxw); margin: 0 auto;
	display: grid; gap: clamp(2rem, 5vw, 4rem); grid-template-columns: 1fr; align-items: center;
}
.sa-story__eyebrow { color: var(--sa-gold-soft); font-weight: 700; letter-spacing: .2em; text-transform: uppercase; font-size: .74rem; }
.sa-story__title { font-family: var(--sa-display); font-weight: 600; font-size: clamp(2rem, 5vw, 3.2rem); line-height: 1.1; margin: .8rem 0 0; }
.sa-story__title em { font-style: italic; color: var(--sa-gold-soft); }
.sa-story__text { margin: 1.3rem 0 0; line-height: 1.8; color: rgba(255,255,255,.85); max-width: 54ch; }
.sa-story__values { display: grid; grid-template-columns: repeat(2, 1fr); gap: 1.2rem; margin-top: 2rem; }
.sa-story__value-icon { font-size: 1.6rem; }
.sa-story__value-title { font-family: var(--sa-display); font-weight: 600; margin: .4rem 0 .2rem; }
.sa-story__value-desc { font-size: .88rem; color: rgba(255,255,255,.7); line-height: 1.5; }
.sa-story__media { border-radius: var(--sa-radius); overflow: hidden; box-shadow: var(--sa-shadow); aspect-ratio: 4/3; }
.sa-story__media img { width: 100%; height: 100%; object-fit: cover; }
@media (min-width: 880px) { .sa-story__inner { grid-template-columns: 1fr 1fr; } }

/* ============================= TRUST ================================== */
.sa-trust { padding: clamp(2.5rem,6vw,4rem) var(--sa-gutter); border-bottom: 1px solid var(--sa-line); }
.sa-trust__inner {
	max-width: var(--sa-maxw); margin: 0 auto;
	display: grid; gap: 1.4rem; grid-template-columns: repeat(2, 1fr);
}
.sa-trust__item { display: flex; gap: .9rem; align-items: flex-start; }
.sa-trust__icon { font-size: 1.7rem; flex: none; line-height: 1; }
.sa-trust__title { font-family: var(--sa-display); font-weight: 600; font-size: 1.02rem; margin: 0 0 .2rem; }
.sa-trust__desc { font-size: .85rem; color: var(--sa-ink-soft); line-height: 1.5; }
@media (min-width: 760px) { .sa-trust__inner { grid-template-columns: repeat(4, 1fr); } }

/* ========================== TESTIMONIALS ============================== */
.sa-testi { padding: var(--sa-section) var(--sa-gutter); }
.sa-testi__inner { max-width: var(--sa-maxw); margin: 0 auto; }
.sa-testi__grid {
	margin-top: clamp(2rem,5vw,3rem);
	display: grid; gap: clamp(1rem,2vw,1.5rem); grid-template-columns: 1fr;
}
.sa-testi-card {
	background: #fff; border: 1px solid var(--sa-line); border-radius: var(--sa-radius);
	padding: clamp(1.4rem,3vw,2rem); display: flex; flex-direction: column; gap: 1rem;
	position: relative;
}
.sa-testi-card::before {
	content: "\201C"; font-family: var(--sa-display); font-size: 4rem; line-height: .6;
	color: var(--sa-gold-soft); position: absolute; top: 1.1rem; right: 1.3rem;
}
.sa-testi-card__stars { color: var(--sa-gold); letter-spacing: .15em; font-size: .9rem; }
.sa-testi-card__quote { font-size: 1.02rem; line-height: 1.7; color: var(--sa-ink); }
.sa-testi-card__author { display: flex; align-items: center; gap: .75rem; margin-top: auto; }
.sa-testi-card__avatar {
	width: 42px; height: 42px; border-radius: 50%; flex: none;
	background: var(--sa-maroon); color: #fff; display: grid; place-items: center;
	font-family: var(--sa-display); font-weight: 600;
}
.sa-testi-card__name { font-weight: 600; font-size: .92rem; }
.sa-testi-card__meta { font-size: .78rem; color: var(--sa-ink-soft); }
@media (min-width: 760px) { .sa-testi__grid { grid-template-columns: repeat(3, 1fr); } }

/* ========================== BUNDLE CTA ================================ */
.sa-bundle-cta {
	margin: var(--sa-section) var(--sa-gutter); padding: clamp(2.5rem,6vw,4.5rem) var(--sa-gutter);
	max-width: var(--sa-maxw);
	background: linear-gradient(135deg, var(--sa-maroon), var(--sa-maroon-deep));
	color: #fff; border-radius: calc(var(--sa-radius) + 8px); text-align: center;
	box-shadow: var(--sa-shadow);
}
@media (min-width: 1264px) { .sa-bundle-cta { margin-inline: auto; } }
.sa-bundle-cta__inner { max-width: 720px; margin: 0 auto; }
.sa-bundle-cta__label { color: var(--sa-gold-soft); font-weight: 700; letter-spacing: .18em; text-transform: uppercase; font-size: .76rem; display: inline-flex; gap: .5em; }
.sa-bundle-cta__title { font-family: var(--sa-display); font-weight: 600; font-size: clamp(2rem,5vw,3rem); line-height: 1.1; margin: 1rem 0 0; }
.sa-bundle-cta__title em { font-style: italic; color: var(--sa-gold-soft); }
.sa-bundle-cta__sub { margin: 1.2rem auto 0; max-width: 52ch; line-height: 1.7; color: rgba(255,255,255,.85); }
.sa-bundle-cta__products { display: flex; flex-wrap: wrap; gap: .6rem; justify-content: center; margin-top: 2rem; }
.sa-bundle-cta__product-chip {
	display: inline-flex; align-items: center; gap: .4em;
	background: rgba(255,255,255,.1); border: 1px solid rgba(255,255,255,.2);
	padding: .5em 1em; border-radius: 100px; font-size: .85rem; font-weight: 500;
}
.sa-bundle-cta__actions { display: flex; flex-wrap: wrap; gap: .85rem; justify-content: center; margin-top: 2.2rem; }
.sa-bundle-cta__btn-primary, .sa-bundle-cta__btn-wa {
	display: inline-flex; align-items: center; gap: .55em;
	padding: .95em 1.8em; border-radius: 100px; font-weight: 600; font-size: .96rem; text-decoration: none;
	transition: transform .25s, background .25s;
}
.sa-bundle-cta__btn-primary { background: var(--sa-gold); color: var(--sa-maroon-deep); }
.sa-bundle-cta__btn-primary:hover { background: var(--sa-gold-soft); transform: translateY(-2px); }
.sa-bundle-cta__btn-wa { background: rgba(255,255,255,.12); color: #fff; border: 1.5px solid rgba(255,255,255,.35); }
.sa-bundle-cta__btn-wa:hover { background: rgba(255,255,255,.2); transform: translateY(-2px); }

/* =========================== LOCATION ================================= */
.sa-location { padding: var(--sa-section) var(--sa-gutter); background: var(--sa-cream); }
.sa-location__inner {
	max-width: var(--sa-maxw); margin: 0 auto;
	display: grid; gap: clamp(2rem,5vw,3.5rem); grid-template-columns: 1fr; align-items: center;
}
.sa-location__info-list { font-style: normal; display: grid; gap: 1.3rem; margin-top: 2rem; }
.sa-location__info-item { display: flex; gap: 1rem; align-items: flex-start; }
.sa-location__info-icon {
	font-size: 1.3rem; flex: none; width: 48px; height: 48px; border-radius: 14px;
	background: #fff; border: 1px solid var(--sa-line); display: grid; place-items: center;
}
.sa-location__info-label { display: block; font-weight: 700; font-size: .82rem; letter-spacing: .04em; color: var(--sa-ink); }
.sa-location__info-value { display: block; color: var(--sa-ink-soft); line-height: 1.5; margin-top: .15rem; }
.sa-location__info-link { display: inline-block; margin-top: .35rem; color: var(--sa-maroon); font-weight: 600; font-size: .88rem; text-decoration: none; }
.sa-location__info-link:hover { text-decoration: underline; }
.sa-location__map-panel { position: relative; border-radius: var(--sa-radius); overflow: hidden; box-shadow: var(--sa-shadow); min-height: 320px; aspect-ratio: 4/3; }
.sa-location__map-iframe { width: 100%; height: 100%; border: 0; display: block; }
.sa-location__map-cta { position: absolute; bottom: 14px; left: 50%; transform: translateX(-50%); }
@media (min-width: 880px) { .sa-location__inner { grid-template-columns: 1fr 1fr; } }

/* ========================== BLOG PREVIEW ============================== */
.sa-blog-preview { padding: var(--sa-section) var(--sa-gutter); }
.sa-blog-preview__inner { max-width: var(--sa-maxw); margin: 0 auto; }
.sa-blog-preview__grid {
	margin-top: clamp(2rem,5vw,3rem);
	display: grid; gap: clamp(1.2rem,3vw,2rem); grid-template-columns: 1fr;
}
.sa-blog-card {
	display: flex; flex-direction: column; background: #fff;
	border: 1px solid var(--sa-line); border-radius: var(--sa-radius); overflow: hidden;
	transition: transform .3s, box-shadow .3s;
}
.sa-blog-card:hover { transform: translateY(-6px); box-shadow: var(--sa-shadow); }
.sa-blog-card__img-link { display: block; }
.sa-blog-card__img-wrap { aspect-ratio: 16/11; overflow: hidden; background: var(--sa-cream); }
.sa-blog-card__img { width: 100%; height: 100%; object-fit: cover; transition: transform .5s; }
.sa-blog-card:hover .sa-blog-card__img { transform: scale(1.06); }
.sa-blog-card__img-placeholder { width: 100%; height: 100%; display: grid; place-items: center; font-size: 2.5rem; }
.sa-blog-card__body { padding: 1.3rem; display: flex; flex-direction: column; gap: .6rem; flex: 1; }
.sa-blog-card__cat { align-self: flex-start; font-size: .72rem; letter-spacing: .1em; text-transform: uppercase; font-weight: 700; color: var(--sa-gold); text-decoration: none; }
.sa-blog-card__title { font-family: var(--sa-display); font-size: 1.12rem; font-weight: 600; line-height: 1.3; margin: 0; }
.sa-blog-card__title a { color: var(--sa-ink); text-decoration: none; }
.sa-blog-card__title a:hover { color: var(--sa-maroon); }
.sa-blog-card__excerpt { font-size: .9rem; line-height: 1.6; color: var(--sa-ink-soft); }
.sa-blog-card__footer { display: flex; align-items: center; justify-content: space-between; margin-top: auto; padding-top: .8rem; border-top: 1px solid var(--sa-line); }
.sa-blog-card__date { font-size: .8rem; color: var(--sa-ink-soft); }
.sa-blog-card__read-more { display: inline-flex; align-items: center; gap: .4em; font-size: .85rem; font-weight: 600; color: var(--sa-maroon); text-decoration: none; }
.sa-blog-card__read-more svg { transition: transform .25s; }
.sa-blog-card__read-more:hover svg { transform: translateX(3px); }
.sa-blog-preview__footer { text-align: center; margin-top: clamp(2rem,5vw,3rem); }
@media (min-width: 720px) { .sa-blog-preview__grid { grid-template-columns: repeat(3, 1fr); } }

/* ============================ FINAL CTA =============================== */
.sa-final-cta {
	padding: var(--sa-section) var(--sa-gutter);
	background:
		radial-gradient(100% 120% at 50% 0%, rgba(190,149,64,.16), transparent 55%),
		var(--sa-ivory);
	text-align: center;
}
.sa-final-cta__inner { max-width: 680px; margin: 0 auto; }
.sa-final-cta__kicker { font-size: .76rem; letter-spacing: .18em; text-transform: uppercase; font-weight: 700; color: var(--sa-gold); }
.sa-final-cta__title { font-family: var(--sa-display); font-weight: 600; font-size: clamp(2.2rem,6vw,3.6rem); line-height: 1.08; margin: 1rem 0 0; }
.sa-final-cta__title em { font-style: italic; color: var(--sa-maroon); }
.sa-final-cta__sub { margin: 1.2rem auto 0; max-width: 50ch; line-height: 1.7; color: var(--sa-ink-soft); }
.sa-final-cta__actions { display: flex; flex-wrap: wrap; gap: .85rem; justify-content: center; margin-top: 2.2rem; }
.sa-final-cta__wa { display: inline-flex; align-items: center; gap: .5em; margin-top: 1.6rem; font-size: .86rem; color: var(--sa-ink-soft); }
.sa-final-cta__wa svg { color: #128C7E; }

/* =====================================================================
   WOOCOMMERCE — light, override-free theming (scoped to .sa-heritage)
   Styles WooCommerce's own markup; no template files replaced, so core
   updates can never break cart/checkout rendering.
   ===================================================================== */
.sa-heritage.woocommerce ul.products li.product .button,
.sa-heritage .woocommerce #respond input#submit,
.sa-heritage .woocommerce a.button,
.sa-heritage .woocommerce button.button,
.sa-heritage .woocommerce input.button {
	background: var(--sa-maroon); color: #fff; border-radius: 100px;
	font-family: var(--sa-body); font-weight: 600; padding: .7em 1.4em; border: 0;
	transition: background .2s, transform .2s;
}
.sa-heritage.woocommerce ul.products li.product .button:hover,
.sa-heritage .woocommerce a.button:hover,
.sa-heritage .woocommerce button.button:hover,
.sa-heritage .woocommerce input.button:hover { background: var(--sa-maroon-deep); transform: translateY(-1px); }

.sa-heritage .woocommerce .price,
.sa-heritage .woocommerce ul.products li.product .price { color: var(--sa-maroon); font-weight: 700; }

.sa-heritage.woocommerce ul.products li.product {
	background: #fff; border: 1px solid var(--sa-line); border-radius: var(--sa-radius);
	padding: 1rem; transition: transform .3s, box-shadow .3s;
}
.sa-heritage.woocommerce ul.products li.product:hover { transform: translateY(-5px); box-shadow: var(--sa-shadow); }
.sa-heritage.woocommerce ul.products li.product h2,
.sa-heritage.woocommerce ul.products li.product .woocommerce-loop-product__title {
	font-family: var(--sa-display); font-weight: 600; font-size: 1.05rem; color: var(--sa-ink);
}
.sa-heritage .woocommerce-message,
.sa-heritage .woocommerce-info { border-top-color: var(--sa-gold); }
.sa-heritage .woocommerce span.onsale {
	background: var(--sa-gold); color: var(--sa-maroon-deep); font-weight: 700; border-radius: 100px;
}
.sa-heritage .single-product div.product .product_title {
	font-family: var(--sa-display); font-weight: 600; color: var(--sa-ink);
}

/* Focus visibility floor across all interactive elements */
.sa-heritage a:focus-visible,
.sa-heritage button:focus-visible { outline: 3px solid var(--sa-gold); outline-offset: 2px; border-radius: 4px; }

/* =====================================================================
   ELEMENTOR COMPATIBILITY — Path B opt-in helpers
   Add these classes to existing Elementor widgets (Advanced → CSS Classes)
   to inherit the Heritage look WITHOUT replacing the widget. All scoped to
   .sa-heritage so nothing leaks into admin or unrelated pages.
   ===================================================================== */

/* Turn an existing Elementor hero SECTION into the Heritage hero band. */
.sa-heritage .sa-elementor-hero {
	background:
		radial-gradient(120% 90% at 85% -10%, rgba(190,149,64,.18), transparent 60%),
		linear-gradient(180deg, var(--sa-cream), var(--sa-ivory)) !important;
}
.sa-heritage .sa-elementor-hero h1,
.sa-heritage .sa-elementor-hero h2 {
	font-family: var(--sa-display) !important;
	letter-spacing: -.01em;
	color: var(--sa-ink);
}
.sa-heritage .sa-elementor-hero em { font-style: italic; color: var(--sa-maroon); }

/* Heritage section-title treatment on an Elementor Heading widget. */
.sa-heritage .sa-sec-header .elementor-heading-title,
.sa-heritage .sa-elementor-heading {
	font-family: var(--sa-display) !important;
	font-weight: 600;
	color: var(--sa-ink);
}

/* Let Elementor Button widgets adopt the Heritage button system: set the
   button's CSS-class field to e.g. "sa-btn sa-btn--primary". The .sa-btn rules
   above already apply; this just neutralises Elementor's default chrome. */
.sa-heritage .elementor-button.sa-btn {
	background-image: none;
	box-shadow: var(--sa-shadow);
}

/* Footer link hover, if you tag an Elementor footer section sa-elementor-footer */
.sa-heritage .sa-elementor-footer a:hover { color: var(--sa-gold); }
