/* ============================================================
   DeutschDino — style.css
   Kosmisch-dunkles Premium-Design · Mobile-first · erwachsen
   Alle Markenfarben als CSS-Variablen in :root
   ============================================================ */

:root{
  /* --- Farbpalette (exakt laut Branding) --- */
  --bg:      #0a0a1f;   /* Weltraum-Dunkel */
  --text:    #e0d4ff;   /* Text hell */
  --muted:   #a89ed4;   /* gedämpfter Text */
  --der:     #6ab2ff;   /* der  = Blau */
  --die:     #ff6abf;   /* die  = Magenta */
  --das:     #6ad26a;   /* das  = Grün */
  --purple:  #aa6aff;   /* Cosmic-Lila (Akzent/Glow) */
  --teal:    #4ad2c4;   /* Türkis */
  --gold:    #ffd66a;   /* Gold */

  /* --- Flächen / Panels --- */
  --panel:        rgba(21, 19, 50, .55);
  --panel-border: rgba(170, 106, 255, .22);
  --radius:       22px;

  --font: 'Nunito', system-ui, -apple-system, 'Segoe UI', sans-serif;
}

/* ---------- Basis / Reset ---------- */
*, *::before, *::after{ box-sizing:border-box; }
*{ margin:0; }

html{ background:var(--bg); }
@media (prefers-reduced-motion: no-preference){
  html{ scroll-behavior:smooth; }
}

body{
  font-family:var(--font);
  color:var(--text);
  line-height:1.6;
  overflow-x:clip;
  -webkit-font-smoothing:antialiased;
}

img, svg{ display:block; max-width:100%; }
a{ color:inherit; }
::selection{ background:rgba(170,106,255,.45); }

:focus-visible{
  outline:2px solid var(--teal);
  outline-offset:3px;
  border-radius:4px;
}

/* Screenreader-only */
.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;
}

.skip-link{
  position:absolute; left:1rem; top:-4rem; z-index:100;
  background:var(--purple); color:#fff; font-weight:700;
  padding:.6em 1.2em; border-radius:999px;
  transition:top .2s;
}
.skip-link:focus{ top:1rem; }

/* ---------- Kosmischer Hintergrund ---------- */
#stars{
  position:fixed; inset:0;
  width:100%; height:100%;
  z-index:-2;
  pointer-events:none;
}

/* Nebel-Schwaden (weich, statisch, sehr dezent) */
.glow{
  position:fixed;
  border-radius:50%;
  z-index:-1;
  pointer-events:none;
}
.g1{ /* Lila, oben links */
  width:70vmax; height:70vmax; top:-25vmax; left:-20vmax;
  background:radial-gradient(closest-side, rgba(170,106,255,.16), transparent 70%);
}
.g2{ /* Türkis, rechts Mitte */
  width:60vmax; height:60vmax; top:20vh; right:-28vmax;
  background:radial-gradient(closest-side, rgba(74,210,196,.10), transparent 70%);
}
.g3{ /* Magenta, unten links */
  width:55vmax; height:55vmax; bottom:-20vmax; left:-15vmax;
  background:radial-gradient(closest-side, rgba(255,106,191,.09), transparent 70%);
}

/* ---------- Layout-Helfer ---------- */
.container{
  width:min(100% - 2.5rem, 1100px);
  margin-inline:auto;
}

.section{
  padding-block:clamp(4rem, 9vw, 6.5rem);
  scroll-margin-top:5rem;
}

.section-head{
  text-align:center;
  max-width:640px;
  margin:0 auto clamp(2.2rem, 5vw, 3.5rem);
}
.section-head h2{
  font-size:clamp(1.8rem, 4.5vw, 2.6rem);
  font-weight:900;
  letter-spacing:-.02em;
  line-height:1.15;
}
.section-sub{
  margin-top:.9rem;
  color:var(--muted);
  font-size:1.02rem;
}

.eyebrow{
  text-transform:uppercase;
  letter-spacing:.22em;
  font-size:.75rem;
  font-weight:800;
  color:var(--purple);
  margin-bottom:.7rem;
}

/* Marken-Verlauf für Text (Blau → Magenta → Grün) */
.grad, .brand-dino, .wm-dino{
  background:linear-gradient(100deg, var(--der), var(--die) 52%, var(--das));
  -webkit-background-clip:text; background-clip:text;
  color:transparent;
}

/* ---------- Panels (dunkle Karten mit Glow + Shine) ---------- */
.panel{
  position:relative;
  background:var(--panel);
  border:1px solid var(--panel-border);
  border-radius:var(--radius);
  box-shadow:0 0 40px rgba(170,106,255,.07);
  backdrop-filter:blur(8px);
  -webkit-backdrop-filter:blur(8px);
}
/* dünner heller „Shine“ an der Oberkante */
.panel::before{
  content:"";
  position:absolute; top:0; left:12%; right:12%; height:1px;
  background:linear-gradient(90deg, transparent, rgba(255,255,255,.35), transparent);
  pointer-events:none;
}

/* ---------- Buttons ---------- */
.btn{
  display:inline-block;
  padding:.85em 1.9em;
  border-radius:999px;
  font-weight:800;
  font-size:1rem;
  text-decoration:none;
  border:none;
  cursor:pointer;
  font-family:inherit;
  transition:transform .25s ease, box-shadow .25s ease, background .25s ease;
}
.btn-primary{
  color:#fff;
  background:linear-gradient(135deg, var(--purple), #7a4ae0);
  box-shadow:0 0 24px rgba(170,106,255,.4);
  animation:btnPulse 3.2s ease-in-out infinite;
}
.btn-primary:hover{ transform:translateY(-2px); box-shadow:0 0 36px rgba(170,106,255,.6); }
.btn-ghost{
  color:var(--text);
  background:transparent;
  border:1px solid rgba(224,212,255,.25);
}
.btn-ghost:hover{ border-color:var(--teal); color:#fff; transform:translateY(-2px); }

@keyframes btnPulse{
  0%, 100%{ box-shadow:0 0 22px rgba(170,106,255,.35); }
  50%     { box-shadow:0 0 34px rgba(170,106,255,.55); }
}

/* ---------- Badges ---------- */
.badge{
  display:inline-flex;
  align-items:center;
  gap:.45em;
  padding:.35em 1em;
  border-radius:999px;
  font-size:.8rem;
  font-weight:800;
  letter-spacing:.04em;
  color:var(--gold);
  background:rgba(255,214,106,.08);
  border:1px solid rgba(255,214,106,.35);
}
.ico-spark{ width:.85em; height:.85em; color:currentColor; }

/* ---------- Header / Nav ---------- */
.site-header{
  position:sticky; top:0; z-index:50;
  background:rgba(10,10,31,.55);
  backdrop-filter:blur(14px);
  -webkit-backdrop-filter:blur(14px);
  border-bottom:1px solid rgba(255,255,255,.06);
  transition:background .3s;
}
.site-header.is-scrolled{ background:rgba(10,10,31,.82); }

.header-inner{
  display:flex;
  align-items:center;
  gap:1.2rem;
  padding-block:.65rem;
}

.brand{
  display:flex; flex-direction:column;
  text-decoration:none; line-height:1.1;
  margin-right:auto;
}
.brand-name{
  font-size:1.35rem; font-weight:900; letter-spacing:-.01em;
}
.brand-deutsch{ color:#f2ecff; }
.brand-dino{ filter:drop-shadow(0 0 10px rgba(170,106,255,.35)); }
.brand-tag{
  font-size:.62rem; font-weight:700;
  letter-spacing:.14em; text-transform:uppercase;
  color:var(--muted);
}

.main-nav{ display:none; gap:1.4rem; }
.main-nav a{
  text-decoration:none;
  font-weight:700;
  font-size:.92rem;
  color:var(--muted);
  transition:color .25s;
}
.main-nav a:hover{ color:#fff; }

.lang-switch{
  display:flex; gap:.25rem;
  padding:.2rem;
  border:1px solid rgba(255,255,255,.1);
  border-radius:999px;
  background:rgba(255,255,255,.04);
}
.lang-btn{
  display:inline-flex; align-items:center; gap:.3em;
  border:none; cursor:pointer;
  background:transparent;
  color:var(--muted);
  font-family:inherit; font-weight:800; font-size:.78rem;
  padding:.35em .7em;
  border-radius:999px;
  transition:background .25s, color .25s;
}
.lang-btn:hover{ color:#fff; }
.lang-btn.is-active{
  background:linear-gradient(135deg, rgba(170,106,255,.35), rgba(122,74,224,.35));
  color:#fff;
}

/* ---------- Hero ---------- */
.hero{
  padding-block:clamp(3.5rem, 8vw, 6rem) clamp(3rem, 7vw, 5rem);
  min-height:calc(92svh - 4rem);
  display:flex; align-items:center;
}
.hero-inner{
  display:grid;
  gap:3rem;
  align-items:center;
}
.hero-badge{ margin-bottom:1.2rem; }
.hero-title{
  font-size:clamp(2.4rem, 7vw, 4.1rem);
  font-weight:900;
  line-height:1.06;
  letter-spacing:-.025em;
}
.hero-sub{
  margin-top:1.2rem;
  font-size:clamp(1.02rem, 2vw, 1.15rem);
  color:var(--muted);
  max-width:34em;
}
.hero-sub strong{ color:var(--text); }
.hero-actions{
  margin-top:2rem;
  display:flex; flex-wrap:wrap; gap:.8rem;
}

/* Hero-Visual: Glas-Panels mit dem der·die·das-Farbsystem */
.hero-visual{
  position:relative;
  min-height:clamp(300px, 38vw, 400px);
  display:flex; align-items:center; justify-content:center;
}
.orb{ /* weicher Farb-Orb im Hintergrund */
  position:absolute; inset:8% 6%;
  background:
    radial-gradient(closest-side at 38% 40%, rgba(170,106,255,.30), transparent 70%),
    radial-gradient(closest-side at 68% 66%, rgba(74,210,196,.16), transparent 70%);
  filter:blur(2px);
}
.demo-card{
  position:relative;
  background:rgba(21,19,50,.6);
  border:1px solid var(--panel-border);
  border-radius:26px;
  padding:2.1rem 2.6rem 1.9rem;
  text-align:center;
  box-shadow:0 20px 60px rgba(5,5,26,.6), 0 0 50px rgba(170,106,255,.12);
  backdrop-filter:blur(10px);
  -webkit-backdrop-filter:blur(10px);
}
.demo-card::before{ /* Shine an der Oberkante */
  content:"";
  position:absolute; top:0; left:14%; right:14%; height:1px;
  background:linear-gradient(90deg, transparent, rgba(255,255,255,.4), transparent);
}
.demo-word{
  font-size:clamp(1.9rem, 3.4vw, 2.4rem);
  font-weight:900;
  letter-spacing:-.02em;
  color:#f2ecff;
}
.demo-articles{
  display:flex; gap:.55rem; justify-content:center;
  margin-top:1.15rem;
}
.da{
  padding:.32em 1.05em;
  border-radius:999px;
  font-weight:800; font-size:.92rem;
}
.da-der{ color:var(--der); background:rgba(106,178,255,.08); border:1px solid rgba(106,178,255,.3); opacity:.55; }
.da-die{ color:var(--die); background:rgba(255,106,191,.08); border:1px solid rgba(255,106,191,.3); opacity:.55; }
.da-das{ color:var(--das); background:rgba(106,210,106,.08); border:1px solid rgba(106,210,106,.3); }
.da-das.is-hit{
  background:rgba(106,210,106,.16);
  border-color:var(--das);
  box-shadow:0 0 18px rgba(106,210,106,.35);
}

.demo-chip{
  position:absolute;
  padding:.5em 1.25em;
  border-radius:999px;
  font-weight:800; font-size:.92rem;
  background:rgba(21,19,50,.65);
  backdrop-filter:blur(8px);
  -webkit-backdrop-filter:blur(8px);
}
.chip-der{
  top:6%; left:4%;
  color:var(--der);
  border:1px solid rgba(106,178,255,.45);
  box-shadow:0 0 22px rgba(106,178,255,.2);
}
.chip-die{
  bottom:8%; right:2%;
  color:var(--die);
  border:1px solid rgba(255,106,191,.45);
  box-shadow:0 0 22px rgba(255,106,191,.2);
}

/* Funkel-Sterne im Hero */
.spark{
  position:absolute; color:var(--gold);
  opacity:.85;
  animation:sparkTwinkle 3.4s ease-in-out infinite;
}
.s1{ width:16px; top:14%; right:12%; color:var(--teal); }
.s2{ width:12px; bottom:14%; left:12%; color:var(--purple); animation-delay:1.4s; }

@keyframes sparkTwinkle{
  0%, 100%{ transform:scale(1);   opacity:.85; }
  50%     { transform:scale(.55); opacity:.35; }
}

/* Sanftes Schweben (dezent, cinematic) */
.float{ animation:float 6s ease-in-out infinite; }
.f1{ animation-duration:7s; }
.f2{ animation-duration:8.2s; animation-delay:.8s; }
.f3{ animation-duration:9s;   animation-delay:.4s; }

@keyframes float{
  0%, 100%{ transform:translateY(0); }
  50%     { transform:translateY(-10px); }
}

/* ---------- Einblenden beim Scrollen ---------- */
.reveal{
  opacity:0;
  transform:translateY(26px);
  transition:opacity .7s ease var(--d, 0s), transform .7s ease var(--d, 0s);
}
.reveal.in{
  opacity:1;
  transform:none;
}

/* ---------- Produkte / Portfolio ---------- */
.product-grid{
  display:grid;
  grid-template-columns:1fr;
  gap:1.2rem;
}
.product-card{
  display:flex; flex-direction:column;
  padding:1.8rem 1.6rem;
}
.product-top{
  display:flex; align-items:center; justify-content:space-between;
  margin-bottom:1.3rem;
}
.card-num{
  font-size:.8rem; font-weight:800;
  letter-spacing:.22em;
  color:rgba(168,158,212,.55);
}
.card-badge{ font-size:.7rem; }
.card-ico{
  display:grid; place-items:center;
  width:46px; height:46px;
  border-radius:14px;
  color:var(--c, var(--purple));
  background:color-mix(in srgb, var(--c, #aa6aff) 12%, transparent);
  border:1px solid color-mix(in srgb, var(--c, #aa6aff) 30%, transparent);
}
.card-ico svg{ width:22px; height:22px; }
.product-title{
  margin-top:1.1rem;
  font-size:1.25rem; font-weight:900;
  letter-spacing:-.01em;
}
.product-card p{
  margin-top:.45rem;
  color:var(--muted);
  font-size:.95rem;
  flex-grow:1;
}
.card-link{
  margin-top:1.3rem;
  display:inline-flex; align-items:center; gap:.4em;
  font-weight:800; font-size:.92rem;
  color:var(--teal);
  text-decoration:none;
  transition:gap .25s ease, color .25s ease;
}
.card-link:hover{ gap:.7em; color:#fff; }
.card-link.is-muted{ color:rgba(168,158,212,.6); cursor:default; }

/* App-Wortmarke in Karten & App-Sektion */
.wm-der{ color:var(--der); }
.wm-die{ color:var(--die); }
.wm-das{ color:var(--das); }

/* ---------- App-Sektion ---------- */
.app-grid{
  display:grid;
  gap:3rem;
  align-items:center;
}
.app-wordmark{
  font-size:clamp(1.9rem, 5vw, 2.8rem);
  font-weight:900;
  letter-spacing:-.015em;
  line-height:1.1;
}
.app-tagline{
  margin-top:.35rem;
  color:var(--muted);
  font-size:.9rem;
  letter-spacing:.06em;
}
.app-sub{
  margin-top:1.1rem;
  color:var(--muted);
  max-width:36em;
}

/* Feature-Pills */
.pill-list{
  list-style:none;
  padding:0;
  margin:1.6rem 0 0;
  display:flex; flex-wrap:wrap;
  gap:.55rem;
}
.pill-list li{
  display:inline-flex; align-items:center; gap:.55em;
  padding:.45em 1.05em;
  border-radius:999px;
  font-size:.85rem; font-weight:700;
  color:var(--text);
  background:rgba(255,255,255,.04);
  border:1px solid rgba(255,255,255,.13);
}
.pill-list li::before{
  content:"";
  width:6px; height:6px;
  border-radius:50%;
  background:var(--purple);
}
.pill-list li:nth-child(6n+1)::before{ background:var(--der); }
.pill-list li:nth-child(6n+2)::before{ background:var(--die); }
.pill-list li:nth-child(6n+3)::before{ background:var(--das); }
.pill-list li:nth-child(6n+4)::before{ background:var(--teal); }
.pill-list li:nth-child(6n+5)::before{ background:var(--purple); }
.pill-list li:nth-child(6n+6)::before{ background:var(--gold); }

/* Handy-Mockup */
.app-visual{
  display:flex; justify-content:center;
}
.phone{
  position:relative;
  width:250px; height:500px;
  border-radius:42px;
  background:#05051a;
  border:1px solid rgba(255,255,255,.14);
  box-shadow:0 0 60px rgba(170,106,255,.22), inset 0 0 0 4px rgba(255,255,255,.03);
  padding:10px;
}
.phone-notch{
  position:absolute; top:20px; left:50%;
  transform:translateX(-50%);
  width:88px; height:22px;
  border-radius:12px;
  background:#05051a;
}
.phone-screen{
  position:relative;
  width:100%; height:100%;
  border-radius:33px;
  overflow:hidden;
  background:
    radial-gradient(1.5px 1.5px at 18% 22%, rgba(255,255,255,.8), transparent 60%),
    radial-gradient(1px 1px   at 72% 14%, rgba(255,255,255,.7), transparent 60%),
    radial-gradient(1.5px 1.5px at 84% 42%, rgba(255,255,255,.55), transparent 60%),
    radial-gradient(1px 1px   at 32% 56%, rgba(255,255,255,.6), transparent 60%),
    radial-gradient(1.5px 1.5px at 58% 72%, rgba(255,255,255,.5), transparent 60%),
    radial-gradient(1px 1px   at 12% 84%, rgba(255,255,255,.6), transparent 60%),
    linear-gradient(180deg, #0c0b26, #151138);
}
.phone-hud{
  position:absolute; top:52px; left:16px; right:16px;
  display:flex; justify-content:space-between;
  font-size:.72rem; font-weight:800;
}
.phone-hearts{ color:var(--die); letter-spacing:.1em; }
.phone-score{ color:var(--gold); }

.phone-word{
  position:absolute; top:80px; left:50%;
  transform:translateX(-50%);
  padding:.35em 1em;
  border-radius:999px;
  background:#1c1a44;
  border:1px solid var(--die);
  font-weight:800; font-size:.9rem;
  color:var(--text);
  box-shadow:0 0 16px rgba(255,106,191,.25);
  animation:wordFall 5.5s ease-in infinite;
}
@keyframes wordFall{
  0%  { transform:translate(-50%, 0);     opacity:0; }
  8%  { opacity:1; }
  78% { transform:translate(-50%, 300px); opacity:1; }
  86% { transform:translate(-50%, 316px); opacity:0; }
  100%{ transform:translate(-50%, 316px); opacity:0; }
}

.phone-lanes{
  position:absolute; bottom:14px; left:14px; right:14px;
  display:flex; gap:8px;
}
.p-lane{
  flex:1;
  text-align:center;
  padding:.55em 0;
  border-radius:12px;
  font-weight:800; font-size:.82rem;
}
.l-der{ color:var(--der); background:rgba(106,178,255,.10); border:1px solid rgba(106,178,255,.4); }
.l-die{ color:var(--die); background:rgba(255,106,191,.10); border:1px solid rgba(255,106,191,.5);
        animation:laneGlow 5.5s ease-in-out infinite; }
.l-das{ color:var(--das); background:rgba(106,210,106,.10); border:1px solid rgba(106,210,106,.4); }

@keyframes laneGlow{
  0%, 70%, 100%{ box-shadow:none; background:rgba(255,106,191,.10); }
  78%, 88%     { box-shadow:0 0 18px rgba(255,106,191,.65); background:rgba(255,106,191,.28); }
}

/* ---------- „So funktioniert's“ ---------- */
.steps{
  display:grid;
  gap:1.2rem;
}
.card{
  padding:1.7rem 1.5rem;
}
.card h3{
  font-size:1.12rem; font-weight:800;
  margin-top:1.1rem;
}
.card p{
  margin-top:.4rem;
  color:var(--muted);
  font-size:.95rem;
}
.how-visual{
  width:100%; height:auto;
  font-family:inherit;
}
.chip-fall{ animation:chipBob 4.5s ease-in-out infinite; }
@keyframes chipBob{
  0%, 100%{ transform:translateY(0); }
  50%     { transform:translateY(9px); }
}

/* ---------- Warteliste ---------- */
.waitlist-wrap{ max-width:620px; }
.waitlist-panel{
  padding:1.8rem 1.6rem;
}
.waitlist-text{ font-weight:600; }

.waitlist-row{
  display:flex; flex-wrap:wrap; gap:.6rem;
  margin-top:1.1rem;
}
#waitlist-form input[type="email"]{
  flex:1 1 220px;
  min-width:0;
  font-family:inherit; font-size:1rem;
  color:var(--text);
  background:rgba(255,255,255,.05);
  border:1px solid rgba(255,255,255,.16);
  border-radius:999px;
  padding:.8em 1.3em;
  transition:border-color .25s, box-shadow .25s;
}
#waitlist-form input[type="email"]::placeholder{ color:rgba(168,158,212,.7); }
#waitlist-form input[type="email"]:focus{
  outline:none;
  border-color:var(--teal);
  box-shadow:0 0 16px rgba(74,210,196,.25);
}

.consent{
  display:flex; gap:.55rem; align-items:flex-start;
  margin-top:1rem;
  font-size:.82rem;
  color:var(--muted);
  cursor:pointer;
  text-align:left;
}
.consent input{
  margin-top:.25em;
  accent-color:var(--purple);
  width:1rem; height:1rem;
  flex:0 0 auto;
}
.consent a, .link{ color:var(--teal); }

/* Spam-Schutz (Honeypot) — unsichtbar */
.gotcha{ position:absolute; left:-9999px; width:1px; height:1px; opacity:0; }

.form-msg{
  margin-top:1rem;
  font-weight:700;
  font-size:.92rem;
  padding:.7em 1.1em;
  border-radius:14px;
}
.form-msg.ok  { color:var(--das);  background:rgba(106,210,106,.1);  border:1px solid rgba(106,210,106,.35); }
.form-msg.err { color:#ff9090;     background:rgba(255,106,106,.08); border:1px solid rgba(255,106,106,.3); }
.form-msg.warn{ color:var(--gold); background:rgba(255,214,106,.08); border:1px solid rgba(255,214,106,.3); }

/* ---------- Footer ---------- */
.site-footer{
  border-top:1px solid rgba(255,255,255,.07);
  padding-block:3rem 2rem;
  margin-top:2rem;
}
.footer-inner{
  display:flex; flex-direction:column; align-items:center;
  gap:1.6rem;
  text-align:center;
}
.footer-brand .brand-name{ font-size:1.5rem; }
.footer-claim{
  margin-top:.4rem;
  color:var(--muted);
  font-size:.9rem;
}
.footer-social-label{
  display:block;
  font-size:.72rem; font-weight:800;
  text-transform:uppercase; letter-spacing:.18em;
  color:var(--muted);
  margin-bottom:.7rem;
}
.social-row{
  display:flex; gap:.8rem; justify-content:center;
}
.social-row a{
  display:grid; place-items:center;
  width:42px; height:42px;
  border-radius:50%;
  border:1px solid rgba(255,255,255,.14);
  color:var(--muted);
  transition:color .25s, border-color .25s, box-shadow .25s, transform .25s;
}
.social-row a:hover{
  color:#fff;
  border-color:var(--purple);
  box-shadow:0 0 18px rgba(170,106,255,.35);
  transform:translateY(-2px);
}
.social-row svg{ width:19px; height:19px; }

.footer-legal{
  display:flex; gap:.7rem;
  font-size:.85rem;
  color:var(--muted);
}
.footer-legal a{ text-decoration:none; transition:color .25s; }
.footer-legal a:hover{ color:#fff; }

.footer-copy{
  font-size:.78rem;
  color:rgba(168,158,212,.6);
}

/* ============================================================
   Responsive: größere Screens
   ============================================================ */
@media (min-width: 720px){
  .main-nav{ display:flex; }
  .steps{ grid-template-columns:repeat(3, 1fr); }
  .product-grid{ grid-template-columns:repeat(3, 1fr); }
}

@media (min-width: 960px){
  .hero-inner{ grid-template-columns:1.05fr .95fr; }
  .app-grid{ grid-template-columns:1.1fr .9fr; }
}

@media (max-width: 480px){
  .brand-tag{ display:none; }
}

/* ============================================================
   Barrierefreiheit: reduzierte Bewegung
   ============================================================ */
@media (prefers-reduced-motion: reduce){
  *, *::before, *::after{
    animation-duration:.01ms !important;
    animation-iteration-count:1 !important;
    transition-duration:.01ms !important;
  }
  html{ scroll-behavior:auto; }
  .reveal{ opacity:1 !important; transform:none !important; }
}
