/* Client Portal — Brand Bible (navy / ivory / gold micro-detail, sharp corners) */

.site-main--client-portal {
	padding: 0;
}

.client-portal {
	padding: var(--space-20) 0 var(--space-16);
	background: var(--hilaire-ivory);
	min-height: 60vh;
}

.client-portal__layout {
	display: grid;
	grid-template-columns: 1fr minmax(280px, 420px);
	gap: var(--space-16);
	align-items: start;
}

.client-portal__tag {
	display: block;
	font-family: var(--font-body);
	font-size: 11px;
	letter-spacing: 3px;
	text-transform: uppercase;
	color: var(--hilaire-gold);
	margin-bottom: 12px;
}

.client-portal__title {
	font-family: var(--font-heading);
	font-size: clamp(32px, 4vw, 40px);
	font-weight: 400;
	color: var(--hilaire-blue);
	line-height: 1.15;
	margin: 0 0 var(--space-5);
}

.client-portal__lede {
	font-family: var(--font-body);
	font-size: 15px;
	line-height: 1.7;
	color: rgba(26, 26, 26, 0.65);
	max-width: 36rem;
	margin: 0;
}

.client-portal__panel {
	background: var(--hilaire-white);
	border: 1px solid rgba(10, 30, 60, 0.08);
	border-radius: var(--radius-sharp);
	padding: var(--space-10) var(--space-8);
	box-shadow: 0 12px 40px rgba(10, 30, 60, 0.06);
}

.client-portal__form {
	margin: 0;
}

.client-portal__form-error {
	font-family: var(--font-body);
	font-size: 13px;
	line-height: 1.5;
	color: #b42318;
	background: rgba(180, 35, 24, 0.06);
	border: 1px solid rgba(180, 35, 24, 0.25);
	border-radius: var(--radius-minimal);
	padding: var(--space-4) var(--space-5);
	margin: 0 0 var(--space-6);
}

.client-portal__form-error[hidden] {
	display: none;
}

.client-portal__field {
	margin-bottom: var(--space-6);
}

.client-portal__label {
	display: block;
	font-family: var(--font-body);
	font-size: 11px;
	font-weight: 500;
	letter-spacing: 1.2px;
	text-transform: uppercase;
	color: var(--hilaire-blue);
	margin-bottom: var(--space-2);
}

.client-portal__input {
	width: 100%;
	box-sizing: border-box;
	font-family: var(--font-body);
	font-size: 15px;
	color: var(--hilaire-charcoal);
	background: var(--hilaire-white);
	border: 1px solid rgba(10, 30, 60, 0.2);
	border-radius: var(--radius-sharp);
	padding: 12px 14px;
	transition: border-color var(--transition-fast), box-shadow var(--transition-fast);
}

.client-portal__input:hover {
	border-color: rgba(10, 30, 60, 0.35);
}

.client-portal__input:focus {
	outline: none;
	border-color: var(--hilaire-blue);
	box-shadow: 0 0 0 1px var(--hilaire-blue);
}

.client-portal__input.is-invalid {
	border-color: #b42318;
	box-shadow: 0 0 0 1px rgba(180, 35, 24, 0.35);
}

.client-portal__field--checkbox {
	margin-bottom: var(--space-8);
}

.client-portal__checkbox-label {
	display: flex;
	align-items: flex-start;
	gap: var(--space-3);
	cursor: pointer;
	font-family: var(--font-body);
	font-size: 13px;
	line-height: 1.55;
	color: rgba(26, 26, 26, 0.75);
	transition: color var(--transition-fast);
}

.client-portal__checkbox-label.is-error {
	color: #8a1c12;
}

.client-portal__checkbox {
	width: 16px;
	height: 16px;
	margin-top: 3px;
	flex-shrink: 0;
	accent-color: var(--hilaire-blue);
	border-radius: var(--radius-minimal);
}

.client-portal__checkbox-text .client-portal__inline-link {
	color: var(--hilaire-blue);
	text-decoration: none;
	border-bottom: 1px solid var(--hilaire-gold);
	padding-bottom: 1px;
	transition: opacity var(--transition-fast);
}

.client-portal__checkbox-text .client-portal__inline-link:hover {
	opacity: 0.75;
}

.client-portal__consent-error {
	font-family: var(--font-body);
	font-size: 12px;
	color: #b42318;
	margin: var(--space-3) 0 0;
	padding-left: calc(16px + var(--space-3));
}

.client-portal__consent-error[hidden] {
	display: none;
}

.client-portal__submit {
	width: 100%;
	text-align: center;
	padding: 14px 24px;
}

.client-portal__note {
	font-family: var(--font-body);
	font-size: 12px;
	line-height: 1.6;
	color: rgba(26, 26, 26, 0.45);
	margin: var(--space-8) 0 0;
	text-align: center;
}

@media (max-width: 900px) {
	.client-portal__layout {
		grid-template-columns: 1fr;
	}

	.client-portal__panel {
		max-width: 480px;
	}
}
