/* CML Shop — PDP styles. Matches design mockups #04, #14, #19. Mobile-first. */

@import url('https://fonts.googleapis.com/css2?family=Cardo:wght@400;700&family=Inter:wght@400;500;600;700&display=swap');

:root {
	--cml-burgundy:    #7a1f3d;
	--cml-burgundy-2:  #6a182f;
	--cml-burgundy-3:  #a04060;
	--cml-rose:        #fcf6f8;
	--cml-cream:       #faf7f4;
	--cml-cream-2:     #f4ede8;
	--cml-gold:        #c89a4a;
	--cml-ink:         #1a1a1a;
	--cml-ink-2:       #555555;
	--cml-ink-3:       #888888;
	--cml-line:        #ebe7e2;
	--cml-line-2:      #d8d3cd;
	--cml-good:        #2a7a4a;

	--cml-radius-sm: 6px;
	--cml-radius-md: 10px;
	--cml-radius-lg: 16px;

	--cml-shadow-sm: 0 1px 2px rgba(60,30,30,.04), 0 1px 3px rgba(60,30,30,.04);
	--cml-shadow-md: 0 2px 6px rgba(60,30,30,.05), 0 10px 24px rgba(60,30,30,.06);

	--cml-serif: "Cardo", "Hoefler Text", Cambria, Georgia, serif;
	--cml-sans:  "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;
}

/* ----- Page shell ----- */
body.cml-page {
	background: var(--cml-cream);
	color: var(--cml-ink);
	font-family: var(--cml-sans);
	font-size: 16px;
	line-height: 1.6;
	margin: 0;
	padding: 0;
}
.cml-page__main {
	min-height: 60vh;
}
.cml-pdp-page {
	background: var(--cml-cream);
}

/* ----- Header ----- */
.cml-header {
	background: #fff;
	border-bottom: 1px solid var(--cml-line);
	position: sticky;
	top: 0;
	z-index: 30;
}
.cml-header__inner {
	max-width: 1280px;
	margin: 0 auto;
	padding: .85rem 1.25rem;
	display: flex;
	align-items: center;
	gap: 1.5rem;
}
.cml-header__logo {
	text-decoration: none;
	color: var(--cml-burgundy);
	display: inline-flex;
	align-items: center;
	flex-shrink: 0;
}
.cml-header__wordmark {
	font-family: var(--cml-serif);
	font-weight: 700;
	font-size: 1.9rem;
	letter-spacing: -.04em;
	line-height: 1;
	color: var(--cml-burgundy);
}
.cml-header__nav {
	display: none;
	gap: 1.75rem;
	margin-left: 2rem;
}
@media (min-width: 820px) {
	.cml-header__nav { display: flex; }
}
.cml-header__nav a {
	color: var(--cml-ink);
	text-decoration: none;
	font-weight: 500;
	font-size: .95rem;
	letter-spacing: .01em;
	transition: color .15s;
}
.cml-header__nav a:hover { color: var(--cml-burgundy); }

.cml-header__actions {
	margin-left: auto;
	display: flex;
	align-items: center;
	gap: .5rem;
}
.cml-header__icon-btn {
	position: relative;
	display: inline-flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	padding: .5rem;
	color: var(--cml-ink);
	text-decoration: none;
	border-radius: var(--cml-radius-sm);
	transition: color .15s, background .15s;
	min-width: 40px;
}
.cml-header__icon-btn:hover {
	color: var(--cml-burgundy);
	background: var(--cml-rose);
}
.cml-header__icon-label {
	display: none;
	font-size: .65rem;
	letter-spacing: .08em;
	text-transform: uppercase;
	margin-top: .15rem;
}
@media (min-width: 820px) {
	.cml-header__icon-label { display: block; }
}
.cml-header__cart-badge {
	position: absolute;
	top: 2px;
	right: 2px;
	background: var(--cml-burgundy);
	color: #fff;
	font-size: .65rem;
	font-weight: 700;
	min-width: 18px;
	height: 18px;
	border-radius: 9px;
	padding: 0 5px;
	display: inline-flex;
	align-items: center;
	justify-content: center;
}
.cml-header__cta {
	display: none;
	margin-left: .35rem;
	font-size: .82rem;
	letter-spacing: .12em;
	text-transform: uppercase;
	padding: .65rem 1.25rem;
}
@media (min-width: 1020px) {
	.cml-header__cta { display: inline-flex; }
}
.cml-header__menu-toggle {
	background: transparent;
	border: 0;
	padding: .5rem;
	color: var(--cml-ink);
	cursor: pointer;
}
@media (min-width: 820px) {
	.cml-header__menu-toggle { display: none; }
}

.cml-header__utility {
	background: var(--cml-rose);
	border-bottom: 1px solid var(--cml-line);
	font-size: .85rem;
	color: var(--cml-ink-2);
}
.cml-header__utility-inner {
	max-width: 1280px;
	margin: 0 auto;
	padding: .5rem 1.25rem;
	display: flex;
	align-items: center;
	justify-content: center;
	gap: .75rem;
}
.cml-header__utility strong { color: var(--cml-ink); font-weight: 600; }
.cml-header__utility-switch {
	color: var(--cml-burgundy);
	text-decoration: underline;
	text-underline-offset: 2px;
	font-weight: 500;
}

/* ----- Footer ----- */
.cml-footer {
	background: #1a1a1a;
	color: #d9d4cc;
	padding: 3rem 1.25rem 0;
	margin-top: 4rem;
}
.cml-footer__inner {
	max-width: 1280px;
	margin: 0 auto;
	display: grid;
	grid-template-columns: 1fr;
	gap: 2rem;
}
@media (min-width: 640px) { .cml-footer__inner { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 900px) { .cml-footer__inner { grid-template-columns: 1.4fr repeat(3, 1fr); } }

.cml-footer__col--brand .cml-footer__wordmark {
	font-family: var(--cml-serif);
	font-weight: 700;
	font-size: 2rem;
	color: #fff;
	letter-spacing: -.04em;
}
.cml-footer__tagline {
	color: #968f86;
	font-size: .92rem;
	line-height: 1.6;
	max-width: 320px;
	margin: .75rem 0 0;
}
.cml-footer__col h3 {
	color: #fff;
	font-family: var(--cml-sans);
	font-size: .8rem;
	font-weight: 600;
	letter-spacing: .14em;
	text-transform: uppercase;
	margin: 0 0 1rem;
}
.cml-footer__col ul {
	list-style: none;
	padding: 0;
	margin: 0;
}
.cml-footer__col li { margin: .55rem 0; }
.cml-footer__col a {
	color: #b8b1a8;
	text-decoration: none;
	font-size: .92rem;
	transition: color .15s;
}
.cml-footer__col a:hover { color: #fff; }

.cml-footer__bottom {
	max-width: 1280px;
	margin: 3rem auto 0;
	padding: 1.5rem 0;
	border-top: 1px solid #2c2c2c;
	color: #777167;
	font-size: .8rem;
	text-align: center;
}

.cml-pdp { padding: 1.5rem 1rem 3rem; }
.cml-pdp__wrap { max-width: 1180px; margin: 0 auto; }

/* Breadcrumbs */
.cml-pdp__crumbs {
	font-size: .85rem;
	color: var(--cml-ink-3);
	margin: 0 0 1.75rem;
	letter-spacing: .01em;
}
.cml-pdp__crumbs a { color: var(--cml-ink-3); text-decoration: none; }
.cml-pdp__crumbs a:hover { color: var(--cml-burgundy); }
.cml-pdp__crumbs span { padding: 0 .4rem; }
.cml-pdp__crumbs [aria-current] { color: var(--cml-ink-2); font-weight: 500; }

/* ----- Hero (image + title + tagline) ----- */
.cml-pdp__hero {
	display: grid;
	grid-template-columns: 1fr;
	gap: 1.5rem;
	margin-bottom: 2.5rem;
}
@media (min-width: 900px) {
	.cml-pdp__hero {
		grid-template-columns: minmax(0, 1fr) minmax(0, 1.05fr);
		gap: 3rem;
		align-items: center;
	}
}

.cml-pdp__media {
	border-radius: var(--cml-radius-lg);
	overflow: hidden;
	background: linear-gradient(135deg, var(--cml-cream-2), #ece3da);
	aspect-ratio: 4 / 3;
	display: flex;
	align-items: center;
	justify-content: center;
	box-shadow: var(--cml-shadow-md);
}
.cml-pdp__media img {
	width: 100%; height: 100%;
	object-fit: cover;
	display: block;
}
.cml-pdp__media-placeholder {
	color: var(--cml-burgundy-3);
	opacity: .35;
}

.cml-pdp__title {
	font-family: var(--cml-serif);
	font-weight: 400;
	font-size: clamp(2rem, 4vw + .5rem, 3rem);
	line-height: 1.1;
	margin: 0 0 .85rem;
	color: var(--cml-ink);
	letter-spacing: -.01em;
}
.cml-pdp__tagline {
	font-size: 1.05rem;
	color: var(--cml-ink-2);
	margin: 0 0 1rem;
	line-height: 1.55;
}
.cml-pdp__intro-body {
	font-size: .98rem;
	color: var(--cml-ink-2);
	margin: 0 0 1.4rem;
	line-height: 1.7;
}

/* Trust strip */
.cml-pdp__trust {
	list-style: none;
	padding: 0;
	margin: 0;
	display: grid;
	gap: .6rem;
}
@media (min-width: 520px) {
	.cml-pdp__trust { grid-template-columns: 1fr 1fr 1fr; }
}
.cml-pdp__trust li {
	display: flex;
	align-items: center;
	gap: .55rem;
	font-size: .88rem;
	color: var(--cml-ink-2);
	line-height: 1.3;
}
.cml-pdp__trust svg { color: var(--cml-burgundy); flex-shrink: 0; }

/* ----- Tier cards row ----- */
.cml-pdp__tiers-section {
	margin: 0 0 2.5rem;
}
.cml-pdp__tiers {
	display: grid;
	grid-template-columns: 1fr;
	gap: 1rem;
}
@media (min-width: 720px) {
	.cml-pdp__tiers {
		grid-template-columns: 1fr 1fr 1fr;
		gap: 1.25rem;
		align-items: stretch;
	}
}

.cml-pdp__tier {
	position: relative;
	background: #fff;
	border: 1px solid var(--cml-line);
	border-radius: var(--cml-radius-lg);
	padding: 1.75rem 1.5rem 1.5rem;
	display: flex;
	flex-direction: column;
	text-align: center;
	transition: transform .15s, border-color .15s, box-shadow .15s;
	box-shadow: var(--cml-shadow-sm);
}
.cml-pdp__tier:hover {
	transform: translateY(-2px);
	border-color: var(--cml-burgundy-3);
	box-shadow: var(--cml-shadow-md);
}
.cml-pdp__tier.is-popular {
	border: 2px solid var(--cml-burgundy);
	box-shadow: 0 10px 32px rgba(122,31,61,.12);
}
@media (min-width: 720px) {
	.cml-pdp__tier.is-popular {
		transform: scale(1.03);
	}
	.cml-pdp__tier.is-popular:hover {
		transform: scale(1.03) translateY(-2px);
	}
}

.cml-pdp__tier-badge {
	position: absolute;
	top: -.7rem;
	left: 50%;
	transform: translateX(-50%);
	background: var(--cml-burgundy);
	color: #fff;
	font-size: .7rem;
	font-weight: 600;
	letter-spacing: .12em;
	text-transform: uppercase;
	padding: .35rem .85rem;
	border-radius: 999px;
	white-space: nowrap;
}

.cml-pdp__tier-head { margin-bottom: 1.1rem; }
.cml-pdp__tier-name {
	font-family: var(--cml-sans);
	font-size: .75rem;
	font-weight: 600;
	letter-spacing: .18em;
	color: var(--cml-ink-2);
	margin: 0;
}

.cml-pdp__tier-pricing {
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: .15rem;
	margin-bottom: .5rem;
}
.cml-pdp__tier-was {
	font-size: .95rem;
	color: var(--cml-ink-3);
	text-decoration: line-through;
}
.cml-pdp__tier-now {
	font-family: var(--cml-serif);
	font-size: 2.6rem;
	font-weight: 700;
	color: var(--cml-ink);
	line-height: 1;
}
.cml-pdp__tier-save {
	display: inline-block;
	background: var(--cml-rose);
	color: var(--cml-burgundy);
	font-size: .75rem;
	font-weight: 600;
	letter-spacing: .04em;
	padding: .25rem .6rem;
	border-radius: 999px;
	margin-top: .35rem;
}

.cml-pdp__tier-perunit {
	font-size: .85rem;
	color: var(--cml-ink-3);
	margin: 0 0 1.5rem;
	min-height: 1.25em;
}

.cml-pdp__tier-cta {
	display: block;
	margin-top: auto;
	background: var(--cml-ink);
	color: #fff;
	font-family: var(--cml-sans);
	font-weight: 600;
	font-size: .82rem;
	letter-spacing: .14em;
	text-transform: uppercase;
	text-decoration: none;
	padding: .95rem 1rem;
	border-radius: var(--cml-radius-sm);
	transition: background .15s;
}
.cml-pdp__tier-cta:hover {
	background: var(--cml-burgundy);
	color: #fff;
}
.cml-pdp__tier.is-popular .cml-pdp__tier-cta {
	background: var(--cml-burgundy);
}
.cml-pdp__tier.is-popular .cml-pdp__tier-cta:hover {
	background: var(--cml-burgundy-2);
}

.cml-pdp__tax-note {
	text-align: center;
	font-size: .82rem;
	color: var(--cml-ink-3);
	margin: 1.25rem 0 0;
}

/* ===== Featured Bundle buy box ===== */
.cml-pdp__bundle {
	background: #fff;
	border: 2px solid var(--cml-burgundy);
	border-radius: var(--cml-radius-lg);
	padding: 1.75rem;
	max-width: 620px;
	margin: 0 auto;
	box-shadow: 0 10px 32px rgba(122,31,61,.12);
}
.cml-pdp__bundle-pricing {
	display: flex;
	align-items: baseline;
	gap: .85rem;
	flex-wrap: wrap;
	padding-bottom: 1.25rem;
	border-bottom: 1px solid var(--cml-line);
	margin-bottom: 1.25rem;
}
.cml-pdp__bundle-price {
	font-family: var(--cml-serif);
	font-weight: 700;
	font-size: 2.6rem;
	color: var(--cml-ink);
	line-height: 1;
}
.cml-pdp__bundle-incl h3 {
	font-family: var(--cml-sans);
	font-size: .9rem;
	font-weight: 600;
	letter-spacing: .04em;
	text-transform: uppercase;
	color: var(--cml-ink-2);
	margin: 0 0 .85rem;
}
.cml-pdp__bundle-incl .cml-pdp__check li { padding-left: 2rem; }
.cml-pdp__bundle-detail { color: var(--cml-ink-3); font-size: .92rem; }
.cml-pdp__bundle-cta {
	display: block;
	width: 100%;
	text-align: center;
	box-sizing: border-box;
	margin-top: 1.5rem;
}
.cml-pdp__bundle-note {
	font-size: .82rem;
	color: var(--cml-ink-3);
	text-align: center;
	margin: .85rem 0 0;
	line-height: 1.5;
}

/* ===== Per-unit slider (Botox) + syringe stepper (Filler) ===== */
.cml-pdp__units,
.cml-pdp__syringes {
	background: #fff;
	border: 2px solid var(--cml-burgundy);
	border-radius: var(--cml-radius-lg);
	padding: 1.5rem;
	max-width: 560px;
	margin: 0 auto;
	box-shadow: 0 10px 32px rgba(122,31,61,.10);
}
.cml-pdp__units-head {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 1rem;
	margin-bottom: 1rem;
}
.cml-pdp__units-label { font-weight: 600; font-size: 1.05rem; color: var(--cml-ink); }
.cml-pdp__units-count { color: var(--cml-burgundy); font-weight: 700; font-size: 1.05rem; }
.cml-pdp__units-slider {
	width: 100%;
	accent-color: var(--cml-burgundy);
	height: 6px;
}
.cml-pdp__units-scale {
	display: flex;
	justify-content: space-between;
	font-size: .78rem;
	color: var(--cml-ink-3);
	margin-top: .35rem;
}
.cml-pdp__units-price {
	display: flex;
	align-items: baseline;
	gap: .6rem;
	margin: 1.1rem 0 .35rem;
}
.cml-pdp__units-price .cml-pdp__summary-final {
	font-family: var(--cml-serif);
	font-weight: 700;
	font-size: 2.1rem;
	color: var(--cml-ink);
}
.cml-pdp__units-rate { color: var(--cml-ink-3); font-size: .9rem; }
.cml-pdp__units-hint { font-size: .82rem; color: var(--cml-ink-3); margin: 0 0 1.25rem; line-height: 1.5; }
.cml-pdp__units-cta,
.cml-pdp__syr-cta {
	display: block;
	width: 100%;
	text-align: center;
	box-sizing: border-box;
}

/* Stepper */
.cml-pdp__stepper {
	display: inline-flex;
	align-items: center;
	border: 1.5px solid var(--cml-line-2);
	border-radius: 999px;
	overflow: hidden;
}
.cml-pdp__stepper-btn {
	background: var(--cml-cream);
	border: 0;
	width: 2.4rem; height: 2.4rem;
	font-size: 1.3rem;
	color: var(--cml-burgundy);
	cursor: pointer;
	line-height: 1;
}
.cml-pdp__stepper-btn:hover { background: var(--cml-rose); }
.cml-pdp__stepper-val {
	min-width: 2.5rem;
	text-align: center;
	font-weight: 700;
	font-size: 1.1rem;
	color: var(--cml-ink);
}

/* ----- Pickup card ----- */
.cml-pdp__pickup {
	background: #fff;
	border: 1px solid var(--cml-line);
	border-radius: var(--cml-radius-lg);
	overflow: hidden;
	display: grid;
	grid-template-columns: 1fr;
	margin: 0 0 2.5rem;
	box-shadow: var(--cml-shadow-sm);
}
@media (min-width: 720px) {
	.cml-pdp__pickup {
		grid-template-columns: minmax(0, 0.85fr) minmax(0, 1.15fr);
		align-items: stretch;
	}
}
.cml-pdp__pickup-map {
	background: linear-gradient(135deg, #f0e8df, var(--cml-cream-2));
	min-height: 220px;
	display: flex;
	align-items: center;
	justify-content: center;
	position: relative;
}
.cml-pdp__pickup-map-fallback {
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: .5rem;
	color: var(--cml-burgundy);
}
.cml-pdp__pickup-map-link {
	display: block;
	width: 100%;
	height: 100%;
	min-height: 220px;
}
.cml-pdp__pickup-map-link img {
	display: block;
	width: 100%;
	height: 100%;
	min-height: 220px;
	object-fit: cover;
}
.cml-pdp__pickup-map-pin {
	font-family: var(--cml-sans);
	font-weight: 600;
	font-size: .9rem;
	color: var(--cml-ink-2);
	background: #fff;
	padding: .35rem .75rem;
	border-radius: 999px;
	box-shadow: var(--cml-shadow-sm);
}
.cml-pdp__pickup-body { padding: 1.75rem; }
.cml-pdp__pickup-eyebrow {
	display: inline-block;
	font-size: .7rem;
	font-weight: 600;
	letter-spacing: .16em;
	text-transform: uppercase;
	color: var(--cml-burgundy);
	margin-bottom: .55rem;
}
.cml-pdp__pickup-name {
	font-family: var(--cml-serif);
	font-weight: 400;
	font-size: 1.55rem;
	margin: 0 0 .65rem;
	color: var(--cml-ink);
	line-height: 1.15;
}
.cml-pdp__pickup-address,
.cml-pdp__pickup-hours,
.cml-pdp__pickup-phone {
	margin: .2rem 0;
	font-size: .92rem;
	color: var(--cml-ink-2);
}
.cml-pdp__pickup-actions {
	display: flex;
	gap: .6rem;
	margin: 1.1rem 0 .75rem;
	flex-wrap: wrap;
}
.cml-pdp__pickup-note {
	font-size: .82rem;
	color: var(--cml-ink-3);
	margin-top: 1rem;
	padding-top: 1rem;
	border-top: 1px solid var(--cml-line);
}
.cml-pdp__pickup-note strong { color: var(--cml-ink-2); font-weight: 600; }

/* ====== Archive / Shop grid ====== */
.cml-archive { background: var(--cml-cream); }

.cml-promo {
	background: linear-gradient(135deg, var(--cml-burgundy), var(--cml-burgundy-2));
	color: #fff;
	text-align: center;
}
.cml-promo__inner {
	max-width: 1280px;
	margin: 0 auto;
	padding: 1.5rem 1.25rem 1.75rem;
}
.cml-promo__eyebrow {
	display: inline-block;
	background: rgba(255,255,255,.16);
	color: #fff;
	font-size: .7rem;
	font-weight: 600;
	letter-spacing: .18em;
	text-transform: uppercase;
	padding: .25rem .7rem;
	border-radius: 999px;
	margin-bottom: .55rem;
}
.cml-promo__headline {
	font-family: var(--cml-serif);
	font-weight: 400;
	font-size: clamp(1.6rem, 3vw + .6rem, 2.4rem);
	margin: 0 0 .35rem;
	line-height: 1.15;
}
.cml-promo__body {
	margin: 0;
	font-size: .95rem;
	color: rgba(255,255,255,.92);
}
.cml-promo__code {
	background: #fff;
	color: var(--cml-burgundy);
	padding: .15rem .55rem;
	border-radius: var(--cml-radius-sm);
	font-family: var(--cml-sans);
	font-weight: 700;
	letter-spacing: .04em;
	font-size: .9rem;
}

.cml-archive__wrap {
	max-width: 1280px;
	margin: 0 auto;
	padding: 1.75rem 1.25rem 3rem;
	display: grid;
	grid-template-columns: 1fr;
	gap: 1.5rem;
}
@media (min-width: 900px) {
	.cml-archive__wrap {
		grid-template-columns: 240px 1fr;
		gap: 2.5rem;
	}
}

/* Sidebar */
.cml-archive__sidebar {
	background: transparent;
	font-size: .92rem;
}
.cml-archive__sidebar-h {
	font-family: var(--cml-sans);
	font-size: .85rem;
	font-weight: 600;
	letter-spacing: .14em;
	text-transform: uppercase;
	color: var(--cml-ink);
	display: flex;
	align-items: center;
	gap: .5rem;
	padding-bottom: .65rem;
	border-bottom: 2px solid var(--cml-ink);
	margin: 0 0 1.25rem;
}
.cml-archive__facet { margin-bottom: 1.5rem; }
.cml-archive__facet h3 {
	font-family: var(--cml-sans);
	font-size: .82rem;
	font-weight: 600;
	letter-spacing: .04em;
	color: var(--cml-ink-2);
	margin: 0 0 .65rem;
	text-transform: uppercase;
}
.cml-archive__facet ul {
	list-style: none;
	padding: 0;
	margin: 0;
}
.cml-archive__facet li { margin: .35rem 0; }
.cml-archive__facet a {
	color: var(--cml-ink-2);
	text-decoration: none;
	font-size: .9rem;
	transition: color .15s;
}
.cml-archive__facet a:hover { color: var(--cml-burgundy); }
.cml-archive__facet label {
	display: flex;
	align-items: center;
	gap: .5rem;
	font-size: .9rem;
	color: var(--cml-ink-2);
	cursor: pointer;
}
.cml-archive__facet input[type="checkbox"] {
	accent-color: var(--cml-burgundy);
	width: 14px; height: 14px;
}
.cml-archive__facet-note {
	font-size: .75rem;
	color: var(--cml-ink-3);
	margin-top: 1rem;
	font-style: italic;
}

/* Main grid */
.cml-archive__head {
	display: flex;
	align-items: flex-end;
	justify-content: space-between;
	gap: 1rem;
	margin: 0 0 1.5rem;
	flex-wrap: wrap;
}
.cml-archive__h1 {
	font-family: var(--cml-serif);
	font-weight: 400;
	font-size: clamp(1.7rem, 2.5vw + .5rem, 2.3rem);
	margin: 0 0 .3rem;
	color: var(--cml-ink);
	line-height: 1.15;
}
.cml-archive__sub {
	color: var(--cml-ink-2);
	margin: 0;
	font-size: .95rem;
}
.cml-archive__sort {
	display: inline-flex;
	align-items: center;
	gap: .5rem;
	font-size: .85rem;
	color: var(--cml-ink-2);
}
.cml-archive__sort select {
	background: #fff;
	border: 1px solid var(--cml-line);
	border-radius: var(--cml-radius-sm);
	padding: .45rem .65rem;
	font-family: inherit;
	font-size: .9rem;
	color: var(--cml-ink);
}

.cml-archive__grid {
	display: grid;
	grid-template-columns: 1fr;
	gap: 1.25rem;
}
@media (min-width: 540px) {
	.cml-archive__grid { grid-template-columns: 1fr 1fr; }
}
@media (min-width: 820px) {
	.cml-archive__grid { grid-template-columns: 1fr 1fr 1fr; gap: 1.5rem; }
}
@media (min-width: 1200px) {
	.cml-archive__grid { grid-template-columns: repeat(4, 1fr); }
}

.cml-tile {
	display: flex;
	flex-direction: column;
	background: #fff;
	border-radius: var(--cml-radius-lg);
	overflow: hidden;
	text-decoration: none;
	color: inherit;
	border: 1px solid var(--cml-line);
	box-shadow: var(--cml-shadow-sm);
	transition: transform .15s, box-shadow .15s, border-color .15s;
	position: relative;
}
.cml-tile:hover {
	transform: translateY(-3px);
	border-color: var(--cml-burgundy-3);
	box-shadow: var(--cml-shadow-md);
}
.cml-tile.is-featured {
	border: 2px solid var(--cml-burgundy);
}
.cml-tile__media {
	aspect-ratio: 4 / 3;
	background: linear-gradient(135deg, var(--cml-cream-2), #ece3da);
	position: relative;
	display: flex;
	align-items: center;
	justify-content: center;
	color: var(--cml-burgundy-3);
}
.cml-tile__media img {
	position: absolute;
	inset: 0;
	width: 100%;
	height: 100%;
	object-fit: cover;
}
.cml-tile__media-placeholder { opacity: .35; }
.cml-tile__badge {
	position: absolute;
	top: .85rem;
	left: .85rem;
	background: var(--cml-rose);
	color: var(--cml-burgundy);
	font-size: .7rem;
	font-weight: 700;
	letter-spacing: .1em;
	text-transform: uppercase;
	padding: .25rem .65rem;
	border-radius: 999px;
	z-index: 1;
}
.cml-tile__body {
	padding: 1.1rem 1.25rem 1.25rem;
	display: flex;
	flex-direction: column;
	flex: 1;
}
.cml-tile__name {
	font-family: var(--cml-serif);
	font-weight: 400;
	font-size: 1.25rem;
	color: var(--cml-ink);
	margin: 0 0 .35rem;
	line-height: 1.2;
}
.cml-tile__tagline {
	font-size: .88rem;
	color: var(--cml-ink-2);
	line-height: 1.5;
	margin: 0 0 .85rem;
	min-height: 2.7em;
}
.cml-tile__price {
	display: flex;
	align-items: baseline;
	gap: .35rem;
	margin-top: auto;
}
.cml-tile__from {
	font-size: .75rem;
	color: var(--cml-ink-3);
	text-transform: uppercase;
	letter-spacing: .08em;
	font-weight: 500;
}
.cml-tile__amount {
	font-family: var(--cml-serif);
	font-weight: 700;
	font-size: 1.45rem;
	color: var(--cml-ink);
	line-height: 1;
}
.cml-tile__cta {
	margin-top: .65rem;
	color: var(--cml-burgundy);
	font-weight: 600;
	font-size: .85rem;
	letter-spacing: .02em;
}

/* ====== Category landing (mockup #17) ====== */
.cml-cat { background: var(--cml-cream); }

.cml-cat__hero {
	background: linear-gradient(180deg, #fff 0%, var(--cml-cream) 100%);
	border-bottom: 1px solid var(--cml-line);
}
.cml-cat__hero-inner {
	max-width: 1280px;
	margin: 0 auto;
	padding: 1.5rem 1.25rem 2rem;
}
.cml-cat__h1 {
	font-family: var(--cml-serif);
	font-weight: 400;
	font-size: clamp(2rem, 4vw + .4rem, 3rem);
	margin: .35rem 0 .75rem;
	color: var(--cml-ink);
	line-height: 1.1;
}
.cml-cat__intro {
	max-width: 760px;
	font-size: 1.02rem;
	color: var(--cml-ink-2);
	line-height: 1.6;
	margin: 0 0 .75rem;
}
.cml-cat__meta {
	font-size: .88rem;
	color: var(--cml-ink-3);
	letter-spacing: .02em;
	margin: 0;
}

.cml-cat__wrap {
	max-width: 1280px;
	margin: 0 auto;
	padding: 1.75rem 1.25rem 3rem;
	display: grid;
	grid-template-columns: 1fr;
	gap: 1.5rem;
}
@media (min-width: 900px) {
	.cml-cat__wrap { grid-template-columns: 240px 1fr; gap: 2.5rem; }
}

/* Sidebar */
.cml-cat__sidebar {
	font-size: .92rem;
	background: #fff;
	border: 1px solid var(--cml-line);
	border-radius: var(--cml-radius-lg);
	padding: 1.25rem 1.25rem 1.5rem;
	box-shadow: var(--cml-shadow-sm);
	align-self: start;
}
.cml-cat__sidebar-head {
	display: flex;
	align-items: center;
	gap: .5rem;
	margin-bottom: 1rem;
}
.cml-cat__sidebar-h {
	font-family: var(--cml-serif);
	font-weight: 400;
	font-size: 1.4rem;
	margin: 0;
	color: var(--cml-ink);
}
.cml-cat__clear {
	margin-left: auto;
	background: transparent;
	border: 0;
	color: var(--cml-burgundy);
	font-size: .82rem;
	text-decoration: underline;
	cursor: pointer;
	padding: 0;
}
.cml-cat__clear:hover { color: var(--cml-burgundy-2); }

/* Active category pill */
.cml-cat__active-pill {
	margin-bottom: 1.25rem;
	padding-bottom: 1.25rem;
	border-bottom: 1px solid var(--cml-line);
}
.cml-cat__active-pill a {
	display: inline-flex;
	align-items: center;
	gap: .55rem;
	background: var(--cml-burgundy);
	color: #fff;
	padding: .45rem .9rem .45rem 1rem;
	border-radius: 999px;
	font-weight: 600;
	font-size: .9rem;
	text-decoration: none;
	transition: background .15s;
}
.cml-cat__active-pill a:hover { background: var(--cml-burgundy-2); color: #fff; }
.cml-cat__active-pill a span {
	font-size: 1.05rem;
	font-weight: 400;
	opacity: .8;
}

.cml-cat__facet { margin-bottom: 1.5rem; }
.cml-cat__facet h3 {
	font-size: .82rem;
	font-weight: 600;
	letter-spacing: .14em;
	text-transform: uppercase;
	color: var(--cml-ink);
	margin: 0 0 .35rem;
}
.cml-cat__facet-help {
	color: var(--cml-ink-3);
	font-size: .82rem;
	margin: 0 0 .75rem;
}

/* Pill chips */
.cml-cat__pills {
	display: flex;
	flex-wrap: wrap;
	gap: .45rem;
}
.cml-cat__pill {
	background: #fff;
	border: 1.5px solid var(--cml-line-2);
	color: var(--cml-ink);
	padding: .4rem 1rem;
	border-radius: 999px;
	font-family: inherit;
	font-size: .88rem;
	font-weight: 500;
	cursor: pointer;
	transition: all .15s;
}
.cml-cat__pill:hover { border-color: var(--cml-burgundy); color: var(--cml-burgundy); }
.cml-cat__pill.is-active {
	background: var(--cml-burgundy);
	color: #fff;
	border-color: var(--cml-burgundy);
}

/* Body Area accordion */
.cml-cat__group {
	border-top: 1px solid var(--cml-line);
	padding: .65rem 0;
}
.cml-cat__group:last-of-type { border-bottom: 1px solid var(--cml-line); }
.cml-cat__group summary {
	display: flex;
	align-items: center;
	gap: .65rem;
	cursor: pointer;
	list-style: none;
	padding: .25rem 0;
}
.cml-cat__group summary::-webkit-details-marker { display: none; }
.cml-cat__group summary::after {
	content: "";
	width: 12px; height: 12px;
	border-right: 1.5px solid var(--cml-ink-2);
	border-bottom: 1.5px solid var(--cml-ink-2);
	transform: rotate(-45deg);
	margin-left: .15rem;
	transition: transform .15s;
}
.cml-cat__group[open] summary::after {
	transform: rotate(45deg) translate(-2px, -2px);
}
.cml-cat__group-name {
	flex: 1;
	display: flex;
	flex-direction: column;
	gap: .1rem;
}
.cml-cat__group-name strong {
	font-weight: 600;
	color: var(--cml-ink);
	font-size: .95rem;
}
.cml-cat__group-name em {
	font-style: normal;
	color: var(--cml-ink-3);
	font-size: .8rem;
}
.cml-cat__group-count {
	background: var(--cml-cream-2);
	color: var(--cml-ink-2);
	font-weight: 600;
	font-size: .8rem;
	padding: .15rem .55rem;
	border-radius: 999px;
	min-width: 26px;
	text-align: center;
}
.cml-cat__group-body {
	list-style: none;
	padding: .35rem 0 .55rem;
	margin: 0;
}
.cml-cat__group-body li { padding: .35rem 0; }
.cml-cat__group-body label {
	display: flex;
	align-items: center;
	gap: .55rem;
	color: var(--cml-ink-2);
	cursor: pointer;
	font-size: .9rem;
}
.cml-cat__group-body input[type="checkbox"] {
	accent-color: var(--cml-burgundy);
}
.cml-cat__group-body em {
	margin-left: auto;
	color: var(--cml-ink-3);
	font-style: normal;
	font-size: .82rem;
}

/* Sessions radios */
.cml-cat__radios {
	list-style: none;
	padding: 0;
	margin: 0;
}
.cml-cat__radios li { padding: .25rem 0; }
.cml-cat__radios label {
	display: flex;
	align-items: center;
	gap: .55rem;
	cursor: pointer;
	color: var(--cml-ink-2);
	font-size: .92rem;
}
.cml-cat__radios input[type="radio"] {
	accent-color: var(--cml-burgundy);
}
.cml-cat__radio-badge {
	display: inline-block;
	margin-left: .35rem;
	background: var(--cml-rose);
	color: var(--cml-burgundy);
	font-size: .65rem;
	font-weight: 700;
	letter-spacing: .08em;
	text-transform: uppercase;
	padding: .15rem .55rem;
	border-radius: 999px;
}

/* Price slider */
.cml-cat__slider {
	width: 100%;
	accent-color: var(--cml-burgundy);
}
.cml-cat__slider-labels {
	display: flex;
	justify-content: space-between;
	margin-top: .25rem;
	font-size: .82rem;
	color: var(--cml-ink-3);
}
.cml-cat__slider-labels [data-cml-price-max] {
	color: var(--cml-ink);
	font-weight: 600;
}

/* WC fields we don't want shown — pre-filled with clinic address in CheckoutFields. */
.cml-hidden,
.woocommerce-billing-fields__field-wrapper .cml-hidden,
.cml-checkout-page form .form-row.cml-hidden { display: none !important; }

/* Per-session label on tiles */
.cml-svc-tile__per {
	font-size: .75rem;
	color: var(--cml-ink-3);
	letter-spacing: .04em;
	margin-left: -.15rem;
}

/* Family tiles (stage-1 selection — Skin Treatments, Body, Facials, etc.) */
.cml-cat__grid--families {
	grid-template-columns: 1fr 1fr;
}
@media (min-width: 720px)  { .cml-cat__grid--families { grid-template-columns: 1fr 1fr 1fr; } }
@media (min-width: 1100px) { .cml-cat__grid--families { grid-template-columns: 1fr 1fr 1fr 1fr; } }

.cml-fam-tile {
	background: #fff;
	border: 1px solid var(--cml-line);
	border-radius: var(--cml-radius-lg);
	overflow: hidden;
	display: flex;
	flex-direction: column;
	text-decoration: none;
	color: inherit;
	transition: transform .15s, border-color .15s, box-shadow .15s;
	box-shadow: var(--cml-shadow-sm);
}
.cml-fam-tile:hover {
	transform: translateY(-3px);
	border-color: var(--cml-burgundy);
	box-shadow: var(--cml-shadow-md);
}
.cml-fam-tile__media {
	aspect-ratio: 5 / 3;
	background: linear-gradient(135deg, var(--cml-rose), var(--cml-cream-2));
	color: var(--cml-burgundy);
	display: flex;
	align-items: center;
	justify-content: center;
}
.cml-fam-tile__body {
	padding: 1rem 1.1rem 1.15rem;
	display: flex;
	flex-direction: column;
	flex: 1;
}
.cml-fam-tile__name {
	font-family: var(--cml-serif);
	font-weight: 400;
	font-size: 1.2rem;
	margin: 0 0 .25rem;
	line-height: 1.2;
	color: var(--cml-ink);
}
.cml-fam-tile__count {
	font-size: .78rem;
	letter-spacing: .04em;
	text-transform: uppercase;
	color: var(--cml-ink-3);
	margin: 0 0 .6rem;
}
.cml-fam-tile__price {
	display: flex;
	align-items: baseline;
	gap: .35rem;
	margin-top: auto;
}

/* H1 sub-label for family-detail view ("Skin Treatments — Morpheus8") */
.cml-cat__h1-sub {
	font-style: italic;
	color: var(--cml-ink-2);
	font-weight: 400;
	font-size: .8em;
}

/* Active-pill sub-label */
.cml-cat__active-pill-sub {
	font-weight: 400;
	font-size: .85rem;
	opacity: .85;
	margin-left: .25rem;
}

/* ====== Static content pages (FAQ / Terms / Privacy / Contact / etc.) ====== */
.cml-static { background: var(--cml-cream); min-height: 60vh; }
.cml-static__wrap { max-width: 820px; margin: 0 auto; padding: 2rem 1.25rem 4rem; }
.cml-static__hero { margin-bottom: 1.5rem; }
.cml-static__h1 {
	font-family: var(--cml-serif);
	font-weight: 400;
	font-size: clamp(2rem, 4vw + .4rem, 3rem);
	margin: .35rem 0 .5rem;
	color: var(--cml-ink);
	line-height: 1.1;
}
.cml-static__article {
	background: #fff;
	border: 1px solid var(--cml-line);
	border-radius: var(--cml-radius-lg);
	box-shadow: var(--cml-shadow-sm);
	padding: 2rem 2.25rem;
	color: var(--cml-ink);
	line-height: 1.75;
	font-size: 1.02rem;
}
.cml-static__article h2,
.cml-static__article h3 {
	font-family: var(--cml-serif);
	font-weight: 400;
	color: var(--cml-ink);
	margin: 1.75rem 0 .75rem;
	line-height: 1.25;
}
.cml-static__article h2 { font-size: 1.6rem; }
.cml-static__article h3 { font-size: 1.2rem; }
.cml-static__article h3:first-of-type,
.cml-static__article h2:first-of-type { margin-top: 0; }
.cml-static__article p { margin: 0 0 1rem; }
.cml-static__article ul,
.cml-static__article ol { padding-left: 1.25rem; margin: 0 0 1rem; }
.cml-static__article li { margin: .35rem 0; }
.cml-static__article a { color: var(--cml-burgundy); }
.cml-static__article a:hover { color: var(--cml-burgundy-2); }
.cml-static__article em { color: var(--cml-ink-3); }

/* ====== Locations page ====== */
.cml-locations { background: var(--cml-cream); }
.cml-locations__wrap { max-width: 1180px; margin: 0 auto; padding: 2rem 1.25rem 4rem; }
.cml-locations__hero { margin-bottom: 2rem; }
.cml-locations__h1 {
	font-family: var(--cml-serif);
	font-weight: 400;
	font-size: clamp(2rem, 4vw + .4rem, 3rem);
	margin: .35rem 0 .85rem;
	line-height: 1.1;
}
.cml-locations__meta {
	color: var(--cml-ink-3);
	font-size: .9rem;
	margin: 1rem 0 0;
}
.cml-locations__grid {
	display: grid;
	grid-template-columns: 1fr;
	gap: 1.25rem;
}
@media (min-width: 720px)  { .cml-locations__grid { grid-template-columns: 1fr 1fr; } }
@media (min-width: 1100px) { .cml-locations__grid { grid-template-columns: 1fr 1fr 1fr; } }

.cml-loc-card {
	background: #fff;
	border: 1px solid var(--cml-line);
	border-radius: var(--cml-radius-lg);
	overflow: hidden;
	box-shadow: var(--cml-shadow-sm);
	display: flex;
	flex-direction: column;
	transition: transform .15s, box-shadow .15s, border-color .15s;
}
.cml-loc-card:hover {
	transform: translateY(-2px);
	border-color: var(--cml-burgundy-3);
	box-shadow: var(--cml-shadow-md);
}
.cml-loc-card__map {
	display: block;
	aspect-ratio: 16/9;
	background: linear-gradient(135deg, var(--cml-cream-2), #ece3da);
	overflow: hidden;
}
.cml-loc-card__map img { display: block; width: 100%; height: 100%; object-fit: cover; }
.cml-loc-card__map-fallback {
	display: flex; align-items: center; justify-content: center;
	width: 100%; height: 100%;
	color: var(--cml-burgundy-3);
}
.cml-loc-card__body { padding: 1.1rem 1.25rem 1.35rem; display: flex; flex-direction: column; flex: 1; }
.cml-loc-card__name {
	font-family: var(--cml-serif);
	font-weight: 400;
	font-size: 1.35rem;
	margin: 0 0 .5rem;
	color: var(--cml-ink);
	line-height: 1.2;
}
.cml-loc-card__addr,
.cml-loc-card__hours,
.cml-loc-card__phone { margin: .1rem 0; color: var(--cml-ink-2); font-size: .9rem; }
.cml-loc-card__phone a { color: inherit; text-decoration: none; }
.cml-loc-card__phone a:hover { color: var(--cml-burgundy); }
.cml-loc-card__actions {
	display: flex; flex-direction: column; gap: .55rem;
	margin-top: 1rem;
}
.cml-loc-card__actions .cml-btn { width: 100%; }
.cml-loc-card__directions {
	color: var(--cml-burgundy);
	font-weight: 500;
	font-size: .85rem;
	text-align: center;
	text-decoration: none;
}
.cml-loc-card__directions:hover { text-decoration: underline; }

.cml-locations__empty {
	background: #fff;
	border: 1px dashed var(--cml-line-2);
	border-radius: var(--cml-radius-lg);
	padding: 3rem 1.5rem;
	text-align: center;
	color: var(--cml-ink-3);
}

/* Grid head */
.cml-cat__grid-head {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 1rem;
	margin: 0 0 1.25rem;
	flex-wrap: wrap;
}
.cml-cat__grid-count {
	color: var(--cml-ink-2);
	margin: 0;
	font-size: .9rem;
}

.cml-cat__grid {
	display: grid;
	grid-template-columns: 1fr 1fr;       /* 2-up on mobile */
	gap: .85rem;
}
@media (min-width: 540px) { .cml-cat__grid { gap: 1.25rem; } }
@media (min-width: 1020px) { .cml-cat__grid { grid-template-columns: 1fr 1fr 1fr; } }

/* Tighter tile typography on small screens so 2-up reads cleanly */
@media (max-width: 540px) {
	.cml-svc-tile__body { padding: .85rem .85rem 1rem; }
	.cml-svc-tile__name { font-size: 1.02rem; }
	.cml-svc-tile__sessions { font-size: .68rem; letter-spacing: .03em; margin: 0 0 .55rem; }
	.cml-svc-tile__from { font-size: .65rem; }
	.cml-svc-tile__amount { font-size: 1.15rem; }
	.cml-svc-tile__per { font-size: .68rem; }
	.cml-svc-tile__cta { font-size: .78rem; margin-top: .55rem; }
	.cml-svc-tile__badge { font-size: .62rem; padding: .2rem .5rem; top: .55rem; left: .55rem; letter-spacing: .06em; }
}

/* Service tile (one per master/area) */
.cml-svc-tile {
	background: #fff;
	border: 1px solid var(--cml-line);
	border-radius: var(--cml-radius-lg);
	overflow: hidden;
	display: flex;
	flex-direction: column;
	transition: transform .15s, border-color .15s, box-shadow .15s;
	box-shadow: var(--cml-shadow-sm);
}
.cml-svc-tile:hover {
	transform: translateY(-2px);
	border-color: var(--cml-burgundy-3);
	box-shadow: var(--cml-shadow-md);
}
.cml-svc-tile[hidden] { display: none; }

.cml-svc-tile__media {
	aspect-ratio: 4 / 3;
	background: linear-gradient(135deg, var(--cml-cream-2), #ece3da);
	display: flex;
	align-items: center;
	justify-content: center;
	color: var(--cml-burgundy-3);
	position: relative;
	overflow: hidden;
}
.cml-svc-tile__media img {
	position: absolute;
	inset: 0;
	width: 100%;
	height: 100%;
	object-fit: cover;
}
.cml-svc-tile__placeholder { opacity: .4; }
.cml-svc-tile__badge {
	position: absolute;
	top: .85rem;
	left: .85rem;
	background: var(--cml-burgundy);
	color: #fff;
	font-size: .7rem;
	font-weight: 700;
	letter-spacing: .08em;
	text-transform: uppercase;
	padding: .3rem .7rem;
	border-radius: 999px;
}

.cml-svc-tile__body {
	padding: 1.1rem 1.25rem 1.25rem;
	display: flex;
	flex-direction: column;
	flex: 1;
}
.cml-svc-tile__name {
	font-family: var(--cml-serif);
	font-weight: 400;
	font-size: 1.2rem;
	margin: 0 0 .35rem;
	line-height: 1.2;
}
.cml-svc-tile__name a { color: var(--cml-ink); text-decoration: none; }
.cml-svc-tile__name a:hover { color: var(--cml-burgundy); }
.cml-svc-tile__sessions {
	font-size: .78rem;
	color: var(--cml-ink-3);
	letter-spacing: .04em;
	text-transform: uppercase;
	margin: 0 0 .65rem;
}
.cml-svc-tile__price {
	display: flex;
	align-items: baseline;
	gap: .35rem;
	margin-top: auto;
}
.cml-svc-tile__from {
	font-size: .72rem;
	color: var(--cml-ink-3);
	letter-spacing: .08em;
	text-transform: uppercase;
}
.cml-svc-tile__amount {
	font-family: var(--cml-serif);
	font-weight: 700;
	font-size: 1.45rem;
	color: var(--cml-ink);
	line-height: 1;
}
.cml-svc-tile__cta {
	margin-top: .65rem;
	color: var(--cml-burgundy);
	font-weight: 600;
	font-size: .85rem;
	text-decoration: none;
}
.cml-svc-tile__cta:hover { text-decoration: underline; }

.cml-cat__no-results,
.cml-cat__empty {
	background: #fff;
	border: 1px dashed var(--cml-line-2);
	border-radius: var(--cml-radius-md);
	padding: 2rem;
	text-align: center;
	color: var(--cml-ink-2);
	grid-column: 1 / -1;
}

/* Bundle promo strip */
.cml-cat__bundle {
	background: linear-gradient(135deg, var(--cml-burgundy), var(--cml-burgundy-2));
	color: #fff;
	margin: 2rem 0;
}
.cml-cat__bundle-inner {
	max-width: 1280px;
	margin: 0 auto;
	padding: 2.5rem 1.25rem;
	text-align: center;
}
.cml-cat__bundle-eyebrow {
	display: inline-block;
	background: rgba(255,255,255,.16);
	color: #fff;
	font-size: .7rem;
	font-weight: 600;
	letter-spacing: .18em;
	text-transform: uppercase;
	padding: .25rem .7rem;
	border-radius: 999px;
	margin-bottom: .55rem;
}
.cml-cat__bundle h2 {
	font-family: var(--cml-serif);
	font-weight: 400;
	font-size: clamp(1.6rem, 3vw + .4rem, 2.2rem);
	margin: 0 0 .55rem;
	color: #fff;
	line-height: 1.2;
}
.cml-cat__bundle p {
	max-width: 540px;
	margin: 0 auto 1.25rem;
	color: rgba(255,255,255,.92);
	font-size: .98rem;
}

.cml-cat__stack {
	max-width: 1280px;
	margin: 0 auto;
	padding: 0 1.25rem 3rem;
	display: grid;
	gap: 1.25rem;
}

/* ====== Side cart drawer (mockup #05) ====== */
.cml-drawer-overlay {
	position: fixed;
	inset: 0;
	background: rgba(20, 12, 14, .45);
	z-index: 40;
	opacity: 0;
	transition: opacity .2s;
	pointer-events: none;
}
.cml-drawer-overlay.is-open {
	opacity: 1;
	pointer-events: auto;
}

.cml-drawer {
	position: fixed;
	top: 0;
	right: 0;
	bottom: 0;
	width: 100%;
	max-width: 420px;
	background: #fff;
	z-index: 41;
	box-shadow: -8px 0 32px rgba(20,12,14,.18);
	display: flex;
	flex-direction: column;
	transform: translateX(100%);
	transition: transform .25s cubic-bezier(.4,0,.2,1);
}
.cml-drawer.is-open { transform: translateX(0); }

.cml-drawer__head {
	display: flex;
	align-items: flex-start;
	justify-content: space-between;
	padding: 1.25rem 1.5rem 1rem;
	border-bottom: 1px solid var(--cml-line);
}
.cml-drawer__head h2 {
	font-family: var(--cml-serif);
	font-weight: 400;
	font-size: 1.5rem;
	margin: 0;
	color: var(--cml-ink);
}
.cml-drawer__clinic {
	font-size: .8rem;
	color: var(--cml-ink-3);
	margin: .25rem 0 0;
	letter-spacing: .04em;
}
.cml-drawer__close {
	background: transparent;
	border: 0;
	padding: .35rem;
	color: var(--cml-ink-2);
	cursor: pointer;
	margin: -.35rem -.35rem 0 0;
}
.cml-drawer__close:hover { color: var(--cml-burgundy); }

.cml-drawer__body {
	flex: 1;
	overflow-y: auto;
	padding: 1rem 1.5rem;
}

.cml-drawer__items {
	list-style: none;
	margin: 0;
	padding: 0;
}
.cml-drawer__item {
	display: grid;
	grid-template-columns: 60px 1fr;
	gap: .85rem;
	padding: 1rem 0;
	border-bottom: 1px solid var(--cml-line);
}
.cml-drawer__item:last-child { border-bottom: 0; }
.cml-drawer__item-media {
	width: 60px;
	height: 60px;
	border-radius: var(--cml-radius-md);
	background: var(--cml-cream-2);
	overflow: hidden;
	display: flex;
	align-items: center;
	justify-content: center;
}
.cml-drawer__item-media img { width: 100%; height: 100%; object-fit: cover; }
.cml-drawer__item-ph { color: var(--cml-burgundy-3); font-size: 1.4rem; opacity: .5; }
.cml-drawer__item-name {
	font-family: var(--cml-serif);
	font-size: 1.02rem;
	font-weight: 400;
	margin: 0 0 .15rem;
	color: var(--cml-ink);
	line-height: 1.2;
}
.cml-drawer__item-tier {
	font-size: .78rem;
	color: var(--cml-ink-3);
	margin: 0 0 .35rem;
}
.cml-drawer__item-bottom {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: .5rem;
}
.cml-drawer__item-qty { color: var(--cml-ink-2); font-size: .88rem; }
.cml-drawer__item-price { font-weight: 700; color: var(--cml-ink); }
.cml-drawer__item-remove {
	color: var(--cml-ink-3);
	font-size: .78rem;
	text-decoration: underline;
	margin-top: .35rem;
	display: inline-block;
}
.cml-drawer__item-remove:hover { color: var(--cml-burgundy); }

.cml-drawer__empty {
	text-align: center;
	padding: 2rem 1rem;
	color: var(--cml-ink-3);
}
.cml-drawer__empty svg { color: var(--cml-line-2); margin-bottom: .85rem; }
.cml-drawer__empty p { margin: 0 0 1rem; }

.cml-drawer__foot {
	padding: 1.25rem 1.5rem;
	border-top: 1px solid var(--cml-line);
	background: var(--cml-cream);
}
.cml-drawer__totals { margin-bottom: 1rem; }
.cml-drawer__line {
	display: flex;
	justify-content: space-between;
	gap: 1rem;
	padding: .25rem 0;
	color: var(--cml-ink-2);
	font-size: .92rem;
}
.cml-drawer__line--muted span:last-child { color: var(--cml-ink-3); font-size: .85rem; }
.cml-drawer__line--total {
	padding-top: .65rem;
	margin-top: .35rem;
	border-top: 1px solid var(--cml-line);
	color: var(--cml-ink);
	font-weight: 600;
	font-size: 1.05rem;
}
.cml-drawer__line--total span:last-child {
	font-family: var(--cml-serif);
	font-weight: 700;
	font-size: 1.25rem;
}
.cml-drawer__checkout {
	width: 100%;
	padding: .95rem;
	font-size: .85rem;
	letter-spacing: .12em;
	text-transform: uppercase;
	margin-bottom: .55rem;
}
.cml-drawer__view-full {
	display: block;
	text-align: center;
	color: var(--cml-burgundy);
	text-decoration: underline;
	font-weight: 500;
	font-size: .88rem;
}

/* ====== Cart page ====== */
.cml-cart-page { background: var(--cml-cream); }
.cml-cart-page__hero {
	background: linear-gradient(180deg, #fff 0%, var(--cml-cream) 100%);
	border-bottom: 1px solid var(--cml-line);
}
.cml-cart-page__hero-inner {
	max-width: 1180px;
	margin: 0 auto;
	padding: 1.5rem 1.25rem 1.75rem;
}
.cml-cart-page__h1 {
	font-family: var(--cml-serif);
	font-weight: 400;
	font-size: clamp(1.8rem, 3vw + .5rem, 2.5rem);
	margin: .35rem 0 .55rem;
	color: var(--cml-ink);
}
.cml-cart-page__meta {
	font-size: .92rem;
	color: var(--cml-ink-2);
	margin: 0;
}
.cml-cart-page__meta strong { color: var(--cml-ink); font-weight: 600; }

.cml-cart-page__wrap {
	max-width: 1180px;
	margin: 0 auto;
	padding: 1.75rem 1.25rem 3rem;
	display: grid;
	grid-template-columns: 1fr;
	gap: 1.5rem;
}
@media (min-width: 880px) {
	.cml-cart-page__wrap {
		grid-template-columns: minmax(0, 1.4fr) minmax(320px, .9fr);
		gap: 2.5rem;
	}
}

.cml-cart-page__items {
	background: #fff;
	border-radius: var(--cml-radius-lg);
	border: 1px solid var(--cml-line);
	box-shadow: var(--cml-shadow-sm);
	overflow: hidden;
}
.cml-cart-item {
	display: grid;
	grid-template-columns: 80px 1fr auto auto;
	gap: 1rem;
	padding: 1.25rem;
	border-bottom: 1px solid var(--cml-line);
	align-items: center;
}
.cml-cart-item:last-child { border-bottom: 0; }
@media (max-width: 600px) {
	.cml-cart-item { grid-template-columns: 70px 1fr; }
	.cml-cart-item__qty,
	.cml-cart-item__price { grid-column: 2; text-align: left; }
	.cml-cart-item__price { padding-top: .35rem; border-top: 1px dashed var(--cml-line); margin-top: .5rem; }
}
.cml-cart-item__media {
	width: 80px;
	height: 80px;
	border-radius: var(--cml-radius-md);
	background: var(--cml-cream-2);
	overflow: hidden;
	display: flex;
	align-items: center;
	justify-content: center;
	color: var(--cml-burgundy-3);
}
.cml-cart-item__media img { width: 100%; height: 100%; object-fit: cover; }
.cml-cart-item__name {
	font-family: var(--cml-serif);
	font-weight: 400;
	font-size: 1.1rem;
	margin: 0 0 .25rem;
	color: var(--cml-ink);
	line-height: 1.2;
}
.cml-cart-item__name a { color: inherit; text-decoration: none; }
.cml-cart-item__name a:hover { color: var(--cml-burgundy); }
.cml-cart-item__tier {
	font-size: .85rem;
	color: var(--cml-ink-2);
	margin: 0 0 .35rem;
}
.cml-cart-item__savings {
	font-size: .78rem;
	color: var(--cml-good);
	margin: 0;
}
.cml-cart-item__qty {
	font-size: 1rem;
	color: var(--cml-ink-2);
	font-weight: 600;
}
.cml-cart-item__price { text-align: right; }
.cml-cart-item__was {
	display: block;
	font-size: .85rem;
	color: var(--cml-ink-3);
	text-decoration: line-through;
}
.cml-cart-item__now {
	font-family: var(--cml-serif);
	font-weight: 700;
	font-size: 1.25rem;
	color: var(--cml-ink);
}
.cml-cart-item__remove {
	display: block;
	font-size: .78rem;
	color: var(--cml-ink-3);
	text-decoration: underline;
	margin-top: .35rem;
}
.cml-cart-item__remove:hover { color: var(--cml-burgundy); }

.cml-cart-page__summary {
	background: #fff;
	border-radius: var(--cml-radius-lg);
	border: 1px solid var(--cml-line);
	padding: 1.5rem;
	box-shadow: var(--cml-shadow-sm);
	align-self: start;
}
.cml-cart-page__summary h2 {
	font-family: var(--cml-serif);
	font-weight: 400;
	font-size: 1.3rem;
	margin: 0 0 1rem;
	padding-bottom: .75rem;
	border-bottom: 1px solid var(--cml-line);
}
.cml-cart-page__coupon { margin-bottom: 1.25rem; }
.cml-cart-page__coupon label {
	display: block;
	font-size: .82rem;
	font-weight: 600;
	color: var(--cml-ink-2);
	margin-bottom: .35rem;
	letter-spacing: .02em;
	text-transform: uppercase;
}
.cml-cart-page__coupon-row { display: flex; gap: .5rem; }
.cml-cart-page__coupon-row input {
	flex: 1;
	border: 1px solid var(--cml-line-2);
	border-radius: var(--cml-radius-sm);
	padding: .65rem .75rem;
	font-family: inherit;
	font-size: .92rem;
}
.cml-cart-page__coupon-row input:focus { outline: 2px solid var(--cml-burgundy); outline-offset: -1px; }

.cml-cart-page__totals { margin: 0; padding: 0; }
.cml-cart-page__totals div {
	display: flex;
	justify-content: space-between;
	gap: 1rem;
	padding: .55rem 0;
}
.cml-cart-page__totals dt {
	color: var(--cml-ink-2);
	font-weight: 500;
	margin: 0;
}
.cml-cart-page__totals dd { margin: 0; font-weight: 600; color: var(--cml-ink); }
.cml-cart-page__tax-line dd { color: var(--cml-ink-3); }
.cml-cart-page__total-line {
	padding-top: .85rem !important;
	margin-top: .35rem;
	border-top: 1px solid var(--cml-line);
}
.cml-cart-page__total-line dt { font-size: 1.05rem; font-weight: 600; color: var(--cml-ink); }
.cml-cart-page__total-line dd {
	font-family: var(--cml-serif);
	font-weight: 700;
	font-size: 1.55rem;
	color: var(--cml-ink);
}

.cml-cart-page__checkout {
	display: block;
	width: 100%;
	margin: 1.25rem 0 .75rem;
	padding: 1rem;
	font-size: .9rem;
	letter-spacing: .08em;
	text-transform: uppercase;
}
.cml-cart-page__pickup-note {
	font-size: .8rem;
	color: var(--cml-ink-3);
	padding: .75rem 0 1rem;
	border-bottom: 1px solid var(--cml-line);
	margin: 0 0 1rem;
}
.cml-cart-page__pickup-note strong { color: var(--cml-ink-2); font-weight: 600; }

.cml-cart-page__trust {
	list-style: none;
	padding: 0;
	margin: 0;
	display: flex;
	flex-direction: column;
	gap: .55rem;
}
.cml-cart-page__trust li {
	display: flex;
	align-items: center;
	gap: .5rem;
	font-size: .82rem;
	color: var(--cml-ink-2);
}
.cml-cart-page__trust svg { color: var(--cml-burgundy); flex-shrink: 0; }

.cml-cart-page__empty {
	max-width: 480px;
	margin: 3rem auto;
	text-align: center;
	padding: 3rem 1.5rem;
	background: #fff;
	border-radius: var(--cml-radius-lg);
	border: 1px dashed var(--cml-line-2);
}
.cml-cart-page__empty svg { color: var(--cml-line-2); margin-bottom: 1rem; }
.cml-cart-page__empty p { color: var(--cml-ink-2); margin: 0 0 1.25rem; }

/* ====== Checkout (mockup #06) ====== */
.cml-checkout-page { background: var(--cml-cream); }

.cml-checkout__help {
	background: var(--cml-cream-2);
	border-bottom: 1px solid var(--cml-line);
}
.cml-checkout__help-inner {
	max-width: 1180px;
	margin: 0 auto;
	padding: .6rem 1.25rem;
	display: flex;
	justify-content: space-between;
	gap: 1rem;
	font-size: .88rem;
	color: var(--cml-ink-2);
	flex-wrap: wrap;
}
.cml-checkout__help strong { color: var(--cml-ink); font-weight: 600; }
.cml-checkout__help-phone a {
	color: var(--cml-burgundy);
	font-weight: 600;
	text-decoration: none;
	margin-left: .25rem;
}
.cml-checkout__help-phone a:hover { text-decoration: underline; }

.cml-checkout__wrap {
	max-width: 1180px;
	margin: 0 auto;
	padding: 2rem 1.25rem 3rem;
	display: grid;
	grid-template-columns: 1fr;
	gap: 1.5rem;
}
@media (min-width: 920px) {
	.cml-checkout__wrap {
		grid-template-columns: minmax(0, 1.3fr) minmax(320px, .9fr);
		gap: 2.25rem;
	}
}

/* Step indicator bar */
.cml-checkout__steps-bar {
	background: #fff;
	border-bottom: 1px solid var(--cml-line);
}
.cml-checkout__steps-bar-inner {
	max-width: 1180px;
	margin: 0 auto;
	padding: 1rem 1.25rem;
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 1.5rem;
}
.cml-step-dot {
	display: inline-flex;
	align-items: center;
	gap: .5rem;
	font-size: .82rem;
	color: var(--cml-ink-3);
	letter-spacing: .04em;
	position: relative;
}
.cml-step-dot:not(:last-child)::after {
	content: "";
	display: inline-block;
	width: 2rem;
	height: 1px;
	background: var(--cml-line-2);
	margin-left: 1rem;
}
.cml-step-dot span {
	width: 1.5rem; height: 1.5rem;
	border-radius: 50%;
	background: var(--cml-cream);
	border: 1.5px solid var(--cml-line-2);
	display: inline-flex;
	align-items: center;
	justify-content: center;
	font-weight: 700;
	font-size: .85rem;
	color: var(--cml-ink-3);
}
.cml-step-dot em {
	font-style: normal;
	font-weight: 500;
}
.cml-step-dot.is-active span {
	background: var(--cml-burgundy);
	color: #fff;
	border-color: var(--cml-burgundy);
}
.cml-step-dot.is-active em { color: var(--cml-ink); font-weight: 600; }
.cml-step-dot.is-done span {
	background: var(--cml-good);
	border-color: var(--cml-good);
	color: #fff;
}
.cml-step-dot.is-done span::after {
	content: "✓";
	font-size: .8rem;
}
.cml-step-dot.is-done span > * { display: none; }

/* Stepped form sections */
.cml-checkout__form { margin: 0; }
.cml-checkout__step {
	background: #fff;
	border: 1px solid var(--cml-line);
	border-radius: var(--cml-radius-lg);
	margin-bottom: 1rem;
	overflow: hidden;
	box-shadow: var(--cml-shadow-sm);
	transition: opacity .2s;
}
.cml-checkout__step.is-locked {
	opacity: .5;
	pointer-events: none;
}
.cml-checkout__step.is-locked .cml-checkout__step-body { display: none; }
.cml-checkout__step.is-done .cml-checkout__step-body { display: none; }
.cml-checkout__step.is-current { opacity: 1; }
.cml-checkout__step-head {
	display: flex;
	align-items: center;
	gap: .85rem;
	padding: 1.25rem 1.5rem;
}
.cml-checkout__step-num {
	width: 1.85rem;
	height: 1.85rem;
	border-radius: 50%;
	background: var(--cml-cream);
	color: var(--cml-ink-2);
	border: 1.5px solid var(--cml-line-2);
	display: inline-flex;
	align-items: center;
	justify-content: center;
	font-family: var(--cml-serif);
	font-weight: 700;
	font-size: 1rem;
	flex-shrink: 0;
}
.cml-checkout__step.is-current .cml-checkout__step-num {
	background: var(--cml-burgundy);
	color: #fff;
	border-color: var(--cml-burgundy);
}
.cml-checkout__step.is-done .cml-checkout__step-num {
	background: var(--cml-good);
	border-color: var(--cml-good);
	color: #fff;
}
.cml-checkout__step-title {
	font-family: var(--cml-serif);
	font-weight: 400;
	font-size: 1.2rem;
	color: var(--cml-ink);
	margin: 0;
	flex: 1;
}
.cml-checkout__step-edit {
	background: transparent;
	border: 0;
	color: var(--cml-burgundy);
	font-size: .82rem;
	text-decoration: underline;
	cursor: pointer;
	padding: 0;
}
.cml-checkout__step.is-done .cml-checkout__step-edit { display: inline; }
.cml-checkout__step-body {
	padding: 0 1.5rem 1.5rem;
}
.cml-checkout__continue {
	width: 100%;
	margin-top: 1.25rem;
	padding: .95rem;
	font-size: .88rem;
	letter-spacing: .1em;
	text-transform: uppercase;
}
.cml-checkout__step-error {
	color: var(--cml-burgundy-2);
	font-size: .88rem;
	margin: .75rem 0 0;
	padding: .55rem .75rem;
	background: #fcf6f8;
	border-radius: var(--cml-radius-sm);
	border-left: 3px solid var(--cml-burgundy);
}

/* Consent box */
.cml-checkout__consent {
	display: flex !important;
	align-items: flex-start;
	gap: .65rem;
	margin: 1rem 0 0;
	padding: .85rem 1rem;
	background: var(--cml-cream);
	border: 1px solid var(--cml-line);
	border-radius: var(--cml-radius-md);
	font-size: .88rem;
	color: var(--cml-ink-2);
	line-height: 1.5;
	cursor: pointer;
}
.cml-checkout__consent input {
	margin-top: .2rem;
	accent-color: var(--cml-burgundy);
	flex-shrink: 0;
}
.cml-checkout__step-body label {
	display: block;
	font-size: .82rem;
	color: var(--cml-ink-2);
	font-weight: 500;
	margin-bottom: .25rem;
	margin-top: .85rem;
}
.cml-checkout__step-body input[type="text"],
.cml-checkout__step-body input[type="email"],
.cml-checkout__step-body input[type="tel"] {
	width: 100%;
	padding: .75rem .85rem;
	border: 1px solid var(--cml-line-2);
	border-radius: var(--cml-radius-sm);
	font-family: inherit;
	font-size: 1rem;
	background: #fff;
}
.cml-checkout__step-body input:focus { outline: 2px solid var(--cml-burgundy); outline-offset: -1px; border-color: var(--cml-burgundy); }
.cml-checkout__row {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 1rem;
}
@media (max-width: 540px) { .cml-checkout__row { grid-template-columns: 1fr; } }
.cml-checkout__checkbox {
	display: flex !important;
	align-items: center;
	gap: .55rem;
	margin: 1rem 0 0;
	font-size: .9rem;
	color: var(--cml-ink-2);
	cursor: pointer;
}
.cml-checkout__checkbox input { accent-color: var(--cml-burgundy); }
.cml-checkout__terms {
	font-size: .8rem;
	color: var(--cml-ink-3);
	margin: 1rem 0 0;
}
.cml-checkout__terms a {
	color: var(--cml-burgundy);
	text-decoration: underline;
}
.cml-checkout__note {
	font-size: .82rem;
	color: var(--cml-ink-3);
	margin: 1rem 0 0;
	font-style: italic;
}

/* Express checkout */
.cml-checkout__express {
	background: var(--cml-cream);
	border-radius: var(--cml-radius-md);
	padding: 1rem;
	margin-bottom: 1rem;
}
.cml-checkout__express-label {
	font-size: .75rem;
	font-weight: 600;
	letter-spacing: .12em;
	text-transform: uppercase;
	color: var(--cml-ink-3);
	margin: 0 0 .55rem;
}
.cml-checkout__express-row {
	display: grid;
	grid-template-columns: 1fr 1fr 1fr;
	gap: .5rem;
}
@media (max-width: 540px) { .cml-checkout__express-row { grid-template-columns: 1fr; } }
.cml-checkout__express-btn {
	background: var(--cml-ink);
	color: #fff;
	border: 0;
	padding: .75rem 1rem;
	border-radius: var(--cml-radius-sm);
	font-weight: 600;
	font-size: .85rem;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: .35rem;
	cursor: pointer;
	opacity: .5;
}
.cml-checkout__express-btn--google { background: #4285f4; }
.cml-checkout__express-btn--link { background: #00d4a3; color: var(--cml-ink); }
.cml-checkout__express-note {
	font-size: .75rem;
	color: var(--cml-ink-3);
	margin: .65rem 0 0;
	text-align: center;
}
.cml-checkout__or {
	text-align: center;
	margin: 1rem 0;
	position: relative;
}
.cml-checkout__or::before {
	content: "";
	position: absolute;
	left: 0; right: 0; top: 50%;
	height: 1px;
	background: var(--cml-line);
}
.cml-checkout__or span {
	background: #fff;
	padding: 0 .75rem;
	color: var(--cml-ink-3);
	font-size: .82rem;
	letter-spacing: .04em;
	position: relative;
}
.cml-checkout__no-gateways {
	background: #fdf6e8;
	border: 1px solid #f0e2c0;
	border-radius: var(--cml-radius-md);
	padding: 1rem;
	font-size: .88rem;
	color: var(--cml-ink-2);
}
.cml-checkout__no-gateways p { margin: 0 0 .5rem; }
.cml-checkout__no-gateways p:last-child { margin: 0; }

.cml-checkout__place-order {
	width: 100%;
	margin-top: 1.25rem;
	padding: 1.1rem;
	font-size: .92rem;
	letter-spacing: .1em;
	text-transform: uppercase;
}

/* RIGHT: summary */
.cml-checkout__summary {
	background: #fff;
	border-radius: var(--cml-radius-lg);
	border: 1px solid var(--cml-line);
	padding: 1.5rem;
	align-self: start;
	box-shadow: var(--cml-shadow-sm);
}
.cml-checkout__summary h2 {
	font-family: var(--cml-serif);
	font-weight: 400;
	font-size: 1.3rem;
	margin: 0 0 .25rem;
}
.cml-checkout__summary-clinic {
	font-size: .82rem;
	color: var(--cml-ink-3);
	margin: 0 0 1.25rem;
	padding-bottom: .85rem;
	border-bottom: 1px solid var(--cml-line);
}
.cml-checkout__summary-items {
	list-style: none;
	padding: 0;
	margin: 0 0 1.25rem;
}
.cml-checkout__summary-items li {
	display: grid;
	grid-template-columns: 48px 1fr auto;
	gap: .85rem;
	padding: .85rem 0;
	border-bottom: 1px solid var(--cml-line);
	align-items: center;
}
.cml-checkout__summary-items li:last-child { border-bottom: 0; }
.cml-checkout__summary-media {
	width: 48px;
	height: 48px;
	background: var(--cml-cream-2);
	border-radius: var(--cml-radius-sm);
	position: relative;
	overflow: hidden;
	display: flex;
	align-items: center;
	justify-content: center;
}
.cml-checkout__summary-media img { width: 100%; height: 100%; object-fit: cover; }
.cml-checkout__summary-ph { color: var(--cml-burgundy-3); opacity: .5; }
.cml-checkout__summary-qty {
	position: absolute;
	top: -.4rem;
	right: -.4rem;
	background: var(--cml-ink);
	color: #fff;
	font-size: .68rem;
	font-weight: 700;
	min-width: 18px;
	height: 18px;
	border-radius: 9px;
	padding: 0 5px;
	display: inline-flex;
	align-items: center;
	justify-content: center;
}
.cml-checkout__summary-name {
	font-family: var(--cml-serif);
	font-size: .98rem;
	margin: 0 0 .15rem;
	color: var(--cml-ink);
}
.cml-checkout__summary-tier {
	font-size: .78rem;
	color: var(--cml-ink-3);
	margin: 0;
}
.cml-checkout__summary-price {
	font-weight: 600;
	color: var(--cml-ink);
	margin: 0;
}

/* ----- Buttons ----- */
.cml-btn {
	box-sizing: border-box;       /* width:100% must include padding + border */
	display: inline-flex;
	align-items: center;
	justify-content: center;
	font-family: var(--cml-sans);
	font-weight: 600;
	font-size: .9rem;
	letter-spacing: .02em;
	padding: .7rem 1.25rem;
	border-radius: 999px;
	text-decoration: none;
	transition: background .15s, color .15s, border-color .15s;
	border: 1.5px solid transparent;
	cursor: pointer;
}
/* Form inputs use the same box model so they line up with buttons */
.cml-pdp-page input[type="text"],
.cml-pdp-page input[type="email"],
.cml-pdp-page input[type="tel"],
.cml-pdp-page select,
.cml-cart-page input[type="text"],
.cml-checkout-page input,
.cml-checkout-page select,
.cml-cart-page__coupon-row input,
.cml-cart-page__coupon-row button {
	box-sizing: border-box;
}
.cml-btn--primary {
	background: var(--cml-burgundy);
	color: #fff;
}
.cml-btn--primary:hover {
	background: var(--cml-burgundy-2);
	color: #fff;
}
.cml-btn--ghost {
	background: transparent;
	color: var(--cml-burgundy);
	border-color: var(--cml-burgundy);
}
.cml-btn--ghost:hover {
	background: var(--cml-rose);
}
.cml-btn--invert {
	background: #fff;
	color: var(--cml-burgundy);
}
.cml-btn--invert:hover {
	background: var(--cml-cream);
}

/* ----- Content stack ----- */
.cml-pdp__stack { display: grid; gap: 1.25rem; }
.cml-pdp__block {
	background: #fff;
	border: 1px solid var(--cml-line);
	border-radius: var(--cml-radius-lg);
	padding: 2rem;
	box-shadow: var(--cml-shadow-sm);
}
.cml-pdp__h2 {
	font-family: var(--cml-serif);
	font-weight: 400;
	font-size: 1.7rem;
	margin: 0 0 1.25rem;
	padding-bottom: .6rem;
	color: var(--cml-ink);
	line-height: 1.2;
	position: relative;
}
.cml-pdp__h2::after {
	content: "";
	position: absolute;
	left: 0;
	bottom: 0;
	width: 44px;
	height: 3px;
	border-radius: 3px;
	background: linear-gradient(90deg, var(--cml-burgundy), var(--cml-gold));
}
.cml-pdp__h3 {
	font-family: var(--cml-sans);
	font-size: .98rem;
	font-weight: 600;
	margin: 1.4rem 0 .6rem;
	color: var(--cml-ink);
}
.cml-pdp__block p { color: var(--cml-ink-2); margin: 0 0 .85rem; }

/* How it works — floating-number step cards */
.cml-pdp__how-steps {
	list-style: none;
	padding: 0;
	margin: 1.4rem 0 0;
	display: grid;
	gap: 1.25rem;
}
@media (min-width: 720px) {
	.cml-pdp__how-steps { grid-template-columns: repeat(3, 1fr); gap: 1.5rem; }
}
.cml-pdp__how-steps li {
	position: relative;
	margin-top: 1.4rem;
	padding: 2.5rem 1.4rem 1.5rem;
	background: linear-gradient(180deg, var(--cml-rose) 0%, #fff 55%);
	border: 1px solid var(--cml-line);
	border-radius: 16px;
	transition: transform .18s ease, box-shadow .18s ease, border-color .18s ease;
}
.cml-pdp__how-steps li:hover {
	transform: translateY(-3px);
	box-shadow: 0 16px 32px -20px rgba(122,31,61,.5);
	border-color: var(--cml-burgundy-3);
}
.cml-pdp__how-num {
	position: absolute;
	top: -1.4rem;
	left: 1.4rem;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 2.85rem;
	height: 2.85rem;
	border-radius: 50%;
	background: linear-gradient(150deg, var(--cml-burgundy-3), var(--cml-burgundy));
	color: #fff;
	font-family: var(--cml-serif);
	font-weight: 600;
	font-size: 1.2rem;
	border: 3px solid #fff;
	box-shadow: 0 8px 18px -8px rgba(122,31,61,.65);
	margin: 0;
}
.cml-pdp__how-steps h3 {
	font-family: var(--cml-sans);
	font-weight: 600;
	font-size: 1.05rem;
	margin: 0 0 .5rem;
	color: var(--cml-ink);
}
.cml-pdp__how-steps p { font-size: .92rem; line-height: 1.6; margin: 0; }

/* Checklists */
.cml-pdp__check {
	list-style: none;
	padding: 0;
	margin: 0;
}
.cml-pdp__check li {
	position: relative;
	padding: .45rem 0 .45rem 2rem;
	color: var(--cml-ink);
	line-height: 1.5;
}
.cml-pdp__check li::before {
	content: "";
	position: absolute;
	left: 0;
	top: .65rem;
	width: 1.25rem;
	height: 1.25rem;
	border-radius: 50%;
	background: var(--cml-rose) url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%237a1f3d' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'><polyline points='5 12 10 17 19 7'/></svg>") center/.8rem no-repeat;
}
.cml-pdp__check--rg li::before { background-color: #fbeed5; background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23c89a4a' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'><polyline points='5 12 10 17 19 7'/></svg>"); }

/* FAQ — card accordion */
.cml-pdp__faq-item {
	background: #fff;
	border: 1px solid var(--cml-line);
	border-radius: 14px;
	margin: 0 0 .7rem;
	padding: 0 1.25rem;
	transition: border-color .18s ease, box-shadow .18s ease, background .18s ease;
}
.cml-pdp__faq-item:last-child { margin-bottom: 0; }
.cml-pdp__faq-item:hover { border-color: var(--cml-burgundy-3); }
.cml-pdp__faq-item[open] {
	background: var(--cml-rose);
	border-color: var(--cml-burgundy-3);
	box-shadow: 0 12px 28px -20px rgba(122,31,61,.55);
}
.cml-pdp__faq-item summary {
	cursor: pointer;
	font-weight: 600;
	font-size: 1.02rem;
	color: var(--cml-ink);
	list-style: none;
	display: flex;
	justify-content: space-between;
	align-items: center;
	gap: 1rem;
	padding: 1.1rem 0;
}
.cml-pdp__faq-item[open] summary { color: var(--cml-burgundy); }
.cml-pdp__faq-item summary::-webkit-details-marker { display: none; }
.cml-pdp__faq-item summary::after {
	content: "";
	width: 26px;
	height: 26px;
	border-radius: 50%;
	background: var(--cml-rose) url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%237a1f3d' stroke-width='2.5' stroke-linecap='round'><line x1='12' y1='5' x2='12' y2='19'/><line x1='5' y1='12' x2='19' y2='12'/></svg>") center/13px no-repeat;
	transition: transform .2s ease, background-color .2s ease;
	flex-shrink: 0;
}
.cml-pdp__faq-item[open] summary::after {
	background-color: var(--cml-burgundy);
	background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23ffffff' stroke-width='2.5' stroke-linecap='round'><line x1='5' y1='12' x2='19' y2='12'/></svg>");
	transform: rotate(180deg);
}
.cml-pdp__faq-a {
	padding-bottom: 1.15rem;
	color: var(--cml-ink-2);
	line-height: 1.65;
	font-size: .95rem;
}
.cml-pdp__faq-a p:last-child { margin-bottom: 0; }

/* Contraindications */
.cml-pdp__contra {
	background: #fdf6e8;
	border: 1px solid #f0e2c0;
	border-left: 4px solid var(--cml-gold);
}
.cml-pdp__contra .cml-pdp__h2 { color: #6e5320; }
.cml-pdp__contra-intro {
	font-weight: 500;
	color: var(--cml-ink);
}
.cml-pdp__contra-list {
	padding-left: 1.2rem;
	margin: 0 0 1rem;
}
.cml-pdp__contra-list li {
	margin: .55rem 0;
	color: var(--cml-ink-2);
	line-height: 1.6;
}

/* Long form — editorial layout with labelled lead-ins */
.cml-pdp__longform { max-width: 72ch; }
.cml-pdp__longform p { line-height: 1.8; margin: 0 0 1.4rem; color: var(--cml-ink-2); }
.cml-pdp__longform p:first-of-type { font-size: 1.08rem; line-height: 1.7; color: var(--cml-ink); }
.cml-pdp__longform p:last-of-type { margin-bottom: 0; }
.cml-pdp__longform strong { color: var(--cml-ink); }
/* A paragraph that opens with a bold lead-in becomes a labelled subsection. */
.cml-pdp__longform p > strong:first-child {
	display: block;
	margin-bottom: .35rem;
	font-family: var(--cml-sans);
	font-weight: 700;
	font-size: .8rem;
	letter-spacing: .05em;
	text-transform: uppercase;
	color: var(--cml-burgundy);
}

/* Final consult CTA — gradient panel with sparkle */
.cml-pdp__consult-cta {
	position: relative;
	overflow: hidden;
	text-align: center;
	border-radius: var(--cml-radius-lg);
	padding: 3.25rem 2rem;
	color: #fff;
	background:
		radial-gradient(circle at 50% -25%, rgba(255,255,255,.18), transparent 55%),
		linear-gradient(135deg, var(--cml-burgundy) 0%, var(--cml-burgundy-2) 100%);
}
.cml-pdp__consult-cta::before {
	content: "";
	display: block;
	width: 38px;
	height: 38px;
	margin: 0 auto 1rem;
	background: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='%23ffffff'><path d='M12 2l1.9 6.4L20 10l-6.1 1.6L12 18l-1.9-6.4L4 10l6.1-1.6z'/><path d='M19 3l.7 2.3L22 6l-2.3.7L19 9l-.7-2.3L16 6l2.3-.7z' opacity='.7'/></svg>") center/contain no-repeat;
}
.cml-pdp__consult-cta-h {
	position: relative;
	font-family: var(--cml-serif);
	font-weight: 400;
	font-size: 2rem;
	color: #fff;
	margin: 0 0 .85rem;
	line-height: 1.2;
}
.cml-pdp__consult-cta p {
	position: relative;
	color: rgba(255,255,255,.9);
	margin: 0 auto 1.6rem;
	max-width: 540px;
	line-height: 1.6;
}
.cml-pdp__consult-cta .cml-btn { position: relative; }

/* ---- HQ announcement bar (Content Manager) ---- */
.cml-announce {
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 1rem;
	flex-wrap: wrap;
	background: var(--cml-burgundy, #7a1f3d);
	color: #fff;
	padding: .6rem 1.25rem;
	font-size: .95rem;
	text-align: center;
}
.cml-announce__text { font-weight: 500; }
.cml-announce__cta {
	color: #fff;
	font-weight: 700;
	text-decoration: underline;
	white-space: nowrap;
}
.cml-announce__cta:hover { opacity: .85; }

/* ---- Location SEO: "About this location" block on the shop archive ---- */
.cml-archive__about {
	margin: 2.5rem 0 0.5rem;
	padding: 1.75rem 1.85rem;
	background: var(--cml-cream, #faf7f4);
	border: 1px solid var(--cml-line, #ebe7e2);
	border-radius: 14px;
}
.cml-archive__about-h {
	font-size: 1.25rem;
	margin: 0 0 .65rem;
	color: var(--cml-burgundy, #7a1f3d);
}
.cml-archive__about-text {
	margin: 0 0 1rem;
	max-width: 760px;
	color: var(--cml-ink-2, #555);
	line-height: 1.65;
}
.cml-archive__about-nap {
	list-style: none;
	margin: 0;
	padding: 0;
	display: flex;
	flex-wrap: wrap;
	gap: .4rem 1.75rem;
	font-size: .92rem;
	color: var(--cml-ink-2, #555);
}
.cml-archive__about-nap li { margin: 0; }
.cml-archive__about-nap strong { color: var(--cml-ink, #1a1a1a); font-weight: 600; }
.cml-archive__about-nap a { color: var(--cml-burgundy, #7a1f3d); text-decoration: none; }
.cml-archive__about-nap a:hover { text-decoration: underline; }
