:root {
  --bg: #f6f4f3;
  --ink: #1e2257;
  --brand: #2e337c;
  --accent: #ca3464;
  --paper: #ffffff;
}
* { box-sizing: border-box; }
body {
  margin: 0;
  background: var(--bg);
  color: var(--ink);
  font-family: "Source Sans 3", sans-serif;
}
.wrap { width: min(980px, 92vw); margin: 1.5rem auto 2rem; }
.topbar {
  display: flex;
  flex-wrap: wrap;
  gap: 0.6rem;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 1rem;
}
h1 { margin: 0.3rem 0; color: var(--brand); font-size: clamp(1.4rem, 3vw, 2rem); }
.controls { display: flex; gap: 0.5rem; flex-wrap: wrap; }
.btn {
  border: 0;
  border-radius: 6px;
  padding: 0.5rem 0.8rem;
  text-decoration: none;
  font-weight: 700;
  cursor: pointer;
  background: var(--brand);
  color: #fff;
}
.btn.alt { background: var(--accent); }
.sheet {
  background: var(--paper);
  border: 1px solid rgba(46, 51, 124, 0.2);
  border-radius: 8px;
  padding: 1.1rem;
}
.script {
  font-family: "Courier New", Courier, monospace;
  font-size: 15px;
  line-height: 1.45;
}
.scene {
  margin: 1rem 0 0.6rem;
  padding: 0.25rem 0;
  border-top: 1px solid #ddd;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.03em;
}
.profile {
  margin: 0.8rem 0;
  padding: 0.6rem;
  background: #f5f6ff;
  border-left: 4px solid var(--brand);
}
.action { margin: 0.25rem 0; }
.cue {
  margin: 0.8rem 0 0.1rem;
  text-align: center;
  font-weight: 700;
  letter-spacing: 0.08em;
}
.dialogue {
  width: min(560px, 92%);
  margin: 0.1rem auto 0.5rem;
}
.note {
  margin: 0.3rem 0 0.6rem;
  font-style: italic;
}
.raw { display: none; }

@media print {
  body { background: #fff; }
  .topbar, .controls, .btn, .back-link { display: none !important; }
  .wrap { width: 100%; margin: 0; }
  .sheet { border: 0; padding: 0; }
  .script { font-size: 12pt; }
  @page { margin: 0.6in; }
}
