/* ===== Page: Collections (light theme continues) ===== */

/* Reuse global palette/typography from styles/style.css */

/* Utilities */
.sheen {
	position: relative;
	overflow: hidden;
}
.sheen::after {
	content: '';
	position: absolute;
	inset: -20%;
	background: linear-gradient(
		110deg,
		rgba(255, 255, 255, 0) 30%,
		rgba(255, 255, 255, 0.5) 50%,
		rgba(255, 255, 255, 0) 70%
	);
	transform: translateX(-120%) rotate(8deg);
	transition: transform 0.8s ease;
}
.sheen:hover::after {
	transform: translateX(120%) rotate(8deg);
}

/* ---------- Section 1: Collections Hero ---------- */
.c-hero {
	padding: clamp(40px, 6vw, 88px) 20px;
	background: radial-gradient(1200px 600px at 10% -10%, #fff, transparent 55%),
		linear-gradient(#fff, #fff) padding-box,
		linear-gradient(180deg, #ffffff 0%, var(--bg-soft) 100%);
	border-bottom: 1px solid var(--line);
	margin-top: 40px;
}
.c-hero-wrap {
	max-width: var(--maxw);
	margin: 0 auto;
	display: grid;
	grid-template-columns: 1.05fr 0.95fr;
	gap: clamp(16px, 3vw, 36px);
	align-items: start;
}
.c-hero .title {
	font-family: 'Playfair Display', serif;
	font-weight: 600;
	font-size: clamp(26px, 3.6vw, 44px);
	line-height: 1.15;
	margin: 0 0 10px;
}
.c-hero .lead {
	color: var(--muted);
	max-width: 62ch;
	margin: 0 0 12px;
}
.c-hero .ticks {
	list-style: none;
	padding: 0;
	margin: 0;
	display: grid;
	gap: 8px;
	color: var(--muted);
}
.c-hero .ticks li {
	padding: 6px 10px;
	border: 1px dashed var(--line);
	border-radius: 999px;
	width: fit-content;
}

/* Horizontal strip with scroll-snap */
.c-hero-strip {
	position: relative;
	overflow-x: auto;
	overflow-y: hidden;
	overscroll-behavior-x: contain;
	scroll-snap-type: x mandatory;
	-webkit-overflow-scrolling: touch;
	border-radius: var(--radius-sm);
	padding-bottom: 6px;
	-webkit-mask-image: linear-gradient(
		90deg,
		transparent 0,
		#000 4%,
		#000 96%,
		transparent 100%
	);
	mask-image: linear-gradient(
		90deg,
		transparent 0,
		#000 4%,
		#000 96%,
		transparent 100%
	);
}
.c-hero .strip {
	display: flex;
	gap: 12px;
	align-items: stretch;
	scroll-padding-inline: 20px;
	padding: 2px 2px 8px;
}
.c-hero .card {
	scroll-snap-align: start;
	flex: 0 0 auto;
	width: clamp(180px, 32vw, 320px);
	max-width: 350px; /* global requirement */
	background: #fff;
	border: 1px solid var(--line);
	border-radius: var(--radius-sm);
	box-shadow: var(--shadow);
	transition: transform 0.24s ease, box-shadow 0.24s ease;
}
.c-hero .card:hover {
	transform: translateY(-4px);
	box-shadow: 0 16px 36px rgba(27, 33, 36, 0.12);
}
.c-hero .card figure {
	position: relative;
	margin: 0;
}
.c-hero .card img {
	display: block;
	width: 100%;
	height: auto;
	max-width: 350px;
	aspect-ratio: 4/3;
	object-fit: cover;
}
.c-hero .card figcaption {
	position: absolute;
	left: 8px;
	bottom: 8px;
	padding: 6px 10px;
	border-radius: 999px;
	background: #fff;
	color: var(--muted);
	font-weight: 700;
	box-shadow: var(--shadow);
}
.c-hero .strip-fade {
	pointer-events: none;
	position: absolute;
	inset: 0;
	background: linear-gradient(
				90deg,
				rgba(255, 255, 255, 1),
				rgba(255, 255, 255, 0) 60%
			)
			left / 80px 100% no-repeat,
		linear-gradient(270deg, rgba(255, 255, 255, 1), rgba(255, 255, 255, 0) 60%)
			right / 80px 100% no-repeat;
}

/* ---------- Section 2: Tapestry (grid mosaic) ---------- */
.tapestry {
	background: #fff;
	border-bottom: 1px solid var(--line);
}
.tapestry .tap-grid {
	max-width: var(--maxw);
	margin: 10px auto 14px;
	padding: 0 20px;
	display: grid;
	grid-template-columns: repeat(10, 1fr);
	grid-auto-rows: 120px;
	gap: 12px;
}
.tapestry .tile {
	background: #fff;
	border: 1px solid var(--line);
	border-radius: var(--radius);
	box-shadow: var(--shadow);
	overflow: hidden;
	position: relative;
}
.tapestry .tile img {
	width: 100%;
	height: 100%;
	max-width: 350px;
	object-fit: cover;
	display: block;
}
.tapestry .tile figcaption {
	position: absolute;
	left: 8px;
	bottom: 8px;
	padding: 6px 10px;
	border-radius: 999px;
	background: #fff;
	color: var(--muted);
	font-weight: 700;
	box-shadow: var(--shadow);
}
/* Mosaic areas */
.t1 {
	grid-column: 1 / span 4;
	grid-row: 1 / span 3;
}
.t2 {
	grid-column: 5 / span 3;
	grid-row: 1 / span 2;
}
.t3 {
	grid-column: 8 / span 3;
	grid-row: 1 / span 3;
}
.t4 {
	grid-column: 1 / span 3;
	grid-row: 4 / span 2;
}
.t5 {
	grid-column: 4 / span 4;
	grid-row: 3 / span 3;
}

.tap-note {
	max-width: var(--maxw);
	margin: 0 auto 14px;
	padding: 0 20px;
	color: var(--muted);
}

/* ---------- Section 3: Occasions ---------- */
.occasions {
	background: var(--bg-soft);
	border-top: 1px solid var(--line);
	border-bottom: 1px solid var(--line);
}
.oc-grid {
	max-width: var(--maxw);
	margin: 8px auto 18px;
	padding: 0 20px;
	list-style: none;
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	gap: 12px;
}
.oc-card {
	background: #fff;
	border: 1px solid var(--line);
	border-radius: var(--radius);
	box-shadow: var(--shadow);
	padding: 12px;
	display: grid;
	grid-template-columns: 120px 1fr;
	gap: 12px;
	align-items: start;
	transition: transform 0.24s ease, box-shadow 0.24s ease;
}
.oc-card:hover {
	transform: translateY(-4px);
	box-shadow: 0 16px 36px rgba(27, 33, 36, 0.12);
}
.oc-pic img {
	width: 100%;
	height: auto;
	max-width: 350px;
	border-radius: 12px;
}
.oc-copy h3 {
	margin: 0 0 6px;
	font-size: clamp(16px, 2vw, 20px);
}
.oc-copy p {
	margin: 0;
	color: var(--muted);
}

/* ---------- Section 4: Scale & Proportion ---------- */
.scale-lab {
	background: #fff;
	border-bottom: 1px solid var(--line);
}
.lab-grid {
	max-width: var(--maxw);
	margin: 8px auto 18px;
	padding: 0 20px;
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 12px;
}
.lab-card {
	background: #fff;
	border: 1px solid var(--line);
	border-radius: var(--radius);
	box-shadow: var(--shadow);
	padding: 12px;
	transition: transform 0.24s ease, box-shadow 0.24s ease;
}
.lab-card:hover {
	transform: translateY(-4px);
	box-shadow: 0 16px 36px rgba(27, 33, 36, 0.12);
}
.lab-card figure {
	margin: 0 0 8px;
}
.lab-card img {
	width: 100%;
	height: auto;
	max-width: 350px;
	border-radius: 12px;
}
.lab-card h3 {
	margin: 0 0 6px;
	font-size: clamp(16px, 2vw, 20px);
}
.lab-card p {
	margin: 0;
	color: var(--muted);
}
.lab-note {
	max-width: var(--maxw);
	margin: 0 auto 14px;
	padding: 0 20px;
	color: var(--muted);
}

/* ---------- Responsiveness ---------- */
@media (max-width: 1100px) {
	.c-hero-wrap {
		grid-template-columns: 1fr;
	}
	.tapestry .tap-grid {
		grid-template-columns: repeat(8, 1fr);
		grid-auto-rows: 120px;
	}
	.t1 {
		grid-column: 1 / span 4;
		grid-row: 1 / span 3;
	}
	.t2 {
		grid-column: 5 / span 4;
		grid-row: 1 / span 2;
	}
	.t3 {
		grid-column: 1 / span 4;
		grid-row: 4 / span 3;
	}
	.t4 {
		grid-column: 5 / span 3;
		grid-row: 3 / span 2;
	}
	.t5 {
		grid-column: 4 / span 5;
		grid-row: 5 / span 3;
	}
	.oc-grid {
		grid-template-columns: repeat(2, 1fr);
	}
}
@media (max-width: 720px) {
	.tapestry .tap-grid {
		grid-template-columns: repeat(4, 1fr);
		grid-auto-rows: 120px;
	}
	.t1 {
		grid-column: 1 / span 4;
		grid-row: auto;
	}
	.t2 {
		grid-column: 1 / span 2;
	}
	.t3 {
		grid-column: 3 / span 2;
	}
	.t4 {
		grid-column: 1 / span 2;
	}
	.t5 {
		grid-column: 3 / span 2;
	}
	.oc-grid {
		grid-template-columns: 1fr;
	}
	.oc-card {
		grid-template-columns: 1fr;
	}
	.lab-grid {
		grid-template-columns: 1fr;
	}
}
@media (max-width: 560px) {
	/* captions cleaner on small screens */
	.tapestry .tile figcaption {
		display: none;
	}
	.c-hero .card figcaption {
		display: none;
	}
}

/* Cap image widths globally for this page */
.c-hero img,
.tapestry img,
.occasions img,
.scale-lab img {
	max-width: 350px;
}
/* ===== Shared section header (Collections page) ===== */
.section-head {
	max-width: var(--maxw);
	margin: clamp(28px, 5vw, 56px) auto 10px;
	padding: 0 20px; /* те же внутренние поля, что у гридов секций */
}
.section-head h2 {
	font-family: 'Playfair Display', serif;
	font-weight: 600;
	font-size: clamp(22px, 3.2vw, 38px);
	line-height: 1.15;
	margin: 0 0 6px;
}
.section-head .lead {
	color: var(--muted);
	margin: 0;
	max-width: 68ch;
}

/* На маленьких — поджимаем отступы, чтобы заголовки не «выпирали» */
@media (max-width: 720px) {
	.section-head {
		margin: 24px auto 8px;
	}
}
/* ===== SECTION 5: Catalog ===== */
.catalog {
	background: #fff;
	border-bottom: 1px solid var(--line);
}
.cat-filters {
	max-width: var(--maxw);
	margin: 6px auto 10px;
	padding: 0 20px;
	list-style: none;
	display: flex;
	flex-wrap: wrap;
	gap: 8px;
}
.catalog .badge {
	padding: 6px 10px;
	border-radius: 999px;
	border: 1px dashed var(--line);
	background: var(--bg-soft);
	font-weight: 700;
}
.cat-grid {
	max-width: var(--maxw);
	margin: 0 auto 16px;
	padding: 0 20px;
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 12px;
}
.cat-card {
	background: #fff;
	border: 1px solid var(--line);
	border-radius: var(--radius);
	box-shadow: var(--shadow);
	padding: 12px;
	transition: transform 0.24s ease, box-shadow 0.24s ease;
}
.cat-card:hover {
	transform: translateY(-4px);
	box-shadow: 0 16px 36px rgba(27, 33, 36, 0.12);
}
.cat-pic img {
	width: 100%;
	height: auto;
	max-width: 350px;
	border-radius: 12px;
}
.cat-card h3 {
	margin: 8px 0 6px;
	font-size: clamp(16px, 2vw, 20px);
}
.cat-card p {
	margin: 0;
	color: var(--muted);
}
@media (max-width: 820px) {
	.cat-grid {
		grid-template-columns: 1fr;
	}
}

/* ===== SECTION 6: Cuts Gallery ===== */
.cuts {
	background: var(--bg-soft);
	border-top: 1px solid var(--line);
	border-bottom: 1px solid var(--line);
}
.cuts-grid {
	max-width: var(--maxw);
	margin: 8px auto 16px;
	padding: 0 20px;
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 12px;
}
.cut-card {
	background: #fff;
	border: 1px solid var(--line);
	border-radius: var(--radius);
	box-shadow: var(--shadow);
	padding: 12px;
	position: relative;
	isolation: isolate;
}
.cut-card::before {
	content: '';
	position: absolute;
	left: 0;
	top: 0;
	bottom: 0;
	width: 5px;
	background: linear-gradient(180deg, var(--brand-200), var(--brand));
	border-top-left-radius: var(--radius);
	border-bottom-left-radius: var(--radius);
}
.cut-card figure {
	margin: 0 0 8px;
}
.cut-card img {
	width: 100%;
	height: auto;
	max-width: 350px;
	border-radius: 12px;
}
.cut-card h3 {
	margin: 0 0 6px;
	font-size: clamp(16px, 2vw, 20px);
}
.cut-card p {
	margin: 0;
	color: var(--muted);
}
@media (max-width: 820px) {
	.cuts-grid {
		grid-template-columns: 1fr;
	}
}

/* ===== SECTION 7: Chains Rail ===== */
.chains {
	background: #fff;
	border-bottom: 1px solid var(--line);
}
.chains-rail {
	position: relative;
	overflow-x: auto;
	overflow-y: hidden;
	scroll-snap-type: x mandatory;
	-webkit-overflow-scrolling: touch;
	overscroll-behavior-x: contain;
	border-radius: var(--radius-sm);
	-webkit-mask-image: linear-gradient(
		90deg,
		transparent 0,
		#000 4%,
		#000 96%,
		transparent 100%
	);
	mask-image: linear-gradient(
		90deg,
		transparent 0,
		#000 4%,
		#000 96%,
		transparent 100%
	);
}
.chains .rail {
	display: flex;
	gap: 12px;
	align-items: stretch;
	padding: 2px 2px 10px;
	scroll-padding-inline: 20px;
}
.rail-card {
	scroll-snap-align: start;
	flex: 0 0 auto;
	width: clamp(200px, 32vw, 320px);
	max-width: 350px;
	background: #fff;
	border: 1px solid var(--line);
	border-radius: var(--radius);
	box-shadow: var(--shadow);
	padding: 12px;
	transition: transform 0.24s ease, box-shadow 0.24s ease;
}
.rail-card:hover {
	transform: translateY(-4px);
	box-shadow: 0 16px 36px rgba(27, 33, 36, 0.12);
}
.rail-card figure {
	position: relative;
	margin: 0 0 8px;
}
.rail-card img {
	width: 100%;
	height: auto;
	max-width: 350px;
	border-radius: 12px;
	aspect-ratio: 4/3;
	object-fit: cover;
}
.rail-card figcaption {
	position: absolute;
	left: 8px;
	bottom: 8px;
	padding: 6px 10px;
	border-radius: 999px;
	background: #fff;
	color: var(--muted);
	font-weight: 700;
	box-shadow: var(--shadow);
}
.rail-card p {
	margin: 0;
	color: var(--muted);
}
.rail-fade {
	pointer-events: none;
	position: absolute;
	inset: 0;
	background: linear-gradient(90deg, #fff, rgba(255, 255, 255, 0) 60%) left /
			80px 100% no-repeat,
		linear-gradient(270deg, #fff, rgba(255, 255, 255, 0) 60%) right / 80px 100%
			no-repeat;
}

/* ===== SECTION 8: Moments Wall ===== */
.moments {
	background: var(--bg-soft);
	border-top: 1px solid var(--line);
	border-bottom: 1px solid var(--line);
}
.moments-wall {
	max-width: var(--maxw);
	margin: 8px auto 10px;
	padding: 0 20px;
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 12px;
	align-items: start;
}
.moment {
	background: #fff;
	border: 1px solid var(--line);
	border-radius: 16px;
	box-shadow: var(--shadow);
	overflow: hidden;
	position: relative;
	transform-origin: center;
	transition: transform 0.25s ease, box-shadow 0.25s ease;
}
.moment img {
	width: 100%;
	height: auto;
	max-width: 350px;
	display: block;
}
.moment figcaption {
	position: absolute;
	left: 10px;
	bottom: 10px;
	padding: 6px 10px;
	border-radius: 999px;
	background: #fff;
	color: var(--muted);
	font-weight: 700;
	box-shadow: var(--shadow);
}
/* лёгкая наклонность «полароидов» */
.tilt-left {
	transform: rotate(-1.6deg);
}
.tilt-right {
	transform: rotate(1.6deg);
}
.moment:hover {
	transform: rotate(0deg) translateY(-3px);
	box-shadow: 0 18px 40px rgba(27, 33, 36, 0.14);
}

.moments-foot {
	max-width: var(--maxw);
	margin: 0 auto 16px;
	padding: 0 20px;
	color: var(--muted);
}

/* Responsive */
@media (max-width: 900px) {
	.moments-wall {
		grid-template-columns: 1fr;
	}
	.tilt-left,
	.tilt-right {
		transform: none;
	}
}

/* Cap image widths for new sections */
.catalog img,
.cuts img,
.chains img,
.moments img {
	max-width: 350px;
}
/* === FIX: Chains rail should stay inside the section container === */
.chains-rail {
	max-width: var(--maxw); /* ширина как у остальных секций */
	margin: 6px auto 16px; /* центрируем */
	padding: 0 20px; /* те же боковые поля */
	box-sizing: border-box;
}

/* чтобы тени карт не провоцировали общий горизонтальный скролл */
.chains {
	overflow-x: hidden;
}

/* трек не должен растягивать страницу — пусть ширина считается от контейнера */
.chains .rail {
	min-width: 0;
}

/* стабилизируем появление/исчезновение скроллбара (Chrome/Edge) */
.chains-rail {
	scrollbar-gutter: stable both-edges;
}

/* на очень узких экранах слегка уменьшим стартовую ширину карточек */
@media (max-width: 420px) {
	.rail-card {
		width: clamp(180px, 78vw, 300px);
	}
}
/* ===== SECTION 9: Ear Stack Planner ===== */
.earstack {
	background: #fff;
	border-bottom: 1px solid var(--line);
}
.es-grid {
	max-width: var(--maxw);
	margin: 8px auto 16px;
	padding: 0 20px;
	display: grid;
	grid-template-columns: 260px 1fr;
	gap: 14px;
	align-items: start;
}
.es-aside {
	position: sticky;
	top: 86px;
}
.es-steps {
	list-style: decimal;
	margin: 0;
	padding-left: 18px;
	color: var(--muted);
	display: grid;
	gap: 8px;
}
.es-board {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 12px;
	align-items: start;
}
.es-card {
	background: #fff;
	border: 1px solid var(--line);
	border-radius: var(--radius);
	box-shadow: var(--shadow);
	overflow: hidden;
	position: relative;
	transition: transform 0.25s ease, box-shadow 0.25s ease;
}
.es-card:hover {
	transform: translateY(-3px);
	box-shadow: 0 18px 40px rgba(27, 33, 36, 0.14);
}
.es-card img {
	width: 100%;
	height: auto;
	max-width: 350px;
	display: block;
}
.es-card figcaption {
	position: absolute;
	left: 8px;
	bottom: 8px;
	padding: 6px 10px;
	border-radius: 999px;
	background: #fff;
	color: var(--muted);
	font-weight: 700;
	box-shadow: var(--shadow);
}
.es-note {
	border: 1px dashed var(--line);
	border-radius: var(--radius);
	background: #fff;
	box-shadow: var(--shadow);
	padding: 12px;
}
.es-note h3 {
	margin: 0 0 6px;
	font-size: clamp(16px, 2vw, 20px);
}
.es-note p {
	margin: 0;
	color: var(--muted);
}
@media (max-width: 940px) {
	.es-grid {
		grid-template-columns: 1fr;
	}
	.es-aside {
		position: static;
	}
}
@media (max-width: 720px) {
	.es-board {
		grid-template-columns: 1fr;
	}
}

/* ===== SECTION 10: Color Stories (horizontal rail) ===== */
.colors {
	background: var(--bg-soft);
	border-top: 1px solid var(--line);
	border-bottom: 1px solid var(--line);
}
.colors-rail {
	max-width: var(--maxw);
	margin: 8px auto 16px;
	padding: 0 20px;
	position: relative;
	overflow-x: auto;
	overflow-y: hidden;
	scroll-snap-type: x mandatory;
	-webkit-overflow-scrolling: touch;
	overscroll-behavior-x: contain;
	border-radius: var(--radius-sm);
	-webkit-mask-image: linear-gradient(
		90deg,
		transparent 0,
		#000 4%,
		#000 96%,
		transparent 100%
	);
	mask-image: linear-gradient(
		90deg,
		transparent 0,
		#000 4%,
		#000 96%,
		transparent 100%
	);
	scrollbar-gutter: stable both-edges;
}
.c-rail {
	display: flex;
	gap: 12px;
	align-items: stretch;
	padding: 2px 2px 10px;
	scroll-padding-inline: 20px;
}
.c-card {
	scroll-snap-align: start;
	flex: 0 0 auto;
	width: clamp(200px, 32vw, 320px);
	max-width: 350px;
	background: #fff;
	border: 1px solid var(--line);
	border-radius: var(--radius);
	box-shadow: var(--shadow);
	padding: 12px;
	transition: transform 0.24s ease, box-shadow 0.24s ease;
}
.c-card:hover {
	transform: translateY(-4px);
	box-shadow: 0 16px 36px rgba(27, 33, 36, 0.12);
}
.c-card figure {
	position: relative;
	margin: 0 0 8px;
}
.c-card img {
	width: 100%;
	height: auto;
	max-width: 350px;
	border-radius: 12px;
	aspect-ratio: 4/3;
	object-fit: cover;
}
.c-card figcaption {
	position: absolute;
	left: 8px;
	bottom: 8px;
	padding: 6px 10px;
	border-radius: 999px;
	background: #fff;
	color: var(--muted);
	font-weight: 700;
	box-shadow: var(--shadow);
}
.c-fade {
	pointer-events: none;
	position: absolute;
	inset: 0;
	background: linear-gradient(90deg, #fff, rgba(255, 255, 255, 0) 60%) left /
			80px 100% no-repeat,
		linear-gradient(270deg, #fff, rgba(255, 255, 255, 0) 60%) right / 80px 100%
			no-repeat;
}

/* ===== SECTION 11: Trio Builder ===== */
.trio {
	background: #fff;
	border-bottom: 1px solid var(--line);
}
.trio-grid {
	max-width: var(--maxw);
	margin: 8px auto 16px;
	padding: 0 20px;
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 12px;
}
.tr-card {
	background: #fff;
	border: 1px solid var(--line);
	border-radius: var(--radius);
	box-shadow: var(--shadow);
	padding: 12px;
	transition: transform 0.24s ease, box-shadow 0.24s ease;
}
.tr-card:hover {
	transform: translateY(-4px);
	box-shadow: 0 16px 36px rgba(27, 33, 36, 0.12);
}
.tr-card figure {
	margin: 0 0 8px;
}
.tr-card img {
	width: 100%;
	height: auto;
	max-width: 350px;
	border-radius: 12px;
}
.tr-card h3 {
	margin: 0 0 6px;
	font-size: clamp(16px, 2vw, 20px);
}
.tr-card p {
	margin: 0;
	color: var(--muted);
}
.tr-card .tokens {
	list-style: none;
	padding: 0;
	margin: 0 0 6px;
	display: flex;
	flex-wrap: wrap;
	gap: 8px;
}
.tr-card .badge {
	padding: 6px 10px;
	border-radius: 999px;
	border: 1px dashed var(--line);
	background: var(--bg-soft);
	font-weight: 700;
}
.tr-card.text-only figure {
	display: none;
}
@media (max-width: 820px) {
	.trio-grid {
		grid-template-columns: 1fr;
	}
}

/* ===== SECTION 12: Service Mini (accordion) ===== */
.service {
	background: #fff;
	border-bottom: 1px solid var(--line);
}
.svc-accordion {
	max-width: var(--maxw);
	margin: 8px auto 16px;
	padding: 0 20px;
	display: grid;
	gap: 12px;
}
.svc-item {
	border: 1px solid var(--line);
	border-radius: var(--radius);
	background: #fff;
	box-shadow: var(--shadow);
	overflow: hidden;
}
.svc-item summary {
	list-style: none;
	cursor: pointer;
	padding: 12px 14px;
	font-weight: 700;
	display: flex;
	align-items: center;
	justify-content: space-between;
}
.svc-item summary::-webkit-details-marker {
	display: none;
}
.svc-item[open] summary {
	color: var(--brand-600);
}
.svc-body {
	display: grid;
	grid-template-columns: 120px 1fr;
	gap: 12px;
	align-items: start;
	padding: 0 14px 14px;
}
.svc-pic img {
	width: 100%;
	height: auto;
	max-width: 350px;
	border-radius: 12px;
}
.svc-body p {
	margin: 0;
	color: var(--muted);
}
@media (max-width: 640px) {
	.svc-body {
		grid-template-columns: 1fr;
	}
}

/* Cap image widths for new sections */
.earstack img,
.colors img,
.trio img,
.service img {
	max-width: 350px;
}
/* === FIX: Service cards without image should be single-column === */
/* По умолчанию тело делаем одной колонкой */
.svc-body {
	grid-template-columns: 1fr; /* перекрывает старое правило */
}

/* Если есть картинка .svc-pic — переключаемся на 120px + контент */
.svc-body:has(.svc-pic) {
	grid-template-columns: 120px 1fr;
}

/* Когда картинка есть, текст кладём явно во 2-ю колонку */
.svc-body:has(.svc-pic) p {
	grid-column: 2;
}

/* На узких экранах всё равно одна колонка (оставим, чтобы не конфликтовало) */
@media (max-width: 640px) {
	.svc-body {
		grid-template-columns: 1fr;
	}
	.svc-body:has(.svc-pic) p {
		grid-column: 1;
	}
}
/* ===== SECTION 13: Band Stacking Matrix ===== */
.bands-matrix {
	background: #fff;
	border-bottom: 1px solid var(--line);
}
.bm-grid {
	max-width: var(--maxw);
	margin: 8px auto 14px;
	padding: 0 20px;
	display: grid;
	gap: 10px;
}
.bm-head {
	display: grid;
	grid-template-columns: 1.1fr 0.8fr 0.8fr 1.4fr;
	gap: 10px;
}
.bm-th {
	background: #fff8f0;
	border: 1px solid var(--line);
	border-radius: var(--radius);
	padding: 10px 12px;
	font-weight: 700;
}
.bm-row {
	display: grid;
	grid-template-columns: 1.1fr 0.8fr 0.8fr 1.4fr;
	gap: 10px;
}
.bm-td {
	background: #fff;
	border: 1px solid var(--line);
	border-radius: var(--radius);
	padding: 10px 12px;
	box-shadow: var(--shadow);
}
.bm-note {
	max-width: var(--maxw);
	margin: 0 auto 14px;
	padding: 0 20px;
	color: var(--muted);
}
.bands-matrix .badge {
	padding: 6px 10px;
	border-radius: 999px;
	border: 1px dashed var(--line);
	background: var(--bg-soft);
	font-weight: 700;
}
@media (max-width: 760px) {
	.bm-head {
		display: none;
	}
	.bm-row {
		grid-template-columns: 1fr;
	}
	.bm-td {
		position: relative;
	}
}

/* ===== SECTION 14: Engraving Gallery ===== */
.engrave {
	background: var(--bg-soft);
	border-top: 1px solid var(--line);
	border-bottom: 1px solid var(--line);
}
.engrave-rail {
	max-width: var(--maxw);
	margin: 8px auto 10px;
	padding: 0 20px;
	position: relative;
	overflow-x: auto;
	overflow-y: hidden;
	scroll-snap-type: x mandatory;
	-webkit-overflow-scrolling: touch;
	overscroll-behavior-x: contain;
	border-radius: var(--radius-sm);
	-webkit-mask-image: linear-gradient(
		90deg,
		transparent 0,
		#000 4%,
		#000 96%,
		transparent 100%
	);
	mask-image: linear-gradient(
		90deg,
		transparent 0,
		#000 4%,
		#000 96%,
		transparent 100%
	);
	scrollbar-gutter: stable both-edges;
}
.e-rail {
	display: flex;
	gap: 12px;
	align-items: stretch;
	padding: 2px 2px 10px;
	scroll-padding-inline: 20px;
}
.e-card {
	scroll-snap-align: start;
	flex: 0 0 auto;
	width: clamp(200px, 32vw, 320px);
	max-width: 350px;
	background: #fff;
	border: 1px solid var(--line);
	border-radius: var(--radius);
	box-shadow: var(--shadow);
	padding: 12px;
	transition: transform 0.24s ease, box-shadow 0.24s ease;
}
.e-card:hover {
	transform: translateY(-4px);
	box-shadow: 0 16px 36px rgba(27, 33, 36, 0.12);
}
.e-card figure {
	position: relative;
	margin: 0 0 8px;
}
.e-card img {
	width: 100%;
	height: auto;
	max-width: 350px;
	border-radius: 12px;
	aspect-ratio: 4/3;
	object-fit: cover;
}
.e-card figcaption {
	position: absolute;
	left: 8px;
	bottom: 8px;
	padding: 6px 10px;
	border-radius: 999px;
	background: #fff;
	color: var(--muted);
	font-weight: 700;
	box-shadow: var(--shadow);
}
.e-fade {
	pointer-events: none;
	position: absolute;
	inset: 0;
	background: linear-gradient(90deg, #fff, rgba(255, 255, 255, 0) 60%) left /
			80px 100% no-repeat,
		linear-gradient(270deg, #fff, rgba(255, 255, 255, 0) 60%) right / 80px 100%
			no-repeat;
}
.engrave-tips {
	max-width: var(--maxw);
	margin: 0 auto 16px;
	padding: 0 20px;
	display: flex;
	flex-wrap: wrap;
	gap: 8px;
	list-style: none;
	color: var(--muted);
}
.engrave-tips li {
	padding: 6px 10px;
	border: 1px dashed var(--line);
	border-radius: 999px;
	background: #fff;
}

/* ===== SECTION 15: Packaging & Gifting ===== */
.pack {
	background: #fff;
	border-bottom: 1px solid var(--line);
}
.pack-card {
	max-width: var(--maxw);
	margin: 8px auto 16px;
	padding: 0 20px;
	display: grid;
	grid-template-columns: 260px 1fr;
	gap: 12px;
	align-items: start;
	background: #fff;
}
.pack-pic img {
	width: 100%;
	height: auto;
	max-width: 350px;
	border-radius: 12px;
	box-shadow: var(--shadow);
}
.pack-copy h3 {
	margin: 0 0 6px;
	font-size: clamp(16px, 2vw, 20px);
}
.pack-copy p {
	margin: 0 0 8px;
	color: var(--muted);
}
.pack .tokens {
	list-style: none;
	padding: 0;
	margin: 0;
	display: flex;
	flex-wrap: wrap;
	gap: 8px;
}
.pack .badge {
	padding: 6px 10px;
	border-radius: 999px;
	border: 1px dashed var(--line);
	background: var(--bg-soft);
	font-weight: 700;
}
@media (max-width: 860px) {
	.pack-card {
		grid-template-columns: 1fr;
	}
}

/* ===== SECTION 16: FAQ Quickfold ===== */
.qfold {
	background: var(--bg-soft);
	border-top: 1px solid var(--line);
	border-bottom: 1px solid var(--line);
}
.q-accordion {
	max-width: var(--maxw);
	margin: 8px auto 16px;
	padding: 0 20px;
	display: grid;
	gap: 10px;
}
.q-item {
	border: 1px solid var(--line);
	border-radius: var(--radius);
	background: #fff;
	box-shadow: var(--shadow);
	overflow: hidden;
}
.q-item summary {
	list-style: none;
	cursor: pointer;
	padding: 12px 14px;
	font-weight: 700;
}
.q-item summary::-webkit-details-marker {
	display: none;
}
.q-item[open] summary {
	color: var(--brand-600);
}
.q-item p {
	margin: 0 0 12px;
	padding: 0 14px 0;
	color: var(--muted);
}

/* Cap image widths for new sections */
.engrave img,
.pack img {
	max-width: 350px;
}
/* ===== SECTION 17: Neckline Guide ===== */
.necklines {
	background: #fff;
	border-bottom: 1px solid var(--line);
}
.nl-grid {
	max-width: var(--maxw);
	margin: 8px auto 16px;
	padding: 0 20px;
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: 12px;
}
.nl-card {
	background: #fff;
	border: 1px solid var(--line);
	border-radius: var(--radius);
	box-shadow: var(--shadow);
	padding: 12px;
	transition: transform 0.24s ease, box-shadow 0.24s ease;
}
.nl-card:hover {
	transform: translateY(-4px);
	box-shadow: 0 16px 36px rgba(27, 33, 36, 0.12);
}
.nl-pic img {
	width: 100%;
	height: auto;
	max-width: 350px;
	border-radius: 12px;
	display: block;
}
.nl-card h3 {
	margin: 8px 0 6px;
	font-size: clamp(16px, 2vw, 20px);
}
.nl-card p {
	margin: 0 0 8px;
	color: var(--muted);
}
.nl-card .tokens {
	list-style: none;
	padding: 0;
	margin: 0;
	display: flex;
	flex-wrap: wrap;
	gap: 8px;
}
.nl-card .badge {
	padding: 6px 10px;
	border-radius: 999px;
	border: 1px dashed var(--line);
	background: var(--bg-soft);
	font-weight: 700;
}
@media (max-width: 820px) {
	.nl-grid {
		grid-template-columns: 1fr;
	}
}

/* ===== SECTION 18: Atelier Timeline ===== */
.timeline {
	background: var(--bg-soft);
	border-top: 1px solid var(--line);
	border-bottom: 1px solid var(--line);
}
.tl-grid {
	max-width: var(--maxw);
	margin: 8px auto 16px;
	padding: 0 20px;
	display: grid;
	grid-template-columns: 240px 1fr;
	gap: 14px;
	align-items: start;
}
.tl-aside figure {
	margin: 0;
}
.tl-aside img {
	width: 100%;
	height: auto;
	max-width: 350px;
	border-radius: 12px;
	box-shadow: var(--shadow);
}

.tl-steps {
	counter-reset: step;
	list-style: none;
	margin: 0;
	padding: 10px 0 10px 10px;
	position: relative;
}
.tl-steps li {
	counter-increment: step;
	background: #fff;
	border: 1px solid var(--line);
	border-radius: var(--radius);
	padding: 10px 12px;
	box-shadow: var(--shadow);
	color: var(--muted);
	display: grid;
	grid-template-columns: auto 1fr;
	gap: 10px;
	align-items: start;
	margin-bottom: 10px;
}
.tl-steps li::before {
	content: counter(step);
	width: 26px;
	height: 26px;
	border-radius: 999px;
	display: grid;
	place-items: center;
	background: linear-gradient(
		110deg,
		var(--brand) 0%,
		#e1bd8f 60%,
		var(--brand) 100%
	);
	color: #fff;
	font-weight: 700;
}
@media (max-width: 860px) {
	.tl-grid {
		grid-template-columns: 1fr;
	}
}

/* ===== SECTION 19: Care Cheatsheet ===== */
.cheatsheet {
	background: #fff;
	border-bottom: 1px solid var(--line);
}
.cs-grid {
	max-width: var(--maxw);
	margin: 8px auto 16px;
	padding: 0 20px;
	display: grid;
	grid-template-columns: 1fr 240px 1fr;
	gap: 12px;
	align-items: start;
}
.cs-pic img {
	width: 100%;
	height: auto;
	max-width: 350px;
	border-radius: 12px;
	box-shadow: var(--shadow);
	display: block;
}
.cs-list {
	background: #fff;
	border: 1px solid var(--line);
	border-radius: var(--radius);
	box-shadow: var(--shadow);
	padding: 12px;
	display: grid;
	gap: 8px;
	color: var(--muted);
}
.cs-list li {
	margin: 0;
}
.cs-do {
	border-left: 5px solid #e6f5ea;
}
.cs-dont {
	border-left: 5px solid #ffe9e9;
}

@media (max-width: 900px) {
	.cs-grid {
		grid-template-columns: 1fr;
	}
}
