/* ============================================================
   QUALI-TRAINER – Stylesheet (minimalistisch / Swiss-Style)
   Neutrale Palette, EIN Akzent, kaum Schatten, klare Typografie.
   Schriften & Icons selbst gehostet (keine externen Ressourcen).
   ============================================================ */

/* ── Selbst gehostete Schrift (optional) ──────────────────────
   Lege die Inter-woff2-Dateien in den Ordner /fonts (siehe
   fonts/README.txt). Fehlen sie, wird sauber auf Helvetica/Arial
   zurückgefallen – die Seite sieht trotzdem gut aus.            */
@font-face{font-family:"Inter";font-style:normal;font-weight:400;font-display:swap;
  src:local("Inter"),url("../fonts/Inter-Regular.woff2") format("woff2")}
@font-face{font-family:"Inter";font-style:normal;font-weight:500;font-display:swap;
  src:local("Inter Medium"),url("../fonts/Inter-Medium.woff2") format("woff2")}
@font-face{font-family:"Inter";font-style:normal;font-weight:600;font-display:swap;
  src:local("Inter SemiBold"),url("../fonts/Inter-SemiBold.woff2") format("woff2")}
@font-face{font-family:"Inter";font-style:normal;font-weight:700;font-display:swap;
  src:local("Inter Bold"),url("../fonts/Inter-Bold.woff2") format("woff2")}


/* ── 1. Tokens & Reset ────────────────────────────────────── */

:root{
  --ink:#17181c;        /* fast schwarz – Text & Überschriften */
  --muted:#6a7079;      /* sekundärer Text */
  --faint:#9aa0a8;      /* Hinweise */
  --bg:#fafafa;         /* Seitenhintergrund */
  --paper:#ffffff;      /* Karten/Flächen */
  --line:#e7e8ea;       /* feine Linien */
  --line-strong:#d2d4d7;
  --accent:#1d4ed8;     /* EINZIGE Akzentfarbe – sparsam einsetzen */
  --accent-weak:#eef2ff;
  --radius:6px;
  --uebergang:.15s ease;
  --sans:"Inter","Helvetica Neue",Helvetica,Arial,system-ui,sans-serif;
}

html[data-theme="dark"]{
  --ink:#e8e9ec; --muted:#9aa0a8; --faint:#6a7079;
  --bg:#0f1115; --paper:#16181d; --line:#262a31; --line-strong:#363b44;
  --accent:#6b8afd; --accent-weak:rgba(107,138,253,.15);
}
html{background:var(--bg)}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;-webkit-tap-highlight-color:transparent}
html{font-size:16px;scroll-behavior:smooth}
body{
  font-family:var(--sans);background:var(--bg);color:var(--ink);
  min-height:100vh;line-height:1.6;-webkit-font-smoothing:antialiased;
  display:flex;flex-direction:column;letter-spacing:-0.005em;
}
h1,h2,h3,h4{font-weight:700;line-height:1.15;letter-spacing:-0.02em}
a{color:var(--accent);text-decoration:none}
a:hover{text-decoration:underline}
button{font-family:inherit;cursor:pointer}
:focus-visible{outline:2px solid var(--accent);outline-offset:2px}

/* Icons */
.ic{width:1.25em;height:1.25em;display:inline-block;vertical-align:-0.18em;
  fill:none;stroke:currentColor;stroke-width:1.75;stroke-linecap:round;stroke-linejoin:round}
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;
  clip:rect(0,0,0,0);white-space:nowrap;border:0}

@media (prefers-reduced-motion:reduce){*{animation:none!important;transition:none!important}}


/* ── 2. Helfer ────────────────────────────────────────────── */

.eyebrow{
  font-size:.72rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase;
  color:var(--faint);
}
.goldline{height:1px;background:var(--line);border:0;margin:18px 0}


/* ── 3. Layout ────────────────────────────────────────────── */

.seite{display:none;flex:1}
.seite.aktiv{display:block}
.container,.wrap{max-width:980px;margin:0 auto;padding:0 24px}
main{flex:1;padding:40px 0 72px}


/* ── 4. Login ─────────────────────────────────────────────── */

#seite-login.aktiv{display:flex;align-items:center;justify-content:center;min-height:100vh;padding:24px;background:var(--bg)}
.login-box{
  background:var(--paper);border:1px solid var(--line);border-top:3px solid var(--ink);
  border-radius:var(--radius);padding:2.4rem 2.1rem;width:100%;max-width:380px;
}
.login-logo{color:var(--ink);margin-bottom:1rem;display:flex}
.login-logo .ic{width:30px;height:30px}
.login-box h1{font-size:1.7rem;margin-bottom:.2rem}
.login-schule{display:block;font-size:.8rem;color:var(--muted);margin-bottom:1.6rem}
.login-box hr.goldline{margin:1.1rem 0 1.4rem}
.login-box label{display:block;font-size:.78rem;font-weight:600;color:var(--muted);margin-bottom:.45rem}
.login-box input[type="password"]{
  width:100%;padding:.7rem .85rem;background:var(--paper);border:1px solid var(--line-strong);
  border-radius:var(--radius);color:var(--ink);font-family:inherit;font-size:1rem;outline:none;
  transition:border-color var(--uebergang),box-shadow var(--uebergang);margin-bottom:1.1rem;
}
.login-box input[type="password"]:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-weak)}
.login-box input[type="password"]::placeholder{color:var(--faint)}
.btn-login{
  width:100%;padding:.75rem;background:var(--ink);color:var(--bg);border:1px solid var(--ink);
  border-radius:var(--radius);font-size:.95rem;font-weight:600;
  transition:filter var(--uebergang);
}
.btn-login:hover{filter:brightness(1.15)}
.login-fehler{
  display:none;font-size:.85rem;color:#e5484d;margin-top:.8rem;padding:.55rem .75rem;
  background:rgba(229,72,77,.12);border:1px solid rgba(229,72,77,.4);border-radius:var(--radius);
}
.login-fehler.sichtbar{display:block}


/* ── 5. Header ────────────────────────────────────────────── */

header{
  background:var(--paper);border-bottom:1px solid var(--line);
  position:sticky;top:0;z-index:100;
}
.header-inner{display:flex;align-items:center;gap:1rem;padding:0 24px;max-width:980px;margin:0 auto;min-height:60px}

.header-home{display:flex;align-items:center;gap:.6rem;cursor:pointer;color:var(--ink);
  padding:.25rem .35rem;margin-left:-.35rem;border-radius:var(--radius)}
.header-home:hover{background:var(--bg)}
.header-logo{display:flex;color:var(--ink)}
.header-logo .ic{width:22px;height:22px}
.header-titel{font-weight:700;font-size:1.05rem;color:var(--ink);letter-spacing:-0.02em}
.header-titel span{display:block;font-size:.7rem;font-weight:400;color:var(--muted);letter-spacing:0;margin-top:1px}

.breadcrumb{display:flex;align-items:center;gap:.5rem;font-size:.9rem;flex:1;margin-left:.75rem}
.breadcrumb-link{color:var(--muted);cursor:pointer;font-weight:500}
.breadcrumb-link:hover{color:var(--ink)}
.breadcrumb-trenner{color:var(--faint)}
.breadcrumb-aktuell{color:var(--ink);font-weight:600}

/* Menü */
.theme-toggle{display:flex;align-items:center;justify-content:center;background:var(--paper);
  border:1px solid var(--line-strong);color:var(--ink);border-radius:var(--radius);
  width:38px;height:38px;flex-shrink:0;transition:background var(--uebergang),border-color var(--uebergang)}
.theme-toggle:hover{background:var(--bg);border-color:var(--ink)}
.theme-toggle .ic{width:19px;height:19px}
.ic-sun{display:none}
html[data-theme="dark"] .ic-sun{display:inline-block}
html[data-theme="dark"] .ic-moon{display:none}

.menu{position:relative;flex-shrink:0}
.menu-btn{display:flex;align-items:center;justify-content:center;background:var(--paper);
  border:1px solid var(--line-strong);color:var(--ink);border-radius:var(--radius);
  width:38px;height:38px;transition:background var(--uebergang),border-color var(--uebergang)}
.menu-btn:hover{background:var(--bg);border-color:var(--ink)}
.menu-btn .ic{width:20px;height:20px}
.menu-panel{position:absolute;top:calc(100% + 8px);right:0;min-width:230px;background:var(--paper);
  border:1px solid var(--line-strong);border-radius:var(--radius);
  box-shadow:0 8px 28px -12px rgba(20,22,28,.25);padding:6px;display:flex;flex-direction:column;z-index:200}
.menu-panel[hidden]{display:none}
.menu-panel a{display:flex;align-items:center;gap:.6rem;padding:.6rem .7rem;border-radius:var(--radius);
  font-weight:500;font-size:.92rem;color:var(--ink)}
.menu-panel a:hover{background:var(--bg);text-decoration:none}
.menu-panel a .ic{width:18px;height:18px;color:var(--muted)}
.menu-panel a .ic-ext{margin-left:auto;width:15px;height:15px;color:var(--faint)}
.menu-sep{height:1px;background:var(--line);margin:5px 4px}


/* ── 6. Startseite ────────────────────────────────────────── */

.startseite-intro{text-align:left;padding:8px 0 28px;border-bottom:1px solid var(--line);margin-bottom:28px}
.startseite-intro .eyebrow{display:block;margin-bottom:10px}
.startseite-intro h2{font-size:clamp(1.7rem,4vw,2.3rem);color:var(--ink)}
.startseite-intro hr.goldline{display:none}
.startseite-intro p{font-size:1.02rem;color:var(--muted);margin-top:8px;max-width:60ch}

.fach-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:14px;margin-bottom:32px}

.fach-karte{
  background:var(--paper);border:1px solid var(--line);border-radius:var(--radius);
  padding:1.3rem 1.25rem;cursor:pointer;position:relative;
  transition:border-color var(--uebergang),background var(--uebergang);
}
.fach-karte::before{display:none}            /* Template-Eck-Label entfernt */
.fach-karte:hover{border-color:var(--ink)}
.fach-icon{display:flex;color:var(--ink);margin-bottom:.9rem}
.fach-icon .ic{width:26px;height:26px}
.fach-name{font-weight:700;font-size:1.12rem;color:var(--ink)}
.fach-anzahl{font-size:.85rem;color:var(--muted);margin-top:.2rem}

/* Spiel-Karte = ruhige Zeile mit Akzent-Hover */
.spiel-karte-start{
  background:var(--paper);border:1px solid var(--line);border-radius:var(--radius);
  padding:1.15rem 1.25rem;display:flex;align-items:center;gap:1.1rem;cursor:pointer;position:relative;
  transition:border-color var(--uebergang);
}
.spiel-karte-start::before{display:none}
.spiel-karte-start:hover{border-color:var(--ink)}
.spiel-icon{display:flex;color:var(--ink);flex-shrink:0}
.spiel-icon .ic{width:30px;height:30px}
.spiel-karte-start h3{font-size:1.08rem;color:var(--ink);margin-bottom:.15rem}
.spiel-karte-start p{font-size:.9rem;color:var(--muted)}


/* ── 7. Fachansicht ───────────────────────────────────────── */

.fach-header{display:flex;align-items:center;gap:.85rem;margin:8px 0 28px;padding-bottom:18px;border-bottom:1px solid var(--line)}
.fach-header-icon{display:flex;color:var(--ink)}
.fach-header-icon .ic{width:26px;height:26px}
.fach-header h2{font-size:1.6rem;color:var(--ink)!important}   /* Inline-Fachfarbe überschreiben */
.fach-header .eyebrow{margin-bottom:.15rem}
.fach-header-anzahl{font-size:.85rem;color:var(--muted);margin-top:.15rem}

.quali-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:16px}

.quali-karte{
  background:var(--paper);border:1px solid var(--line);border-radius:var(--radius);
  display:flex;flex-direction:column;overflow:hidden;
  transition:border-color var(--uebergang);
}
.quali-karte:hover{border-color:var(--line-strong)}
.quali-karte-kopf{
  padding:.85rem 1.05rem;border-bottom:1px solid var(--line);
  display:flex;align-items:center;justify-content:space-between;gap:.6rem;
  background:var(--paper)!important;     /* Inline-Pastelltöne neutralisieren */
}
.quali-karte-titel{font-weight:700;font-size:1.05rem;color:var(--ink)}
.quali-badge{
  font-size:.66rem;font-weight:600;letter-spacing:.06em;text-transform:uppercase;
  padding:.2rem .5rem;border-radius:4px;background:var(--bg);color:var(--muted);border:1px solid var(--line);
  white-space:nowrap;
}
.quali-karte-inhalt{padding:1rem 1.05rem 1.1rem;display:flex;flex-direction:column;gap:.9rem}
.quali-abschnitt-label{font-size:.72rem;font-weight:600;letter-spacing:.04em;color:var(--muted);margin-bottom:.5rem}

.btn-gruppe{display:flex;flex-wrap:wrap;gap:.5rem}
.btn-aufgabe,.btn-loesung{
  display:inline-flex;align-items:center;gap:.4rem;padding:.45rem .8rem;border-radius:var(--radius);
  font-family:inherit;font-size:.85rem;font-weight:600;text-decoration:none;transition:all var(--uebergang);
}
.btn-aufgabe .ic,.btn-loesung .ic{width:16px;height:16px}
.btn-aufgabe{background:var(--ink);color:var(--bg);border:1px solid var(--ink)}
.btn-aufgabe:hover{filter:brightness(1.15);color:var(--bg);text-decoration:none}
.btn-loesung{background:var(--paper);color:var(--ink);border:1px solid var(--line-strong)}
.btn-loesung:hover{border-color:var(--ink);text-decoration:none}
.kein-inhalt{font-size:.84rem;color:var(--faint)}


/* ── 8. Audio ─────────────────────────────────────────────── */

.audio-bereich{background:var(--bg);border:1px solid var(--line);border-radius:var(--radius);padding:.8rem .9rem}
.audio-titel{display:flex;align-items:center;gap:.4rem;font-size:.72rem;font-weight:600;color:var(--muted);margin-bottom:.55rem}
.audio-titel .ic{width:16px;height:16px}
.audio-item{display:flex;flex-direction:column;gap:.25rem;margin-bottom:.55rem}
.audio-item:last-child{margin-bottom:0}
.audio-item-label{font-size:.78rem;color:var(--muted)}
.audio-item audio{width:100%;height:34px}


/* ── 9. Spielseite (iframe, falls genutzt) ────────────────── */
#seite-spiel main{padding:0}
.spiel-frame-wrapper{width:100%;height:calc(100vh - 60px)}
.spiel-frame-wrapper iframe{width:100%;height:100%;border:none;display:block}


/* ── 10. Footer & rechtliche Seiten ───────────────────────── */

footer{background:var(--paper);border-top:1px solid var(--line);padding:1.4rem 24px;
  text-align:center;font-size:.82rem;color:var(--muted)}
footer a{color:var(--muted);margin:0 .55rem;font-weight:500}
footer a:hover{color:var(--ink)}

.recht-inhalt{background:var(--paper);border:1px solid var(--line);border-radius:var(--radius);
  padding:2.2rem 2rem;max-width:720px;margin:32px auto}
.recht-inhalt h1{font-size:1.7rem;color:var(--ink);margin-bottom:.7rem;padding-bottom:.7rem;border-bottom:1px solid var(--line)}
.recht-inhalt h2{font-size:.95rem;font-weight:700;color:var(--ink);margin:1.6rem 0 .4rem}
.recht-inhalt p{font-size:.95rem;color:var(--muted);margin-bottom:.7rem;line-height:1.7}
.recht-inhalt strong{color:var(--ink)}
.recht-inhalt address{font-style:normal;color:var(--ink);line-height:1.9}
.recht-inhalt code{font-family:ui-monospace,Menlo,Consolas,monospace;font-size:.85rem;
  background:var(--bg);border:1px solid var(--line);border-radius:4px;padding:.1rem .4rem;color:var(--ink)}


/* ── 11. Responsive ───────────────────────────────────────── */

@media (max-width:600px){
  .fach-grid{grid-template-columns:1fr 1fr}
  .quali-grid{grid-template-columns:1fr}
  .spiel-karte-start{flex-direction:column;text-align:center;align-items:flex-start}
  .header-titel span{display:none}
  .breadcrumb{font-size:.85rem;margin-left:.5rem}
}
@media (max-width:380px){
  .fach-grid{grid-template-columns:1fr}
}
