:root{
  --bg:#000000;
  --panel:#000000;
  --line:#0f1012;
  --text:#eef2f5;
  --muted:#c7d0d8;
  --sub:#9aa9b8;
  --sub-2:#7f8c99;
  --accent:#8ea4b8;
  --content:1600px;
  --rail:120px;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  min-width:320px;
  background:var(--bg);
  color:var(--text);
  font-family:Inter,system-ui,-apple-system,"Segoe UI",sans-serif;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
a{color:inherit;text-decoration:none}
img{display:block;max-width:100%}
.skip-link{position:absolute;left:-9999px;top:0}
.skip-link:focus{left:1rem;top:1rem;z-index:1000;background:#fff;color:#000;padding:.75rem 1rem;border-radius:999px}
.page-shell{max-width:1600px;margin:0 auto;background:#000}
.shell-inner{width:min(calc(100% - 2.5rem), 1488px);margin:0 auto}
.hero-wrap{min-height:100svh;display:grid;grid-template-columns:120px 1fr;border-bottom:1px solid var(--line)}
.side-rail{border-right:1px solid var(--line);display:flex;flex-direction:column;justify-content:space-between}
.side-rail__vertical{writing-mode:vertical-rl;transform:rotate(180deg);font-size:11px;letter-spacing:.45em;text-transform:uppercase;color:var(--sub);padding:32px 24px}
.side-rail__bottom{padding:32px 24px;font-size:11px;letter-spacing:.35em;text-transform:uppercase;color:var(--sub-2)}
.hero-main{padding:24px 56px 40px;display:flex;flex-direction:column;min-height:100svh;background:#000}
.topbar{display:flex;align-items:center;justify-content:space-between;padding-bottom:20px;border-bottom:1px solid var(--line);gap:2rem}
.brand{display:inline-flex;align-items:center}
.brand-logo{height:58px;width:auto;display:block;filter:none}
.site-nav{display:flex;gap:32px;font-size:14px;color:#b8c4cf;align-items:center}
.site-nav a:hover,.site-nav a:focus-visible{color:#fff}
.nav-toggle{display:none;width:46px;height:46px;border:1px solid rgba(255,255,255,.14);border-radius:14px;background:transparent;position:relative;padding:0}
.nav-toggle span:not(.visually-hidden){position:absolute;left:12px;right:12px;height:2px;background:var(--text);border-radius:2px}
.nav-toggle span:nth-child(1){top:15px}.nav-toggle span:nth-child(2){top:22px}.nav-toggle span:nth-child(3){top:29px}
.visually-hidden{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}
.hero-stage{position:relative;flex:1;overflow:hidden}
.hero-media,.hero-image,.hero-overlay{position:absolute;inset:0}
.hero-image{width:100%;height:100%;object-fit:cover;filter:grayscale(1);opacity:.9}
.hero-overlay{background:linear-gradient(90deg,rgba(0,0,0,.76),rgba(0,0,0,.48),rgba(0,0,0,.30)),linear-gradient(180deg,rgba(0,0,0,.12),transparent 45%,rgba(0,0,0,.60));backdrop-filter:blur(.6px)}
.hero-grid{position:relative;display:grid;grid-template-columns:1.15fr .85fr;align-items:end;gap:48px;flex:1;padding:56px 0 80px;overflow:hidden;min-height:calc(100svh - 103px);z-index:1}
.hero-copy,.hero-intro{position:relative;z-index:2}
h1,h2,h3,.director-name,.privacy-title{font-family:"Iowan Old Style","Palatino Linotype","Book Antiqua",Georgia,serif;font-weight:400;margin:0}
.hero-copy h1{font-size:clamp(3.4rem,8vw,8.5rem);line-height:.92;letter-spacing:-.05em;max-width:980px;color:#f3f7fa}
.hero-intro{max-width:530px;justify-self:end}
.hero-intro p,.prose p,.fact-card p,.service-item p,.director-quote,.privacy-content p,.checkbox-field label{text-align:justify;hyphens:auto;text-wrap:pretty}
.hero-intro p{font-size:1.125rem;line-height:2.25rem;color:var(--muted);margin:0}
.hero-actions{display:flex;gap:16px;flex-wrap:wrap;margin-top:40px}
.button{display:inline-flex;align-items:center;justify-content:center;padding:14px 24px;border-radius:0;border:1px solid transparent;min-height:auto;font:inherit;font-size:12px;text-transform:uppercase;letter-spacing:.24em;cursor:pointer;transition:.2s ease}
.button-primary{border-color:var(--accent);background:transparent;color:#f3efe7}
.button-primary:hover,.button-primary:focus-visible{background:var(--accent);color:#000}
.button-secondary{border-color:#4a443e;background:transparent;color:#c3cdd7}
.button-secondary:hover,.button-secondary:focus-visible{border-color:var(--accent);color:#fff}
.section{padding:0;border-bottom:1px solid var(--line);background:#000}
.split-section{padding-top:0}
.section-grid,.director-grid,.contact-grid{display:grid;gap:0}
.section-grid{grid-template-columns:1.15fr .85fr}
.section-grid > :first-child{padding:64px 56px 96px}
.section-grid > :last-child{padding:64px 56px 96px}
#profil .section-grid > :last-child{border-left:1px solid var(--line)}
.section-label{font-size:11px;letter-spacing:.35em;text-transform:uppercase;color:var(--sub);margin:0}
.prose-large p{margin-top:40px;max-width:880px;font-size:clamp(1.45rem,2.1vw,2.2rem);line-height:1.45;color:#edf3f8}
.prose p,.fact-card p,.service-item p,.privacy-content p,.contact-details .prose p{margin:0;line-height:2rem;color:var(--muted)}
.prose p + p,.contact-details .prose p + p{margin-top:1rem}
.facts-grid{display:grid;gap:40px}

.subsection-label{margin:0 0 14px;font-size:11px;letter-spacing:.35em;text-transform:uppercase;color:var(--sub);font-family:Inter,system-ui,-apple-system,"Segoe UI",sans-serif;font-weight:500}
#profil .prose-large p{max-width:920px;text-wrap:pretty;hyphens:auto}
.facts-grid p{text-wrap:pretty;hyphens:auto}
.hero-intro p{text-wrap:pretty;hyphens:auto}
.service-item p,.contact-details .prose p,.privacy-content p{hyphens:auto;text-wrap:pretty}
.fact-card,.form-card{padding:0;border:0;background:transparent;border-radius:0;box-shadow:none}
.form-card > .section-label{margin-bottom:20px}
.privacy-content h2{margin:0 0 16px;font-family:"Iowan Old Style","Palatino Linotype","Book Antiqua",Georgia,serif;font-size:1.18rem;font-weight:400;color:#eef4f8}
#leistungen .section-grid{grid-template-columns:.9fr 1.1fr;gap:80px;padding:64px 56px 96px;align-items:start}
#leistungen .section-grid > :first-child,#leistungen .section-grid > :last-child{padding:0}
.section-title{margin-top:32px;max-width:620px;font-size:clamp(2.2rem,4vw,4.4rem);line-height:1.02;letter-spacing:-.04em;color:#f3f7fa}
.service-list{border-top:1px solid var(--line)}
.service-item{padding:32px 0;border-bottom:1px solid var(--line)}
.service-item:last-child{border-bottom:0}
.service-item h3{font-size:2rem;color:#eef4f8;font-weight:500}
.service-item p{margin-top:16px;max-width:760px}
.director-section{background:#000}
.director-center{max-width:760px;text-align:center;padding:64px 56px 96px;margin:0 auto}
.director-image-frame{overflow:hidden;border-radius:28px;border:0;background:transparent;box-shadow:none}
.director-image-frame--center{max-width:430px;margin:0 auto}
.director-image{width:100%;height:auto;object-fit:cover}
.director-name{margin-top:32px;font-size:clamp(2rem,3.8vw,4rem);line-height:1.04;letter-spacing:-.04em;color:#f3f7fa}
.director-role{margin-top:12px;font-size:16px;letter-spacing:.24em;text-transform:uppercase;color:var(--sub)}
.director-quote{margin:32px auto 0;max-width:620px;color:var(--sub);font-style:italic;line-height:2rem;text-align:center}
#kontakt .contact-grid{grid-template-columns:.9fr 1.1fr;gap:64px;padding:64px 56px 96px}
.contact-grid > *{min-width:0}
.field,.checkbox-field{display:grid;gap:0}
.field-grid{display:grid;grid-template-columns:1fr 1fr;gap:20px}
.field label{display:block;margin:0 0 6px;color:#b8c4cf;font-size:14px;line-height:1.35}
.field input,.field textarea,.field select{width:100%;background:#000;border:1px solid #2f2f2f;border-radius:14px;padding:14px 16px;color:#f3efe7;font:inherit}
.field input:focus,.field textarea:focus,.field select:focus{outline:none;border-color:var(--accent);box-shadow:none}
.field textarea{min-height:160px;resize:vertical}
.checkbox-field{display:flex;gap:12px;align-items:flex-start;padding:16px;border:1px solid #16181b;border-radius:14px;background:#000;font-size:14px;color:#b8c4cf}
.checkbox-field input{margin-top:4px;accent-color:var(--accent)}
.form-note{display:none}
.site-footer{padding:18px 0 36px;background:#000}
.footer-grid{display:flex;justify-content:space-between;align-items:center;gap:1rem;color:var(--sub);font-size:.94rem}.footer-grid p{margin:0}.footer-links{display:flex;flex-wrap:wrap;gap:1rem 1.25rem}
.site-header,.site-header-solid,.header-shell,.static-nav{display:none}
.privacy-page{padding-top:0;background:#000}
.privacy-shell{max-width:1100px;padding:40px 56px 56px;margin:0 auto}
.privacy-topbar{display:flex;align-items:center;justify-content:space-between;border-bottom:1px solid var(--line);padding-bottom:20px}
.privacy-brand{height:56px;width:auto}
.privacy-back{font-size:14px;letter-spacing:.22em;text-transform:uppercase;color:#b8c4cf}
.privacy-head{margin-top:56px;max-width:760px}
.privacy-head .section-label{margin-bottom:24px}
.privacy-title{font-size:clamp(2.6rem,4.8vw,4.8rem);line-height:.98;letter-spacing:-.04em;color:#f3f7fa}
.privacy-content{margin-top:48px;color:var(--muted)}
.privacy-content section{padding:0 0 48px;border-top:0}
.privacy-content h2{font-size:2rem;margin-bottom:16px}

@media (max-width:1100px){
  #leistungen .section-grid{padding:48px 24px 64px;}
  #leistungen .section-grid > :first-child{padding:0 0 28px;}
  #leistungen .section-grid > :last-child{padding:0;}
  .service-list{width:100%;}
}
@media (max-width:640px){
  #leistungen .section-grid{padding:40px 20px 52px;}
  #leistungen .section-grid > :first-child{padding:0 0 22px;}
  #leistungen .section-grid > :last-child{padding:0;}
  .service-item{padding:26px 0;}
}
@media (max-width:1100px){
  .topbar{gap:1rem}
  .hero-intro{max-width:100%;justify-self:start}
  .hero-intro p{max-width:42rem}
  .facts-grid{gap:32px}
  .section-title{max-width:680px}
  .hero-wrap{grid-template-columns:1fr}
  .side-rail{display:none}
  .hero-main{padding:20px 24px 32px}
  .hero-grid,.section-grid,.contact-grid{grid-template-columns:1fr}
  .section-grid > :first-child,.section-grid > :last-child,#leistungen .section-grid,#kontakt .contact-grid,.director-center{padding:48px 24px 64px}
  #profil .section-grid > :last-child{border-left:none;border-top:1px solid var(--line)}
  .site-nav{display:none}
  .nav-toggle{display:inline-block}
  .site-nav.is-open{display:flex;position:absolute;top:82px;right:24px;left:24px;flex-direction:column;align-items:flex-start;gap:0;padding:8px;background:#000;border:1px solid rgba(255,255,255,.08);border-radius:20px}
  .site-nav.is-open a{width:100%;padding:14px 16px;border-radius:14px}
  .site-nav.is-open a:hover{background:rgba(255,255,255,.04)}
  .director-image-frame--center{max-width:340px}
  .privacy-shell{padding:32px 24px 48px}
}
@media (max-width:640px){
  .section-grid > :first-child,.section-grid > :last-child,#leistungen .section-grid,#kontakt .contact-grid,.director-center{padding:40px 20px 52px}
  .hero-main{padding:16px 20px 28px}
  .hero-intro p,.prose p,.fact-card p,.service-item p,.contact-details .prose p{line-height:1.8rem;text-align:justify}
  .prose-large p{font-size:1.14rem;line-height:1.6}
  .section-title{margin-top:24px}
  .subsection-label,.section-label{font-size:10px;letter-spacing:.28em}
  .hero-copy h1{font-size:clamp(2.5rem,14vw,4.3rem)}
  .prose-large p{font-size:1.25rem}
  .field-grid{grid-template-columns:1fr}
  .brand-logo{height:44px}
  .hero-grid{padding:40px 0 56px;min-height:auto}
  .service-item h3{font-size:1.55rem}
  .hero-actions{flex-direction:column}
  .button{width:100%}
  .footer-grid{flex-direction:column;align-items:flex-start}
}


.section-services{padding:64px 0 96px;border-bottom:1px solid var(--line);}
.services-stack{display:grid;grid-template-columns:.92fr 1.08fr;gap:80px;align-items:start;}
.services-head{max-width:620px;}
.services-head .section-title{max-width:620px;}
.service-list--stacked{max-width:none;margin-top:0;border-top:1px solid var(--line);}
.service-list--stacked .service-item{padding:30px 0;}

@media (max-width:1100px){
  .section-services{padding:48px 0 64px;}
  .services-stack{grid-template-columns:.96fr 1.04fr;gap:40px;align-items:start;}
  .services-head{max-width:420px;}
  .services-head .section-title{max-width:420px;}
  .service-list--stacked{margin-top:0;max-width:none;}
}
@media (max-width:640px){
  .section-services{padding:40px 0 52px;}
  .services-stack{display:block;}
  .services-head{max-width:none;}
  .services-head .section-title{max-width:12ch;margin-top:24px;font-size:clamp(2rem,9.4vw,2.65rem);line-height:1.04;}
  .service-list--stacked{margin-top:22px;}
  .service-list--stacked .service-item{padding:24px 0;}
  .contact-details .section-label,
  .contact-details .section-title,
  .contact-details .prose,
  .contact-details .prose p{hyphens:none;word-break:normal;overflow-wrap:normal;text-align:left;text-wrap:pretty;}
}
