/* components.css — buttons, three-tick divider, diamond glyph, pull quotes, breadcrumbs, shirt-number badge, legal prose. */

/* ----- Buttons ----- */

.btn,
.btn-primary,
.btn-secondary,
.btn-tertiary,
.btn-ghost {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: var(--s-8);
	font-family: var(--f-body);
	font-weight: 600;
	font-size: 0.8125rem;
	letter-spacing: 2px;
	text-transform: uppercase;
	padding: 14px 28px;
	border-radius: var(--r-sm);
	cursor: pointer;
	text-decoration: none;
	border: 1.5px solid transparent;
	transition: background var(--dur) var(--ease), color var(--dur) var(--ease), border-color var(--dur) var(--ease), transform var(--dur) var(--ease);
	line-height: 1;
}

.btn-primary {
	background: var(--c-accent);
	color: var(--c-white);
	border-color: var(--c-accent);
}

.btn-primary:hover,
.btn-primary:focus-visible {
	background: var(--c-accent-hover);
	border-color: var(--c-accent-hover);
	color: var(--c-white);
	transform: translateY(-1px);
}

.btn-secondary {
	background: transparent;
	color: var(--c-accent);
	border-color: var(--c-accent);
	padding: 12.5px 26.5px;
}

.btn-secondary:hover,
.btn-secondary:focus-visible {
	background: var(--c-accent);
	color: var(--c-white);
}

.btn-tertiary {
	background: var(--c-accent-sec);
	color: var(--c-bg);
	border-color: var(--c-accent-sec);
}

.btn-tertiary:hover,
.btn-tertiary:focus-visible {
	background: var(--c-white);
	border-color: var(--c-white);
	color: var(--c-bg);
}

.btn-ghost {
	background: transparent;
	border: none;
	color: var(--c-accent);
	padding: 0;
	text-transform: uppercase;
	font-size: 0.75rem;
	letter-spacing: 1.5px;
	border-bottom: 1px solid transparent;
	padding-bottom: 2px;
	border-radius: 0;
}

.btn-ghost:hover,
.btn-ghost:focus-visible {
	border-bottom-color: var(--c-accent);
	color: var(--c-accent);
}

.btn--sm {
	padding: 10px 20px;
	font-size: 0.75rem;
}

.btn--lg {
	padding: 18px 36px;
	font-size: 0.9375rem;
}

.btn-row {
	display: flex;
	flex-wrap: wrap;
	gap: var(--s-16);
	margin-top: var(--s-24);
}

/* ----- Three-tick decorative divider ----- */

.three-tick {
	display: block;
	width: 68px;
	height: 1px;
	background-image: linear-gradient(to right,
		var(--c-accent) 0 20px,
		transparent 20px 24px,
		var(--c-accent) 24px 44px,
		transparent 44px 48px,
		var(--c-accent) 48px 68px
	);
	margin: var(--s-24) 0;
	border: 0;
}

.three-tick--centered {
	margin-left: auto;
	margin-right: auto;
}

.three-tick--cream {
	background-image: linear-gradient(to right,
		var(--c-accent-sec) 0 20px,
		transparent 20px 24px,
		var(--c-accent-sec) 24px 44px,
		transparent 44px 48px,
		var(--c-accent-sec) 48px 68px
	);
}

/* ----- Diamond glyph separator ----- */

.diamond-glyph {
	display: inline-block;
	width: 6px;
	height: 6px;
	background: var(--c-accent);
	transform: rotate(45deg);
	margin: 0 var(--s-12);
	vertical-align: middle;
}

.diamond-sep > * + *::before {
	content: '';
	display: inline-block;
	width: 6px;
	height: 6px;
	background: var(--c-accent);
	transform: rotate(45deg);
	margin: 0 var(--s-12);
	vertical-align: middle;
}

/* ----- Pull quote ----- */

.pull-quote {
	font-family: var(--f-heading);
	font-style: italic;
	font-size: 1.5rem;
	line-height: 1.4;
	color: var(--c-text);
	padding-left: var(--s-32);
	border-left: 2px solid var(--c-accent);
	margin: var(--s-32) 0;
}

.pull-quote cite {
	display: block;
	margin-top: var(--s-16);
	font-style: normal;
	font-family: var(--f-body);
	font-size: 0.8125rem;
	letter-spacing: 1.5px;
	text-transform: uppercase;
	color: var(--c-text-dim);
	font-weight: 500;
}

/* ----- Shirt-number badge ----- */

.shirt-badge {
	display: inline-flex;
	width: 28px;
	height: 28px;
	border: 1.5px solid var(--c-accent);
	border-radius: var(--r-sm);
	align-items: center;
	justify-content: center;
	font-family: var(--f-heading);
	font-weight: 600;
	font-size: 1rem;
	color: var(--c-accent);
	line-height: 1;
}

/* ----- Breadcrumbs ----- */

.breadcrumbs {
	font-family: var(--f-body);
	font-size: 0.6875rem;
	letter-spacing: 1.5px;
	text-transform: uppercase;
	opacity: 0.6;
	color: var(--c-text-dim);
	padding: var(--s-24) 0;
}

.breadcrumbs a {
	color: inherit;
}

.breadcrumbs a:hover {
	color: var(--c-accent);
}

.breadcrumbs__sep {
	display: inline-block;
	width: 5px;
	height: 5px;
	background: currentColor;
	transform: rotate(45deg);
	margin: 0 var(--s-8);
	vertical-align: middle;
}

/* ----- Legal prose (privacy / terms / cookies) ----- */

.legal-prose {
	max-width: 760px;
	margin: 0 auto;
	font-size: 1rem;
	line-height: 1.8;
	color: var(--c-text);
}

.legal-prose h1 {
	margin-bottom: var(--s-24);
}

.legal-prose h2 {
	margin-top: var(--s-48);
	margin-bottom: var(--s-16);
	font-size: 1.625rem;
}

.legal-prose h3 {
	margin-top: var(--s-32);
	margin-bottom: var(--s-12);
}

.legal-prose p {
	margin-bottom: var(--s-16);
}

.legal-prose ul,
.legal-prose ol {
	list-style: disc;
	padding-left: var(--s-24);
	margin: var(--s-16) 0;
}

.legal-prose ol {
	list-style: decimal;
}

.legal-prose li {
	margin-bottom: var(--s-8);
}

.legal-prose strong {
	color: var(--c-white);
}

.legal-prose .effective-date {
	color: var(--c-text-dim);
	font-size: 0.875rem;
	letter-spacing: 1.5px;
	text-transform: uppercase;
	margin-bottom: var(--s-32);
}

/* ----- Entry content (default page.php / single.php) ----- */

.entry-content {
	max-width: 760px;
	margin: 0 auto;
	padding: var(--s-48) 0;
}

.entry-content > * + * {
	margin-top: var(--s-16);
}

/* ----- Alert / notice ----- */

.alert {
	background: var(--c-surface);
	border-left: 3px solid var(--c-accent);
	padding: var(--s-16) var(--s-24);
	margin: var(--s-24) 0;
	color: var(--c-text);
	font-size: 0.9375rem;
}

.alert--error {
	border-left-color: var(--c-error);
}

.alert--success {
	border-left-color: var(--c-success);
}

/* ----- Compliance inline strip (reused on thank-you, book, etc.) ----- */

.compliance-line {
	font-size: 0.8125rem;
	color: var(--c-text-dim);
	text-align: center;
	letter-spacing: 0.5px;
}

.compliance-line strong {
	color: var(--c-text);
}

.compliance-line a {
	color: var(--c-accent-sec);
	border-bottom: 1px solid transparent;
}

.compliance-line a:hover {
	border-bottom-color: var(--c-accent-sec);
}

/* ----- reCAPTCHA attribution ----- */

.recaptcha-attribution {
	font-size: 0.6875rem;
	color: var(--c-text-dim);
	line-height: 1.5;
	margin-top: var(--s-16);
}

.recaptcha-attribution a {
	color: var(--c-accent-sec);
	border-bottom: 1px solid transparent;
}

.recaptcha-attribution a:hover {
	border-bottom-color: var(--c-accent-sec);
}

.grecaptcha-badge {
	visibility: hidden !important;
}
