/* ═══════════════════════════════════════════════════════════
   The Creator System — site chrome
   Tokens, global reset, header/footer, reusable primitives.
   Page-specific layout rules live in each page's own CSS.
   ═══════════════════════════════════════════════════════════ */

:root{
  --cream:     #F6F2E8;
  --cream-2:   #EEE8D8;
  --ink:       #111111;
  --ink-2:     #2A2A2A;
  --mute:      #6F665A;
  --rule:      #CDC4B0;
  --pink:      #E63E7F;
  --pink-soft: #F5C9D9;
  --char:      #15130F;

  --serif: "Playfair Display","EB Garamond",Georgia,serif;
  --sans:  "Inter","Helvetica Neue",Arial,sans-serif;
  --mono:  "IBM Plex Mono","JetBrains Mono",Menlo,monospace;
}

/* Reset — scoped to common elements, gentle so it doesn't
   collide with inline styles already present on pages. */
*,*::before,*::after{ box-sizing:border-box; }
html,body{ margin:0; padding:0; }
body{
  background: var(--cream);
  color: var(--ink);
  font-family: var(--sans);
  -webkit-font-smoothing: antialiased;
}
a{ color:inherit; }

/* ─── Global site header ──────────────────────────────────── */
.site-header{
  background: var(--cream);
  border-bottom: 1px solid var(--rule);
  padding: 1.1rem 5vw .9rem;
  font-family: var(--sans);
}
.site-header .eyebrow{
  display:flex; justify-content:space-between; align-items:center;
  font-family: var(--mono);
  font-size:.64rem; letter-spacing:.4em; text-transform:uppercase;
  color: var(--mute);
  margin-bottom: .65rem;
}
.site-header .eyebrow .dot{ color: var(--pink); }
.site-header .bar{
  display:flex; justify-content:space-between; align-items:baseline;
  gap: 1.5rem; flex-wrap: wrap;
}
.site-header .brand{
  font-family: var(--serif); font-weight: 800; font-style: italic;
  font-size: 1.35rem; letter-spacing: -.01em;
  color: var(--ink);
  text-decoration: none;
}
.site-header .brand em{ color: var(--pink); font-style: italic; }
.site-header nav{
  display:flex; gap: 1.1rem; flex-wrap: wrap;
  font-family: var(--mono);
  font-size:.66rem; letter-spacing:.32em; text-transform:uppercase;
  color: var(--ink-2);
}
.site-header nav a{
  text-decoration: none;
  padding: .25rem 0;
  border-bottom: 1px solid transparent;
  transition: border-color .15s, color .15s;
}
.site-header nav a:hover{
  color: var(--ink);
  border-bottom-color: var(--pink);
}
.site-header nav a.here{
  color: var(--pink);
  border-bottom-color: var(--pink);
}

/* ─── Global site footer ──────────────────────────────────── */
.site-footer{
  margin-top: 4rem;
  border-top: 1px solid var(--rule);
  padding: 1.6rem 5vw 2.2rem;
  font-family: var(--mono);
  font-size:.62rem; letter-spacing:.32em; text-transform:uppercase;
  color: var(--mute);
  display: flex; justify-content: space-between; gap: 1rem;
  flex-wrap: wrap;
}
.site-footer a{ text-decoration:none; border-bottom:1px solid transparent; }
.site-footer a:hover{ color: var(--ink); border-bottom-color: var(--pink); }

/* ─── Layout wrapper ──────────────────────────────────────── */
.wrap{ max-width: 1200px; margin: 0 auto; padding: 0 5vw; }
.wrap--reading{ max-width: 880px; }

/* ─── Reusable primitives ─────────────────────────────────── */
.kicker{
  font-family: var(--mono);
  font-size:.68rem; letter-spacing:.38em; text-transform:uppercase;
  color: var(--mute);
}
.kicker--pink{ color: var(--pink); }

.h-display{
  font-family: var(--serif);
  font-weight: 800;
  letter-spacing: -.018em;
  line-height: .98;
}
.h-display em{ font-style: italic; font-weight: 600; color: var(--pink); }

.rule-thin{ height:1px; background: var(--rule); width:100%; border:0; }
.dot-pink{
  width:.55em; height:.55em; border-radius:50%;
  background: var(--pink); display:inline-block; vertical-align:.1em;
}

/* Deck-style content card — used on the hub grid and press index */
.deck-card{
  display:block;
  padding: 1.3rem 1.4rem 1.2rem;
  border: 1px solid var(--rule);
  background: #fff;
  position: relative;
  transition: transform .15s, box-shadow .15s, border-color .15s;
  text-decoration: none;
  color: var(--ink);
  min-height: 10rem;
}
.deck-card:hover{
  border-color: var(--pink);
  transform: translateY(-2px);
  box-shadow: 0 10px 30px rgba(0,0,0,.06);
}
.deck-card .num{
  font-family: var(--mono);
  font-size:.6rem; letter-spacing:.35em; text-transform:uppercase;
  color: var(--pink);
  margin-bottom: .5rem;
}
.deck-card .nm{
  font-family: var(--serif); font-weight: 800;
  font-size: 1.35rem; line-height: 1; letter-spacing: -.015em;
  margin-bottom: .2rem;
}
.deck-card .nm em{ font-style: italic; color: var(--pink); }
.deck-card .for{
  font-family: var(--mono);
  font-size:.6rem; letter-spacing:.3em; text-transform:uppercase;
  color: var(--mute);
  margin-bottom: .7rem;
}
.deck-card .dc{
  font-size:.84rem; line-height: 1.5;
  color: var(--ink-2);
  margin-bottom: .9rem;
  padding-bottom: .7rem;
  border-bottom: 1px solid var(--rule);
}
.deck-card .cta{
  display:flex; justify-content:space-between; align-items:center;
  font-family: var(--mono);
  font-size:.65rem; letter-spacing:.3em; text-transform:uppercase;
}
.deck-card .cta .arr{
  color: var(--pink);
  font-family: var(--serif); font-style: italic;
  font-size: 1rem; letter-spacing: 0;
}

/* ─── Page hero (used on artist/business/speaker/etc.) ────── */
.page-hero{
  padding: 4rem 5vw 2rem;
  max-width: 1200px; margin: 0 auto;
}
.page-hero .kicker{ margin-bottom: 1rem; }
.page-hero .h-display{
  font-size: clamp(2.6rem, 6vw, 4.8rem);
  max-width: 18ch;
  margin-bottom: 1.1rem;
}
.page-hero .lede{
  font-family: var(--serif); font-style: italic;
  font-size: 1.2rem; line-height: 1.55;
  color: var(--ink-2);
  max-width: 34em;
}

/* ─── Responsive ──────────────────────────────────────────── */
@media (max-width: 760px){
  .site-header{ padding: .9rem 5vw .7rem; }
  .site-header .eyebrow{ font-size:.6rem; letter-spacing:.3em; }
  .site-header nav{ gap: .75rem; font-size:.6rem; letter-spacing:.25em; }
  .site-header .brand{ font-size: 1.1rem; }
  .site-footer{ padding: 1.2rem 5vw 2rem; font-size:.58rem; letter-spacing:.24em; }
}
