/* =============================================================
   BC Fund Training — Theme Styles
   Palette: BC maroon #8A100B, gold #B29146, cream #F5EFE4, ink #1A1A1A
   ============================================================= */

:root {
	--bc-maroon: #8A100B;
	--bc-maroon-dark: #5E0A07;
	--bc-gold: #B29146;
	--bc-gold-soft: #E9DBB6;
	--bc-cream: #F7F1E3;
	--bc-paper: #FBF8F1;
	--bc-ink: #1A1A1A;
	--bc-ink-soft: #4A4A4A;
	--bc-line: #E4DECB;
	--bc-success: #2F7D4F;
	--bc-warn: #B8761C;
	--bc-error: #A61E1A;
	--bc-radius: 10px;
	--bc-radius-lg: 18px;
	--bc-shadow: 0 2px 8px rgba(138,16,11,0.06), 0 8px 24px rgba(26,26,26,0.04);
	--bc-shadow-lg: 0 4px 16px rgba(138,16,11,0.10), 0 16px 48px rgba(26,26,26,0.08);
}

* { box-sizing: border-box; }

/* Global: honor the HTML [hidden] attribute even when a more specific
   display rule (e.g. .bcfund-btn { display: inline-flex }) would win.
   This ensures JS that toggles `el.hidden = true/false` actually hides. */
[hidden] { display: none !important; }

html, body {
	margin: 0;
	padding: 0;
	background: var(--bc-paper);
	color: var(--bc-ink);
	font-family: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, Helvetica, Arial, sans-serif;
	font-size: 16px;
	line-height: 1.55;
	-webkit-font-smoothing: antialiased;
}

a { color: var(--bc-maroon); text-decoration: none; }
a:hover { color: var(--bc-maroon-dark); text-decoration: underline; }

h1, h2, h3, h4, h5 {
	font-family: 'Playfair Display', Georgia, serif;
	color: var(--bc-ink);
	margin: 0 0 0.5em;
	line-height: 1.2;
}

.bcfund-container { max-width: 1180px; margin: 0 auto; padding: 0 28px; }
.bcfund-main { min-height: 60vh; }
.bcfund-section { padding: 56px 28px 72px; max-width: 1180px; }
.bcfund-eyebrow {
	text-transform: uppercase;
	letter-spacing: 0.12em;
	font-size: 12px;
	font-weight: 700;
	color: var(--bc-gold);
	margin: 0 0 14px;
}

.bcfund-h1 { font-size: 44px; font-weight: 700; margin-bottom: 18px; }
.bcfund-h2 { font-size: 30px; font-weight: 700; margin-bottom: 20px; }
.bcfund-h3 { font-size: 22px; font-weight: 600; margin-bottom: 12px; }

.bcfund-lede { font-size: 19px; color: var(--bc-ink-soft); max-width: 68ch; margin: 0 0 28px; }

/* ======= HEADER ======= */
.bcfund-header {
	background: #fff;
	border-bottom: 1px solid var(--bc-line);
	position: sticky;
	top: 0;
	z-index: 40;
}
.bcfund-header-inner {
	display: flex;
	align-items: center;
	justify-content: space-between;
	padding: 14px 28px;
	gap: 24px;
}
.bcfund-brand { display: flex; align-items: center; gap: 12px; color: var(--bc-ink); text-decoration: none; }
.bcfund-brand:hover { text-decoration: none; }
.bcfund-brand-mark {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 40px; height: 40px;
	background: var(--bc-maroon);
	color: #fff;
	font-family: 'Playfair Display', Georgia, serif;
	font-weight: 700;
	font-size: 17px;
	border-radius: 8px;
	letter-spacing: 0.5px;
}
.bcfund-brand-text { display: flex; flex-direction: column; line-height: 1.1; }
.bcfund-brand-text strong { font-size: 15px; font-weight: 600; }
.bcfund-brand-text em { font-style: normal; font-size: 12px; color: var(--bc-gold); letter-spacing: 0.08em; text-transform: uppercase; }

.bcfund-menu { list-style: none; margin: 0; padding: 0; display: flex; gap: 24px; }
.bcfund-menu li a {
	display: inline-block;
	color: var(--bc-ink);
	font-weight: 500;
	font-size: 15px;
	padding: 8px 2px;
	border-bottom: 2px solid transparent;
	transition: border-color 0.15s, color 0.15s;
	text-decoration: none;
}
.bcfund-menu li a:hover { color: var(--bc-maroon); border-bottom-color: var(--bc-gold); }
.bcfund-menu .current_page_item a,
.bcfund-menu .current-menu-item a { color: var(--bc-maroon); border-bottom-color: var(--bc-maroon); }

/* ======= BUTTONS ======= */
.bcfund-btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	padding: 13px 22px;
	border: 0;
	border-radius: var(--bc-radius);
	font-family: inherit;
	font-weight: 600;
	font-size: 15px;
	line-height: 1;
	cursor: pointer;
	transition: background 0.15s, color 0.15s, transform 0.05s, box-shadow 0.15s;
	text-decoration: none;
	white-space: nowrap;
}
.bcfund-btn:hover { text-decoration: none; transform: translateY(-1px); }
.bcfund-btn:active { transform: translateY(0); }
.bcfund-btn:disabled { opacity: 0.45; cursor: not-allowed; transform: none; }
.bcfund-btn-primary { background: var(--bc-maroon); color: #fff; }
.bcfund-btn-primary:hover { background: var(--bc-maroon-dark); color: #fff; }
.bcfund-btn-ghost { background: transparent; color: var(--bc-maroon); border: 1px solid var(--bc-maroon); }
.bcfund-btn-ghost:hover { background: var(--bc-maroon); color: #fff; }
.bcfund-btn-outline { background: #fff; color: var(--bc-ink); border: 1px solid var(--bc-line); }
.bcfund-btn-outline:hover { border-color: var(--bc-maroon); color: var(--bc-maroon); }
.bcfund-btn-small { padding: 10px 16px; font-size: 14px; }

/* ======= FRONTEND VOICE PICKER ======= */
.bcfund-voice-picker-row { margin: 18px 0 4px; }
.bcfund-voice-picker-controls { display: flex; gap: 10px; align-items: center; }
.bcfund-voice-picker-controls .bcfund-text-input { flex: 1 1 auto; margin: 0; }
.bcfund-voice-picker-controls .bcfund-btn { flex: 0 0 auto; white-space: nowrap; }
.bcfund-voice-preview-status { display: block; margin-top: 6px; font-size: 13px; color: var(--bc-muted, #6b6b6b); min-height: 18px; }

/* ======= HERO ======= */
.bcfund-hero {
	background: linear-gradient(135deg, var(--bc-cream) 0%, #fff 60%);
	padding: 72px 28px 60px;
	border-bottom: 1px solid var(--bc-line);
}
.bcfund-hero-actions { display: flex; gap: 14px; flex-wrap: wrap; margin-top: 28px; }

/* ======= GRID HELPERS ======= */
.bcfund-grid-2 { display: grid; gap: 36px; grid-template-columns: 1fr 1fr; align-items: start; }
.bcfund-grid-3 { display: grid; gap: 24px; grid-template-columns: repeat(3, 1fr); }
@media (max-width: 860px) {
	.bcfund-grid-2, .bcfund-grid-3 { grid-template-columns: 1fr; }
}

/* ======= CARDS ======= */
.bcfund-card {
	background: #fff;
	border: 1px solid var(--bc-line);
	border-radius: var(--bc-radius-lg);
	padding: 26px 26px 22px;
	box-shadow: var(--bc-shadow);
}
.bcfund-card h3 {
	color: var(--bc-maroon);
	font-size: 21px;
	margin-bottom: 10px;
}

/* ======= IMPACT BAND ======= */
.bcfund-band {
	background: var(--bc-maroon);
	color: #fff;
	padding: 56px 28px;
}
.bcfund-band h2 { color: #fff; }
.bcfund-impact-grid {
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	gap: 22px;
	margin-top: 28px;
}
@media (max-width: 860px) { .bcfund-impact-grid { grid-template-columns: repeat(2, 1fr); } }
.bcfund-impact {
	background: rgba(255,255,255,0.08);
	padding: 22px 20px;
	border-radius: var(--bc-radius);
	border: 1px solid rgba(255,255,255,0.12);
}
.bcfund-impact .bcfund-amount {
	display: block;
	font-family: 'Playfair Display', Georgia, serif;
	font-size: 32px;
	font-weight: 700;
	color: var(--bc-gold);
	margin-bottom: 6px;
}
.bcfund-impact p { margin: 0; font-size: 15px; color: #fff; opacity: 0.92; }

/* ======= STEPS + LINK LIST ======= */
.bcfund-steps { padding-left: 20px; margin: 0 0 24px; }
.bcfund-steps li { margin-bottom: 10px; font-size: 16px; }
.bcfund-link-list { list-style: none; padding: 0; margin: 0; display: grid; gap: 14px; }
.bcfund-link-list a {
	display: block;
	padding: 18px 20px;
	background: #fff;
	border: 1px solid var(--bc-line);
	border-radius: var(--bc-radius);
	text-decoration: none;
	color: var(--bc-ink);
	transition: border-color 0.15s, box-shadow 0.15s;
}
.bcfund-link-list a:hover { border-color: var(--bc-maroon); box-shadow: var(--bc-shadow); color: var(--bc-ink); text-decoration: none; }
.bcfund-link-list strong { display: block; color: var(--bc-maroon); font-size: 17px; margin-bottom: 4px; }
.bcfund-link-list span { color: var(--bc-ink-soft); font-size: 14px; }

/* ======= SCENARIOS ======= */
.bcfund-scenario-grid {
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: 22px;
	margin-top: 20px;
}
@media (max-width: 860px) { .bcfund-scenario-grid { grid-template-columns: 1fr; } }
.bcfund-scenario-card {
	background: #fff;
	border: 1px solid var(--bc-line);
	border-radius: var(--bc-radius-lg);
	padding: 24px;
	display: flex;
	flex-direction: column;
	gap: 12px;
	box-shadow: var(--bc-shadow);
}
.bcfund-scenario-card-head {
	display: flex; justify-content: space-between; align-items: center;
	font-size: 13px;
}
.bcfund-diff-badge {
	display: inline-flex; padding: 4px 10px;
	border-radius: 99px; font-weight: 600; font-size: 12px;
	letter-spacing: 0.02em;
}
.bcfund-diff-easy   { background: #E7F3EC; color: var(--bc-success); }
.bcfund-diff-medium { background: #FCF2DC; color: var(--bc-warn); }
.bcfund-diff-hard   { background: #FBE3E1; color: var(--bc-error); }
.bcfund-gift-range { color: var(--bc-ink-soft); font-size: 13px; font-weight: 500; }
.bcfund-scenario-title { color: var(--bc-maroon); font-size: 22px; margin: 0; }
.bcfund-scenario-summary { color: var(--bc-ink-soft); margin: 0; }
.bcfund-scenario-details summary {
	cursor: pointer; font-weight: 600; color: var(--bc-ink);
	padding: 6px 0; list-style: none; user-select: none;
}
.bcfund-scenario-details summary::-webkit-details-marker { display: none; }
.bcfund-scenario-details summary::before { content: '▸ '; color: var(--bc-gold); display: inline-block; transition: transform 0.15s; }
.bcfund-scenario-details[open] summary::before { content: '▾ '; }
.bcfund-scenario-details ul { margin: 6px 0 0 18px; padding: 0; color: var(--bc-ink-soft); font-size: 14px; }
.bcfund-scenario-details li { margin-bottom: 6px; }

/* ======= QUESTIONS PAGE ======= */
.bcfund-questions { display: grid; gap: 28px; margin-top: 24px; }
.bcfund-question-group {
	background: #fff;
	border: 1px solid var(--bc-line);
	border-radius: var(--bc-radius-lg);
	padding: 22px 26px;
	box-shadow: var(--bc-shadow);
}
.bcfund-question-list { list-style: none; padding: 0; margin: 0; }
.bcfund-question-list li {
	display: flex; gap: 14px; align-items: flex-start;
	padding: 12px 0; border-bottom: 1px dashed var(--bc-line);
}
.bcfund-question-list li:last-child { border-bottom: 0; }
.bcfund-q-marker {
	flex: 0 0 auto;
	display: inline-flex; align-items: center; justify-content: center;
	width: 26px; height: 26px;
	background: var(--bc-gold-soft);
	color: var(--bc-maroon);
	border-radius: 99px;
	font-weight: 700;
	font-size: 14px;
}
.bcfund-q-text { color: var(--bc-ink); }
.bcfund-cta-band {
	margin-top: 40px;
	padding: 32px;
	background: var(--bc-cream);
	border: 1px solid var(--bc-gold-soft);
	border-radius: var(--bc-radius-lg);
	text-align: center;
}
.bcfund-cta-band h2 { margin-bottom: 16px; }

/* ======= TRAINING PAGE ======= */
.bcfund-notice {
	padding: 14px 18px; border-radius: var(--bc-radius);
	margin: 14px 0 28px; font-size: 15px;
}
.bcfund-notice-warn { background: #FFF4DD; color: #7a4a10; border: 1px solid #F2C97B; }

.bcfund-training-setup { margin-top: 20px; }
.bcfund-setup-help { color: var(--bc-ink-soft); font-size: 14px; margin: -6px 0 12px; }
.bcfund-preselect-banner {
	background: var(--bc-cream);
	border: 1px solid var(--bc-gold-soft);
	border-left: 4px solid var(--bc-maroon);
	border-radius: var(--bc-radius);
	padding: 12px 16px;
	margin: 0 0 24px;
	font-size: 14.5px;
	color: var(--bc-ink);
	line-height: 1.5;
}
.bcfund-preselect-banner strong { color: var(--bc-maroon); }
.bcfund-preselect-banner em { font-style: normal; font-weight: 600; }

.bcfund-recording-notice {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	font-size: 13px;
	color: var(--bc-ink-soft);
	background: var(--bc-paper);
	border: 1px solid var(--bc-line);
	border-radius: 99px;
	padding: 6px 14px;
	margin: 0 0 18px;
}

/* === Recording & Downloads block (frontend coaching report) === */
.bcfund-downloads-block {
	margin-top: 22px;
	padding: 20px 22px;
	background: #fff;
	border: 1px solid var(--bc-line);
	border-radius: var(--bc-radius-lg);
	box-shadow: var(--bc-shadow);
}
.bcfund-downloads-title {
	color: var(--bc-maroon);
	font-size: 19px;
	margin: 0 0 14px;
}
.bcfund-downloads-list {
	list-style: none;
	padding: 0;
	margin: 0;
	display: flex;
	flex-direction: column;
	gap: 10px;
}
.bcfund-downloads-list li {
	display: flex;
	align-items: center;
	gap: 10px;
}
.bcfund-downloads-player audio { width: 100%; max-width: 540px; }
.bcfund-downloads-uploading {
	color: var(--bc-ink-soft);
	font-style: italic;
	font-size: 14px;
	display: inline-flex;
	align-items: center;
	gap: 8px;
	padding: 8px 0;
}

/* New: side-by-side action row used by renderDownloadsBlock (2.8.0+) */
.bcfund-downloads-row {
	display: flex;
	flex-wrap: wrap;
	gap: 10px;
	align-items: center;
	margin-bottom: 12px;
}
#bcfund-downloads-player-host audio {
	width: 100%;
	max-width: 540px;
	display: block;
}

/* Front-end record-this-session toggle */
.bcfund-record-row {
	margin: 6px 0 24px;
	padding: 12px 14px;
	background: var(--bc-paper);
	border: 1px solid var(--bc-line);
	border-radius: var(--bc-radius);
}
.bcfund-record-toggle {
	display: flex;
	align-items: flex-start;
	gap: 10px;
	cursor: pointer;
	font-size: 14.5px;
}
.bcfund-record-toggle input[type="checkbox"] {
	margin-top: 3px;
	width: 18px; height: 18px;
	accent-color: var(--bc-maroon);
	flex: 0 0 auto;
}
.bcfund-record-label { display: flex; flex-direction: column; }
.bcfund-record-label strong { font-weight: 600; color: var(--bc-ink); }
.bcfund-record-help { color: var(--bc-ink-soft); font-size: 13px; margin-top: 2px; }

/* Hide the live transcript when the trainee opted out of showing it.
   Data is still collected; only the visual display is hidden. */
.bcfund-transcript.is-hidden { display: none !important; }
.bcfund-spinner-small {
	display: inline-block;
	width: 14px; height: 14px;
	border-radius: 99px;
	border: 2px solid var(--bc-gold-soft);
	border-top-color: var(--bc-maroon);
	animation: bcfundSpin 0.9s linear infinite;
}

/* === Focused scenario-start card (when ?scenario= deep-link lands here) === */
.bcfund-back-link {
	display: inline-flex;
	align-items: center;
	gap: 4px;
	font-size: 14px;
	color: var(--bc-ink-soft);
	text-decoration: none;
	margin-bottom: 16px;
	padding: 6px 0;
	font-weight: 500;
}
.bcfund-back-link:hover { color: var(--bc-maroon); text-decoration: none; }

.bcfund-scenario-start {
	background: #fff;
	border: 1px solid var(--bc-line);
	border-radius: var(--bc-radius-lg);
	box-shadow: var(--bc-shadow-lg);
	padding: 36px 38px 32px;
	max-width: 760px;
	margin: 0 auto;
}
@media (max-width: 700px) {
	.bcfund-scenario-start { padding: 24px 22px; }
}

.bcfund-scenario-start-title {
	font-family: 'Playfair Display', Georgia, serif;
	font-size: 38px;
	font-weight: 700;
	color: var(--bc-maroon);
	margin: 6px 0 14px;
	line-height: 1.15;
}
.bcfund-scenario-start-meta {
	display: flex; gap: 12px; align-items: center; flex-wrap: wrap;
	margin-bottom: 16px;
}
.bcfund-scenario-start-summary {
	font-size: 17px;
	line-height: 1.55;
	color: var(--bc-ink);
	margin: 0 0 20px;
}
.bcfund-scenario-start .bcfund-scenario-details {
	background: var(--bc-paper);
	border: 1px solid var(--bc-line);
	border-radius: var(--bc-radius);
	padding: 12px 16px;
	margin-bottom: 28px;
}
.bcfund-scenario-start .bcfund-scenario-details summary {
	color: var(--bc-maroon);
	font-weight: 600;
	font-size: 14.5px;
}
.bcfund-scenario-start .bcfund-scenario-details ul {
	margin: 10px 0 4px 20px;
	color: var(--bc-ink-soft);
	font-size: 14.5px;
}
.bcfund-scenario-start .bcfund-scenario-details li { margin-bottom: 6px; }

.bcfund-scenario-start-form {
	border-top: 1px solid var(--bc-line);
	padding-top: 24px;
	margin-top: 8px;
}
.bcfund-form-label {
	display: block;
	font-family: 'Inter', sans-serif;
	text-transform: uppercase;
	letter-spacing: 0.08em;
	font-size: 12px;
	font-weight: 700;
	color: var(--bc-gold);
	margin: 18px 0 4px;
}
.bcfund-form-label:first-child { margin-top: 0; }
.bcfund-form-optional {
	font-weight: 500;
	letter-spacing: 0;
	color: var(--bc-ink-soft);
	text-transform: none;
}
.bcfund-form-help {
	color: var(--bc-ink-soft);
	font-size: 13px;
	margin: 0 0 8px;
}
.bcfund-scenario-start-form .bcfund-text-input {
	max-width: none;
	margin-bottom: 12px;
}
.bcfund-scenario-start-form .bcfund-difficulty-row {
	margin-bottom: 28px;
	gap: 18px;
}
.bcfund-scenario-start-btn {
	width: 100%;
	padding: 16px 22px;
	font-size: 16px;
}
.bcfund-text-input {
	display: block;
	width: 100%;
	max-width: 420px;
	padding: 12px 14px;
	font-family: inherit;
	font-size: 15px;
	border: 1px solid var(--bc-line);
	border-radius: var(--bc-radius);
	background: #fff;
	margin-bottom: 28px;
}
.bcfund-text-input:focus { outline: 2px solid var(--bc-gold); border-color: var(--bc-gold); }
.bcfund-scenario-picker {
	display: grid; grid-template-columns: repeat(2, 1fr); gap: 12px;
	margin-bottom: 28px;
}
@media (max-width: 860px) { .bcfund-scenario-picker { grid-template-columns: 1fr; } }
.bcfund-scenario-chip {
	text-align: left;
	padding: 14px 18px;
	background: #fff;
	border: 2px solid var(--bc-line);
	border-radius: var(--bc-radius);
	cursor: pointer;
	font-family: inherit;
	transition: border-color 0.15s, background 0.15s;
}
.bcfund-scenario-chip:hover { border-color: var(--bc-gold); }
.bcfund-scenario-chip.is-selected { border-color: var(--bc-maroon); background: #FFF8F7; }
.bcfund-scenario-chip .bcfund-chip-title { display: block; font-weight: 600; color: var(--bc-ink); font-size: 16px; margin-bottom: 3px; }
.bcfund-scenario-chip .bcfund-chip-meta { display: block; color: var(--bc-ink-soft); font-size: 13px; }

.bcfund-difficulty-row {
	display: flex; gap: 22px; flex-wrap: wrap; margin-bottom: 28px;
}
.bcfund-difficulty-row label {
	display: inline-flex; align-items: center; gap: 8px;
	font-size: 15px; cursor: pointer;
}

/* ======= CHAT ======= */
.bcfund-chat-wrap {
	display: grid;
	grid-template-columns: 320px 1fr;
	gap: 24px;
	margin-top: 20px;
	align-items: start;
}
@media (max-width: 980px) { .bcfund-chat-wrap { grid-template-columns: 1fr; } }

.bcfund-chat-sidebar {
	background: #fff;
	border: 1px solid var(--bc-line);
	border-radius: var(--bc-radius-lg);
	padding: 22px;
	box-shadow: var(--bc-shadow);
	position: sticky; top: 84px;
}
.bcfund-active-scenario h3 { color: var(--bc-maroon); font-size: 22px; margin: 4px 0 8px; }
.bcfund-active-scenario p  { color: var(--bc-ink-soft); font-size: 14px; margin: 0 0 14px; }
.bcfund-active-meta { display: flex; gap: 10px; align-items: center; margin-bottom: 18px; }
.bcfund-objectives h4 {
	font-family: 'Inter', sans-serif; text-transform: uppercase; letter-spacing: 0.1em;
	font-size: 11px; color: var(--bc-gold); margin: 18px 0 8px;
}
.bcfund-objectives ul { padding-left: 18px; margin: 0; }
.bcfund-objectives li { font-size: 13.5px; color: var(--bc-ink-soft); margin-bottom: 6px; }
.bcfund-session-actions { display: flex; flex-direction: column; gap: 10px; margin-top: 22px; }

.bcfund-chat-main {
	background: #fff;
	border: 1px solid var(--bc-line);
	border-radius: var(--bc-radius-lg);
	box-shadow: var(--bc-shadow);
	display: flex; flex-direction: column;
	min-height: 560px;
}

/* ======= MODE TOGGLE ======= */
.bcfund-mode-toggle {
	display: flex;
	gap: 6px;
	padding: 12px 14px;
	border-bottom: 1px solid var(--bc-line);
	background: var(--bc-paper);
	border-radius: var(--bc-radius-lg) var(--bc-radius-lg) 0 0;
	align-items: center;
}
.bcfund-mode-btn {
	display: inline-flex;
	align-items: center;
	gap: 6px;
	padding: 8px 14px;
	font-family: inherit;
	font-size: 14px;
	font-weight: 600;
	color: var(--bc-ink-soft);
	background: #fff;
	border: 1px solid var(--bc-line);
	border-radius: 99px;
	cursor: pointer;
	transition: color 0.15s, background 0.15s, border-color 0.15s;
}
.bcfund-mode-btn:hover { color: var(--bc-maroon); border-color: var(--bc-gold); }
.bcfund-mode-btn.is-active {
	background: var(--bc-maroon);
	color: #fff;
	border-color: var(--bc-maroon);
}
.bcfund-mode-ico { font-size: 15px; line-height: 1; }
.bcfund-voice-warning {
	color: var(--bc-warn);
	font-size: 13px;
}

/* Mid-session transcript visibility toggle — lives in the same toolbar as the
   Text / Voice / Live mode buttons but pinned to the right edge. Looks like a
   mode chip but with subtler styling since it's a secondary control. */
.bcfund-transcript-toggle-btn {
	margin-left: auto; /* eat all remaining horizontal space → button hugs the right */
	order: 99;         /* belt-and-suspenders: stays last in the flex flow */
	display: inline-flex;
	align-items: center;
	gap: 6px;
	padding: 7px 12px;
	font-family: inherit;
	font-size: 13px;
	font-weight: 500;
	color: var(--bc-ink-soft);
	background: #fff;
	border: 1px solid var(--bc-line);
	border-radius: 99px;
	cursor: pointer;
	transition: color 0.15s, background 0.15s, border-color 0.15s;
}
.bcfund-transcript-toggle-btn:hover {
	color: var(--bc-maroon);
	border-color: var(--bc-gold);
}
.bcfund-transcript-toggle-btn.is-active {
	color: var(--bc-maroon);
	border-color: var(--bc-gold);
	background: var(--bc-paper);
}

/* ======= VOICE STAGE ======= */
.bcfund-voice-stage {
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	padding: 36px 20px 28px;
	border-bottom: 1px solid var(--bc-line);
	background: linear-gradient(135deg, #fff 0%, var(--bc-cream) 100%);
	gap: 18px;
}
.bcfund-avatar {
	position: relative;
	width: 130px; height: 130px;
	border-radius: 99px;
	background: linear-gradient(135deg, var(--bc-maroon), var(--bc-maroon-dark));
	color: #fff;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	box-shadow: 0 20px 50px rgba(138,16,11,0.25);
}
.bcfund-avatar-initials {
	font-family: 'Playfair Display', Georgia, serif;
	font-size: 52px;
	font-weight: 700;
	letter-spacing: 1px;
	color: var(--bc-gold);
}
.bcfund-avatar-pulse {
	position: absolute;
	inset: -10px;
	border-radius: 99px;
	border: 3px solid var(--bc-gold);
	opacity: 0;
	pointer-events: none;
}
.bcfund-avatar.is-speaking .bcfund-avatar-pulse {
	animation: bcfundPulse 1.4s ease-out infinite;
}
@keyframes bcfundPulse {
	0%   { transform: scale(1);   opacity: 0.65; }
	70%  { transform: scale(1.25); opacity: 0;    }
	100% { transform: scale(1.25); opacity: 0;    }
}
.bcfund-voice-status {
	font-size: 15px;
	color: var(--bc-ink-soft);
	font-weight: 500;
	min-height: 20px;
}
.bcfund-mic-btn {
	width: 72px; height: 72px;
	border-radius: 99px;
	border: 0;
	background: var(--bc-maroon);
	color: #fff;
	cursor: pointer;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	box-shadow: 0 6px 20px rgba(138,16,11,0.30);
	transition: background 0.15s, transform 0.1s, box-shadow 0.15s;
}
.bcfund-mic-btn:hover  { background: var(--bc-maroon-dark); }
.bcfund-mic-btn:active { transform: scale(0.96); }
.bcfund-mic-btn.is-listening {
	background: #C21F1A;
	animation: bcfundMicPulse 1.2s ease-in-out infinite;
}
@keyframes bcfundMicPulse {
	0%   { box-shadow: 0 0 0 0 rgba(194,31,26,0.55); }
	70%  { box-shadow: 0 0 0 18px rgba(194,31,26,0);  }
	100% { box-shadow: 0 0 0 0 rgba(194,31,26,0);     }
}
.bcfund-interim {
	min-height: 22px;
	max-width: 600px;
	text-align: center;
	font-size: 14px;
	color: var(--bc-ink-soft);
	font-style: italic;
	margin-top: 4px;
}
.bcfund-voice-help {
	max-width: 520px;
	margin: 4px 0 0;
	text-align: center;
	font-size: 13px;
	color: var(--bc-ink-soft);
	line-height: 1.5;
}

/* ======= LIVE VOICE (REALTIME) STAGE ======= */
.bcfund-live-stage {
	display: flex;
	flex-direction: column;
	align-items: center;
	padding: 26px 20px 28px;
	border-bottom: 1px solid var(--bc-line);
	background: linear-gradient(135deg, #fff 0%, var(--bc-cream) 100%);
	gap: 18px;
}
.bcfund-live-header {
	display: flex; align-items: center; gap: 10px;
	font-size: 14px;
	color: var(--bc-ink-soft);
	font-weight: 600;
}
.bcfund-live-dot {
	width: 10px; height: 10px; border-radius: 99px;
	background: var(--bc-line);
	display: inline-block;
}
.bcfund-live-stage .bcfund-live-avatar.is-speaking ~ .bcfund-live-header,
.bcfund-live-stage .bcfund-live-header:has(~ .bcfund-live-avatar.is-speaking) {
	/* no-op — handled via JS class on live-avatar */
}
.bcfund-live-stage .bcfund-live-header .bcfund-live-dot {
	background: var(--bc-line);
}
.bcfund-live-stage:has(.bcfund-live-avatar.is-speaking) .bcfund-live-dot,
.bcfund-live-stage[data-active="true"] .bcfund-live-dot {
	background: #D63D3D;
	box-shadow: 0 0 0 0 rgba(214,61,61,0.45);
	animation: bcfundLivePulse 1.2s ease-out infinite;
}
@keyframes bcfundLivePulse {
	0%   { box-shadow: 0 0 0 0 rgba(214,61,61,0.55); }
	70%  { box-shadow: 0 0 0 10px rgba(214,61,61,0);  }
	100% { box-shadow: 0 0 0 0 rgba(214,61,61,0);     }
}
.bcfund-live-timer {
	font-family: 'Inter', monospace;
	font-variant-numeric: tabular-nums;
	font-size: 13px;
	color: var(--bc-ink-soft);
	margin-left: 6px;
	padding: 2px 10px;
	border: 1px solid var(--bc-line);
	border-radius: 99px;
	background: #fff;
	transition: background 0.2s, color 0.2s, border-color 0.2s;
}
.bcfund-live-timer.is-warning {
	background: #FBE3E1;
	color: var(--bc-error);
	border-color: #F3B4AF;
	font-weight: 600;
	animation: bcfundTimerBlink 1s ease-in-out infinite;
}
@keyframes bcfundTimerBlink {
	0%, 100% { opacity: 1; }
	50%      { opacity: 0.6; }
}
.bcfund-live-avatar {
	position: relative;
	width: 150px; height: 150px;
	border-radius: 99px;
	background: linear-gradient(135deg, var(--bc-maroon), var(--bc-maroon-dark));
	color: #fff;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	box-shadow: 0 22px 58px rgba(138,16,11,0.28);
}
.bcfund-live-avatar .bcfund-avatar-initials {
	font-size: 60px;
}
.bcfund-live-avatar.is-speaking .bcfund-avatar-pulse {
	animation: bcfundPulse 1.4s ease-out infinite;
}
.bcfund-live-controls {
	display: flex; gap: 10px; flex-wrap: wrap; justify-content: center;
}
.bcfund-live-help {
	text-align: center;
	max-width: 520px;
	color: var(--bc-ink-soft);
	font-size: 14px;
	margin: 0;
}
.bcfund-transcript {
	padding: 22px;
	flex: 1; overflow-y: auto;
	max-height: 60vh;
	display: flex; flex-direction: column; gap: 14px;
}
.bcfund-msg { display: flex; gap: 12px; max-width: 88%; }
.bcfund-msg-avatar {
	flex: 0 0 auto;
	width: 34px; height: 34px; border-radius: 99px;
	display: inline-flex; align-items: center; justify-content: center;
	font-weight: 700; font-size: 13px; letter-spacing: 0.02em;
}
.bcfund-msg-body {
	padding: 12px 16px;
	border-radius: 14px;
	font-size: 15px; line-height: 1.5;
	white-space: pre-wrap;
}
.bcfund-msg-prospect { align-self: flex-start; }
.bcfund-msg-prospect .bcfund-msg-avatar { background: var(--bc-maroon); color: #fff; }
.bcfund-msg-prospect .bcfund-msg-body { background: var(--bc-cream); color: var(--bc-ink); border: 1px solid var(--bc-gold-soft); }

.bcfund-msg-trainee { align-self: flex-end; flex-direction: row-reverse; }
.bcfund-msg-trainee .bcfund-msg-avatar { background: var(--bc-gold); color: var(--bc-ink); }
.bcfund-msg-trainee .bcfund-msg-body { background: #F3F4F5; color: var(--bc-ink); border: 1px solid var(--bc-line); }

.bcfund-msg.is-typing .bcfund-msg-body { display: inline-flex; gap: 4px; padding: 14px 18px; }
.bcfund-msg.is-typing .bcfund-msg-body span {
	width: 7px; height: 7px; background: var(--bc-maroon); border-radius: 99px; opacity: 0.25;
	animation: bcfundBlink 1.2s infinite ease-in-out;
}
.bcfund-msg.is-typing .bcfund-msg-body span:nth-child(2) { animation-delay: 0.15s; }
.bcfund-msg.is-typing .bcfund-msg-body span:nth-child(3) { animation-delay: 0.3s; }
@keyframes bcfundBlink { 0%, 80%, 100% { opacity: 0.25; } 40% { opacity: 1; } }

.bcfund-chat-form {
	display: flex; gap: 12px;
	padding: 16px;
	border-top: 1px solid var(--bc-line);
	background: var(--bc-paper);
	border-radius: 0 0 var(--bc-radius-lg) var(--bc-radius-lg);
}
.bcfund-chat-form textarea {
	flex: 1;
	padding: 12px 14px;
	font-family: inherit;
	font-size: 15px;
	border: 1px solid var(--bc-line);
	border-radius: var(--bc-radius);
	resize: vertical;
	min-height: 46px;
	background: #fff;
}
.bcfund-chat-form textarea:focus { outline: 2px solid var(--bc-gold); border-color: var(--bc-gold); }

.bcfund-msg-error .bcfund-msg-body { background: #FBE3E1; color: var(--bc-error); border-color: #F3B4AF; }

/* ======= COACHING REPORT ======= */
.bcfund-coaching { margin-top: 20px; }
.bcfund-coaching-loading {
	text-align: center; padding: 60px 20px;
	background: #fff; border: 1px solid var(--bc-line); border-radius: var(--bc-radius-lg);
}
.bcfund-spinner {
	width: 42px; height: 42px; border-radius: 99px;
	border: 4px solid var(--bc-gold-soft); border-top-color: var(--bc-maroon);
	margin: 0 auto 16px;
	animation: bcfundSpin 0.9s linear infinite;
}
@keyframes bcfundSpin { to { transform: rotate(360deg); } }

.bcfund-report {
	background: #fff; border: 1px solid var(--bc-line); border-radius: var(--bc-radius-lg);
	padding: 32px; box-shadow: var(--bc-shadow);
}
.bcfund-score-row {
	display: flex; align-items: center; gap: 24px;
	padding-bottom: 22px; margin-bottom: 22px;
	border-bottom: 1px solid var(--bc-line);
}
.bcfund-score {
	flex: 0 0 auto;
	width: 88px; height: 88px; border-radius: 99px;
	background: linear-gradient(135deg, var(--bc-maroon), var(--bc-maroon-dark));
	color: #fff;
	display: flex; align-items: center; justify-content: center;
	font-family: 'Playfair Display', Georgia, serif;
	font-size: 36px; font-weight: 700;
	box-shadow: 0 10px 24px rgba(138,16,11,0.25);
}
.bcfund-score small { font-size: 13px; font-weight: 500; opacity: 0.8; margin-left: 2px; }
.bcfund-score-head h2 { margin: 0 0 4px; font-size: 24px; }
.bcfund-score-head p { margin: 0; color: var(--bc-ink-soft); }

.bcfund-report-section { margin-top: 26px; }
.bcfund-report-section h3 {
	color: var(--bc-maroon);
	font-size: 19px;
	padding-bottom: 6px;
	border-bottom: 2px solid var(--bc-gold-soft);
	margin-bottom: 14px;
}
.bcfund-report-section > ul { padding-left: 20px; margin: 0; }
.bcfund-report-section > p  { margin: 0 0 12px; color: var(--bc-ink); line-height: 1.6; }

/* Bullet lists */
.bcfund-bullets {
	list-style: none;
	padding: 0;
	margin: 0;
	display: grid;
	gap: 10px;
}
.bcfund-bullets li {
	position: relative;
	padding: 10px 14px 10px 34px;
	background: var(--bc-paper);
	border: 1px solid var(--bc-line);
	border-radius: var(--bc-radius);
	font-size: 15px;
	line-height: 1.55;
}
.bcfund-bullets li::before {
	content: '';
	position: absolute;
	top: 16px; left: 14px;
	width: 8px; height: 8px;
	border-radius: 99px;
	background: var(--bc-gold);
}
.bcfund-bullets-positive li { border-left: 3px solid var(--bc-success); }
.bcfund-bullets-positive li::before { background: var(--bc-success); }
.bcfund-bullets-practice li {
	background: var(--bc-cream);
	border-color: var(--bc-gold-soft);
	border-left: 3px solid var(--bc-maroon);
}
.bcfund-bullets-practice li::before { background: var(--bc-maroon); }

/* Labeled bullets (What happened / Try this) */
.bcfund-bullet-label {
	display: block;
	font-size: 11px;
	font-weight: 700;
	letter-spacing: 0.1em;
	text-transform: uppercase;
	color: var(--bc-ink-soft);
	margin-bottom: 4px;
}
.bcfund-bullet-label.bcfund-label-try { color: var(--bc-maroon); }
.bcfund-bullet-text { display: block; color: var(--bc-ink); }

/* Key learnings */
.bcfund-learning {
	background: #fff;
	border: 1px solid var(--bc-line);
	border-left: 4px solid var(--bc-gold);
	border-radius: var(--bc-radius);
	padding: 16px 18px 18px;
	margin-bottom: 14px;
}
.bcfund-learning-head {
	display: flex;
	align-items: center;
	gap: 12px;
	margin-bottom: 12px;
}
.bcfund-learning-head strong {
	color: var(--bc-maroon);
	font-size: 16px;
	font-weight: 600;
}
.bcfund-learning-num {
	flex: 0 0 auto;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 28px; height: 28px;
	background: var(--bc-maroon);
	color: #fff;
	border-radius: 99px;
	font-family: 'Playfair Display', Georgia, serif;
	font-weight: 700;
	font-size: 14px;
}

/* Missed messaging blocks */
.bcfund-missed {
	background: #fff;
	border: 1px solid var(--bc-line);
	border-left: 4px solid var(--bc-gold-soft);
	border-radius: var(--bc-radius);
	padding: 16px 18px;
	margin-bottom: 12px;
}
.bcfund-missed > strong {
	display: block;
	color: var(--bc-ink);
	font-size: 15.5px;
	font-weight: 600;
	margin-bottom: 10px;
}

/* Suggested rewrite */
.bcfund-rewrite {
	background: var(--bc-cream);
	border: 1px solid var(--bc-gold-soft);
	border-radius: var(--bc-radius);
	padding: 18px 20px;
	font-size: 15px;
}
.bcfund-rewrite .label { display: block; color: var(--bc-gold); text-transform: uppercase; letter-spacing: 0.08em; font-size: 11px; font-weight: 700; margin-top: 12px; margin-bottom: 4px; }
.bcfund-rewrite .label:first-child { margin-top: 0; }
.bcfund-rewrite .quote { font-style: italic; color: var(--bc-ink-soft); border-left: 3px solid var(--bc-line); padding-left: 12px; margin: 0 0 6px; }
.bcfund-rewrite .rewrite { color: var(--bc-ink); border-left: 3px solid var(--bc-maroon); padding-left: 12px; margin: 0; font-weight: 500; }
.bcfund-rewrite .why { color: var(--bc-ink-soft); font-size: 14px; margin: 0; }

.bcfund-tone-notes { color: var(--bc-ink-soft); font-size: 14.5px; margin: 10px 0 14px; }
.bcfund-practice h3 { color: var(--bc-maroon); }

.bcfund-tone {
	display: inline-flex; gap: 10px; align-items: center;
	padding: 8px 14px; border-radius: 99px;
	background: var(--bc-paper); border: 1px solid var(--bc-line);
	font-size: 14px; font-weight: 600; color: var(--bc-ink);
	margin-bottom: 10px;
}
.bcfund-tone.excellent { background: #E7F3EC; color: var(--bc-success); border-color: #BADBC3; }
.bcfund-tone.good { background: #F0F6E7; color: #4A7E2F; border-color: #CCE0B3; }
.bcfund-tone.developing { background: #FCF2DC; color: var(--bc-warn); border-color: #F2C97B; }
.bcfund-tone\.needs-work,
.bcfund-tone.needs-work { background: #FBE3E1; color: var(--bc-error); border-color: #F3B4AF; }

.bcfund-coaching-actions {
	display: flex; justify-content: space-between; gap: 14px;
	margin-top: 24px; flex-wrap: wrap;
	align-items: center;
}
.bcfund-coaching-actions-right {
	display: flex; gap: 12px; flex-wrap: wrap; margin-left: auto;
}

/* ==========================================================================
   PRINT / PDF EXPORT
   The trainee clicks "Download as PDF" → window.print() opens with these
   rules applied. Hides chrome, formats the report cleanly for paper.
   ========================================================================== */

.bcfund-print-header { display: none; } /* Hidden on screen; shown when printing. */

@media print {
	@page {
		size: Letter;
		margin: 0.6in 0.6in 0.7in 0.6in;
	}

	html, body {
		background: #fff !important;
		color: #1A1A1A !important;
		font-size: 11pt;
		-webkit-print-color-adjust: exact;
		print-color-adjust: exact;
	}

	/* Hide everything that isn't the report */
	.bcfund-header,
	.bcfund-footer,
	.bcfund-mode-toggle,
	.bcfund-voice-stage,
	.bcfund-live-stage,
	.bcfund-chat-form,
	.bcfund-chat-sidebar,
	.bcfund-transcript,
	.bcfund-chat-main > .bcfund-mode-toggle,
	.bcfund-training-setup,
	.bcfund-coaching-loading,
	.bcfund-coaching-actions,
	#wpadminbar,
	.bcfund-eyebrow,
	.bcfund-h1 { display: none !important; }

	.bcfund-main,
	.bcfund-section,
	.bcfund-container,
	.bcfund-chat-wrap,
	.bcfund-chat-main,
	.bcfund-coaching {
		all: unset; display: block; max-width: none; width: auto;
		padding: 0; margin: 0; background: transparent;
	}

	.bcfund-report {
		box-shadow: none !important;
		border: none !important;
		padding: 0 !important;
		background: #fff !important;
		max-width: none !important;
	}

	/* Print-only header */
	.bcfund-print-header {
		display: block !important;
		border-bottom: 2px solid var(--bc-maroon);
		padding-bottom: 10pt;
		margin-bottom: 14pt;
	}
	.bcfund-print-brand {
		display: flex; align-items: baseline; gap: 12pt;
		margin-bottom: 8pt;
	}
	.bcfund-print-brand strong {
		font-family: 'Playfair Display', Georgia, serif;
		font-size: 18pt;
		color: var(--bc-maroon);
	}
	.bcfund-print-brand span {
		font-size: 11pt;
		color: var(--bc-ink-soft);
		text-transform: uppercase;
		letter-spacing: 0.08em;
	}
	.bcfund-print-meta {
		width: 100%; border-collapse: collapse; font-size: 10pt;
	}
	.bcfund-print-meta th {
		text-align: left; padding: 3pt 12pt 3pt 0;
		width: 90pt; color: var(--bc-ink-soft); font-weight: 600;
		text-transform: uppercase; letter-spacing: 0.05em; font-size: 9pt;
	}
	.bcfund-print-meta td {
		padding: 3pt 0; color: var(--bc-ink); font-weight: 500;
	}

	/* Score block compactness */
	.bcfund-score-row {
		gap: 16pt; padding-bottom: 12pt; margin-bottom: 14pt;
		page-break-inside: avoid;
	}
	.bcfund-score {
		width: 60pt; height: 60pt; font-size: 24pt;
		box-shadow: none !important;
	}

	/* Section spacing for print */
	.bcfund-report-section {
		margin-top: 16pt;
		page-break-inside: avoid;
	}
	.bcfund-report-section h3 {
		font-size: 13pt;
		margin-bottom: 6pt;
		page-break-after: avoid;
	}

	/* Bullets in print form */
	.bcfund-bullets li {
		background: #FAF6E8 !important;
		border-color: #E4DECB !important;
		padding: 6pt 10pt 6pt 22pt;
		font-size: 10.5pt;
		page-break-inside: avoid;
	}
	.bcfund-bullets li::before { top: 11pt; left: 9pt; width: 5pt; height: 5pt; }
	.bcfund-bullets-positive li { border-left: 2pt solid var(--bc-success) !important; }
	.bcfund-bullets-practice li { border-left: 2pt solid var(--bc-maroon) !important; }

	.bcfund-learning,
	.bcfund-missed,
	.bcfund-rewrite {
		page-break-inside: avoid;
		box-shadow: none !important;
	}

	/* Body class added by JS while preparing the print dialog */
	.bcfund-printing .bcfund-coaching-actions { display: none !important; }

	/* Links: show URLs after, but skip for short anchors */
	a[href]::after { content: ''; }

	/* Avoid orphan headers */
	h2, h3, h4 { page-break-after: avoid; }
}

/* ======= FOOTER ======= */
.bcfund-footer {
	margin-top: 64px;
	padding: 28px 28px 36px;
	background: #fff;
	border-top: 1px solid var(--bc-line);
	font-size: 13px;
	color: var(--bc-ink-soft);
}
.bcfund-footer-note { margin: 0 0 6px; }
.bcfund-footer-sub  { margin: 0; font-size: 12px; color: var(--bc-ink-soft); opacity: 0.8; }
