:root {
  --bg: #0d1820;
  --ink: #f7fbfb;
  --muted: #bdd0cf;
  --panel: #12242c;
  --panel-2: #17323a;
  --line: rgba(255,255,255,.14);
  --gold: #e7c36b;
  --mint: #8fd8c7;
  --rose: #d79a9e;
  --shadow: 0 22px 70px rgba(0,0,0,.34);
  font-family: Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", Arial, sans-serif;
}
* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  margin: 0;
  color: var(--ink);
  background:
    radial-gradient(circle at 18% 0%, rgba(231,195,107,.16), transparent 30%),
    linear-gradient(135deg, #081219 0%, #132c33 46%, #28352d 100%);
  min-height: 100vh;
}
a { color: inherit; }
img { max-width: 100%; display: block; }
.site-header {
  position: sticky;
  top: 0;
  z-index: 10;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 18px;
  padding: 14px clamp(18px, 4vw, 56px);
  background: rgba(8,18,25,.78);
  border-bottom: 1px solid var(--line);
  backdrop-filter: blur(14px);
}
.brand { display: inline-flex; align-items: center; gap: 12px; text-decoration: none; font-weight: 800; }
.brand img { width: 44px; height: 44px; }
nav { display: flex; gap: 12px; flex-wrap: wrap; justify-content: flex-end; }
nav a { color: var(--muted); text-decoration: none; font-size: 14px; }
main { width: min(1180px, calc(100% - 28px)); margin: 0 auto; }
.hero {
  display: grid;
  grid-template-columns: minmax(0, 1.05fr) minmax(260px, .75fr);
  gap: clamp(22px, 4vw, 54px);
  align-items: center;
  min-height: calc(100vh - 86px);
  padding: clamp(28px, 6vw, 74px) 0 36px;
}
.article-hero { min-height: auto; padding-top: 34px; }
.eyebrow { color: var(--gold); text-transform: uppercase; letter-spacing: 0; font-size: 13px; font-weight: 800; }
h1 { font-size: clamp(40px, 7vw, 86px); line-height: .98; margin: 10px 0 18px; letter-spacing: 0; }
.article-hero h1 { font-size: clamp(34px, 5vw, 62px); }
.lead { color: var(--muted); font-size: clamp(18px, 2vw, 22px); line-height: 1.7; max-width: 760px; }
.hero-actions { display: flex; gap: 12px; flex-wrap: wrap; margin-top: 26px; }
.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 46px;
  padding: 12px 18px;
  border-radius: 8px;
  text-decoration: none;
  font-weight: 800;
  border: 1px solid var(--line);
}
.btn.primary { background: var(--gold); color: #172018; border-color: transparent; }
.btn.ghost { color: var(--ink); background: rgba(255,255,255,.06); }
.btn.full { width: 100%; }
.portrait-figure {
  margin: 0;
  padding: 10px;
  width: min(100%, 420px);
  background: linear-gradient(180deg, rgba(255,255,255,.1), rgba(255,255,255,.03));
  border: 1px solid var(--line);
  border-radius: 8px;
  box-shadow: var(--shadow);
}
.portrait-figure img { width: 400px; height: 600px; max-width: 100%; aspect-ratio: 2 / 3; object-fit: cover; border-radius: 6px; background: #10222a; }
figcaption { color: var(--muted); font-size: 12px; margin-top: 10px; line-height: 1.5; }
.stats, .content-grid, .audio-grid, .related-grid, .channels {
  display: grid;
  gap: 14px;
}
.stats { grid-template-columns: repeat(4, 1fr); margin: 18px 0 30px; }
.stats div, .answer-card, .service-box, .listen-panel, .faq-section, .related, .toc-section {
  background: rgba(18,36,44,.78);
  border: 1px solid var(--line);
  border-radius: 8px;
  box-shadow: var(--shadow);
}
.stats div { padding: 18px; }
.stats strong { display: block; color: var(--gold); font-size: 28px; }
.stats span { color: var(--muted); }
.toc-section { padding: clamp(18px, 3vw, 28px); margin: 20px 0; }
.section-head { display: flex; justify-content: space-between; align-items: center; gap: 16px; flex-wrap: wrap; margin-bottom: 16px; }
.section-head h2 { margin: 0; font-size: 28px; }
.section-head a { color: var(--gold); font-weight: 800; }
.toc-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: 10px;
}
.toc-grid a, .related-grid a, .channels a, .audio-card {
  min-height: 56px;
  padding: 13px 14px;
  border-radius: 8px;
  border: 1px solid var(--line);
  background: rgba(255,255,255,.045);
  text-decoration: none;
}
.toc-grid a { display: flex; gap: 10px; align-items: center; color: var(--ink); }
.toc-grid span { color: var(--gold); font-weight: 800; font-size: 12px; }
.breadcrumb { display: flex; gap: 10px; flex-wrap: wrap; color: var(--muted); padding-top: 24px; font-size: 14px; }
.breadcrumb a { color: var(--gold); text-decoration: none; }
.article-shell { padding-bottom: 34px; }
.answer-card, .faq-section, .related, .listen-panel { padding: clamp(18px, 3vw, 30px); margin: 20px 0; }
.answer-card h2, .faq-section h2, .related h2, .listen-panel h2 { margin-top: 0; }
.answer-card p, .content-grid p, details p, footer p { color: var(--muted); line-height: 1.75; }
.answer-card a, .content-grid a { color: var(--gold); font-weight: 800; }
.content-grid { grid-template-columns: minmax(0, 1fr) 310px; margin: 20px 0; }
.content-grid > div, .service-box { padding: clamp(18px, 3vw, 30px); }
.content-grid li { margin: 12px 0; color: var(--muted); line-height: 1.7; }
.service-box { align-self: start; }
.image-strip {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 14px;
  margin: 20px 0;
}
.image-strip a { width: min(100%, 400px); overflow: hidden; border-radius: 8px; border: 1px solid var(--line); background: var(--panel); }
.image-strip img { width: 400px; height: 600px; max-width: 100%; aspect-ratio: 2 / 3; object-fit: cover; }
details { border-top: 1px solid var(--line); padding: 15px 0; }
details:first-of-type { border-top: 0; }
summary { cursor: pointer; font-weight: 800; color: var(--ink); }
.audio-grid { grid-template-columns: repeat(3, 1fr); }
.audio-card { display: grid; gap: 6px; color: var(--muted); }
.audio-card strong { color: var(--gold); }
.related-grid { grid-template-columns: repeat(auto-fit, minmax(180px, 1fr)); }
.related-grid a { display: grid; gap: 6px; color: var(--ink); }
.related-grid span, .channels span { color: var(--muted); font-size: 13px; }
.channels { grid-template-columns: repeat(3, 1fr); margin: 20px 0 44px; }
.channels a { display: grid; gap: 6px; }
footer {
  width: min(1180px, calc(100% - 28px));
  margin: 0 auto;
  border-top: 1px solid var(--line);
  padding: 28px 0 40px;
  color: var(--muted);
}
footer a { color: var(--gold); }
@media (max-width: 820px) {
  .site-header { position: static; align-items: flex-start; flex-direction: column; }
  nav { justify-content: flex-start; }
  .hero, .content-grid { grid-template-columns: 1fr; min-height: auto; }
  .stats, .audio-grid, .channels, .image-strip { grid-template-columns: 1fr; }
  h1 { font-size: 42px; }
  .portrait-figure { max-width: 420px; margin: 0 auto; }
}
