/* Selbsteinschätzung – Schülerformular
   Farbwelt hoerstrup.com: Türkis + Dunkelrot, viel Weißraum */

.se-app {
	--se-teal: #2ec4a7;
	--se-teal-dark: #189e85;
	--se-teal-soft: #e6f7f3;
	--se-red: #8c1d2f;
	--se-ink: #2b2f33;
	--se-grey: #6b7378;
	--se-line: #e3e7e9;
	--se-amber: #d99a27;
	--se-bg: #ffffff;

	max-width: 720px;
	margin: 0 auto;
	color: var(--se-ink);
	font-size: 17px;
	line-height: 1.55;
	padding-bottom: 90px; /* Platz für die untere Leiste */
}

.se-app *, .se-app *::before, .se-app *::after { box-sizing: border-box; }

/* ---------- Schritte ---------- */
.se-step { display: none; animation: se-in .35s ease; }
.se-step.is-active { display: block; }
@keyframes se-in { from { opacity: 0; transform: translateY(8px); } to { opacity: 1; transform: none; } }
@media (prefers-reduced-motion: reduce) { .se-step { animation: none; } }

.se-stephead { display: flex; align-items: center; gap: .7em; margin: 0 0 .4em; }
.se-stephead h2 { margin: 0; font-size: 1.5em; font-weight: 700; color: var(--se-ink); }
.se-stepnum {
	flex: 0 0 auto; width: 2em; height: 2em; border-radius: 50%;
	background: var(--se-teal); color: #fff; font-weight: 700;
	display: flex; align-items: center; justify-content: center; font-size: .95em;
}
.se-intro { color: var(--se-grey); margin-top: 0; }

/* ---------- Felder ---------- */
.se-field { margin: 1.4em 0; }
.se-field > label { display: block; font-weight: 700; margin-bottom: .45em; }
.se-field > label small { font-weight: 400; color: var(--se-grey); }

.se-app input[type="text"],
.se-app input[type="search"],
.se-app textarea {
	width: 100%; padding: .7em .9em; font: inherit; color: var(--se-ink);
	border: 2px solid var(--se-line); border-radius: 10px; background: #fff;
}
.se-app input[type="text"]:focus,
.se-app textarea:focus,
.se-app input[type="range"]:focus-visible,
.se-app button:focus-visible,
.se-card input:focus-visible + .se-card-dot {
	outline: 3px solid var(--se-teal); outline-offset: 2px; border-color: var(--se-teal);
}
#se-code { text-transform: uppercase; letter-spacing: .18em; font-weight: 700; max-width: 14em; }

.se-hint { color: var(--se-teal-dark); font-weight: 600; }
.se-error { color: var(--se-red); font-weight: 600; margin: .4em 0 0; }

/* ---------- Klassen-Chips ---------- */
.se-klassen { display: grid; grid-template-columns: repeat(auto-fill, minmax(86px, 1fr)); gap: .5em; }
.se-chip {
	font: inherit; font-weight: 700; padding: .55em 0; cursor: pointer;
	border: 2px solid var(--se-line); border-radius: 10px; background: #fff; color: var(--se-ink);
	transition: border-color .15s, background .15s;
}
.se-chip:hover { border-color: var(--se-teal); }
.se-chip.is-selected { border-color: var(--se-teal); background: var(--se-teal-soft); color: var(--se-teal-dark); }

/* ---------- Kriterien-Karten ---------- */
.se-krit { border: 0; padding: 0; margin: 2em 0; }
.se-krit legend { font-size: 1.1em; margin-bottom: .6em; padding: 0; }
.se-krit-icon { font-size: 1.2em; margin-right: .15em; }

.se-cards { display: grid; gap: .5em; }
.se-card {
	display: flex; align-items: flex-start; gap: .8em; cursor: pointer;
	border: 2px solid var(--se-line); border-radius: 12px; padding: .75em .9em;
	background: #fff; transition: border-color .15s, background .15s, transform .1s;
}
.se-card:hover { border-color: var(--se-teal); }
.se-card:active { transform: scale(.99); }
.se-card input { position: absolute; opacity: 0; pointer-events: none; }

.se-card-dot {
	flex: 0 0 auto; width: 1.1em; height: 1.1em; margin-top: .25em; border-radius: 50%;
	border: 2px solid currentColor; position: relative;
}
/* Stufenfarben: 1–2 türkis, 3–4 bernstein, 5–6 dunkelrot */
.se-l1 .se-card-dot, .se-l2 .se-card-dot { color: var(--se-teal-dark); }
.se-l3 .se-card-dot, .se-l4 .se-card-dot { color: var(--se-amber); }
.se-l5 .se-card-dot, .se-l6 .se-card-dot { color: var(--se-red); }

.se-card-title { display: block; font-weight: 700; }
.se-card-text { display: block; color: var(--se-grey); font-size: .92em; }

.se-card.is-selected { border-color: var(--se-teal); background: var(--se-teal-soft); }
.se-card.is-selected .se-card-dot::after {
	content: ""; position: absolute; inset: 2px; border-radius: 50%; background: currentColor;
}

/* ---------- Ergebnis / Tacho ---------- */
.se-result {
	display: flex; gap: 1.6em; align-items: center; flex-wrap: wrap;
	background: var(--se-teal-soft); border-radius: 16px; padding: 1.2em 1.4em; margin: 1em 0 1.6em;
}
.se-gauge { position: relative; width: 130px; height: 130px; flex: 0 0 auto; }
.se-gauge svg { width: 100%; height: 100%; transform: rotate(-90deg); }
.se-gauge circle { fill: none; stroke-width: 10; stroke-linecap: round; }
.se-gauge-bg { stroke: #fff; }
.se-gauge-val { stroke: var(--se-teal); stroke-dasharray: 326.7; stroke-dashoffset: 326.7; transition: stroke-dashoffset .5s ease; }
.se-gauge-num {
	position: absolute; inset: 0; display: flex; flex-direction: column;
	align-items: center; justify-content: center; font-weight: 800; font-size: 2em; color: var(--se-ink);
}
.se-gauge-num small { font-size: .42em; font-weight: 600; color: var(--se-grey); }

.se-result-side { flex: 1 1 220px; }
.se-result-label { margin: 0; color: var(--se-grey); }
.se-suggestion { margin: .1em 0 .6em; font-size: 1.3em; font-weight: 800; color: var(--se-teal-dark); }

.se-mini-bars { display: grid; gap: .35em; }
.se-mini-bar { display: grid; grid-template-columns: 9.5em 1fr; align-items: center; gap: .6em; font-size: .85em; }
.se-mini-bar .track { display: block; height: 8px; border-radius: 4px; background: #fff; overflow: hidden; }
.se-mini-bar .fill { display: block; height: 100%; border-radius: 4px; background: var(--se-teal); transition: width .4s ease; }
.se-mini-bar.warn .fill { background: var(--se-amber); }
.se-mini-bar.bad .fill { background: var(--se-red); }

/* ---------- Slider ---------- */
.se-app input[type="range"] { width: 100%; accent-color: var(--se-teal); height: 2.2em; }
.se-slider-scale { display: flex; justify-content: space-between; color: var(--se-grey); font-size: .85em; }

/* ---------- Buttons ---------- */
.se-btn {
	font: inherit; font-weight: 700; cursor: pointer; border-radius: 12px;
	padding: .8em 1.6em; border: 2px solid transparent; transition: background .15s, transform .1s;
}
.se-btn:active { transform: scale(.98); }
.se-btn-primary { background: var(--se-teal); color: #fff; }
.se-btn-primary:hover { background: var(--se-teal-dark); }
.se-btn-primary:disabled { background: var(--se-line); color: var(--se-grey); cursor: not-allowed; }

/* ---------- Erfolg ---------- */
.se-success { text-align: center; padding: 2em 1em; }
.se-success-check {
	width: 72px; height: 72px; margin: 0 auto .8em; border-radius: 50%;
	background: var(--se-teal); color: #fff; font-size: 2.4em; font-weight: 800;
	display: flex; align-items: center; justify-content: center;
}
.se-done-summary {
	display: inline-flex; gap: .6em; flex-wrap: wrap; justify-content: center; margin-top: 1em;
}
.se-done-summary .tag {
	background: var(--se-teal-soft); color: var(--se-teal-dark);
	border-radius: 999px; padding: .35em .9em; font-weight: 700; font-size: .9em;
}
.se-done-summary .tag.big { background: var(--se-teal); color: #fff; font-size: 1.05em; }

/* ---------- Untere Leiste ---------- */
.se-bar {
	position: fixed; left: 0; right: 0; bottom: 0; z-index: 50;
	display: flex; align-items: center; gap: 1em;
	background: #fff; border-top: 3px solid var(--se-teal);
	padding: .6em max(1em, calc((100% - 720px) / 2));
	box-shadow: 0 -4px 16px rgba(0,0,0,.07);
}
.se-bar-progress { flex: 1; height: 10px; border-radius: 5px; background: var(--se-line); overflow: hidden; }
.se-bar-progress span { display: block; height: 100%; width: 0; background: var(--se-teal); border-radius: 5px; transition: width .3s ease; }
.se-bar-note { font-weight: 800; color: var(--se-teal-dark); white-space: nowrap; min-width: 5.5em; text-align: right; }

/* ---------- Mobil ---------- */
@media (max-width: 560px) {
	.se-app { font-size: 16px; }
	.se-result { flex-direction: column; text-align: center; }
	.se-mini-bar { grid-template-columns: 8em 1fr; text-align: left; }
	.se-btn { width: 100%; }
}
