:root {
  --accent: #d27722;
  --accent-strong: #a94d1f;
  --signal: #f0b84f;
  --ink: #171717;
  --text: #3f413d;
  --muted: #6e716b;
  --line: #d6cec0;
  --paper: #f4f0e8;
  --soft: #e9e1d4;
  --panel: #fffaf0;
  --night: #101112;
  --night-soft: #1b1c1d;
}
* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body { margin: 0; background: var(--night); color: var(--text); font: 16px/1.68 Inter, "Helvetica Neue", Arial, sans-serif; }
body::before { content: ""; position: fixed; inset: 0; pointer-events: none; opacity: .34; background-image: linear-gradient(90deg, rgba(255,255,255,.035) 1px, transparent 1px), linear-gradient(180deg, rgba(255,255,255,.025) 1px, transparent 1px); background-size: 42px 42px; }
img { max-width: 100%; height: auto; display: block; }
a { color: #4f555a; text-decoration: none; transition: color .16s ease, border-color .16s ease, background .16s ease, box-shadow .16s ease, transform .16s ease; }
a:hover, a:focus { color: var(--accent); }
strong, b { font-weight: 750; color: var(--ink); }
em { font-family: Georgia, "Times New Roman", serif; color: #656963; }
h1, h2, h3, h4 { color: var(--ink); line-height: 1.08; margin: 0 0 18px; }
h1 { font-size: 64px; letter-spacing: 0; }
h2 { font-size: 30px; color: var(--ink); }
h3 { font-size: 22px; }
h4 { font-size: 16px; }
.page-header h1 { font-size: 58px; }
.label-hero h1 { font-size: 68px; }
p { margin: 0 0 18px; }
.site { position: relative; width: min(1180px, calc(100% - 36px)); margin: 0 auto; min-height: 100vh; background: var(--paper); box-shadow: 0 0 0 1px rgba(255,255,255,.08), 0 34px 90px rgba(0,0,0,.45); }
.site-header { position: sticky; top: 0; z-index: 10; padding: 22px clamp(18px, 4vw, 44px) 0; background: rgba(244, 240, 232, .96); border-bottom: 1px solid var(--line); backdrop-filter: blur(12px); }
.header-inner { min-height: 66px; display: flex; align-items: flex-end; justify-content: space-between; gap: 28px; }
.logo-link { display: inline-flex; align-items: center; gap: 12px; min-height: 58px; max-width: 270px; padding: 0 0 12px; border-bottom: 3px solid var(--accent); }
.logo-link img { width: 58px; height: 42px; object-fit: contain; flex: 0 0 auto; }
.logo-link span { color: var(--ink); font-size: 18px; font-weight: 850; letter-spacing: .03em; white-space: nowrap; }
.nav-toggle { display: none; }
.site-nav ul { display: flex; flex-wrap: wrap; gap: 0 28px; align-items: flex-end; list-style: none; margin: 0; padding: 0; }
.site-nav a { display: block; min-height: 58px; padding-top: 18px; border-bottom: 3px solid transparent; color: #4d514d; font-size: 13px; font-weight: 800; letter-spacing: .08em; text-transform: uppercase; }
.site-nav a:hover, .site-nav a[aria-current="page"] { color: var(--ink); border-bottom-color: var(--accent); }
.site-nav .listen-link { color: var(--accent-strong); }
main, .site-footer { padding-inline: clamp(18px, 4vw, 44px); }
.page-header { position: relative; border-bottom: 1px solid var(--line); padding: 58px 0 28px; }
.page-header::before { content: "dPole Records / Underground Electronic Music"; display: block; margin-bottom: 14px; color: var(--accent-strong); font-size: 12px; font-weight: 800; letter-spacing: .12em; text-transform: uppercase; }
.page-header h1 { color: var(--ink); }
.page-header p { max-width: 780px; color: var(--muted); font: italic 21px/1.45 Georgia, "Times New Roman", serif; }
.content { padding: 38px 0 24px; }
.label-hero { display: grid; grid-template-columns: minmax(0, 1fr) minmax(260px, 392px); gap: clamp(28px, 5vw, 62px); align-items: stretch; padding: clamp(30px, 6vw, 70px) 0 44px; border-bottom: 1px solid var(--line); }
.label-hero-copy { align-self: center; }
.kicker, .section-kicker { margin-bottom: 14px; color: var(--accent-strong); font-size: 12px; font-weight: 850; letter-spacing: .14em; text-transform: uppercase; }
.label-hero h1 { max-width: 760px; margin-bottom: 24px; color: var(--ink); }
.hero-statement { max-width: 680px; color: #343732; font-size: clamp(20px, 3vw, 28px); line-height: 1.36; }
.hero-actions { display: flex; flex-wrap: wrap; gap: 14px; margin-top: 30px; }
.hero-art { position: relative; align-self: center; padding: 16px; background: var(--night-soft); box-shadow: 18px 18px 0 var(--accent), 0 24px 60px rgba(0,0,0,.28); }
.hero-art img { width: 100%; aspect-ratio: 1 / 1; object-fit: cover; background: #f7f6f2; }
.hero-art figcaption { margin-top: 13px; color: #f3efe7; font-size: 13px; font-weight: 800; letter-spacing: .08em; text-transform: uppercase; }
.home-grid { display: grid; grid-template-columns: minmax(0, 1fr) minmax(250px, 340px); gap: clamp(28px, 5vw, 60px); align-items: start; }
.symbol-panel { background: var(--night-soft); color: #ede8dc; border-top: 4px solid var(--accent); padding: 24px; }
.symbol-panel img { width: 42px; height: auto; margin-bottom: 22px; }
.symbol-panel strong { color: #fff8ec; }
.symbol-panel p { color: #d7cfc3; }
.entry-list { display: grid; gap: 0; }
.entry { border-top: 1px solid var(--line); padding: 30px 0 24px; }
.entry:first-child { border-top: 0; padding-top: 0; }
.entry-meta { margin-bottom: 13px; color: var(--accent-strong); font-size: 12px; font-weight: 850; letter-spacing: .12em; text-transform: uppercase; }
.read-more { display: inline-block; margin-top: 5px; font-weight: 800; color: #4f555a; border-bottom: 2px solid rgba(210, 119, 34, .38); }
.read-more:hover, .read-more:focus { border-bottom-color: var(--accent); }
.cta-link, .secondary-cta { display: inline-flex; align-items: center; min-height: 44px; border: 1px solid var(--accent); border-radius: 2px; padding: 11px 16px; font-size: 13px; font-weight: 850; letter-spacing: .08em; text-transform: uppercase; }
.cta-link { color: #fffaf0; background: var(--accent); border-bottom: 1px solid var(--accent); box-shadow: 0 12px 24px rgba(210, 119, 34, .18); }
.cta-link:hover, .cta-link:focus { color: #fff; background: var(--accent-strong); border-color: var(--accent-strong); transform: translateY(-1px); }
.secondary-cta { color: var(--ink); background: transparent; }
.secondary-cta:hover, .secondary-cta:focus { color: var(--ink); background: rgba(210, 119, 34, .1); }
.release-notice { padding-bottom: 0; }
.release-notice + .grid { padding-top: 16px; }
.grid { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 30px; }
.tile { position: relative; background: var(--panel); border: 1px solid var(--line); border-top: 4px solid var(--accent); padding: 16px; box-shadow: 0 18px 42px rgba(16, 17, 18, .11); }
.tile:hover { transform: translateY(-2px); }
.tile img { width: 100%; max-height: 520px; aspect-ratio: 1 / 1; object-fit: cover; background: var(--soft); }
.tile h2, .tile h3 { margin-top: 16px; margin-bottom: 8px; }
.tile p { color: var(--text); }
.text-tile { min-height: 245px; display: flex; flex-direction: column; justify-content: space-between; }
.text-tile h2 { margin-top: 0; }
.collaborator-section { border-top: 1px solid var(--line); }
.collaborator-grid { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 24px; }
.collaborator-group { background: var(--panel); border: 1px solid var(--line); border-left: 4px solid var(--accent); padding: 24px; }
.collaborator-group ul { list-style: none; margin: 0; padding: 0; }
.collaborator-group li { border-top: 1px solid var(--line); padding: 11px 0; }
.collaborator-group li:first-child { border-top: 0; padding-top: 0; }
.collaborator-group strong { display: block; }
.collaborator-group span { display: block; margin-top: 3px; color: var(--muted); font-size: 14px; line-height: 1.45; }
.profile, .release-cover { display: grid; grid-template-columns: minmax(280px, 430px) minmax(0, 1fr); gap: clamp(30px, 5vw, 58px); align-items: start; }
.profile img, .release-cover img { width: 100%; background: var(--night-soft); border: 14px solid var(--night-soft); box-shadow: 14px 14px 0 var(--accent); }
.profile img { max-height: 620px; object-fit: cover; }
.release-cover img { max-height: 620px; object-fit: contain; }
.artist-note { max-width: 760px; }
.release-copy { max-width: 620px; }
.track-list { margin: 0 0 24px; padding-left: 20px; }
.track-list li { margin-bottom: 8px; }
.soundcloud { width: 100%; height: 166px; border: 0; margin: 10px 0 25px; background: var(--soft); }
.contact-block { max-width: 840px; }
.contact-sections { display: grid; gap: 24px; }
.contact-section { background: var(--panel); border: 1px solid var(--line); border-left: 4px solid var(--accent); padding: 26px; }
.contact-section h2 { font-size: 26px; line-height: 1.12; }
.contact-section .callout { margin-bottom: 0; }
.callout { background: var(--panel); border: 1px solid var(--line); border-left: 4px solid var(--accent); padding: 22px 24px; margin: 24px 0; box-shadow: 0 14px 34px rgba(16, 17, 18, .08); }
.site-footer { margin-top: 44px; border-top: 1px solid var(--line); padding-top: 36px; padding-bottom: 58px; color: var(--muted); }
.footer-inner { display: flex; justify-content: space-between; gap: 25px; align-items: center; }
.footer-brand { display: inline-flex; align-items: center; gap: 10px; font-weight: 800; }
.footer-brand img { width: 46px; height: 33px; object-fit: contain; }
.footer-brand span { white-space: nowrap; }
.footer-nav { display: flex; gap: 22px; flex-wrap: wrap; }
.footer-nav a { font-size: 13px; font-weight: 800; letter-spacing: .08em; text-transform: uppercase; }
@media (max-width: 920px) { h1 { font-size: 54px; } h2 { font-size: 28px; } .page-header h1 { font-size: 52px; } .label-hero h1 { font-size: 58px; } .site-header { position: static; padding-top: 24px; } .header-inner { align-items: stretch; flex-direction: column; gap: 0; } .logo-link { width: max-content; } .site-nav { border-top: 1px solid var(--line); } .site-nav ul { gap: 0 22px; } .site-nav a { min-height: 46px; padding-top: 13px; } .label-hero, .home-grid, .profile, .release-cover { grid-template-columns: 1fr; } .hero-art { max-width: 480px; } .grid, .collaborator-grid { grid-template-columns: 1fr; } .tile img, .profile img, .release-cover img { max-height: 520px; } }
@media (max-width: 560px) { h1 { font-size: 42px; } h2 { font-size: 25px; } h3 { font-size: 20px; } h4 { font-size: 15px; } .page-header h1, .label-hero h1 { font-size: 42px; } .contact-section h2 { font-size: 23px; } body::before { display: none; } .site { width: 100%; } .site-header { padding-inline: 16px; } main, .site-footer { padding-inline: 16px; } .logo-link img { width: 52px; height: 37px; } .logo-link span { font-size: 16px; } .site-nav ul { gap: 0 16px; } .site-nav a { min-height: 40px; font-size: 12px; padding-top: 11px; } .label-hero { padding-top: 34px; } .page-header { padding-top: 36px; } .page-header p { font-size: 18px; } .content { padding: 30px 0 18px; } .hero-statement { font-size: 20px; } .hero-art { padding: 10px; box-shadow: 10px 10px 0 var(--accent); } .tile { padding: 12px; } .tile img, .profile img, .release-cover img { max-height: 410px; } .profile img, .release-cover img { border-width: 10px; box-shadow: 10px 10px 0 var(--accent); } .footer-inner { align-items: flex-start; flex-direction: column; } }
