/* ============================================================
 * template-glossary.css
 * GC – Glossary Hub  (Page Template: template-glossary.php)
 *
 * Path:  gc-theme/assets/css/templates/template-glossary.css
 * Loaded conditionally from inc/enqueue.php when the Glossary page is shown.
 *
 * Design DNA: 1:1 with gc-about (template-about.css)
 *   - White everywhere
 *   - 0.5px borders
 *   - Inline line SVG icons via PHP helpers (no emoji, no library)
 *   - Single teal accent (no per-category multi-color theming)
 *   - Pulse-dot badge
 *   - Numbered sections (01 / 02 / 03 / 04)
 *   - 1280px container
 *   - Sora display / Inter body
 *
 * Conventions:
 *   - Base tokens (--gc-primary, --gc-navy, --gc-muted, etc.) come from style.css
 *   - Zero !important
 *   - Zero inline styles in the template
 *   - All state changes use a class (.is-on / .is-hidden)
 * ========================================================== */


.gc-glossary { background: #ffffff; }


/* HERO -------------------------------------------------------- */
.gc-glossary__hero {
	background: #ffffff;
	border-bottom: 0.5px solid var(--gc-border, #e5e7eb);
	position: relative;
	overflow: hidden;
}
.gc-glossary__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-glossary__hero-content {
	max-width: 1280px;
	margin: 0 auto;
	padding: 56px 32px 36px;
	position: relative;
	z-index: 1;
}

.gc-glossary__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-glossary__hero-badge-dot {
	width: 6px;
	height: 6px;
	background: var(--gc-primary-dark, #00A894);
	border-radius: 50%;
	flex-shrink: 0;
	animation: gc-glossary-pulse 2s ease-in-out infinite;
}
@keyframes gc-glossary-pulse {
	0%, 100% { opacity: 1;   transform: scale(1); }
	50%      { opacity: 0.5; transform: scale(0.85); }
}

.gc-glossary__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: 880px;
}
.gc-glossary__hero-accent { color: var(--gc-primary, #00C6AE); }

.gc-glossary__hero-sub {
	font-size: 17px;
	line-height: 1.7;
	color: var(--gc-muted, #6b7280);
	max-width: 760px;
	margin: 0 0 28px;
}


/* HERO JUMP CARDS (1 per category, max 4-5) ------------------- */
.gc-glossary__hero-jumps {
	display: grid;
	grid-template-columns: repeat(4, minmax(0, 1fr));
	gap: 10px;
	margin-top: 28px;
}
.gc-glossary__jump {
	background: #ffffff;
	border: 0.5px solid var(--gc-border, #e5e7eb);
	border-radius: 10px;
	padding: 14px 16px;
	display: flex;
	align-items: center;
	gap: 12px;
	text-decoration: none;
	transition: all 180ms ease;
}
.gc-glossary__jump:hover {
	border-color: rgba(0, 198, 174, 0.4);
	transform: translateY(-2px);
	box-shadow: 0 6px 16px rgba(13, 27, 62, 0.05);
}
.gc-glossary__jump:focus-visible {
	outline: 2px solid var(--gc-primary, #00C6AE);
	outline-offset: 2px;
}
.gc-glossary__jump-icon {
	width: 36px;
	height: 36px;
	border-radius: 9px;
	background: rgba(0, 198, 174, 0.10);
	color: var(--gc-primary-dark, #00A894);
	display: flex;
	align-items: center;
	justify-content: center;
	flex-shrink: 0;
}
.gc-glossary__jump-text {
	flex: 1;
	display: flex;
	flex-direction: column;
	gap: 1px;
	min-width: 0;
}
.gc-glossary__jump-name {
	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.2;
}
.gc-glossary__jump-count {
	font-size: 11px;
	color: var(--gc-muted, #6b7280);
	font-variant-numeric: tabular-nums;
}
.gc-glossary__jump-arrow {
	color: #cbd5e1;
	flex-shrink: 0;
	transition: color 180ms ease, transform 180ms ease;
}
.gc-glossary__jump:hover .gc-glossary__jump-arrow {
	color: var(--gc-primary-dark, #00A894);
	transform: translate(2px, -2px);
}


/* TICKER ------------------------------------------------------ */
.gc-glossary__ticker {
	background: #F8FAFC;
	border-top: 0.5px solid var(--gc-border, #e5e7eb);
	border-bottom: 0.5px solid var(--gc-border, #e5e7eb);
}
.gc-glossary__ticker-inner {
	max-width: 1280px;
	margin: 0 auto;
	padding: 16px 32px;
	display: flex;
	align-items: center;
	gap: 36px;
	flex-wrap: wrap;
}
.gc-glossary__ticker-item {
	display: flex;
	flex-direction: column;
	gap: 2px;
}
.gc-glossary__ticker-label {
	font-size: 11px;
	color: #9ca3af;
	text-transform: uppercase;
	letter-spacing: 1px;
	font-weight: 500;
}
.gc-glossary__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;
	font-variant-numeric: tabular-nums;
}


/* TOOLBAR (sticky) -------------------------------------------- */
.gc-glossary__toolbar {
	position: sticky;
	top: 0;
	z-index: 50;
	background: rgba(255, 255, 255, 0.95);
	backdrop-filter: saturate(180%) blur(8px);
	-webkit-backdrop-filter: saturate(180%) blur(8px);
	border-bottom: 0.5px solid var(--gc-border, #e5e7eb);
}
.gc-glossary__toolbar-inner {
	max-width: 1280px;
	margin: 0 auto;
	padding: 14px 32px;
	display: flex;
	align-items: center;
	gap: 12px;
	flex-wrap: wrap;
}

.gc-glossary__search {
	flex: 1;
	min-width: 220px;
	position: relative;
	display: flex;
	align-items: center;
}
.gc-glossary__search-icon {
	position: absolute;
	left: 14px;
	top: 50%;
	transform: translateY(-50%);
	color: #9ca3af;
	pointer-events: none;
}
.gc-glossary__search input {
	width: 100%;
	padding: 10px 14px 10px 40px;
	border: 0.5px solid var(--gc-border, #e5e7eb);
	border-radius: 9px;
	font-family: var(--gc-font-body, 'Inter', sans-serif);
	font-size: 13.5px;
	color: var(--gc-navy, #0D1B3E);
	background: #ffffff;
	transition: border-color 150ms ease, box-shadow 150ms ease;
}
.gc-glossary__search input::placeholder { color: #9ca3af; }
.gc-glossary__search input:focus {
	outline: none;
	border-color: var(--gc-primary, #00C6AE);
	box-shadow: 0 0 0 3px rgba(0, 198, 174, 0.12);
}

/* Chip tabs — about-page aw-tabs style */
.gc-glossary__chips {
	display: flex;
	gap: 4px;
	background: #F8FAFC;
	padding: 5px;
	border: 0.5px solid var(--gc-border, #e5e7eb);
	border-radius: 10px;
	flex-wrap: wrap;
}
.gc-glossary__chip {
	padding: 7px 13px;
	font-size: 12px;
	font-weight: 600;
	color: var(--gc-muted, #6b7280);
	background: transparent;
	border: 0;
	border-radius: 7px;
	font-family: var(--gc-font-display, 'Sora', sans-serif);
	display: flex;
	align-items: center;
	gap: 7px;
	letter-spacing: -0.005em;
	transition: all 150ms ease;
	cursor: pointer;
}
.gc-glossary__chip:hover:not(.is-on) { color: var(--gc-primary-dark, #00A894); }
.gc-glossary__chip.is-on {
	background: #ffffff;
	color: var(--gc-navy, #0D1B3E);
	box-shadow: 0 1px 3px rgba(13, 27, 62, 0.06);
}
.gc-glossary__chip-count {
	display: inline-block;
	padding: 1px 7px;
	background: rgba(13, 27, 62, 0.06);
	color: var(--gc-muted, #6b7280);
	border-radius: 999px;
	font-size: 10px;
	font-weight: 600;
	font-variant-numeric: tabular-nums;
}
.gc-glossary__chip.is-on .gc-glossary__chip-count {
	background: var(--gc-primary-dark, #00A894);
	color: #ffffff;
}

.gc-glossary__clear {
	padding: 8px 13px;
	background: transparent;
	border: 0.5px solid var(--gc-border, #e5e7eb);
	border-radius: 9px;
	font-family: var(--gc-font-display, 'Sora', sans-serif);
	font-size: 12px;
	font-weight: 600;
	color: var(--gc-muted, #6b7280);
	cursor: pointer;
	transition: border-color 150ms ease, color 150ms ease;
}
.gc-glossary__clear:hover {
	border-color: var(--gc-navy, #0D1B3E);
	color: var(--gc-navy, #0D1B3E);
}

.gc-glossary__count {
	font-size: 12px;
	color: #9ca3af;
	font-weight: 600;
	margin-left: auto;
	font-variant-numeric: tabular-nums;
}


/* MAIN WRAP --------------------------------------------------- */
.gc-glossary__wrap {
	max-width: 1280px;
	margin: 0 auto;
	padding: 36px 32px 80px;
	display: flex;
	flex-direction: column;
	gap: 36px;
}

.gc-glossary__about {
	background: #ffffff;
	border: 0.5px solid var(--gc-border, #e5e7eb);
	border-radius: 12px;
	padding: 24px 28px;
}
.gc-glossary__about h2 {
	font-family: var(--gc-font-display, 'Sora', sans-serif);
	font-size: 16px;
	font-weight: 700;
	color: var(--gc-navy, #0D1B3E);
	margin: 0 0 10px;
	letter-spacing: -0.01em;
}
.gc-glossary__about p {
	font-size: 13.5px;
	color: var(--gc-muted, #6b7280);
	line-height: 1.8;
	margin: 0 0 8px;
}
.gc-glossary__about p:last-child { margin: 0; }
.gc-glossary__about strong { color: var(--gc-navy, #0D1B3E); font-weight: 600; }
.gc-glossary__about a {
	color: var(--gc-primary-dark, #00A894);
	font-weight: 600;
	text-decoration: none;
	border-bottom: 0.5px solid rgba(0, 168, 148, 0.3);
	transition: border-color 150ms ease;
}
.gc-glossary__about a:hover { border-bottom-color: var(--gc-primary-dark, #00A894); }

.gc-glossary__empty {
	padding: 48px 24px;
	text-align: center;
	color: var(--gc-muted, #6b7280);
	background: #ffffff;
	border: 0.5px dashed var(--gc-border, #e5e7eb);
	border-radius: 12px;
}
.gc-glossary__empty h3 {
	font-family: var(--gc-font-display, 'Sora', sans-serif);
	font-size: 15px;
	font-weight: 700;
	color: var(--gc-navy, #0D1B3E);
	margin: 0 0 6px;
	letter-spacing: -0.01em;
}
.gc-glossary__empty p { font-size: 13px; margin: 0; }


/* CATEGORY SECTION -------------------------------------------- */
.gc-glossary__cat { scroll-margin-top: 100px; }

.gc-glossary__cat-head {
	display: flex;
	gap: 14px;
	align-items: flex-start;
	margin-bottom: 18px;
	padding-bottom: 14px;
	border-bottom: 0.5px solid var(--gc-border, #e5e7eb);
}
.gc-glossary__cat-icon {
	width: 36px;
	height: 36px;
	border-radius: 9px;
	background: rgba(0, 198, 174, 0.10);
	color: var(--gc-primary-dark, #00A894);
	display: flex;
	align-items: center;
	justify-content: center;
	flex-shrink: 0;
}
.gc-glossary__cat-meta {
	flex: 1;
	min-width: 0;
}
.gc-glossary__cat-title-row {
	display: flex;
	align-items: center;
	gap: 10px;
	margin-bottom: 4px;
	flex-wrap: wrap;
}
.gc-glossary__cat-num {
	font-family: var(--gc-font-display, 'Sora', sans-serif);
	font-size: 11px;
	font-weight: 700;
	color: var(--gc-primary-dark, #00A894);
	letter-spacing: 0.5px;
	font-variant-numeric: tabular-nums;
}
.gc-glossary__cat-title {
	font-family: var(--gc-font-display, 'Sora', sans-serif);
	font-size: 22px;
	font-weight: 700;
	color: var(--gc-navy, #0D1B3E);
	letter-spacing: -0.01em;
	line-height: 1.25;
	margin: 0;
}
.gc-glossary__cat-count {
	font-size: 10px;
	font-weight: 700;
	letter-spacing: 0.5px;
	text-transform: uppercase;
	color: var(--gc-muted, #6b7280);
	background: #F8FAFC;
	border: 0.5px solid var(--gc-border, #e5e7eb);
	padding: 3px 9px;
	border-radius: 999px;
	font-family: var(--gc-font-display, 'Sora', sans-serif);
	font-variant-numeric: tabular-nums;
}
.gc-glossary__cat-desc {
	font-size: 13px;
	color: var(--gc-muted, #6b7280);
	line-height: 1.65;
	margin: 4px 0 0;
	max-width: 780px;
}

.gc-glossary__cat-grid {
	display: grid;
	grid-template-columns: repeat(3, minmax(0, 1fr));
	gap: 10px;
}


/* TERM CARD --------------------------------------------------- */
.gc-glossary__card {
	background: #ffffff;
	border: 0.5px solid var(--gc-border, #e5e7eb);
	border-radius: 10px;
	padding: 14px 16px;
	text-decoration: none;
	transition: all 180ms ease;
	display: flex;
	flex-direction: column;
	gap: 4px;
	min-height: 78px;
}
.gc-glossary__card:hover {
	border-color: rgba(0, 198, 174, 0.4);
	transform: translateY(-2px);
	box-shadow: 0 6px 16px rgba(13, 27, 62, 0.05);
}
.gc-glossary__card:focus-visible {
	outline: 2px solid var(--gc-primary, #00C6AE);
	outline-offset: 2px;
}
.gc-glossary__card-name {
	font-family: var(--gc-font-display, 'Sora', sans-serif);
	font-size: 14px;
	font-weight: 700;
	color: var(--gc-navy, #0D1B3E);
	line-height: 1.3;
	letter-spacing: -0.005em;
}
.gc-glossary__card-desc {
	font-size: 12px;
	color: var(--gc-muted, #6b7280);
	line-height: 1.55;
	display: -webkit-box;
	-webkit-line-clamp: 2;
	-webkit-box-orient: vertical;
	overflow: hidden;
}


/* HIDDEN STATES (filter / search) ----------------------------- */
.gc-glossary__card.is-hidden,
.gc-glossary__cat.is-hidden { display: none; }


/* RESPONSIVE -------------------------------------------------- */
@media (max-width: 1100px) {
	.gc-glossary__hero-content,
	.gc-glossary__ticker-inner,
	.gc-glossary__toolbar-inner,
	.gc-glossary__wrap {
		padding-left: 24px;
		padding-right: 24px;
	}
	.gc-glossary__hero-jumps { grid-template-columns: repeat(2, minmax(0, 1fr)); }
	.gc-glossary__cat-grid   { grid-template-columns: repeat(2, minmax(0, 1fr)); }
	.gc-glossary__ticker-inner { gap: 24px; }
}

@media (max-width: 700px) {
	.gc-glossary__hero-content {
		padding: 40px 20px 28px;
	}
	.gc-glossary__ticker-inner,
	.gc-glossary__toolbar-inner,
	.gc-glossary__wrap {
		padding-left: 20px;
		padding-right: 20px;
	}
	.gc-glossary__hero-jumps  { grid-template-columns: 1fr; }
	.gc-glossary__cat-grid    { grid-template-columns: repeat(2, minmax(0, 1fr)); }
	.gc-glossary__ticker-inner { gap: 18px 24px; }
	.gc-glossary__toolbar      { position: static; }
	.gc-glossary__toolbar-inner { flex-direction: column; align-items: stretch; }
	.gc-glossary__chips {
		justify-content: flex-start;
		flex-wrap: wrap;
	}
	.gc-glossary__count { margin-left: 0; }
	.gc-glossary__cat-title { font-size: 19px; }
}


/* DARK MODE --------------------------------------------------- */
[data-theme="dark"] .gc-glossary,
[data-theme="dark"] .gc-glossary__hero { background: transparent; }
[data-theme="dark"] .gc-glossary__hero,
[data-theme="dark"] .gc-glossary__ticker { border-color: rgba(255, 255, 255, 0.06); }
[data-theme="dark"] .gc-glossary__ticker { background: rgba(255, 255, 255, 0.02); }

[data-theme="dark"] .gc-glossary__hero-title,
[data-theme="dark"] .gc-glossary__cat-title,
[data-theme="dark"] .gc-glossary__card-name,
[data-theme="dark"] .gc-glossary__jump-name,
[data-theme="dark"] .gc-glossary__ticker-value,
[data-theme="dark"] .gc-glossary__about h2 { color: #ffffff; }

[data-theme="dark"] .gc-glossary__hero-sub,
[data-theme="dark"] .gc-glossary__cat-desc,
[data-theme="dark"] .gc-glossary__card-desc,
[data-theme="dark"] .gc-glossary__about p,
[data-theme="dark"] .gc-glossary__jump-count,
[data-theme="dark"] .gc-glossary__ticker-label { color: rgba(255, 255, 255, 0.65); }

[data-theme="dark"] .gc-glossary__jump,
[data-theme="dark"] .gc-glossary__card,
[data-theme="dark"] .gc-glossary__about,
[data-theme="dark"] .gc-glossary__search input,
[data-theme="dark"] .gc-glossary__chips {
	background: var(--gc-bg-soft);
	border-color: rgba(255, 255, 255, 0.06);
}
[data-theme="dark"] .gc-glossary__toolbar { background: rgba(20, 23, 33, 0.95); }
[data-theme="dark"] .gc-glossary__chip.is-on { background: #2A2D3D; color: #ffffff; }
[data-theme="dark"] .gc-glossary__cat-count { background: rgba(255, 255, 255, 0.04); border-color: rgba(255, 255, 255, 0.06); }

/* ── Dark mode: hero eyebrow badge — match iHub (subtle teal pill) ── */
[data-theme="dark"] .gc-glossary__hero-badge {
	background: rgba(0, 198, 174, 0.08);
	border-color: rgba(0, 198, 174, 0.20);
	color: #7DD3C8;
}
[data-theme="dark"] .gc-glossary__hero-badge-dot {
	background: #7DD3C8;
}