/*
Theme Name: Savannah Backline Theme
Theme URI: https://savannahbackline.local
Author: Savannah Backline
Description: Backstage musician directory theme for Savannah Backline.
Version: 0.2.0
Text Domain: savannah-backline-theme
*/

/* ── Variables ──────────────────────────────────────────────────────────── */
:root {
	/* backgrounds */
	--sb-bg:           #0a0c0d;
	--sb-bg-soft:      #111517;
	--sb-surface:      #151a1c;
	--sb-surface-2:    #1b2124;

	/* backward-compat aliases (panel → surface) */
	--sb-panel:        var(--sb-surface);
	--sb-panel-strong: var(--sb-surface-2);

	/* borders / lines */
	--sb-border:       #2a3135;
	--sb-border-mid:   #2a3135;   /* kept for compat — same value as border */
	--sb-line:         #2a3135;

	/* text */
	--sb-text:         #e9e3d7;   /* warm off-white */
	--sb-heading:      #fff8ec;   /* warm near-white for headings */
	--sb-text-soft:    #c7c0b3;
	--sb-text-muted:   #9b9589;

	/* rust / copper accent — primary brand color */
	--sb-rust:         #c46f36;
	--sb-rust-hover:   #d88447;
	--sb-rust-soft:    rgba(196, 111, 54, 0.12);

	/* canonical accent aliases (keep existing refs working) */
	--sb-accent:       var(--sb-rust);
	--sb-accent-hi:    var(--sb-rust-hover);
	--sb-accent-soft:  var(--sb-rust-soft);

	/* deprecated — kept only for backward compat, do not use */
	--sb-accent-strong: var(--sb-rust-hover);
	--sb-border-strong: #2a3135;

	/* chrome */
	--sb-shadow:   none;
	--sb-radius:   8px;
	--sb-radius-sm: 5px;
	--sb-content:  1180px;
	--sb-gutter:   clamp(1rem, 2vw, 1.4rem);
	--sb-font-display: "Inter", system-ui, sans-serif;
	--sb-font-body:    "Inter", "Segoe UI", system-ui, sans-serif;
}

/* ── Reset ──────────────────────────────────────────────────────────────── */
*,
*::before,
*::after { box-sizing: border-box; }

html { scroll-behavior: smooth; }

body {
	margin: 0;
	background: var(--sb-bg);
	/* faint diagonal texture — backstage/stagecraft feel */
	background-image: repeating-linear-gradient(
		-55deg,
		transparent,
		transparent 60px,
		rgba(255, 255, 255, 0.009) 60px,
		rgba(255, 255, 255, 0.009) 61px
	);
	color: var(--sb-text);
	font-family: var(--sb-font-body);
	font-size: 16px;
	line-height: 1.65;
}

a {
	color: var(--sb-text-soft);
	text-decoration: none;
}

a:hover,
a:focus {
	color: var(--sb-text);
}

img {
	display: block;
	max-width: 100%;
	height: auto;
}

button,
input,
select,
textarea {
	font: inherit;
}

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

/* ── Shell ──────────────────────────────────────────────────────────────── */
.site-shell {
	min-height: 100vh;
	display: flex;
	flex-direction: column;
}

/* ── Header ─────────────────────────────────────────────────────────────── */
.site-header {
	position: sticky;
	top: 0;
	z-index: 20;
	background: rgba(10, 12, 13, 0.97);
	border-bottom: 1px solid var(--sb-border);
	backdrop-filter: blur(6px);
}

.site-bar,
.site-footer__inner,
.section__inner,
.page-hero__inner,
.single-layout,
.site-main {
	width: min(calc(100% - 2rem), var(--sb-content));
	margin: 0 auto;
}

.site-bar {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 1rem;
	padding: 0.75rem 0;
}

/* ── Brand mark ─────────────────────────────────────────────────────────── */
.brand-mark {
	display: inline-flex;
	align-items: center;
	gap: 0.65rem;
	color: var(--sb-heading);
}

/* rust-tinted badge — the SB monogram feels like a stamp */
.brand-mark__badge {
	display: grid;
	place-items: center;
	width: 2.2rem;
	height: 2.2rem;
	border-radius: var(--sb-radius-sm);
	border: 1px solid rgba(200, 120, 61, 0.40);
	background: rgba(200, 120, 61, 0.10);
	color: var(--sb-accent);
	font-size: 0.72rem;
	font-weight: 800;
	letter-spacing: 0.04em;
	text-transform: uppercase;
}

.brand-mark__title {
	display: block;
	font-family: var(--sb-font-display);
	font-size: 1rem;
	font-weight: 700;
	letter-spacing: 0;
	line-height: 1.2;
	color: var(--sb-heading);
}

.brand-mark__tagline {
	display: block;
	color: var(--sb-text-muted);
	font-size: 0.78rem;
	line-height: 1.2;
}

/* ── Custom logo (WordPress site identity) ──────────────────────────────── */
/* WP wraps the logo in .custom-logo-link; we normalise it to sit cleanly
   inside .brand-mark without any default link chrome.                       */
.custom-logo-link {
	display: inline-flex;
	align-items: center;
	line-height: 1;
	border: 0;
	outline-offset: 3px;
}

.custom-logo-link:hover,
.custom-logo-link:focus {
	opacity: 0.88;
}

.custom-logo {
	display: block;
	width: auto;
	max-width: 200px;   /* horizontal logo — desktop */
	max-height: 44px;   /* keeps header compact */
	height: auto;
	object-fit: contain;
}

/* ── Nav ────────────────────────────────────────────────────────────────── */
.site-nav ul {
	display: flex;
	flex-wrap: wrap;
	gap: 0.2rem;
	list-style: none;
	padding: 0;
	margin: 0;
}

.site-nav a {
	display: inline-flex;
	align-items: center;
	min-height: 2.2rem;
	padding: 0.3rem 0.75rem;
	border-radius: var(--sb-radius-sm);
	color: var(--sb-text-soft);
	font-size: 0.92rem;
	letter-spacing: 0.01em;
}

.site-nav a:hover {
	background: rgba(255, 255, 255, 0.05);
	color: var(--sb-text);
}

/* active page item gets rust — the current location is marked */
.site-nav .current-menu-item > a,
.site-nav .current_page_item > a {
	background: rgba(200, 120, 61, 0.10);
	color: var(--sb-accent);
}

/* ── Main ───────────────────────────────────────────────────────────────── */
.site-main {
	flex: 1;
	padding: clamp(1.5rem, 3vw, 2.5rem) 0 4rem;
}

/* ── Sections ───────────────────────────────────────────────────────────── */
.section {
	padding: clamp(2rem, 4vw, 3.5rem) 0;
}

.section--compact {
	padding-top: clamp(1.2rem, 2.5vw, 2rem);
}

.section + .section {
	border-top: 1px solid var(--sb-border);
}

.section-header {
	display: flex;
	flex-wrap: wrap;
	align-items: end;
	justify-content: space-between;
	gap: 1rem;
	margin-bottom: 1.4rem;
}

/* ── Type scale ─────────────────────────────────────────────────────────── */
.section-kicker,
.eyebrow {
	display: inline-block;
	margin-bottom: 0.55rem;
	color: var(--sb-accent);
	font-size: 0.68rem;
	font-weight: 700;
	letter-spacing: 0.14em;
	text-transform: uppercase;
}

.section-title,
.page-hero__title,
.hero__title,
.entry-title {
	margin: 0;
	font-family: var(--sb-font-display);
	font-size: clamp(1.8rem, 4vw, 3.6rem);
	font-weight: 800;
	line-height: 1.08;
	letter-spacing: -0.02em;
	color: var(--sb-heading);
}

.section-title {
	font-size: clamp(1.5rem, 2.8vw, 2.4rem);
}

.section-description,
.page-hero__description,
.hero__body,
.entry-summary {
	max-width: 58ch;
	color: var(--sb-text-soft);
}

/* ── Hero / page-hero ───────────────────────────────────────────────────── */
.hero,
.page-hero,
.single-hero {
	position: relative;
	overflow: hidden;
	padding: clamp(1.8rem, 3.5vw, 2.8rem);
	border: 1px solid var(--sb-border);
	border-radius: var(--sb-radius);
	background: var(--sb-panel);
	box-shadow: none;
}

.single-hero {
	display: grid;
	grid-template-columns: minmax(0, 1fr) minmax(220px, 0.34fr);
	align-items: end;
	gap: clamp(1.2rem, 3vw, 2.4rem);
	padding: clamp(1.4rem, 3vw, 2.2rem);
}

/* warm rust ambient for single listing pages */
.single-hero::after {
	content: "";
	position: absolute;
	inset: auto -10% -50% 25%;
	height: 14rem;
	background: radial-gradient(circle, rgba(200, 120, 61, 0.06), transparent 65%);
	pointer-events: none;
}

/* archive / generic hero: no ambient glow */
.hero::after,
.page-hero::after {
	content: none;
}

.single-hero__content,
.single-hero__aside {
	position: relative;
	z-index: 1;
}

.single-hero__meta {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: 0.7rem;
	margin-bottom: 0.75rem;
}

.single-hero__meta .eyebrow {
	margin-bottom: 0;
}

.single-hero .entry-title {
	max-width: 16ch;
	font-size: clamp(1.8rem, 4vw, 3rem);
}

.single-hero .entry-summary {
	margin-bottom: 0;
}

.single-hero__terms {
	justify-content: flex-end;
	margin: 0 0 1rem;
}

.single-hero__aside {
	display: grid;
	justify-items: end;
	gap: 0.75rem;
}

.hero__actions,
.page-hero__actions,
.cta-row {
	display: flex;
	flex-wrap: wrap;
	gap: 0.75rem;
	margin-top: 1.4rem;
}

/* ── Buttons ────────────────────────────────────────────────────────────── */
.button,
.wp-block-button__link,
button,
input[type="submit"] {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 0.4rem;
	min-height: 2.5rem;
	padding: 0.5rem 1.1rem;
	border: 1px solid var(--sb-accent);
	border-radius: var(--sb-radius-sm);
	background: var(--sb-accent);
	color: #fff;
	font-size: 0.88rem;
	font-weight: 700;
	letter-spacing: 0.03em;
	cursor: pointer;
	transition: background 0.12s ease, border-color 0.12s ease;
}

.button:hover,
.button:focus,
.wp-block-button__link:hover,
button:hover,
input[type="submit"]:hover {
	background: var(--sb-accent-hi);
	border-color: var(--sb-accent-hi);
	color: #fff;
}

.button--ghost,
.button--ghost:hover {
	background: transparent;
	color: var(--sb-text-soft);
}

.button--ghost {
	border-color: var(--sb-border-mid);
}

.button--ghost:hover {
	border-color: var(--sb-border-mid);
	color: var(--sb-text);
}

.button--small {
	min-height: 2.1rem;
	padding: 0.38rem 0.85rem;
	font-size: 0.82rem;
}

/* ── Grids ──────────────────────────────────────────────────────────────── */
.discovery-grid,
.listing-grid,
.detail-grid,
.footer-grid,
.stat-grid {
	display: grid;
	gap: var(--sb-gutter);
}

.discovery-grid {
	grid-template-columns: repeat(4, minmax(0, 1fr));
}

.listing-grid {
	grid-template-columns: repeat(3, minmax(0, 1fr));
	gap: clamp(0.8rem, 1.8vw, 1rem);
}

.detail-grid {
	grid-template-columns: repeat(2, minmax(0, 1fr));
}

.stat-grid {
	grid-template-columns: repeat(3, minmax(0, 1fr));
	margin-top: 2rem;
}

/* ── Base card surface ──────────────────────────────────────────────────── */
.card,
.listing-card,
.stat-card,
.newsletter-card,
.detail-card {
	border: 1px solid var(--sb-border);
	border-radius: var(--sb-radius);
	background: var(--sb-panel);
	box-shadow: none;
}

.card,
.stat-card,
.newsletter-card,
.detail-card {
	padding: 1.2rem;
}

.discovery-card {
	display: flex;
	flex-direction: column;
	justify-content: space-between;
	min-height: 14rem;
	padding: 1.2rem;
}

.discovery-card__title,
.listing-card__title,
.detail-card__title {
	margin: 0 0 0.55rem;
	font-family: var(--sb-font-display);
	font-size: 1.2rem;
	font-weight: 700;
	color: var(--sb-heading);
}

/* ── Listing card ───────────────────────────────────────────────────────── */
.listing-card {
	position: relative;
	overflow: hidden;
	display: grid;
	min-height: 0;
	border-radius: var(--sb-radius);
	background: var(--sb-panel);
	transition: border-color 0.15s ease, background 0.15s ease;
}

.listing-card:hover,
.listing-card:focus-within {
	border-color: var(--sb-border-mid);
	border-left-color: var(--sb-accent);  /* rust left stripe */
	background: var(--sb-panel-strong);
}

/* image-layout cards (band, venue): accent on top instead of left */
.listing-card--image:hover,
.listing-card--image:focus-within {
	border-top-color: var(--sb-accent);
	border-left-color: var(--sb-border-mid);
}

.listing-card__image {
	position: relative;
	display: block;
	aspect-ratio: 16 / 9;
	overflow: hidden;
	background: var(--sb-panel-strong);
}

.listing-card__image::after {
	content: "";
	position: absolute;
	inset: 50% 0 0;
	background: linear-gradient(180deg, transparent, rgba(0, 0, 0, 0.65));
	pointer-events: none;
}

.listing-card__image img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	filter: saturate(0.85) contrast(1.06);
}

/* backstage diagonal texture on image placeholders */
.listing-card__placeholder {
	display: grid;
	place-items: center;
	width: 100%;
	height: 100%;
	background: var(--sb-panel-strong);
	background-image: repeating-linear-gradient(
		-45deg,
		transparent,
		transparent 8px,
		rgba(255, 255, 255, 0.022) 8px,
		rgba(255, 255, 255, 0.022) 9px
	);
	color: var(--sb-text-muted);
	font-family: var(--sb-font-display);
	font-size: 2.4rem;
	font-weight: 700;
}

/* ── Badges ─────────────────────────────────────────────────────────────── */
.listing-card__badge,
.profile-badge {
	display: inline-flex;
	align-items: center;
	min-height: 1.25rem;
	padding: 0.15rem 0.4rem;
	border: 1px solid rgba(200, 120, 61, 0.32);
	border-radius: 3px;
	background: var(--sb-accent-soft);
	color: var(--sb-accent);
	font-size: 0.58rem;
	font-weight: 700;
	letter-spacing: 0.09em;
	line-height: 1;
	text-transform: uppercase;
}

.listing-card__badge {
	position: static;
	justify-self: end;
	white-space: nowrap;
}

/* ── Card body / content ────────────────────────────────────────────────── */
.listing-card__body {
	display: grid;
	gap: 0.85rem;
	padding: 0.9rem;
}

.listing-card--horizontal .listing-card__body {
	display: grid;
	grid-template-columns: clamp(6rem, 9vw, 7.5rem) minmax(0, 1fr);
	gap: 1rem;
	align-items: start;
}

.listing-card--opportunity .listing-card__body {
	display: block;
	padding: 0.95rem;
}

.listing-card__avatar {
	overflow: hidden;
	width: 100%;
	aspect-ratio: 1;
	border: 1px solid var(--sb-border);
	border-radius: var(--sb-radius-sm);
	background: var(--sb-panel-strong);
}

.listing-card__avatar img,
.listing-card__avatar span {
	width: 100%;
	height: 100%;
}

.listing-card__avatar img {
	object-fit: cover;
	filter: saturate(0.85) contrast(1.06);
}

.listing-card__avatar span {
	display: grid;
	place-items: center;
	color: var(--sb-text-muted);
	font-family: var(--sb-font-display);
	font-size: 2rem;
	font-weight: 700;
}

.listing-card__content {
	display: grid;
	gap: 0.55rem;
	min-width: 0;
}

.listing-card__head {
	display: grid;
	grid-template-columns: minmax(0, 1fr) auto;
	align-items: start;
	gap: 0.65rem;
}

.listing-card__title {
	margin-bottom: 0;
	font-size: 1.08rem;
	font-weight: 700;
	line-height: 1.2;
	color: var(--sb-heading);
}

.listing-card__title a {
	color: inherit;
}

/* opportunity type chip */
.listing-card__type {
	display: inline-flex;
	align-items: center;
	width: fit-content;
	min-height: 1.4rem;
	margin-bottom: 0.4rem;
	padding: 0.2rem 0.5rem;
	border: 1px solid rgba(200, 120, 61, 0.28);
	border-radius: 3px;
	background: var(--sb-accent-soft);
	color: var(--sb-accent);
	font-size: 0.62rem;
	font-weight: 700;
	letter-spacing: 0.09em;
	line-height: 1;
	text-transform: uppercase;
}

/* card CTA link */
.listing-card__link {
	justify-self: start;
	display: inline-flex;
	align-items: center;
	min-height: 1.9rem;
	margin-top: 0.05rem;
	padding: 0.3rem 0.7rem;
	border: 1px solid var(--sb-border-mid);
	border-radius: var(--sb-radius-sm);
	background: transparent;
	color: var(--sb-text-muted);
	font-size: 0.76rem;
	font-weight: 600;
	letter-spacing: 0.02em;
	transition: border-color 0.12s ease, color 0.12s ease;
}

.listing-card__link:hover,
.listing-card__link:focus {
	border-color: var(--sb-accent);
	color: var(--sb-accent);
}

.listing-card--opportunity .listing-card__title {
	font-size: 1.1rem;
}

.listing-card__excerpt,
.muted {
	color: var(--sb-text-soft);
}

.listing-card__excerpt {
	display: -webkit-box;
	overflow: hidden;
	margin: 0;
	color: var(--sb-text-soft);
	font-size: 0.86rem;
	line-height: 1.45;
	-webkit-box-orient: vertical;
	-webkit-line-clamp: 2;
}

.listing-card__facts {
	display: flex;
	flex-wrap: wrap;
	gap: 0.28rem 0.6rem;
}

.listing-card__fact {
	display: inline-flex;
	align-items: baseline;
	gap: 0.25rem;
	min-width: 0;
	color: var(--sb-text-soft);
}

.listing-card__fact-label {
	color: var(--sb-text-muted);
	font-size: 0.64rem;
	font-weight: 700;
	letter-spacing: 0.06em;
	line-height: 1.25;
	text-transform: uppercase;
}

.listing-card__fact-label::after {
	content: ":";
}

.listing-card__fact-value {
	color: var(--sb-text-soft);
	font-size: 0.84rem;
	line-height: 1.3;
}

.listing-card--image {
	grid-template-rows: auto 1fr;
}

.listing-card--image .listing-card__body {
	gap: 0.65rem;
	padding: 0.85rem;
}

/* ── Term pills / chips ─────────────────────────────────────────────────── */
.term-pills,
.social-links,
.meta-stack,
.link-grid {
	display: flex;
	flex-wrap: wrap;
	gap: 0.45rem;
}

.term-pill,
.meta-chip {
	display: inline-flex;
	align-items: center;
	padding: 0.28rem 0.6rem;
	border: 1px solid var(--sb-border);
	border-radius: 3px;
	background: rgba(255, 255, 255, 0.03);
	color: var(--sb-text-soft);
	font-size: 0.80rem;
	letter-spacing: 0.01em;
	line-height: 1.2;
}

/* ── Single layout ──────────────────────────────────────────────────────── */
.single-layout {
	display: grid;
	grid-template-columns: minmax(0, 1.65fr) minmax(280px, 0.82fr);
	gap: clamp(1.2rem, 2.5vw, 2rem);
}

.single-layout__main,
.single-layout__sidebar {
	display: grid;
	gap: var(--sb-gutter);
	align-content: start;
}

.entry-content,
.detail-list {
	color: var(--sb-text-soft);
}

.detail-card--sticky {
	position: sticky;
	top: 5rem;
}

/* ── Single media ───────────────────────────────────────────────────────── */
.single-media {
	position: relative;
	overflow: hidden;
	border: 1px solid var(--sb-border);
	border-radius: var(--sb-radius);
	background: var(--sb-panel-strong);
}

.single-media::after {
	content: "";
	position: absolute;
	inset: 45% 0 0;
	background: linear-gradient(180deg, transparent, rgba(0, 0, 0, 0.38));
	pointer-events: none;
}

.single-media img {
	width: 100%;
	aspect-ratio: 16 / 9;
	max-height: 22rem;
	object-fit: cover;
	filter: saturate(0.88) contrast(1.05);
}

.single-media--musician,
.single-media--service_provider {
	max-width: 34rem;
}

.single-media--musician img,
.single-media--service_provider img {
	aspect-ratio: 5 / 4;
	max-height: 20rem;
}

/* ── Single sections ────────────────────────────────────────────────────── */
.single-section {
	padding: clamp(1rem, 2.2vw, 1.5rem) 0 0;
	border-top: 1px solid var(--sb-border);
}

.single-media + .single-section {
	border-top: 0;
}

.single-section--minor {
	padding-top: 0.9rem;
}

.single-section__title {
	margin: 0 0 0.65rem;
	font-family: var(--sb-font-display);
	font-size: clamp(1.1rem, 2vw, 1.5rem);
	font-weight: 700;
	line-height: 1.2;
	color: var(--sb-heading);
}

/* ── Detail card ────────────────────────────────────────────────────────── */
.detail-card--merged {
	display: grid;
	gap: 0.9rem;
	padding: 1rem;
	border-radius: var(--sb-radius);
}

.detail-list {
	display: grid;
	grid-template-columns: 1fr;
	gap: 0.6rem;
}

.detail-row {
	padding-top: 0.6rem;
	border-top: 1px solid var(--sb-border);
}

.detail-row:first-child {
	padding-top: 0;
	border-top: 0;
}

.detail-label {
	display: block;
	margin-bottom: 0.18rem;
	color: var(--sb-text-muted);
	font-size: 0.68rem;
	font-weight: 700;
	letter-spacing: 0.08em;
	text-transform: uppercase;
}

.link-grid {
	align-items: center;
}

.single-tags {
	display: flex;
	flex-wrap: wrap;
	gap: 0.4rem;
	padding-top: 0.75rem;
	border-top: 1px solid var(--sb-border);
}

/* ── Archive toolbar / empty ────────────────────────────────────────────── */
.archive-toolbar,
.archive-empty {
	padding: 0.9rem 1rem;
	margin-bottom: 1.2rem;
	border: 1px solid var(--sb-border);
	border-radius: var(--sb-radius-sm);
	background: transparent;
	color: var(--sb-text-soft);
	font-size: 0.9rem;
}

/* ── Filter panel ─────────────────────────────────────────────────────────
   Feels like a compact control board: labeled, structured, utilitarian.
─────────────────────────────────────────────────────────────────────────── */
.archive-filters {
	margin-bottom: 1.2rem;
	padding: 0.85rem 1rem;
	border-radius: var(--sb-radius);
	border-color: var(--sb-border-mid);
}

.archive-filter-form {
	display: grid;
	gap: 0.65rem;
}

.archive-filter-form__header {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	justify-content: space-between;
	gap: 0.75rem;
	margin-bottom: 0;
}

/* rust label — marks this as a functional tool, not a bland panel */
.archive-filter-form__title {
	margin: 0;
	font-family: var(--sb-font-body);
	font-size: 0.66rem;
	font-weight: 700;
	letter-spacing: 0.13em;
	text-transform: uppercase;
	color: var(--sb-accent);
}

.archive-filter-form__description {
	margin: 0;
	color: var(--sb-text-soft);
}

.archive-filter-grid {
	display: grid;
	grid-template-columns: repeat(3, minmax(0, 1fr));
	gap: 0.5rem;
}

.archive-filter-field {
	display: grid;
	gap: 0.25rem;
}

.archive-filter-field--keyword {
	grid-column: 1 / -1;
}

.archive-filter-field input,
.archive-filter-field select {
	width: 100%;
	min-height: 2.3rem;
	padding: 0.45rem 0.75rem;
	border: 1px solid var(--sb-border);
	border-radius: var(--sb-radius-sm);
	background: var(--sb-bg-soft);
	color: var(--sb-text);
	font-size: 0.88rem;
}

.archive-filter-field input::placeholder {
	color: var(--sb-text-muted);
}

.archive-filter-field select option {
	color: var(--sb-bg);
}

/* rust focus ring — consistent with brand accent */
.archive-filter-field input:focus,
.archive-filter-field select:focus {
	outline: 2px solid rgba(196, 111, 54, 0.35);
	outline-offset: 2px;
	border-color: var(--sb-rust);
}

.archive-filter-actions {
	display: flex;
	flex-wrap: wrap;
	gap: 0.55rem;
}

/* ── Pagination ─────────────────────────────────────────────────────────── */
.pagination {
	display: flex;
	justify-content: center;
	margin-top: 2rem;
}

.pagination .nav-links {
	display: flex;
	flex-wrap: wrap;
	gap: 0.5rem;
}

.pagination a,
.pagination span {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-width: 2.4rem;
	min-height: 2.4rem;
	padding: 0.4rem 0.7rem;
	border-radius: var(--sb-radius-sm);
	border: 1px solid var(--sb-border);
	background: transparent;
	color: var(--sb-text-soft);
	font-size: 0.9rem;
}

.pagination a:hover {
	border-color: var(--sb-accent);
	color: var(--sb-accent);
}

.pagination .current {
	border-color: var(--sb-accent);
	background: var(--sb-accent-soft);
	color: var(--sb-accent);
	font-weight: 700;
}

/* ── Newsletter card ────────────────────────────────────────────────────── */
.newsletter-card {
	display: grid;
	grid-template-columns: minmax(0, 1.6fr) auto;
	align-items: center;
	gap: 1rem;
}

/* ── Footer ─────────────────────────────────────────────────────────────── */
.site-footer {
	padding: 1.4rem 0 2.4rem;
	border-top: 1px solid var(--sb-border);
	background: var(--sb-bg-soft);
}

.site-footer__inner {
	display: grid;
	gap: 1.1rem;
}

.footer-grid {
	grid-template-columns: 1.5fr 1fr 1fr;
}

.site-footer h2,
.site-footer h3 {
	margin: 0 0 0.65rem;
	font-family: var(--sb-font-display);
	font-size: 1rem;
	font-weight: 700;
	color: var(--sb-heading);
}

.footer-links,
.footer-links ul {
	list-style: none;
	padding: 0;
	margin: 0;
}

.footer-links li + li {
	margin-top: 0.4rem;
}

.copyright {
	color: var(--sb-text-muted);
	font-size: 0.88rem;
}

.entry-content > *:first-child { margin-top: 0; }
.entry-content > *:last-child  { margin-bottom: 0; }

/* ── Archive page header ─────────────────────────────────────────────────
   Left rust bar marks this as a section entry — music platform style.
─────────────────────────────────────────────────────────────────────────── */
.section--archive-hero {
	padding: 0.65rem 0 0;
}

.section--archive-hero + .section--compact {
	border-top: 0;
	padding-top: 0.65rem;
	padding-bottom: clamp(1.5rem, 3vw, 2.5rem);
}

.archive-page-header {
	position: relative;
	padding-left: 1.1rem;
	padding-bottom: 0.85rem;
	border-bottom: 1px solid var(--sb-line);
}

/* rust left accent bar */
.archive-page-header::before {
	content: "";
	position: absolute;
	left: 0;
	top: 0.05rem;
	bottom: 0.85rem;
	width: 3px;
	background: var(--sb-accent);
	border-radius: 2px;
}

.archive-page-header__title {
	margin: 0;
	font-family: var(--sb-font-display);
	font-size: clamp(1.1rem, 2.5vw, 1.75rem);
	font-weight: 800;
	letter-spacing: 0.04em;
	text-transform: uppercase;
	color: var(--sb-heading);
	line-height: 1.1;
}

.archive-page-header__desc {
	margin: 0.35rem 0 0;
	color: var(--sb-text-soft);
	font-size: 0.88rem;
	max-width: 58ch;
	line-height: 1.5;
}

/* ── Musician archive: 2-column grid ────────────────────────────────────── */
@media (min-width: 761px) {
	.post-type-archive-musician .listing-grid {
		grid-template-columns: repeat(2, minmax(0, 1fr));
		max-width: 1080px;
		margin-inline: auto;
	}
}

/* ── Musician card ──────────────────────────────────────────────────────── */
.listing-card--musician .listing-card__body {
	grid-template-columns: 104px minmax(0, 1fr);
	gap: 1.25rem;
	padding: 20px 22px;
}

.listing-card--musician .listing-card__content {
	gap: 0.32rem;
}

.listing-card--musician .listing-card__title {
	font-size: 1.04rem;
	line-height: 1.2;
}

/* musician hover: rust left stripe + slightly brighter borders */
.listing-card--musician:hover,
.listing-card--musician:focus-within {
	border-color: var(--sb-border-mid);
	border-left-color: var(--sb-accent);
	background: var(--sb-panel-strong);
}

/* musician badge */
.listing-card--musician .listing-card__badge {
	min-height: 1.15rem;
	padding: 0.14rem 0.38rem;
	font-size: 0.56rem;
}

/* musician CTA */
.listing-card--musician .listing-card__link {
	min-height: 1.8rem;
	padding: 0.26rem 0.6rem;
	font-size: 0.73rem;
}

/* compact musician meta lines */
.listing-card__meta {
	display: grid;
	gap: 0.16rem;
}

.listing-card__meta-summary,
.listing-card__meta-line {
	margin: 0;
	color: var(--sb-text-soft);
	font-size: 0.81rem;
	line-height: 1.35;
}

.listing-card__meta-key {
	color: var(--sb-text-muted);
	font-size: 0.76rem;
	font-weight: 600;
}

/* ── Responsive: 1024px ─────────────────────────────────────────────────── */
@media (max-width: 1024px) {
	.discovery-grid,
	.listing-grid,
	.footer-grid,
	.stat-grid,
	.newsletter-card,
	.single-layout,
	.single-hero,
	.detail-grid,
	.archive-filter-grid {
		grid-template-columns: 1fr 1fr;
	}

	.newsletter-card {
		align-items: start;
	}

	.single-hero {
		grid-template-columns: 1fr;
	}

	.single-hero__aside {
		justify-items: start;
	}

	.single-hero__terms {
		justify-content: flex-start;
	}
}

/* ── Responsive: 760px ──────────────────────────────────────────────────── */
@media (max-width: 760px) {
	.site-bar,
	.section-header {
		align-items: start;
	}

	.site-nav ul,
	.discovery-grid,
	.listing-grid,
	.footer-grid,
	.stat-grid,
	.newsletter-card,
	.single-layout,
	.single-hero,
	.detail-grid,
	.archive-filter-grid {
		grid-template-columns: 1fr;
	}

	.site-main {
		width: min(calc(100% - 1rem), var(--sb-content));
	}

	.hero,
	.page-hero,
	.single-hero {
		padding: 1.2rem;
	}

	.single-hero__aside {
		justify-items: start;
	}

	.single-hero__terms {
		justify-content: flex-start;
		margin-bottom: 0.3rem;
	}

	.detail-card--sticky {
		position: static;
	}

	.listing-card__facts {
		grid-template-columns: 1fr;
	}

	.listing-card__head {
		grid-template-columns: 1fr;
	}

	.listing-card--horizontal .listing-card__body {
		grid-template-columns: 5.5rem minmax(0, 1fr);
		gap: 0.8rem;
	}

	.listing-card--musician .listing-card__body {
		grid-template-columns: 80px minmax(0, 1fr);
		padding: 13px 15px;
		gap: 0.65rem;
	}

	.listing-card__link {
		justify-self: start;
	}

	.brand-mark__tagline {
		display: none;
	}

	/* scale logo image on mobile — keeps header tight */
	.custom-logo {
		max-width: 140px;
		max-height: 36px;
	}
}
