/* ============================================================================
 * tm-login.css — styling voor wp-login.php (login, lostpassword, rp,
 * checkemail-interstitial) + de inline login-card op /lp-profile/ logged-out.
 *
 * Geladen via:
 *   - login_enqueue_scripts (alleen op wp-login.php) → samen met tm-components.css
 *   - tm-components.css verwijst er niet zelf naar (lp-profile-card-styles
 *     komen wel mee via tm-components.css; deze file dekt alleen wp-login).
 * ========================================================================= */

/* WP-login laadt style.css van het child-theme NIET, dus de :root-tokens
   uit style.css ontbreken. tm-components.css refereert er aan (o.a. de
   oranje hinge-dot). Tokens hier dupliceren zodat var(--tm-*) werkt. */
:root {
	--tm-purple: #5B4FE5;
	--tm-purple-deep: #3F35B8;
	--tm-purple-soft: #EEEBFD;
	--tm-orange: #FF8A1F;
	--tm-orange-soft: #FFF1DF;
	--tm-ink: #1E1B4B;
	--tm-ink-soft: #4A4870;
	--tm-ink-mute: #767492;
	--tm-mint: #34C8A2;
	--tm-coral: #FF6F61;
	--tm-bg: #FAFAFC;
	--tm-bg-soft: #FAFAFC;
	--tm-line: #ECEAF6;
}

/* ---------------------------------------------------------------------------
 * BASIS — body + reset van default wp-login look.
 * ------------------------------------------------------------------------- */

body.login.tm-login-page {
	font-family: "Plus Jakarta Sans", "Montserrat", system-ui, -apple-system, sans-serif;
	background: var(--tm-bg-soft, #F5F4FB);
	color: var(--tm-ink, #1E1B4B);
	margin: 0;
	padding: 0;
}

/* WP zet z-index/transform op #login om de submit-button-animatie te doen;
   we resetten dat zodat onze layout voorspelbaar blijft. */
body.login.tm-login-page #login {
	padding: 0;
	margin: 24px auto 32px;
	max-width: 460px;
	width: calc(100% - 32px);
}

/* WP-default H1 met de WordPress-W-circle. Wij rendere onze eigen hero
   via login_header — die default kop dus verbergen. */
body.login.tm-login-page #login h1 {
	display: none;
}

/* ---------------------------------------------------------------------------
 * HERO — onze tm-page-hero rendert via login_header-action.
 * Aanpassingen voor de wp-login-context: dichter op de card.
 * ------------------------------------------------------------------------- */

body.login.tm-login-page .tm-login-hero {
	padding: 32px 16px 4px;
	text-align: center;
	background: transparent;
}
body.login.tm-login-page .tm-login-hero .tm-page-hero__inner {
	max-width: 720px;
	margin: 0 auto;
}
body.login.tm-login-page .tm-login-hero .tm-page-hero__title {
	font-family: "Plus Jakarta Sans", system-ui, sans-serif;
	font-size: clamp(40px, 6vw, 64px);
	font-weight: 800;
	letter-spacing: -0.02em;
	line-height: 1.05;
	margin: 0;
	color: var(--tm-ink, #1E1B4B);
}
body.login.tm-login-page .tm-login-hero .tm-page-hero__accent {
	color: var(--tm-orange, #FF8A1F);
}
body.login.tm-login-page .tm-login-hero__intro {
	max-width: 640px;
	margin: 0 auto 16px;
	padding: 0 16px;
	text-align: center;
}
body.login.tm-login-page .tm-login-hero__intro .tm-hinge {
	padding: 12px 0 0;
}
body.login.tm-login-page .tm-login-hero__intro .tm-auth-hero__lede {
	margin: 12px auto 0;
	max-width: 520px;
	font-size: 15px;
	color: var(--tm-ink-soft, #4A4870);
	line-height: 1.55;
}

/* ---------------------------------------------------------------------------
 * FORM-CARD — het <form>-element (login/lostpassword/resetpass) krijgt onze
 * soft-card-styling.
 * ------------------------------------------------------------------------- */

body.login.tm-login-page #loginform,
body.login.tm-login-page #lostpasswordform,
body.login.tm-login-page #resetpassform,
body.login.tm-login-page #registerform {
	background: #FFFFFF;
	border: 1px solid var(--tm-line, #ECEAF6);
	border-radius: 16px;
	padding: 28px 28px 24px;
	box-shadow: 0 8px 32px rgba(30, 27, 75, 0.06);
	margin-top: 8px;
}

/* Form-paragrafen — WP zet alle labels+inputs in <p> tags */
body.login.tm-login-page form p {
	margin: 0 0 14px;
}
body.login.tm-login-page form p:last-of-type {
	margin-bottom: 0;
}

/* Labels */
body.login.tm-login-page form label {
	display: block;
	font-size: 13px;
	font-weight: 600;
	color: var(--tm-ink-soft, #4A4870);
	margin-bottom: 6px;
}

/* Inputs (text, password, email) */
body.login.tm-login-page input[type="text"],
body.login.tm-login-page input[type="password"],
body.login.tm-login-page input[type="email"] {
	width: 100%;
	box-sizing: border-box;
	font-family: inherit;
	font-size: 15px;
	color: var(--tm-ink, #1E1B4B);
	background: #FFFFFF;
	border: 1px solid var(--tm-line, #ECEAF6);
	border-radius: 10px;
	padding: 11px 14px;
	box-shadow: none;
	transition: border-color 0.15s ease, box-shadow 0.15s ease;
}
body.login.tm-login-page input[type="text"]:focus,
body.login.tm-login-page input[type="password"]:focus,
body.login.tm-login-page input[type="email"]:focus {
	border-color: var(--tm-purple, #5B4FE5);
	box-shadow: 0 0 0 3px rgba(91, 79, 229, 0.12);
	outline: 0;
}

/* WP wrapt password-input in .wp-pwd (op login-form binnen .user-pass-wrap,
   op resetpass-form direct in de form). Positioneer eye-toggle relatief aan
   .wp-pwd zodat 'm op beide flows gecentreerd over het input-veld zit. */
body.login.tm-login-page .wp-pwd {
	position: relative;
}
body.login.tm-login-page .wp-pwd input[type="text"],
body.login.tm-login-page .wp-pwd input[type="password"] {
	padding-right: 44px;
}
body.login.tm-login-page button.wp-hide-pw {
	position: absolute;
	right: 6px;
	/* Op login-form is .wp-pwd alleen de input (44px) → top:50%-50% klopt.
	   Op resetpass-form bevat .wp-pwd ook strength-result-div eronder
	   (88px totaal). De input is altijd 44px hoog → een vast offset van
	   22px (halve inputhoogte) lijnt het uit met de input-center. */
	top: 22px;
	transform: translateY(-50%);
	background: transparent;
	border: 0;
	padding: 6px 8px;
	margin: 0;
	color: var(--tm-ink-soft, #4A4870);
	cursor: pointer;
	line-height: 1;
}
body.login.tm-login-page button.wp-hide-pw:hover {
	color: var(--tm-purple, #5B4FE5);
}
body.login.tm-login-page button.wp-hide-pw .dashicons {
	font-size: 18px;
	width: 18px;
	height: 18px;
	line-height: 18px;
}
/* Wp-default button.wp-hide-pw heeft op resetpass-form `.button .button-secondary`
   classes die border + bg + height meegeven. Override naar transparent. */
body.login.tm-login-page button.wp-hide-pw.button,
body.login.tm-login-page button.wp-hide-pw.button-secondary {
	min-height: 0;
	box-shadow: none;
	border: 0;
	background: transparent;
}

/* "Onthoud mij"-checkbox */
body.login.tm-login-page .forgetmenot {
	margin: 4px 0 18px;
}
body.login.tm-login-page .forgetmenot label {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	font-size: 14px;
	font-weight: 500;
	color: var(--tm-ink-soft, #4A4870);
	cursor: pointer;
}
body.login.tm-login-page .forgetmenot input[type="checkbox"] {
	width: 16px;
	height: 16px;
	margin: 0;
	accent-color: var(--tm-orange, #FF8A1F);
	cursor: pointer;
}

/* Submit-button */
body.login.tm-login-page .submit {
	margin: 6px 0 0;
}
body.login.tm-login-page #wp-submit,
body.login.tm-login-page input.button-primary {
	width: 100%;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	background: var(--tm-orange, #FF8A1F);
	color: #FFFFFF;
	font-family: inherit;
	font-size: 15px;
	font-weight: 700;
	letter-spacing: 0;
	padding: 13px 24px;
	border: 0;
	border-radius: 12px;
	cursor: pointer;
	transition: background 0.15s ease, transform 0.1s ease;
	box-shadow: 0 4px 14px rgba(255, 138, 31, 0.25);
	text-shadow: none;
}
body.login.tm-login-page #wp-submit:hover,
body.login.tm-login-page input.button-primary:hover {
	background: #F37A12;
}
body.login.tm-login-page #wp-submit:active,
body.login.tm-login-page input.button-primary:active {
	transform: translateY(1px);
	box-shadow: 0 2px 8px rgba(255, 138, 31, 0.25);
}

/* ---------------------------------------------------------------------------
 * MESSAGES + ERRORS — WP rendert .message (info) en .login-error (error).
 * "Check je e-mail"-interstitial loopt via .message.
 * ------------------------------------------------------------------------- */

body.login.tm-login-page .message,
body.login.tm-login-page .login .message,
body.login.tm-login-page #login_error,
body.login.tm-login-page .notice {
	background: #FFFFFF;
	border-left: 4px solid var(--tm-purple, #5B4FE5);
	border-radius: 10px;
	padding: 14px 18px;
	margin: 0 0 16px;
	font-size: 14px;
	line-height: 1.55;
	color: var(--tm-ink, #1E1B4B);
	box-shadow: 0 4px 16px rgba(30, 27, 75, 0.05);
}
body.login.tm-login-page #login_error,
body.login.tm-login-page .login-error {
	border-left-color: #D7263D;
	color: #861529;
	background: #FCEEF1;
}
body.login.tm-login-page .message a,
body.login.tm-login-page #login_error a {
	color: var(--tm-orange, #FF8A1F);
	font-weight: 600;
}

/* ---------------------------------------------------------------------------
 * NAV-LINKS onder de form.
 * ------------------------------------------------------------------------- */

body.login.tm-login-page #nav,
body.login.tm-login-page #backtoblog {
	font-size: 14px;
	text-align: center;
	margin: 16px 0 0;
	color: var(--tm-ink-soft, #4A4870);
	text-shadow: none;
}
body.login.tm-login-page #nav a,
body.login.tm-login-page #backtoblog a {
	color: var(--tm-orange, #FF8A1F);
	font-weight: 600;
	text-decoration: none;
}
body.login.tm-login-page #nav a:hover,
body.login.tm-login-page #backtoblog a:hover {
	color: #F37A12;
	text-decoration: underline;
}
body.login.tm-login-page #backtoblog {
	margin-top: 24px;
}

/* ---------------------------------------------------------------------------
 * LANGUAGE-SWITCHER — verbergen (NL-only site).
 * ------------------------------------------------------------------------- */

body.login.tm-login-page .language-switcher,
body.login.tm-login-page .login-language-row {
	display: none !important;
}

/* ---------------------------------------------------------------------------
 * RESET-PASSWORD-FORM specifieke aanpassingen — WP rendert daar een password-
 * strength-indicator (#pass-strength-result) en een hint-paragraaf.
 * ------------------------------------------------------------------------- */

body.login.tm-login-page.tm-login-action-rp #resetpassform .description,
body.login.tm-login-page.tm-login-action-resetpass #resetpassform .description {
	font-size: 13px;
	color: var(--tm-ink-soft, #4A4870);
	margin: -8px 0 12px;
	line-height: 1.5;
}
body.login.tm-login-page #pass-strength-result {
	display: block !important;
	margin: 8px 0 14px;
	padding: 8px 14px;
	border-radius: 8px;
	font-size: 13px;
	font-weight: 600;
	text-align: center;
	border: 1px solid var(--tm-line, #ECEAF6);
	background: #FAFAFC;
	color: var(--tm-ink-soft, #4A4870);
}
body.login.tm-login-page #pass-strength-result.short { background: #FCEEF1; color: #861529; border-color: #F1C9D2; }
body.login.tm-login-page #pass-strength-result.bad { background: #FEF6E7; color: #8A5800; border-color: #F2D88A; }
body.login.tm-login-page #pass-strength-result.good { background: #E8F4EE; color: #1A5E36; border-color: #B2D8C2; }
body.login.tm-login-page #pass-strength-result.strong { background: #DDF0E5; color: #16502E; border-color: #97C8AC; }

/* "Wachtwoord genereren"-secundair knopje */
body.login.tm-login-page button.wp-generate-pw {
	display: inline-block;
	margin: 0 0 14px;
	padding: 9px 18px;
	background: transparent;
	color: var(--tm-purple, #5B4FE5);
	border: 1px solid var(--tm-purple, #5B4FE5);
	border-radius: 10px;
	font-family: inherit;
	font-size: 14px;
	font-weight: 600;
	cursor: pointer;
	transition: background 0.15s ease, color 0.15s ease;
}
body.login.tm-login-page button.wp-generate-pw:hover {
	background: var(--tm-purple, #5B4FE5);
	color: #FFFFFF;
}
body.login.tm-login-page button.wp-cancel-pw {
	background: transparent;
	border: 0;
	color: var(--tm-ink-soft, #4A4870);
	cursor: pointer;
	padding: 8px;
}

/* ---------------------------------------------------------------------------
 * LOGOUT-CONFIRM-SCHERM (action=logout zonder geldig nonce).
 * Markup uit tm-login.php login_init-handler.
 * ------------------------------------------------------------------------- */

body.login.tm-login-page.tm-login-action-logout .tm-logout-confirm {
	background: #FFFFFF;
	border: 1px solid var(--tm-line, #ECEAF6);
	border-radius: 16px;
	padding: 28px;
	box-shadow: 0 8px 32px rgba(30, 27, 75, 0.06);
}
body.login.tm-login-page.tm-login-action-logout .tm-logout-confirm .message {
	background: transparent;
	border: 0;
	border-radius: 0;
	padding: 0 0 20px;
	margin: 0 0 20px;
	box-shadow: none;
	border-bottom: 1px solid var(--tm-line, #ECEAF6);
	color: var(--tm-ink, #1E1B4B);
	font-size: 15px;
	line-height: 1.55;
}
body.login.tm-login-page.tm-login-action-logout .tm-logout-confirm__actions {
	display: flex;
	flex-direction: column;
	gap: 10px;
}
body.login.tm-login-page.tm-login-action-logout .tm-logout-confirm__primary {
	display: block;
	background: var(--tm-orange, #FF8A1F);
	color: #FFFFFF !important;
	font-family: inherit;
	font-size: 15px;
	font-weight: 700;
	text-align: center;
	text-decoration: none;
	padding: 13px 24px;
	border-radius: 12px;
	box-shadow: 0 4px 14px rgba(255, 138, 31, 0.25);
	transition: background 0.15s ease;
}
body.login.tm-login-page.tm-login-action-logout .tm-logout-confirm__primary:hover {
	background: #F37A12;
}
body.login.tm-login-page.tm-login-action-logout .tm-logout-confirm__secondary {
	display: block;
	background: transparent;
	color: var(--tm-ink-soft, #4A4870) !important;
	font-family: inherit;
	font-size: 14px;
	font-weight: 600;
	text-align: center;
	text-decoration: none;
	padding: 10px 24px;
}
body.login.tm-login-page.tm-login-action-logout .tm-logout-confirm__secondary:hover {
	color: var(--tm-orange, #FF8A1F) !important;
	text-decoration: underline;
}

/* ---------------------------------------------------------------------------
 * INLINE LOGIN-CARD op /lp-profile/ logged-out.
 *
 * Markup uit tm_render_lp_profile_login_prompt() — staat midden in de
 * lp-profile-content-area. Soft-card identiek aan wp-login-form-card.
 * ------------------------------------------------------------------------- */

.tm-login-card {
	max-width: 460px;
	margin: 24px auto;
	background: #FFFFFF;
	border: 1px solid var(--tm-line, #ECEAF6);
	border-radius: 16px;
	padding: 28px 28px 24px;
	box-shadow: 0 8px 32px rgba(30, 27, 75, 0.06);
	font-family: "Plus Jakarta Sans", system-ui, sans-serif;
}
.tm-login-card__title {
	margin: 0 0 16px;
	font-size: 20px;
	font-weight: 800;
	letter-spacing: -0.01em;
	color: var(--tm-ink, #1E1B4B);
}
/* wp_login_form() rendert <form class="login"><p class="login-username">…</p>… */
.tm-login-card form p {
	margin: 0 0 14px;
}
.tm-login-card form label {
	display: block;
	font-size: 13px;
	font-weight: 600;
	color: var(--tm-ink-soft, #4A4870);
	margin-bottom: 6px;
}
.tm-login-card form input[type="text"],
.tm-login-card form input[type="password"],
.tm-login-card form input[type="email"] {
	width: 100%;
	box-sizing: border-box;
	font-family: inherit;
	font-size: 15px;
	color: var(--tm-ink, #1E1B4B);
	background: #FFFFFF;
	border: 1px solid var(--tm-line, #ECEAF6);
	border-radius: 10px;
	padding: 11px 14px;
	transition: border-color 0.15s ease, box-shadow 0.15s ease;
}
.tm-login-card form input[type="text"]:focus,
.tm-login-card form input[type="password"]:focus,
.tm-login-card form input[type="email"]:focus {
	border-color: var(--tm-purple, #5B4FE5);
	box-shadow: 0 0 0 3px rgba(91, 79, 229, 0.12);
	outline: 0;
}
.tm-login-card form p.login-remember label {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	font-size: 14px;
	font-weight: 500;
	color: var(--tm-ink-soft, #4A4870);
	cursor: pointer;
}
.tm-login-card form p.login-remember input[type="checkbox"] {
	width: 16px;
	height: 16px;
	margin: 0;
	accent-color: var(--tm-orange, #FF8A1F);
}
.tm-login-card form p.login-submit {
	margin: 6px 0 0;
}
.tm-login-card form p.login-submit input[type="submit"] {
	width: 100%;
	background: var(--tm-orange, #FF8A1F);
	color: #FFFFFF;
	font-family: inherit;
	font-size: 15px;
	font-weight: 700;
	padding: 13px 24px;
	border: 0;
	border-radius: 12px;
	cursor: pointer;
	box-shadow: 0 4px 14px rgba(255, 138, 31, 0.25);
	transition: background 0.15s ease, transform 0.1s ease;
}
.tm-login-card form p.login-submit input[type="submit"]:hover {
	background: #F37A12;
}
.tm-login-card form p.login-submit input[type="submit"]:active {
	transform: translateY(1px);
	box-shadow: 0 2px 8px rgba(255, 138, 31, 0.25);
}
.tm-login-card__lostpass {
	margin: 14px 0 0;
	text-align: center;
	font-size: 14px;
}
.tm-login-card__lostpass a {
	color: var(--tm-orange, #FF8A1F);
	font-weight: 600;
	text-decoration: none;
}
.tm-login-card__lostpass a:hover {
	text-decoration: underline;
}
.tm-login-card__footnote {
	margin: 20px 0 0;
	padding: 16px 18px 0;
	border-top: 1px solid var(--tm-line, #ECEAF6);
	font-size: 13px;
	line-height: 1.55;
	color: var(--tm-ink-soft, #4A4870);
	text-align: center;
}

/* ---------------------------------------------------------------------------
 * /register/ — LP-form `.learn-press-form-register` gestyled als tm-login-card.
 *
 * LP renderet:
 *   <div class="learn-press-form-register">
 *     <h3>Registreer</h3>
 *     <form>
 *       <ul class="form-fields">
 *         <li class="form-field"><label>...</label><input ...></li> × 4
 *       </ul>
 *       <p><input nonce> <button>Registreer</button></p>
 *     </form>
 *   </div>
 * ------------------------------------------------------------------------- */
.tm-page-register .learn-press-form-register {
	max-width: 460px;
	margin: 24px auto;
	background: #FFFFFF;
	border: 1px solid var(--tm-line, #ECEAF6);
	border-radius: 16px;
	padding: 28px 28px 24px;
	box-shadow: 0 8px 32px rgba(30, 27, 75, 0.06);
	font-family: "Plus Jakarta Sans", system-ui, sans-serif;
}
.tm-page-register .learn-press-form-register h3 {
	margin: 0 0 18px;
	font-size: 20px;
	font-weight: 800;
	letter-spacing: -0.01em;
	color: var(--tm-ink, #1E1B4B);
}
.tm-page-register .learn-press-form-register form { margin: 0; }
.tm-page-register .learn-press-form-register .form-fields {
	list-style: none;
	margin: 0;
	padding: 0;
}
.tm-page-register .learn-press-form-register .form-field {
	margin: 0 0 14px;
	padding: 0;
}
.tm-page-register .learn-press-form-register .form-field label {
	display: block;
	font-style: normal;
	font-size: 13px;
	font-weight: 600;
	color: var(--tm-ink-soft, #4A4870);
	margin-bottom: 6px;
}
.tm-page-register .learn-press-form-register .form-field label .required {
	color: #B33A2F;
	font-weight: 700;
	margin-left: 2px;
}
.tm-page-register .learn-press-form-register .form-field input[type="text"],
.tm-page-register .learn-press-form-register .form-field input[type="email"],
.tm-page-register .learn-press-form-register .form-field input[type="password"] {
	width: 100%;
	box-sizing: border-box;
	font-family: inherit;
	font-size: 15px;
	color: var(--tm-ink, #1E1B4B);
	background: #FFFFFF;
	border: 1px solid var(--tm-line, #ECEAF6);
	border-radius: 10px;
	padding: 11px 14px;
	transition: border-color 0.15s ease, box-shadow 0.15s ease;
}
.tm-page-register .learn-press-form-register .form-field input:focus {
	border-color: var(--tm-purple, #5B4FE5);
	box-shadow: 0 0 0 3px rgba(91, 79, 229, 0.12);
	outline: 0;
}
.tm-page-register .learn-press-form-register form > p {
	margin: 6px 0 0;
}
.tm-page-register .learn-press-form-register button[type="submit"] {
	width: 100%;
	background: var(--tm-orange, #FF8A1F);
	color: #FFFFFF;
	font-family: inherit;
	font-size: 15px;
	font-weight: 700;
	padding: 13px 24px;
	border: 0;
	border-radius: 12px;
	cursor: pointer;
	box-shadow: 0 4px 14px rgba(255, 138, 31, 0.25);
	transition: background 0.15s ease, transform 0.1s ease;
}
.tm-page-register .learn-press-form-register button[type="submit"]:hover {
	background: #F37A12;
}
.tm-page-register .learn-press-form-register button[type="submit"]:active {
	transform: translateY(1px);
	box-shadow: 0 2px 8px rgba(255, 138, 31, 0.25);
}

/* Cross-link onder de card op zowel /login/ als /register/ */
.tm-page-auth .tm-auth-cross-link {
	max-width: 460px;
	margin: 14px auto 0;
	text-align: center;
	font-size: 14px;
	color: var(--tm-ink-soft, #4A4870);
}
.tm-page-auth .tm-auth-cross-link a {
	color: var(--tm-orange, #FF8A1F);
	font-weight: 600;
	text-decoration: none;
}
.tm-page-auth .tm-auth-cross-link a:hover {
	text-decoration: underline;
}

/* Flash bovenaan /login/ na account-deletion (groene success-strook). */
.tm-login-flash {
	max-width: 460px;
	margin: 20px auto 0;
	padding: 14px 18px;
	border-radius: 12px;
	font-family: "Plus Jakarta Sans", system-ui, sans-serif;
	font-size: 14px;
	line-height: 1.5;
}
.tm-login-flash--ok {
	background: rgba(74, 167, 88, 0.10);
	color: #2F7A3D;
	border: 1px solid rgba(74, 167, 88, 0.30);
}

/* ---------------------------------------------------------------------------
 * /check-je-mail/ + /account-activeren/ — card-varianten naast tm-login-card.
 * ------------------------------------------------------------------------- */
.tm-login-card--check-mail,
.tm-login-card--activate-error {
	text-align: center;
}
.tm-login-card__icon {
	font-size: 48px;
	line-height: 1;
	margin: 0 0 12px;
	--fa-primary-color: var(--tm-green, #4AA758);
	--fa-secondary-color: var(--tm-green, #4AA758);
	--fa-secondary-opacity: 0.20;
}
.tm-login-card__icon--err {
	--fa-primary-color: #B33A2F;
	--fa-secondary-color: #B33A2F;
	--fa-secondary-opacity: 0.20;
}
.tm-login-card__hint {
	margin: -8px 0 18px;
	font-size: 13px;
	line-height: 1.5;
	color: var(--tm-ink-mute, #767492);
}
.tm-login-card__submit,
.tm-login-card__btn-primary {
	display: inline-block;
	width: 100%;
	box-sizing: border-box;
	background: var(--tm-orange, #FF8A1F);
	color: #FFFFFF;
	border: 1px solid var(--tm-orange, #FF8A1F);
	padding: 13px 24px;
	border-radius: 12px;
	font-family: inherit;
	font-size: 15px;
	font-weight: 700;
	text-align: center;
	text-decoration: none;
	cursor: pointer;
	box-shadow: 0 4px 14px rgba(255, 138, 31, 0.25);
	transition: background 0.15s ease, transform 0.1s ease;
}
.tm-login-card__submit:hover,
.tm-login-card__btn-primary:hover {
	background: #F37A12;
	border-color: #F37A12;
	color: #FFFFFF;
}
.tm-login-card__btn-secondary {
	display: inline-block;
	background: #FFFFFF;
	color: var(--tm-ink, #1E1B4B);
	border: 1px solid var(--tm-line, #ECEAF6);
	padding: 11px 22px;
	border-radius: 12px;
	font-family: inherit;
	font-size: 14px;
	font-weight: 700;
	cursor: pointer;
	transition: border-color 0.15s ease;
}
.tm-login-card__btn-secondary:hover {
	border-color: var(--tm-ink-soft, #4A4870);
}
.tm-login-card .tm-field__help {
	display: block;
	margin-top: 6px;
	font-size: 12px;
	color: var(--tm-ink-mute, #767492);
}
.tm-login-flash--info {
	background: rgba(91, 79, 229, 0.08);
	color: var(--tm-purple-deep, #3F35B8);
	border: 1px solid rgba(91, 79, 229, 0.20);
}
.tm-login-flash--err {
	background: rgba(255, 111, 97, 0.10);
	color: #B33A2F;
	border: 1px solid rgba(255, 111, 97, 0.30);
}
.tm-resend-form {
	margin: 14px 0 0;
	text-align: center;
}

/* Tip-box (passphrase-uitleg op /account-activeren/) */
.tm-pw-tip {
	display: block;
	margin: 0 0 18px;
	padding: 14px 16px;
	background: rgba(91, 79, 229, 0.05);
	border: 1px solid rgba(91, 79, 229, 0.15);
	border-radius: 10px;
	font-size: 13px;
	line-height: 1.5;
	color: var(--tm-ink, #1E1B4B);
}
.tm-pw-tip strong {
	display: block;
	margin-bottom: 4px;
	font-weight: 700;
	color: var(--tm-purple-deep, #3F35B8);
}
.tm-pw-tip span { color: var(--tm-ink-soft, #4A4870); }
.tm-pw-tip em {
	font-style: normal;
	font-family: ui-monospace, SFMono-Regular, Menlo, Consolas, monospace;
	font-size: 12px;
	background: rgba(91, 79, 229, 0.10);
	color: var(--tm-purple-deep, #3F35B8);
	padding: 1px 6px;
	border-radius: 4px;
}

/* Strength-meter onder het wachtwoord-veld */
.tm-pw-meter {
	margin-top: 8px;
}
.tm-pw-meter__bar {
	position: relative;
	height: 6px;
	background: var(--tm-line, #ECEAF6);
	border-radius: 4px;
	overflow: hidden;
}
.tm-pw-meter__fill {
	display: block;
	height: 100%;
	width: 0;
	background: #B33A2F;
	border-radius: 4px;
	transition: width 0.2s ease, background 0.2s ease;
}
.tm-pw-meter[data-level="kort"]  .tm-pw-meter__fill,
.tm-pw-meter[data-level="zwak"]  .tm-pw-meter__fill { background: #B33A2F; }
.tm-pw-meter[data-level="matig"] .tm-pw-meter__fill { background: #E67E22; }
.tm-pw-meter[data-level="goed"]  .tm-pw-meter__fill { background: #4AA758; }
.tm-pw-meter[data-level="sterk"] .tm-pw-meter__fill { background: #2F7A3D; }
.tm-pw-meter__label {
	display: inline-block;
	margin-top: 6px;
	font-size: 12px;
	font-weight: 600;
	color: var(--tm-ink-mute, #767492);
}
.tm-pw-meter[data-level="kort"]  .tm-pw-meter__label,
.tm-pw-meter[data-level="zwak"]  .tm-pw-meter__label { color: #B33A2F; }
.tm-pw-meter[data-level="matig"] .tm-pw-meter__label { color: #B5651D; }
.tm-pw-meter[data-level="goed"]  .tm-pw-meter__label { color: #2F7A3D; }
.tm-pw-meter[data-level="sterk"] .tm-pw-meter__label { color: #2F7A3D; }

/* Info-variant: ingelogde user op /login/ of /register/ — geen form, alleen
   uitleg + actie-knoppen. */
.tm-login-card--info {
	text-align: center;
}
.tm-login-card__lede {
	margin: 0 0 20px;
	font-size: 15px;
	line-height: 1.55;
	color: var(--tm-ink-soft, #4A4870);
}
.tm-login-card__actions {
	display: flex;
	flex-direction: column;
	gap: 10px;
}
.tm-login-card__btn {
	display: inline-block;
	width: 100%;
	box-sizing: border-box;
	padding: 13px 24px;
	border-radius: 12px;
	font-family: inherit;
	font-size: 15px;
	font-weight: 700;
	text-align: center;
	text-decoration: none;
	transition: background 0.15s ease, border-color 0.15s ease, color 0.15s ease, transform 0.1s ease;
}
.tm-login-card__btn--primary {
	background: var(--tm-orange, #FF8A1F);
	color: #FFFFFF;
	border: 1px solid var(--tm-orange, #FF8A1F);
	box-shadow: 0 4px 14px rgba(255, 138, 31, 0.25);
}
.tm-login-card__btn--primary:hover {
	background: #F37A12;
	border-color: #F37A12;
	color: #FFFFFF;
}
.tm-login-card__btn--primary:active {
	transform: translateY(1px);
	box-shadow: 0 2px 8px rgba(255, 138, 31, 0.25);
}
.tm-login-card__btn--secondary {
	background: #FFFFFF;
	color: var(--tm-ink, #1E1B4B);
	border: 1px solid var(--tm-line, #ECEAF6);
}
.tm-login-card__btn--secondary:hover {
	border-color: var(--tm-ink-soft, #4A4870);
	color: var(--tm-ink, #1E1B4B);
}
