/* ============================================================
   pages.css — page-specific layouts (home extras, location, inkoop)
   Scoped by <body class="page-…">.
   ============================================================ */

/* per-location accent overrides ---------------------------------- */
body.loc-utrecht   { --accent: var(--teal); --accent-deep: var(--teal-deep); }
body.loc-rotterdam { --accent: var(--red);  --accent-deep: var(--red-deep); }

/* ============================================================
   HOME — intro split
   ============================================================ */
.intro-split { display: grid; grid-template-columns: 1.1fr .9fr; gap: clamp(1.5rem,4vw,3rem); align-items: center; }
.intro-split__art { position: relative; }
.intro-split__art img { border: 8px solid #fff; box-shadow: var(--shadow-md); width: 100%; aspect-ratio: 4/3; object-fit: cover; transform: rotate(-1.4deg); }
.intro-split__art .stamp { position: absolute; right: -10px; bottom: -22px; background: var(--paper-card); }
.intro-split__art .sticker { position: absolute; left: -10px; top: -12px; }
@media (max-width: 820px){ .intro-split { grid-template-columns: 1fr; } .intro-split__art { order: -1; } }

/* big stat strip */
.stats { display: grid; grid-template-columns: repeat(4,1fr); gap: 1rem; }
.stat { text-align: center; padding: 1rem .5rem; }
.stat b { display: block; font-family: var(--f-display); font-size: clamp(1.8rem,4.5vw,2.8rem); color: var(--accent); line-height: 1; }
.stat span { font-family: var(--f-mono); font-size: .74rem; letter-spacing: .12em; text-transform: uppercase; color: var(--ink-faint); }
@media (max-width: 620px){ .stats { grid-template-columns: 1fr 1fr; gap: 1.4rem; } }

/* ============================================================
   LOCATION pages (rotterdam.html / utrecht.html)
   ============================================================ */
.lochero { position: relative; padding-block: clamp(2rem,5vw,3.5rem) clamp(2rem,4vw,3rem); overflow: hidden; }
.lochero__grid { display: grid; grid-template-columns: 1.05fr .95fr; gap: clamp(1.5rem,4vw,3rem); align-items: center; }
.lochero__pin {
  display: inline-flex; align-items: center; gap: .5rem; background: var(--accent); color: #fff;
  font-family: var(--f-mono); font-weight: 700; text-transform: uppercase; letter-spacing: .14em; font-size: .76rem;
  padding: .4em .9em; border-radius: 40px; border: 2px solid var(--ink); box-shadow: var(--shadow-sm);
}
.lochero__title { font-family: var(--f-display); text-transform: uppercase; font-size: clamp(3rem,9vw,6rem); line-height: .9; margin: .8rem 0 .2rem; }
.lochero__sub { font-family: var(--f-mono); font-size: .9rem; color: var(--ink-faint); letter-spacing: .04em; }
.lochero__lead { margin-top: 1.1rem; font-size: 1.12rem; color: var(--ink-soft); max-width: 48ch; }
.lochero__quick { margin-top: 1.5rem; display: flex; flex-wrap: wrap; gap: .7rem; }
.qchip {
  display: inline-flex; align-items: center; gap: .5rem; background: var(--paper-card);
  border: 2px solid var(--ink); border-radius: 40px; padding: .5rem 1rem; box-shadow: var(--shadow-sm);
  font-family: var(--f-mono); font-size: .82rem;
}
.qchip svg { width: 17px; height: 17px; stroke: var(--accent-deep); fill: none; stroke-width: 1.8; }
.qchip b { color: var(--accent-deep); }
.lochero__media { position: relative; }
.lochero__media img { width: 100%; aspect-ratio: 4/3; object-fit: cover; border: 8px solid #fff; box-shadow: var(--shadow-lg); transform: rotate(1.2deg); }
.lochero__media .stamp { position: absolute; left: -14px; bottom: -18px; background: var(--paper-card); }
@media (max-width: 820px){ .lochero__grid { grid-template-columns: 1fr; } .lochero__media { order: -1; } }

/* visit grid: hours | info | map */
.visit { display: grid; grid-template-columns: 1fr 1fr; gap: clamp(1.5rem,4vw,2.6rem); align-items: start; }
.visit__panel { background: var(--paper-card); border: 2px solid var(--ink); border-radius: var(--radius-lg); padding: 1.4rem 1.5rem; box-shadow: var(--shadow-sm); }
.visit__map { grid-column: 1 / -1; }
@media (max-width: 760px){ .visit { grid-template-columns: 1fr; } }

/* story (Utrecht revival etc.) */
.story { display: grid; grid-template-columns: .95fr 1.05fr; gap: clamp(1.5rem,4vw,3rem); align-items: center; }
.story__art img { width: 100%; aspect-ratio: 4/5; object-fit: cover; border: 8px solid #fff; box-shadow: var(--shadow-md); transform: rotate(-1.6deg); }
.story blockquote { font-family: var(--f-display); text-transform: none; font-weight: 400; font-size: clamp(1.3rem,2.6vw,1.9rem); line-height: 1.15; color: var(--ink); border-left: 4px solid var(--accent); padding-left: 1rem; margin: 1.2rem 0; }
.story cite { display:block; font-family: var(--f-mono); font-size: .78rem; color: var(--ink-faint); font-style: normal; margin-top: .5rem; letter-spacing: .04em; }
@media (max-width: 820px){ .story { grid-template-columns: 1fr; } .story__art { max-width: 360px; } }

/* genre two-col with description */
.genre-block { display: grid; grid-template-columns: .85fr 1.15fr; gap: clamp(1.5rem,4vw,3rem); align-items: center; }
@media (max-width: 760px){ .genre-block { grid-template-columns: 1fr; } }

/* sessions list (Utrecht events) */
.sessions { list-style: none; display: grid; gap: .8rem; }
.sessions li { display: flex; gap: 1rem; align-items: baseline; background: var(--paper-card); border: 1.5px solid var(--ink-line); border-left: 5px solid var(--accent); border-radius: var(--radius); padding: .9rem 1.1rem; }
.sessions time { font-family: var(--f-mono); font-weight: 700; color: var(--accent-deep); font-size: .9rem; white-space: nowrap; }

/* ============================================================
   INKOOP page
   ============================================================ */
.sell-hero { display: grid; grid-template-columns: 1.1fr .9fr; gap: clamp(1.5rem,4vw,3rem); align-items: center; }
.sell-hero__art { position: relative; display: grid; place-items: center; }
.sell-hero__art .vinyl { width: min(80%, 300px); }
.sell-hero__art .stamp { position: absolute; right: 8%; top: 6%; background: var(--paper-card); transform: rotate(10deg); }
@media (max-width: 820px){ .sell-hero { grid-template-columns: 1fr; } .sell-hero__art { order: -1; } .sell-hero__art .vinyl { width: 200px; } }

/* numbered steps */
.steps { counter-reset: step; display: grid; grid-template-columns: repeat(2,1fr); gap: 1.1rem; }
.step { position: relative; counter-increment: step; background: var(--paper-card); border: 2px solid var(--ink); border-radius: var(--radius-lg); padding: 1.4rem 1.4rem 1.4rem 4.2rem; box-shadow: var(--shadow-sm); }
.step::before {
  content: counter(step); position: absolute; left: 1.1rem; top: 1.2rem;
  width: 2.1rem; height: 2.1rem; display: grid; place-items: center; border-radius: 50%;
  background: var(--accent); color: #fff; font-family: var(--f-display); font-size: 1.2rem;
  border: 2px solid var(--ink);
}
.step h3 { font-family: var(--f-body); font-weight: 800; font-size: 1.12rem; margin-bottom: .35rem; }
.step p { color: var(--ink-soft); font-size: .96rem; }
@media (max-width: 680px){ .steps { grid-template-columns: 1fr; } }

/* what-we-buy chips already use .crate; "buy/sell" two cols */
.buy-cols { display: grid; grid-template-columns: 1fr 1fr; gap: clamp(1.5rem,4vw,2.6rem); }
@media (max-width: 760px){ .buy-cols { grid-template-columns: 1fr; } }

/* generic two-column prose + aside */
.prose-aside { display: grid; grid-template-columns: 1.2fr .8fr; gap: clamp(1.5rem,4vw,3rem); align-items: start; }
@media (max-width: 820px){ .prose-aside { grid-template-columns: 1fr; } }

/* page hero strip (inkoop / generic) accent gradient behind */
.page-inkoop .sell-hero, .lochero {
  background:
    radial-gradient(120% 120% at 100% 0, color-mix(in srgb, var(--accent) 9%, transparent) 0, transparent 60%);
  border-radius: var(--radius-lg);
}
