/* =============================================================================
   howtogoogle.de — Design-System
   Rekonstruiert aus dem Claude-Design-Handoff „Google richtig nutzen“.
   Fonts: Bricolage Grotesque (Display), Hanken Grotesk (Text), Space Mono (Mono)
   ============================================================================= */

:root {
  /* Akzent (per JS überschrieben) */
  --mk: #F4DF4E;

  /* Helle Flächen */
  --bg: #F6F2E9;
  --ink: #1A1813;
  --mut: #6B6557;
  --mut2: #726D5D;  /* AA: ~4.6:1 auf --bg (vorher #8A8475 = 3.3:1) */
  --mut3: #726D5D;  /* AA-konform; vorher #A89F8D = 2.4:1 */
  --line: #E7E1D2;
  --line2: #E2DCCD;
  --line3: #E0DACB;
  --line4: #ECE6D8;
  --surf: #FBF8F0;
  --surf2: #F1ECDF;
  --surf3: #EFE9DC;

  /* Dunkle Flächen */
  --dark: #17150F;
  --dark2: #221D16;
  --darkline: #2C2620;
  --darkline2: #3A3327;
  --darkfg: #F4F0E6;
  --darkmut: #A39B89;
  --darkmut2: #CFC7B5;

  --maxw: 1120px;
  --radius: 16px;
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  margin: 0;
  background: var(--bg);
  color: var(--ink);
  font-family: 'Hanken Grotesk', system-ui, sans-serif;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}
::selection { background: var(--mk); color: #1A1813; }
a { color: inherit; }
img { max-width: 100%; }

@keyframes blink { 0%,49% { opacity: 1; } 50%,100% { opacity: 0; } }
@keyframes heartbeat {
  0%, 100% { transform: scale(1); }
  15% { transform: scale(1.28); }
  30% { transform: scale(1); }
  45% { transform: scale(1.18); }
}
@keyframes wobble {
  0%, 100% { transform: rotate(-7deg); }
  50% { transform: rotate(-13deg); }
}
@keyframes spin-slow { to { transform: rotate(360deg); } }
@keyframes pop-in {
  from { opacity: 0; transform: translateY(8px) scale(.98); }
  to { opacity: 1; transform: none; }
}
@media (prefers-reduced-motion: reduce) {
  * {
    animation-duration: .001ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: .001ms !important;
    scroll-behavior: auto !important;
  }
  /* dekorative Dauer-Animationen ganz unterdrücken (kein Bewegungs-Burst beim Laden) */
  .heart, .seal, .seal:hover, .googly::after, .caret { animation: none !important; }
}

/* ---- Sichtbarer Tastatur-Fokus (WCAG 2.4.7) ----------------------------- */
:focus-visible { outline: 3px solid var(--ink); outline-offset: 2px; border-radius: 4px; }
/* auf dunklen Flächen und Primär-Buttons den Akzent als Ring nutzen */
.sidebar :focus-visible,
.section--dark :focus-visible,
.section--dark2 :focus-visible,
.btn--primary:focus-visible,
.btn--dark:focus-visible { outline-color: var(--mk); }
/* der per JS fokussierte Hauptcontainer braucht keinen sichtbaren Rahmen */
#main:focus, #main:focus-visible { outline: none; }

/* ---- Skip-Link ---------------------------------------------------------- */
.skip {
  position: fixed; top: 10px; left: 10px; z-index: 100;
  background: var(--ink); color: var(--bg); padding: 10px 16px; border-radius: 10px;
  font-family: 'Hanken Grotesk', sans-serif; font-weight: 700; font-size: 14px; text-decoration: none;
  transform: translateY(-160%); transition: transform .15s ease;
}
.skip:focus { transform: none; }

/* ---- Nur für Screenreader ----------------------------------------------- */
.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;
}

/* ---- Typo-Bausteine ----------------------------------------------------- */
.mono { font-family: 'Space Mono', monospace; }
.display { font-family: 'Bricolage Grotesque', sans-serif; }

.eyebrow {
  margin: 0;
  font-family: 'Space Mono', monospace;
  font-size: 13px;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: var(--mut);
}
.eyebrow--dark { color: var(--darkmut); }

mark, .mark {
  background: var(--mk);
  color: #1A1813;
  padding: .02em .18em;
  border-radius: 3px;
  -webkit-box-decoration-break: clone;
  box-decoration-break: clone;
}

/* ---- App-Layout --------------------------------------------------------- */
#app { min-height: 100vh; display: flex; flex-direction: column; }
.view { flex: 1 0 auto; animation: pop-in .35s ease both; }
.container {
  max-width: var(--maxw);
  margin: 0 auto;
  padding-left: clamp(20px, 5vw, 56px);
  padding-right: clamp(20px, 5vw, 56px);
}

/* =============================================================================
   HEADER (Lernseite / Test / Zertifikat)
   ============================================================================= */
.site-header {
  position: sticky; top: 0; z-index: 30;
  background: rgba(246,242,233,.82);
  backdrop-filter: saturate(150%) blur(10px);
  -webkit-backdrop-filter: saturate(150%) blur(10px);
  border-bottom: 1px solid var(--line);
}
.site-header__inner {
  max-width: var(--maxw); margin: 0 auto;
  padding: 13px clamp(20px, 5vw, 56px);
  display: flex; align-items: center; justify-content: space-between;
  gap: 16px; flex-wrap: wrap;
}
.brand {
  font-family: 'Space Mono', monospace;
  font-size: 15px; font-weight: 700; letter-spacing: -.01em;
  color: var(--ink); text-decoration: none;
}
.brand__tld { background: var(--mk); color: #1A1813; padding: 0 4px; border-radius: 3px; }
.site-nav { display: flex; gap: clamp(14px, 2.4vw, 28px); align-items: center; }
.site-nav a {
  font-family: 'Space Mono', monospace; font-size: 13px;
  color: var(--mut); text-decoration: none;
}
.site-nav a:hover { color: var(--ink); }
.site-nav a.is-active { color: var(--ink); }
.site-nav a.pill {
  color: #1A1813; background: var(--mk); padding: 3px 9px; border-radius: 20px;
}

/* =============================================================================
   SECTIONS
   ============================================================================= */
.section { }
.section--pad > .container { padding-top: clamp(60px,10vh,110px); padding-bottom: clamp(60px,10vh,110px); }
.section--dark { background: var(--dark); color: var(--darkfg); }
.section--dark2 { background: #17150F; color: #F4F0E6; }
.section--line-top { border-top: 1px solid var(--line); }

.h1 {
  font-family: 'Bricolage Grotesque', sans-serif; font-weight: 800;
  font-size: clamp(42px, 8.2vw, 94px); line-height: .95; letter-spacing: -.025em;
  margin: 16px 0 0; max-width: 15ch; text-wrap: balance;
}
.h2 {
  font-family: 'Bricolage Grotesque', sans-serif; font-weight: 800;
  font-size: clamp(30px, 5.2vw, 56px); line-height: 1.0; letter-spacing: -.02em;
  margin: 14px 0 0; max-width: 18ch;
}
.h2--w700 { font-weight: 700; }
.lead {
  max-width: 56ch; font-size: clamp(17px, 2.1vw, 21px); line-height: 1.5;
  color: var(--mut); margin: 22px 0 0;
}

/* ---- Hero --------------------------------------------------------------- */
.hero {
  background: var(--hbg, var(--bg));
  color: var(--hfg, var(--ink));
  padding-top: clamp(52px, 9vh, 104px);
  padding-bottom: clamp(52px, 9vh, 104px);
  transition: background .3s ease, color .3s ease;
}
.hero .eyebrow { color: var(--hmut, var(--mut)); }
.hero .h1 { color: var(--hfg, var(--ink)); }
.hero .lead { color: var(--hmut, var(--mut)); }

.toggle-row { display: flex; gap: 18px; flex-wrap: wrap; margin-bottom: 14px; }
.toggle-btn {
  appearance: none; background: none; border: none; cursor: pointer; padding: 0;
  display: inline-flex; flex-direction: column; align-items: flex-start; gap: 6px;
  font-family: 'Space Mono', monospace; font-size: 13px; letter-spacing: .02em;
  color: var(--hfg, var(--ink));
}
.toggle-btn__bar { align-self: stretch; height: 5px; background: var(--mk); border-radius: 3px; }
.toggle-btn[aria-pressed="false"] .toggle-btn__bar { visibility: hidden; }

.search-bar {
  display: flex; align-items: center; gap: 14px;
  background: var(--hsur, var(--surf)); border: 1.5px solid var(--hlin, var(--line2));
  border-radius: var(--radius); padding: clamp(15px,2vw,20px) clamp(16px,2.5vw,24px);
}
.search-bar__icon { flex: none; opacity: .8; }
.search-bar__text {
  font-family: 'Space Mono', monospace; font-size: clamp(16px,2.7vw,26px);
  line-height: 1.45; color: var(--hfg, var(--ink)); word-break: break-word;
}
.caret {
  display: inline-block; width: 2px; height: 1.05em;
  background: var(--hfg, var(--ink)); vertical-align: -.16em; margin-left: 3px;
  animation: blink 1.06s steps(1) infinite;
}
.hint {
  margin: 14px 2px 0; font-family: 'Space Mono', monospace; font-size: 13px;
  color: var(--hmut, var(--mut)); min-height: 1.3em;
}

/* ---- Regel-Grid --------------------------------------------------------- */
.grid-rules {
  margin-top: clamp(34px,5vh,56px); display: grid; gap: clamp(26px,3.5vw,48px);
  grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
}
.rule__n { font-family: 'Space Mono', monospace; font-size: 14px; color: var(--mk); }
.rule__h {
  font-family: 'Bricolage Grotesque', sans-serif; font-weight: 700;
  font-size: clamp(20px,2.6vw,27px); margin: 12px 0 9px; letter-spacing: -.01em;
}
.rule__p { margin: 0; color: var(--darkmut2); font-size: 16px; line-height: 1.55; max-width: 34ch; }

/* ---- Operator-Karten ---------------------------------------------------- */
.grid-ops {
  margin-top: clamp(32px,5vh,52px); display: grid; gap: 16px;
  grid-template-columns: repeat(auto-fit, minmax(268px, 1fr));
}
.op-card {
  background: var(--surf); border: 1px solid var(--line); border-radius: var(--radius);
  padding: clamp(20px,2.4vw,26px); display: flex; flex-direction: column; gap: 10px;
}
.op-card__sym {
  font-family: 'Space Mono', monospace; font-weight: 700;
  font-size: clamp(26px,3.4vw,38px); line-height: 1; color: var(--ink);
}
.op-card__h { font-family: 'Hanken Grotesk', sans-serif; font-weight: 700; font-size: 17px; margin: 0; }
.op-card__p { margin: 0; color: var(--mut); font-size: 15px; line-height: 1.5; flex: 1; }
.op-card__ex {
  background: var(--surf2); border-radius: 9px; padding: 10px 13px;
  font-family: 'Space Mono', monospace; font-size: 14.5px; color: var(--ink); word-break: break-word;
}

/* ---- Reflexe ------------------------------------------------------------ */
.grid-reflex {
  margin-top: clamp(24px,4vh,40px); display: grid; gap: 0 clamp(28px,5vw,72px);
  grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
}
.reflex { border-top: 1px solid var(--line3); padding: 20px 0; display: flex; flex-direction: column; gap: 6px; }
.reflex__label {
  font-family: 'Space Mono', monospace; font-size: 13px; letter-spacing: .04em;
  text-transform: uppercase; color: var(--ink);
}
.reflex__p { margin: 0; color: #5C5648; font-size: 16px; line-height: 1.5; max-width: 44ch; }
.kbd {
  font-family: 'Space Mono', monospace; background: var(--surf3);
  border-radius: 5px; padding: 1px 6px; font-size: .92em;
}

/* ---- Mini-Test (Landing) ------------------------------------------------ */
.quiz-list { margin-top: clamp(30px,5vh,50px); display: flex; flex-direction: column; gap: 18px; max-width: 800px; }
.quiz-card { background: var(--dark2); border: 1px solid var(--darkline2); border-radius: var(--radius); padding: clamp(18px,2.5vw,26px); }
.quiz-card__q { margin: 0 0 15px; font-size: clamp(16px,2vw,19px); font-weight: 600; color: var(--darkfg); line-height: 1.4; }
.quiz-card__opts { display: grid; gap: 10px; }
.quiz-opt {
  text-align: left; appearance: none; cursor: pointer; background: var(--dark);
  border: 1px solid var(--darkline2); border-radius: 12px; padding: 14px 16px;
  display: flex; align-items: center; justify-content: space-between; gap: 12px;
  color: var(--darkfg); font-family: 'Space Mono', monospace;
  font-size: clamp(13.5px,1.7vw,16px); line-height: 1.4; transition: border-color .15s ease, background .15s ease;
}
.quiz-opt:hover { border-color: #5A5240; }
.quiz-opt > span:first-child { word-break: break-word; }
.quiz-opt__tags { display: flex; gap: 8px; flex: none; align-items: center; }
.tag {
  font-family: 'Hanken Grotesk', sans-serif; font-size: 12px; border-radius: 20px;
  padding: 2px 9px; white-space: nowrap;
}
.tag--ghost { color: var(--darkmut); border: 1px solid var(--darkline2); }
.tag--best { color: #1A1813; background: var(--mk); font-weight: 700; }
.quiz-card__fb { margin: 15px 0 0; font-size: 15px; line-height: 1.55; color: var(--darkmut2); }
.quiz-card__fb b { color: var(--mk); }
.quiz-card__fb.is-wrong b { color: var(--darkfg); }

/* ---- Footer (Merksatz + Credit) ----------------------------------------- */
.site-footer { background: var(--bg); border-top: 1px solid var(--line3); }
.site-footer__inner { max-width: var(--maxw); margin: 0 auto; padding: clamp(48px,8vh,86px) clamp(20px,5vw,56px); }
.merk {
  font-family: 'Bricolage Grotesque', sans-serif; font-weight: 800;
  font-size: clamp(30px,6.5vw,68px); line-height: .98; letter-spacing: -.025em; margin: 14px 0 0;
}
.merk__hl { background: var(--mk); color: #1A1813; padding: 0 .12em; border-radius: 6px; -webkit-box-decoration-break: clone; box-decoration-break: clone; }
.footer-meta { margin-top: clamp(30px,5vh,52px); display: flex; justify-content: space-between; flex-wrap: wrap; gap: 14px; align-items: flex-end; }
.footer-meta__brand { font-family: 'Space Mono', monospace; font-weight: 700; font-size: 15px; color: var(--ink); }
.footer-meta__note { font-family: 'Space Mono', monospace; font-size: 12px; color: var(--mut2); max-width: 44ch; line-height: 1.5; }

.credit {
  margin-top: 26px; padding-top: 18px; border-top: 1px dashed var(--line3);
  font-family: 'Space Mono', monospace; font-size: 13px; color: var(--mut2);
  display: flex; align-items: center; gap: 7px; flex-wrap: wrap;
}
.credit b { color: var(--ink); font-weight: 700; }
.heart { color: #E5484D; display: inline-block; animation: heartbeat 1.6s ease-in-out infinite; transform-origin: center; }

/* =============================================================================
   PORTAL- / LEKTIONS-LAYOUT (Sidebar + Main)
   ============================================================================= */
.layout { display: flex; align-items: flex-start; min-height: 100vh; }
.sidebar {
  width: 250px; flex: none; align-self: stretch; position: sticky; top: 0;
  height: 100vh; background: var(--sbg, var(--dark)); color: var(--sfg, var(--darkfg));
  display: flex; flex-direction: column; padding: 24px 18px;
  border-right: 1px solid var(--sln, var(--darkline));
}
.sidebar .brand { color: var(--sfg, var(--darkfg)); padding: 0 6px; }
.side-nav { margin-top: 34px; display: flex; flex-direction: column; gap: 4px; }
.side-nav a, .side-nav button {
  display: flex; align-items: center; gap: 10px; padding: 10px 12px; border-radius: 10px;
  text-decoration: none; font-size: 14.5px; font-weight: 600;
  color: var(--smut, var(--darkmut)); background: none; border: none; cursor: pointer;
  font-family: inherit; text-align: left; width: 100%; transition: background .15s ease, color .15s ease;
}
.side-nav a:hover, .side-nav button:hover { background: var(--sln, var(--darkline)); color: var(--sfg, var(--darkfg)); }
.side-nav a.is-active { font-weight: 700; color: #1A1813; background: var(--mk); }
.side-nav a.is-active:hover { color: #1A1813; }

.side-progress { margin-top: 24px; padding: 14px; border-radius: 12px; border: 1px solid var(--sln, var(--darkline)); }
.side-progress__row { display: flex; justify-content: space-between; align-items: baseline; font-family: 'Space Mono', monospace; font-size: 12px; color: var(--smut, var(--darkmut)); }
.side-progress__row b { color: var(--mk); font-weight: 700; }
.bar { margin-top: 9px; height: 8px; border-radius: 99px; background: var(--sln, var(--darkline)); overflow: hidden; }
.bar__fill { height: 100%; border-radius: inherit; background: var(--mk); transition: width .5s ease; }

.side-user { margin-top: auto; display: flex; align-items: center; gap: 11px; padding: 6px 6px 0; }
.avatar {
  width: 38px; height: 38px; flex: none; border-radius: 50%; background: var(--mk); color: #1A1813;
  display: flex; align-items: center; justify-content: center; font-family: 'Space Mono', monospace; font-weight: 700; font-size: 14px;
}
.side-user__name { font-weight: 600; font-size: 14px; color: var(--sfg, var(--darkfg)); }
.side-user__sub { font-size: 12px; color: var(--smut, var(--darkmut)); }

.side-back { margin-top: auto; font-family: 'Space Mono', monospace; font-size: 13px; color: var(--darkmut); text-decoration: none; padding: 8px 6px 0; }
.side-back:hover { color: var(--darkfg); }
.side-foot { margin-top: auto; display: flex; flex-direction: column; gap: 2px; padding-top: 10px; border-top: 1px solid var(--sln, var(--darkline)); }
.side-foot .side-back { margin-top: 0; padding: 6px 6px; }
.side-module { margin-top: 28px; padding: 0 6px; }
.side-module__eyebrow { font-family: 'Space Mono', monospace; font-size: 12px; letter-spacing: .1em; text-transform: uppercase; color: var(--darkmut); }
.side-module__title { font-family: 'Bricolage Grotesque', sans-serif; font-weight: 700; font-size: 19px; letter-spacing: -.01em; margin-top: 5px; line-height: 1.15; }

.lesson-nav { margin-top: 20px; display: flex; flex-direction: column; gap: 2px; overflow: auto; }
.lesson-nav button {
  width: 100%; text-align: left; display: flex; align-items: center; gap: 11px;
  padding: 9px 10px; border-radius: 9px; border: none; cursor: pointer;
  font-family: 'Hanken Grotesk', sans-serif; font-size: 14px; background: transparent; color: #9A9483;
}
.lesson-nav button.is-active { background: var(--dark2); color: var(--darkfg); }
.lesson-nav button.is-done { color: #C7C0B0; }
.lesson-nav__dot { width: 21px; height: 21px; flex: none; border-radius: 50%; display: flex; align-items: center; justify-content: center; font-size: 12px; font-weight: 700; }
.lesson-nav__dot--done { background: var(--mk); color: #1A1813; }
.lesson-nav__dot--active { border: 2px solid var(--mk); }
.lesson-nav__dot--open { border: 2px solid #4A4636; }
.lesson-nav__label { white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.lesson-nav__num { font-family: 'Space Mono', monospace; font-size: 12px; opacity: .7; }

.main { flex: 1; min-width: 0; padding: clamp(24px,4vw,52px) clamp(20px,4vw,52px); }
.main--lesson { padding: clamp(28px,5vw,72px) clamp(22px,5vw,72px); }
.main__inner { max-width: 1040px; margin: 0 auto; }
.main__inner--narrow { max-width: 720px; }

/* ---- Portal-Dashboard --------------------------------------------------- */
.portal-head { margin-bottom: clamp(24px,4vh,40px); }
.portal-head .eyebrow { color: var(--mut2); }
.portal-head h1 { font-family: 'Bricolage Grotesque', sans-serif; font-weight: 800; font-size: clamp(30px,4.5vw,52px); line-height: 1.0; letter-spacing: -.025em; margin: 12px 0 0; }
.portal-head p { margin: 10px 0 0; font-size: clamp(16px,2vw,19px); color: var(--mut); }

.name-form { display: flex; gap: 10px; flex-wrap: wrap; margin: 16px 0 0; }
.name-input {
  font-family: 'Hanken Grotesk', sans-serif; font-size: 15px; padding: 11px 15px;
  border: 1.5px solid var(--line2); border-radius: 11px; background: var(--surf); color: var(--ink);
  min-width: 220px;
}
.name-input:focus { border-color: var(--ink); }

.cards-top { display: flex; gap: 18px; flex-wrap: wrap; margin-bottom: clamp(28px,4vh,44px); }
.card-continue {
  flex: 2 1 360px; background: var(--dark); color: var(--darkfg); border-radius: 18px;
  padding: clamp(22px,3vw,32px); display: flex; flex-direction: column; gap: 14px; min-height: 210px;
}
.card-continue__eyebrow { font-family: 'Space Mono', monospace; font-size: 13px; letter-spacing: .12em; text-transform: uppercase; color: var(--mk); }
.card-continue__mod { font-family: 'Space Mono', monospace; font-size: 13px; color: var(--darkmut); }
.card-continue h2 { font-family: 'Bricolage Grotesque', sans-serif; font-weight: 800; font-size: clamp(24px,3.2vw,40px); line-height: 1.04; letter-spacing: -.02em; margin: 7px 0 0; }
.card-continue p { color: var(--darkmut2); margin: 11px 0 0; max-width: 44ch; line-height: 1.5; font-size: 15.5px; }

.card-progress {
  flex: 1 1 230px; background: var(--surf); border: 1px solid var(--line); border-radius: 18px;
  padding: clamp(22px,3vw,30px); display: flex; flex-direction: column; gap: 15px;
}
.card-progress__eyebrow { font-family: 'Space Mono', monospace; font-size: 13px; letter-spacing: .12em; text-transform: uppercase; color: var(--mut2); }
.card-progress__big { display: flex; align-items: baseline; gap: 6px; }
.card-progress__num { font-family: 'Bricolage Grotesque', sans-serif; font-weight: 800; font-size: clamp(46px,6vw,72px); line-height: .9; letter-spacing: -.03em; }
.card-progress__pct { font-family: 'Bricolage Grotesque', sans-serif; font-weight: 700; font-size: 24px; color: var(--mut2); }
.card-progress .bar { background: #ECE6D8; height: 10px; }
.card-progress__sub { font-family: 'Space Mono', monospace; font-size: 12.5px; color: var(--mut2); }

.section-title { font-family: 'Bricolage Grotesque', sans-serif; font-weight: 700; font-size: clamp(20px,2.6vw,26px); letter-spacing: -.01em; margin: 0 0 16px; }

.grid-modules { display: grid; gap: 16px; grid-template-columns: repeat(auto-fit, minmax(290px, 1fr)); }
.module-card { background: var(--surf); border: 1px solid var(--line); border-radius: var(--radius); padding: 22px; display: flex; flex-direction: column; gap: 14px; }
.module-card__top { display: flex; align-items: center; justify-content: space-between; gap: 12px; }
.module-card__n { font-family: 'Space Mono', monospace; font-size: 12.5px; color: var(--mut2); }
.badge { font-family: 'Hanken Grotesk', sans-serif; font-size: 12px; border-radius: 20px; padding: 3px 11px; white-space: nowrap; }
.badge--done { background: var(--mk); color: #1A1813; font-weight: 700; }
.badge--open { border: 1px solid #CFC8B6; color: var(--mut); }
.badge--locked { background: #ECE6D8; color: var(--mut); }
.module-card__body { display: flex; gap: 13px; align-items: flex-start; }
.check-toggle { width: 30px; height: 30px; border-radius: 50%; flex: none; display: flex; align-items: center; justify-content: center; cursor: pointer; padding: 0; font-size: 15px; font-weight: 700; }
.check-toggle--done { background: var(--mk); border: none; color: #1A1813; }
.check-toggle--open { background: none; border: 2px solid #CFC8B6; }
.check-toggle--locked { background: none; border: 2px dashed #CFC8B6; cursor: default; }
.module-card__h { font-family: 'Bricolage Grotesque', sans-serif; font-weight: 700; font-size: 19px; letter-spacing: -.01em; margin: 1px 0 0; line-height: 1.15; }
.module-card__desc { margin: 7px 0 0; color: var(--mut); font-size: 14.5px; line-height: 1.5; }
.module-card__foot { margin-top: auto; display: flex; align-items: center; justify-content: space-between; gap: 10px; padding-top: 6px; }
.module-card__meta { font-family: 'Space Mono', monospace; font-size: 12.5px; color: var(--mut2); }
.module-card__locknote { font-family: 'Space Mono', monospace; font-size: 12px; color: var(--mut3); }

/* ---- Buttons ------------------------------------------------------------ */
.btn {
  font-family: 'Hanken Grotesk', sans-serif; font-weight: 600; font-size: 14px;
  border-radius: 10px; cursor: pointer; text-decoration: none; display: inline-flex;
  align-items: center; justify-content: center; gap: 7px; border: 1px solid transparent;
  padding: 10px 16px; transition: transform .12s ease, background .15s ease, border-color .15s ease, color .15s ease;
  white-space: nowrap;
}
.btn:active { transform: translateY(1px); }
.btn--primary { background: var(--mk); color: #1A1813; font-weight: 700; border: none; }
.btn--dark { background: var(--ink); color: var(--bg); border: none; }
.btn--dark:hover { background: #322d24; }
.btn--ghost { background: none; border: 1px solid #D6CFBE; color: #3A352B; }
.btn--ghost:hover { border-color: var(--ink); color: var(--ink); }
.btn--lg { padding: 12px 22px; font-size: 15px; border-radius: 11px; }
.btn--block { width: 100%; }
.module-card__cta { background: var(--ink); color: var(--bg); text-decoration: none; font-weight: 600; font-size: 14px; padding: 9px 16px; border-radius: 10px; white-space: nowrap; }

/* =============================================================================
   LEKTION (Detailseite)
   ============================================================================= */
.crumbs { font-family: 'Space Mono', monospace; font-size: 12.5px; color: var(--mut2); margin-bottom: 20px; }
.crumbs a { color: var(--mut2); text-decoration: none; }
.crumbs a:hover { color: var(--ink); }
.crumbs .sep { color: #C9C2B1; }
.crumbs .cur { color: var(--ink); }

.lesson-eyebrow { margin: 0; font-family: 'Space Mono', monospace; font-size: 13px; letter-spacing: .13em; text-transform: uppercase; color: var(--mut2); }
.lesson-h1 { font-family: 'Bricolage Grotesque', sans-serif; font-weight: 800; font-size: clamp(32px,5vw,56px); line-height: 1.0; letter-spacing: -.025em; margin: 12px 0 0; }
.lesson-intro { color: #5C5648; font-size: clamp(16px,2vw,19px); line-height: 1.6; margin: 20px 0 0; max-width: 60ch; }
.lesson-label { margin: clamp(28px,4vw,40px) 0 12px; font-family: 'Space Mono', monospace; font-size: 13px; letter-spacing: .06em; text-transform: uppercase; color: var(--mut2); }
.lesson-how { color: #5C5648; font-size: 16px; line-height: 1.65; margin: 22px 0 0; max-width: 60ch; }

.lesson-search {
  display: flex; align-items: center; gap: 14px; background: var(--surf); flex-wrap: wrap;
  border: 1.5px solid var(--line2); border-radius: var(--radius); padding: clamp(15px,2vw,20px) clamp(16px,2.5vw,24px);
}
.lesson-search__text { flex: 1 1 200px; min-width: 0; font-family: 'Space Mono', monospace; font-size: clamp(16px,2.7vw,24px); line-height: 1.45; color: var(--ink); word-break: break-word; }
.lesson-search__text mark { padding: .04em .22em; } /* großes Mono-Feld: Original-Padding aus Lektion.dc.html */
.lesson-search__go {
  flex: none; margin-left: auto; cursor: pointer; white-space: nowrap;
  font-family: 'Hanken Grotesk', sans-serif; font-weight: 700; font-size: 14px;
  background: var(--mk); color: #1A1813; border: none; border-radius: 10px; padding: 10px 16px;
  transition: filter .15s ease, opacity .15s ease;
}
.lesson-search__go:hover { filter: brightness(.95); }
.lesson-search__go:disabled { background: var(--surf2); color: var(--mut); cursor: default; }

.results--reveal { animation: pop-in .4s ease both; }
.results-hint {
  margin: 18px 0 0; font-family: 'Space Mono', monospace; font-size: 13.5px; line-height: 1.5; color: var(--mut2);
}
.results-hint b { color: var(--ink); font-weight: 700; }

.results { background: var(--surf); border: 1px solid var(--line); border-radius: var(--radius); padding: 4px 22px; }
.result { display: flex; gap: 13px; padding: 16px 0; border-top: 1px solid var(--line4); align-items: flex-start; }
.result:first-child { border-top: none; }
.result__dot { margin-top: 6px; width: 9px; height: 9px; border-radius: 50%; flex: none; }
.result__dot--ok { background: var(--mk); }
.result__dot--no { border: 1.5px solid #CFC8B6; }
.result__main { min-width: 0; flex: 1; }
.result__title { font-weight: 600; font-size: 15.5px; color: var(--ink); line-height: 1.3; }
.result__title--no { color: var(--mut3); text-decoration: line-through; }
.result__url { font-family: 'Space Mono', monospace; font-size: 12.5px; color: var(--mut2); margin-top: 4px; }
.result__flag { font-family: 'Space Mono', monospace; font-size: 11px; color: var(--mut3); border: 1px solid var(--line3); border-radius: 20px; padding: 2px 9px; white-space: nowrap; align-self: center; }

.points { list-style: none; padding: 0; margin: 18px 0 0; display: flex; flex-direction: column; gap: 12px; }
.points li { display: flex; gap: 12px; align-items: flex-start; color: #3A352B; font-size: 16px; line-height: 1.55; max-width: 62ch; }
.points li::before { content: ""; margin-top: 8px; width: 9px; height: 9px; border-radius: 50%; background: var(--mk); flex: none; }

.tip { margin-top: 26px; background: var(--surf); border: 1px solid var(--line); border-radius: 14px; padding: 18px 20px; display: flex; flex-direction: column; gap: 9px; }
.tip__label { align-self: flex-start; font-family: 'Space Mono', monospace; font-size: 11.5px; letter-spacing: .08em; text-transform: uppercase; background: var(--mk); color: #1A1813; padding: 3px 9px; border-radius: 5px; font-weight: 700; }
.tip p { margin: 0; color: #3A352B; font-size: 15.5px; line-height: 1.6; }

.lesson-foot { margin-top: 40px; border-top: 1px solid var(--line3); padding-top: 22px; display: flex; align-items: center; justify-content: space-between; gap: 14px; flex-wrap: wrap; }
.lesson-foot__count { font-family: 'Space Mono', monospace; font-size: 12.5px; color: var(--mut2); }
.lesson-foot__actions { display: flex; gap: 10px; }

.module-done {
  margin-top: 22px; background: var(--dark); color: var(--darkfg); border-radius: var(--radius);
  padding: 20px 24px; display: flex; align-items: center; justify-content: space-between; gap: 16px; flex-wrap: wrap;
}
.module-done__h { font-family: 'Bricolage Grotesque', sans-serif; font-weight: 700; font-size: 20px; }
.module-done__sub { color: var(--darkmut2); font-size: 14px; margin-top: 3px; }

/* =============================================================================
   ABSCHLUSSTEST
   ============================================================================= */
.test-intro { color: var(--darkmut2); font-size: clamp(16px,2vw,19px); margin: 16px 0 0; max-width: 60ch; line-height: 1.5; }
.test-list { margin-top: clamp(30px,5vh,50px); display: flex; flex-direction: column; gap: 18px; max-width: 820px; }
.test-card { background: var(--dark2); border: 1px solid var(--darkline2); border-radius: var(--radius); padding: clamp(18px,2.5vw,26px); }
.test-card__n { font-family: 'Space Mono', monospace; font-size: 12px; color: var(--darkmut); }
.test-card__q { margin: 6px 0 15px; font-size: clamp(16px,2vw,19px); font-weight: 600; color: var(--darkfg); line-height: 1.4; }
.test-opt {
  width: 100%; text-align: left; appearance: none; cursor: pointer; background: var(--dark);
  border: 1px solid var(--darkline2); border-radius: 12px; padding: 14px 16px; margin-top: 10px;
  display: flex; align-items: center; gap: 12px; color: var(--darkfg); font-family: 'Space Mono', monospace;
  font-size: clamp(13.5px,1.7vw,16px); line-height: 1.4; transition: border-color .15s ease, background .15s ease;
}
.test-opt:first-of-type { margin-top: 0; }
.test-opt:hover { border-color: #5A5240; }
.test-opt.is-picked { border-color: var(--mk); background: #2A241B; }
.test-opt.is-correct { border-color: var(--mk); background: rgba(244,223,78,.12); }
.test-opt.is-wrong { border-color: #B4503F; background: rgba(180,80,63,.12); }
.test-opt__radio { width: 18px; height: 18px; flex: none; border-radius: 50%; border: 2px solid var(--darkline2); display: flex; align-items: center; justify-content: center; }
.test-opt.is-picked .test-opt__radio { border-color: var(--mk); }
.test-opt.is-picked .test-opt__radio::after { content: ""; width: 8px; height: 8px; border-radius: 50%; background: var(--mk); }
.test-opt.is-correct .test-opt__radio { border-color: var(--mk); background: var(--mk); }
.test-opt.is-correct .test-opt__radio::after { content: "✓"; color: #1A1813; font-size: 11px; }
.test-opt__mark { margin-left: auto; flex: none; font-family: 'Hanken Grotesk', sans-serif; font-size: 12px; padding: 2px 9px; border-radius: 20px; white-space: nowrap; }
.test-opt__mark--ok { background: var(--mk); color: #1A1813; font-weight: 700; }
.test-card__fb { margin: 14px 0 0; font-size: 14.5px; line-height: 1.55; color: var(--darkmut2); }
.test-card__fb b { color: var(--mk); }

.test-actions { margin-top: 26px; display: flex; align-items: center; gap: 14px; flex-wrap: wrap; max-width: 820px; }
.test-progress { font-family: 'Space Mono', monospace; font-size: 13px; color: var(--darkmut); }

.test-result {
  margin-top: clamp(30px,5vh,50px); max-width: 820px; background: var(--dark2);
  border: 1px solid var(--darkline2); border-radius: 18px; padding: clamp(24px,3vw,34px); animation: pop-in .4s ease both;
}
.test-result__score { font-family: 'Bricolage Grotesque', sans-serif; font-weight: 800; font-size: clamp(48px,8vw,84px); line-height: .9; letter-spacing: -.03em; }
.test-result__score b { color: var(--mk); }
.test-result__verdict { font-size: clamp(17px,2.2vw,22px); margin: 14px 0 0; color: var(--darkfg); }
.test-result__sub { color: var(--darkmut2); margin: 8px 0 0; line-height: 1.5; max-width: 52ch; }
.test-result__actions { margin-top: 24px; display: flex; gap: 12px; flex-wrap: wrap; }

/* =============================================================================
   ZERTIFIKAT (goofy)
   ============================================================================= */
.cert-page { min-height: 100vh; display: flex; flex-direction: column; align-items: center; padding: clamp(28px,5vw,64px) clamp(18px,4vw,40px); }
.cert-wrap { width: 100%; max-width: 740px; }

.cert {
  background: var(--surf); border: 1px solid var(--line2); border-radius: 18px;
  box-shadow: 0 30px 70px -40px rgba(26,24,19,.35); overflow: hidden; position: relative;
}
.cert__inner { margin: clamp(12px,1.6vw,16px); border: 1px solid var(--line2); border-radius: 11px; padding: clamp(26px,4.5vw,52px); position: relative; }

/* „Vorschau"-Wasserzeichen — nur im Vorschau-Modus über das Zertifikat gelegt */
.cert__watermark {
  position: absolute; inset: 0; z-index: 6; pointer-events: none; user-select: none;
  display: flex; align-items: center; justify-content: center; overflow: hidden;
  font-family: 'Bricolage Grotesque', sans-serif; font-weight: 800;
  font-size: clamp(48px, 12vw, 124px); letter-spacing: .06em; text-transform: uppercase;
  color: rgba(26,24,19,.09); transform: rotate(-22deg); white-space: nowrap;
}
.cert__top { display: flex; align-items: center; justify-content: space-between; gap: 12px; flex-wrap: wrap; }
.cert__brand { font-family: 'Space Mono', monospace; font-size: 15px; font-weight: 700; letter-spacing: -.01em; }
.cert__nr { font-family: 'Space Mono', monospace; font-size: 12px; color: var(--mut2); letter-spacing: .05em; }
.cert__kicker { margin: 0; font-family: 'Space Mono', monospace; font-size: 13px; letter-spacing: .2em; text-transform: uppercase; color: var(--mut2); }
.cert__title { font-family: 'Bricolage Grotesque', sans-serif; font-weight: 800; font-size: clamp(40px,7.5vw,74px); line-height: .92; letter-spacing: -.03em; margin: 12px 0 0; }
.cert__lede { color: var(--mut); font-size: 15px; line-height: 1.6; margin: clamp(26px,4vw,40px) 0 0; }
.cert__name-wrap { margin: 10px 0 0; }
.cert__name {
  font-family: 'Bricolage Grotesque', sans-serif; font-weight: 800; font-size: clamp(28px,4.8vw,46px);
  letter-spacing: -.02em; line-height: 1.1; display: inline-block;
  background: var(--mk); color: #1A1813; padding: .04em .2em; border-radius: 5px;
  -webkit-box-decoration-break: clone; box-decoration-break: clone;
  border: none; outline: none; min-width: 4ch;
}
.cert__name:focus { box-shadow: 0 0 0 3px rgba(26,24,19,.18); }
.cert__name-hint { display: block; margin-top: 8px; font-family: 'Space Mono', monospace; font-size: 11px; color: var(--mut3); }
.cert__role { margin: 16px 0 0; font-family: 'Bricolage Grotesque', sans-serif; font-weight: 700; font-size: clamp(18px,2.4vw,24px); color: var(--ink); }
.cert__blurb { color: #3A352B; font-size: clamp(16px,2vw,18px); line-height: 1.6; margin: 10px 0 0; max-width: 54ch; }
.cert__roll { display: inline-flex; align-items: center; gap: 8px; cursor: pointer; background: none; border: 1px dashed #C9C2B1; border-radius: 20px; padding: 4px 11px; font-family: 'Space Mono', monospace; font-size: 11.5px; color: var(--mut); margin-top: 12px; }
.cert__roll:hover { border-color: var(--ink); color: var(--ink); }

.cert__stats { margin-top: clamp(26px,4vw,40px); display: flex; flex-wrap: wrap; gap: 14px 40px; border-top: 1px solid var(--line4); border-bottom: 1px solid var(--line4); padding: 20px 0; }
.cert__stat { display: flex; flex-direction: column; gap: 4px; }
.cert__stat-k { font-family: 'Space Mono', monospace; font-size: 11.5px; letter-spacing: .1em; text-transform: uppercase; color: var(--mut2); }
.cert__stat-v { font-family: 'Bricolage Grotesque', sans-serif; font-weight: 700; font-size: 24px; }

.cert__goofy-eyebrow { margin: 22px 0 0; color: var(--mut2); font-size: 10px; letter-spacing: .18em; }
.cert__goofy { margin-top: 8px; display: flex; flex-wrap: wrap; gap: 10px 28px; }
.cert__goofy .cert__stat-v { font-size: 20px; color: var(--mut); }

.cert__modules { margin-top: 24px; display: grid; grid-template-columns: repeat(auto-fit, minmax(240px,1fr)); gap: 10px 24px; }
.cert__mod { display: flex; gap: 10px; align-items: center; }
.cert__mod-tick { width: 20px; height: 20px; flex: none; border-radius: 50%; background: var(--mk); color: #1A1813; display: flex; align-items: center; justify-content: center; font-size: 11px; font-weight: 700; }
.cert__mod-txt { font-size: 14.5px; color: #3A352B; }
.cert__mod-n { font-family: 'Space Mono', monospace; color: var(--mut2); }

.cert__sign { margin-top: clamp(26px,4vw,40px); display: flex; align-items: flex-end; justify-content: space-between; gap: 24px; flex-wrap: wrap; }
.cert__sign-line { font-family: 'Bricolage Grotesque', sans-serif; font-size: 22px; color: var(--ink); border-bottom: 1px solid #C9C2B1; padding-bottom: 6px; min-width: 180px; }
.cert__sign-sub { font-family: 'Space Mono', monospace; font-size: 12px; color: var(--mut2); margin-top: 8px; }

/* Handschriftliche „Unterschrift“ von Dave */
.cert__signature {
  font-family: 'Caveat', cursive; font-weight: 700;
  font-size: clamp(38px, 6vw, 52px); line-height: 1; color: var(--ink);
  border-bottom: 1px solid #C9C2B1; padding: 0 14px 2px; min-width: 180px;
  display: inline-block; transform: rotate(-3deg); transform-origin: left bottom;
}

/* Augenzwinkernder „INOFFIZIELL“-Stempel */
.cert__stamp {
  position: absolute; top: clamp(64px, 13vw, 104px); right: clamp(16px, 4vw, 40px);
  transform: rotate(-13deg); pointer-events: none; user-select: none;
  border: 2.5px solid #C0392B; color: #C0392B; border-radius: 10px;
  padding: 5px 12px 4px; text-align: center; opacity: .8; background: rgba(251,248,240,.35);
}
.cert__stamp-main { font-family: 'Space Mono', monospace; font-weight: 700; font-size: clamp(15px,2.4vw,20px); letter-spacing: .16em; }
.cert__stamp-sub { font-family: 'Space Mono', monospace; font-size: 8.5px; letter-spacing: .1em; margin-top: 2px; }

/* Disclaimer: inoffiziell & nicht aussagekräftig */
.cert__disclaimer {
  margin: clamp(20px,3vw,28px) 0 0; padding-top: 16px; border-top: 1px dashed var(--line4);
  font-family: 'Space Mono', monospace; font-size: 11.5px; line-height: 1.6; color: var(--mut2);
}

/* Goofy seal: googly eyes + wobble */
.seal {
  width: 104px; height: 104px; flex: none; border-radius: 50%;
  border: 2px solid var(--mk); display: flex; flex-direction: column; align-items: center; justify-content: center;
  gap: 2px; text-align: center; background: var(--surf); position: relative;
  animation: wobble 4s ease-in-out infinite; transform-origin: center;
}
.seal:hover { animation: spin-slow 1.4s linear infinite; }
.seal__ring { position: absolute; inset: 6px; border-radius: 50%; border: 1.5px dashed rgba(26,24,19,.25); }
.seal__check { font-size: 20px; line-height: 1; color: var(--ink); }
.seal__t1 { font-family: 'Space Mono', monospace; font-size: 9px; letter-spacing: .2em; font-weight: 700; color: var(--ink); }
.seal__t2 { font-family: 'Space Mono', monospace; font-size: 7.5px; letter-spacing: .06em; color: var(--mut2); }
.seal__eyes { display: flex; gap: 9px; margin-bottom: 1px; }
.googly { width: 15px; height: 15px; border-radius: 50%; background: #fff; border: 1.5px solid var(--ink); position: relative; overflow: hidden; }
.googly::after { content: ""; position: absolute; width: 6px; height: 6px; border-radius: 50%; background: var(--ink); left: 50%; top: 60%; transform: translate(-50%, -50%); animation: googly-roll 3.5s ease-in-out infinite; }
@keyframes googly-roll {
  0%,100% { left: 40%; top: 65%; }
  25% { left: 65%; top: 45%; }
  50% { left: 55%; top: 70%; }
  75% { left: 35%; top: 50%; }
}

.cert-actions { margin-top: 18px; display: flex; gap: 10px; flex-wrap: wrap; align-items: center; }
.cert-actions a.back { font-family: 'Space Mono', monospace; font-size: 13px; color: var(--mut2); text-decoration: none; margin-left: 6px; }
.cert-actions a.back:hover { color: var(--ink); }
.cert-toast { font-family: 'Space Mono', monospace; font-size: 12.5px; color: var(--mut); margin-left: 4px; opacity: 0; transition: opacity .2s ease; }
.cert-toast.show { opacity: 1; }

/* Locked certificate state */
.cert-locked { background: var(--surf); border: 1px solid var(--line2); border-radius: 18px; padding: clamp(30px,5vw,56px); text-align: center; }
.cert-locked__h { font-family: 'Bricolage Grotesque', sans-serif; font-weight: 800; font-size: clamp(26px,4vw,40px); letter-spacing: -.02em; margin: 8px 0 0; }
.cert-locked__p { color: var(--mut); font-size: 16px; line-height: 1.6; margin: 12px auto 0; max-width: 46ch; }
.cert-locked__actions { margin-top: 24px; display: flex; gap: 12px; justify-content: center; flex-wrap: wrap; }

/* Confetti canvas */
#confetti { position: fixed; inset: 0; width: 100%; height: 100%; pointer-events: none; z-index: 60; }

/* =============================================================================
   RESPONSIVE — Sidebar wird zur Topbar
   ============================================================================= */
@media (max-width: 760px) {
  .layout { flex-direction: column; }
  .sidebar {
    width: 100%; height: auto; position: static; flex-direction: row; flex-wrap: wrap;
    align-items: center; gap: 10px 16px; padding: 14px clamp(16px,4vw,24px);
    border-right: none; border-bottom: 1px solid var(--sln, var(--darkline));
  }
  .sidebar .brand { padding: 0; }
  .side-nav { margin-top: 0; flex-direction: row; flex-wrap: wrap; gap: 6px; }
  .side-nav a, .side-nav button { padding: 7px 11px; font-size: 13px; width: auto; }
  .side-progress { margin-top: 0; flex: 1 1 160px; padding: 8px 12px; }
  .side-user, .side-back { display: none; }
  /* Modulkontext sichtbar lassen, Lektionsnavigation horizontal scrollbar */
  .side-module { margin-top: 0; flex: 1 1 100%; padding: 0; }
  .side-module__title { font-size: 16px; }
  .lesson-nav { margin-top: 0; flex-direction: row; flex-wrap: nowrap; overflow-x: auto; gap: 6px; width: 100%; padding-bottom: 4px; -webkit-overflow-scrolling: touch; }
  .lesson-nav button { width: auto; flex: none; }
  .main { padding: clamp(20px,5vw,28px) clamp(16px,5vw,24px); width: 100%; }
}

/* =============================================================================
   PRINT — nur das Zertifikat, einseitig, im vollen Farb-Design der Seite
   ============================================================================= */
@media print {
  @page { size: A4 portrait; margin: 0; }   /* kein weißer Papierrand */

  /* Hintergründe & Akzentfarben WIRKLICH drucken (Browser unterdrücken das sonst) */
  *, *::before, *::after { -webkit-print-color-adjust: exact !important; print-color-adjust: exact !important; }
  html, body { background: var(--bg) !important; margin: 0 !important; }

  /* alles außer dem Zertifikat ausblenden */
  .skip, .site-header, .site-footer, .cert-actions, #confetti,
  .cert__name-hint, .cert__roll, .cert-wrap .credit { display: none !important; }

  .view { animation: none !important; }
  .cert-page { padding: 0 !important; min-height: 0 !important; display: block !important; }
  .cert-wrap { max-width: 100% !important; width: 100% !important; margin: 0 !important; }

  /* Karte füllt die GANZE Seite: cremefarbener Rand außen, surf-Karte mit Rahmen,
     Inhalt vertikal zentriert → keine weißen Ränder oben/unten. */
  .cert {
    box-shadow: none !important; border: none !important; border-radius: 0 !important;
    margin: 0 !important; background: var(--bg) !important; overflow: visible !important;
    min-height: 100vh; display: flex; flex-direction: column;
  }
  .cert__inner {
    flex: 1 1 auto; margin: 6mm !important;
    border: 1.5px solid var(--line2) !important; border-radius: 12px;
    background: var(--surf) !important;
    display: flex; flex-direction: column; justify-content: center;
    padding: 7mm 9mm !important; break-inside: avoid;
  }

  /* kompakte Typo, damit der zentrierte Inhalt sicher auf eine Seite passt */
  .cert__title { font-size: 46px !important; }
  .cert__name { font-size: 32px !important; }
  .cert__lede { margin-top: 14px !important; }
  .cert__role { margin-top: 12px !important; }
  .cert__blurb { margin-top: 8px !important; }
  .cert__stats { margin-top: 14px !important; padding: 12px 0 !important; }
  .cert__goofy-eyebrow { margin-top: 12px !important; }
  .cert__goofy { margin-top: 6px !important; }
  .cert__modules { margin-top: 12px !important; }
  .cert__sign { margin-top: 14px !important; }
  .cert__disclaimer { margin-top: 12px !important; padding-top: 10px !important; }
  .cert__signature { font-size: 38px !important; }

  /* Animationen einfrieren (sonst zufälliger Frame im Druck) */
  .seal, .seal:hover, .googly::after, .heart, .caret { animation: none !important; }
}
