:root{
  --brand:#0B5FA5;        /* Logo-Blau */
  --brand-2:#1679C4;      /* Hellblau */
  --cta:#F4A000;          /* Logo-Orange */
  --bg:#F7FAFF;

  --card:#FFFFFF;
  --text:#0F172A;
  --muted:#475569;
  --line:#E2E8F0;

  --radius:18px;

  --shadow:0 10px 30px rgba(2,24,43,.08);
  --shadow-soft:0 6px 18px rgba(2,24,43,.06);

  --max:1180px;
}

*{box-sizing:border-box}

body{
  background:var(--bg);
  color:var(--text);
  font-family:Inter, system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  line-height:1.7;
}

main{display:block}
section{padding:72px 20px}

h1,h2,h3{line-height:1.2; letter-spacing:-.02em}
h1{font-size:clamp(2rem,3vw,3rem); margin:0 0 12px}
h2{font-size:clamp(1.5rem,2.2vw,2.1rem); margin:0 0 14px}
h3{font-size:1.2rem; margin:0 0 10px}
p{margin:0 0 14px; color:var(--muted)}

.container{
  max-width:var(--max);
  margin:0 auto;
}

/* HERO */
#hero{
  position:relative;
  color:#fff;
  padding:120px 20px;
}

#hero::before{
  content:"";
  position:absolute;
  inset:0;
  background:linear-gradient(
    120deg,
    rgba(11,95,165,.82),
    rgba(0,0,0,.25)
  );
}

#hero .container{
  position:relative;
  z-index:1;
  text-align:center;
  max-width:900px;
}

#hero p{
  color:rgba(255,255,255,.92);
  font-size:1.1rem;
  margin:10px auto 0;
}

.hero-actions{
  display:flex;
  gap:12px;
  justify-content:center;
  flex-wrap:wrap;
  margin-top:28px;
}

/* BUTTONS */
.btn-primary,
.btn-secondary{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding:14px 18px;
  border-radius:999px;
  text-decoration:none;
  font-weight:650;
  border:1px solid transparent;
  transition:.15s ease;
  box-shadow:var(--shadow-soft);
}

.btn-primary{
  background:var(--cta);
  color:#1b1b1b;
  font-weight:700;
}

.btn-primary:hover{
  background:#d98e00;
  transform:translateY(-1px);
  box-shadow:var(--shadow);
}

.btn-secondary{
  background:rgba(255,255,255,.15);
  color:#fff;
  border-color:rgba(255,255,255,.3);
  backdrop-filter:blur(8px);
}

.btn-secondary:hover{
  transform:translateY(-1px);
  box-shadow:var(--shadow);
}

/* QUICK FINDER */
#quick-finder{
  background:linear-gradient(180deg,#F3F8FF,#F7FAFF);
}

#quick-finder .card{
  background:var(--card);
  border:1px solid var(--line);
  border-radius:var(--radius);
  box-shadow:var(--shadow-soft);
  padding:22px;
}

#quick-finder form{
  display:grid;
  grid-template-columns:1fr 1fr 1fr auto;
  gap:12px;
  margin-top:14px;
}

#quick-finder select{
  width:100%;
  padding:14px;
  border-radius:12px;
  border:1px solid var(--line);
  background:#fff;
  font-size:1rem;
}

#quick-finder button{
  border:0;
  cursor:pointer;
  padding:14px 18px;
  border-radius:12px;
  background:var(--brand);
  color:#fff;
  font-weight:700;
}

#quick-finder button:hover{
  background:#084f8a;
}

/* KACHELN */
.kachel-grid{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:16px;
  margin-top:18px;
}

.kachel{
  background:var(--card);
  border:1px solid var(--line);
  border-radius:var(--radius);
  box-shadow:var(--shadow-soft);
  padding:20px;
  transition:.15s ease;
  min-height:160px;
  text-decoration:none;
  color:inherit;
}

.kachel:hover{
  transform:translateY(-2px);
  box-shadow:var(--shadow);
}

.kachel p{margin:0; color:var(--muted)}

/* MAP */
#karte .map-placeholder{
  margin-top:16px;
  border-radius:var(--radius);
  border:1px solid var(--line);
  background:#EAF3FF;
  min-height:420px;
  box-shadow:var(--shadow-soft);
}

/* SPOTLIGHTS */
#spotlights .grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:18px;
  margin-top:18px;
}

.spot-card{
  background:var(--card);
  border:1px solid var(--line);
  border-radius:var(--radius);
  box-shadow:var(--shadow-soft);
  padding:20px;
}

/* FOOTER */
footer{
  background:var(--brand);
  color:rgba(255,255,255,.92);
  padding:44px 20px;
  text-align:center;
}

footer a{
  color:rgba(255,255,255,.95);
  text-decoration:none;
}

footer a:hover{
  text-decoration:underline;
}

/* RESPONSIVE */
@media (max-width:980px){
  #quick-finder form{grid-template-columns:1fr 1fr}
  .kachel-grid{grid-template-columns:repeat(2,1fr)}
  #spotlights .grid{grid-template-columns:1fr}
}

@media (max-width:560px){
  #hero{padding:92px 18px}
  #quick-finder form{grid-template-columns:1fr}
  .kachel-grid{grid-template-columns:1fr}
}

/* TERM ICONS */
.term-icon{
  display:inline-flex;
  align-items:center;
  gap:10px;
  font-weight:500;
}

.term-icon .icon-badge{
  width:34px;
  height:34px;
  border-radius:10px;
  background:linear-gradient(135deg,#EAF3FF,#D6E8FF);
  display:flex;
  align-items:center;
  justify-content:center;
  box-shadow:0 4px 12px rgba(0,0,0,.06);
  flex-shrink:0;
}

.term-icon .icon-badge svg{
  width:18px;
  height:18px;
  fill:var(--brand-2);
}