/* =============================================================================
   TGB WooCommerce Overrides v1.1.0
   Scoped to .woocommerce context where possible
   =============================================================================

   01. Buttons
   02. Notices
   03. Form Fields
   04. Product Page
   05. Cart & Order Tables
   06. Checkout
   07. My Account
   08. Order Confirmation
   ============================================================================= */

/* -----------------------------------------------------------------------------
   01. Buttons
   ----------------------------------------------------------------------------- */

.woocommerce a.button,
.woocommerce button.button,
.woocommerce input.button,
.woocommerce #respond input#submit,
.woocommerce-cart .wc-proceed-to-checkout a.checkout-button {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	font-family: var(--font-heading);
	font-size: var(--scale-sm);
	font-weight: 600;
	letter-spacing: 0.02em;
	background-color: var(--colour-primary);
	color: var(--colour-text-inverse) !important;
	border-radius: var(--radius);
	padding: var(--space-3) var(--space-6);
	border: 2px solid var(--colour-primary);
	transition: background-color var(--transition), border-color var(--transition),
	            box-shadow var(--transition), transform var(--transition);
	text-decoration: none;
	cursor: pointer;
	box-shadow: 0 2px 8px rgb(17 81 211 / 0.25);
	line-height: 1.4;
}

.woocommerce a.button:hover,
.woocommerce button.button:hover,
.woocommerce input.button:hover,
.woocommerce #respond input#submit:hover,
.woocommerce-cart .wc-proceed-to-checkout a.checkout-button:hover {
	background-color: var(--colour-primary-dark);
	border-color: var(--colour-primary-dark);
	color: var(--colour-text-inverse) !important;
	box-shadow: 0 4px 16px rgb(17 81 211 / 0.35);
}

.woocommerce a.button:focus-visible,
.woocommerce button.button:focus-visible,
.woocommerce input.button:focus-visible,
.woocommerce #respond input#submit:focus-visible {
	outline: 3px solid var(--colour-primary);
	outline-offset: 3px;
}

.woocommerce a.button.alt,
.woocommerce button.button.alt,
.woocommerce input.button.alt {
	background-color: var(--colour-navy);
	border-color: var(--colour-navy);
	box-shadow: var(--shadow-navy);
}

.woocommerce a.button.alt:hover,
.woocommerce button.button.alt:hover {
	background-color: var(--colour-navy-mid);
	border-color: var(--colour-navy-mid);
	color: var(--colour-text-inverse) !important;
}

.woocommerce a.button.disabled,
.woocommerce button.button:disabled,
.woocommerce input.button:disabled {
	opacity: 0.5;
	cursor: not-allowed;
}

/* -----------------------------------------------------------------------------
   02. Notices
   ----------------------------------------------------------------------------- */

.woocommerce-message,
.woocommerce-info,
.woocommerce-error {
	border-radius: var(--radius-lg);
	border-top: none;
	border-left: 4px solid;
	padding: var(--space-4) var(--space-6);
	font-size: var(--scale-sm);
	margin-bottom: var(--space-6);
	display: flex;
	align-items: flex-start;
	gap: var(--space-3);
}

.woocommerce-message {
	background-color: #ECFDF5;
	color: #065F46;
	border-color: #10B981;
}

.woocommerce-info {
	background-color: var(--colour-primary-light);
	color: var(--colour-navy);
	border-color: var(--colour-primary);
}

.woocommerce-error {
	background-color: #FEF2F2;
	color: #991B1B;
	border-color: #EF4444;
}

.woocommerce-error ul,
.woocommerce-message ul {
	margin: 0;
	padding: 0;
	list-style: none;
}

/* -----------------------------------------------------------------------------
   03. Form Fields
   ----------------------------------------------------------------------------- */

.woocommerce form .form-row {
	margin-bottom: var(--space-4);
}

.woocommerce form .form-row label {
	display: block;
	font-family: var(--font-heading);
	font-size: var(--scale-sm);
	font-weight: 600;
	color: var(--colour-text-primary);
	margin-bottom: var(--space-2);
	letter-spacing: 0.01em;
}

.woocommerce form .form-row label abbr {
	color: #EF4444;
	text-decoration: none;
}

.woocommerce form .form-row input.input-text,
.woocommerce form .form-row textarea,
.woocommerce form .form-row select {
	width: 100%;
	border: 1px solid var(--colour-border);
	border-radius: var(--radius);
	padding: var(--space-3) var(--space-4);
	font-family: var(--font-body);
	font-size: var(--scale-sm);
	color: var(--colour-text-primary);
	background-color: var(--colour-surface);
	transition: border-color var(--transition), box-shadow var(--transition);
	height: 44px;
}

.woocommerce form .form-row textarea {
	height: auto;
	min-height: 120px;
	resize: vertical;
}

.woocommerce form .form-row input.input-text:focus,
.woocommerce form .form-row textarea:focus,
.woocommerce form .form-row select:focus {
	border-color: var(--colour-primary);
	box-shadow: 0 0 0 3px rgba(17 81 211 / 0.12);
	outline: none;
}

.woocommerce form .form-row.woocommerce-invalid input.input-text {
	border-color: #EF4444;
}

.woocommerce form .form-row.woocommerce-validated input.input-text {
	border-color: #10B981;
}

/* -----------------------------------------------------------------------------
   04. Product Page
   ----------------------------------------------------------------------------- */

.woocommerce div.product {
	padding-block: var(--space-12);
}

.woocommerce div.product .woocommerce-breadcrumb {
	font-size: var(--scale-sm);
	color: var(--colour-text-muted);
	margin-bottom: var(--space-6);
}

.woocommerce div.product .woocommerce-breadcrumb a {
	color: var(--colour-text-secondary);
	text-decoration: none;
	transition: color var(--transition);
}

.woocommerce div.product .woocommerce-breadcrumb a:hover {
	color: var(--colour-primary);
}

.woocommerce div.product .product_title {
	font-family: var(--font-editorial);
	font-size: clamp(var(--scale-2xl), 3vw, var(--scale-4xl));
	font-weight: 400;
	color: var(--colour-text-primary);
	line-height: 1.15;
	letter-spacing: -0.02em;
	margin-bottom: var(--space-4);
}

.woocommerce div.product .price {
	font-family: var(--font-heading);
	font-size: var(--scale-3xl);
	font-weight: 700;
	color: var(--colour-text-primary);
	letter-spacing: -0.03em;
	margin-bottom: var(--space-6);
}

.woocommerce div.product .price del {
	font-size: var(--scale-xl);
	color: var(--colour-text-muted);
	font-weight: 400;
	margin-right: var(--space-2);
}

.woocommerce div.product .price ins {
	text-decoration: none;
}

.woocommerce div.product .woocommerce-product-details__short-description {
	font-size: var(--scale-md);
	color: var(--colour-text-secondary);
	line-height: 1.7;
	margin-bottom: var(--space-6);
}

/* Single add-to-cart */
.woocommerce div.product form.cart {
	margin-bottom: var(--space-6);
}

.woocommerce div.product form.cart .single_add_to_cart_button {
	font-size: var(--scale-base);
	padding: var(--space-4) var(--space-10);
}

.woocommerce div.product .product_meta {
	font-size: var(--scale-sm);
	color: var(--colour-text-muted);
	border-top: 1px solid var(--colour-border);
	padding-top: var(--space-4);
	margin-top: var(--space-6);
}

.woocommerce div.product .product_meta span {
	display: block;
	margin-bottom: var(--space-1);
}

.woocommerce div.product .product_meta a {
	color: var(--colour-primary);
}

/* Tabs */
.woocommerce div.product .woocommerce-tabs {
	margin-top: var(--space-16);
}

.woocommerce div.product .woocommerce-tabs ul.tabs {
	display: flex;
	list-style: none;
	padding: 0;
	margin: 0 0 var(--space-8);
	border-bottom: 2px solid var(--colour-border);
	gap: 0;
}

.woocommerce div.product .woocommerce-tabs ul.tabs li {
	margin: 0;
	background: none;
	border: none;
	border-radius: 0;
}

.woocommerce div.product .woocommerce-tabs ul.tabs li a {
	display: block;
	padding: var(--space-3) var(--space-5);
	font-family: var(--font-heading);
	font-size: var(--scale-sm);
	font-weight: 600;
	color: var(--colour-text-secondary);
	text-decoration: none;
	border-bottom: 2px solid transparent;
	margin-bottom: -2px;
	transition: color var(--transition), border-color var(--transition);
}

.woocommerce div.product .woocommerce-tabs ul.tabs li.active a,
.woocommerce div.product .woocommerce-tabs ul.tabs li a:hover {
	color: var(--colour-primary);
	border-bottom-color: var(--colour-primary);
}

.woocommerce div.product .woocommerce-tabs .panel {
	padding: 0;
	font-size: var(--scale-md);
	line-height: 1.75;
	color: var(--colour-text-primary);
}

/* -----------------------------------------------------------------------------
   05. Cart & Order Tables
   ----------------------------------------------------------------------------- */

.woocommerce table.shop_table {
	border-collapse: collapse;
	width: 100%;
	background-color: var(--colour-surface);
	border-radius: var(--radius-lg);
	overflow: hidden;
	box-shadow: var(--shadow);
	border: 1px solid var(--colour-border);
}

.woocommerce table.shop_table thead tr {
	background-color: var(--colour-surface-raised);
}

.woocommerce table.shop_table th {
	font-family: var(--font-heading);
	font-size: var(--scale-xs);
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.08em;
	color: var(--colour-text-secondary);
	padding: var(--space-4) var(--space-5);
	border-bottom: 1px solid var(--colour-border);
	text-align: left;
}

.woocommerce table.shop_table td {
	padding: var(--space-4) var(--space-5);
	border-bottom: 1px solid var(--colour-border);
	font-size: var(--scale-sm);
	vertical-align: middle;
	color: var(--colour-text-primary);
}

.woocommerce table.shop_table tr:last-child td {
	border-bottom: none;
}

.woocommerce table.shop_table tfoot tr td {
	font-weight: 600;
	font-family: var(--font-heading);
}

.woocommerce table.shop_table tfoot .order-total .amount {
	font-size: var(--scale-xl);
	font-weight: 700;
	color: var(--colour-primary);
}

/* Proceed to checkout */
.woocommerce-cart .wc-proceed-to-checkout {
	text-align: right;
	margin-top: var(--space-6);
}

.woocommerce-cart .wc-proceed-to-checkout a.checkout-button {
	font-size: var(--scale-base);
	padding: var(--space-4) var(--space-10);
}

/* -----------------------------------------------------------------------------
   06. Checkout
   ----------------------------------------------------------------------------- */

.woocommerce #order_review_heading,
.woocommerce #payment ul.payment_methods {
	list-style: none;
}

.woocommerce #order_review_heading {
	font-family: var(--font-heading);
	font-size: var(--scale-xl);
	font-weight: 700;
	color: var(--colour-text-primary);
	letter-spacing: -0.025em;
	margin-bottom: var(--space-6);
	padding-bottom: var(--space-4);
	border-bottom: 1px solid var(--colour-border);
}

.woocommerce #payment {
	background-color: var(--colour-surface-raised);
	border-radius: var(--radius-lg);
	border: 1px solid var(--colour-border);
	padding: var(--space-6);
	margin-top: var(--space-6);
}

.woocommerce #payment ul.payment_methods {
	padding: 0;
	margin-bottom: var(--space-6);
}

.woocommerce #payment ul.payment_methods li {
	padding: var(--space-3) 0;
	border-bottom: 1px solid var(--colour-border);
	font-size: var(--scale-sm);
}

.woocommerce #payment ul.payment_methods li:last-child {
	border-bottom: none;
}

.woocommerce #payment div.payment_box {
	background-color: var(--colour-primary-light);
	border-radius: var(--radius);
	padding: var(--space-4);
	margin-top: var(--space-3);
	font-size: var(--scale-sm);
	color: var(--colour-navy);
}

.woocommerce #payment #place_order {
	font-size: var(--scale-base);
	padding: var(--space-4) var(--space-10);
	width: 100%;
	justify-content: center;
}

/* Checkout two-column layout */
@media (min-width: 768px) {
	.woocommerce form.checkout {
		display: grid;
		grid-template-columns: 1fr 420px;
		gap: var(--space-10);
		align-items: start;
	}

	.woocommerce form.checkout > h3:first-child,
	.woocommerce form.checkout .woocommerce-billing-fields,
	.woocommerce form.checkout .woocommerce-additional-fields {
		grid-column: 1;
	}

	.woocommerce form.checkout .woocommerce-checkout-review-order {
		grid-column: 2;
	}
}

/* -----------------------------------------------------------------------------
   07. My Account
   ----------------------------------------------------------------------------- */

.woocommerce-account .woocommerce-MyAccount-navigation {
	background-color: var(--colour-surface);
	border: 1px solid var(--colour-border);
	border-radius: var(--radius-lg);
	padding: var(--space-3);
	margin-bottom: var(--space-6);
}

@media (min-width: 768px) {
	.woocommerce-account .woocommerce {
		display: grid;
		grid-template-columns: 220px 1fr;
		gap: var(--space-8);
		align-items: start;
	}

	.woocommerce-account .woocommerce-MyAccount-navigation {
		margin-bottom: 0;
		position: sticky;
		top: calc(68px + var(--space-6));
	}
}

.woocommerce-MyAccount-navigation ul {
	list-style: none;
	padding: 0;
	margin: 0;
}

.woocommerce-MyAccount-navigation li {
	border-bottom: none;
}

.woocommerce-MyAccount-navigation li a {
	display: flex;
	align-items: center;
	padding: var(--space-3) var(--space-4);
	font-family: var(--font-heading);
	font-size: var(--scale-sm);
	font-weight: 600;
	color: var(--colour-text-secondary);
	text-decoration: none;
	border-radius: var(--radius);
	transition: color var(--transition), background-color var(--transition);
}

.woocommerce-MyAccount-navigation li a:hover {
	color: var(--colour-primary);
	background-color: var(--colour-primary-light);
}

.woocommerce-MyAccount-navigation li.is-active a,
.woocommerce-MyAccount-navigation li a[href*="logout"] {
	/* logout stays neutral */
}

.woocommerce-MyAccount-navigation li.is-active a {
	color: var(--colour-primary);
	background-color: var(--colour-primary-light);
}

.woocommerce-MyAccount-navigation li a:focus-visible {
	outline: 2px solid var(--colour-primary);
	outline-offset: 1px;
}

/* Account content area */
.woocommerce-account .woocommerce-MyAccount-content {
	font-size: var(--scale-sm);
}

.woocommerce-account .woocommerce-MyAccount-content h2 {
	font-family: var(--font-heading);
	font-size: var(--scale-xl);
	font-weight: 700;
	color: var(--colour-text-primary);
	letter-spacing: -0.025em;
	margin-bottom: var(--space-6);
}

/* -----------------------------------------------------------------------------
   08. Order Confirmation
   ----------------------------------------------------------------------------- */

.woocommerce-order {
	padding-block: var(--space-16);
}

.woocommerce-order .woocommerce-order-received h2 {
	font-family: var(--font-editorial);
	font-size: var(--scale-4xl);
	font-weight: 400;
	color: var(--colour-text-primary);
	letter-spacing: -0.02em;
	margin-bottom: var(--space-6);
}

.woocommerce-order ul.woocommerce-order-overview {
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: var(--space-4);
	list-style: none;
	padding: 0;
	margin-bottom: var(--space-10);
	background-color: var(--colour-surface);
	border: 1px solid var(--colour-border);
	border-radius: var(--radius-lg);
	padding: var(--space-6);
}

@media (min-width: 640px) {
	.woocommerce-order ul.woocommerce-order-overview {
		grid-template-columns: repeat(4, 1fr);
	}
}

.woocommerce-order ul.woocommerce-order-overview li {
	font-size: var(--scale-sm);
	color: var(--colour-text-secondary);
}

.woocommerce-order ul.woocommerce-order-overview li strong {
	display: block;
	font-family: var(--font-heading);
	font-weight: 700;
	font-size: var(--scale-base);
	color: var(--colour-text-primary);
	margin-top: var(--space-1);
}

.woocommerce-order-details__title,
.woocommerce-customer-details h2 {
	font-family: var(--font-heading);
	font-size: var(--scale-xl);
	font-weight: 700;
	color: var(--colour-text-primary);
	letter-spacing: -0.025em;
	margin-bottom: var(--space-4);
	margin-top: var(--space-10);
}

/* =============================================================================
   09. Product Library — /shop/ archive
   ============================================================================= */

.tgb-product-library__hero {
	background-color: var(--colour-navy);
	padding-block: var(--space-16) var(--space-12);
	position: relative;
	overflow: hidden;
}

.tgb-product-library__hero::before {
	content: '';
	position: absolute;
	inset: 0;
	background-image:
		repeating-linear-gradient(
			45deg,
			rgba(255, 255, 255, 0.03) 0px,
			rgba(255, 255, 255, 0.03) 1px,
			transparent 1px,
			transparent 48px
		);
	pointer-events: none;
}

.tgb-product-library__eyebrow {
	font-family: var(--font-heading);
	font-size: var(--scale-xs);
	font-weight: 700;
	letter-spacing: 0.15em;
	text-transform: uppercase;
	color: var(--colour-gold-mid, #C9A84C);
	margin-bottom: var(--space-3);
}

.tgb-product-library__title {
	font-family: var(--font-editorial);
	font-size: clamp(var(--scale-3xl), 4vw, var(--scale-5xl));
	font-weight: 400;
	color: #fff;
	line-height: 1.08;
	letter-spacing: -0.025em;
	margin-bottom: var(--space-4);
}

.tgb-product-library__subtitle {
	font-family: var(--font-body);
	font-size: var(--scale-md);
	color: rgba(255, 255, 255, 0.72);
	line-height: 1.65;
	max-width: 660px;
	margin-bottom: var(--space-8);
}

.tgb-product-library__pass-strip {
	display: flex;
	align-items: center;
	flex-wrap: wrap;
	gap: var(--space-3) var(--space-6);
	background: rgba(255, 255, 255, 0.07);
	border: 1px solid rgba(255, 255, 255, 0.14);
	border-radius: var(--radius-lg);
	padding: var(--space-4) var(--space-6);
	max-width: 680px;
}

.tgb-product-library__pass-label {
	font-family: var(--font-heading);
	font-size: var(--scale-sm);
	font-weight: 700;
	color: #fff;
	white-space: nowrap;
}

.tgb-product-library__pass-desc {
	font-size: var(--scale-sm);
	color: rgba(255, 255, 255, 0.6);
	flex: 1;
	min-width: 160px;
}

/* Filter bar */
.tgb-product-library__filters-wrap {
	background-color: var(--colour-surface);
	border-bottom: 1px solid var(--colour-border);
	padding-block: var(--space-4) var(--space-5);
	position: sticky;
	top: 68px;
	z-index: var(--z-sticky, 20);
}

.tgb-filter-row {
	display: flex;
	flex-wrap: wrap;
	gap: var(--space-5) var(--space-8);
	align-items: flex-start;
}

.tgb-filter-group {
	display: flex;
	flex-direction: column;
	gap: var(--space-2);
}

.tgb-filter-group__label {
	font-family: var(--font-heading);
	font-size: var(--scale-xs);
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.1em;
	color: var(--colour-text-muted);
}

.tgb-filter-chips {
	display: flex;
	flex-wrap: wrap;
	gap: var(--space-2);
}

.tgb-filter-chip {
	display: inline-flex;
	align-items: center;
	font-family: var(--font-heading);
	font-size: var(--scale-xs);
	font-weight: 600;
	color: var(--colour-text-secondary);
	background-color: var(--colour-surface-raised);
	border: 1.5px solid var(--colour-border);
	border-radius: var(--radius-full);
	padding: 5px var(--space-4);
	cursor: pointer;
	transition: background-color var(--transition), border-color var(--transition),
	            color var(--transition), box-shadow var(--transition);
	letter-spacing: 0.02em;
	line-height: 1.4;
	white-space: nowrap;
	-webkit-appearance: none;
	appearance: none;
}

.tgb-filter-chip:hover {
	background-color: var(--colour-primary-light);
	border-color: var(--colour-primary);
	color: var(--colour-primary);
}

.tgb-filter-chip.is-active {
	background-color: var(--colour-navy);
	border-color: var(--colour-navy);
	color: #fff;
}

[data-filter-vertical].tgb-filter-chip.is-active {
	background-color: var(--chip-colour, var(--colour-navy));
	border-color: var(--chip-colour, var(--colour-navy));
	color: #fff;
}

.tgb-filter-chip:focus-visible {
	outline: 3px solid var(--colour-primary);
	outline-offset: 2px;
}

.tgb-filter-status {
	font-size: var(--scale-xs);
	color: var(--colour-text-muted);
	margin-top: var(--space-3);
	min-height: 1.5em;
}

.tgb-filter-empty {
	text-align: center;
	color: var(--colour-text-muted);
	padding-block: var(--space-16);
	font-size: var(--scale-md);
	font-style: italic;
}

.tgb-product-grid-item[hidden] {
	display: none !important;
}

/* =============================================================================
   10. Single Product — tgb-product-single
   ============================================================================= */

.tgb-product-single {
	padding-bottom: var(--space-20);
}

.tgb-product-single__band {
	height: 6px;
	background-color: var(--product-colour, var(--colour-primary));
}

/* Breadcrumb */
.tgb-breadcrumb {
	padding-block: var(--space-4) var(--space-2);
}

.tgb-breadcrumb__list {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: 0;
	list-style: none;
	padding: 0;
	margin: 0;
}

.tgb-breadcrumb__item {
	display: flex;
	align-items: center;
	font-size: var(--scale-xs);
	color: var(--colour-text-muted);
}

.tgb-breadcrumb__item:not(:last-child)::after {
	content: '/';
	margin-inline: var(--space-2);
	color: var(--colour-border);
}

.tgb-breadcrumb__link {
	color: var(--colour-text-secondary);
	text-decoration: none;
	transition: color var(--transition);
}

.tgb-breadcrumb__link:hover {
	color: var(--colour-primary);
}

.tgb-breadcrumb__item--current {
	color: var(--colour-text-primary);
	font-weight: 500;
}

/* Layout */
.tgb-product-single__layout {
	display: grid;
	grid-template-columns: 1fr;
	gap: var(--space-10);
	padding-top: var(--space-6);
}

@media (min-width: 900px) {
	.tgb-product-single__layout {
		grid-template-columns: 1fr 340px;
		gap: var(--space-12);
		align-items: start;
	}
}

/* Badges */
.tgb-product-single__badges {
	display: flex;
	flex-wrap: wrap;
	gap: var(--space-2);
	margin-bottom: var(--space-4);
}

.tgb-badge {
	display: inline-flex;
	align-items: center;
	font-family: var(--font-heading);
	font-size: var(--scale-xs);
	font-weight: 700;
	letter-spacing: 0.07em;
	text-transform: uppercase;
	border-radius: var(--radius-full);
	padding: 3px var(--space-3);
	line-height: 1.5;
}

.tgb-badge--vertical {
	color: #fff;
}

.tgb-badge--format {
	background-color: var(--colour-surface-raised);
	color: var(--colour-text-secondary);
	border: 1px solid var(--colour-border);
}

/* Title */
.tgb-product-single__title {
	font-family: var(--font-editorial);
	font-size: clamp(var(--scale-2xl), 3.5vw, var(--scale-4xl));
	font-weight: 400;
	color: var(--colour-text-primary);
	line-height: 1.1;
	letter-spacing: -0.025em;
	margin-bottom: var(--space-4);
}

/* Upsell / lede */
.tgb-product-single__upsell {
	font-size: var(--scale-md);
	color: var(--colour-text-secondary);
	line-height: 1.7;
	margin-bottom: var(--space-6);
}

/* Product image */
.tgb-product-single__image {
	margin-bottom: var(--space-8);
}

.tgb-product-single__image img {
	width: 100%;
	height: auto;
	display: block;
	border-radius: var(--radius-lg);
	box-shadow: var(--shadow);
}

/* Placeholder image */
.tgb-product-single__placeholder-img {
	width: 100%;
	aspect-ratio: 16 / 9;
	background-color: var(--product-colour, var(--colour-navy));
	background-image: linear-gradient(135deg, transparent 0%, rgba(0, 0, 0, 0.38) 100%);
	border-radius: var(--radius-lg);
	display: flex;
	align-items: center;
	justify-content: center;
	position: relative;
	overflow: hidden;
	box-shadow: var(--shadow);
}

.tgb-product-single__placeholder-img::before {
	content: '';
	position: absolute;
	inset: 0;
	background-image: repeating-linear-gradient(
		-45deg,
		rgba(255, 255, 255, 0.03) 0px,
		rgba(255, 255, 255, 0.03) 1px,
		transparent 1px,
		transparent 44px
	);
}

.tgb-product-single__placeholder-inner {
	display: flex;
	flex-direction: column;
	align-items: center;
	text-align: center;
	padding: var(--space-8) var(--space-6);
	position: relative;
	z-index: 1;
	gap: var(--space-3);
}

.tgb-product-single__placeholder-format {
	font-family: var(--font-heading);
	font-size: var(--scale-xs);
	font-weight: 700;
	letter-spacing: 0.2em;
	text-transform: uppercase;
	color: rgba(255, 255, 255, 0.55);
}

.tgb-product-single__placeholder-title {
	font-family: var(--font-editorial);
	font-size: clamp(var(--scale-lg), 2.5vw, var(--scale-3xl));
	font-weight: 400;
	color: #fff;
	line-height: 1.2;
	letter-spacing: -0.02em;
	max-width: 520px;
}

.tgb-product-single__placeholder-vertical {
	font-family: var(--font-heading);
	font-size: var(--scale-xs);
	font-weight: 600;
	color: rgba(255, 255, 255, 0.45);
	letter-spacing: 0.1em;
	text-transform: uppercase;
}

/* Content sections */
.tgb-product-single__description {
	margin-bottom: var(--space-8);
}

.tgb-product-single__section {
	margin-bottom: var(--space-6);
	padding-top: var(--space-8);
	border-top: 1px solid var(--colour-border);
}

.tgb-product-single__section-title {
	font-family: var(--font-heading);
	font-size: var(--scale-lg);
	font-weight: 700;
	color: var(--colour-text-primary);
	letter-spacing: -0.02em;
	margin-bottom: var(--space-5);
}

.tgb-product-single__includes,
.tgb-product-single__personas {
	list-style: none;
	padding: 0;
	margin: 0;
	display: flex;
	flex-direction: column;
	gap: var(--space-3);
}

.tgb-product-single__includes li,
.tgb-product-single__personas li {
	display: flex;
	align-items: flex-start;
	gap: var(--space-3);
	font-size: var(--scale-sm);
	color: var(--colour-text-secondary);
	line-height: 1.65;
}

.tgb-product-single__includes li::before {
	content: '';
	display: inline-block;
	flex-shrink: 0;
	width: 18px;
	height: 18px;
	margin-top: 2px;
	background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='18' height='18' viewBox='0 0 18 18' fill='none'%3E%3Ccircle cx='9' cy='9' r='8' stroke='%231151D3' stroke-width='1.5'/%3E%3Cpath d='M5.5 9L7.5 11L12.5 6.5' stroke='%231151D3' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");
	background-size: contain;
	background-repeat: no-repeat;
}

.tgb-product-single__personas li::before {
	content: '→';
	color: var(--colour-primary);
	font-size: var(--scale-sm);
	font-weight: 700;
	flex-shrink: 0;
	width: 1.2em;
	margin-top: 1px;
}

/* Sidebar */
@media (min-width: 900px) {
	.tgb-product-single__sidebar {
		position: sticky;
		top: calc(68px + var(--space-6));
	}
}

.tgb-product-single__purchase-box {
	background-color: var(--colour-surface);
	border: 1px solid var(--colour-border);
	border-radius: var(--radius-lg);
	padding: var(--space-6);
	box-shadow: var(--shadow);
	display: flex;
	flex-direction: column;
	gap: var(--space-4);
}

.tgb-product-single__price-wrap {
	padding-bottom: var(--space-4);
	border-bottom: 1px solid var(--colour-border);
}

.tgb-product-single__price {
	font-family: var(--font-heading);
	font-size: var(--scale-3xl);
	font-weight: 700;
	color: var(--colour-text-primary);
	letter-spacing: -0.04em;
	line-height: 1.1;
	margin-bottom: var(--space-1);
}

.tgb-product-single__price .amount {
	font-family: var(--font-heading);
	font-size: var(--scale-3xl);
	font-weight: 700;
	letter-spacing: -0.04em;
}

.tgb-product-single__price-note {
	font-size: var(--scale-xs);
	color: var(--colour-text-muted);
	margin: 0;
}

.tgb-btn--full {
	width: 100%;
	justify-content: center;
}

/* WC add-to-cart inside sidebar */
.tgb-product-single__purchase-box .cart {
	margin: 0;
}

.tgb-product-single__purchase-box .cart .single_add_to_cart_button {
	width: 100%;
	justify-content: center;
	padding-block: var(--space-4);
	font-size: var(--scale-base);
}

/* Pass strip in sidebar */
.tgb-product-single__pass-strip {
	border-top: 1px solid var(--colour-border);
	padding-top: var(--space-4);
	display: flex;
	flex-direction: column;
	gap: var(--space-2);
}

.tgb-product-single__pass-or {
	font-family: var(--font-heading);
	font-size: var(--scale-xs);
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.1em;
	color: var(--colour-text-muted);
	text-align: center;
	margin: 0;
}

.tgb-product-single__pass-note {
	font-family: var(--font-heading);
	font-size: var(--scale-sm);
	font-weight: 700;
	color: var(--colour-text-primary);
	margin: 0;
}

.tgb-product-single__pass-desc {
	font-size: var(--scale-xs);
	color: var(--colour-text-secondary);
	line-height: 1.55;
	margin: 0;
}

/* Purchase tabs — CSS-only (Buy / Operator Pass / Work With an Expert) */
.tgb-purchase-tabs {
	display: flex;
	flex-direction: column;
	gap: var(--space-4);
}

/* Radios drive the tabs; visually hidden but kept focusable for keyboard users. */
.tgb-purchase-tabs__radio {
	position: absolute;
	width: 1px;
	height: 1px;
	margin: -1px;
	padding: 0;
	overflow: hidden;
	clip: rect(0 0 0 0);
	white-space: nowrap;
	border: 0;
}

.tgb-purchase-tabs__nav {
	display: flex;
	gap: var(--space-1);
	border-bottom: 1px solid var(--colour-border);
}

.tgb-purchase-tabs__tab {
	flex: 1;
	text-align: center;
	cursor: pointer;
	padding: var(--space-2) var(--space-1);
	margin-bottom: -1px;
	font-family: var(--font-heading);
	font-size: var(--scale-xs);
	font-weight: 600;
	line-height: 1.2;
	color: var(--colour-text-muted);
	border-bottom: 2px solid transparent;
	transition: color .15s ease, border-color .15s ease;
}

.tgb-purchase-tabs__tab:hover {
	color: var(--colour-text-primary);
}

#tgb-ptab-buy:checked    ~ .tgb-purchase-tabs__nav label[for="tgb-ptab-buy"],
#tgb-ptab-pass:checked   ~ .tgb-purchase-tabs__nav label[for="tgb-ptab-pass"],
#tgb-ptab-expert:checked ~ .tgb-purchase-tabs__nav label[for="tgb-ptab-expert"] {
	color: var(--colour-text-primary);
	border-bottom-color: var(--colour-text-primary);
}

#tgb-ptab-buy:focus-visible    ~ .tgb-purchase-tabs__nav label[for="tgb-ptab-buy"],
#tgb-ptab-pass:focus-visible   ~ .tgb-purchase-tabs__nav label[for="tgb-ptab-pass"],
#tgb-ptab-expert:focus-visible ~ .tgb-purchase-tabs__nav label[for="tgb-ptab-expert"] {
	outline: 2px solid var(--colour-text-primary);
	outline-offset: 2px;
	border-radius: var(--radius-sm);
}

.tgb-purchase-tabs__panel {
	display: none;
	flex-direction: column;
	gap: var(--space-4);
}

#tgb-ptab-buy:checked    ~ .tgb-purchase-tabs__panels .tgb-purchase-tabs__panel--buy,
#tgb-ptab-pass:checked   ~ .tgb-purchase-tabs__panels .tgb-purchase-tabs__panel--pass,
#tgb-ptab-expert:checked ~ .tgb-purchase-tabs__panels .tgb-purchase-tabs__panel--expert {
	display: flex;
}

/* Expert Session panel + post-purchase confirmation */
.tgb-expert-session__eyebrow {
	font-family: var(--font-heading);
	font-size: var(--scale-xs);
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.08em;
	color: var(--colour-text-primary);
	margin: 0;
}

.tgb-expert-session__desc {
	font-size: var(--scale-xs);
	color: var(--colour-text-secondary);
	line-height: 1.55;
	margin: 0;
}

.tgb-expert-session__price {
	font-family: var(--font-heading);
	font-size: var(--scale-xl);
	font-weight: 700;
	letter-spacing: -0.02em;
	color: var(--colour-text-primary);
	margin: 0;
}

.tgb-expert-session__reqd {
	font-size: var(--scale-xs);
	color: var(--colour-text-secondary);
	line-height: 1.55;
	margin: 0;
	padding: var(--space-2) var(--space-3);
	border-left: 3px solid var(--colour-border);
	background: var(--colour-surface);
}

.tgb-expert-session__note {
	font-size: var(--scale-xs);
	color: var(--colour-text-muted);
	margin: 0;
}

/* Bottom-of-page Expert Session CTA band */
.tgb-expert-session-band {
	border-top: 1px solid var(--colour-border);
	background: var(--colour-surface);
	padding: var(--space-8) var(--space-6);
}

.tgb-expert-session-band__inner {
	max-width: 720px;
	margin: 0 auto;
	display: flex;
	flex-direction: column;
	gap: var(--space-3);
	align-items: flex-start;
}

.tgb-expert-session-band .tgb-expert-session__desc {
	font-size: var(--scale-sm);
}

.tgb-expert-session-band .tgb-expert-session__price {
	font-size: var(--scale-2xl);
}

.tgb-expert-session-confirm {
	border: 1px solid var(--colour-border);
	border-radius: var(--radius-lg);
	padding: var(--space-6);
	margin-bottom: var(--space-6);
}

.tgb-expert-session-confirm__title {
	font-family: var(--font-heading);
	font-size: var(--scale-lg);
	margin: 0 0 var(--space-2);
}

.tgb-expert-session-confirm__body {
	margin: 0;
	line-height: 1.6;
	color: var(--colour-text-secondary);
}

/* Trust signals */
.tgb-product-single__trust {
	list-style: none;
	padding: 0;
	margin: 0;
	display: flex;
	flex-direction: column;
	gap: var(--space-2);
	border-top: 1px solid var(--colour-border);
	padding-top: var(--space-4);
}

.tgb-product-single__trust li {
	display: flex;
	align-items: center;
	gap: var(--space-2);
	font-size: var(--scale-xs);
	color: var(--colour-text-muted);
}

.tgb-product-single__trust li svg {
	color: #10B981;
	flex-shrink: 0;
}

/* Meta tags (vertical / format) */
.tgb-product-single__meta-tags {
	border-top: 1px solid var(--colour-border);
	padding-top: var(--space-4);
	display: flex;
	flex-direction: column;
	gap: var(--space-2);
}

.tgb-product-single__meta-row {
	display: flex;
	align-items: center;
	justify-content: space-between;
	font-size: var(--scale-xs);
	gap: var(--space-3);
}

.tgb-product-single__meta-label {
	color: var(--colour-text-muted);
	font-family: var(--font-heading);
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: 0.07em;
}

.tgb-product-single__meta-value {
	color: var(--colour-text-secondary);
	font-weight: 500;
	text-decoration: none;
}

a.tgb-product-single__meta-value:hover {
	color: var(--colour-primary);
}

/* Mobile: stack sidebar above main on small screens — override order */
@media (max-width: 899px) {
	.tgb-product-single__sidebar {
		order: -1;
	}
}

/* ==========================================================================
   11. Operator Pass page
   ========================================================================== */

/* ── Shared section utilities ─────────────────────────────────────────────── */

.tgb-pass-section-header {
	text-align: center;
	margin-bottom: var(--space-10);
}

.tgb-pass-section-title {
	font-family: var(--font-heading);
	font-weight: 700;
	font-size: clamp(1.5rem, 2.5vw, 2.25rem);
	color: var(--colour-text-primary);
	letter-spacing: -0.025em;
	margin-bottom: var(--space-4);
}

.tgb-pass-section-sub {
	font-size: var(--scale-md);
	color: var(--colour-text-secondary);
	line-height: 1.65;
	max-width: 640px;
	margin-inline: auto;
	margin-bottom: 0;
}

/* Dark-background overrides */
.tgb-pass-hero .tgb-pass-section-title,
.tgb-pass-stats .tgb-pass-section-title,
.tgb-pass-pricing .tgb-pass-section-title,
.tgb-pass-final-cta .tgb-pass-section-title {
	color: var(--colour-text-inverse);
}

.tgb-pass-hero .tgb-pass-section-sub,
.tgb-pass-stats .tgb-pass-section-sub,
.tgb-pass-pricing .tgb-pass-section-sub,
.tgb-pass-final-cta .tgb-pass-section-sub {
	color: rgba(255, 255, 255, 0.65);
}

/* XL button size */
.tgb-btn--xl {
	padding: 14px 32px;
	font-size: var(--scale-base);
	font-weight: 700;
}

/* Outline-inverse button (white on dark bg) */
.tgb-btn--outline-inverse {
	background: transparent;
	color: #ffffff;
	border: 2px solid rgba(255, 255, 255, 0.55);
	transition: background var(--transition), color var(--transition), border-color var(--transition);
}

.tgb-btn--outline-inverse:hover,
.tgb-btn--outline-inverse:focus-visible {
	background: #ffffff;
	color: var(--colour-navy);
	border-color: #ffffff;
}

/* ── 1. Hero ──────────────────────────────────────────────────────────────── */

.tgb-pass-hero {
	background-color: var(--colour-navy);
	padding-block: 96px 80px;
	overflow: hidden;
	position: relative;
}

/* Diagonal stripe texture */
.tgb-pass-hero::before {
	content: '';
	position: absolute;
	inset: 0;
	background-image: repeating-linear-gradient(
		-45deg,
		rgba(255, 255, 255, 0.025) 0px,
		rgba(255, 255, 255, 0.025) 1px,
		transparent 1px,
		transparent 24px
	);
	pointer-events: none;
}

.tgb-pass-hero__layout {
	display: grid;
	grid-template-columns: 1fr;
	gap: var(--space-12);
	position: relative;
	z-index: 1;
}

@media (min-width: 960px) {
	.tgb-pass-hero__layout {
		grid-template-columns: 1fr 380px;
		align-items: center;
	}
}

.tgb-pass-hero__eyebrow {
	font-family: var(--font-heading);
	font-weight: 700;
	font-size: var(--scale-xs);
	color: var(--colour-gold-mid);
	text-transform: uppercase;
	letter-spacing: 0.15em;
	margin-bottom: var(--space-4);
}

.tgb-pass-hero__title {
	font-family: var(--font-editorial);
	font-size: clamp(2rem, 4vw, 3.25rem);
	color: #ffffff;
	line-height: 1.1;
	letter-spacing: -0.02em;
	margin-bottom: var(--space-5);
}

.tgb-pass-hero__subtitle {
	font-family: var(--font-body);
	font-size: var(--scale-md);
	color: rgba(255, 255, 255, 0.72);
	line-height: 1.65;
	max-width: 560px;
	margin-bottom: var(--space-8);
}

.tgb-pass-hero__price-wrap {
	margin-bottom: var(--space-6);
}

.tgb-pass-hero__price {
	font-family: var(--font-heading);
	font-size: clamp(2.5rem, 5vw, 4rem);
	font-weight: 700;
	color: #ffffff;
	letter-spacing: -0.04em;
	line-height: 1;
}

/* WooCommerce price amount inherits hero colour */
.tgb-pass-hero__price .woocommerce-Price-amount,
.tgb-pass-hero__price .woocommerce-Price-currencySymbol {
	color: inherit;
	font-family: inherit;
	font-size: inherit;
	font-weight: inherit;
}

.tgb-pass-hero__price-period {
	font-family: var(--font-body);
	font-size: var(--scale-sm);
	color: rgba(255, 255, 255, 0.55);
	display: block;
	margin-top: 4px;
}

.tgb-pass-hero__cta-group {
	display: flex;
	gap: var(--space-4);
	flex-wrap: wrap;
	align-items: center;
	margin-bottom: var(--space-6);
}

.tgb-pass-hero__cta-group form {
	margin: 0;
}

.tgb-pass-hero__trust {
	display: flex;
	gap: var(--space-4);
	flex-wrap: wrap;
	font-size: var(--scale-xs);
	color: rgba(255, 255, 255, 0.45);
	margin: 0;
	padding: 0;
	list-style: none;
}

/* Hero visual — decorative card stack */
.tgb-pass-hero__visual {
	display: none;
}

@media (min-width: 960px) {
	.tgb-pass-hero__visual {
		display: flex;
		flex-direction: column;
		align-items: flex-end;
		justify-content: center;
		position: relative;
		min-height: 360px;
	}
}

.tgb-pass-hero__cards {
	position: relative;
	width: 260px;
	height: 340px;
}

.tgb-pass-hero__card {
	background: #ffffff;
	border-radius: var(--radius-lg);
	padding: var(--space-5);
	width: 240px;
	box-shadow: 0 8px 32px rgba(0, 0, 0, 0.25);
	border-left: 4px solid var(--card-accent, var(--colour-primary));
	position: absolute;
}

.tgb-pass-hero__card--1 {
	top: 0;
	left: 0;
	z-index: 3;
	transform: rotate(-1.5deg);
}

.tgb-pass-hero__card--2 {
	top: 80px;
	left: 20px;
	z-index: 2;
	transform: rotate(1deg);
}

.tgb-pass-hero__card--3 {
	top: 165px;
	left: 8px;
	z-index: 1;
	transform: rotate(-0.5deg);
}

.tgb-pass-hero__card-format {
	display: block;
	font-family: var(--font-heading);
	font-size: var(--scale-xs);
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.1em;
	color: var(--colour-text-muted);
	margin-bottom: var(--space-2);
}

.tgb-pass-hero__card-title {
	font-family: var(--font-editorial);
	font-size: 1rem;
	color: var(--colour-text-primary);
	line-height: 1.3;
	margin: 0 0 var(--space-3);
}

.tgb-pass-hero__card-badge {
	display: inline-block;
	font-family: var(--font-heading);
	font-size: var(--scale-xs);
	font-weight: 700;
	padding: 2px 8px;
	border-radius: var(--radius-full);
}

/* ── 2. Stats bar ─────────────────────────────────────────────────────────── */

.tgb-pass-stats {
	background: var(--colour-navy-mid);
	padding-block: var(--space-8);
}

.tgb-pass-stats__grid {
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: var(--space-8);
}

@media (min-width: 640px) {
	.tgb-pass-stats__grid {
		grid-template-columns: repeat(4, 1fr);
	}
}

.tgb-pass-stats__item {
	text-align: center;
}

.tgb-pass-stats__number {
	font-family: var(--font-editorial);
	font-size: 2.5rem;
	color: var(--colour-gold-mid);
	line-height: 1;
}

.tgb-pass-stats__label {
	font-family: var(--font-heading);
	font-size: var(--scale-xs);
	color: rgba(255, 255, 255, 0.55);
	text-transform: uppercase;
	letter-spacing: 0.1em;
	margin-top: var(--space-2);
}

/* ── 3. What's included ───────────────────────────────────────────────────── */

.tgb-pass-includes {
	padding-block: var(--space-20);
	background: var(--colour-surface);
}

.tgb-pass-verticals-grid {
	margin-top: 0;
}

.tgb-pass-vertical-card {
	background: var(--colour-surface);
	border: 1px solid var(--colour-border);
	border-top: 4px solid var(--card-colour, var(--colour-primary));
	border-radius: var(--radius-lg);
	padding: var(--space-6);
	transition: box-shadow var(--transition);
}

.tgb-pass-vertical-card:hover {
	box-shadow: var(--shadow);
}

.tgb-pass-vertical-card__name {
	font-family: var(--font-heading);
	font-weight: 700;
	font-size: var(--scale-base);
	color: var(--colour-text-primary);
	margin-bottom: var(--space-2);
}

.tgb-pass-vertical-card__count {
	font-family: var(--font-heading);
	font-size: var(--scale-xs);
	font-weight: 700;
	color: var(--colour-gold);
	margin-bottom: var(--space-3);
}

.tgb-pass-vertical-card__desc {
	font-size: var(--scale-sm);
	color: var(--colour-text-secondary);
	line-height: 1.6;
	margin: 0;
}

/* ── 4. Case for the pass ─────────────────────────────────────────────────── */

.tgb-pass-value--why {
	padding-block: var(--space-20);
	background: var(--colour-surface-raised);
}

.tgb-pass-reason {
	padding: var(--space-6);
	background: var(--colour-surface);
	border-radius: var(--radius-lg);
	border: 1px solid var(--colour-border);
}

.tgb-pass-reason__icon {
	width: 40px;
	height: 40px;
	border-radius: 50%;
	background: var(--colour-primary-light);
	color: var(--colour-primary);
	display: flex;
	align-items: center;
	justify-content: center;
	margin-bottom: var(--space-4);
	flex-shrink: 0;
}

.tgb-pass-reason__title {
	font-family: var(--font-heading);
	font-weight: 700;
	font-size: var(--scale-lg);
	color: var(--colour-text-primary);
	letter-spacing: -0.02em;
	margin-bottom: var(--space-3);
}

.tgb-pass-reason__body {
	font-size: var(--scale-sm);
	color: var(--colour-text-secondary);
	line-height: 1.65;
	margin: 0;
}

/* ── 5. Pricing / value comparison ───────────────────────────────────────── */

.tgb-pass-pricing {
	padding-block: var(--space-20);
	background: var(--colour-navy);
	position: relative;
}

.tgb-pass-pricing::before {
	content: '';
	position: absolute;
	inset: 0;
	background-image: repeating-linear-gradient(
		-45deg,
		rgba(255, 255, 255, 0.02) 0px,
		rgba(255, 255, 255, 0.02) 1px,
		transparent 1px,
		transparent 24px
	);
	pointer-events: none;
}

.tgb-pass-pricing__layout {
	display: grid;
	grid-template-columns: 1fr;
	gap: var(--space-12);
	position: relative;
	z-index: 1;
}

@media (min-width: 768px) {
	.tgb-pass-pricing__layout {
		grid-template-columns: 1fr 1fr;
		gap: var(--space-16);
		align-items: center;
	}
}

.tgb-pass-pricing__title {
	font-family: var(--font-editorial);
	font-size: clamp(1.75rem, 3vw, 2.75rem);
	color: #ffffff;
	letter-spacing: -0.02em;
	margin-bottom: var(--space-5);
}

.tgb-pass-pricing__body {
	font-size: var(--scale-md);
	color: rgba(255, 255, 255, 0.70);
	line-height: 1.7;
	margin: 0;
}

.tgb-pass-compare {
	display: flex;
	flex-direction: column;
	gap: var(--space-4);
	justify-content: center;
}

.tgb-pass-compare__vs {
	text-align: center;
	font-family: var(--font-heading);
	font-size: var(--scale-sm);
	font-weight: 700;
	color: rgba(255, 255, 255, 0.35);
	text-transform: uppercase;
	letter-spacing: 0.1em;
}

.tgb-pass-compare__item {
	padding: var(--space-5) var(--space-6);
	border-radius: var(--radius-lg);
	background: rgba(255, 255, 255, 0.07);
	border: 1px solid rgba(255, 255, 255, 0.12);
}

.tgb-pass-compare__item--featured {
	background: rgba(184, 146, 42, 0.15);
	border-color: var(--colour-gold-mid);
}

.tgb-pass-compare__label {
	font-family: var(--font-heading);
	font-size: var(--scale-xs);
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.1em;
	color: rgba(255, 255, 255, 0.50);
	margin-bottom: var(--space-2);
}

.tgb-pass-compare__item--featured .tgb-pass-compare__label {
	color: var(--colour-gold-mid);
}

.tgb-pass-compare__price {
	font-family: var(--font-editorial);
	font-size: 2rem;
	color: #ffffff;
	letter-spacing: -0.03em;
	line-height: 1.1;
}

.tgb-pass-compare__sub {
	font-size: var(--scale-xs);
	color: rgba(255, 255, 255, 0.55);
	margin-top: var(--space-1);
}

/* ── 6. Personas ──────────────────────────────────────────────────────────── */

.tgb-pass-personas {
	padding-block: var(--space-20);
	background: var(--colour-surface);
}

.tgb-pass-persona-grid {
	display: grid;
	grid-template-columns: 1fr;
	gap: var(--space-4);
}

@media (min-width: 480px) {
	.tgb-pass-persona-grid {
		grid-template-columns: repeat(2, 1fr);
	}
}

@media (min-width: 960px) {
	.tgb-pass-persona-grid {
		grid-template-columns: repeat(3, 1fr);
	}
}

.tgb-pass-persona {
	padding: var(--space-5);
	background: var(--colour-surface-raised);
	border-radius: var(--radius-lg);
	border: 1px solid var(--colour-border);
}

.tgb-pass-persona__role {
	font-family: var(--font-heading);
	font-weight: 700;
	font-size: var(--scale-sm);
	color: var(--colour-text-primary);
	margin-bottom: var(--space-2);
}

.tgb-pass-persona__desc {
	font-size: var(--scale-sm);
	color: var(--colour-text-secondary);
	line-height: 1.55;
	margin: 0;
}

/* ── 7. Formats grid ──────────────────────────────────────────────────────── */

.tgb-pass-formats {
	padding-block: var(--space-20);
	background: var(--colour-surface-raised);
}

.tgb-pass-format-grid {
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: var(--space-4);
}

@media (min-width: 768px) {
	.tgb-pass-format-grid {
		grid-template-columns: repeat(4, 1fr);
	}
}

.tgb-pass-format {
	padding: var(--space-5);
	background: var(--colour-surface);
	border-radius: var(--radius-lg);
	border: 1px solid var(--colour-border);
}

.tgb-pass-format__name {
	font-family: var(--font-heading);
	font-weight: 700;
	font-size: var(--scale-sm);
	color: var(--colour-text-primary);
	margin-bottom: var(--space-2);
}

.tgb-pass-format__desc {
	font-size: var(--scale-xs);
	color: var(--colour-text-muted);
	line-height: 1.55;
	margin: 0;
}

/* ── 8. FAQ ───────────────────────────────────────────────────────────────── */

.tgb-pass-faq {
	padding-block: var(--space-20);
	background: var(--colour-surface);
}

.tgb-pass-faq .tgb-pass-section-header {
	text-align: left;
}

.tgb-pass-faq .tgb-pass-section-title {
	margin-bottom: var(--space-8);
}

.tgb-pass-faq__items {
	max-width: 720px;
}

.tgb-pass-faq details {
	border-bottom: 1px solid var(--colour-border);
	padding-block: var(--space-5);
}

.tgb-pass-faq details:first-of-type {
	border-top: 1px solid var(--colour-border);
}

.tgb-pass-faq summary {
	font-family: var(--font-heading);
	font-weight: 700;
	font-size: var(--scale-base);
	color: var(--colour-text-primary);
	cursor: pointer;
	list-style: none;
	display: flex;
	justify-content: space-between;
	align-items: center;
	gap: var(--space-4);
}

.tgb-pass-faq summary::-webkit-details-marker {
	display: none;
}

.tgb-pass-faq summary::after {
	content: '+';
	font-size: 1.25rem;
	font-weight: 400;
	color: var(--colour-text-muted);
	flex-shrink: 0;
	transition: transform var(--transition), color var(--transition);
}

.tgb-pass-faq details[open] summary {
	color: var(--colour-primary);
}

.tgb-pass-faq details[open] summary::after {
	content: '−';
	color: var(--colour-primary);
}

.tgb-pass-faq details p {
	font-size: var(--scale-sm);
	color: var(--colour-text-secondary);
	line-height: 1.7;
	margin-top: var(--space-4);
	margin-bottom: 0;
}

.tgb-pass-faq details p a {
	color: var(--colour-primary);
	text-decoration: underline;
}

/* ── 9. Final CTA ─────────────────────────────────────────────────────────── */

.tgb-pass-final-cta {
	padding-block: var(--space-20);
	background: var(--colour-navy);
	text-align: center;
	position: relative;
	overflow: hidden;
}

.tgb-pass-final-cta::before {
	content: '';
	position: absolute;
	inset: 0;
	background-image: repeating-linear-gradient(
		-45deg,
		rgba(255, 255, 255, 0.025) 0px,
		rgba(255, 255, 255, 0.025) 1px,
		transparent 1px,
		transparent 24px
	);
	pointer-events: none;
}

.tgb-pass-final-cta > .tgb-container {
	position: relative;
	z-index: 1;
}

.tgb-pass-final-cta__title {
	font-family: var(--font-editorial);
	font-size: clamp(1.75rem, 3vw, 2.75rem);
	color: #ffffff;
	letter-spacing: -0.02em;
	margin-bottom: var(--space-4);
}

.tgb-pass-final-cta__sub {
	font-size: var(--scale-md);
	color: rgba(255, 255, 255, 0.65);
	margin-bottom: var(--space-8);
}

.tgb-pass-final-cta__button {
	display: flex;
	justify-content: center;
}

.tgb-pass-final-cta__button form {
	margin: 0;
}

.tgb-pass-final-cta__trust {
	display: flex;
	justify-content: center;
	gap: var(--space-4);
	flex-wrap: wrap;
	font-size: var(--scale-xs);
	color: rgba(255, 255, 255, 0.40);
	margin-top: var(--space-6);
	margin-bottom: 0;
	padding: 0;
	list-style: none;
}
