/* HostLabel – gemeinsames Stylesheet (Theme, Layout, Komponenten) */

:root[data-theme="light"] {
	color-scheme: light;
	--bg: #ffffff;
	--text: #0f172a;
	--muted: #64748b;
	--panel: #ffffff;
	--field: #ffffff;
	--border: #e2e8f0;
	--hover: #f1f5f9;
	--accent: #2563eb;
	--accent-hover: #1d4ed8;
	--accent-contrast: #ffffff;
	--shadow: rgba(2, 6, 23, .12);
}
:root[data-theme="dark"] {
	color-scheme: dark;
	--bg: #0f172a;
	--text: #e2e8f0;
	--muted: #94a3b8;
	--panel: #1e293b;
	--field: #0f172a;
	--border: #334155;
	--hover: #334155;
	--accent: #3b82f6;
	--accent-hover: #2563eb;
	--accent-contrast: #ffffff;
	--shadow: rgba(0, 0, 0, .45);
}

* { box-sizing: border-box; }
[hidden] { display: none !important; }

body {
	font-family: system-ui, sans-serif;
	background: var(--bg);
	color: var(--text);
	margin: 0;
	min-height: 100vh;
	transition: background-color .2s ease, color .2s ease;
}
a { color: var(--accent); }

/* ---------- Startseite ---------- */
.home {
	display: flex;
	min-height: 100vh;
	align-items: center;
	justify-content: center;
}
.box { text-align: center; padding: 2rem; }
.box h1 { font-size: 2.5rem; margin: 0 0 .5rem; }
.box p { color: var(--muted); margin: 0; }

/* ---------- Topbar (Dropdown + Buttons) ---------- */
.topbar {
	position: fixed;
	top: 16px;
	right: 16px;
	z-index: 50;
	display: flex;
	align-items: center;
	gap: 8px;
}

/* ---------- Buttons ---------- */
.btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 8px;
	height: 40px;
	padding: 0 16px;
	font: inherit;
	font-size: 14px;
	font-weight: 500;
	line-height: 1;
	border: 1px solid transparent;
	border-radius: 10px;
	cursor: pointer;
	text-decoration: none;
	white-space: nowrap;
	transition: background-color .15s ease, border-color .15s ease, color .15s ease;
}
.btn--primary { background: var(--accent); color: var(--accent-contrast); }
.btn--primary:hover { background: var(--accent-hover); }
.btn--outline { background: var(--panel); color: var(--text); border-color: var(--border); }
.btn--outline:hover { background: var(--hover); }
.btn--block { width: 100%; }
.btn--lg { height: 44px; font-size: 15px; }
.btn:focus-visible { outline: 2px solid var(--accent); outline-offset: 2px; }

/* ---------- Dropdown-Menü ---------- */
.menu { position: relative; }
.menu__trigger {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 40px;
	height: 40px;
	padding: 0;
	color: var(--text);
	background: var(--panel);
	border: 1px solid var(--border);
	border-radius: 10px;
	cursor: pointer;
	transition: background-color .15s ease, border-color .15s ease;
}
.menu__trigger:hover { background: var(--hover); }
.menu__trigger:focus-visible { outline: 2px solid var(--accent); outline-offset: 2px; }

.menu__panel {
	position: absolute;
	top: calc(100% + 8px);
	right: 0;
	min-width: 224px;
	padding: 6px;
	background: var(--panel);
	border: 1px solid var(--border);
	border-radius: 12px;
	box-shadow: 0 12px 32px -8px var(--shadow), 0 4px 10px -6px var(--shadow);
	opacity: 0;
	visibility: hidden;
	transform: translateY(-6px) scale(.97);
	transform-origin: top right;
	transition: opacity .14s ease, transform .14s ease, visibility .14s;
}
.menu.is-open .menu__panel {
	opacity: 1;
	visibility: visible;
	transform: translateY(0) scale(1);
}
.menu__heading {
	margin: 0;
	padding: 8px 10px 4px;
	font-size: 11px;
	font-weight: 600;
	letter-spacing: .06em;
	text-transform: uppercase;
	color: var(--muted);
}
.menu__item {
	display: flex;
	align-items: center;
	gap: 10px;
	width: 100%;
	padding: 8px 10px;
	font: inherit;
	font-size: 14px;
	color: var(--text);
	text-align: left;
	background: none;
	border: 0;
	border-radius: 8px;
	cursor: pointer;
}
.menu__item:hover { background: var(--hover); }
.menu__item:focus-visible { outline: 2px solid var(--accent); outline-offset: -2px; }
.menu__lead {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 18px;
	height: 18px;
	flex: none;
	color: var(--muted);
	font-size: 10px;
	font-weight: 700;
}
.menu__label { flex: 1; }
.menu__check {
	width: 16px;
	height: 16px;
	flex: none;
	color: var(--accent);
	opacity: 0;
}
.menu__item.is-active .menu__check { opacity: 1; }
.menu__item.is-active .menu__lead { color: var(--text); }
.menu__divider { height: 1px; margin: 6px 4px; background: var(--border); }

/* ---------- Auth-Seiten (Login / Register) ---------- */
.auth {
	min-height: 100vh;
	display: flex;
	align-items: center;
	justify-content: center;
	padding: 80px 16px 48px;
}
.card {
	width: 100%;
	max-width: 440px;
	background: var(--panel);
	border: 1px solid var(--border);
	border-radius: 16px;
	padding: 28px;
	box-shadow: 0 18px 40px -18px var(--shadow);
}
.card--wide { max-width: 580px; }
.auth__title { margin: 0 0 4px; font-size: 1.5rem; }
.auth__subtitle { margin: 0 0 24px; color: var(--muted); font-size: .925rem; }

.back {
	position: fixed;
	top: 16px;
	left: 16px;
	z-index: 50;
	display: inline-flex;
	align-items: center;
	gap: 6px;
	font-size: .875rem;
	color: var(--muted);
	text-decoration: none;
}
.back:hover { color: var(--text); }

/* ---------- Formular ---------- */
.section-title {
	margin: 22px 0 12px;
	font-size: .7rem;
	font-weight: 600;
	letter-spacing: .06em;
	text-transform: uppercase;
	color: var(--muted);
}
.section-title:first-of-type { margin-top: 0; }

.field { margin-bottom: 14px; }
.field > label {
	display: block;
	margin-bottom: 6px;
	font-size: .8rem;
	font-weight: 500;
	color: var(--muted);
}
.input {
	width: 100%;
	height: 42px;
	padding: 0 12px;
	font: inherit;
	font-size: .95rem;
	color: var(--text);
	background: var(--field);
	border: 1px solid var(--border);
	border-radius: 10px;
	transition: border-color .15s ease, box-shadow .15s ease;
}
select.input { cursor: pointer; }
.input:focus {
	outline: none;
	border-color: var(--accent);
	box-shadow: 0 0 0 3px color-mix(in srgb, var(--accent) 25%, transparent);
}
.input::placeholder { color: var(--muted); opacity: .7; }

/* Passwortfeld: Auge (anzeigen) + Randomizer (generieren) */
.pw { position: relative; display: block; }
.pw__btns {
	position: absolute;
	top: 0;
	right: 4px;
	height: 42px;
	display: flex;
	align-items: center;
	gap: 2px;
}
.pw__btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 32px;
	height: 32px;
	padding: 0;
	border: 0;
	border-radius: 8px;
	background: none;
	color: var(--muted);
	cursor: pointer;
	transition: background-color .15s ease, color .15s ease;
}
.pw__btn:hover { background: var(--hover); color: var(--text); }
.pw__btn:focus-visible { outline: 2px solid var(--accent); outline-offset: -2px; }
.pw__btn svg { width: 18px; height: 18px; display: block; }
.pw__btn .icon-eyeoff { display: none; }
.pw__btn[aria-pressed="true"] .icon-eye { display: none; }
.pw__btn[aria-pressed="true"] .icon-eyeoff { display: block; }

.row { display: grid; gap: 12px; }
.row--2 { grid-template-columns: 1fr 1fr; }
.row--addr { grid-template-columns: 1fr 96px; }

.auth__foot {
	margin-top: 18px;
	text-align: center;
	font-size: .875rem;
	color: var(--muted);
}
.auth__foot a { font-weight: 500; text-decoration: none; }
.auth__foot a:hover { text-decoration: underline; }

.note {
	margin: 16px 0 0;
	padding: 10px 12px;
	border-radius: 10px;
	background: var(--hover);
	color: var(--muted);
	font-size: .8rem;
	text-align: center;
}
.note.is-active {
	background: color-mix(in srgb, var(--accent) 14%, transparent);
	color: var(--text);
}

@media (max-width: 480px) {
	.row--2 { grid-template-columns: 1fr; }
	.card { padding: 22px; }
}
