/* ============================================================
   USER DASHBOARD PRO – LOGIN & PASSWORD RESET
   Modernes, sauberes Design (Version 2.0)
   ============================================================ */

:root {
	--udw-primary:      var(--udw-primary-global, #2563eb);
	--udw-primary-dark: #1d4ed8;
	--udw-success:      #16a34a;
	--udw-danger:       #dc2626;
	--udw-warning:      #d97706;
	--udw-text:         #111827;
	--udw-muted:        #6b7280;
	--udw-border:       #e5e7eb;
	--udw-bg-input:     #f9fafb;
	--udw-radius:       14px;
	--udw-shadow:       0 4px 6px -1px rgba(0,0,0,.07), 0 2px 4px -2px rgba(0,0,0,.07);
	--udw-shadow-lg:    0 20px 25px -5px rgba(0,0,0,.1), 0 8px 10px -6px rgba(0,0,0,.1);
	--udw-transition:   all .2s cubic-bezier(.4,0,.2,1);
}

/* ── Container ──────────────────────────────────────────────── */
.udw-login-form,
.udw-password-reset-form {
	max-width: 440px;
	margin: 0 auto;
	padding: 48px 44px;
	background: #fff;
	border-radius: 20px;
	box-shadow: var(--udw-shadow-lg);
	transition: box-shadow .3s ease;
	position: relative;
	overflow: hidden;
}

.udw-login-form::before,
.udw-password-reset-form::before {
	content: '';
	position: absolute;
	top: 0; left: 0; right: 0;
	height: 4px;
	background: linear-gradient(90deg, var(--udw-primary), #7c3aed);
	border-radius: 20px 20px 0 0;
}

/* ── Header ─────────────────────────────────────────────────── */
.udw-login-header {
	text-align: center;
	margin-bottom: 36px;
}

.udw-login-logo {
	width: 64px;
	height: 64px;
	background: linear-gradient(135deg, var(--udw-primary) 0%, #7c3aed 100%);
	border-radius: 18px;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	margin-bottom: 20px;
	box-shadow: 0 8px 16px rgba(37,99,235,.25);
}

.udw-login-logo i {
	font-size: 26px;
	color: #fff;
}

.udw-login-title {
	font-size: 26px !important;
	font-weight: 700 !important;
	color: var(--udw-text) !important;
	margin: 0 0 8px !important;
	letter-spacing: -.4px;
	line-height: 1.2 !important;
}

.udw-login-subtitle {
	font-size: 14px;
	color: var(--udw-muted);
	margin: 0;
	line-height: 1.5;
}

/* ── Form Groups ────────────────────────────────────────────── */
.udw-login-form .udw-form-group,
.udw-password-reset-form .udw-form-group {
	margin-bottom: 22px;
}

.udw-login-form label,
.udw-password-reset-form label {
	display: flex !important;
	align-items: center;
	gap: 7px;
	font-size: 13px !important;
	font-weight: 600 !important;
	color: var(--udw-text) !important;
	margin-bottom: 8px !important;
}

.udw-login-form label i,
.udw-password-reset-form label i {
	color: var(--udw-primary);
	font-size: 13px;
	width: 14px;
}

/* ── Input Wrapper mit Icon ─────────────────────────────────── */
.udw-input-wrapper {
	position: relative;
	display: flex;
	align-items: center;
}

.udw-input-icon {
	position: absolute;
	left: 16px;
	color: var(--udw-muted);
	font-size: 14px;
	pointer-events: none;
	z-index: 1;
	transition: color .2s;
}

.udw-login-form input[type="text"],
.udw-login-form input[type="password"],
.udw-login-form input[type="email"],
.udw-password-reset-form input[type="text"],
.udw-password-reset-form input[type="password"],
.udw-password-reset-form input[type="email"] {
	width: 100%;
	padding: 13px 16px 13px 44px !important;
	font-size: 14px;
	color: var(--udw-text);
	background: var(--udw-bg-input);
	border: 1.5px solid var(--udw-border) !important;
	border-radius: var(--udw-radius);
	outline: none;
	transition: var(--udw-transition);
	box-sizing: border-box;
	box-shadow: 0 1px 2px rgba(0,0,0,.04);
}

.udw-login-form input[type="text"]:focus,
.udw-login-form input[type="password"]:focus,
.udw-login-form input[type="email"]:focus,
.udw-password-reset-form input:focus {
	border-color: var(--udw-primary) !important;
	background: #fff;
	box-shadow: 0 0 0 4px rgba(37,99,235,.1);
}

.udw-input-wrapper:focus-within .udw-input-icon {
	color: var(--udw-primary);
}

.udw-login-form input::placeholder,
.udw-password-reset-form input::placeholder {
	color: #c4c4c4;
}

/* ── Passwort-Toggle ───────────────────────────────────────── */
.udw-password-wrapper .udw-toggle-password {
	position: absolute;
	right: 14px;
	background: none;
	border: none;
	cursor: pointer;
	color: var(--udw-muted);
	font-size: 15px;
	padding: 4px;
	transition: color .2s;
	z-index: 1;
}

.udw-password-wrapper .udw-toggle-password:hover {
	color: var(--udw-primary);
}

/* ── Checkbox ──────────────────────────────────────────────── */
.udw-checkbox-group {
	margin-bottom: 18px !important;
}

.udw-checkbox-label {
	display: flex !important;
	align-items: center;
	gap: 10px;
	cursor: pointer;
	font-size: 13px !important;
	font-weight: 500 !important;
	color: var(--udw-muted) !important;
	margin-bottom: 0 !important;
}

.udw-checkbox-label input[type="checkbox"] {
	display: none;
}

.udw-checkbox-custom {
	width: 18px;
	height: 18px;
	border: 2px solid var(--udw-border);
	border-radius: 5px;
	background: #fff;
	flex-shrink: 0;
	display: flex;
	align-items: center;
	justify-content: center;
	transition: var(--udw-transition);
	position: relative;
}

.udw-checkbox-label input:checked ~ .udw-checkbox-custom {
	background: var(--udw-primary);
	border-color: var(--udw-primary);
}

.udw-checkbox-label input:checked ~ .udw-checkbox-custom::after {
	content: '';
	width: 5px;
	height: 9px;
	border: 2px solid #fff;
	border-top: none;
	border-left: none;
	transform: rotate(45deg) translateY(-1px);
	display: block;
}

/* ── Submit Button ─────────────────────────────────────────── */
.udw-login-submit,
.udw-reset-submit {
	width: 100%;
	padding: 14px 24px;
	font-size: 15px;
	font-weight: 600;
	color: #fff;
	background: linear-gradient(135deg, var(--udw-primary) 0%, #1d4ed8 100%);
	border: none;
	border-radius: var(--udw-radius);
	cursor: pointer;
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 8px;
	margin-top: 8px;
	transition: var(--udw-transition);
	box-shadow: 0 4px 14px rgba(37,99,235,.35);
	letter-spacing: .01em;
}

.udw-login-submit:hover,
.udw-reset-submit:hover {
	transform: translateY(-2px);
	box-shadow: 0 8px 20px rgba(37,99,235,.45);
}

.udw-login-submit:active,
.udw-reset-submit:active {
	transform: translateY(0);
}

.udw-login-submit:disabled,
.udw-reset-submit:disabled {
	opacity: .65;
	cursor: not-allowed;
	transform: none;
}

/* ── Links ─────────────────────────────────────────────────── */
.udw-login-links {
	display: flex;
	justify-content: space-between;
	align-items: center;
	margin-top: 20px;
	padding-top: 18px;
	border-top: 1px solid var(--udw-border);
	flex-wrap: wrap;
	gap: 8px;
}

.udw-lost-password,
.udw-register,
.udw-back-to-login {
	font-size: 13px;
	font-weight: 500;
	color: var(--udw-primary);
	text-decoration: none;
	display: inline-flex;
	align-items: center;
	gap: 6px;
	transition: color .2s;
}

.udw-lost-password:hover,
.udw-register:hover,
.udw-back-to-login:hover {
	color: var(--udw-primary-dark);
	text-decoration: underline;
}

.udw-redirect-hint {
	color: var(--udw-muted);
	font-size: 13px;
	margin: 8px 0 16px;
}

/* ── Nachrichten ───────────────────────────────────────────── */
.udw-pro-message {
	display: flex;
	align-items: flex-start;
	gap: 10px;
	padding: 12px 16px;
	border-radius: 10px;
	font-size: 13.5px;
	font-weight: 500;
	margin-bottom: 20px;
	line-height: 1.5;
	animation: udwFadeIn .25s ease;
}

@keyframes udwFadeIn {
	from { opacity: 0; transform: translateY(-4px); }
	to   { opacity: 1; transform: translateY(0); }
}

.udw-pro-message.success {
	background: #f0fdf4;
	color: #166534;
	border: 1px solid #bbf7d0;
}

.udw-pro-message.success i {
	color: var(--udw-success);
	margin-top: 1px;
}

.udw-pro-message.error {
	background: #fef2f2;
	color: #991b1b;
	border: 1px solid #fecaca;
}

.udw-pro-message.error i {
	color: var(--udw-danger);
	margin-top: 1px;
}

.udw-pro-message.info {
	background: #eff6ff;
	color: #1e40af;
	border: 1px solid #bfdbfe;
}

.udw-pro-message.info i {
	color: var(--udw-primary);
	margin-top: 1px;
}

/* ── Style Varianten ────────────────────────────────────────── */

/* Glassmorphism */
.udw-login-glass,
.udw-password-reset-form.udw-login-glass {
	background: rgba(255,255,255,.72);
	backdrop-filter: blur(20px);
	-webkit-backdrop-filter: blur(20px);
	border: 1px solid rgba(255,255,255,.5);
	box-shadow: 0 8px 32px rgba(0,0,0,.12);
}

/* Minimal */
.udw-login-minimal,
.udw-password-reset-form.udw-login-minimal {
	box-shadow: none;
	border: 1.5px solid var(--udw-border);
}

.udw-login-minimal::before {
	display: none;
}

/* Gradient */
.udw-login-gradient,
.udw-password-reset-form.udw-login-gradient {
	background: linear-gradient(135deg, #667eea 0%, #764ba2 100%);
	color: #fff;
}

.udw-login-gradient .udw-login-title,
.udw-login-gradient .udw-login-subtitle,
.udw-login-gradient label {
	color: rgba(255,255,255,.95) !important;
}

.udw-login-gradient .udw-login-links {
	border-top-color: rgba(255,255,255,.2);
}

.udw-login-gradient .udw-lost-password,
.udw-login-gradient .udw-register {
	color: rgba(255,255,255,.9);
}

.udw-login-gradient input {
	background: rgba(255,255,255,.15) !important;
	border-color: rgba(255,255,255,.3) !important;
	color: #fff !important;
}

.udw-login-gradient input::placeholder {
	color: rgba(255,255,255,.5) !important;
}

/* ── Already-Logged-In Zustand ─────────────────────────────── */
.udw-already-logged-in {
	text-align: center;
}

/* ── Onboarding / Magic Link Widget ────────────────────────── */
.udw-onboarding-card {
	max-width: 500px;
	margin: 0 auto;
	padding: 48px 44px;
	background: #fff;
	border-radius: 20px;
	box-shadow: var(--udw-shadow-lg);
	text-align: center;
	position: relative;
	overflow: hidden;
}

.udw-onboarding-card::before {
	content: '';
	position: absolute;
	top: 0; left: 0; right: 0;
	height: 4px;
	background: linear-gradient(90deg, var(--udw-success), #059669);
}

.udw-onboarding-logo {
	width: 72px;
	height: 72px;
	background: linear-gradient(135deg, var(--udw-success), #059669);
	border-radius: 20px;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	margin-bottom: 24px;
	box-shadow: 0 8px 16px rgba(22,163,74,.25);
}

.udw-onboarding-logo i {
	font-size: 30px;
	color: #fff;
}

.udw-onboarding-title {
	font-size: 24px !important;
	font-weight: 700 !important;
	color: var(--udw-text) !important;
	margin: 0 0 8px !important;
}

.udw-onboarding-subtitle {
	font-size: 14px;
	color: var(--udw-muted);
	margin: 0 0 32px;
	line-height: 1.6;
}

.udw-qr-wrapper {
	background: #f8fafc;
	border: 2px solid var(--udw-border);
	border-radius: 16px;
	padding: 24px;
	margin: 0 auto 28px;
	display: inline-block;
}

.udw-qr-wrapper img {
	display: block;
	border-radius: 8px;
}

.udw-qr-hint {
	font-size: 12px;
	color: var(--udw-muted);
	margin-top: 12px;
}

.udw-magic-btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 10px;
	width: 100%;
	padding: 15px 28px;
	font-size: 15px;
	font-weight: 600;
	color: #fff;
	background: linear-gradient(135deg, var(--udw-success), #059669);
	border: none;
	border-radius: var(--udw-radius);
	cursor: pointer;
	text-decoration: none;
	transition: var(--udw-transition);
	box-shadow: 0 4px 14px rgba(22,163,74,.35);
}

.udw-magic-btn:hover {
	transform: translateY(-2px);
	box-shadow: 0 8px 20px rgba(22,163,74,.45);
	color: #fff;
	text-decoration: none;
}

.udw-token-expired {
	background: #fef2f2;
	border: 1px solid #fecaca;
	border-radius: 12px;
	padding: 20px 24px;
	color: #991b1b;
}

.udw-set-password-form {
	text-align: left;
	margin-top: 24px;
}

/* ── Admin Invite Section ──────────────────────────────────── */
.udw-invite-card {
	background: #f8fafc;
	border: 1.5px solid var(--udw-border);
	border-radius: 16px;
	padding: 28px;
	margin-top: 24px;
}

.udw-invite-card h3 {
	font-size: 16px;
	font-weight: 700;
	color: var(--udw-text);
	margin: 0 0 6px;
}

.udw-invite-card p {
	font-size: 13px;
	color: var(--udw-muted);
	margin: 0 0 20px;
}

.udw-invite-fields {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 14px;
	margin-bottom: 16px;
}

.udw-invite-fields.full {
	grid-template-columns: 1fr;
}

.udw-invite-fields label {
	font-size: 12px;
	font-weight: 600;
	color: var(--udw-text);
	display: block;
	margin-bottom: 6px;
}

.udw-invite-fields input,
.udw-invite-fields select {
	width: 100%;
	padding: 10px 14px;
	font-size: 13px;
	border: 1.5px solid var(--udw-border);
	border-radius: 10px;
	background: #fff;
	color: var(--udw-text);
	outline: none;
	transition: border-color .2s;
	box-sizing: border-box;
}

.udw-invite-fields input:focus,
.udw-invite-fields select:focus {
	border-color: var(--udw-primary);
}

.udw-invite-btn {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	padding: 11px 22px;
	font-size: 13px;
	font-weight: 600;
	color: #fff;
	background: var(--udw-primary);
	border: none;
	border-radius: 10px;
	cursor: pointer;
	transition: var(--udw-transition);
}

.udw-invite-btn:hover {
	background: var(--udw-primary-dark);
}

.udw-invite-result {
	margin-top: 16px;
	padding: 14px 16px;
	border-radius: 10px;
	font-size: 13px;
	display: none;
}

.udw-invite-result.ok    { background: #f0fdf4; border: 1px solid #bbf7d0; color: #166534; }
.udw-invite-result.error { background: #fef2f2; border: 1px solid #fecaca; color: #991b1b; }

/* ── Mobile ─────────────────────────────────────────────────── */
@media (max-width: 480px) {
	.udw-login-form,
	.udw-password-reset-form,
	.udw-onboarding-card {
		padding: 36px 24px;
	}

	.udw-invite-fields {
		grid-template-columns: 1fr;
	}
}
