/* ============================================================
   RGI Methodology Page Template

   Mirrors hero / ticker / layout / callout patterns from
   template-about.css 1:1 for visual consistency. RGI-specific
   sections (tier grid, feature grid, helplines, regulators)
   reuse pillar / tile patterns from About.

   Conventions:
   - 1280px container, 32px horizontal padding
   - 1fr + 280px sidebar grid, 32px gap
   - JS-based sticky sidebar (rgi-page.js), not CSS sticky
   - 0 !important, full [data-theme="dark"] coverage
   ============================================================ */

/* Tier color tokens (light mode) */
.gc-rgi {
	--rgi-poor-tc:        #EF4444;
	--rgi-poor-tb:        #FEE2E2;
	--rgi-concern-tc:     #F97316;
	--rgi-concern-tb:     #FFEDD5;
	--rgi-average-tc:     #CA8A04;
	--rgi-average-tb:     #FEF3C7;
	--rgi-great-tc:       #3B82F6;
	--rgi-great-tb:       #DBEAFE;
	--rgi-exceptional-tc: #16A34A;
	--rgi-exceptional-tb: #DCFCE7;
	background: #ffffff;
}

[data-theme="dark"] .gc-rgi {
	--rgi-poor-tc:        #FCA5A5;
	--rgi-poor-tb:        rgba(239, 68, 68, 0.14);
	--rgi-concern-tc:     #FDBA74;
	--rgi-concern-tb:     rgba(249, 115, 22, 0.14);
	--rgi-average-tc:     #FACC15;
	--rgi-average-tb:     rgba(202, 138, 4, 0.16);
	--rgi-great-tc:       #93C5FD;
	--rgi-great-tb:       rgba(59, 130, 246, 0.16);
	--rgi-exceptional-tc: #6EE7B7;
	--rgi-exceptional-tb: rgba(22, 163, 74, 0.16);
}

/* ============================================================
   HERO (white + subtle teal radial — matches About)
   ============================================================ */

.gc-rgi__hero {
	background: #ffffff;
	border-bottom: 0.5px solid var(--gc-border, #e5e7eb);
	position: relative;
	overflow: hidden;
}

.gc-rgi__hero::after {
	content: '';
	position: absolute;
	top: 0;
	right: 0;
	width: 50%;
	height: 100%;
	background: radial-gradient(ellipse 60% 80% at 100% 50%, rgba(0, 198, 174, 0.05) 0%, transparent 60%);
	pointer-events: none;
}

.gc-rgi__hero-content {
	max-width: 1280px;
	margin: 0 auto;
	padding: 56px 32px 36px;
	position: relative;
	z-index: 1;
}

.gc-rgi__hero-badge {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	padding: 5px 14px;
	background: var(--gc-primary-soft, #E6FAF7);
	border: 0.5px solid rgba(0, 198, 174, .3);
	color: var(--gc-primary-dark, #00A894);
	border-radius: 999px;
	font-size: 11px;
	font-weight: 800;
	letter-spacing: 0.4px;
	text-transform: uppercase;
	margin-bottom: 16px;
}

.gc-rgi__hero-badge-dot {
	width: 6px;
	height: 6px;
	background: #00A894;
	border-radius: 50%;
	flex-shrink: 0;
	animation: gc-rgi-pulse 2s ease-in-out infinite;
}

@keyframes gc-rgi-pulse {
	0%, 100% { opacity: 1; transform: scale(1); }
	50%      { opacity: 0.5; transform: scale(0.85); }
}

.gc-rgi__hero-title {
	font-family: var(--gc-font-display, 'Sora', sans-serif);
	font-size: clamp(32px, 4.5vw, 44px);
	font-weight: 700;
	color: var(--gc-navy, #0D1B3E);
	letter-spacing: -0.025em;
	line-height: 1.1;
	margin: 0 0 14px;
	max-width: 780px;
}

.gc-rgi__hero-accent {
	color: var(--gc-primary, #00C6AE);
}

.gc-rgi__hero-sub {
	font-size: 17px;
	line-height: 1.7;
	color: var(--gc-muted, #6b7280);
	max-width: 720px;
	margin: 0;
}

/* ===== Hero ticker bar (matches About 1:1) ===== */

.gc-rgi__hero-ticker {
	background: #F8FAFC;
	border-top: 0.5px solid var(--gc-border, #e5e7eb);
	border-bottom: 0.5px solid var(--gc-border, #e5e7eb);
}

.gc-rgi__hero-ticker-inner {
	max-width: 1280px;
	margin: 0 auto;
	padding: 16px 32px;
	display: flex;
	align-items: center;
	gap: 36px;
	flex-wrap: wrap;
}

.gc-rgi__hero-ticker-item {
	display: flex;
	flex-direction: column;
	gap: 2px;
}

.gc-rgi__hero-ticker-label {
	font-size: 11px;
	color: #9ca3af;
	text-transform: uppercase;
	letter-spacing: 1px;
	font-weight: 500;
}
/* Desktop: keep "Reviewed" on the same line with a normal space.
   The mobile rule flips this span to block so it wraps to its own line. */
.gc-rgi__lbl-break::before { content: " "; }

.gc-rgi__hero-ticker-value {
	font-family: var(--gc-font-display, 'Sora', sans-serif);
	font-size: 15px;
	font-weight: 600;
	color: var(--gc-navy, #0D1B3E);
	letter-spacing: -0.01em;
	line-height: 1.3;
}

/* ============================================================
   LAYOUT — main + sidebar right (matches About)
   ============================================================ */

.gc-rgi__layout {
	display: grid;
	grid-template-columns: minmax(0, 1fr) 280px;
	gap: 32px;
	max-width: 1280px;
	margin: 0 auto;
	padding: 32px 32px 80px;
	align-items: start;
	position: relative;
}

.gc-rgi__main {
	display: flex;
	flex-direction: column;
	gap: 36px;
	min-width: 0;
	margin-top:36px;
}

.gc-rgi .gc-single-sidebar {
	align-self: start;
	min-width: 0;
	position: relative;
}

.gc-rgi .gc-single-sidebar-inner {
	display: flex;
	flex-direction: column;
	gap: 16px;
}

/* Align the TOC top with the hero/stat content in the main column.
   The sticky widget starts ~40px low; pull it up to match. */
.gc-rgi .gc-toc-widget {
	top: 180px !important;
}

/* ============================================================
   SECTION HEADER (matches About)
   ============================================================ */

.gc-rgi__section {
	scroll-margin-top: 100px;
}

/* Sibling spacing — every child after the first gets a 16px gap.
   Margin collapse with sec-head's 20px margin-bottom keeps header
   spacing at 20px while non-header siblings get a tidy 16px. */
.gc-rgi__section > * + * {
	margin-top: 16px;
}

.gc-rgi__sec-head {
	display: flex;
	align-items: flex-start;
	gap: 12px;
	margin-bottom: 20px;
	padding-bottom: 14px;
	border-bottom: 0.5px solid var(--gc-border, #e5e7eb);
}

.gc-rgi__sec-num {
	width: 36px;
	height: 36px;
	border-radius: 9px;
	background: rgba(0, 198, 174, 0.1);
	color: var(--gc-primary-dark, #00A894);
	display: flex;
	align-items: center;
	justify-content: center;
	flex-shrink: 0;
	font-family: var(--gc-font-display, 'Sora', sans-serif);
	font-size: 13px;
	font-weight: 700;
	letter-spacing: 0.3px;
}

.gc-rgi__sec-num--arrow {
	font-size: 17px;
	font-weight: 600;
	letter-spacing: 0;
}

.gc-rgi__sec-title {
	font-family: var(--gc-font-display, 'Sora', sans-serif);
	font-size: 22px;
	font-weight: 700;
	color: var(--gc-navy, #0D1B3E);
	margin: 0;
	letter-spacing: -0.01em;
	line-height: 1.25;
}

.gc-rgi__sec-desc {
	font-size: 13px;
	color: var(--gc-muted, #6b7280);
	margin: 4px 0 0;
	line-height: 1.55;
}

/* ============================================================
   CALLOUTS (matches About — SVG icon + block title pattern)
   ============================================================ */

.gc-rgi__callout {
	border-radius: 10px;
	padding: 16px 20px;
	display: flex;
	align-items: flex-start;
	gap: 14px;
	font-size: 13.5px;
	line-height: 1.65;
}

.gc-rgi__callout--gold {
	background: rgba(245, 158, 11, 0.08);
	border: 0.5px solid rgba(245, 158, 11, 0.25);
	color: #92400E;
}

.gc-rgi__callout--gold svg {
	color: #B45309;
	flex-shrink: 0;
	margin-top: 1px;
}

.gc-rgi__callout--teal {
	background: rgba(0, 198, 174, 0.08);
	border: 0.5px solid rgba(0, 198, 174, 0.25);
	color: #04342C;
}

.gc-rgi__callout--teal svg {
	color: var(--gc-primary-dark, #00A894);
	flex-shrink: 0;
	margin-top: 1px;
}

.gc-rgi__callout-title {
	font-family: var(--gc-font-display, 'Sora', sans-serif);
	font-size: 14px;
	font-weight: 700;
	display: block;
	margin-bottom: 4px;
	color: inherit;
}

.gc-rgi__callout a {
	color: inherit;
	font-weight: 600;
	border-bottom: 0.5px solid currentColor;
	text-decoration: none;
}

/* ============================================================
   OVERVIEW PILLAR (RGI-specific intro card)
   ============================================================ */

.gc-rgi__overview {
	background: #ffffff;
	border: 0.5px solid var(--gc-border, #e5e7eb);
	border-radius: 12px;
	padding: 28px 30px;
}

.gc-rgi__overview-eyebrow {
	display: inline-flex;
	align-items: center;
	background: rgba(0, 198, 174, 0.12);
	color: #04342C;
	font-size: 11px;
	font-weight: 500;
	padding: 5px 14px;
	border-radius: 999px;
	margin-bottom: 14px;
	text-transform: uppercase;
	letter-spacing: 0.4px;
}

.gc-rgi__overview-title {
	font-family: var(--gc-font-display, 'Sora', sans-serif);
	font-size: 24px;
	font-weight: 700;
	color: var(--gc-navy, #0D1B3E);
	letter-spacing: -0.02em;
	margin: 0 0 12px;
	line-height: 1.2;
}

.gc-rgi__overview-accent {
	color: var(--gc-primary, #00C6AE);
}

.gc-rgi__overview-desc {
	font-size: 15px;
	line-height: 1.75;
	color: #374151;
	margin: 0 0 14px;
}

.gc-rgi__overview-desc:last-of-type {
	margin-bottom: 18px;
}

.gc-rgi__overview-desc strong {
	color: var(--gc-navy, #0D1B3E);
	font-weight: 600;
}

.gc-rgi__overview-meta {
	display: grid;
	grid-template-columns: repeat(3, minmax(0, 1fr));
	gap: 10px;
	margin-top: 4px;
}

.gc-rgi__meta-card {
	background: #F8FAFC;
	border: 0.5px solid var(--gc-border, #e5e7eb);
	border-radius: 10px;
	padding: 14px 16px;
}

.gc-rgi__meta-card--highlight {
	background: rgba(0, 198, 174, 0.06);
	border-color: rgba(0, 198, 174, 0.25);
}

.gc-rgi__meta-lbl {
	font-family: var(--gc-font-display, 'Sora', sans-serif);
	font-size: 10px;
	font-weight: 700;
	color: var(--gc-muted, #6b7280);
	text-transform: uppercase;
	letter-spacing: 1.2px;
	margin-bottom: 6px;
}

.gc-rgi__meta-card--highlight .gc-rgi__meta-lbl {
	color: var(--gc-primary-dark, #00A894);
}

.gc-rgi__meta-val {
	font-size: 12.5px;
	color: #374151;
	line-height: 1.6;
}

/* ============================================================
   TIER GRID — Variant D (5 cards, clean white, no top stripe)
   ============================================================ */

.gc-rgi__tier-grid {
	display: grid;
	grid-template-columns: repeat(5, minmax(0, 1fr));
	gap: 8px;
}

.gc-rgi__tier-card {
	background: #ffffff;
	border: 0.5px solid var(--gc-border, #e5e7eb);
	border-radius: 10px;
	padding: 16px 14px 15px;
	transition: border-color 180ms ease, box-shadow 180ms ease;
}

.gc-rgi__tier-card:hover {
	border-color: var(--tc);
	box-shadow: 0 6px 16px rgba(13, 27, 62, 0.05);
}

.gc-rgi__tier-card--poor        { --tc: var(--rgi-poor-tc);        --tb: var(--rgi-poor-tb); }
.gc-rgi__tier-card--concern     { --tc: var(--rgi-concern-tc);     --tb: var(--rgi-concern-tb); }
.gc-rgi__tier-card--average     { --tc: var(--rgi-average-tc);     --tb: var(--rgi-average-tb); }
.gc-rgi__tier-card--great       { --tc: var(--rgi-great-tc);       --tb: var(--rgi-great-tb); }
.gc-rgi__tier-card--exceptional { --tc: var(--rgi-exceptional-tc); --tb: var(--rgi-exceptional-tb); }

.gc-rgi__tier-eyebrow {
	font-family: var(--gc-font-display, 'Sora', sans-serif);
	font-size: 10px;
	font-weight: 700;
	letter-spacing: 1.2px;
	text-transform: uppercase;
	color: #9ca3af;
	margin-bottom: 9px;
}

.gc-rgi__tier-range {
	display: inline-block;
	font-family: var(--gc-font-display, 'Sora', sans-serif);
	font-size: 10.5px;
	font-weight: 700;
	background: var(--tb);
	color: var(--tc);
	padding: 3px 10px;
	border-radius: 999px;
	margin-bottom: 10px;
}

.gc-rgi__tier-label {
	font-family: var(--gc-font-display, 'Sora', sans-serif);
	font-size: 15px;
	font-weight: 700;
	color: var(--tc);
	letter-spacing: -0.01em;
	margin-bottom: 7px;
	line-height: 1.2;
}

.gc-rgi__tier-desc {
	font-size: 12px;
	color: var(--gc-muted, #6b7280);
	line-height: 1.55;
	margin: 0;
}

/* ============================================================
   FEATURE GRID (12 criteria cards, 3-col)
   ============================================================ */

.gc-rgi__feat-grid {
	display: grid;
	grid-template-columns: repeat(3, minmax(0, 1fr));
	gap: 10px;
}

.gc-rgi__feat-card {
	background: #ffffff;
	border: 0.5px solid var(--gc-border, #e5e7eb);
	border-radius: 10px;
	padding: 16px 16px 15px;
	transition: border-color 180ms ease, box-shadow 180ms ease;
}

.gc-rgi__feat-card:hover {
	border-color: rgba(0, 198, 174, 0.4);
	box-shadow: 0 6px 16px rgba(13, 27, 62, 0.05);
}

.gc-rgi__feat-num {
	font-family: var(--gc-font-display, 'Sora', sans-serif);
	font-size: 10px;
	font-weight: 700;
	color: var(--gc-primary-dark, #00A894);
	letter-spacing: 1.2px;
	text-transform: uppercase;
	margin-bottom: 8px;
}

.gc-rgi__feat-title {
	font-family: var(--gc-font-display, 'Sora', sans-serif);
	font-size: 14px;
	font-weight: 700;
	color: var(--gc-navy, #0D1B3E);
	letter-spacing: -0.01em;
	line-height: 1.3;
	margin: 0 0 7px;
}

.gc-rgi__feat-desc {
	font-size: 12px;
	color: var(--gc-muted, #6b7280);
	line-height: 1.6;
	margin: 0;
}

/* ============================================================
   METHOD GRID (4 integrity pillars, 2-col)
   ============================================================ */

.gc-rgi__method-grid {
	display: grid;
	grid-template-columns: repeat(2, minmax(0, 1fr));
	gap: 10px;
}

.gc-rgi__method-row {
	display: flex;
	align-items: flex-start;
	gap: 14px;
	background: #ffffff;
	border: 0.5px solid var(--gc-border, #e5e7eb);
	border-radius: 10px;
	padding: 16px 18px;
	transition: border-color 180ms ease, box-shadow 180ms ease;
}

.gc-rgi__method-row:hover {
	border-color: rgba(0, 198, 174, 0.4);
	box-shadow: 0 6px 16px rgba(13, 27, 62, 0.05);
}

.gc-rgi__method-num {
	width: 30px;
	height: 30px;
	border-radius: 50%;
	background: rgba(0, 198, 174, 0.1);
	color: var(--gc-primary-dark, #00A894);
	display: flex;
	align-items: center;
	justify-content: center;
	font-family: var(--gc-font-display, 'Sora', sans-serif);
	font-size: 11px;
	font-weight: 800;
	flex-shrink: 0;
}

.gc-rgi__method-content {
	flex: 1;
	min-width: 0;
}

.gc-rgi__method-title {
	font-family: var(--gc-font-display, 'Sora', sans-serif);
	font-size: 14px;
	font-weight: 700;
	color: var(--gc-navy, #0D1B3E);
	letter-spacing: -0.01em;
	line-height: 1.3;
	margin: 0 0 5px;
}

.gc-rgi__method-desc {
	font-size: 12px;
	color: var(--gc-muted, #6b7280);
	line-height: 1.6;
	margin: 0;
}

/* ============================================================
   ANNUAL REPORT CARD
   ============================================================ */

.gc-rgi__report {
	background: #ffffff;
	border: 0.5px solid var(--gc-border, #e5e7eb);
	border-radius: 12px;
	padding: 28px 30px;
}

.gc-rgi__report-eyebrow {
	display: inline-flex;
	align-items: center;
	background: rgba(0, 198, 174, 0.12);
	color: #04342C;
	font-size: 11px;
	font-weight: 500;
	padding: 5px 14px;
	border-radius: 999px;
	margin-bottom: 14px;
	text-transform: uppercase;
	letter-spacing: 0.4px;
}

.gc-rgi__report-title {
	font-family: var(--gc-font-display, 'Sora', sans-serif);
	font-size: 22px;
	font-weight: 700;
	color: var(--gc-navy, #0D1B3E);
	letter-spacing: -0.02em;
	line-height: 1.25;
	margin: 0 0 12px;
}

.gc-rgi__report-desc {
	font-size: 14.5px;
	line-height: 1.75;
	color: #374151;
	margin: 0 0 18px;
}

/* ============================================================
   HELP GRID (6 region cards, 2-col)
   ============================================================ */

.gc-rgi__help-grid {
	display: grid;
	grid-template-columns: repeat(2, minmax(0, 1fr));
	gap: 12px;
}

.gc-rgi__help-card {
	background: #ffffff;
	border: 0.5px solid var(--gc-border, #e5e7eb);
	border-radius: 12px;
	padding: 18px 20px 16px;
	transition: border-color 180ms ease, box-shadow 180ms ease;
}

.gc-rgi__help-card:hover {
	border-color: rgba(0, 198, 174, 0.4);
	box-shadow: 0 6px 16px rgba(13, 27, 62, 0.05);
}

.gc-rgi__help-region {
	font-family: var(--gc-font-display, 'Sora', sans-serif);
	font-size: 13px;
	font-weight: 700;
	color: var(--gc-navy, #0D1B3E);
	letter-spacing: -0.005em;
	line-height: 1.4;
	margin: 0 0 14px;
	padding-bottom: 10px;
	border-bottom: 0.5px solid var(--gc-border, #e5e7eb);
}

.gc-rgi__help-orgs {
	display: flex;
	flex-direction: column;
	gap: 12px;
}

.gc-rgi__help-org {
	display: flex;
	flex-direction: column;
	gap: 2px;
}

.gc-rgi__help-org-name {
	font-family: var(--gc-font-display, 'Sora', sans-serif);
	font-size: 13px;
	font-weight: 600;
	color: var(--gc-primary-dark, #00A894);
	text-decoration: none;
	letter-spacing: -0.005em;
	line-height: 1.4;
	transition: color 180ms ease;
}

.gc-rgi__help-org-name:hover {
	color: var(--gc-primary, #00C6AE);
	text-decoration: underline;
}

.gc-rgi__help-org-desc {
	font-size: 12px;
	color: var(--gc-muted, #6b7280);
	line-height: 1.55;
	margin: 0;
}

/* ============================================================
   REG GRID (16 regulator cards, 3-col)
   ============================================================ */

.gc-rgi__reg-grid {
	display: grid;
	grid-template-columns: repeat(3, minmax(0, 1fr));
	gap: 10px;
}

.gc-rgi__reg-card {
	display: flex;
	flex-direction: column;
	gap: 4px;
	background: #ffffff;
	border: 0.5px solid var(--gc-border, #e5e7eb);
	border-radius: 10px;
	padding: 14px 16px;
	text-decoration: none;
	transition: border-color 180ms ease, box-shadow 180ms ease, transform 180ms ease;
}

.gc-rgi__reg-card:hover {
	border-color: rgba(0, 198, 174, 0.4);
	box-shadow: 0 6px 16px rgba(13, 27, 62, 0.05);
	transform: translateY(-2px);
}

.gc-rgi__reg-abbr {
	font-family: var(--gc-font-display, 'Sora', sans-serif);
	font-size: 10.5px;
	font-weight: 700;
	color: var(--gc-primary-dark, #00A894);
	letter-spacing: 1.2px;
	text-transform: uppercase;
}

.gc-rgi__reg-name {
	font-family: var(--gc-font-display, 'Sora', sans-serif);
	font-size: 13.5px;
	font-weight: 700;
	color: var(--gc-navy, #0D1B3E);
	letter-spacing: -0.01em;
	line-height: 1.35;
}

.gc-rgi__reg-desc {
	font-size: 11.5px;
	color: var(--gc-muted, #6b7280);
	line-height: 1.55;
	margin: 4px 0 0;
}

/* ============================================================
   CTA ROW (3-col, matches About cta pattern)
   ============================================================ */

.gc-rgi__cta-row {
	display: grid;
	grid-template-columns: repeat(3, minmax(0, 1fr));
	gap: 12px;
}

.gc-rgi__cta-card {
	background: #ffffff;
	border: 0.5px solid var(--gc-border, #e5e7eb);
	border-radius: 10px;
	padding: 22px 24px;
	text-decoration: none;
	transition: border-color 180ms ease, box-shadow 180ms ease, transform 180ms ease;
	display: flex;
	flex-direction: column;
}

.gc-rgi__cta-card:hover {
	border-color: rgba(0, 198, 174, 0.4);
	box-shadow: 0 6px 16px rgba(13, 27, 62, 0.05);
	transform: translateY(-2px);
}

.gc-rgi__cta-name {
	font-family: var(--gc-font-display, 'Sora', sans-serif);
	font-size: 15px;
	font-weight: 700;
	color: var(--gc-navy, #0D1B3E);
	margin-bottom: 7px;
	letter-spacing: -0.01em;
}

.gc-rgi__cta-desc {
	font-size: 12.5px;
	color: var(--gc-muted, #6b7280);
	line-height: 1.6;
	margin: 0 0 14px;
	flex: 1;
}

.gc-rgi__cta-link {
	font-family: var(--gc-font-display, 'Sora', sans-serif);
	font-size: 12.5px;
	font-weight: 600;
	color: var(--gc-primary-dark, #00A894);
	letter-spacing: -0.005em;
}

/* ============================================================
   BUTTON (Annual Report CTA)
   ============================================================ */

.gc-rgi__btn {
	font-family: var(--gc-font-display, 'Sora', sans-serif);
	font-size: 13.5px;
	font-weight: 700;
	padding: 12px 22px;
	border-radius: 9px;
	text-decoration: none;
	display: inline-flex;
	align-items: center;
	gap: 7px;
	transition: all 180ms ease;
	letter-spacing: -0.005em;
	border: 0.5px solid transparent;
	cursor: pointer;
	align-self: flex-start;
}

.gc-rgi__btn--primary {
	background: var(--gc-primary, #00C6AE);
	color: #ffffff;
}

.gc-rgi__btn--primary:hover {
	background: var(--gc-primary-dark, #00A894);
	transform: translateY(-1px);
	box-shadow: 0 4px 14px rgba(0, 198, 174, 0.25);
	color: #ffffff;
}

/* ============================================================
   RESPONSIVE (matches About breakpoints)
   ============================================================ */

@media (max-width: 1100px) {
	.gc-rgi__layout {
		grid-template-columns: minmax(0, 1fr) 240px;
		gap: 24px;
		padding: 28px 24px 60px;
	}
	.gc-rgi__hero-content,
	.gc-rgi__hero-ticker-inner {
		padding-left: 24px;
		padding-right: 24px;
	}
	.gc-rgi__hero-ticker-inner {
		gap: 24px;
	}
	.gc-rgi__feat-grid,
	.gc-rgi__reg-grid {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}
}

@media (max-width: 900px) {
	.gc-rgi__layout {
		grid-template-columns: 1fr;
		gap: 24px;
	}
	.gc-rgi .gc-single-sidebar {
		display: none;
	}
	.gc-rgi__hero-content {
		padding: 48px 24px 32px;
	}
	.gc-rgi__overview {
		padding: 24px 22px;
	}
	.gc-rgi__overview-title {
		font-size: 22px;
	}
	.gc-rgi__overview-meta,
	.gc-rgi__method-grid,
	.gc-rgi__help-grid,
	.gc-rgi__cta-row {
		grid-template-columns: 1fr;
	}
	.gc-rgi__tier-grid {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}
	.gc-rgi__tier-card:last-child {
		grid-column: 1 / -1;
	}
	.gc-rgi__report {
		padding: 22px 20px;
	}
	.gc-rgi__report-title {
		font-size: 19px;
	}
}

@media (max-width: 700px) {
	.gc-rgi__hero-content,
	.gc-rgi__hero-ticker-inner {
		padding-left: 20px;
		padding-right: 20px;
	}
	.gc-rgi__layout {
		padding: 20px 16px 56px;
	}
	.gc-rgi__hero-content {
		padding: 40px 20px 28px;
	}
	.gc-rgi__hero-ticker-inner {
		display: grid;
		grid-template-columns: repeat(3, minmax(0, 1fr));
		gap: 18px 16px;
		align-items: start;
	}
	.gc-rgi__lbl-break {
		display: block;
	}
	.gc-rgi__lbl-break::before { content: none; }
	.gc-rgi__sec-title {
		font-size: 19px;
	}
	.gc-rgi__sec-num {
		width: 32px;
		height: 32px;
		font-size: 12px;
	}
	.gc-rgi__feat-grid,
	.gc-rgi__reg-grid,
	.gc-rgi__tier-grid {
		grid-template-columns: 1fr;
	}
	.gc-rgi__tier-card:last-child {
		grid-column: auto;
	}
	.gc-rgi__overview {
		padding: 20px 18px;
	}
	.gc-rgi__overview-title {
		font-size: 20px;
	}
	.gc-rgi__report {
		padding: 20px 18px;
	}
}

/* ============================================================
   DARK MODE
   ============================================================ */

[data-theme="dark"] .gc-rgi,
[data-theme="dark"] .gc-rgi__hero {
	background: transparent;
}

[data-theme="dark"] .gc-rgi__hero {
	border-color: rgba(255, 255, 255, 0.06);
}

[data-theme="dark"] .gc-rgi__hero-ticker {
	background: rgba(255, 255, 255, 0.02);
	border-color: rgba(255, 255, 255, 0.06);
}

[data-theme="dark"] .gc-rgi__hero-title,
[data-theme="dark"] .gc-rgi__sec-title,
[data-theme="dark"] .gc-rgi__hero-ticker-value,
[data-theme="dark"] .gc-rgi__overview-title,
[data-theme="dark"] .gc-rgi__meta-val,
[data-theme="dark"] .gc-rgi__feat-title,
[data-theme="dark"] .gc-rgi__method-title,
[data-theme="dark"] .gc-rgi__report-title,
[data-theme="dark"] .gc-rgi__help-region,
[data-theme="dark"] .gc-rgi__reg-name,
[data-theme="dark"] .gc-rgi__cta-name {
	color: #ffffff;
}

[data-theme="dark"] .gc-rgi__hero-sub,
[data-theme="dark"] .gc-rgi__sec-desc,
[data-theme="dark"] .gc-rgi__hero-ticker-label,
[data-theme="dark"] .gc-rgi__overview-desc,
[data-theme="dark"] .gc-rgi__tier-desc,
[data-theme="dark"] .gc-rgi__feat-desc,
[data-theme="dark"] .gc-rgi__method-desc,
[data-theme="dark"] .gc-rgi__report-desc,
[data-theme="dark"] .gc-rgi__help-org-desc,
[data-theme="dark"] .gc-rgi__reg-desc,
[data-theme="dark"] .gc-rgi__cta-desc {
	color: rgba(255, 255, 255, 0.65);
}

[data-theme="dark"] .gc-rgi__overview,
[data-theme="dark"] .gc-rgi__tier-card,
[data-theme="dark"] .gc-rgi__feat-card,
[data-theme="dark"] .gc-rgi__method-row,
[data-theme="dark"] .gc-rgi__report,
[data-theme="dark"] .gc-rgi__help-card,
[data-theme="dark"] .gc-rgi__reg-card,
[data-theme="dark"] .gc-rgi__cta-card {
	background: var(--gc-bg-soft);
	border-color: rgba(255, 255, 255, 0.06);
}

[data-theme="dark"] .gc-rgi__meta-card {
	background: rgba(255, 255, 255, 0.03);
	border-color: rgba(255, 255, 255, 0.06);
}

[data-theme="dark"] .gc-rgi__meta-card--highlight {
	background: rgba(0, 198, 174, 0.10);
	border-color: rgba(0, 198, 174, 0.30);
}

[data-theme="dark"] .gc-rgi__overview-desc strong {
	color: #ffffff;
}

[data-theme="dark"] .gc-rgi__callout--gold {
	background: rgba(245, 158, 11, 0.06);
	border-color: rgba(245, 158, 11, 0.20);
	color: rgba(255, 255, 255, 0.78);
}
[data-theme="dark"] .gc-rgi__callout--gold .gc-rgi__callout-title {
	color: #FCD34D;
}
[data-theme="dark"] .gc-rgi__callout--gold svg {
	color: #FCD34D;
}

[data-theme="dark"] .gc-rgi__callout--teal {
	color: rgba(255, 255, 255, 0.85);
}
/* ── Dark mode: teal eyebrow badges ── */
[data-theme="dark"] .gc-rgi__overview-eyebrow,
[data-theme="dark"] .gc-rgi__report-eyebrow {
	background: rgba(0, 198, 174, 0.08);
	color: #7DD3C8;
}

/* ── Dark mode: hero eyebrow badge — match iHub (subtle teal pill) ── */
[data-theme="dark"] .gc-rgi__hero-badge {
	background: rgba(0, 198, 174, 0.08);
	border-color: rgba(0, 198, 174, 0.20);
	color: #7DD3C8;
}
[data-theme="dark"] .gc-rgi__hero-badge-dot {
	background: #7DD3C8;
}