.vision-wrap {
	max-width: 980px;
	margin: 32px auto;
	padding: 0 16px;
	font-family: inherit;
}

.vision-grid {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
	gap: 16px;
	margin-top: 24px;
}

.vision-card {
	background: #fff;
	border: 1px solid #e5e7eb;
	border-radius: 16px;
	padding: 20px;
	box-shadow: 0 8px 24px rgba(15, 23, 42, 0.06);
}

.vision-button {
	display: inline-block;
	margin: 8px 8px 0 0;
	padding: 10px 14px;
	border-radius: 999px;
	text-decoration: none;
	background: #111827;
	color: #fff;
	font-weight: 600;
}

.vision-button:hover,
.vision-button:focus {
	color: #fff;
	opacity: 0.9;
}

.vision-button-secondary {
	background: #f3f4f6;
	color: #111827;
}

.vision-button-secondary:hover,
.vision-button-secondary:focus {
	color: #111827;
}

.vision-question-list li {
	margin-bottom: 12px;
}

.vision-progress {
	background: #eef2f7;
	border-radius: 999px;
	height: 10px;
	overflow: hidden;
	margin: 10px 0 14px;
}

.vision-progress span {
	display: block;
	height: 100%;
	background: #111827;
	border-radius: 999px;
	transition: width 180ms ease;
}

.vision-step-meta {
	display: flex;
	justify-content: space-between;
	gap: 12px;
	font-size: 14px;
	color: #4b5563;
	margin-bottom: 8px;
}

.vision-question {
	border-top: 1px solid #eef2f7;
	padding: 18px 0;
}

.vision-question:first-of-type {
	border-top: 0;
}

.vision-question-label {
	display: block;
	font-weight: 700;
	margin-bottom: 10px;
}

.vision-scale-group,
.vision-checkbox-group {
	display: grid;
	gap: 8px;
}

.vision-scale-option,
.vision-checkbox-group label {
	display: flex;
	align-items: flex-start;
	gap: 10px;
	padding: 10px 12px;
	border: 1px solid #e5e7eb;
	border-radius: 12px;
	background: #f9fafb;
	cursor: pointer;
}

.vision-scale-option:has(input:checked),
.vision-checkbox-group label:has(input:checked) {
	background: #f3f4f6;
	border-color: #111827;
}

.vision-question textarea,
.vision-card input[type="text"],
.vision-card input[type="email"] {
	width: 100%;
	max-width: 680px;
	border: 1px solid #d1d5db;
	border-radius: 10px;
	padding: 10px 12px;
}

.vision-alert {
	border: 1px solid #f59e0b;
	background: #fffbeb;
	padding: 12px;
	border-radius: 12px;
	margin: 14px 0;
}

.vision-form-actions {
	display: flex;
	gap: 8px;
	flex-wrap: wrap;
	margin-top: 16px;
}

button.vision-button {
	border: 0;
	cursor: pointer;
}

/* Phase 4 missions and reflections */
.vision-wrap textarea,
.vision-wrap select,
.vision-wrap input[type="text"],
.vision-wrap input[type="email"] {
	max-width: 100%;
}
.vision-wrap textarea {
	width: 100%;
	min-height: 96px;
}
.vision-released-report .vision-report {
	max-width: 920px;
	margin: 0 auto;
}
.vision-rhythm p {
	margin-bottom: 0.75rem;
}

.vision-report-insight {
	border: 1px solid #e2e8f0;
	border-radius: 14px;
	padding: 14px 16px;
	margin: 12px 0;
	background: #ffffff;
}

.vision-report-insight h3 {
	margin-top: 0;
}

.vision-report-insight strong {
	font-weight: 700;
}

/* Phase 6 launch QA and report polish */
.vision-launch-qa .vision-qa-summary {
	display: flex;
	gap: 8px;
	margin: 16px 0;
	align-items: center;
	flex-wrap: wrap;
}
.vision-qa-pill {
	display: inline-block;
	border-radius: 999px;
	padding: 4px 10px;
	font-size: 12px;
	font-weight: 700;
	border: 1px solid #c3c4c7;
	background: #f6f7f7;
}
.vision-qa-ok { background: #edfaef; border-color: #8ed29d; color: #0f5132; }
.vision-qa-warn { background: #fff8e5; border-color: #f0c36d; color: #7a4d00; }
.vision-qa-fail { background: #fde8e8; border-color: #e29a9a; color: #842029; }
.vision-launch-list li { margin-bottom: 8px; }
.vision-report {
	max-width: 940px;
	margin: 0 auto;
	font-size: 16px;
	line-height: 1.62;
	color: #1f2933;
}
.vision-report h1 {
	font-size: 34px;
	line-height: 1.18;
	margin: 0 0 16px;
}
.vision-report h2 {
	font-size: 23px;
	margin-top: 34px;
	padding-top: 18px;
	border-top: 1px solid #e5e7eb;
}
.vision-report h3 {
	font-size: 18px;
	margin-top: 18px;
}
.vision-report section {
	margin-bottom: 22px;
}
.vision-report-table {
	width: 100%;
	border-collapse: collapse;
	margin: 12px 0 20px;
	background: #fff;
}
.vision-report-table th,
.vision-report-table td {
	border: 1px solid #e5e7eb;
	padding: 12px 14px;
	vertical-align: top;
}
.vision-report-table th {
	width: 34%;
	text-align: left;
	background: #f9fafb;
}
.vision-student-snapshot {
	max-width: 760px;
}

/* Phase 7 / v3.0.14 guided VISION UI polish */
:root {
	--vision-ink: #111827;
	--vision-muted: #667085;
	--vision-border: #e6e8ef;
	--vision-soft: #f7f8fb;
	--vision-soft-blue: #eef7ff;
	--vision-soft-lavender: #f3efff;
	--vision-accent: #f27a1a;
	--vision-navy: #101828;
	--vision-button: #253858;
	--vision-button-2: #2f6fbe;
	--vision-radius: 24px;
}

.vision-wrap {
	max-width: 1180px;
	margin: 48px auto;
	padding: 0 20px;
	color: var(--vision-ink);
}

.vision-wrap h1,
.vision-wrap h2,
.vision-wrap h3 {
	letter-spacing: -0.03em;
	color: var(--vision-ink);
}

.vision-wrap h1 {
	font-size: clamp(2.25rem, 5vw, 4.35rem);
	line-height: 1.04;
	margin: 0 0 18px;
}

.vision-wrap h2 {
	font-size: clamp(1.55rem, 3vw, 2.35rem);
	line-height: 1.12;
}

.vision-wrap h3 {
	font-size: 1.35rem;
	line-height: 1.2;
}

.vision-kicker,
.vision-section-eyebrow,
.vision-question-type {
	margin: 0 0 10px;
	font-size: 0.78rem;
	line-height: 1.2;
	font-weight: 800;
	letter-spacing: 0.08em;
	text-transform: uppercase;
	color: var(--vision-accent);
}

.vision-lead {
	font-size: clamp(1.05rem, 2vw, 1.32rem);
	line-height: 1.62;
	color: #475467;
	max-width: 760px;
}

.vision-muted,
.vision-module-intro {
	color: var(--vision-muted);
}

.vision-hero-card,
.vision-flow-header {
	display: grid;
	grid-template-columns: minmax(0, 1.25fr) minmax(300px, 0.75fr);
	gap: 28px;
	align-items: stretch;
	margin-bottom: 28px;
}

.vision-hero-card {
	background: linear-gradient(135deg, #fff 0%, #fbfcff 52%, #fff7ed 100%);
	border: 1px solid var(--vision-border);
	border-radius: 32px;
	padding: clamp(28px, 5vw, 54px);
	box-shadow: 0 24px 70px rgba(16, 24, 40, 0.08);
}

.vision-soft-panel,
.vision-flow-progress-box {
	background: linear-gradient(135deg, var(--vision-soft-lavender) 0%, var(--vision-soft-blue) 100%);
	border: 1px solid rgba(111, 78, 255, 0.12);
	border-radius: var(--vision-radius);
	padding: 24px;
	box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.7);
}

.vision-soft-panel h2,
.vision-flow-progress-box h2 {
	margin-top: 0;
}

.vision-numbered-steps {
	list-style: none;
	margin: 18px 0 0;
	padding: 0;
	display: grid;
	gap: 14px;
}

.vision-numbered-steps li {
	position: relative;
	padding-left: 44px;
	min-height: 34px;
}

.vision-numbered-steps li::before {
	content: counter(list-item);
	position: absolute;
	left: 0;
	top: 0;
	width: 30px;
	height: 30px;
	border-radius: 999px;
	background: var(--vision-navy);
	color: #fff;
	display: grid;
	place-items: center;
	font-weight: 800;
	font-size: 0.88rem;
}

.vision-numbered-steps span {
	display: block;
	color: var(--vision-muted);
	font-size: 0.94rem;
	margin-top: 2px;
}

.vision-card {
	border-radius: var(--vision-radius);
	border-color: var(--vision-border);
	box-shadow: 0 16px 48px rgba(16, 24, 40, 0.07);
}

.vision-button {
	background: linear-gradient(135deg, var(--vision-button), var(--vision-button-2));
	border-radius: 12px;
	padding: 13px 20px;
	font-weight: 800;
	box-shadow: 0 10px 24px rgba(47, 111, 190, 0.18);
	transition: transform 160ms ease, box-shadow 160ms ease, opacity 160ms ease;
}

.vision-button:hover,
.vision-button:focus {
	transform: translateY(-1px);
	box-shadow: 0 14px 32px rgba(47, 111, 190, 0.22);
	opacity: 1;
}

.vision-button-secondary {
	background: #fff;
	border: 1px solid var(--vision-border);
	box-shadow: none;
	color: var(--vision-ink);
}

.vision-field-grid {
	display: grid;
	grid-template-columns: repeat(2, minmax(0, 1fr));
	gap: 16px;
}

.vision-field-grid p,
.vision-start-form p {
	margin: 0;
}

.vision-field-wide {
	grid-column: 1 / -1;
}

.vision-form-section {
	border-top: 1px solid var(--vision-border);
	padding: 28px 0;
}

.vision-form-section:first-child {
	border-top: 0;
	padding-top: 0;
}

.vision-start-form input[type="text"],
.vision-start-form input[type="email"],
.vision-question textarea,
.vision-wrap textarea,
.vision-wrap select {
	border-radius: 14px;
	border: 1px solid #d7dce6;
	background: #fff;
	padding: 13px 14px;
	font-size: 1rem;
	transition: border-color 160ms ease, box-shadow 160ms ease;
}

.vision-start-form input:focus,
.vision-question textarea:focus,
.vision-wrap select:focus {
	outline: none;
	border-color: #8098f9;
	box-shadow: 0 0 0 4px rgba(128, 152, 249, 0.18);
}

.vision-consent-list {
	display: grid;
	gap: 12px;
}

.vision-consent-list label {
	display: grid;
	grid-template-columns: 20px 1fr;
	gap: 12px;
	align-items: start;
	padding: 14px 16px;
	background: var(--vision-soft);
	border: 1px solid var(--vision-border);
	border-radius: 16px;
}

.vision-start-actions {
	align-items: center;
	justify-content: space-between;
	padding: 18px;
	border-radius: 18px;
	background: #f9fafb;
}

.vision-start-actions p {
	margin: 4px 0 0;
	color: var(--vision-muted);
}

.vision-journey-path,
.vision-module-stepper {
	display: flex;
	gap: 0;
	margin: 22px 0 32px;
	overflow-x: auto;
	padding-bottom: 4px;
}

.vision-path-item,
.vision-module-step {
	position: relative;
	min-width: 150px;
	text-decoration: none;
	color: var(--vision-muted);
	display: grid;
	gap: 6px;
	justify-items: center;
	text-align: center;
	font-size: 0.86rem;
	padding: 0 12px;
}

.vision-path-item:not(:last-child)::after,
.vision-module-step:not(:last-child)::after {
	content: "";
	position: absolute;
	top: 16px;
	left: calc(50% + 18px);
	width: calc(100% - 36px);
	height: 2px;
	background: #d7dce6;
}

.vision-path-item span,
.vision-module-step span {
	position: relative;
	z-index: 1;
	display: grid;
	place-items: center;
	width: 34px;
	height: 34px;
	border-radius: 999px;
	background: #fff;
	border: 2px solid #d7dce6;
	font-weight: 800;
}

.vision-path-item.is-active span,
.vision-module-step.is-current span {
	border-color: #2f6fbe;
	color: #2f6fbe;
	box-shadow: 0 0 0 5px rgba(47, 111, 190, 0.12);
}

.vision-path-item.is-complete span,
.vision-module-step.is-complete span {
	background: #12b76a;
	border-color: #12b76a;
	color: #fff;
}

.vision-hub-grid {
	grid-template-columns: repeat(4, minmax(220px, 1fr));
}

.vision-hub-card {
	min-height: 280px;
	display: flex;
	flex-direction: column;
}

.vision-hub-card .vision-button {
	margin-top: auto;
	align-self: flex-start;
}

.vision-card-icon {
	width: 54px;
	height: 54px;
	border-radius: 18px;
	display: grid;
	place-items: center;
	font-size: 1.8rem;
	background: linear-gradient(135deg, #fff7ed, #eef7ff);
	margin-bottom: 12px;
}

.vision-status-pill {
	display: inline-flex;
	align-items: center;
	align-self: flex-start;
	border-radius: 999px;
	padding: 6px 10px;
	background: #f2f4f7;
	border: 1px solid #e4e7ec;
	color: #344054;
	font-size: 0.78rem;
	font-weight: 800;
	margin-bottom: 12px;
}

.vision-status-active {
	background: #ecfdf3;
	border-color: #abefc6;
	color: #067647;
}

.vision-flow-header {
	align-items: center;
}

.vision-flow-progress-box {
	min-width: 280px;
}

.vision-flow-progress-box span {
	color: var(--vision-muted);
	font-weight: 700;
}

.vision-flow-progress-box strong {
	display: block;
	font-size: 1.7rem;
	margin: 4px 0 10px;
}

.vision-flow-layout {
	display: grid;
	grid-template-columns: minmax(0, 1fr) 360px;
	gap: 28px;
	align-items: start;
}

.vision-guidance-panel {
	position: sticky;
	top: 24px;
}

.vision-guidance-panel hr {
	border: 0;
	border-top: 1px solid rgba(16, 24, 40, 0.10);
	margin: 20px 0;
}

.vision-guidance-panel ul {
	margin: 8px 0 0;
	padding-left: 20px;
}

.vision-step-card {
	padding: clamp(22px, 4vw, 38px);
}

.vision-question-card {
	border: 1px solid var(--vision-border);
	border-radius: 20px;
	padding: 22px;
	margin: 18px 0;
	background: #fff;
	box-shadow: 0 8px 26px rgba(16, 24, 40, 0.045);
}

.vision-question-heading {
	margin-bottom: 16px;
}

.vision-question-label {
	font-size: clamp(1.08rem, 2vw, 1.45rem);
	line-height: 1.35;
	font-weight: 800;
	margin-bottom: 0;
}

.vision-answer-grid {
	grid-template-columns: repeat(auto-fit, minmax(145px, 1fr));
	gap: 12px;
}

.vision-answer-card,
.vision-choice-card {
	justify-content: center;
	min-height: 64px;
	padding: 14px 14px;
	border: 2px solid #cfd8ff;
	background: #fff;
	border-radius: 16px;
	font-weight: 800;
	color: #253858;
	text-align: center;
	transition: transform 140ms ease, border-color 140ms ease, background 140ms ease, box-shadow 140ms ease;
}

.vision-answer-card input,
.vision-choice-card input {
	position: absolute;
	opacity: 0;
	pointer-events: none;
}

.vision-answer-card:hover,
.vision-choice-card:hover {
	transform: translateY(-1px);
	border-color: #2f6fbe;
	box-shadow: 0 10px 26px rgba(47, 111, 190, 0.10);
}

.vision-answer-card:has(input:checked),
.vision-choice-card:has(input:checked),
.vision-answer-card.is-selected,
.vision-choice-card.is-selected {
	background: linear-gradient(135deg, #eef7ff, #f3efff);
	border-color: #2f6fbe;
	box-shadow: 0 0 0 4px rgba(47, 111, 190, 0.12);
}

.vision-choice-grid {
	grid-template-columns: repeat(auto-fit, minmax(170px, 1fr));
	gap: 12px;
}

.vision-sticky-actions {
	position: sticky;
	bottom: 0;
	z-index: 5;
	background: rgba(255, 255, 255, 0.96);
	backdrop-filter: blur(10px);
	border: 1px solid var(--vision-border);
	border-radius: 20px;
	padding: 14px;
	align-items: center;
	justify-content: space-between;
	box-shadow: 0 -10px 32px rgba(16, 24, 40, 0.08);
}

.vision-action-copy {
	display: grid;
	gap: 2px;
}

.vision-action-copy span {
	color: var(--vision-muted);
	font-size: 0.9rem;
}

@media (max-width: 980px) {
	.vision-hero-card,
	.vision-flow-header,
	.vision-flow-layout {
		grid-template-columns: 1fr;
	}

	.vision-hub-grid {
		grid-template-columns: repeat(2, minmax(220px, 1fr));
	}

	.vision-guidance-panel {
		position: static;
		order: -1;
	}
}

@media (max-width: 700px) {
	.vision-wrap {
		margin: 24px auto;
		padding: 0 14px;
	}

	.vision-hero-card {
		border-radius: 24px;
		padding: 24px;
	}

	.vision-field-grid,
	.vision-hub-grid,
	.vision-answer-grid,
	.vision-choice-grid {
		grid-template-columns: 1fr;
	}

	.vision-path-item,
	.vision-module-step {
		min-width: 112px;
		font-size: 0.74rem;
	}

	.vision-sticky-actions {
		align-items: stretch;
	}

	.vision-sticky-actions,
	.vision-sticky-actions > div:last-child {
		display: grid;
		grid-template-columns: 1fr;
		gap: 10px;
	}

	.vision-button {
		width: 100%;
		text-align: center;
	}
}
