/* ============================================================
   praxiskonzeption · arnd kensy — Praxiskauf & Praxisgründung
   Rebuilt 1:1 from the Safari webarchive + design spec.
   Values calibrated against the original render (≤5% deviation).
   ============================================================ */

/* ---------- Fonts: League Spartan (self-hosted woff2) ---------- */
@font-face{font-family:"League Spartan";font-style:normal;font-weight:300;font-display:swap;src:url("assets/fonts/ls-300.woff2") format("woff2");}
@font-face{font-family:"League Spartan";font-style:normal;font-weight:400;font-display:swap;src:url("assets/fonts/ls-400.woff2") format("woff2");}
@font-face{font-family:"League Spartan";font-style:normal;font-weight:500;font-display:swap;src:url("assets/fonts/ls-500.woff2") format("woff2");}
@font-face{font-family:"League Spartan";font-style:normal;font-weight:600;font-display:swap;src:url("assets/fonts/ls-600.woff2") format("woff2");}
@font-face{font-family:"League Spartan";font-style:normal;font-weight:700;font-display:swap;src:url("assets/fonts/ls-700.woff2") format("woff2");}

/* ---------- Design tokens ---------- */
:root{
  --navy:#0E2E5D;
  --teal:#2DA2B2;
  --sage:#D7E7C2;
  --green:#39B54A;
  --white:#FFFFFF;
  --offwhite:#FAFAFA;
  --surface:#F5F5F5;
  --border:#E5E5E5;
  --hover:#3A3A3A;

  --font:"League Spartan","Roboto",sans-serif;
  --container:1340px;
  --text-col:760px;        /* constrained centred text column */

  --shadow-card:0 10px 35px rgba(14,46,93,.10);
}

/* ---------- Reset ---------- */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%;}
body{
  font-family:var(--font);
  font-weight:400;
  font-size:15px;
  line-height:1.65;
  color:var(--navy);
  background:var(--white);
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
img{max-width:100%;display:block;}
a{color:var(--teal);text-decoration:none;transition:color .2s ease;}
a:hover{color:var(--hover);}
button{font-family:inherit;cursor:pointer;border:none;background:none;}
/* lange deutsche Komposita in Überschriften sauber umbrechen statt überlaufen (mobil) */
h1,h2,h3,h4,h5,h6,.eyebrow{overflow-wrap:break-word;-webkit-hyphens:auto;hyphens:auto;}

/* ---------- Layout helpers ---------- */
.container{width:100%;max-width:var(--container);margin:0 auto;padding:0 24px;}
.section{padding:78px 0;}
.section--alt{background:var(--offwhite);}
.center{text-align:center;}
.text-col{max-width:var(--text-col);margin-left:auto;margin-right:auto;}

/* ---------- Shared type roles ---------- */
.eyebrow{
  font-size:24px;font-weight:700;line-height:1;color:var(--navy);
  text-transform:uppercase;letter-spacing:.5px;margin-bottom:18px;
}
.section-title{
  font-size:36px;font-weight:600;line-height:1.4;color:var(--navy);
  text-transform:uppercase;letter-spacing:.5px;
}
.lead{
  font-size:23px;font-weight:400;line-height:1.32;color:var(--navy);
  margin:26px auto 0;max-width:680px;
}
.body-text{font-size:18px;font-weight:400;line-height:1.65;color:var(--navy);}
.body-text + .body-text{margin-top:20px;}

/* muted body (the thinner paragraph blocks read slightly lighter) */
.body-soft{color:#3f5675;}

/* ---------- Buttons ---------- */
.btn{
  display:inline-block;font-size:15px;font-weight:400;line-height:1;
  color:var(--white);background:var(--navy);
  padding:15px 41px;border-radius:3px;letter-spacing:.4px;
  transition:background .2s ease;
}
.btn:hover{background:var(--hover);color:var(--white);}
.btn--teal{background:var(--teal);}
.btn--teal:hover{background:var(--hover);}

/* ============================================================
   HEADER  (logo left · search + burger right · sticky)
   ============================================================ */
.site-header{
  position:sticky;top:0;z-index:50;background:var(--white);
  border-bottom:1px solid var(--border);
  box-shadow:0 1px 8px rgba(14,46,93,.05);
}
.site-header .container{
  display:flex;align-items:center;justify-content:space-between;
  min-height:96px;
}
.brand img{height:54px;width:auto;}
.header-actions{display:flex;align-items:center;gap:22px;}
.icon-btn{
  width:30px;height:30px;display:grid;place-items:center;color:var(--navy);
  background:none;border:none;
}
.icon-btn svg{width:22px;height:22px;}
.icon-btn:hover{color:var(--teal);}

/* nav drawer */
.nav-drawer{
  position:fixed;inset:0 0 0 auto;width:min(360px,86vw);
  background:var(--navy);transform:translateX(100%);
  transition:transform .32s cubic-bezier(.4,0,.2,1);
  z-index:60;padding:90px 38px 40px;display:flex;flex-direction:column;gap:6px;
  box-shadow:-12px 0 40px rgba(0,0,0,.25);
}
.nav-drawer.open{transform:translateX(0);}
.nav-drawer a{
  color:var(--white);font-size:18px;font-weight:600;text-transform:uppercase;
  letter-spacing:.5px;padding:14px 0;border-bottom:1px solid rgba(255,255,255,.12);
}
.nav-drawer a:hover{color:var(--teal);}
.nav-close{position:absolute;top:26px;right:30px;color:var(--white);width:30px;height:30px;font-size:26px;line-height:1;}
.nav-backdrop{
  position:fixed;inset:0;background:rgba(14,46,93,.45);opacity:0;visibility:hidden;
  transition:opacity .3s ease;z-index:55;
}
.nav-backdrop.open{opacity:1;visibility:visible;}

/* search bar (revealed) */
.search-bar{
  max-height:0;overflow:hidden;background:var(--offwhite);
  border-bottom:1px solid var(--border);transition:max-height .3s ease;
}
.search-bar.open{max-height:90px;}
.search-bar .container{display:flex;padding-top:18px;padding-bottom:18px;}
.search-bar input{
  flex:1;font-family:inherit;font-size:16px;color:var(--navy);
  padding:12px 16px;border:1px solid var(--border);border-radius:3px;background:var(--white);
}

/* ============================================================
   HERO IMAGE BAND
   ============================================================ */
.hero-image{
  width:100%;height:clamp(300px,30vw,420px);
  background:url("assets/hero.jpg") center 38%/cover no-repeat;
}
/* page variant: Praxisoptimierung hero */
.hero-image--opt{background-image:url("assets/hero-opt.jpg");background-position:center 42%;}

/* ============================================================
   HERO INTRO (centred text)
   ============================================================ */
.hero-intro{background:var(--offwhite);padding:92px 0 76px;}

/* ============================================================
   SERVICES — teal band + card grid
   ============================================================ */
.services{
  background:#2DA2B2 url("assets/teal-x.jpg") center/cover no-repeat;
  padding:74px 0;
}
.services .section-title{color:var(--white);font-size:24px;line-height:1.3;margin-bottom:42px;}
.cards{
  display:grid;grid-template-columns:repeat(3,1fr);gap:24px;
  max-width:1180px;margin:0 auto;
}
.card{
  background:rgba(255,255,255,.94);border-radius:4px;
  padding:38px 34px;text-align:center;
  box-shadow:0 8px 26px rgba(0,0,0,.10);
}
.card h3{
  font-size:22px;font-weight:700;line-height:1.25;color:var(--navy);
  text-transform:uppercase;letter-spacing:.3px;margin-bottom:16px;
}
.card p{font-size:15px;font-weight:400;line-height:1.6;color:var(--navy);}

/* ============================================================
   STIMMEN — navy testimonial carousel
   ============================================================ */
.stimmen{background:var(--navy);padding:70px 0 64px;color:var(--white);}
.stimmen .section-title{color:var(--white);font-size:24px;margin-bottom:34px;}
.carousel{position:relative;max-width:880px;margin:0 auto;overflow:hidden;}
.slides{display:flex;transition:transform .5s ease;}
.slide{flex:0 0 100%;padding:14px 30px 6px;text-align:center;}
.slide .quote{
  font-size:22px;font-weight:400;font-style:italic;line-height:1.5;color:var(--white);
}
.slide .qname{
  display:block;margin-top:26px;font-size:22px;font-weight:300;
  text-transform:uppercase;letter-spacing:.5px;color:var(--white);
}
.slide .qurl{display:block;margin-top:8px;font-size:14px;font-weight:700;color:var(--teal);}
.slide .qurl a{color:var(--teal);}
.dots{display:flex;justify-content:center;gap:12px;margin-top:34px;}
.dot{width:9px;height:9px;border-radius:50%;background:rgba(255,255,255,.4);transition:background .2s,transform .2s;}
.dot.active{background:var(--teal);transform:scale(1.15);}

/* ============================================================
   LEITFADEN — book CTA band with overlay card
   ============================================================ */
.leitfaden{
  background:#e9eaf0 url("assets/book-band.jpg") center/cover no-repeat;
  padding:64px 0;
}
/* page variant: Praxisoptimierung book band (teal book on grey) */
.leitfaden--opt{background-color:#e7e8ea;background-image:url("assets/book-opt.webp");background-position:center right;}
.leitfaden .container{display:flex;}
.cta-card{
  background:rgba(255,255,255,.86);backdrop-filter:blur(2px);
  border-radius:4px;padding:42px 46px;max-width:470px;
  box-shadow:var(--shadow-card);
}
.cta-card .eyebrow{margin-bottom:14px;}
.cta-card h3{
  font-size:27px;font-weight:600;line-height:1.25;color:var(--navy);
  text-transform:uppercase;letter-spacing:.3px;margin-bottom:14px;
}
.cta-card p{font-size:15px;line-height:1.6;color:var(--navy);margin-bottom:26px;}

/* ============================================================
   MEIN BUCH — centred text + CTA
   ============================================================ */
.mein-buch{background:var(--offwhite);padding:86px 0 90px;}
.mein-buch .lead{max-width:760px;}
.mein-buch .btn{margin-top:30px;}

/* ============================================================
   CONTACT — sage band, white card, 2 columns
   ============================================================ */
.contact{
  background:#D7E7C2 url("assets/green-x.jpg") center/cover no-repeat;
  padding:64px 0 60px;
}
.contact-card{
  background:var(--white);border-radius:5px;box-shadow:var(--shadow-card);
  display:grid;grid-template-columns:1fr 1fr;gap:54px;padding:52px 56px;
}
.contact-info .ksmall{font-size:18px;font-weight:700;text-transform:uppercase;letter-spacing:.4px;color:var(--navy);}
.contact-info h2.section-title{font-size:28px;line-height:1.3;margin:6px 0 22px;}
.contact-info p{font-size:15px;line-height:1.65;color:var(--navy);max-width:360px;}
.contact-detail{margin-top:28px;}
.contact-detail .name{font-size:16px;font-weight:700;text-transform:uppercase;letter-spacing:.4px;color:var(--navy);margin-bottom:12px;}
.contact-detail .row{font-size:15px;margin-bottom:6px;color:var(--navy);}
.contact-detail .row b{font-weight:700;}
.contact-detail .row a{color:var(--teal);font-weight:700;}
.insta{
  margin-top:20px;display:inline-grid;place-items:center;width:42px;height:42px;
  background:var(--navy);border-radius:6px;color:var(--white);
}
.insta:hover{background:var(--teal);color:var(--white);}
.insta svg{width:22px;height:22px;}

/* form */
.contact-form{display:flex;flex-direction:column;gap:16px;}
.contact-form input,
.contact-form select,
.contact-form textarea{
  width:100%;font-family:inherit;font-size:15px;color:var(--navy);
  padding:14px 16px;border:1px solid var(--border);border-radius:4px;
  background:var(--white);
}
.contact-form textarea{min-height:120px;resize:vertical;}
.contact-form select{appearance:none;background:var(--white) url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath fill='%230E2E5D' d='M1 1l5 5 5-5'/%3E%3C/svg%3E") no-repeat right 16px center;}
.consent{display:flex;gap:10px;align-items:flex-start;font-size:13px;line-height:1.55;color:var(--navy);}
.consent input{width:auto;margin-top:3px;flex:0 0 auto;}
.contact-form .btn{align-self:flex-end;margin-top:4px;}

/* ============================================================
   FOOTER
   ============================================================ */
.footer-nav{
  background:#D7E7C2 url("assets/green-x.jpg") center/cover no-repeat;
  padding:54px 0 70px;
}
.footer-nav ul{list-style:none;display:flex;flex-direction:column;gap:22px;}
.footer-nav a{
  font-size:24px;font-weight:700;text-transform:uppercase;letter-spacing:.4px;color:var(--navy);
}
.footer-nav a:hover{color:var(--teal);}
.footer-bar{background:var(--white);padding:26px 0;font-size:13px;color:var(--navy);}
.footer-bar .container{display:flex;align-items:center;justify-content:space-between;gap:24px;flex-wrap:wrap;}
.footer-bar .legal a{color:var(--navy);font-weight:600;}
.footer-bar .legal a:hover{color:var(--teal);}
.footer-bar .legal .sep{margin:0 8px;color:var(--border);}
.footer-bar .copyright{margin-top:6px;color:#6b7686;}
.footer-bar .brand-mid img{height:38px;}
.footer-bar .credits{text-align:right;color:#6b7686;line-height:1.5;}
.footer-bar .credits a{color:var(--teal);}

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media(max-width:1024px){
  .cards{grid-template-columns:repeat(2,1fr);}
  .footer-bar .container{justify-content:center;text-align:center;}
  .footer-bar .credits{text-align:center;}
}
@media(max-width:767px){
  body{font-size:15px;}
  .section,.hero-intro,.services,.stimmen,.mein-buch,.contact{padding-left:0;padding-right:0;}
  .hero-intro{padding:56px 0 48px;}
  .section-title,.hero-intro .section-title{font-size:30px;}
  .eyebrow{font-size:20px;}
  .lead{font-size:20px;}
  .cards{grid-template-columns:1fr;gap:18px;}
  .cta-card{max-width:none;padding:32px 28px;}
  .leitfaden{background-position:right -120px top;}
  .contact-card{grid-template-columns:1fr;gap:34px;padding:34px 26px;}
  .contact-info p{max-width:none;}
  .footer-bar .container{flex-direction:column;}
  .site-header .container{min-height:78px;}
  .brand img{height:44px;}
}

/* ============================================================
   LEISTUNGS-UNTERSEITEN  (Beratungsschwerpunkte im Detail)
   ============================================================ */

/* --- klickbare Schwerpunkt-Kacheln --- */
a.card{display:block;text-decoration:none;cursor:pointer;transition:transform .22s ease,box-shadow .22s ease;}
a.card:hover{transform:translateY(-5px);box-shadow:0 18px 44px rgba(14,46,93,.20);}
.card .more{display:inline-block;margin-top:16px;font-size:13px;font-weight:700;letter-spacing:.5px;text-transform:uppercase;color:var(--teal);}
.card .more::after{content:" →";}
a.card:hover .more{color:var(--navy);}

/* --- Subpage-Hero (Foto + Overlay + Titel) --- */
.subhero{position:relative;display:flex;align-items:flex-end;min-height:360px;background:var(--navy) center/cover no-repeat;}
.subhero::before{content:"";position:absolute;inset:0;background:linear-gradient(160deg,rgba(14,46,93,.52),rgba(14,46,93,.85));}
.subhero--teal::before{background:linear-gradient(160deg,rgba(14,46,93,.30),rgba(45,162,178,.85));}
.subhero .container{position:relative;z-index:2;padding-top:58px;padding-bottom:48px;}
.breadcrumb{font-size:13px;font-weight:600;letter-spacing:.5px;text-transform:uppercase;color:rgba(255,255,255,.82);margin-bottom:18px;}
.breadcrumb a{color:rgba(255,255,255,.82);}
.breadcrumb a:hover{color:#fff;}
.breadcrumb .sep{margin:0 9px;opacity:.5;}
.subhero h1{color:#fff;font-size:42px;font-weight:600;line-height:1.18;text-transform:uppercase;letter-spacing:.5px;max-width:780px;}
.subhero .sub-lead{color:rgba(255,255,255,.92);font-size:19px;line-height:1.45;max-width:700px;margin-top:18px;}

/* --- Inhalt: Text + seitliche Spalte --- */
.leistung-grid{display:grid;grid-template-columns:1.35fr .65fr;gap:50px;align-items:start;}
.leistung-grid .aside{background:var(--offwhite);border:1px solid var(--border);border-radius:8px;padding:32px 30px;position:sticky;top:118px;}
.leistung-grid .aside h3{font-size:15px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:var(--navy);margin-bottom:16px;}

/* --- Ablauf-Schritte --- */
.steps{list-style:none;counter-reset:step;display:grid;gap:22px;margin-top:10px;}
.steps li{counter-increment:step;position:relative;padding-left:64px;}
.steps li::before{content:counter(step,decimal-leading-zero);position:absolute;left:0;top:-2px;width:46px;height:46px;display:grid;place-items:center;background:var(--teal);color:#fff;border-radius:50%;font-weight:700;font-size:16px;}
.steps li h4{font-size:18px;font-weight:700;color:var(--navy);text-transform:uppercase;letter-spacing:.3px;margin-bottom:5px;}
.steps li p{font-size:16px;line-height:1.6;color:var(--navy);}

/* --- Häkchen-Liste --- */
.ticks{list-style:none;display:grid;gap:13px;}
.ticks li{position:relative;padding-left:34px;font-size:16px;line-height:1.5;color:var(--navy);}
.ticks li::before{content:"";position:absolute;left:0;top:2px;width:21px;height:21px;background:var(--teal);border-radius:50%;}
.ticks li::after{content:"";position:absolute;left:7px;top:6px;width:5px;height:10px;border:solid #fff;border-width:0 2px 2px 0;transform:rotate(45deg);}

/* --- FAQ-Akkordeon --- */
.faq-wrap{max-width:880px;margin:0 auto;}
.faq-item{border-bottom:1px solid var(--border);}
.faq-item:first-child{border-top:1px solid var(--border);}
.faq-item summary{list-style:none;cursor:pointer;padding:23px 46px 23px 0;position:relative;font-size:19px;font-weight:600;color:var(--navy);line-height:1.4;}
.faq-item summary::-webkit-details-marker{display:none;}
.faq-item summary::after{content:"+";position:absolute;right:4px;top:50%;transform:translateY(-50%);font-size:28px;font-weight:400;color:var(--teal);line-height:1;}
.faq-item[open] summary::after{content:"–";}
.faq-item .faq-a{padding:0 46px 26px 0;font-size:16px;line-height:1.72;color:var(--navy);}

/* --- Foto-Band --- */
.imgband{height:320px;background:var(--surface) center/cover no-repeat;position:relative;}
.imgband--tint::after{content:"";position:absolute;inset:0;background:rgba(45,162,178,.26);}

/* --- Schluss-CTA --- */
.cta-band{background:var(--navy);color:#fff;text-align:center;padding:66px 0;}
.cta-band h2{color:#fff;font-size:30px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;margin-bottom:14px;}
.cta-band p{color:rgba(255,255,255,.9);font-size:17px;line-height:1.6;max-width:620px;margin:0 auto 28px;}
.cta-band .btn--teal{background:var(--teal);}
.cta-band .btn--teal:hover{background:#fff;color:var(--navy);}

/* --- verwandte Schwerpunkte --- */
.related{background:var(--offwhite);}
.related-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-top:26px;}
.related-grid a{display:block;background:#fff;border:1px solid var(--border);border-radius:6px;padding:24px 26px;text-decoration:none;transition:transform .2s,box-shadow .2s,border-color .2s;}
.related-grid a:hover{border-color:var(--teal);transform:translateY(-3px);box-shadow:0 12px 30px rgba(14,46,93,.12);}
.related-grid a span{display:block;font-size:12px;font-weight:700;letter-spacing:.5px;text-transform:uppercase;color:var(--teal);margin-bottom:7px;}
.related-grid a strong{font-size:18px;font-weight:700;color:var(--navy);text-transform:uppercase;letter-spacing:.3px;line-height:1.25;}

@media(max-width:900px){
  .leistung-grid{grid-template-columns:1fr;gap:34px;}
  .leistung-grid .aside{position:static;}
  .related-grid{grid-template-columns:1fr 1fr;}
}
@media(max-width:767px){
  .subhero{min-height:300px;}
  .subhero h1{font-size:30px;}
  .subhero .sub-lead{font-size:17px;}
  .related-grid{grid-template-columns:1fr;}
  .faq-item summary{font-size:17px;}
  .steps li{padding-left:56px;}
}

/* ============================================================
   ARND KENSY / ÜBER MICH
   ============================================================ */
.portrait-hero{
  width:100%;height:clamp(360px,38vw,520px);
  background:#ffffff url("assets/arnd-kensy-portrait.jpg") center top/contain no-repeat;
}
.presse{background:var(--navy);padding:62px 0;}
.presse .section-title{color:#fff;font-size:24px;margin-bottom:38px;}
.press-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:26px;max-width:920px;margin:0 auto;}
.press-grid img{width:100%;height:auto;border-radius:6px;box-shadow:0 14px 34px rgba(0,0,0,.28);display:block;}
@media(max-width:767px){
  .portrait-hero{height:300px;background-size:contain;}
  .press-grid{grid-template-columns:1fr;gap:18px;max-width:340px;}
}

/* ============================================================
   RECHTSTEXT-SEITEN (Impressum, Datenschutz …)
   ============================================================ */
.legal-hero{background:var(--navy);color:#fff;padding:52px 0 44px;}
.legal-hero .breadcrumb{font-size:13px;font-weight:600;letter-spacing:.5px;text-transform:uppercase;color:rgba(255,255,255,.8);margin-bottom:14px;}
.legal-hero .breadcrumb a{color:rgba(255,255,255,.8);}
.legal-hero .breadcrumb a:hover{color:#fff;}
.legal-hero .breadcrumb .sep{margin:0 9px;opacity:.5;}
.legal-hero h1{color:#fff;font-size:40px;font-weight:600;line-height:1.15;text-transform:uppercase;letter-spacing:.5px;}
.legal-page{padding:54px 0 80px;}
.legal-page .wrap{max-width:840px;font-size:16px;line-height:1.7;color:var(--navy);overflow-wrap:break-word;}
.legal-page h5{font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:#8792a6;margin:14px 0 1px;}
.legal-page h2{font-size:23px;font-weight:700;color:var(--navy);text-transform:uppercase;letter-spacing:.4px;margin:40px 0 14px;}
.legal-page h2:first-child{margin-top:0;}
.legal-page h3{font-size:18px;font-weight:700;color:var(--navy);margin:26px 0 8px;}
.legal-page h4{font-size:16px;font-weight:700;color:var(--navy);margin:20px 0 6px;}
.legal-page p{font-size:16px;line-height:1.7;color:var(--navy);margin-bottom:14px;}
.legal-page ul,.legal-page ol{margin:0 0 16px 22px;}
.legal-page li{font-size:16px;line-height:1.7;color:var(--navy);margin-bottom:6px;}
.legal-page .addr{font-size:16px;line-height:1.85;color:var(--navy);margin-bottom:8px;}
.legal-page a{color:var(--teal);font-weight:600;word-break:break-word;}
@media(max-width:767px){.legal-hero h1{font-size:30px;}}

/* ============================================================
   HEADER: filigrane Direkteinstieg-Buttons (mittig)
   ============================================================ */
.header-cta{display:flex;gap:12px;margin:0 auto;}
.hbtn{
  font-size:13px;font-weight:600;letter-spacing:.6px;text-transform:uppercase;
  color:var(--navy);padding:9px 24px;border:1px solid var(--navy);border-radius:999px;
  white-space:nowrap;transition:background .2s ease,color .2s ease,border-color .2s ease;
}
.hbtn:hover{background:var(--navy);color:#fff;}
.hbtn--teal{color:var(--teal);border-color:var(--teal);}
.hbtn--teal:hover{background:var(--teal);color:#fff;border-color:var(--teal);}
@media(max-width:980px){.header-cta{display:none;}}

/* ============================================================
   Vollständiges Burger-Menü mit Unterpunkten
   ============================================================ */
.nav-drawer{overflow-y:auto;}
.nav-drawer a.nav-main{font-size:16px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;padding:13px 0;color:#fff;}
.nav-sub{display:flex;flex-direction:column;padding:8px 0 14px;}
.nav-sub a{font-size:13.5px;font-weight:400;color:rgba(255,255,255,.78);padding:6px 0 6px 18px;text-transform:none;letter-spacing:.2px;border-bottom:none;}
.nav-sub a:hover{color:var(--teal);}

/* gleich hohe Schwerpunkt-Kacheln (alle Reihen gleich hoch) */
.cards{grid-auto-rows:1fr;}

/* ============================================================
   Header-Buttons rechtsbündig: 22px Abstand zur Lupe (= Lupe↔Burger)
   ============================================================ */
.header-cta{margin-left:auto;margin-right:22px;}

/* ============================================================
   "Kontaktaufnahme"-Button (flächig Navy, Pill, zentriert)
   ============================================================ */
.btn-contact-wrap{text-align:center;margin-top:40px;}
.btn-contact{
  display:inline-block;font-size:13px;font-weight:600;letter-spacing:.6px;text-transform:uppercase;
  color:#fff;background:var(--navy);padding:13px 34px;border:1px solid var(--navy);border-radius:999px;
  transition:background .2s ease,border-color .2s ease;
}
.btn-contact:hover{background:#3A3A3A;border-color:#3A3A3A;color:#fff;}

/* mobiler schwebender Kontakt-Button (folgt beim Scrollen) */
.fab-contact{
  position:fixed;right:16px;bottom:16px;z-index:45;display:none;align-items:center;gap:8px;
  background:var(--navy);color:#fff;border-radius:999px;padding:13px 20px;
  font-size:13px;font-weight:600;letter-spacing:.5px;text-transform:uppercase;
  box-shadow:0 10px 26px rgba(14,46,93,.40);
}
.fab-contact svg{width:17px;height:17px;}
.fab-contact:hover{background:#3A3A3A;color:#fff;}
@media(max-width:767px){
  .btn-contact-wrap{display:none;}
  .fab-contact{display:inline-flex;}
}

/* ============================================================
   Header v2: Telefonnummer rechtsbündig + höherer Header
   ============================================================ */
.site-header .container{min-height:118px;align-items:center;}
.header-right{display:flex;flex-direction:column;align-items:flex-end;gap:11px;margin-left:auto;}
.header-top{display:flex;align-items:center;gap:22px;}
.header-cta{margin:0;}
.header-phone{display:inline-flex;align-items:center;gap:8px;font-size:16px;font-weight:600;color:var(--navy);letter-spacing:.3px;}
.header-phone svg{width:16px;height:16px;color:var(--teal);flex:none;}
.header-phone:hover{color:var(--teal);}

/* ============================================================
   Zweiter "Kontaktaufnahme"-Button unten vor dem Footer
   ============================================================ */
.btn-row{display:flex;gap:14px;justify-content:center;align-items:center;flex-wrap:wrap;margin-top:26px;}
.btn-bottom{text-align:center;padding:50px 0 6px;}
@media(max-width:767px){
  .is-extra{display:none;}
  .btn-bottom{display:none;}
  .header-phone{font-size:14px;gap:6px;}
  .header-right{gap:8px;}
}

.btn-row .btn,.btn-row .btn-contact{margin-top:0;}

/* Header-Telefon mobil sauber (kein Umbruch, kompakter) */
.header-phone{white-space:nowrap;}
@media(max-width:767px){
  .brand img{height:36px;}
  .header-phone{font-size:12.5px;gap:5px;}
  .header-phone svg{width:14px;height:14px;}
  .site-header .container{min-height:94px;}
}

/* Logo oben bündig mit der oberen Header-Zeile (Buttons bzw. Lupe) */
.site-header .container{align-items:flex-start;padding-top:24px;padding-bottom:20px;min-height:0;}
@media(max-width:767px){.site-header .container{padding-top:16px;padding-bottom:14px;}}

/* Header-Buttons gleich groß + Schrift vertikal/horizontal mittig */
.hbtn{display:inline-flex;align-items:center;justify-content:center;min-width:185px;}
