/**
 * WAMS Glossary — frontend styles.
 *
 * Color and font tokens pulled from the live whiteautoandmedia.com theme:
 *   --wams-green       #39ce7d  (primary brand accent)
 *   --wams-green-hover #178060  (darker green, link underlines)
 *   --wams-green-dark  #0d5c45  (deepest green, hover state)
 *   --wams-dark        #0a0a0a  (near-black, headers/footers)
 *   --wams-bg-soft     #f9f9f9  (soft callout background)
 *   --wams-border      #e0e0e0
 *   font family: Cabin (theme default) with Helvetica fallback
 *
 * If your theme adds the Cabin webfont at the page level (it does), the plugin
 * inherits it automatically via font-family: inherit on the wrapper elements.
 */

.wams-glossary-single,
.wams-glossary-archive {
	--wams-green: #39ce7d;
	--wams-green-hover: #178060;
	--wams-green-dark: #0d5c45;
	--wams-dark: #0a0a0a;
	--wams-dark-3: #2f2f2f;
	--wams-gray: #6b6b6b;
	--wams-bg-soft: #f9f9f9;
	--wams-border: #e0e0e0;

	max-width: 920px;
	margin: 2rem auto;
	padding: 0 1rem;
	line-height: 1.6;
	font-family: inherit;
	font-size: 18px; /* absolute — escape theme html font-size override */
}

.screen-reader-text {
	position: absolute;
	clip: rect(1px,1px,1px,1px);
	width: 1px; height: 1px;
	overflow: hidden;
}

/* ===== Single Term ===== */

.wams-glossary-header {
	border-bottom: 1px solid var(--wams-border);
	padding-bottom: 1.25rem;
	margin-bottom: 1.5rem;
}
.wams-glossary-title {
	margin: 0 0 0.5rem;
	font-size: 44px;
	line-height: 1.2;
	color: var(--wams-dark);
	font-weight: 700;
	overflow-wrap: anywhere;
	word-break: break-word;
	hyphens: auto;
}
.wams-glossary-fullname {
	font-weight: 400;
	color: var(--wams-gray);
	font-size: 0.55em;
}
.wams-glossary-category {
	margin: 0 0 0.85rem !important;
	font-size: 15px !important;
	text-transform: uppercase;
	letter-spacing: 0.08em;
	font-weight: 700 !important;
}
.wams-glossary-category-link {
	color: var(--wams-green-hover);
	text-decoration: none;
	border-bottom: 1px solid var(--wams-green-hover);
}
.wams-glossary-category-link:hover {
	border-bottom-width: 2px;
	border-bottom-color: var(--wams-green-dark);
}
.wams-glossary-lede {
	font-size: 22px;
	line-height: 1.45;
	color: var(--wams-dark-3);
	margin: 0;
	font-weight: 500;
}

.wams-glossary-content {
	margin: 1.5rem 0;
	max-width: 760px;
	font-size: 18px;
	line-height: 1.65;
}
.wams-glossary-entry .wams-glossary-content h2,
.wams-glossary-content h2 {
	font-size: 28px !important;
	color: var(--wams-dark) !important;
	margin-top: 1.75rem !important;
	margin-bottom: 0.6rem !important;
	font-weight: 700 !important;
	line-height: 1.3 !important;
}
.wams-glossary-content p { margin: 0.9rem 0; }
.wams-glossary-content ul { padding-left: 1.5rem; margin: 0.85rem 0; }
.wams-glossary-content ul li { margin: 0.45rem 0; }

.wams-glossary-content a {
	color: var(--wams-green-hover);
	text-decoration: none;
	border-bottom: 1px solid var(--wams-green-hover);
}
.wams-glossary-content a:hover {
	border-bottom-width: 2px;
	border-bottom-color: var(--wams-green-dark);
}

.wams-glossary-disambiguation,
.wams-glossary-applicability {
	background: var(--wams-bg-soft);
	border-left: 4px solid var(--wams-green);
	padding: 1.1rem 1.4rem;
	margin: 1.75rem 0;
	border-radius: 0 4px 4px 0;
	font-size: 18px;
	line-height: 1.6;
}
.wams-glossary-entry .wams-glossary-disambiguation h2,
.wams-glossary-entry .wams-glossary-applicability h2,
.wams-glossary-disambiguation h2,
.wams-glossary-applicability h2 {
	margin: 0 0 0.6rem !important;
	font-size: 22px !important;
	color: var(--wams-dark) !important;
	font-weight: 700 !important;
	letter-spacing: -0.005em;
	line-height: 1.3 !important;
	text-transform: none !important;
}

.wams-glossary-aliases {
	font-size: 17px;
	color: var(--wams-dark-3);
	margin: 1.25rem 0;
}

.wams-glossary-related-terms,
.wams-glossary-related-guides,
.wams-glossary-related-products {
	margin-top: 2rem;
}
.wams-glossary-entry .wams-glossary-related-terms h2,
.wams-glossary-entry .wams-glossary-related-guides h2,
.wams-glossary-entry .wams-glossary-related-products h2,
.wams-glossary-related-terms h2,
.wams-glossary-related-guides h2,
.wams-glossary-related-products h2 {
	font-size: 28px !important;
	color: var(--wams-dark) !important;
	margin: 0 0 0.85rem !important;
	font-weight: 700 !important;
	border-bottom: 3px solid var(--wams-green) !important;
	padding-bottom: 0.35rem !important;
	display: inline-block !important;
	line-height: 1.3 !important;
	letter-spacing: -0.005em;
	text-transform: none !important;
}
.wams-glossary-related-terms ul,
.wams-glossary-related-guides ul,
.wams-glossary-related-products ul {
	list-style: none;
	padding: 0;
	margin: 0;
}
.wams-glossary-related-terms li,
.wams-glossary-related-guides li,
.wams-glossary-related-products li {
	padding: 0.75rem 0;
	border-bottom: 1px solid #eee;
}
.wams-glossary-related-terms li a,
.wams-glossary-related-guides li a,
.wams-glossary-related-products li a {
	color: var(--wams-dark);
	font-weight: 700;
	font-size: 21px;
	text-decoration: none;
	border-bottom: 1px solid var(--wams-green-hover);
}
.wams-glossary-related-terms li a:hover,
.wams-glossary-related-guides li a:hover,
.wams-glossary-related-products li a:hover {
	border-bottom-width: 2px;
	border-bottom-color: var(--wams-green-dark);
}
.wams-glossary-related-def {
	color: var(--wams-gray);
	font-size: 16px;
	display: block;
	margin-top: 0.3rem;
	font-weight: 400;
	line-height: 1.5;
}

.wams-glossary-footer {
	margin-top: 2rem;
	padding-top: 1rem;
	border-top: 1px solid var(--wams-border);
}

/* ===== Archive ===== */

.wams-glossary-archive-header {
	text-align: center;
	margin-bottom: 2rem;
}
.wams-glossary-archive-header h1 {
	color: var(--wams-dark);
	font-size: 2.25rem;
	font-weight: 700;
	margin: 0 0 0.5rem;
}
.wams-glossary-archive-intro {
	max-width: 680px;
	margin: 1rem auto;
	color: var(--wams-dark-3);
}

/* Toolbar with search + view toggle + category filter */
.wams-glossary-toolbar {
	padding: 1rem;
	background: var(--wams-bg-soft);
	border: 1px solid var(--wams-border);
	border-radius: 6px;
	margin-bottom: 1.5rem;
}
.wams-glossary-toolbar-row {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: 1rem;
	margin-bottom: 0.75rem;
}
.wams-glossary-search-label { flex: 1 1 280px; }
.wams-glossary-search {
	width: 100%;
	padding: 0.85rem 1rem;
	font-size: 17px;
	min-height: 44px;
	border: 1px solid #ccc;
	border-radius: 4px;
	background: #fff;
	font-family: inherit;
	box-sizing: border-box;
}
.wams-glossary-search:focus {
	outline: none;
	border-color: var(--wams-green);
	box-shadow: 0 0 0 3px rgba(57, 206, 125, 0.2);
}

.wams-glossary-view-toggle {
	display: inline-flex;
	border: 1px solid #ccc;
	border-radius: 4px;
	overflow: hidden;
	background: #fff;
}
.wams-view-btn {
	background: transparent;
	border: none;
	padding: 0.85rem 1.25rem;
	min-height: 44px;
	font-size: 16px;
	cursor: pointer;
	color: var(--wams-dark);
	border-right: 1px solid #ddd;
	font-family: inherit;
	font-weight: 500;
}
.wams-view-btn:last-child { border-right: none; }
.wams-view-btn:hover { background: var(--wams-bg-soft); }
.wams-view-btn.is-active {
	background: var(--wams-green);
	color: var(--wams-dark);
	font-weight: 600;
}

.wams-glossary-filter {
	display: flex;
	flex-wrap: wrap;
	gap: 0.4rem;
	padding-top: 0.6rem;
	border-top: 1px solid var(--wams-border);
}
.wams-filter-btn {
	background: #fff;
	border: 1px solid #ccc;
	border-radius: 4px;
	padding: 0.7rem 1.1rem;
	min-height: 44px;
	font-size: 15px;
	cursor: pointer;
	color: var(--wams-dark);
	font-family: inherit;
}
.wams-filter-btn:hover { border-color: var(--wams-green); }
.wams-filter-btn.is-active {
	background: var(--wams-green);
	color: var(--wams-dark);
	border-color: var(--wams-green);
	font-weight: 600;
}

.wams-glossary-atoz {
	display: flex;
	flex-wrap: wrap;
	gap: 0.4rem;
	margin-bottom: 1.5rem;
	padding: 0.75rem;
	background: #fff;
	border: 1px solid var(--wams-border);
	border-radius: 6px;
	position: sticky;
	top: 0;
	z-index: 10;
}
.wams-glossary-atoz a {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-width: 44px;
	min-height: 44px;
	padding: 0.4rem 0.7rem;
	background: var(--wams-bg-soft);
	border: 1px solid var(--wams-border);
	border-radius: 4px;
	text-decoration: none;
	font-weight: 700;
	font-size: 17px;
	color: var(--wams-green-hover);
	transition: opacity 0.15s ease;
}
.wams-glossary-atoz a:hover {
	background: var(--wams-green);
	color: var(--wams-dark);
	border-color: var(--wams-green);
}

.wams-glossary-letter-group { margin: 2rem 0; }
.wams-glossary-letter {
	font-size: 30px;
	color: var(--wams-dark);
	border-bottom: 3px solid var(--wams-green);
	padding-bottom: 0.25rem;
	margin: 0 0 1rem;
	font-weight: 700;
}

.wams-glossary-entry-row {
	padding: 1.1rem 0;
	border-bottom: 1px solid #eee;
}
/* Title selectors use higher specificity (.wams-glossary-list scope) plus
   !important on sizing so they win against theme h3/h4 cascades. */
.wams-glossary-list .wams-glossary-entry-title,
.wams-glossary-entry-row .wams-glossary-entry-title {
	margin: 0 0 0.35rem !important;
	font-size: 28px !important;
	line-height: 1.25 !important;
	font-weight: 700 !important;
	overflow-wrap: anywhere;
	word-break: break-word;
	hyphens: auto;
}
.wams-glossary-list .wams-glossary-entry-title a {
	font-weight: 700;
	color: var(--wams-dark);
	text-decoration: none;
	border-bottom: 2px solid var(--wams-green-hover);
	font-size: inherit;
}
.wams-glossary-list .wams-glossary-entry-title a:hover {
	border-bottom-color: var(--wams-green-dark);
}
.wams-glossary-list .wams-glossary-entry-fullname {
	font-weight: 400 !important;
	color: var(--wams-gray);
	font-size: 17px !important;
	border: none !important;
	margin-left: 0.4em;
}
.wams-glossary-list .wams-glossary-entry-lede {
	margin: 0.4rem 0 0 !important;
	font-size: 18px !important;
	line-height: 1.55 !important;
	color: var(--wams-dark-3);
	font-weight: 400 !important;
}

/* Full content hidden by default (summary view) */
.wams-glossary-entry-full {
	display: none;
	margin-top: 0.75rem;
	padding-left: 0.75rem;
	border-left: 3px solid var(--wams-green);
}
.wams-glossary-list.is-full .wams-glossary-entry-full { display: block; }
.wams-glossary-list.is-full .wams-glossary-entry-lede { display: none; }
.wams-glossary-list.is-full .wams-glossary-entry-row { padding: 1.25rem 0; }

.wams-glossary-entry-aliases {
	font-size: 0.9rem;
	color: var(--wams-dark-3);
	margin: 0.75rem 0 0;
}
.wams-glossary-entry-more { margin: 0.5rem 0 0; font-size: 0.9rem; }
.wams-glossary-entry-more a {
	color: var(--wams-green-hover);
	text-decoration: none;
	border-bottom: 1px solid var(--wams-green-hover);
}
.wams-glossary-entry-more a:hover {
	border-bottom-width: 2px;
	border-bottom-color: var(--wams-green-dark);
}

.wams-glossary-empty-state {
	text-align: center;
	padding: 2rem;
	color: var(--wams-gray);
}
.wams-glossary-reset {
	background: var(--wams-green);
	color: var(--wams-dark);
	border: none;
	padding: 0.4rem 0.8rem;
	border-radius: 4px;
	cursor: pointer;
	margin-left: 0.5rem;
	font-weight: 600;
	font-family: inherit;
}
.wams-glossary-reset:hover { background: var(--wams-green-hover); color: #fff; }

/* === Tablet: 601px – 900px === */
@media (max-width: 900px) {
	.wams-glossary-single,
	.wams-glossary-archive {
		margin: 1.5rem auto;
		padding: 0 1.25rem;
	}
	.wams-glossary-title { font-size: 36px; }
	.wams-glossary-content {
		max-width: 100%;
	}
	.wams-glossary-list .wams-glossary-entry-title,
	.wams-glossary-entry-row .wams-glossary-entry-title {
		font-size: 24px !important;
	}
	.wams-glossary-letter { font-size: 26px; }
}

/* === Mobile: ≤600px === */
@media (max-width: 600px) {
	.wams-glossary-single,
	.wams-glossary-archive {
		margin: 1rem auto;
		padding: 0 1rem;
		font-size: 17px;
	}
	.wams-glossary-title { font-size: 30px; }
	.wams-glossary-lede { font-size: 18px; }

	/* Stack toolbar vertically — but reset the search-label flex sizing
	   so it doesn't claim 280px of vertical space in column mode. */
	.wams-glossary-toolbar-row {
		flex-direction: column;
		align-items: stretch;
		gap: 0.75rem;
	}
	.wams-glossary-search-label {
		flex: 0 0 auto;
		width: 100%;
	}
	.wams-glossary-view-toggle { width: 100%; }
	.wams-view-btn { flex: 1; }

	/* A-Z nav: horizontal scroll on narrow screens so 14 letters don't crowd */
	.wams-glossary-atoz {
		flex-wrap: nowrap;
		overflow-x: auto;
		overflow-y: hidden;
		-webkit-overflow-scrolling: touch;
		padding: 0.5rem;
		gap: 0.35rem;
	}
	.wams-glossary-atoz a {
		flex: 0 0 auto;
	}

	/* Filter buttons: keep wrap, smaller gap */
	.wams-glossary-filter { gap: 0.35rem; }

	/* Entry row sizes — clear title-to-lede hierarchy on mobile */
	.wams-glossary-list .wams-glossary-entry-title,
	.wams-glossary-entry-row .wams-glossary-entry-title {
		font-size: 22px !important;
		line-height: 1.25 !important;
	}
	.wams-glossary-list .wams-glossary-entry-fullname {
		display: block;
		margin-left: 0;
		margin-top: 0.15rem;
		font-size: 16px !important;
	}
	.wams-glossary-list .wams-glossary-entry-lede {
		font-size: 17px !important;
		line-height: 1.5 !important;
	}
	.wams-glossary-letter { font-size: 24px; }

	/* Section headings on single-page — keep readable but tighter */
	.wams-glossary-entry .wams-glossary-related-terms h2,
	.wams-glossary-entry .wams-glossary-related-guides h2,
	.wams-glossary-entry .wams-glossary-related-products h2,
	.wams-glossary-related-terms h2,
	.wams-glossary-related-guides h2,
	.wams-glossary-related-products h2 {
		font-size: 22px !important;
	}

	/* Disambig / Applicability callouts — tighter padding */
	.wams-glossary-disambiguation,
	.wams-glossary-applicability {
		padding: 0.85rem 1rem;
		font-size: 17px;
	}

	/* Related links — let titles wrap cleanly */
	.wams-glossary-related-terms li a,
	.wams-glossary-related-guides li a,
	.wams-glossary-related-products li a {
		font-size: 17px;
		overflow-wrap: anywhere;
		word-break: break-word;
	}

	/* Body content paragraphs: comfortable mobile read */
	.wams-glossary-content { font-size: 17px; }
	.wams-glossary-content p { margin: 0.7rem 0; }
}

@media print {
	.wams-glossary-toolbar,
	.wams-glossary-atoz { display: none; }
	.wams-glossary-entry-full { display: block !important; border-left: none; padding-left: 0; }
	.wams-glossary-entry-lede { display: none; }
}
