/* ============================================================
   components.css — reusable building blocks shared across pages
   ============================================================ */

/* ---- section heading cluster ----------------------------------- */
.head { max-width: 60ch; }
.head--center { margin-inline: auto; text-align: center; }
.head__title { font-family: var(--f-display); text-transform: uppercase; font-size: var(--fs-h2); margin-top: .5rem; }
.head__lead  { margin-top: .9rem; color: var(--ink-soft); font-size: 1.08rem; }

/* "stamp" — round rubber-stamp accent (tweedehands / sinds 1981 …) */
.stamp {
  display: inline-flex; align-items: center; justify-content: center; text-align: center;
  font-family: var(--f-mono); font-weight: 700; text-transform: uppercase; letter-spacing: .08em;
  color: var(--accent-deep); border: 2.5px solid var(--accent-deep); border-radius: 50%;
  width: 92px; height: 92px; font-size: .58rem; line-height: 1.25; padding: .4rem;
  transform: rotate(-9deg); opacity: .85; mix-blend-mode: multiply;
}

/* little price-sticker dot */
.sticker {
  display: inline-block; background: var(--gold); color: var(--ink);
  font-family: var(--f-mono); font-weight: 700; font-size: .72rem; letter-spacing: .04em;
  padding: .25em .6em; border-radius: 40px; transform: rotate(-3deg);
  box-shadow: var(--shadow-sm); border: 1px solid var(--gold-deep);
}

/* ============================================================
   HERO (home)
   ============================================================ */
.hero { position: relative; padding-top: clamp(2.5rem,6vw,5rem); padding-bottom: 0; overflow: hidden; }
.hero__grid {
  display: grid; grid-template-columns: 1.25fr .85fr; gap: clamp(1.5rem,4vw,3.5rem);
  align-items: center;
}
.hero__eyebrow { margin-bottom: 1rem; }
.hero__title {
  font-family: var(--f-display); text-transform: uppercase; font-size: var(--fs-hero);
  line-height: .88; letter-spacing: .005em; color: var(--ink);
}
.hero__title .red { color: var(--accent); -webkit-text-stroke: 0; }
.hero__lead { margin-top: 1.3rem; font-size: 1.18rem; max-width: 46ch; color: var(--ink-soft); }
.hero__slogan {
  margin-top: 1.1rem; font-family: var(--f-mono); font-size: .85rem; letter-spacing: .04em;
  color: var(--ink-faint); border-left: 3px solid var(--accent); padding-left: .8rem; font-style: italic;
}
.hero__cta { margin-top: 1.8rem; display: flex; flex-wrap: wrap; gap: .8rem; }
.hero__art { position: relative; display: grid; place-items: center; min-height: 320px; }
.hero__art .vinyl { width: min(86%, 360px); }
.hero__art .stamp { position: absolute; right: 4%; bottom: 6%; background: var(--paper-card); }
.hero__discs { position:absolute; inset:0; pointer-events:none; }
@media (max-width: 860px) {
  .hero__grid { grid-template-columns: 1fr; }
  .hero__art { order: -1; min-height: 230px; }
  .hero__art .vinyl { width: 220px; }
}

/* ============================================================
   Two-shop chooser cards
   ============================================================ */
.shops { display: grid; grid-template-columns: 1fr 1fr; gap: clamp(1rem,3vw,2rem); }
.shopcard {
  --c: var(--red); --cd: var(--red-deep);
  position: relative; display: flex; flex-direction: column;
  background: var(--paper-card); border: 2px solid var(--ink); border-radius: var(--radius-lg);
  overflow: hidden; box-shadow: var(--shadow-md); text-decoration: none; color: var(--ink);
  transition: transform var(--t-med) var(--ease), box-shadow var(--t-med) var(--ease);
}
.shopcard.is-utrecht { --c: var(--teal); --cd: var(--teal-deep); }
.shopcard:hover { transform: translateY(-6px); box-shadow: var(--shadow-lg); }
.shopcard__media { position: relative; aspect-ratio: 16/10; overflow: hidden; background: var(--paper-deep); }
.shopcard__media img { width: 100%; height: 100%; object-fit: cover; transition: transform var(--t-med) var(--ease); }
.shopcard:hover .shopcard__media img { transform: scale(1.05); }
.shopcard__pin {
  position: absolute; top: .9rem; left: .9rem; background: var(--c); color: #fff;
  font-family: var(--f-mono); font-weight: 700; text-transform: uppercase; letter-spacing: .12em;
  font-size: .72rem; padding: .35em .8em; border-radius: 40px; border: 2px solid var(--ink); box-shadow: var(--shadow-sm);
}
.shopcard__body { padding: 1.2rem 1.3rem 1.4rem; display: flex; flex-direction: column; gap: .55rem; flex: 1; }
.shopcard__city { font-family: var(--f-display); text-transform: uppercase; font-size: clamp(1.8rem,4vw,2.6rem); line-height: .95; }
.shopcard__addr { font-family: var(--f-mono); font-size: .85rem; color: var(--ink-faint); }
.shopcard__hours-today { font-size: .92rem; }
.shopcard__hours-today b { color: var(--cd); }
.shopcard__go { margin-top: auto; display: inline-flex; align-items: center; gap: .4rem; font-weight: 700; color: var(--cd); padding-top: .6rem; }
.shopcard__go::after { content: "→"; transition: transform var(--t-fast); }
.shopcard:hover .shopcard__go::after { transform: translateX(5px); }
@media (max-width: 720px){ .shops { grid-template-columns: 1fr; } }

/* ============================================================
   Genre crate — divider tabs like the cardboard separators in bins
   ============================================================ */
.crate { display: flex; flex-wrap: wrap; gap: .6rem; }
.crate__tab {
  font-family: var(--f-mono); font-weight: 700; text-transform: uppercase; letter-spacing: .05em;
  font-size: .82rem; color: var(--ink); background: var(--paper-card);
  border: 1.5px solid var(--ink); border-bottom-width: 4px; border-radius: 7px 7px 3px 3px;
  padding: .5em .9em; box-shadow: var(--shadow-sm); cursor: default; user-select: none;
  transition: transform var(--t-fast) var(--ease), background var(--t-fast), color var(--t-fast);
}
.crate__tab:nth-child(3n)   { transform: rotate(-1.4deg); }
.crate__tab:nth-child(3n+1) { transform: rotate(1deg); }
.crate__tab:hover { background: var(--accent); color: #fff; transform: translateY(-3px) rotate(0); }

/* ============================================================
   Format chips (LP / CD / DVD / cassette)
   ============================================================ */
.formats { display: flex; flex-wrap: wrap; gap: 1rem; }
.fmt {
  display: flex; align-items: center; gap: .7rem; background: var(--paper-card);
  border: 2px solid var(--ink); border-radius: var(--radius-lg); padding: .9rem 1.15rem; box-shadow: var(--shadow-sm);
}
.fmt svg { width: 30px; height: 30px; flex: none; fill: none; stroke: var(--accent-deep); stroke-width: 1.6; }
.fmt b { display: block; font-size: 1rem; }
.fmt span { font-size: .82rem; color: var(--ink-faint); font-family: var(--f-mono); }

/* ============================================================
   Feature row (icon + text), used on home + inkoop
   ============================================================ */
.features { display: grid; grid-template-columns: repeat(3,1fr); gap: clamp(1rem,2.5vw,1.8rem); }
.feature { background: var(--paper-card); border: 2px solid var(--ink); border-radius: var(--radius-lg); padding: 1.4rem; box-shadow: var(--shadow-sm); }
.feature__n { font-family: var(--f-display); font-size: 1.5rem; color: var(--accent); }
.feature h3 { font-family: var(--f-body); font-weight: 800; font-size: 1.18rem; margin: .3rem 0 .5rem; }
.feature p { color: var(--ink-soft); font-size: .96rem; }
@media (max-width: 760px){ .features { grid-template-columns: 1fr; } }

/* ============================================================
   Discogs CTA band
   ============================================================ */
.discogs-band {
  background: var(--ink); color: var(--paper-2); border-radius: var(--radius-lg);
  padding: clamp(1.6rem,4vw,2.6rem); display: grid; grid-template-columns: 1fr auto;
  gap: 1.5rem; align-items: center; box-shadow: var(--shadow-md); position: relative; overflow: hidden;
}
.discogs-band::after { /* faint big record */
  content: ""; position: absolute; right: -60px; top: 50%; transform: translateY(-50%);
  width: 260px; height: 260px; border-radius: 50%;
  background: repeating-radial-gradient(circle at center, rgba(255,255,255,.05) 0 2px, transparent 2px 7px);
  pointer-events: none;
}
.discogs-band h2 { font-family: var(--f-display); text-transform: uppercase; font-size: var(--fs-h2); }
.discogs-band p { color: #cdbfa6; margin-top: .4rem; max-width: 48ch; }
.discogs-band .btn { position: relative; z-index: 1; }

/* ============================================================
   Opening hours table
   ============================================================ */
.hours { width: 100%; border-collapse: collapse; font-family: var(--f-mono); font-size: .94rem; }
.hours caption { text-align: left; font-family: var(--f-body); font-weight: 800; font-size: 1.05rem; margin-bottom: .6rem; text-transform: none; letter-spacing: 0; }
.hours th, .hours td { padding: .5rem .2rem; border-bottom: 1px dashed var(--ink-line); text-align: left; }
.hours th { font-weight: 400; color: var(--ink-soft); text-transform: uppercase; letter-spacing: .04em; font-size: .82rem; }
.hours td { text-align: right; }
.hours td.closed { color: var(--ink-faint); }
.hours tr[data-today="true"] th, .hours tr[data-today="true"] td { color: var(--accent-deep); font-weight: 700; }
.hours tr[data-today="true"] th::before { content: "▸ "; }
.hours__note { font-family: var(--f-mono); font-size: .76rem; color: var(--ink-faint); margin-top: .7rem; }

/* ============================================================
   Info list (address / phone / mail …)
   ============================================================ */
.infolist { list-style: none; display: grid; gap: .85rem; }
.infolist li { display: grid; grid-template-columns: 26px 1fr; gap: .8rem; align-items: start; }
.infolist svg { width: 20px; height: 20px; margin-top: .15rem; fill: none; stroke: var(--accent-deep); stroke-width: 1.7; }
.infolist a { color: var(--ink); text-decoration: none; border-bottom: 1px solid var(--ink-line); }
.infolist a:hover { border-color: var(--accent); color: var(--accent-deep); }
.infolist .lbl { display:block; font-family: var(--f-mono); font-size: .68rem; letter-spacing: .14em; text-transform: uppercase; color: var(--ink-faint); }

/* ============================================================
   Map embed
   ============================================================ */
.mapframe {
  border: 2px solid var(--ink); border-radius: var(--radius-lg); overflow: hidden;
  box-shadow: var(--shadow-md); background: var(--paper-deep); aspect-ratio: 16/10; width: 100%;
}
.mapframe iframe { width: 100%; height: 100%; border: 0; display: block; filter: saturate(.92) contrast(1.02); }

/* ============================================================
   Photo gallery + lightbox
   ============================================================ */
.gallery { display: grid; grid-template-columns: repeat(12, 1fr); gap: .9rem; }
.shot {
  position: relative; margin: 0; border: 8px solid #fff; background: #fff;
  box-shadow: var(--shadow-md); cursor: zoom-in; overflow: hidden;
  transition: transform var(--t-med) var(--ease), box-shadow var(--t-med) var(--ease);
}
.shot:nth-child(odd)  { transform: rotate(-.8deg); }
.shot:nth-child(even) { transform: rotate(.9deg); }
.shot:hover { transform: rotate(0) translateY(-4px); box-shadow: var(--shadow-lg); z-index: 2; }
.shot img { width: 100%; height: 100%; object-fit: cover; display: block; }
.shot figcaption {
  position: absolute; left: 0; right: 0; bottom: 0; padding: .5rem .7rem;
  font-family: var(--f-mono); font-size: .72rem; letter-spacing: .03em; color: #fff;
  background: linear-gradient(transparent, rgba(0,0,0,.72)); text-align: left;
}
/* layout spans */
.shot--wide  { grid-column: span 8; aspect-ratio: 16/10; }
.shot--tall  { grid-column: span 4; aspect-ratio: 3/4; }
.shot--half  { grid-column: span 6; aspect-ratio: 4/3; }
.shot--third { grid-column: span 4; aspect-ratio: 4/3; }
.shot--full  { grid-column: 1 / -1; aspect-ratio: 2/1; }
@media (max-width: 720px){
  .shot--wide, .shot--tall, .shot--half, .shot--third { grid-column: span 12; aspect-ratio: 4/3; }
}

/* lightbox */
.lightbox {
  position: fixed; inset: 0; z-index: 300; display: none;
  background: rgba(12,10,8,.92); padding: clamp(1rem,4vw,3rem);
  align-items: center; justify-content: center; cursor: zoom-out;
}
.lightbox[data-open="true"] { display: flex; }
.lightbox img { max-width: 100%; max-height: 86vh; border: 8px solid #fff; box-shadow: var(--shadow-lg); }
.lightbox__cap { position: absolute; bottom: 1.2rem; left: 0; right: 0; text-align: center; color: #f1e7d4; font-family: var(--f-mono); font-size: .85rem; }
.lightbox__close, .lightbox__nav {
  position: absolute; background: rgba(255,255,255,.12); color: #fff; border: 1.5px solid rgba(255,255,255,.4);
  width: 48px; height: 48px; border-radius: 50%; font-size: 1.4rem; cursor: pointer; display: grid; place-items: center;
}
.lightbox__close { top: 1.2rem; right: 1.2rem; }
.lightbox__nav { top: 50%; transform: translateY(-50%); }
.lightbox__nav--prev { left: 1.2rem; }
.lightbox__nav--next { right: 1.2rem; }
.lightbox__nav:hover, .lightbox__close:hover { background: rgba(255,255,255,.25); }

/* ============================================================
   Callout / note panel
   ============================================================ */
.note {
  background: var(--paper-card); border: 2px solid var(--ink); border-left-width: 7px; border-left-color: var(--accent);
  border-radius: var(--radius); padding: 1.1rem 1.3rem; box-shadow: var(--shadow-sm);
}
.note strong { font-weight: 800; }

/* breadcrumb */
.crumbs { font-family: var(--f-mono); font-size: .78rem; letter-spacing: .04em; color: var(--ink-faint); padding-top: 1.4rem; }
.crumbs a { color: var(--ink-faint); text-decoration: none; }
.crumbs a:hover { color: var(--accent-deep); }

/* open/closed status dot (filled by main.js) */
.dot { display: inline-block; width: .6em; height: .6em; border-radius: 50%; margin-right: .45em; vertical-align: baseline; background: var(--ink-faint); }
.dot.is-open   { background: #2e9e5b; box-shadow: 0 0 0 3px rgba(46,158,91,.2); }
.dot.is-closed { background: var(--red); box-shadow: 0 0 0 3px rgba(195,49,34,.18); }
.openstatus {
  display: inline-flex; align-items: center; font-family: var(--f-mono); font-weight: 700; font-size: .82rem;
  background: var(--paper-2); border: 1.5px solid var(--ink-line); border-radius: 40px; padding: .3rem .8rem;
}
.openstatus.is-open { color: #1f7a45; }
.openstatus:not(.is-open) { color: var(--red-deep); }
