/* =========================================================
   Sora & Stone — WordPress theme stylesheet
   Mobile-first; tokens ported from design_handoff_sora_and_stone/colors_and_type.css
   Breakpoints (min-width): 600 sm, 880 md, 1100 lg
   ========================================================= */

:root {
	--stone:        #3D3530;
	--ink:          #2A2420;
	--cream:        #F7F3ED;
	--mist:         #E8E4DF;
	--sand:         #C9B99A;
	--soft-gold:    #C9A86B;
	--dusty-rose:   #D4A99A;
	--silver:       #B8BFC6;

	--fg-1: var(--ink);
	--fg-2: #5A4F48;
	--fg-3: #7A6E67;
	--fg-4: #9A8E87;
	--fg-on-dark: var(--cream);

	--bg:        var(--cream);
	--bg-card:   #FFFFFF;
	--bg-soft:   #FBF8F3;
	--bg-dark:   var(--stone);

	--border-hairline: 1px solid var(--mist);

	--r-sm:   4px;
	--r-md:   6px;
	--r-lg:   8px;
	--r-pill: 100px;

	--shadow-1: 0 2px 12px rgba(61,53,48,0.08);
	--shadow-2: 0 8px 28px rgba(61,53,48,0.12);

	--space-1: 4px;
	--space-2: 8px;
	--space-3: 12px;
	--space-4: 16px;
	--space-5: 20px;
	--space-6: 24px;
	--space-8: 32px;
	--space-10: 40px;
	--space-12: 48px;
	--space-16: 64px;
	--space-20: 80px;
	--space-24: 96px;

	--gutter:   20px;
	--maxw:     1200px;

	--font-display: 'Cormorant Garamond', Garamond, 'Times New Roman', serif;
	--font-body:    'Jost', 'Helvetica Neue', system-ui, sans-serif;

	--fs-cover:   clamp(40px, 9vw, 88px);
	--fs-h1:      clamp(32px, 7vw, 56px);
	--fs-h2:      clamp(26px, 5vw, 40px);
	--fs-h3:      22px;
	--fs-body:    15px;
	--fs-body-lg: 17px;
	--fs-small:   13px;
	--fs-cap:     11px;
	--fs-eyebrow: 10px;
	--fs-micro:   9px;

	--tracking-tight:    -0.01em;
	--tracking-display:   0.03em;
	--tracking-wordmark:  0.08em;
	--tracking-cap:       0.15em;
	--tracking-eyebrow:   0.35em;
	--tracking-micro:     0.4em;

	--leading-tight: 1.1;
	--leading-snug:  1.3;
	--leading-body:  1.7;

	--ease: cubic-bezier(0.22, 0.61, 0.36, 1);
	--dur-state:    220ms;
	--dur-entrance: 420ms;
}

/* -------- Base reset -------- */
*, *::before, *::after { box-sizing: border-box; }

html { scroll-behavior: smooth; }

body {
	margin: 0;
	background: var(--bg);
	color: var(--fg-2);
	font-family: var(--font-body);
	font-weight: 300;
	font-size: var(--fs-body);
	line-height: var(--leading-body);
	-webkit-font-smoothing: antialiased;
	text-rendering: optimizeLegibility;
}

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

h1, h2, h3, h4 {
	font-family: var(--font-display);
	color: var(--stone);
	font-weight: 300;
	line-height: var(--leading-tight);
	letter-spacing: var(--tracking-display);
	margin: 0 0 var(--space-6);
}
h1 { font-size: var(--fs-h1); }
h2 { font-size: var(--fs-h2); }
h3 { font-size: var(--fs-h3); font-weight: 400; }
h4 { font-size: 18px; font-weight: 400; }

h1 em, h2 em, h3 em, h4 em { font-style: italic; color: var(--dusty-rose); }

p { margin: 0 0 var(--space-4); color: var(--fg-2); }
p strong { font-weight: 500; color: var(--stone); }

a {
	color: var(--stone);
	text-decoration: underline;
	text-decoration-color: var(--mist);
	text-underline-offset: 3px;
	transition: color var(--dur-state) var(--ease), text-decoration-color var(--dur-state) var(--ease);
}
a:hover { color: var(--ink); text-decoration-color: var(--sand); }

::selection { background: var(--sand); color: var(--stone); }

:focus-visible {
	outline: 2px solid var(--soft-gold);
	outline-offset: 2px;
	border-radius: var(--r-sm);
}

/* Skip link */
.sas-skip {
	position: absolute; left: -9999px; top: -9999px;
	background: var(--stone); color: var(--cream);
	padding: 12px 16px;
	font-size: var(--fs-cap); letter-spacing: var(--tracking-cap); text-transform: uppercase;
}
.sas-skip:focus { left: 16px; top: 16px; z-index: 100; }

/* -------- Tokens-as-utilities -------- */
.sas-shell  { width: 100%; max-width: var(--maxw); margin: 0 auto; padding: 0 var(--gutter); }
.sas-eyebrow { font-family: var(--font-body); font-weight: 400; font-size: var(--fs-eyebrow); letter-spacing: var(--tracking-eyebrow); text-transform: uppercase; color: var(--soft-gold); margin-bottom: var(--space-3); }
.sas-caps    { font-family: var(--font-body); font-weight: 400; font-size: var(--fs-cap); letter-spacing: var(--tracking-cap); text-transform: uppercase; }

/* -------- Diamond marker -------- */
.sas-diamond { display: inline-block; background: var(--sand); transform: rotate(45deg); }

/* =========================================================
   Banner + Site header
   ========================================================= */
.sas-banner {
	background: var(--ink);
	color: var(--cream);
	border-bottom: 2px solid var(--soft-gold);
	padding: 12px 16px;
	font-family: var(--font-body);
	font-weight: 600;
	font-size: 11px;
	letter-spacing: 0.28em;
	text-transform: uppercase;
	text-align: center;
	overflow: hidden;
}
.sas-banner__inner {
	display: flex; flex-wrap: wrap; gap: 8px 14px;
	justify-content: center; align-items: center;
}
.sas-banner__chunk { white-space: nowrap; }
.sas-banner__sep { color: var(--soft-gold); font-size: 13px; line-height: 1; }
.sas-banner__sep--rose { color: var(--dusty-rose); }

@media (min-width: 880px) {
	.sas-banner { font-size: 12px; letter-spacing: 0.32em; padding: 14px 16px; }
}

.sas-header {
	background: var(--cream);
	border-bottom: var(--border-hairline);
	position: sticky; top: 0; z-index: 30;
}
.sas-header__inner {
	display: grid;
	grid-template-columns: auto 1fr auto;
	align-items: center;
	gap: 12px;
	padding: 14px var(--gutter);
	max-width: var(--maxw); margin: 0 auto;
}
@media (min-width: 880px) {
	.sas-header__inner { grid-template-columns: 1fr auto 1fr; gap: 24px; padding: 18px 32px; }
}

.sas-nav-toggle {
	background: transparent; border: 0; padding: 6px;
	color: var(--stone); cursor: pointer;
	display: inline-flex; align-items: center; justify-content: center;
}
@media (min-width: 880px) { .sas-nav-toggle { display: none; } }

.sas-nav { display: none; }
@media (min-width: 880px) {
	.sas-nav { display: flex; gap: 28px; }
	.sas-nav a {
		font-family: var(--font-body); font-size: 11px; font-weight: 400;
		letter-spacing: 0.25em; text-transform: uppercase;
		color: var(--stone); text-decoration: none;
		position: relative; padding: 4px 0;
	}
	.sas-nav a::after {
		content: ''; position: absolute; left: 50%; bottom: 0;
		width: 0; height: 1px; background: var(--dusty-rose);
		transition: width var(--dur-state) var(--ease), left var(--dur-state) var(--ease);
	}
	.sas-nav a:hover::after, .sas-nav a:focus-visible::after { width: 100%; left: 0; }
}

.sas-brand {
	font-family: var(--font-display); font-weight: 300; font-size: 22px;
	letter-spacing: var(--tracking-wordmark);
	text-align: center; color: var(--stone);
	white-space: nowrap; text-decoration: none;
	display: inline-block;
}
.sas-brand:hover { color: var(--stone); text-decoration: none; }
.sas-brand em { font-style: italic; color: var(--sand); }
.sas-brand__sub {
	display: block; font-family: var(--font-body); font-style: normal;
	font-size: 7px; letter-spacing: 0.45em; color: var(--soft-gold);
	margin-top: 3px;
}
@media (min-width: 880px) { .sas-brand { font-size: 26px; } .sas-brand__sub { font-size: 8px; } }

.sas-icons { display: flex; gap: 10px; justify-content: flex-end; align-items: center; }
@media (min-width: 880px) { .sas-icons { gap: 16px; } }

.sas-iconbtn {
	background: transparent; border: 0; cursor: pointer;
	width: 36px; height: 36px; padding: 0;
	display: inline-flex; align-items: center; justify-content: center;
	color: var(--stone); position: relative;
	transition: color var(--dur-state) var(--ease), transform var(--dur-state) var(--ease);
	text-decoration: none;
}
.sas-iconbtn:hover, .sas-iconbtn:focus-visible { color: var(--dusty-rose); transform: translateY(-1px); text-decoration: none; }
.sas-iconbtn--wishlist { color: var(--dusty-rose); }
.sas-iconbtn__pill {
	position: absolute; top: 2px; right: 2px;
	min-width: 16px; height: 16px; padding: 0 4px;
	border-radius: var(--r-pill);
	background: var(--dusty-rose); color: var(--cream);
	font-family: var(--font-body); font-size: 9px; font-weight: 600;
	display: flex; align-items: center; justify-content: center;
	box-shadow: 0 0 0 2px var(--cream);
	letter-spacing: 0;
}

/* Mobile slide-in nav drawer */
.sas-mobile-nav {
	position: fixed; inset: 0 30% 0 0;
	background: var(--cream);
	transform: translateX(-100%);
	transition: transform 320ms var(--ease);
	z-index: 70;
	display: flex; flex-direction: column;
	padding: var(--space-8) var(--space-6);
	box-shadow: 8px 0 28px rgba(61,53,48,0.12);
}
.sas-mobile-nav.is-open { transform: translateX(0); }
.sas-mobile-nav__close { align-self: flex-end; }
.sas-mobile-nav ul { list-style: none; padding: 0; margin: var(--space-4) 0 0; }
.sas-mobile-nav a {
	display: block; padding: 14px 0;
	font-family: var(--font-body); font-size: 13px; letter-spacing: 0.25em;
	text-transform: uppercase; color: var(--stone);
	text-decoration: none; border-bottom: var(--border-hairline);
}

/* =========================================================
   Buttons
   ========================================================= */
.sas-btn {
	font-family: var(--font-body); font-weight: 400; font-size: 11px;
	letter-spacing: 0.3em; text-transform: uppercase;
	padding: 14px 28px; border-radius: var(--r-sm);
	border: 0; cursor: pointer;
	display: inline-flex; align-items: center; justify-content: center;
	white-space: nowrap; text-decoration: none;
	transition: background var(--dur-state) var(--ease),
	            color var(--dur-state) var(--ease),
	            transform var(--dur-state) var(--ease),
	            box-shadow var(--dur-state) var(--ease);
}
.sas-btn--primary { background: var(--stone); color: var(--cream); }
.sas-btn--primary:hover, .sas-btn--primary:focus-visible {
	background: var(--ink); color: var(--cream); text-decoration: none;
	box-shadow: inset 0 -2px 0 var(--soft-gold);
}
.sas-btn--primary:active { transform: scale(0.98); }
.sas-btn--outline { background: transparent; color: var(--stone); border: 1px solid var(--stone); }
.sas-btn--outline:hover { background: var(--stone); color: var(--cream); text-decoration: none; }
.sas-btn--ghost {
	background: transparent; border: 0; color: var(--stone); padding: 0;
	font-family: var(--font-body); font-size: 11px; letter-spacing: 0.3em;
	text-transform: uppercase;
}
.sas-btn--ghost::after { content: ' →'; }
.sas-btn--ghost:hover { color: var(--sand); }
.sas-btn--block { width: 100%; padding: 16px; }

@keyframes sasFlash {
	0%, 100% { background: var(--stone); }
	30%      { background: var(--dusty-rose); }
}
.sas-btn--primary.is-flashing { animation: sasFlash 700ms var(--ease); }

/* =========================================================
   Hero
   ========================================================= */
.sas-hero {
	background: var(--stone); color: var(--cream);
	padding: var(--space-16) var(--gutter);
	position: relative; overflow: hidden;
}
.sas-hero__inner {
	max-width: var(--maxw); margin: 0 auto;
	position: relative; z-index: 1;
	display: grid; grid-template-columns: 1fr; gap: var(--space-10); align-items: center;
}
@media (min-width: 880px) {
	.sas-hero { padding: var(--space-24) var(--gutter); }
	.sas-hero__inner { grid-template-columns: 1fr 1fr; gap: var(--space-12); }
}

.sas-hero__eyebrow {
	font-family: var(--font-body); font-size: var(--fs-eyebrow); letter-spacing: var(--tracking-micro);
	text-transform: uppercase; color: var(--sand); margin-bottom: var(--space-5);
	display: inline-flex; align-items: center; gap: 12px;
}
.sas-hero__eyebrow::before {
	content: ''; width: 24px; height: 1px; background: var(--dusty-rose);
}
.sas-hero__title {
	font-family: var(--font-display); font-weight: 300;
	font-size: clamp(36px, 8vw, 64px);
	line-height: 1.1; color: var(--cream);
	letter-spacing: 0.02em; margin: 0 0 var(--space-5);
}
.sas-hero__title em { font-style: italic; color: var(--sand); }
.sas-hero__body {
	font-family: var(--font-body); font-weight: 300; font-size: 15px;
	line-height: 1.7; color: rgba(247,243,237,0.78);
	max-width: 460px; margin: 0 0 var(--space-8);
}
@media (min-width: 880px) { .sas-hero__body { font-size: 16px; } }
.sas-hero__ctas { display: flex; flex-wrap: wrap; gap: 12px; }
.sas-hero__ctas .sas-btn--ghost-on-dark {
	background: transparent; color: var(--cream);
	border: 1px solid rgba(247,243,237,0.4);
}
.sas-hero__ctas .sas-btn--ghost-on-dark:hover { background: rgba(247,243,237,0.08); }

.sas-hero__art {
	position: relative; aspect-ratio: 1;
	width: 100%; max-width: 460px; margin: 0 auto;
	background:
		radial-gradient(circle at 50% 55%, rgba(201,185,154,0.55) 0%, rgba(201,185,154,0.08) 35%, transparent 60%),
		radial-gradient(ellipse at 35% 30%, rgba(184,191,198,0.25) 0%, transparent 50%);
}
.sas-hero__art::after {
	content: ''; position: absolute; left: 50%; top: 55%; transform: translate(-50%, -50%);
	width: 36%; height: 14%;
	background: linear-gradient(120deg, #c9b99a 0%, #b8bfc6 50%, #d4a99a 100%);
	border-radius: 50%; filter: blur(0.5px);
	box-shadow: 0 6px 24px rgba(0,0,0,0.4);
}
.sas-hero__rings,
.sas-hero__rings::before,
.sas-hero__rings::after {
	position: absolute; border-radius: 50%; border: 1px solid rgba(201,185,154,0.25);
}
.sas-hero__rings { display: none; }
@media (min-width: 880px) {
	.sas-hero__rings { display: block; width: 480px; height: 480px; right: -120px; top: 50%; transform: translateY(-50%); }
	.sas-hero__rings::before, .sas-hero__rings::after { content: ''; top: 50%; left: 50%; transform: translate(-50%,-50%); }
	.sas-hero__rings::before { width: 320px; height: 320px; border-color: rgba(201,185,154,0.18); }
	.sas-hero__rings::after  { width: 180px; height: 180px; border-color: rgba(201,185,154,0.32); }
}

/* =========================================================
   Sections
   ========================================================= */
.sas-section { padding: var(--space-16) var(--gutter); }
@media (min-width: 880px) { .sas-section { padding: var(--space-24) var(--gutter); } }

.sas-section__head { text-align: center; margin-bottom: var(--space-10); }
.sas-section__eyebrow {
	font-family: var(--font-body); font-size: var(--fs-eyebrow); letter-spacing: var(--tracking-eyebrow);
	text-transform: uppercase; color: var(--soft-gold); margin-bottom: 12px;
}
.sas-section__title {
	font-family: var(--font-display); font-weight: 300;
	font-size: clamp(28px, 6vw, 48px);
	color: var(--stone); letter-spacing: 0.02em; margin: 0;
}
.sas-section__title em { font-style: italic; color: var(--dusty-rose); }

/* =========================================================
   Product card / grid
   ========================================================= */
.sas-grid {
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: var(--space-5);
	max-width: var(--maxw); margin: 0 auto;
}
@media (min-width: 600px) { .sas-grid { gap: var(--space-6); } }
@media (min-width: 880px) { .sas-grid { grid-template-columns: repeat(3, 1fr); gap: var(--space-8); } }

.sas-card { display: flex; flex-direction: column; }
.sas-card__link {
	text-decoration: none; color: inherit;
	display: block;
	transition: transform var(--dur-state) var(--ease);
}
.sas-card__link:hover { transform: translateY(-2px); text-decoration: none; }
.sas-card__media {
	aspect-ratio: 4 / 5;
	border-radius: var(--r-sm);
	border: var(--border-hairline);
	background: var(--bg-soft);
	position: relative; overflow: hidden;
}
.sas-card__media img {
	width: 100%; height: 100%; object-fit: cover;
	transition: transform 600ms var(--ease);
}
.sas-card__link:hover .sas-card__media img { transform: scale(1.02); }
.sas-card__badge {
	position: absolute; top: 10px; left: 10px;
	background: var(--cream); color: var(--stone);
	font-family: var(--font-body); font-size: 9px;
	letter-spacing: 0.3em; text-transform: uppercase;
	padding: 5px 11px; border-radius: var(--r-pill);
}
.sas-card__name {
	font-family: var(--font-display); font-weight: 400; font-size: 17px;
	color: var(--stone); line-height: 1.2;
	margin: 12px 0 4px;
}
@media (min-width: 880px) { .sas-card__name { font-size: 18px; margin-top: 14px; } }
.sas-card__meta {
	font-family: var(--font-body); font-size: 11px; color: var(--fg-3);
	letter-spacing: 0.04em;
}
.sas-card__edition {
	font-family: var(--font-display); font-style: italic;
	font-size: 12px; color: var(--soft-gold);
	margin-top: 4px;
}
.sas-card__price {
	font-family: var(--font-body); font-size: 14px; color: var(--stone);
	margin-top: 6px; font-weight: 400;
}
.sas-card__price .sas-card__price--was { color: var(--fg-3); text-decoration: line-through; margin-right: 8px; }

.sas-card__add {
	margin-top: var(--space-3);
	width: 100%;
	padding: 10px 14px; font-size: 10px; letter-spacing: 0.25em;
}

/* Edition mark — used on cards and PDP */
.sas-edition {
	font-family: var(--font-display); font-style: italic;
	font-size: 13px; color: var(--soft-gold);
	letter-spacing: 0.04em;
}
.sas-edition span { font-style: normal; }

/* =========================================================
   Shop archive layout
   ========================================================= */
.sas-shop { max-width: var(--maxw); margin: 0 auto; padding: var(--space-10) var(--gutter) var(--space-24); }

.sas-shop__head { text-align: center; margin-bottom: var(--space-10); }
.sas-shop__title {
	font-family: var(--font-display); font-weight: 300;
	font-size: clamp(32px, 6vw, 56px);
	color: var(--stone); letter-spacing: 0.02em; margin: 0 0 12px;
}
.sas-shop__title em { font-style: italic; color: var(--dusty-rose); }
.sas-shop__blurb { font-family: var(--font-body); font-size: 14px; color: var(--fg-3); }

.sas-shop__layout { display: grid; grid-template-columns: 1fr; gap: var(--space-8); }
@media (min-width: 880px) {
	.sas-shop__layout { grid-template-columns: 220px 1fr; gap: var(--space-12); }
}

/* Filter rail — collapses to a top bar with a toggle on mobile */
.sas-filter { font-family: var(--font-body); }
.sas-filter__toggle {
	display: flex; width: 100%;
	justify-content: space-between; align-items: center;
	background: transparent; border: var(--border-hairline);
	border-radius: var(--r-sm);
	padding: 12px 16px; cursor: pointer;
	font-family: var(--font-body); font-size: 11px; letter-spacing: 0.25em;
	text-transform: uppercase; color: var(--stone);
}
@media (min-width: 880px) { .sas-filter__toggle { display: none; } }

.sas-filter__body { display: none; padding-top: var(--space-4); }
.sas-filter.is-open .sas-filter__body { display: block; }
@media (min-width: 880px) { .sas-filter__body { display: block; padding-top: 0; } }

.sas-filter__group { border-bottom: var(--border-hairline); padding: 14px 0; }
.sas-filter__h {
	width: 100%; background: transparent; border: 0; padding: 4px 0;
	font-family: var(--font-body); font-size: 11px; letter-spacing: 0.3em;
	text-transform: uppercase; color: var(--stone); cursor: pointer;
	display: flex; justify-content: space-between; align-items: center;
}
.sas-filter__list { list-style: none; padding: 14px 0 4px; margin: 0; display: flex; flex-direction: column; gap: 8px; }
.sas-filter__opt { display: flex; gap: 10px; align-items: center; font-size: 13px; color: var(--fg-2); }
.sas-filter__opt input { accent-color: var(--stone); }

.sas-shop__bar {
	display: flex; flex-wrap: wrap; gap: 12px;
	justify-content: space-between; align-items: center;
	padding-bottom: 18px; border-bottom: var(--border-hairline);
	margin-bottom: var(--space-8);
}
.sas-shop__count { font-family: var(--font-body); font-size: 11px; letter-spacing: 0.25em; text-transform: uppercase; color: var(--fg-3); }
.sas-shop__sort { display: flex; gap: 12px; align-items: center; font-size: 11px; letter-spacing: 0.25em; text-transform: uppercase; color: var(--stone); }
.sas-shop__sort select {
	font-family: var(--font-body); font-size: 13px; border: var(--border-hairline);
	background: #fff; padding: 8px 12px; border-radius: var(--r-sm);
	color: var(--stone); letter-spacing: 0; text-transform: none;
}

/* WooCommerce pagination */
.woocommerce-pagination { margin-top: var(--space-12); text-align: center; }
.woocommerce-pagination ul.page-numbers {
	display: inline-flex; gap: 6px; list-style: none; padding: 0; margin: 0;
}
.woocommerce-pagination .page-numbers {
	display: inline-flex; align-items: center; justify-content: center;
	min-width: 36px; height: 36px; padding: 0 12px;
	font-family: var(--font-body); font-size: 12px;
	color: var(--stone); text-decoration: none;
	border: var(--border-hairline); border-radius: var(--r-sm);
}
.woocommerce-pagination .page-numbers.current { background: var(--stone); color: var(--cream); border-color: var(--stone); }
.woocommerce-pagination .page-numbers:hover { border-color: var(--stone); }

/* =========================================================
   Single product (PDP)
   ========================================================= */
.sas-pdp { padding: var(--space-10) var(--gutter) var(--space-24); }
.sas-pdp__grid {
	max-width: var(--maxw); margin: 0 auto;
	display: grid; grid-template-columns: 1fr; gap: var(--space-10);
}
@media (min-width: 880px) {
	.sas-pdp__grid { grid-template-columns: 1.1fr 1fr; gap: var(--space-16); align-items: start; }
}

.sas-pdp__gallery { display: flex; flex-direction: column; gap: 12px; }
.sas-pdp__main {
	aspect-ratio: 1; border-radius: var(--r-sm); border: var(--border-hairline);
	overflow: hidden; background: var(--bg-soft);
}
.sas-pdp__main img { width: 100%; height: 100%; object-fit: cover; }
.sas-pdp__thumbs { display: grid; grid-template-columns: repeat(4, 1fr); gap: 12px; }
.sas-pdp__thumb {
	aspect-ratio: 1; border-radius: var(--r-sm); border: var(--border-hairline);
	overflow: hidden; cursor: pointer; background: var(--bg-soft);
}
.sas-pdp__thumb img { width: 100%; height: 100%; object-fit: cover; }
.sas-pdp__thumb.is-active { border-color: var(--stone); }

.sas-pdp__info { padding-top: 4px; }
@media (min-width: 880px) { .sas-pdp__info { position: sticky; top: 100px; padding-top: 12px; } }

.sas-pdp__back {
	background: transparent; border: 0; color: var(--fg-3);
	font-family: var(--font-body); font-size: 11px; letter-spacing: 0.25em;
	text-transform: uppercase; padding: 0; margin-bottom: 18px; cursor: pointer;
	text-decoration: none;
}
.sas-pdp__cat {
	font-family: var(--font-body); font-size: 10px; letter-spacing: 0.35em;
	text-transform: uppercase; color: var(--soft-gold); margin-bottom: 14px;
}
.sas-pdp__name {
	font-family: var(--font-display); font-weight: 300;
	font-size: clamp(28px, 6vw, 44px);
	line-height: 1.1; color: var(--stone);
	letter-spacing: 0.02em; margin: 8px 0 18px;
}
.sas-pdp__name em { font-style: italic; color: var(--dusty-rose); }
.sas-pdp__price {
	font-family: var(--font-body); font-size: 20px; color: var(--stone);
	margin-bottom: 24px; font-weight: 400;
}
.sas-pdp__price del { color: var(--fg-3); margin-right: 10px; }
.sas-pdp__price ins { text-decoration: none; }
.sas-pdp__body { font-family: var(--font-body); font-weight: 300; font-size: 15px; line-height: 1.75; color: var(--fg-2); }

.sas-pdp__divider { display: flex; align-items: center; gap: 14px; margin: var(--space-8) 0; }
.sas-pdp__divider::before, .sas-pdp__divider::after { content: ''; flex: 1; height: 1px; background: var(--mist); }

.sas-spec-row {
	display: flex; justify-content: space-between;
	padding: 12px 0; border-bottom: var(--border-hairline);
	font-family: var(--font-body); font-size: 13px;
}
.sas-spec-row .k { color: var(--fg-3); letter-spacing: 0.05em; }
.sas-spec-row .v { color: var(--stone); }

.sas-cta-row { display: flex; gap: 12px; margin: var(--space-8) 0 var(--space-6); align-items: stretch; }
.sas-qty {
	display: inline-flex; align-items: stretch;
	border: var(--border-hairline); border-radius: var(--r-sm); background: #fff;
}
.sas-qty button {
	background: transparent; border: 0; width: 38px;
	font-family: var(--font-display); font-size: 20px; color: var(--stone); cursor: pointer;
}
.sas-qty input {
	width: 44px; border: 0; background: transparent;
	font-family: var(--font-body); font-size: 14px; color: var(--stone);
	text-align: center; -moz-appearance: textfield;
}
.sas-qty input::-webkit-outer-spin-button,
.sas-qty input::-webkit-inner-spin-button { -webkit-appearance: none; margin: 0; }

.sas-pdp__cta { flex: 1; }
.sas-pdp__small {
	font-family: var(--font-body); font-size: 12px; color: var(--fg-3);
	letter-spacing: 0.04em; line-height: 1.7;
}

/* WooCommerce tabs (description / specs) */
.woocommerce-tabs { max-width: var(--maxw); margin: var(--space-16) auto 0; padding: 0 var(--gutter); }
.woocommerce-tabs ul.tabs { list-style: none; padding: 0; margin: 0 0 var(--space-6); display: flex; flex-wrap: wrap; gap: 24px; border-bottom: var(--border-hairline); }
.woocommerce-tabs ul.tabs li a {
	display: inline-block; padding: 12px 0;
	font-family: var(--font-body); font-size: 11px; letter-spacing: 0.3em;
	text-transform: uppercase; color: var(--fg-3); text-decoration: none;
}
.woocommerce-tabs ul.tabs li.active a { color: var(--stone); border-bottom: 1px solid var(--stone); }

/* WooCommerce notices */
.woocommerce-notices-wrapper { padding: 0 var(--gutter); max-width: var(--maxw); margin: 0 auto; }
.woocommerce-message, .woocommerce-info, .woocommerce-error {
	font-family: var(--font-body); font-size: 13px;
	background: var(--bg-soft); border: var(--border-hairline); border-left: 3px solid var(--soft-gold);
	padding: 14px 18px; border-radius: var(--r-sm); margin-bottom: var(--space-5);
	color: var(--fg-2); list-style: none;
}
.woocommerce-error { border-left-color: var(--dusty-rose); }
.woocommerce-message a, .woocommerce-info a { color: var(--stone); }

/* =========================================================
   Cart drawer
   ========================================================= */
.sas-overlay {
	position: fixed; inset: 0;
	background: rgba(42,36,32,0.4);
	opacity: 0; pointer-events: none;
	transition: opacity 280ms var(--ease);
	z-index: 50;
}
.sas-overlay.is-open { opacity: 1; pointer-events: auto; }

.sas-drawer {
	position: fixed; top: 0; right: 0; height: 100dvh;
	width: 100%; max-width: 440px;
	background: var(--cream); z-index: 60;
	transform: translateX(100%);
	transition: transform 320ms var(--ease);
	display: flex; flex-direction: column;
	box-shadow: -8px 0 28px rgba(61,53,48,0.12);
}
.sas-drawer.is-open { transform: translateX(0); }
.sas-drawer__head {
	padding: 20px 22px; border-bottom: var(--border-hairline);
	display: flex; justify-content: space-between; align-items: center;
}
.sas-drawer__title {
	font-family: var(--font-display); font-size: 22px;
	color: var(--stone); font-weight: 300;
	margin: 0;
}
.sas-drawer__inner { flex: 1; display: flex; flex-direction: column; min-height: 0; }
.sas-drawer__body { flex: 1; overflow-y: auto; padding: 20px 22px; }
.sas-drawer__empty { text-align: center; padding: 56px 0; color: var(--fg-3); }
.sas-drawer__empty .e1 { font-family: var(--font-display); font-style: italic; font-size: 22px; color: var(--stone); margin-bottom: 8px; }

/* Mini-cart line item */
.sas-line {
	display: grid; grid-template-columns: 70px 1fr auto; gap: 14px;
	padding: 14px 0; border-bottom: var(--border-hairline); align-items: start;
}
.sas-line__media {
	aspect-ratio: 1; border-radius: var(--r-sm); border: var(--border-hairline);
	overflow: hidden; background: var(--bg-soft);
}
.sas-line__media img { width: 100%; height: 100%; object-fit: cover; }
.sas-line__name {
	font-family: var(--font-display); font-size: 16px; color: var(--stone);
	line-height: 1.2; margin: 0 0 4px; text-decoration: none;
}
.sas-line__meta { font-family: var(--font-body); font-size: 11px; color: var(--fg-3); letter-spacing: 0.04em; }
.sas-line__qty { display: inline-flex; align-items: center; gap: 4px; margin-top: 8px; font-size: 12px; color: var(--stone); }
.sas-line__qty button { background: transparent; border: var(--border-hairline); width: 22px; height: 22px; border-radius: 3px; cursor: pointer; color: var(--stone); }
.sas-line__price { font-family: var(--font-body); font-size: 14px; color: var(--stone); padding-top: 2px; }
.sas-line__remove {
	background: transparent; border: 0; padding: 0; margin-top: 8px;
	font-family: var(--font-body); font-size: 10px; letter-spacing: 0.2em;
	text-transform: uppercase; color: var(--fg-3); cursor: pointer; text-decoration: none;
	display: inline-block;
}
.sas-line__remove:hover { color: var(--dusty-rose); }

.sas-drawer__foot { padding: 18px 22px 22px; border-top: var(--border-hairline); }
.sas-foot-row { display: flex; justify-content: space-between; font-family: var(--font-body); font-size: 13px; color: var(--fg-3); margin-bottom: 8px; }
.sas-foot-row.total { color: var(--stone); font-size: 16px; margin: 12px 0 16px; padding-top: 12px; border-top: var(--border-hairline); }
.sas-foot-row.total .v { font-weight: 500; }
.sas-foot-note { font-family: var(--font-body); font-size: 11px; color: var(--fg-3); text-align: center; margin-top: 12px; letter-spacing: 0.04em; }

/* WC mini-cart fallback markup */
.woocommerce-mini-cart__empty-message { font-family: var(--font-display); font-style: italic; font-size: 20px; color: var(--stone); text-align: center; padding: 56px 0 0; }
.woocommerce-mini-cart__buttons { display: flex; flex-direction: column; gap: 10px; padding: 0; margin: 0; }
.woocommerce-mini-cart__buttons .button { width: 100%; }

/* =========================================================
   Cart page
   ========================================================= */
.sas-cart-page { max-width: var(--maxw); margin: 0 auto; padding: var(--space-10) var(--gutter) var(--space-24); }
.woocommerce-cart-form table.shop_table {
	width: 100%; border-collapse: collapse;
	font-family: var(--font-body); font-size: 14px;
}
.woocommerce-cart-form table.shop_table th {
	font-family: var(--font-body); font-size: 11px; letter-spacing: 0.25em; text-transform: uppercase;
	color: var(--fg-3); text-align: left; padding: 12px 8px; border-bottom: var(--border-hairline);
}
.woocommerce-cart-form table.shop_table td { padding: 16px 8px; border-bottom: var(--border-hairline); vertical-align: middle; }
.woocommerce-cart-form .product-thumbnail img { width: 80px; border-radius: var(--r-sm); }
.woocommerce-cart-form .product-name a { font-family: var(--font-display); font-size: 18px; color: var(--stone); text-decoration: none; }
.woocommerce-cart-form .quantity input { width: 64px; padding: 8px; border: var(--border-hairline); border-radius: var(--r-sm); text-align: center; }
.cart-collaterals { margin-top: var(--space-10); display: grid; grid-template-columns: 1fr; gap: var(--space-6); }
@media (min-width: 880px) { .cart-collaterals { grid-template-columns: 1fr 1fr; } }
.cart_totals h2 { font-size: 24px; }
.cart_totals table { width: 100%; }
.cart_totals th, .cart_totals td { padding: 10px 0; border-bottom: var(--border-hairline); font-size: 14px; text-align: left; }

/* On narrow screens render cart rows as stacked cards. */
@media (max-width: 600px) {
	.woocommerce-cart-form table.shop_table thead { display: none; }
	.woocommerce-cart-form table.shop_table, .woocommerce-cart-form tbody, .woocommerce-cart-form tr, .woocommerce-cart-form td { display: block; width: 100%; }
	.woocommerce-cart-form tr { padding: var(--space-4) 0; border-bottom: var(--border-hairline); }
	.woocommerce-cart-form td { border: 0; padding: 4px 0; }
	.woocommerce-cart-form td.product-remove { text-align: right; }
}

/* =========================================================
   Checkout
   ========================================================= */
.sas-checkout { max-width: var(--maxw); margin: 0 auto; padding: var(--space-10) var(--gutter) var(--space-24); }
.sas-checkout__steps {
	display: flex; gap: 12px; align-items: center;
	font-family: var(--font-body); font-size: 11px; letter-spacing: 0.25em;
	text-transform: uppercase; color: var(--fg-4); margin-bottom: var(--space-10);
}
.sas-checkout__steps .on { color: var(--stone); }
.sas-checkout__steps .done { color: var(--soft-gold); }
.sas-checkout__steps .sep { color: var(--mist); }

.woocommerce-checkout form.checkout {
	display: grid; grid-template-columns: 1fr; gap: var(--space-10);
}
@media (min-width: 880px) {
	.woocommerce-checkout form.checkout { grid-template-columns: 1.2fr 1fr; gap: var(--space-16); align-items: start; }
}
.woocommerce-checkout #order_review_heading,
.woocommerce-checkout #order_review {
	background: #fff; border: var(--border-hairline); border-radius: var(--r-md); padding: 24px;
}
@media (min-width: 880px) {
	.woocommerce-checkout #order_review_heading,
	.woocommerce-checkout #order_review { position: sticky; top: 100px; }
	.woocommerce-checkout #order_review_heading { margin-bottom: 0; border-bottom: 0; border-radius: var(--r-md) var(--r-md) 0 0; }
	.woocommerce-checkout #order_review { border-top: 0; border-radius: 0 0 var(--r-md) var(--r-md); }
}

.woocommerce-checkout h3 {
	font-family: var(--font-display); font-weight: 300; font-size: 26px;
	color: var(--stone); margin: 0 0 var(--space-5);
}
.woocommerce-checkout .form-row {
	display: flex; flex-direction: column; gap: 6px; margin-bottom: var(--space-4);
}
.woocommerce-checkout .form-row label {
	font-family: var(--font-body); font-size: 10px; letter-spacing: 0.2em;
	text-transform: uppercase; color: var(--stone);
}
.woocommerce-checkout .form-row input,
.woocommerce-checkout .form-row textarea,
.woocommerce-checkout .form-row select,
.woocommerce-checkout .select2-selection {
	font-family: var(--font-body); font-weight: 300; font-size: 14px; color: var(--stone);
	background: #fff; border: var(--border-hairline); border-radius: var(--r-sm);
	padding: 12px 14px; outline: none; min-height: 46px;
}
.woocommerce-checkout .form-row input:focus,
.woocommerce-checkout .form-row textarea:focus,
.woocommerce-checkout .form-row select:focus { border-color: var(--soft-gold); box-shadow: 0 0 0 2px rgba(201,168,107,0.18); }
@media (min-width: 600px) {
	.woocommerce-checkout .form-row-first, .woocommerce-checkout .form-row-last { display: inline-block; width: 49%; vertical-align: top; }
	.woocommerce-checkout .form-row-first { margin-right: 1.5%; }
}

#payment ul.payment_methods { list-style: none; padding: 0; margin: 0 0 var(--space-5); }
#payment ul.payment_methods li { padding: 14px; border: var(--border-hairline); border-radius: var(--r-sm); margin-bottom: 8px; }
#payment .place-order .button { width: 100%; }

/* =========================================================
   Editorial section
   ========================================================= */
.sas-editorial {
	background: var(--bg-soft);
	padding: var(--space-16) var(--gutter);
}
@media (min-width: 880px) { .sas-editorial { padding: var(--space-24) var(--gutter); } }
.sas-editorial__inner {
	max-width: var(--maxw); margin: 0 auto;
	display: grid; grid-template-columns: 1fr; gap: var(--space-10); align-items: center;
}
@media (min-width: 880px) { .sas-editorial__inner { grid-template-columns: 1fr 1fr; gap: var(--space-16); } }
.sas-editorial__art {
	aspect-ratio: 5/4; border-radius: var(--r-sm); position: relative; overflow: hidden;
	background: linear-gradient(135deg, #d4c4a4 0%, #a98f6a 100%);
}
.sas-editorial__art::before {
	content: ''; position: absolute; inset: 12%; border-radius: 50%;
	background: radial-gradient(circle at 35% 30%, rgba(255,255,255,0.4) 0%, transparent 50%), linear-gradient(135deg, #c9b99a 0%, #8a755a 100%);
	box-shadow: 0 12px 40px rgba(61,53,48,0.3);
}
.sas-editorial h2 {
	font-family: var(--font-display); font-weight: 300;
	font-size: clamp(28px, 5vw, 44px);
	line-height: 1.1; color: var(--stone);
	margin: 0 0 18px; letter-spacing: 0.02em;
}
.sas-editorial h2 em { font-style: italic; color: var(--dusty-rose); }
.sas-editorial p { font-size: 15px; line-height: 1.75; }

/* =========================================================
   Footer
   ========================================================= */
.sas-footer {
	background: var(--stone); color: rgba(247,243,237,0.7);
	padding: var(--space-16) var(--gutter) var(--space-10);
	margin-top: var(--space-20);
}
.sas-footer__inner {
	max-width: var(--maxw); margin: 0 auto;
	display: grid; grid-template-columns: 1fr; gap: var(--space-10);
}
@media (min-width: 600px) { .sas-footer__inner { grid-template-columns: 1fr 1fr; } }
@media (min-width: 880px) { .sas-footer__inner { grid-template-columns: 1.4fr 1fr 1fr 1fr; gap: var(--space-12); } }

.sas-footer__wm {
	font-family: var(--font-display); font-weight: 300; font-size: 30px;
	letter-spacing: 0.08em; color: var(--cream); margin-bottom: 10px;
}
.sas-footer__wm em { font-style: italic; color: var(--sand); }
.sas-footer__tag {
	font-family: var(--font-body); font-size: 9px; letter-spacing: 0.4em;
	text-transform: uppercase; color: var(--sand); margin-bottom: 22px;
}
.sas-footer__blurb {
	font-family: var(--font-body); font-size: 13px; line-height: 1.7;
	color: rgba(247,243,237,0.6); max-width: 320px; margin-bottom: 18px;
}
.sas-footer__news { display: flex; gap: 8px; max-width: 360px; }
.sas-footer__news input {
	flex: 1; background: transparent; border: 1px solid rgba(201,185,154,0.4);
	padding: 11px 14px; border-radius: var(--r-sm);
	font-family: var(--font-body); font-size: 13px; color: var(--cream); outline: none;
}
.sas-footer__news input::placeholder { color: rgba(247,243,237,0.45); }
.sas-footer__news button {
	background: var(--sand); color: var(--stone); border: 0;
	padding: 0 18px; border-radius: var(--r-sm);
	font-family: var(--font-body); font-size: 10px; letter-spacing: 0.25em;
	text-transform: uppercase; cursor: pointer;
}
.sas-footer h4 {
	font-family: var(--font-body); font-size: 10px; letter-spacing: 0.35em;
	text-transform: uppercase; color: var(--sand); margin: 0 0 16px; font-weight: 400;
}
.sas-footer ul { list-style: none; margin: 0; padding: 0; display: flex; flex-direction: column; gap: 10px; }
.sas-footer ul a { font-family: var(--font-body); font-size: 13px; color: rgba(247,243,237,0.7); text-decoration: none; }
.sas-footer ul a:hover { color: var(--sand); text-decoration: none; }
.sas-footer__base {
	max-width: var(--maxw); margin: var(--space-12) auto 0;
	padding-top: 22px; border-top: 1px solid rgba(201,185,154,0.18);
	display: flex; flex-direction: column; gap: 8px;
	font-family: var(--font-body); font-size: 10px; letter-spacing: 0.25em;
	text-transform: uppercase; color: rgba(201,185,154,0.5);
}
@media (min-width: 600px) { .sas-footer__base { flex-direction: row; justify-content: space-between; } }

/* =========================================================
   Generic page / blog
   ========================================================= */
.sas-page { max-width: 860px; margin: 0 auto; padding: var(--space-16) var(--gutter); }
.sas-page h1 { margin-bottom: var(--space-8); }

/* Reduce-motion respect */
@media (prefers-reduced-motion: reduce) {
	*, *::before, *::after { animation-duration: 0.001ms !important; transition-duration: 0.001ms !important; }
}
