/* =========================================================
   SCULPTUNES — theme stylesheet
   Editorial × audio-engineering, dark by default
   ========================================================= */

@import url('https://fonts.googleapis.com/css2?family=Anton&family=Archivo:wght@400;500;600;700&family=JetBrains+Mono:wght@400;500;600&display=swap');

:root {
  --bg:        #0b0b0d;
  --bg-1:      #111114;
  --bg-2:      #17171c;
  --bg-3:      #1f1f26;
  --line:      rgba(237,233,224,0.08);
  --line-2:    rgba(237,233,224,0.14);
  --ink:       #ede9e0;
  --ink-dim:   #9b948a;
  --ink-mute:  #5a554c;
  --accent:    #e8a24a;   /* LED amber */
  --accent-2:  #c8503a;   /* REC red   */
  --accent-3:  #c4d2c7;   /* phosphor green-grey */

  --display:   'Anton', 'Oswald', sans-serif;
  --sans:      'Archivo', system-ui, sans-serif;
  --mono:      'JetBrains Mono', ui-monospace, monospace;

  --container: 1440px;
  --gutter:    32px;
}

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

html, body {
  margin: 0;
  background: var(--bg);
  color: var(--ink);
  font-family: var(--sans);
  font-size: 15px;
  line-height: 1.5;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}

img { max-width: 100%; display: block; }
a { color: inherit; text-decoration: none; }

/* film-grain overlay, subtle */
body::before {
  content: "";
  position: fixed; inset: 0;
  pointer-events: none;
  z-index: 999;
  opacity: 0.06;
  mix-blend-mode: overlay;
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='160' height='160'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/><feColorMatrix values='0 0 0 0 1  0 0 0 0 1  0 0 0 0 1  0 0 0 1 0'/></filter><rect width='100%25' height='100%25' filter='url(%23n)'/></svg>");
}

/* ---------- type ---------- */

.display {
  font-family: var(--display);
  font-weight: 400;
  letter-spacing: 0.005em;
  line-height: 0.86;
  text-transform: uppercase;
}

.mono { font-family: var(--mono); }
.upper { text-transform: uppercase; letter-spacing: 0.12em; }
.muted { color: var(--ink-dim); }
.tiny  { font-size: 11px; }
.label { font: 500 11px/1 var(--mono); letter-spacing: 0.18em; text-transform: uppercase; color: var(--ink-dim); }
.tag   { font: 500 10px/1 var(--mono); letter-spacing: 0.14em; text-transform: uppercase; color: var(--accent); }

/* the brand wordmark with the signature strike on "UNE" */
.wordmark {
  font-family: var(--display);
  font-size: 22px;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  line-height: 1;
  white-space: nowrap;
}
.wordmark .strike {
  position: relative;
}
.wordmark .strike::after {
  content: "";
  position: absolute; left: -2%; right: -2%; top: 50%;
  height: 2px;
  background: currentColor;
  transform: translateY(-50%) rotate(-1deg);
}

/* ---------- layout ---------- */

.container {
  width: 100%;
  max-width: var(--container);
  margin: 0 auto;
  padding: 0 var(--gutter);
}

.hr { border: 0; border-top: 1px solid var(--line); margin: 0; }

/* ---------- top bar ---------- */

.topbar {
  position: sticky; top: 0;
  z-index: 50;
  background: rgba(11,11,13,0.78);
  backdrop-filter: blur(14px);
  border-bottom: 1px solid var(--line);
}
.topbar__inner {
  display: grid;
  grid-template-columns: 1fr auto 1fr;
  align-items: center;
  height: 64px;
  gap: 24px;
}
.topbar__left {
  display: flex; align-items: center; gap: 20px;
}
.topbar__nav {
  display: flex; align-items: center; gap: 28px;
  font: 500 12px/1 var(--mono);
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--ink-dim);
}
.topbar__nav ul {
  display: flex;
  align-items: center;
  gap: 28px;
  list-style: none;
  margin: 0;
  padding: 0;
}
.topbar__nav li {
  list-style: none;
  margin: 0;
  padding: 0;
}
.topbar__nav a { transition: color .15s; }
.topbar__nav a:hover, .topbar__nav a.active { color: var(--ink); }
.topbar__right {
  justify-self: end;
  display: flex; align-items: center; gap: 18px;
  font: 500 12px/1 var(--mono);
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--ink-dim);
}
.cart-pill {
  display: inline-flex; align-items: center; gap: 8px;
  padding: 8px 14px;
  border: 1px solid var(--line-2);
  border-radius: 999px;
  color: var(--ink);
  transition: border-color .15s;
}
.cart-pill:hover { border-color: var(--accent); }
.cart-pill .dot {
  width: 6px; height: 6px; border-radius: 999px; background: var(--accent);
  box-shadow: 0 0 8px var(--accent);
}

/* ---------- ticker / status strip ---------- */
.status-strip {
  display: flex; align-items: center; gap: 28px;
  font: 500 11px/1 var(--mono);
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--ink-mute);
  padding: 10px var(--gutter);
  border-bottom: 1px solid var(--line);
  background: #08080a;
  white-space: nowrap;
  overflow: hidden;
}
.status-strip .sep { color: var(--ink-mute); opacity: 0.5; }
.status-strip .live {
  display: inline-flex; align-items: center; gap: 8px;
  color: var(--accent-2);
}
.status-strip .live::before {
  content: ""; width: 6px; height: 6px; border-radius: 99px;
  background: var(--accent-2); box-shadow: 0 0 10px var(--accent-2);
  animation: blink 1.4s infinite;
}
@keyframes blink { 50% { opacity: 0.3; } }

/* ---------- buttons ---------- */

.btn {
  display: inline-flex; align-items: center; gap: 10px;
  padding: 14px 22px;
  font: 600 12px/1 var(--mono);
  letter-spacing: 0.18em;
  text-transform: uppercase;
  border-radius: 0;
  border: 1px solid var(--ink);
  background: var(--ink);
  color: var(--bg);
  cursor: pointer;
  transition: transform .15s, background .15s, color .15s, border-color .15s;
}
.btn:hover { background: var(--accent); border-color: var(--accent); color: #1a1208; }
.btn--ghost { background: transparent; color: var(--ink); }
.btn--ghost:hover { background: var(--ink); color: var(--bg); }
.btn--accent { background: var(--accent); border-color: var(--accent); color: #1a1208; }
.btn--accent:hover { background: var(--ink); border-color: var(--ink); color: var(--bg); }
.btn .arrow { font-size: 14px; transition: transform .15s; }
.btn:hover .arrow { transform: translateX(4px); }

/* ---------- hero ---------- */

.hero {
  position: relative;
  padding: 64px 0 0;
  overflow: hidden;
  border-bottom: 1px solid var(--line);
}
.hero__head {
  display: grid;
  grid-template-columns: auto 1fr auto;
  gap: 32px;
  align-items: start;
  padding: 0 var(--gutter);
  margin-bottom: 32px;
}
.hero__edition {
  font: 500 11px/1.6 var(--mono);
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--ink-dim);
}
.hero__edition strong { color: var(--ink); font-weight: 600; }
.hero__intro {
  max-width: 520px;
  font-size: 16px;
  line-height: 1.5;
  color: var(--ink-dim);
}
.hero__intro strong { color: var(--ink); font-weight: 500; }

.hero__foot {
  display: grid;
  grid-template-columns: 1fr auto 1fr;
  gap: 32px;
  align-items: end;
  padding: 32px var(--gutter) 24px;
}
.hero__cta {
  display: flex; gap: 12px; align-items: center; flex-wrap: wrap;
}
.hero__meta {
  font: 500 11px/1.6 var(--mono);
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--ink-dim);
  text-align: right;
}
.hero__meta strong { color: var(--ink); display: block; font-size: 13px; margin-top: 4px; font-weight: 600; }

/* waveform strip */
.waveform {
  height: 96px;
  width: 100%;
  display: block;
}
.waveform-wrap {
  position: relative;
  padding: 0 var(--gutter);
  border-top: 1px solid var(--line);
  background: linear-gradient(180deg, transparent, rgba(232,162,74,0.04));
}
.waveform-wrap .axis {
  display: flex; justify-content: space-between;
  font: 500 10px/1 var(--mono); letter-spacing: 0.18em;
  color: var(--ink-mute);
  padding: 8px var(--gutter);
  border-top: 1px solid var(--line);
}

/* ---------- composed hero (sandwich: type / artwork / type) ---------- */

.hero--composed { padding-top: 0; padding-bottom: 0; }

.hero__stage {
  position: relative;
  margin: 16px var(--gutter) 0;
  border: 1px solid var(--line-2);
  background: #08080a;
  overflow: hidden;
}

/* Top + bottom bands carry the title rows */
.hero__band {
  position: relative;
  padding: 28px max(40px, 4vw);
}
.hero__band--top    { border-bottom: 1px solid var(--line); }
.hero__band--bottom { border-top: 1px solid var(--line); }

.hero__title {
  font-family: var(--display);
  text-transform: uppercase;
  line-height: 0.86;
  letter-spacing: -0.012em;
  margin: 0;
  padding: 0;
  font-size: clamp(64px, 9vw, 156px);
}
.hero__title .row { display: block; }
.hero__title em { font-style: normal; color: var(--accent); }
.hero__title .dot-accent { color: var(--accent); }
.hero__title--top .row--accent { text-align: right; }
.hero__title--bottom .row--indent { padding-left: 14vw; }
.hero__title--bottom .row--right  { text-align: right; }

/* Artwork band — full bleed, natural aspect */
.hero__art {
  position: relative;
  width: 100%;
  aspect-ratio: 1920 / 540;
  overflow: hidden;
  background: #06060a;
}
.hero__art img {
  position: absolute; inset: 0;
  width: 100%; height: 100%;
  object-fit: cover;
  object-position: center 50%;
  /* MUCH lighter touch — let the artwork live */
  filter: contrast(1.02) brightness(0.95);
}
.hero__art::after {
  content: "";
  position: absolute; inset: 0;
  background:
    linear-gradient(180deg, rgba(11,11,13,0.35) 0%, rgba(11,11,13,0) 22%, rgba(11,11,13,0) 78%, rgba(11,11,13,0.35) 100%);
  pointer-events: none;
}
.hero__art-grid {
  position: absolute; inset: 0;
  background-image:
    linear-gradient(to right, rgba(237,233,224,0.035) 1px, transparent 1px);
  background-size: calc(100%/12) 100%;
  pointer-events: none;
  opacity: 0.7;
}
.hero__scan {
  position: absolute; left: 0; right: 0; bottom: 0; height: 1px;
  background: linear-gradient(90deg, transparent, var(--accent), transparent);
  opacity: 0.5;
  pointer-events: none;
}

/* registration marks at band corners */
.reg {
  position: absolute;
  width: 14px; height: 14px;
  border: 1px solid rgba(237,233,224,0.35);
  z-index: 3;
}
.reg--tl { top: 10px; left: 10px;  border-right: 0; border-bottom: 0; }
.reg--tr { top: 10px; right: 10px; border-left: 0; border-bottom: 0; }
.reg--bl { bottom: 10px; left: 10px;  border-right: 0; border-top: 0; }
.reg--br { bottom: 10px; right: 10px; border-left: 0; border-top: 0; }

/* Telemetry tags — sit on the title band, not the title itself */
.hero__tag {
  position: absolute;
  z-index: 4;
  font: 500 10px/1.5 var(--mono);
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--ink);
  padding: 8px 12px;
  background: rgba(8,8,10,0.6);
  border: 1px solid rgba(237,233,224,0.12);
  backdrop-filter: blur(6px);
}
.hero__tag .muted { color: var(--ink-dim); }
.hero__tag .dot {
  display: inline-block; width: 6px; height: 6px; border-radius: 99px;
  background: var(--accent); margin-right: 8px; vertical-align: 1px;
  box-shadow: 0 0 8px var(--accent);
}
/* Place tags in the empty corners of the top band:
   Row 1 "Shaping" is left-aligned → top-right is free.
   Row 2 "Sounds"  is right-aligned → bottom-left is free. */
.hero__tag--lt {
  top: 28px;
  right: max(40px, 4vw);
}
.hero__tag--rt {
  bottom: 28px;
  left: max(40px, 4vw);
  text-align: left;
}

@media (max-width: 900px) {
  .hero__art { aspect-ratio: 1920 / 760; }
  .hero__tag--lt, .hero__tag--rt { display: none; }
  .hero__title--bottom .row--indent { padding-left: 0; }
}

/* ---------- section heading ---------- */

.section {
  padding: 120px 0;
  border-bottom: 1px solid var(--line);
}
.section--tight { padding: 80px 0; }

.section-head {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 64px;
  align-items: end;
  margin-bottom: 56px;
}
.section-head__num {
  font: 500 11px/1 var(--mono);
  letter-spacing: 0.2em;
  color: var(--accent);
  margin-bottom: 16px;
  display: block;
}
.section-head__title {
  font-family: var(--display);
  font-size: clamp(48px, 7vw, 110px);
  line-height: 0.88;
  letter-spacing: -0.005em;
  text-transform: uppercase;
  margin: 0;
}
.section-head__lead {
  font-size: 17px;
  line-height: 1.5;
  color: var(--ink-dim);
  max-width: 460px;
  justify-self: end;
}
.section-head__lead strong { color: var(--ink); font-weight: 500; }

/* ---------- category tiles ---------- */

.categories {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  border-top: 1px solid var(--line);
  border-bottom: 1px solid var(--line);
}
.cat {
  position: relative;
  display: flex; flex-direction: column;
  min-height: 540px;
  border-right: 1px solid var(--line);
  overflow: hidden;
}
.cat:last-child { border-right: 0; }
.cat__img {
  position: absolute; inset: 0;
  background-size: cover;
  background-position: center;
  filter: grayscale(0.5) contrast(1.1) brightness(0.55);
  transition: transform .8s ease, filter .4s;
}
.cat:hover .cat__img { transform: scale(1.04); filter: grayscale(0) contrast(1.05) brightness(0.7); }
.cat__img::after {
  content: "";
  position: absolute; inset: 0;
  background: linear-gradient(180deg, rgba(11,11,13,0.4) 0%, rgba(11,11,13,0.2) 40%, rgba(11,11,13,0.9) 100%);
}
.cat__head, .cat__body {
  position: relative; z-index: 2;
  padding: 28px;
}
.cat__head {
  display: flex; justify-content: space-between; align-items: start;
}
.cat__head .label { color: var(--ink); opacity: 0.7; }
.cat__num {
  font: 500 11px/1 var(--mono);
  letter-spacing: 0.18em;
  color: var(--ink);
  opacity: 0.7;
}
.cat__body { margin-top: auto; }
.cat__title {
  font-family: var(--display);
  font-size: 56px;
  line-height: 0.9;
  letter-spacing: 0.005em;
  text-transform: uppercase;
  margin: 0 0 8px;
}
.cat__sub {
  color: var(--ink-dim);
  font-size: 13px;
  max-width: 360px;
  margin-bottom: 18px;
}
.cat__cta {
  display: inline-flex; align-items: center; gap: 10px;
  font: 600 11px/1 var(--mono);
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--accent);
  padding-bottom: 4px;
  border-bottom: 1px solid var(--accent);
}

/* ---------- product grid ---------- */

.products {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 0;
  border-top: 1px solid var(--line);
  border-left: 1px solid var(--line);
}
.product {
  position: relative;
  border-right: 1px solid var(--line);
  border-bottom: 1px solid var(--line);
  padding: 24px;
  background: var(--bg);
  transition: background .2s;
  display: flex; flex-direction: column;
}
.product:hover { background: var(--bg-1); }
.product__sale {
  position: absolute; top: 16px; right: 16px;
  font: 600 10px/1 var(--mono);
  letter-spacing: 0.16em;
  text-transform: uppercase;
  background: var(--accent-2);
  color: var(--ink);
  padding: 6px 8px;
  z-index: 2;
}
.product__media {
  aspect-ratio: 1 / 1;
  background: var(--bg-2);
  margin-bottom: 18px;
  position: relative;
  overflow: hidden;
  border: 1px solid var(--line);
}
.product__media img {
  position: absolute; inset: 0;
  width: 100%; height: 100%; object-fit: cover;
  transition: transform .6s;
}
.product:hover .product__media img { transform: scale(1.05); }
.product__play {
  position: absolute; bottom: 12px; left: 12px;
  width: 38px; height: 38px;
  background: rgba(11,11,13,0.7);
  border: 1px solid var(--line-2);
  border-radius: 99px;
  display: flex; align-items: center; justify-content: center;
  color: var(--ink);
  backdrop-filter: blur(6px);
  cursor: pointer;
  transition: background .15s;
}
.product__play:hover { background: var(--accent); color: #1a1208; border-color: var(--accent); }
.product__cat {
  font: 500 10px/1 var(--mono);
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--accent);
  margin-bottom: 8px;
}
.product__title {
  font-family: var(--sans);
  font-size: 17px;
  font-weight: 500;
  line-height: 1.25;
  margin: 0 0 8px;
  letter-spacing: -0.005em;
}
.product__meta {
  font: 500 11px/1.5 var(--mono);
  letter-spacing: 0.1em;
  color: var(--ink-mute);
  text-transform: uppercase;
  margin-bottom: 18px;
}
.product__price {
  margin-top: auto;
  display: flex; justify-content: space-between; align-items: end;
}
.product__price-amount {
  font-family: var(--display);
  font-size: 32px;
  letter-spacing: 0.01em;
}
.product__price-amount .cents {
  font-size: 16px; opacity: 0.6; vertical-align: 4px;
  font-family: var(--mono);
}
.product__price-amount .was {
  display: block;
  font: 500 11px/1 var(--mono);
  color: var(--ink-mute);
  text-decoration: line-through;
  margin-bottom: 4px;
}
.product__cart {
  background: transparent;
  border: 1px solid var(--line-2);
  color: var(--ink);
  padding: 10px 14px;
  font: 600 10px/1 var(--mono);
  letter-spacing: 0.16em;
  text-transform: uppercase;
  cursor: pointer;
  transition: all .15s;
}
.product__cart:hover { background: var(--accent); border-color: var(--accent); color: #1a1208; }

/* ---------- featured (editorial) ---------- */

.feature {
  display: grid;
  grid-template-columns: 1.2fr 1fr;
  gap: 0;
  border-top: 1px solid var(--line);
  border-bottom: 1px solid var(--line);
}
.feature__media {
  position: relative;
  min-height: 640px;
  border-right: 1px solid var(--line);
  background: var(--bg-2);
  overflow: hidden;
}
.feature__media img {
  position: absolute; inset: 0;
  width: 100%; height: 100%; object-fit: cover;
}
.feature__media::after {
  content: "";
  position: absolute; inset: 0;
  background: linear-gradient(180deg, rgba(11,11,13,0.0) 60%, rgba(11,11,13,0.7));
}
.feature__media-meta {
  position: absolute; bottom: 24px; left: 24px; right: 24px; z-index: 2;
  display: flex; justify-content: space-between; align-items: end;
  font: 500 11px/1.4 var(--mono);
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--ink);
}
.feature__body { padding: 56px 48px; }
.feature__tag {
  font: 500 11px/1 var(--mono);
  letter-spacing: 0.2em;
  color: var(--accent);
  text-transform: uppercase;
}
.feature__title {
  font-family: var(--display);
  font-size: clamp(48px, 5.5vw, 80px);
  line-height: 0.92;
  letter-spacing: -0.005em;
  text-transform: uppercase;
  margin: 28px 0 24px;
}
.feature__desc {
  font-size: 16px; line-height: 1.55;
  color: var(--ink-dim);
  margin-bottom: 32px;
  max-width: 460px;
}
.specs {
  display: grid; grid-template-columns: repeat(2, 1fr);
  gap: 0;
  border-top: 1px solid var(--line);
  margin-bottom: 32px;
}
.specs__row {
  display: flex; justify-content: space-between;
  padding: 12px 0;
  border-bottom: 1px solid var(--line);
  font: 500 12px/1 var(--mono);
  letter-spacing: 0.08em;
}
.specs__row:nth-child(odd) { padding-right: 18px; border-right: 1px solid var(--line); }
.specs__row:nth-child(even) { padding-left: 18px; }
.specs__row .k { color: var(--ink-mute); text-transform: uppercase; }
.specs__row .v { color: var(--ink); }

.player {
  border: 1px solid var(--line-2);
  padding: 16px 18px;
  display: flex; align-items: center; gap: 14px;
  margin-bottom: 24px;
}
.player__btn {
  width: 38px; height: 38px;
  background: var(--accent);
  color: #1a1208;
  border: 0;
  display: flex; align-items: center; justify-content: center;
  cursor: pointer;
  flex-shrink: 0;
}
.player__bar {
  flex: 1; height: 28px;
  position: relative;
  background: transparent;
}
.player__time {
  font: 500 11px/1 var(--mono);
  color: var(--ink-dim);
  letter-spacing: 0.1em;
  white-space: nowrap;
}

/* ---------- newsletter ---------- */

.newsletter {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 0;
  border-bottom: 1px solid var(--line);
}
.newsletter__left {
  padding: 96px 48px;
  border-right: 1px solid var(--line);
  background: var(--bg-1);
}
.newsletter__right {
  padding: 96px 48px;
  display: flex; flex-direction: column; justify-content: center;
}
.newsletter__title {
  font-family: var(--display);
  font-size: clamp(48px, 6vw, 88px);
  line-height: 0.9;
  text-transform: uppercase;
  margin: 0 0 20px;
}
.newsletter__title em { font-style: normal; color: var(--accent); }
.newsletter__lead {
  font-size: 17px; color: var(--ink-dim);
  max-width: 380px;
  line-height: 1.5;
}
.newsletter__offer {
  font: 500 12px/1 var(--mono);
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--accent);
  margin-bottom: 28px;
}
.newsletter__form {
  display: flex; gap: 0;
  margin-bottom: 18px;
  border: 1px solid var(--ink);
}
.newsletter__form input {
  flex: 1;
  background: transparent;
  border: 0;
  padding: 16px 18px;
  font: 500 14px/1 var(--mono);
  letter-spacing: 0.04em;
  color: var(--ink);
  outline: 0;
}
.newsletter__form input::placeholder { color: var(--ink-mute); }
.newsletter__form button {
  background: var(--ink);
  color: var(--bg);
  border: 0;
  padding: 0 28px;
  font: 600 12px/1 var(--mono);
  letter-spacing: 0.2em;
  text-transform: uppercase;
  cursor: pointer;
  transition: background .15s, color .15s;
}
.newsletter__form button:hover { background: var(--accent); color: #1a1208; }
.newsletter__small {
  font: 500 11px/1.5 var(--mono);
  letter-spacing: 0.06em;
  color: var(--ink-mute);
  font-style: italic;
}

/* ---------- footer ---------- */

footer.site {
  padding: 80px 0 32px;
  background: #08080a;
  border-top: 1px solid var(--line);
}
.footer__grid {
  display: grid;
  grid-template-columns: 2fr 1fr 1fr 1fr;
  gap: 48px;
  margin-bottom: 72px;
}
.footer__brand .wordmark { font-size: 36px; }
.footer__brand p {
  margin-top: 20px;
  color: var(--ink-dim);
  max-width: 320px;
  font-size: 14px;
  line-height: 1.5;
}
.footer__col h5 {
  font: 600 11px/1 var(--mono);
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--ink-dim);
  margin: 0 0 18px;
}
.footer__col ul { list-style: none; padding: 0; margin: 0; display: grid; gap: 10px; font-size: 14px; }
.footer__col a:hover { color: var(--accent); }
.footer__bottom {
  border-top: 1px solid var(--line);
  padding-top: 24px;
  display: flex; justify-content: space-between; align-items: center;
  font: 500 11px/1 var(--mono);
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--ink-mute);
}

/* ---------- shop page ---------- */

.shop-head {
  padding: 80px 0 56px;
  border-bottom: 1px solid var(--line);
}
.shop-head .container {
  display: grid; grid-template-columns: 2fr 1fr; gap: 64px; align-items: end;
}
.shop-head h1 {
  font-family: var(--display);
  font-size: clamp(72px, 11vw, 180px);
  line-height: 0.85;
  letter-spacing: -0.012em;
  text-transform: uppercase;
  margin: 16px 0 0;
}
.shop-head__meta {
  font: 500 12px/1.6 var(--mono);
  text-transform: uppercase; letter-spacing: 0.14em;
  color: var(--ink-dim);
}
.shop-toolbar {
  display: flex; justify-content: space-between; align-items: center;
  padding: 18px var(--gutter);
  border-bottom: 1px solid var(--line);
  font: 500 11px/1 var(--mono);
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--ink-dim);
}
.shop-toolbar .filters { display: flex; gap: 20px; align-items: center; }
.shop-toolbar a.active { color: var(--ink); border-bottom: 1px solid var(--accent); padding-bottom: 4px; }

/* ---------- product detail ---------- */

.detail {
  display: grid;
  grid-template-columns: 1fr 1fr;
  border-bottom: 1px solid var(--line);
  min-height: 720px;
}
.detail__media {
  position: relative;
  background: var(--bg-1);
  border-right: 1px solid var(--line);
  display: flex; align-items: center; justify-content: center;
  padding: 64px;
  overflow: hidden;
}
.detail__media img {
  max-width: 480px;
  width: 100%; height: auto;
  filter: drop-shadow(0 30px 80px rgba(0,0,0,0.5));
}
.detail__media .corner {
  position: absolute;
  font: 500 11px/1 var(--mono);
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--ink-mute);
}
.detail__media .corner.tl { top: 24px; left: 24px; }
.detail__media .corner.tr { top: 24px; right: 24px; }
.detail__media .corner.bl { bottom: 24px; left: 24px; }
.detail__media .corner.br { bottom: 24px; right: 24px; }

.detail__info {
  padding: 56px 48px;
  display: flex; flex-direction: column;
}
.detail__info .crumb {
  font: 500 11px/1 var(--mono);
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--ink-dim);
  margin-bottom: 24px;
}
.detail__info h1 {
  font-family: var(--display);
  font-size: clamp(40px, 4.8vw, 72px);
  line-height: 0.92;
  letter-spacing: -0.005em;
  text-transform: uppercase;
  margin: 0 0 24px;
}
.detail__info .desc { color: var(--ink-dim); font-size: 16px; line-height: 1.55; margin-bottom: 32px; max-width: 480px; }

.priceblock {
  display: flex; align-items: end; gap: 20px;
  padding: 24px 0;
  border-top: 1px solid var(--line);
  border-bottom: 1px solid var(--line);
  margin: 32px 0;
}
.priceblock .amt {
  font-family: var(--display);
  font-size: 64px;
  line-height: 1;
  letter-spacing: 0.01em;
}
.priceblock .currency { color: var(--ink-dim); font-family: var(--mono); font-size: 18px; vertical-align: top; }
.priceblock .lic { color: var(--ink-dim); font: 500 11px/1.4 var(--mono); letter-spacing: 0.14em; text-transform: uppercase; }
.priceblock .lic strong { color: var(--ink); display: block; }

.actions { display: flex; gap: 12px; margin-bottom: 32px; }
.actions .btn { flex: 1; justify-content: center; padding: 18px; }

/* ---------- free sounds ---------- */

.gate {
  min-height: 720px;
  display: flex; align-items: center; justify-content: center;
  padding: 80px var(--gutter);
  background:
    radial-gradient(ellipse at top, rgba(232,162,74,0.08), transparent 60%),
    var(--bg);
  position: relative;
  overflow: hidden;
}
.gate__card {
  max-width: 720px; text-align: center;
  position: relative; z-index: 2;
}
.gate__icon {
  width: 88px; height: 88px;
  margin: 0 auto 28px;
  border: 1px solid var(--line-2);
  display: flex; align-items: center; justify-content: center;
  color: var(--accent);
}
.gate h1 {
  font-family: var(--display);
  font-size: clamp(48px, 6vw, 88px);
  line-height: 0.92;
  letter-spacing: -0.005em;
  text-transform: uppercase;
  margin: 0 0 20px;
}
.gate p { color: var(--ink-dim); font-size: 17px; line-height: 1.5; margin-bottom: 32px; }
.gate__buttons { display: flex; gap: 12px; justify-content: center; flex-wrap: wrap; }

.freelist {
  border-top: 1px solid var(--line);
  display: grid;
  grid-template-columns: repeat(2, 1fr);
}
.freelist__item {
  padding: 32px;
  border-right: 1px solid var(--line);
  border-bottom: 1px solid var(--line);
  display: flex; gap: 24px; align-items: center;
  filter: blur(3px) saturate(0.4);
  pointer-events: none;
  user-select: none;
}
.freelist__item:nth-child(2n) { border-right: 0; }
.freelist__thumb {
  width: 88px; height: 88px;
  background: var(--bg-2);
  flex-shrink: 0;
}

/* ---------- waveform svg ---------- */

.wf-stroke { stroke: var(--accent); }
.wf-played { stroke: var(--accent); }
.wf-rest   { stroke: var(--ink-mute); }

/* ---------- small chips ---------- */

.chip {
  display: inline-flex; align-items: center; gap: 8px;
  padding: 6px 10px;
  border: 1px solid var(--line-2);
  font: 500 10px/1 var(--mono);
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--ink-dim);
}
.chip--accent { color: var(--accent); border-color: var(--accent); }

/* ---------- responsive ---------- */

@media (max-width: 1100px) {
  .categories { grid-template-columns: 1fr; }
  .cat { min-height: 380px; border-right: 0; border-bottom: 1px solid var(--line); }
  .products { grid-template-columns: repeat(2, 1fr); }
  .feature, .newsletter, .detail { grid-template-columns: 1fr; }
  .feature__media, .newsletter__left, .detail__media { border-right: 0; border-bottom: 1px solid var(--line); }
  .section-head { grid-template-columns: 1fr; gap: 24px; }
  .section-head__lead { justify-self: start; }
  .hero__head, .hero__foot { grid-template-columns: 1fr; }
  .hero__meta { text-align: left; }
  .footer__grid { grid-template-columns: 1fr 1fr; }
  .freelist { grid-template-columns: 1fr; }
  .freelist__item { border-right: 0; }
}

/* ---------- embedded preview preservation ---------- */

.product-preview-embed {
  border: 1px solid var(--line);
  background: var(--bg-1);
  padding: 14px;
}

.product-preview-embed iframe,
.product-preview-embed audio,
.product-preview-embed .wp-block-embed,
.product-preview-embed .wp-block-embed__wrapper {
  width: 100%;
  max-width: 100%;
}

.product-preview-embed iframe {
  min-height: 166px;
  border: 0;
}

/* ---------- generic WooCommerce pages ---------- */

.woocommerce-shell {
  max-width: none;
  font-size: 16px;
  line-height: 1.6;
}

.woocommerce .woocommerce-notices-wrapper,
.woocommerce-shell .woocommerce-notices-wrapper {
  margin-bottom: 24px;
}

.woocommerce .woocommerce-message,
.woocommerce .woocommerce-info,
.woocommerce .woocommerce-error,
.woocommerce-shell .woocommerce-message,
.woocommerce-shell .woocommerce-info,
.woocommerce-shell .woocommerce-error {
  margin: 0 0 16px;
  padding: 18px 20px;
  border: 1px solid var(--line-2);
  background: var(--bg-1);
  color: var(--ink);
  list-style: none;
}

.woocommerce form .form-row,
.woocommerce-page form .form-row {
  margin-bottom: 18px;
}

.woocommerce input.input-text,
.woocommerce textarea,
.woocommerce select,
.woocommerce-page input.input-text,
.woocommerce-page textarea,
.woocommerce-page select {
  width: 100%;
  min-height: 48px;
  padding: 12px 14px;
  border: 1px solid var(--line-2);
  background: var(--bg-1);
  color: var(--ink);
  font: 500 14px/1.4 var(--sans);
}

.woocommerce textarea,
.woocommerce-page textarea {
  min-height: 140px;
}

.woocommerce input::placeholder,
.woocommerce textarea::placeholder,
.woocommerce-page input::placeholder,
.woocommerce-page textarea::placeholder {
  color: var(--ink-mute);
}

.woocommerce button.button,
.woocommerce a.button,
.woocommerce input.button,
.woocommerce #payment #place_order,
.woocommerce-page button.button,
.woocommerce-page a.button,
.woocommerce-page input.button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  min-height: 48px;
  padding: 14px 22px;
  border: 1px solid var(--ink);
  background: var(--ink);
  color: var(--bg);
  font: 600 12px/1 var(--mono);
  letter-spacing: 0.18em;
  text-transform: uppercase;
  border-radius: 0;
}

.woocommerce button.button:hover,
.woocommerce a.button:hover,
.woocommerce input.button:hover,
.woocommerce #payment #place_order:hover,
.woocommerce-page button.button:hover,
.woocommerce-page a.button:hover,
.woocommerce-page input.button:hover {
  background: var(--accent);
  border-color: var(--accent);
  color: #1a1208;
}

.woocommerce-cart table.shop_table,
.woocommerce-checkout table.shop_table,
.woocommerce-account table.shop_table,
.woocommerce-order table.shop_table,
.woocommerce table.shop_table,
.woocommerce-page table.shop_table {
  width: 100%;
  border-collapse: collapse;
  border: 1px solid var(--line);
  background: var(--bg-1);
}

.woocommerce table.shop_table th,
.woocommerce table.shop_table td,
.woocommerce-page table.shop_table th,
.woocommerce-page table.shop_table td {
  padding: 16px 14px;
  border-bottom: 1px solid var(--line);
  color: var(--ink);
}

.woocommerce table.shop_table th,
.woocommerce-page table.shop_table th {
  font: 600 11px/1.2 var(--mono);
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--ink-dim);
}

.woocommerce-cart-form,
.cart-collaterals,
.cart_totals,
.woocommerce-checkout-review-order,
.woocommerce-checkout #customer_details,
.woocommerce-checkout #payment,
.woocommerce-order-pay #payment,
.woocommerce-account .woocommerce,
.woocommerce-order,
.woocommerce form.login,
.woocommerce form.register,
.woocommerce-form-coupon,
.woocommerce-EditAccountForm,
.woocommerce-address-fields,
.woocommerce-MyAccount-content {
  border: 1px solid var(--line);
  background: var(--bg-1);
  padding: 24px;
}

.woocommerce-cart .cart-collaterals,
.woocommerce-checkout .woocommerce-checkout,
.woocommerce-account .woocommerce,
.woocommerce-order-pay .woocommerce,
.woocommerce-order {
  display: grid;
  gap: 24px;
}

.woocommerce-checkout .woocommerce-checkout {
  grid-template-columns: minmax(0, 1.2fr) minmax(320px, 0.8fr);
  align-items: start;
}

.woocommerce-order-pay .woocommerce,
.woocommerce-order-received .woocommerce {
  max-width: 1080px;
  margin: 0 auto;
}

.woocommerce-checkout .woocommerce-checkout-review-order-table,
.woocommerce-order-pay table.shop_table,
.woocommerce-order-received table.shop_table,
.woocommerce-account table.woocommerce-MyAccount-paymentMethods,
.woocommerce-account table.woocommerce-orders-table {
  margin-bottom: 0;
}

.woocommerce-checkout .shop_table tfoot th,
.woocommerce-checkout .shop_table tfoot td,
.woocommerce-order-pay .shop_table tfoot th,
.woocommerce-order-pay .shop_table tfoot td,
.woocommerce-order-received .shop_table tfoot th,
.woocommerce-order-received .shop_table tfoot td {
  border-top: 1px solid var(--line);
}

.woocommerce-checkout #payment,
.woocommerce-order-pay #payment {
  border: 1px solid var(--line);
  background: var(--bg-1);
  padding: 24px;
}

.woocommerce-checkout #payment div.form-row,
.woocommerce-order-pay #payment div.form-row {
  padding: 0;
  margin: 18px 0 0;
}

.woocommerce-checkout #payment ul.payment_methods,
.woocommerce-order-pay #payment ul.payment_methods {
  list-style: none;
  margin: 0 0 18px;
  padding: 0;
  border: 0;
}

.woocommerce-checkout #payment ul.payment_methods li,
.woocommerce-order-pay #payment ul.payment_methods li {
  margin: 0;
  padding: 16px 0;
  border-bottom: 1px solid var(--line);
}

.woocommerce-checkout #payment ul.payment_methods li:last-child,
.woocommerce-order-pay #payment ul.payment_methods li:last-child {
  border-bottom: 0;
}

.woocommerce-checkout #payment ul.payment_methods li > label,
.woocommerce-order-pay #payment ul.payment_methods li > label {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  font: 600 12px/1.4 var(--mono);
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--ink);
}

.woocommerce-checkout #payment ul.payment_methods input[type="radio"],
.woocommerce-order-pay #payment ul.payment_methods input[type="radio"] {
  margin: 0;
}

.woocommerce-checkout #payment div.payment_box,
.woocommerce-order-pay #payment div.payment_box {
  margin: 14px 0 0;
  padding: 16px 18px;
  border: 1px solid var(--line);
  background: var(--bg-2);
  color: var(--ink-dim);
}

.woocommerce-checkout #payment div.payment_box p:last-child,
.woocommerce-order-pay #payment div.payment_box p:last-child {
  margin-bottom: 0;
}

.woocommerce-checkout #payment .place-order,
.woocommerce-order-pay #payment .place-order {
  display: grid;
  gap: 16px;
}

.woocommerce-checkout #payment .place-order .button,
.woocommerce-checkout #payment #place_order,
.woocommerce-order-pay #payment .place-order .button,
.woocommerce-order-pay #payment #place_order {
  width: 100%;
}

.woocommerce-checkout #payment .wc_payment_method img,
.woocommerce-order-pay #payment .wc_payment_method img,
.woocommerce-checkout #payment .about_paypal,
.woocommerce-order-pay #payment .about_paypal {
  max-height: 26px;
  width: auto;
  vertical-align: middle;
}

.woocommerce-checkout .woocommerce-privacy-policy-text,
.woocommerce-order-pay .woocommerce-privacy-policy-text {
  color: var(--ink-dim);
  font-size: 14px;
  line-height: 1.6;
}

.woocommerce-checkout .form-row.terms,
.woocommerce-order-pay .form-row.terms {
  display: flex;
  align-items: flex-start;
  gap: 10px;
}

.woocommerce-checkout .form-row.terms input,
.woocommerce-order-pay .form-row.terms input {
  margin-top: 3px;
}

.woocommerce-checkout .wc_payment_methods .payment_method_stripe label,
.woocommerce-order-pay .wc_payment_methods .payment_method_stripe label,
.woocommerce-checkout .wc_payment_methods .payment_method_ppcp-gateway label,
.woocommerce-order-pay .wc_payment_methods .payment_method_ppcp-gateway label {
  flex-wrap: wrap;
}

.woocommerce-account .woocommerce {
  grid-template-columns: minmax(220px, 0.34fr) minmax(0, 1fr);
}

.woocommerce-account .woocommerce-MyAccount-navigation,
.woocommerce-account .woocommerce-MyAccount-content,
.woocommerce-account .u-column1,
.woocommerce-account .u-column2,
.woocommerce-account .col-1,
.woocommerce-account .col-2 {
  float: none;
  width: auto;
  margin: 0;
}

.woocommerce-account .woocommerce-MyAccount-navigation,
.woocommerce-account .woocommerce-MyAccount-content {
  min-width: 0;
}

.woocommerce-account .woocommerce-MyAccount-navigation ul {
  margin: 0;
  padding: 0;
  list-style: none;
}

.woocommerce-account .woocommerce-MyAccount-navigation li + li {
  margin-top: 10px;
}

.woocommerce-account .woocommerce-MyAccount-navigation a {
  display: block;
  padding: 12px 14px;
  border: 1px solid var(--line);
  color: var(--ink-dim);
  font: 600 12px/1.3 var(--mono);
  letter-spacing: 0.12em;
  text-transform: uppercase;
}

.woocommerce-account .woocommerce-MyAccount-navigation .is-active a,
.woocommerce-account .woocommerce-MyAccount-navigation a:hover {
  color: var(--ink);
  border-color: var(--accent);
}

.woocommerce-account .woocommerce-Address-title,
.woocommerce-account .woocommerce-MyAccount-content h2,
.woocommerce-account .woocommerce-order-details__title,
.woocommerce-checkout h3,
.woocommerce-order h2,
.woocommerce-order h3 {
  margin-top: 0;
  font-family: var(--display);
  font-size: clamp(28px, 3vw, 42px);
  line-height: 0.94;
  text-transform: uppercase;
}

.woocommerce-account .u-columns {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 24px;
}

.woocommerce-account .u-column1,
.woocommerce-account .u-column2,
.woocommerce-account .col-1,
.woocommerce-account .col-2 {
  border: 1px solid var(--line);
  background: var(--bg-1);
  padding: 24px;
}

.woocommerce-account .woocommerce-form-login,
.woocommerce-account .woocommerce-form-register {
  border: 0;
  background: transparent;
  padding: 0;
  margin: 0;
}

.woocommerce-account .woocommerce-form-login p,
.woocommerce-account .woocommerce-form-register p {
  margin-top: 0;
}

.woocommerce-account .lost_password {
  margin-bottom: 0;
}

.woocommerce ul.order_details,
.woocommerce-order-overview {
  margin: 0 0 24px;
  padding: 0;
  list-style: none;
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
  gap: 12px;
}

.woocommerce ul.order_details li,
.woocommerce-order-overview li {
  padding: 14px;
  border: 1px solid var(--line);
  background: var(--bg-2);
  font: 500 11px/1.5 var(--mono);
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--ink-dim);
}

.woocommerce .quantity .qty {
  width: 88px;
  min-width: 88px;
}

.woocommerce .woocommerce-form-login .woocommerce-form-login__rememberme,
.woocommerce .woocommerce-form-register .woocommerce-form-register__rememberme {
  display: flex;
  align-items: center;
  gap: 8px;
}

.woocommerce .col2-set,
.woocommerce-page .col2-set {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 24px;
}

@media (max-width: 980px) {
  .woocommerce-checkout .woocommerce-checkout,
  .woocommerce-account .woocommerce,
  .woocommerce-account .u-columns,
  .woocommerce .col2-set,
  .woocommerce-page .col2-set {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 640px) {
  .woocommerce-cart-form,
  .cart-collaterals,
  .cart_totals,
  .woocommerce-checkout-review-order,
  .woocommerce-checkout #customer_details,
  .woocommerce-account .woocommerce,
  .woocommerce-order,
  .woocommerce form.login,
  .woocommerce form.register,
  .woocommerce-form-coupon,
  .woocommerce-EditAccountForm,
  .woocommerce-address-fields,
  .woocommerce-MyAccount-content {
    padding: 18px;
  }

  .woocommerce table.shop_table th,
  .woocommerce table.shop_table td,
  .woocommerce-page table.shop_table th,
  .woocommerce-page table.shop_table td {
    padding: 12px 10px;
  }
}
