/*
 * ka-intake front-end styles. K&A brand is scoped to .kai-wizard via --kai-*
 * custom properties so the wizard renders on-brand (K&A blue #00ADEF / ink
 * #231F20 / Montserrat + Open Sans) regardless of the host site's Site Tokens
 * (the shared toolkit tokens are WES gold, not K&A — see plan D-D).
 */
.kai-wizard {
	--kai-primary: #00ADEF;
	--kai-primary-deep: #007EB3;
	--kai-primary-deep2: #006B97;
	--kai-primary-wash: #E6F7FE;
	--kai-ink: #231F20;
	--kai-gray: #7F7F7F;
	--kai-line: #d9e2e8;
	--kai-white: #ffffff;
	--kai-radius: 12px;
	--kai-radius-sm: 8px;
	--kai-gap: 1.25rem;
	--kai-font-head: "Montserrat", system-ui, "Segoe UI", Arial, sans-serif;
	--kai-font-body: "Open Sans", system-ui, Arial, sans-serif;
	--kai-shadow: 0 6px 24px rgba(35, 31, 32, 0.08);
	--kai-shadow-card: 0 2px 10px rgba(35, 31, 32, 0.06);

	font-family: var(--kai-font-body);
	color: var(--kai-ink);
	max-width: 720px;
	margin: 0 auto;
	background: var(--kai-white);
	border: 1px solid #cdd8df; /* firm enough to read without the shadow */
	border-radius: 16px;
	box-shadow: var(--kai-shadow);
	padding: 28px 32px 32px;
	position: relative;
	overflow: hidden;
}
/* Signature: the K&A screen-blue band along the card top (brand motif). */
.kai-wizard::before {
	content: "";
	position: absolute;
	top: 0; left: 0; right: 0;
	height: 5px;
	background: linear-gradient(90deg, var(--kai-light), var(--kai-primary) 45%, var(--kai-primary-deep));
}
@media (max-width: 560px) {
	.kai-wizard { padding: 20px 16px 24px; border-radius: 12px; }
}

/* In-wizard brand anchor */
.kai-wizard__brand {
	display: flex;
	align-items: center;
	gap: 0.6rem;
	margin-bottom: 1.25rem;
	padding-bottom: 0.9rem;
	border-bottom: 1px solid var(--kai-line);
}
.kai-wizard__brand-mark {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-width: 2.1rem;
	height: 2.1rem;
	padding: 0 0.3rem;
	border-radius: 8px;
	background: linear-gradient(135deg, var(--kai-primary-deep), var(--kai-primary-deep2, #006B97));
	color: var(--kai-white);
	font-family: var(--kai-font-head);
	font-weight: 800;
	font-size: 0.8rem;
	letter-spacing: 0.02em;
}
.kai-wizard__brand-text {
	font-family: var(--kai-font-head);
	font-weight: 700;
	font-size: 0.74rem;
	letter-spacing: 0.14em;
	text-transform: uppercase;
	color: var(--kai-gray-d, #565657);
}

.kai-wizard__inner { width: 100%; }

.kai-wizard__intro-heading,
.kai-step__title {
	font-family: var(--kai-font-head);
	font-weight: 700;
	line-height: 1.2;
	color: var(--kai-ink);
	margin: 0 0 0.5rem;
	font-size: clamp(1.35rem, 1.1rem + 1.4vw, 1.9rem);
	text-wrap: balance;
}
/* Signature: the K&A thin blue rule under each step heading (brand motif). */
.kai-step__title::after {
	content: "";
	display: block;
	width: 44px;
	height: 4px;
	border-radius: 2px;
	margin-top: 10px;
	background: linear-gradient(90deg, var(--kai-primary), var(--kai-primary-deep));
}

.kai-step__lede { margin: 0 0 0.35rem; font-size: 1.02rem; }
.kai-step__why {
	margin: 0 0 1.1rem;
	font-size: 0.9rem;
	color: var(--kai-gray-d, #565657);
	display: flex;
	gap: 0.5rem;
	align-items: flex-start;
}
.kai-step__why-mark { /* deepest blue for AA on the wash */
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 1.25rem;
	height: 1.25rem;
	border-radius: 50%;
	background: var(--kai-primary-wash);
	color: var(--kai-primary-deep2, #006B97);
	font-weight: 700;
	font-size: 0.8rem;
	flex: 0 0 auto;
}

/* Progress */
.kai-progress { margin-bottom: 1.5rem; }
.kai-progress__track {
	height: 8px;
	border-radius: 999px;
	background: var(--kai-line);
	overflow: hidden;
	position: relative;
}
/* One segment per step (total set by JS via --kai-total). */
.kai-progress__track::after {
	content: "";
	position: absolute;
	inset: 0;
	background: repeating-linear-gradient(
		90deg,
		transparent 0 calc(100% / var(--kai-total, 8) - 3px),
		var(--kai-white) calc(100% / var(--kai-total, 8) - 3px) calc(100% / var(--kai-total, 8))
	);
}
.kai-progress__bar {
	height: 100%;
	width: 0;
	border-radius: 999px;
	background: linear-gradient(90deg, var(--kai-primary), var(--kai-primary-deep));
	transition: width 0.35s ease;
}
.kai-progress__label {
	margin: 0.45rem 0 0;
	font-size: 0.82rem;
	font-weight: 600;
	letter-spacing: 0.02em;
	color: var(--kai-gray-d, #565657);
	text-transform: uppercase;
}

/* Steps */
.kai-step { border: 0; padding: 0; margin: 0; min-inline-size: 0; }
.kai-step[hidden] { display: none; }
.kai-step__fields { display: flex; flex-direction: column; gap: var(--kai-gap); }

/* Reused ka-forms field wrapper, restyled for the wizard */
.kai-wizard .ka_form__field { display: flex; flex-direction: column; gap: 0.4rem; }
.kai-wizard .ka_form__label,
.kai-cards__legend {
	font-family: var(--kai-font-head);
	font-weight: 600;
	font-size: 0.98rem;
}
.kai-wizard .ka_form__required,
.kai-cards__required { color: var(--kai-primary-deep); }
.kai-wizard .ka_form__input,
.kai-wizard .ka_form__textarea,
.kai-wizard .ka_form__select {
	width: 100%;
	padding: 0.7rem 0.85rem;
	border: 1.5px solid var(--kai-line);
	border-radius: var(--kai-radius-sm);
	font: inherit;
	color: var(--kai-ink);
	background: var(--kai-white);
	transition: border-color 0.15s ease, box-shadow 0.15s ease;
}
.kai-wizard .ka_form__input:focus,
.kai-wizard .ka_form__textarea:focus,
.kai-wizard .ka_form__select:focus {
	outline: none;
	border-color: var(--kai-primary);
	box-shadow: 0 0 0 3px var(--kai-primary-wash);
}
.kai-wizard .ka_form__help { font-size: 0.82rem; color: var(--kai-gray-d, #565657); }
.kai-wizard .ka_form__error { font-size: 0.82rem; color: #c0392b; font-weight: 600; }
.kai-wizard .ka_form__field--invalid .ka_form__input,
.kai-wizard .ka_form__field--invalid .ka_form__select,
.kai-wizard .ka_form__field--invalid .ka_form__textarea { border-color: #c0392b; }

/* Option cards (low-typing) */
.kai-cards { border: 0; padding: 0; margin: 0; min-inline-size: 0; }
.kai-cards__legend { padding: 0; margin-bottom: 0.6rem; }
.kai-cards__legend--sr {
	position: absolute;
	width: 1px; height: 1px;
	margin: -1px; padding: 0; border: 0;
	clip: rect(0 0 0 0); clip-path: inset(50%);
	overflow: hidden; white-space: nowrap;
}
.kai-cards__grid {
	display: grid;
	grid-template-columns: 1fr;
	gap: 0.75rem;
}
@media (min-width: 560px) {
	.kai-cards__grid { grid-template-columns: 1fr 1fr; }
}
.kai-card {
	position: relative;
	display: flex;
	gap: 0.7rem;
	align-items: flex-start;
	padding: 1rem 1.05rem;
	border: 1.5px solid var(--kai-line);
	border-radius: var(--kai-radius);
	background: var(--kai-white);
	box-shadow: var(--kai-shadow-card);
	cursor: pointer;
	transition: border-color 0.15s ease, box-shadow 0.15s ease, transform 0.1s ease;
}
.kai-card:hover { border-color: var(--kai-primary); transform: translateY(-1px); }
.kai-card__input {
	margin-top: 0.2rem;
	accent-color: var(--kai-primary);
	width: 1.1rem;
	height: 1.1rem;
	flex: 0 0 auto;
}
.kai-card:has(.kai-card__input:checked) {
	border-color: var(--kai-primary);
	box-shadow: 0 0 0 3px var(--kai-primary-wash), var(--kai-shadow-card);
	background: var(--kai-primary-wash);
}
.kai-card:has(.kai-card__input:focus-visible) { outline: 2px solid var(--kai-primary-deep); outline-offset: 2px; }
.kai-card__icon { font-size: 1.4rem; line-height: 1; }
.kai-card__body { display: flex; flex-direction: column; gap: 0.2rem; }
.kai-card__title { font-family: var(--kai-font-head); font-weight: 600; }
.kai-card__desc { font-size: 0.85rem; color: var(--kai-gray-d, #565657); }
.kai-cards__help { font-size: 0.82rem; color: var(--kai-gray-d, #565657); margin-top: 0.5rem; display: block; }

/* Nav */
.kai-wizard__nav {
	display: flex;
	flex-wrap: wrap;
	gap: 0.6rem;
	align-items: center;
	margin-top: 1.75rem;
	padding-top: 1.25rem;
	border-top: 1px solid var(--kai-line);
}
.kai-btn {
	font-family: var(--kai-font-head);
	font-weight: 600;
	font-size: 0.95rem;
	padding: 0.7rem 1.4rem;
	border-radius: 999px;
	border: 1.5px solid transparent;
	cursor: pointer;
	transition: background 0.15s ease, color 0.15s ease, border-color 0.15s ease;
}
.kai-btn--next,
.kai-btn--submit {
	background: var(--kai-primary);
	color: var(--kai-ink); /* brand motif: ink on blue panels; AA 6.3:1 (white was 2.4:1) */
	margin-left: auto;
}
.kai-btn--next:hover,
.kai-btn--submit:hover { background: var(--kai-primary-deep2, #006B97); color: var(--kai-white); }
.kai-btn--back { background: transparent; color: var(--kai-ink); border-color: var(--kai-line); }
.kai-btn--skip {
	background: transparent;
	color: var(--kai-gray-d, #565657);
	border: 1.5px solid transparent;
	text-decoration: none;
}
.kai-btn--skip:hover {
	color: var(--kai-primary-deep);
	background: var(--kai-primary-wash);
}
.kai-btn[hidden] { display: none; }

/* Confirm-back + status */
.kai-confirm { background: var(--kai-primary-wash); border-radius: var(--kai-radius); padding: 1.25rem; }
.kai-wizard__status { margin-top: 1rem; font-weight: 600; }
.kai-wizard__status--error { color: #c0392b; }
.kai-wizard__status--success { color: var(--kai-primary-deep); }

/* Scheduling embed (MS Bookings) */
.kai-schedule { margin-top: 1.75rem; padding-top: 1.25rem; border-top: 1px solid var(--kai-line); }
.kai-schedule__lede { color: var(--kai-gray-d, #565657); margin: 0 0 0.75rem; }
.kai-schedule__iframe { border: 1.5px solid var(--kai-line); border-radius: var(--kai-radius); width: 100%; min-height: 520px; background: var(--kai-white); }
.kai-schedule--fallback { background: var(--kai-primary-wash); border-radius: var(--kai-radius); padding: 1.25rem; border-top: 0; }
.kai-confirm__pages, .kai-confirm__why-list { margin: 0.25rem 0 0.75rem 1.1rem; }
.kai-confirm__why { font-weight: 600; margin: 0.5rem 0 0.15rem; }
.kai-confirm__note { color: var(--kai-gray); font-size: 0.9rem; }

/* a11y: honor prefers-reduced-motion (A9) */
@media (prefers-reduced-motion: reduce) {
	.kai-progress__bar,
	.kai-card,
	.kai-btn,
	.kai-wizard .ka_form__input,
	.kai-wizard .ka_form__textarea,
	.kai-wizard .ka_form__select {
		transition: none !important;
	}
	.kai-card:hover { transform: none; }
}

/* Compact option rows on small screens (critic: tall lopsided first card) */
@media (max-width: 560px) {
	.kai-card { padding: 0.8rem 0.85rem; gap: 0.55rem; }
	.kai-card__title { font-size: 0.95rem; }
	.kai-card__desc { font-size: 0.8rem; }
}

/* Mobile: recompose the progress as a plain bar (8 notches turn to dashes). */
@media (max-width: 560px) {
	.kai-progress__track::after { display: none; }
}

/* Honeypot: display-none. Stays in the DOM (the JS submit reads its value and
   name-targeting bots still fill it) while being invisible to users, AT, and
   the bounds/target-size audits alike. */
.kai-hp { display: none; }
