/* =============================================================================
   TGB Theme — Main Stylesheet v1.1.0
   The Gaming Boardroom — Operator Intelligence Platform
   =============================================================================

   Contents
   01. Design Tokens
   02. Reset & Base
   03. Typography
   04. Layout & Grid
   05. Buttons
   06. Focus & Accessibility
   07. Cards (base)
   08. Vertical Colour Bands
   09. Site Header & Navigation
   10. Search Bar
   11. Homepage — Hero & Journey Grid
   12. Homepage — Urgent Situations
   13. Section Headings
   14. Article (single.php)
   15. Vertical Hub
   16. Product Cards
   17. Pass CTA Block
   18. Content-to-Product Aside
   19. Paywall
   20. Elite Cards
   21. Pass Badge
   22. Site Footer
   23. Pagination
   24. 404 & Archive fallbacks
   25. Animations & Utilities
   ============================================================================= */

/* -----------------------------------------------------------------------------
   01. Design Tokens
   ----------------------------------------------------------------------------- */

:root {
	/* ── Brand colours ── */
	--colour-primary:        #1151D3;
	--colour-primary-dark:   #0D3EA6;
	--colour-primary-light:  #EEF3FD;

	/* ── Navy scale ── */
	--colour-navy:           #0D2554;
	--colour-navy-mid:       #1A3570;
	--colour-navy-light:     #243D80;
	--colour-navy-pale:      #E8EDF8;

	/* ── Gold — premium/elite accent ── */
	--colour-gold:           #B8922A;
	--colour-gold-mid:       #C9A84C;
	--colour-gold-light:     #FDF3D0;
	--colour-gold-text:      #7A5F18;

	/* ── Text ── */
	--colour-text-primary:   #0F1923;
	--colour-text-secondary: #5A6A7E;
	--colour-text-muted:     #8898A8;
	--colour-text-inverse:   #FFFFFF;

	/* ── Surfaces ── */
	--colour-background:     #F4F6FA;
	--colour-surface:        #FFFFFF;
	--colour-surface-raised: #FAFBFD;
	--colour-border:         #DDE3EC;
	--colour-border-strong:  #B8C4D4;

	/* ── Vertical accent colours ── */
	--colour-vertical-licensing: #DC2626;
	--colour-vertical-rg:        #EA580C;
	--colour-vertical-cyber:     #0891B2;
	--colour-vertical-ops:       #0D9488;
	--colour-vertical-hr:        #7C3AED;
	--colour-vertical-market:    #D97706;

	/* ── Typography ── */
	--font-editorial: 'DM Serif Display', Georgia, 'Times New Roman', serif;
	--font-heading:   'Montserrat', system-ui, sans-serif;
	--font-body:      'Work Sans', system-ui, sans-serif;

	/* ── Type scale ── */
	--scale-xs:   0.6875rem;   /* 11px */
	--scale-sm:   0.8125rem;   /* 13px */
	--scale-base: 1rem;         /* 16px */
	--scale-md:   1.0625rem;   /* 17px */
	--scale-lg:   1.1875rem;   /* 19px */
	--scale-xl:   1.375rem;    /* 22px */
	--scale-2xl:  1.625rem;    /* 26px */
	--scale-3xl:  2rem;         /* 32px */
	--scale-4xl:  2.5rem;      /* 40px */
	--scale-5xl:  3.25rem;     /* 52px */
	--scale-6xl:  4rem;         /* 64px */

	/* ── Spacing ── */
	--space-1:  0.25rem;
	--space-2:  0.5rem;
	--space-3:  0.75rem;
	--space-4:  1rem;
	--space-5:  1.25rem;
	--space-6:  1.5rem;
	--space-8:  2rem;
	--space-10: 2.5rem;
	--space-12: 3rem;
	--space-16: 4rem;
	--space-20: 5rem;
	--space-24: 6rem;
	--space-32: 8rem;

	/* ── Radius ── */
	--radius-sm:  4px;
	--radius:     8px;
	--radius-lg:  12px;
	--radius-xl:  16px;
	--radius-2xl: 24px;

	/* ── Shadows ── */
	--shadow-sm:   0 1px 2px rgb(0 0 0 / 0.05);
	--shadow:      0 1px 4px rgb(0 0 0 / 0.07), 0 0 0 1px rgb(0 0 0 / 0.03);
	--shadow-md:   0 4px 12px rgb(0 0 0 / 0.09), 0 1px 3px rgb(0 0 0 / 0.05);
	--shadow-lg:   0 12px 28px rgb(0 0 0 / 0.12), 0 4px 8px rgb(0 0 0 / 0.06);
	--shadow-xl:   0 24px 48px rgb(0 0 0 / 0.14), 0 8px 16px rgb(0 0 0 / 0.07);
	--shadow-navy: 0 8px 24px rgb(13 37 84 / 0.35);
	--shadow-gold: 0 4px 16px rgb(184 146 42 / 0.3);

	/* ── Layout ── */
	--container-max:    1260px;
	--container-narrow: 720px;
	--container-wide:   1440px;

	/* ── Motion ── */
	--transition:      180ms cubic-bezier(0.4, 0, 0.2, 1);
	--transition-slow: 320ms cubic-bezier(0.4, 0, 0.2, 1);
	--ease-out:        cubic-bezier(0.0, 0.0, 0.2, 1);
	--ease-spring:     cubic-bezier(0.34, 1.56, 0.64, 1);
}

/* -----------------------------------------------------------------------------
   02. Reset & Base
   ----------------------------------------------------------------------------- */

*,
*::before,
*::after {
	box-sizing: border-box;
	margin: 0;
	padding: 0;
}

html {
	font-size: 16px;
	-webkit-text-size-adjust: 100%;
	scroll-behavior: smooth;
}

body {
	font-family: var(--font-body);
	font-size: var(--scale-base);
	line-height: 1.65;
	color: var(--colour-text-primary);
	background-color: var(--colour-background);
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
}

img,
video {
	max-width: 100%;
	height: auto;
	display: block;
}

a {
	color: var(--colour-primary);
	text-decoration: none;
	transition: color var(--transition);
}

a:hover {
	color: var(--colour-primary-dark);
}

ul,
ol {
	list-style: none;
}

button,
input,
select,
textarea {
	font: inherit;
}

/* -----------------------------------------------------------------------------
   03. Typography
   ----------------------------------------------------------------------------- */

h1, h2, h3, h4, h5, h6 {
	font-family: var(--font-heading);
	font-weight: 700;
	line-height: 1.2;
	color: var(--colour-text-primary);
	letter-spacing: -0.02em;
}

h1 { font-size: var(--scale-4xl); }
h2 { font-size: var(--scale-3xl); }
h3 { font-size: var(--scale-2xl); }
h4 { font-size: var(--scale-xl); }
h5 { font-size: var(--scale-lg); }
h6 { font-size: var(--scale-base); }

@media (max-width: 767px) {
	h1 { font-size: var(--scale-3xl); }
	h2 { font-size: var(--scale-2xl); }
	h3 { font-size: var(--scale-xl); }
}

p {
	margin-bottom: var(--space-4);
}

p:last-child {
	margin-bottom: 0;
}

/* Article body — editorial long-form reading experience */
.entry-content {
	font-size: var(--scale-md);
	line-height: 1.75;
	color: var(--colour-text-primary);
}

.entry-content h2,
.entry-content h3,
.entry-content h4 {
	margin-top: var(--space-12);
	margin-bottom: var(--space-4);
	letter-spacing: -0.025em;
}

.entry-content h2 { font-size: var(--scale-2xl); }
.entry-content h3 { font-size: var(--scale-xl); }
.entry-content h4 { font-size: var(--scale-lg); }

.entry-content p,
.entry-content li {
	color: var(--colour-text-primary);
	line-height: 1.8;
}

.entry-content ul,
.entry-content ol {
	list-style: revert;
	padding-left: var(--space-6);
	margin-bottom: var(--space-6);
}

.entry-content li {
	margin-bottom: var(--space-2);
}

.entry-content blockquote {
	border-left: 3px solid var(--colour-primary);
	padding: var(--space-4) var(--space-6);
	margin: var(--space-8) 0;
	background-color: var(--colour-primary-light);
	border-radius: 0 var(--radius) var(--radius) 0;
	font-style: italic;
	color: var(--colour-text-secondary);
}

.entry-content a {
	color: var(--colour-primary);
	text-decoration: underline;
	text-underline-offset: 3px;
}

.entry-content a:hover {
	color: var(--colour-primary-dark);
}

/* -----------------------------------------------------------------------------
   04. Layout & Grid
   ----------------------------------------------------------------------------- */

.tgb-container {
	max-width: var(--container-max);
	margin-inline: auto;
	padding-inline: var(--space-4);
}

@media (min-width: 640px) {
	.tgb-container {
		padding-inline: var(--space-6);
	}
}

@media (min-width: 768px) {
	.tgb-container {
		padding-inline: var(--space-8);
	}
}

@media (min-width: 1280px) {
	.tgb-container {
		padding-inline: var(--space-12);
	}
}

.tgb-container--narrow {
	max-width: var(--container-narrow);
	margin-inline: auto;
}

.tgb-grid {
	display: grid;
	gap: var(--space-6);
}

.tgb-grid--2 { grid-template-columns: repeat(2, 1fr); }
.tgb-grid--3 { grid-template-columns: repeat(3, 1fr); }
.tgb-grid--4 { grid-template-columns: repeat(4, 1fr); }

@media (max-width: 1023px) {
	.tgb-grid--4 { grid-template-columns: repeat(2, 1fr); }
	.tgb-grid--3 { grid-template-columns: repeat(2, 1fr); }
}

@media (max-width: 639px) {
	.tgb-grid--2,
	.tgb-grid--3,
	.tgb-grid--4 {
		grid-template-columns: 1fr;
	}
}

.tgb-section {
	padding-block: var(--space-16);
}

@media (max-width: 767px) {
	.tgb-section {
		padding-block: var(--space-12);
	}
}

.tgb-section--sm {
	padding-block: var(--space-10);
}

.tgb-section--lg {
	padding-block: var(--space-24);
}

.tgb-section--bg-light {
	background-color: var(--colour-surface);
}

.tgb-section--bg-pale {
	background-color: var(--colour-navy-pale);
}

.tgb-main {
	min-height: 60vh;
}

/* -----------------------------------------------------------------------------
   05. Buttons
   ----------------------------------------------------------------------------- */

.tgb-btn {
	display: inline-flex;
	align-items: center;
	gap: var(--space-2);
	padding: var(--space-3) var(--space-6);
	border-radius: var(--radius);
	font-family: var(--font-heading);
	font-size: var(--scale-sm);
	font-weight: 600;
	letter-spacing: 0.02em;
	text-decoration: none;
	cursor: pointer;
	border: 2px solid transparent;
	transition: background-color var(--transition), color var(--transition),
	            border-color var(--transition), box-shadow var(--transition),
	            transform var(--transition);
	white-space: nowrap;
	line-height: 1.4;
	position: relative;
}

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

.tgb-btn:active {
	transform: translateY(1px);
}

.tgb-btn--primary {
	background-color: var(--colour-primary);
	color: var(--colour-text-inverse);
	border-color: var(--colour-primary);
	box-shadow: 0 2px 8px rgb(17 81 211 / 0.3);
}

.tgb-btn--primary:hover {
	background-color: var(--colour-primary-dark);
	border-color: var(--colour-primary-dark);
	color: var(--colour-text-inverse);
	box-shadow: 0 4px 16px rgb(17 81 211 / 0.4);
}

.tgb-btn--navy {
	background-color: var(--colour-navy);
	color: var(--colour-text-inverse);
	border-color: var(--colour-navy);
}

.tgb-btn--navy:hover {
	background-color: var(--colour-navy-mid);
	border-color: var(--colour-navy-mid);
	color: var(--colour-text-inverse);
}

.tgb-btn--gold {
	background-color: var(--colour-gold);
	color: var(--colour-text-inverse);
	border-color: var(--colour-gold);
	box-shadow: var(--shadow-gold);
}

.tgb-btn--gold:hover {
	background-color: #9C7A1E;
	border-color: #9C7A1E;
	color: var(--colour-text-inverse);
}

.tgb-btn--ghost {
	background-color: transparent;
	color: var(--colour-primary);
	border-color: var(--colour-primary);
}

.tgb-btn--ghost:hover {
	background-color: var(--colour-primary-light);
	color: var(--colour-primary-dark);
}

.tgb-btn--ghost-inverse {
	background-color: transparent;
	color: var(--colour-text-inverse);
	border-color: rgba(255 255 255 / 0.5);
}

.tgb-btn--ghost-inverse:hover {
	background-color: rgba(255 255 255 / 0.12);
	border-color: var(--colour-text-inverse);
	color: var(--colour-text-inverse);
}

.tgb-btn--lg {
	padding: var(--space-4) var(--space-10);
	font-size: var(--scale-base);
	border-radius: var(--radius-lg);
}

.tgb-btn--sm {
	padding: var(--space-2) var(--space-4);
	font-size: var(--scale-xs);
	letter-spacing: 0.03em;
}

/* -----------------------------------------------------------------------------
   06. Focus & Accessibility
   ----------------------------------------------------------------------------- */

/* Keyboard focus — show only for non-pointer users */
:focus:not(:focus-visible) {
	outline: none;
}

:focus-visible {
	outline: 3px solid var(--colour-primary);
	outline-offset: 3px;
	border-radius: var(--radius-sm);
}

a:focus-visible,
button:focus-visible {
	outline: 3px solid var(--colour-primary);
	outline-offset: 3px;
}

/* Skip link */
.sr-only {
	position: absolute;
	width: 1px;
	height: 1px;
	padding: 0;
	margin: -1px;
	overflow: hidden;
	clip: rect(0, 0, 0, 0);
	white-space: nowrap;
	border-width: 0;
}

.sr-only:focus-visible {
	position: fixed;
	top: var(--space-4);
	left: var(--space-4);
	width: auto;
	height: auto;
	padding: var(--space-3) var(--space-6);
	margin: 0;
	clip: auto;
	white-space: normal;
	background-color: var(--colour-navy);
	color: var(--colour-text-inverse);
	border-radius: var(--radius);
	z-index: 9999;
	font-family: var(--font-heading);
	font-weight: 600;
	font-size: var(--scale-sm);
}

/* Reduced motion */
@media (prefers-reduced-motion: reduce) {
	*,
	*::before,
	*::after {
		animation-duration: 0.01ms !important;
		animation-iteration-count: 1 !important;
		transition-duration: 0.01ms !important;
	}
	html {
		scroll-behavior: auto;
	}
}

/* -----------------------------------------------------------------------------
   07. Cards (base)
   ----------------------------------------------------------------------------- */

.tgb-card {
	background: var(--colour-surface);
	border-radius: var(--radius-lg);
	box-shadow: var(--shadow);
	border: 1px solid var(--colour-border);
	overflow: hidden;
	transition: box-shadow var(--transition-slow), transform var(--transition-slow),
	            border-color var(--transition);
	display: flex;
	flex-direction: column;
}

.tgb-card:hover {
	box-shadow: var(--shadow-lg);
	transform: translateY(-3px);
	border-color: var(--colour-border-strong);
}

.tgb-card__body {
	padding: var(--space-6);
	display: flex;
	flex-direction: column;
	flex: 1;
}

.tgb-card__meta {
	display: flex;
	align-items: center;
	flex-wrap: wrap;
	gap: var(--space-2);
	margin-bottom: var(--space-3);
}

.tgb-card__vertical-tag {
	display: inline-flex;
	align-items: center;
	padding: 2px var(--space-3);
	border-radius: 100px;
	font-size: var(--scale-xs);
	font-weight: 700;
	letter-spacing: 0.04em;
	text-transform: uppercase;
	color: #fff;
	line-height: 1.8;
}

.tgb-card__title {
	font-family: var(--font-heading);
	font-size: var(--scale-lg);
	font-weight: 700;
	margin-bottom: var(--space-3);
	line-height: 1.3;
	letter-spacing: -0.02em;
}

.tgb-card__title a {
	color: var(--colour-text-primary);
	text-decoration: none;
	transition: color var(--transition);
}

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

.tgb-card__excerpt {
	font-size: var(--scale-sm);
	color: var(--colour-text-secondary);
	line-height: 1.6;
	margin-bottom: var(--space-4);
	flex-grow: 1;
	display: -webkit-box;
	-webkit-line-clamp: 3;
	-webkit-box-orient: vertical;
	overflow: hidden;
}

.tgb-card__footer {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: var(--space-3);
	margin-top: auto;
	padding-top: var(--space-4);
	border-top: 1px solid var(--colour-border);
}

.tgb-card__date {
	font-size: var(--scale-xs);
	color: var(--colour-text-muted);
	font-weight: 500;
	letter-spacing: 0.02em;
}

.tgb-card__read-link {
	font-size: var(--scale-xs);
	font-weight: 600;
	font-family: var(--font-heading);
	color: var(--colour-primary);
	letter-spacing: 0.02em;
	transition: color var(--transition);
	white-space: nowrap;
}

.tgb-card__read-link:hover {
	color: var(--colour-primary-dark);
}

/* Post card thumbnail */
.tgb-post-card__thumb {
	overflow: hidden;
	aspect-ratio: 16 / 9;
}

.tgb-post-card__thumb img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	transition: transform 400ms var(--ease-out);
}

.tgb-post-card:hover .tgb-post-card__thumb img {
	transform: scale(1.04);
}

/* -----------------------------------------------------------------------------
   08. Vertical Colour Bands
   ----------------------------------------------------------------------------- */

.tgb-vertical-band {
	display: block;
	height: 3px;
	width: 100%;
	flex-shrink: 0;
}

.tgb-vertical-band--licensing-regulation { background-color: var(--colour-vertical-licensing); }
.tgb-vertical-band--responsible-gambling  { background-color: var(--colour-vertical-rg); }
.tgb-vertical-band--cybersecurity-tech    { background-color: var(--colour-vertical-cyber); }
.tgb-vertical-band--operations-logistics  { background-color: var(--colour-vertical-ops); }
.tgb-vertical-band--hr-talent             { background-color: var(--colour-vertical-hr); }
.tgb-vertical-band--market-trends         { background-color: var(--colour-vertical-market); }

/* -----------------------------------------------------------------------------
   09. Site Header & Navigation
   ----------------------------------------------------------------------------- */

.tgb-site-header {
	background-color: var(--colour-navy);
	position: sticky;
	top: 0;
	z-index: 200;
	box-shadow: 0 1px 0 rgba(255 255 255 / 0.06), 0 4px 16px rgb(0 0 0 / 0.35);
}

.tgb-site-header__inner {
	display: flex;
	align-items: center;
	justify-content: space-between;
	height: 68px;
	gap: var(--space-4);
}

.tgb-site-header__logo {
	display: flex;
	align-items: center;
	gap: var(--space-3);
	text-decoration: none;
	flex-shrink: 0;
}

.tgb-site-header__logo-img {
	display: block;
	height: 38px;
	width: auto;
}

.tgb-site-header__logo-text {
	font-family: var(--font-heading);
	font-weight: 700;
	font-size: var(--scale-lg);
	color: var(--colour-text-inverse);
	letter-spacing: -0.03em;
}

.tgb-site-header__logo-text span {
	color: var(--colour-primary);
}

/* ── Desktop nav ── */

.tgb-nav {
	display: none;
	flex: 1;
	justify-content: center;
}

@media (min-width: 1024px) {
	.tgb-nav {
		display: flex;
		align-items: center;
	}
}

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

.tgb-nav__item > a {
	display: block;
	padding: var(--space-2) var(--space-3);
	color: rgba(255 255 255 / 0.8);
	font-family: var(--font-heading);
	font-size: var(--scale-sm);
	font-weight: 600;
	letter-spacing: 0.01em;
	border-radius: var(--radius-sm);
	transition: color var(--transition), background-color var(--transition);
	text-decoration: none;
}

.tgb-nav__item > a:hover,
.tgb-nav__item.current-menu-item > a,
.tgb-nav__item.current-menu-ancestor > a {
	color: var(--colour-text-inverse);
	background-color: rgba(255 255 255 / 0.1);
}

.tgb-nav__item > a:focus-visible {
	outline: 2px solid rgba(255 255 255 / 0.7);
	outline-offset: 2px;
	color: var(--colour-text-inverse);
}

.tgb-nav__cta {
	margin-left: var(--space-4);
	flex-shrink: 0;
}

/* ── Dropdown submenu ── */

.tgb-nav__item.menu-item-has-children {
	position: relative;
}

.tgb-nav__item.menu-item-has-children > a::after {
	content: '';
	display: inline-block;
	width: 8px;
	height: 5px;
	margin-left: var(--space-2);
	background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 8 5'%3E%3Cpath d='M1 1l3 3 3-3' stroke='rgba(255,255,255,0.6)' stroke-width='1.5' fill='none' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");
	background-repeat: no-repeat;
	background-size: contain;
	vertical-align: middle;
	transition: transform var(--transition);
}

.tgb-nav__item.menu-item-has-children:hover > a::after,
.tgb-nav__item.menu-item-has-children:focus-within > a::after {
	transform: rotate(180deg);
}

.tgb-nav__item.menu-item-has-children > .sub-menu {
	position: absolute;
	top: calc(100% + 8px);
	left: 0;
	min-width: 230px;
	background-color: var(--colour-navy);
	border: 1px solid rgba(255 255 255 / 0.1);
	border-radius: var(--radius-lg);
	box-shadow: 0 16px 40px rgb(0 0 0 / 0.45), 0 2px 8px rgb(0 0 0 / 0.2);
	padding: var(--space-2) var(--space-2);
	list-style: none;
	margin: 0;
	opacity: 0;
	visibility: hidden;
	transform: translateY(-8px) scale(0.98);
	transform-origin: top left;
	transition: opacity 0.18s var(--ease-out),
	            transform 0.18s var(--ease-out),
	            visibility 0.18s var(--ease-out);
	z-index: 200;
}

.tgb-nav__item.menu-item-has-children:hover > .sub-menu,
.tgb-nav__item.menu-item-has-children:focus-within > .sub-menu {
	opacity: 1;
	visibility: visible;
	transform: translateY(0) scale(1);
}

.tgb-nav__sub-link {
	display: block;
	padding: var(--space-2) var(--space-3);
	color: rgba(255 255 255 / 0.7);
	font-family: var(--font-heading);
	font-size: var(--scale-sm);
	font-weight: 500;
	white-space: nowrap;
	border-radius: var(--radius);
	transition: color var(--transition), background-color var(--transition);
	text-decoration: none;
}

.tgb-nav__sub-link:hover {
	color: var(--colour-text-inverse);
	background-color: rgba(255 255 255 / 0.1);
}

.tgb-nav__sub-link:focus-visible {
	outline: 2px solid rgba(255 255 255 / 0.7);
	outline-offset: 1px;
}

/* ── Mobile toggle ── */

.tgb-nav-toggle {
	display: flex;
	flex-direction: column;
	justify-content: space-between;
	width: 24px;
	height: 18px;
	background: none;
	border: none;
	cursor: pointer;
	padding: 0;
	flex-shrink: 0;
}

@media (min-width: 1024px) {
	.tgb-nav-toggle {
		display: none;
	}
}

.tgb-nav-toggle:focus-visible {
	outline: 2px solid rgba(255 255 255 / 0.7);
	outline-offset: 4px;
	border-radius: 3px;
}

.tgb-nav-toggle__line {
	display: block;
	width: 100%;
	height: 2px;
	background-color: var(--colour-text-inverse);
	border-radius: 2px;
	transition: transform var(--transition), opacity var(--transition);
}

.tgb-nav-toggle[aria-expanded="true"] .tgb-nav-toggle__line:nth-child(1) {
	transform: translateY(8px) rotate(45deg);
}

.tgb-nav-toggle[aria-expanded="true"] .tgb-nav-toggle__line:nth-child(2) {
	opacity: 0;
}

.tgb-nav-toggle[aria-expanded="true"] .tgb-nav-toggle__line:nth-child(3) {
	transform: translateY(-8px) rotate(-45deg);
}

/* ── Mobile drawer ── */

.tgb-mobile-nav {
	display: none;
	background-color: var(--colour-navy);
	border-top: 1px solid rgba(255 255 255 / 0.08);
}

.tgb-mobile-nav.is-open {
	display: block;
	animation: slideDown 0.22s var(--ease-out);
}

@media (min-width: 1024px) {
	.tgb-mobile-nav {
		display: none !important;
	}
}

.tgb-mobile-nav__list {
	padding: var(--space-3) var(--space-4) var(--space-5);
}

.tgb-mobile-nav__list > .menu-item > a {
	display: block;
	padding: var(--space-3) var(--space-3);
	color: rgba(255 255 255 / 0.85);
	font-family: var(--font-heading);
	font-size: var(--scale-base);
	font-weight: 600;
	border-radius: var(--radius);
	text-decoration: none;
	transition: color var(--transition), background-color var(--transition);
}

.tgb-mobile-nav__list > .menu-item > a:hover {
	color: var(--colour-text-inverse);
	background-color: rgba(255 255 255 / 0.1);
}

.tgb-mobile-nav__list > .menu-item > a:focus-visible {
	outline: 2px solid rgba(255 255 255 / 0.7);
	outline-offset: 1px;
}

.tgb-mobile-nav__list .sub-menu {
	list-style: none;
	margin: 0;
	padding: var(--space-1) 0 var(--space-2) var(--space-4);
}

.tgb-mobile-nav__list .sub-menu a {
	display: block;
	padding: var(--space-2) var(--space-3);
	color: rgba(255 255 255 / 0.6);
	font-size: var(--scale-sm);
	border-radius: var(--radius-sm);
	text-decoration: none;
	transition: color var(--transition), background-color var(--transition);
}

.tgb-mobile-nav__list .sub-menu a:hover {
	color: var(--colour-text-inverse);
	background-color: rgba(255 255 255 / 0.08);
}

/* -----------------------------------------------------------------------------
   10. Search Bar
   ----------------------------------------------------------------------------- */

.tgb-search-toggle {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 38px;
	height: 38px;
	background: none;
	border: 1px solid transparent;
	cursor: pointer;
	color: rgba(255 255 255 / 0.7);
	border-radius: var(--radius);
	transition: color var(--transition), background-color var(--transition), border-color var(--transition);
	flex-shrink: 0;
}

.tgb-search-toggle:hover {
	color: var(--colour-text-inverse);
	background-color: rgba(255 255 255 / 0.1);
	border-color: rgba(255 255 255 / 0.15);
}

.tgb-search-toggle:focus-visible {
	outline: 2px solid rgba(255 255 255 / 0.7);
	outline-offset: 2px;
}

/* Cart icon — header */
.tgb-cart-icon {
	position: relative;
	display: flex;
	align-items: center;
	justify-content: center;
	width: 38px;
	height: 38px;
	background: none;
	border: 1px solid transparent;
	color: rgba(255, 255, 255, 0.7);
	border-radius: var(--radius);
	text-decoration: none;
	transition: color var(--transition), background-color var(--transition), border-color var(--transition);
	flex-shrink: 0;
}

.tgb-cart-icon:hover {
	color: var(--colour-text-inverse);
	background-color: rgba(255, 255, 255, 0.1);
	border-color: rgba(255, 255, 255, 0.15);
}

.tgb-cart-icon:focus-visible {
	outline: 2px solid rgba(255, 255, 255, 0.7);
	outline-offset: 2px;
}

.tgb-cart-icon__count {
	display: none;
	position: absolute;
	top: 3px;
	right: 2px;
	min-width: 17px;
	height: 17px;
	padding: 0 4px;
	background-color: var(--colour-primary);
	color: #fff;
	font-family: var(--font-heading);
	font-size: 10px;
	font-weight: 700;
	line-height: 17px;
	text-align: center;
	border-radius: 99px;
	pointer-events: none;
}

.tgb-cart-icon__count.is-visible {
	display: block;
}

.tgb-search-bar {
	background-color: var(--colour-navy-mid);
	border-top: 1px solid rgba(255 255 255 / 0.08);
	padding: var(--space-4) 0;
}

.tgb-search-bar form {
	display: flex;
	align-items: center;
	gap: var(--space-3);
	max-width: 600px;
}

.tgb-search-bar__input {
	flex: 1;
	background: rgba(255 255 255 / 0.08);
	border: 1px solid rgba(255 255 255 / 0.18);
	border-radius: var(--radius);
	padding: var(--space-3) var(--space-4);
	color: var(--colour-text-inverse);
	font-family: var(--font-body);
	font-size: var(--scale-sm);
	outline: none;
	transition: border-color var(--transition), background-color var(--transition);
	height: 44px;
}

.tgb-search-bar__input::placeholder {
	color: rgba(255 255 255 / 0.4);
}

.tgb-search-bar__input:focus {
	border-color: rgba(255 255 255 / 0.5);
	background-color: rgba(255 255 255 / 0.13);
	outline: none;
}

/* -----------------------------------------------------------------------------
   11. Homepage — Hero & Journey Grid
   ----------------------------------------------------------------------------- */

.tgb-hero {
	background-color: var(--colour-navy);
	background-image:
		radial-gradient(ellipse 100% 80% at 65% -20%, rgb(17 81 211 / 0.22) 0%, transparent 65%),
		radial-gradient(ellipse 60% 50% at 10% 110%, rgb(26 53 112 / 0.5) 0%, transparent 60%);
	padding-block: var(--space-24) var(--space-16);
	position: relative;
	overflow: hidden;
}

/* Fine grid texture overlay */
.tgb-hero::after {
	content: '';
	position: absolute;
	inset: 0;
	background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='40' height='40'%3E%3Cpath d='M0 0h40v40H0z' fill='none'/%3E%3Ccircle cx='20' cy='20' r='0.6' fill='rgba(255,255,255,0.04)'/%3E%3C/svg%3E");
	pointer-events: none;
}

.tgb-hero__text {
	text-align: center;
	max-width: 800px;
	margin-inline: auto;
	margin-bottom: var(--space-16);
	position: relative;
	z-index: 1;
}

.tgb-hero__eyebrow {
	display: inline-block;
	font-family: var(--font-heading);
	font-size: var(--scale-xs);
	font-weight: 700;
	letter-spacing: 0.12em;
	text-transform: uppercase;
	color: var(--colour-primary);
	background-color: rgba(17 81 211 / 0.15);
	border: 1px solid rgba(17 81 211 / 0.3);
	padding: var(--space-1) var(--space-3);
	border-radius: 100px;
	margin-bottom: var(--space-6);
}

.tgb-hero__title {
	font-family: var(--font-editorial);
	font-size: clamp(var(--scale-3xl), 4.5vw, var(--scale-5xl));
	font-weight: 400;
	font-style: italic;
	color: var(--colour-text-inverse);
	line-height: 1.12;
	letter-spacing: -0.01em;
	margin-bottom: var(--space-6);
}

.tgb-hero__title strong {
	font-style: normal;
	color: #a8bfff;
}

.tgb-hero__subtitle {
	font-size: var(--scale-lg);
	color: rgba(255 255 255 / 0.7);
	line-height: 1.65;
	margin: 0;
	font-weight: 400;
	max-width: 620px;
	margin-inline: auto;
}

/* Journey grid */
.tgb-journey-grid {
	display: grid;
	grid-template-columns: 1fr;
	gap: var(--space-4);
	position: relative;
	z-index: 1;
}

@media (min-width: 768px) {
	.tgb-journey-grid {
		grid-template-columns: 1fr 1.2fr 1fr;
		align-items: start;
	}
}

.tgb-journey-entry {
	background-color: rgba(255 255 255 / 0.05);
	border: 1px solid rgba(255 255 255 / 0.1);
	border-radius: var(--radius-xl);
	transition: background-color var(--transition-slow), border-color var(--transition-slow),
	            transform var(--transition-slow), box-shadow var(--transition-slow);
}

.tgb-journey-entry:hover {
	background-color: rgba(255 255 255 / 0.09);
	border-color: rgba(255 255 255 / 0.18);
	transform: translateY(-3px);
	box-shadow: 0 12px 32px rgb(0 0 0 / 0.25);
}

.tgb-journey-entry--primary {
	background: linear-gradient(145deg, var(--colour-primary) 0%, var(--colour-primary-dark) 100%);
	border-color: transparent;
	box-shadow: 0 8px 32px rgb(17 81 211 / 0.5), 0 0 0 1px rgba(255 255 255 / 0.1);
}

.tgb-journey-entry--primary:hover {
	background: linear-gradient(145deg, #1B5DE8 0%, var(--colour-primary) 100%);
	transform: translateY(-4px);
	box-shadow: 0 16px 48px rgb(17 81 211 / 0.55), 0 0 0 1px rgba(255 255 255 / 0.15);
}

@media (min-width: 768px) {
	.tgb-journey-entry--primary {
		margin-block: -var(--space-4);
	}
}

.tgb-journey-entry__inner {
	padding: var(--space-8);
	display: flex;
	flex-direction: column;
	height: 100%;
}

.tgb-journey-entry__eyebrow {
	font-size: var(--scale-xs);
	font-weight: 700;
	letter-spacing: 0.1em;
	text-transform: uppercase;
	color: rgba(255 255 255 / 0.5);
	margin-bottom: var(--space-3);
}

.tgb-journey-entry--primary .tgb-journey-entry__eyebrow {
	color: rgba(255 255 255 / 0.75);
}

.tgb-journey-entry__title {
	font-family: var(--font-heading);
	font-size: var(--scale-lg);
	font-weight: 700;
	color: var(--colour-text-inverse);
	line-height: 1.35;
	margin-bottom: var(--space-4);
	letter-spacing: -0.02em;
}

@media (min-width: 768px) {
	.tgb-journey-entry--primary .tgb-journey-entry__title {
		font-size: var(--scale-xl);
	}
}

.tgb-journey-entry__description {
	font-size: var(--scale-sm);
	color: rgba(255 255 255 / 0.6);
	line-height: 1.65;
	margin-bottom: var(--space-6);
	flex-grow: 1;
}

.tgb-journey-entry--primary .tgb-journey-entry__description {
	color: rgba(255 255 255 / 0.82);
}

.tgb-journey-entry__actions {
	display: flex;
	flex-wrap: wrap;
	gap: var(--space-3);
}

/* -----------------------------------------------------------------------------
   12. Homepage — Urgent Situations
   ----------------------------------------------------------------------------- */

.tgb-urgent-situations {
	background-color: var(--colour-surface);
	border-bottom: 1px solid var(--colour-border);
}

.tgb-urgent-grid {
	display: grid;
	grid-template-columns: 1fr;
	gap: var(--space-3);
	margin-top: var(--space-8);
}

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

@media (min-width: 1024px) {
	.tgb-urgent-grid {
		grid-template-columns: repeat(3, 1fr);
	}
	.tgb-urgent-grid > *:nth-child(4) { grid-column: 1 / 2; }
	.tgb-urgent-grid > *:nth-child(5) { grid-column: 2 / 3; }
}

.tgb-urgent-tile {
	display: flex;
	align-items: flex-start;
	justify-content: space-between;
	gap: var(--space-4);
	padding: var(--space-5) var(--space-6);
	background-color: var(--colour-surface-raised);
	border: 1px solid var(--colour-border);
	border-left-width: 4px;
	border-radius: var(--radius-lg);
	text-decoration: none;
	transition: box-shadow var(--transition-slow), transform var(--transition-slow),
	            background-color var(--transition), border-color var(--transition);
}

.tgb-urgent-tile:hover {
	box-shadow: var(--shadow-md);
	transform: translateY(-2px);
	background-color: var(--colour-surface);
	border-color: var(--colour-border-strong);
	border-left-color: inherit;
}

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

.tgb-urgent-tile__text {
	font-size: var(--scale-sm);
	font-weight: 500;
	color: var(--colour-text-primary);
	line-height: 1.5;
	margin: 0;
}

.tgb-urgent-tile__arrow {
	flex-shrink: 0;
	width: 28px;
	height: 28px;
	display: flex;
	align-items: center;
	justify-content: center;
	border-radius: 50%;
	background-color: var(--colour-border);
	color: var(--colour-text-secondary);
	font-size: var(--scale-base);
	transition: transform var(--transition), color var(--transition),
	            background-color var(--transition);
	margin-top: 2px;
}

.tgb-urgent-tile:hover .tgb-urgent-tile__arrow {
	color: #fff;
	background-color: var(--colour-primary);
	transform: translateX(3px);
}

/* -----------------------------------------------------------------------------
   13. Section Headings
   ----------------------------------------------------------------------------- */

.tgb-section-header {
	display: flex;
	align-items: baseline;
	justify-content: space-between;
	gap: var(--space-4);
	margin-bottom: var(--space-8);
	flex-wrap: wrap;
}

.tgb-section-heading {
	font-family: var(--font-heading);
	font-size: var(--scale-2xl);
	font-weight: 700;
	color: var(--colour-text-primary);
	letter-spacing: -0.03em;
	line-height: 1.2;
}

@media (max-width: 767px) {
	.tgb-section-heading {
		font-size: var(--scale-xl);
	}
}

.tgb-section-header__link {
	font-family: var(--font-heading);
	font-size: var(--scale-sm);
	font-weight: 600;
	color: var(--colour-primary);
	white-space: nowrap;
	letter-spacing: 0.01em;
	text-decoration: none;
	transition: color var(--transition);
}

.tgb-section-header__link:hover {
	color: var(--colour-primary-dark);
}

/* Standalone heading (no link) */
#intelligence-heading,
#featured-tools-heading,
#urgent-heading {
	font-family: var(--font-heading);
	font-size: var(--scale-2xl);
	font-weight: 700;
	letter-spacing: -0.03em;
	color: var(--colour-text-primary);
}

/* -----------------------------------------------------------------------------
   14. Article (single.php)
   ----------------------------------------------------------------------------- */

.tgb-article {
	max-width: var(--container-narrow);
	margin-inline: auto;
}

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

.tgb-article__vertical {
	margin-bottom: var(--space-4);
}

.tgb-article__vertical a {
	font-family: var(--font-heading);
	font-size: var(--scale-xs);
	font-weight: 700;
	letter-spacing: 0.1em;
	text-transform: uppercase;
	text-decoration: none;
	transition: opacity var(--transition);
}

.tgb-article__vertical a:hover {
	opacity: 0.75;
}

.tgb-article__title {
	font-family: var(--font-editorial);
	font-size: clamp(var(--scale-3xl), 3.5vw, var(--scale-5xl));
	font-weight: 400;
	line-height: 1.15;
	letter-spacing: -0.01em;
	color: var(--colour-text-primary);
	margin-bottom: var(--space-6);
}

.tgb-article__meta {
	display: flex;
	align-items: center;
	gap: var(--space-4);
	flex-wrap: wrap;
}

.tgb-article__meta time {
	font-size: var(--scale-sm);
	color: var(--colour-text-muted);
	font-weight: 500;
}

.tgb-article__meta .tgb-pass-badge {
	flex-shrink: 0;
}

.tgb-article__thumbnail {
	margin-bottom: var(--space-10);
	border-radius: var(--radius-xl);
	overflow: hidden;
	aspect-ratio: 16 / 9;
}

.tgb-article__thumbnail img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}

.tgb-article__body {
	margin-bottom: var(--space-12);
}

/* Article body reading rhythm */
.tgb-article .entry-content > *:first-child {
	font-size: var(--scale-lg);
	color: var(--colour-text-secondary);
	line-height: 1.75;
}

/* -----------------------------------------------------------------------------
   15. Vertical Hub
   ----------------------------------------------------------------------------- */

.tgb-vertical-hub {
	min-height: 60vh;
}

.tgb-vertical-hub__hero {
	background-color: var(--colour-navy);
	background-image:
		radial-gradient(ellipse 80% 100% at 90% 50%, color-mix(in srgb, var(--hub-colour, #1151D3) 30%, transparent) 0%, transparent 60%),
		radial-gradient(ellipse 60% 80% at -10% 50%, rgba(255 255 255 / 0.03) 0%, transparent 70%);
	padding-block: var(--space-20) var(--space-16);
	position: relative;
	overflow: hidden;
}

.tgb-vertical-hub__hero::before {
	content: '';
	position: absolute;
	inset: 0;
	background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='60' height='60'%3E%3Ccircle cx='30' cy='30' r='0.7' fill='rgba(255,255,255,0.03)'/%3E%3C/svg%3E");
	pointer-events: none;
}

.tgb-vertical-hub__eyebrow {
	font-family: var(--font-heading);
	font-size: var(--scale-xs);
	font-weight: 700;
	letter-spacing: 0.12em;
	text-transform: uppercase;
	color: rgba(255 255 255 / 0.55);
	margin-bottom: var(--space-4);
	position: relative;
	z-index: 1;
}

.tgb-vertical-hub__title {
	font-family: var(--font-editorial);
	font-size: clamp(var(--scale-3xl), 4vw, var(--scale-5xl));
	font-weight: 400;
	color: var(--colour-text-inverse);
	line-height: 1.1;
	margin-bottom: var(--space-4);
	position: relative;
	z-index: 1;
	letter-spacing: -0.01em;
}

.tgb-vertical-hub__description {
	font-size: var(--scale-lg);
	color: rgba(255 255 255 / 0.7);
	line-height: 1.65;
	max-width: 600px;
	position: relative;
	z-index: 1;
}

.tgb-vertical-hub__section-title {
	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: 2px solid var(--colour-border);
	display: flex;
	align-items: center;
	gap: var(--space-3);
}

.tgb-vertical-hub__section-title::before {
	content: '';
	display: block;
	width: 4px;
	height: 22px;
	background-color: var(--hub-colour, var(--colour-primary));
	border-radius: 2px;
	flex-shrink: 0;
}

/* -----------------------------------------------------------------------------
   16. Product Cards
   ----------------------------------------------------------------------------- */

.tgb-product-card__format {
	display: inline-flex;
	align-items: center;
	padding: 2px var(--space-3);
	border-radius: 100px;
	font-family: var(--font-heading);
	font-size: var(--scale-xs);
	font-weight: 600;
	letter-spacing: 0.04em;
	text-transform: uppercase;
	background-color: var(--colour-surface-raised);
	border: 1px solid var(--colour-border);
	color: var(--colour-text-secondary);
}

.tgb-product-card__upsell {
	font-size: var(--scale-sm);
	color: var(--colour-text-secondary);
	line-height: 1.55;
	margin-bottom: var(--space-4);
	flex-grow: 1;
}

.tgb-product-card__footer {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: var(--space-3);
	margin-top: auto;
	padding-top: var(--space-4);
	border-top: 1px solid var(--colour-border);
	flex-wrap: wrap;
}

.tgb-product-card__price {
	font-family: var(--font-heading);
	font-size: var(--scale-lg);
	font-weight: 700;
	color: var(--colour-text-primary);
	letter-spacing: -0.02em;
}

.tgb-product-card__price .woocommerce-Price-amount {
	color: var(--colour-text-primary);
}

.tgb-product-card__price ins {
	text-decoration: none;
}

.tgb-product-card__price del {
	font-size: var(--scale-sm);
	color: var(--colour-text-muted);
	font-weight: 400;
}

/* Featured product card */
.tgb-product-card--featured {
	border-top-width: 4px;
}

.tgb-product-card--featured .tgb-card__title {
	font-size: var(--scale-xl);
}

/* -----------------------------------------------------------------------------
   17. Pass CTA Block
   ----------------------------------------------------------------------------- */

.tgb-pass-cta {
	background: linear-gradient(135deg, var(--colour-navy) 0%, var(--colour-navy-mid) 60%, #1D3A78 100%);
	color: var(--colour-text-inverse);
	padding-block: var(--space-20);
	position: relative;
	overflow: hidden;
}

.tgb-pass-cta::before {
	content: '';
	position: absolute;
	inset: 0;
	background-image:
		radial-gradient(ellipse 60% 80% at 85% 50%, rgba(17 81 211 / 0.2) 0%, transparent 60%),
		url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='40' height='40'%3E%3Ccircle cx='20' cy='20' r='0.5' fill='rgba(255,255,255,0.04)'/%3E%3C/svg%3E");
	pointer-events: none;
}

.tgb-pass-cta__inner {
	position: relative;
	z-index: 1;
	display: grid;
	grid-template-columns: 1fr;
	gap: var(--space-10);
	align-items: center;
}

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

.tgb-pass-cta__label {
	display: inline-flex;
	align-items: center;
	gap: var(--space-2);
	font-family: var(--font-heading);
	font-size: var(--scale-xs);
	font-weight: 700;
	letter-spacing: 0.1em;
	text-transform: uppercase;
	color: var(--colour-gold-mid);
	margin-bottom: var(--space-4);
}

.tgb-pass-cta__label::before {
	content: '';
	display: inline-block;
	width: 20px;
	height: 1px;
	background-color: var(--colour-gold-mid);
	flex-shrink: 0;
}

.tgb-pass-cta__title {
	font-family: var(--font-editorial);
	font-size: clamp(var(--scale-2xl), 3vw, var(--scale-4xl));
	font-weight: 400;
	color: var(--colour-text-inverse);
	line-height: 1.15;
	margin-bottom: var(--space-6);
	letter-spacing: -0.01em;
}

.tgb-pass-cta__benefits {
	list-style: none;
	display: flex;
	flex-direction: column;
	gap: var(--space-3);
	margin-bottom: var(--space-8);
}

.tgb-pass-cta__benefits li {
	display: flex;
	align-items: flex-start;
	gap: var(--space-3);
	font-size: var(--scale-sm);
	color: rgba(255 255 255 / 0.8);
	line-height: 1.5;
}

.tgb-pass-cta__benefits li::before {
	content: '✓';
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 20px;
	height: 20px;
	min-width: 20px;
	border-radius: 50%;
	background-color: rgba(17 81 211 / 0.35);
	border: 1px solid rgba(17 81 211 / 0.5);
	color: #a8bfff;
	font-size: var(--scale-xs);
	font-weight: 700;
	margin-top: 1px;
}

.tgb-pass-cta__price {
	display: flex;
	align-items: baseline;
	gap: var(--space-1);
}

.tgb-pass-cta__amount {
	font-family: var(--font-heading);
	font-size: var(--scale-5xl);
	font-weight: 700;
	color: var(--colour-text-inverse);
	letter-spacing: -0.04em;
	line-height: 1;
}

.tgb-pass-cta__period {
	font-size: var(--scale-lg);
	color: rgba(255 255 255 / 0.55);
	font-weight: 400;
}

.tgb-pass-cta__action {
	display: flex;
	flex-direction: column;
	align-items: flex-start;
	gap: var(--space-4);
	min-width: 220px;
}

@media (min-width: 768px) {
	.tgb-pass-cta__action {
		align-items: center;
		text-align: center;
	}
}

.tgb-pass-cta__action .tgb-btn--primary {
	width: 100%;
	justify-content: center;
	padding: var(--space-4) var(--space-8);
	font-size: var(--scale-base);
}

.tgb-pass-cta__note {
	font-size: var(--scale-xs);
	color: rgba(255 255 255 / 0.45);
	line-height: 1.5;
	text-align: center;
	max-width: 200px;
}

/* -----------------------------------------------------------------------------
   18. Content-to-Product Aside
   ----------------------------------------------------------------------------- */

.tgb-content-to-product {
	margin-block: var(--space-10);
	padding: var(--space-6);
	background-color: var(--colour-surface);
	border: 1px solid var(--colour-border);
	border-radius: var(--radius-lg);
	border-left-width: 4px;
	box-shadow: var(--shadow-sm);
	transition: box-shadow var(--transition-slow);
}

.tgb-content-to-product:hover {
	box-shadow: var(--shadow-md);
}

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

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

.tgb-content-to-product__name a {
	color: inherit;
	text-decoration: none;
}

.tgb-content-to-product__name a:hover {
	color: var(--colour-primary);
}

.tgb-content-to-product__upsell {
	font-size: var(--scale-sm);
	color: var(--colour-text-secondary);
	margin-bottom: var(--space-4);
	line-height: 1.55;
}

/* -----------------------------------------------------------------------------
   19. Paywall
   ----------------------------------------------------------------------------- */

.tgb-elite-teaser {
	position: relative;
}

.tgb-elite-teaser::after {
	content: '';
	position: absolute;
	bottom: 0;
	left: 0;
	right: 0;
	height: 100px;
	background: linear-gradient(to bottom, transparent 0%, var(--colour-background) 100%);
	pointer-events: none;
}

.tgb-paywall {
	margin-block: var(--space-8);
	border-radius: var(--radius-2xl);
	background: linear-gradient(150deg, var(--colour-navy) 0%, var(--colour-navy-mid) 100%);
	color: var(--colour-text-inverse);
	overflow: hidden;
	box-shadow: var(--shadow-navy);
	border: 1px solid rgba(255 255 255 / 0.08);
}

.tgb-paywall__inner {
	padding: var(--space-12) var(--space-8);
	text-align: center;
	max-width: 540px;
	margin-inline: auto;
}

.tgb-paywall__lock {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 60px;
	height: 60px;
	border-radius: 50%;
	background-color: rgba(255 255 255 / 0.08);
	border: 1px solid rgba(255 255 255 / 0.12);
	margin-bottom: var(--space-6);
	color: var(--colour-gold-mid);
}

.tgb-paywall__title {
	font-family: var(--font-editorial);
	font-size: var(--scale-3xl);
	font-weight: 400;
	color: var(--colour-text-inverse);
	margin-bottom: var(--space-4);
	line-height: 1.2;
}

.tgb-paywall__description {
	font-size: var(--scale-base);
	color: rgba(255 255 255 / 0.72);
	margin-bottom: var(--space-8);
	line-height: 1.65;
}

.tgb-paywall__actions {
	display: flex;
	align-items: center;
	justify-content: center;
	gap: var(--space-4);
	flex-wrap: wrap;
}

/* The paywall is injected via the_content, so it renders inside .entry-content.
   Those article rules (.entry-content p / a — specificity 0,1,1) override the
   paywall's on-navy colours (0,1,0), turning the text dark and the buttons
   blue-on-blue. Re-assert with 0,2,0 so the navy UI stays readable. */
.tgb-paywall .tgb-paywall__title { color: var(--colour-text-inverse); }
.tgb-paywall .tgb-paywall__description { color: rgba(255 255 255 / 0.78); }
.tgb-paywall .tgb-btn--primary { color: var(--colour-text-inverse); }
.tgb-paywall .tgb-btn--ghost {
	color: var(--colour-text-inverse);
	border-color: rgba(255 255 255 / 0.45);
}
.tgb-paywall .tgb-btn--ghost:hover {
	background-color: rgba(255 255 255 / 0.12);
	color: var(--colour-text-inverse);
}

/* -----------------------------------------------------------------------------
   20. Elite Cards
   ----------------------------------------------------------------------------- */

.tgb-post-card--elite {
	border-color: var(--colour-gold);
	background: linear-gradient(145deg, var(--colour-gold-light) 0%, var(--colour-surface) 40%);
}

.tgb-post-card--elite .tgb-card__title a {
	color: var(--colour-text-primary);
}

.tgb-post-card--elite.is-locked {
	opacity: 0.9;
}

.tgb-post-card--elite.is-locked .tgb-card__body {
	position: relative;
}

/* Elite badge in card meta — gold treatment */
.tgb-post-card--elite .tgb-pass-badge {
	background-color: var(--colour-gold-light) !important;
	color: var(--colour-gold-text) !important;
	border: 1px solid var(--colour-gold);
}

/* -----------------------------------------------------------------------------
   21. Pass Badge
   ----------------------------------------------------------------------------- */

.tgb-pass-badge {
	display: inline-flex;
	align-items: center;
	gap: var(--space-1);
	padding: 2px var(--space-3);
	border-radius: 100px;
	font-family: var(--font-heading);
	font-size: var(--scale-xs);
	font-weight: 700;
	letter-spacing: 0.03em;
	white-space: nowrap;
}

.tgb-pass-badge--active  {
	background-color: #D1FAE5;
	color: #065F46;
	border: 1px solid #6EE7B7;
}

.tgb-pass-badge--grace   {
	background-color: #FEF3C7;
	color: #92400E;
	border: 1px solid #FCD34D;
}

.tgb-pass-badge--expired {
	background-color: #FEE2E2;
	color: #991B1B;
	border: 1px solid #FCA5A5;
}

/* -----------------------------------------------------------------------------
   22. Site Footer
   ----------------------------------------------------------------------------- */

.tgb-site-footer {
	background-color: var(--colour-navy);
	background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='40' height='40'%3E%3Ccircle cx='20' cy='20' r='0.5' fill='rgba(255,255,255,0.025)'/%3E%3C/svg%3E");
	color: rgba(255 255 255 / 0.65);
	padding-block: var(--space-16) var(--space-12);
	border-top: 1px solid rgba(255 255 255 / 0.06);
}

.tgb-site-footer__grid {
	display: grid;
	gap: var(--space-10);
}

@media (min-width: 768px) {
	.tgb-site-footer__grid {
		grid-template-columns: 2fr 1fr 1fr;
		gap: var(--space-12);
	}
}

.tgb-site-footer__logo-link {
	display: inline-block;
	margin-bottom: var(--space-4);
}

.tgb-site-footer__logo-img {
	display: block;
	height: 41px;
	width: auto;
}

.tgb-site-footer__brand-name {
	font-family: var(--font-heading);
	font-weight: 700;
	font-size: var(--scale-xl);
	color: var(--colour-text-inverse);
	margin-bottom: var(--space-3);
	letter-spacing: -0.03em;
}

.tgb-site-footer__tagline {
	font-size: var(--scale-sm);
	line-height: 1.6;
	color: rgba(255 255 255 / 0.55);
	margin-bottom: var(--space-6);
	max-width: 280px;
}

.tgb-site-footer__heading {
	font-family: var(--font-heading);
	font-size: var(--scale-xs);
	font-weight: 700;
	color: rgba(255 255 255 / 0.4);
	text-transform: uppercase;
	letter-spacing: 0.1em;
	margin-bottom: var(--space-5);
}

.tgb-site-footer__links {
	display: flex;
	flex-direction: column;
	gap: var(--space-3);
}

.tgb-site-footer__links li {
	margin: 0;
}

.tgb-site-footer__links a {
	color: rgba(255 255 255 / 0.65);
	font-size: var(--scale-sm);
	text-decoration: none;
	transition: color var(--transition);
	line-height: 1.4;
}

.tgb-site-footer__links a:hover {
	color: var(--colour-text-inverse);
}

.tgb-site-footer__links a:focus-visible {
	outline: 2px solid rgba(255 255 255 / 0.5);
	outline-offset: 2px;
	border-radius: 2px;
}

.tgb-site-footer__bottom {
	border-top: 1px solid rgba(255 255 255 / 0.08);
	margin-top: var(--space-10);
	padding-top: var(--space-6);
	display: flex;
	align-items: center;
	justify-content: space-between;
	flex-wrap: wrap;
	gap: var(--space-4);
	font-size: var(--scale-xs);
	color: rgba(255 255 255 / 0.4);
}

.tgb-site-footer__bottom a {
	color: inherit;
	text-decoration: none;
	transition: color var(--transition);
}

.tgb-site-footer__bottom a:hover {
	color: rgba(255 255 255 / 0.75);
}

/* -----------------------------------------------------------------------------
   23. Pagination
   ----------------------------------------------------------------------------- */

.nav-links {
	display: flex;
	align-items: center;
	justify-content: center;
	gap: var(--space-2);
	margin-block: var(--space-16);
	flex-wrap: wrap;
}

.page-numbers {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-width: 40px;
	height: 40px;
	padding-inline: var(--space-3);
	border-radius: var(--radius);
	font-family: var(--font-heading);
	font-size: var(--scale-sm);
	font-weight: 600;
	color: var(--colour-text-secondary);
	border: 1px solid var(--colour-border);
	background-color: var(--colour-surface);
	text-decoration: none;
	transition: all var(--transition);
}

.page-numbers:hover {
	background-color: var(--colour-primary-light);
	color: var(--colour-primary);
	border-color: var(--colour-primary);
}

.page-numbers.current {
	background-color: var(--colour-primary);
	color: var(--colour-text-inverse);
	border-color: var(--colour-primary);
	box-shadow: 0 2px 8px rgb(17 81 211 / 0.3);
}

.page-numbers:focus-visible {
	outline: 3px solid var(--colour-primary);
	outline-offset: 2px;
}

/* -----------------------------------------------------------------------------
   24. 404 & Archive Fallbacks
   ----------------------------------------------------------------------------- */

.tgb-not-found {
	text-align: center;
	padding-block: var(--space-32);
}

.tgb-not-found__code {
	font-family: var(--font-heading);
	font-size: 8rem;
	font-weight: 700;
	color: var(--colour-border);
	line-height: 1;
	letter-spacing: -0.05em;
	margin-bottom: var(--space-4);
}

.tgb-not-found__title {
	font-size: var(--scale-2xl);
	color: var(--colour-text-primary);
	margin-bottom: var(--space-4);
}

.tgb-not-found__description {
	color: var(--colour-text-secondary);
	margin-bottom: var(--space-8);
	max-width: 440px;
	margin-inline: auto;
}

/* -----------------------------------------------------------------------------
   25. Animations & Utilities
   ----------------------------------------------------------------------------- */

/* Page load fade-in */
@keyframes fadeInUp {
	from {
		opacity: 0;
		transform: translateY(16px);
	}
	to {
		opacity: 1;
		transform: translateY(0);
	}
}

@keyframes slideDown {
	from {
		opacity: 0;
		transform: translateY(-8px);
	}
	to {
		opacity: 1;
		transform: translateY(0);
	}
}

@keyframes fadeIn {
	from { opacity: 0; }
	to   { opacity: 1; }
}

/* Staggered card reveal — apply to grid wrappers */
.tgb-grid .tgb-card,
.tgb-grid article,
.tgb-urgent-grid .tgb-urgent-tile {
	animation: fadeInUp 0.45s var(--ease-out) both;
}

.tgb-grid .tgb-card:nth-child(1),
.tgb-grid article:nth-child(1),
.tgb-urgent-grid .tgb-urgent-tile:nth-child(1) { animation-delay: 0.05s; }

.tgb-grid .tgb-card:nth-child(2),
.tgb-grid article:nth-child(2),
.tgb-urgent-grid .tgb-urgent-tile:nth-child(2) { animation-delay: 0.1s; }

.tgb-grid .tgb-card:nth-child(3),
.tgb-grid article:nth-child(3),
.tgb-urgent-grid .tgb-urgent-tile:nth-child(3) { animation-delay: 0.15s; }

.tgb-grid .tgb-card:nth-child(4),
.tgb-grid article:nth-child(4),
.tgb-urgent-grid .tgb-urgent-tile:nth-child(4) { animation-delay: 0.2s; }

.tgb-grid .tgb-card:nth-child(5),
.tgb-grid article:nth-child(5),
.tgb-urgent-grid .tgb-urgent-tile:nth-child(5) { animation-delay: 0.22s; }

/* Hero entrance */
.tgb-hero__text,
.tgb-vertical-hub__hero .tgb-container > * {
	animation: fadeInUp 0.6s var(--ease-out) both;
}

.tgb-hero__title  { animation-delay: 0.05s; }
.tgb-hero__subtitle { animation-delay: 0.12s; }
.tgb-journey-grid { animation: fadeInUp 0.6s var(--ease-out) 0.18s both; }

/* -----------------------------------------------------------------------------
   24b. Intelligence Archive (home.php — posts page at /intelligence/)
   ----------------------------------------------------------------------------- */

.tgb-intelligence-archive__hero {
	background-color: var(--colour-navy);
	background-image:
		radial-gradient(ellipse 70% 90% at 80% 0%, rgba(17 81 211 / 0.18) 0%, transparent 60%);
	padding-block: var(--space-16) var(--space-12);
}

.tgb-intelligence-archive__eyebrow {
	font-family: var(--font-heading);
	font-size: var(--scale-xs);
	font-weight: 700;
	letter-spacing: 0.12em;
	text-transform: uppercase;
	color: rgba(255 255 255 / 0.45);
	margin-bottom: var(--space-4);
}

.tgb-intelligence-archive__title {
	font-family: var(--font-editorial);
	font-size: clamp(var(--scale-2xl), 3.5vw, var(--scale-4xl));
	font-weight: 400;
	color: var(--colour-text-inverse);
	line-height: 1.15;
	letter-spacing: -0.01em;
	margin-bottom: var(--space-4);
	max-width: 680px;
}

.tgb-intelligence-archive__subtitle {
	font-size: var(--scale-base);
	color: rgba(255 255 255 / 0.6);
	line-height: 1.65;
	max-width: 560px;
	margin-bottom: var(--space-8);
}

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

.tgb-vertical-pill {
	display: inline-flex;
	align-items: center;
	padding: var(--space-2) var(--space-4);
	border-radius: 100px;
	font-family: var(--font-heading);
	font-size: var(--scale-xs);
	font-weight: 700;
	letter-spacing: 0.04em;
	text-decoration: none;
	color: var(--colour-text-inverse);
	background-color: rgba(255 255 255 / 0.08);
	border: 1px solid rgba(255 255 255 / 0.15);
	transition: background-color var(--transition), border-color var(--transition),
	            transform var(--transition);
}

.tgb-vertical-pill:hover {
	background-color: var(--pill-colour, rgba(255 255 255 / 0.15));
	border-color: transparent;
	color: var(--colour-text-inverse);
	transform: translateY(-1px);
}

/* Archive page header — used by generic archive.php (category/tag/format) */
.tgb-archive__header {
	margin-bottom: var(--space-10);
	padding-bottom: var(--space-8);
	border-bottom: 1px solid var(--colour-border);
}

.tgb-archive__title {
	font-family: var(--font-editorial);
	font-size: var(--scale-4xl);
	font-weight: 400;
	color: var(--colour-text-primary);
	letter-spacing: -0.02em;
	line-height: 1.15;
	margin-bottom: var(--space-2);
}

.tgb-archive__description {
	font-size: var(--scale-base);
	color: var(--colour-text-secondary);
	max-width: 560px;
}

/* ── Utilities ── */

.text-center  { text-align: center; }
.text-right   { text-align: right; }
.text-muted   { color: var(--colour-text-secondary); }
.text-inverse { color: var(--colour-text-inverse); }
.font-heading { font-family: var(--font-heading); }

.mt-auto  { margin-top: auto; }
.mb-0     { margin-bottom: 0 !important; }

.visually-hidden {
	position: absolute;
	width: 1px;
	height: 1px;
	padding: 0;
	margin: -1px;
	overflow: hidden;
	clip: rect(0, 0, 0, 0);
	white-space: nowrap;
	border-width: 0;
}

/* High-contrast mode adjustments */
@media (forced-colors: active) {
	.tgb-btn {
		border: 2px solid ButtonText;
	}
	.tgb-card {
		border: 1px solid ButtonText;
	}
}

/* ── Bundle contents + bundle upsell (single product) ───────────────────── */
.tgb-bundle-tools { list-style:none; margin:0; padding:0; display:grid; gap:.75rem; }
.tgb-bundle-tools__item { margin:0; }
.tgb-bundle-tools__link { display:block; padding:1rem 1.25rem; border:1px solid #e3e6ee; border-radius:10px; text-decoration:none; color:inherit; transition:border-color .15s, box-shadow .15s, transform .15s; }
.tgb-bundle-tools__link:hover { border-color:var(--product-colour,#1151D3); box-shadow:0 4px 18px rgba(17,81,211,.10); transform:translateY(-1px); }
.tgb-bundle-tools__head { display:flex; align-items:baseline; gap:.6rem; flex-wrap:wrap; }
.tgb-bundle-tools__name { font-weight:650; font-size:1.02rem; }
.tgb-bundle-tools__format { font-size:.72rem; text-transform:uppercase; letter-spacing:.04em; color:#6b7280; border:1px solid #d7dbe6; border-radius:999px; padding:.08rem .5rem; }
.tgb-bundle-tools__desc { display:block; margin-top:.3rem; color:#4b5565; font-size:.92rem; line-height:1.45; }

.tgb-bundle-upsell__lead { color:#4b5565; margin:0 0 1rem; }
.tgb-bundle-upsell__card { display:flex; align-items:center; justify-content:space-between; gap:1rem; padding:1rem 1.25rem; border:1.5px solid var(--product-colour,#1151D3); border-radius:12px; background:color-mix(in srgb, var(--product-colour,#1151D3) 6%, white); text-decoration:none; color:inherit; margin-bottom:.75rem; transition:background .15s, transform .15s; }
.tgb-bundle-upsell__card:hover { background:color-mix(in srgb, var(--product-colour,#1151D3) 12%, white); transform:translateY(-1px); }
.tgb-bundle-upsell__name { display:block; font-weight:700; font-size:1.05rem; }
.tgb-bundle-upsell__meta { display:block; margin-top:.2rem; color:#4b5565; font-size:.92rem; }
.tgb-bundle-upsell__cta { white-space:nowrap; font-weight:650; color:var(--product-colour,#1151D3); }

/* ── Intelligence-signal landing layout ─────────────────────────────── */
.tgb-signal__badges { display:flex; flex-wrap:wrap; align-items:center; gap:.5rem; margin-bottom:1rem; }

/* Materiality pill + tooltip */
.tgb-materiality-pill {
	display:inline-flex; align-items:center; gap:.4rem; padding:2px 12px; border-radius:100px;
	font-size:.78rem; font-weight:700; line-height:1.6; cursor:help; position:relative;
	color:var(--materiality-colour,#374151);
	background:color-mix(in srgb, var(--materiality-colour,#374151) 12%, white);
	border:1px solid color-mix(in srgb, var(--materiality-colour,#374151) 35%, white);
}
.tgb-materiality-pill::before {
	content:""; width:7px; height:7px; border-radius:50%; background:var(--materiality-colour,#374151);
}
.tgb-materiality-pill[data-tooltip]:hover::after,
.tgb-materiality-pill[data-tooltip]:focus::after {
	content:attr(data-tooltip); position:absolute; top:calc(100% + 8px); left:0; z-index:50;
	width:max-content; max-width:280px; white-space:normal; text-align:left;
	background:var(--colour-navy,#0B1F3A); color:#fff; font-size:.78rem; font-weight:500; line-height:1.45;
	padding:.5rem .7rem; border-radius:8px; box-shadow:0 6px 20px rgba(11,31,58,.25);
}

/* Sidebar CTA intro (matcher copy above the purchase box) */
.tgb-signal__cta-intro { margin-bottom:1rem; padding-top:.85rem; }
.tgb-signal__cta-head { margin:0 0 .35rem; font-weight:750; font-size:1.02rem; line-height:1.3; }
.tgb-signal__cta-line { margin:0; color:#4b5565; font-size:.92rem; line-height:1.5; }
.tgb-signal__product-name { margin:0 0 .5rem; font-weight:700; font-size:1.05rem; }
.tgb-signal__product-name a { color:inherit; text-decoration:none; }
.tgb-signal__product-name a:hover { text-decoration:underline; }

/* ============================================================
   Landing-page shared blocks (Events / Partnerships templates)
   ============================================================ */
.tgb-lp-hero-cta { display:flex; flex-wrap:wrap; gap:var(--space-3); margin-top:var(--space-6); }

.tgb-lp-head { text-align:center; max-width:46rem; margin:0 auto var(--space-8); }
.tgb-lp-head h2 { margin:0 0 var(--space-2); }
.tgb-lp-head p { margin:0; color:var(--colour-text-secondary); }
.tgb-lp-eyebrow { font-family:var(--font-heading); font-size:var(--scale-xs); font-weight:700; text-transform:uppercase; letter-spacing:.1em; color:var(--colour-text-muted); margin:0 0 var(--space-2); }

.tgb-lp-card { background:var(--colour-surface); border:1px solid var(--colour-border); border-radius:var(--radius-lg); padding:var(--space-6); }
.tgb-lp-card__title { font-family:var(--font-heading); font-size:var(--scale-lg); margin:0 0 var(--space-2); }
.tgb-lp-card__body { margin:0; color:var(--colour-text-secondary); line-height:1.6; font-size:var(--scale-sm); }

.tgb-lp-steps { display:flex; flex-direction:column; gap:var(--space-5); }
.tgb-lp-step { display:flex; gap:var(--space-4); align-items:flex-start; }
.tgb-lp-step__num { flex:0 0 auto; min-width:2.5rem; font-family:var(--font-heading); font-weight:700; font-size:var(--scale-xl); color:var(--colour-text-muted); }
.tgb-lp-step__title { font-family:var(--font-heading); font-size:var(--scale-base); margin:0 0 var(--space-1); }
.tgb-lp-step__body { margin:0; color:var(--colour-text-secondary); font-size:var(--scale-sm); line-height:1.6; }
.tgb-lp-feature-note { margin-top:var(--space-6); font-size:var(--scale-sm); font-style:italic; color:var(--colour-text-muted); }

.tgb-lp-next { display:flex; flex-wrap:wrap; align-items:center; justify-content:space-between; gap:var(--space-4); background:var(--colour-surface); border:1px solid var(--colour-border); border-left:4px solid var(--colour-navy); border-radius:var(--radius-lg); padding:var(--space-6); }
.tgb-lp-next__title { font-family:var(--font-heading); font-size:var(--scale-lg); margin:0; max-width:40rem; }
.tgb-lp-next__meta { margin:var(--space-2) 0 0; font-size:var(--scale-sm); color:var(--colour-text-muted); }

.tgb-lp-tier { display:flex; flex-direction:column; gap:var(--space-3); background:var(--colour-surface); border:1px solid var(--colour-border); border-radius:var(--radius-lg); padding:var(--space-6); }
.tgb-lp-tier--featured { border-width:2px; border-color:var(--colour-navy); }
.tgb-lp-tier__meta { margin:0; font-size:var(--scale-xs); text-transform:uppercase; letter-spacing:.08em; color:var(--colour-text-muted); }
.tgb-lp-tier__name { font-family:var(--font-heading); font-size:var(--scale-lg); margin:0; }
.tgb-lp-tier__list { list-style:none; margin:0; padding:0; display:flex; flex-direction:column; gap:var(--space-2); }
.tgb-lp-tier__list li { position:relative; padding-left:1.5em; font-size:var(--scale-sm); color:var(--colour-text-secondary); line-height:1.5; }
.tgb-lp-tier__list li::before { content:"\2713"; position:absolute; left:0; color:var(--colour-navy); font-weight:700; }

.tgb-lp-callout { background:var(--colour-surface); border:1px solid var(--colour-border); border-radius:var(--radius-lg); padding:var(--space-6); }
.tgb-lp-callout p { margin:0 0 var(--space-3); color:var(--colour-text-secondary); line-height:1.6; }
.tgb-lp-callout p:last-child { margin-bottom:0; }

.tgb-lp-quote { background:var(--colour-surface); border:1px solid var(--colour-border); border-radius:var(--radius-lg); padding:var(--space-6); }
.tgb-lp-quote__text { margin:0 0 var(--space-3); font-size:var(--scale-base); line-height:1.6; color:var(--colour-text-primary); }
.tgb-lp-quote__cite { margin:0; font-size:var(--scale-sm); color:var(--colour-text-muted); }
.tgb-lp-stat-strip { display:flex; flex-wrap:wrap; justify-content:center; gap:var(--space-6); margin-top:var(--space-6); }
.tgb-lp-stat { font-family:var(--font-heading); font-weight:700; font-size:var(--scale-base); color:var(--colour-navy); }

.tgb-lp-cta { text-align:center; }
.tgb-lp-cta .tgb-lp-hero-cta { justify-content:center; }

/* ============================================================
   Quarterly Report — single issue (gated reading view)
   ============================================================ */
.tgb-report-single__layout { display:grid; grid-template-columns:1fr; gap:var(--space-8); }
@media (min-width:900px){ .tgb-report-single__layout { grid-template-columns:minmax(0,1fr) 320px; align-items:start; } }
.tgb-report-single__lock { margin-top:var(--space-6); padding:var(--space-6); background:var(--colour-surface); border:1px solid var(--colour-border); border-left:4px solid var(--report-colour); border-radius:var(--radius-lg); }
.tgb-report-single__lock-title { font-family:var(--font-heading); font-size:var(--scale-lg); margin:0 0 var(--space-2); }
.tgb-report-single__lock-note { margin:0; color:var(--colour-text-secondary); }
.tgb-report-single__sidebar { position:sticky; top:var(--space-8); }
.tgb-report-buy { display:flex; flex-direction:column; gap:var(--space-6); }
.tgb-report-buy__opt { display:flex; flex-direction:column; gap:var(--space-2); }
.tgb-report-buy__opt + .tgb-report-buy__opt { padding-top:var(--space-6); border-top:1px solid var(--colour-border); }
.tgb-report-buy__label { font-family:var(--font-heading); font-weight:700; font-size:var(--scale-xs); text-transform:uppercase; letter-spacing:.06em; color:var(--colour-text-muted); margin:0; }
.tgb-report-buy__price { font-family:var(--font-heading); font-size:var(--scale-xl); font-weight:700; color:var(--colour-text-primary); margin:0; }
.tgb-report-buy__per { font-size:var(--scale-sm); font-weight:500; color:var(--colour-text-muted); }
.tgb-report-buy__desc { font-size:var(--scale-xs); color:var(--colour-text-secondary); margin:0 0 var(--space-1); }

/* Report archive cards + account panel */
.tgb-report-card { display:flex; flex-direction:column; gap:var(--space-2); text-decoration:none; border-top:3px solid var(--report-colour); transition:box-shadow .15s ease, transform .15s ease; }
.tgb-report-card:hover { box-shadow:var(--shadow); transform:translateY(-2px); }
.tgb-report-card__meta { font-family:var(--font-heading); font-weight:700; font-size:var(--scale-xs); text-transform:uppercase; letter-spacing:.06em; color:var(--colour-text-muted); }
.tgb-report-card .tgb-lp-card__title { display:block; }
.tgb-report-card .tgb-lp-card__body { display:block; }
.tgb-report-card__link { margin-top:auto; font-weight:600; font-size:var(--scale-sm); color:var(--report-colour); }
.tgb-report-card:hover .tgb-report-card__link { text-decoration:underline; }
.tgb-account-reports { margin-bottom:var(--space-8); padding:var(--space-6); border:1px solid var(--colour-border); border-radius:var(--radius-lg); background:var(--colour-surface); }
.tgb-account-reports h3 { margin-top:0; }
.tgb-account-reports ul { margin:0 0 var(--space-4); padding-left:1.2em; }
