
/* Feuerwehr x Weihnachten – polished theme (3 snow layers, 7px flakes) */
:root{
  --bg:#0a0f1a;
  --bg2:#111a2b;
  --card:#ffffff;
  --ink:#0e1726;
  --muted:#5f6b7a;
  --primary:#c40000;   /* Feuerwehr-Rot */
  --accent:#ffd166;    /* warmes Gold */
  --evergreen:#0f5132; /* Tannengrün */
  --ring:rgba(196,0,0,.25);
  --border:#e9edf3;
  --shadow:0 18px 48px rgba(0,0,0,.38);
  --flake:7px;         /* 6–8px Wunsch: Mittelwert 7px */
}
*{box-sizing:border-box}
html,body{height:100%}
body{
  margin:0;
  font-family: system-ui,-apple-system,"Segoe UI",Roboto,Arial,Helvetica,sans-serif;
  color:var(--ink);
  background:
    radial-gradient(1100px 800px at 20% -10%, rgba(196,0,0,.16), transparent 60%),
    radial-gradient(1100px 800px at 90% 110%, rgba(15,81,50,.13), transparent 60%),
    linear-gradient(180deg,var(--bg),var(--bg2));
  background-attachment:fixed;
  overflow-x:hidden;
}
.snow{position:fixed;inset:0;pointer-events:none;z-index:0}
.snow .layer{
  position:absolute;inset:-320px 0 0 0;
  background-size: 720px 280px;
  animation: snow 20s linear infinite;
  opacity:.72;
}
.snow .layer:nth-child(2){ animation-duration: 32s; opacity:.52; filter: blur(.6px) }
.snow .layer:nth-child(3){ animation-duration: 46s; opacity:.38; filter: blur(1.1px) }
.snow .layer{
  background-image:
    radial-gradient(var(--flake) var(--flake) at 40px 30px, #fff, #fff0 62%),
    radial-gradient(var(--flake) var(--flake) at 180px 120px, #fff, #fff0 62%),
    radial-gradient(calc(var(--flake)*1.15) calc(var(--flake)*1.15) at 340px 60px, #fff, #fff0 62%),
    radial-gradient(calc(var(--flake)*0.85) calc(var(--flake)*0.85) at 520px 100px, #fff, #fff0 62%),
    radial-gradient(calc(var(--flake)*1.05) calc(var(--flake)*1.05) at 260px 10px, #fff, #fff0 62%),
    radial-gradient(calc(var(--flake)*0.9) calc(var(--flake)*0.9) at 80px 180px, rgba(255,160,64,.85), #fff0 65%);
}
@keyframes snow{from{transform:translateY(-320px)} to{transform:translateY(100vh)}}
.wrap{position:relative;z-index:1;min-height:100%;display:flex;align-items:center;justify-content:center;padding:32px 18px}
.card{
  width:min(1000px,100%);
  background:var(--card);
  border-radius:18px;
  box-shadow:0 18px 48px rgba(0,0,0,.38);
  padding:clamp(18px, 2.6vw, 36px);
  border:1px solid #e9edf3;
}
.header{display:flex;gap:18px;align-items:center;flex-wrap:wrap;margin-bottom:10px}
.brand{display:flex;align-items:center;gap:14px}
.brand img{width:78px;height:auto;display:block}
h1{margin:0;font-size:clamp(1.25rem,2.6vw,2rem);letter-spacing:.2px}
.subtitle{margin:6px 0 0;color:#5f6b7a;font-size:.98rem}
.ribbon{
  margin:0 0 16px 0;
  background:linear-gradient(90deg,#c40000,#8a0000);
  color:#fff; padding:10px 14px; border-radius:12px; display:flex; gap:10px; align-items:center;
  box-shadow:0 12px 26px rgba(196,0,0,.35);
}
.ribbon .emoji{font-size:1.25rem}
.ribbon strong{letter-spacing:.3px}
.grid{display:grid;gap:22px;grid-template-columns:1fr}
@media(min-width:900px){.grid{grid-template-columns:1.1fr .9fr}}
fieldset{border:0;padding:0;margin:0}
label{display:block;font-weight:800;margin:10px 0 6px}
input,textarea,select{
  width:100%;padding:12px 14px;border-radius:12px;border:1px solid #e5e7eb;
  font:inherit;color:inherit;background:#fff;outline:none;box-shadow:inset 0 1px 0 rgba(0,0,0,.02)
}
input:focus,textarea:focus,select:focus{border-color:#c40000;box-shadow:0 0 0 4px rgba(196,0,0,.25)}
.actions{display:flex;gap:12px;align-items:center;flex-wrap:wrap;margin-top:10px}
button,.btn{
  appearance:none;border:0;cursor:pointer;
  background:linear-gradient(180deg,#c40000,#8a0000);
  color:#fff;padding:12px 16px;border-radius:12px;font-weight:900;letter-spacing:.3px;
  box-shadow:0 10px 18px rgba(196,0,0,.28), inset 0 -1px 0 rgba(0,0,0,.15)
}
button:hover{filter:brightness(1.06)} button:active{transform:translateY(1px)}
.note{color:#5f6b7a;font-size:.95rem}
.hr{height:1px;background:#eef2f7;margin:16px 0}
.alert{margin:12px 0 10px;padding:10px 12px;border-radius:12px;background:#fef2f2;color:#7f1d1d;border:1px solid #fecaca}
.kicker{display:flex;gap:14px;align-items:center;color:#fff;margin:0 auto 14px;width:min(1000px,100%)}
.kicker .pill{display:inline-flex;align-items:center;gap:8px;padding:8px 12px;border-radius:999px;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.15);font-size:.95rem}
.footer{margin:18px auto 28px;text-align:center;color:#e2e8f0;font-size:.92rem;width:min(1000px,100%)}
.footer a{color:#fff;text-decoration:underline;text-decoration-color:rgba(255,255,255,.4)}
.footer .line{color:#aab4c3}
