/**
 * Porte d'acces (.se-gate) + pages connexion/mot de passe (.se-auth).
 * Reutilise les tokens du theme (--color-*, --font-*). Mobile-first, BEM.
 */

/* ====================================================================== *
 *  Ecran porte plein ecran
 * ====================================================================== */

.se-gate-body {
	margin: 0;
}

.se-gate {
	--se-gate-ink: var(--color-night, #0a1740);
	--se-gate-paper: var(--color-cream, #f8f5ec);
	--se-gate-accent: var(--color-primary, #14246e);

	position: relative;
	display: flex;
	align-items: center;
	justify-content: center;
	min-height: 100vh;
	min-height: 100svh;
	padding: 1.5rem;
	box-sizing: border-box;
	background-color: var(--se-gate-ink);
	background-image: var(--se-gate-bg, none);
	background-size: cover;
	background-position: center;
	font-family: var(--font-body, system-ui, sans-serif);
}

.se-gate__overlay {
	position: absolute;
	inset: 0;
	background: linear-gradient(160deg, rgba(10, 23, 64, 0.82), rgba(10, 23, 64, 0.94));
}

.se-gate__card {
	position: relative;
	z-index: 1;
	width: 100%;
	max-width: 30rem;
	padding: 2.25rem 1.75rem 2rem;
	background: var(--se-gate-paper);
	border-radius: 14px;
	box-shadow: 0 24px 60px rgba(0, 0, 0, 0.35);
	text-align: center;
	box-sizing: border-box;
}

.se-gate__lang {
	display: flex;
	justify-content: center;
	margin-bottom: 1rem;
}

.se-gate__head {
	margin-bottom: 1.25rem;
}

.se-gate__logo {
	max-height: 64px;
	width: auto;
	margin: 0 auto;
}

.se-gate__brand {
	font-family: var(--font-heading, serif);
	font-size: 1.5rem;
	color: var(--se-gate-accent);
}

.se-gate__tagline {
	margin: 0.5rem 0 0;
	font-size: 0.8rem;
	letter-spacing: 0.04em;
	text-transform: uppercase;
	color: var(--se-gate-accent);
	opacity: 0.8;
}

.se-gate__title {
	margin: 0 0 0.5rem;
	font-family: var(--font-heading, serif);
	font-size: 1.65rem;
	line-height: 1.2;
	color: var(--se-gate-ink);
}

.se-gate__intro {
	margin: 0 0 1.25rem;
	font-size: 0.95rem;
	line-height: 1.5;
	color: var(--se-gate-ink);
	opacity: 0.82;
}

.se-gate__error {
	margin: 0 0 1rem;
	padding: 0.6rem 0.8rem;
	border-radius: 8px;
	background: rgba(200, 16, 46, 0.1);
	color: var(--color-danger, #c8102e);
	font-size: 0.9rem;
}

.se-gate__form {
	display: grid;
	gap: 1rem;
	text-align: left;
}

.se-gate__row {
	display: grid;
	gap: 0.35rem;
}

.se-gate__label {
	font-size: 0.82rem;
	font-weight: 600;
	letter-spacing: 0.02em;
	color: var(--se-gate-ink);
}

.se-gate__input {
	width: 100%;
	padding: 0.7rem 0.85rem;
	border: 1px solid rgba(10, 23, 64, 0.2);
	border-radius: 8px;
	background: #fff;
	font-size: 1rem;
	font-family: inherit;
	color: var(--se-gate-ink);
	box-sizing: border-box;
}

.se-gate__input:focus {
	outline: none;
	border-color: var(--se-gate-accent);
	box-shadow: 0 0 0 3px rgba(20, 36, 110, 0.15);
}

.se-gate__input[aria-invalid="true"] {
	border-color: var(--color-danger, #c8102e);
}

.se-gate__field-error {
	font-size: 0.8rem;
	color: var(--color-danger, #c8102e);
}

/* Honeypot : hors flux et hors lecteurs d'ecran via aria-hidden. */
.se-gate__hp {
	position: absolute;
	left: -9999px;
	width: 1px;
	height: 1px;
	overflow: hidden;
}

.se-gate__consent {
	display: flex;
	gap: 0.55rem;
	align-items: flex-start;
	font-size: 0.85rem;
	line-height: 1.4;
	color: var(--se-gate-ink);
}

.se-gate__consent input {
	margin-top: 0.2rem;
	flex: 0 0 auto;
}

.se-gate__submit {
	margin-top: 0.25rem;
	padding: 0.8rem 1rem;
	border: 0;
	border-radius: 8px;
	background: var(--se-gate-accent);
	color: #fff;
	font-size: 1rem;
	font-weight: 600;
	font-family: inherit;
	cursor: pointer;
	transition: transform 0.12s ease, opacity 0.12s ease;
}

.se-gate__submit:hover {
	opacity: 0.92;
}

.se-gate__submit:active {
	transform: translateY(1px);
}

.se-gate__login-link {
	margin: 1.25rem 0 0;
	font-size: 0.85rem;
	color: var(--se-gate-ink);
}

.se-gate__login-link a {
	color: var(--se-gate-accent);
	font-weight: 600;
}

@media (min-width: 480px) {
	.se-gate__card {
		padding: 2.75rem 2.5rem 2.25rem;
	}
	.se-gate__title {
		font-size: 1.9rem;
	}
}

/* ====================================================================== *
 *  Pages connexion / mot de passe (dans le layout du theme)
 * ====================================================================== */

.se-auth__container {
	display: flex;
	justify-content: center;
	padding-top: 3rem;
	padding-bottom: 4rem;
}

.se-auth__card {
	width: 100%;
	max-width: 28rem;
	padding: 2rem 1.5rem;
	background: #fff;
	border: 1px solid rgba(10, 23, 64, 0.1);
	border-radius: 14px;
	box-shadow: 0 14px 40px rgba(10, 23, 64, 0.08);
	box-sizing: border-box;
}

.se-auth__head {
	margin-bottom: 1.25rem;
	text-align: center;
}

.se-auth__title {
	margin: 0 0 0.4rem;
	font-family: var(--font-heading, serif);
	font-size: 1.6rem;
	color: var(--color-night, #0a1740);
}

.se-auth__intro {
	margin: 0;
	font-size: 0.95rem;
	line-height: 1.5;
	color: var(--color-night, #0a1740);
	opacity: 0.8;
}

.se-auth__notice {
	margin: 0 0 1rem;
	padding: 0.65rem 0.85rem;
	border-radius: 8px;
	font-size: 0.9rem;
}

.se-auth__notice--error {
	background: rgba(200, 16, 46, 0.1);
	color: var(--color-danger, #c8102e);
}

.se-auth__notice--success {
	background: rgba(20, 110, 60, 0.1);
	color: #146e3c;
}

.se-auth__notice--info {
	background: rgba(20, 36, 110, 0.08);
	color: var(--color-primary, #14246e);
}

.se-auth__form {
	display: grid;
	gap: 1rem;
}

.se-auth__row {
	display: grid;
	gap: 0.35rem;
}

.se-auth__label {
	font-size: 0.82rem;
	font-weight: 600;
	color: var(--color-night, #0a1740);
}

.se-auth__input {
	width: 100%;
	padding: 0.7rem 0.85rem;
	border: 1px solid rgba(10, 23, 64, 0.2);
	border-radius: 8px;
	font-size: 1rem;
	font-family: inherit;
	box-sizing: border-box;
}

.se-auth__input:focus {
	outline: none;
	border-color: var(--color-primary, #14246e);
	box-shadow: 0 0 0 3px rgba(20, 36, 110, 0.15);
}

.se-auth__input[aria-invalid="true"] {
	border-color: var(--color-danger, #c8102e);
}

.se-auth__field-error {
	font-size: 0.8rem;
	color: var(--color-danger, #c8102e);
}

.se-auth__remember {
	display: flex;
	gap: 0.5rem;
	align-items: center;
	font-size: 0.88rem;
	color: var(--color-night, #0a1740);
}

.se-auth__submit {
	display: inline-block;
	width: 100%;
	margin-top: 0.25rem;
	padding: 0.8rem 1rem;
	border: 0;
	border-radius: 8px;
	background: var(--color-primary, #14246e);
	color: #fff;
	font-size: 1rem;
	font-weight: 600;
	font-family: inherit;
	text-align: center;
	text-decoration: none;
	cursor: pointer;
	box-sizing: border-box;
}

.se-auth__submit:hover {
	opacity: 0.92;
}

.se-auth__actions {
	display: grid;
	gap: 0.75rem;
	text-align: center;
}

.se-auth__alt {
	margin: 1.1rem 0 0;
	text-align: center;
	font-size: 0.88rem;
}

.se-auth__link {
	color: var(--color-primary, #14246e);
	font-weight: 600;
}

@media (min-width: 480px) {
	.se-auth__card {
		padding: 2.5rem 2.25rem;
	}
}
