/* =========================================================
   Sound Of Mind Records — Bold Modern Redesign
   ========================================================= */

@import url('https://fonts.googleapis.com/css2?family=Syne:wght@400;500;600;700;800&family=DM+Sans:ital,opsz,wght@0,9..40,300;0,9..40,400;0,9..40,500;0,9..40,600;1,9..40,300&display=swap');

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

:root {
  --black:  #0c0c0c;
  --white:  #ffffff;
  --g1:     #1c1c1c;
  --g2:     #3a3a3a;
  --g3:     #6b6b6b;
  --g4:     #a0a0a0;
  --g5:     #d4d4d4;
  --g6:     #ebebeb;
  --g7:     #f5f5f5;
  --accent: #0c0c0c;
  --t:      .28s cubic-bezier(.4,0,.2,1);
}

html { scroll-behavior: smooth; font-size: 16px; }

body {
  font-family: 'DM Sans', sans-serif;
  background: var(--white);
  color: var(--black);
  -webkit-font-smoothing: antialiased;
  overflow-x: hidden;
  line-height: 1.6;
}

*, input, button, select, textarea { font-family: inherit; }
a { color: inherit; text-decoration: none; }
img { display: block; max-width: 100%; }
ul { list-style: none; }

::-webkit-scrollbar { width: 2px; }
::-webkit-scrollbar-track { background: var(--white); }
::-webkit-scrollbar-thumb { background: var(--g5); }

/* ── Utilities ── */
.wrap { max-width: 1360px; margin: 0 auto; padding: 0 48px; }
.s-gap { padding: 110px 0; }
.s-gap-sm { padding: 72px 0; }

/* ─────────────────────────────────────────────
   NAV
───────────────────────────────────────────── */
#nav {
  position: fixed;
  inset: 0 0 auto;
  height: 60px;
  z-index: 200;
  display: grid;
  grid-template-columns: 1fr auto 1fr;
  align-items: center;
  padding: 0 48px;
}
#nav.scrolled {
  background: rgba(255,255,255,.95);
  backdrop-filter: blur(16px);
  -webkit-backdrop-filter: blur(16px);
  border-bottom: 1px solid var(--g6);
}
.nav-logo {
  font-family: 'Syne', sans-serif;
  font-weight: 800;
  font-size: .95rem;
  letter-spacing: .04em;
  text-transform: uppercase;
  color: var(--black);
  line-height: 1;
}
.nav-logo small {
  display: block;
  font-size: .5rem;
  font-weight: 600;
  letter-spacing: .25em;
  color: var(--g4);
  margin-top: 3px;
}
.nav-mid {
  display: flex;
  gap: 36px;
  justify-self: center;
}
.nav-mid a {
  font-size: .7rem;
  font-weight: 600;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: var(--g3);
  transition: color var(--t);
  position: relative;
}
.nav-mid a::after {
  content: '';
  position: absolute;
  bottom: -3px; left: 0; right: 0;
  height: 1px;
  background: var(--black);
  transform: scaleX(0);
  transition: transform var(--t);
}
.nav-mid a:hover { color: var(--black); }
.nav-mid a:hover::after { transform: scaleX(1); }
.nav-cta {
  font-family: 'Syne', sans-serif;
  font-size: .68rem;
  font-weight: 700;
  letter-spacing: .12em;
  text-transform: uppercase;
  background: var(--black);
  color: var(--white);
  padding: 10px 22px;
  transition: background var(--t), color var(--t);
}
.nav-cta:hover { background: var(--g1); color: var(--white); }

.nav-right {
  display: flex;
  align-items: center;
  gap: 16px;
  justify-self: end;
}
.nav-social {
  display: flex;
  align-items: center;
  gap: 16px;
}
.nav-social a {
  color: var(--g3);
  display: flex;
  align-items: center;
  transition: color var(--t);
}
.nav-social a:hover { color: var(--black); }

.nav-toggle {
  display: none;
  flex-direction: column;
  gap: 5px;
  cursor: pointer;
  border: none;
  background: none;
  padding: 4px;
}
.nav-toggle span { display: block; width: 22px; height: 1.5px; background: var(--black); transition: all var(--t); }

.nav-drawer {
  position: fixed;
  inset: 0;
  background: var(--white);
  z-index: 190;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  gap: 28px;
  opacity: 0;
  pointer-events: none;
  transition: opacity var(--t);
}
.nav-drawer.open { opacity: 1; pointer-events: all; }
.nav-drawer a {
  font-family: 'Syne', sans-serif;
  font-size: 3rem;
  font-weight: 800;
  letter-spacing: -.01em;
  text-transform: uppercase;
  color: var(--black);
  transition: color var(--t);
}
.nav-drawer a:hover { color: var(--g4); }

/* ─────────────────────────────────────────────
   HERO
───────────────────────────────────────────── */
#hero {
  min-height: 100vh;
  min-height: 100svh;
  display: flex;
  flex-direction: column;
  background: var(--white);
  padding-top: 60px;
  position: relative;
  overflow: hidden;
}
.hero-bg-image {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center 30%;
  opacity: .05;
  filter: grayscale(100%);
  pointer-events: none;
  user-select: none;
}

/* Top row */
.hero-top {
  flex: 1;
  display: flex;
  flex-direction: column;
  justify-content: center;
  padding: 48px 48px 0;
}
.hero-eyebrow {
  display: flex;
  align-items: center;
  gap: 14px;
  margin-bottom: 24px;
}
.hero-eyebrow span {
  font-size: .62rem;
  font-weight: 600;
  letter-spacing: .24em;
  text-transform: uppercase;
  color: var(--g4);
}
.hero-eyebrow-dot {
  width: 6px; height: 6px;
  border-radius: 50%;
  background: var(--black);
  animation: pulse 2.5s ease infinite;
}
@keyframes pulse { 0%,100% { opacity:1; } 50% { opacity:.3; } }

.hero-title {
  font-family: 'Syne', sans-serif;
  font-weight: 800;
  font-size: clamp(5rem, 12vw, 11rem);
  line-height: .88;
  letter-spacing: -.04em;
  text-transform: uppercase;
  color: var(--black);
  margin-bottom: 0;
}
.hero-title-outline {
  -webkit-text-stroke: 1.5px var(--black);
  color: transparent;
  display: block;
}

/* Ticker */
.hero-ticker {
  border-top: 1px solid var(--g6);
  border-bottom: 1px solid var(--g6);
  padding: 14px 0;
  overflow: hidden;
  margin-top: 40px;
  background: var(--white);
}
.hero-ticker-track {
  display: flex;
  gap: 0;
  animation: ticker 20s linear infinite;
  width: max-content;
}
.hero-ticker-track:hover { animation-play-state: paused; }
.hero-ticker-item {
  display: flex;
  align-items: center;
  gap: 20px;
  padding: 0 40px;
  font-family: 'Syne', sans-serif;
  font-size: .72rem;
  font-weight: 700;
  letter-spacing: .18em;
  text-transform: uppercase;
  color: var(--g3);
  white-space: nowrap;
}
.hero-ticker-item::before {
  content: '◆';
  font-size: .4rem;
  color: var(--black);
}
@keyframes ticker { from { transform: translateX(0); } to { transform: translateX(-50%); } }

/* Bottom row */
.hero-bottom {
  display: grid;
  grid-template-columns: 1fr auto;
  align-items: end;
  gap: 48px;
  padding: 40px 48px 56px;
  border-top: none;
}
.hero-desc {
  font-size: 1rem;
  color: var(--g3);
  line-height: 1.75;
  max-width: 500px;
  font-weight: 300;
}
.hero-actions {
  display: flex;
  flex-direction: column;
  align-items: flex-end;
  gap: 12px;
}
.hero-number {
  font-family: 'Syne', sans-serif;
  font-size: 5rem;
  font-weight: 800;
  color: var(--g6);
  line-height: 1;
  letter-spacing: -.04em;
  user-select: none;
}

/* ─────────────────────────────────────────────
   BUTTONS
───────────────────────────────────────────── */
.btn {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  font-family: 'Syne', sans-serif;
  font-size: .68rem;
  font-weight: 700;
  letter-spacing: .14em;
  text-transform: uppercase;
  padding: 14px 30px;
  border: none;
  cursor: pointer;
  transition: all var(--t);
  white-space: nowrap;
}
.btn-fill { background: var(--black); color: var(--white); }
.btn-fill:hover { background: var(--g1); color: var(--white); }
.btn-ghost { background: transparent; color: var(--black); border: 1.5px solid var(--g5); }
.btn-ghost:hover { border-color: var(--black); }
.btn-arrow::after { content: '→'; font-size: .85em; transition: transform var(--t); }
.btn-arrow:hover::after { transform: translateX(4px); }

/* ─────────────────────────────────────────────
   SECTION LABEL ROW
───────────────────────────────────────────── */
.sec-label-row {
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  padding-bottom: 32px;
  border-bottom: 1px solid var(--g6);
  margin-bottom: 56px;
}
.sec-label {
  display: flex;
  flex-direction: column;
  gap: 10px;
}
.sec-tag {
  font-size: .62rem;
  font-weight: 600;
  letter-spacing: .22em;
  text-transform: uppercase;
  color: var(--g4);
}
.sec-title {
  font-family: 'Syne', sans-serif;
  font-size: clamp(2rem, 4.5vw, 3.8rem);
  font-weight: 800;
  letter-spacing: -.03em;
  text-transform: uppercase;
  color: var(--black);
  line-height: .95;
}
.sec-meta {
  font-size: .72rem;
  color: var(--g4);
  letter-spacing: .06em;
  padding-bottom: 6px;
}

/* ─────────────────────────────────────────────
   RELEASES
───────────────────────────────────────────── */
#releases { background: var(--white); }

.releases-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1px;
  background: var(--g6);
  outline: 1px solid var(--g6);
}
.rel-card {
  background: var(--white);
  display: flex;
  flex-direction: column;
  overflow: hidden;
  transition: box-shadow var(--t);
  cursor: pointer;
}
.rel-card:hover { box-shadow: 0 12px 48px rgba(0,0,0,.1); z-index: 1; position: relative; }
.rel-card-img {
  aspect-ratio: 1;
  overflow: hidden;
  background: var(--g7);
  position: relative;
}
.rel-card-img img {
  width: 100%; height: 100%;
  object-fit: cover;
  transition: transform .6s cubic-bezier(.4,0,.2,1);
}
.rel-card:hover .rel-card-img img { transform: scale(1.06); }
.rel-card-num {
  position: absolute;
  top: 14px; left: 14px;
  font-family: 'Syne', sans-serif;
  font-size: .62rem;
  font-weight: 800;
  letter-spacing: .1em;
  background: var(--white);
  color: var(--black);
  padding: 4px 9px;
}
.rel-card-body { padding: 18px 22px 22px; flex: 1; display: flex; flex-direction: column; }
.rel-card-type {
  font-size: .58rem;
  font-weight: 700;
  letter-spacing: .16em;
  text-transform: uppercase;
  color: var(--g4);
  margin-bottom: 8px;
}
.rel-card-title {
  font-family: 'Syne', sans-serif;
  font-size: 1.05rem;
  font-weight: 700;
  color: var(--black);
  line-height: 1.25;
  margin-bottom: 4px;
  letter-spacing: -.01em;
}
.rel-card-artist { font-size: .8rem; color: var(--g3); margin-bottom: 16px; }
.rel-card-links { display: flex; gap: 6px; flex-wrap: wrap; margin-top: auto; }
.rel-link {
  font-size: .56rem;
  font-weight: 700;
  letter-spacing: .1em;
  text-transform: uppercase;
  padding: 6px 11px;
  border: 1px solid var(--g6);
  color: var(--g3);
  transition: all var(--t);
}
.rel-link:hover { background: var(--black); border-color: var(--black); color: var(--white); }

.releases-empty {
  grid-column: 1 / -1;
  text-align: center;
  padding: 100px 0;
  color: var(--g4);
}

/* ─────────────────────────────────────────────
   ARTISTS
───────────────────────────────────────────── */
#artists { background: var(--g7); }

.artists-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 24px;
}
.art-card {
  background: var(--white);
  overflow: hidden;
  border: 1px solid var(--g6);
  transition: border-color var(--t), transform var(--t), box-shadow var(--t);
}
.art-card:hover {
  border-color: var(--black);
  transform: translateY(-4px);
  box-shadow: 0 16px 48px rgba(0,0,0,.1);
}
.art-card-img {
  aspect-ratio: 3/4;
  overflow: hidden;
  background: var(--g6);
  position: relative;
}
.art-card-img img {
  width: 100%; height: 100%;
  object-fit: cover;
  filter: grayscale(8%);
  transition: transform .6s cubic-bezier(.4,0,.2,1), filter .4s ease;
}
.art-card:hover .art-card-img img { transform: scale(1.04); filter: grayscale(0%); }
.art-card-body { padding: 20px 22px 24px; }
.art-card-name {
  font-family: 'Syne', sans-serif;
  font-size: 1.15rem;
  font-weight: 800;
  letter-spacing: -.01em;
  text-transform: uppercase;
  color: var(--black);
  margin-bottom: 8px;
}
.art-card-bio {
  font-size: .83rem;
  color: var(--g3);
  line-height: 1.65;
  margin-bottom: 16px;
  display: -webkit-box;
  -webkit-line-clamp: 3;
  -webkit-box-orient: vertical;
  overflow: hidden;
}
.art-card-links { display: flex; gap: 6px; flex-wrap: wrap; }
.art-link {
  font-size: .58rem;
  font-weight: 700;
  letter-spacing: .1em;
  text-transform: uppercase;
  padding: 6px 12px;
  border: 1px solid var(--g6);
  color: var(--g3);
  transition: all var(--t);
}
.art-link:hover { background: var(--black); border-color: var(--black); color: var(--white); }
.artists-empty { grid-column:1/-1; text-align:center; padding:80px 0; color:var(--g4); }

/* ─────────────────────────────────────────────
   ABOUT — Split editorial
───────────────────────────────────────────── */
#about { background: var(--white); }

.about-split {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1px;
  background: var(--g6);
  outline: 1px solid var(--g6);
  margin-bottom: 1px;
}
.about-col {
  background: var(--white);
  padding: 64px;
}
.about-col.alt { background: var(--g7); }
.about-big-quote {
  font-family: 'Syne', sans-serif;
  font-size: clamp(1.6rem, 3.5vw, 2.6rem);
  font-weight: 800;
  letter-spacing: -.03em;
  text-transform: uppercase;
  color: var(--black);
  line-height: 1.1;
  margin-bottom: 40px;
}
.about-big-quote em {
  font-style: normal;
  color: var(--g4);
}
.about-body-text {
  font-size: .95rem;
  color: var(--g2);
  line-height: 1.85;
  font-weight: 300;
  margin-bottom: 32px;
}

.about-stats-row {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1px;
  background: var(--g6);
  outline: 1px solid var(--g6);
  margin-bottom: 40px;
}
.about-stat {
  background: var(--white);
  padding: 28px 20px;
  text-align: left;
}
.about-stat-n {
  font-family: 'Syne', sans-serif;
  font-size: 3rem;
  font-weight: 800;
  color: var(--black);
  line-height: 1;
  display: block;
  letter-spacing: -.04em;
}
.about-stat-l {
  font-size: .6rem;
  font-weight: 600;
  letter-spacing: .18em;
  text-transform: uppercase;
  color: var(--g4);
  margin-top: 8px;
  display: block;
}

.about-genres-list { margin-top: 8px; }
.about-genre-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 16px 0;
  border-bottom: 1px solid var(--g6);
  font-family: 'Syne', sans-serif;
  font-size: .82rem;
  font-weight: 700;
  letter-spacing: .04em;
  text-transform: uppercase;
  color: var(--black);
  transition: color var(--t);
  cursor: default;
}
.about-genre-row:first-child { border-top: 1px solid var(--g6); }
.about-genre-row:hover { color: var(--g3); }
.about-genre-row span {
  font-family: 'DM Sans', sans-serif;
  font-size: .62rem;
  font-weight: 400;
  color: var(--g5);
  letter-spacing: .05em;
}

/* ─────────────────────────────────────────────
   CONTACT
───────────────────────────────────────────── */
#contact { background: var(--g7); }

.contact-split {
  display: grid;
  grid-template-columns: 400px 1fr;
  gap: 1px;
  background: var(--g6);
  outline: 1px solid var(--g6);
}
.contact-info {
  background: var(--black);
  padding: 56px 48px;
  color: var(--white);
  display: flex;
  flex-direction: column;
}
.contact-info-title {
  font-family: 'Syne', sans-serif;
  font-size: 1.8rem;
  font-weight: 800;
  letter-spacing: -.03em;
  text-transform: uppercase;
  color: var(--white);
  line-height: 1.1;
  margin-bottom: 20px;
}
.contact-info-desc {
  font-size: .88rem;
  color: rgba(255,255,255,.5);
  line-height: 1.75;
  font-weight: 300;
  margin-bottom: 40px;
}
.contact-detail {
  padding: 20px 0;
  border-top: 1px solid rgba(255,255,255,.08);
}
.contact-detail:last-of-type { border-bottom: 1px solid rgba(255,255,255,.08); }
.contact-d-label {
  font-size: .56rem;
  font-weight: 700;
  letter-spacing: .2em;
  text-transform: uppercase;
  color: rgba(255,255,255,.35);
  margin-bottom: 6px;
  display: block;
}
.contact-d-val {
  font-size: .88rem;
  color: rgba(255,255,255,.8);
  font-weight: 500;
}
.contact-d-val a { color: rgba(255,255,255,.8); transition: color var(--t); }
.contact-d-val a:hover { color: var(--white); }
.contact-socials {
  margin-top: auto;
  padding-top: 32px;
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
}
.c-social {
  font-size: .58rem;
  font-weight: 700;
  letter-spacing: .12em;
  text-transform: uppercase;
  padding: 8px 14px;
  border: 1px solid rgba(255,255,255,.15);
  color: rgba(255,255,255,.5);
  transition: all var(--t);
}
.c-social:hover { border-color: var(--white); color: var(--white); }

.contact-form-wrap {
  background: var(--white);
  padding: 56px 48px;
}
.form { display: flex; flex-direction: column; gap: 22px; }
.form-row { display: grid; grid-template-columns: 1fr 1fr; gap: 22px; }
.fg { display: flex; flex-direction: column; gap: 8px; }
.flabel {
  font-size: .6rem;
  font-weight: 700;
  letter-spacing: .16em;
  text-transform: uppercase;
  color: var(--black);
}
.finput {
  width: 100%;
  background: var(--g7);
  border: 1px solid transparent;
  border-bottom: 1.5px solid var(--g5);
  color: var(--black);
  padding: 13px 16px;
  font-size: .9rem;
  font-weight: 400;
  outline: none;
  transition: background var(--t), border-color var(--t);
  appearance: none;
}
.finput:focus { background: var(--white); border-color: transparent; border-bottom-color: var(--black); }
.finput::placeholder { color: var(--g5); }
.ftextarea { resize: vertical; min-height: 140px; }
.fmsg { font-size: .85rem; padding: 12px 16px; display: none; }
.fmsg.ok  { background: #ecfdf5; color: #166534; border: 1px solid #bbf7d0; display: block; }
.fmsg.err { background: #fef2f2; color: #991b1b; border: 1px solid #fecaca; display: block; }

/* ─────────────────────────────────────────────
   FOOTER
───────────────────────────────────────────── */
#footer {
  background: var(--black);
  color: var(--white);
}
.footer-top {
  display: grid;
  grid-template-columns: 1.8fr 1fr 1fr 1fr;
  gap: 1px;
  background: rgba(255,255,255,.06);
  outline: 1px solid rgba(255,255,255,.06);
  border-bottom: 1px solid rgba(255,255,255,.06);
}
.footer-col {
  padding: 56px 48px;
}
.footer-brand {
  font-family: 'Syne', sans-serif;
  font-size: 1.4rem;
  font-weight: 800;
  letter-spacing: -.02em;
  text-transform: uppercase;
  color: var(--white);
  margin-bottom: 6px;
  line-height: 1.1;
}
.footer-brand-sub {
  font-size: .56rem;
  font-weight: 600;
  letter-spacing: .22em;
  text-transform: uppercase;
  color: rgba(255,255,255,.3);
  display: block;
  margin-bottom: 18px;
}
.footer-desc {
  font-size: .82rem;
  color: rgba(255,255,255,.38);
  line-height: 1.75;
  max-width: 260px;
  font-weight: 300;
}
.footer-socials { display: flex; gap: 8px; margin-top: 24px; }
.footer-soc {
  width: 34px; height: 34px;
  display: flex; align-items: center; justify-content: center;
  border: 1px solid rgba(255,255,255,.1);
  color: rgba(255,255,255,.4);
  transition: all var(--t);
}
.footer-soc:hover { border-color: var(--white); color: var(--white); }
.footer-col-title {
  font-size: .58rem;
  font-weight: 700;
  letter-spacing: .22em;
  text-transform: uppercase;
  color: rgba(255,255,255,.25);
  margin-bottom: 20px;
  display: block;
}
.footer-links { display: flex; flex-direction: column; gap: 12px; }
.footer-links a {
  font-size: .84rem;
  color: rgba(255,255,255,.45);
  transition: color var(--t);
  font-weight: 400;
}
.footer-links a:hover { color: var(--white); }

.footer-bottom {
  padding: 24px 48px;
  display: flex;
  justify-content: space-between;
  align-items: center;
  border-top: 1px solid rgba(255,255,255,.06);
}
.footer-copy { font-size: .75rem; color: rgba(255,255,255,.22); }
.footer-tag {
  font-family: 'Syne', sans-serif;
  font-size: .6rem;
  font-weight: 700;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: rgba(255,255,255,.18);
}

/* ─────────────────────────────────────────────
   ANIMATIONS
───────────────────────────────────────────── */
.fade-up {
  opacity: 0;
  transform: translateY(28px);
  transition: opacity .65s cubic-bezier(.4,0,.2,1), transform .65s cubic-bezier(.4,0,.2,1);
}
.fade-up.in { opacity: 1; transform: translateY(0); }

/* ─────────────────────────────────────────────
   RESPONSIVE
───────────────────────────────────────────── */

/* ── Tablet landscape (≤1100px) ── */
@media (max-width: 1100px) {
  .releases-grid { grid-template-columns: repeat(2, 1fr); }
  .artists-grid  { grid-template-columns: repeat(2, 1fr); }
  .about-split   { grid-template-columns: 1fr; }
  .about-col     { padding: 48px; }
  .contact-split { grid-template-columns: 1fr; }
  .footer-top    { grid-template-columns: 1fr 1fr; }
  .nav-social    { display: none; }
  .nav-right     { gap: 12px; }
  .hero-title    { font-size: clamp(4rem, 10vw, 7rem); }
}

/* ── Tablet portrait (≤900px) ── */
@media (max-width: 900px) {
  .wrap          { padding: 0 32px; }
  .s-gap         { padding: 80px 0; }
  #nav           { padding: 0 32px; }
  .hero-title    { font-size: clamp(3.5rem, 9vw, 5.5rem); }
  .hero-top      { padding: 40px 32px 0; }
  .hero-bottom   { padding: 32px 32px 48px; }
  .about-col     { padding: 40px 32px; }
  .contact-info      { padding: 44px 36px; }
  .contact-form-wrap { padding: 44px 36px; }
  .footer-col    { padding: 44px 36px; }
  .footer-bottom { padding: 22px 36px; }
}

/* ── Mobile (≤768px) ── */
@media (max-width: 768px) {
  .wrap          { padding: 0 20px; }
  .s-gap         { padding: 64px 0; }
  #nav           { padding: 0 20px; grid-template-columns: auto 1fr auto; }
  .nav-mid       { display: none; }
  .nav-cta       { display: none; }
  .nav-toggle    { display: flex; }
  .hero-title    { font-size: clamp(3rem, 9vw, 4.5rem); }
  .hero-top      { padding: 36px 24px 0; }
  .hero-bottom   { grid-template-columns: 1fr; padding: 28px 20px 44px; gap: 20px; }
  .hero-actions  { align-items: flex-start; flex-direction: row; flex-wrap: wrap; }
  .hero-desc     { font-size: .9rem; max-width: 100%; }
  .sec-label-row { flex-direction: column; align-items: flex-start; gap: 8px; }
  .form-row      { grid-template-columns: 1fr; }
  .about-col     { padding: 36px 20px; }
  .about-stats-row { grid-template-columns: repeat(3, 1fr); }
  .contact-info      { padding: 36px 20px; }
  .contact-form-wrap { padding: 36px 20px; }
  .footer-top    { grid-template-columns: 1fr; }
  .footer-col    { padding: 36px 20px; }
  .footer-bottom { flex-direction: column; gap: 10px; text-align: center; padding: 20px; }
}

/* ── Small phone (≤520px) ── */
@media (max-width: 520px) {
  .wrap          { padding: 0 16px; }
  .s-gap         { padding: 52px 0; }
  #nav           { padding: 0 16px; }
  .hero-title    { font-size: clamp(2.2rem, 10.5vw, 3.2rem); }
  .hero-top      { padding: 28px 20px 0; }
  .hero-bottom   { padding: 20px 16px 36px; }
  .hero-desc     { font-size: .85rem; }
  .hero-actions  { flex-direction: column; }
  .btn           { padding: 13px 22px; font-size: .64rem; }
  .releases-grid { grid-template-columns: 1fr; }
  .artists-grid  { grid-template-columns: 1fr; }
  .nav-drawer a  { font-size: 2rem; gap: 18px; }
  .about-col     { padding: 28px 16px; }
  .about-big-quote { font-size: clamp(1.3rem, 5.5vw, 1.8rem); }
  .about-stat-n  { font-size: 2.2rem; }
  .contact-info       { padding: 28px 16px; }
  .contact-info-title { font-size: 1.5rem; }
  .contact-form-wrap  { padding: 28px 16px; }
  .footer-col    { padding: 28px 16px; }
  .footer-bottom { padding: 16px; }
  .sec-title     { font-size: clamp(1.8rem, 8vw, 2.8rem); }
  .hero-ticker-item { padding: 0 24px; font-size: .65rem; }
}

/* ── Reduced motion ── */
@media (prefers-reduced-motion: reduce) {
  .fade-up              { opacity: 1; transform: none; transition: none; }
  .hero-ticker-track    { animation-play-state: paused; }
  *, *::before, *::after { transition-duration: .01ms !important; animation-duration: .01ms !important; }
}
