/* =========================================================================
   OEUK Dynamics Subscriptions
   -------------------------------------------------------------------------
   Brand colours live in the variables below. Drop in OEUK's exact hex values
   from your brand guidelines and the whole form re-themes instantly.
   ========================================================================= */

.oeuk-subs {
	/* --- Brand palette (replace with exact OEUK hex) --- */
	--oeuk-navy:    #0b2545;  /* deep navy – headings, text            */
	--oeuk-teal:    #0fb6d6;  /* primary brand teal/cyan – accents     */
	--oeuk-accent:  #e5007d;  /* magenta accent – focus / active       */
	--oeuk-ink:     #1c2b3a;  /* body text                             */
	--oeuk-muted:   #5b6b7b;  /* secondary text                        */
	--oeuk-line:    #d9e1e8;  /* borders                               */
	--oeuk-surface: #ffffff;  /* card background                       */
	--oeuk-bg:      #f4f7f9;  /* form background                       */
	--oeuk-radius:  14px;
	--oeuk-radius-sm: 10px;

	box-sizing: border-box;
	max-width: 720px;
	margin: 0 auto;
	padding: clamp( 20px, 4vw, 40px );
	background: var( --oeuk-bg );
	border-radius: var( --oeuk-radius );
	color: var( --oeuk-ink );
	font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;
	line-height: 1.5;
}

.oeuk-subs *,
.oeuk-subs *::before,
.oeuk-subs *::after { box-sizing: border-box; }

/* --- Header --- */
.oeuk-subs__head { margin-bottom: 24px; }

.oeuk-subs__heading {
	margin: 0 0 6px;
	font-size: clamp( 1.4rem, 1.1rem + 1.2vw, 1.9rem );
	font-weight: 700;
	color: var( --oeuk-navy );
	letter-spacing: -0.01em;
}
.oeuk-subs__heading::after {
	content: "";
	display: block;
	width: 52px;
	height: 4px;
	margin-top: 12px;
	border-radius: 4px;
	background: linear-gradient( 90deg, var( --oeuk-teal ), var( --oeuk-accent ) );
}
.oeuk-subs__intro { margin: 14px 0 0; color: var( --oeuk-muted ); }

/* --- Fields --- */
.oeuk-subs__grid {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 16px;
}
@media ( max-width: 520px ) {
	.oeuk-subs__grid { grid-template-columns: 1fr; }
}

.oeuk-subs__field { margin-bottom: 16px; }

.oeuk-subs__field label,
.oeuk-subs__prefs legend {
	display: block;
	margin-bottom: 6px;
	font-size: 0.9rem;
	font-weight: 600;
	color: var( --oeuk-navy );
}

.oeuk-subs__req { color: var( --oeuk-accent ); }

.oeuk-subs__field input[type="text"],
.oeuk-subs__field input[type="email"] {
	width: 100%;
	padding: 12px 14px;
	font-size: 1rem;
	color: var( --oeuk-ink );
	background: var( --oeuk-surface );
	border: 1.5px solid var( --oeuk-line );
	border-radius: var( --oeuk-radius-sm );
	transition: border-color 0.15s ease, box-shadow 0.15s ease;
}
.oeuk-subs__field input:focus {
	outline: none;
	border-color: var( --oeuk-teal );
	box-shadow: 0 0 0 3px rgba( 15, 182, 214, 0.18 );
}

/* --- Preference cards --- */
.oeuk-subs__prefs {
	margin: 8px 0 20px;
	padding: 0;
	border: 0;
}
.oeuk-subs__prefs legend {
	margin-bottom: 12px;
	padding: 0;
	font-size: 1rem;
}

.oeuk-subs__card {
	position: relative;
	display: flex;
	align-items: flex-start;
	gap: 14px;
	padding: 16px 18px;
	margin-bottom: 12px;
	background: var( --oeuk-surface );
	border: 1.5px solid var( --oeuk-line );
	border-radius: var( --oeuk-radius-sm );
	cursor: pointer;
	transition: border-color 0.15s ease, box-shadow 0.15s ease, transform 0.05s ease;
}
.oeuk-subs__card:hover { border-color: var( --oeuk-teal ); }
.oeuk-subs__card:active { transform: scale( 0.998 ); }

/* Hide the native checkbox but keep it accessible/focusable. */
.oeuk-subs__card input[type="checkbox"] {
	position: absolute;
	opacity: 0;
	width: 1px;
	height: 1px;
}

/* Custom check indicator. */
.oeuk-subs__check {
	order: 2;
	flex: 0 0 auto;
	width: 24px;
	height: 24px;
	margin-top: 2px;
	border: 2px solid var( --oeuk-line );
	border-radius: 7px;
	background: #fff;
	transition: background 0.15s ease, border-color 0.15s ease;
}
.oeuk-subs__check::after {
	content: "";
	display: block;
	width: 6px;
	height: 11px;
	margin: 3px auto 0;
	border: solid #fff;
	border-width: 0 2.5px 2.5px 0;
	transform: rotate( 45deg ) scale( 0 );
	transition: transform 0.12s ease;
}

.oeuk-subs__card-body { order: 1; flex: 1 1 auto; }
.oeuk-subs__card-title {
	display: block;
	font-weight: 600;
	color: var( --oeuk-navy );
}
.oeuk-subs__card-desc {
	display: block;
	margin-top: 2px;
	font-size: 0.88rem;
	color: var( --oeuk-muted );
}

/* Checked + focus states */
.oeuk-subs__card input:checked ~ .oeuk-subs__check {
	background: var( --oeuk-teal );
	border-color: var( --oeuk-teal );
}
.oeuk-subs__card input:checked ~ .oeuk-subs__check::after { transform: rotate( 45deg ) scale( 1 ); }
.oeuk-subs__card input:checked ~ .oeuk-subs__card-body .oeuk-subs__card-title { color: var( --oeuk-navy ); }
.oeuk-subs__card:has( input:checked ) { border-color: var( --oeuk-teal ); box-shadow: 0 0 0 1px var( --oeuk-teal ); }
.oeuk-subs__card input:focus-visible ~ .oeuk-subs__check {
	box-shadow: 0 0 0 3px rgba( 229, 0, 125, 0.25 );
	border-color: var( --oeuk-accent );
}

/* --- Consent --- */
.oeuk-subs__consent {
	display: flex;
	align-items: flex-start;
	gap: 10px;
	margin: 4px 0 22px;
	font-size: 0.9rem;
	color: var( --oeuk-muted );
	cursor: pointer;
}
.oeuk-subs__consent input { margin-top: 3px; accent-color: var( --oeuk-teal ); }
.oeuk-subs__consent a { color: var( --oeuk-accent ); text-decoration: underline; }

/* --- Honeypot (hidden from humans) --- */
.oeuk-subs__hp {
	position: absolute !important;
	left: -9999px !important;
	width: 1px;
	height: 1px;
	overflow: hidden;
}

/* --- Submit --- */
.oeuk-subs__submit {
	appearance: none;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-width: 220px;
	padding: 14px 28px;
	font-size: 1rem;
	font-weight: 700;
	color: #fff;
	background: var( --oeuk-navy );
	border: 0;
	border-radius: 999px;
	cursor: pointer;
	transition: background 0.15s ease, transform 0.05s ease, box-shadow 0.15s ease;
}
.oeuk-subs__submit:hover { background: var( --oeuk-teal ); }
.oeuk-subs__submit:focus-visible {
	outline: none;
	box-shadow: 0 0 0 3px rgba( 229, 0, 125, 0.3 );
}
.oeuk-subs__submit:disabled { opacity: 0.65; cursor: progress; }

/* --- Status messages --- */
.oeuk-subs__status {
	margin-top: 16px;
	font-size: 0.95rem;
	font-weight: 600;
	min-height: 1.2em;
}
.oeuk-subs__status.is-success { color: #157347; }
.oeuk-subs__status.is-error   { color: #c1352b; }

/* --- Gated members message --- */
.oeuk-subs--gated {
	text-align: center;
	color: var( --oeuk-muted );
}

/* Reduce motion */
@media ( prefers-reduced-motion: reduce ) {
	.oeuk-subs *,
	.oeuk-subs *::before,
	.oeuk-subs *::after { transition: none !important; }
}

/* --- Combined form: membership + conditional sections --- */
.oeuk-subs__cond.is-hidden { display: none; }

.oeuk-subs__membership {
	margin: 4px 0 18px;
	padding: 0;
	border: 0;
}
.oeuk-subs__membership legend {
	margin-bottom: 10px;
	padding: 0;
	font-size: 1rem;
	font-weight: 600;
	color: var( --oeuk-navy );
}
.oeuk-subs__radio {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	margin-right: 22px;
	font-weight: 500;
	cursor: pointer;
}
.oeuk-subs__radio input { accent-color: var( --oeuk-teal ); width: 18px; height: 18px; }

.oeuk-subs__field select {
	width: 100%;
	padding: 12px 14px;
	font-size: 1rem;
	color: var( --oeuk-ink );
	background: var( --oeuk-surface );
	border: 1.5px solid var( --oeuk-line );
	border-radius: var( --oeuk-radius-sm );
	transition: border-color 0.15s ease, box-shadow 0.15s ease;
}
.oeuk-subs__field select:focus {
	outline: none;
	border-color: var( --oeuk-teal );
	box-shadow: 0 0 0 3px rgba( 15, 182, 214, 0.18 );
}

.oeuk-subs__hint {
	margin: 6px 0 0;
	font-size: 0.82rem;
	color: var( --oeuk-muted );
}

/* --- Type-to-search company combobox --- */
.oeuk-subs__combo { position: relative; }

.oeuk-subs__combo-input {
	width: 100%;
	padding: 12px 14px;
	font-size: 1rem;
	color: var( --oeuk-ink );
	background: var( --oeuk-surface );
	border: 1.5px solid var( --oeuk-line );
	border-radius: var( --oeuk-radius-sm );
	transition: border-color 0.15s ease, box-shadow 0.15s ease;
}
.oeuk-subs__combo-input:focus {
	outline: none;
	border-color: var( --oeuk-teal );
	box-shadow: 0 0 0 3px rgba( 15, 182, 214, 0.18 );
}

.oeuk-subs__combo-list {
	position: absolute;
	z-index: 20;
	left: 0;
	right: 0;
	margin: 4px 0 0;
	padding: 4px;
	list-style: none;
	max-height: 260px;
	overflow-y: auto;
	background: var( --oeuk-surface );
	border: 1.5px solid var( --oeuk-line );
	border-radius: var( --oeuk-radius-sm );
	box-shadow: 0 8px 24px rgba( 11, 37, 69, 0.12 );
}

.oeuk-subs__combo-item {
	padding: 10px 12px;
	border-radius: 8px;
	cursor: pointer;
	font-size: 0.95rem;
	color: var( --oeuk-ink );
}
.oeuk-subs__combo-item:hover,
.oeuk-subs__combo-item.is-active {
	background: rgba( 15, 182, 214, 0.12 );
	color: var( --oeuk-navy );
}
