:root{
  --pink-25:#fff4f8;
  --pink-50:#ffe9f1;
  --pink-100:#ffd9e6;
  --pink-300:#f3a4bf;
  --pink-500:#cf5f88;
  --red-600:#ed1f26;
  --white:#ffffff;
  --ink:#1f2328;
  --muted:#5f6670;
  --hair:#efc6d6;
  --container:1040px;
  --radius:20px;
}

html,body{margin:0}
body{
  font-family:"Work Sans",system-ui,Arial,Helvetica,sans-serif;
  line-height:1.6;
  color:var(--ink);
  background:var(--white);
}

h1,h2,h3{
  margin:0 0 .6rem;
  font-weight:700;
  color:var(--red-600);
  text-wrap:balance;
}

p,li,.prose{
  margin:.65rem 0;
  text-align:start;
  hyphens:auto;
  overflow-wrap:anywhere;
}

a{color:var(--red-600);text-decoration:none}

.container{max-width:var(--container);margin:0 auto;padding:0 18px}
section{padding:84px 0}
.section--tight{padding:56px 0}
.section--roomy{padding:112px 0}
.prose{max-width:65ch}
.prose--narrow{max-width:58ch}
.muted{color:var(--muted)}
.center{text-align:center}
.flow{display:grid;gap:18px}
.grid{display:grid;gap:20px}
.cols-3{grid-template-columns:1fr}
.split-2{display:grid;grid-template-columns:1fr;gap:20px;align-items:start}
.stack{display:grid;gap:14px}
.section-head{display:grid;gap:10px}
.section-head .prose{margin:0 auto}
.mt-20{margin-top:20px}
.contact-form{max-width:900px;margin:20px auto 0}
.contact-split{display:grid;grid-template-columns:1fr;gap:20px;align-items:start}

/* Anchor safety under fixed nav */
section[id], header[id], main[id], article[id]{scroll-margin-top:88px}

.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:.5rem;
  padding:.85rem 1.2rem;
  border-radius:999px;
  border:1px solid #d98ca6;
  background:var(--red-600);
  color:#fff;
  font-weight:700;
  box-shadow:4px 4px 0 rgba(0,0,0,.10);
}
.btn-sm{padding:.62rem .95rem;font-size:.92rem}
.btn-md{padding:.85rem 1.2rem;font-size:1rem}
.btn:hover{filter:brightness(.96)}
.btn.ghost{background:#fff;color:var(--red-600)}

.input{
  width:100%;
  padding:.9rem 1rem;
  border-radius:12px;
  border:1px solid var(--hair);
  background:#fff;
  color:var(--ink);
  box-sizing:border-box;
}
label span{display:block;margin-bottom:6px;color:var(--ink);font-weight:600}

.textbox{
  position:relative;
  border:1px solid var(--red-600);
  border-radius:var(--radius);
  padding:22px 20px 22px 66px;
  background:linear-gradient(90deg,var(--red-600) 0 10px,#fff 10px);
  box-shadow:6px 6px 0 rgba(0,0,0,.08);
  min-height:160px;
  margin-top:18px; /* safe space for top badge */
}
.textbox h3{color:var(--red-600)}
.badge{
  position:absolute;
  top:-18px;
  left:16px;
  width:40px;
  height:40px;
  border-radius:50%;
  border:1px solid var(--red-600);
  background:#fff;
  color:var(--red-600);
  display:grid;
  place-items:center;
  font-size:.75rem;
  font-weight:700;
}

.cta-pink{
  background:var(--pink-100);
  color:var(--ink);
}
.cta-pink h2,.cta-pink p,.cta-pink a:not(.btn){color:var(--ink)}

.media-card{
  border:1px solid var(--hair);
  border-radius:var(--radius);
  overflow:hidden;
  background:#fff;
  box-shadow:6px 6px 0 rgba(0,0,0,.08);
  aspect-ratio:4/3;
}
.media-card img{display:block;width:100%;height:100%;object-fit:cover}
.hero-split{display:grid;grid-template-columns:1fr;gap:20px;align-items:center}
.profile-photo{aspect-ratio:3/4;max-height:none}

footer{background:var(--pink-500);color:#fff;padding:64px 0}
footer a{color:#fff}
.footer-grid{display:grid;gap:20px;grid-template-columns:1fr}
.foot-links{list-style:none;padding:0;margin:0;display:grid;gap:8px}

@media(min-width:760px){
  .container{padding:0 24px}
  section{padding:104px 0}
  .grid{gap:26px}
  .cols-3{grid-template-columns:repeat(2,minmax(0,1fr))}
  .hero-split{grid-template-columns:1.1fr .9fr;gap:28px}
  .split-2{grid-template-columns:1.05fr .95fr;gap:28px}
  .contact-split{grid-template-columns:1fr 1fr;gap:28px}
}

@media(min-width:980px){
  section{padding:124px 0}
  .grid{gap:34px}
  .cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}
  .grid.cols-3{align-items:stretch}
  .grid.cols-3 > .textbox,
  .grid.cols-3 > .media-card{height:100%}
  .grid.cols-3 > .textbox{display:flex;flex-direction:column}
  .footer-grid{grid-template-columns:1.2fr 1fr 1fr}
  #profil .grid,#kontaktformular .grid,#zert-teaser .grid{gap:42px}
}

@media(max-width:900px){
  #profil .grid,
  #kontaktformular .grid,
  #zert-teaser .grid,
  .hero-split{
    grid-template-columns:1fr !important;
    gap:20px !important;
  }
}
