/* ============================================================
   ARCHIVE CASSETTE — Template Styles
   /assets/css/archive-cassette.css
   ============================================================ */

/* ── Container ─────────────────────────────────────────────── */

.cm-archive-page {
	background-color: var(--cm-bg);
	min-height: 100vh;
}

.cm-arc-container {
	max-width: 1200px;
	margin: 0 auto;
	padding: 0 2rem;
}

/* ============================================================
   ARCHIVE HERO
   ============================================================ */

.cm-archive-hero {
	background-color: var(--cm-tape);
	padding: 4.5rem 0 0;
	overflow: hidden;
	position: relative;
}

.cm-archive-hero::before {
	content: '';
	position: absolute;
	inset: 0;
	background-image:
		repeating-linear-gradient(
			0deg,
			transparent,
			transparent 2px,
			rgba(255,255,255,0.012) 2px,
			rgba(255,255,255,0.012) 4px
		);
	pointer-events: none;
}

.cm-archive-hero-inner {
	display: grid;
	grid-template-columns: 1fr auto;
	gap: 3rem;
	align-items: center;
	position: relative;
	z-index: 1;
}

.cm-archive-eyebrow {
	display: flex;
	align-items: center;
	gap: 0.5rem;
	font-family: var(--cm-font-mono);
	font-size: 0.7rem;
	letter-spacing: 0.14em;
	text-transform: uppercase;
	color: var(--cm-accent-light);
	margin-bottom: 1.25rem;
}

.eyebrow-dot {
	width: 6px;
	height: 6px;
	border-radius: 50%;
	background-color: var(--cm-accent);
	animation: pulse-dot 2.4s ease-in-out infinite;
}

@keyframes pulse-dot {
	0%, 100% { opacity: 1; transform: scale(1); }
	50%       { opacity: 0.4; transform: scale(0.65); }
}

.cm-archive-title {
	font-family: var(--cm-font-display);
	font-size: clamp(2.5rem, 6vw, 5rem);
	color: var(--cm-text-on-dark);
	line-height: 1.05;
	margin: 0 0 1.25rem;
	letter-spacing: -0.02em;
}

.cm-archive-title em {
	color: var(--cm-accent-light);
	font-style: italic;
}

.cm-archive-subtitle {
	font-size: 1rem;
	color: var(--cm-text-on-dark-2);
	max-width: 46ch;
	margin: 0;
	line-height: 1.6;
}

/* ── Gestapelte Deko-Kassetten ──────────────────────────────── */

.cm-archive-deco {
	position: relative;
	width: 200px;
	height: 210px;
	flex-shrink: 0;
}

.deco-cassette {
	position: absolute;
	width: 140px;
	height: 92px;
	border-radius: 9px;
	overflow: hidden;
	box-shadow: 0 6px 24px rgba(0,0,0,0.45);
}

.deco-cassette--0 { background: linear-gradient(135deg, #3A2F27, #1A1612); top:   0; right:  0; transform: rotate(7deg);  z-index: 5; }
.deco-cassette--1 { background: linear-gradient(135deg, #2D3A2A, #1A1612); top:  18px; right: 22px; transform: rotate(-4deg); z-index: 4; }
.deco-cassette--2 { background: linear-gradient(135deg, #2A2A3A, #1A1612); top:  38px; right:  8px; transform: rotate(11deg); z-index: 3; }
.deco-cassette--3 { background: linear-gradient(135deg, #3A2A2A, #1A1612); top:  55px; right: 28px; transform: rotate(-7deg); z-index: 2; }
.deco-cassette--4 { background: linear-gradient(135deg, #2A3A36, #1A1612); top:  72px; right:  5px; transform: rotate(3deg);  z-index: 1; }

.deco-label {
	position: absolute;
	left: 8%; right: 8%;
	top: 10%; bottom: 28%;
	background: rgba(244, 239, 230, 0.1);
	border-radius: 3px;
}

.deco-reel {
	position: absolute;
	bottom: 8%;
	width: 21%;
	aspect-ratio: 1;
	border-radius: 50%;
	background: rgba(255,255,255,0.05);
	border: 1px solid rgba(255,255,255,0.07);
}
.deco-reel-l { left: 10%; }
.deco-reel-r { right: 10%; }

/* ── Stats Bar ──────────────────────────────────────────────── */

.cm-stats-bar {
	display: flex;
	align-items: stretch;
	margin-top: 3.5rem;
	border-top: 1px solid rgba(255,255,255,0.06);
	background: rgba(0,0,0,0.18);
	position: relative;
	z-index: 1;
}

.cm-stat {
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	padding: 1.35rem 2rem;
	flex: 1;
	gap: 0.2rem;
}

.stat-num {
	font-family: var(--cm-font-display);
	font-size: 2rem;
	font-weight: 700;
	color: var(--cm-text-on-dark);
	line-height: 1;
}

.stat-label {
	font-family: var(--cm-font-mono);
	font-size: 0.6rem;
	letter-spacing: 0.1em;
	text-transform: uppercase;
	color: rgba(196,184,172,0.6);
}

.cm-stat-divider {
	width: 1px;
	background: rgba(255,255,255,0.06);
	flex-shrink: 0;
	align-self: stretch;
}

/* ============================================================
   GENRE FILTER — Sticky
   ============================================================ */

.cm-genre-filter-section {
	background-color: var(--cm-bg-card);
	border-bottom: 1px solid var(--cm-border);
	padding: 0.85rem 0;
	position: sticky;
	top: 0;
	z-index: 100;
	box-shadow: 0 2px 12px rgba(26,22,18,0.06);
	overflow: hidden; /* verhindert horizontales Seitenscrolling */
}

.cm-genre-filter-wrap {
	display: flex;
	align-items: baseline;
	gap: 0.75rem;
	flex-wrap: wrap; /* Desktop: umbrechen */
}

.cm-genre-filter-label {
	font-family: var(--cm-font-mono);
	font-size: 0.62rem;
	letter-spacing: 0.12em;
	text-transform: uppercase;
	color: var(--cm-text-light);
	white-space: nowrap;
	flex-shrink: 0;
	padding-top: 0.15rem;
}

/* Desktop: kein Scroll-Container, direkt alle Pills */
.cm-genre-filter-scroll {
	flex: 1;
	overflow: visible;
}

.cm-genre-filter {
	display: flex;
	flex-wrap: wrap;
	gap: 0.35rem;
	padding: 0;
	min-width: 0;
}

.cm-genre-pill {
	display: inline-flex;
	align-items: center;
	gap: 0.3rem;
	padding: 0.28em 0.9em;
	border-radius: 500px;
	border: 1px solid var(--cm-border);
	background-color: transparent;
	font-family: var(--cm-font-body);
	font-size: 0.78rem;
	color: var(--cm-text-muted);
	white-space: nowrap;
	transition: all 0.15s ease;
	cursor: pointer;
}

.cm-genre-pill:hover {
	border-color: var(--cm-accent-muted);
	color: var(--cm-accent);
	background-color: rgba(196, 98, 45, 0.05);
}

.cm-genre-pill.active {
	background-color: var(--cm-accent);
	border-color: var(--cm-accent);
	color: #fff;
}

.cm-genre-pill.active .pill-count { opacity: 0.75; }

.pill-count {
	font-family: var(--cm-font-mono);
	font-size: 0.62rem;
	opacity: 0.55;
}

/* ============================================================
   FILTER ACTIVE BANNER
   ============================================================ */

.cm-filter-active-banner {
	display: flex;
	align-items: center;
	justify-content: space-between;
	padding: 0.6rem 1rem;
	background-color: rgba(196, 98, 45, 0.07);
	border: 1px solid rgba(196, 98, 45, 0.18);
	border-radius: var(--cm-radius-lg);
	margin-bottom: 1.5rem;
	font-size: 0.83rem;
	color: var(--cm-text-muted);
}

.cm-filter-active-banner strong {
	color: var(--cm-accent);
	font-style: italic;
}

.filter-clear {
	font-family: var(--cm-font-mono);
	font-size: 0.68rem;
	letter-spacing: 0.06em;
	color: var(--cm-text-light);
	padding: 0.2em 0.55em;
	border-radius: 3px;
	transition: var(--cm-transition);
}

.filter-clear:hover {
	color: var(--cm-accent);
	background-color: rgba(196, 98, 45, 0.08);
}

/* ============================================================
   GRID SECTION
   ============================================================ */

.cm-grid-section {
	padding: 3rem 0 5rem;
}

.cm-cassette-grid {
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(310px, 1fr));
	gap: 1.25rem;
}

/* ============================================================
   CASSETTE CARD
   ============================================================ */

.cm-card {
	background-color: var(--cm-bg-card);
	border: 1px solid var(--cm-border);
	border-radius: var(--cm-radius-lg);
	overflow: hidden;
	transition: transform 0.22s ease, box-shadow 0.22s ease, border-color 0.22s ease;
	animation: card-appear 0.45s ease both;
}

@keyframes card-appear {
	from { opacity: 0; transform: translateY(14px); }
	to   { opacity: 1; transform: translateY(0); }
}

.cm-card:hover {
	transform: translateY(-4px);
	box-shadow: 0 12px 36px rgba(26,22,18,0.14);
	border-color: var(--cm-accent-muted);
}

.cm-card-link {
	display: block;
	text-decoration: none;
	color: inherit;
}

/* ── Mini Kassetten-Visual ──────────────────────────────────── */

.cm-card-visual {
	background: linear-gradient(155deg, #E8E3D8 0%, #DDD8CD 55%, #E2DCCE 100%);
	padding: 1.5rem;
	display: flex;
	align-items: center;
	justify-content: center;
	position: relative;
	overflow: hidden;
	aspect-ratio: 16 / 9;
}

.cm-card-visual::before {
	content: '';
	position: absolute;
	inset: 0;
	background: repeating-linear-gradient(
		0deg,
		transparent,
		transparent 3px,
		rgba(26,22,18,0.012) 3px,
		rgba(26,22,18,0.012) 4px
	);
	pointer-events: none;
}

.mini-cassette {
	width: 190px;
	height: 126px;
	background: linear-gradient(155deg, #3A302A, #1E1813);
	border-radius: 9px;
	position: relative;
	box-shadow:
		0 6px 24px rgba(0,0,0,0.5),
		inset 0 1px 0 rgba(255,255,255,0.045);
	transition: transform 0.35s ease;
}

.cm-card:hover .mini-cassette {
	transform: scale(1.05) rotateY(-4deg) rotateX(1deg);
}

.mini-label {
	position: absolute;
	left: 8%; right: 8%;
	top: 10%; bottom: 28%;
	background: linear-gradient(145deg, #F4EFE6, #EDE8DE);
	border-radius: 4px;
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	text-align: center;
	padding: 0.35rem 0.5rem;
	gap: 0.12rem;
	box-shadow: inset 0 1px 4px rgba(0,0,0,0.07);
}

.mini-vol {
	font-family: var(--cm-font-mono);
	font-size: 0.48rem;
	letter-spacing: 0.12em;
	text-transform: uppercase;
	color: var(--cm-accent);
	line-height: 1;
}

.mini-genre {
	font-family: var(--cm-font-display);
	font-size: 0.62rem;
	color: var(--cm-text);
	line-height: 1.15;
	font-style: italic;
}

.mini-reel {
	position: absolute;
	bottom: 8%;
	width: 22%;
	aspect-ratio: 1;
	border-radius: 50%;
	background: radial-gradient(circle at center,
		#4A3F36 0%, #4A3F36 22%,
		transparent 22%, transparent 32%,
		#3A302A 32%, #3A302A 38%,
		transparent 38%
	);
	border: 1.5px solid #4A3F36;
}

.mini-reel::after {
	content: '';
	position: absolute;
	inset: 16%;
	border-radius: 50%;
	background: #2B2520;
}

.mini-reel-l { left: 10%; }
.mini-reel-r { right: 10%; }

.mini-window {
	position: absolute;
	bottom: 5%;
	left: 50%;
	transform: translateX(-50%);
	width: 34%;
	height: 9%;
	background: #0D0B09;
	border-radius: 2px;
}

/* ── Card Body ──────────────────────────────────────────────── */

.cm-card-body {
	padding: 1rem 1.2rem 1.1rem;
	display: flex;
	flex-direction: column;
	gap: 0.45rem;
}

.cm-card-header {
	display: flex;
	align-items: center;
	justify-content: space-between;
}

.cm-card-vol {
	font-family: var(--cm-font-mono);
	font-size: 0.62rem;
	font-weight: 500;
	letter-spacing: 0.1em;
	text-transform: uppercase;
	color: var(--cm-accent);
}

.cm-card-date {
	font-family: var(--cm-font-mono);
	font-size: 0.6rem;
	color: var(--cm-text-light);
}

.cm-card-title {
	font-family: var(--cm-font-display);
	font-size: 1.05rem;
	font-weight: 700;
	color: var(--cm-text);
	margin: 0;
	line-height: 1.25;
	transition: color 0.15s ease;
}

.cm-card:hover .cm-card-title {
	color: var(--cm-accent);
}

.cm-card-meta {
	display: flex;
	flex-wrap: wrap;
	gap: 0.3rem;
}

.cm-card-genre-tag {
	display: inline-block;
	background-color: var(--cm-tape);
	color: var(--cm-text-on-dark-2);
	font-family: var(--cm-font-mono);
	font-size: 0.6rem;
	letter-spacing: 0.06em;
	text-transform: uppercase;
	padding: 0.17em 0.5em;
	border-radius: 2px;
}

.cm-card-footer {
	display: flex;
	align-items: center;
	gap: 0;
	margin-top: 0.15rem;
	padding-top: 0.6rem;
	border-top: 1px solid rgba(214, 204, 191, 0.45);
}

.cm-card-tracks {
	font-family: var(--cm-font-mono);
	font-size: 0.68rem;
	color: var(--cm-text-light);
}

.cm-card-tracks::after {
	content: '·';
	margin: 0 0.6rem;
	color: var(--cm-border);
}

.cm-card-dur {
	font-family: var(--cm-font-mono);
	font-size: 0.68rem;
	color: var(--cm-text-light);
}

.cm-card-arrow {
	margin-left: auto;
	font-size: 0.85rem;
	color: var(--cm-border);
	transition: all 0.2s ease;
}

.cm-card:hover .cm-card-arrow {
	color: var(--cm-accent);
	transform: translateX(4px);
}

/* ============================================================
   PAGINATION
   ============================================================ */

.cm-pagination {
	margin-top: 3rem;
	display: flex;
	justify-content: center;
}

.cm-pagination .page-numbers {
	display: inline-flex;
	flex-wrap: wrap;
	gap: 0.4rem;
	list-style: none;
	margin: 0;
	padding: 0;
	align-items: center;
}

.cm-pagination .page-numbers li { margin: 0; }

.cm-pagination .page-numbers a,
.cm-pagination .page-numbers span {
	display: flex;
	align-items: center;
	justify-content: center;
	min-width: 2.4rem;
	height: 2.4rem;
	padding: 0 0.75rem;
	border-radius: var(--cm-radius);
	font-family: var(--cm-font-mono);
	font-size: 0.78rem;
	border: 1px solid var(--cm-border);
	color: var(--cm-text-muted);
	transition: var(--cm-transition);
}

.cm-pagination .page-numbers a:hover {
	border-color: var(--cm-accent);
	color: var(--cm-accent);
	background-color: rgba(196, 98, 45, 0.05);
}

.cm-pagination .page-numbers .current {
	background-color: var(--cm-accent);
	border-color: var(--cm-accent);
	color: #fff;
}

.cm-pagination .page-numbers .dots {
	border: none;
	color: var(--cm-text-light);
}

/* ============================================================
   NO RESULTS
   ============================================================ */

.cm-no-results {
	text-align: center;
	padding: 6rem 1rem;
}

.no-results-tape {
	font-size: 2rem;
	color: var(--cm-border);
	margin-bottom: 1rem;
	letter-spacing: 0.8rem;
}

.cm-no-results p {
	color: var(--cm-text-muted);
	font-size: 1rem;
	margin: 0 0 1.5rem;
	max-width: none;
}

.cm-btn-secondary {
	display: inline-block;
	padding: 0.6em 1.4em;
	border: 1.5px solid var(--cm-border);
	border-radius: var(--cm-radius);
	font-family: var(--cm-font-body);
	font-size: 0.85rem;
	color: var(--cm-text-muted);
	transition: var(--cm-transition);
}

.cm-btn-secondary:hover {
	border-color: var(--cm-accent);
	color: var(--cm-accent);
}

/* ============================================================
   RESPONSIVE
   ============================================================ */

@media (max-width: 900px) {
	.cm-archive-hero-inner {
		grid-template-columns: 1fr;
		gap: 2rem;
	}
	.cm-archive-deco { display: none; }
}

@media (max-width: 640px) {
	.cm-arc-container { padding: 0 1rem; }
	.cm-archive-title { font-size: 2.25rem; }
	.cm-cassette-grid { grid-template-columns: 1fr; }
	.cm-stats-bar { display: grid; grid-template-columns: 1fr 1fr; }
	.cm-stat-divider { display: none; }
	.cm-genre-filter-wrap { gap: 0.4rem; flex-wrap: nowrap; }
	.cm-genre-filter-label { font-size: 0.58rem; white-space: nowrap; flex-shrink: 0; }
	.cm-genre-filter-scroll {
		overflow-x: auto;
		-webkit-overflow-scrolling: touch;
		scrollbar-width: none;
		-webkit-mask-image: linear-gradient(to right, black 80%, transparent 100%);
		mask-image: linear-gradient(to right, black 80%, transparent 100%);
	}
	.cm-genre-filter-scroll::-webkit-scrollbar { display: none; }
	.cm-genre-filter {
		flex-wrap: nowrap;
		min-width: max-content;
		padding-right: 2rem;
	}
	.cm-archive-hero { padding: 2.5rem 0 0; }
}

/* ============================================================
   COVER-BILD im Kassetten-Label
   ============================================================ */

/* Vollflächiges Cover als Hintergrund der Mini-Kassette */
.mini-cover {
	position: absolute;
	inset: 0;
	border-radius: 9px;
	background-size: cover;
	background-position: center;
	opacity: 0.5;
	transition: opacity 0.3s ease;
}

.cm-card:hover .mini-cover {
	opacity: 0.65;
}

/* Label mit Cover: dunkler Gradient über dem Bild */
.mini-label--overlay {
	background: linear-gradient(
		to top,
		rgba(20, 15, 10, 0.92) 0%,
		rgba(20, 15, 10, 0.35) 60%,
		transparent 100%
	);
	justify-content: flex-end;
	padding-bottom: 0.5rem;
}

.mini-label--overlay .mini-vol  { color: #E8906A; }
.mini-label--overlay .mini-genre { color: #F4EFE6; opacity: 0.9; }

/* Reels & Window über dem Cover = etwas kräftiger */
.has-cover .mini-reel {
	border-color: rgba(255,255,255,0.18);
	background: radial-gradient(circle at center,
		rgba(255,255,255,0.12) 0%, rgba(255,255,255,0.12) 22%,
		transparent 22%, transparent 32%,
		rgba(255,255,255,0.08) 32%, rgba(255,255,255,0.08) 38%,
		transparent 38%
	);
}

.has-cover .mini-reel::after {
	background: rgba(10,8,6,0.7);
}


/* ═══════════════════════════════════════════════════════════
   ARTIST PAGE — cma-* Klassen
   ═══════════════════════════════════════════════════════════ */

/* ── Seiten-Wrapper ───────────────────────────────────────── */
.cma-page {
	background: var(--cm-bg, #F4EFE6);
	min-height: 100vh;
	color: var(--cm-text, #1A1612);
	font-family: var(--cm-font-body, system-ui, sans-serif);
	display: block;
	width: 100%;
}

body:has(.cma-page) .ct-container,
body:has(.cma-page) .site-content,
body:has(.cma-page) .content-area,
body:has(.cma-page) main.site-main,
body:has(.cma-page) .entry-content,
body:has(.cma-page) .entry-header,
body:has(.cma-page) .ct-post-header,
body:has(.cma-page) .ct-breadcrumbs {
	background: transparent !important;
	padding: 0 !important;
	margin: 0 !important;
	max-width: none !important;
	width: 100% !important;
}

body:has(.cma-page) [data-id="breadcrumbs"],
body:has(.cma-page) [data-id="post-header"],
body:has(.cma-page) .ct-hero {
	display: none !important;
}

/* ── Header ───────────────────────────────────────────────── */
.cma-header {
	position: relative;
	background: var(--cm-bg-dark, #1A1612);
	overflow: hidden;
	width: 100%;
	box-sizing: border-box;
}

.cma-header-bg {
	position: absolute;
	inset: 0;
	z-index: 0;
}

.cma-header-bg img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	object-position: center top;
	display: block;
	opacity: 0.35;
	filter: saturate(0.6);
}

.cma-header-overlay {
	position: absolute;
	inset: 0;
	z-index: 1;
	background: linear-gradient(
		to bottom,
		rgba(26, 22, 18, 0.5) 0%,
		rgba(26, 22, 18, 0.85) 100%
	);
}

.cma-header-inner {
	position: relative;
	z-index: 2;
	max-width: 860px;
	margin: 0 auto;
	padding: 20px 24px 36px;
}

.cma-header-nav {
	display: flex;
	justify-content: space-between;
	align-items: center;
	margin-bottom: 28px;
}

.cma-header-nav-right {
	display: flex;
	align-items: center;
	gap: 10px;
}

.cma-blocked-badge {
	display: inline-flex;
	align-items: center;
	gap: 4px;
	font-size: 11px;
	font-family: var(--cm-font-mono, monospace);
	font-weight: 600;
	letter-spacing: 0.05em;
	color: #fff;
	background: rgba(214, 54, 56, 0.85);
	border: 1px solid rgba(214, 54, 56, 0.5);
	border-radius: 4px;
	padding: 3px 8px;
	text-transform: uppercase;
}

.cma-back {
	font-size: 13px;
	font-weight: 500;
	color: rgba(244, 239, 230, 0.6);
	text-decoration: none;
	transition: color 0.15s;
}
.cma-back:hover { color: var(--cm-accent-light, #E8906A); }

.cma-updated {
	font-size: 11px;
	color: rgba(244, 239, 230, 0.35);
	font-family: var(--cm-font-mono, monospace);
	letter-spacing: 0.05em;
}

/* ── Identity: Avatar + Name ──────────────────────────────── */
.cma-identity {
	display: flex;
	align-items: flex-end;
	gap: 20px;
}

.cma-avatar {
	flex-shrink: 0;
	width: 100px;
	height: 100px;
	border-radius: 50%;
	overflow: hidden;
	border: 3px solid rgba(244, 239, 230, 0.15);
	box-shadow: 0 4px 24px rgba(0,0,0,0.4);
}

.cma-avatar img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
}

.cma-kicker {
	display: block;
	font-family: var(--cm-font-mono, monospace);
	font-size: 0.6rem;
	letter-spacing: 0.15em;
	text-transform: uppercase;
	color: var(--cm-accent-light, #E8906A);
	margin-bottom: 4px;
}

.cma-name {
	font-family: var(--cm-font-display, Georgia, serif);
	font-size: clamp(1.8rem, 5vw, 2.8rem);
	font-weight: 700;
	line-height: 1.1;
	color: var(--cm-bg, #F4EFE6);
	margin: 0 0 12px;
	letter-spacing: -0.02em;
}

/* Kein Bild: dunkle Textfarbe statt hell */
.cma-header:not(:has(.cma-header-bg)) .cma-name { color: var(--cm-text, #1A1612); }
.cma-header:not(:has(.cma-header-bg)) .cma-kicker { color: var(--cm-accent, #C4622D); }
.cma-header:not(:has(.cma-header-bg)) .cma-back { color: var(--cm-text-muted, #6B5E52); }
.cma-header:not(:has(.cma-header-bg)) { background: var(--cm-bg-card, #EDE8DE); }

.cma-genres {
	display: flex;
	flex-wrap: wrap;
	gap: 6px;
}

.cma-genre-pill {
	display: inline-block;
	padding: 3px 10px;
	border-radius: 500px;
	border: 1px solid rgba(244, 239, 230, 0.2);
	font-size: 11px;
	color: rgba(244, 239, 230, 0.7);
	font-family: var(--cm-font-mono, monospace);
	letter-spacing: 0.04em;
	white-space: nowrap;
}

/* ── Stats Bar ────────────────────────────────────────────── */
.cma-stats-bar {
	background: var(--cm-bg-card, #EDE8DE);
	border-bottom: 1px solid var(--cm-border, rgba(26,22,18,0.08));
}

.cma-stats-inner {
	max-width: 860px;
	margin: 0 auto;
	padding: 16px 24px;
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 1rem;
	flex-wrap: wrap;
}

.cma-stats {
	display: flex;
	gap: 2rem;
}

.cma-stat {
	display: flex;
	flex-direction: column;
	gap: 2px;
}

/* Stat als klickbarer Link (z.B. Tracks in DB) */
a.cma-stat--link {
	text-decoration: none;
	cursor: pointer;
	border-radius: 6px;
	padding: 4px 6px;
	margin: -4px -6px;
	transition: background 0.15s ease;
}
a.cma-stat--link:hover {
	background: rgba(0, 0, 0, 0.06);
}
a.cma-stat--link:hover .cma-stat-value {
	color: var(--cm-accent, #C9452A);
}
a.cma-stat--link .cma-stat-label {
	text-decoration: none;
}

.cma-stat-value {
	font-family: var(--cm-font-display, Georgia, serif);
	font-size: 1.3rem;
	font-weight: 700;
	color: var(--cm-text, #1A1612);
	line-height: 1;
}

.cma-stat-value small {
	font-size: 0.65rem;
	color: var(--cm-text-light, #9C8D84);
	font-family: var(--cm-font-mono, monospace);
}

.cma-stat-label {
	font-family: var(--cm-font-mono, monospace);
	font-size: 0.6rem;
	letter-spacing: 0.1em;
	text-transform: uppercase;
	color: var(--cm-text-light, #9C8D84);
}

.cma-spotify-btn {
	display: inline-flex;
	align-items: center;
	gap: 7px;
	background: #1DB954;
	color: #fff !important;
	text-decoration: none !important;
	font-family: var(--cm-font-mono, monospace);
	font-size: 12px;
	font-weight: 700;
	letter-spacing: 0.04em;
	padding: 9px 18px;
	border-radius: 500px;
	transition: background 0.2s, transform 0.1s;
	border: none !important;
	box-shadow: none !important;
	white-space: nowrap;
}
.cma-spotify-btn:hover { background: #17a349 !important; transform: translateY(-1px); }

/* ── Body ─────────────────────────────────────────────────── */
.cma-body {
	max-width: 860px;
	margin: 0 auto;
	padding: 32px 24px 64px;
	display: flex;
	flex-direction: column;
	gap: 40px;
}

.cma-section-title {
	font-family: var(--cm-font-mono, monospace);
	font-size: 0.62rem;
	font-weight: 700;
	letter-spacing: 0.14em;
	text-transform: uppercase;
	color: var(--cm-text-light, #9C8D84);
	margin: 0 0 16px;
	padding-bottom: 10px;
	border-bottom: 1px solid var(--cm-border, rgba(26,22,18,0.08));
}

/* Bio */
.cma-bio-text {
	font-size: 15px;
	line-height: 1.8;
	color: var(--cm-text-muted, #6B5E52);
	max-width: 640px;
}

/* ── Kassetten Grid ───────────────────────────────────────── */
.cma-cassette-grid {
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(160px, 1fr));
	gap: 16px;
}

.cma-card {
	display: flex;
	flex-direction: column;
	text-decoration: none !important;
	color: inherit;
	border-radius: 10px;
	overflow: hidden;
	border: 1px solid var(--cm-border, rgba(26,22,18,0.08));
	background: var(--cm-bg-card, #EDE8DE);
	transition: transform 0.2s, box-shadow 0.2s;
}

.cma-card:hover {
	transform: translateY(-3px);
	box-shadow: 0 8px 24px rgba(26,22,18,0.1);
}

/* Mini-Kassette im Card */
.cma-card-cassette {
	background: linear-gradient(155deg, #2B2520, #1A1612);
	padding: 16px 12px 12px;
	position: relative;
	height: 100px;
	display: flex;
	align-items: center;
	justify-content: center;
}

.cma-mc-label {
	position: absolute;
	left: 14%; right: 14%;
	top: 10%; bottom: 30%;
	background: linear-gradient(145deg, #F4EFE6, #EDE8DE);
	border-radius: 3px;
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	padding: 4px 6px;
	gap: 2px;
	box-shadow: inset 0 1px 3px rgba(0,0,0,0.07);
}

.cma-mc-vol {
	font-family: var(--cm-font-mono, monospace);
	font-size: 0.42rem;
	letter-spacing: 0.12em;
	text-transform: uppercase;
	color: var(--cm-accent, #C4622D);
	line-height: 1;
}

.cma-mc-genre {
	font-family: var(--cm-font-display, Georgia, serif);
	font-size: 0.55rem;
	color: var(--cm-text, #1A1612);
	line-height: 1.2;
	font-style: italic;
	text-align: center;
	overflow: hidden;
	display: -webkit-box;
	-webkit-line-clamp: 2;
	-webkit-box-orient: vertical;
}

.cma-mc-reel {
	position: absolute;
	bottom: 8%;
	width: 20%;
	aspect-ratio: 1;
	border-radius: 50%;
	background: radial-gradient(circle at center, #3A302A 0%, #3A302A 22%, transparent 22%, transparent 32%, #2B2520 32%, #2B2520 38%, transparent 38%);
	border: 1.5px solid #3A302A;
}
.cma-mc-reel::after { content: ''; position: absolute; inset: 16%; border-radius: 50%; background: #1A1612; }
.cma-mc-reel-l { left: 10%; }
.cma-mc-reel-r { right: 10%; }

.cma-mc-window {
	position: absolute;
	bottom: 5%;
	left: 50%;
	transform: translateX(-50%);
	width: 30%;
	height: 8%;
	background: #0D0B09;
	border-radius: 2px;
}

/* Card Body */
.cma-card-meta {
	padding: 10px 12px 12px;
	display: flex;
	flex-direction: column;
	gap: 2px;
}

.cma-card-vol {
	font-family: var(--cm-font-mono, monospace);
	font-size: 0.62rem;
	font-weight: 700;
	letter-spacing: 0.08em;
	color: var(--cm-accent, #C4622D);
	text-transform: uppercase;
}

.cma-card-genre {
	font-size: 13px;
	font-weight: 600;
	color: var(--cm-text, #1A1612);
	white-space: nowrap;
	overflow: hidden;
	text-overflow: ellipsis;
}

.cma-card-dur {
	font-family: var(--cm-font-mono, monospace);
	font-size: 0.65rem;
	color: var(--cm-text-light, #9C8D84);
}

/* ── Responsive ───────────────────────────────────────────── */
@media (max-width: 600px) {
	.cma-identity { flex-direction: column; align-items: flex-start; gap: 12px; }
	.cma-avatar { width: 80px; height: 80px; }
	.cma-stats-inner { flex-direction: column; align-items: flex-start; gap: 12px; }
	.cma-cassette-grid { grid-template-columns: repeat(auto-fill, minmax(140px, 1fr)); }
}

/* ── Count Badge ─────────────────────────────────────────── */
.cma-count {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-width: 18px;
	height: 18px;
	padding: 0 5px;
	background: var(--cm-bg-dark-card, #26211B);
	color: var(--cm-text-light, #9C8D84);
	border-radius: 500px;
	font-size: 0.55rem;
	font-weight: 700;
	letter-spacing: 0;
	vertical-align: middle;
	margin-left: 6px;
}

/* ── Discography ─────────────────────────────────────────── */
.cma-album-grid {
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(130px, 1fr));
	gap: 16px;
}

.cma-album-card {
	display: flex;
	flex-direction: column;
	gap: 8px;
	text-decoration: none !important;
	color: inherit;
	transition: transform 0.2s;
}

.cma-album-card:hover { transform: translateY(-3px); }

.cma-album-cover {
	position: relative;
	aspect-ratio: 1;
	border-radius: 6px;
	overflow: hidden;
	background: var(--cm-bg-card, #EDE8DE);
}

.cma-album-cover img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
	transition: opacity 0.2s;
}

.cma-album-card:hover .cma-album-cover img { opacity: 0.75; }

.cma-album-play {
	position: absolute;
	inset: 0;
	display: flex;
	align-items: center;
	justify-content: center;
	opacity: 0;
	transition: opacity 0.2s;
	color: #1DB954;
}
.cma-album-play svg { width: 28px; height: 28px; filter: drop-shadow(0 2px 6px rgba(0,0,0,0.5)); }
.cma-album-card:hover .cma-album-play { opacity: 1; }

.cma-album-placeholder {
	width: 100%;
	height: 100%;
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 2rem;
}

.cma-album-meta {
	display: flex;
	flex-direction: column;
	gap: 2px;
}

.cma-album-name {
	font-size: 12px;
	font-weight: 600;
	color: var(--cm-text, #1A1612);
	line-height: 1.3;
	display: -webkit-box;
	-webkit-line-clamp: 2;
	-webkit-box-orient: vertical;
	overflow: hidden;
}

.cma-album-year {
	font-family: var(--cm-font-mono, monospace);
	font-size: 0.62rem;
	color: var(--cm-text-light, #9C8D84);
}

/* ── Related Artists ─────────────────────────────────────── */
.cma-related-grid {
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(180px, 1fr));
	gap: 10px;
}

.cma-related-card {
	display: flex;
	align-items: center;
	gap: 12px;
	padding: 10px 12px;
	border: 1px solid var(--cm-border, rgba(26,22,18,0.08));
	border-radius: 8px;
	background: var(--cm-bg-card, #EDE8DE);
	text-decoration: none !important;
	color: inherit;
	transition: background 0.15s, border-color 0.15s, transform 0.15s;
}

a.cma-related-card:hover {
	background: var(--cm-bg, #F4EFE6);
	border-color: var(--cm-accent-muted, #D4956A);
	transform: translateY(-2px);
}

.cma-related-img {
	flex-shrink: 0;
	width: 44px;
	height: 44px;
	border-radius: 50%;
	overflow: hidden;
	background: var(--cm-bg, #F4EFE6);
}

.cma-related-img img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
}

.cma-related-initial {
	width: 100%;
	height: 100%;
	display: flex;
	align-items: center;
	justify-content: center;
	font-family: var(--cm-font-display, Georgia, serif);
	font-weight: 700;
	font-size: 18px;
	color: var(--cm-text-muted, #6B5E52);
	background: var(--cm-bg, #F4EFE6);
}

.cma-related-info {
	display: flex;
	flex-direction: column;
	gap: 2px;
	min-width: 0;
}

.cma-related-name {
	font-size: 13px;
	font-weight: 600;
	color: var(--cm-text, #1A1612);
	white-space: nowrap;
	overflow: hidden;
	text-overflow: ellipsis;
}

.cma-related-genre {
	font-family: var(--cm-font-mono, monospace);
	font-size: 0.62rem;
	color: var(--cm-text-light, #9C8D84);
	white-space: nowrap;
	overflow: hidden;
	text-overflow: ellipsis;
}


/* ═══════════════════════════════════════════════════════════
   ARTIST ARCHIVE — cma-arc-* Klassen
   ═══════════════════════════════════════════════════════════ */

.cma-archive {
	background: var(--cm-bg, #F4EFE6);
	min-height: 100vh;
}

/* ── Header ── */
.cma-arc-header {
	background: var(--cm-bg-dark, #1A1612);
	padding: 48px 0 40px;
}

.cma-arc-header-inner {
	max-width: 1400px;
	margin: 0 auto;
	padding: 0 24px;
}

.cma-arc-kicker {
	display: block;
	font-family: var(--cm-font-mono, monospace);
	font-size: 0.62rem;
	letter-spacing: 0.18em;
	text-transform: uppercase;
	color: var(--cm-accent-light, #E8906A);
	margin-bottom: 10px;
}

.cma-arc-title {
	font-family: var(--cm-font-display, Georgia, serif);
	font-size: clamp(1.8rem, 4vw, 2.8rem);
	font-weight: 700;
	line-height: 1.1;
	color: var(--cm-bg, #F4EFE6);
	margin: 0 0 12px;
	letter-spacing: -0.02em;
}

.cma-arc-title em {
	font-style: italic;
	color: var(--cm-accent-light, #E8906A);
}

.cma-arc-sub {
	font-family: var(--cm-font-mono, monospace);
	font-size: 0.75rem;
	color: rgba(244, 239, 230, 0.4);
	margin: 0;
}

.cma-arc-reset {
	color: var(--cm-accent-light, #E8906A);
	text-decoration: none;
	transition: color 0.15s;
}
.cma-arc-reset:hover { color: var(--cm-accent, #C4622D); }

/* ── Genre Filter ── */
.cma-arc-filter {
	background: var(--cm-bg-card, #EDE8DE);
	border-bottom: 1px solid var(--cm-border, rgba(26,22,18,0.08));
	position: sticky;
	top: 0;
	z-index: 100;
	overflow: hidden;
}

.cma-arc-filter-inner {
	max-width: 1400px;
	margin: 0 auto;
	padding: 10px 24px;
	display: flex;
	flex-wrap: wrap;   /* Desktop: umbrechen */
	gap: 5px;
	align-items: center;
}

/* Mobile: horizontal scrollen */
@media (max-width: 640px) {
	.cma-arc-filter { overflow: visible; }
	.cma-arc-filter-inner {
		flex-wrap: nowrap;
		overflow-x: auto;
		-webkit-overflow-scrolling: touch;
		scrollbar-width: none;
		padding-right: 32px;
		-webkit-mask-image: linear-gradient(to right, black 80%, transparent 100%);
		mask-image: linear-gradient(to right, black 80%, transparent 100%);
	}
	.cma-arc-filter-inner::-webkit-scrollbar { display: none; }
}

.cma-arc-pill {
	display: inline-flex;
	align-items: center;
	gap: 5px;
	padding: 4px 12px;
	border-radius: 500px;
	border: 1px solid var(--cm-border, rgba(26,22,18,0.12));
	background: transparent;
	font-family: var(--cm-font-mono, monospace);
	font-size: 0.65rem;
	letter-spacing: 0.04em;
	color: var(--cm-text-muted, #6B5E52);
	text-decoration: none !important;
	transition: background 0.15s, border-color 0.15s, color 0.15s;
	white-space: nowrap;
}

.cma-arc-pill:hover {
	background: var(--cm-bg, #F4EFE6);
	border-color: var(--cm-accent-muted, #D4956A);
	color: var(--cm-text, #1A1612);
}

.cma-arc-pill--active {
	background: var(--cm-accent, #C4622D) !important;
	border-color: var(--cm-accent, #C4622D) !important;
	color: #fff !important;
}

.cma-arc-pill-count {
	opacity: 0.65;
	font-size: 0.58rem;
}

/* ── Grid ── */
.cma-arc-body {
	max-width: 1400px;
	margin: 0 auto;
	padding: 32px 24px 64px;
}

.cma-arc-empty {
	font-family: var(--cm-font-mono, monospace);
	font-size: 0.8rem;
	color: var(--cm-text-light, #9C8D84);
	text-align: center;
	padding: 48px 0;
}

.cma-arc-grid {
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
	gap: 12px;
}

/* ── Artist Card ── */
.cma-arc-card {
	display: flex;
	align-items: center;
	gap: 14px;
	padding: 14px;
	border: 1px solid var(--cm-border, rgba(26,22,18,0.08));
	border-radius: 10px;
	background: var(--cm-bg-card, #EDE8DE);
	text-decoration: none !important;
	color: inherit;
	transition: transform 0.18s, box-shadow 0.18s, border-color 0.18s;
}

.cma-arc-card:hover {
	transform: translateY(-2px);
	box-shadow: 0 6px 20px rgba(26,22,18,0.08);
	border-color: var(--cm-accent-muted, #D4956A);
}

.cma-arc-card-img {
	flex-shrink: 0;
	width: 52px;
	height: 52px;
	border-radius: 50%;
	overflow: hidden;
	background: var(--cm-bg, #F4EFE6);
}

.cma-arc-card-img img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
}

.cma-arc-card-initial {
	width: 100%;
	height: 100%;
	display: flex;
	align-items: center;
	justify-content: center;
	font-family: var(--cm-font-display, Georgia, serif);
	font-weight: 700;
	font-size: 20px;
	color: var(--cm-text-muted, #6B5E52);
}

.cma-arc-card-body {
	display: flex;
	flex-direction: column;
	gap: 2px;
	min-width: 0;
}

.cma-arc-card-name {
	font-size: 14px;
	font-weight: 700;
	color: var(--cm-text, #1A1612);
	white-space: nowrap;
	overflow: hidden;
	text-overflow: ellipsis;
}

.cma-arc-card-genre {
	font-size: 12px;
	color: var(--cm-accent, #C4622D);
	font-style: italic;
	white-space: nowrap;
	overflow: hidden;
	text-overflow: ellipsis;
}

.cma-arc-card-meta {
	display: flex;
	gap: 8px;
	flex-wrap: wrap;
}

.cma-arc-card-meta span {
	font-family: var(--cm-font-mono, monospace);
	font-size: 0.6rem;
	color: var(--cm-text-light, #9C8D84);
}

/* ── Genre Pills auf Artist-Seite: klickbar ── */
a.cma-genre-pill {
	text-decoration: none !important;
	transition: background 0.15s, border-color 0.15s, color 0.15s;
}

a.cma-genre-pill:hover {
	background: rgba(196, 98, 45, 0.25);
	border-color: var(--cm-accent-light, #E8906A);
	color: #fff;
}

/* ── Responsive ── */
@media (max-width: 600px) {
	.cma-arc-grid { grid-template-columns: 1fr; }
}

/* ============================================================
   ALPHABET-NAVIGATION
   ============================================================ */

.cma-arc-alphabet {
	border-bottom: 1px solid var(--cma-border, #E0DAD0);
	background: var(--cma-bg, #F5F1EA);
	overflow-x: auto;
	-webkit-overflow-scrolling: touch;
	scrollbar-width: none;
}
.cma-arc-alphabet::-webkit-scrollbar { display: none; }

.cma-arc-alphabet-inner {
	display: flex;
	align-items: center;
	justify-content: center;
	flex-wrap: wrap;
	gap: 2px;
	max-width: 1400px;
	margin: 0 auto;
	padding: 10px 24px;
}

.cma-arc-alpha {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-width: 32px;
	height: 32px;
	padding: 0 4px;
	font-family: var(--cm-font-mono, monospace);
	font-size: 11px;
	font-weight: 600;
	letter-spacing: 0.05em;
	color: var(--cm-text, #2A2218);
	text-decoration: none;
	border-radius: 4px;
	transition: background 0.15s, color 0.15s;
}

.cma-arc-alpha:hover:not(.cma-arc-alpha--empty) {
	background: var(--cm-accent, #C4622D);
	color: #fff;
}

.cma-arc-alpha--active {
	background: var(--cm-accent, #C4622D);
	color: #fff !important;
}

.cma-arc-alpha--empty {
	color: var(--cm-border, #C8C0B4);
	cursor: default;
	pointer-events: none;
}

/* "All" etwas breiter */
.cma-arc-alphabet-inner .cma-arc-alpha:first-child {
	min-width: 40px;
	margin-right: 6px;
	border: 1px solid var(--cm-border, #C8C0B4);
}
.cma-arc-alphabet-inner .cma-arc-alpha:first-child.cma-arc-alpha--active {
	border-color: transparent;
}

/* ============================================================
   PAGINATION
   ============================================================ */

.cma-arc-pagination {
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 4px;
	padding: 40px 0 24px;
	flex-wrap: wrap;
}

.cma-arc-page {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-width: 36px;
	height: 36px;
	padding: 0 6px;
	font-family: var(--cm-font-mono, monospace);
	font-size: 12px;
	font-weight: 500;
	color: var(--cm-text, #2A2218);
	text-decoration: none;
	border: 1px solid var(--cm-border, #C8C0B4);
	border-radius: 4px;
	transition: background 0.15s, border-color 0.15s, color 0.15s;
}

.cma-arc-page:hover {
	background: var(--cm-bg-card, #EDE8DF);
	border-color: var(--cm-accent, #C4622D);
}

.cma-arc-page--active {
	background: var(--cm-accent, #C4622D);
	border-color: var(--cm-accent, #C4622D);
	color: #fff;
	cursor: default;
	pointer-events: none;
}

.cma-arc-page--arrow {
	font-size: 14px;
	border-color: transparent;
	background: transparent;
}
.cma-arc-page--arrow:hover {
	background: var(--cm-bg-card, #EDE8DF);
	border-color: var(--cm-border, #C8C0B4);
}

.cma-arc-page--gap {
	border: none;
	color: var(--cm-text-muted, #8A7E72);
	pointer-events: none;
	cursor: default;
}

@media (max-width: 600px) {
	.cma-arc-page--gap { display: none; }
}

/* ── Alphabet Mobile: scrollen statt umbrechen ── */
@media (max-width: 700px) {
	.cma-arc-alphabet-inner {
		flex-wrap: nowrap;
		overflow-x: auto;
		justify-content: flex-start;
		padding: 10px 16px;
	}
}

.cma-arc-card-genre-more {
	font-style: normal;
	opacity: 0.6;
	font-size: 0.85em;
}

/* ================================================================
   TRACK LIST – page-tracks.php
   ================================================================ */

.cma-track-list {
	display: flex;
	flex-direction: column;
	gap: 0;
	border-radius: 8px;
	overflow: hidden;
	border: 1px solid var(--arc-border, rgba(0,0,0,.08));
}

.cma-track-row {
	display: grid;
	grid-template-columns: 48px 1fr auto 36px;
	align-items: center;
	gap: 12px;
	padding: 10px 16px 10px 12px;
	background: var(--arc-card-bg, #f5f2ef);
	border-bottom: 1px solid var(--arc-border, rgba(0,0,0,.06));
	transition: background .15s;
}
.cma-track-row:last-child { border-bottom: none; }
.cma-track-row:hover { background: var(--arc-card-hover, #ede9e4); }

/* Cover / Initial */
.cma-track-cover {
	width: 48px;
	height: 48px;
	border-radius: 4px;
	overflow: hidden;
	flex-shrink: 0;
}
.cma-track-cover img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
}
.cma-track-initial {
	width: 48px;
	height: 48px;
	border-radius: 4px;
	background: var(--arc-initial-bg, #c8b89a);
	color: #fff;
	display: flex;
	align-items: center;
	justify-content: center;
	font-family: var(--font-mono, monospace);
	font-size: 1.1rem;
	font-weight: 700;
}

/* Info */
.cma-track-info {
	min-width: 0;
	display: flex;
	flex-direction: column;
	gap: 2px;
}
.cma-track-title {
	font-size: .9rem;
	font-weight: 600;
	color: var(--arc-title-color, #1a1a1a);
	text-decoration: none;
	white-space: nowrap;
	overflow: hidden;
	text-overflow: ellipsis;
	display: flex;
	align-items: center;
	gap: 5px;
}
.cma-track-title:hover { color: var(--accent, #b5622a); }
.cma-track-meta {
	display: flex;
	align-items: center;
	gap: 8px;
	font-size: .78rem;
	color: var(--arc-sub-color, #888);
}
.cma-track-artist {
	color: var(--arc-sub-color, #888);
	text-decoration: none;
	white-space: nowrap;
	overflow: hidden;
	text-overflow: ellipsis;
	max-width: 180px;
}
.cma-track-artist:hover { color: var(--accent, #b5622a); }
.cma-track-genre {
	font-size: .72rem;
	color: var(--accent, #b5622a);
	white-space: nowrap;
}

/* Duration */
.cma-track-duration {
	font-family: var(--font-mono, monospace);
	font-size: .78rem;
	color: var(--arc-sub-color, #888);
	white-space: nowrap;
}

/* Spotify Icon */
.cma-track-spotify {
	color: var(--arc-sub-color, #aaa);
	display: flex;
	align-items: center;
	justify-content: center;
	opacity: .5;
	transition: opacity .15s, color .15s;
}
.cma-track-row:hover .cma-track-spotify {
	opacity: 1;
	color: #1DB954;
}

@media (max-width: 480px) {
	.cma-track-row {
		grid-template-columns: 40px 1fr auto;
		gap: 10px;
		padding: 8px 12px;
	}
	.cma-track-spotify { display: none; }
	.cma-track-cover, .cma-track-initial { width: 40px; height: 40px; }
}

/* ═══ Cookie Consent Banner ═══════════════════════════════════════════════ */
#cm-cookie-banner {
    position: fixed;
    bottom: 0;
    left: 0;
    right: 0;
    background: var(--cm-bg-card, #1E1813);
    border-top: 1px solid var(--cm-border, #3A302A);
    z-index: 9999;
    padding: 0;
}
.cm-cb__inner {
    max-width: 960px;
    margin: 0 auto;
    padding: 16px 24px;
    display: flex;
    align-items: center;
    gap: 24px;
    flex-wrap: wrap;
}
.cm-cb__text {
    flex: 1;
    font-size: .875rem;
    color: var(--cm-text-muted, #A09890);
    margin: 0;
    line-height: 1.5;
}
.cm-cb__text a {
    color: var(--cm-accent, #C4622D);
    text-decoration: underline;
}
.cm-cb__actions {
    display: flex;
    gap: 10px;
    flex-shrink: 0;
}
.cm-cb__btn {
    padding: 8px 20px;
    border-radius: 4px;
    font-size: .875rem;
    font-weight: 500;
    cursor: pointer;
    border: 1px solid transparent;
    transition: opacity .15s;
}
.cm-cb__btn:hover { opacity: .8; }
.cm-cb__btn--accept {
    background: var(--cm-accent, #C4622D);
    color: #fff;
}
.cm-cb__btn--decline {
    background: transparent;
    border-color: var(--cm-border, #3A302A);
    color: var(--cm-text-muted, #A09890);
}
@media (max-width: 600px) {
    .cm-cb__inner { flex-direction: column; align-items: stretch; }
    .cm-cb__actions { justify-content: stretch; }
    .cm-cb__btn { flex: 1; text-align: center; }
}


/* ── Artist Track Load More ─────────────────────────────────────────────── */
.cma-track-load-wrap {
	padding: 16px 0 4px;
	display: flex;
	justify-content: center;
}

.cma-track-load-more {
	display: inline-flex;
	align-items: center;
	gap: 6px;
	padding: 9px 24px;
	font-family: var(--cm-font-mono, monospace);
	font-size: 11px;
	font-weight: 700;
	letter-spacing: 0.08em;
	text-transform: uppercase;
	color: var(--cm-text-muted, #888);
	background: transparent;
	border: 1px solid var(--cm-border, #ddd);
	border-radius: 3px;
	cursor: pointer;
	transition: color .15s, border-color .15s;
}

.cma-track-load-more:hover {
	color: var(--cm-accent, #d4612a);
	border-color: var(--cm-accent, #d4612a);
}

.cma-track-load-more:disabled {
	opacity: 0.4;
	cursor: default;
}

/* ============================================================
   SEARCH PAGE
   ============================================================ */

/* Blocksy-Container zurücksetzen */
body.search .ct-container,
body.search .site-content,
body.search .content-area,
body.search main.site-main,
body.search .entry-content {
	background: transparent !important;
	padding: 0 !important;
	margin: 0 !important;
	max-width: none !important;
	width: 100% !important;
}

body.search,
body.search #page,
body.search #content {
	background: var(--cm-bg, #F4EFE6) !important;
}

/* ── Page Wrapper ── */
.cm-search-page {
	background: var(--cm-bg, #F4EFE6);
	min-height: 100vh;
	display: block;
	width: 100%;
}

/* ── Header ── */
.cm-search-header {
	background: var(--cm-bg-dark, #1A1612);
	padding: 48px 24px 40px;
}

.cm-search-header-inner {
	max-width: 720px;
	margin: 0 auto;
}

.cm-search-eyebrow {
	font-family: var(--cm-font-mono, monospace);
	font-size: 0.65rem;
	font-weight: 700;
	letter-spacing: 0.14em;
	text-transform: uppercase;
	color: var(--cm-accent, #C4622D);
	margin: 0 0 8px;
}

.cm-search-term {
	font-family: var(--cm-font-display, Georgia, serif);
	font-size: clamp(1.8rem, 5vw, 2.8rem);
	font-weight: 400;
	color: #F4EFE6;
	margin: 0 0 10px;
	line-height: 1.15;
}

.cm-search-count {
	font-size: 0.85rem;
	color: rgba(244, 239, 230, 0.55);
	margin: 0 0 28px;
}

/* Search Form */
.cm-search-form {
	display: flex;
	align-items: center;
	gap: 0;
	background: rgba(244, 239, 230, 0.07);
	border: 1px solid rgba(244, 239, 230, 0.15);
	border-radius: 4px;
	overflow: hidden;
	max-width: 480px;
}

.cm-search-input {
	flex: 1;
	background: transparent;
	border: none;
	padding: 12px 16px;
	font-family: inherit;
	font-size: 0.95rem;
	color: #F4EFE6;
	outline: none;
}

.cm-search-input::placeholder { color: rgba(244,239,230,0.35); }

.cm-search-submit {
	background: transparent;
	border: none;
	padding: 12px 16px;
	color: rgba(244,239,230,0.5);
	cursor: pointer;
	display: flex;
	align-items: center;
	transition: color 0.15s;
}

.cm-search-submit:hover { color: var(--cm-accent, #C4622D); }

/* ── Body ── */
.cm-search-body {
	max-width: 900px;
	margin: 0 auto;
	padding: 40px 24px 80px;
	display: flex;
	flex-direction: column;
	gap: 48px;
}

/* ── Empty State ── */
.cm-search-empty {
	text-align: center;
	padding: 60px 24px;
}

.cm-search-empty-icon {
	font-size: 2.5rem;
	color: var(--cm-text-light, #9C8D84);
	margin-bottom: 16px;
}

.cm-search-empty-title {
	font-size: 1.1rem;
	font-weight: 600;
	color: var(--cm-text, #1A1612);
	margin: 0 0 8px;
}

.cm-search-empty-sub {
	font-size: 0.9rem;
	color: var(--cm-text-light, #9C8D84);
	margin: 0;
}

/* ── Section ── */
.cm-search-section {}

.cm-search-section-title {
	display: flex;
	align-items: center;
	gap: 10px;
	font-family: var(--cm-font-mono, monospace);
	font-size: 0.62rem;
	font-weight: 700;
	letter-spacing: 0.14em;
	text-transform: uppercase;
	color: var(--cm-text-light, #9C8D84);
	margin: 0 0 20px;
	padding-bottom: 10px;
	border-bottom: 1px solid var(--cm-border, rgba(26,22,18,0.08));
}

.cm-search-section-count {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	background: var(--cm-accent, #C4622D);
	color: #fff;
	font-size: 0.6rem;
	font-weight: 700;
	border-radius: 99px;
	padding: 1px 6px;
	letter-spacing: 0.06em;
}

/* ── Artist List ── */
.cm-search-artist-list {
	display: flex;
	flex-direction: column;
	gap: 2px;
}

.cm-search-artist-row {
	display: flex;
	align-items: center;
	gap: 14px;
	padding: 10px 12px;
	border-radius: 6px;
	text-decoration: none;
	color: inherit;
	transition: background 0.12s;
}

.cm-search-artist-row:hover {
	background: var(--cm-bg-card, #EDE8DE);
}

.cm-search-artist-avatar {
	width: 48px;
	height: 48px;
	border-radius: 50%;
	overflow: hidden;
	flex-shrink: 0;
	background: var(--cm-border, #ddd);
	display: flex;
	align-items: center;
	justify-content: center;
	font-family: var(--cm-font-mono, monospace);
	font-size: 1.1rem;
	font-weight: 700;
	color: var(--cm-text-light, #9C8D84);
}

.cm-search-artist-avatar img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
}

.cm-search-artist-info {
	flex: 1;
	min-width: 0;
	display: flex;
	flex-direction: column;
	gap: 3px;
}

.cm-search-artist-name {
	font-size: 0.95rem;
	font-weight: 600;
	color: var(--cm-text, #1A1612);
	white-space: nowrap;
	overflow: hidden;
	text-overflow: ellipsis;
}

.cm-search-artist-meta {
	display: flex;
	align-items: center;
	gap: 8px;
	font-size: 0.75rem;
	color: var(--cm-text-light, #9C8D84);
	flex-wrap: wrap;
}

.cm-search-artist-genre {
	color: var(--cm-accent, #C4622D);
}

.cm-search-artist-arrow {
	font-size: 1.4rem;
	color: var(--cm-text-light, #9C8D84);
	flex-shrink: 0;
	line-height: 1;
}

@media (max-width: 480px) {
	.cm-search-header { padding: 32px 16px 28px; }
	.cm-search-body { padding: 28px 16px 60px; gap: 36px; }
	.cm-search-term { font-size: 1.6rem; }
}
