/**
 * IKS — Fluent Forms branded styling.
 *
 * Aligns the Membership Application form (and any other Fluent Forms on the site)
 * with the IKS brand: Inter typography, purple/magenta accents, soft shadows,
 * pill submit button, branded radio "card" tier picker.
 */

/* ── Form container & section ── */
.fluentform .ff-el-group,
.fluentform .ff-el-input--label,
.fluentform .ff-el-input--content,
.fluentform .ff-el-form-check label,
.fluentform .ff_btn_style,
.fluentform .ff-el-form-check-label,
.fluentform .ff-el-form-step .ff-step-titles,
.fluentform .ff-el-progress-status,
.fluentform input,
.fluentform select,
.fluentform textarea,
.fluentform button {
	font-family: var(--iks-font, 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif) !important;
}

.fluentform {
	color: var(--iks-ink, #1a0d1f);
}

.fluentform .ff-el-group {
	margin-bottom: 22px;
}

/* Section headings — both legacy custom_html and native section_break */
.fluentform .ff_custom_html h3,
.fluentform .ff-el-section-break .ff-el-section-title {
	margin: 28px 0 6px;
	padding-bottom: 10px;
	border-bottom: 1px solid rgba(129, 37, 165, 0.12);
	font-size: 1.05rem;
	font-weight: 700;
	letter-spacing: 0.01em;
	color: var(--iks-purple, #8125A5);
}
.fluentform .ff_custom_html h3:first-child,
.fluentform .ff-el-section-break:first-child .ff-el-section-title {
	margin-top: 0;
}
.fluentform .ff-el-section-break .ff_section_break_desk {
	margin: 0 0 12px;
	font-size: 0.88rem;
	color: var(--iks-slate, #5f6360);
}

/* ── Labels ── */
.fluentform .ff-el-input--label label {
	font-weight: 600;
	font-size: 0.9rem;
	color: var(--iks-ink, #1a0d1f);
	margin-bottom: 8px;
	letter-spacing: 0.005em;
}

.fluentform .ff-el-input--label label .ff-el-is-required {
	color: var(--iks-magenta, #AE0083);
}

/* ── Inputs / selects / textareas ── */
.fluentform .ff-el-form-control,
.fluentform input[type="text"],
.fluentform input[type="email"],
.fluentform input[type="tel"],
.fluentform input[type="number"],
.fluentform input[type="url"],
.fluentform input[type="date"],
.fluentform input[type="password"],
.fluentform select,
.fluentform textarea {
	width: 100%;
	height: 46px;
	padding: 10px 14px;
	font-size: 0.95rem;
	color: var(--iks-ink, #1a0d1f);
	background: #fff;
	border: 1px solid rgba(45, 17, 56, 0.14);
	border-radius: 10px;
	box-shadow: none;
	transition: border-color 0.2s var(--iks-ease-soft, ease), box-shadow 0.2s var(--iks-ease-soft, ease);
}

.fluentform textarea {
	height: auto;
	min-height: 120px;
	padding: 12px 14px;
}

.fluentform .ff-el-form-control:focus,
.fluentform input:focus,
.fluentform select:focus,
.fluentform textarea:focus {
	outline: none !important;
	border-color: var(--iks-purple, #8125A5) !important;
	box-shadow: 0 0 0 3px rgba(129, 37, 165, 0.12) !important;
}

.fluentform .ff-el-form-control::placeholder {
	color: rgba(45, 17, 56, 0.38);
}

/* Read-only inputs (e.g. the email field — pre-filled from logged-in user). */
.fluentform input[readonly],
.fluentform input[readonly]:focus {
	background: rgba(129, 37, 165, 0.04) !important;
	color: var(--iks-slate, #5f6360) !important;
	cursor: default;
	border-color: rgba(45, 17, 56, 0.10) !important;
	box-shadow: none !important;
}

/* ── Choices.js dropdowns (Fluent Forms ships Choices.js, not Select2) ── */
.fluentform .choices {
	margin-bottom: 0 !important;
}
.fluentform .choices__inner {
	height: 46px !important;
	min-height: 46px !important;
	padding: 0 14px !important;
	display: flex !important;
	align-items: center !important;
	border: 1px solid rgba(45, 17, 56, 0.14) !important;
	border-radius: 10px !important;
	background: #fff !important;
	font-size: 0.95rem;
	line-height: 1;
}
.fluentform .choices__inner .choices__list--single {
	padding: 0 !important;
	width: 100%;
}
.fluentform .choices__inner .choices__list--single .choices__item {
	padding: 0 !important;
	white-space: nowrap;
	overflow: hidden;
	text-overflow: ellipsis;
}
.fluentform .choices.is-open .choices__inner,
.fluentform .choices.is-focused .choices__inner {
	border-color: var(--iks-purple, #8125A5) !important;
	box-shadow: 0 0 0 3px rgba(129, 37, 165, 0.12) !important;
}
.fluentform .choices__placeholder {
	color: rgba(45, 17, 56, 0.4) !important;
	opacity: 1 !important;
}
.fluentform .choices[data-type*="select-one"]::after {
	border-color: var(--iks-purple, #8125A5) transparent transparent !important;
	right: 14px !important;
}

/* Dropdown panel + options list */
.fluentform .choices__list--dropdown,
.fluentform .choices__list[aria-expanded] {
	border: 1px solid rgba(45, 17, 56, 0.14) !important;
	border-radius: 10px !important;
	box-shadow: 0 12px 32px rgba(45, 17, 56, 0.12) !important;
	overflow: hidden !important;
	margin-top: 6px !important;
}

/* HIDE the inline search input at the top of the dropdown — most of our
   dropdowns are short (≤6 options). Per-field opt-in for long lists later. */
.fluentform .choices__list--dropdown .choices__input,
.fluentform .choices__list[aria-expanded] .choices__input,
.fluentform .choices__input.choices__input--cloned {
	display: none !important;
}

/* Inner options list — single scroll context with a thin branded scrollbar */
.fluentform .choices__list--dropdown .choices__list,
.fluentform .choices__list[aria-expanded] .choices__list {
	max-height: 240px !important;
	overflow-y: auto !important;
	overflow-x: hidden !important;
	overscroll-behavior: contain;
	scrollbar-width: thin;
	scrollbar-color: rgba(129, 37, 165, 0.45) transparent;
}
.fluentform .choices__list--dropdown .choices__list::-webkit-scrollbar,
.fluentform .choices__list[aria-expanded] .choices__list::-webkit-scrollbar {
	width: 8px;
}
.fluentform .choices__list--dropdown .choices__list::-webkit-scrollbar-thumb,
.fluentform .choices__list[aria-expanded] .choices__list::-webkit-scrollbar-thumb {
	background: rgba(129, 37, 165, 0.45);
	border-radius: 4px;
}
.fluentform .choices__list--dropdown .choices__list::-webkit-scrollbar-track,
.fluentform .choices__list[aria-expanded] .choices__list::-webkit-scrollbar-track {
	background: transparent;
}

/* Option rows + hover/keyboard-highlighted state */
.fluentform .choices__item {
	padding: 10px 14px !important;
	font-size: 14.5px;
	color: var(--iks-ink, #1a0d1f);
	white-space: nowrap;
	overflow: hidden;
	text-overflow: ellipsis;
}
.fluentform .choices__item--selectable.is-highlighted,
.fluentform .choices__list--dropdown .choices__item--selectable.is-highlighted,
.fluentform .choices__list[aria-expanded] .choices__item--selectable.is-highlighted {
	background: var(--iks-purple, #8125A5) !important;
	color: #fff !important;
}
/* Kill the "Press to select" hint on hover — it's noisy and not needed. */
.fluentform .choices__item--selectable[data-select-text]::after {
	display: none !important;
}

/* ── Anti-FOUC: hide form until Choices.js has wrapped native <select>s.
   JS in iks-fluentform.js flips body.iks-ff-ready on after init. */
body:not(.iks-ff-ready) .fluentform form {
	opacity: 0;
	pointer-events: none;
}
.fluentform form {
	transition: opacity 220ms ease;
}
body.iks-ff-ready .fluentform form {
	opacity: 1;
}
body:not(.iks-ff-ready) .fluentform::before {
	content: "";
	display: block;
	min-height: 360px;
}

/* ── Radio / checkbox base ── */
.fluentform .ff-el-form-check {
	display: flex;
	align-items: center;
	gap: 10px;
	padding: 6px 0;
}
.fluentform .ff-el-form-check input[type="radio"],
.fluentform .ff-el-form-check input[type="checkbox"] {
	accent-color: var(--iks-purple, #8125A5);
	width: 18px;
	height: 18px;
	margin: 0;
}

/* ── ff_list_inline grid (used for Degrees / Certifications multi-checkbox) ── */
.fluentform .ff_list_inline {
	display: grid;
	gap: 6px 18px;
	grid-template-columns: repeat(2, 1fr);
	margin-top: 4px;
}
@media (min-width: 720px) {
	.fluentform .ff_list_inline { grid-template-columns: repeat(3, 1fr); }
}
@media (min-width: 1100px) {
	.fluentform .ff_list_inline { grid-template-columns: repeat(4, 1fr); }
}
.fluentform .ff_list_inline .ff-el-form-check {
	padding: 4px 0;
}
.fluentform .ff_list_inline label.ff-el-form-check-label {
	font-size: 0.88rem;
	font-weight: 500;
	color: var(--iks-ink, #1a0d1f);
	cursor: pointer;
	display: inline-flex;
	align-items: center;
	gap: 8px;
}
.fluentform .ff_list_inline label.ff-el-form-check-label:hover {
	color: var(--iks-purple, #8125A5);
}

/* ── Tier picker — Fluent Forms ff_list_buttons layout becomes a card grid ── */
.fluentform .ff_list_buttons {
	display: grid;
	gap: 14px;
	grid-template-columns: 1fr;
	margin-top: 6px;
}
@media (min-width: 720px) {
	.fluentform .ff_list_buttons {
		grid-template-columns: repeat(3, 1fr);
	}
}
.fluentform .ff_list_buttons .ff-el-form-check {
	margin: 0;
	padding: 0;
}
.fluentform .ff_list_buttons .ff-el-form-check label,
.fluentform .ff_list_buttons label.ff-el-form-check-label {
	display: flex !important;
	align-items: center;
	justify-content: center;
	min-height: 64px;
	padding: 14px 18px;
	font-size: 0.95rem;
	font-weight: 600;
	color: var(--iks-ink, #1a0d1f);
	text-align: center;
	background: #fff;
	border: 1.5px solid rgba(45, 17, 56, 0.12);
	border-radius: 14px;
	cursor: pointer;
	transition: border-color 0.2s var(--iks-ease-soft, ease), background 0.2s var(--iks-ease-soft, ease), box-shadow 0.2s var(--iks-ease-soft, ease), color 0.2s var(--iks-ease-soft, ease);
	box-shadow: 0 2px 6px rgba(45, 17, 56, 0.04);
}
.fluentform .ff_list_buttons .ff-el-form-check label:hover {
	border-color: var(--iks-purple, #8125A5);
	box-shadow: 0 8px 20px rgba(129, 37, 165, 0.12);
}
/* Selected state — Fluent Forms toggles `ff_item_selected` on the parent .ff-el-form-check;
   we also use :has(input:checked) for instant client-side feedback. */
.fluentform .ff_list_buttons .ff-el-form-check.ff_item_selected label.ff-el-form-check-label,
.fluentform .ff_list_buttons .ff-el-form-check:has(input:checked) label.ff-el-form-check-label {
	background: linear-gradient(135deg, var(--iks-purple, #8125A5) 0%, var(--iks-magenta, #AE0083) 100%);
	border-color: transparent;
	color: #fff;
	box-shadow: 0 10px 24px rgba(129, 37, 165, 0.28);
}
.fluentform .ff_list_buttons input[type="radio"] {
	position: absolute;
	opacity: 0;
	pointer-events: none;
}

/* ── Multi-step: progress bar + tabs ── */
.fluentform .ff-el-progress {
	background: rgba(129, 37, 165, 0.08);
	border-radius: 999px;
	height: 8px;
	overflow: hidden;
}
.fluentform .ff-el-progress-bar {
	background: linear-gradient(90deg, var(--iks-purple, #8125A5), var(--iks-magenta, #AE0083));
	border-radius: 999px;
}
.fluentform .ff-el-progress-status {
	font-weight: 600;
	color: var(--iks-purple, #8125A5);
	margin-bottom: 6px;
}
.fluentform .ff-step-header .ff-step-titles {
	display: flex;
	flex-wrap: wrap;
	gap: 6px;
	margin: 0 0 18px;
	padding: 0;
	list-style: none;
}
.fluentform .ff-step-header .ff-step-titles li {
	flex: 1 1 0;
	padding: 10px 14px;
	font-size: 0.85rem;
	font-weight: 600;
	color: var(--iks-slate, #5f6360);
	background: rgba(129, 37, 165, 0.04);
	border-radius: 10px;
	text-align: center;
	border: 1px solid transparent;
}
.fluentform .ff-step-header .ff-step-titles li.ff_active {
	color: var(--iks-purple, #8125A5);
	background: #fff;
	border-color: rgba(129, 37, 165, 0.25);
	box-shadow: 0 2px 8px rgba(129, 37, 165, 0.08);
}
.fluentform .ff-step-header .ff-step-titles li.ff_completed {
	color: var(--iks-magenta, #AE0083);
}

/* ── Buttons: prev / next / submit ── */
.fluentform .ff-btn,
.fluentform button[type="submit"],
.fluentform .ff-el-ss-buttons button {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 8px;
	min-height: 46px;
	padding: 12px 28px;
	font-family: var(--iks-font, 'Inter', sans-serif);
	font-size: 0.92rem;
	font-weight: 600;
	letter-spacing: 0.01em;
	border-radius: 999px;
	border: none;
	cursor: pointer;
	transition: transform 0.25s var(--iks-ease-soft, ease), box-shadow 0.25s var(--iks-ease-soft, ease), background 0.25s var(--iks-ease-soft, ease), color 0.25s var(--iks-ease-soft, ease);
}

.fluentform .ff-btn-submit,
.fluentform button[type="submit"],
.fluentform .ff-btn-next {
	background: linear-gradient(135deg, var(--iks-purple, #8125A5) 0%, var(--iks-magenta, #AE0083) 100%);
	color: #fff;
	box-shadow: 0 8px 24px rgba(129, 37, 165, 0.25);
}
.fluentform .ff-btn-submit:hover,
.fluentform button[type="submit"]:hover,
.fluentform .ff-btn-next:hover {
	transform: translateY(-1px);
	box-shadow: 0 14px 32px rgba(129, 37, 165, 0.35);
	color: #fff;
}

.fluentform .ff-btn-prev {
	background: #fff;
	color: var(--iks-purple, #8125A5);
	border: 1.5px solid rgba(129, 37, 165, 0.25);
}
.fluentform .ff-btn-prev:hover {
	background: rgba(129, 37, 165, 0.05);
	border-color: var(--iks-purple, #8125A5);
}

/* ── Help / error / success messages ── */
.fluentform .ff-el-help-message {
	font-size: 0.82rem;
	color: var(--iks-slate, #5f6360);
	margin-top: 6px;
}
.fluentform .ff-el-is-error .ff-el-form-control,
.fluentform .ff-el-is-error input,
.fluentform .ff-el-is-error select,
.fluentform .ff-el-is-error textarea {
	border-color: var(--iks-magenta, #AE0083) !important;
	box-shadow: 0 0 0 3px rgba(174, 0, 131, 0.10) !important;
}
.fluentform .error,
.fluentform .text-danger,
.fluentform .ff-el-is-error .text-danger {
	color: var(--iks-magenta, #AE0083);
	font-size: 0.82rem;
	margin-top: 6px;
}

.fluentform .ff-message-success,
.ff_form_success_msg {
	background: rgba(129, 37, 165, 0.06);
	border: 1px solid rgba(129, 37, 165, 0.18);
	color: var(--iks-ink, #1a0d1f);
	border-radius: 12px;
	padding: 18px 22px;
}

/* ── Two-column row helper for paired fields (first/last name, country/city, etc.) ── */
@media (min-width: 720px) {
	.fluentform .ff-t-cell.ff-t-column-1-2 {
		padding-right: 8px;
	}
	.fluentform .ff-t-cell.ff-t-column-2-2 {
		padding-left: 8px;
	}
}

/* ── Tighten the page intro custom_html block above the form ── */
.fluentform > .ff_custom_html:first-of-type {
	margin-bottom: 24px;
	font-size: 1.02rem;
	color: var(--iks-slate, #5f6360);
	line-height: 1.65;
}

/* ── Price summary right above Submit ── */
.fluentform .iks-price-summary {
	margin: 20px 0 8px;
	padding: 18px 22px;
	border-radius: 14px;
	background: linear-gradient(135deg, rgba(129, 37, 165, 0.06), rgba(174, 0, 131, 0.04));
	border: 1px solid rgba(129, 37, 165, 0.15);
}
.fluentform .iks-price-summary__row {
	display: flex;
	justify-content: space-between;
	align-items: baseline;
	gap: 16px;
}
.fluentform .iks-price-summary__label {
	font-size: 14px;
	font-weight: 600;
	color: #4d4a5a;
	text-transform: uppercase;
	letter-spacing: 0.06em;
}
.fluentform .iks-price-summary__value {
	font-size: 26px;
	font-weight: 700;
	background: linear-gradient(135deg, #8125A5 0%, #AE0083 100%);
	-webkit-background-clip: text;
	background-clip: text;
	color: transparent;
	-webkit-text-fill-color: transparent;
}
.fluentform .iks-price-summary__note {
	margin: 10px 0 0;
	font-size: 12px;
	color: #6a6080;
	line-height: 1.5;
}

/* ============================================================
 * Closed-applications state (.iks-form--disabled wrapper)
 *
 * Applied to the wrapper around the FF shortcode when the
 * applications-open option is '0'. Visually communicates the
 * form is inert; server-side guard rejects any POST that
 * bypasses this UI lock.
 * ============================================================ */
.iks-form--disabled {
	position: relative;
	opacity: 0.65;
	pointer-events: none;
	user-select: none;
	filter: grayscale(0.4);
}
/* Submit button stays visible but is muted — `pointer-events: none`
 * on the wrapper above already intercepts clicks; the color change
 * is the visual cue. */
.iks-form--disabled .fluentform button[type="submit"],
.iks-form--disabled .fluentform input[type="submit"],
.iks-form--disabled .ff_btn_style {
	background: #c8c4d0 !important;
	color: #ffffff !important;
	border-color: #c8c4d0 !important;
	cursor: not-allowed !important;
	opacity: 1 !important; /* don't double-dim — the wrapper already provides the dim */
}

/* Banner above the form on the public membership apply page.
 * Mirrors the iks-portal__notice styling so observership + membership
 * closed-state notices read as one design language. */
.iks-membership-notice {
	margin: 0 0 24px;
	padding: 18px 22px;
	border-radius: 10px;
	background: #F0EDF0;
	border-left: 4px solid #8125A5;
}
.iks-membership-notice--info {
	background: #F0EDF0;
	border-left-color: #8125A5;
}
.iks-membership-notice strong {
	display: block;
	font-size: 16px;
	color: #1a0d1f;
	margin-bottom: 6px;
}
.iks-membership-notice p {
	margin: 0;
	color: #4d4a5a;
	font-size: 14px;
	line-height: 1.55;
}
