.cp-page {
	--cp-ink: #eef6ff;
	--cp-muted: #9fb4d6;
	--cp-border: #2c3f66;
	--cp-panel: #111f3d;
	--cp-panel-soft: #15284e;
	--cp-navy: #2c5fff;
	--cp-navy-deep: #1a3ca6;
	--cp-blue: #56a3ff;
	--cp-blue-soft: rgba(86, 163, 255, 0.12);
	--cp-gold: #f7b84b;
	--cp-gold-soft: rgba(247, 184, 75, 0.14);
	--cp-safe: #5dd488;
	--cp-safe-soft: rgba(93, 212, 136, 0.14);
	--cp-target: #ffd166;
	--cp-target-soft: rgba(255, 209, 102, 0.14);
	--cp-dream: #ff6b7f;
	--cp-dream-soft: rgba(255, 107, 127, 0.14);
	padding: 12px 16px 40px;
	position: relative;
	background: var(--tn-page-bg, linear-gradient(180deg, #070f24 0%, #09142f 55%, #0a1736 100%));
}

.cp-wrap {
	max-width: 1160px;
	margin: 0 auto;
}

.cp-skip-link {
	position: absolute;
	left: 12px;
	top: -100px;
	z-index: 200;
	padding: 10px 14px;
	border-radius: 10px;
	background: #13375a;
	color: #ffffff;
	font-size: 13px;
	font-weight: 700;
	text-decoration: none;
}

.cp-skip-link:focus-visible {
	top: 12px;
}

.cp-hero {
	display: grid;
	grid-template-columns: minmax(0, 1fr);
	gap: 12px;
	align-items: stretch;
	margin-bottom: 12px;
	padding: 16px 18px;
	border-radius: 28px;
	position: relative;
	overflow: hidden;
	background:
		linear-gradient(135deg, rgba(215, 156, 29, 0.2), transparent 40%),
		linear-gradient(140deg, #14375a 0%, #0b2440 65%, #1a446c 100%);
	color: #ffffff;
	box-shadow: 0 24px 60px rgba(11, 36, 64, 0.22);
}

.cp-hero::before,
.cp-hero::after {
	content: "";
	position: absolute;
	border-radius: 999px;
	pointer-events: none;
}

.cp-hero::before {
	width: 220px;
	height: 220px;
	right: -80px;
	top: -80px;
	background: radial-gradient(circle, rgba(255, 255, 255, 0.12) 0%, rgba(255, 255, 255, 0) 70%);
}

.cp-hero::after {
	width: 180px;
	height: 180px;
	left: -60px;
	bottom: -70px;
	background: radial-gradient(circle, rgba(215, 156, 29, 0.22) 0%, rgba(215, 156, 29, 0) 72%);
}

.cp-kicker,
.cp-form-kicker,
.cp-results-kicker {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	padding: 7px 12px;
	border-radius: 999px;
	background: rgba(255, 255, 255, 0.12);
	color: #f8e2a8;
	font-size: 12px;
	font-weight: 800;
	letter-spacing: 0.08em;
	text-transform: uppercase;
}

.cp-title {
	margin: 8px 0 6px;
	font-size: clamp(1.9rem, 4.4vw, 2.7rem);
	line-height: 1.04;
	font-weight: 800;
	letter-spacing: -0.03em;
	color: #ffffff;
}

.cp-subtitle {
	margin: 0;
	max-width: 760px;
	font-size: 0.96rem;
	line-height: 1.5;
	color: rgba(255, 255, 255, 0.82);
}

.cp-subtitle-meta {
	margin: 6px 0 0;
	font-size: 0.82rem;
	line-height: 1.4;
	color: rgba(255, 255, 255, 0.72);
}

.cp-subtitle-meta strong {
	color: #ffffff;
	font-weight: 800;
}

.cp-subtitle-meta-plain {
	color: rgba(221, 237, 255, 0.86);
}

.tn-section-toc-predictor {
	margin-bottom: 18px;
}

.cp-form-side-note-label,
.cp-results-stat-label {
	display: block;
	margin-bottom: 8px;
	font-size: 12px;
	font-weight: 800;
	letter-spacing: 0.08em;
	text-transform: uppercase;
}

.cp-form-side-note-copy {
	margin-top: 8px;
	font-size: 14px;
	line-height: 1.7;
	color: rgba(255, 255, 255, 0.72);
}

.cp-alert {
	padding: 16px 18px;
	border-radius: 16px;
	margin-bottom: 24px;
	font-weight: 600;
}

.cp-alert-error {
	background: #fff1f2;
	border: 1px solid #fecdd3;
	color: #9f1239;
}

.cp-alert-warning {
	background: #fff8e8;
	border: 1px solid #f7d9a0;
	color: #7d4f05;
}

.cp-alert-info {
	background: #eef6ff;
	border: 1px solid #bfd8f6;
	color: #174d80;
}

.cp-context-links {
	margin-top: 12px;
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: 8px;
	font-size: 14px;
	line-height: 1.7;
	color: var(--cp-muted);
}

.cp-context-links a {
	color: #8ec7ff;
	font-weight: 700;
	text-decoration: none;
}

.cp-context-links a:hover,
.cp-context-links a:focus-visible {
	color: #d9ecff;
	text-decoration: underline;
}

.cp-form-alert {
	margin-bottom: 18px;
}

.cp-cluster-links {
	display: flex;
	flex-wrap: wrap;
	gap: 8px;
	margin-top: 10px;
}

.cp-cluster-links a {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-height: 38px;
	padding: 0 12px;
	border-radius: 999px;
	border: 1px solid #d6e4f1;
	background: #ffffff;
	color: #2a4f72;
	font-size: 12px;
	font-weight: 700;
	text-decoration: none;
}

.cp-cluster-links a:hover,
.cp-cluster-links a:focus-visible {
	border-color: #9ab9d7;
	background: #f3f8ff;
}

.cp-top-summary-grid {
	display: grid;
	grid-template-columns: repeat(2, minmax(0, 1fr));
	gap: 18px;
	margin: 0 0 24px;
}

.cp-back-to-top {
	position: fixed;
	right: 16px;
	bottom: 18px;
	z-index: 30;
	min-width: 54px;
	height: 54px;
	border-radius: 999px;
	border: 1px solid #9ab6d4;
	background: linear-gradient(180deg, #1f5f9e 0%, #144272 100%);
	color: #ffffff;
	font-size: 13px;
	font-weight: 800;
	letter-spacing: 0.03em;
	text-transform: uppercase;
	box-shadow: 0 14px 30px rgba(20, 66, 114, 0.35);
	cursor: pointer;
	opacity: 0;
	transform: translateY(14px);
	pointer-events: none;
	transition: opacity 180ms ease, transform 180ms ease, box-shadow 180ms ease;
}

.cp-narrow-results-button {
	position: fixed;
	right: 82px;
	bottom: 18px;
	z-index: 30;
	min-height: 54px;
	padding: 0 16px;
	border-radius: 999px;
	border: 1px solid #9ab6d4;
	background: linear-gradient(180deg, #1f5f9e 0%, #144272 100%);
	color: #ffffff;
	font-size: 12px;
	font-weight: 800;
	letter-spacing: 0.01em;
	text-transform: uppercase;
	box-shadow: 0 14px 30px rgba(20, 66, 114, 0.35);
	cursor: pointer;
	opacity: 0;
	transform: translateY(14px);
	pointer-events: none;
	transition: opacity 180ms ease, transform 180ms ease, box-shadow 180ms ease;
}

.cp-back-to-top.is-visible {
	opacity: 1;
	transform: translateY(0);
	pointer-events: auto;
}

.cp-narrow-results-button.is-visible {
	opacity: 1;
	transform: translateY(0);
	pointer-events: auto;
}

.cp-back-to-top:hover,
.cp-back-to-top:focus-visible {
	box-shadow: 0 18px 34px rgba(20, 66, 114, 0.4);
	outline: none;
}

.cp-narrow-results-button:hover,
.cp-narrow-results-button:focus-visible {
	box-shadow: 0 18px 34px rgba(20, 66, 114, 0.4);
	outline: none;
}

.cp-form-card,
.cp-summary-card,
.cp-info-card,
.cp-card {
	background: var(--cp-panel);
	border: 1px solid rgba(16, 35, 59, 0.09);
	border-radius: 24px;
	box-shadow: 0 16px 36px rgba(17, 31, 48, 0.08);
}

.cp-form-card,
.cp-summary-card,
.cp-info-card,
.cp-card,
.cp-group {
	position: relative;
}

.cp-form-card {
	padding: 26px;
	margin-bottom: 28px;
}

.cp-form-head {
	display: flex;
	align-items: flex-start;
	justify-content: space-between;
	gap: 18px;
	margin-bottom: 20px;
}

.cp-form-kicker {
	background: var(--cp-blue-soft);
	color: var(--cp-blue);
}

.cp-form-title {
	margin: 12px 0 10px;
	font-size: 30px;
	line-height: 1.1;
	color: var(--cp-ink);
}

.cp-form-copy {
	margin: 0;
	max-width: 720px;
	color: var(--cp-muted);
	line-height: 1.8;
}

.cp-form-side-note {
	min-width: 220px;
	padding: 16px 18px;
	border-radius: 20px;
	background: linear-gradient(180deg, #eff6ff 0%, #f7fbff 100%);
	border: 1px solid #d7e7f7;
}

.cp-form-side-note-label {
	color: #557391;
}

.cp-form-side-note-value {
	font-size: 26px;
	font-weight: 800;
	line-height: 1.1;
	color: var(--cp-navy);
}

.cp-form-grid {
	display: grid;
	grid-template-columns: repeat(3, minmax(0, 1fr));
	gap: 16px;
}

.cp-form-primary-grid {
	display: grid;
	grid-template-columns: repeat(3, minmax(0, 1fr));
	gap: 16px;
}

.cp-form-grid > *,
.cp-form-primary-grid > * {
	min-width: 0;
}

.cp-form-start-note {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	margin: 0 0 14px;
	padding: 8px 12px;
	border-radius: 999px;
	border: 1px solid #cfe0f2;
	background: #f3f8ff;
	color: #355877;
	font-size: 13px;
	font-weight: 700;
	line-height: 1.4;
}

.cp-form-advanced {
	margin-top: 14px;
	padding: 12px 14px;
	border: 1px solid #385a8f;
	border-radius: 16px;
	background: rgba(16, 35, 74, 0.9);
}

.cp-form-advanced[open] {
	background: #132b57;
	border-color: #5f8fd0;
}

.cp-form-advanced-summary {
	display: flex;
	flex-direction: column;
	gap: 4px;
	cursor: pointer;
	list-style: none;
}

.cp-form-advanced-summary::-webkit-details-marker {
	display: none;
}

.cp-form-advanced-title {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	font-size: 14px;
	font-weight: 800;
	color: #eaf3ff;
}

.cp-form-advanced-title::before {
	content: "▸";
	font-size: 14px;
	color: #9fc3ee;
	transform: translateY(-1px);
	transition: transform 120ms ease;
}

.cp-form-advanced[open] .cp-form-advanced-title::before {
	transform: rotate(90deg) translateY(0);
}

.cp-form-advanced-subtitle {
	font-size: 12px;
	font-weight: 600;
	color: #9fb6d5;
	line-height: 1.5;
}

.cp-form-advanced-help {
	margin: 10px 0 12px;
	font-size: 13px;
	line-height: 1.6;
	color: #a9c0de;
}

.cp-field label {
	display: block;
	margin-bottom: 8px;
	font-size: 14px;
	font-weight: 800;
	color: var(--cp-ink);
}

.cp-field-label-row {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 12px;
	margin-bottom: 8px;
}

.cp-field-label-row label {
	margin-bottom: 0;
}

.cp-detect-location-btn {
	display: inline-flex;
	align-items: center;
	gap: 6px;
	height: 34px;
	padding: 0 10px;
	border: 1px solid #385a8f;
	border-radius: 999px;
	background: #132b57;
	color: #eaf3ff;
	font-size: 12px;
	font-weight: 800;
	line-height: 1;
	cursor: pointer;
	transition: transform 120ms ease, box-shadow 120ms ease, border-color 120ms ease;
}

.cp-detect-location-btn[hidden] {
	display: none;
}

.cp-detect-location-btn:hover,
.cp-detect-location-btn:focus-visible {
	transform: translateY(-1px);
	background: #1b3a72;
	border-color: #5f8fd0;
	box-shadow: 0 0 0 3px rgba(86, 163, 255, 0.22);
	outline: none;
}

.cp-detect-location-btn:disabled {
	opacity: 0.65;
	cursor: wait;
	transform: none;
	box-shadow: none;
}

.cp-detect-location-icon {
	width: 13px;
	height: 13px;
	fill: currentColor;
}

.cp-mobile-location-only {
	display: none;
}

.cp-field input,
.cp-field select {
	width: 100%;
	max-width: 100%;
	min-width: 0;
	box-sizing: border-box;
	outline: none;
	transition: border-color 0.2s ease, box-shadow 0.2s ease;
}

.cp-field input:focus,
.cp-field select:focus {
	transform: none;
}

.cp-field select:disabled {
	cursor: not-allowed;
}

.cp-field-help {
	margin: 8px 0 0;
	font-size: 13px;
	line-height: 1.6;
	color: var(--cp-muted);
}

.cp-location-status {
	margin: 8px 0 0;
	font-size: 8px;
	font-weight: 700;
	line-height: 1.2;
	color: #a8bddc;
}

.cp-location-mode-panel {
	margin: 0 0 14px;
	padding: 10px 12px;
	border-radius: 12px;
	border: 1px solid #385a8f;
	background: rgba(13, 31, 67, 0.9);
}

.cp-location-mode-panel-head {
	display: flex;
	flex-direction: column;
	align-items: stretch;
	gap: 10px;
}

.cp-location-mode-switch {
	margin-top: 8px;
	display: grid;
	grid-template-columns: repeat(2, minmax(0, 1fr));
	gap: 8px;
	width: 100%;
}

.cp-location-mode-panel .cp-location-mode-switch {
	margin-top: 0;
}

.cp-location-mode-option {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-height: 46px;
	padding: 0 14px;
	border-radius: 14px;
	border: 1px solid #385a8f;
	background: #0d1f43;
	color: #eaf3ff;
	font-size: 14px;
	font-weight: 800;
	line-height: 1;
	cursor: pointer;
	transition: transform 120ms ease, background 120ms ease, border-color 120ms ease, box-shadow 120ms ease, opacity 120ms ease;
	opacity: 1;
}

.cp-location-mode-option:hover,
.cp-location-mode-option:focus-visible {
	transform: translateY(-1px);
	background: #1b3a72;
	border-color: #5f8fd0;
	box-shadow: 0 0 0 3px rgba(86, 163, 255, 0.22);
	outline: none;
}

.cp-location-mode-option.is-active {
	background: linear-gradient(135deg, #2f86ff 0%, #4263ff 100%);
	border-color: #4a82ff;
	color: #ffffff;
	box-shadow: 0 14px 28px rgba(4, 10, 28, 0.45);
}

.cp-detect-location-btn-compact {
	height: 32px;
	min-height: 32px;
	padding: 0 8px;
	font-size: 11px;
	flex-shrink: 0;
	white-space: nowrap;
	align-self: flex-end;
	border-radius: 10px;
}

.cp-location-status.is-info {
	color: #a8bddc;
}

.cp-location-status.is-success {
	color: #8fe6ad;
}

.cp-location-status.is-error {
	color: #ffafbb;
}

.cp-location-chip {
	margin-top: 8px;
	padding: 8px 10px;
	border: 1px solid #385a8f;
	border-radius: 12px;
	background: rgba(10, 24, 52, 0.92);
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 10px;
}

.cp-location-chip[hidden] {
	display: none;
}

.cp-location-chip-label {
	font-size: 12px;
	font-weight: 800;
	line-height: 1.4;
	color: #dbe9ff;
}

.cp-location-chip-actions {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	flex-shrink: 0;
}

.cp-location-chip-action {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-height: 28px;
	padding: 0 9px;
	border: 1px solid #385a8f;
	border-radius: 999px;
	background: #132b57;
	color: #eaf3ff;
	font-size: 11px;
	font-weight: 800;
	line-height: 1;
	text-decoration: none;
	cursor: pointer;
	transition: background 120ms ease, border-color 120ms ease, box-shadow 120ms ease;
}

.cp-location-chip-action[hidden] {
	display: none;
}

.cp-location-chip-action:hover,
.cp-location-chip-action:focus,
.cp-location-chip-action:focus-visible {
	background: #1b3a72;
	border-color: #5f8fd0;
	box-shadow: 0 0 0 3px rgba(86, 163, 255, 0.22);
	outline: none;
}

.cp-location-chip-action-clear {
	color: #ffdbe2;
	border-color: #8a4b5a;
}

.cp-location-chip-action-clear:hover,
.cp-location-chip-action-clear:focus,
.cp-location-chip-action-clear:focus-visible {
	background: #6a3140;
	border-color: #ab6174;
	box-shadow: 0 0 0 3px rgba(171, 97, 116, 0.28);
}

.cp-location-mode-panel .cp-location-chip {
	margin-top: 8px;
}

.cp-autocomplete {
	position: relative;
	min-width: 0;
}

.cp-college-suggestions {
	position: absolute;
	top: calc(100% + 6px);
	left: 0;
	right: 0;
	z-index: 24;
	margin: 0;
	padding: 6px;
	list-style: none;
	border: 1px solid #5f8fd0;
	border-radius: 14px;
	background: #132b57;
	box-shadow: 0 18px 32px rgba(8, 19, 44, 0.35);
	max-height: 280px;
	overflow-y: auto;
}

.cp-college-option {
	display: flex;
	flex-direction: column;
	gap: 2px;
	padding: 10px 12px;
	border-radius: 10px;
	cursor: pointer;
	transition: background 0.15s ease;
}

.cp-college-option:hover,
.cp-college-option.is-active {
	background: #1b3a72;
}

.cp-college-option-name {
	font-size: 14px;
	font-weight: 700;
	line-height: 1.4;
	color: var(--cp-ink);
}

.cp-college-option-meta {
	font-size: 12px;
	font-weight: 600;
	line-height: 1.4;
	color: #a9c0de;
}

.cp-college-search-status {
	margin: 8px 0 0;
	font-size: 12px;
	line-height: 1.5;
	color: #64778c;
	min-height: 1.2em;
}

.cp-select-wrap {
	position: relative;
	min-width: 0;
}

.cp-select-wrap select {
	padding-right: 42px;
	appearance: none;
}

.cp-select-arrow {
	position: absolute;
	top: 50%;
	right: 14px;
	transform: translateY(-50%);
	font-size: 14px;
	color: #718197;
	pointer-events: none;
}

.cp-form-pills {
	display: flex;
	flex-wrap: wrap;
	gap: 10px;
	margin-top: 18px;
}

.cp-form-pill,
.cp-card-tag {
	display: inline-flex;
	align-items: center;
	padding: 9px 12px;
	border-radius: 999px;
	font-size: 13px;
	font-weight: 700;
	line-height: 1.2;
}

.cp-form-pill {
	background: #f4f8fc;
	border: 1px solid #d9e4ef;
	color: #46627d;
}

.cp-form-actions {
	margin-top: 20px;
	display: flex;
	flex-wrap: wrap;
	gap: 10px;
}

.cp-btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 8px;
	padding: 0 18px;
	text-decoration: none;
	cursor: pointer;
}

/* Keep predictor form actions compact without changing global CTA sizing. */
#cp-predictor-form .cp-btn {
	min-height: 40px;
	padding: 0 14px;
	font-size: 0.86rem;
	border-radius: 12px;
}

#cp-predictor-form .cp-form-actions {
	margin-top: 16px;
	gap: 8px;
}

#cp-predictor-form .cp-location-mode-option {
	min-height: 40px;
	padding: 0 12px;
	font-size: 0.82rem;
	border-radius: 12px;
}

#cp-predictor-form .cp-detect-location-btn-compact {
	height: 30px;
	min-height: 30px;
	padding: 0 8px;
	font-size: 10px;
}

.cp-form-card.is-submitting {
	opacity: 0.96;
}

.cp-form-card.is-submitting .cp-field input,
.cp-form-card.is-submitting .cp-field select,
.cp-form-card.is-submitting .cp-field button,
.cp-form-card.is-submitting .cp-field a {
	pointer-events: none;
}

.cp-form-card.is-submitting [data-predictor-submit] {
	cursor: progress;
}

.cp-submit-feedback {
	margin: 12px 0 0;
	font-size: 13px;
	font-weight: 700;
	line-height: 1.5;
	color: #1f4f7a;
}

.cp-results-loading {
	padding: 18px;
	border-radius: 18px;
	border: 1px solid #dbe7f3;
	background: linear-gradient(180deg, #f6fbff 0%, #ffffff 100%);
	box-shadow: 0 10px 26px rgba(17, 31, 48, 0.06);
}

.cp-results-loading-head h3 {
	margin: 0;
	font-size: 20px;
	line-height: 1.25;
	color: var(--cp-ink);
}

.cp-results-loading-head p {
	margin: 6px 0 0;
	font-size: 14px;
	line-height: 1.6;
	color: var(--cp-muted);
}

.cp-results-loading-grid {
	margin-top: 14px;
	display: grid;
	grid-template-columns: repeat(3, minmax(0, 1fr));
	gap: 12px;
}

.cp-results-loading-card {
	padding: 14px;
	border: 1px solid #dce7f3;
	border-radius: 14px;
	background: #ffffff;
}

.cp-skeleton {
	display: block;
	border-radius: 8px;
	background: linear-gradient(90deg, #edf3fa 0%, #f8fbfe 50%, #edf3fa 100%);
	background-size: 220% 100%;
	animation: cpSkeletonPulse 1.2s ease-in-out infinite;
}

.cp-skeleton-line {
	height: 12px;
}

.cp-skeleton-line + .cp-skeleton-line {
	margin-top: 10px;
}

.cp-skeleton-line-lg {
	width: 78%;
}

.cp-skeleton-line-sm {
	width: 52%;
}

.cp-skeleton-metrics {
	display: grid;
	grid-template-columns: repeat(3, minmax(0, 1fr));
	gap: 8px;
	margin-top: 12px;
}

.cp-skeleton-pill {
	height: 34px;
	border-radius: 10px;
}

@keyframes cpSkeletonPulse {
	0% {
		background-position: 100% 50%;
	}
	100% {
		background-position: 0% 50%;
	}
}

.cp-results {
	display: grid;
	gap: 20px;
	scroll-margin-top: 96px;
}

.cp-results-stack {
	display: grid;
	gap: 20px;
	margin: 0 0 30px;
}

.cp-results-stack[hidden],
.cp-results-stack.is-cleared {
	display: none !important;
}

.cp-results-summary,
.cp-results-search {
	padding: 24px;
}

/* Keep bucket sections flat inside the search card (avoid card-in-card layout). */
.cp-results-search .cp-group {
	margin-bottom: 14px;
	padding: 0;
	border: 0;
	border-radius: 0;
	background: transparent;
	box-shadow: none;
}

.cp-results-search .cp-group:last-child {
	margin-bottom: 0;
}

.cp-results-search .cp-group-safe,
.cp-results-search .cp-group-target,
.cp-results-search .cp-group-dream {
	border-left: 0;
}

.cp-results-search .cp-group-head {
	margin-bottom: 12px;
	padding: 8px 10px;
	border-radius: 10px;
	border: 1px solid transparent;
}

.cp-results-search .cp-group-safe .cp-group-head {
	border-color: rgba(93, 212, 136, 0.42);
	background: rgba(93, 212, 136, 0.1);
}

.cp-results-search .cp-group-target .cp-group-head {
	border-color: rgba(255, 209, 102, 0.42);
	background: rgba(255, 209, 102, 0.1);
}

.cp-results-search .cp-group-dream .cp-group-head {
	border-color: rgba(255, 107, 127, 0.4);
	background: rgba(255, 107, 127, 0.09);
}

.cp-results-head {
	display: flex;
	align-items: flex-start;
	justify-content: space-between;
	gap: 16px;
}

.cp-results-kicker {
	background: #eef4fa;
	color: var(--cp-blue);
}

.cp-results-head h2 {
	margin: 12px 0 8px;
	font-size: 34px;
	line-height: 1.1;
	color: var(--cp-ink);
}

.cp-results-head p {
	margin: 0;
	max-width: 760px;
	color: var(--cp-muted);
	line-height: 1.8;
}

.cp-results-page-meta {
	margin-top: 8px;
	font-size: 13px;
	font-weight: 700;
	color: #5f7388;
}

.cp-results-filter-state {
	margin-top: 10px;
	font-size: 13px;
	line-height: 1.6;
	color: #4f647a;
}

.cp-results-filter-state a {
	display: inline-block;
	margin-left: 8px;
	font-weight: 800;
	color: #1b4f7f;
	text-decoration: underline;
	text-underline-offset: 2px;
}

.cp-results-stats {
	display: grid;
	grid-template-columns: repeat(3, minmax(0, 1fr));
	gap: 10px;
	min-width: 310px;
	align-items: stretch;
}

.cp-results-sort {
	min-width: 230px;
	display: flex;
	flex-direction: column;
	gap: 6px;
}

.cp-results-sort label {
	font-size: 12px;
	font-weight: 700;
	color: #5c7085;
}

.cp-results-sort .cp-select-wrap select,
.cp-results-sort .cp-select-wrap select:not([multiple]) {
	height: 48px;
	padding: 0 42px 0 14px;
	border-radius: 14px;
	border: 1px solid #385a8f;
	background: #0d1f43;
	color: #eaf3ff;
	font-size: 15px;
	font-weight: 700;
	line-height: 1.2;
	appearance: none;
	-webkit-appearance: none;
	box-shadow: none;
}

.cp-results-sort .cp-select-wrap select:hover,
.cp-results-sort .cp-select-wrap select:not([multiple]):hover {
	border-color: #5f8fd0;
	background: #132b57;
}

.cp-results-sort .cp-select-wrap select:focus,
.cp-results-sort .cp-select-wrap select:focus-visible,
.cp-results-sort .cp-select-wrap select:not([multiple]):focus,
.cp-results-sort .cp-select-wrap select:not([multiple]):focus-visible {
	outline: none;
	border-color: #5f8fd0;
	box-shadow: 0 0 0 3px rgba(86, 163, 255, 0.22);
}

.cp-results-sort .cp-select-wrap select option {
	background: #132b57;
	color: #eaf3ff;
}

.cp-results-sort .cp-select-arrow {
	color: #d6e7ff;
}

.cp-results-stat {
	padding: 14px 14px;
	border-radius: 18px;
	background: #ffffff;
	border: 1px solid #dbe3ec;
	text-align: center;
	box-shadow: 0 12px 30px rgba(17, 31, 48, 0.05);
}

.cp-results-stat-filter {
	width: 100%;
	font-family: inherit;
	cursor: pointer;
	appearance: none;
	min-height: 118px;
	border-width: 2px;
	transition: transform 120ms ease, box-shadow 120ms ease, border-color 120ms ease, background 120ms ease, color 120ms ease;
}

.cp-results-stat-filter:hover,
.cp-results-stat-filter:focus-visible {
	transform: translateY(-2px);
	border-color: #7ea6d0;
	box-shadow: 0 14px 28px rgba(17, 31, 48, 0.12);
	outline: none;
}

.cp-results-stat-filter.is-active {
	box-shadow: 0 0 0 3px rgba(47, 111, 178, 0.14), 0 14px 30px rgba(17, 31, 48, 0.12);
}

@keyframes cp-bucket-highlight-pulse {
	0% {
		transform: translateY(0);
		box-shadow: 0 0 0 0 rgba(86, 163, 255, 0), 0 14px 30px rgba(17, 31, 48, 0.12);
	}
	35% {
		transform: translateY(-2px);
		box-shadow: 0 0 0 4px rgba(86, 163, 255, 0.22), 0 18px 34px rgba(17, 31, 48, 0.18);
	}
	100% {
		transform: translateY(0);
		box-shadow: 0 0 0 0 rgba(86, 163, 255, 0), 0 14px 30px rgba(17, 31, 48, 0.12);
	}
}

.cp-results-stat-filter.is-active.cp-bucket-highlight {
	animation: cp-bucket-highlight-pulse 640ms cubic-bezier(0.22, 1, 0.36, 1) both;
}

.cp-results-stat-filter.cp-results-stat-safe.is-active {
	background: var(--cp-safe-soft);
	border-color: #9fd6b5;
}

.cp-results-stat-filter.cp-results-stat-target.is-active {
	background: var(--cp-target-soft);
	border-color: #e8c274;
}

.cp-results-stat-filter.cp-results-stat-dream.is-active {
	background: var(--cp-dream-soft);
	border-color: #e4a8b9;
}

.cp-results-stat-action {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	margin-top: 8px;
	padding: 5px 9px;
	border-radius: 999px;
	background: #edf4fb;
	border: 1px solid #cde0f2;
	color: #365676;
	font-size: 10px;
	font-weight: 800;
	letter-spacing: 0.05em;
	text-transform: uppercase;
	line-height: 1.1;
}

.cp-results-stat-filter.is-active .cp-results-stat-action {
	background: #ffffff;
	border-color: rgba(54, 86, 118, 0.25);
}

.cp-results-stat-label {
	color: #465d74;
	margin-bottom: 4px;
}

.cp-results-stat-hint {
	display: block;
	margin-bottom: 8px;
	font-size: 11px;
	font-weight: 700;
	color: #5b738a;
}

.cp-results-note {
	margin: -8px 0 0;
	font-size: 13px;
	line-height: 1.6;
	color: #5f6f82;
}

.cp-results-stat strong {
	display: block;
	font-size: 30px;
	line-height: 1;
	color: var(--cp-ink);
}

.cp-featured-partners {
	padding: 18px;
	border-radius: 22px;
	border: 1px solid #d8e5f2;
	background:
		linear-gradient(145deg, rgba(232, 242, 252, 0.82) 0%, rgba(255, 255, 255, 0.95) 46%, rgba(255, 243, 214, 0.55) 100%);
	box-shadow: 0 12px 28px rgba(17, 31, 48, 0.06);
}

.cp-featured-partners-head h3 {
	margin: 10px 0 8px;
	font-size: 24px;
	line-height: 1.2;
	color: var(--cp-ink);
}

.cp-featured-partners-head p {
	margin: 0;
	max-width: 760px;
	font-size: 14px;
	line-height: 1.7;
	color: #4f657d;
}

.cp-featured-partners-grid {
	display: grid;
	grid-template-columns: repeat(3, minmax(0, 1fr));
	gap: 12px;
	margin-top: 14px;
}

.cp-featured-partner-card {
	display: grid;
	gap: 8px;
	padding: 16px;
	border-radius: 16px;
	border: 1px solid #d2e0ee;
	background: #ffffff;
	box-shadow: 0 10px 22px rgba(17, 31, 48, 0.05);
}

.cp-featured-partner-tag {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: fit-content;
	margin: 0;
	padding: 5px 10px;
	border-radius: 999px;
	border: 1px solid #ccdceb;
	background: #f4f9ff;
	color: #355676;
	font-size: 11px;
	font-weight: 800;
	letter-spacing: 0.04em;
	text-transform: uppercase;
}

.cp-featured-partner-title {
	margin: 0;
	font-size: 18px;
	line-height: 1.35;
	color: #183451;
}

.cp-featured-partner-meta {
	margin: 0;
	font-size: 13px;
	line-height: 1.6;
	color: #5f7388;
}

.cp-partner-distance {
	color: #355a7d;
	font-weight: 700;
}

.cp-partner-distance::before {
	content: "•";
	margin: 0 6px;
	color: #c6d1dd;
}

.cp-featured-partners-gps {
	margin-top: 14px;
}

.cp-featured-partner-actions {
	margin-top: 2px;
	display: flex;
	align-items: center;
	gap: 8px;
}

.cp-featured-partner-actions .cp-btn {
	min-height: 40px;
	padding-inline: 14px;
	font-size: 13px;
}

.cp-share-bar {
	padding: 16px 18px;
	border-radius: 18px;
	background: linear-gradient(180deg, #f6fbff 0%, #ffffff 100%);
	border: 1px solid #dbe7f3;
	box-shadow: 0 12px 30px rgba(17, 31, 48, 0.05);
}

.cp-share-copy h3 {
	margin: 0 0 6px;
	font-size: 18px;
	line-height: 1.25;
	color: var(--cp-ink);
}

.cp-share-copy p {
	margin: 0;
	color: var(--cp-muted);
	line-height: 1.7;
}

.cp-share-actions {
	display: flex;
	flex-wrap: wrap;
	gap: 10px;
	margin-top: 12px;
}

.cp-share-btn {
	min-height: 40px;
	padding: 0 14px;
}

.cp-share-actions .cp-share-btn {
	min-height: 44px;
	padding: 0 16px;
	border-radius: 999px;
	font-weight: 800;
	letter-spacing: 0.01em;
	border-width: 1px;
	box-shadow: 0 8px 18px rgba(17, 31, 48, 0.08);
	transition: transform 120ms ease, box-shadow 120ms ease, filter 120ms ease;
}

.cp-share-actions .cp-share-btn:hover,
.cp-share-actions .cp-share-btn:focus-visible {
	transform: translateY(-1px);
	box-shadow: 0 12px 22px rgba(17, 31, 48, 0.14);
	outline: none;
	filter: saturate(1.04);
}

.cp-share-actions [data-share-action="native"] {
	background: linear-gradient(135deg, #18477a 0%, #143f6b 100%);
	border-color: #11375c;
	color: #ffffff;
}

.cp-share-actions [data-share-action="whatsapp"] {
	background: linear-gradient(135deg, #21b760 0%, #16914a 100%);
	border-color: #148242;
	color: #ffffff;
}

.cp-share-actions [data-share-action="telegram"] {
	background: linear-gradient(135deg, #2d8fe0 0%, #2278c0 100%);
	border-color: #1f69a8;
	color: #ffffff;
}

.cp-share-actions [data-share-action="copy"] {
	background: #ffffff;
	border-color: #b8cadc;
	color: #24496d;
}

.cp-share-status {
	margin: 10px 0 0;
	min-height: 20px;
	font-size: 13px;
	font-weight: 700;
	color: var(--cp-blue);
}

.cp-pagination {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: 8px;
	margin-top: 14px;
}

.cp-page-link {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-width: 44px;
	height: 44px;
	padding: 0 12px;
	border-radius: 12px;
	background: #ffffff;
	border: 1px solid #d8e4f0;
	color: #2d4660;
	font-size: 14px;
	font-weight: 700;
	text-decoration: none;
	transition: transform 120ms ease, box-shadow 120ms ease, border-color 120ms ease;
}

.cp-page-link:hover,
.cp-page-link:focus-visible {
	transform: translateY(-1px);
	border-color: #9fbbd8;
	box-shadow: 0 8px 18px rgba(17, 31, 48, 0.08);
	outline: none;
}

.cp-page-link-current {
	background: #e9f3ff;
	border-color: #8fb3d8;
	color: #154779;
}

.cp-page-link-nav {
	min-width: 82px;
}

.cp-page-ellipsis {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-width: 20px;
	height: 38px;
	color: #6b7c8e;
	font-weight: 700;
}

.cp-summary-card,
.cp-info-card {
	padding: 24px;
	border-color: rgba(112, 148, 208, 0.28);
	box-shadow:
		0 18px 42px rgba(4, 12, 29, 0.34),
		inset 0 1px 0 rgba(182, 206, 255, 0.08);
}

.cp-summary-card {
	background: linear-gradient(180deg, rgba(22, 38, 74, 0.98) 0%, rgba(15, 28, 56, 0.98) 100%);
}

.cp-info-card {
	background: linear-gradient(180deg, rgba(21, 36, 70, 0.98) 0%, rgba(14, 27, 54, 0.98) 100%);
}

.cp-summary-card h2,
.cp-summary-card h3,
.cp-info-card h2,
.cp-info-card h3 {
	margin-top: 0;
	color: var(--cp-ink);
}

.cp-summary-card h2 {
	margin-bottom: 12px;
	font-size: 28px;
	line-height: 1.15;
}

.cp-info-card h2 {
	padding-bottom: 10px;
	border-bottom: 1px solid rgba(162, 188, 228, 0.18);
	margin-bottom: 14px;
}

.cp-info-card h3 {
	margin-top: 18px;
	margin-bottom: 8px;
}

.cp-info-card ul {
	margin: 0;
	padding-left: 20px;
}

.cp-summary-card ul {
	margin: 0;
	padding-left: 20px;
}

.cp-info-card-methodology {
	border-top: 4px solid #7fa6d1;
}

.cp-info-card-nearby {
	border-top: 4px solid #4f8ac4;
}

.cp-info-card-next-steps {
	border-top: 4px solid #4f8ac4;
}

.cp-summary-card-before-start {
	border-top: 4px solid #4f8ac4;
	background: linear-gradient(180deg, rgba(23, 43, 84, 0.99) 0%, rgba(15, 29, 58, 0.99) 100%);
}

.cp-summary-card-trust {
	border-top: 4px solid #d6ac5a;
	background: linear-gradient(180deg, rgba(39, 33, 58, 0.98) 0%, rgba(18, 27, 52, 0.99) 100%);
}

.cp-summary-card p,
.cp-summary-card li,
.cp-info-card p,
.cp-info-card li,
.cp-faq p {
	color: #bfd0e9;
	line-height: 1.85;
}

.cp-summary-card a,
.cp-info-card a {
	color: #8ec7ff;
}

.cp-summary-card li > a,
.cp-info-card li > a {
	display: inline-flex;
	align-items: center;
	min-height: 40px;
	padding: 4px 2px;
}

.cp-summary-card li + li,
.cp-info-card li + li {
	margin-top: 4px;
}

.cp-summary-card a:hover,
.cp-summary-card a:focus-visible,
.cp-info-card a:hover,
.cp-info-card a:focus-visible {
	color: #d9ecff;
}

.cp-next-steps-grid {
	display: grid;
	grid-template-columns: repeat(2, minmax(0, 1fr));
	gap: 14px;
}

.cp-next-step-card {
	display: flex;
	flex-direction: column;
	gap: 8px;
	padding: 18px;
	border-radius: 18px;
	border: 1px solid rgba(112, 148, 208, 0.24);
	background: linear-gradient(180deg, rgba(30, 50, 92, 0.82) 0%, rgba(20, 36, 68, 0.9) 100%);
	color: #c8daef;
	text-decoration: none;
	transition: transform 120ms ease, box-shadow 120ms ease, border-color 120ms ease;
}

.cp-next-step-card strong {
	font-size: 17px;
	line-height: 1.35;
	color: var(--cp-ink);
}

.cp-next-step-card span {
	font-size: 14px;
	line-height: 1.75;
	color: #a9bedc;
}

.cp-next-step-card:hover,
.cp-next-step-card:focus-visible {
	transform: translateY(-1px);
	border-color: rgba(149, 186, 238, 0.44);
	box-shadow: 0 14px 26px rgba(4, 12, 29, 0.24);
	outline: none;
}

.cp-group {
	margin-bottom: 8px;
	padding: 22px 22px 20px;
	border-radius: 26px;
	background: rgba(255, 255, 255, 0.72);
	border: 1px solid rgba(16, 35, 59, 0.08);
}

.cp-group-safe {
	background: linear-gradient(180deg, rgba(231, 247, 236, 0.72) 0%, rgba(255, 255, 255, 0.92) 100%);
	border-left: 4px solid #79bc92;
}

.cp-group-target {
	background: linear-gradient(180deg, rgba(255, 244, 219, 0.75) 0%, rgba(255, 255, 255, 0.92) 100%);
	border-left: 4px solid #dcad56;
}

.cp-group-dream {
	background: linear-gradient(180deg, rgba(253, 235, 240, 0.76) 0%, rgba(255, 255, 255, 0.92) 100%);
	border-left: 4px solid #d090a0;
}

.cp-group-head {
	display: flex;
	align-items: flex-end;
	justify-content: space-between;
	gap: 12px;
	margin-bottom: 16px;
}

.cp-group-head h2,
.cp-group-head h3 {
	margin: 0;
	font-size: 26px;
	color: var(--cp-ink);
}

.cp-group-head p {
	margin: 6px 0 0;
	max-width: 740px;
	color: var(--cp-muted);
	line-height: 1.7;
}

.cp-group-count {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-width: 42px;
	height: 42px;
	padding: 0 12px;
	border-radius: 999px;
	font-weight: 800;
	font-size: 15px;
}

.cp-group-count-safe {
	background: var(--cp-safe-soft);
	color: var(--cp-safe);
}

.cp-group-count-target {
	background: var(--cp-target-soft);
	color: var(--cp-target);
}

.cp-group-count-dream {
	background: var(--cp-dream-soft);
	color: var(--cp-dream);
}

.cp-empty {
	padding: 18px;
	background: rgba(13, 31, 67, 0.84);
	border: 1px dashed rgba(121, 152, 206, 0.55);
	border-radius: 16px;
	color: #c2d6f1;
}

.cp-empty p {
	margin: 0;
}

.cp-empty p + p {
	margin-top: 10px;
}

.cp-recovery-actions {
	display: flex;
	flex-wrap: wrap;
	gap: 8px;
	margin-top: 12px;
}

.cp-recovery-actions .cp-btn {
	min-height: 44px;
}

.cp-results-grid {
	display: grid;
	grid-template-columns: 1fr;
	gap: 10px;
}

.cp-card {
	padding: 10px 12px;
	border-radius: 14px;
	border: 1px solid rgba(121, 152, 206, 0.55);
	background: #10234a;
	box-shadow: 0 10px 24px rgba(4, 10, 28, 0.34);
}

.cp-card-top {
	display: flex;
	align-items: flex-start;
	justify-content: space-between;
	gap: 8px;
	margin-bottom: 8px;
}

.cp-card-title {
	margin: 0 0 2px;
	font-size: 17px;
	line-height: 1.2;
	color: var(--cp-ink);
}

.cp-card-meta {
	margin: 0;
	color: #b7cae6;
	font-size: 11px;
	line-height: 1.35;
}

.cp-card-meta > span:not(.cp-card-distance) {
	margin: 0 6px;
	color: #6f89ad;
}

.cp-card-distance {
	color: #8fc8ff;
	font-weight: 700;
}

.cp-card-distance::before {
	content: "•";
	margin: 0 6px;
	color: #c6d1dd;
}

.cp-card-tags {
	display: flex;
	flex-wrap: wrap;
	gap: 8px;
	margin-top: 12px;
}

.cp-card-tag {
	background: rgba(16, 35, 74, 0.85);
	border: 1px solid rgba(121, 152, 206, 0.5);
	color: #dce8ff;
	font-size: 12px;
}

.cp-badge {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	padding: 5px 9px;
	border-radius: 999px;
	font-size: 10px;
	font-weight: 800;
	white-space: nowrap;
}

.cp-badge-safe {
	background: var(--cp-safe-soft);
	color: var(--cp-safe);
	border: 1px solid #bee4ca;
}

.cp-badge-target {
	background: var(--cp-target-soft);
	color: var(--cp-target);
	border: 1px solid #f1d494;
}

.cp-badge-dream {
	background: var(--cp-dream-soft);
	color: var(--cp-dream);
	border: 1px solid #f1c7d2;
}

.cp-metrics {
	display: grid;
	gap: 6px;
	margin-bottom: 6px;
	width: 100%;
	max-width: min(100%, 900px);
}

.cp-metrics-3 {
	grid-template-columns: repeat(3, minmax(0, 1fr));
}

.cp-metrics-4 {
	grid-template-columns: repeat(4, minmax(0, 1fr));
}

.cp-metrics:not(.cp-metrics-3):not(.cp-metrics-4) {
	grid-template-columns: repeat(3, minmax(0, 1fr));
}

.cp-metric {
	padding: 8px 9px;
	border: 1px solid rgba(121, 152, 206, 0.52);
	border-radius: 10px;
	background: var(--cp-panel-soft);
}

.cp-metric-label {
	font-size: 9px;
	font-weight: 800;
	letter-spacing: 0.04em;
	text-transform: uppercase;
	color: #9cb8da;
	margin-bottom: 3px;
}

.cp-metric-value {
	font-size: 16px;
	line-height: 1.1;
	font-weight: 800;
	color: var(--cp-ink);
}

.cp-metric-value-sm {
	font-size: 14px;
}

.cp-metric-sub {
	margin-top: 6px;
	font-size: 13px;
	color: var(--cp-muted);
}

.cp-trend-impact-note {
	margin: 0 0 10px;
	padding: 10px 12px;
	border: 1px solid rgba(121, 152, 206, 0.52);
	border-radius: 12px;
	background: rgba(16, 35, 74, 0.86);
	font-size: 13px;
	line-height: 1.5;
	color: #c9ddf8;
}

.cp-comparison-summary {
	margin: 0 0 8px;
	font-size: 13px;
	line-height: 1.55;
	color: #d7e6fb;
}

.cp-detail-meta-list {
	display: flex;
	flex-wrap: wrap;
	gap: 8px;
	margin: 0 0 12px;
}

.cp-detail-meta-item {
	display: inline-flex;
	align-items: center;
	min-height: 30px;
	padding: 0 10px;
	border-radius: 999px;
	border: 1px solid rgba(121, 152, 206, 0.4);
	background: rgba(17, 39, 79, 0.92);
	color: #bfd2ee;
	font-size: 12px;
	font-weight: 700;
	line-height: 1.4;
}

.cp-history {
	margin-bottom: 10px;
}

.cp-history-label {
	font-size: 13px;
	font-weight: 800;
	color: #a9c0df;
	margin-bottom: 8px;
}

.cp-history-box {
	padding: 10px;
	border: 1px solid rgba(121, 152, 206, 0.52);
	border-radius: 12px;
	background: var(--cp-panel-soft);
	color: #c9dcf6;
	line-height: 1.6;
	font-size: 12px;
}

.cp-card-aside {
	display: inline-flex;
	align-items: center;
	justify-content: flex-end;
	gap: 8px;
	flex: 0 0 auto;
}

.cp-card-aside .cp-card-details-toggle {
	min-height: 30px;
	padding: 0 10px;
	font-size: 11px;
	width: auto;
	display: inline-flex;
}

.cp-card-details[hidden] {
	display: none;
}

.cp-card-details {
	margin-top: 8px;
	padding: 10px;
	border: 1px solid rgba(121, 152, 206, 0.55);
	border-radius: 10px;
	background: #13254c;
}

.cp-trend-inline-head {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 12px;
	margin: 8px 0 8px;
}

.cp-trend-inline-head h4 {
	margin: 0;
	font-size: 16px;
	color: var(--cp-ink);
}

.cp-trend-pill {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	padding: 6px 10px;
	border-radius: 999px;
	border: 1px solid transparent;
	background: #203d67;
	color: #dbe9ff;
	font-size: 12px;
	font-weight: 800;
	letter-spacing: 0.03em;
	text-transform: uppercase;
}

.cp-trend-pill-rising {
	background: rgba(120, 34, 55, 0.36);
	border-color: rgba(239, 133, 159, 0.58);
	color: #ffdbe5;
}

.cp-trend-pill-falling {
	background: rgba(21, 96, 60, 0.34);
	border-color: rgba(129, 214, 170, 0.58);
	color: #d8ffe7;
}

.cp-trend-pill-stable {
	background: rgba(36, 77, 128, 0.36);
	border-color: rgba(131, 180, 232, 0.58);
	color: #dbeeff;
}

.cp-trend-pill-not-enough {
	background: rgba(66, 85, 112, 0.36);
	border-color: rgba(168, 187, 214, 0.52);
	color: #e1ebf8;
}

.cp-trend-summary {
	margin: 0 0 8px;
	color: #c9dbf3;
	line-height: 1.6;
}

.cp-trend-stats-line {
	margin: 0 0 10px;
	font-size: 12px;
	line-height: 1.6;
	color: #b7cae6;
}

.cp-trend-stats-line strong {
	color: #eef6ff;
	font-weight: 800;
}

.cp-trend-range-summary {
	margin: 0 0 10px;
	font-size: 12px;
	line-height: 1.55;
	color: #adc3e4;
}

.cp-trend-table-head,
.cp-trend-row {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 12px;
	padding: 8px 0;
}

.cp-trend-table-head {
	font-size: 12px;
	font-weight: 800;
	letter-spacing: 0.03em;
	text-transform: uppercase;
	color: #9cb8da;
	border-bottom: 1px solid rgba(121, 152, 206, 0.46);
}

.cp-trend-row {
	border-bottom: 1px solid rgba(121, 152, 206, 0.34);
	color: #d2e3fa;
}

.cp-trend-row:last-child {
	border-bottom: 0;
}

.cp-trend-year {
	font-weight: 700;
}

.cp-trend-cutoff {
	font-weight: 700;
	text-align: right;
}

.cp-trend-cutoff-muted {
	color: #8ea7ca;
	font-weight: 600;
}

.cp-trend-chart-wrap {
	margin: 8px 0 8px;
	padding: 6px 0 0;
	border: 0;
	border-top: 1px solid rgba(121, 152, 206, 0.42);
	border-radius: 0;
	background: transparent;
}

.cp-trend-chart-host {
	margin: 8px 0 10px;
}

.cp-trend-svg {
	display: block;
	width: 100%;
	height: auto;
	overflow: visible;
}

.cp-trend-graph-empty {
	padding: 12px;
	border: 1px dashed rgba(121, 152, 206, 0.5);
	border-radius: 10px;
	background: rgba(16, 35, 74, 0.8);
	color: #b8cdea;
	text-align: center;
}

.cp-trend-gridline {
	stroke: rgba(121, 152, 206, 0.3);
	stroke-width: 1;
}

.cp-trend-baseline {
	stroke: rgba(121, 152, 206, 0.56);
	stroke-width: 1.2;
}

.cp-trend-axis-label,
.cp-trend-year-label {
	fill: #9cb8da;
	font-size: 11px;
	font-weight: 600;
}

.cp-trend-line {
	fill: none;
	stroke: var(--cp-blue);
	stroke-width: 3;
	stroke-linecap: round;
	stroke-linejoin: round;
}

.cp-trend-line-single {
	stroke-width: 2.5;
	stroke-dasharray: 6 5;
	opacity: 0.9;
}

.cp-trend-point {
	fill: var(--cp-blue);
	stroke: #ffffff;
	stroke-width: 2;
}

.cp-faq {
	display: grid;
	gap: 16px;
}

.cp-faq-search {
	margin-bottom: 14px;
}

.cp-faq-search-label {
	display: block;
	margin-bottom: 8px;
	font-size: 12px;
	font-weight: 800;
	letter-spacing: 0.05em;
	text-transform: uppercase;
	color: #9fb6d5;
}

.cp-faq-search-input {
	width: 100%;
	height: 44px;
	padding: 0 14px;
	border-radius: 12px;
	border: 1px solid #cfdceb;
	background: #ffffff;
	font-size: 14px;
	color: #1f3650;
}

.cp-faq-search-input:focus {
	outline: none;
	border-color: #8fb1d4;
	box-shadow: 0 0 0 3px rgba(47, 111, 178, 0.12);
}

.cp-faq-search-status {
	margin: 8px 0 0;
	font-size: 12px;
	font-weight: 700;
	color: #bcd0ea;
}

.cp-faq-search-empty {
	margin: 0;
	padding: 12px 14px;
	border-radius: 12px;
	background: #fff5f6;
	border: 1px solid #f2c9d1;
	color: #813247;
	font-size: 13px;
	font-weight: 700;
}

.cp-faq-item {
	border-radius: 18px;
	background: #10234a;
	border: 1px solid #385a8f;
	overflow: hidden;
}

.cp-faq-summary {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 12px;
	width: 100%;
	padding: 16px 18px;
	cursor: pointer;
	list-style: none;
}

.cp-faq-summary::-webkit-details-marker {
	display: none;
}

.cp-faq-question {
	font-size: 18px;
	font-weight: 700;
	line-height: 1.4;
	color: #eef6ff;
}

.cp-faq-icon {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 18px;
	height: 18px;
	flex: 0 0 18px;
	position: relative;
	color: #9fc3ee;
}

.cp-faq-icon::before,
.cp-faq-icon::after {
	content: "";
	position: absolute;
	background: currentColor;
	border-radius: 2px;
}

.cp-faq-icon::before {
	width: 12px;
	height: 2px;
}

.cp-faq-icon::after {
	width: 2px;
	height: 12px;
}

.cp-faq-item[open] .cp-faq-icon::after {
	opacity: 0;
}

.cp-faq-answer {
	padding: 0 18px 16px;
	border-top: 1px solid rgba(159, 195, 238, 0.26);
}

.cp-faq-answer p {
	margin: 12px 0 0;
	color: #bcd0ea;
}

#predictor-guide,
#predictor-methodology,
#predictor-provenance,
#predictor-faq {
	position: relative;
	padding-top: 10px;
	scroll-margin-top: 92px;
}

#predictor-guide::before,
#predictor-methodology::before,
#predictor-provenance::before,
#predictor-faq::before {
	content: "";
	display: block;
	margin: 6px 0 20px;
	height: 1px;
	background: linear-gradient(90deg, rgba(20, 55, 90, 0.06), rgba(20, 55, 90, 0.2), rgba(20, 55, 90, 0.06));
}

@keyframes cp-surface-enter {
	from {
		opacity: 0;
		transform: translateY(14px);
	}
	to {
		opacity: 1;
		transform: translateY(0);
	}
}

@keyframes cp-card-enter {
	from {
		opacity: 0;
		transform: translateY(10px);
	}
	to {
		opacity: 1;
		transform: translateY(0);
	}
}

@keyframes cp-detail-enter {
	from {
		opacity: 0;
		transform: translateY(-6px);
	}
	to {
		opacity: 1;
		transform: translateY(0);
	}
}

@keyframes cp-detail-exit {
	from {
		opacity: 1;
		transform: translateY(0);
	}
	to {
		opacity: 0;
		transform: translateY(-6px);
	}
}

.cp-motion-surface.cp-motion-in {
	animation: cp-surface-enter 460ms cubic-bezier(0.22, 1, 0.36, 1) both;
	animation-delay: var(--cp-motion-delay, 0ms);
}

.cp-motion-card.cp-motion-in {
	animation: cp-card-enter 380ms cubic-bezier(0.2, 0.88, 0.24, 1) both;
	animation-delay: var(--cp-motion-delay, 0ms);
}

.cp-motion-detail.cp-motion-in {
	animation: cp-detail-enter 220ms ease both;
}

.cp-card-details.cp-detail-closing {
	animation: cp-detail-exit 180ms ease both;
	pointer-events: none;
}

.cp-summary-card,
.cp-info-card,
.cp-card,
.cp-featured-partner-card {
	transition:
		transform 160ms ease,
		box-shadow 180ms ease,
		border-color 180ms ease;
}

.cp-summary-card:hover,
.cp-summary-card:focus-within,
.cp-info-card:hover,
.cp-info-card:focus-within,
.cp-card:hover,
.cp-card:focus-within,
.cp-featured-partner-card:hover,
.cp-featured-partner-card:focus-within {
	transform: translateY(-2px);
	box-shadow:
		0 18px 34px rgba(4, 12, 29, 0.24),
		inset 0 1px 0 rgba(182, 206, 255, 0.08);
	border-color: rgba(149, 186, 238, 0.44);
}

@media (prefers-reduced-motion: reduce) {
	.cp-motion-surface.cp-motion-in,
	.cp-motion-card.cp-motion-in,
	.cp-motion-detail.cp-motion-in,
	.cp-card-details.cp-detail-closing,
	.cp-results-stat-filter.is-active.cp-bucket-highlight,
	.cp-summary-card,
	.cp-info-card,
	.cp-card,
	.cp-featured-partner-card,
	.cp-btn,
	.cp-page-link {
		animation: none !important;
		transition: none !important;
	}
}

@media (max-width: 1040px) {
	.cp-hero,
	.cp-results-head,
	.cp-form-head {
		grid-template-columns: 1fr;
		display: grid;
	}

	.cp-results-stats {
		min-width: 0;
	}

	.cp-results-sort {
		min-width: 0;
		width: 100%;
		max-width: 360px;
	}
}

@media (max-width: 900px) {
	.cp-form-grid {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}

	.cp-form-primary-grid {
		grid-template-columns: 1fr;
	}

	.cp-top-summary-grid,
	.cp-next-steps-grid {
		grid-template-columns: 1fr;
	}

	.cp-metrics-3,
	.cp-metrics-4,
	.cp-metrics:not(.cp-metrics-3):not(.cp-metrics-4) {
		grid-template-columns: repeat(3, minmax(0, 1fr));
		max-width: 100%;
	}

	.cp-results-head,
	.cp-group-head,
	.cp-card-top {
		align-items: flex-start;
	}

	.cp-results-stats {
		grid-template-columns: repeat(3, minmax(0, 1fr));
		gap: 8px;
		min-width: 0;
		width: 100%;
	}

	.cp-results-sort {
		width: 100%;
		max-width: none;
	}

	.cp-featured-partners-grid {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}

	.cp-results-stat {
		padding: 10px 10px;
		border-radius: 14px;
		text-align: center;
	}

	.cp-results-stat-label {
		margin-bottom: 6px;
		font-size: 10px;
	}

	.cp-results-stat-hint {
		margin-bottom: 6px;
		font-size: 10px;
	}

	.cp-results-stat strong {
		font-size: 24px;
	}

	.cp-faq-question {
		font-size: 17px;
	}

	.cp-share-actions .cp-btn {
		flex: 1 1 160px;
	}

	.cp-results-loading-grid {
		grid-template-columns: 1fr;
	}

	.cp-page-link-nav {
		min-width: 72px;
	}

}

@media (max-width: 640px) {
	.cp-page {
		padding: 16px 12px 36px;
	}

	.cp-hero,
	.cp-form-card,
	.cp-summary-card,
	.cp-info-card,
	.cp-group,
	.cp-card {
		border-radius: 20px;
	}

	.cp-hero,
	.cp-form-card,
	.cp-summary-card,
	.cp-info-card,
	.cp-group,
	.cp-card {
		padding: 18px;
	}

	.cp-results-summary,
	.cp-results-search {
		padding: 18px;
	}

	.cp-card {
		padding: 10px;
		border-radius: 14px;
	}

	.cp-field-label-row {
		flex-wrap: wrap;
	}

	.cp-detect-location-btn {
		height: 28px;
		padding: 0 8px;
		font-size: 10px;
	}

	.cp-location-status {
		font-size: 7px;
		line-height: 1.15;
	}

	.cp-cluster-links a {
		flex: 1 1 calc(50% - 6px);
		min-height: 40px;
	}

	.cp-form-grid {
		grid-template-columns: 1fr;
	}

	.cp-form-primary-grid {
		grid-template-columns: 1fr;
	}

	.cp-metrics-3,
	.cp-metrics-4,
	.cp-metrics:not(.cp-metrics-3):not(.cp-metrics-4) {
		grid-template-columns: repeat(3, minmax(0, 1fr));
		gap: 6px;
		max-width: 100%;
	}

	.cp-results-stats {
		grid-template-columns: repeat(3, minmax(0, 1fr));
		gap: 6px;
	}

	.cp-results-sort label {
		font-size: 11px;
	}

	.cp-results-stat {
		padding: 8px 8px;
		border-radius: 12px;
	}

	.cp-results-stat-filter {
		min-height: 112px;
	}

	.cp-results-stat strong {
		font-size: 18px;
	}

	.cp-results-note {
		font-size: 12px;
	}

	.cp-featured-partners {
		padding: 14px;
		border-radius: 16px;
	}

	.cp-featured-partners-head h3 {
		font-size: 20px;
	}

	.cp-featured-partners-grid {
		grid-template-columns: 1fr;
		gap: 10px;
	}

	.cp-featured-partner-card {
		padding: 13px;
		border-radius: 14px;
	}

	.cp-featured-partner-title {
		font-size: 17px;
	}

	.cp-featured-partner-actions .cp-btn {
		width: 100%;
	}

	.cp-results-filter-state a {
		margin-left: 0;
		margin-top: 6px;
	}

	.cp-college-suggestions {
		max-height: 220px;
	}

	.cp-card-top,
	.cp-group-head,
	.cp-trend-inline-head {
		flex-direction: column;
		align-items: flex-start;
	}

	.cp-title {
		font-size: 38px;
	}

	.cp-form-title,
	.cp-results-head h2 {
		font-size: 28px;
	}

	.cp-card-title {
		font-size: 16px;
	}

	.cp-card-details {
		padding: 8px;
		border-radius: 10px;
	}

	.cp-metric {
		padding: 7px 8px;
		border-radius: 10px;
	}

	.cp-metric-label {
		font-size: 8px;
		margin-bottom: 2px;
	}

	.cp-metric-value {
		font-size: 15px;
	}

	.cp-metric-value-sm {
		font-size: 13px;
	}

	.cp-metric-sub {
		margin-top: 4px;
		font-size: 11px;
	}

	.cp-btn {
		width: 100%;
	}

	/* Keep per-card details button compact on mobile. */
	.cp-card-details-toggle {
		width: auto;
		display: inline-flex;
	}

	/* Keep badge + details action together and centered on mobile. */
	.cp-card-aside {
		width: 100%;
		justify-content: center;
		align-items: center;
	}

	.cp-share-bar {
		padding: 14px;
		border-radius: 14px;
	}

	.cp-results-loading {
		padding: 14px;
		border-radius: 14px;
	}

	.cp-share-copy h3 {
		font-size: 16px;
	}

	.cp-share-status {
		font-size: 12px;
		min-height: 18px;
	}

	.cp-faq-summary {
		padding: 14px 14px;
	}

	.cp-faq-question {
		font-size: 16px;
	}

	.cp-faq-answer {
		padding: 0 14px 14px;
	}

	.cp-pagination {
		gap: 6px;
	}

	.cp-page-link {
		min-width: 44px;
		height: 44px;
		padding: 0 10px;
		font-size: 13px;
		border-radius: 10px;
	}

	.cp-page-link-nav {
		min-width: 64px;
	}

	.cp-back-to-top {
		right: 12px;
		bottom: 14px;
		min-width: 48px;
		height: 48px;
		font-size: 12px;
	}

	.cp-narrow-results-button {
		right: 66px;
		bottom: 14px;
		min-height: 48px;
		padding: 0 12px;
		font-size: 11px;
	}

}

@media (min-width: 769px) {
	.cp-narrow-results-button {
		display: none;
	}
}

@media (max-width: 1024px) {
	.cp-mobile-location-only {
		display: block;
	}

	button.cp-mobile-location-only {
		display: inline-flex;
	}

	.cp-mobile-location-only[hidden] {
		display: none;
	}
}

.cp-lead-form {
  margin-top: 24px;
  background: #fff;
  border: 1px solid #ccd0d4;
  border-radius: 16px;
  padding: 20px;
}

.cp-lead-form-copy h3 {
  margin: 0 0 6px;
}

.cp-lead-form-copy p {
  margin: 0 0 16px;
  color: #425466;
}

.cp-lead-form-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: 12px;
}

.cp-lead-form-grid .cp-field {
  display: flex;
  flex-direction: column;
  gap: 8px;
  min-width: 0;
}

.cp-lead-form-grid .cp-field label {
  display: block;
  margin-bottom: 0;
}

.cp-lead-form-grid .cp-field :is(input, select) {
  display: block;
  width: 100%;
}

.cp-field-checkbox {
  display: flex;
  align-items: flex-end;
}

.cp-lead-form-grid .cp-field-checkbox {
  justify-content: flex-end;
}

.cp-lead-form-grid .cp-field-checkbox label,
.cp-field-checkbox label {
  display: flex;
  gap: 8px;
  align-items: flex-start;
  font-size: 14px;
  line-height: 1.6;
  color: var(--cp-ink);
}

.cp-field-checkbox input[type="checkbox"] {
  appearance: auto;
  -webkit-appearance: checkbox;
  width: 18px;
  min-width: 18px;
  max-width: 18px;
  height: 18px;
  min-height: 18px;
  max-height: 18px;
  padding: 0;
  margin: 2px 4px 0 0;
  flex: 0 0 18px;
  accent-color: var(--cp-blue);
  border-radius: 4px;
  box-shadow: none;
  align-self: flex-start;
  vertical-align: top;
}

.cp-field-full {
  grid-column: 1 / -1;
}

.cp-lead-form-grid .cp-field-full {
  align-items: flex-start;
}

.cp-lead-form-grid .cp-field-full .cp-btn {
  width: auto;
  max-width: 100%;
}

.cp-field-full .cp-submit-feedback {
  margin-top: 8px;
}

@media (max-width: 767px) {
  .cp-lead-form {
    padding: 16px;
    border-radius: 14px;
  }

  .cp-lead-form-grid .cp-field-full .cp-btn {
    width: 100%;
  }
}

.cp-results-loading-card {
	background: #10234a;
	border-color: #385a8f;
}

.cp-skeleton {
	background: linear-gradient(
		90deg,
		rgba(75, 104, 153, 0.32) 0%,
		rgba(123, 153, 206, 0.42) 50%,
		rgba(75, 104, 153, 0.32) 100%
	);
}

/* Compact result-card metrics so more cards fit per screen. */
.cp-card .cp-metrics {
	display: flex;
	flex-wrap: wrap;
	gap: 5px;
	width: auto;
	max-width: 100%;
	margin-bottom: 4px;
}

.cp-card .cp-metric {
	flex: 0 0 auto;
	min-width: 86px;
	padding: 6px 8px;
	border-radius: 9px;
}

.cp-card .cp-metric-label {
	font-size: 8px;
	margin-bottom: 2px;
	letter-spacing: 0.03em;
}

.cp-card .cp-metric-value {
	font-size: 15px;
}

@media (max-width: 640px) {
	.cp-card .cp-metrics {
		gap: 4px;
	}

	.cp-card .cp-metric {
		min-width: 78px;
		padding: 6px 7px;
	}
}

.cp-card-details .cp-metrics {
	display: grid;
	grid-template-columns: repeat(3, minmax(0, 1fr));
	width: 100%;
	max-width: 100%;
	gap: 6px;
	margin-bottom: 8px;
}

.cp-card-details .cp-metric {
	min-width: 0;
}

@media (min-width: 1025px) {
	.cp-card-dense {
		padding: 8px 10px;
		border-radius: 12px;
	}

	.cp-card-top-dense {
		display: flex;
		align-items: center;
		justify-content: space-between;
		gap: 10px;
		margin-bottom: 4px;
	}

	.cp-card-main {
		min-width: 0;
		flex: 1 1 auto;
	}

	.cp-card-dense .cp-card-title {
		font-size: 15px;
		line-height: 1.2;
		margin: 0 0 1px;
	}

	.cp-card-dense .cp-card-meta {
		font-size: 10px;
		line-height: 1.25;
		white-space: nowrap;
		overflow: hidden;
		text-overflow: ellipsis;
	}

	.cp-card-dense .cp-badge {
		padding: 4px 8px;
		font-size: 9px;
	}

	.cp-card-dense .cp-card-aside {
		gap: 6px;
	}

	.cp-card-dense .cp-card-aside .cp-card-details-toggle {
		min-height: 26px;
		padding: 0 9px;
		font-size: 10px;
	}

	.cp-card-dense .cp-card-details {
		margin-top: 6px;
		padding: 8px;
		font-size: 13px;
		line-height: 1.5;
	}

	.cp-card-dense .cp-card-details .cp-metric {
		padding: 6px 7px;
		border-radius: 8px;
	}

	.cp-card-dense .cp-card-details .cp-metric-label {
		font-size: 8px;
		margin-bottom: 2px;
	}

	.cp-card-dense .cp-card-details .cp-metric-value {
		font-size: 13px;
	}

	.cp-card-dense .cp-history-label {
		font-size: 11px;
		margin-bottom: 5px;
	}

	.cp-card-dense .cp-history-box {
		padding: 7px 8px;
		font-size: 12px;
		line-height: 1.4;
	}

	.cp-card-dense .cp-field-help {
		margin-top: 4px;
		font-size: 12px;
	}

	.cp-card-dense .cp-trend-inline-head h4 {
		font-size: 14px;
	}

	.cp-card-dense .cp-trend-summary,
	.cp-card-dense .cp-trend-stats-line,
	.cp-card-dense .cp-trend-row {
		font-size: 12px;
	}

	.cp-card-dense .cp-comparison-summary,
	.cp-card-dense .cp-detail-meta-item,
	.cp-card-dense .cp-trend-range-summary {
		font-size: 12px;
	}

	.cp-card-dense .cp-trend-table-head {
		font-size: 11px;
	}

	.cp-card-dense .cp-trend-impact-note {
		padding: 8px 10px;
		font-size: 12px;
		margin-bottom: 8px;
	}

	.cp-card-dense .cp-trend-chart-wrap {
		margin: 6px 0 6px;
		padding-top: 4px;
	}

	.cp-card-dense .cp-trend-chart-host {
		margin: 6px 0 8px;
	}
}
