/**
 * Gemini Trumpet Configurator: panel styling.
 *
 * Class prefix: gtc- (Gemini Trumpet Configurator).
 * Page-wide rules are scoped under `body.has-gemini-configurator` so they
 * affect only pages that render the configurator shortcode.
 */

/* ------------ Page-wide on configurator pages ------------ */

body.has-gemini-configurator {
	background-color: #45474b !important;
	color: #fff8e7;
}

/*
 * Per-Key Elementor section visibility.
 *
 * The configurator JS sets `data-gemini-key="Bb"` or `"C"` on body in
 * sync with the user's Key selection. Tag any Elementor section,
 * column, or widget with `gemini-key-bb` or `gemini-key-c` (Advanced
 * > CSS Classes) to make it show only when the matching Key is active.
 * Untagged sections always show. See INSTRUCTIONS.md for usage.
 */
body[data-gemini-key="Bb"] .gemini-key-c,
body[data-gemini-key="C"] .gemini-key-bb {
	display: none !important;
}

/* Hide the theme or Elementor page title on configurator pages. */
body.has-gemini-configurator .entry-title,
body.has-gemini-configurator .page-title,
body.has-gemini-configurator .post-title,
body.has-gemini-configurator .elementor-page-title,
body.has-gemini-configurator header.entry-header,
body.has-gemini-configurator .page-header {
	display: none !important;
}

.gtc-config {
	/* Palette */
	--gtc-bg: #45474b;
	--gtc-card-bg: transparent;
	--gtc-image-bg: #3a3c3f;
	--gtc-text: #fff8e7;
	--gtc-text-muted: rgba(255, 248, 231, 0.65);
	--gtc-border: rgba(255, 248, 231, 0.35);
	--gtc-accent: #0a6e9c;
	--gtc-accent-hover: #355a7e;
	--gtc-disabled-opacity: 0.4;

	/* Spacing */
	--gtc-gap-sm: 8px;
	--gtc-gap: 16px;
	--gtc-gap-lg: 28px;
	--gtc-radius: 6px;
	--gtc-radius-lg: 10px;

	/* Typography */
	--gtc-font: inherit;
	--gtc-font-label: 12px;
	--gtc-font-pill: 11px;
	--gtc-font-body: 15px;
	--gtc-font-name: 24px;
	--gtc-font-price: 32px;

	box-sizing: border-box;
	max-width: 1180px;
	margin: 0 auto;
	padding: 32px;
	background: transparent;
	color: var(--gtc-text);
	font-family: var(--gtc-font);
}

.gtc-config *,
.gtc-config *::before,
.gtc-config *::after {
	box-sizing: border-box;
}

/* ------------ Model nav row ------------ */

.gtc-config .gtc-models-label {
	display: block !important;
	text-align: center !important;
	margin-bottom: var(--gtc-gap-sm);
}

.gtc-models {
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	gap: var(--gtc-gap-sm);
	margin-bottom: var(--gtc-gap-lg);
}

.gtc-config .gtc-model-btn,
.gtc-config .gtc-model-btn:link,
.gtc-config .gtc-model-btn:visited,
.gtc-config .gtc-model-btn:hover,
.gtc-config .gtc-model-btn:active,
.gtc-config .gtc-model-btn:focus,
.gtc-config .gtc-model-btn:focus-visible {
	text-decoration: none !important;
}

.gtc-model-btn {
	display: inline-block;
	padding: 10px 22px;
	border: 1px solid var(--gtc-border);
	border-radius: var(--gtc-radius);
	background: transparent;
	color: var(--gtc-text);
	font-size: var(--gtc-font-body);
	line-height: 1.2;
	transition: background-color 120ms ease, border-color 120ms ease, color 120ms ease;
}

.gtc-model-btn:hover,
.gtc-model-btn:focus-visible {
	background: var(--gtc-accent-hover);
	border-color: var(--gtc-accent-hover);
	color: var(--gtc-text);
	outline: none;
}

.gtc-model-btn.is-active {
	background: var(--gtc-accent);
	border-color: var(--gtc-accent);
	color: var(--gtc-text);
}

.gtc-model-btn.is-active:hover,
.gtc-model-btn.is-active:focus-visible {
	background: var(--gtc-accent-hover);
	border-color: var(--gtc-accent-hover);
}

/* ------------ Selectors (Key, Pipe) ------------ */

.gtc-selectors {
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: var(--gtc-gap);
	margin-bottom: var(--gtc-gap-lg);
}

.gtc-selector {
	display: flex;
	align-items: center;
	gap: var(--gtc-gap);
	flex-wrap: wrap;
	justify-content: center;
}

.gtc-selector-label {
	font-size: var(--gtc-font-label);
	font-weight: 700;
	letter-spacing: 0.12em;
	text-transform: uppercase;
	color: var(--gtc-text);
}

.gtc-key-btn,
.gtc-pipe-btn {
	display: inline-block;
	min-width: 64px;
	padding: 8px 18px;
	border: 1px solid var(--gtc-border);
	border-radius: var(--gtc-radius);
	background: transparent;
	color: var(--gtc-text);
	font-size: var(--gtc-font-body);
	font-family: inherit;
	cursor: pointer;
	line-height: 1.2;
	transition: background-color 120ms ease, border-color 120ms ease, color 120ms ease, opacity 120ms ease;
}

.gtc-key-btn:hover,
.gtc-pipe-btn:hover,
.gtc-key-btn:focus-visible,
.gtc-pipe-btn:focus-visible {
	background: var(--gtc-accent-hover);
	border-color: var(--gtc-accent-hover);
	color: var(--gtc-text);
	outline: none;
}

.gtc-key-btn.is-active,
.gtc-pipe-btn.is-active {
	background: var(--gtc-accent);
	border-color: var(--gtc-accent);
	color: var(--gtc-text);
}

.gtc-key-btn.is-active:hover,
.gtc-pipe-btn.is-active:hover,
.gtc-key-btn.is-active:focus-visible,
.gtc-pipe-btn.is-active:focus-visible {
	background: var(--gtc-accent-hover);
	border-color: var(--gtc-accent-hover);
}

.gtc-key-btn.is-disabled:hover,
.gtc-key-btn[disabled]:hover {
	background: transparent;
	border-color: var(--gtc-border);
	color: var(--gtc-text);
}

.gtc-key-btn.is-disabled,
.gtc-key-btn[disabled] {
	opacity: var(--gtc-disabled-opacity);
	cursor: not-allowed;
}

/* ------------ Display row (image + info + secondary) ------------ */

.gtc-display {
	display: grid;
	grid-template-columns: minmax(0, 1fr) minmax(0, 1.2fr) minmax(0, 0.8fr);
	gap: var(--gtc-gap-lg);
	align-items: stretch;
	background: var(--gtc-card-bg);
	border-radius: var(--gtc-radius-lg);
	padding: var(--gtc-gap-lg);
}

.gtc-hero-image {
	display: flex;
	align-items: center;
	justify-content: center;
	background: var(--gtc-image-bg);
	border-radius: var(--gtc-radius);
	padding: var(--gtc-gap);
	min-height: 320px;
}

.gtc-product-image {
	max-width: 100%;
	max-height: 360px;
	height: auto;
	width: auto;
	display: block;
	object-fit: contain;
}

.gtc-info {
	display: flex;
	flex-direction: column;
	gap: var(--gtc-gap-sm);
	padding: 4px 8px;
}

.gtc-pill {
	display: inline-block;
	align-self: flex-start;
	background: var(--gtc-accent);
	color: #fff;
	font-size: var(--gtc-font-pill);
	letter-spacing: 0.12em;
	text-transform: uppercase;
	padding: 4px 10px;
	border-radius: 999px;
}

.gtc-config .gtc-product-name {
	font-size: var(--gtc-font-name);
	font-weight: 600;
	margin: 6px 0 0 0;
	line-height: 1.15;
	color: var(--gtc-text) !important;
	/* Modern browsers (Chrome 114+, Safari 17.4+, Firefox 121+) balance the
	 * wrap so long product names break cleanly instead of orphaning the
	 * trailing variation suffix on its own line. Older browsers ignore. */
	text-wrap: balance;
}

.gtc-subtitle {
	margin: 0;
	font-size: var(--gtc-font-body);
	color: var(--gtc-text-muted);
}

.gtc-price,
.gtc-price .woocommerce-Price-amount,
.gtc-price bdi {
	color: var(--gtc-text);
}

.gtc-price {
	margin: 12px 0 0 0;
	font-size: var(--gtc-font-price);
	font-weight: 600;
	line-height: 1.1;
}

.gtc-shipping-note {
	margin: 0;
	font-size: 13px;
	color: var(--gtc-text-muted);
}

/*
 * Short product description, pulled from WooCommerce "Product Short
 * Description" field via $product->get_short_description(). HTML is
 * filtered through wp_kses_post.
 */
.gtc-config .gtc-blurb {
	margin: var(--gtc-gap) 0 0 0;
	font-size: var(--gtc-font-body);
	line-height: 1.5;
	color: var(--gtc-text);
}

.gtc-config .gtc-blurb:empty {
	display: none;
}

.gtc-config .gtc-blurb p {
	margin: 0 0 8px 0;
	color: var(--gtc-text);
}

.gtc-config .gtc-blurb p:last-child {
	margin-bottom: 0;
}

/* Buy row: quantity input + Add to Cart button */

.gtc-buy-row {
	display: flex;
	align-items: stretch;
	gap: var(--gtc-gap-sm);
	margin-top: var(--gtc-gap);
}

/* ------------ Quantity stepper ( - 1 + ) ------------ */

.gtc-config .gtc-quantity-stepper {
	display: inline-flex;
	align-items: stretch;
	flex: 0 0 auto;
	border-radius: var(--gtc-radius);
	overflow: hidden;
}

.gtc-config .gtc-qty-decrement,
.gtc-config .gtc-qty-increment {
	width: 36px;
	min-width: 36px;
	padding: 0;
	background: rgba(0, 0, 0, 0.18) !important;
	border: 1px solid var(--gtc-border) !important;
	color: var(--gtc-text) !important;
	font-size: 18px;
	font-weight: 400;
	font-family: inherit;
	line-height: 1;
	cursor: pointer;
	transition: background-color 120ms ease;
}

.gtc-config .gtc-qty-decrement {
	border-radius: var(--gtc-radius) 0 0 var(--gtc-radius) !important;
	border-right-width: 0 !important;
}

.gtc-config .gtc-qty-increment {
	border-radius: 0 var(--gtc-radius) var(--gtc-radius) 0 !important;
	border-left-width: 0 !important;
}

.gtc-config .gtc-qty-decrement:hover,
.gtc-config .gtc-qty-increment:hover,
.gtc-config .gtc-qty-decrement:focus-visible,
.gtc-config .gtc-qty-increment:focus-visible {
	background: var(--gtc-accent-hover) !important;
	border-color: var(--gtc-accent-hover) !important;
	outline: none;
}

.gtc-config .gtc-quantity {
	width: 56px !important;
	flex: 0 0 56px;
	padding: 10px 4px;
	border-top: 1px solid var(--gtc-border) !important;
	border-bottom: 1px solid var(--gtc-border) !important;
	border-left: 0 !important;
	border-right: 0 !important;
	border-radius: 0 !important;
	background: rgba(0, 0, 0, 0.18) !important;
	color: var(--gtc-text) !important;
	font-size: var(--gtc-font-body);
	font-family: inherit;
	text-align: center;
	-moz-appearance: textfield;
}

.gtc-config .gtc-quantity::-webkit-outer-spin-button,
.gtc-config .gtc-quantity::-webkit-inner-spin-button {
	-webkit-appearance: none;
	margin: 0;
}

.gtc-quantity:focus-visible {
	outline: 2px solid var(--gtc-accent);
	outline-offset: 1px;
	border-color: var(--gtc-accent);
}

.gtc-config .gtc-add-to-cart,
.gtc-config .gtc-add-to-cart:link,
.gtc-config .gtc-add-to-cart:visited,
.gtc-config .gtc-add-to-cart:hover,
.gtc-config .gtc-add-to-cart:active,
.gtc-config .gtc-add-to-cart:focus,
.gtc-config .gtc-add-to-cart:focus-visible {
	text-decoration: none !important;
}

.gtc-add-to-cart {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	flex: 1 1 auto;
	padding: 10px 20px;
	background: var(--gtc-accent);
	color: var(--gtc-text);
	border: 1px solid var(--gtc-accent);
	border-radius: var(--gtc-radius);
	font-size: var(--gtc-font-body);
	font-weight: 600;
	letter-spacing: 0.04em;
	text-transform: uppercase;
	cursor: pointer;
	line-height: 1.2;
	white-space: nowrap;
	transition: background-color 120ms ease, border-color 120ms ease;
}

.gtc-add-to-cart:hover,
.gtc-add-to-cart:focus-visible {
	background: var(--gtc-accent-hover);
	border-color: var(--gtc-accent-hover);
	color: var(--gtc-text);
	outline: none;
}

/*
 * Secondary image (e.g. bell engraving / detail photo).
 * Source: per-product `_gemini_secondary_image_id` postmeta. See INSTRUCTIONS.md.
 * Variations inherit from parent. The <img> always renders; the wrapper hides
 * when no image source is set so the layout collapses cleanly.
 */
.gtc-secondary-image {
	background: var(--gtc-image-bg);
	border-radius: var(--gtc-radius);
	min-height: 320px;
	display: flex;
	align-items: center;
	justify-content: center;
	overflow: hidden;
}

.gtc-secondary-image.is-empty {
	display: none;
}

.gtc-secondary-product-image {
	max-width: 100%;
	max-height: 360px;
	height: auto;
	width: auto;
	display: block;
	object-fit: contain;
}

/* Visually hidden label, accessible to screen readers */
.gtc-config .screen-reader-text {
	border: 0;
	clip: rect(1px, 1px, 1px, 1px);
	clip-path: inset(50%);
	height: 1px;
	margin: -1px;
	overflow: hidden;
	padding: 0;
	position: absolute;
	width: 1px;
	word-wrap: normal !important;
}

/*
 * Top Banner: full-bleed image with a dark tint overlay.
 *
 * The `width: 100vw; margin-left: calc(50% - 50vw);` trick breaks the
 * banner out of any constraining parent (Elementor section, theme
 * container, etc.) so it spans the full viewport edge to edge.
 */
.gtc-top-banner {
	position: relative;
	width: 100vw;
	margin-left: calc(50% - 50vw);
	margin-top: 0;
	margin-bottom: 32px;
	height: 320px;
	background-size: cover;
	background-position: center;
	background-repeat: no-repeat;
	overflow: hidden;
}

.gtc-top-banner.is-empty {
	display: none;
}

.gtc-top-banner::after {
	content: '';
	position: absolute;
	inset: 0;
	background: rgba(20, 24, 32, 0.45);
	pointer-events: none;
}

@media (max-width: 980px) {
	.gtc-top-banner {
		height: 240px;
	}
}

@media (max-width: 600px) {
	.gtc-top-banner {
		height: 180px;
	}
}

/* ------------ Gallery (below Add to Cart row, full configurator width) ------------ */

.gtc-config .gtc-gallery {
	margin-top: var(--gtc-gap-lg);
	padding: 0 var(--gtc-gap-lg);
}

.gtc-config .gtc-gallery.is-empty {
	display: none;
}

.gtc-config .gtc-gallery-list {
	list-style: none;
	margin: 0;
	padding: 0;
	display: flex;
	flex-wrap: wrap;
	gap: var(--gtc-gap);
}

.gtc-config .gtc-gallery-item {
	margin: 0;
	padding: 0;
	flex: 0 0 auto;
}

.gtc-config .gtc-gallery-thumb {
	display: block;
	width: 96px;
	height: 96px;
	padding: 4px;
	background: var(--gtc-image-bg);
	border: 1px solid var(--gtc-border);
	border-radius: var(--gtc-radius);
	cursor: pointer;
	transition: border-color 120ms ease, transform 120ms ease;
	overflow: hidden;
}

.gtc-config .gtc-gallery-thumb img {
	display: block;
	width: 100%;
	height: 100%;
	object-fit: cover;
	border-radius: 3px;
}

.gtc-config .gtc-gallery-thumb:hover,
.gtc-config .gtc-gallery-thumb:focus-visible {
	border-color: var(--gtc-accent);
	outline: none;
	transform: translateY(-1px);
}

.gtc-config .gtc-gallery-thumb.is-active {
	border-color: var(--gtc-accent);
	box-shadow: 0 0 0 2px var(--gtc-accent);
}

/* Mobile: horizontal scroll instead of wrap so thumbs stay compact. */
@media (max-width: 600px) {
	.gtc-config .gtc-gallery {
		padding: 0 var(--gtc-gap);
	}
	.gtc-config .gtc-gallery-list {
		flex-wrap: nowrap;
		overflow-x: auto;
		scroll-snap-type: x mandatory;
		-webkit-overflow-scrolling: touch;
		padding-bottom: 6px;
	}
	.gtc-config .gtc-gallery-item {
		scroll-snap-align: start;
	}
	.gtc-config .gtc-gallery-thumb {
		width: 80px;
		height: 80px;
	}
}

/* ------------ Page Hero (above configurator) ------------ */

.gtc-page-hero {
	max-width: 1180px;
	margin: 0 auto 32px;
	padding: 32px 32px 0;
	color: var(--gtc-text);
}

.gtc-page-hero.is-empty {
	display: none;
}

.gtc-page-hero__image-wrap {
	display: flex;
	align-items: center;
	justify-content: center;
	margin-bottom: 24px;
}

.gtc-page-hero__image {
	max-width: 100%;
	height: auto;
	max-height: 420px;
	display: block;
	object-fit: contain;
}

/*
 * Headline and body share a centered column with a fixed max-width.
 * Text inside flows left-aligned (like the Figma reference), while the
 * column itself sits centered on the page.
 */
.gtc-config .gtc-page-hero__headline,
.gtc-page-hero__headline {
	max-width: 760px;
	margin: 0 auto 16px auto;
	font-size: 38px;
	line-height: 1.15;
	font-weight: 700;
	letter-spacing: 0.02em;
	color: var(--gtc-text) !important;
	text-align: center;
}

.gtc-page-hero__body {
	max-width: 760px;
	margin: 0 auto;
	font-size: 16px;
	line-height: 1.6;
	color: var(--gtc-text);
	text-align: left;
}

.gtc-page-hero__body p {
	margin: 0 0 14px 0;
}

.gtc-page-hero__body p:last-child {
	margin-bottom: 0;
}

/* ------------ Series Header (below configurator) ------------ */

.gtc-series-header {
	max-width: 1180px;
	margin: 16px auto 24px;
	padding: 0 32px;
	color: var(--gtc-text);
}

.gtc-series-header.is-empty {
	display: none;
}

.gtc-config .gtc-series-header__headline,
.gtc-series-header__headline {
	font-size: 28px;
	line-height: 1.2;
	font-weight: 700;
	margin: 0 0 12px 0;
	color: var(--gtc-text) !important;
}

.gtc-series-header__body {
	font-size: 16px;
	line-height: 1.6;
}

.gtc-series-header__body p {
	margin: 0 0 12px 0;
}

.gtc-series-header__body p:last-child {
	margin-bottom: 0;
}

/* ------------ Feature Sections (alternating) ------------ */

.gtc-features {
	max-width: 1180px;
	margin: 0 auto;
	padding: 0 32px 32px;
	color: var(--gtc-text);
}

.gtc-features.is-empty {
	display: none;
}

.gtc-feature-section {
	display: grid;
	grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
	gap: 40px;
	align-items: center;
	padding: 32px 0;
}

.gtc-feature-section + .gtc-feature-section {
	border-top: 1px solid rgba(255, 248, 231, 0.12);
}

.gtc-feature-section:nth-child(even) .gtc-feature-section__image-wrap {
	order: 2;
}

.gtc-feature-section:nth-child(even) .gtc-feature-section__copy {
	order: 1;
}

.gtc-feature-section__image-wrap {
	display: flex;
	align-items: center;
	justify-content: center;
	background: var(--gtc-image-bg);
	border-radius: var(--gtc-radius);
	padding: 16px;
	min-height: 240px;
}

.gtc-feature-section__image {
	max-width: 100%;
	max-height: 320px;
	height: auto;
	width: auto;
	object-fit: contain;
}

.gtc-config .gtc-feature-section__headline,
.gtc-feature-section__headline {
	font-size: 22px;
	font-weight: 700;
	line-height: 1.2;
	margin: 0 0 12px 0;
	color: var(--gtc-text) !important;
}

.gtc-feature-section__body {
	font-size: 15px;
	line-height: 1.6;
}

.gtc-feature-section__body p {
	margin: 0 0 12px 0;
}

.gtc-feature-section__body p:last-child {
	margin-bottom: 0;
}

/* ------------ Landing page: Model Picker (4-card grid) ------------ */

.gtl-model-picker {
	max-width: 1180px;
	margin: 32px auto 16px;
	padding: 0 32px;
}

.gtl-model-list {
	display: grid;
	grid-template-columns: repeat(4, minmax(0, 1fr));
	gap: 24px;
	list-style: none;
	margin: 0;
	padding: 0;
}

.gtl-model-card {
	margin: 0;
	padding: 0;
}

.gtl-model-card-link,
.gtl-model-card-link:link,
.gtl-model-card-link:visited,
.gtl-model-card-link:hover,
.gtl-model-card-link:active,
.gtl-model-card-link:focus,
.gtl-model-card-link:focus-visible {
	display: block;
	background: rgba(0, 0, 0, 0.18);
	border: 1px solid rgba(255, 248, 231, 0.35);
	border-radius: 10px;
	overflow: hidden;
	text-decoration: none !important;
	color: #fff8e7;
	transition: border-color 120ms ease, transform 120ms ease, box-shadow 120ms ease;
}

.gtl-model-card-link:hover,
.gtl-model-card-link:focus-visible {
	border-color: #0a6e9c;
	transform: translateY(-2px);
	box-shadow: 0 4px 16px rgba(0, 0, 0, 0.25);
	outline: none;
}

.gtl-model-card-image-wrap {
	background: #3a3c3f;
	padding: 20px;
	display: flex;
	align-items: center;
	justify-content: center;
	min-height: 200px;
}

.gtl-model-card-image {
	display: block;
	max-width: 100%;
	max-height: 180px;
	width: auto;
	height: auto;
	object-fit: contain;
}

.gtl-model-card-body {
	padding: 18px 20px 22px;
	color: #fff8e7;
}

.gtl-model-card-pill {
	display: inline-block;
	background: #0a6e9c;
	color: #fff;
	font-size: 11px;
	letter-spacing: 0.12em;
	text-transform: uppercase;
	padding: 4px 10px;
	border-radius: 999px;
}

.gtl-model-card-name {
	font-size: 22px;
	font-weight: 600;
	margin: 10px 0 4px 0;
	color: #fff8e7 !important;
	line-height: 1.15;
}

.gtl-model-card-tagline {
	margin: 0 0 12px 0;
	font-size: 14px;
	line-height: 1.5;
	color: rgba(255, 248, 231, 0.75);
}

.gtl-model-card-price {
	margin: 0 0 12px 0;
	font-size: 16px;
	font-weight: 600;
	color: #fff8e7;
}

.gtl-model-card-cta {
	display: inline-block;
	color: #0a6e9c;
	font-size: 14px;
	font-weight: 600;
	letter-spacing: 0.04em;
	text-transform: uppercase;
}

.gtl-model-card-link:hover .gtl-model-card-cta,
.gtl-model-card-link:focus-visible .gtl-model-card-cta {
	color: #fff8e7;
}

@media (max-width: 980px) {
	.gtl-model-list {
		grid-template-columns: repeat(2, minmax(0, 1fr));
		gap: 16px;
	}
	.gtl-model-picker {
		padding: 0 20px;
	}
}

@media (max-width: 600px) {
	.gtl-model-list {
		grid-template-columns: 1fr;
	}
}

/* ------------ Artist Spotlight (site-wide; bottom of every model page) ------------ */

.gtc-spotlight {
	max-width: 1180px;
	margin: 24px auto 0;
	padding: 32px;
	color: var(--gtc-text);
	display: grid;
	grid-template-columns: auto minmax(0, 1fr);
	gap: 32px;
	align-items: center;
	border-top: 1px solid rgba(255, 248, 231, 0.12);
	box-sizing: border-box;
}

.gtc-spotlight.is-empty {
	display: none;
}

.gtc-spotlight__image-wrap {
	display: flex;
	align-items: center;
	justify-content: center;
}

.gtc-spotlight__image {
	display: block;
	max-width: 100%;
	max-height: 200px;
	width: auto;
	height: auto;
	object-fit: contain;
}

.gtc-spotlight__body {
	font-size: 16px;
	line-height: 1.6;
	color: var(--gtc-text);
	min-width: 0;
}

.gtc-spotlight__body p {
	margin: 0 0 14px 0;
}

.gtc-spotlight__body p:last-child {
	margin-bottom: 0;
}

@media (max-width: 980px) {
	.gtc-spotlight {
		grid-template-columns: 1fr;
		gap: 16px;
		padding: 24px 20px;
	}
	.gtc-spotlight__image-wrap {
		justify-content: flex-start;
	}
}

@media (max-width: 600px) {
	.gtc-spotlight {
		padding: 20px;
	}
}

/* ------------ Responsive ------------ */

@media (max-width: 980px) {
	.gtc-display {
		grid-template-columns: 1fr;
	}

	/* Stack collapses to one column. Source order is hero, info,
	   secondary, so the secondary image appears below the buy row.
	   The `.is-empty` class still hides it when no image is set. */

	/* Center the info content so the pill, name, price, blurb, and
	   buy row all sit on the same axis. */
	.gtc-config .gtc-info {
		align-items: center;
		text-align: center;
	}
	.gtc-config .gtc-pill {
		align-self: center;
	}
	.gtc-config .gtc-buy-row {
		justify-content: center;
	}
}

@media (max-width: 980px) {
	.gtc-feature-section {
		grid-template-columns: 1fr;
		gap: 20px;
	}
	.gtc-feature-section:nth-child(even) .gtc-feature-section__image-wrap {
		order: 0;
	}
	.gtc-feature-section:nth-child(even) .gtc-feature-section__copy {
		order: 0;
	}
	.gtc-page-hero,
	.gtc-series-header,
	.gtc-features {
		padding-left: 20px;
		padding-right: 20px;
	}
}

@media (max-width: 600px) {
	.gtc-config {
		padding: 20px;
	}
	.gtc-display {
		padding: var(--gtc-gap);
		gap: var(--gtc-gap);
	}
	.gtc-config .gtc-product-name {
		font-size: 24px;
	}
	.gtc-price {
		font-size: 26px;
	}
	.gtc-page-hero__headline {
		font-size: 28px;
	}
	.gtc-series-header__headline {
		font-size: 22px;
	}
}
