*, *::before, *::after {
	box-sizing: border-box;
	margin: 0;
	padding: 0;
}

:root {
	--paper: #f6eedd;
	--paper2: #ede0c4;
	--paper3: #e4d0a8;
	--ink: #2b1a07;
	--ink2: #56310f;
	--ink3: #8a5c2a;
	--ink4: #b88a50;
	--accent: #7b3b0e;
	--accent2: #a04f18;
	--gold: #c9953a;
	--rule: rgba(90, 55, 20, 0.18);
	--rule2: rgba(90, 55, 20, 0.09);
	--shadow: rgba(43, 26, 7, 0.14);
}

html {
	scroll-behavior: smooth;
}

body {
	background: var(--paper);
	color: var(--ink);
	font-family: 'Cormorant Garamond', Georgia, serif;
	font-size: 18px;
	line-height: 1.75;
	overflow-x: hidden;
}

body::before {
	content: '';
	position: fixed;
	inset: 0;
	pointer-events: none;
	z-index: 9000;
	background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='300' height='300'%3E%3Cfilter id='g'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.8' numOctaves='4' stitchTiles='stitch'/%3E%3CfeColorMatrix type='saturate' values='0'/%3E%3C/filter%3E%3Crect width='300' height='300' filter='url(%23g)' opacity='0.06'/%3E%3C/svg%3E");
	mix-blend-mode: multiply;
	opacity: 0.7;
}

.top-rule {
	height: 3px;
	background: linear-gradient(to right, transparent 0%, var(--ink4) 20%, var(--accent) 50%, var(--ink4) 80%, transparent 100%);
}

nav {
	position: sticky;
	top: 0;
	z-index: 200;
	background: var(--paper2);
	border-bottom: 1px solid var(--rule);
	display: flex;
	align-items: center;
	justify-content: space-between;
	padding: 0 5rem;
	height: 66px;
	box-shadow: 0 2px 16px var(--shadow);
}

.nav-logo {
	display: flex;
	align-items: center;
	text-decoration: none;
}

.nav-logo img {
	height: 40px;
	width: auto;
	filter: sepia(0.3) brightness(0.85) contrast(1.15);
	transition: filter 0.3s;
}

.nav-logo img:hover {
	filter: sepia(0.1) brightness(0.95);
}

.nav-logo-text {
	font-family: 'EB Garamond', serif;
	font-size: 1.15rem;
	font-weight: 500;
	font-style: italic;
	color: var(--ink);
	display: none;
}

.nav-links {
	display: flex;
	gap: 2.5rem;
	list-style: none;
	align-items: center;
}

.nav-links a {
	font-family: 'DM Mono', monospace;
	font-size: 0.58rem;
	letter-spacing: 0.22em;
	text-transform: uppercase;
	color: var(--ink3);
	text-decoration: none;
	transition: color 0.25s;
	border-bottom: 1px solid transparent;
	padding-bottom: 2px;
}

.nav-links a:hover {
	color: var(--accent);
	border-bottom-color: var(--accent);
}

.hero {
	display: grid;
	grid-template-columns: 1fr 400px;
	min-height: 88vh;
	position: relative;
}

.hero-sep {
	position: absolute;
	left: calc(100% - 400px);
	top: 6%;
	bottom: 6%;
	width: 1px;
	background: linear-gradient(to bottom, transparent, var(--rule), var(--rule), transparent);
	z-index: 2;
}

.hero-left {
	display: flex;
	flex-direction: column;
	justify-content: center;
	padding: 6rem 5rem 5rem 6rem;
	position: relative;
}

.hero-eyebrow {
	font-family: 'DM Mono', monospace;
	font-size: 0.57rem;
	letter-spacing: 0.32em;
	text-transform: uppercase;
	color: var(--ink3);
	margin-bottom: 1.75rem;
	display: flex;
	align-items: center;
	gap: 1rem;
	opacity: 0;
	animation: fadeUp 0.7s 0.15s forwards;
}

.hero-eyebrow::before {
	content: '';
	display: block;
	width: 2.5rem;
	height: 1px;
	background: var(--rule);
	flex-shrink: 0;
}

.hero-title {
	font-family: 'EB Garamond', serif;
	font-size: clamp(3rem, 5.5vw, 5.2rem);
	font-weight: 400;
	line-height: 1.0;
	color: var(--ink);
	margin-bottom: 0.4rem;
	opacity: 0;
	animation: fadeUp 0.8s 0.3s forwards;
}

.hero-title-italic {
	font-family: 'EB Garamond', serif;
	font-size: clamp(1.4rem, 2.2vw, 2rem);
	font-weight: 400;
	font-style: italic;
	color: var(--ink3);
	margin-bottom: 2.5rem;
	opacity: 0;
	animation: fadeUp 0.8s 0.45s forwards;
}

.hero-ornament {
	display: flex;
	align-items: center;
	gap: 0.75rem;
	margin-bottom: 2rem;
	opacity: 0;
	animation: fadeUp 0.7s 0.55s forwards;
}

.hero-ornament::before, .hero-ornament::after {
	content: '';
	flex: 1;
	max-width: 5rem;
	height: 1px;
	background: var(--rule);
}

.hero-ornament span {
	font-size: 0.65rem;
	color: var(--gold);
	letter-spacing: 0.3em;
}

.hero-bio {
	font-size: 1.1rem;
	line-height: 1.9;
	color: var(--ink2);
	font-style: italic;
	font-weight: 300;
	max-width: 44ch;
	margin-bottom: 3rem;
	opacity: 0;
	animation: fadeUp 0.8s 0.65s forwards;
}

.hero-actions {
	display: flex;
	gap: 1rem;
	flex-wrap: wrap;
	opacity: 0;
	animation: fadeUp 0.8s 0.8s forwards;
}

.btn-primary {
	display: inline-flex;
	align-items: center;
	gap: 0.6rem;
	background: var(--accent);
	color: var(--paper);
	padding: 0.75rem 2rem;
	font-family: 'DM Mono', monospace;
	font-size: 0.58rem;
	letter-spacing: 0.22em;
	text-transform: uppercase;
	text-decoration: none;
	transition: all 0.3s;
	box-shadow: 2px 3px 12px rgba(123, 59, 14, 0.22);
}

.btn-primary:hover {
	background: var(--accent2);
	transform: translateY(-2px);
}

.btn-ghost {
	display: inline-flex;
	align-items: center;
	gap: 0.6rem;
	border: 1px solid var(--rule);
	color: var(--ink3);
	padding: 0.75rem 2rem;
	font-family: 'DM Mono', monospace;
	font-size: 0.58rem;
	letter-spacing: 0.22em;
	text-transform: uppercase;
	text-decoration: none;
	transition: all 0.3s;
	background: transparent;
}

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

.hero-right {
	position: relative;
	overflow: hidden;
	background: var(--paper3);
}

.hero-photo {
	position: absolute;
	inset: 0;
	opacity: 0;
	animation: fadeIn 1.1s 0.25s forwards;
}

.hero-photo img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	object-position: top center;
	filter: sepia(0.6) contrast(0.88) brightness(0.9) saturate(0.65);
}

.hero-photo::after {
	content: '';
	position: absolute;
	inset: 0;
	background: linear-gradient(to right, var(--paper) 0%, rgba(246, 238, 221, 0.2) 28%, transparent 55%), linear-gradient(to top, var(--paper) 0%, transparent 22%);
}

.sidenote {
	background: var(--paper2);
	border-top: 1px solid var(--rule);
	border-bottom: 1px solid var(--rule);
	padding: 2rem 6rem;
	display: flex;
	align-items: flex-start;
	gap: 3rem;
}

.sidenote-label {
	font-family: 'DM Mono', monospace;
	font-size: 0.53rem;
	letter-spacing: 0.28em;
	text-transform: uppercase;
	color: var(--accent);
	white-space: nowrap;
	padding-top: 0.25rem;
	flex-shrink: 0;
}

.sidenote-body {
	border-left: 2px solid var(--rule);
	padding-left: 2.5rem;
	font-size: 0.92rem;
	color: var(--ink3);
	font-style: italic;
	font-weight: 300;
	line-height: 1.8;
}

.socials {
	padding: 2rem 6rem;
	display: flex;
	align-items: center;
	gap: 0.6rem;
	flex-wrap: wrap;
	border-bottom: 1px solid var(--rule);
}

.socials-label {
	font-family: 'DM Mono', monospace;
	font-size: 0.52rem;
	letter-spacing: 0.25em;
	text-transform: uppercase;
	color: var(--ink4);
	margin-right: 0.75rem;
	flex-shrink: 0;
}

.social-link {
	display: inline-flex;
	align-items: center;
	gap: 0.45rem;
	padding: 0.38rem 0.85rem;
	border: 1px solid var(--rule);
	color: var(--ink3);
	text-decoration: none;
	font-family: 'DM Mono', monospace;
	font-size: 0.52rem;
	letter-spacing: 0.12em;
	text-transform: uppercase;
	transition: all 0.22s;
}

.social-link img {
	width: 13px;
	height: 13px;
	object-fit: contain;
	filter: sepia(1) brightness(0.55) contrast(1.2);
	transition: filter 0.22s;
}

.social-link:hover {
	border-color: var(--accent);
	color: var(--accent);
	background: rgba(123, 59, 14, 0.04);
}

.social-link:hover img {
	filter: sepia(1) saturate(4) brightness(0.5) hue-rotate(-15deg);
}

.section {
	padding: 5rem 6rem;
}

.section-top {
	display: flex;
	align-items: baseline;
	gap: 1.5rem;
	margin-bottom: 0.5rem;
}

.section-title {
	font-family: 'EB Garamond', serif;
	font-size: clamp(2rem, 3.5vw, 2.8rem);
	font-weight: 400;
	color: var(--ink);
}

.section-sub {
	font-family: 'DM Mono', monospace;
	font-size: 0.53rem;
	color: var(--ink4);
	letter-spacing: 0.2em;
	text-transform: uppercase;
}

.section-divider {
	display: flex;
	align-items: center;
	gap: 0.75rem;
	margin-bottom: 3rem;
	color: var(--gold);
	font-size: 0.6rem;
	letter-spacing: 0.3em;
}

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

.albums-grid {
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(155px, 1fr));
	gap: 1.6rem;
	margin-bottom: 2rem;
}

.album-card {
	cursor: pointer;
	transition: transform 0.3s ease;
}

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

.album-cover {
	position: relative;
	aspect-ratio: 1;
	overflow: hidden;
	margin-bottom: 0.75rem;
	box-shadow: 2px 4px 14px var(--shadow);
}

.album-cover img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	filter: sepia(0.45) brightness(0.92) contrast(0.95) saturate(0.75);
	transition: filter 0.4s, transform 0.4s;
	display: block;
}

.album-card:hover .album-cover img, .album-card.active .album-cover img {
	filter: sepia(0.1) brightness(1) contrast(1) saturate(1);
	transform: scale(1.05);
}

.album-cover::before {
	content: '';
	position: absolute;
	inset: 6px;
	border: 1px solid rgba(255, 255, 255, 0.12);
	z-index: 1;
	pointer-events: none;
}

.album-cover::after {
	content: '';
	position: absolute;
	inset: 0;
	border: 2px solid transparent;
	transition: border-color 0.3s;
	z-index: 2;
	pointer-events: none;
}

.album-card:hover .album-cover::after, .album-card.active .album-cover::after {
	border-color: var(--accent);
}

.album-vol-badge {
	position: absolute;
	bottom: 0;
	left: 0;
	right: 0;
	background: linear-gradient(to top, rgba(43, 26, 7, 0.82), transparent);
	color: var(--paper);
	font-family: 'DM Mono', monospace;
	font-size: 0.48rem;
	letter-spacing: 0.18em;
	text-transform: uppercase;
	padding: 1rem 0.5rem 0.4rem;
	z-index: 3;
	opacity: 0;
	transition: opacity 0.3s;
	text-align: center;
}

.album-card:hover .album-vol-badge, .album-card.active .album-vol-badge {
	opacity: 1;
}

.album-name {
	font-family: 'EB Garamond', serif;
	font-size: 0.9rem;
	font-weight: 500;
	line-height: 1.3;
	color: var(--ink);
	margin-bottom: 0.18rem;
}

.album-edition {
	font-family: 'DM Mono', monospace;
	font-size: 0.48rem;
	color: var(--ink4);
	letter-spacing: 0.1em;
	text-transform: uppercase;
}

.tracklist-panel {
	display: none;
	background: var(--paper2);
	border: 1px solid var(--rule);
	padding: 2.5rem 3.5rem;
	margin-bottom: 2rem;
	position: relative;
	box-shadow: inset 0 1px 6px var(--shadow), 0 4px 18px rgba(43, 26, 7, 0.1);
}

.tracklist-panel::before {
	content: '\2736';
	position: absolute;
	top: 0.6rem;
	left: 0.9rem;
	font-size: 0.5rem;
	color: var(--ink4);
}

.tracklist-panel::after {
	content: '\2736';
	position: absolute;
	top: 0.6rem;
	right: 0.9rem;
	font-size: 0.5rem;
	color: var(--ink4);
}

.tracklist-panel.open {
	display: block;
	animation: fadeIn 0.28s ease;
}

.tracklist-head {
	display: flex;
	align-items: flex-start;
	justify-content: space-between;
	margin-bottom: 1.5rem;
	padding-bottom: 1.2rem;
	border-bottom: 1px solid var(--rule);
	gap: 2rem;
}

.tracklist-title {
	font-family: 'EB Garamond', serif;
	font-size: 1.55rem;
	font-weight: 400;
	font-style: italic;
	color: var(--ink);
}

.tracklist-close {
	background: none;
	border: 1px solid var(--rule);
	color: var(--ink3);
	width: 1.9rem;
	height: 1.9rem;
	cursor: pointer;
	font-size: 0.75rem;
	display: flex;
	align-items: center;
	justify-content: center;
	flex-shrink: 0;
	transition: all 0.2s;
}

.tracklist-close:hover {
	border-color: var(--accent);
	color: var(--accent);
}

.track {
	display: flex;
	align-items: center;
	padding: 0.6rem 0.5rem;
	border-bottom: 1px solid var(--rule2);
	gap: 1.25rem;
	transition: background 0.15s;
}

.track:last-child {
	border-bottom: none;
}

.track:hover {
	background: rgba(123, 59, 14, 0.04);
}

.track-num {
	font-family: 'DM Mono', monospace;
	font-size: 0.58rem;
	color: var(--ink4);
	width: 1.5rem;
	text-align: right;
	flex-shrink: 0;
}

.track-name {
	flex: 1;
	font-size: 0.98rem;
	color: var(--ink);
	text-decoration: none;
	transition: color 0.2s;
}

.track-name:hover {
	color: var(--accent);
}

.track-links {
	display: flex;
	gap: 0.4rem;
	flex-shrink: 0;
}

.track-link {
	display: inline-flex;
	align-items: center;
	padding: 0.18rem 0.55rem;
	border: 1px solid var(--rule);
	color: var(--ink3);
	text-decoration: none;
	font-family: 'DM Mono', monospace;
	font-size: 0.48rem;
	letter-spacing: 0.1em;
	text-transform: uppercase;
	transition: all 0.2s;
	background: var(--paper);
	white-space: nowrap;
}

.track-link:hover {
	border-color: var(--accent);
	color: var(--accent);
}

.track-link.soon {
	opacity: 0.38;
	pointer-events: none;
	font-style: italic;
	background: transparent;
}

footer {
	border-top: 1px solid var(--rule);
	background: var(--paper2);
	padding: 2.5rem 6rem;
	display: flex;
	align-items: center;
	justify-content: space-between;
	flex-wrap: wrap;
	gap: 1rem;
}

.footer-logo img {
	height: 30px;
	width: auto;
	filter: sepia(0.4) brightness(0.8) contrast(1.1);
	opacity: 0.8;
}

.footer-logo-text {
	font-family: 'EB Garamond', serif;
	font-size: 1rem;
	font-style: italic;
	color: var(--ink3);
}

.footer-copy {
	font-family: 'DM Mono', monospace;
	font-size: 0.52rem;
	color: var(--ink4);
	letter-spacing: 0.18em;
	text-align: right;
	line-height: 1.8;
}

.bottom-rule {
	height: 3px;
	background: linear-gradient(to right, transparent 0%, var(--ink4) 20%, var(--accent) 50%, var(--ink4) 80%, transparent 100%);
}

@keyframes fadeUp {
	from {
		opacity: 0;
		transform: translateY(18px);
	}

	to {
		opacity: 1;
		transform: translateY(0);
	}
}

@keyframes fadeIn {
	from {
		opacity: 0;
	}

	to {
		opacity: 1;
	}
}

@media (max-width: 1000px) {
	nav {
		padding: 0 2rem;
	}

	.nav-links {
		gap: 1.5rem;
	}

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

	.hero-sep {
		display: none;
	}

	.hero-right {
		height: 60vw;
		max-height: 380px;
		order: -1;
	}

	.hero-photo::after {
		background: linear-gradient(to top, var(--paper) 0%, transparent 40%);
	}

	.hero-left {
		padding: 3rem 2.5rem 4rem;
	}

	.sidenote {
		padding: 2rem 2.5rem;
		flex-direction: column;
		gap: 1rem;
	}

	.sidenote-body {
		border-left: none;
		padding-left: 0;
		border-top: 1px solid var(--rule);
		padding-top: 1rem;
	}

	.socials {
		padding: 1.75rem 2.5rem;
	}

	.section {
		padding: 3.5rem 2.5rem;
	}

	footer {
		padding: 2rem 2.5rem;
	}

	.albums-grid {
		grid-template-columns: repeat(auto-fill, minmax(130px, 1fr));
		gap: 1.2rem;
	}

	.tracklist-panel {
		padding: 1.75rem 1.5rem;
	}
}

@media (max-width: 600px) {
	.hero-title {
		font-size: 2.8rem;
	}

	.nav-links {
		display: none;
	}

	.track {
		flex-wrap: wrap;
	}

	.track-links {
		width: 100%;
		padding-left: 2.75rem;
	}

	.albums-grid {
		grid-template-columns: repeat(auto-fill, minmax(115px, 1fr));
		gap: 1rem;
	}

	.section {
		padding: 3rem 1.5rem;
	}

	footer {
		padding: 1.75rem 1.5rem;
		flex-direction: column;
		align-items: flex-start;
	}
}