/* ============================================================
   My Collection — vinyl tracker, valuation & wishlist
   Editorial extension of the Bring Back Records design language.
   Reuses --paper / --ink / --accent / type tokens from styles.css.
   ============================================================ */

.mc { position: relative; z-index: 2; max-width: var(--content-w); margin: 0 auto; padding: 104px 40px 120px; }
.mc * { box-sizing: border-box; }

/* ---- shared small bits -------------------------------------------------- */
.mc-eyebrow { font-family: var(--mono); font-size: 11px; letter-spacing: 0.2em; text-transform: uppercase; color: var(--ink-mute); }
.mc-rule { border: 0; border-top: 1px solid var(--rule); margin: 0; }
.mc-money { font-family: var(--sans); font-weight: 900; letter-spacing: -0.03em; font-variant-numeric: tabular-nums; }
.mc-serif-it { font-family: var(--serif); font-style: italic; font-weight: 400; }

.mc-chip {
  display: inline-flex; align-items: center; gap: 6px; white-space: nowrap;
  font-family: var(--mono); font-size: 10px; letter-spacing: 0.12em; text-transform: uppercase;
  padding: 4px 9px; border: 1px solid var(--rule); border-radius: 999px; color: var(--ink-2);
  background: color-mix(in oklab, var(--paper) 60%, #fff 40%);
}
.mc-delta { display: inline-flex; align-items: center; gap: 5px; font-family: var(--mono); font-size: 12px; font-weight: 600; font-variant-numeric: tabular-nums; }
.mc-delta.up { color: oklch(0.52 0.13 150); }
.mc-delta.down { color: oklch(0.55 0.16 28); }
.mc-delta.flat { color: var(--ink-mute); }
.mc-arrow { font-size: 11px; line-height: 1; }

/* ---- hero: the rolling collection value --------------------------------- */
.mc-hero {
  display: grid; grid-template-columns: 1.35fr 1fr; gap: 48px; align-items: end;
  padding: 8px 0 32px;
}
.mc-hero-label { display: flex; align-items: center; gap: 14px; margin-bottom: 6px; }
.mc-hero-total {
  font-family: var(--sans); font-weight: 900; letter-spacing: -0.045em;
  font-size: clamp(64px, 9vw, 132px); line-height: 0.86; color: var(--ink);
  font-variant-numeric: tabular-nums; display: flex; align-items: baseline;
}
.mc-hero-total .cur { font-size: 0.46em; color: var(--ink-mute); margin-right: 0.06em; font-weight: 800; }
.mc-hero-sub { display: flex; align-items: center; gap: 18px; margin-top: 16px; flex-wrap: wrap; }
.mc-hero-milestone { margin-top: 22px; max-width: 460px; }
.mc-milestone-bar { height: 6px; background: var(--paper-2); border: 1px solid var(--rule); border-radius: 999px; overflow: hidden; }
.mc-milestone-fill { height: 100%; background: var(--accent); border-radius: 999px; transition: width 0.7s cubic-bezier(0.2,0.8,0.2,1); }
.mc-milestone-cap { font-family: var(--mono); font-size: 10.5px; letter-spacing: 0.08em; color: var(--ink-mute); margin-top: 7px; display: flex; justify-content: space-between; }

/* hero side stats */
.mc-hero-stats { display: grid; grid-template-columns: 1fr 1fr; gap: 1px; background: var(--rule); border: 1px solid var(--rule); }
.mc-stat { background: var(--paper); padding: 16px 18px; }
.mc-stat-k { font-family: var(--mono); font-size: 10px; letter-spacing: 0.16em; text-transform: uppercase; color: var(--ink-mute); }
.mc-stat-v { font-family: var(--serif); font-size: 26px; line-height: 1.05; margin-top: 8px; }
.mc-stat-v small { font-family: var(--sans); font-weight: 700; font-size: 13px; color: var(--ink-2); display: block; margin-top: 3px; }

/* ---- toolbar: tabs + controls ------------------------------------------- */
.mc-bar { display: flex; align-items: flex-end; justify-content: space-between; gap: 20px; margin: 36px 0 22px; flex-wrap: wrap; }
.mc-tabs { display: flex; gap: 0; border-bottom: 1px solid var(--ink); }
.mc-tab {
  font-family: var(--mono); font-size: 12px; letter-spacing: 0.12em; text-transform: uppercase;
  padding: 12px 4px; margin-right: 30px; color: var(--ink-mute); position: relative; transition: color 0.15s;
}
.mc-tab:hover { color: var(--ink); }
.mc-tab.active { color: var(--ink); }
.mc-tab.active::after { content: ""; position: absolute; left: 0; right: 0; bottom: -1px; height: 3px; background: var(--accent); }
.mc-tab .ct { font-weight: 400; color: var(--ink-mute); margin-left: 7px; }

.mc-controls { display: flex; align-items: center; gap: 10px; flex-wrap: wrap; }
.mc-search { display: flex; align-items: center; gap: 8px; border: 1px solid var(--rule); background: #fff8; padding: 8px 12px; min-width: 200px; }
.mc-search input { border: 0; background: transparent; outline: none; font-family: var(--sans); font-size: 14px; color: var(--ink); width: 100%; }
.mc-search svg { color: var(--ink-mute); flex-shrink: 0; }
.mc-select { position: relative; }
.mc-select select {
  appearance: none; -webkit-appearance: none; font-family: var(--mono); font-size: 11px; letter-spacing: 0.08em; text-transform: uppercase;
  border: 1px solid var(--rule); background: #fff8; color: var(--ink-2); padding: 9px 30px 9px 12px; cursor: pointer; outline: none;
}
.mc-select::after { content: "▾"; position: absolute; right: 11px; top: 50%; transform: translateY(-50%); pointer-events: none; color: var(--ink-mute); font-size: 10px; }
.mc-add {
  display: inline-flex; align-items: center; gap: 8px; white-space: nowrap; font-family: var(--mono); font-size: 11px; letter-spacing: 0.1em; text-transform: uppercase; font-weight: 600;
  background: var(--ink); color: var(--paper); padding: 10px 16px; transition: background 0.15s;
}
.mc-add:hover { background: var(--accent); }
.mc-add .plus { font-size: 14px; line-height: 1; }

/* ---- record cards ------------------------------------------------------- */
.mc-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(330px, 1fr)); gap: 1px; background: var(--rule); border: 1px solid var(--rule); }
.mc-card { background: var(--paper); padding: 18px; display: grid; grid-template-columns: 76px 1fr; gap: 16px; position: relative; transition: background 0.15s; }
.mc-card:hover { background: color-mix(in oklab, var(--paper) 82%, #fff 18%); }
.mc-card-cover { width: 76px; height: 76px; flex-shrink: 0; }
.mc-card-cover > div { box-shadow: 0 8px 18px -12px rgba(0,0,0,.4) !important; }
.mc-card-body { min-width: 0; }
.mc-card-top { display: flex; align-items: flex-start; justify-content: space-between; gap: 10px; }
.mc-card-title { font-family: var(--serif); font-style: italic; font-size: 18px; line-height: 1.16; }
.mc-card-artist { font-family: var(--sans); font-weight: 700; font-size: 12.5px; color: var(--ink-2); margin-top: 6px; }
.mc-card-meta { font-family: var(--mono); font-size: 10px; letter-spacing: 0.04em; color: var(--ink-mute); margin-top: 10px; line-height: 1.5; }
.mc-card-meta b { color: var(--ink-2); font-weight: 600; }
.mc-card-foot { display: flex; align-items: flex-end; justify-content: space-between; gap: 10px; margin-top: 14px; }
.mc-card-val { font-family: var(--sans); font-weight: 900; font-size: 25px; letter-spacing: -0.03em; font-variant-numeric: tabular-nums; line-height: 1; }
.mc-card-val .cur { font-size: 0.6em; color: var(--ink-mute); font-weight: 800; }
.mc-card-range { font-family: var(--mono); font-size: 9.5px; color: var(--ink-mute); margin-top: 5px; letter-spacing: 0.03em; }

/* condition chip */
.mc-cond { font-family: var(--mono); font-size: 10px; font-weight: 600; letter-spacing: 0.08em; padding: 3px 7px; border: 1px solid currentColor; border-radius: 3px; }
.mc-cond.M, .mc-cond.NM { color: oklch(0.50 0.12 150); }
.mc-cond.VGplus { color: oklch(0.55 0.10 90); }
.mc-cond.VG { color: oklch(0.55 0.10 70); }
.mc-cond.low { color: var(--ink-mute); }

/* row actions on hover */
.mc-card-actions { position: absolute; top: 12px; right: 12px; display: flex; gap: 6px; opacity: 0; transition: opacity 0.15s; }
.mc-card:hover .mc-card-actions { opacity: 1; }
.mc-iconbtn { width: 26px; height: 26px; display: grid; place-items: center; border: 1px solid var(--rule); background: var(--paper); color: var(--ink-mute); border-radius: 4px; transition: all 0.15s; }
.mc-iconbtn:hover { color: var(--ink); border-color: var(--ink); }
.mc-iconbtn.danger:hover { color: oklch(0.55 0.16 28); border-color: oklch(0.55 0.16 28); }

/* sparkline */
.mc-spark { display: flex; align-items: flex-end; gap: 12px; }
.mc-spark svg { display: block; overflow: visible; }

/* ---- wishlist card variant --------------------------------------------- */
.mc-card.wish .mc-card-foot { flex-direction: column; align-items: stretch; gap: 12px; }
.mc-buy {
  display: inline-flex; align-items: center; justify-content: center; gap: 9px; width: 100%;
  font-family: var(--mono); font-size: 11px; letter-spacing: 0.1em; text-transform: uppercase; font-weight: 600;
  background: var(--accent); color: #fff; padding: 11px 14px; transition: filter 0.15s;
}
.mc-buy:hover { filter: brightness(1.07); }
.mc-buy .ar { transition: transform 0.18s; }
.mc-buy:hover .ar { transform: translateX(3px); }
.mc-buy-row { display: flex; gap: 8px; }
.mc-move {
  font-family: var(--mono); font-size: 10px; letter-spacing: 0.08em; text-transform: uppercase; font-weight: 600;
  border: 1px solid var(--ink); color: var(--ink); padding: 11px 12px; white-space: nowrap; transition: all 0.15s;
}
.mc-move:hover { background: var(--ink); color: var(--paper); }
.mc-vendor { font-family: var(--mono); font-size: 9.5px; letter-spacing: 0.06em; color: var(--ink-mute); text-align: center; }

/* ---- stats dashboard ---------------------------------------------------- */
.mc-dash { margin-top: 64px; }
.mc-dash-head { display: flex; align-items: baseline; gap: 14px; margin-bottom: 24px; }
.mc-dash-head h3 { font-family: var(--serif); font-size: 30px; font-weight: 400; margin: 0; }
.mc-dash-grid { display: grid; grid-template-columns: 1.6fr 1fr; gap: 1px; background: var(--rule); border: 1px solid var(--rule); }
.mc-panel { background: var(--paper); padding: 24px; }
.mc-panel-k { font-family: var(--mono); font-size: 10.5px; letter-spacing: 0.16em; text-transform: uppercase; color: var(--ink-mute); margin-bottom: 18px; }

/* trend line chart */
.mc-trend svg { width: 100%; height: auto; display: block; overflow: visible; }
.mc-trend-foot { display: flex; justify-content: space-between; font-family: var(--mono); font-size: 9.5px; color: var(--ink-mute); margin-top: 8px; }

/* breakdown bars */
.mc-break + .mc-break { margin-top: 26px; }
.mc-bk-row { display: grid; grid-template-columns: 92px 1fr 52px; align-items: center; gap: 12px; margin-bottom: 9px; }
.mc-bk-label { font-family: var(--mono); font-size: 10px; letter-spacing: 0.04em; text-transform: uppercase; color: var(--ink-2); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.mc-bk-track { height: 9px; background: var(--paper-2); border: 1px solid var(--rule); position: relative; }
.mc-bk-fill { position: absolute; inset: 0 auto 0 0; background: var(--ink); transition: width 0.7s cubic-bezier(0.2,0.8,0.2,1); }
.mc-bk-fill.accent { background: var(--accent); }
.mc-bk-val { font-family: var(--mono); font-size: 10.5px; color: var(--ink-mute); text-align: right; font-variant-numeric: tabular-nums; }

/* highlight tiles */
.mc-tiles { display: grid; grid-template-columns: 1fr 1fr; gap: 1px; background: var(--rule); border: 1px solid var(--rule); margin-top: 1px; }
.mc-tile { background: var(--paper); padding: 22px 24px; display: flex; gap: 16px; align-items: center; }
.mc-tile .cv { width: 64px; height: 64px; flex-shrink: 0; }
.mc-tile-k { font-family: var(--mono); font-size: 9.5px; letter-spacing: 0.16em; text-transform: uppercase; color: var(--ink-mute); }
.mc-tile-t { font-family: var(--serif); font-style: italic; font-size: 19px; line-height: 1.05; margin-top: 6px; }
.mc-tile-s { font-family: var(--mono); font-size: 10px; color: var(--ink-2); margin-top: 6px; }

/* ---- empty state -------------------------------------------------------- */
.mc-empty { text-align: center; padding: 80px 24px; border: 1px dashed var(--rule); }
.mc-empty h3 { font-family: var(--serif); font-style: italic; font-size: 34px; font-weight: 400; margin: 0 0 12px; }
.mc-empty p { font-family: var(--body-serif); font-size: 17px; line-height: 1.55; color: var(--ink-2); max-width: 460px; margin: 0 auto 28px; }
.mc-empty-cta { display: inline-flex; gap: 12px; flex-wrap: wrap; justify-content: center; }
.mc-empty-stack { display: flex; justify-content: center; gap: -20px; margin-bottom: 32px; }
.mc-empty-stack > div { margin-left: -28px; box-shadow: 0 16px 30px -20px rgba(0,0,0,.5) !important; transform: rotate(var(--r)); }
.mc-empty-stack > div:first-child { margin-left: 0; }

.mc-btn {
  display: inline-flex; align-items: center; gap: 9px; font-family: var(--mono); font-size: 11px; letter-spacing: 0.1em; text-transform: uppercase; font-weight: 600;
  padding: 12px 18px; transition: all 0.15s;
}
.mc-btn.solid { background: var(--ink); color: var(--paper); }
.mc-btn.solid:hover { background: var(--accent); }
.mc-btn.ghost { border: 1px solid var(--ink); color: var(--ink); }
.mc-btn.ghost:hover { background: var(--ink); color: var(--paper); }

/* ===========================================================
   MARKETING SURFACE (logged out)
   =========================================================== */
.mkt { position: relative; z-index: 2; }
.mkt-hero { max-width: var(--content-w); margin: 0 auto; padding: 120px 40px 56px; display: grid; grid-template-columns: 1.05fr 1fr; gap: 56px; align-items: center; }
.mkt-eyebrow { font-family: var(--mono); font-size: 11px; letter-spacing: 0.2em; text-transform: uppercase; color: var(--accent); margin-bottom: 22px; }
.mkt-h1 { font-family: var(--serif); font-weight: 400; font-size: clamp(44px, 5.4vw, 84px); line-height: 0.98; letter-spacing: -0.015em; margin: 0; }
.mkt-h1 em { font-style: italic; color: var(--accent); }
.mkt-lede { font-family: var(--body-serif); font-size: clamp(17px, 1.4vw, 20px); line-height: 1.55; color: var(--ink-2); max-width: 520px; margin: 26px 0 32px; }
.mkt-cta { display: flex; gap: 14px; align-items: center; flex-wrap: wrap; }
.mkt-fine { font-family: var(--mono); font-size: 10.5px; letter-spacing: 0.04em; color: var(--ink-mute); margin-top: 18px; }

/* sample collection preview with blurred values */
.mkt-preview { position: relative; }
.mkt-preview-card { background: var(--paper); border: 1px solid var(--rule); box-shadow: 0 40px 80px -50px rgba(0,0,0,.55); }
.mkt-pv-top { padding: 20px 22px; border-bottom: 1px solid var(--rule); display: flex; align-items: flex-end; justify-content: space-between; }
.mkt-pv-total { font-family: var(--sans); font-weight: 900; font-size: 44px; letter-spacing: -0.04em; line-height: 0.9; }
.mkt-pv-total .blur { filter: blur(9px); user-select: none; }
.mkt-pv-list > div { display: grid; grid-template-columns: 40px 1fr auto; gap: 12px; align-items: center; padding: 12px 22px; border-bottom: 1px solid var(--rule); }
.mkt-pv-list > div:last-child { border-bottom: 0; }
.mkt-pv-t { font-family: var(--serif); font-style: italic; font-size: 15px; line-height: 1.05; }
.mkt-pv-a { font-family: var(--mono); font-size: 9.5px; color: var(--ink-mute); text-transform: uppercase; letter-spacing: 0.06em; margin-top: 2px; }
.mkt-pv-v { font-family: var(--sans); font-weight: 800; font-size: 15px; font-variant-numeric: tabular-nums; }
.mkt-pv-v.blur { filter: blur(6px); }
.mkt-pv-lock {
  position: absolute; inset: 0; display: flex; flex-direction: column; align-items: center; justify-content: flex-end;
  padding-bottom: 26px; background: linear-gradient(to bottom, transparent 40%, color-mix(in oklab, var(--paper) 88%, transparent) 100%);
  pointer-events: none;
}
.mkt-pv-lock span { font-family: var(--mono); font-size: 10px; letter-spacing: 0.12em; text-transform: uppercase; color: var(--ink-2); background: var(--paper); border: 1px solid var(--rule); padding: 7px 13px; border-radius: 999px; }

/* feature row */
.mkt-feat { max-width: var(--content-w); margin: 0 auto; padding: 40px 40px 110px; }
.mkt-feat-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1px; background: var(--rule); border: 1px solid var(--rule); }
.mkt-feat-cell { background: var(--paper); padding: 30px 26px; }
.mkt-feat-n { font-family: var(--mono); font-size: 11px; color: var(--accent); letter-spacing: 0.16em; }
.mkt-feat-h { font-family: var(--serif); font-size: 23px; font-style: italic; margin: 14px 0 10px; }
.mkt-feat-p { font-family: var(--body-serif); font-size: 15px; line-height: 1.55; color: var(--ink-2); }

/* ===========================================================
   AUTH SCREENS (login / signup / forgot)
   =========================================================== */
.auth { position: fixed; inset: 0; z-index: 90; display: grid; grid-template-columns: 1fr 1fr; background: var(--paper); animation: mcFade 0.25s ease; }
@keyframes mcFade { from { opacity: 0; } to { opacity: 1; } }
.auth-aside { position: relative; background: var(--ink); color: var(--paper); padding: 48px 52px; display: flex; flex-direction: column; justify-content: space-between; overflow: hidden; }
.auth-aside .grainwash { position: absolute; inset: 0; opacity: 0.5; background-image: repeating-linear-gradient(0deg, rgba(255,255,255,0.025) 0 1px, transparent 1px 3px); pointer-events: none; }
.auth-brand { display: flex; align-items: center; gap: 11px; font-family: var(--sans); font-weight: 800; font-size: 15px; position: relative; }
.auth-brand .dot { width: 9px; height: 9px; border-radius: 50%; background: var(--accent); }
.auth-aside-quote { position: relative; }
.auth-aside-quote .q { font-family: var(--serif); font-style: italic; font-size: clamp(28px, 3vw, 44px); line-height: 1.1; letter-spacing: -0.01em; }
.auth-aside-quote .q em { color: var(--accent); font-style: italic; }
.auth-aside-meta { position: relative; font-family: var(--mono); font-size: 10.5px; letter-spacing: 0.1em; text-transform: uppercase; color: rgba(243,237,225,0.55); display: flex; gap: 18px; flex-wrap: wrap; }

.auth-main { display: flex; align-items: center; justify-content: center; padding: 40px; overflow-y: auto; }
.auth-form { width: 100%; max-width: 380px; }
.auth-close { position: absolute; top: 24px; right: 28px; font-family: var(--mono); font-size: 11px; letter-spacing: 0.1em; text-transform: uppercase; color: var(--ink-mute); display: flex; align-items: center; gap: 7px; z-index: 2; }
.auth-close:hover { color: var(--ink); }
.auth-kicker { font-family: var(--mono); font-size: 11px; letter-spacing: 0.18em; text-transform: uppercase; color: var(--ink-mute); }
.auth-h { font-family: var(--serif); font-size: clamp(34px, 3.4vw, 46px); font-weight: 400; line-height: 1.02; margin: 14px 0 8px; }
.auth-sub { font-family: var(--body-serif); font-size: 15.5px; line-height: 1.5; color: var(--ink-2); margin: 0 0 28px; }

.auth-social { display: grid; gap: 10px; margin-bottom: 22px; }
.auth-soc-btn { display: flex; align-items: center; justify-content: center; gap: 11px; border: 1px solid var(--ink); background: #fff8; padding: 12px; font-family: var(--sans); font-weight: 600; font-size: 14px; transition: all 0.15s; }
.auth-soc-btn:hover { background: var(--ink); color: var(--paper); }
.auth-soc-btn:hover svg, .auth-soc-btn:hover svg * { filter: none; }
.auth-or { display: flex; align-items: center; gap: 14px; margin: 4px 0 22px; font-family: var(--mono); font-size: 10px; letter-spacing: 0.16em; text-transform: uppercase; color: var(--ink-mute); }
.auth-or::before, .auth-or::after { content: ""; flex: 1; height: 1px; background: var(--rule); }

.auth-field { margin-bottom: 18px; }
.auth-field label { display: block; font-family: var(--mono); font-size: 10px; letter-spacing: 0.12em; text-transform: uppercase; color: var(--ink-mute); margin-bottom: 7px; }
.auth-input { width: 100%; border: 0; border-bottom: 1.5px solid var(--rule); background: transparent; padding: 9px 2px; font-family: var(--sans); font-size: 16px; color: var(--ink); outline: none; transition: border-color 0.15s; }
.auth-input:focus { border-color: var(--accent); }
.auth-input::placeholder { color: var(--ink-mute); opacity: 0.6; }
.auth-field-row { display: flex; justify-content: space-between; align-items: baseline; }
.auth-field-row a { font-family: var(--mono); font-size: 9.5px; letter-spacing: 0.06em; text-transform: uppercase; color: var(--ink-mute); }
.auth-field-row a:hover { color: var(--accent); }

.auth-submit { width: 100%; background: var(--ink); color: var(--paper); padding: 14px; font-family: var(--mono); font-size: 12px; letter-spacing: 0.12em; text-transform: uppercase; font-weight: 600; margin-top: 8px; transition: background 0.15s; }
.auth-submit:hover { background: var(--accent); }
.auth-foot { font-family: var(--body-serif); font-size: 14.5px; color: var(--ink-2); margin-top: 24px; text-align: center; }
.auth-foot a { color: var(--ink); text-decoration: underline; text-underline-offset: 3px; text-decoration-color: var(--accent); }
.auth-foot a:hover { color: var(--accent); }
.auth-legal { font-family: var(--mono); font-size: 9.5px; line-height: 1.6; color: var(--ink-mute); margin-top: 22px; text-align: center; }
.auth-legal a { text-decoration: underline; text-underline-offset: 2px; }

/* ===========================================================
   SIGNUP GATE (the soft wall)
   =========================================================== */
.gate-backdrop { position: fixed; inset: 0; z-index: 95; background: color-mix(in oklab, var(--ink) 38%, transparent); backdrop-filter: blur(3px); display: grid; place-items: center; padding: 24px; animation: mcFade 0.2s ease; }
.gate { width: 100%; max-width: 440px; background: var(--paper); border: 1px solid var(--ink); box-shadow: 0 40px 90px -40px rgba(0,0,0,.6); animation: gateIn 0.28s cubic-bezier(0.2,0.8,0.2,1); }
@keyframes gateIn { from { opacity: 0; transform: translateY(12px) scale(0.98); } to { opacity: 1; transform: none; } }
.gate-top { background: var(--ink); color: var(--paper); padding: 26px 28px; position: relative; overflow: hidden; }
.gate-top .grainwash { position: absolute; inset: 0; opacity: 0.4; background-image: repeating-linear-gradient(0deg, rgba(255,255,255,0.03) 0 1px, transparent 1px 3px); }
.gate-eyebrow { font-family: var(--mono); font-size: 10px; letter-spacing: 0.18em; text-transform: uppercase; color: var(--accent); position: relative; }
.gate-h { font-family: var(--serif); font-size: 30px; font-weight: 400; line-height: 1.05; margin: 12px 0 0; position: relative; }
.gate-body { padding: 26px 28px 28px; }
.gate-p { font-family: var(--body-serif); font-size: 16px; line-height: 1.55; color: var(--ink-2); margin: 0 0 22px; }
.gate-list { display: grid; gap: 12px; margin-bottom: 26px; }
.gate-li { display: flex; gap: 12px; align-items: flex-start; font-family: var(--sans); font-size: 14px; color: var(--ink-2); }
.gate-li .gi { width: 22px; height: 22px; flex-shrink: 0; display: grid; place-items: center; border: 1px solid var(--accent); color: var(--accent); border-radius: 50%; }
.gate-actions { display: grid; gap: 10px; }
.gate-skip { font-family: var(--mono); font-size: 10.5px; letter-spacing: 0.08em; text-transform: uppercase; color: var(--ink-mute); text-align: center; padding: 4px; }
.gate-skip:hover { color: var(--ink); }
.gate-x { position: absolute; top: 18px; right: 20px; color: rgba(243,237,225,0.6); font-size: 18px; line-height: 1; z-index: 2; }
.gate-x:hover { color: var(--paper); }

/* ===========================================================
   ADD-RECORD FLOW (stepped modal / drawer)
   =========================================================== */
.add-backdrop { position: fixed; inset: 0; z-index: 95; background: color-mix(in oklab, var(--ink) 40%, transparent); backdrop-filter: blur(3px); display: grid; place-items: center; padding: 24px; animation: mcFade 0.2s ease; }
.add-modal { width: 100%; max-width: 620px; max-height: 88vh; display: flex; flex-direction: column; background: var(--paper); border: 1px solid var(--ink); box-shadow: 0 40px 90px -40px rgba(0,0,0,.6); animation: gateIn 0.28s cubic-bezier(0.2,0.8,0.2,1); }
.add-head { display: flex; align-items: center; justify-content: space-between; padding: 20px 24px; border-bottom: 1px solid var(--rule); }
.add-steps { display: flex; align-items: center; gap: 10px; font-family: var(--mono); font-size: 10px; letter-spacing: 0.1em; text-transform: uppercase; color: var(--ink-mute); }
.add-step { display: flex; align-items: center; gap: 7px; }
.add-step .n { width: 19px; height: 19px; border-radius: 50%; border: 1px solid var(--rule); display: grid; place-items: center; font-size: 9px; }
.add-step.active { color: var(--ink); }
.add-step.active .n { background: var(--accent); border-color: var(--accent); color: #fff; }
.add-step.done .n { background: var(--ink); border-color: var(--ink); color: var(--paper); }
.add-step-sep { width: 18px; height: 1px; background: var(--rule); }
.add-x { color: var(--ink-mute); font-size: 20px; line-height: 1; }
.add-x:hover { color: var(--ink); }
.add-body { padding: 22px 24px; overflow-y: auto; }
.add-foot { display: flex; align-items: center; justify-content: space-between; gap: 12px; padding: 16px 24px; border-top: 1px solid var(--rule); }

.add-title { font-family: var(--serif); font-size: 24px; font-weight: 400; margin: 0 0 4px; }
.add-hint { font-family: var(--body-serif); font-size: 14px; color: var(--ink-2); margin: 0 0 18px; }

/* search results */
.add-search { display: flex; align-items: center; gap: 10px; border: 1px solid var(--ink); background: #fff8; padding: 11px 14px; margin-bottom: 14px; }
.add-search input { border: 0; background: transparent; outline: none; font-family: var(--sans); font-size: 15px; width: 100%; color: var(--ink); }
.add-results { display: grid; gap: 1px; background: var(--rule); border: 1px solid var(--rule); max-height: 330px; overflow-y: auto; }
.add-res { display: grid; grid-template-columns: 46px 1fr auto; gap: 13px; align-items: center; background: var(--paper); padding: 11px 14px; text-align: left; transition: background 0.12s; }
.add-res:hover { background: color-mix(in oklab, var(--paper) 78%, #fff 22%); }
.add-res-t { font-family: var(--serif); font-style: italic; font-size: 16px; line-height: 1.05; }
.add-res-a { font-family: var(--mono); font-size: 9.5px; text-transform: uppercase; letter-spacing: 0.06em; color: var(--ink-mute); margin-top: 3px; }
.add-res-rank { font-family: var(--mono); font-size: 10px; color: var(--accent); }
.add-manual-link { font-family: var(--mono); font-size: 10.5px; letter-spacing: 0.06em; text-transform: uppercase; color: var(--ink-mute); margin-top: 14px; display: inline-flex; gap: 7px; align-items: center; }
.add-manual-link:hover { color: var(--accent); }

/* selected album banner */
.add-sel { display: flex; gap: 14px; align-items: center; padding: 12px; border: 1px solid var(--rule); background: #fff6; margin-bottom: 20px; }
.add-sel .cv { width: 54px; height: 54px; flex-shrink: 0; }
.add-sel-t { font-family: var(--serif); font-style: italic; font-size: 18px; }
.add-sel-a { font-family: var(--mono); font-size: 10px; text-transform: uppercase; letter-spacing: 0.06em; color: var(--ink-mute); margin-top: 3px; }
.add-sel-change { margin-left: auto; font-family: var(--mono); font-size: 9.5px; letter-spacing: 0.06em; text-transform: uppercase; color: var(--ink-mute); border: 1px solid var(--rule); padding: 6px 9px; }
.add-sel-change:hover { color: var(--ink); border-color: var(--ink); }

/* pressing picker (Discogs) */
.add-pr-attr { font-family: var(--mono); font-size: 9.5px; letter-spacing: 0.06em; color: var(--ink-mute); margin: 0 0 12px; display: flex; align-items: center; gap: 6px; }
.add-pr-list { display: grid; gap: 10px; }
.add-pr {
  display: grid; grid-template-columns: 1fr auto; gap: 12px; align-items: center;
  border: 1px solid var(--rule); background: var(--paper); padding: 14px 16px; text-align: left; transition: all 0.14s;
}
.add-pr:hover { border-color: var(--ink-mute); }
.add-pr.sel { border-color: var(--accent); box-shadow: inset 0 0 0 1px var(--accent); background: color-mix(in oklab, var(--paper) 92%, var(--accent) 8%); }
.add-pr-main { min-width: 0; }
.add-pr-label { font-family: var(--sans); font-weight: 700; font-size: 14.5px; }
.add-pr-tags { display: flex; flex-wrap: wrap; gap: 5px; margin-top: 8px; }
.add-pr-tag { font-family: var(--mono); font-size: 9px; letter-spacing: 0.04em; text-transform: uppercase; padding: 3px 6px; border: 1px solid var(--rule); color: var(--ink-2); border-radius: 3px; }
.add-pr-notes { font-family: var(--body-serif); font-size: 13px; color: var(--ink-2); margin-top: 8px; }
.add-pr-meta { font-family: var(--mono); font-size: 9px; color: var(--ink-mute); margin-top: 8px; letter-spacing: 0.03em; }
.add-pr-val { text-align: right; white-space: nowrap; }
.add-pr-val .num { font-family: var(--sans); font-weight: 900; font-size: 20px; letter-spacing: -0.02em; font-variant-numeric: tabular-nums; }
.add-pr-val .lbl { font-family: var(--mono); font-size: 8.5px; letter-spacing: 0.08em; text-transform: uppercase; color: var(--ink-mute); margin-top: 3px; }

/* condition selector */
.add-cond-list { display: grid; gap: 7px; }
.add-cond {
  display: grid; grid-template-columns: 58px 1fr auto; gap: 14px; align-items: center;
  border: 1px solid var(--rule); background: var(--paper); padding: 12px 15px; text-align: left; transition: all 0.14s;
}
.add-cond:hover { border-color: var(--ink-mute); }
.add-cond.sel { border-color: var(--accent); box-shadow: inset 0 0 0 1px var(--accent); }
.add-cond-code { font-family: var(--mono); font-weight: 700; font-size: 14px; }
.add-cond-name { font-family: var(--sans); font-weight: 700; font-size: 13.5px; }
.add-cond-blurb { font-family: var(--body-serif); font-size: 12.5px; line-height: 1.4; color: var(--ink-2); margin-top: 3px; }
.add-cond-val { font-family: var(--sans); font-weight: 800; font-size: 16px; font-variant-numeric: tabular-nums; white-space: nowrap; }

.add-back { font-family: var(--mono); font-size: 11px; letter-spacing: 0.08em; text-transform: uppercase; color: var(--ink-mute); }
.add-back:hover { color: var(--ink); }
.add-next { background: var(--ink); color: var(--paper); padding: 12px 22px; font-family: var(--mono); font-size: 11px; letter-spacing: 0.1em; text-transform: uppercase; font-weight: 600; transition: background 0.15s; }
.add-next:hover { background: var(--accent); }
.add-next:disabled { opacity: 0.4; cursor: not-allowed; }
.add-next:disabled:hover { background: var(--ink); }

/* manual entry form */
.add-manual-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; }
.add-manual-grid .full { grid-column: 1 / -1; }
.add-mf label { display: block; font-family: var(--mono); font-size: 10px; letter-spacing: 0.1em; text-transform: uppercase; color: var(--ink-mute); margin-bottom: 6px; }
.add-mf input, .add-mf select { width: 100%; border: 1px solid var(--rule); background: #fff8; padding: 10px 11px; font-family: var(--sans); font-size: 14px; color: var(--ink); outline: none; }
.add-mf input:focus, .add-mf select:focus { border-color: var(--accent); }

/* ===========================================================
   NAV AVATAR + DROPDOWN
   =========================================================== */
.nav-acct { position: relative; display: flex; align-items: center; }
.nav-avatar { display: flex; align-items: center; gap: 9px; cursor: pointer; }
.nav-avatar .av { width: 30px; height: 30px; border-radius: 50%; background: var(--accent); color: #fff; font-family: var(--sans); font-weight: 800; font-size: 11px; display: grid; place-items: center; letter-spacing: 0.02em; }
.nav-avatar .nm { font-family: var(--mono); font-size: 11px; letter-spacing: 0.06em; text-transform: uppercase; color: var(--ink-2); }
.nav-avatar:hover .nm { color: var(--ink); }
.nav-signin { font-family: var(--mono); font-size: 11px; letter-spacing: 0.1em; text-transform: uppercase; white-space: nowrap; border: 1px solid var(--ink); padding: 7px 13px; transition: all 0.15s; color: var(--ink); }
.nav-signin:hover { background: var(--ink); color: var(--paper); }
.nav-menu { position: absolute; top: calc(100% + 12px); right: 0; width: 230px; background: var(--paper); border: 1px solid var(--ink); box-shadow: 0 24px 50px -28px rgba(0,0,0,.5); z-index: 80; animation: gateIn 0.18s ease; }
.nav-menu-head { padding: 16px; border-bottom: 1px solid var(--rule); }
.nav-menu-head .nm { font-family: var(--sans); font-weight: 700; font-size: 14px; }
.nav-menu-head .em { font-family: var(--mono); font-size: 10px; color: var(--ink-mute); margin-top: 3px; }
.nav-menu a { display: flex; align-items: center; gap: 11px; padding: 12px 16px; font-family: var(--sans); font-size: 13.5px; color: var(--ink-2); transition: background 0.12s, color 0.12s; cursor: pointer; }
.nav-menu a:hover { background: color-mix(in oklab, var(--paper) 80%, #fff 20%); color: var(--ink); }
.nav-menu a svg { color: var(--ink-mute); }
.nav-menu a.sep { border-top: 1px solid var(--rule); }
.nav-menu a.signout { color: oklch(0.55 0.16 28); }

/* ===========================================================
   PROTOTYPE STATE SWITCHER
   =========================================================== */
.proto-sw { position: fixed; bottom: 24px; left: 24px; z-index: 88; background: var(--ink); color: var(--paper); border-radius: 8px; box-shadow: 0 16px 40px -18px rgba(0,0,0,.6); font-family: var(--mono); max-width: 230px; overflow: hidden; }
.proto-sw-head { display: flex; align-items: center; justify-content: space-between; gap: 10px; padding: 10px 12px; cursor: pointer; }
.proto-sw-head .t { font-size: 9.5px; letter-spacing: 0.14em; text-transform: uppercase; color: rgba(243,237,225,0.6); }
.proto-sw-head .dot { width: 7px; height: 7px; border-radius: 50%; background: oklch(0.7 0.16 145); }
.proto-sw-body { padding: 4px 8px 10px; display: grid; gap: 4px; }
.proto-sw-grp { font-size: 8.5px; letter-spacing: 0.14em; text-transform: uppercase; color: rgba(243,237,225,0.4); margin: 7px 4px 2px; }
.proto-sw button { text-align: left; font-family: var(--mono); font-size: 10.5px; letter-spacing: 0.04em; color: rgba(243,237,225,0.8); padding: 7px 9px; border-radius: 5px; transition: background 0.12s, color 0.12s; }
.proto-sw button:hover { background: rgba(243,237,225,0.1); color: var(--paper); }
.proto-sw button.on { background: var(--accent); color: #fff; }
.proto-sw .chev { transition: transform 0.2s; font-size: 10px; }
.proto-sw.collapsed .chev { transform: rotate(-90deg); }

/* ===========================================================
   RESPONSIVE
   =========================================================== */
@media (max-width: 980px) {
  .mc-hero { grid-template-columns: 1fr; gap: 28px; }
  .mc-dash-grid { grid-template-columns: 1fr; }
  .mkt-hero { grid-template-columns: 1fr; gap: 36px; padding-top: 104px; }
  .mkt-feat-grid { grid-template-columns: 1fr; }
  .auth { grid-template-columns: 1fr; }
  .auth-aside { display: none; }
}
@media (max-width: 640px) {
  .mc { padding: 92px 18px 120px; }
  .mc-hero-total { font-size: clamp(54px, 17vw, 92px); }
  .mc-grid { grid-template-columns: 1fr; }
  .mc-tiles { grid-template-columns: 1fr; }
  .mc-bar { position: sticky; top: 56px; background: color-mix(in oklab, var(--paper) 92%, transparent); backdrop-filter: blur(8px); z-index: 40; padding-top: 10px; margin-left: -18px; margin-right: -18px; padding-left: 18px; padding-right: 18px; }
  .mc-controls { width: 100%; }
  .mc-search { flex: 1; min-width: 0; }
  /* The backdrop height is set to window.visualViewport.height in JS so it
     shrinks when the keyboard opens (iOS doesn't shrink vh/dvh for the
     keyboard). The modal fits within that and its body scrolls. */
  .add-modal { max-width: 100%; max-height: 100%; align-self: flex-end; }
  .add-modal .add-body { flex: 1 1 auto; min-height: 0; -webkit-overflow-scrolling: touch; }
  .add-backdrop { place-items: end stretch; padding: 0; }
  .add-manual-grid { grid-template-columns: 1fr; }
  .mkt-pv-total { font-size: 36px; }
  .proto-sw { bottom: 14px; left: 14px; }
  .nav-avatar .nm { display: none; }
}

/* ---- Password show/hide toggle (login + signup) ---- */
.auth-pass-wrap { position: relative; display: block; }
.auth-pass-wrap .auth-input { width: 100%; padding-right: 52px; }
.auth-pass-toggle {
  position: absolute; right: 0; bottom: 7px;
  background: none; border: 0; padding: 2px 2px;
  font-family: var(--sans); font-size: 12px; font-weight: 600;
  letter-spacing: 0.04em; text-transform: uppercase;
  color: var(--ink-mute); cursor: pointer; opacity: 0.7;
  transition: color 0.15s, opacity 0.15s;
}
.auth-pass-toggle:hover { color: var(--accent); opacity: 1; }

/* ---- Add-record: "every record ever made" catalog results ---- */
.add-cat-head {
  font-family: var(--mono); font-size: 10px; letter-spacing: 0.12em;
  text-transform: uppercase; color: var(--ink-mute);
  padding: 14px 14px 6px; border-top: 1px solid var(--rule); margin-top: 6px;
}
.add-cat-spin { opacity: 0.6; text-transform: none; letter-spacing: 0; }
.add-res-cat .add-res-cover { overflow: hidden; border-radius: 2px; background: var(--paper-2, #eee); }
.add-res-cat-tag {
  color: var(--paper); background: var(--accent);
  padding: 3px 9px; border-radius: 999px; font-size: 10px;
  letter-spacing: 0.08em; text-transform: uppercase;
}
.add-res-cat[disabled] { opacity: 0.5; pointer-events: none; }
.add-cat-empty { padding: 14px; font-size: 13px; color: var(--ink-mute); font-style: italic; }
.add-cat-pricing {
  padding: 12px 14px; font-family: var(--mono); font-size: 11px;
  letter-spacing: 0.08em; text-transform: uppercase; color: var(--accent);
}

/* ======================================================================
   Collection v2 — scanner, add flow, verified cards
   (appended; see MyCollectionAdd_v2.jsx / BarcodeScanner.jsx / MyCollectionV2.jsx)
   ====================================================================== */

/* verified-collection card extras */
.v2-badge { display:inline-block; margin-left:8px; padding:1px 7px; border-radius:20px; font-size:11px; letter-spacing:.02em; }
.v2-badge.scanned { background:oklch(0.52 0.13 150 / .15); color:oklch(0.42 0.13 150); }
.v2-badge.manual { background:var(--paper-2, #efe9df); color:var(--ink-mute); }
.v2-public-note { font-size:12px; color:var(--ink-mute); margin-top:12px; max-width:46ch; }

/* ---- scanner overlay ---- */
.bs-overlay { position:fixed; inset:0; z-index:9999; background:#000; display:flex; flex-direction:column; }
.bs-topbar { display:flex; align-items:center; justify-content:space-between; padding:14px 18px; color:#fff; }
.bs-title { font-size:15px; letter-spacing:.04em; text-transform:uppercase; }
.bs-close { background:none; border:none; color:#fff; font-size:30px; line-height:1; cursor:pointer; }
.bs-stage { position:relative; flex:1; overflow:hidden; }
.bs-video { position:absolute; inset:0; width:100%; height:100%; object-fit:cover; }
.bs-frame { position:absolute; left:50%; top:50%; transform:translate(-50%,-50%); width:min(78vw,360px); height:170px; }
.bs-corner { position:absolute; width:26px; height:26px; border:3px solid #fff; }
.bs-corner.tl { top:0; left:0; border-right:none; border-bottom:none; }
.bs-corner.tr { top:0; right:0; border-left:none; border-bottom:none; }
.bs-corner.bl { bottom:0; left:0; border-right:none; border-top:none; }
.bs-corner.br { bottom:0; right:0; border-left:none; border-top:none; }
.bs-scanline { position:absolute; left:6px; right:6px; top:50%; height:2px; background:var(--accent); box-shadow:0 0 8px var(--accent); animation:bsscan 1.8s ease-in-out infinite; }
@keyframes bsscan { 0%{top:10%} 50%{top:90%} 100%{top:10%} }
.bs-hint { position:absolute; left:0; right:0; top:50%; text-align:center; color:#fff; font-size:14px; }
.bs-hint-bottom { top:auto; bottom:28px; opacity:.85; }
.bs-fallback { background:#111; color:#fff; padding:18px; }
.bs-fallback-msg { font-size:13px; opacity:.85; margin-bottom:12px; }
.bs-manual { display:flex; gap:8px; }
.bs-manual-input { flex:1; padding:12px; font-size:16px; border-radius:8px; border:1px solid #444; background:#1c1c1c; color:#fff; }
.bs-manual-go { padding:12px 16px; border:none; border-radius:8px; background:var(--accent); color:#fff; font-size:15px; }
.bs-manual-go:disabled { opacity:.4; }
.bs-type-instead { background:none; border:none; color:#fff; opacity:.8; padding:16px; font-size:14px; text-decoration:underline; cursor:pointer; }

/* ---- add flow modal ---- */
.av2-backdrop { position:fixed; inset:0; background:rgba(20,16,12,.55); display:flex; align-items:center; justify-content:center; padding:16px; z-index:500; }
.av2-modal { background:var(--paper); width:100%; max-width:520px; max-height:90vh; border-radius:14px; overflow:hidden; display:flex; flex-direction:column; box-shadow:0 24px 60px rgba(0,0,0,.3); }
.av2-head { display:flex; align-items:center; justify-content:space-between; padding:16px 18px; border-bottom:1px solid var(--rule); }
.av2-head-title { text-transform:uppercase; letter-spacing:.06em; font-size:13px; }
.av2-x { background:none; border:none; font-size:26px; line-height:1; cursor:pointer; color:var(--ink-mute); }
.av2-body { overflow:auto; }
.av2-pane { padding:20px; }
.av2-title { font-size:20px; margin:0 0 6px; }
.av2-hint { color:var(--ink-mute); font-size:14px; margin:0 0 14px; }
.av2-foot { display:flex; justify-content:space-between; gap:10px; margin-top:18px; }
.av2-next { padding:11px 18px; border:none; border-radius:8px; background:var(--ink); color:var(--paper); font-size:15px; cursor:pointer; }
.av2-next:disabled { opacity:.4; }
.av2-back { padding:11px 16px; border:1px solid var(--rule); border-radius:8px; background:#fff; cursor:pointer; }
.av2-back:disabled { opacity:.4; }
.av2-back-link, .av2-entry-link { background:none; border:none; color:var(--accent); cursor:pointer; padding:6px 0; font-size:14px; }
.av2-consent-lede { font-size:15px; }
.av2-consent-list { padding-left:18px; font-size:14px; line-height:1.55; }
.av2-consent-ack { display:flex; gap:10px; align-items:flex-start; margin-top:14px; font-size:14px; }
.av2-entry-primary { width:100%; display:flex; flex-direction:column; align-items:center; gap:4px; padding:22px; border:2px solid var(--ink); border-radius:12px; background:#fff; cursor:pointer; margin-bottom:12px; }
.av2-entry-primary span { font-size:17px; font-weight:600; }
.av2-entry-primary small { color:var(--ink-mute); }
.av2-entry-secondary { width:100%; padding:13px; border:1px solid var(--rule); border-radius:10px; background:#fff; cursor:pointer; margin-bottom:10px; font-size:15px; }
.av2-public-note { font-size:12px; color:var(--ink-mute); margin-top:14px; }
.av2-cand-list, .av2-results { display:flex; flex-direction:column; gap:8px; }
.av2-cand, .av2-res { display:flex; gap:10px; align-items:center; text-align:left; padding:10px; border:1px solid var(--rule); border-radius:10px; background:#fff; cursor:pointer; }
.av2-cand-thumb { width:48px; height:48px; object-fit:cover; border-radius:6px; background:#eee; flex:none; }
.av2-cand-main { display:flex; flex-direction:column; gap:2px; }
.av2-cand-meta, .av2-cand-fmt { font-size:12px; color:var(--ink-mute); }
.av2-res { justify-content:space-between; }
.av2-res-rank { color:var(--ink-mute); font-size:12px; }
.av2-search input, .av2-manual-grid input { width:100%; padding:11px; border:1px solid var(--rule); border-radius:8px; font-size:16px; }
.av2-search { margin-bottom:12px; }
.av2-manual-grid { display:flex; flex-direction:column; gap:10px; }
.av2-manual-grid label { display:flex; flex-direction:column; gap:4px; font-size:13px; color:var(--ink-mute); }
.av2-chosen { display:flex; gap:12px; align-items:center; margin-bottom:16px; }
.av2-chosen-cover { width:56px; height:56px; object-fit:cover; border-radius:6px; }
.av2-chosen-meta { font-size:13px; color:var(--ink-mute); }
.av2-grade-group { margin-bottom:14px; }
.av2-grade-label { font-size:13px; color:var(--ink-mute); margin-bottom:6px; }
.av2-grade-row { display:flex; flex-wrap:wrap; gap:6px; }
.av2-grade { min-width:42px; padding:9px 10px; border:1px solid var(--rule); border-radius:8px; background:#fff; cursor:pointer; font-size:14px; }
.av2-grade.sel { background:var(--ink); color:var(--paper); border-color:var(--ink); }
.av2-est { min-height:22px; font-size:14px; margin-top:8px; }
.av2-est-val { color:var(--accent); font-weight:600; }
.av2-est-busy, .av2-est-none { color:var(--ink-mute); }

/* ---- collection v2 dashboard ---- */
.v2-progress-panel { margin-bottom:18px; }
.v2-progress-head { font-size:22px; margin:6px 0 8px; }
.v2-progress-head b { font-size:26px; }
.v2-progress-pct { color:var(--ink-mute); font-size:14px; margin-left:8px; }
.v2-gaps-label { font-size:12px; color:var(--ink-mute); margin:16px 0 8px; text-transform:uppercase; letter-spacing:.04em; }
.v2-gaps { display:flex; gap:10px; overflow-x:auto; padding-bottom:6px; }
.v2-gap { flex:none; width:56px; text-align:center; text-decoration:none; color:inherit; opacity:.92; transition:opacity .15s; }
.v2-gap:hover { opacity:1; }
.v2-gap-rank { display:block; font-size:10px; color:var(--ink-mute); margin-top:4px; }
.v2-cond-dist { display:flex; flex-direction:column; gap:7px; margin-top:6px; }
.v2-cond-row { display:flex; align-items:center; gap:10px; }
.v2-cond-code { width:38px; font-size:13px; font-weight:600; }
.v2-cond-track { flex:1; height:10px; background:var(--rule); border-radius:6px; overflow:hidden; }
.v2-cond-fill { display:block; height:100%; background:var(--accent); }
.v2-cond-n { width:28px; text-align:right; font-size:13px; color:var(--ink-mute); }

/* value-over-time chart with axes */
.v2-vot { display:flex; gap:8px; }
.v2-vot-yaxis { display:flex; flex-direction:column; justify-content:space-between; height:150px; text-align:right; font-size:11px; color:var(--ink-mute); min-width:42px; }
.v2-vot-plot { flex:1; min-width:0; }
.v2-vot-xaxis { display:flex; justify-content:space-between; font-size:11px; color:var(--ink-mute); margin-top:4px; }

/* ===== Collection v2 — leaderboards + public collection view ===== */
.lb, .pubcol { max-width:780px; margin:0 auto; padding:32px 18px 80px; }
.lb-title { font-family:var(--serif, Georgia); font-size:34px; margin:0 0 6px; }
.lb-sub { color:var(--ink-mute); font-size:14px; max-width:54ch; margin:0 0 18px; }
.lb-tabs { display:flex; gap:6px; border-bottom:1px solid var(--rule); margin-bottom:18px; }
.lb-tab { background:none; border:none; padding:10px 14px; font-size:15px; color:var(--ink-mute); cursor:pointer; border-bottom:2px solid transparent; margin-bottom:-1px; }
.lb-tab.active { color:var(--ink); border-bottom-color:var(--accent); font-weight:600; }
.lb-genre-select { margin-bottom:14px; }
.lb-genre-select select { padding:9px 12px; border:1px solid var(--rule); border-radius:8px; font-size:14px; background:#fff; }
.lb-note { color:var(--ink-mute); font-size:13px; font-style:italic; margin:0 0 14px; }
.lb-empty { padding:40px 0; text-align:center; color:var(--ink-mute); }
.lb-list { display:flex; flex-direction:column; gap:6px; }
.lb-row { display:flex; align-items:center; gap:14px; width:100%; text-align:left; padding:14px 16px; border:1px solid var(--rule); border-radius:10px; background:#fff; cursor:pointer; transition:border-color .15s; }
.lb-row:hover { border-color:var(--accent); }
.lb-row.me { background:var(--paper-2, #efe9df); }
.lb-rank { width:30px; font-size:16px; font-weight:600; color:var(--ink-mute); text-align:center; flex:none; }
.lb-rank.medal.r0 { color:#b8860b; } .lb-rank.medal.r1 { color:#8a8a8a; } .lb-rank.medal.r2 { color:#a0673a; }
.lb-name { font-size:16px; flex:1; min-width:0; overflow:hidden; text-overflow:ellipsis; white-space:nowrap; }
.lb-meta { font-size:14px; color:var(--ink-mute); text-align:right; }
.lb-meta b { color:var(--ink); font-size:16px; }
.lb-arrow { color:var(--ink-mute); flex:none; }
.lb-back { background:none; border:none; color:var(--accent); cursor:pointer; font-size:14px; padding:0 0 14px; }
.pubcol-head { margin-bottom:20px; }
.pubcol-stats { display:flex; gap:8px; flex-wrap:wrap; margin:8px 0; }

/* leaderboard rows — crown jewel cover + collecting-since */
.lb-crown { flex:none; width:48px; height:48px; border-radius:4px; overflow:hidden; }
.lb-crown-blank { display:block; width:48px; height:48px; background:var(--paper-2, #efe9df); }
.lb-name-col { flex:1; min-width:0; display:flex; flex-direction:column; gap:2px; }
.lb-name-col .lb-name { flex:none; font-size:16px; overflow:hidden; text-overflow:ellipsis; white-space:nowrap; }
.lb-since { font-size:12px; color:var(--ink-mute); overflow:hidden; text-overflow:ellipsis; white-space:nowrap; }
.lb-meta small { display:block; font-size:11px; font-weight:400; color:var(--ink-mute); }

/* clear the fixed nav (match .mc) */
.lb, .pubcol { padding-top: 104px; }

/* leaderboard crown key + badge */
.lb-key { display:flex; align-items:center; gap:7px; font-size:13px; color:var(--ink-mute); margin-top:4px; }
.lb-key-crown { color:#b8860b; display:inline-flex; }
.lb-since svg { color:#b8860b; }
.lb-crown { position:relative; }
.lb-crown-badge { position:absolute; top:-5px; right:-5px; width:16px; height:16px; border-radius:50%; background:#b8860b; color:#fff; display:flex; align-items:center; justify-content:center; box-shadow:0 1px 3px rgba(0,0,0,.3); }

/* ===== Account settings ===== */
.acct { max-width:640px; margin:0 auto; padding:104px 18px 80px; }
.acct-head { display:flex; align-items:center; gap:16px; margin-bottom:22px; }
.acct-avatar { flex:none; width:52px; height:52px; border-radius:50%; background:var(--ink); color:var(--paper); display:flex; align-items:center; justify-content:center; font-size:18px; font-weight:700; }
.acct-sub { color:var(--ink-mute); font-size:14px; margin-top:4px; }
.acct-card { border:1px solid var(--rule); border-radius:12px; padding:18px; margin-bottom:14px; background:#fff; }
.acct-card-k { font-size:15px; font-weight:600; }
.acct-card-d { font-size:13px; color:var(--ink-mute); margin:4px 0 12px; }
.acct-row { display:flex; gap:8px; }
.acct-row input { flex:1; min-width:0; padding:11px; border:1px solid var(--rule); border-radius:8px; font-size:15px; }
.acct-btn { padding:11px 16px; border:none; border-radius:8px; background:var(--ink); color:var(--paper); font-size:14px; cursor:pointer; white-space:nowrap; }
.acct-btn:disabled { opacity:.5; }
.acct-btn.ghost { background:#fff; color:var(--ink); border:1px solid var(--rule); }
.acct-btn.danger { background:none; color:oklch(0.55 0.16 28); border:1px solid currentColor; }
.acct-link { background:none; border:none; color:var(--accent); cursor:pointer; font-size:13px; padding:10px 0 0; }
.acct-msg { font-size:13px; color:var(--ink-mute); margin-top:10px; }

.acct-col { display:flex; flex-direction:column; gap:8px; }

/* ===== Leaderboards — dynamism: podium, bars, badges, movers, champions, rarest ===== */
.lb-tabs { overflow-x: auto; overflow-y: hidden; touch-action: pan-x; flex-wrap: nowrap; -webkit-overflow-scrolling: touch; scrollbar-width: none; }
.lb-tabs::-webkit-scrollbar { display: none; }
.lb-tab { white-space: nowrap; flex: none; }

/* podium */
.lb-podium { display: flex; align-items: flex-end; justify-content: center; gap: 12px; margin: 12px 0 24px; }
.lb-pod { flex: 1; max-width: 168px; text-align: center; background: #fff; border: 1px solid var(--rule); border-radius: 12px; padding: 14px 8px 0; cursor: pointer; display: flex; flex-direction: column; align-items: center; transition: transform .2s ease, box-shadow .2s ease; }
.lb-pod:hover { transform: translateY(-3px); box-shadow: 0 14px 30px rgba(0,0,0,.1); }
.lb-pod-1 { transform: scale(1.05); } .lb-pod-1:hover { transform: translateY(-3px) scale(1.05); }
.lb-pod-medal { width: 28px; height: 28px; border-radius: 50%; display: flex; align-items: center; justify-content: center; font-weight: 700; color: #fff; margin: 10px 0 4px; }
.lb-pod-medal.m1 { background: #caa53d; } .lb-pod-medal.m2 { background: #9a9a9a; } .lb-pod-medal.m3 { background: #a0673a; }
.lb-pod-name { font-size: 13px; font-weight: 600; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; max-width: 100%; }
.lb-pod-val { font-size: 13px; color: var(--ink-mute); }
.lb-pod-bar { width: 64%; margin-top: 10px; border-radius: 6px 6px 0 0; background: linear-gradient(var(--accent), color-mix(in oklab, var(--accent) 35%, var(--paper))); }
.lb-pod-1 .lb-pod-bar { height: 36px; } .lb-pod-2 .lb-pod-bar { height: 22px; } .lb-pod-3 .lb-pod-bar { height: 14px; }

/* per-row value bar (animates on mount) */
.lb-bar { display: block; height: 5px; background: var(--rule); border-radius: 5px; overflow: hidden; margin-top: 7px; }
.lb-bar i { display: block; height: 100%; width: 0; background: var(--accent); border-radius: 5px; animation: lbbar .85s cubic-bezier(.2,.7,.2,1) forwards; }
@keyframes lbbar { to { width: var(--w); } }
@media (prefers-reduced-motion: reduce) { .lb-bar i { animation: none; width: var(--w); } }

/* badges */
.lb-badges { display: flex; flex-wrap: wrap; gap: 5px; margin-top: 5px; }
.lb-badge { font-size: 10px; font-family: var(--mono); letter-spacing: .04em; text-transform: uppercase; color: var(--ink-mute); background: var(--paper-2, #efe9df); border-radius: 20px; padding: 2px 7px; }

/* movers chip */
.lb-mv { font-size: 11px; font-weight: 700; margin-left: 4px; white-space: nowrap; }
.lb-mv.up { color: oklch(0.5 0.13 150); } .lb-mv.down { color: oklch(0.55 0.16 28); } .lb-mv.flat { color: var(--ink-mute); }

/* genre champions */
.lb-champ-grid { display: grid; grid-template-columns: 1fr; gap: 10px; }
@media (min-width: 560px) { .lb-champ-grid { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 860px) { .lb-champ-grid { grid-template-columns: repeat(3, 1fr); } }
.lb-champ { text-align: left; background: #fff; border: 1px solid var(--rule); border-radius: 12px; padding: 16px; cursor: pointer; transition: transform .2s ease, box-shadow .2s ease, border-color .2s ease; }
.lb-champ:hover { transform: translateY(-3px); box-shadow: 0 12px 28px rgba(0,0,0,.09); border-color: var(--accent); }
.lb-champ-genre { font-family: var(--mono); font-size: 11px; letter-spacing: .12em; text-transform: uppercase; color: var(--accent); }
.lb-champ-name { font-family: var(--serif); font-size: 20px; margin: 6px 0 2px; }
.lb-champ-val { font-weight: 700; }
.lb-champ-tag { font-size: 11px; color: var(--ink-mute); margin-top: 8px; }

/* rarest finds */
.lb-rare-list { display: flex; flex-direction: column; gap: 6px; }
.lb-rare { display: flex; align-items: center; gap: 12px; text-align: left; background: #fff; border: 1px solid var(--rule); border-radius: 10px; padding: 10px 14px; cursor: pointer; transition: border-color .2s ease; }
.lb-rare:hover { border-color: var(--accent); }
.lb-rare-rank { width: 20px; font-weight: 700; color: var(--ink-mute); flex: none; }
.lb-rare-cover { flex: none; }
.lb-rare-main { flex: 1; min-width: 0; display: flex; flex-direction: column; }
.lb-rare-t { font-weight: 600; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.lb-rare-a { font-size: 12px; color: var(--ink-mute); overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.lb-rare-v { font-weight: 700; flex: none; }

/* ===== Leaderboards v3 — stats hero, dramatic podium, gallery, polish ===== */

/* Entrance: rows/cards rise + fade, staggered by --i. */
@keyframes lbrise { from { opacity: 0; transform: translateY(10px); } to { opacity: 1; transform: none; } }
@keyframes lbshine { 0% { left: -60%; } 32%, 100% { left: 130%; } }

/* ---- Aggregate stats hero band (dark command bar) ---- */
.lb-stats {
  display: grid; grid-template-columns: repeat(5, 1fr); gap: 1px;
  background: var(--rule); border-radius: 16px; overflow: hidden;
  margin: 0 0 24px; box-shadow: 0 22px 50px -30px rgba(0,0,0,.5);
}
.lb-stat {
  background: radial-gradient(150% 170% at 0% 0%, #241d15 0%, #14110d 62%);
  color: #f3ede1; padding: 20px 14px; text-align: center;
}
.lb-stat-n { font-family: var(--sans, system-ui); font-weight: 900; font-size: 30px; letter-spacing: -0.03em; line-height: 1; }
.lb-stat-n .cur { font-size: .6em; opacity: .8; margin-right: 1px; font-weight: 800; }
.lb-stat-n small { font-size: .46em; font-weight: 700; opacity: .55; letter-spacing: 0; }
.lb-stat-l { font-family: var(--mono, ui-monospace); font-size: 10px; letter-spacing: .12em; text-transform: uppercase; color: rgba(243,237,225,.58); margin-top: 8px; }
.lb-stat-hero { background: radial-gradient(150% 170% at 100% 0%, #2a2016 0%, #14110d 62%); }
.lb-stat-hero .lb-stat-n { color: color-mix(in oklab, var(--accent) 72%, #f3ede1); font-size: 35px; }
@media (max-width: 680px) {
  .lb-stats { grid-template-columns: repeat(2, 1fr); }
  .lb-stat-hero { grid-column: 1 / -1; order: -1; }
  .lb-stat-n { font-size: 26px; } .lb-stat-hero .lb-stat-n { font-size: 30px; }
}

/* ---- Podium: taller, gradient leader, shine, crown + sub-line ---- */
.lb-podium { gap: 14px; margin: 8px 0 30px; }
.lb-pod { position: relative; overflow: hidden; padding: 18px 10px 0; border-radius: 14px; }
.lb-pod-1 {
  background: linear-gradient(180deg, #fff, color-mix(in oklab, var(--accent) 9%, #fff));
  border-color: color-mix(in oklab, var(--accent) 42%, var(--rule));
  box-shadow: 0 16px 36px -20px color-mix(in oklab, var(--accent) 60%, rgba(0,0,0,.5));
}
.lb-pod-cover { position: relative; border-radius: 6px; box-shadow: 0 12px 26px -12px rgba(0,0,0,.45); }
.lb-pod-crownico {
  position: absolute; top: -8px; right: -8px; width: 21px; height: 21px; border-radius: 50%;
  background: #caa53d; color: #fff; display: flex; align-items: center; justify-content: center;
  box-shadow: 0 2px 6px rgba(0,0,0,.32); z-index: 2;
}
.lb-pod-val { font-family: var(--sans, system-ui); font-size: 17px; font-weight: 800; letter-spacing: -.02em; color: var(--ink); margin-top: 2px; }
.lb-pod-1 .lb-pod-val { font-size: 19px; }
.lb-pod-val .cur { font-size: .7em; opacity: .7; margin-right: 1px; }
.lb-pod-val b { font-weight: 800; }
.lb-pod-sub { font-size: 11px; color: var(--ink-mute); margin-top: 3px; }
.lb-pod-1 .lb-pod-bar { height: 50px; } .lb-pod-2 .lb-pod-bar { height: 32px; } .lb-pod-3 .lb-pod-bar { height: 18px; }
.lb-pod-bar { margin-top: 12px; }
.lb-pod-shine {
  position: absolute; top: 0; left: -60%; width: 42%; height: 100%; pointer-events: none; z-index: 1;
  background: linear-gradient(100deg, transparent, rgba(255,255,255,.55), transparent);
  transform: skewX(-18deg); animation: lbshine 3.6s ease-in-out 1.1s infinite;
}

/* ---- Ranked rows: stagger in, sub-line, richer bar, hover ---- */
.lb-row { animation: lbrise .5s cubic-bezier(.2,.7,.2,1) backwards; animation-delay: calc(var(--i, 0) * 38ms); transition: border-color .15s, transform .15s, box-shadow .15s; }
.lb-row:hover { border-color: var(--accent); transform: translateX(3px); box-shadow: 0 10px 22px -14px rgba(0,0,0,.35); }
.lb-row.top { border-color: color-mix(in oklab, var(--accent) 26%, var(--rule)); }
.lb-sub-line { font-size: 12px; color: var(--ink-mute); overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.lb-bar i { background: linear-gradient(90deg, color-mix(in oklab, var(--accent) 55%, var(--paper)), var(--accent)); }
.lb-meta b { display: inline-flex; align-items: baseline; }
.lb-meta .cur { font-size: .68em; opacity: .7; margin-right: 1px; }

/* ---- Genre champions: cover-led cards ---- */
.lb-champ { display: flex; gap: 14px; align-items: center; animation: lbrise .5s cubic-bezier(.2,.7,.2,1) backwards; animation-delay: calc(var(--i, 0) * 48ms); }
.lb-champ-cover { flex: none; border-radius: 6px; overflow: hidden; box-shadow: 0 10px 22px -12px rgba(0,0,0,.42); }
.lb-champ-body { flex: 1; min-width: 0; }
.lb-champ-name { font-size: 18px; margin: 4px 0 0; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.lb-champ-val { font-family: var(--sans, system-ui); font-weight: 800; font-size: 21px; letter-spacing: -.02em; margin-top: 2px; }
.lb-champ-val .cur { font-size: .68em; opacity: .7; margin-right: 1px; }
.lb-champ-tag { display: inline-flex; align-items: center; gap: 6px; color: #b8860b; margin-top: 8px; }
.lb-champ-tag svg { color: #caa53d; flex: none; }

/* ---- Rarest finds: cover gallery ---- */
.lb-rare-grid { display: grid; grid-template-columns: repeat(auto-fill, 150px); justify-content: center; gap: 16px; }
.lb-rare-card {
  position: relative; display: flex; flex-direction: column; text-align: left; width: 150px;
  background: #fff; border: 1px solid var(--rule); border-radius: 12px; overflow: hidden;
  padding: 0 0 12px; cursor: pointer; transition: transform .2s, box-shadow .2s, border-color .2s;
  animation: lbrise .5s cubic-bezier(.2,.7,.2,1) backwards; animation-delay: calc(var(--i, 0) * 42ms);
}
.lb-rare-card:hover { transform: translateY(-4px); box-shadow: 0 20px 38px -18px rgba(0,0,0,.32); border-color: var(--accent); }
.lb-rare-card.top { border-color: #caa53d; box-shadow: 0 0 0 1px #caa53d inset; }
.lb-rare-rank {
  position: absolute; top: 8px; left: 8px; width: 24px; height: 24px; border-radius: 50%;
  background: rgba(20,17,13,.78); color: #fff; font-weight: 700; font-size: 12px;
  display: flex; align-items: center; justify-content: center; backdrop-filter: blur(2px); z-index: 2;
}
.lb-rare-card.top .lb-rare-rank { background: #caa53d; }
.lb-rare-v {
  position: absolute; top: 8px; right: 8px; z-index: 2;
  background: rgba(20,17,13,.8); color: #fff; font-weight: 800; font-size: 13px;
  padding: 3px 9px; border-radius: 20px; backdrop-filter: blur(2px);
}
.lb-rare-v .cur { font-size: .8em; opacity: .85; margin-right: 1px; }
.lb-rare-body { padding: 10px 12px 0; min-width: 0; display: flex; flex-direction: column; gap: 1px; }
.lb-rare-body .lb-rare-t { font-weight: 600; font-size: 13px; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.lb-rare-body .lb-rare-a { font-size: 12px; color: var(--ink-mute); overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.lb-rare-owner { font-size: 11px; color: var(--ink-mute); overflow: hidden; text-overflow: ellipsis; white-space: nowrap; margin-top: 2px; }

@media (prefers-reduced-motion: reduce) {
  .lb-row, .lb-champ, .lb-rare-card { animation: none; }
  .lb-pod-shine { animation: none; display: none; }
}
