/* =====================================================================
   Phartenaas — components.css
   Buttons, breadcrumbs, callouts, steps, trust-bar, CTA, legal, entry,
   kicker labels, hair-rule divider, pull quotes, info callouts
   ===================================================================== */

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

/* Primary: serif-underline ghost — Fraunces italic garnet */
.btn-primary {
	display: inline-block;
	font-family: var(--f-heading);
	font-style: italic;
	font-weight: 500;
	font-size: 1rem;
	color: var(--c-accent);
	background: transparent;
	border: none;
	text-decoration: underline;
	text-underline-offset: 6px;
	text-decoration-thickness: 1px;
	padding: var(--s-8) 0;
	cursor: pointer;
	transition: text-decoration-thickness var(--dur) var(--ease), color var(--dur) var(--ease);
}

.btn-primary:hover,
.btn-primary:focus-visible {
	text-decoration-thickness: 2px;
	color: var(--c-accent-hover);
}

/* Secondary: solid accent fill, uppercase, small radius */
.btn-secondary {
	display: inline-block;
	font-family: var(--f-body);
	font-weight: 600;
	font-size: 0.75rem;
	text-transform: uppercase;
	letter-spacing: 1.5px;
	color: var(--c-white);
	background: var(--c-accent);
	border: none;
	border-radius: var(--r-sm);
	padding: var(--s-12) var(--s-24);
	cursor: pointer;
	transition: background var(--dur) var(--ease);
}

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

/* Tertiary: wheat fill for dark hero — only on dark backgrounds */
.btn-tertiary {
	display: inline-block;
	font-family: var(--f-body);
	font-weight: 600;
	font-size: 0.75rem;
	text-transform: uppercase;
	letter-spacing: 1.5px;
	color: var(--c-bg);
	background: var(--c-accent-sec);
	border: none;
	border-radius: var(--r-sm);
	padding: var(--s-12) var(--s-24);
	cursor: pointer;
	transition: background var(--dur) var(--ease);
}

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

/* Sizes */
.btn--sm {
	padding: var(--s-8) var(--s-16);
	font-size: 0.6875rem;
}

.btn--lg {
	padding: var(--s-16) var(--s-32);
	font-size: 0.875rem;
}

/* Button rows */
.btn-row {
	display: flex;
	flex-wrap: wrap;
	gap: var(--s-16);
	align-items: center;
	margin-top: var(--s-24);
}

.btn-row--center {
	justify-content: center;
}

/* Button with arrow (inline link variant) */
.inline-arrow {
	display: inline-flex;
	align-items: center;
	gap: var(--s-4);
	font-family: var(--f-body);
	font-weight: 500;
	font-size: 0.875rem;
	color: var(--c-accent);
	transition: color var(--dur) var(--ease), gap var(--dur) var(--ease);
}

.inline-arrow::after {
	content: '→';
	font-size: 1em;
	transition: transform var(--dur) var(--ease);
}

.inline-arrow:hover {
	color: var(--c-accent-hover);
	gap: var(--s-8);
}

/* ---------- Breadcrumbs ---------- */
.breadcrumbs {
	font-family: var(--f-body);
	font-weight: 500;
	font-size: 0.6875rem;
	text-transform: uppercase;
	letter-spacing: 1.5px;
	color: var(--c-text-dim);
	opacity: 0.75;
	margin-bottom: var(--s-24);
}

.breadcrumbs a {
	color: inherit;
}

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

.breadcrumbs__sep {
	margin: 0 var(--s-8);
	color: var(--c-border);
}

/* ---------- Hair-rule divider with heart glyph ---------- */
.hair-rule {
	display: flex;
	align-items: center;
	gap: var(--s-12);
	color: var(--c-border);
	margin: var(--s-48) 0;
}

.hair-rule::before,
.hair-rule::after {
	content: '';
	flex: 1;
	height: 1px;
	background: var(--c-border);
}

.hair-rule__glyph {
	width: 12px;
	height: 12px;
	color: var(--c-accent);
	flex-shrink: 0;
	display: inline-block;
}

.hair-rule__text {
	font-family: var(--f-heading);
	font-style: italic;
	font-weight: 400;
	font-size: 0.9375rem;
	color: var(--c-text-dim);
	flex-shrink: 0;
	padding: 0 var(--s-8);
}

/* Centered decorative text rule (no hairline) */
.decorative-line {
	font-family: var(--f-heading);
	font-style: italic;
	color: var(--c-text-dim);
	text-align: center;
	font-size: 0.9375rem;
	margin: var(--s-32) 0;
}

/* ---------- Pull quote ---------- */
.pull-quote {
	font-family: var(--f-heading);
	font-style: italic;
	font-weight: 400;
	font-size: 1.5rem;
	line-height: 1.4;
	color: var(--c-text);
	border-left: 2px solid var(--c-accent);
	padding-left: var(--s-24);
	margin: var(--s-40) 0;
	max-width: 680px;
}

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

/* ---------- Inline info notice (inside section) ---------- */
.info-notice {
	background: var(--c-surface);
	border: 1px solid var(--c-border);
	border-radius: var(--r-md);
	padding: var(--s-24);
	margin: var(--s-24) 0;
	font-size: 0.9375rem;
	color: var(--c-text);
	position: relative;
}

.info-notice::before {
	content: '';
	position: absolute;
	top: var(--s-16);
	left: var(--s-24);
	width: 20%;
	height: 1px;
	background: var(--c-accent);
}

.info-notice__title {
	font-family: var(--f-heading);
	font-weight: 500;
	color: var(--c-white);
	margin-bottom: var(--s-8);
}

/* inline italic note */
.italic-note {
	font-style: italic;
	color: var(--c-text-dim);
	font-size: 0.9375rem;
}

/* ---------- Anchor nav ---------- */
.anchor-nav {
	display: flex;
	flex-wrap: wrap;
	gap: var(--s-16);
	justify-content: center;
	align-items: center;
	margin-top: var(--s-24);
}

.anchor-nav a {
	color: var(--c-text-dim);
	font-family: var(--f-body);
	font-weight: 500;
	font-size: 0.8125rem;
	transition: color var(--dur) var(--ease);
}

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

.anchor-nav > * + *::before {
	content: '·';
	margin-right: var(--s-16);
	color: var(--c-border);
}

/* ---------- Badge row (for hero badges, 18+, etc) ---------- */
.badge-row {
	display: flex;
	flex-wrap: wrap;
	gap: var(--s-16);
	justify-content: center;
	margin: var(--s-24) 0;
}

.badge {
	display: inline-flex;
	align-items: center;
	gap: var(--s-8);
	font-family: var(--f-body);
	font-weight: 500;
	font-size: 0.6875rem;
	letter-spacing: 2px;
	text-transform: uppercase;
	color: var(--c-text-dim);
	padding: var(--s-4) var(--s-12);
	border: 1px solid var(--c-border);
	border-radius: var(--r-sm);
}

.badge--accent {
	color: var(--c-accent);
	border-color: var(--c-accent);
}

/* ---------- CTA block ---------- */
.cta-block {
	text-align: center;
	padding: var(--s-64) var(--s-24);
}

.cta-block__title {
	margin-bottom: var(--s-16);
}

.cta-block__lead {
	color: var(--c-text-dim);
	font-size: 1.0625rem;
	max-width: 560px;
	margin: 0 auto var(--s-32);
}

/* ---------- Legal pages ---------- */
.legal-meta {
	color: var(--c-text-dim);
	font-size: 0.9375rem;
	font-style: italic;
	margin-bottom: var(--s-24);
}

.contact-block {
	margin-top: var(--s-40);
	padding: var(--s-24);
	background: var(--c-surface);
	border-radius: var(--r-md);
	border-left: 2px solid var(--c-accent);
}

.contact-block p {
	margin: 0;
	color: var(--c-text);
	font-size: 0.9375rem;
	line-height: 1.8;
}

.contact-block a {
	color: var(--c-accent);
}

/* ---------- Form-legend / Attribution ---------- */
.recaptcha-note {
	font-size: 0.75rem;
	color: var(--c-text-dim);
	margin-top: var(--s-16);
	line-height: 1.6;
}

.recaptcha-note a {
	color: var(--c-accent-sec);
	text-decoration: underline;
}

/* ---------- Trust / guarantee strip ---------- */
.trust-bar {
	display: grid;
	grid-template-columns: 1fr;
	gap: var(--s-24);
	padding: var(--s-32) 0;
	border-top: 1px solid var(--c-border);
	border-bottom: 1px solid var(--c-border);
}

@media (min-width: 768px) {
	.trust-bar {
		grid-template-columns: repeat(4, 1fr);
	}
}

.trust-bar__item {
	text-align: center;
}

.trust-bar__label {
	font-family: var(--f-heading);
	font-weight: 500;
	color: var(--c-white);
	margin-bottom: var(--s-4);
}

.trust-bar__sub {
	font-size: 0.8125rem;
	color: var(--c-text-dim);
}
