/* ============================================================
   Foxie.css  –  Jess / Foxie personal site
   Dark theme · system-ui base · CSS custom properties
   ============================================================ */

/* ── 1. DESIGN TOKENS ───────────────────────────────────────── */
:root {
  /* Colours */
  --clr-bg:          #1e1e1e;
  --clr-bg-card:     #2a2a2a;
  --clr-bg-nav:      #141414;
  --clr-text:        #e8e8e8;
  --clr-text-muted:  #888888;
  --clr-text-dark:   #0d0d0d;
  --clr-accent:      #f5f5f5;
  --clr-border:      #383838;
  --clr-btn-primary-bg:   #e8e8e8;
  --clr-btn-primary-text: #0d0d0d;

  /* Accent trio */
  --clr-accent-white: #f5f5f5;
  --clr-accent-pink:  #f4b8ce;
  --clr-accent-blue:  #b8d4f4;

  /* Typography */
  --font-sans:   'Segoe UI', system-ui, sans-serif;
  --fw-normal:   400;
  --fw-semibold: 600;
  --fw-bold:     700;

  /* Spacing scale */
  --sp-xs:  0.5rem;
  --sp-s:   1rem;
  --sp-m:   1.5rem;
  --sp-l:   2.5rem;
  --sp-xl:  4rem;
  --sp-2xl: 6rem;

  /* Layout */
  --max-w: 1024px;
  --radius-s: 0.5rem;
  --radius-m: 1rem;
  --radius-pill: 100vmax;

  /* Transitions */
  --ease-out: cubic-bezier(0.25, 0, 0.3, 1);
  --dur: 0.2s;
}

/* ── 2. RESET & BASE ────────────────────────────────────────── */
*,
*::before,
*::after {
  box-sizing: border-box;
  margin: 0;
  padding: 0;
}

html {
  font-family: var(--font-sans);
  font-size: 16px;
  line-height: 1.5;
  background-color: var(--clr-bg);
  color: var(--clr-text);
  -webkit-font-smoothing: antialiased;
  scroll-behavior: smooth;
}

body {
  min-height: 100vh;
}

img {
  display: block;
  max-width: 100%;
  height: auto;
}

a {
  color: inherit;
  text-decoration: none;
}

ul, ol {
  list-style: none;
}

/* ── 3. UTILITY CLASSES ─────────────────────────────────────── */
.container {
  width: 100%;
  max-width: var(--max-w);
  margin-inline: auto;
  padding-inline: var(--sp-m);
}

.section-title {
  font-size: clamp(1.25rem, 3vw, 1.75rem);
  font-weight: var(--fw-bold);
  color: var(--clr-text);
  letter-spacing: 0.04em;
  text-transform: uppercase;
  margin-bottom: var(--sp-l);
  padding-bottom: var(--sp-xs);
  border-bottom: 1px solid var(--clr-accent-blue);
}

/* ── 4. HEADER / NAV ────────────────────────────────────────── */
.site-header {
  position: sticky;
  top: 0;
  z-index: 100;
  background-color: var(--clr-bg-nav);
  border-bottom: 1px solid var(--clr-accent-blue);
}

.site-header .container {
  display: grid;
  grid-template-columns: auto 1fr auto;
  align-items: center;
  column-gap: var(--sp-s);
  padding-block: var(--sp-xs);
}

/* Logo */
.site-logo {
  display: flex;
  align-items: center;
}

.site-logo img {
  width: 80px;
  height: 80px;
  object-fit: contain;
}

/* Desktop nav */
.main-nav {
  display: flex;
  justify-content: center;
}

.main-nav ul {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: var(--sp-xs);
  justify-content: space-evenly;
  white-space: normal;
}

.main-nav a {
  display: inline-flex;
  align-items: center;
  padding: var(--sp-xs) var(--sp-s);
  font-weight: var(--fw-semibold);
  border-bottom: 1px solid transparent;
  transition:
    color var(--dur) var(--ease-out),
    border-bottom-color var(--dur) var(--ease-out);
}

.main-nav a:hover {
  color: var(--clr-text-muted);
}

/* Mobile menu button (hidden on desktop) */
.mobile-menu-btn {
  display: none;
  padding: 0;
  background: transparent;
  border: none;
  color: var(--clr-text);
  cursor: pointer;
  width: 1.5rem;
  height: 1.5rem;
}

/* ── 5. HERO SECTION ────────────────────────────────────────── */
.hero {
  position: relative;
  overflow: hidden;
  padding-block: var(--sp-2xl);
}

.hero .container {
  display: grid;
  grid-template-columns: 1.5fr 1fr;
  align-items: center;
  column-gap: 0;
  row-gap: var(--sp-s);
}

/* Text column */
.hero-content {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  row-gap: var(--sp-m);
}

.hero-text {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  row-gap: var(--sp-s);
}

.hero-title {
  font-size: clamp(2rem, 9vw, 3.5rem);
  font-weight: var(--fw-bold);
  color: var(--clr-text);
  text-wrap: balance;
  max-width: 35ch;
  line-height: 1.1;
  margin: 0;
}

.hero-description {
  font-size: 1.25rem;
  color: var(--clr-text-muted);
  max-width: 45ch;
  text-wrap: balance;
  margin: 0;
}

/* CTA buttons */
.hero-actions {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: var(--sp-s);
}

/* Shared button base */
.btn {
  display: inline-flex;
  align-items: center;
  gap: var(--sp-xs);
  padding: var(--sp-xs) var(--sp-s);
  border-radius: var(--radius-m);
  font-weight: var(--fw-semibold);
  border: 1px solid var(--clr-border);
  cursor: pointer;
  transition:
    opacity var(--dur) var(--ease-out),
    scale var(--dur) var(--ease-out),
    box-shadow 0.3s cubic-bezier(0.5, 1, 0.75, 1.25);
  text-align: center;
  white-space: nowrap;
  flex-grow: 0;
  flex-shrink: 0;
}

.btn:hover {
  box-shadow: 0 0 8px rgba(244,184,206,0.25), 0 0 0 0.5rem var(--clr-bg-card);
}

.btn:active {
  scale: 0.97 0.97;
}

.btn-primary {
  background-color: var(--clr-btn-primary-bg);
  color: var(--clr-btn-primary-text);
}

.btn-outline {
  background-color: transparent;
  color: var(--clr-text);
  border: 1px solid currentColor;
}

/* Hero illustration */
.hero-illustration {
  position: absolute;
  top: 50%;
  right: 0;
  translate: 0 -50%;
  height: 80%;
  max-height: 480px;
  width: auto;
  pointer-events: none;
  display: flex;
  align-items: center;
  justify-content: flex-end;
  padding-right: var(--sp-m);
}

.hero-illustration svg {
  height: 100%;
  width: auto;
  opacity: 0.7;
}

/* ── 6. ARTICLES SECTION ────────────────────────────────────── */
.articles-section {
  padding-block: var(--sp-xl);
  border-top: 1px solid var(--clr-border);
}

.articles-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
  gap: var(--sp-m);
}

.article-card {
  background-color: var(--clr-bg-card);
  border: 1px solid var(--clr-border);
  border-radius: var(--radius-m);
  padding: var(--sp-m);
  display: flex;
  flex-direction: column;
  gap: var(--sp-s);
  transition: border-color var(--dur) var(--ease-out);
}

.article-card:hover {
  border-color: var(--clr-accent-pink);
}

.article-tag {
  display: inline-block;
  font-size: 0.7rem;
  font-weight: var(--fw-semibold);
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: var(--clr-accent-pink);
  border: 1px solid var(--clr-accent-pink);
  border-radius: var(--radius-pill);
  padding: 2px var(--sp-xs);
  width: fit-content;
}

.article-card h3 {
  font-size: 1.1rem;
  font-weight: var(--fw-bold);
  line-height: 1.3;
  color: var(--clr-text);
}

.article-card p {
  font-size: 0.9rem;
  color: var(--clr-text-muted);
  flex-grow: 1;
}

.article-card-footer {
  display: flex;
  align-items: center;
  justify-content: space-between;
  font-size: 0.8rem;
  color: var(--clr-text-muted);
  margin-top: auto;
  padding-top: var(--sp-xs);
  border-top: 1px solid var(--clr-border);
}

.article-read-more {
  font-weight: var(--fw-semibold);
  color: var(--clr-accent-blue);
  transition: color var(--dur) var(--ease-out);
}

.article-read-more:hover {
  color: var(--clr-text-muted);
}

/* ── 7. IMAGE GALLERY SECTION ───────────────────────────────── */
.gallery-section {
  padding-block: var(--sp-xl);
  border-top: 1px solid var(--clr-border);
}

.gallery-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  grid-template-rows: auto;
  gap: var(--sp-xs);
}

/* Make certain items span more columns/rows for a mosaic feel */
.gallery-item:nth-child(1) {
  grid-column: span 2;
  grid-row: span 2;
}

.gallery-item:nth-child(5) {
  grid-column: span 2;
}

.gallery-item {
  position: relative;
  overflow: hidden;
  border-radius: var(--radius-s);
  background-color: var(--clr-bg-card);
  aspect-ratio: 1;
}

.gallery-item img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: scale 0.4s var(--ease-out), opacity 0.4s var(--ease-out);
}

.gallery-item:hover img {
  scale: 1.04;
}

.gallery-item-overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(to top, rgba(0,0,0,0.65) 0%, transparent 55%);
  opacity: 0;
  transition: opacity var(--dur) var(--ease-out);
  display: flex;
  align-items: flex-end;
  padding: var(--sp-s);
}

.gallery-item:hover .gallery-item-overlay {
  opacity: 1;
}

.gallery-item-label {
  font-size: 0.85rem;
  font-weight: var(--fw-semibold);
  color: #fff;
}

/* Placeholder for gallery items without images */
.gallery-placeholder {
  width: 100%;
  height: 100%;
  background: linear-gradient(135deg, var(--clr-bg-card) 0%, #1a1a1a 100%);
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--clr-border);
  font-size: 0.8rem;
  font-weight: var(--fw-semibold);
  letter-spacing: 0.05em;
  text-transform: uppercase;
}

/* ── 8. YOUTUBE EMBEDS SECTION ──────────────────────────────── */
.videos-section {
  padding-block: var(--sp-xl);
  border-top: 1px solid var(--clr-border);
}

.videos-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(300px, 1fr));
  gap: var(--sp-m);
}

.video-card {
  background-color: var(--clr-bg-card);
  border: 1px solid var(--clr-border);
  border-radius: var(--radius-m);
  overflow: hidden;
  display: flex;
  flex-direction: column;
  transition: border-color var(--dur) var(--ease-out);
}

.video-card:hover {
  border-color: var(--clr-accent-blue);
}

.video-embed-wrapper {
  position: relative;
  width: 100%;
  aspect-ratio: 16 / 9;
  background-color: #000;
  overflow: hidden;
}

.video-embed-wrapper iframe {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  border: none;
}

.video-card-info {
  padding: var(--sp-s) var(--sp-m);
  display: flex;
  flex-direction: column;
  gap: var(--sp-xs);
}

.video-card-info h3 {
  font-size: 1rem;
  font-weight: var(--fw-bold);
  color: var(--clr-text);
  line-height: 1.3;
}

.video-card-info p {
  font-size: 0.85rem;
  color: var(--clr-text-muted);
}

/* ── 9. FOOTER ──────────────────────────────────────────────── */
.site-footer {
  margin-top: var(--sp-xl);
  border-top: 1px solid var(--clr-border);
  padding-block: var(--sp-l);
  background-color: var(--clr-bg-nav);
}

.footer-inner {
  display: grid;
  grid-template-columns: 1fr auto;
  align-items: start;
  gap: var(--sp-l);
}

.footer-brand {
  display: flex;
  flex-direction: column;
  gap: var(--sp-s);
}

.footer-brand img {
  width: 60px;
  height: 60px;
  object-fit: contain;
}

.footer-brand p {
  font-size: 0.9rem;
  color: var(--clr-text-muted);
  max-width: 35ch;
}

.footer-links {
  display: flex;
  flex-direction: column;
  gap: var(--sp-xs);
  text-align: right;
}

.footer-links a {
  font-size: 0.9rem;
  color: var(--clr-text-muted);
  transition: color var(--dur) var(--ease-out);
}

.footer-links a:hover {
  color: var(--clr-accent-white);
}

.footer-bottom {
  margin-top: var(--sp-l);
  padding-top: var(--sp-s);
  border-top: 1px solid var(--clr-border);
  font-size: 0.8rem;
  color: var(--clr-text-muted);
  text-align: center;
}

/* ── 10. RESPONSIVE ─────────────────────────────────────────── */

/* Tablet */
@media (max-width: 991px) {
  .hero .container {
    grid-template-columns: 1fr 1fr;
  }

  .gallery-grid {
    grid-template-columns: repeat(3, 1fr);
  }

  .gallery-item:nth-child(1) {
    grid-column: span 2;
  }

  .gallery-item:nth-child(5) {
    grid-column: span 1;
  }
}

/* Mobile large */
@media (max-width: 767px) {
  .site-header .container {
    grid-template-columns: auto 1fr auto;
  }

  .main-nav {
    display: none;
  }

  .mobile-menu-btn {
    display: flex;
    align-items: center;
    justify-content: center;
  }

  .hero .container {
    grid-template-columns: 1fr;
  }

  .hero-illustration {
    display: none;
  }

  .footer-inner {
    grid-template-columns: 1fr;
  }

  .footer-links {
    text-align: left;
    flex-direction: row;
    flex-wrap: wrap;
    gap: var(--sp-s);
  }
}

/* Mobile small */
@media (max-width: 479px) {
  .hero-title {
    hyphens: auto;
  }

  .btn {
    flex-grow: 1;
    flex-shrink: 0;
  }

  .gallery-grid {
    grid-template-columns: repeat(2, 1fr);
  }

  .gallery-item:nth-child(1) {
    grid-column: span 2;
  }

  .gallery-item:nth-child(5) {
    grid-column: span 2;
  }
}


/* ══════════════════════════════════════════════════════════════
   ABOUT PAGE
   ══════════════════════════════════════════════════════════════ */

/* ── 11. PAGE BANNER (reusable across inner pages) ──────────── */
.page-banner {
  padding-block: var(--sp-xl) var(--sp-l);
  border-bottom: 1px solid var(--clr-border);
}

.page-banner-label {
  display: inline-block;
  font-size: 0.7rem;
  font-weight: var(--fw-semibold);
  text-transform: uppercase;
  letter-spacing: 0.15em;
  color: var(--clr-accent-pink);
  margin-bottom: var(--sp-xs);
}

.page-banner h1 {
  font-size: clamp(2rem, 7vw, 3rem);
  font-weight: var(--fw-bold);
  line-height: 1.1;
  color: var(--clr-text);
}

.page-banner p {
  margin-top: var(--sp-s);
  font-size: 1.1rem;
  color: var(--clr-text-muted);
  max-width: 55ch;
}

/* ── 12. ABOUT LAYOUT ───────────────────────────────────────── */
.about-section {
  padding-block: var(--sp-xl);
}

.about-grid {
  display: grid;
  grid-template-columns: 280px 1fr;
  gap: var(--sp-xl);
  align-items: start;
}

/* ── 13. PORTRAIT CARD ──────────────────────────────────────── */
.portrait-card {
  display: flex;
  flex-direction: column;
  gap: var(--sp-s);
  position: sticky;
  top: calc(80px + var(--sp-m)); /* clear sticky nav */
}

.portrait-frame {
  position: relative;
  width: 100%;
  aspect-ratio: 1;
  border-radius: var(--radius-m);
  overflow: hidden;
  background-color: var(--clr-bg-card);
  border: 1px solid var(--clr-border);
}

/* Decorative corner accent */
.portrait-frame::before {
  content: '';
  position: absolute;
  inset: 0;
  border-radius: var(--radius-m);
  background: linear-gradient(
    135deg,
    rgba(244, 184, 206, 0.12) 0%,
    rgba(184, 212, 244, 0.06) 50%,
    transparent 100%
  );
  z-index: 1;
  pointer-events: none;
}

.portrait-frame img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

/* Placeholder when no portrait image yet */
.portrait-placeholder {
  width: 100%;
  height: 100%;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: var(--sp-s);
  background: linear-gradient(135deg, #2a2a2a 0%, #1a1a1a 100%);
  color: var(--clr-text-muted);
  font-size: 0.8rem;
  font-weight: var(--fw-semibold);
  letter-spacing: 0.05em;
  text-transform: uppercase;
}

.portrait-placeholder svg {
  width: 56px;
  height: 56px;
  opacity: 0.3;
}

.portrait-meta {
  display: flex;
  flex-direction: column;
  gap: var(--sp-xs);
}

.portrait-name {
  font-size: 1.2rem;
  font-weight: var(--fw-bold);
  color: var(--clr-text);
}

.portrait-handle {
  font-size: 0.85rem;
  color: var(--clr-accent-pink);
}

.portrait-tags {
  display: flex;
  flex-wrap: wrap;
  gap: var(--sp-xs);
  margin-top: var(--sp-xs);
}

.portrait-tag {
  font-size: 0.7rem;
  font-weight: var(--fw-semibold);
  text-transform: uppercase;
  letter-spacing: 0.08em;
  padding: 3px var(--sp-xs);
  border-radius: var(--radius-pill);
  border: 1px solid var(--clr-border);
  color: var(--clr-text-muted);
}

.portrait-tag.pink  { border-color: var(--clr-accent-pink); color: var(--clr-accent-pink); }
.portrait-tag.blue  { border-color: var(--clr-accent-blue); color: var(--clr-accent-blue); }
.portrait-tag.white { border-color: var(--clr-accent-white); color: var(--clr-accent-white); }

/* ── 14. BIO CONTENT ────────────────────────────────────────── */
.bio-content {
  display: flex;
  flex-direction: column;
  gap: var(--sp-l);
}

.bio-block {
  display: flex;
  flex-direction: column;
  gap: var(--sp-s);
}

.bio-block-label {
  font-size: 0.7rem;
  font-weight: var(--fw-semibold);
  text-transform: uppercase;
  letter-spacing: 0.15em;
  color: var(--clr-accent-blue);
}

.bio-block h2 {
  font-size: clamp(1.1rem, 2.5vw, 1.4rem);
  font-weight: var(--fw-bold);
  color: var(--clr-text);
  line-height: 1.2;
}

.bio-block p {
  font-size: 1rem;
  color: var(--clr-text-muted);
  line-height: 1.75;
  max-width: 65ch;
}

.bio-block p + p {
  margin-top: var(--sp-xs);
}

/* Divider between bio blocks */
.bio-divider {
  border: none;
  border-top: 1px solid var(--clr-border);
}

/* ── 15. QUICK-FACTS / INTERESTS GRID ───────────────────────── */
.facts-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(160px, 1fr));
  gap: var(--sp-s);
}

.fact-card {
  background-color: var(--clr-bg-card);
  border: 1px solid var(--clr-border);
  border-radius: var(--radius-m);
  padding: var(--sp-s) var(--sp-m);
  display: flex;
  flex-direction: column;
  gap: 4px;
  transition: border-color var(--dur) var(--ease-out);
}

.fact-card:hover { border-color: var(--clr-accent-pink); }

.fact-card-label {
  font-size: 0.65rem;
  font-weight: var(--fw-semibold);
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: var(--clr-text-muted);
}

.fact-card-value {
  font-size: 0.95rem;
  font-weight: var(--fw-semibold);
  color: var(--clr-text);
}

/* ── 16. ABOUT PAGE RESPONSIVE ──────────────────────────────── */
@media (max-width: 767px) {
  .about-grid {
    grid-template-columns: 1fr;
    gap: var(--sp-l);
  }

  .portrait-card {
    position: static;
    flex-direction: row;
    align-items: center;
    gap: var(--sp-m);
  }

  .portrait-frame {
    width: 120px;
    flex-shrink: 0;
    aspect-ratio: 1;
  }

  .portrait-tags {
    margin-top: 4px;
  }
}

@media (max-width: 479px) {
  .portrait-card {
    flex-direction: column;
    align-items: flex-start;
  }

  .portrait-frame {
    width: 100%;
  }

  .facts-grid {
    grid-template-columns: repeat(2, 1fr);
  }
}


/* ══════════════════════════════════════════════════════════════
   PROJECTS PAGE
   ══════════════════════════════════════════════════════════════ */

/* ── 17. TAB BAR ────────────────────────────────────────────── */
.projects-section {
  padding-block: var(--sp-xl);
}

.tab-bar {
  display: flex;
  align-items: center;
  gap: 2px;
  border-bottom: 1px solid var(--clr-border);
  margin-bottom: var(--sp-l);
  overflow-x: auto;
  scrollbar-width: none;
}

.tab-bar::-webkit-scrollbar { display: none; }

.tab-btn {
  display: inline-flex;
  align-items: center;
  gap: var(--sp-xs);
  padding: var(--sp-s) var(--sp-m);
  background: transparent;
  border: none;
  border-bottom: 2px solid transparent;
  color: var(--clr-text-muted);
  font-family: var(--font-sans);
  font-size: 0.85rem;
  font-weight: var(--fw-semibold);
  letter-spacing: 0.04em;
  text-transform: uppercase;
  cursor: pointer;
  white-space: nowrap;
  margin-bottom: -1px;
  transition:
    color var(--dur) var(--ease-out),
    border-bottom-color var(--dur) var(--ease-out);
}

.tab-btn:hover {
  color: var(--clr-text);
}

.tab-btn.active {
  color: var(--clr-accent-pink);
  border-bottom-color: var(--clr-accent-pink);
}

.tab-btn svg {
  width: 14px;
  height: 14px;
  flex-shrink: 0;
}

/* ── 18. TAB PANELS ─────────────────────────────────────────── */
.tab-panel {
  display: none;
}

.tab-panel.active {
  display: block;
}

/* ── 19. INSTAGRAM-STYLE IMAGE GRID ─────────────────────────── */
.insta-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 3px;
}

.insta-item {
  position: relative;
  aspect-ratio: 1;
  overflow: hidden;
  background-color: var(--clr-bg-card);
  cursor: pointer;
}

.insta-item img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: scale 0.35s var(--ease-out);
  display: block;
}

.insta-item:hover img {
  scale: 1.05;
}

/* Hover overlay */
.insta-overlay {
  position: absolute;
  inset: 0;
  background: rgba(0, 0, 0, 0.55);
  display: flex;
  align-items: center;
  justify-content: center;
  gap: var(--sp-m);
  opacity: 0;
  transition: opacity 0.25s var(--ease-out);
}

.insta-item:hover .insta-overlay {
  opacity: 1;
}

.insta-overlay-stat {
  display: flex;
  align-items: center;
  gap: 6px;
  color: #fff;
  font-size: 0.95rem;
  font-weight: var(--fw-bold);
}

.insta-overlay-stat svg {
  width: 18px;
  height: 18px;
}

/* Placeholder tile */
.insta-placeholder {
  width: 100%;
  height: 100%;
  background: linear-gradient(135deg, #2a2a2a 0%, #1a1a1a 100%);
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--clr-border);
}

.insta-placeholder svg {
  width: 32px;
  height: 32px;
}

/* ── 20. LIGHTBOX ───────────────────────────────────────────── */
.lightbox {
  position: fixed;
  inset: 0;
  z-index: 200;
  display: none;
  align-items: center;
  justify-content: center;
  background: rgba(0, 0, 0, 0.88);
}

.lightbox.open {
  display: flex;
}

.lightbox-inner {
  position: relative;
  display: grid;
  grid-template-columns: 1fr 360px;
  max-width: 960px;
  width: 95vw;
  max-height: 90vh;
  background-color: var(--clr-bg-card);
  border: 1px solid var(--clr-border);
  border-radius: var(--radius-m);
  overflow: hidden;
}

.lightbox-img-wrap {
  position: relative;
  background: #000;
  display: flex;
  align-items: center;
  justify-content: center;
  overflow: hidden;
}

.lightbox-img-wrap img {
  width: 100%;
  height: 100%;
  object-fit: contain;
  max-height: 90vh;
}

.lightbox-info {
  display: flex;
  flex-direction: column;
  padding: var(--sp-m);
  gap: var(--sp-s);
  overflow-y: auto;
  border-left: 1px solid var(--clr-border);
}

.lightbox-info-header {
  display: flex;
  align-items: center;
  gap: var(--sp-s);
  padding-bottom: var(--sp-s);
  border-bottom: 1px solid var(--clr-border);
}

.lightbox-avatar {
  width: 36px;
  height: 36px;
  border-radius: 50%;
  object-fit: cover;
  background-color: var(--clr-border);
  flex-shrink: 0;
}

.lightbox-username {
  font-size: 0.9rem;
  font-weight: var(--fw-bold);
  color: var(--clr-text);
}

.lightbox-title {
  font-size: 1rem;
  font-weight: var(--fw-bold);
  color: var(--clr-text);
  line-height: 1.3;
}

.lightbox-caption {
  font-size: 0.875rem;
  color: var(--clr-text-muted);
  line-height: 1.65;
  flex-grow: 1;
}

.lightbox-meta {
  font-size: 0.75rem;
  color: var(--clr-text-muted);
  text-transform: uppercase;
  letter-spacing: 0.06em;
  padding-top: var(--sp-s);
  border-top: 1px solid var(--clr-border);
}

.lightbox-close {
  position: absolute;
  top: var(--sp-s);
  right: var(--sp-s);
  width: 36px;
  height: 36px;
  border-radius: 50%;
  background: rgba(0,0,0,0.6);
  border: none;
  color: #fff;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 10;
  transition: background var(--dur) var(--ease-out);
}

.lightbox-close:hover {
  background: rgba(0,0,0,0.9);
}

.lightbox-nav-btn {
  position: absolute;
  top: 50%;
  translate: 0 -50%;
  width: 40px;
  height: 40px;
  border-radius: 50%;
  background: rgba(0,0,0,0.55);
  border: none;
  color: #fff;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 10;
  transition: background var(--dur) var(--ease-out);
}

.lightbox-nav-btn:hover { background: rgba(0,0,0,0.9); }
.lightbox-nav-btn.prev  { left:  var(--sp-s); }
.lightbox-nav-btn.next  { right: var(--sp-s); }

/* ── 21. MUSIC GALLERY ──────────────────────────────────────── */
.music-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(300px, 1fr));
  gap: var(--sp-m);
}

.track-card {
  background-color: var(--clr-bg-card);
  border: 1px solid var(--clr-border);
  border-radius: var(--radius-m);
  overflow: hidden;
  display: flex;
  flex-direction: column;
  transition: border-color var(--dur) var(--ease-out);
}

.track-card:hover {
  border-color: var(--clr-accent-pink);
}

.track-art {
  position: relative;
  width: 100%;
  aspect-ratio: 1;
  background: linear-gradient(135deg, #2a2a2a 0%, #1a1a1a 100%);
  overflow: hidden;
  flex-shrink: 0;
}

.track-art img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.track-art-placeholder {
  width: 100%;
  height: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--clr-border);
}

.track-art-placeholder svg {
  width: 56px;
  height: 56px;
}

/* Play button overlay on album art */
.track-play-overlay {
  position: absolute;
  inset: 0;
  background: rgba(0,0,0,0.4);
  display: flex;
  align-items: center;
  justify-content: center;
  opacity: 0;
  transition: opacity 0.25s var(--ease-out);
}

.track-card:hover .track-play-overlay {
  opacity: 1;
}

.track-play-btn {
  width: 56px;
  height: 56px;
  border-radius: 50%;
  background: var(--clr-accent-pink);
  border: none;
  color: var(--clr-text-dark);
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: scale 0.2s var(--ease-out);
  flex-shrink: 0;
}

.track-play-btn:hover {
  scale: 1.08;
}

.track-play-btn svg {
  width: 22px;
  height: 22px;
  margin-left: 3px; /* optical centre for play triangle */
}

.track-info {
  padding: var(--sp-s) var(--sp-m);
  display: flex;
  flex-direction: column;
  gap: 4px;
}

.track-title {
  font-size: 1rem;
  font-weight: var(--fw-bold);
  color: var(--clr-text);
  line-height: 1.3;
}

.track-artist {
  font-size: 0.85rem;
  color: var(--clr-accent-pink);
  font-weight: var(--fw-semibold);
}

.track-meta {
  font-size: 0.75rem;
  color: var(--clr-text-muted);
  margin-top: 2px;
}

/* Native audio player — styled to match theme */
.track-audio {
  width: 100%;
  padding: 0 var(--sp-m) var(--sp-m);
}

.track-audio audio {
  width: 100%;
  height: 32px;
  filter: invert(1) hue-rotate(180deg) brightness(0.8);
  border-radius: var(--radius-s);
}

/* ── 22. PROJECTS PAGE RESPONSIVE ───────────────────────────── */
@media (max-width: 767px) {
  .insta-grid {
    grid-template-columns: repeat(3, 1fr);
    gap: 2px;
  }

  .lightbox-inner {
    grid-template-columns: 1fr;
    grid-template-rows: 60vw 1fr;
    max-height: 95vh;
  }

  .lightbox-info {
    border-left: none;
    border-top: 1px solid var(--clr-border);
  }
}

@media (max-width: 479px) {
  .insta-grid {
    grid-template-columns: repeat(2, 1fr);
  }

  .tab-btn {
    padding: var(--sp-xs) var(--sp-s);
    font-size: 0.75rem;
  }

  .music-grid {
    grid-template-columns: 1fr;
  }
}


/* ══════════════════════════════════════════════════════════════
   BLOG PAGE
   ══════════════════════════════════════════════════════════════ */

/* ── 23. BLOG LAYOUT ────────────────────────────────────────── */
.blog-section {
  padding-block: var(--sp-xl);
}

.blog-layout {
  display: grid;
  grid-template-columns: 1fr 280px;
  gap: var(--sp-xl);
  align-items: start;
}

/* ── 24. POST FEED ──────────────────────────────────────────── */
.post-feed {
  display: flex;
  flex-direction: column;
  gap: var(--sp-l);
}

/* ── 25. POST CARD (shared base) ────────────────────────────── */
.post-card {
  background-color: var(--clr-bg-card);
  border: 1px solid var(--clr-border);
  border-radius: var(--radius-m);
  overflow: hidden;
  transition: border-color var(--dur) var(--ease-out);
}

.post-card:hover {
  border-color: var(--clr-accent-pink);
}

/* Post type label strip at top of each card */
.post-type-strip {
  display: flex;
  align-items: center;
  gap: var(--sp-xs);
  padding: var(--sp-xs) var(--sp-m);
  border-bottom: 1px solid var(--clr-border);
  font-size: 0.65rem;
  font-weight: var(--fw-bold);
  text-transform: uppercase;
  letter-spacing: 0.12em;
}

.post-type-strip svg {
  width: 12px;
  height: 12px;
  flex-shrink: 0;
}

.post-type-strip.type-text    { color: var(--clr-accent-white); }
.post-type-strip.type-image   { color: var(--clr-accent-blue);  }
.post-type-strip.type-quote   { color: var(--clr-accent-pink);  }
.post-type-strip.type-link    { color: var(--clr-accent-blue);  }
.post-type-strip.type-audio   { color: var(--clr-accent-pink);  }
.post-type-strip.type-video   { color: var(--clr-accent-blue);  }

/* Post body padding */
.post-body {
  padding: var(--sp-m);
  display: flex;
  flex-direction: column;
  gap: var(--sp-s);
}

/* Post footer — tags + date */
.post-footer {
  display: flex;
  align-items: center;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: var(--sp-xs);
  padding: var(--sp-xs) var(--sp-m) var(--sp-m);
}

.post-tags {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
}

.post-tag {
  font-size: 0.7rem;
  color: var(--clr-accent-blue);
  font-weight: var(--fw-semibold);
  cursor: pointer;
  transition: color var(--dur) var(--ease-out);
}

.post-tag::before { content: '#'; }

.post-tag:hover { color: var(--clr-accent-pink); }

.post-date {
  font-size: 0.75rem;
  color: var(--clr-text-muted);
  white-space: nowrap;
}

/* ── 26. TEXT POST ──────────────────────────────────────────── */
.post-title {
  font-size: clamp(1.1rem, 2.5vw, 1.4rem);
  font-weight: var(--fw-bold);
  color: var(--clr-text);
  line-height: 1.25;
}

.post-title a {
  transition: color var(--dur) var(--ease-out);
}

.post-title a:hover { color: var(--clr-accent-pink); }

.post-excerpt {
  font-size: 0.95rem;
  color: var(--clr-text-muted);
  line-height: 1.75;
}

.post-read-more {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  font-size: 0.85rem;
  font-weight: var(--fw-semibold);
  color: var(--clr-accent-blue);
  transition: color var(--dur) var(--ease-out);
  width: fit-content;
}

.post-read-more:hover { color: var(--clr-accent-pink); }

/* ── 27. IMAGE POST ─────────────────────────────────────────── */
.post-image-wrap {
  position: relative;
  width: 100%;
  background: #111;
  overflow: hidden;
}

.post-image-wrap img {
  width: 100%;
  height: auto;
  display: block;
  transition: scale 0.4s var(--ease-out);
}

.post-card:hover .post-image-wrap img {
  scale: 1.02;
}

.post-image-placeholder {
  width: 100%;
  aspect-ratio: 16 / 9;
  background: linear-gradient(135deg, #2a2a2a 0%, #1a1a1a 100%);
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--clr-border);
}

.post-image-placeholder svg {
  width: 40px;
  height: 40px;
}

/* ── 28. QUOTE POST ─────────────────────────────────────────── */
.post-quote {
  border-left: 3px solid var(--clr-accent-pink);
  padding-left: var(--sp-m);
  display: flex;
  flex-direction: column;
  gap: var(--sp-xs);
}

.post-quote blockquote {
  font-size: clamp(1rem, 2.5vw, 1.3rem);
  font-style: italic;
  color: var(--clr-text);
  line-height: 1.55;
}

.post-quote cite {
  font-size: 0.85rem;
  font-style: normal;
  color: var(--clr-accent-pink);
  font-weight: var(--fw-semibold);
}

/* ── 29. LINK POST ──────────────────────────────────────────── */
.post-link-card {
  display: flex;
  align-items: center;
  gap: var(--sp-m);
  padding: var(--sp-m);
  background: rgba(184, 212, 244, 0.05);
  border: 1px solid rgba(184, 212, 244, 0.15);
  border-radius: var(--radius-s);
  transition: border-color var(--dur) var(--ease-out);
}

.post-link-card:hover {
  border-color: var(--clr-accent-blue);
}

.post-link-icon {
  width: 40px;
  height: 40px;
  border-radius: var(--radius-s);
  background-color: var(--clr-border);
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  color: var(--clr-accent-blue);
}

.post-link-icon svg { width: 20px; height: 20px; }

.post-link-text {
  display: flex;
  flex-direction: column;
  gap: 2px;
  overflow: hidden;
}

.post-link-title {
  font-size: 0.95rem;
  font-weight: var(--fw-bold);
  color: var(--clr-text);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.post-link-url {
  font-size: 0.75rem;
  color: var(--clr-accent-blue);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

/* ── 30. AUDIO POST ─────────────────────────────────────────── */
.post-audio-art {
  position: relative;
  width: 100%;
  aspect-ratio: 16 / 9;
  background: linear-gradient(135deg, #2a2a2a 0%, #111 100%);
  display: flex;
  align-items: center;
  justify-content: center;
  overflow: hidden;
}

.post-audio-art img {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  opacity: 0.45;
}

.post-audio-art-placeholder {
  color: var(--clr-border);
}

.post-audio-art-placeholder svg { width: 48px; height: 48px; }

.post-audio-info {
  display: flex;
  flex-direction: column;
  gap: 2px;
}

.post-audio-title {
  font-size: 1.05rem;
  font-weight: var(--fw-bold);
  color: var(--clr-text);
}

.post-audio-artist {
  font-size: 0.85rem;
  color: var(--clr-accent-pink);
  font-weight: var(--fw-semibold);
}

.post-audio-player {
  padding-bottom: var(--sp-xs);
}

.post-audio-player audio {
  width: 100%;
  height: 32px;
  filter: invert(1) hue-rotate(180deg) brightness(0.8);
}

/* ── 31. VIDEO POST ─────────────────────────────────────────── */
.post-video-wrap {
  position: relative;
  width: 100%;
  aspect-ratio: 16 / 9;
  background: #000;
  overflow: hidden;
}

.post-video-wrap iframe {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  border: none;
}

/* ── 32. SIDEBAR ────────────────────────────────────────────── */
.blog-sidebar {
  position: sticky;
  top: calc(80px + var(--sp-m));
  display: flex;
  flex-direction: column;
  gap: var(--sp-m);
}

.sidebar-card {
  background-color: var(--clr-bg-card);
  border: 1px solid var(--clr-border);
  border-radius: var(--radius-m);
  overflow: hidden;
}

.sidebar-card-header {
  padding: var(--sp-s) var(--sp-m);
  border-bottom: 1px solid var(--clr-border);
  font-size: 0.7rem;
  font-weight: var(--fw-bold);
  text-transform: uppercase;
  letter-spacing: 0.12em;
  color: var(--clr-text-muted);
}

.sidebar-card-body {
  padding: var(--sp-m);
  display: flex;
  flex-direction: column;
  gap: var(--sp-s);
}

/* About blurb in sidebar */
.sidebar-avatar {
  width: 64px;
  height: 64px;
  border-radius: 50%;
  object-fit: contain;
  background-color: var(--clr-border);
}

.sidebar-name {
  font-size: 1rem;
  font-weight: var(--fw-bold);
  color: var(--clr-text);
}

.sidebar-handle {
  font-size: 0.8rem;
  color: var(--clr-accent-pink);
}

.sidebar-bio {
  font-size: 0.85rem;
  color: var(--clr-text-muted);
  line-height: 1.6;
}

/* Tag cloud in sidebar */
.sidebar-tags {
  display: flex;
  flex-wrap: wrap;
  gap: var(--sp-xs);
}

.sidebar-tag {
  font-size: 0.75rem;
  font-weight: var(--fw-semibold);
  color: var(--clr-accent-blue);
  padding: 3px var(--sp-xs);
  border: 1px solid rgba(184, 212, 244, 0.25);
  border-radius: var(--radius-pill);
  cursor: pointer;
  transition:
    color var(--dur) var(--ease-out),
    border-color var(--dur) var(--ease-out);
}

.sidebar-tag::before { content: '#'; }

.sidebar-tag:hover {
  color: var(--clr-accent-pink);
  border-color: rgba(244, 184, 206, 0.35);
}

/* Archive list in sidebar */
.sidebar-archive {
  display: flex;
  flex-direction: column;
  gap: 2px;
}

.sidebar-archive-item {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: var(--sp-xs) 0;
  border-bottom: 1px solid var(--clr-border);
  font-size: 0.85rem;
  cursor: pointer;
  transition: color var(--dur) var(--ease-out);
  color: var(--clr-text-muted);
}

.sidebar-archive-item:last-child { border-bottom: none; }

.sidebar-archive-item:hover { color: var(--clr-text); }

.sidebar-archive-count {
  font-size: 0.75rem;
  color: var(--clr-text-muted);
  background: var(--clr-bg);
  border: 1px solid var(--clr-border);
  border-radius: var(--radius-pill);
  padding: 1px 6px;
}

/* ── 33. BLOG RESPONSIVE ────────────────────────────────────── */
@media (max-width: 900px) {
  .blog-layout {
    grid-template-columns: 1fr;
  }

  .blog-sidebar {
    position: static;
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(240px, 1fr));
    gap: var(--sp-m);
  }
}

@media (max-width: 479px) {
  .blog-sidebar {
    grid-template-columns: 1fr;
  }

  .post-link-card {
    flex-direction: column;
    align-items: flex-start;
  }
}


/* ══════════════════════════════════════════════════════════════
   WIKI PAGE
   ══════════════════════════════════════════════════════════════ */

/* ── 34. WIKI HERO ──────────────────────────────────────────── */
.wiki-hero {
  position: relative;
  padding-block: var(--sp-2xl);
  border-bottom: 1px solid var(--clr-border);
  overflow: hidden;
}

/* Subtle radial glow behind the hero text */
.wiki-hero::before {
  content: '';
  position: absolute;
  inset: 0;
  background:
    radial-gradient(ellipse 70% 60% at 50% 50%,
      rgba(244,184,206,0.06) 0%,
      rgba(184,212,244,0.04) 50%,
      transparent 100%);
  pointer-events: none;
}

.wiki-hero-inner {
  position: relative;
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  gap: var(--sp-m);
}

.wiki-hero-eyebrow {
  display: inline-flex;
  align-items: center;
  gap: var(--sp-xs);
  font-size: 0.7rem;
  font-weight: var(--fw-bold);
  text-transform: uppercase;
  letter-spacing: 0.18em;
  color: var(--clr-accent-pink);
}

.wiki-hero-eyebrow::before,
.wiki-hero-eyebrow::after {
  content: '';
  display: block;
  width: 32px;
  height: 1px;
  background: var(--clr-accent-pink);
  opacity: 0.5;
}

.wiki-hero-title {
  font-size: clamp(2.4rem, 8vw, 4.5rem);
  font-weight: var(--fw-bold);
  line-height: 1.05;
  color: var(--clr-text);
  letter-spacing: -0.01em;
}

.wiki-hero-title span {
  color: var(--clr-accent-pink);
}

.wiki-hero-desc {
  max-width: 60ch;
  font-size: 1.05rem;
  color: var(--clr-text-muted);
  line-height: 1.75;
}

.wiki-hero-stats {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: var(--sp-l);
  margin-top: var(--sp-s);
}

.wiki-stat {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 2px;
}

.wiki-stat-value {
  font-size: 1.6rem;
  font-weight: var(--fw-bold);
  color: var(--clr-text);
  line-height: 1;
}

.wiki-stat-label {
  font-size: 0.7rem;
  font-weight: var(--fw-semibold);
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: var(--clr-text-muted);
}

/* ── 35. WIKI SEARCH BAR ────────────────────────────────────── */
.wiki-search-wrap {
  padding-block: var(--sp-l);
  border-bottom: 1px solid var(--clr-border);
  background-color: var(--clr-bg-nav);
  position: sticky;
  top: 80px; /* height of site-header */
  z-index: 90;
}

.wiki-search-inner {
  display: flex;
  align-items: center;
  gap: var(--sp-s);
}

.wiki-search-field {
  position: relative;
  flex: 1;
}

.wiki-search-field svg {
  position: absolute;
  left: var(--sp-m);
  top: 50%;
  translate: 0 -50%;
  width: 16px;
  height: 16px;
  color: var(--clr-text-muted);
  pointer-events: none;
}

.wiki-search-input {
  width: 100%;
  background: var(--clr-bg-card);
  border: 1px solid var(--clr-border);
  border-radius: var(--radius-m);
  padding: var(--sp-s) var(--sp-m) var(--sp-s) calc(var(--sp-m) * 2 + 16px);
  color: var(--clr-text);
  font-family: var(--font-sans);
  font-size: 0.95rem;
  outline: none;
  transition: border-color var(--dur) var(--ease-out), box-shadow var(--dur) var(--ease-out);
}

.wiki-search-input::placeholder { color: var(--clr-text-muted); }

.wiki-search-input:focus {
  border-color: var(--clr-accent-pink);
  box-shadow: 0 0 0 3px rgba(244,184,206,0.12);
}

.wiki-search-clear {
  position: absolute;
  right: var(--sp-s);
  top: 50%;
  translate: 0 -50%;
  background: transparent;
  border: none;
  color: var(--clr-text-muted);
  cursor: pointer;
  padding: 2px;
  display: none;
  align-items: center;
  justify-content: center;
  transition: color var(--dur) var(--ease-out);
}

.wiki-search-clear:hover { color: var(--clr-text); }
.wiki-search-clear svg   { width: 14px; height: 14px; }
.wiki-search-clear.visible { display: flex; }

.wiki-search-meta {
  font-size: 0.8rem;
  color: var(--clr-text-muted);
  white-space: nowrap;
  flex-shrink: 0;
}

/* ── 36. WIKI TAB BAR ───────────────────────────────────────── */
.wiki-section { padding-block: var(--sp-xl); }

.wiki-tab-bar {
  display: flex;
  align-items: center;
  gap: 2px;
  border-bottom: 1px solid var(--clr-border);
  margin-bottom: var(--sp-l);
  overflow-x: auto;
  scrollbar-width: none;
}

.wiki-tab-bar::-webkit-scrollbar { display: none; }

.wiki-tab-btn {
  display: inline-flex;
  align-items: center;
  gap: var(--sp-xs);
  padding: var(--sp-s) var(--sp-m);
  background: transparent;
  border: none;
  border-bottom: 2px solid transparent;
  color: var(--clr-text-muted);
  font-family: var(--font-sans);
  font-size: 0.85rem;
  font-weight: var(--fw-semibold);
  letter-spacing: 0.04em;
  text-transform: uppercase;
  cursor: pointer;
  white-space: nowrap;
  margin-bottom: -1px;
  transition: color var(--dur) var(--ease-out), border-bottom-color var(--dur) var(--ease-out);
}

.wiki-tab-btn:hover { color: var(--clr-text); }

.wiki-tab-btn.active {
  color: var(--clr-accent-pink);
  border-bottom-color: var(--clr-accent-pink);
}

.wiki-tab-btn svg { width: 14px; height: 14px; flex-shrink: 0; }

.wiki-tab-btn .tab-count {
  font-size: 0.65rem;
  font-weight: var(--fw-bold);
  background: var(--clr-bg);
  border: 1px solid var(--clr-border);
  border-radius: var(--radius-pill);
  padding: 0 5px;
  line-height: 1.6;
  color: var(--clr-text-muted);
}

.wiki-tab-btn.active .tab-count {
  background: rgba(244,184,206,0.15);
  border-color: rgba(244,184,206,0.3);
  color: var(--clr-accent-pink);
}

/* ── 37. WIKI TAB PANELS ────────────────────────────────────── */
.wiki-tab-panel { display: none; }
.wiki-tab-panel.active { display: block; }

/* ── 38. WIKI ENTRY GRID ────────────────────────────────────── */
.wiki-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
  gap: var(--sp-m);
}

/* Empty / no-results state */
.wiki-empty {
  grid-column: 1 / -1;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: var(--sp-s);
  padding: var(--sp-2xl) var(--sp-m);
  color: var(--clr-text-muted);
  text-align: center;
}

.wiki-empty svg {
  width: 40px;
  height: 40px;
  opacity: 0.35;
}

.wiki-empty p { font-size: 0.9rem; }

/* ── 39. WIKI ENTRY CARD ────────────────────────────────────── */
.wiki-card {
  background-color: var(--clr-bg-card);
  border: 1px solid var(--clr-border);
  border-radius: var(--radius-m);
  overflow: hidden;
  display: flex;
  flex-direction: column;
  cursor: pointer;
  transition:
    border-color var(--dur) var(--ease-out),
    translate 0.2s var(--ease-out);
}

.wiki-card:hover {
  border-color: var(--clr-accent-pink);
  translate: 0 -2px;
}

.wiki-card[hidden] { display: none; }

/* Card thumbnail */
.wiki-card-thumb {
  position: relative;
  width: 100%;
  aspect-ratio: 4 / 3;
  background: linear-gradient(135deg, #2a2a2a 0%, #1a1a1a 100%);
  overflow: hidden;
  flex-shrink: 0;
}

.wiki-card-thumb img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  transition: scale 0.35s var(--ease-out);
}

.wiki-card:hover .wiki-card-thumb img { scale: 1.04; }

.wiki-card-thumb-placeholder {
  width: 100%;
  height: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--clr-border);
}

.wiki-card-thumb-placeholder svg { width: 36px; height: 36px; }

/* Category badge overlaid on thumb */
.wiki-card-badge {
  position: absolute;
  top: var(--sp-xs);
  left: var(--sp-xs);
  font-size: 0.6rem;
  font-weight: var(--fw-bold);
  text-transform: uppercase;
  letter-spacing: 0.1em;
  padding: 2px var(--sp-xs);
  border-radius: var(--radius-pill);
  border: 1px solid currentColor;
}

.badge-characters { color: var(--clr-accent-pink);  border-color: rgba(244,184,206,0.5);  background: rgba(244,184,206,0.12); }
.badge-items      { color: var(--clr-accent-blue);  border-color: rgba(184,212,244,0.5);  background: rgba(184,212,244,0.12); }
.badge-systems    { color: var(--clr-accent-white); border-color: rgba(245,245,245,0.3);   background: rgba(245,245,245,0.08); }
.badge-bestiary   { color: #c8b4f4;                 border-color: rgba(200,180,244,0.5);   background: rgba(200,180,244,0.12); }
.badge-locations  { color: #b4f4c8;                 border-color: rgba(180,244,200,0.5);   background: rgba(180,244,200,0.12); }
.badge-events     { color: #f4d4b4;                 border-color: rgba(244,212,180,0.5);   background: rgba(244,212,180,0.12); }

/* Card body */
.wiki-card-body {
  padding: var(--sp-s) var(--sp-m);
  display: flex;
  flex-direction: column;
  gap: 4px;
  flex-grow: 1;
}

.wiki-card-title {
  font-size: 1rem;
  font-weight: var(--fw-bold);
  color: var(--clr-text);
  line-height: 1.25;
}

.wiki-card-sub {
  font-size: 0.8rem;
  color: var(--clr-accent-blue);
  font-weight: var(--fw-semibold);
}

.wiki-card-excerpt {
  font-size: 0.85rem;
  color: var(--clr-text-muted);
  line-height: 1.55;
  margin-top: 4px;
  display: -webkit-box;
  -webkit-line-clamp: 3;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

.wiki-card-footer {
  padding: var(--sp-xs) var(--sp-m) var(--sp-s);
  display: flex;
  align-items: center;
  justify-content: space-between;
  border-top: 1px solid var(--clr-border);
  margin-top: auto;
}

.wiki-card-tags {
  display: flex;
  flex-wrap: wrap;
  gap: 4px;
}

.wiki-card-tag {
  font-size: 0.65rem;
  font-weight: var(--fw-semibold);
  color: var(--clr-text-muted);
}

.wiki-card-tag::before { content: '#'; }

.wiki-card-arrow {
  font-size: 0.75rem;
  color: var(--clr-text-muted);
  transition: color var(--dur) var(--ease-out);
}

.wiki-card:hover .wiki-card-arrow { color: var(--clr-accent-pink); }

/* ── 40. WIKI RESPONSIVE ────────────────────────────────────── */
@media (max-width: 767px) {
  .wiki-hero { padding-block: var(--sp-xl); }

  .wiki-search-wrap {
    top: 80px;
    padding-block: var(--sp-s);
  }

  .wiki-search-inner { flex-wrap: wrap; }

  .wiki-hero-stats { gap: var(--sp-m); }

  .wiki-grid {
    grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
  }
}

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

  .wiki-tab-btn {
    padding: var(--sp-xs) var(--sp-s);
    font-size: 0.75rem;
  }

  .wiki-hero-stats { gap: var(--sp-s); }
}


/* ══════════════════════════════════════════════════════════════
   WIKI ARTICLE PAGES  (sections 41 – 45)
   ══════════════════════════════════════════════════════════════ */

/* ── 41. WIKI ARTICLE BREADCRUMB ────────────────────────────── */
.wiki-breadcrumb {
  padding-block: var(--sp-s);
  border-bottom: 1px solid var(--clr-border);
  background: var(--clr-bg-nav);
}

.wiki-breadcrumb-inner {
  display: flex;
  align-items: center;
  gap: var(--sp-xs);
  flex-wrap: wrap;
  font-size: 0.8rem;
  color: var(--clr-text-muted);
}

.wiki-breadcrumb-inner a {
  color: var(--clr-accent-blue);
  transition: color var(--dur) var(--ease-out);
}

.wiki-breadcrumb-inner a:hover { color: var(--clr-text); }

.wiki-breadcrumb-sep { opacity: 0.4; }

.wiki-breadcrumb-current { color: var(--clr-text); }

/* ── 42. WIKI ARTICLE LAYOUT ────────────────────────────────── */
.wiki-article-section { padding-block: var(--sp-xl); }

.wiki-article-layout {
  display: grid;
  grid-template-columns: 1fr 280px;
  gap: var(--sp-xl);
  align-items: start;
}

/* ── 43. WIKI ARTICLE MAIN COLUMN ───────────────────────────── */
.wiki-article-header {
  display: flex;
  flex-direction: column;
  gap: var(--sp-s);
  padding-bottom: var(--sp-l);
  border-bottom: 1px solid var(--clr-border);
  margin-bottom: var(--sp-l);
}

.wiki-article-category {
  display: inline-flex;
  align-items: center;
  gap: var(--sp-xs);
  font-size: 0.7rem;
  font-weight: var(--fw-bold);
  text-transform: uppercase;
  letter-spacing: 0.12em;
  width: fit-content;
  padding: 3px var(--sp-s);
  border-radius: var(--radius-pill);
  border: 1px solid currentColor;
}

.wiki-article-category svg { width: 12px; height: 12px; }

/* Reuse badge colour classes from wiki grid */
.wiki-article-category.badge-characters { color: var(--clr-accent-pink);  border-color: rgba(244,184,206,0.5);  background: rgba(244,184,206,0.08); }
.wiki-article-category.badge-items      { color: var(--clr-accent-blue);  border-color: rgba(184,212,244,0.5);  background: rgba(184,212,244,0.08); }
.wiki-article-category.badge-systems    { color: var(--clr-accent-white); border-color: rgba(245,245,245,0.3);  background: rgba(245,245,245,0.05); }
.wiki-article-category.badge-bestiary   { color: #c8b4f4;                 border-color: rgba(200,180,244,0.5);  background: rgba(200,180,244,0.08); }
.wiki-article-category.badge-locations  { color: #b4f4c8;                 border-color: rgba(180,244,200,0.5);  background: rgba(180,244,200,0.08); }
.wiki-article-category.badge-events     { color: #f4d4b4;                 border-color: rgba(244,212,180,0.5);  background: rgba(244,212,180,0.08); }

.wiki-article-title {
  font-size: clamp(1.8rem, 5vw, 3rem);
  font-weight: var(--fw-bold);
  line-height: 1.1;
  color: var(--clr-text);
}

.wiki-article-subtitle {
  font-size: 1rem;
  color: var(--clr-accent-blue);
  font-weight: var(--fw-semibold);
}

.wiki-article-lead {
  font-size: 1.05rem;
  color: var(--clr-text-muted);
  line-height: 1.8;
  max-width: 70ch;
}

/* Article body prose */
.wiki-article-body {
  display: flex;
  flex-direction: column;
  gap: var(--sp-l);
}

.wiki-section-block {
  display: flex;
  flex-direction: column;
  gap: var(--sp-s);
}

.wiki-section-heading {
  font-size: 1.1rem;
  font-weight: var(--fw-bold);
  color: var(--clr-text);
  padding-bottom: var(--sp-xs);
  border-bottom: 1px solid var(--clr-border);
  display: flex;
  align-items: center;
  gap: var(--sp-xs);
}

.wiki-section-heading svg { width: 16px; height: 16px; color: var(--clr-accent-pink); flex-shrink: 0; }

.wiki-article-body p {
  font-size: 0.95rem;
  color: var(--clr-text-muted);
  line-height: 1.8;
}

.wiki-article-body p + p { margin-top: var(--sp-xs); }

.wiki-article-body strong { color: var(--clr-text); font-weight: var(--fw-semibold); }

.wiki-article-body em { color: var(--clr-accent-pink); font-style: italic; }

/* Pull quote / notable quote box */
.wiki-quote-box {
  border-left: 3px solid var(--clr-accent-pink);
  padding: var(--sp-s) var(--sp-m);
  background: rgba(244,184,206,0.05);
  border-radius: 0 var(--radius-s) var(--radius-s) 0;
}

.wiki-quote-box blockquote {
  font-size: 1rem;
  font-style: italic;
  color: var(--clr-text);
  line-height: 1.6;
}

.wiki-quote-box cite {
  display: block;
  margin-top: var(--sp-xs);
  font-size: 0.8rem;
  font-style: normal;
  color: var(--clr-accent-pink);
  font-weight: var(--fw-semibold);
}

/* Spoiler warning banner */
.wiki-spoiler-banner {
  display: flex;
  align-items: center;
  gap: var(--sp-s);
  padding: var(--sp-s) var(--sp-m);
  background: rgba(244,212,180,0.08);
  border: 1px solid rgba(244,212,180,0.3);
  border-radius: var(--radius-s);
  font-size: 0.85rem;
  color: #f4d4b4;
}

.wiki-spoiler-banner svg { width: 16px; height: 16px; flex-shrink: 0; }

/* Related entries links */
.wiki-related-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(180px, 1fr));
  gap: var(--sp-s);
}

.wiki-related-card {
  background: var(--clr-bg-card);
  border: 1px solid var(--clr-border);
  border-radius: var(--radius-s);
  padding: var(--sp-s);
  display: flex;
  flex-direction: column;
  gap: 4px;
  cursor: pointer;
  transition: border-color var(--dur) var(--ease-out), translate 0.2s var(--ease-out);
}

.wiki-related-card:hover {
  border-color: var(--clr-accent-pink);
  translate: 0 -2px;
}

.wiki-related-label {
  font-size: 0.65rem;
  font-weight: var(--fw-bold);
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: var(--clr-text-muted);
}

.wiki-related-title {
  font-size: 0.9rem;
  font-weight: var(--fw-bold);
  color: var(--clr-text);
  line-height: 1.2;
}

.wiki-related-sub {
  font-size: 0.75rem;
  color: var(--clr-accent-blue);
}

/* ── 44. WIKI ARTICLE SIDEBAR ───────────────────────────────── */
.wiki-article-sidebar {
  position: sticky;
  top: calc(80px + var(--sp-m));
  display: flex;
  flex-direction: column;
  gap: var(--sp-m);
}

/* Info card (key facts) */
.wiki-info-card {
  background: var(--clr-bg-card);
  border: 1px solid var(--clr-border);
  border-radius: var(--radius-m);
  overflow: hidden;
}

.wiki-info-card-portrait {
  width: 100%;
  aspect-ratio: 1;
  background: linear-gradient(135deg, #2a2a2a 0%, #1a1a1a 100%);
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--clr-border);
  overflow: hidden;
  border-bottom: 1px solid var(--clr-border);
}

.wiki-info-card-portrait img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.wiki-info-card-portrait svg { width: 48px; height: 48px; }

.wiki-info-card-name {
  padding: var(--sp-s) var(--sp-m) var(--sp-xs);
  font-size: 1.05rem;
  font-weight: var(--fw-bold);
  color: var(--clr-text);
}

.wiki-info-card-sub {
  padding: 0 var(--sp-m) var(--sp-s);
  font-size: 0.8rem;
  color: var(--clr-accent-blue);
  font-weight: var(--fw-semibold);
  border-bottom: 1px solid var(--clr-border);
}

.wiki-info-rows {
  display: flex;
  flex-direction: column;
}

.wiki-info-row {
  display: grid;
  grid-template-columns: 40% 1fr;
  gap: var(--sp-xs);
  padding: var(--sp-xs) var(--sp-m);
  border-bottom: 1px solid var(--clr-border);
  font-size: 0.8rem;
}

.wiki-info-row:last-child { border-bottom: none; }

.wiki-info-row-label {
  color: var(--clr-text-muted);
  font-weight: var(--fw-semibold);
}

.wiki-info-row-value { color: var(--clr-text); }

/* Contents / on-this-page card */
.wiki-toc-card {
  background: var(--clr-bg-card);
  border: 1px solid var(--clr-border);
  border-radius: var(--radius-m);
  overflow: hidden;
}

.wiki-toc-header {
  padding: var(--sp-s) var(--sp-m);
  border-bottom: 1px solid var(--clr-border);
  font-size: 0.7rem;
  font-weight: var(--fw-bold);
  text-transform: uppercase;
  letter-spacing: 0.12em;
  color: var(--clr-text-muted);
}

.wiki-toc-list {
  padding: var(--sp-s) var(--sp-m);
  display: flex;
  flex-direction: column;
  gap: 6px;
}

.wiki-toc-item {
  font-size: 0.85rem;
  color: var(--clr-accent-blue);
  cursor: pointer;
  transition: color var(--dur) var(--ease-out);
  display: flex;
  align-items: center;
  gap: 6px;
}

.wiki-toc-item::before {
  content: '';
  display: block;
  width: 4px;
  height: 4px;
  border-radius: 50%;
  background: currentColor;
  flex-shrink: 0;
  opacity: 0.5;
}

.wiki-toc-item:hover { color: var(--clr-accent-pink); }

/* ── 45. WIKI ARTICLE RESPONSIVE ────────────────────────────── */
@media (max-width: 900px) {
  .wiki-article-layout {
    grid-template-columns: 1fr;
  }

  .wiki-article-sidebar {
    position: static;
    order: -1; /* sidebar above body on mobile */
  }

  .wiki-info-card-portrait {
    aspect-ratio: 2 / 1;
  }
}

@media (max-width: 479px) {
  .wiki-related-grid { grid-template-columns: 1fr 1fr; }
  .wiki-article-title { font-size: 1.6rem; }
}


/* ══════════════════════════════════════════════════════════════
   BLOG ARTICLE PAGES  (sections 46 – 49)
   ══════════════════════════════════════════════════════════════ */

/* ── 46. BLOG ARTICLE BREADCRUMB & HEADER ───────────────────── */
.blog-article-header {
  padding-block: var(--sp-xl) var(--sp-l);
  border-bottom: 1px solid var(--clr-border);
}

.blog-article-meta-row {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: var(--sp-s);
  margin-bottom: var(--sp-m);
}

.blog-post-type-badge {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-size: 0.68rem;
  font-weight: var(--fw-bold);
  text-transform: uppercase;
  letter-spacing: 0.12em;
  padding: 3px var(--sp-s);
  border-radius: var(--radius-pill);
  border: 1px solid currentColor;
}

.blog-post-type-badge svg { width: 11px; height: 11px; }

.badge-type-text   { color: var(--clr-accent-white); border-color: rgba(245,245,245,0.35); background: rgba(245,245,245,0.07); }
.badge-type-photo  { color: var(--clr-accent-blue);  border-color: rgba(184,212,244,0.4);  background: rgba(184,212,244,0.07); }
.badge-type-quote  { color: var(--clr-accent-pink);  border-color: rgba(244,184,206,0.4);  background: rgba(244,184,206,0.07); }
.badge-type-link   { color: var(--clr-accent-blue);  border-color: rgba(184,212,244,0.4);  background: rgba(184,212,244,0.07); }
.badge-type-audio  { color: var(--clr-accent-pink);  border-color: rgba(244,184,206,0.4);  background: rgba(244,184,206,0.07); }
.badge-type-video  { color: var(--clr-accent-blue);  border-color: rgba(184,212,244,0.4);  background: rgba(184,212,244,0.07); }

.blog-article-date {
  font-size: 0.8rem;
  color: var(--clr-text-muted);
}

.blog-article-title {
  font-size: clamp(1.6rem, 5vw, 2.8rem);
  font-weight: var(--fw-bold);
  line-height: 1.15;
  color: var(--clr-text);
  max-width: 20ch;
  margin-bottom: var(--sp-s);
}

.blog-article-tags {
  display: flex;
  flex-wrap: wrap;
  gap: var(--sp-xs);
}

.blog-article-tag {
  font-size: 0.75rem;
  font-weight: var(--fw-semibold);
  color: var(--clr-accent-blue);
  border: 1px solid rgba(184,212,244,0.25);
  border-radius: var(--radius-pill);
  padding: 2px var(--sp-xs);
  transition: color var(--dur) var(--ease-out), border-color var(--dur) var(--ease-out);
}

.blog-article-tag::before { content: '#'; }
.blog-article-tag:hover { color: var(--clr-accent-pink); border-color: rgba(244,184,206,0.35); }

/* ── 47. BLOG ARTICLE LAYOUT ────────────────────────────────── */
.blog-article-section { padding-block: var(--sp-xl); }

.blog-article-layout {
  display: grid;
  grid-template-columns: 1fr 260px;
  gap: var(--sp-xl);
  align-items: start;
}

/* ── 48. BLOG ARTICLE BODY PROSE ────────────────────────────── */
.blog-prose {
  display: flex;
  flex-direction: column;
  gap: var(--sp-m);
  font-size: 1rem;
  color: var(--clr-text-muted);
  line-height: 1.85;
  max-width: 68ch;
}

.blog-prose h2 {
  font-size: 1.25rem;
  font-weight: var(--fw-bold);
  color: var(--clr-text);
  margin-top: var(--sp-s);
  padding-bottom: var(--sp-xs);
  border-bottom: 1px solid var(--clr-border);
}

.blog-prose h3 {
  font-size: 1rem;
  font-weight: var(--fw-bold);
  color: var(--clr-text);
}

.blog-prose strong { color: var(--clr-text); font-weight: var(--fw-semibold); }

.blog-prose em { color: var(--clr-accent-pink); font-style: italic; }

.blog-prose a {
  color: var(--clr-accent-blue);
  text-decoration: underline;
  text-underline-offset: 3px;
  transition: color var(--dur) var(--ease-out);
}

.blog-prose a:hover { color: var(--clr-accent-pink); }

.blog-prose hr {
  border: none;
  border-top: 1px solid var(--clr-border);
  margin-block: var(--sp-s);
}

.blog-prose ul,
.blog-prose ol {
  padding-left: var(--sp-m);
  display: flex;
  flex-direction: column;
  gap: 6px;
}

.blog-prose ul { list-style: disc; }
.blog-prose ol { list-style: decimal; }

/* Image within prose */
.blog-prose-image {
  width: 100%;
  border-radius: var(--radius-m);
  overflow: hidden;
  background: var(--clr-bg-card);
  border: 1px solid var(--clr-border);
}

.blog-prose-image img { width: 100%; height: auto; display: block; }

.blog-prose-image-placeholder {
  width: 100%;
  aspect-ratio: 16 / 9;
  display: flex;
  align-items: center;
  justify-content: center;
  background: linear-gradient(135deg, #2a2a2a 0%, #1a1a1a 100%);
  color: var(--clr-border);
}

.blog-prose-image-placeholder svg { width: 40px; height: 40px; }

.blog-image-caption {
  padding: var(--sp-xs) var(--sp-s);
  font-size: 0.8rem;
  color: var(--clr-text-muted);
  text-align: center;
  font-style: italic;
  border-top: 1px solid var(--clr-border);
}

/* Quote post — large display quote */
.blog-display-quote {
  border-left: 4px solid var(--clr-accent-pink);
  padding: var(--sp-m) var(--sp-l);
  background: rgba(244,184,206,0.05);
  border-radius: 0 var(--radius-m) var(--radius-m) 0;
}

.blog-display-quote blockquote {
  font-size: clamp(1.1rem, 2.5vw, 1.6rem);
  font-style: italic;
  color: var(--clr-text);
  line-height: 1.5;
}

.blog-display-quote cite {
  display: block;
  margin-top: var(--sp-s);
  font-size: 0.9rem;
  font-style: normal;
  color: var(--clr-accent-pink);
  font-weight: var(--fw-semibold);
}

/* Link post card */
.blog-link-embed {
  display: flex;
  align-items: center;
  gap: var(--sp-m);
  padding: var(--sp-m);
  background: rgba(184,212,244,0.05);
  border: 1px solid rgba(184,212,244,0.2);
  border-radius: var(--radius-m);
  transition: border-color var(--dur) var(--ease-out);
}

.blog-link-embed:hover { border-color: var(--clr-accent-blue); }

.blog-link-embed-icon {
  width: 48px;
  height: 48px;
  border-radius: var(--radius-s);
  background: var(--clr-border);
  flex-shrink: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--clr-accent-blue);
}

.blog-link-embed-icon svg { width: 22px; height: 22px; }

.blog-link-embed-text { display: flex; flex-direction: column; gap: 4px; overflow: hidden; }

.blog-link-embed-title {
  font-size: 1rem;
  font-weight: var(--fw-bold);
  color: var(--clr-text);
}

.blog-link-embed-desc {
  font-size: 0.85rem;
  color: var(--clr-text-muted);
}

.blog-link-embed-url {
  font-size: 0.75rem;
  color: var(--clr-accent-blue);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

/* Audio post player */
.blog-audio-banner {
  position: relative;
  width: 100%;
  aspect-ratio: 16 / 9;
  background: linear-gradient(135deg, #2a2a2a 0%, #111 100%);
  border-radius: var(--radius-m);
  overflow: hidden;
  display: flex;
  align-items: center;
  justify-content: center;
  margin-bottom: var(--sp-xs);
}

.blog-audio-banner img {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  opacity: 0.4;
}

.blog-audio-banner-placeholder {
  color: var(--clr-border);
  position: relative;
}

.blog-audio-banner-placeholder svg { width: 56px; height: 56px; }

.blog-audio-info { display: flex; flex-direction: column; gap: 4px; margin-bottom: var(--sp-xs); }

.blog-audio-track-title { font-size: 1.1rem; font-weight: var(--fw-bold); color: var(--clr-text); }

.blog-audio-track-artist { font-size: 0.9rem; color: var(--clr-accent-pink); font-weight: var(--fw-semibold); }

.blog-audio-player audio {
  width: 100%;
  height: 36px;
  filter: invert(1) hue-rotate(180deg) brightness(0.8);
  border-radius: var(--radius-s);
}

/* Video embed */
.blog-video-embed {
  position: relative;
  width: 100%;
  aspect-ratio: 16 / 9;
  background: #000;
  border-radius: var(--radius-m);
  overflow: hidden;
}

.blog-video-embed iframe {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  border: none;
}

/* ── 49. BLOG ARTICLE SIDEBAR ───────────────────────────────── */
.blog-article-sidebar {
  position: sticky;
  top: calc(80px + var(--sp-m));
  display: flex;
  flex-direction: column;
  gap: var(--sp-m);
}

.blog-sidebar-card {
  background: var(--clr-bg-card);
  border: 1px solid var(--clr-border);
  border-radius: var(--radius-m);
  overflow: hidden;
}

.blog-sidebar-header {
  padding: var(--sp-s) var(--sp-m);
  border-bottom: 1px solid var(--clr-border);
  font-size: 0.7rem;
  font-weight: var(--fw-bold);
  text-transform: uppercase;
  letter-spacing: 0.12em;
  color: var(--clr-text-muted);
}

.blog-sidebar-body {
  padding: var(--sp-m);
  display: flex;
  flex-direction: column;
  gap: var(--sp-s);
}

.blog-sidebar-avatar {
  width: 56px;
  height: 56px;
  border-radius: 50%;
  object-fit: contain;
}

.blog-sidebar-name { font-size: 0.95rem; font-weight: var(--fw-bold); color: var(--clr-text); }

.blog-sidebar-handle { font-size: 0.8rem; color: var(--clr-accent-pink); }

.blog-sidebar-bio { font-size: 0.85rem; color: var(--clr-text-muted); line-height: 1.6; }

/* Related posts */
.blog-related-list {
  display: flex;
  flex-direction: column;
}

.blog-related-item {
  display: flex;
  flex-direction: column;
  gap: 4px;
  padding: var(--sp-s) var(--sp-m);
  border-bottom: 1px solid var(--clr-border);
  transition: background var(--dur) var(--ease-out);
  cursor: pointer;
}

.blog-related-item:last-child { border-bottom: none; }

.blog-related-item:hover { background: rgba(255,255,255,0.02); }

.blog-related-item-type {
  font-size: 0.65rem;
  font-weight: var(--fw-bold);
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: var(--clr-text-muted);
}

.blog-related-item-title {
  font-size: 0.85rem;
  font-weight: var(--fw-semibold);
  color: var(--clr-text);
  line-height: 1.3;
  transition: color var(--dur) var(--ease-out);
}

.blog-related-item:hover .blog-related-item-title { color: var(--clr-accent-pink); }

.blog-related-item-date { font-size: 0.75rem; color: var(--clr-text-muted); }

/* ── 50. BLOG & WIKI ARTICLE RESPONSIVE ─────────────────────── */
@media (max-width: 900px) {
  .blog-article-layout { grid-template-columns: 1fr; }
  .blog-article-sidebar { position: static; }
}

@media (max-width: 767px) {
  .blog-article-title { max-width: none; }
  .wiki-article-layout { grid-template-columns: 1fr; }
  .wiki-article-sidebar { position: static; }
}

@media (max-width: 479px) {
  .blog-display-quote { padding: var(--sp-s); }
  .blog-link-embed { flex-direction: column; align-items: flex-start; }
}


/* ── WIKI HERO LORE QUOTE (missed in original append) ───────── */
.wiki-hero-lore {
  max-width: 68ch;
  font-size: 0.95rem;
  color: var(--clr-text-muted);
  line-height: 1.8;
  border-left: 3px solid var(--clr-accent-pink);
  padding-left: var(--sp-m);
  text-align: left;
  font-style: italic;
  opacity: 0.85;
}
