/* ── FONTS ── */
@import url('https://fonts.googleapis.com/css2?family=Playfair+Display:ital,wght@0,700;0,900;1,700&family=DM+Sans:wght@300;400;500&family=Space+Mono:wght@700&display=swap');

/* ── DESIGN TOKENS ── */
:root {
  --cream:        #F5EFE4;
  --cream-dk:     #EDE4D3;
  --slate:        #2C3E52;
  --slate-lt:     #3D5268;
  --gold:         #C8963E;
  --gold-lt:      #D9A94F;
  --rust:         #C25940;
  --rust-lt:      #D46B52;
  --blue:         #5B7FA6;
  --blue-lt:      #7296BB;
  --text:         #1E2B36;
  --muted:        #5e6e78;
  --muted-footer: #5a6871;
}

/* ── GLOBAL RESET ── */
*, *::before, *::after { box-sizing: border-box; }
html { scroll-behavior: smooth; }

body {
  background: var(--cream);
  color: var(--text);
  font-family: 'DM Sans', system-ui, sans-serif;
  font-weight: 300;
  display: flex;
  flex-direction: column;
  min-height: 100vh;
  overflow-x: hidden;
}

h1, h2, h3, h4, h5, h6 {
  font-family: 'Playfair Display', serif;
  color: var(--slate);
}

main { flex: 1; padding-top: 80px; }

/* ── SKIP LINK ── */
.skip-link {
  position: absolute; top: -100%; left: 1rem;
  background: var(--slate); color: var(--cream);
  padding: .6rem 1.2rem; font-size: .75rem; font-weight: 500;
  letter-spacing: .08em; text-decoration: none; z-index: 200;
  transition: top .15s;
}
.skip-link:focus { top: 1rem; }

/* ── NAVBAR ── */
.site-nav {
  position: fixed; top: 0; left: 0; right: 0;
  z-index: 100; background: var(--cream);
  border-bottom: 1px solid rgba(44,62,82,.12);
  padding: 0 2rem; height: 64px;
  display: flex; align-items: center;
  justify-content: space-between; gap: 1rem;
}
.nav-brand {
  display: flex; align-items: center;
  gap: .75rem; text-decoration: none;
}
.nav-monogram {
  width: 40px; height: 40px; background: var(--slate); color: var(--cream);
  display: flex; align-items: center; justify-content: center;
  font-family: 'Space Mono', monospace; font-size: .75rem;
  font-weight: 700; letter-spacing: .05em; flex-shrink: 0;
}
.nav-brand-text { line-height: 1.1; }
.nav-brand-name {
  font-family: 'Space Mono', monospace; font-size: .7rem;
  font-weight: 700; letter-spacing: .12em; text-transform: uppercase;
  color: var(--slate); display: block;
}
.nav-brand-sub {
  font-size: .6rem; letter-spacing: .15em; text-transform: uppercase;
  color: var(--gold); display: block;
}
.nav-links {
  display: flex; align-items: center; gap: .25rem;
  list-style: none; margin: 0; padding: 0;
}
.nav-links a {
  font-family: 'DM Sans', sans-serif;
  font-size: .65rem; font-weight: 500; letter-spacing: .14em;
  text-transform: uppercase; color: var(--slate); text-decoration: none;
  padding: .4rem .6rem; transition: color .2s;
}
.nav-links a:hover, .nav-links a.active { color: var(--gold); }
.nav-accent-dots { display: flex; gap: 4px; align-items: center; }
.nav-dot-sq  { width: 18px; height: 18px; border-radius: 3px; }
.nav-dot-rect { width: 30px; height: 18px; border-radius: 3px; }
.nav-toggle {
  display: none; background: none; border: none;
  cursor: pointer; padding: 6px;
}
.nav-toggle span {
  display: block; width: 22px; height: 2px;
  background: var(--slate); margin: 5px 0; transition: .3s;
}
.mobile-menu {
  display: none; position: fixed; top: 64px; left: 0; right: 0;
  background: var(--cream); border-bottom: 1px solid rgba(44,62,82,.12);
  padding: 1rem 2rem 1.5rem; z-index: 99;
}
.mobile-menu.open { display: block; }
.mobile-menu a {
  display: block; font-family: 'DM Sans', sans-serif;
  font-size: .7rem; letter-spacing: .14em;
  text-transform: uppercase; color: var(--slate); text-decoration: none;
  padding: .5rem 0; border-bottom: 1px solid var(--cream-dk);
}
.mobile-menu a:last-child { border-bottom: none; }

/* ── HERO (index.html) ── */
.hero {
  padding-top: 0; min-height: 100vh;
  display: grid; grid-template-columns: 1fr 1fr;
  align-items: center; gap: 0;
  max-width: 1200px; margin: 0 auto;
  padding-left: 2rem; padding-right: 2rem;
}
.hero-left { padding: 2rem 3rem 4rem 0; animation: fadeUp .8s ease both; }
.hero-eyebrow {
  display: inline-flex; align-items: center; gap: .5rem;
  font-family: 'DM Sans', sans-serif; font-size: .65rem;
  letter-spacing: .2em; text-transform: uppercase;
  color: var(--gold); font-weight: 500; margin-bottom: 1.25rem;
}
.hero-eyebrow::before {
  content: ''; display: block; width: 28px; height: 2px; background: var(--gold);
}
.hero-headline {
  font-family: 'Playfair Display', serif;
  font-size: clamp(2.8rem, 5vw, 4.5rem); font-weight: 900;
  line-height: 1.05; color: var(--slate); margin-bottom: 1.5rem; letter-spacing: -.02em;
}
.hero-headline em { font-style: normal; color: var(--rust); }
.hero-divider { display: flex; align-items: center; gap: .5rem; margin-bottom: 1.5rem; }
.hero-divider-line {
  flex: 1; height: 1px;
  background: linear-gradient(to right, var(--gold), transparent); max-width: 120px;
}
.hero-divider-dot { width: 6px; height: 6px; border-radius: 50%; background: var(--gold); }
.hero-lead {
  font-size: 1rem; line-height: 1.7; color: var(--text);
  margin-bottom: 1rem; font-weight: 400; max-width: 480px;
}
.hero-body {
  font-size: .9rem; line-height: 1.7; color: var(--muted);
  margin-bottom: 2rem; max-width: 480px;
}
.hero-ctas { display: flex; gap: .75rem; flex-wrap: wrap; margin-bottom: 2rem; }
.btn-primary-ap {
  background: var(--slate); color: var(--cream); border: none;
  padding: .75rem 1.75rem; font-family: 'DM Sans', sans-serif;
  font-size: .7rem; letter-spacing: .14em; text-transform: uppercase;
  font-weight: 500; text-decoration: none;
  display: inline-flex; align-items: center; gap: .5rem;
  transition: background .2s, transform .15s;
}
.btn-primary-ap:hover { background: var(--slate-lt); color: var(--cream); transform: translateY(-1px); }
.btn-outline-ap {
  background: transparent; color: var(--gold);
  border: 1.5px solid var(--gold); padding: .75rem 1.75rem;
  font-family: 'DM Sans', sans-serif; font-size: .7rem;
  letter-spacing: .14em; text-transform: uppercase; font-weight: 500;
  text-decoration: none; display: inline-flex; align-items: center; gap: .5rem;
  transition: background .2s, color .2s, transform .15s;
}
.btn-outline-ap:hover { background: var(--gold); color: var(--cream); transform: translateY(-1px); }
.hero-meta { display: flex; gap: 1.5rem; flex-wrap: wrap; }
.hero-meta a {
  font-family: 'DM Sans', sans-serif; font-size: .72rem; color: var(--muted);
  text-decoration: none; display: flex; align-items: center; gap: .35rem;
  transition: color .2s; letter-spacing: .04em;
}
.hero-meta a:hover { color: var(--gold); }
.hero-right { position: relative; height: 560px; animation: fadeUp .8s .15s ease both; }
.hero-photo {
  position: absolute; top: 60px; left: 20px;
  width: 310px; height: 420px; object-fit: cover;
  object-position: top center; z-index: 2;
}
.color-block { position: absolute; border-radius: 0 28px 0 0; }
.cb-gold  { width: 150px; height: 128px; background: var(--gold); top: 50px;  right: 16px; }
.cb-blue  { width: 150px; height: 108px; background: var(--blue); top: 193px; right: 16px; }
.cb-rust  { width: 150px; height: 128px; background: var(--rust); top: 316px; right: 16px; }
.cb-cream-dk {
  position: absolute; width: 310px; height: 420px;
  background: var(--cream-dk); top: 75px; left: 32px; z-index: 1;
}

/* ── SECTION HEADERS ── */
.section-outer { border-top: 1px solid rgba(44,62,82,.08); }
.section-header { display: flex; align-items: center; gap: 1rem; margin-bottom: 2rem; }
.section-label {
  font-family: 'Space Mono', monospace; font-size: .85rem;
  letter-spacing: .2em; text-transform: uppercase; color: var(--blue);
  font-weight: 700; white-space: nowrap; margin: 0; padding: 0; line-height: 1;
}
.section-rule { flex: 1; height: 1px; background: linear-gradient(to right, var(--blue), transparent); }
.section-dot { width: 8px; height: 8px; border-radius: 50%; background: var(--blue); flex-shrink: 0; }

/* ── FEATURED WORK GRID (index.html) ── */
.featured-section { background: var(--cream); padding: 5rem 2rem; max-width: 1200px; margin: 0 auto; }
.work-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1.5rem; }
.work-card {
  background: white; border: 1px solid rgba(44,62,82,.08); overflow: hidden;
  display: flex; flex-direction: column; transition: transform .2s, box-shadow .2s; position: relative;
}
.work-card::before {
  content: ''; position: absolute; top: 0; left: 0;
  width: 3px; height: 100%; background: var(--gold); opacity: 0; transition: opacity .2s;
}
.work-card:hover { transform: translateY(-3px); box-shadow: 0 12px 40px rgba(44,62,82,.10); }
.work-card:hover::before { opacity: 1; }
.work-card-img { width: 100%; height: 200px; object-fit: cover; display: block; background: var(--cream-dk); }
.work-card-img-placeholder {
  width: 100%; height: 200px; background: var(--cream-dk);
  display: none; align-items: center; justify-content: center;
  color: var(--muted); font-size: .7rem; letter-spacing: .1em; text-transform: uppercase;
}
.work-card-body { padding: 1.5rem; display: flex; flex-direction: column; flex: 1; }
.work-card-tags { display: flex; gap: .4rem; flex-wrap: wrap; margin-bottom: .75rem; }
.work-card-org { font-size: .65rem; letter-spacing: .08em; color: var(--muted); margin-bottom: .75rem; }
.work-card-title {
  font-family: 'Playfair Display', serif; font-size: 1.15rem;
  font-weight: 700; color: var(--slate); margin-bottom: .75rem; line-height: 1.3;
}
.work-card-text { font-size: .85rem; line-height: 1.65; color: var(--muted); flex: 1; margin-bottom: 1.25rem; }
.work-card-link {
  font-family: 'DM Sans', sans-serif; font-size: .65rem; letter-spacing: .14em;
  text-transform: uppercase; color: var(--gold); text-decoration: none; font-weight: 500;
  display: inline-flex; align-items: center; gap: .4rem; transition: gap .2s, color .2s;
}
.work-card-link:hover { gap: .7rem; color: var(--rust); }

/* ── MORE WORK (index.html) ── */
.more-section { padding: 3.5rem 2rem; max-width: 1200px; margin: 0 auto; }
.more-pills { display: flex; gap: .6rem; flex-wrap: wrap; margin-top: 1.25rem; }
.pill {
  font-family: 'DM Sans', sans-serif; font-size: .65rem; letter-spacing: .12em;
  text-transform: uppercase; font-weight: 500; color: var(--slate);
  border: 1.5px solid rgba(44,62,82,.2); padding: .55rem 1.1rem;
  text-decoration: none; display: inline-flex; align-items: center; gap: .4rem;
  transition: border-color .2s, color .2s, background .2s;
}
.pill:hover { border-color: var(--gold); color: var(--gold); background: rgba(200,150,62,.05); }

/* ── TAGS ── */
.tag {
  font-family: 'DM Sans', sans-serif; font-size: .58rem; letter-spacing: .1em;
  text-transform: uppercase; font-weight: 500; padding: .25rem .6rem;
  background: var(--cream-dk); color: var(--slate);
}
.tag-gold { background: rgba(200,150,62,.12); color: var(--gold); }
.tag-rust { background: rgba(194,89,64,.10); color: var(--rust); }
.tag-blue { background: rgba(91,127,166,.10); color: var(--blue); }
.tag-purple { background: rgba(130,90,180,.10); color: #7a52b8; }
.tag-green { background: rgba(60,140,90,.10); color: #3a8a58; }

/* ── DETAIL PAGE HEADER ── */
.back-link {
  font-family: 'DM Sans', sans-serif; font-size: .72rem; letter-spacing: .08em;
  color: var(--muted); text-decoration: none; display: inline-flex;
  align-items: center; gap: .35rem; transition: color .2s; margin-bottom: 1rem;
}
.back-link:hover { color: var(--gold); }
.page-header {
  padding: 2rem 0 1.5rem; border-bottom: 1px solid rgba(44,62,82,.10); margin-bottom: 2.5rem;
}
.page-header h1 {
  font-family: 'Playfair Display', serif;
  font-size: clamp(1.6rem, 3vw, 2.4rem); font-weight: 700;
  color: var(--slate); line-height: 1.15; margin-bottom: .75rem;
}
.page-meta {
  font-family: 'DM Sans', sans-serif; font-size: .72rem; color: var(--muted);
  letter-spacing: .06em; display: flex; align-items: center; gap: .5rem; flex-wrap: wrap;
}
.tag-pill {
  font-family: 'DM Sans', sans-serif; font-size: .58rem; letter-spacing: .1em;
  text-transform: uppercase; font-weight: 500; padding: .25rem .6rem;
  background: rgba(200,150,62,.12); color: var(--gold); border-radius: 0;
}

/* ── PROJECT STATS SIDEBAR ── */
.project-stats {
  background: white; border: 1px solid rgba(44,62,82,.08);
  border-left: 3px solid var(--gold); padding: 1.5rem; border-radius: 0;
}
.project-stats h6 {
  font-family: 'Space Mono', monospace; font-size: .75rem; letter-spacing: .18em;
  text-transform: uppercase; color: var(--blue); font-weight: 700; margin-bottom: .75rem;
}
.project-stats p, .project-stats li {
  font-family: 'DM Sans', sans-serif; font-size: .85rem; color: var(--muted);
  line-height: 1.6; margin-bottom: .25rem;
}
.project-stats hr { border-color: rgba(44,62,82,.10); }

/* ── PROJECT BODY ── */
.project-body { color: var(--text); }
.project-body p { font-size: .95rem; line-height: 1.75; margin-bottom: 1rem; }
.project-body ul, .project-body ol {
  font-size: .95rem; line-height: 1.75; padding-left: 1.25rem; margin-bottom: 1rem;
}
.project-body li { margin-bottom: .25rem; }
.project-body h2 {
  font-family: 'Playfair Display', serif; font-size: 1.5rem; font-weight: 700;
  color: var(--slate); margin-top: 2.5rem; margin-bottom: 1rem;
  padding-bottom: .5rem; border-bottom: 1px solid rgba(44,62,82,.08);
  scroll-margin-top: 130px;
}
.project-body h3 {
  font-family: 'DM Sans', sans-serif; font-size: 1rem; font-weight: 500;
  color: var(--slate); margin-top: 1.5rem; margin-bottom: .5rem; letter-spacing: .02em;
}
.project-body strong { color: var(--slate); font-weight: 500; }
figcaption, .figure-caption,
p.text-muted.small.fst-italic { font-size: 0.72rem; }
.project-body a:not(.btn-primary-ap):not(.btn-outline-ap), .article-body a:not(.btn-primary-ap):not(.btn-outline-ap),
.card-text a:not(.btn-primary-ap):not(.btn-outline-ap), .accordion-body a:not(.btn-primary-ap):not(.btn-outline-ap),
.figure-caption a:not(.btn-primary-ap):not(.btn-outline-ap), .list-group-item a:not(.btn-primary-ap):not(.btn-outline-ap) {
  color: var(--slate);
  text-decoration: underline;
  text-decoration-color: rgba(44, 62, 82, 0.3);
  text-underline-offset: 3px;
  transition: text-decoration-color 0.2s;
}
.project-body a:not(.btn-primary-ap):not(.btn-outline-ap):hover, .article-body a:not(.btn-primary-ap):not(.btn-outline-ap):hover,
.card-text a:not(.btn-primary-ap):not(.btn-outline-ap):hover, .accordion-body a:not(.btn-primary-ap):not(.btn-outline-ap):hover,
.figure-caption a:not(.btn-primary-ap):not(.btn-outline-ap):hover, .list-group-item a:not(.btn-primary-ap):not(.btn-outline-ap):hover {
  color: var(--slate);
  text-decoration-color: var(--gold);
}

/* ── PERSONA TABS ── */
.persona-tabs .nav-link {
  font-family: 'DM Sans', sans-serif; font-size: .7rem; letter-spacing: .08em;
  text-transform: uppercase; font-weight: 500; color: var(--slate);
  background: transparent; border: 1.5px solid rgba(44,62,82,.15);
  border-radius: 0; padding: .4rem .9rem; transition: all .2s;
}
.persona-tabs .nav-link:hover { border-color: var(--gold); color: var(--gold); }
.persona-tabs .nav-link.active {
  background: var(--slate); color: var(--cream); border-color: var(--slate);
}
.tab-content.bg-body-tertiary {
  background: white !important; border: 1px solid rgba(44,62,82,.08);
}
.tab-content h5 { font-family: 'Playfair Display', serif; color: var(--slate); font-size: 1.1rem; }

/* ── STICKY TOC ── */
.toc-bar {
  position: sticky; top: 64px; z-index: 50;
  background: white; border-top: 2px solid var(--blue);
  border-bottom: 1px solid rgba(44,62,82,.10);
  box-shadow: 0 2px 8px rgba(44,62,82,.06); margin-bottom: 2rem;
}
.toc-collapsed {
  display: flex; flex-direction: column; gap: .2rem;
  padding: .55rem 1rem; cursor: pointer; user-select: none;
}
.toc-top-row { display: flex; align-items: center; justify-content: space-between; }
.toc-eyebrow {
  font-family: 'Space Mono', monospace; font-size: .58rem;
  font-weight: 700; letter-spacing: .18em; text-transform: uppercase; color: var(--blue);
}
.toc-current {
  font-family: 'DM Sans', sans-serif; font-size: .82rem; font-weight: 500;
  color: var(--slate); white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
.toc-toggle {
  background: none; border: none; cursor: pointer; padding: 2px;
  color: var(--muted); display: flex; align-items: center;
  transition: color .2s; flex-shrink: 0;
}
.toc-toggle:hover { color: var(--gold); }
.toc-toggle svg { transition: transform .25s ease; }
.toc-bar.open .toc-toggle svg { transform: rotate(180deg); }
.toc-dropdown {
  display: none; border-top: 1px solid rgba(44,62,82,.08); padding: .5rem 0 .75rem;
}
.toc-bar.open .toc-dropdown { display: block; }
.toc-dropdown ol { list-style: none; margin: 0; padding: 0; counter-reset: toc; }
.toc-dropdown li { counter-increment: toc; }
.toc-dropdown a {
  font-family: 'DM Sans', sans-serif; display: flex; align-items: baseline;
  gap: .65rem; padding: .35rem 1rem; font-size: .8rem; color: var(--muted);
  text-decoration: none; transition: background .15s, color .15s;
}
.toc-dropdown a::before {
  content: counter(toc, decimal-leading-zero); font-family: 'Space Mono', monospace;
  font-size: .58rem; color: var(--muted); flex-shrink: 0;
}
.toc-dropdown a:hover { background: rgba(44,62,82,.04); color: var(--slate); }
.toc-dropdown a.active { color: var(--gold); font-weight: 500; }
.toc-dropdown a.active::before { color: var(--gold); }

/* ── FILTER BAR (lxd.html) ── */
.filter-bar { display: flex; flex-wrap: wrap; gap: .5rem; justify-content: center; margin-bottom: 1.5rem; }
.filter-bar .btn {
  border-radius: 0; font-family: 'DM Sans', sans-serif; font-size: .65rem;
  font-weight: 500; letter-spacing: .1em; text-transform: uppercase;
}
.filter-bar .btn-primary {
  background: var(--gold) !important; border-color: var(--gold) !important;
  color: var(--slate) !important;
}
.filter-bar .btn-primary:hover, .filter-bar .btn-primary:focus {
  background: var(--gold-lt) !important; border-color: var(--gold-lt) !important;
}
.filter-bar .btn-outline-secondary {
  color: var(--slate) !important; border-color: rgba(44,62,82,.3) !important;
  background: transparent !important;
}
.filter-bar .btn-outline-secondary:hover {
  background: rgba(44,62,82,.05) !important; border-color: var(--slate) !important;
}

/* ── LXD CARD OVERRIDES ── */
.card { border-color: rgba(44,62,82,.10); background: white; }
.card .card-title { font-family: 'Playfair Display', serif; font-weight: 700; color: var(--slate); }
.card .list-group-item { border-color: rgba(44,62,82,.08); background: transparent; }
.card-col--hidden { display: none !important; }

/* ── BOOTSTRAP BUTTON OVERRIDES ── */
.btn-primary {
  --bs-btn-bg: var(--slate);
  --bs-btn-border-color: var(--slate);
  --bs-btn-hover-bg: var(--slate-lt);
  --bs-btn-hover-border-color: var(--slate-lt);
  --bs-btn-active-bg: var(--slate);
  --bs-btn-active-border-color: var(--slate);
  --bs-btn-focus-shadow-rgb: 44, 62, 82;
  color: var(--cream);
}
.btn-outline-primary {
  --bs-btn-color: var(--gold);
  --bs-btn-border-color: var(--gold);
  --bs-btn-hover-bg: var(--gold);
  --bs-btn-hover-border-color: var(--gold);
  --bs-btn-hover-color: white;
  --bs-btn-active-bg: var(--gold-lt);
  --bs-btn-active-border-color: var(--gold-lt);
}
.btn-info {
  --bs-btn-bg: var(--blue);
  --bs-btn-border-color: var(--blue);
  --bs-btn-hover-bg: var(--blue-lt);
  --bs-btn-hover-border-color: var(--blue-lt);
  --bs-btn-color: white;
  --bs-btn-hover-color: white;
}
.btn-outline-secondary {
  --bs-btn-color: var(--slate);
  --bs-btn-border-color: rgba(44,62,82,.3);
  --bs-btn-hover-bg: rgba(44,62,82,.08);
  --bs-btn-hover-border-color: var(--slate);
  --bs-btn-hover-color: var(--slate);
}

/* Bootstrap badge */
.badge.bg-secondary {
  background-color: rgba(44,62,82,.12) !important;
  color: var(--slate) !important;
  font-family: 'DM Sans', sans-serif;
}

/* Bootstrap alert */
.alert-info {
  background-color: rgba(91,127,166,.1);
  border-color: rgba(91,127,166,.2);
  color: var(--slate);
}
.alert-info a { color: var(--gold); }

/* Bootstrap modal header */
.modal-content { background: var(--cream); }
.modal-header { border-bottom-color: rgba(44,62,82,.10); }

/* ── SECTION PAGE HEADERS (lxd.html, games.html, etc.) ── */
.section-page-intro {
  padding: 3rem 0 2rem; text-align: center;
}
.section-page-intro h1 {
  font-family: 'Playfair Display', serif;
  font-size: clamp(2rem, 4vw, 3rem); font-weight: 700;
  color: var(--slate); margin-bottom: 1rem;
}
.section-page-intro p { color: var(--muted); font-size: 1rem; line-height: 1.7; margin-bottom: 0; max-width: 560px; margin-left: auto; margin-right: auto; }

/* bg overrides for album sections */
.album, .bg-body-tertiary { background-color: var(--cream) !important; }
.bg-light { background-color: var(--cream-dk) !important; }

/* ── GAMES PAGE ── */
.games-section-label {
  font-family: 'Space Mono', monospace; font-size: 0.65rem; font-weight: 700;
  letter-spacing: 0.18em; text-transform: uppercase; color: var(--muted);
  margin-bottom: 1.25rem; padding-bottom: 0.5rem;
  border-bottom: 1px solid rgba(44,62,82,.10);
}
.rating-badge {
  display: inline-flex; align-items: center; gap: 0.5rem;
  background: rgba(46,125,50,.08); color: #2e7d32;
  border: 1px solid rgba(46,125,50,.2);
  padding: 0.3rem 0.75rem; font-family: 'DM Sans', sans-serif;
  font-size: 0.8rem; font-weight: 600; letter-spacing: 0.02em;
}
.roles-grid {
  display: grid; grid-template-columns: repeat(auto-fill, minmax(200px, 1fr)); gap: 1rem;
}
.role-card {
  background: white; border: 1px solid rgba(44,62,82,.10); padding: 1rem 1.125rem;
}
.role-card-title {
  font-family: 'Space Mono', monospace; font-size: 0.62rem; font-weight: 700;
  letter-spacing: 0.1em; text-transform: uppercase; color: var(--blue); margin-bottom: 0.375rem;
}
.role-card-desc {
  font-family: 'DM Sans', sans-serif; font-size: 0.85rem; color: var(--muted); line-height: 1.55;
}
.games-aside {
  background: white; border-left: 3px solid rgba(44,62,82,.15);
  padding: 1rem 1.25rem; font-family: 'DM Sans', sans-serif;
  font-size: 0.9rem; color: var(--muted); line-height: 1.65;
}
.games-meta { border-collapse: collapse; width: 100%; }
.games-meta td { padding: 0.375rem 0; vertical-align: top; font-family: 'DM Sans', sans-serif; }
.games-meta td:first-child {
  color: var(--muted); font-size: 0.72rem; text-transform: uppercase;
  letter-spacing: 0.08em; width: 130px; padding-right: 1rem;
}
.games-meta td:last-child { color: var(--text); font-size: 0.875rem; }
.review-card {
  background: white; border: 1px solid rgba(44,62,82,.10);
  padding: 1.25rem; display: flex; flex-direction: column; gap: 0.5rem;
}
.review-thumb { color: #2e7d32; font-size: 0.85rem; }
.review-text {
  font-family: 'Playfair Display', serif; font-size: 0.95rem;
  color: var(--slate); line-height: 1.6; font-style: italic; flex: 1;
}
.review-attribution {
  font-family: 'DM Sans', sans-serif; font-size: 0.72rem;
  color: var(--muted); text-transform: uppercase; letter-spacing: 0.08em;
}
.review-placeholder {
  background: var(--cream); border: 1px dashed rgba(44,62,80,.2);
  padding: 1.25rem; font-family: 'DM Sans', sans-serif;
  font-size: 0.82rem; color: var(--muted); font-style: italic; line-height: 1.5;
}

/* ── WRITING INDEX CARDS ── */
.writing-card {
  border-left: 3px solid var(--gold) !important;
  border-radius: 0 !important;
  background: white !important;
}
.writing-card h2 a { color: var(--slate); }
.writing-card h2 a:hover { color: var(--gold); }

/* ── ARTICLE BODY (writing pages) ── */
.article-body {
  max-width: 680px; margin: 0 auto; line-height: 1.75; font-size: 1.05rem; color: var(--text);
}
.article-body p, .article-body li { margin-bottom: 1rem; }
.article-body h2 {
  font-family: 'Playfair Display', serif; color: var(--slate);
  margin-top: 2.5rem; margin-bottom: 1rem; scroll-margin-top: 130px;
}

/* ── CONNECT STRIP ── */
.connect-strip { background: var(--slate); padding: 3rem 2rem; text-align: center; }
.connect-strip h3 {
  font-family: 'Space Mono', monospace; font-size: .7rem; letter-spacing: .2em;
  text-transform: uppercase; color: var(--gold); margin-bottom: 1rem;
}
.connect-icons { display: flex; justify-content: center; gap: 1rem; }
.connect-icon {
  width: 44px; height: 44px; border: 1.5px solid rgba(245,239,228,.2);
  display: flex; align-items: center; justify-content: center;
  color: var(--cream); text-decoration: none; font-size: 1rem;
  transition: border-color .2s, color .2s, background .2s;
}
.connect-icon:hover { border-color: var(--gold); color: var(--gold); background: rgba(200,150,62,.08); }

/* ── COLOR BAR ── */
.color-bar { height: 10px; display: flex; }

/* ── FOOTER ── */
footer {
  background: var(--cream-dk); padding: 1.25rem 2rem; text-align: center;
}
footer p {
  font-family: 'DM Sans', sans-serif; font-size: .65rem; letter-spacing: .1em;
  text-transform: uppercase; color: var(--muted-footer); margin: 0;
}

/* ── ANIMATIONS ── */
@keyframes fadeUp {
  from { opacity: 0; transform: translateY(24px); }
  to   { opacity: 1; transform: translateY(0); }
}
.fade-in   { animation: fadeUp .7s ease both; }
.fade-in-2 { animation: fadeUp .7s .1s ease both; }
.fade-in-3 { animation: fadeUp .7s .2s ease both; }
.fade-in-4 { animation: fadeUp .7s .3s ease both; }

/* ── FOCUS STATES ── */
:focus-visible { outline: 2.5px solid var(--gold); outline-offset: 3px; }

/* ── REDUCED MOTION ── */
@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after {
    animation-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.01ms !important;
  }
  html { scroll-behavior: auto; }
}

/* ── RESPONSIVE ── */
@media (max-width: 900px) {
  .nav-links, .nav-accent-dots { display: none; }
  .nav-toggle { display: block; }
  .hero { grid-template-columns: 1fr; min-height: auto; padding-top: 14px; }
  .hero-left { padding: 1.5rem 0 1rem; }
  .hero-right { height: 340px; margin-bottom: 2rem; }
  .hero-photo { width: 220px; height: 280px; top: 30px; left: 20px; }
  .cb-gold { width: 110px; height: 90px; top: 20px; right: 10px; }
  .cb-blue { width: 110px; height: 75px; top: 122px; right: 10px; }
  .cb-rust { width: 110px; height: 90px; top: 210px; right: 10px; }
  .cb-cream-dk { width: 220px; height: 280px; top: 42px; left: 32px; }
  .work-grid { grid-template-columns: 1fr 1fr; }
  .featured-section, .more-section { padding-left: 1rem; padding-right: 1rem; }
}

@media (max-width: 600px) {
  .work-grid { grid-template-columns: 1fr; }
}

@media (max-width: 540px) {
  .hero-headline { font-size: 2.3rem; }
  .hero-ctas { flex-direction: column; }
  .btn-primary-ap, .btn-outline-ap { text-align: center; justify-content: center; }
}
