/* Shared styles for content/landing pages (/about, /learn, /teachers, articles).
   Reuses the CRT shell, topbar and footer from home.css; this adds readable
   long-form prose typography and a few on-brand content components. */

.content-nav a { margin-left: 4px; }

main.page { max-width: 760px; padding-top: 8px; padding-bottom: 56px; }

/* breadcrumb */
.crumbs { font-size: 12px; letter-spacing: 1px; color: var(--dim); padding: 22px 0 4px; }
.crumbs a { color: var(--neon); }
.crumbs a:hover { color: var(--gold); }

/* page head */
.page h1 {
  font-size: clamp(28px, 6vw, 52px); font-weight: 900; letter-spacing: 2px; line-height: 1.05;
  color: var(--neon); text-shadow: 0 0 10px var(--neon), 0 0 28px rgba(0,240,255,.4);
  margin: 14px 0 10px; word-break: break-word;
}
.page h1 span { color: var(--neon2); text-shadow: 0 0 10px var(--neon2); }
.lede { color: var(--gold); font-size: 16px; line-height: 1.6; margin-bottom: 8px; }

/* prose */
.prose { color: #c2d6ef; line-height: 1.7; font-size: 15.5px; }
.prose h2 {
  color: var(--gold); letter-spacing: 1px; font-size: 22px; margin: 36px 0 12px;
  text-shadow: 0 0 8px rgba(255,207,58,.4); padding-top: 6px;
}
.prose h3 { color: var(--neon); letter-spacing: 1px; font-size: 17px; margin: 24px 0 8px; }
.prose p { margin: 0 0 14px; }
.prose ul, .prose ol { margin: 0 0 16px; padding-left: 22px; }
.prose li { margin: 6px 0; }
.prose b, .prose strong { color: #eaf3ff; }
.prose a { color: var(--neon); text-shadow: 0 0 6px rgba(0,240,255,.4); border-bottom: 1px dotted currentColor; }
.prose a:hover { color: var(--gold); }
.prose hr { border: none; border-top: 1px solid rgba(0,240,255,.15); margin: 32px 0; }
.prose code {
  background: rgba(0,240,255,.07); border: 1px solid rgba(0,240,255,.2);
  padding: 1px 6px; border-radius: 4px; color: var(--neon); font-size: 13.5px;
}

/* a call-to-play card pointing at a game */
.play-card {
  display: flex; flex-wrap: wrap; align-items: center; gap: 16px;
  border: 1px solid rgba(57,255,136,.35); background: rgba(57,255,136,.04);
  box-shadow: 0 0 24px rgba(57,255,136,.08);
  padding: 18px 20px; margin: 26px 0;
}
.play-card .pc-body { flex: 1 1 240px; }
.play-card .pc-kicker { color: var(--green); font-size: 11px; letter-spacing: 2px; text-transform: uppercase; }
.play-card h3 { color: var(--neon); letter-spacing: 2px; font-size: 20px; margin: 4px 0 6px; text-shadow: 0 0 8px var(--neon); }
.play-card p { color: #9fb6d6; font-size: 13.5px; line-height: 1.55; margin: 0; }
.play-card .pc-cta {
  border: 2px solid var(--green); color: var(--green); padding: 12px 26px; white-space: nowrap;
  letter-spacing: 2px; font-weight: bold; text-shadow: 0 0 8px var(--green); transition: all .12s;
}
.play-card .pc-cta:hover { background: var(--green); color: #001016; box-shadow: 0 0 22px var(--green); }

/* link grid (learn hub / related) */
.tiles { display: grid; grid-template-columns: repeat(2, 1fr); gap: 16px; margin: 24px 0 8px; }
.tile {
  border: 1px solid rgba(0,240,255,.22); background: rgba(0,240,255,.03);
  padding: 20px; transition: all .12s; display: block;
}
.tile:hover { border-color: var(--neon); box-shadow: 0 0 22px rgba(0,240,255,.18); }
.tile h3 { color: var(--neon); letter-spacing: 1px; font-size: 17px; margin: 0 0 6px; text-shadow: 0 0 6px var(--neon); }
.tile p { color: #9fb6d6; font-size: 13px; line-height: 1.5; margin: 0; }
.tile .tag-mini { color: var(--gold); font-size: 11px; letter-spacing: 1px; }

/* music figures (staff, notes, rhythm) drawn with the Bravura SMuFL font */
.fig {
  margin: 26px 0; border: 1px solid rgba(0,240,255,0.18); background: rgba(0,240,255,0.025);
  padding: 20px 16px 12px; text-align: center;
}
.fig svg { width: 100%; max-width: 440px; height: auto; display: block; margin: 0 auto; }
.fig figcaption { color: var(--dim); font-size: 12px; letter-spacing: 0.5px; margin-top: 10px; line-height: 1.5; }
.staff-line { stroke: #c2d2ee; stroke-width: 1.5; }
.staff-clef { fill: var(--neon); }
.staff-note { fill: var(--gold); }
.staff-label { fill: #cfe7ff; font-family: var(--font); font-size: 13px; font-weight: bold; text-anchor: middle; }
.staff-glyph { fill: var(--gold); }
.staff-glyph-label { fill: #9fb6d6; font-family: var(--font); font-size: 12px; text-anchor: middle; }

/* FAQ */
.faq { margin: 8px 0; }
.faq details {
  border: 1px solid rgba(0,240,255,.18); background: rgba(0,240,255,.02);
  padding: 4px 16px; margin: 10px 0;
}
.faq summary {
  cursor: pointer; color: #eaf3ff; font-weight: bold; letter-spacing: .5px;
  padding: 12px 0; list-style: none;
}
.faq summary::-webkit-details-marker { display: none; }
.faq summary::before { content: "▸ "; color: var(--neon); }
.faq details[open] summary::before { content: "▾ "; }
.faq details p { color: #9fb6d6; line-height: 1.65; font-size: 14px; padding: 0 0 14px; margin: 0; }

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