/* --- Dance card shell */
.dance-card {
	max-width: var(--max-content);
	margin: 0 auto;
	background: var(--color-surface);
	border: 1px solid var(--color-border);
	border-radius: var(--radius-sm);
	padding: var(--space-xl);
	box-shadow: var(--shadow-subtle);
}

/* --- Section headings */
.dance-card section {
	margin-bottom: var(--space-lg);
}

.dance-card h2 {
	font-size: var(--text-sm);
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.07em;
	color: var(--color-text-muted);
	margin-bottom: var(--space-sm);
	border-bottom: 1px solid var(--color-border);
	padding-bottom: var(--space-xs);
}
.dance-header {
	margin-bottom: var(--space-lg);
	padding-bottom: var(--space-md);
	border-bottom: 2px solid var(--color-border);
}

.dance-header-top {
	display: flex;
	align-items: center;
	gap: var(--space-md);
	flex-wrap: wrap;
	margin-bottom: var(--space-xs);
}

.dance-title {
	font-size: var(--text-xl);
	font-weight: 700;
	margin: 0;
}

.dance-alternate-title {
	font-size: var(--text-md);
	font-weight: 400;
	font-style: italic;
	color: var(--color-text-muted);
	margin: var(--space-xs) 0 0;
}

.dance-alternate-title-title {
	font-style: normal;
	font-weight: 700;
	color: var(--color-text);
}

.dance-meta {
	font-size: var(--text-sm);
	color: var(--color-text-muted);
	margin: 0;
}

.dance-meta .author {
	margin-right: var(--space-xs);
}

.dance-formation {
	font-size: var(--text-sm);
	color: var(--color-text-muted);
	margin: var(--space-xs) 0 0;
}

.formation-note {
	font-style: italic;
}
.tune-inline {
	font-size: var(--text-sm);
	color: var(--color-text-muted);
	margin: calc(-1 * var(--space-sm)) 0 var(--space-lg);
}

.tune-title {
	font-style: italic;
	color: var(--color-text);
}

.tune-detail::before {
	content: " · ";
	color: var(--color-text-muted);
}

.tune-detail:first-child::before {
	content: none;
}

.tune-sep {
	color: var(--color-text-muted);
}

.tunes-table {
	width: 100%;
	border-collapse: collapse;
	font-size: var(--text-sm);
}

.tunes-table th {
	text-align: left;
	font-weight: 600;
	padding: var(--space-xs) var(--space-sm);
	border-bottom: 1px solid var(--color-border);
	color: var(--color-text-muted);
}

.tunes-table td {
	padding: var(--space-xs) var(--space-sm);
	vertical-align: top;
}

.tunes-table tbody tr:nth-child(even) {
	background: #f5f5f3;
}
.choreo-sections {
	display: flex;
	flex-direction: column;
	gap: var(--space-md);
}

.choreo-section {
	display: grid;
	grid-template-columns: 3rem 1fr;
	gap: var(--space-sm);
	align-items: baseline;
}

.section-label {
	font-size: var(--text-sm);
	font-variant: small-caps;
	font-weight: 700;
	letter-spacing: 0.06em;
	color: var(--color-text-muted);
	margin: 0;
	white-space: nowrap;
}

.section-description {
	margin: 0;
	line-height: 1.5;
}

.figure-list {
	list-style: none;
	margin: 0;
	padding: 0;
	display: flex;
	flex-direction: column;
	gap: 4px;
}

.figure {
	display: grid;
	grid-template-columns: 3rem 1fr 2.5rem;
	align-items: baseline;
	gap: var(--space-sm);
}

.figure-description {
	line-height: 1.45;
}

.figure-bars {
	font-size: var(--text-sm);
	color: var(--color-text-muted);
	font-variant-numeric: tabular-nums;
	text-align: right;
	white-space: nowrap;
}

.figure-beats {
	font-size: var(--text-sm);
	color: var(--color-text-muted);
	font-variant-numeric: tabular-nums;
	text-align: right;
	white-space: nowrap;
}
.background-section p,
.background-section li {
	color: var(--color-text-muted);
	margin-bottom: 0.5em;
}

.background-section p:last-child,
.background-section li:last-child {
	margin-bottom: 0;
}

.background-section ul,
.background-section ol {
	padding-left: var(--space-lg);
	margin-bottom: var(--space-sm);
}

.teaching-notes-section blockquote,
.background-section blockquote {
	font-style: italic;
	border-left: 2px solid var(--color-border);
	margin: 0.25em 0 0.5em var(--space-md);
	padding-left: var(--space-md);
	color: var(--color-text-muted);
}

.teaching-notes-section blockquote p,
.background-section blockquote p {
	margin-bottom: 0.25em;
}

.teaching-notes-section blockquote p:last-child,
.background-section blockquote p:last-child {
	margin-bottom: 0;
}

.teaching-notes-section p,
.teaching-notes-section li {
	color: var(--color-text-muted);
	margin-bottom: 0.5em;
}

.teaching-notes-section p:last-child,
.teaching-notes-section li:last-child {
	margin-bottom: 0;
}

.teaching-notes-section ul,
.teaching-notes-section ol {
	padding-left: var(--space-lg);
	margin-bottom: var(--space-sm);
}
/* ============================================================
   print-styles-core.njk — @media print styles for dance cards
   and shared elements; included by base.njk + print-base.njk
   ============================================================ */

@media print {

.no-print { display: none !important; }

body, main {
	font-family: Georgia, 'Times New Roman', serif;
	font-size: 10pt;
	line-height: 1.4;
	color: #000;
	background: #fff;
	margin: 0;
	padding: 0;
	max-width: none;
}

main { padding: 0; }

a { color: #000; text-decoration: none; }

a[href]:after { content: none !important; }

.dance-card {
	max-width: none;
	border: none;
	box-shadow: none;
	padding: 0;
	background: #fff;
}

.dance-header {
	margin-bottom: 12pt;
	padding-bottom: 8pt;
	border-bottom: 1.5pt solid #000;
}

.dance-header-top {
	display: flex;
	align-items: baseline;
	gap: 10pt;
}

.dance-title {
	font-size: 18pt;
	font-weight: bold;
	margin: 0;
	line-height: 1.2;
}

.dance-type-badge {
	font-size: 8pt;
	font-weight: bold;
	padding: 1pt 5pt;
	border: 1pt solid #000;
	border-radius: 999pt;
	background: none !important;
	color: #000 !important;
	text-transform: lowercase;
	letter-spacing: 0.03em;
}

.dance-meta {
	font-size: 9pt;
	color: #333;
	margin: 4pt 0 0;
}

.dance-card h2 {
	font-size: 7.5pt;
	text-transform: uppercase;
	letter-spacing: 0.07em;
	color: #444;
	border-bottom: 0.5pt solid #aaa;
	padding-bottom: 2pt;
	margin-bottom: 6pt;
	margin-top: 14pt;
	font-family: -apple-system, BlinkMacSystemFont, "Helvetica Neue", Arial, sans-serif;
}

.tunes-table {
	width: 100%;
	border-collapse: collapse;
	font-size: 9pt;
}

.tunes-table th {
	font-weight: bold;
	padding: 2pt 4pt;
	border-bottom: 0.75pt solid #000;
	text-align: left;
}

.tunes-table td {
	padding: 2pt 4pt;
	vertical-align: top;
}

.tunes-table tbody tr:nth-child(even) { background: none; }

.choreo-sections { display: block; }

.choreo-section {
	display: grid;
	grid-template-columns: 2.5rem 1fr;
	gap: 6pt;
	align-items: baseline;
	page-break-inside: avoid;
	break-inside: avoid;
	margin-bottom: 5pt;
}

.section-label {
	font-size: 8pt;
	font-variant: small-caps;
	font-weight: bold;
	letter-spacing: 0.06em;
	color: #333;
	margin: 0;
	font-family: -apple-system, BlinkMacSystemFont, "Helvetica Neue", Arial, sans-serif;
}

.section-description {
	font-size: 10pt;
	margin: 0;
	line-height: 1.4;
}

.teaching-notes-section {
	page-break-inside: avoid;
	break-inside: avoid;
}

.teaching-notes-section p,
.background-section p {
	font-size: 9pt;
	color: #333;
	margin: 0 0 5pt;
}

.teaching-notes-section p:last-child,
.background-section p:last-child { margin-bottom: 0; }

.teaching-notes-section li,
.background-section li { font-size: 9pt; color: #333; }

.teaching-notes-section blockquote,
.background-section blockquote {
	font-style: italic;
	border-left: 0.5pt solid #aaa;
	margin: 3pt 0 3pt 12pt;
	padding-left: 8pt;
}

.teaching-notes-section blockquote p,
.background-section blockquote p { margin-bottom: 2pt; }

.teaching-notes-section,
.background-section { hyphens: auto; }

p, li { widows: 2; orphans: 2; }

* { box-shadow: none !important; }

.print-only { display: block; }

/* Program table — shared by program page and print page */
.program-table {
	font-size: 7pt;
	table-layout: fixed;
	width: 100%;
}

.program-table th,
.program-table td {
	padding: 2pt 3pt;
	overflow: hidden;
	text-overflow: ellipsis;
	white-space: nowrap;
}

.program-table th { font-size: 6pt; white-space: nowrap; }

.program-table td:nth-child(1),
.program-table td:nth-child(2),
.program-table td:nth-child(4),
.program-table td:nth-child(7),
.program-table td:nth-child(8) {
	white-space: normal;
	overflow-wrap: break-word;
	word-break: break-word;
}

.program-table .col-title       { width: 16%; }
.program-table .col-choreographer { width: 14%; }
.program-table .col-year        { width: 5%; }
.program-table .col-formation   { width: 14%; }
.program-table .col-key         { width: 11%; }
.program-table .col-meter       { width: 5%; }
.program-table .col-tune        { width: 14%; }
.program-table .col-composer    { width: 13%; }
.program-table .col-source      { width: 8%; }

.program-table th:first-child,
.program-table td:first-child { position: static; box-shadow: none; }

.program-table-actions { display: none !important; }

.dots-section { display: none !important; }

/* Program header — used by main program page and print page */
.program-title { font-size: 20pt; font-weight: bold; margin: 0 0 4pt; }
.program-meta { font-size: 10pt; color: #333; margin: 0 0 18pt; }

/* Program TOC — shared between main page and print page */
.program-section-label {
	font-size: 7.5pt;
	text-transform: uppercase;
	letter-spacing: 0.07em;
	color: #444;
	border-bottom: 0.5pt solid #aaa;
	padding-bottom: 2pt;
	margin-bottom: 5pt;
	margin-top: 14pt;
	font-family: -apple-system, BlinkMacSystemFont, "Helvetica Neue", Arial, sans-serif;
}

.program-dance-list {
	list-style: none;
	padding: 0;
	margin: 0;
	counter-reset: program-dance;
}

.program-dance-item {
	counter-increment: program-dance;
	display: grid;
	grid-template-columns: 1.5rem 1fr;
	gap: 0 6pt;
	background: none;
	border: none;
	box-shadow: none;
	padding: 2pt 0;
}

.program-dance-item::before {
	content: counter(program-dance) ".";
	font-size: 9pt;
	color: #555;
	padding-top: 0;
}

.program-dance-main {
	display: flex;
	align-items: baseline;
	gap: 6pt;
}

.program-dance-link { font-size: 10pt; font-weight: normal; color: #000; flex: 1; }
.program-dance-author { font-size: 8.5pt; color: #555; }
.program-dance-note {
	font-size: 8.5pt;
	color: #555;
	font-style: italic;
	margin-top: 0;
	grid-column: 2;
}

}
/* ============================================================
   print-base.njk — screen-preview styles applied to .print-content-area
   Makes the preview look like the printed output on screen.
   Sheet music is hidden since it's not relevant to print layout.
   ============================================================ */

@media screen {
	.dots-section { display: none; }

	.print-content-area {
		font-family: Georgia, 'Times New Roman', serif;
		font-size: 10pt;
		line-height: 1.4;
		color: #000;
	}

	.print-content-area .dance-type-badge {
		background: none !important;
		color: #000 !important;
		border: 1px solid #000;
		border-radius: 999px;
		padding: 1pt 5pt;
	}

	.print-content-area .dance-header {
		border-bottom: 1.5pt solid #000;
	}

	.print-content-area .dance-title {
		font-size: 18pt;
	}

	.print-content-area .dance-meta {
		font-size: 9pt;
		color: #333;
	}

	.print-content-area .dance-card h2 {
		font-size: 7.5pt;
		color: #444;
		border-bottom: 0.5pt solid #aaa;
	}

	.print-content-area .tunes-table {
		font-size: 9pt;
	}

	.print-content-area .section-label {
		font-size: 8pt;
		font-variant: small-caps;
		color: #333;
	}

	.print-content-area .section-description {
		font-size: 10pt;
	}

	.print-content-area .teaching-notes-section p,
	.print-content-area .background-section p {
		font-size: 9pt;
		color: #333;
	}

	/* Program TOC preview — strip card chrome, apply print-like typography */
	.print-content-area .program-title { font-size: 20pt; font-weight: bold; margin: 0 0 4pt; }
	.print-content-area .program-meta { font-size: 10pt; color: #333; margin: 0 0 18pt; }

	.print-content-area .program-section-label {
		font-size: 7.5pt;
		text-transform: uppercase;
		letter-spacing: 0.07em;
		color: #444;
		border-bottom: 0.5pt solid #aaa;
		padding-bottom: 2pt;
		margin: 14pt 0 5pt;
		font-family: -apple-system, BlinkMacSystemFont, "Helvetica Neue", Arial, sans-serif;
	}

	.print-content-area .program-dance-list {
		list-style: none;
		padding: 0;
		margin: 0;
		display: block;
		counter-reset: program-dance;
	}

	.print-content-area .program-dance-item {
		counter-increment: program-dance;
		display: grid;
		grid-template-columns: 1.5rem 1fr;
		gap: 0 6pt;
		background: none;
		border: none;
		box-shadow: none;
		border-radius: 0;
		padding: 2pt 0;
		transition: none;
	}

	.print-content-area .program-dance-item::before {
		content: counter(program-dance) ".";
		font-size: 9pt;
		color: #555;
		padding-top: 0;
		align-self: start;
	}

	.print-content-area .program-dance-item:hover { border-color: transparent; }

	.print-content-area .program-dance-main {
		display: flex;
		align-items: baseline;
		gap: 6pt;
	}

	.print-content-area .program-dance-link { font-size: 10pt; font-weight: normal; color: #000; text-decoration: none; flex: 1; }
	.print-content-area .program-dance-link:hover { color: #000; }
	.print-content-area .program-dance-author { font-size: 8.5pt; color: #555; }
	.print-content-area .program-dance-note { font-size: 8.5pt; color: #555; font-style: italic; grid-column: 2; }
}