/* ============================================================================
   Curio — home page (the cabinet's front door)
   ----------------------------------------------------------------------------
   The "reading / framing" surface: editorial, dark, generous. Built on the
   shared design tokens (tokens.css). Masthead, hero, a featured curio, and the
   cabinet grid.
   ========================================================================== */

html, body { margin: 0; }
body.curio-collection {
  background: var(--bg);
  color: var(--fg-1);
  font-family: var(--font-ui);
  /* faint observatory glow on the page itself */
  background-image: radial-gradient(1200px 720px at 78% -8%, rgba(217, 164, 65, 0.06), transparent 62%);
  min-height: 100vh;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}
*, *::before, *::after { box-sizing: border-box; }

.wrap { max-width: 1080px; margin: 0 auto; padding: 0 32px; }

/* ---- Top bar ----------------------------------------------------------- */
.topbar { display: flex; align-items: center; justify-content: space-between; padding: 24px 0 0; }
.brand { display: flex; align-items: center; gap: 11px; }
.brand img { width: 28px; height: 28px; }
.brand .word { font-family: var(--font-display); font-weight: 600; font-size: 22px; letter-spacing: -0.01em; }
.brand .word .dot { color: var(--brass); }
.topmeta { display: flex; align-items: center; gap: 22px; font-size: 12.5px; color: var(--fg-3); }

/* ---- Hero -------------------------------------------------------------- */
.hero { padding: 86px 0 64px; max-width: 760px; }
.hero .eyebrow { font-size: 11px; font-weight: 600; letter-spacing: 0.18em; text-transform: uppercase; color: var(--brass); margin-bottom: 22px; }
.hero h1 { font-family: var(--font-display); font-weight: 500; font-size: 58px; line-height: 1.05; letter-spacing: -0.018em; margin: 0; color: var(--fg-1); }
.hero h1 em { font-style: italic; color: var(--brass-bright); }
.hero .lede { font-family: var(--font-display); font-weight: 400; font-size: 19px; line-height: 1.6; color: #c2ccd9; margin: 24px 0 0; max-width: 620px; }

/* ---- Section label ----------------------------------------------------- */
.section-head { display: flex; align-items: baseline; justify-content: space-between; margin: 18px 0 18px; padding-bottom: 14px; border-bottom: 1px solid var(--line); }
.section-head .lbl { font-size: 11px; font-weight: 600; letter-spacing: 0.16em; text-transform: uppercase; color: var(--fg-3); }
.section-head .count { font-family: var(--font-mono); font-size: 11.5px; color: var(--fg-4); }

/* ---- Featured ---------------------------------------------------------- */
.featured { display: grid; grid-template-columns: 1.15fr 1fr; gap: 0; background: var(--surface-2); border: 1px solid var(--line); border-radius: var(--r-lg); overflow: hidden; margin-bottom: 56px; transition: border-color var(--t-base) var(--ease); text-decoration: none; color: inherit; }
.featured:hover { border-color: var(--brass-line); }
.featured .preview { position: relative; min-height: 280px; background-color: var(--stage); background-image: linear-gradient(var(--line-faint) 1px, transparent 1px), linear-gradient(90deg, var(--line-faint) 1px, transparent 1px); background-size: var(--grid-size) var(--grid-size), var(--grid-size) var(--grid-size); border-right: 1px solid var(--line); }
.featured .body { padding: 34px 36px; display: flex; flex-direction: column; justify-content: center; }
.featured .cat { font-size: 10.5px; font-weight: 600; letter-spacing: 0.14em; text-transform: uppercase; color: var(--brass); margin-bottom: 13px; }
.featured h2 { font-family: var(--font-display); font-weight: 600; font-size: 32px; line-height: 1.1; letter-spacing: -0.01em; margin: 0; }
.featured .hook { font-family: var(--font-display); font-size: 17px; line-height: 1.55; color: #c2ccd9; margin: 14px 0 24px; }
.featured .hook em { font-style: italic; color: var(--fg-1); }

.open-btn { align-self: flex-start; display: inline-flex; align-items: center; gap: 8px; white-space: nowrap; font-family: var(--font-ui); font-size: 13.5px; font-weight: 600; background: var(--brass); color: var(--brass-ink); border: 1px solid var(--brass-deep); border-radius: var(--r-sm); padding: 10px 18px; text-decoration: none; transition: background var(--t-fast) var(--ease), transform var(--t-fast) var(--ease); }
.featured:hover .open-btn { background: var(--brass-bright); }
.featured:active .open-btn { transform: scale(0.985); }
.open-btn .arrow { font-size: 15px; }

/* ---- Card grid --------------------------------------------------------- */
.grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 18px; padding-bottom: 80px; }
@media (max-width: 920px) {
  .grid { grid-template-columns: repeat(2, 1fr); }
  .featured { grid-template-columns: 1fr; }
  .featured .preview { border-right: none; border-bottom: 1px solid var(--line); }
}
@media (max-width: 560px) {
  .grid { grid-template-columns: 1fr; }
  .wrap { padding: 0 22px; }
  .hero { padding: 56px 0 44px; }
  .hero h1 { font-size: 44px; }
}

.card { background: var(--surface-2); border: 1px solid var(--line); border-radius: var(--r-lg); overflow: hidden; text-decoration: none; color: inherit; display: flex; flex-direction: column; transition: border-color var(--t-base) var(--ease), transform var(--t-base) var(--ease); }
.card:hover { border-color: var(--brass-line); transform: translateY(-3px); }
.card .preview { position: relative; height: 132px; background-color: var(--stage); background-image: linear-gradient(var(--line-faint) 1px, transparent 1px), linear-gradient(90deg, var(--line-faint) 1px, transparent 1px); background-size: var(--grid-size) var(--grid-size), var(--grid-size) var(--grid-size); border-bottom: 1px solid var(--line); }
.card .body { padding: 16px 17px 17px; display: flex; flex-direction: column; flex: 1; }
.card .cat { font-size: 10px; font-weight: 600; letter-spacing: 0.13em; text-transform: uppercase; color: var(--brass); margin-bottom: 8px; }
.card h3 { font-family: var(--font-display); font-weight: 600; font-size: 19px; line-height: 1.15; letter-spacing: -0.005em; margin: 0; color: var(--fg-1); }
.card .hook { font-size: 13px; line-height: 1.5; color: var(--fg-2); margin: 7px 0 0; }
.card .meta { display: flex; align-items: center; gap: 7px; margin-top: 14px; font-size: 11px; color: var(--fg-3); }
.card .meta .dot { width: 7px; height: 7px; border-radius: var(--r-full); }
.card .meta .dot.live { background: var(--good); }
.card .meta .dot.soon { background: var(--warn); }

/* Workshop entries aren't linked yet — don't invite a click that goes nowhere. */
.card.workshop { opacity: 0.82; cursor: default; }
.card.workshop:hover { border-color: var(--line); transform: none; }

.mini-canvas { display: block; width: 100%; height: 100%; }

/* ---- Footer ------------------------------------------------------------ */
.footer { border-top: 1px solid var(--line); padding: 28px 0 48px; display: flex; align-items: center; justify-content: space-between; }
.footer .left { display: flex; align-items: center; gap: 10px; font-size: 12.5px; color: var(--fg-3); }
.footer .left img { width: 20px; height: 20px; opacity: 0.8; }
.footer .right { font-family: var(--font-mono); font-size: 11.5px; color: var(--fg-4); }

/* ---- Keyboard focus — brass ring, per the design system ---------------- */
.featured:focus-visible,
.card:focus-visible {
  outline: 2px solid var(--brass-line);
  outline-offset: 2px;
}

/* ---- Respect reduced-motion: no card lift transition ------------------- */
@media (prefers-reduced-motion: reduce) {
  .card, .featured, .open-btn { transition: none; }
  .card:hover { transform: none; }
}
