/* ===== shared helpers for this page ===== */
.cap-img {
	max-width: 350px;
	width: 100%;
}
.sec-head h2 {
	font-family: var(--ff-display);
	font-size: clamp(1.3rem, 2.1vw, 2rem);
	margin: 0.25rem 0 0.5rem;
}

/* ===== SECTION 1: Range Hero ===== */
.range-hero {
	padding: clamp(2rem, 6vw, 4rem) 0 clamp(1.5rem, 5vw, 3rem);
	background: radial-gradient(
				900px 420px at 15% 0%,
				#eef5ea 0%,
				transparent 60%
			)
			no-repeat,
		radial-gradient(700px 380px at 100% 100%, #fff7e7 0%, transparent 55%)
			no-repeat,
		var(--c-cream);
}
.range-hero-grid {
	display: grid;
	grid-template-columns: 1.1fr 0.9fr;
	gap: clamp(1rem, 4vw, 2rem);
	align-items: center;
}
.rh-copy h1 {
	font-family: var(--ff-display);
	font-size: clamp(1.6rem, 2.6vw, 2.5rem);
	margin: 0.25rem 0 0.75rem;
}
.rh-lede {
	font-size: 1.05rem;
}
.hero-cta {
	display: flex;
	gap: 0.75rem;
	flex-wrap: wrap;
	margin-top: 0.9rem;
}

.rh-mosaic {
	position: relative;
	min-height: 520px;
}
.rh-tile {
	position: absolute;
	width: min(330px, 42vw);
	box-shadow: var(--shadow-soft);
	border-radius: var(--radius-lg);
}
.t1 {
	top: -4%;
	left: 4%;
	rotate: -1.2deg;
}
.t2 {
	top: 26%;
	right: 0%;
	rotate: 0.8deg;
}
.t3 {
	top: 52%;
	left: 14%;
	rotate: -0.6deg;
}
.t4 {
	top: 8%;
	right: 32%;
	rotate: 1deg;
}

@media (max-width: 1024px) {
	.range-hero-grid {
		grid-template-columns: 1fr;
	}
	.rh-mosaic {
		min-height: 480px;
		order: -1;
		margin-bottom: 0.5rem;
	}
	.rh-tile {
		width: min(300px, 80vw);
	}
}
@media (max-width: 560px) {
	.rh-tile {
		width: min(230px, 86vw);
	}
	.t1,
	.t2,
	.t3,
	.t4 {
		rotate: 0deg;
	}
}

/* ===== SECTION 2: Grain Ribbon (belt) ===== */
.grain-ribbon {
	padding: clamp(1.75rem, 4vw, 2.5rem) 0;
	background: linear-gradient(180deg, #fffdf7, #f7f5ef);
}
.belt-wrap {
	position: relative;
}
.belt {
	display: grid;
	grid-auto-flow: column;
	grid-auto-columns: minmax(240px, 280px);
	gap: 0.9rem;
	overflow-x: auto;
	scroll-snap-type: x mandatory;
	padding: 0.25rem 0.25rem 1rem;
}
.batch-card {
	scroll-snap-align: start;
	background: var(--c-paper);
	border-radius: var(--radius-xl);
	padding: 1rem;
	box-shadow: var(--shadow-soft);
	transition: transform 0.2s ease, box-shadow 0.2s ease;
}
.batch-card:hover {
	transform: translateY(-2px);
	box-shadow: var(--shadow-float);
}
.batch-fig {
	margin: 0 0 0.5rem 0;
}
.belt-btn {
	position: absolute;
	top: 50%;
	transform: translateY(-50%);
	width: 36px;
	height: 36px;
	border-radius: 50%;
	border: 2px solid var(--c-olive);
	background: #fff;
	color: var(--c-olive);
	display: grid;
	place-items: center;
	cursor: pointer;
	transition: background 0.2s ease;
}
.belt-btn:hover {
	background: #e7efe7;
}
.belt-btn.prev {
	left: -6px;
}
.belt-btn.next {
	right: -6px;
}
@media (max-width: 640px) {
	.belt-btn {
		display: none;
	}
}

/* ===== SECTION 3: Dairy & Eggs ===== */
.dairy-eggs {
	padding: clamp(1.75rem, 4vw, 2.5rem) 0;
}
.dairy-grid {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 1rem;
	align-items: start;
}
.de-fig {
	margin: 0;
}
.de-copy {
	background: var(--c-paper);
	border-radius: var(--radius-xl);
	padding: 1rem;
	box-shadow: var(--shadow-soft);
	display: grid;
	gap: 0.6rem;
}
.ticks {
	margin: 0;
	padding-left: 1rem;
}
@media (max-width: 980px) {
	.dairy-grid {
		grid-template-columns: 1fr;
	}
}

/* ===== SECTION 4: Spice Notes ===== */
.spice-notes {
	padding: clamp(1.75rem, 4vw, 2.5rem) 0;
	background: radial-gradient(
			800px 400px at 90% 10%,
			#eef5ea 0%,
			transparent 60%
		)
		no-repeat;
}
.spice-grid {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 1rem;
}
.spice-card {
	background: var(--c-paper);
	border-radius: var(--radius-xl);
	box-shadow: var(--shadow-soft);
	padding: 1rem;
	display: grid;
	gap: 0.5rem;
	transition: transform 0.2s ease, box-shadow 0.2s ease;
}
.spice-card:hover {
	transform: translateY(-2px);
	box-shadow: var(--shadow-float);
}
.spice-fig {
	margin: 0;
}
@media (max-width: 1024px) {
	.spice-grid {
		grid-template-columns: 1fr;
	}
}
/* ===== SECTION 1: Tasting Mat (совершенно иной паттерн) ===== */
.range-mat {
	padding: clamp(2rem, 6vw, 4rem) 0 clamp(1.5rem, 5vw, 3rem);
	background: radial-gradient(
				900px 420px at 50% -10%,
				#eef5ea 0%,
				transparent 60%
			)
			no-repeat,
		radial-gradient(700px 380px at 10% 105%, #fff7e7 0%, transparent 55%)
			no-repeat,
		var(--c-cream);
}
.mat-area {
	position: relative;
	display: grid;
	place-items: center;
	min-height: 620px;
}
.mat-core {
	z-index: 2;
	max-width: 680px;
	text-align: center;
	background: var(--c-paper);
	padding: 1.1rem 1.2rem;
	border-radius: var(--radius-xl);
	box-shadow: var(--shadow-soft);
}
.mat-core h1 {
	font-family: var(--ff-display);
	font-size: clamp(1.7rem, 2.6vw, 2.5rem);
	margin: 0.25rem 0 0.6rem;
}
.mat-lede {
	font-size: 1.05rem;
	color: var(--c-ink);
}

/* кольцо-коврик */
.mat-ring {
	position: absolute;
	inset: 0;
	display: grid;
	place-items: center;
	pointer-events: none;
}
.mat-halo {
	position: absolute;
	width: min(760px, 90vw);
	aspect-ratio: 1/1;
	border-radius: 50%;
	box-shadow: inset 0 0 0 2px #d9d1b7,
		inset 0 0 0 12px rgba(233, 227, 201, 0.45);
}
.mat-dash {
	position: absolute;
	width: min(560px, 72vw);
	aspect-ratio: 1/1;
	border-radius: 50%;
	border: 2px dashed #d9d1b7;
	opacity: 0.9;
}

/* круглые «коастеры» вокруг ядра */
.coaster {
	position: absolute;
	display: grid;
	place-items: center;
	gap: 0.35rem;
	text-align: center;
	pointer-events: auto;
	user-select: none;
	transition: transform 0.2s ease, filter 0.2s ease;
}
.coaster:hover {
	transform: translateY(-2px);
	filter: saturate(1.05);
}
.tm-img {
	width: min(180px, 45vw); /* ≤ 350px гарантировано */
	height: auto;
	aspect-ratio: 1/1;
	border-radius: 50%;
	box-shadow: var(--shadow-soft);
}
.coaster figcaption {
	background: #fffdf7;
	border: 1px dashed #e2d7b6;
	padding: 0.25rem 0.5rem;
	border-radius: 0.6rem;
	font-weight: 600;
}

/* размещение 4 коастеров по кругу (не как на главной) */
.c1 {
	top: 6%;
	left: 50%;
	transform: translate(-50%, 0);
}
.c2 {
	right: 4%;
	top: 50%;
	transform: translate(0, -50%);
}
.c3 {
	bottom: 6%;
	left: 50%;
	transform: translate(-50%, 0);
}
.c4 {
	left: 4%;
	top: 50%;
	transform: translate(0, -50%);
}

/* лёгкое дыхание — иная анимация, не как у геро на главной */
.float {
	animation: mat-float 7.5s ease-in-out infinite alternate;
}
@keyframes mat-float {
	from {
		transform: translateY(-2px);
	}
	to {
		transform: translateY(2px);
	}
}

/* Responsive: на маленьких — раскладываем в сетку под ядром */
@media (max-width: 980px) {
	.mat-area {
		min-height: unset;
	}
	.mat-ring {
		position: static;
		display: grid;
		gap: 1rem;
		margin-top: 1rem;
	}
	.mat-halo,
	.mat-dash {
		display: none;
	}
	.coaster,
	.c1,
	.c2,
	.c3,
	.c4 {
		position: static;
		transform: none;
	}
	.coaster {
		grid-template-rows: auto auto;
	}
}
/* --- Tasting Mat: фикс наложения слоёв --- */
.range-mat .mat-ring {
	z-index: 1;
} /* кольца позади */
.range-mat .mat-halo,
.range-mat .mat-dash {
	z-index: 1;
}
.range-mat .mat-core {
	z-index: 2;
} /* центр над кольцами */
.range-mat .coaster {
	z-index: 3;
} /* кружки поверх текста */

/* --- Не даём анимации ломать transform позиционирования --- */
/* Раньше .float анимировал transform самой .coaster — теперь анимируем ТОЛЬКО картинку */
.range-mat .float {
	animation: none;
} /* отключаем старое на этой секции */
.range-mat .coaster .tm-img {
	animation: mat-float 7.5s ease-in-out infinite alternate;
}
@keyframes mat-float {
	from {
		transform: translateY(-2px);
	}
	to {
		transform: translateY(2px);
	}
}

/* --- Чуть выносим кружки наружу, чтобы они не касались центра --- */
.range-mat .c1 {
	top: -2%;
	left: 50%;
	transform: translate(-50%, 0);
}
.range-mat .c2 {
	right: -2%;
	top: 50%;
	transform: translate(0, -50%);
}
.range-mat .c3 {
	bottom: -2%;
	left: 50%;
	transform: translate(-50%, 0);
}
.range-mat .c4 {
	left: -2%;
	top: 50%;
	transform: translate(0, -50%);
}
/* ===== SECTION 5: Millet Strip ===== */
.millet-strip {
	padding: clamp(1.75rem, 4vw, 2.5rem) 0;
	background: linear-gradient(180deg, #fffdf7, #f7f5ef);
}
.ms-rail {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 1rem;
	margin-top: 0.5rem;
}
.seed-chip {
	background: var(--c-paper);
	border-radius: var(--radius-xl);
	box-shadow: var(--shadow-soft);
	padding: 1rem;
	display: grid;
	gap: 0.5rem;
	align-content: start;
	transition: transform 0.2s ease, box-shadow 0.2s ease;
}
.seed-chip:hover {
	transform: translateY(-2px);
	box-shadow: var(--shadow-float);
}
.chip-fig {
	margin: 0;
}
.ms-base {
	position: relative;
	height: 8px;
	background: #e9e1c9;
	border-radius: 999px;
	margin-top: 1rem;
	overflow: hidden;
}
.ms-progress {
	position: absolute;
	inset: 0;
	transform: scaleX(0);
	transform-origin: left;
	background: linear-gradient(90deg, #4f7b5c, #b2772a);
	transition: transform 1.4s ease;
}
.millet-strip.is-on .ms-progress {
	transform: scaleX(1);
}

@media (max-width: 1024px) {
	.ms-rail {
		grid-template-columns: 1fr;
	}
}

/* ===== SECTION 6: Dairy Compass ===== */
.dairy-compass {
	padding: clamp(1.75rem, 4vw, 2.5rem) 0;
}
.dc-grid {
	display: grid;
	grid-template-columns: 1fr auto 1fr;
	gap: 1rem;
	align-items: center;
}
.dc-fig {
	margin: 0;
	text-align: center;
}
.dc-core {
	position: relative;
	width: min(360px, 86vw);
	aspect-ratio: 1/1;
	display: grid;
	place-items: center;
}
.dc-ring {
	position: absolute;
	inset: 0;
	border-radius: 50%;
	box-shadow: inset 0 0 0 2px #d9d1b7,
		inset 0 0 0 10px rgba(233, 227, 201, 0.45);
	animation: dc-slow 18s linear infinite;
}
@keyframes dc-slow {
	to {
		transform: rotate(360deg);
	}
}
.dc-steps {
	z-index: 1;
	background: #fffdf7;
	border: 1px dashed #e2d7b6;
	padding: 0.8rem 1rem;
	border-radius: 0.9rem;
	box-shadow: var(--shadow-soft);
	width: 88%;
}
.dc-steps li {
	margin: 0.2rem 0;
}
@media (max-width: 1024px) {
	.dc-grid {
		grid-template-columns: 1fr;
	}
}

/* ===== SECTION 7: Label Showcase ===== */
.labels-display {
	padding: clamp(1.75rem, 4vw, 2.5rem) 0;
	background: radial-gradient(
			800px 400px at 85% 10%,
			#eef5ea 0%,
			transparent 60%
		)
		no-repeat;
}
.lb-grid {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 1rem;
}
.lb-card {
	background: var(--c-paper);
	border-radius: var(--radius-xl);
	box-shadow: var(--shadow-soft);
	padding: 1rem;
	display: grid;
	gap: 0.6rem;
	transform: rotate(-1deg);
	transition: transform 0.25s ease, box-shadow 0.25s ease;
}
.lb-card:nth-child(2) {
	transform: rotate(1.5deg);
}
.lb-card:hover {
	transform: rotate(0deg) translateY(-2px);
	box-shadow: var(--shadow-float);
}
.lb-fig {
	margin: 0;
}
@media (max-width: 1024px) {
	.lb-grid {
		grid-template-columns: 1fr;
	}
}

/* ===== SECTION 8: Pairings Triad ===== */
.pairings-triad {
	padding: clamp(1.75rem, 4vw, 2.5rem) 0;
}
.triad {
	position: relative;
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 1rem;
	align-items: start;
}
.tri-card {
	background: var(--c-paper);
	border-radius: var(--radius-xl);
	box-shadow: var(--shadow-soft);
	padding: 1rem;
	display: grid;
	gap: 0.5rem;
	text-align: center;
	transition: transform 0.2s ease, box-shadow 0.2s ease;
}
.tri-card:hover {
	transform: translateY(-2px);
	box-shadow: var(--shadow-float);
}
.tri-fig {
	margin: 0;
}

/* connectors */
.tri-line {
	position: absolute;
	height: 2px;
	background: linear-gradient(90deg, #4f7b5c, #b2772a);
	opacity: 0;
	transform: scaleX(0);
	transform-origin: left;
	transition: transform 0.8s ease 0.1s, opacity 0.6s ease 0.1s;
}
.l1 {
	left: 12%;
	right: 12%;
	top: 26%;
}
.l2 {
	left: 12%;
	right: 12%;
	top: 50%;
}
.l3 {
	left: 12%;
	right: 12%;
	top: 74%;
}
.pairings-triad.is-on .tri-line {
	opacity: 1;
	transform: scaleX(1);
}

@media (max-width: 1024px) {
	.triad {
		grid-template-columns: 1fr;
	}
	.tri-line {
		display: none;
	}
}
/* Альтернатива: линии остаются, но под карточками */
.triad {
	position: relative;
}
.tri-card {
	position: relative;
	z-index: 2;
} /* карточки сверху */
.tri-line {
	z-index: 1;
	height: 1px;
	opacity: 0.18;
	pointer-events: none;
}
/* ===== SECTION 9: Storage Shelves (редизайн) ===== */
.storage-shelves {
	padding: clamp(1.75rem, 4vw, 2.5rem) 0;
	background: linear-gradient(180deg, #fffdf7, #f7f5ef);
}
.shelves-grid {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 1rem;
	align-items: start;
}
.shelf-card {
	position: relative;
	background: var(--c-paper);
	border-radius: var(--radius-xl);
	box-shadow: var(--shadow-soft);
	padding: 1rem;
	display: grid;
	grid-template-columns: auto 1fr;
	gap: 0.9rem;
	transition: transform 0.2s ease, box-shadow 0.2s ease;
	overflow: hidden;
}
.shelf-card:hover {
	transform: translateY(-2px);
	box-shadow: var(--shadow-float);
}
/* акцентная «полка» снизу, появляется при ховере */
.shelf-card::after {
	content: '';
	position: absolute;
	left: 0;
	right: 0;
	bottom: 0;
	height: 3px;
	background: linear-gradient(90deg, #4f7b5c, #b2772a);
	transform: scaleX(0);
	transform-origin: left;
	transition: transform 0.45s ease;
}
.shelf-card:hover::after {
	transform: scaleX(1);
}

.shelf-fig {
	margin: 0;
}
.shelf-copy h3 {
	margin: 0.1rem 0 0.25rem;
	font-size: 1.05rem;
}
.shelf-badges {
	display: grid;
	grid-template-columns: repeat(4, auto);
	gap: 0.5rem 0.75rem;
	margin: 0.25rem 0 0;
	padding: 0;
	list-style: none;
	font-size: 0.85rem;
	color: var(--c-muted);
}
.shelf-badges li::before {
	content: '';
	display: inline-block;
	width: 0.5rem;
	height: 0.5rem;
	margin-right: 0.35rem;
	border-radius: 50%;
	background: radial-gradient(circle at 30% 30%, #b2772a, #4f7b5c);
}

@media (max-width: 1024px) {
	.shelves-grid {
		grid-template-columns: 1fr;
	}
	.shelf-card {
		grid-template-columns: auto 1fr;
	}
}

/* ===== SECTION 10: Spotlight Duo ===== */
.spotlight-duo {
	padding: clamp(1.75rem, 4vw, 2.5rem) 0;
	background: radial-gradient(
			800px 420px at 85% 10%,
			#eef5ea 0%,
			transparent 60%
		)
		no-repeat;
}
.sd-grid {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 1rem;
}
.sd-card {
	background: var(--c-paper);
	border-radius: var(--radius-xl);
	box-shadow: var(--shadow-soft);
	padding: 1rem;
	display: grid;
	grid-template-columns: auto 1fr;
	gap: 0.9rem;
	align-items: center;
	transition: transform 0.2s ease, box-shadow 0.2s ease;
}
.sd-card:hover {
	transform: translateY(-2px);
	box-shadow: var(--shadow-float);
}
.sd-fig {
	margin: 0;
}
.sd-copy blockquote {
	margin: 0 0 0.25rem 0;
	font-size: 1rem;
	line-height: 1.5;
}
@media (max-width: 1024px) {
	.sd-grid {
		grid-template-columns: 1fr;
	}
	.sd-card {
		grid-template-columns: auto 1fr;
	}
}

/* ===== SECTION 11: Bundles ===== */
.bundles {
	padding: clamp(1.75rem, 4vw, 2.5rem) 0;
}
.bd-grid {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 1rem;
}
.bd-card {
	background: var(--c-paper);
	border-radius: var(--radius-xl);
	box-shadow: var(--shadow-soft);
	padding: 1rem;
	display: grid;
	gap: 0.5rem;
	align-content: start;
	position: relative;
	overflow: hidden;
	transition: transform 0.2s ease, box-shadow 0.2s ease;
}
.bd-card:hover {
	transform: translateY(-2px);
	box-shadow: var(--shadow-float);
}
.bd-fig {
	margin: 0;
}
.bd-progress {
	position: relative;
	height: 6px;
	background: #e9e1c9;
	border-radius: 999px;
	overflow: hidden;
	margin-top: 1rem;
}
.bd-progress i {
	position: absolute;
	inset: 0;
	transform: scaleX(0);
	transform-origin: left;
	background: linear-gradient(90deg, #4f7b5c, #b2772a);
}
.bundles.is-on .bd-progress i {
	transform: scaleX(1);
	transition: transform 1.4s ease;
}

@media (max-width: 1024px) {
	.bd-grid {
		grid-template-columns: 1fr;
	}
}

/* ===== SECTION 12: Buying Guide (Q&A) ===== */
.buying-guide {
	padding: clamp(1.75rem, 4vw, 2.5rem) 0;
	background: linear-gradient(180deg, #f7f5ef, #fffdf7);
}
.bg-wrap {
	display: grid;
	grid-template-columns: auto 1fr auto;
	gap: 1rem;
	align-items: start;
}
.bg-fig {
	margin: 0;
}
.bg-accordion {
	display: grid;
	gap: 0.5rem;
}
.qa-toggle {
	width: 100%;
	text-align: left;
	padding: 0.8rem 1rem;
	border: 0;
	cursor: pointer;
	border-radius: 0.75rem;
	background: #fffaf0;
	border: 1px solid #efe6cf;
	font-weight: 700;
}
.qa-toggle:focus-visible {
	outline: 3px solid #1d6;
	outline-offset: 2px;
}
.qa-panel {
	background: var(--c-paper);
	box-shadow: var(--shadow-soft);
	border-radius: 0.75rem;
	padding: 0.75rem 1rem;
}
@media (max-width: 980px) {
	.bg-wrap {
		grid-template-columns: 1fr;
	}
}
/* ===== SECTION 13: Region Grid ===== */
.region-grid {
	padding: clamp(1.75rem, 4vw, 2.5rem) 0;
	background: radial-gradient(
			900px 420px at 12% 0%,
			#eef5ea 0%,
			transparent 60%
		)
		no-repeat;
}
.rg-cards {
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	gap: 1rem;
}
.rg-card {
	background: var(--c-paper);
	border-radius: var(--radius-xl);
	box-shadow: var(--shadow-soft);
	padding: 1rem;
	display: grid;
	gap: 0.5rem;
	align-content: start;
	position: relative;
	transition: transform 0.2s ease, box-shadow 0.2s ease;
}
.rg-card:hover {
	transform: translateY(-2px);
	box-shadow: var(--shadow-float);
}
.rg-fig {
	margin: 0;
}
@media (max-width: 1180px) {
	.rg-cards {
		grid-template-columns: repeat(2, 1fr);
	}
}
@media (max-width: 640px) {
	.rg-cards {
		grid-template-columns: 1fr;
	}
}

/* ===== SECTION 14: Cooking Techniques ===== */
.cook-tech {
	padding: clamp(1.75rem, 4vw, 2.5rem) 0;
	background: linear-gradient(180deg, #fffdf7, #f7f5ef);
}
.ct-grid {
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	gap: 1rem;
}
.ct-card {
	background: var(--c-paper);
	border-radius: var(--radius-xl);
	box-shadow: var(--shadow-soft);
	padding: 1rem;
	display: grid;
	gap: 0.5rem;
	align-content: start;
	text-align: left;
	transition: transform 0.2s ease, box-shadow 0.2s ease;
}
.ct-card:hover {
	transform: translateY(-2px);
	box-shadow: var(--shadow-float);
}
.ct-fig {
	margin: 0;
}
@media (max-width: 1180px) {
	.ct-grid {
		grid-template-columns: repeat(2, 1fr);
	}
}
@media (max-width: 640px) {
	.ct-grid {
		grid-template-columns: 1fr;
	}
}

/* ===== SECTION 15: Pantry Gallery ===== */
.pantry-gallery {
	padding: clamp(1.75rem, 4vw, 2.5rem) 0;
}
.pg-grid {
	display: grid;
	grid-template-columns: repeat(5, 1fr);
	gap: 1rem;
}
.pg-card {
	background: var(--c-paper);
	border-radius: var(--radius-xl);
	box-shadow: var(--shadow-soft);
	padding: 0.75rem;
	display: grid;
	gap: 0.4rem;
	text-align: center;
	transition: transform 0.2s ease, box-shadow 0.2s ease, filter 0.2s ease;
}
.pg-card:hover {
	transform: translateY(-2px);
	box-shadow: var(--shadow-float);
	filter: saturate(1.05);
}
.pg-card figcaption {
	color: var(--c-muted);
	font-size: 0.9rem;
}

@media (max-width: 1180px) {
	.pg-grid {
		grid-template-columns: repeat(3, 1fr);
	}
}
@media (max-width: 700px) {
	.pg-grid {
		grid-template-columns: repeat(2, 1fr);
	}
}
@media (max-width: 480px) {
	.pg-grid {
		grid-template-columns: 1fr;
	}
}
/* ===== SECTION 16: Seasonal Calendar ===== */
.season-calendar {
	padding: clamp(1.75rem, 4vw, 2.5rem) 0;
	background: linear-gradient(180deg, #f7f5ef, #fffdf7);
}
.cal-toolbar {
	display: flex;
	flex-wrap: wrap;
	gap: 0.5rem;
	margin: 0.5rem 0 0.75rem;
}
.tab {
	border: 1px solid #e2d7b6;
	background: #fffaf0;
	border-radius: 0.6rem;
	padding: 0.45rem 0.7rem;
	cursor: pointer;
	font-weight: 600;
	transition: background 0.2s ease, box-shadow 0.2s ease, transform 0.1s ease;
}
.tab:hover {
	background: #fff5df;
	transform: translateY(-1px);
	box-shadow: var(--shadow-soft);
}
.tab.is-active {
	background: #eef5ea;
	border-color: #cfe2cf;
}

.cal-legend {
	display: flex;
	align-items: center;
	gap: 0.9rem;
	color: var(--c-muted);
	font-size: 0.9rem;
}
.chip {
	width: 14px;
	height: 14px;
	display: inline-block;
	border-radius: 4px;
	border: 1px solid #d9d1b7;
	vertical-align: middle;
}
.chip.in {
	background: linear-gradient(90deg, #4f7b5c, #b2772a);
}
.chip.shoulder {
	background: #f0e6c9;
}

.cal-grid {
	border: 1px solid #eee3c9;
	border-radius: var(--radius-xl);
	overflow: hidden;
	box-shadow: var(--shadow-soft);
}
.cal-row {
	display: grid;
	grid-template-columns: 1.2fr repeat(12, 1fr);
}
.cal-row:not(.cal-head):nth-child(odd) {
	background: #fffdf7;
}
.cal-cell {
	padding: 0.5rem 0.6rem;
	border-bottom: 1px solid #f1ead6;
	font-size: 0.95rem;
}
.cal-head .cal-cell {
	font-weight: 700;
	background: #fffaf0;
}
.cal-cell.name {
	font-weight: 700;
}
.cal-cell.in {
	background: linear-gradient(
		90deg,
		rgba(79, 123, 92, 0.12),
		rgba(178, 119, 42, 0.12)
	);
}
.cal-cell.shoulder {
	background: rgba(230, 215, 182, 0.45);
}

@media (max-width: 980px) {
	.cal-row {
		grid-template-columns: 1.2fr repeat(6, 1fr);
	}
	.cal-head .cal-cell:nth-child(n + 8),
	.cal-row .cal-cell:nth-child(n + 8) {
		display: none;
	} /* показываем Jan–Jun на узких экранах */
}

/* ===== SECTION 17: Trade Notes ===== */
.trade-notes {
	padding: clamp(1.75rem, 4vw, 2.5rem) 0;
}
.tn-grid {
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	gap: 1rem;
	align-items: stretch;
	margin-bottom: 1rem;
}
.tn-card {
	background: var(--c-paper);
	border-radius: var(--radius-xl);
	box-shadow: var(--shadow-soft);
	padding: 1rem;
	display: grid;
	gap: 0.5rem;
	align-content: start;
	transition: transform 0.2s ease, box-shadow 0.2s ease;
	position: relative;
}
.tn-card::after {
	content: '';
	position: absolute;
	left: 0;
	right: 0;
	bottom: 0;
	height: 3px;
	background: linear-gradient(90deg, #4f7b5c, #b2772a);
	transform: scaleX(0);
	transform-origin: left;
	transition: transform 0.45s ease;
}
.tn-card:hover {
	transform: translateY(-2px);
	box-shadow: var(--shadow-float);
}
.tn-card:hover::after {
	transform: scaleX(1);
}

.tn-accordion {
	display: grid;
	gap: 0.5rem;
}
.tn-accordion details {
	background: #fffdf7;
	border: 1px solid #eee3c9;
	border-radius: 0.6rem;
	padding: 0.5rem 0.75rem;
}
.tn-accordion summary {
	cursor: pointer;
	font-weight: 700;
}
.tn-accordion details[open] {
	box-shadow: var(--shadow-soft);
}

@media (max-width: 1180px) {
	.tn-grid {
		grid-template-columns: repeat(2, 1fr);
	}
}
@media (max-width: 640px) {
	.tn-grid {
		grid-template-columns: 1fr;
	}
}
/* cross-browser hide for [hidden] */
[hidden] {
	display: none !important;
}
html {
	overflow-x: hidden;
}
/* ===== RANGE S1 — mobile fixes for the tasting mat ===== */
@media (max-width: 980px) {
	/* делаем коврик отдельным блоком под карточкой */
	.range-mat .mat-area {
		min-height: unset;
	}
	.range-mat .mat-ring {
		position: static;
		display: grid;
		grid-template-columns: repeat(2, minmax(140px, 1fr));
		gap: 0.8rem 0.9rem;
		justify-items: center;
		align-items: start;
		margin-top: 0.9rem;
		padding-bottom: 0.25rem;
	}
	/* убираем декоративные кольца */
	.range-mat .mat-halo,
	.range-mat .mat-dash {
		display: none;
	}

	/* кружки — статичны, ровные, по центру */
	.range-mat .coaster,
	.range-mat .c1,
	.range-mat .c2,
	.range-mat .c3,
	.range-mat .c4 {
		position: static;
		transform: none;
		rotate: 0deg;
		text-align: center;
		width: 100%;
	}

	/* размер фото-кружков и подписи */
	.range-mat .tm-img {
		width: clamp(120px, 40vw, 160px);
		height: auto; /* сохраняем круг за счёт aspect-ratio в базовых стилях */
		box-shadow: var(--shadow-soft);
		animation: none; /* без «дыхания» на мобилках */
	}
	.range-mat .coaster figcaption {
		margin-top: 0.35rem;
		padding: 0.25rem 0.5rem;
		line-height: 1.2;
		white-space: normal; /* не обрезаем текст */
		max-width: 16ch;
	}
}

@media (max-width: 420px) {
	.range-mat .mat-ring {
		grid-template-columns: repeat(2, minmax(120px, 1fr));
		gap: 0.6rem 0.7rem;
	}
	.range-mat .tm-img {
		width: clamp(110px, 44vw, 140px);
	}
	.range-mat .coaster figcaption {
		font-size: 0.95rem;
	}
}

/* перестраховка: слои правильные и клики по тексту не блокируются */
.range-mat .mat-core {
	z-index: 2;
	position: relative;
}
.range-mat .mat-ring {
	z-index: 1;
}
