:root{
  --bg:#0f0f12; --text:#151515; --text-soft:#4a4a4a; --muted:#777;
  --brand:#e57b55; --brand-2:#5b7d95; --card:#ffffff;
  --ring: rgba(229,123,85,.45); --radius:14px; --maxw:1120px;
}

/* Base */
*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{
  font-family:system-ui,-apple-system,Segoe UI,Roboto,Ubuntu,Cantarell,"Noto Sans","Helvetica Neue",Arial,"Apple Color Emoji","Segoe UI Emoji";
  color:var(--text); background:#fafafa; line-height:1.45;
  -webkit-font-smoothing:antialiased; text-rendering:optimizeLegibility;
}
a{color:var(--brand-2); text-decoration:none}
a:focus-visible,button:focus-visible,input:focus-visible,select:focus-visible,summary:focus-visible{
  outline:3px solid var(--ring); outline-offset:2px; border-radius:6px;
}
.container{max-width:var(--maxw); margin:0 auto; padding:0 20px}

/* Topbar / Nav (eine Zeile) */
.topbar{position:relative;z-index:5;}
.nav{display:flex; justify-content:space-between; align-items:center; gap:16px}
.logo{font-weight:700; letter-spacing:.4px}
.logo, .logo:link, .logo:visited{color:#fff; text-decoration:none}

.menu{display:flex; align-items:center; gap:18px; flex-wrap:nowrap}
.menu a{color:#fff; opacity:.9; text-decoration:none; font-weight:500; white-space:nowrap}
.menu a:hover{opacity:1}

/* Language Switcher */
.lang{position:relative}
.lang-btn{
  display:inline-flex; align-items:center; gap:8px; cursor:pointer;
  background: rgba(255,255,255,.08); color:#fff; border:1px solid rgba(255,255,255,.2);
  padding:8px 10px; border-radius:10px;
}
.lang .lang-list{ display:none; position:absolute; right:0; top:100%; background:#fff;
  border:1px solid #e7edf3; border-radius:10px; box-shadow:0 10px 24px rgba(17,23,32,.08);
  padding:6px; z-index:50; min-width:140px; }
.lang-list a{
  display:flex; align-items:center; justify-content:space-between;
  padding:10px; border-radius:8px; color:#1d2a33; font-weight:600;
}
.lang-list a[aria-current="true"]{background:#eef5ff; color:#2b5278}
.lang-list a:hover{background:#f5f7fa}
.lang.open .lang-list{display:block}

/* Hero */
.hero{position:relative; min-height:clamp(64vh,74vh,86vh); display:flex; align-items:center; color:#fff; background:#000; isolation:isolate}
.hero-media{position:absolute; inset:0; width:100%; height:100%; z-index:-2; pointer-events:none;}
.hero-bg{object-fit:cover; object-position:center 60%; width:100%; height:100%}
.hero::before{
  content:""; position:absolute; inset:0;
  background-image:linear-gradient(to bottom, rgba(0,0,0,.25), rgba(0,0,0,.55) 60%, rgba(0,0,0,.75));
  z-index:-1;
}
.hero::after{
  content:""; position:absolute; left:0; right:0; bottom:-1px; height:22%;
  background:linear-gradient(to top, rgba(0,0,0,.55), transparent); z-index:-1;
}
.hero-inner{max-width:70%; margin-left:auto; margin-right:auto; padding:clamp(28px,5vw,60px) 20px 40px; text-align:center}
.hero h1{font-size:clamp(28px,5.6vw,56px); line-height:1.1; margin:0 0 16px}
/* .hero p.lead{font-size:clamp(16px,2.1vw,22px); margin:0 auto 24px; max-width:55ch}*/
.hero p.lead {
  color: #fff;
  font-weight: 300;
  font-size: 1.25rem;
  line-height: 1.5;
  max-width: 80ch;
  text-align: center;   /* sorgt für Mitte */
  margin-left: auto;    /* verhindert seitliches Hängen */
  margin-right: auto;
}



/* CTA */
.cta{
  display:inline-block; background:var(--brand); color:#fff; font-weight:600;
  padding:14px 20px; border-radius:999px; box-shadow:0 6px 22px rgba(229,123,85,.25);
  transition:transform .08s ease, box-shadow .2s ease; border:0; cursor:pointer;
}
.cta:hover{transform:translateY(-1px); box-shadow:0 10px 28px rgba(229,123,85,.35)}

/* Search Card */
.search-wrap{transform:translateY(-32px)}
.search{
  background:var(--card); border-radius:var(--radius);
  box-shadow:0 14px 40px rgba(17,23,32,.15);
  padding:18px; display:grid; gap:16px;
}
fieldset{border:0; padding:0; margin:0; display:grid; gap:10px}
.grid{display:grid; gap:16px}
.row{display:flex; align-items:center; gap:12px; flex-wrap:wrap}
input,select{padding:12px 14px; border:1px solid #dbe3ea; border-radius:10px; background:#fff; font-size:1rem}
.hint{color:var(--muted); font-size:.95rem; margin-top:-4px}
.check{display:flex; align-items:center; gap:10px; padding:10px 12px; border-radius:10px; background:#f8fafc; border:1px solid #e8eef4}
.check input{accent-color:var(--brand-2)}
.actions{display:flex; gap:10px; justify-content:flex-end}
.btn{border:0; border-radius:10px; padding:12px 16px; cursor:pointer; font-weight:600}
.btn.secondary{background:#eaeef3; color:#2b2f33}
.btn{background:var(--brand-2); color:#fff}
.badge{background:#eef5ff; color:#2b5278; padding:4px 8px; border-radius:999px; font-size:.82rem; font-weight:600}

/* Segmented scope */
.seg{background:#f3f5f7; border-radius:999px; padding:6px; display:inline-flex; gap:4px}
.seg input{display:none}
.seg label{padding:8px 14px; border-radius:999px; cursor:pointer; user-select:none; color:#334; opacity:.8; font-weight:600; font-size:.95rem}
.seg input:checked + label{background:#fff; box-shadow:0 0 0 1px #d9e1e8 inset; opacity:1}

/* Schöne Selects (Pfeil) */
select{
  appearance:none; -webkit-appearance:none; -moz-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'%3E%3Cpath fill='%23677' d='M7 10l5 5 5-5z'/%3E%3C/svg%3E");
  background-repeat:no-repeat; background-position:right 12px center; background-size:14px 14px;
  padding-right:38px;
}
.selects-row{gap:16px}
.select-wrap{flex:1; min-width:220px; display:grid; gap:8px}

/* Info Section */
section.info{padding:40px 0 72px}
.cards{display:grid; gap:16px; grid-template-columns:repeat(2,minmax(0,1fr)); margin-top:22px}
.card{background:#fff; border:1px solid #eef1f4; border-radius:14px; padding:18px 16px; box-shadow:0 10px 22px rgba(17,23,32,.08)}
.card h3{margin:4px 0 6px 0}
.card p{margin:0; color:var(--text-soft)}

/* Footer */
footer{padding:28px 0; color:#677; font-size:.95rem}

/* Sections / Utilities */
.section{padding:36px 0}
.lead{color:var(--text-soft); max-width:80ch}
.badge{display:inline-block; background:#eef5ff; color:#2b5278; padding:4px 10px; border-radius:999px; font-weight:600; font-size:.85rem}
.card{background:#fff; border:1px solid #e7edf3; border-radius:14px; box-shadow:0 10px 24px rgba(17,23,32,.06); padding:18px}
.grid{display:grid; gap:18px}
.cols-2{grid-template-columns:1fr 1fr}
.cols-3{grid-template-columns:repeat(3,1fr)}
@media (max-width:880px){.cols-2,.cols-3{grid-template-columns:1fr}}

/* Tables */
table{width:100%; border-collapse:separate; border-spacing:0; border-radius:12px; background:#fff; border:1px solid #e7edf3; overflow:hidden}
thead th{background:#f6f9fc; text-align:left; font-weight:700; padding:14px 12px; border-bottom:1px solid #e7edf3}
tbody td{padding:12px; border-bottom:1px solid #e7edf3; vertical-align:top; color:#2b3137}
tbody tr:last-child td{border-bottom:0}
.muted{color:#6f7a86}
.ok{color:#2f855a; font-weight:600}
.dim{color:#9aa7b4}

/* Topbar fix: volle Breite + oben an den Hero kleben */
.topbar{ position:absolute; top:0; left:0; width:100%; padding:14px 0; z-index:5; }

/* .nav soll die ganze Breite füllen, damit space-between wirkt */
.nav{ display:flex; width:100%; justify-content:space-between; align-items:center; }

/* Sicherheit: Menü nicht umbrechen, rechtsbündig laufen lassen */
.menu{ display:flex; align-items:center; gap:18px; flex-wrap:nowrap; margin-left:auto; }


/* Responsive */
@media (max-width:920px){ .menu{gap:12px} .lang-btn{padding:8px 10px} }
@media (max-width:860px){ .search-wrap{transform:none; margin-top:-18px} .cards{grid-template-columns:1fr} .hero p.lead{max-width:60ch} }
