:root{
  --red:#C32631;
  --red-dark:#C32631;
  --ink:#444444;
  --ink-soft:#4a4a4a;
  --muted:#8a8a8a;
  --line:#e4e4e4;
  --bg:#f3f4f5;
  --card:#ffffff;
  --ok:#1f9d55;
  --radius:0px;
  --shadow:0 10px 30px rgba(0,0,0,.07),0 2px 6px rgba(0,0,0,.04);
  --font:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,"Helvetica Neue",Arial,"Noto Sans",sans-serif;
}
*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{
  font-family:var(--font);
  color:var(--ink);
  background:var(--bg);
  line-height:1.55;
  -webkit-font-smoothing:antialiased;
  display:flex;flex-direction:column;min-height:100vh;
}

/* ---------- Header ---------- */
.site-header{
  background:#fff;border-bottom:1px solid var(--line);
}
.site-header .wrap{
  max-width:1080px;margin:0 auto;padding:16px 22px;
  display:flex;align-items:center;justify-content:space-between;gap:16px;
}
.brand img{width:auto;display:block}
.lang-switch{display:flex;align-items:center;gap:8px;font-size:14px}
.lang-switch .label{color:var(--muted)}
.lang-switch a{
  display:inline-flex;align-items:center;justify-content:center;
  min-width:40px;height:34px;padding:0 12px;border:1px solid var(--line);
  border-radius:8px;text-decoration:none;color:var(--ink-soft);font-weight:600;
  transition:.15s;
}
.lang-switch a:hover{border-color:var(--red);color:var(--red)}

/* ---------- Hero ---------- */
.hero{
  background:linear-gradient(180deg,#fff 0,#fff 60%,transparent 100%);
  border-bottom:1px solid var(--line);
}
.hero .wrap{max-width:1080px;margin:0 auto;padding:30px 22px 26px}
.hero h1{
  margin:0 0 6px;font-size:30px;letter-spacing:-.01em;
  position:relative;padding-left:16px;
}
.hero h1::before{
  content:"";position:absolute;left:0;top:6px;bottom:6px;width:5px;
  background:var(--red);border-radius:3px;
}
.hero p{margin:0;color:var(--ink-soft);max-width:60ch}

/* ---------- Main / Card ---------- */
main{flex:1 0 auto}
.container{max-width:1080px;margin:0 auto;padding:26px 22px 50px}
.card{
  background:var(--card);border:1px solid var(--line);
  border-radius:var(--radius);box-shadow:var(--shadow);padding:30px;
}
@media(min-width:640px){.card{padding:38px}}

/* ---------- Form ---------- */
.form-grid{display:grid;grid-template-columns:1fr;gap:18px}
@media(min-width:640px){
  .form-grid{grid-template-columns:1fr 1fr}
  .span-2{grid-column:1 / -1}
}
.field label{display:block;font-weight:600;font-size:14px;margin-bottom:7px;color:var(--ink)}
.field .req{color:var(--red);margin-left:2px}
.field input,.field select{
  width:100%;padding:13px 14px;font-size:16px;font-family:inherit;color:var(--ink);
  background:#fff;border:1.5px solid var(--line);transition:.15s;
}
/* .field input:focus,.field select:focus{
  outline:none;border-color:var(--red);box-shadow:0 0 0 3px rgba(226,0,26,.12)
} */
.field.invalid input,.field.invalid select{border-color:var(--red);background:#fff8f8}
.field .hint{color:var(--red);font-size:13px;margin-top:6px;min-height:0}
.field select{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 24 24' fill='none' stroke='%238a8a8a' stroke-width='2'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 14px center;padding-right:40px}

/* honeypot – für Menschen unsichtbar */
.hp{position:absolute!important;left:-9999px!important;top:-9999px!important;width:1px;height:1px;overflow:hidden}

/* consent */
.consent{display:flex;gap:12px;align-items:flex-start;margin-top:4px}
.consent input{margin-top:3px;width:20px;height:20px;accent-color:var(--red);flex:0 0 auto}
.consent label{font-size:14px;color:var(--ink-soft);line-height:1.5}
.consent a{color:var(--red)}
.consent.invalid label{color:var(--red)}

.alert{
  background:#fff5f5;border:1px solid #f3c2c2;color:#a3000f;
  padding:12px 14px;border-radius:10px;margin-bottom:22px;font-size:14px
}

.actions{margin-top:28px;display:flex;align-items:center;gap:14px;flex-wrap:wrap}
.btn{
  appearance:none;cursor:pointer;border:none;font-family:inherit;
  background:var(--red);color:#fff;font-weight:700;font-size:16px;
  padding:14px 30px;transition:.15s;letter-spacing:.01em;
}
.btn:hover{background:var(--red-dark)}
.btn:disabled{opacity:.6;cursor:progress}
.btn.secondary{background:#fff;color:var(--ink);border:1.5px solid var(--line)}
.btn.secondary:hover{border-color:var(--red);color:var(--red);background:#fff}
.required-note{color:var(--muted);font-size:13px}

/* ---------- Confirmation ---------- */
.confirm-head{display:flex;align-items:center;gap:16px;margin-bottom:8px}
.check{
  flex:0 0 auto;width:52px;height:52px;border-radius:50%;
  background:rgba(31,157,85,.12);display:flex;align-items:center;justify-content:center;
}
.check svg{width:28px;height:28px;stroke:var(--ok)}
.confirm-head h1{margin:0;font-size:26px}
.summary{width:100%;border-collapse:collapse;margin:22px 0 6px}
.summary td{padding:12px 0;border-bottom:1px solid var(--line);font-size:15px;vertical-align:top}
.summary td:first-child{color:var(--muted);width:42%;padding-right:16px}
.summary td:last-child{font-weight:600}

/* ---------- Legal pages ---------- */
.legal h1{font-size:26px;margin-top:0}
.legal h2{font-size:18px;margin-top:26px;color:var(--red)}
.legal p,.legal li{color:var(--ink-soft);font-size:15px}
.legal address{font-style:normal;line-height:1.7}

/* ---------- Footer ---------- */
.site-footer{
  background:var(--red-dark);color:#ffffff;margin-top:auto;
}
.site-footer .wrap{
  max-width:1080px;margin:0 auto;padding:30px 22px;
  display:flex;flex-wrap:wrap;gap:20px 40px;align-items:center;justify-content:space-between;
}
.site-footer img{height:60px;opacity:.95}
.site-footer .addr{font-size:13px;line-height:1.6;}
.site-footer a{color:#e6e6e6;text-decoration:none;font-size:14px;margin-left:20px}
.site-footer a:first-child{margin-left:0}
.site-footer a:hover{color:var(--red)}
.site-footer .links{display:flex;flex-wrap:wrap}
