/* ============================================================
   DAMON FLORES — Beat Store
   Editorial / streetwear. High-contrast bone + ink, forest accent,
   poster type (Anton), humanist serif accents (Fraunces).
   ============================================================ */
:root {
  --paper:    #F1ECE0;   /* warm bone */
  --paper-2:  #E7E0D0;   /* deeper panel */
  --ink:      #15130E;   /* warm near-black */
  --ink-soft: #5A5347;   /* muted secondary */
  --accent:   #2E4636;   /* deep forest green (from the merch) */
  --accent-2: #B5482A;   /* clay/rust, used sparingly */
  --line:     #15130E;
  --maxw: 1200px;
}

* { box-sizing: border-box; }
[hidden] { display: none !important; }
html { scroll-behavior: smooth; }
body {
  margin: 0;
  background: var(--paper);
  color: var(--ink);
  font-family: 'Archivo', system-ui, sans-serif;
  font-size: 16px;
  line-height: 1.55;
  -webkit-font-smoothing: antialiased;
  padding-bottom: 96px;
}
/* faint film grain so surfaces don't read as flat/synthetic */
body::after {
  content: "";
  position: fixed; inset: 0; z-index: 9999; pointer-events: none;
  opacity: .035; mix-blend-mode: multiply;
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='120' height='120'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2'/></filter><rect width='100%25' height='100%25' filter='url(%23n)'/></svg>");
}

.wrap { max-width: var(--maxw); margin: 0 auto; padding: 0 28px; }
a { color: inherit; text-decoration: none; }

/* poster headings */
.hero-head, .sec-title, .wordmark-name, .band-quote, .num {
  font-family: 'Anton', 'Archivo', sans-serif; font-weight: 400;
  text-transform: uppercase; letter-spacing: .005em; line-height: .94;
}

/* ---- Buttons (hard-edged, uppercase) ---- */
.btn {
  display: inline-flex; align-items: center; justify-content: center;
  font: 700 13px 'Archivo', sans-serif; letter-spacing: .08em; text-transform: uppercase;
  padding: 14px 22px; border: 2px solid var(--ink); cursor: pointer;
  background: var(--ink); color: var(--paper); transition: transform .08s ease, background .15s, color .15s;
}
.btn:hover { background: var(--accent); border-color: var(--accent); color: var(--paper); }
.btn:active { transform: translateY(1px); }
.btn-line { background: transparent; color: var(--ink); }
.btn-line:hover { background: var(--ink); color: var(--paper); border-color: var(--ink); }
.btn-line.invert { border-color: var(--paper); color: var(--paper); }
.btn-line.invert:hover { background: var(--paper); color: var(--accent); }
.btn.full { width: 100%; }

/* ---- Masthead ---- */
.masthead { position: sticky; top: 0; z-index: 50; background: var(--paper); border-bottom: 2px solid var(--ink); }
.mast-inner { display: flex; align-items: center; justify-content: space-between; height: 76px; }
.wordmark { display: flex; align-items: baseline; gap: 12px; }
.wordmark-name { font-size: 30px; }
.wordmark-sub { font: 700 11px 'Archivo'; letter-spacing: .22em; text-transform: uppercase; color: var(--accent); padding: 3px 8px; border: 1.5px solid var(--accent); }
.mast-nav { display: flex; gap: 30px; }
.mast-nav a { font: 700 13px 'Archivo'; letter-spacing: .1em; text-transform: uppercase; padding-bottom: 2px; border-bottom: 2px solid transparent; }
.mast-nav a:hover { border-color: var(--ink); }

/* ---- Hero ---- */
.hero { border-bottom: 2px solid var(--ink); }
.hero-grid { display: grid; grid-template-columns: 1fr 280px; gap: 0; align-items: stretch; }
.hero-main { padding: 64px 0 56px; }
.kicker { font: 700 12px 'Archivo'; letter-spacing: .18em; text-transform: uppercase; color: var(--accent); margin: 0 0 22px; }
.hero-head { font-size: clamp(48px, 8.5vw, 110px); margin: 0 0 26px; }
.hero-quote { font-family: 'Fraunces', Georgia, serif; font-style: italic; font-size: clamp(18px, 2.4vw, 26px); color: var(--ink-soft); max-width: 30ch; margin: 0 0 32px; line-height: 1.3; }
.hero-cta { display: flex; gap: 14px; flex-wrap: wrap; }
.hero-side { border-left: 2px solid var(--ink); display: flex; flex-direction: column; }
.side-stat { flex: 1; padding: 26px 28px; display: flex; flex-direction: column; justify-content: center; }
.side-stat + .side-stat { border-top: 2px solid var(--ink); }
.side-stat .num { font-size: 40px; line-height: 1; }
.side-stat .lbl { font: 600 11px 'Archivo'; letter-spacing: .14em; text-transform: uppercase; color: var(--ink-soft); margin-top: 8px; }

/* ---- Section heads ---- */
.sec-head { padding: 56px 0 28px; }
.sec-title { font-size: clamp(34px, 5.5vw, 64px); margin: 0; }
.sec-note { font-family: 'Fraunces', Georgia, serif; font-style: italic; font-size: 19px; color: var(--ink-soft); margin: 10px 0 0; }

/* ---- Controls ---- */
.controls {
  position: sticky; top: 76px; z-index: 30;
  display: flex; gap: 12px; flex-wrap: wrap; align-items: center;
  padding: 16px 0; background: var(--paper);
  border-top: 2px solid var(--ink); border-bottom: 2px solid var(--ink); margin-bottom: 30px;
}
.control input, .control select {
  background: var(--paper); border: 2px solid var(--ink); color: var(--ink);
  padding: 11px 13px; font: 600 13px 'Archivo'; text-transform: uppercase; letter-spacing: .04em; outline: none;
}
.control input::placeholder { color: var(--ink-soft); text-transform: none; letter-spacing: 0; }
.control input:focus, .control select:focus { background: #fff; box-shadow: 3px 3px 0 var(--ink); }
.control.search { flex: 1 1 240px; }
.control.search input { width: 100%; }
.control.bpm { display: flex; align-items: center; gap: 8px; }
.control.bpm input { width: 104px; }
.dash { color: var(--ink-soft); }
.view-toggle { display: flex; margin-left: auto; }
.vt { width: 46px; height: 46px; border: 2px solid var(--ink); background: var(--paper); color: var(--ink); cursor: pointer; font-size: 17px; }
.vt + .vt { border-left: none; }
.vt.active { background: var(--ink); color: var(--paper); }

.catalog-status { padding: 60px 0; text-align: center; font-family: 'Fraunces', serif; font-style: italic; font-size: 19px; color: var(--ink-soft); }

/* ---- Grid ---- */
.grid { display: grid; grid-template-columns: repeat(5, 1fr); gap: 20px; }
.grid.list { grid-template-columns: 1fr; gap: 0; border-top: 2px solid var(--ink); }

.card { background: var(--paper); border: 2px solid var(--ink); display: flex; flex-direction: column;
  transition: transform .1s ease, box-shadow .1s ease; }
.card:hover { transform: translate(-3px, -3px); box-shadow: 6px 6px 0 var(--ink); }
.card.playing { box-shadow: 6px 6px 0 var(--accent); transform: translate(-3px,-3px); }
.card-art { position: relative; aspect-ratio: 1/1; overflow: hidden; border-bottom: 2px solid var(--ink);
  background: var(--accent); display: flex; align-items: center; justify-content: center; }
.card-art img { width: 100%; height: 100%; object-fit: cover; }
.card-art .ph { font-family: 'Anton', sans-serif; font-size: 64px; color: rgba(241,236,224,.85); line-height: 1; }
.card:nth-child(3n) .card-art { background: var(--ink); }
.card:nth-child(3n) .card-art .ph { color: rgba(241,236,224,.7); }
.card:nth-child(3n+2) .card-art { background: var(--accent-2); }
.card-play { position: absolute; inset: 0; display: flex; align-items: center; justify-content: center;
  background: rgba(21,19,14,.28); opacity: 0; transition: opacity .12s; border: 0; cursor: pointer; }
.card-art:hover .card-play, .card.playing .card-play { opacity: 1; }
.card-play span { width: 56px; height: 56px; border: 2px solid var(--paper); background: var(--paper); color: var(--ink);
  display: grid; place-items: center; font-size: 19px; }
.card-body { padding: 14px 15px 16px; display: flex; flex-direction: column; gap: 12px; flex: 1; }
.card-title { font: 800 16px 'Archivo'; text-transform: uppercase; letter-spacing: .01em; line-height: 1.12; }
.card-meta { display: flex; flex-wrap: wrap; gap: 6px; }
.tag { font: 700 10px 'Archivo'; letter-spacing: .08em; text-transform: uppercase; color: var(--ink-soft);
  border: 1.5px solid var(--ink-soft); padding: 3px 7px; font-variant-numeric: tabular-nums; }
.card-foot { display: flex; align-items: center; justify-content: space-between; margin-top: auto; gap: 10px; }
.card-price { font: 800 18px 'Archivo'; font-variant-numeric: tabular-nums; }
.card-license { font: 700 11px 'Archivo'; letter-spacing: .08em; text-transform: uppercase;
  padding: 9px 14px; background: var(--ink); color: var(--paper); border: 2px solid var(--ink); cursor: pointer; }
.card-license:hover { background: var(--accent); border-color: var(--accent); }

/* list view */
.grid.list .card { flex-direction: row; align-items: center; border-top: none; border-left: none; border-right: none;
  border-bottom: 2px solid var(--ink); }
.grid.list .card:hover { transform: none; box-shadow: inset 4px 0 0 var(--accent); }
.grid.list .card.playing { box-shadow: inset 4px 0 0 var(--accent); transform: none; }
.grid.list .card-art { width: 70px; height: 70px; aspect-ratio: auto; flex: none; border: 2px solid var(--ink); margin: 12px; }
.grid.list .card-art .ph { font-size: 28px; }
.grid.list .card-play span { width: 36px; height: 36px; font-size: 13px; }
.grid.list .card-body { flex-direction: row; align-items: center; gap: 22px; width: 100%; padding: 10px 16px 10px 0; }
.grid.list .card-title { flex: 1 1 220px; }
.grid.list .card-meta { flex: 2 1 auto; }
.grid.list .card-foot { margin: 0; flex: 0 0 auto; }

/* ---- Pager ---- */
.pager { display: flex; align-items: center; justify-content: center; gap: 22px; padding: 44px 0 8px; }
.page-info { font: 700 12px 'Archivo'; letter-spacing: .1em; text-transform: uppercase; color: var(--ink-soft); font-variant-numeric: tabular-nums; }
.btn:disabled { opacity: .3; cursor: not-allowed; }

/* ---- Quote band ---- */
.band { background: var(--ink); color: var(--paper); margin: 80px 0 0; padding: 84px 0; border-top: 2px solid var(--ink); border-bottom: 2px solid var(--ink); }
.band-quote { font-size: clamp(34px, 6vw, 72px); margin: 0; text-align: center; }
.band-quote em { font-family: 'Fraunces', serif; font-style: italic; font-weight: 400; text-transform: none; color: var(--paper); display: inline-block; }

/* ---- Licensing ---- */
.licensing { padding-bottom: 40px; }
.license-cards { display: grid; grid-template-columns: 1fr 1fr; gap: 22px; }
.license-card { position: relative; border: 2px solid var(--ink); padding: 34px 30px 30px; background: var(--paper); }
.license-card.featured { background: var(--accent); color: var(--paper); border-color: var(--ink); }
.lc-num { font: 800 13px 'Archivo'; letter-spacing: .1em; color: var(--ink-soft); }
.license-card.featured .lc-num { color: rgba(241,236,224,.7); }
.license-card h3 { font: 800 24px 'Archivo'; text-transform: uppercase; margin: 8px 0 10px; }
.license-card .price { font: 800 30px 'Archivo'; margin: 0 0 20px; font-variant-numeric: tabular-nums; }
.license-card .per { font: 600 13px 'Archivo'; letter-spacing: .06em; text-transform: uppercase; color: var(--ink-soft); }
.license-card.featured .per { color: rgba(241,236,224,.75); }
.license-card ul { list-style: none; padding: 0; margin: 0 0 24px; display: grid; gap: 10px; }
.license-card li { padding-left: 24px; position: relative; }
.license-card li::before { content: "→"; position: absolute; left: 0; font-weight: 700; }
.ribbon { position: absolute; top: 30px; right: 30px; font: 700 11px 'Archivo'; letter-spacing: .1em; text-transform: uppercase;
  padding: 5px 10px; border: 1.5px solid currentColor; }
.lc-foot { font-family: 'Fraunces', serif; font-style: italic; color: var(--ink-soft); margin: 0; }

/* ---- Contact form ---- */
.contact-sec { padding-bottom: 40px; }
.contact-form { display: grid; gap: 16px; max-width: 760px; }
.contact-form .cf-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; }
.contact-form label { display: grid; gap: 6px; font: 700 11px 'Archivo'; letter-spacing: .1em; text-transform: uppercase; color: var(--ink-soft); }
.contact-form input, .contact-form textarea { background: #fff; border: 2px solid var(--ink); padding: 12px 14px; color: var(--ink); font: 500 15px 'Archivo'; outline: none; resize: vertical; }
.contact-form input:focus, .contact-form textarea:focus { box-shadow: 3px 3px 0 var(--ink); }
.contact-form button { justify-self: start; }
@media (max-width: 600px) { .contact-form .cf-grid { grid-template-columns: 1fr; } }

/* ---- Footer ---- */
.site-foot { background: var(--ink); color: var(--paper); margin-top: 80px; padding: 56px 0 26px; }
.foot-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 40px; padding-bottom: 36px; }
.foot-brand { font-family: 'Anton', sans-serif; text-transform: uppercase; font-size: 38px; margin: 0 0 12px; line-height: .95; }
.foot-tag { color: rgba(241,236,224,.7); max-width: 32ch; margin: 0; }
.foot-label { font: 700 12px 'Archivo'; letter-spacing: .16em; text-transform: uppercase; color: var(--accent); margin: 0 0 12px; }
.foot-contact p { margin: 0 0 4px; color: rgba(241,236,224,.8); }
.foot-mail { display: inline-block; margin-top: 10px; font: 700 14px 'Archivo'; letter-spacing: .06em; text-transform: uppercase;
  border-bottom: 2px solid var(--accent); padding-bottom: 3px; }
.foot-rule { display: flex; justify-content: space-between; padding-top: 24px; border-top: 1px solid rgba(241,236,224,.2);
  font: 600 11px 'Archivo'; letter-spacing: .12em; text-transform: uppercase; color: rgba(241,236,224,.55); }

/* ---- Sticky player ---- */
.player { position: fixed; left: 0; right: 0; bottom: 0; z-index: 60; background: var(--ink); color: var(--paper); border-top: 2px solid var(--ink); }
.player-inner { display: flex; align-items: center; gap: 22px; height: 84px; }
.now { display: flex; align-items: center; gap: 14px; width: 230px; min-width: 0; }
.now-art { width: 52px; height: 52px; border: 2px solid var(--paper); background: var(--accent); background-size: cover; background-position: center; flex: none; }
.now-meta { min-width: 0; }
.now-title { font: 800 14px 'Archivo'; text-transform: uppercase; letter-spacing: .02em; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.now-sub { font: 600 11px 'Archivo'; letter-spacing: .08em; text-transform: uppercase; color: rgba(241,236,224,.6); font-variant-numeric: tabular-nums; }
.transport { display: flex; align-items: center; gap: 10px; }
.transport button { background: none; border: 0; color: var(--paper); font-size: 17px; cursor: pointer; opacity: .8; }
.transport button:hover { opacity: 1; color: var(--accent); }
.transport .play { width: 46px; height: 46px; border: 2px solid var(--paper); background: var(--paper); color: var(--ink); font-size: 16px; display: grid; place-items: center; }
.transport .play:hover { background: var(--accent); border-color: var(--accent); color: var(--paper); opacity: 1; }
.scrub { display: flex; align-items: center; gap: 12px; flex: 1; min-width: 120px; }
.time { font: 600 11px 'Archivo'; color: rgba(241,236,224,.6); width: 38px; text-align: center; font-variant-numeric: tabular-nums; }
.vol { display: flex; align-items: center; gap: 8px; width: 130px; }
.vol button { background: none; border: 0; cursor: pointer; font-size: 15px; }
input[type=range] { -webkit-appearance: none; appearance: none; height: 3px; background: rgba(241,236,224,.3); outline: none; cursor: pointer; }
.scrub input[type=range] { flex: 1; }
input[type=range]::-webkit-slider-thumb { -webkit-appearance: none; width: 14px; height: 14px; background: var(--paper); border: 0; }
input[type=range]::-moz-range-thumb { width: 14px; height: 14px; border: 0; background: var(--paper); }
.buy-now { padding: 11px 18px; }

/* ---- Modal ---- */
.modal { position: fixed; inset: 0; z-index: 80; background: rgba(21,19,14,.72); display: flex; align-items: center; justify-content: center; padding: 20px; }
.modal-card { background: var(--paper); border: 2px solid var(--ink); box-shadow: 10px 10px 0 var(--ink); padding: 32px; width: 100%; max-width: 480px; position: relative; }
.modal-close { position: absolute; top: 14px; right: 16px; background: none; border: 0; color: var(--ink); font-size: 28px; cursor: pointer; line-height: 1; }
.modal-card h3 { font: 800 24px 'Archivo'; text-transform: uppercase; margin: 0 0 4px; }
.modal-beat { font-family: 'Fraunces', serif; font-style: italic; color: var(--ink-soft); margin: 0; }
.choice-row { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; margin: 22px 0 4px; }
.choice { background: var(--paper); border: 2px solid var(--ink); padding: 18px 14px; cursor: pointer; text-align: center; display: grid; gap: 5px; transition: .1s; }
.choice:hover { background: var(--ink); color: var(--paper); transform: translate(-2px,-2px); box-shadow: 4px 4px 0 var(--accent); }
.choice-name { font: 800 14px 'Archivo'; text-transform: uppercase; }
.choice-price { font: 800 22px 'Archivo'; font-variant-numeric: tabular-nums; }
.choice-note { font: 600 10px 'Archivo'; letter-spacing: .08em; text-transform: uppercase; color: var(--ink-soft); }
.choice:hover .choice-note { color: rgba(241,236,224,.7); }
.modal-form { display: grid; gap: 14px; margin-top: 22px; }
.modal-form label { display: grid; gap: 6px; font: 700 11px 'Archivo'; letter-spacing: .1em; text-transform: uppercase; color: var(--ink-soft); }
.modal-form input, .modal-form textarea { background: #fff; border: 2px solid var(--ink); padding: 11px 13px; color: var(--ink); font: 500 15px 'Archivo'; text-transform: none; letter-spacing: 0; outline: none; }
.modal-form input:focus, .modal-form textarea:focus { box-shadow: 3px 3px 0 var(--ink); }
.form-note { font-family: 'Fraunces', serif; font-style: italic; font-size: 13px; color: var(--ink-soft); margin: 2px 0 0; }

/* ---- Toast ---- */
.toast { position: fixed; bottom: 104px; left: 50%; transform: translateX(-50%); background: var(--ink); color: var(--paper);
  border: 2px solid var(--accent); padding: 14px 20px; z-index: 90; font: 700 12px 'Archivo'; letter-spacing: .06em; text-transform: uppercase; box-shadow: 6px 6px 0 rgba(0,0,0,.25); }

/* ---- Responsive ---- */
@media (max-width: 1080px) { .grid { grid-template-columns: repeat(4, 1fr); } }
@media (max-width: 880px) {
  .grid { grid-template-columns: repeat(3, 1fr); }
  .hero-grid { grid-template-columns: 1fr; }
  .hero-side { flex-direction: row; border-left: none; border-top: 2px solid var(--ink); }
  .side-stat + .side-stat { border-top: none; border-left: 2px solid var(--ink); }
  .license-cards, .foot-grid { grid-template-columns: 1fr; }
  .mast-nav { display: none; }
  .vol { display: none; }
  .now { width: 150px; }
}
@media (max-width: 600px) {
  .grid { grid-template-columns: repeat(2, 1fr); }
  .player-inner { gap: 12px; height: 74px; }
  .scrub { display: none; }
  .buy-now { display: none; }
  body { padding-bottom: 82px; }
  .grid.list .card-meta { display: none; }
  .wrap { padding: 0 18px; }
}
@media (prefers-reduced-motion: reduce) { * { transition: none !important; scroll-behavior: auto; } }

/* ============================================================
   THEME — light (default) + dark. Toggled via [data-theme] on <html>.
   ============================================================ */
.theme-toggle {
  background: var(--paper); border: 2px solid var(--ink); color: var(--ink);
  width: 40px; height: 40px; cursor: pointer; font-size: 16px; line-height: 1;
  display: inline-grid; place-items: center; flex: none;
}
.theme-toggle:hover { background: var(--ink); color: var(--paper); }

[data-theme="dark"] {
  --paper:    #14120D;
  --paper-2:  #1F1A12;
  --ink:      #EFE9DC;
  --ink-soft: #A99F8C;
  --accent:   #5E8E6E;
  --accent-2: #D2674A;
  --line:     #EFE9DC;
}
/* Inputs that were hardcoded white in light mode */
[data-theme="dark"] .control input,
[data-theme="dark"] .control select,
[data-theme="dark"] .control input:focus,
[data-theme="dark"] .control select:focus,
[data-theme="dark"] .contact-form input,
[data-theme="dark"] .contact-form textarea,
[data-theme="dark"] .modal-form input,
[data-theme="dark"] .modal-form textarea { background: #0E0C08; color: var(--ink); }
/* Keep the band a raised dark panel rather than flipping to light */
[data-theme="dark"] .band { background: var(--paper-2); color: var(--ink); }
[data-theme="dark"] .band-quote em { color: var(--ink); }
/* Featured license card: keep light text on green */
[data-theme="dark"] .license-card.featured { color: #F6F2E8; }
[data-theme="dark"] .license-card.featured .per,
[data-theme="dark"] .license-card.featured .lc-num { color: rgba(246,242,232,.75); }
/* Play button rings read off the (now dark) paper */
[data-theme="dark"] .card-play span { border-color: var(--paper); background: var(--paper); color: var(--ink); }
/* Grain: multiply vanishes on dark — switch to screen */
[data-theme="dark"] body::after { mix-blend-mode: screen; opacity: .05; }
