/*
 * accessory.css
 * Standalone recreation of Figma node 76:16010 ("Dental Accessories").
 * Styles ONLY this page's main content via .acc-* classes. The shared
 * header/footer chrome keeps its own storefront styling (footer layout is
 * nudged at the bottom of this file, scoped to body.acc-page).
 *
 * Figma tokens:
 *   Blue_Main #2DA7FA · Blue_Subtle #EDF7FF · Text #333536 · Muted #737A82
 *   BG/Default #F6F6F6 · Card #FDFDFD
 *   Title/Display 36/44 · Title/Title 24/30 · H3 14 · Body/Lead 16/22
 *   Body/Body-B 14 · Body/Body-sm 12 · Label/Button 16
 */

.acc-main {
	--acc-blue: #2da7fa;
	--acc-blue-subtle: #edf7ff;
	--acc-text: #333536;
	--acc-muted: #737a82;
	--acc-shell: min(1320px, 100% - 80px);
	color: var(--acc-text);
	font-family: "Montserrat", sans-serif;
}

.acc-main *,
.acc-main *::before,
.acc-main *::after {
	box-sizing: border-box;
}

.acc-shell {
	width: var(--acc-shell);
	margin-inline: auto;
}

/* Hero sits on a wider 18.75% gutter than the sections (Figma: hero copy x=360,
 * sections x=300), exactly like the homepage hero (.ft-section--hero .ft-shell).
 * Uses the homepage scaling formula so it HOLDS the 1200px design block down to
 * the stack breakpoint instead of collapsing the media column at ~1040px (flat
 * 62.5% gave only ~120px of media there). 62.5% only kicks in ≥1920px, so 4K is
 * unchanged. Applied from 991px up; below that it stacks. */
@media (min-width: 991px) {
	.acc-section--hero .acc-shell {
		width: min(100% - 48px, max(1200px, 62.5%));
		max-width: none;
	}
}

/* ---- Sections ---- */
.acc-section {
	padding: 80px 0;
	scroll-margin-top: calc(var(--shop-header-height, 96px) + 12px);
}

.acc-section--hero {
	background: #f6f6f6;
	padding: 56px 0 64px;
}

.acc-section--articulator,
.acc-section--screws {
	background: #fdfdfd;
}

.acc-section--bench,
.acc-section--plates,
.acc-section--adapters {
	background: #f6f6f6;
}

.acc-section--banner {
	background: #fcfcfc;
}

.acc-section--sim {
	background: var(--acc-blue-subtle);
}

/* ---- Section headings ---- */
.acc-head {
	display: grid;
	gap: 8px;
	margin-bottom: 32px;
}

.acc-head--center {
	justify-items: center;
	text-align: center;
}

.acc-eyebrow {
	margin: 0;
	font-size: 14px;
	font-weight: 600;
	line-height: 1.2;
	text-transform: uppercase;
	color: var(--acc-text);
}

.acc-title {
	margin: 0;
	font-size: 24px;
	line-height: 30px;
	font-weight: 700;
	color: var(--acc-text);
}

.acc-accent {
	color: var(--acc-blue);
}

/* ---- Buttons / links ---- */
.acc-btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 12px;
	width: fit-content;
	padding: 12px 32px;
	border: 1.5px solid transparent;
	border-radius: 8px;
	font-size: 16px;
	font-weight: 600;
	line-height: 1;
	cursor: pointer;
	text-decoration: none;
}

.acc-btn--primary {
	background: var(--acc-blue);
	color: #f6f6f6;
}

.acc-btn i {
	font-size: 15px;
}

.acc-cart {
	display: inline-flex;
	align-items: center;
	gap: 6px;
	color: var(--acc-blue);
	font-size: 14px;
	font-weight: 600;
	line-height: 1;
	text-decoration: none;
}

.acc-cart i {
	font-size: 14px;
}

/* ---- Hero ---- */
.acc-hero {
	display: grid;
	grid-template-columns: minmax(0, 480px) minmax(0, 1fr);
	gap: 48px;
	align-items: center;
}

.acc-hero__copy {
	display: grid;
	gap: 24px;
	max-width: 480px; /* Figma node 76:14199 copy column = 480px */
}

.acc-hero__badge {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	width: fit-content;
	padding: 8px 14px;
	background: #fdfdfd;
	border-radius: 999px;
	box-shadow: 0 8px 24px rgba(39, 55, 75, 0.08);
	font-size: 14px;
	font-weight: 600;
}

.acc-hero__badge i {
	font-size: 15px;
	color: var(--acc-blue);
}

.acc-hero__badge-icon {
	width: 16px;
	height: 16px;
	color: var(--acc-blue);
	flex: none;
}

.acc-hero__title {
	margin: 0;
	font-size: 36px;
	line-height: 44px;
	font-weight: 700;
}

.acc-hero__desc {
	margin: 0;
	font-size: 16px;
	line-height: 22px;
	font-weight: 500;
	color: var(--acc-muted);
}

.acc-hero__media {
	position: relative;
	display: flex;
	align-items: center;
	justify-content: center;
}

/* Hero cluster wrapper. Mobile (stacked) value: fills the single column, capped.
 * The desktop sizing is in the min-width:991px block below — confining the
 * cluster to the narrow media column (672px) made it render ~40% smaller than the
 * Figma hero (node 76:14185: the cluster + manikin head fill the right half), so
 * desktop sizes it relative to the viewport and lets it overflow its column. */
.acc-hero__media-stack {
	position: relative;
	width: 100%;
	max-width: 672px;
}

.acc-hero__media-stack img {
	display: block;
	width: 100%;
	height: auto;
	object-fit: contain;
}

/* Desktop: size the cluster to the Figma proportion (~49vw → the manikin head
 * lands at ~16% of the viewport, matching node 76:14185) instead of the media
 * column. flex:none keeps the flex row from shrinking it back to the column;
 * left-aligning (flex-start) makes it start after the copy and overflow toward
 * the right edge, exactly as the design overhangs the content gutter. 49vw scales
 * correctly across desktop AND 4K (941px@1920, 1882px@3840 — both 2× the design).
 * The max-width is a safety cap so the cluster never clips the right edge in the
 * ~991–1082px band where the fixed copy column pushes its start too far right. */
@media (min-width: 991px) {
	.acc-hero__media {
		justify-content: flex-start;
		overflow: visible;
	}
	.acc-hero__media-stack {
		width: 49vw;
		max-width: calc(100vw - 600px);
		flex: none;
	}
}

/* ---- Generic product card grids (Articulator / Screws / Adapters) ---- */
.acc-grid {
	display: grid;
	gap: 16px;
}

.acc-grid--4 {
	grid-template-columns: repeat(4, minmax(0, 1fr));
}

.acc-grid--5 {
	grid-template-columns: repeat(5, minmax(0, 1fr));
}

.acc-card {
	display: flex;
	flex-direction: column;
	gap: 8px;
	padding: 24px 22px;
	border-radius: 16px;
}

.acc-card--blue {
	background: var(--acc-blue-subtle);
}

.acc-card--white {
	background: #ffffff;
	box-shadow: 0 12px 32px rgba(20, 33, 50, 0.06);
}

.acc-card__title {
	margin: 0;
	font-size: 14px;
	font-weight: 600;
	line-height: 1.25;
	color: var(--acc-text);
}

.acc-card__desc {
	margin: 0;
	font-size: 12px;
	font-weight: 500;
	line-height: 1.45;
	color: var(--acc-muted);
}

.acc-card__img {
	display: flex;
	align-items: center;
	justify-content: center;
}

.acc-card__img img {
	display: block;
	max-width: 100%;
	object-fit: contain;
}

/* Variant: title + desc on top, product in the middle, cart pinned bottom */
.acc-card--toptext .acc-card__text {
	display: grid;
	gap: 8px;
}

.acc-card--toptext .acc-card__img {
	flex: 1 1 auto;
	min-height: 170px;
	padding: 12px 0;
}

.acc-card--toptext .acc-card__img img {
	max-height: 200px;
}

.acc-card--toptext .acc-cart {
	margin-top: 8px;
	align-self: center;
}

/* Variant: product on top, centered text, cart pinned bottom */
.acc-card--centered {
	align-items: center;
	text-align: center;
}

.acc-card--centered .acc-card__img {
	width: 100%;
	min-height: 170px;
	margin-bottom: 8px;
}

.acc-card--centered .acc-card__img img {
	max-height: 180px;
}

.acc-card--centered .acc-cart {
	margin-top: auto;
	padding-top: 8px;
}

/* ---- Bench Mounts ---- */
.acc-bench {
	display: grid;
	grid-template-columns: 1fr 1fr 0.56fr;
	gap: 16px;
	align-items: stretch;
}

.acc-bcard {
	display: flex;
	align-items: center;
	gap: 20px;
	padding: 28px 32px;
	background: #ffffff;
	border-radius: 16px;
	box-shadow: 0 12px 32px rgba(20, 33, 50, 0.06);
}

.acc-bcard__text {
	display: grid;
	gap: 10px;
	flex: 1 1 auto;
}

.acc-bcard__img {
	flex: 0 0 38%;
	display: flex;
	align-items: center;
	justify-content: center;
	align-self: stretch;
	background: var(--acc-blue-subtle);
	border-radius: 12px;
	padding: 16px;
}

.acc-bcard__img img {
	display: block;
	max-width: 100%;
	max-height: 168px;
	object-fit: contain;
}

.acc-video {
	margin: 0;
	display: flex;
	flex-direction: column;
	justify-content: center;
	background: #ffffff;
	border-radius: 16px;
	box-shadow: 0 12px 32px rgba(20, 33, 50, 0.06);
	overflow: hidden;
}

/* The render bakes the video thumbnail + "Bench Mount Instruction" caption on a
 * white field. Wrap it in a real white card (matching .acc-bcard: same radius +
 * shadow) and centre it so the white box lines up with the other two items. */
.acc-video img {
	display: block;
	width: 100%;
}

/* ---- CheckMate banners ---- */
.acc-banner {
	display: grid;
	grid-template-columns: minmax(0, 1fr) minmax(0, 0.78fr);
	gap: 48px;
	align-items: center;
	/* Keep the card + product as a tight, centred group rather than spread to
	 * the shell edges (matches the Figma layout, which sits ~1100/1920 wide). */
	max-width: 1060px;
	margin-inline: auto;
}

.acc-banner__card {
	display: grid;
	gap: 16px;
	padding: 40px;
	background: #f3f5f9;
	border-radius: 16px;
}

.acc-banner__card .acc-card__desc {
	font-size: 14px;
	line-height: 1.5;
}

.acc-banner__card .acc-cart {
	margin-top: 8px;
}

.acc-banner__media {
	display: flex;
	align-items: center;
	justify-content: center;
}

.acc-banner__media img {
	display: block;
	width: 100%;
	max-width: 420px;
	height: auto;
	object-fit: contain;
}

/* Image-left / card-right variant — the tools cluster reads larger than the
 * single CheckMate product, so give its (left) media column the larger share.
 * Per the Figma layout the tools image hugs the left edge and sits well clear
 * of the card, so widen the column gap and left-align the media. */
.acc-banner--reverse {
	grid-template-columns: minmax(0, 1fr) minmax(0, 0.82fr);
	gap: 100px;
	max-width: 1140px;
}

.acc-banner--reverse .acc-banner__media {
	justify-content: flex-start;
}

.acc-banner--reverse .acc-banner__media img {
	max-width: 540px;
}

/* ---- Simulation Accessories ---- */
.acc-sim {
	display: grid;
	grid-template-columns: repeat(3, minmax(0, 1fr));
	gap: 16px;
}

.acc-simcard {
	position: relative;
	display: flex;
	flex-direction: column;
	min-height: 280px;
	padding: 24px;
	background: #ffffff;
	border-radius: 16px;
	box-shadow: 0 12px 32px rgba(20, 33, 50, 0.06);
	overflow: hidden;
}

.acc-simcard__dot {
	position: absolute;
	top: 24px;
	left: 24px;
	width: 24px;
	height: 24px;
	border-radius: 999px;
	background: var(--acc-blue);
	z-index: 1;
}

/* Image sits in the top-right in normal flow; the body's margin-top:auto pins
 * the copy to the bottom of the card. Because the image is in flow (not
 * absolutely positioned) the text can never slide underneath it, no matter how
 * long the description runs. Image kept compact to match the design. */
.acc-simcard__img {
	align-self: flex-end;
	width: 56%;
	max-width: 210px;
	height: 170px; /* Figma sim products read large (≈138–173 tall); 150 still too small */
	display: flex;
	align-items: flex-start;
	justify-content: flex-end;
}

.acc-simcard__img img {
	max-width: 100%;
	max-height: 100%;
	object-fit: contain;
}

.acc-simcard__body {
	margin-top: auto;
	display: grid;
	gap: 8px;
}

/* Wide Clear Face card — copy on the left, a large product image anchored to
 * the bottom-right (per the design). The image is absolutely positioned so it
 * can read large without pushing the copy around. */
.acc-simcard--wide {
	grid-column: span 2;
	min-height: 280px;
}

/* Figma: the Clear Face image box is 200×273, on the right edge of the wide card
 * and vertically centred (was filling the full card height — far too big). */
.acc-simcard--wide .acc-simcard__img {
	position: absolute;
	top: 50%;
	right: 48px;
	transform: translateY(-50%);
	width: 200px;
	max-width: 200px;
	height: 273px;
	align-items: center;
	justify-content: center;
}

.acc-simcard--wide .acc-simcard__body {
	margin-top: auto;
	max-width: 48%;
}

/* ---- ModuPRO Plates ---- */
.acc-plates {
	display: grid;
	grid-template-columns: 1fr 1.7fr;
	gap: 16px;
	align-items: stretch;
}

.acc-pcard {
	display: flex;
	flex-direction: column;
	gap: 16px;
	padding: 24px;
	background: #ffffff;
	border-radius: 16px;
	box-shadow: 0 12px 32px rgba(20, 33, 50, 0.06);
}

.acc-pcard__img {
	display: flex;
	align-items: center;
	justify-content: center;
	background: var(--acc-blue-subtle);
	border-radius: 12px;
	padding: 24px;
	min-height: 190px;
}

.acc-pcard__img img {
	display: block;
	max-width: 100%;
	max-height: 185px;
	object-fit: contain;
}

.acc-pcard__body {
	display: flex;
	flex-direction: column;
	gap: 8px;
	flex: 1 1 auto;
}

.acc-pcard__body .acc-card__desc {
	font-size: 13px;
}

/* Pin the cart to the bottom of the body so it lines up across both plate cards
 * regardless of differing description / image heights. */
.acc-pcard__body .acc-cart {
	margin-top: auto;
	padding-top: 8px;
}

/* The DH & Calibration strip render already includes its own blue panel, so
 * let it fill the image block edge-to-edge instead of nesting a second panel. */
.acc-pcard--wide .acc-pcard__img {
	padding: 0;
	background: transparent;
	min-height: 0;
	overflow: hidden;
}

.acc-pcard--wide .acc-pcard__img img {
	width: 100%;
	max-height: none;
	height: auto;
	border-radius: 12px;
}

/* ============================================================
 * Responsive — CSS-only reflow, same convention as modupro / charlie /
 * licensure: a tablet step → a uniform 2-col phone band (450px+) →
 * 1-col below 450px. Min target width 325px. Hero stacks copy-first.
 * ============================================================ */
@media (max-width: 1100px) {
	.acc-grid--5 {
		grid-template-columns: repeat(3, minmax(0, 1fr));
	}
}

@media (max-width: 990px) {
	.acc-section {
		padding: 64px 0;
	}

	/* Hero stacks: copy first (DOM order), image below — matches Figma mobile. */
	.acc-hero {
		grid-template-columns: 1fr;
		gap: 32px;
		text-align: center;
		justify-items: center;
	}

	.acc-hero__copy {
		max-width: none;
		justify-items: center;
	}

	/* All product grids collapse to one uniform 2-col layout (convention). */
	.acc-grid--4,
	.acc-grid--5,
	.acc-sim {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}

	/* Bench cards stack full-width (like charlie's Titan cards + the Figma mobile
	 * single-card carousel) rather than two cramped side-by-side cards. */
	.acc-bench {
		grid-template-columns: 1fr;
	}

	.acc-video {
		max-width: 480px;
		margin-inline: auto;
	}

	/* Clear Face stops spanning + drops its absolute image so all five sim cards
	 * are uniform same-size 2-col cards (avoids the span-2 auto-placement gap). */
	.acc-simcard--wide {
		grid-column: auto;
	}

	.acc-simcard--wide .acc-simcard__img {
		position: static;
		top: auto;
		right: auto;
		transform: none;
		align-self: flex-end;
		width: 56%;
		max-width: 210px;
		height: 170px;
		align-items: flex-start;
		justify-content: flex-end;
	}

	.acc-simcard--wide .acc-simcard__body {
		max-width: none;
	}

	/* Banners + plates stack (card text first, product below). */
	.acc-banner,
	.acc-banner--reverse {
		grid-template-columns: 1fr;
		gap: 28px;
	}

	.acc-banner--reverse .acc-banner__media {
		order: 2;
	}

	.acc-plates {
		grid-template-columns: 1fr;
	}
}

@media (max-width: 600px) {
	.acc-section {
		padding: 48px 0;
	}

	.acc-section--hero {
		padding: 40px 0 48px;
	}

	/* Bench card → image on top, text below. */
	.acc-bcard {
		flex-direction: column;
		align-items: stretch;
		text-align: left;
	}

	.acc-bcard__img {
		flex-basis: auto;
		order: -1;
	}

	.acc-video {
		max-width: none;
	}
}

/* Below 450 → single column (convention); narrow the gutter to 16px each side. */
@media (max-width: 449px) {
	.acc-grid--4,
	.acc-grid--5,
	.acc-sim {
		grid-template-columns: 1fr;
	}

	.acc-simcard,
	.acc-simcard--wide {
		min-height: 0;
	}

	.acc-simcard__img,
	.acc-simcard--wide .acc-simcard__img {
		position: static;
		width: 100%;
		max-width: none;
		height: 150px;
		justify-content: center;
		margin: 8px 0 16px;
	}

	.acc-simcard__dot {
		display: none;
	}

	.acc-simcard__body,
	.acc-simcard--wide .acc-simcard__body {
		max-width: none;
	}

	.acc-main {
		--acc-shell: min(1320px, 100% - 32px);
	}
}

/* ============================================================
 * 4K / ultra-wide — scale the desktop layout up ~2.2x to match the
 * shared header (homePage_design.css widens --shop-shell at this same
 * breakpoint). Mirrors new/homepage.css.
 * ============================================================ */
@media (min-width: 3000px) {
	.acc-main {
		/* 2640px block → 600px (15.625%) gutter at 3840, matching the homepage's
		 * 4K split sections (.ft-split max-width: 2640). Hero overrides this with
		 * the 18.75% %-based rule above. */
		--acc-shell: min(2640px, 100% - 180px);
	}

	.acc-section {
		padding: 176px 0;
	}

	.acc-section--hero {
		padding: 124px 0 140px;
	}

	.acc-eyebrow {
		font-size: 30px;
	}

	.acc-title {
		font-size: 52px;
		line-height: 64px;
	}

	.acc-head {
		gap: 18px;
		margin-bottom: 70px;
	}

	.acc-hero__title {
		font-size: 78px;
		line-height: 96px;
	}

	.acc-hero {
		gap: 96px;
		/* Scale the copy column with everything else (2× the 480px base). Without
		 * this the column stayed capped at 480 and the hero text was crammed into
		 * half-width at 4K. */
		grid-template-columns: minmax(0, 960px) minmax(0, 1fr);
	}

	.acc-banner {
		gap: 96px;
		max-width: 2380px;
	}

	/* The shared 2380 above scales the (card-left) banner ~2.25×, so its text
	 * block grew ~12% past the design at 4K. Pin it to 2× the 1080p width (2×1060)
	 * so the card keeps the same proportion it has at 1080p. Reverse keeps 2380. */
	.acc-banner:not(.acc-banner--reverse) {
		max-width: 2120px;
	}

	/* Reverse banner: 2× its 1080p base (max-width 1140, gap 100). The shared
	 * rule above left it at 2380 / gap 96, so the card was slightly oversized and
	 * the tools image sat too close to the card. */
	.acc-banner--reverse {
		max-width: 2280px;
		gap: 200px;
	}

	.acc-hero__copy {
		max-width: 960px; /* 480 × 2 */
		gap: 53px;
	}

	.acc-hero__badge {
		padding: 18px 31px;
		font-size: 30px;
	}

	.acc-hero__desc,
	.acc-banner__card .acc-card__desc {
		font-size: 34px;
		line-height: 48px;
	}

	.acc-btn,
	.acc-btn i {
		font-size: 34px;
		gap: 26px;
	}

	.acc-btn--primary {
		padding: 26px 70px;
	}

	.acc-cart,
	.acc-cart i,
	.acc-video figcaption {
		font-size: 28px;
		gap: 12px;
	}

	/* Cards: 2× the 1920 Figma base, matching the homepage 4K scale */
	.acc-card,
	.acc-bcard,
	.acc-pcard,
	.acc-simcard,
	.acc-banner__card {
		border-radius: 32px;
		padding: 48px 44px;
		gap: 16px;
	}

	/* Gaps between cards stayed at the 16px base, crowding the cards at 4K. 2×. */
	.acc-grid,
	.acc-sim,
	.acc-bench,
	.acc-plates {
		gap: 32px;
	}

	/* Banner cards need 2× their 1080p 40px padding for the same whitespace. */
	.acc-banner__card {
		padding: 80px;
		gap: 32px;
	}

	/* Bench cards (1080p padding 28/32, gap 20) — the shared 48/44 above under-
	 * scaled them; bring to 2×. */
	.acc-bcard {
		padding: 56px 64px;
		gap: 40px;
	}

	/* Plate card body/image gap was 16 at base → 2×. */
	.acc-pcard {
		gap: 32px;
	}

	.acc-video {
		border-radius: 32px;
	}

	.acc-card__title {
		font-size: 28px;
	}

	.acc-card__desc {
		font-size: 24px;
		line-height: 1.45;
	}

	.acc-pcard__body .acc-card__desc,
	.acc-banner__card .acc-card__desc {
		font-size: 28px;
	}

	.acc-card--toptext .acc-card__img img,
	.acc-card--centered .acc-card__img img {
		max-height: 360px;
	}

	.acc-card--toptext .acc-card__img,
	.acc-card--centered .acc-card__img {
		min-height: 340px;
	}

	.acc-bcard__img img {
		max-height: 336px;
	}

	.acc-simcard {
		min-height: 560px;
	}

	.acc-simcard__dot {
		top: 48px;
		left: 48px;
		width: 48px;
		height: 48px;
	}

	.acc-simcard__img {
		height: 340px;
		max-width: 420px;
	}

	/* Wide Clear Face image scaled ~2× (200×273 → 400×546) to keep pace with the
	 * scaled-up card; needed because this selector outranks the rule above. */
	.acc-simcard--wide .acc-simcard__img {
		width: 400px;
		max-width: 400px;
		height: 546px;
		right: 96px;
	}

	.acc-pcard__img {
		min-height: 380px;
		border-radius: 24px;
	}

	.acc-pcard__img img {
		max-height: 370px;
	}

	.acc-banner__media img {
		max-width: 840px; /* 2× the 420px 1080p cap; only the card-left banner uses this */
	}

	/* The reverse banner's base image rule has 2-class specificity, so the 980px
	 * cap above never reaches it (it stayed pinned at the 540px base width and
	 * looked tiny at 4K). Scale it with its column to keep the 1080p proportion. */
	.acc-banner--reverse .acc-banner__media img {
		max-width: 1080px; /* 2× the 540px 1080p cap */
	}

	/* Let the viewport-relative 49vw width (set in the min-width:991px block) carry
	 * through to 4K = 1882px, i.e. 2× the 1920 size. The old 1344px cap re-confined
	 * the cluster to the media column and shrank it again at 4K. */
	.acc-hero__media-stack {
		max-width: none;
	}
}

/* ============================================================
 * Shared footer — match new/homepage.php's footer treatment, scoped to
 * body.acc-page so only this page is affected.
 * ============================================================ */
@media (min-width: 991px) {
	body.acc-page .shop-footer__grid {
		grid-template-columns: 1fr repeat(4, minmax(0, max-content));
		gap: 100px;
		align-items: start;
	}

	body.acc-page .shop-footer__brand {
		max-width: 370px;
	}
}

@media (max-width: 680px) {
	body.acc-page .shop-footer__main {
		padding: 48px 0;
	}

	body.acc-page .shop-footer__grid {
		display: grid;
		grid-template-columns: repeat(3, minmax(0, 1fr));
		gap: 28px 16px;
		align-items: start;
	}

	body.acc-page .shop-footer__brand {
		grid-column: 1 / -1;
		margin-bottom: 4px;
	}

	body.acc-page .shop-footer__column h3 {
		font-size: 16px;
	}

	body.acc-page .shop-footer__column a,
	body.acc-page .shop-footer__brand p {
		font-size: 15px;
		line-height: 1.9;
	}

	body.acc-page .shop-footer__bar-inner {
		gap: 12px;
	}

	body.acc-page .shop-footer__policies {
		flex-direction: row;
		flex-wrap: nowrap;
		align-items: center;
		gap: 14px;
	}

	body.acc-page .shop-footer__policies a {
		font-size: 10px;
		white-space: nowrap;
	}

	body.acc-page .shop-footer__youtube img {
		height: 22px;
	}
}

@media (max-width: 380px) {
	body.acc-page .shop-footer__bar-inner {
		flex-wrap: wrap;
		gap: 10px;
	}

	body.acc-page .shop-footer__policies {
		flex-wrap: wrap;
		gap: 8px 12px;
	}
}

/* 4K shared header + footer (mirrors new/homepage.css / new/charlie.css).
 * Without this the shared chrome stays ~1.2x while this page's content is
 * scaled ~2.24x at 4K, making the header and footer look tiny. */
@media (min-width: 3000px) {
	body.acc-page {
		--shop-header-height: 210px;
	}

	body.acc-page .shop-header__brand img {
		width: 388px;
	}

	body.acc-page .shop-nav__link {
		gap: 18px;
		padding: 20px 26px;
		font-size: 33px;
	}

	body.acc-page .shop-nav__caret {
		font-size: 31px;
	}

	body.acc-page .shop-header__actions {
		gap: 31px;
	}

	body.acc-page .shop-header__actions a,
	body.acc-page .shop-header__icon-btn,
	body.acc-page .shop-header__search-trigger {
		width: 88px;
		height: 88px;
		font-size: 44px;
	}

	body.acc-page .shop-desktop-search {
		width: 88px;
		height: 106px;
	}

	body.acc-page .shop-desktop-search input {
		font-size: 40px;
	}

	body.acc-page .shop-footer__main {
		padding: 158px 0;
	}

	body.acc-page .shop-footer__grid {
		gap: 220px;
	}

	body.acc-page .shop-footer__brand {
		max-width: 810px;
	}

	body.acc-page .shop-footer__brand img {
		width: 360px;
		margin-bottom: 35px;
	}

	body.acc-page .shop-footer__brand p,
	body.acc-page .shop-footer__column a {
		font-size: 35px;
	}

	body.acc-page .shop-footer__column h3 {
		margin-bottom: 26px;
		font-size: 40px;
	}

	body.acc-page .shop-footer__bar-inner {
		gap: 53px;
		padding: 62px 0;
	}

	body.acc-page .shop-footer__policies {
		gap: 106px;
	}

	body.acc-page .shop-footer__policies a {
		font-size: 35px;
	}

	body.acc-page .shop-footer__youtube img {
		height: 62px;
	}
}
