:root{
  --site-max-width: 1440px;
  --content-max-width: 1240px;
  --site-padding-desktop: 48px;
  --site-padding-tablet: 32px;
  --site-padding-mobile: 20px;
  --primary:#111111;
  --background:#ffffff;
  --surface:#f7f7f7;
  --surface-strong:#f1f1f1;
  --text:#374151;
  --muted:#6b7280;
  --line:#e5e7eb;
  --accent:#0e7490;
  --radius:24px;
  --shadow:0 24px 80px rgba(17,17,17,.06);
}
*{box-sizing:border-box}
html{scroll-behavior:smooth;overflow-x:hidden}
body{margin:0;font-family:Inter,system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;background:var(--background);color:var(--text);line-height:1.65;-webkit-font-smoothing:antialiased;overflow-x:hidden}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block;height:auto}
.container{
  width: min(100% - 96px, var(--site-max-width));
  margin-inline: auto;
}
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}
.site-header{position:sticky;top:0;z-index:50;background:rgba(255,255,255,.86);backdrop-filter:blur(16px);border-bottom:1px solid rgba(229,231,235,.8)}
.nav-wrap{height:76px;display:flex;align-items:center;justify-content:space-between;gap:32px}
.brand{font-weight:800;letter-spacing:.08em;font-size:.9rem;color:var(--primary);white-space:nowrap}
.site-nav{display:flex;align-items:center;gap:26px;font-size:.94rem;color:#252525}
.nav-item{position:relative;padding:26px 0}
.nav-item>a,.site-nav>a{color:#252525;white-space:nowrap}.nav-item:after,.site-nav>a:after{content:"";position:absolute;left:0;right:0;bottom:20px;height:1px;background:var(--primary);transform:scaleX(0);transform-origin:left;transition:transform .2s ease}.nav-item:hover:after,.site-nav>a:hover:after{transform:scaleX(1)}
.has-dropdown{position:relative}.dropdown{position:absolute;top:64px;left:-20px;min-width:230px;padding:12px;background:white;border:1px solid var(--line);border-radius:18px;box-shadow:var(--shadow);display:none}.has-dropdown:hover .dropdown{display:grid}.dropdown a{padding:10px 12px;border-radius:12px;color:var(--text)}.dropdown a:hover{background:var(--surface)}
.nav-toggle{display:none;background:transparent;border:0;width:42px;height:42px;cursor:pointer}.nav-toggle span:not(.sr-only){display:block;width:22px;height:1.5px;background:var(--primary);margin:6px auto}
.section{padding:clamp(72px,9vw,112px) 0}.surface{background:var(--surface)}
.hero{min-height:calc(100vh - 76px);display:grid;align-items:center;padding:clamp(64px,7vw,96px) 0;overflow:hidden}.hero-grid{display:grid;grid-template-columns:minmax(0,1fr) minmax(360px,.9fr);gap:clamp(48px,6vw,92px);align-items:center}.hero-grid>div:first-child{min-width:0;position:relative;z-index:2}.eyebrow{font-size:.78rem;letter-spacing:.14em;text-transform:uppercase;color:var(--muted);font-weight:800;margin:0 0 18px}.hero-eyebrow{display:block;white-space:nowrap;max-width:100%;font-size:clamp(.48rem,.74vw,.78rem);letter-spacing:clamp(.045em,.38vw,.14em);line-height:1.55;overflow:visible}.hero h1,.page-hero h1{font-size:clamp(3.2rem,6.7vw,6.4rem);line-height:.98;letter-spacing:-.075em;color:var(--primary);margin:0}.hero-title{font-size:clamp(2.45rem,3.75vw,5.15rem)!important;line-height:1.06!important;letter-spacing:-.065em!important;max-width:100%}.hero-title span{display:block;white-space:nowrap}.hero p:not(.eyebrow),.page-hero p{font-size:clamp(1.05rem,1.65vw,1.3rem);max-width:620px;color:var(--muted);margin:28px 0 0}.button-row{display:flex;gap:14px;flex-wrap:wrap;margin-top:34px}.btn{display:inline-flex;align-items:center;justify-content:center;min-height:52px;padding:14px 22px;border-radius:999px;font-weight:800;font-size:.94rem;transition:transform .2s ease,box-shadow .2s ease,border-color .2s ease}.btn:hover{transform:translateY(-1px)}.btn-primary{background:var(--primary);color:#fff;box-shadow:0 12px 35px rgba(17,17,17,.14)}.btn-secondary{border:1px solid var(--line);background:#fff;color:var(--primary)}
.hero-visual{position:relative;min-width:0}.hero-photo-card{position:relative;overflow:hidden;border:1px solid var(--line);border-radius:34px;background:var(--surface);box-shadow:var(--shadow);isolation:isolate;width:100%;max-width:620px;margin-inline:auto}.hero-photo-card:after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(255,255,255,0) 55%,rgba(255,255,255,.18));pointer-events:none}.hero-photo-card img{width:100%;height:clamp(420px,55vh,650px);min-height:0;object-fit:cover;object-position:center;filter:saturate(.92) contrast(1.02)}.system-dot{position:absolute;width:12px;height:12px;border-radius:50%;background:#111;box-shadow:0 0 0 9px rgba(255,255,255,.18),0 0 0 18px rgba(255,255,255,.08)}.system-dot-1{right:12%;top:18%}.system-dot-2{left:12%;bottom:22%}.system-dot-3{right:22%;bottom:14%}
.section-head{display:grid;grid-template-columns:minmax(0,1fr) minmax(280px,540px);gap:40px;align-items:end;margin-bottom:36px}.section-head h2,.cta-card h2{font-size:clamp(2.1rem,4vw,4rem);line-height:1.05;letter-spacing:-.055em;color:var(--primary);margin:0}.section-head p{margin:0;color:var(--muted);font-size:1.05rem}.cards-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:18px}.card{min-height:270px;border:1px solid var(--line);border-radius:var(--radius);padding:28px;background:#fff;transition:transform .2s ease,box-shadow .2s ease,border-color .2s ease;min-width:0}.card:hover{transform:translateY(-4px);box-shadow:var(--shadow);border-color:#d1d5db}.card-icon{width:34px;height:34px;border:1px solid var(--line);border-radius:12px;display:inline-flex;align-items:center;justify-content:center;margin-bottom:24px;color:var(--primary);background:#fff}.card-icon svg{width:19px;height:19px;stroke:currentColor;stroke-width:1.8;fill:none;stroke-linecap:round;stroke-linejoin:round}.card:hover .card-icon{border-color:#d1d5db}
.card .kicker{font-size:.74rem;font-weight:800;letter-spacing:.12em;text-transform:uppercase;color:var(--muted)}.card h3{margin:20px 0 12px;font-size:1.25rem;line-height:1.2;color:var(--primary);overflow-wrap:anywhere}.card p{margin:0;color:var(--muted)}.card .arrow{display:inline-block;margin-top:28px;font-weight:800;color:var(--primary)}
.project-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:18px}.project-card{border:1px solid var(--line);border-radius:var(--radius);padding:28px;background:#fff;min-width:0}.project-card h3{overflow-wrap:anywhere}.status{display:inline-flex;margin-top:22px;padding:6px 10px;border-radius:999px;background:var(--surface);font-size:.8rem;font-weight:700;color:var(--primary)}.process{display:flex;align-items:center;justify-content:space-between;gap:12px;border:1px solid var(--line);border-radius:var(--radius);padding:28px;background:#fff;overflow-x:auto;-webkit-overflow-scrolling:touch}.process span{white-space:nowrap;font-weight:700;color:var(--primary)}.process i{display:block;min-width:44px;height:1px;background:var(--line)}.about-grid{display:grid;grid-template-columns:minmax(260px,360px) minmax(0,1fr);gap:56px;align-items:center}.portrait{border-radius:32px;overflow:hidden;background:var(--surface);aspect-ratio:4/5}.portrait img{width:100%;height:100%;object-fit:cover}.about-copy h2{font-size:clamp(2rem,4vw,4rem);line-height:1.06;letter-spacing:-.055em;color:var(--primary);margin:0 0 22px}.about-copy p{font-size:1.18rem;color:var(--muted);max-width:620px}.cta-card{text-align:center;border:1px solid var(--line);border-radius:34px;padding:clamp(46px,7vw,70px) 8%;background:linear-gradient(180deg,#fff,var(--surface));box-shadow:var(--shadow)}.cta-card p:not(.eyebrow){max-width:680px;margin:20px auto 0;color:var(--muted);font-size:1.1rem}.cta-card .button-row{justify-content:center}.site-footer{border-top:1px solid var(--line);padding:60px 0;color:var(--muted)}.footer-grid{display:grid;grid-template-columns:1.3fr 1fr 1fr;gap:36px}.footer-links{display:grid;gap:10px}.footer-links a:hover{color:var(--primary)}
.page-hero{padding:clamp(80px,10vw,120px) 0 clamp(48px,6vw,70px)}.page-hero h1{max-width:980px}.content-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:18px}.text-block{padding:34px;border:1px solid var(--line);border-radius:var(--radius);background:#fff;min-width:0}.text-block h3{margin-top:0;color:var(--primary);overflow-wrap:anywhere}.contact-box{max-width:760px;border:1px solid var(--line);border-radius:var(--radius);padding:34px;background:#fff}.contact-box a{font-weight:800;color:var(--primary);overflow-wrap:anywhere}.legal-hero{padding-bottom:44px}.legal-container{width:min(880px,90vw)}.back-link{display:inline-flex;margin-bottom:34px;color:var(--muted);font-weight:700;font-size:.95rem;transition:color .2s ease,transform .2s ease}.back-link:hover{color:var(--primary);transform:translateX(-2px)}.legal-section{padding-top:0}.legal-card{border:1px solid var(--line);border-radius:34px;background:#fff;box-shadow:var(--shadow);padding:clamp(28px,5vw,58px)}.legal-card h2{font-size:clamp(1.45rem,2.4vw,2.15rem);line-height:1.18;letter-spacing:-.035em;color:var(--primary);margin:0 0 8px}.legal-card h3{font-size:1rem;line-height:1.3;color:var(--primary);margin:0 0 8px}.legal-card p{margin:0;color:var(--text)}.legal-card a{font-weight:700;color:var(--primary);text-decoration:underline;text-decoration-thickness:1px;text-underline-offset:3px;overflow-wrap:anywhere}.legal-note{color:var(--muted)!important;margin-bottom:34px!important}.legal-block{padding:28px 0;border-top:1px solid var(--line)}.legal-card .legal-block:first-of-type{border-top:0;padding-top:10px}
@media (max-width:1280px){.hero{min-height:auto;padding:72px 0 90px}.hero-grid{grid-template-columns:1fr;gap:52px}.hero-title{font-size:clamp(2.35rem,6.1vw,5rem)!important}.hero-eyebrow{font-size:clamp(.48rem,1.15vw,.72rem);letter-spacing:clamp(.03em,.28vw,.11em)}.hero-photo-card{width:min(620px,100%)}.hero-photo-card img{height:clamp(420px,60vw,620px)}}
@media (max-width:1080px){.cards-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.section-head{grid-template-columns:1fr}.site-nav{gap:18px}.nav-wrap{gap:18px}}
@media (max-width:980px){.site-nav{position:fixed;inset:76px 0 auto 0;background:#fff;border-bottom:1px solid var(--line);padding:24px 5vw;display:none;flex-direction:column;align-items:flex-start;gap:10px}.site-nav.is-open{display:flex}.nav-toggle{display:block}.nav-item{padding:8px 0}.nav-item:after,.site-nav>a:after{display:none}.dropdown{position:static;display:grid;box-shadow:none;border:0;padding:8px 0 0}.project-grid,.content-grid{grid-template-columns:1fr 1fr}.about-grid{grid-template-columns:1fr}.portrait{max-width:420px}.footer-grid{grid-template-columns:1fr 1fr}.page-hero h1{font-size:clamp(2.5rem,8vw,5rem)}}
@media (max-width:760px){.hero{padding:54px 0 72px}.hero-grid{gap:38px}.hero-title{font-size:clamp(1.72rem,7vw,3.35rem)!important;line-height:1.12!important;letter-spacing:-.055em!important}.hero-eyebrow{font-size:clamp(.36rem,1.58vw,.58rem);letter-spacing:clamp(.015em,.22vw,.075em)}.hero p:not(.eyebrow){font-size:1rem;line-height:1.65}.button-row{gap:10px}.btn{min-height:48px;padding:12px 17px;font-size:.86rem}.hero-photo-card{border-radius:28px}.hero-photo-card img{height:clamp(340px,105vw,480px)}.cards-grid,.project-grid,.content-grid{grid-template-columns:1fr}.card,.project-card,.text-block{padding:26px}.section{padding:68px 0}.section-head{gap:18px}.footer-grid{grid-template-columns:1fr}.process{padding:22px}.legal-card{border-radius:24px;padding:26px}.legal-block{padding:22px 0}.back-link{margin-bottom:24px}}
@media (max-width:420px){.container{width:92vw}.brand{font-size:.8rem}.hero-title{font-size:clamp(1.28rem,6.85vw,1.82rem)!important}.hero-eyebrow{font-size:clamp(.28rem,1.42vw,.42rem);letter-spacing:.01em}.button-row,.btn{width:100%}.btn{justify-content:center}.hero-photo-card img{height:clamp(320px,112vw,440px)}.section-head h2,.cta-card h2,.about-copy h2{letter-spacing:-.045em}.page-hero h1{letter-spacing:-.055em}.site-footer{padding:44px 0}}


/* Final responsive stability overrides
   Prevents hero text and image from overlapping at every viewport width. */
.container{
  width: min(100% - 96px, var(--site-max-width));
  margin-inline: auto;
}
.hero{
  overflow:hidden;
}
.hero-grid{
  min-width:0;
}
.hero-grid > div:first-child{
  min-width:0;
}
.hero-title span{
  display:block;
  white-space:nowrap;
}
.hero-eyebrow{
  display:block;
  white-space:nowrap;
  max-width:100%;
  font-size:clamp(.5rem,.85vw,.78rem);
  letter-spacing:clamp(.035em,.22vw,.12em);
}
.hero-visual{
  min-width:0;
  z-index:1;
}
.hero-photo-card{
  max-width:520px;
}

@media (min-width:1181px){
  .hero-grid{
    grid-template-columns:minmax(0,680px) minmax(360px,520px);
    gap:clamp(36px,4.5vw,72px);
    justify-content:space-between;
    align-items:center;
  }
  .hero-grid > div:first-child{
    max-width:680px;
  }
  .hero-title{
    font-size:clamp(2.35rem,3.05vw,3.35rem)!important;
    line-height:1.08!important;
    letter-spacing:-.055em!important;
    max-width:680px;
  }
  .hero p:not(.eyebrow){
    max-width:620px;
  }
}

@media (max-width:1180px){
  .hero-grid{
    grid-template-columns:1fr;
    gap:clamp(36px,7vw,64px);
  }
  .hero-grid > div:first-child{
    max-width:100%;
  }
  .hero-title{
    font-size:clamp(2rem,6.2vw,4.15rem)!important;
    line-height:1.1!important;
  }
  .hero-photo-card{
    max-width:min(620px,100%);
  }
}

@media (max-width:760px){
  .container{
    width:min(100% - 32px,1320px);
  }
  .hero-title{
    font-size:clamp(1.45rem,6.2vw,2.8rem)!important;
    line-height:1.14!important;
    letter-spacing:-.045em!important;
  }
  .hero-eyebrow{
    font-size:clamp(.34rem,1.55vw,.56rem);
    letter-spacing:clamp(.01em,.12vw,.045em);
  }
}

@media (max-width:420px){
  .container{
    width:min(100% - 28px,1320px);
  }
  .hero-title{
    font-size:clamp(1.18rem,5.85vw,1.55rem)!important;
    line-height:1.16!important;
  }
  .hero-eyebrow{
    font-size:clamp(.29rem,1.32vw,.38rem);
    letter-spacing:0;
  }
}


/* Clean portrait hero: no graphic overlays, lines or network symbols */
.hero-system,
.hero-network,
.network,
.network-node,
.network-line,
.system-node,
.system-line,
.hero-node,
.hero-line,
.system-visual,
.network-visual,
.visual-network,
.system-line-1,
.system-line-2 {
  display: none !important;
  content: none !important;
}

.hero-image,
.hero-visual,
.portrait-wrap {
  position: relative;
  isolation: isolate;
}

.hero-image::before,
.hero-image::after,
.hero-visual::before,
.hero-visual::after,
.portrait-wrap::before,
.portrait-wrap::after {
  display: none !important;
  content: none !important;
}

.hero-image img,
.hero-visual img,
.portrait-wrap img {
  display: block;
  width: 100%;
  height: auto;
  object-fit: cover;
  position: relative;
  z-index: 1;
}

/* Insights final content styles */
.card-kicker {
  display: block;
  margin-bottom: 14px;
  font-size: 0.78rem;
  line-height: 1.2;
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--muted, #6b7280);
}

.card-grid.three {
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

@media (max-width: 980px) {
  .card-grid.three {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 680px) {
  .card-grid.three {
    grid-template-columns: 1fr;
  }
}


/* Insights page expansion */
.insights-featured {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(260px, 360px);
  gap: clamp(28px, 5vw, 64px);
  align-items: stretch;
  border: 1px solid var(--line);
  border-radius: 34px;
  padding: clamp(30px, 5vw, 58px);
  background: linear-gradient(180deg, #ffffff, var(--surface));
  box-shadow: var(--shadow);
}

.insights-featured h2 {
  font-size: clamp(2rem, 4vw, 4rem);
  line-height: 1.05;
  letter-spacing: -0.055em;
  color: var(--primary);
  margin: 0 0 22px;
}

.insights-featured p {
  margin: 0 0 18px;
  color: var(--muted);
  font-size: 1.08rem;
}

.insights-featured-meta {
  display: grid;
  align-content: center;
  gap: 8px;
  border: 1px solid var(--line);
  border-radius: 24px;
  padding: 28px;
  background: #ffffff;
}

.insights-featured-meta span {
  font-size: 0.75rem;
  font-weight: 800;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--muted);
  margin-top: 12px;
}

.insights-featured-meta span:first-child {
  margin-top: 0;
}

.insights-featured-meta strong {
  color: var(--primary);
  font-size: 1.02rem;
}

.insight-filter {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin: 0 0 28px;
}

.filter-button {
  appearance: none;
  border: 1px solid var(--line);
  background: #ffffff;
  color: var(--primary);
  border-radius: 999px;
  padding: 10px 16px;
  font: inherit;
  font-size: 0.9rem;
  font-weight: 800;
  cursor: pointer;
  transition: background 0.2s ease, color 0.2s ease, border-color 0.2s ease, transform 0.2s ease;
}

.filter-button:hover {
  transform: translateY(-1px);
  border-color: #d1d5db;
}

.filter-button.is-active {
  background: var(--primary);
  color: #ffffff;
  border-color: var(--primary);
}

.insights-card-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 18px;
}

.card-kicker {
  display: block;
  margin-bottom: 14px;
  font-size: 0.78rem;
  line-height: 1.2;
  font-weight: 800;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--muted);
}

.insights-principles {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 18px;
}

.insights-principles article {
  border: 1px solid var(--line);
  border-radius: var(--radius);
  padding: 28px;
  background: #ffffff;
  min-width: 0;
}

.insights-principles span {
  display: inline-flex;
  margin-bottom: 22px;
  font-weight: 800;
  color: var(--muted);
}

.insights-principles h3,
.insight-example h3 {
  margin: 0 0 14px;
  color: var(--primary);
  line-height: 1.2;
}

.insights-principles p,
.insight-example dd {
  color: var(--muted);
}

.insights-example-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 18px;
}

.insight-example {
  border: 1px solid var(--line);
  border-radius: var(--radius);
  padding: 28px;
  background: #ffffff;
  min-width: 0;
}

.insight-example dl,
.insight-example dd {
  margin: 0;
}

.insight-example dt {
  margin-top: 18px;
  margin-bottom: 6px;
  font-size: 0.78rem;
  line-height: 1.2;
  font-weight: 800;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--primary);
}

.split-section {
  display: grid;
  grid-template-columns: minmax(0, 0.9fr) minmax(300px, 1.1fr);
  gap: clamp(28px, 5vw, 64px);
  align-items: start;
}

.split-section h2 {
  font-size: clamp(2rem, 4vw, 4rem);
  line-height: 1.05;
  letter-spacing: -0.055em;
  color: var(--primary);
  margin: 0;
}

@media (max-width: 1080px) {
  .insights-card-grid,
  .insights-example-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .insights-principles {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .insights-featured,
  .split-section {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 680px) {
  .insights-card-grid,
  .insights-example-grid,
  .insights-principles {
    grid-template-columns: 1fr;
  }

  .insight-filter {
    display: grid;
    grid-template-columns: 1fr 1fr;
  }

  .filter-button {
    width: 100%;
  }

  .insights-featured,
  .insights-featured-meta,
  .insight-example,
  .insights-principles article {
    padding: 24px;
  }
}


/* v26 hero spacing and portrait optimization */
.hero{
  min-height:unset !important;
  height:auto !important;
  display:block !important;
  align-items:initial !important;
  padding-top:clamp(64px,7vh,96px) !important;
  padding-bottom:clamp(56px,6vh,84px) !important;
  overflow:hidden !important;
}
.hero-grid{
  display:grid !important;
  grid-template-columns:minmax(0,660px) minmax(420px,600px) !important;
  align-items:center !important;
  justify-content:space-between !important;
  gap:clamp(44px,5vw,86px) !important;
}
.hero-grid > div:first-child{
  max-width:660px !important;
  min-width:0 !important;
  position:relative !important;
  z-index:2 !important;
}
.hero-title{
  font-size:clamp(2.55rem,3.45vw,4.15rem) !important;
  line-height:1.07 !important;
  letter-spacing:-.06em !important;
  max-width:660px !important;
}
.hero-title span{
  display:block !important;
  white-space:nowrap !important;
}
.hero p:not(.eyebrow){
  max-width:650px !important;
  margin-top:28px !important;
}
.hero-visual{
  min-width:0 !important;
  width:100% !important;
  position:relative !important;
  z-index:1 !important;
  isolation:isolate !important;
}
.hero-photo-card{
  width:100% !important;
  max-width:600px !important;
  margin-inline:auto !important;
  border-radius:34px !important;
}
.hero-photo-card img{
  width:100% !important;
  height:clamp(390px,34vw,540px) !important;
  object-fit:cover !important;
  object-position:center !important;
}
/* No decorative symbols over the portrait */
.hero-photo-card::before,
.hero-photo-card::after,
.hero-visual::before,
.hero-visual::after{
  display:none !important;
  content:none !important;
}
.system-dot,
.system-dot-1,
.system-dot-2,
.system-dot-3,
.hero-system,
.hero-network,
.network,
.network-node,
.network-line,
.system-node,
.system-line,
.hero-node,
.hero-line{
  display:none !important;
}

@media (max-width:1180px){
  .hero{
    padding-top:clamp(52px,7vw,78px) !important;
    padding-bottom:clamp(52px,7vw,78px) !important;
  }
  .hero-grid{
    grid-template-columns:1fr !important;
    gap:clamp(34px,6vw,54px) !important;
  }
  .hero-grid > div:first-child{
    max-width:760px !important;
  }
  .hero-title{
    font-size:clamp(2.25rem,6vw,4rem) !important;
    max-width:760px !important;
  }
  .hero-photo-card{
    max-width:680px !important;
    margin-inline:0 !important;
  }
  .hero-photo-card img{
    height:clamp(360px,58vw,560px) !important;
  }
}
@media (max-width:760px){
  .hero{
    padding-top:44px !important;
    padding-bottom:56px !important;
  }
  .hero-title{
    font-size:clamp(1.45rem,6.2vw,2.8rem) !important;
    line-height:1.14 !important;
  }
  .hero-photo-card{
    max-width:100% !important;
    border-radius:28px !important;
  }
  .hero-photo-card img{
    height:clamp(320px,92vw,480px) !important;
  }
}
@media (max-width:420px){
  .hero-title{
    font-size:clamp(1.16rem,5.8vw,1.55rem) !important;
  }
}


/* v29: Insights headline and responsive layout refinement */
.insights-section-head,
.insights-head,
.section-head,
.split-section {
  min-width: 0;
}

.section-head h1,
.section-head h2,
.split-section h1,
.split-section h2 {
  max-width: 100%;
  overflow-wrap: normal;
  word-break: normal;
  hyphens: none;
}

.insights-section-head {
  display: grid;
  grid-template-columns: minmax(0, 1.05fr) minmax(280px, 0.95fr);
  gap: clamp(32px, 5vw, 80px);
  align-items: end;
}

.insights-section-head h2 {
  max-width: 820px;
  font-size: clamp(44px, 5.2vw, 86px);
  line-height: 0.96;
  letter-spacing: -0.055em;
}

.insights-section-head p {
  max-width: 640px;
}

@media (max-width: 1180px) {
  .insights-section-head {
    grid-template-columns: 1fr;
    align-items: start;
    gap: 24px;
  }

  .insights-section-head h2 {
    max-width: 900px;
    font-size: clamp(42px, 7vw, 72px);
  }
}

@media (max-width: 720px) {
  .insights-section-head h2 {
    font-size: clamp(34px, 11vw, 52px);
    line-height: 1.02;
    letter-spacing: -0.045em;
  }
}

/* Fallback for the existing generic section header layout */
.section-head {
  gap: clamp(24px, 4vw, 64px);
}

.section-head h2 {
  max-width: 820px;
}

@media (max-width: 1180px) {
  .section-head {
    grid-template-columns: 1fr !important;
  }
}





/* v31: Optimierte Hero-Kategoriezeile */
.hero-eyebrow {
  display: inline-block;
  white-space: nowrap;
  font-weight: 700;
  letter-spacing: 0.12em;
  color: var(--primary);
  font-size: 0.92rem;
  line-height: 1.2;
}

@media (max-width: 1024px) {
  .hero-eyebrow {
    font-size: 0.86rem;
    letter-spacing: 0.1em;
  }
}

@media (max-width: 768px) {
  .hero-eyebrow {
    font-size: 0.78rem;
    letter-spacing: 0.08em;
    white-space: normal;
    line-height: 1.35;
  }
}

@media (max-width: 480px) {
  .hero-eyebrow {
    font-size: 0.72rem;
    letter-spacing: 0.06em;
  }
}


/* v31: Globales 1440px Layoutsystem */
body {
  background: #f7f7f5;
}

.site-header,
.site-footer,
main {
  max-width: var(--site-max-width);
  margin-left: auto;
  margin-right: auto;
  background: var(--background);
}

.container {
  width: min(100% - 96px, var(--site-max-width));
  margin-inline: auto;
}

.hero,
.page-hero,
.section {
  width: 100%;
}

.hero-grid,
.section-head,
.cards-grid,
.content-grid,
.footer-grid {
  min-width: 0;
}

.hero-title,
.page-hero h1,
.section h2 {
  overflow-wrap: normal;
  word-break: normal;
}

.hero-visual,
.hero-photo-card {
  min-width: 0;
}

.hero-photo-card img {
  width: 100%;
  height: auto;
  object-fit: cover;
}

@media (min-width: 1441px) {
  .site-header,
  .site-footer,
  main {
    border-left: 1px solid rgba(229, 231, 235, 0.8);
    border-right: 1px solid rgba(229, 231, 235, 0.8);
  }
}

@media (max-width: 1200px) {
  .container {
    width: min(100% - 64px, var(--site-max-width));
  }
}

@media (max-width: 760px) {
  .container {
    width: min(100% - 40px, var(--site-max-width));
  }
}

@media (max-width: 420px) {
  .container {
    width: min(100% - 32px, var(--site-max-width));
  }
}


/* v32: Hero-Grid stabilisieren und Überlappungen verhindern */
:root {
  --site-max-width: 1440px;
  --content-max-width: 1240px;
}

main,
.site-header,
.site-footer {
  max-width: var(--site-max-width);
  margin-left: auto;
  margin-right: auto;
}

.container {
  width: min(100% - 96px, var(--content-max-width));
  margin-inline: auto;
}

.hero .container.hero-grid,
.hero-grid {
  display: grid;
  grid-template-columns: minmax(0, 620px) minmax(420px, 560px);
  justify-content: space-between;
  align-items: center;
  gap: clamp(56px, 6vw, 96px);
}

.hero-grid > div:first-child {
  max-width: 620px;
  min-width: 0;
}

.hero-visual,
.hero-photo-card {
  width: 100%;
  max-width: 560px;
  min-width: 0;
  justify-self: end;
}

.hero-photo-card img {
  width: 100%;
  height: auto;
  object-fit: cover;
}

.hero-title {
  font-size: clamp(48px, 3.9vw, 68px);
  line-height: 0.96;
  letter-spacing: -0.055em;
}

.hero-title span {
  display: block;
  white-space: nowrap;
}

.hero p:not(.eyebrow) {
  max-width: 620px;
}

@media (min-width: 1441px) {
  body {
    background: #f7f7f5;
  }
}

@media (max-width: 1180px) {
  .container {
    width: min(100% - 64px, var(--content-max-width));
  }

  .hero .container.hero-grid,
  .hero-grid {
    grid-template-columns: 1fr;
    gap: 48px;
  }

  .hero-grid > div:first-child {
    max-width: 760px;
  }

  .hero-visual,
  .hero-photo-card {
    max-width: 760px;
    justify-self: start;
  }

  .hero-title {
    font-size: clamp(44px, 7vw, 68px);
  }

  .hero-title span {
    white-space: normal;
  }
}

@media (max-width: 760px) {
  .container {
    width: min(100% - 40px, var(--content-max-width));
  }

  .hero .container.hero-grid,
  .hero-grid {
    gap: 38px;
  }

  .hero-title {
    font-size: clamp(40px, 10vw, 54px);
    line-height: 1.02;
  }
}

@media (max-width: 420px) {
  .container {
    width: min(100% - 32px, var(--content-max-width));
  }

  .hero-title {
    font-size: clamp(34px, 10vw, 46px);
  }
}


/* v33: Finaler Hero-Fix gegen Überlappungen */
:root {
  --site-max-width: 1440px;
  --content-max-width: 1240px;
}

main,
.site-header,
.site-footer {
  max-width: var(--site-max-width);
  margin-left: auto;
  margin-right: auto;
}

.container {
  width: min(100% - 96px, var(--content-max-width));
  margin-inline: auto;
}

.hero {
  overflow: hidden;
}

.hero .container.hero-grid,
.hero-grid {
  display: grid;
  grid-template-columns: minmax(0, 560px) minmax(420px, 560px);
  gap: 96px;
  justify-content: space-between;
  align-items: center;
}

.hero-grid > div:first-child {
  max-width: 560px;
  min-width: 0;
}

.hero-visual,
.hero-photo-card {
  width: 100%;
  max-width: 560px;
  min-width: 0;
  justify-self: end;
}

.hero-photo-card img {
  width: 100%;
  height: auto;
  object-fit: cover;
}

.hero-title {
  font-size: clamp(44px, 3.4vw, 60px);
  line-height: 1;
  letter-spacing: -0.055em;
  max-width: 560px;
}

.hero-title span {
  display: block;
  white-space: normal;
}

.hero p:not(.eyebrow) {
  max-width: 560px;
}

@media (min-width: 1441px) {
  body {
    background: #f7f7f5;
  }
}

@media (max-width: 1280px) {
  .container {
    width: min(100% - 64px, var(--content-max-width));
  }

  .hero .container.hero-grid,
  .hero-grid {
    grid-template-columns: 1fr;
    gap: 48px;
  }

  .hero-grid > div:first-child {
    max-width: 760px;
  }

  .hero-visual,
  .hero-photo-card {
    max-width: 760px;
    justify-self: start;
  }

  .hero-title {
    font-size: clamp(44px, 7vw, 64px);
    max-width: 760px;
  }

  .hero p:not(.eyebrow) {
    max-width: 680px;
  }
}

@media (max-width: 760px) {
  .container {
    width: min(100% - 40px, var(--content-max-width));
  }

  .hero .container.hero-grid,
  .hero-grid {
    gap: 38px;
  }

  .hero-title {
    font-size: clamp(40px, 10vw, 54px);
    line-height: 1.02;
  }
}

@media (max-width: 420px) {
  .container {
    width: min(100% - 32px, var(--content-max-width));
  }

  .hero-title {
    font-size: clamp(34px, 10vw, 46px);
  }
}


/* v34: Variante A, kompakter Hero */
.hero .container.hero-grid,
.hero-grid {
  grid-template-columns: 520px 520px;
  gap: 96px;
  justify-content: space-between;
  align-items: center;
}

.hero-grid > div:first-child {
  max-width: 520px;
}

.hero-title {
  font-size: clamp(42px, 3vw, 52px);
  line-height: 1.02;
  letter-spacing: -0.05em;
  max-width: 520px;
}

.hero-title span {
  display: block;
  white-space: normal;
}

.hero p:not(.eyebrow) {
  max-width: 520px;
}

.hero-visual,
.hero-photo-card {
  max-width: 520px;
}

@media (max-width: 1280px) {
  .hero .container.hero-grid,
  .hero-grid {
    grid-template-columns: 1fr;
    gap: 48px;
  }

  .hero-title {
    font-size: clamp(42px, 7vw, 60px);
    max-width: 760px;
  }

  .hero-grid > div:first-child,
  .hero-visual,
  .hero-photo-card {
    max-width: 760px;
  }
}

@media (max-width: 760px) {
  .hero-title {
    font-size: clamp(38px, 9vw, 48px);
  }
}


/* v35: Harte Hero-Korrektur ohne Überlappung */
.hero {
  overflow: hidden;
}

.hero .container.hero-grid,
.hero-grid {
  display: grid !important;
  grid-template-columns: 500px 520px !important;
  gap: 120px !important;
  justify-content: space-between !important;
  align-items: center !important;
}

.hero-grid > div:first-child {
  width: 500px !important;
  max-width: 500px !important;
  min-width: 0 !important;
}

.hero-title {
  width: 500px !important;
  max-width: 500px !important;
  font-size: 48px !important;
  line-height: 1.05 !important;
  letter-spacing: -0.05em !important;
  overflow-wrap: break-word !important;
  word-break: normal !important;
  white-space: normal !important;
}

.hero-title span {
  display: inline !important;
  white-space: normal !important;
}

.hero-title br {
  display: block !important;
}

.hero p:not(.eyebrow) {
  width: 500px !important;
  max-width: 500px !important;
}

.hero-visual,
.hero-photo-card {
  width: 520px !important;
  max-width: 520px !important;
  min-width: 0 !important;
  justify-self: end !important;
}

.hero-photo-card img {
  width: 100% !important;
  height: auto !important;
  object-fit: cover !important;
}

@media (max-width: 1280px) {
  .hero .container.hero-grid,
  .hero-grid {
    grid-template-columns: 1fr !important;
    gap: 48px !important;
  }

  .hero-grid > div:first-child,
  .hero-title,
  .hero p:not(.eyebrow) {
    width: 100% !important;
    max-width: 760px !important;
  }

  .hero-title {
    font-size: clamp(42px, 7vw, 60px) !important;
  }

  .hero-visual,
  .hero-photo-card {
    width: 100% !important;
    max-width: 760px !important;
    justify-self: start !important;
  }
}

@media (max-width: 760px) {
  .hero-title {
    font-size: clamp(38px, 9vw, 48px) !important;
    line-height: 1.04 !important;
  }
}

@media (max-width: 420px) {
  .hero-title {
    font-size: clamp(34px, 10vw, 42px) !important;
  }
}


/* Smart Navigation v2 */
.site-header[data-header] {
  position: fixed !important;
  top: 0 !important;
  left: 50% !important;
  right: auto !important;
  width: 100% !important;
  max-width: var(--site-max-width, 1440px) !important;
  transform: translate3d(-50%, 0, 0) !important;
  z-index: 9999 !important;
  transition: transform 240ms ease, background-color 240ms ease, box-shadow 240ms ease, border-color 240ms ease !important;
  will-change: transform;
}

.site-header[data-header].is-hidden {
  transform: translate3d(-50%, -110%, 0) !important;
}

.site-header[data-header].is-scrolled {
  background: rgba(255, 255, 255, 0.94) !important;
  box-shadow: 0 16px 42px rgba(17, 17, 17, 0.08) !important;
}

body {
  padding-top: var(--header-offset, 76px);
}

@media (max-width: 760px) {
  body {
    padding-top: var(--header-offset, 72px);
  }
}

@media (prefers-reduced-motion: reduce) {
  .site-header[data-header] {
    transition: none !important;
  }
}


/* Floating Contact Buttons */
.floating-contact {
  position: fixed;
  right: max(18px, env(safe-area-inset-right));
  bottom: max(24px, env(safe-area-inset-bottom));
  z-index: 9998;
  display: grid;
  gap: 12px;
  pointer-events: none;
}

.floating-contact__button {
  pointer-events: auto;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  min-width: 54px;
  min-height: 54px;
  padding: 0 18px;
  border-radius: 999px;
  background: var(--primary);
  color: #fff;
  border: 1px solid rgba(255, 255, 255, 0.18);
  box-shadow: 0 18px 48px rgba(17, 17, 17, 0.18);
  font-size: 0.9rem;
  font-weight: 800;
  line-height: 1;
  transition: transform 200ms ease, box-shadow 200ms ease, background-color 200ms ease;
}

.floating-contact__button:hover,
.floating-contact__button:focus-visible {
  transform: translateY(-2px);
  box-shadow: 0 22px 58px rgba(17, 17, 17, 0.24);
}

.floating-contact__button:focus-visible {
  outline: 3px solid rgba(14, 116, 144, 0.32);
  outline-offset: 3px;
}

.floating-contact__button svg {
  width: 21px;
  height: 21px;
  flex: 0 0 21px;
  fill: currentColor;
}


.floating-contact__button--phone {
  background: #25D366;
  color: #fff;
  border-color: rgba(255,255,255,0.18);
}

.floating-contact__button--phone:hover,
.floating-contact__button--phone:focus-visible {
  background: #20BD5A;
}

.floating-contact__button--mail,
.floating-contact__button--prices,
.floating-contact__button--appointment {
  background: #fff;
  color: var(--primary);
  border-color: var(--line);
}

@media (min-width: 981px) {
  .floating-contact {
    bottom: 42px;
  }
}

@media (max-width: 760px) {
  .floating-contact {
    right: max(14px, env(safe-area-inset-right));
    bottom: max(14px, env(safe-area-inset-bottom));
    gap: 10px;
  }

  .floating-contact__button {
    width: 52px;
    height: 52px;
    min-width: 52px;
    min-height: 52px;
    padding: 0;
  }

  .floating-contact__button span {
    position: absolute;
    width: 1px;
    height: 1px;
    padding: 0;
    margin: -1px;
    overflow: hidden;
    clip: rect(0, 0, 0, 0);
    white-space: nowrap;
    border: 0;
  }
}

@media (prefers-reduced-motion: reduce) {
  .floating-contact__button {
    transition: none;
  }

  .floating-contact__button:hover,
  .floating-contact__button:focus-visible {
    transform: none;
  }
}

/* Positioning refinement v1: clearer homepage storytelling */
.hero--positioning .hero-title {
  width: auto !important;
  max-width: 620px !important;
  font-size: clamp(42px, 4vw, 64px) !important;
  line-height: 1.03 !important;
  letter-spacing: -0.055em !important;
}

.hero--positioning .hero-grid > div:first-child,
.hero--positioning .hero p:not(.eyebrow) {
  width: auto !important;
  max-width: 620px !important;
}

.pain-grid,
.question-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 18px;
}

.pain-card,
.question-grid article {
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: #fff;
  padding: 28px;
  min-width: 0;
}

.pain-card span {
  display: inline-flex;
  margin-bottom: 20px;
  font-size: 0.78rem;
  font-weight: 800;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--muted);
}

.pain-card h3,
.question-grid h3 {
  margin: 0 0 12px;
  color: var(--primary);
  font-size: 1.18rem;
  line-height: 1.22;
  letter-spacing: -0.02em;
}

.pain-card p,
.question-grid p {
  margin: 0;
  color: var(--muted);
}

.about-grid--home .about-copy p + p {
  margin-top: 14px;
}

.target-card {
  border: 1px solid var(--line);
  border-radius: 34px;
  padding: clamp(40px, 6vw, 72px);
  background: linear-gradient(180deg, #ffffff, var(--surface));
  box-shadow: var(--shadow);
}

.target-card h2 {
  max-width: 980px;
  margin: 0;
  font-size: clamp(2rem, 4vw, 4.2rem);
  line-height: 1.05;
  letter-spacing: -0.055em;
  color: var(--primary);
}

.target-card p:not(.eyebrow) {
  max-width: 720px;
  margin: 22px 0 0;
  color: var(--muted);
  font-size: 1.1rem;
}

@media (max-width: 1080px) {
  .pain-grid,
  .question-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 760px) {
  .hero--positioning .hero-title {
    font-size: clamp(36px, 9vw, 52px) !important;
  }

  .pain-grid,
  .question-grid {
    grid-template-columns: 1fr;
  }

  .pain-card,
  .question-grid article {
    padding: 24px;
  }

  .target-card {
    border-radius: 24px;
    padding: 30px 24px;
  }
}

/* Fallbeispiele: trust and case-study section */
.case-highlight {
  display: grid;
  grid-template-columns: minmax(0, 1.15fr) minmax(280px, .85fr);
  gap: 18px;
  align-items: stretch;
}

.case-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 18px;
}

.case-card {
  display: flex;
  flex-direction: column;
  gap: 16px;
  min-height: 320px;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  padding: 28px;
  background: #fff;
  color: inherit;
  transition: transform .2s ease, box-shadow .2s ease, border-color .2s ease;
}

.case-card[href]:hover {
  transform: translateY(-2px);
  box-shadow: var(--shadow);
  border-color: rgba(17, 17, 17, .18);
}

.case-card--featured {
  background: linear-gradient(180deg, #ffffff, var(--surface));
  box-shadow: var(--shadow);
}

.case-card h3 {
  margin: 0;
  color: var(--primary);
  font-size: clamp(1.35rem, 2vw, 2.1rem);
  line-height: 1.12;
  letter-spacing: -0.035em;
}

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

.case-card strong {
  margin-top: auto;
  color: var(--primary);
}

.kicker {
  display: block;
  font-size: .78rem;
  line-height: 1.35;
  font-weight: 800;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: var(--muted);
}

.case-meta {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
  margin-top: auto;
}

.case-meta span {
  display: inline-flex;
  padding: 6px 10px;
  border-radius: 999px;
  background: var(--surface);
  color: var(--primary);
  font-size: .78rem;
  font-weight: 800;
}

.case-mini-grid {
  display: grid;
  gap: 18px;
}

.case-mini-grid article,
.case-proof-grid article {
  border: 1px solid var(--line);
  border-radius: var(--radius);
  padding: 24px;
  background: #fff;
}

.case-mini-grid span,
.case-proof-grid span {
  display: inline-flex;
  margin-bottom: 14px;
  font-size: .78rem;
  font-weight: 800;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: var(--muted);
}

.case-mini-grid h3,
.case-proof-grid h3 {
  margin: 0 0 10px;
  color: var(--primary);
  font-size: 1.08rem;
  line-height: 1.2;
}

.case-mini-grid p,
.case-proof-grid p {
  margin: 0;
  color: var(--muted);
}

.case-proof-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 18px;
}

.case-summary-card {
  border: 1px solid var(--line);
  border-radius: 34px;
  padding: clamp(30px, 5vw, 58px);
  background: #fff;
  box-shadow: var(--shadow);
}

.case-summary-grid {
  display: grid;
  grid-template-columns: repeat(5, minmax(0, 1fr));
  gap: 14px;
}

.case-summary-grid article {
  border: 1px solid var(--line);
  border-radius: 20px;
  padding: 18px;
  background: var(--surface);
}

.case-summary-grid strong {
  display: block;
  margin-bottom: 8px;
  color: var(--primary);
  font-size: .9rem;
}

.case-summary-grid span {
  display: block;
  color: var(--muted);
  font-size: .92rem;
  line-height: 1.5;
}

.case-layout {
  display: grid;
  grid-template-columns: 260px minmax(0, 820px);
  gap: clamp(32px, 6vw, 80px);
  align-items: start;
  justify-content: center;
}

.case-sidebar {
  position: sticky;
  top: 100px;
}

.case-sidebar nav {
  display: grid;
  gap: 8px;
  border: 1px solid var(--line);
  border-radius: 22px;
  padding: 14px;
  background: #fff;
}

.case-sidebar a {
  padding: 10px 12px;
  border-radius: 14px;
  color: var(--muted);
  font-weight: 700;
  font-size: .92rem;
}

.case-sidebar a:hover {
  background: var(--surface);
  color: var(--primary);
}

.case-article {
  min-width: 0;
}

.case-article section {
  padding: 0 0 54px;
  margin-bottom: 54px;
  border-bottom: 1px solid var(--line);
}

.case-article section:last-child {
  margin-bottom: 0;
}

.case-article h2 {
  margin: 0 0 22px;
  color: var(--primary);
  font-size: clamp(2rem, 3.2vw, 3.5rem);
  line-height: 1.08;
  letter-spacing: -0.055em;
}

.case-article p {
  margin: 0 0 18px;
  color: var(--text);
  font-size: 1.08rem;
}

.case-list {
  display: grid;
  gap: 10px;
  margin: 0 0 24px;
  padding: 0;
  list-style: none;
}

.case-list li {
  position: relative;
  padding-left: 28px;
  color: var(--text);
}

.case-list li::before {
  content: "";
  position: absolute;
  left: 0;
  top: .72em;
  width: 9px;
  height: 9px;
  border-radius: 50%;
  background: var(--primary);
}

.case-learning {
  border: 1px solid var(--line) !important;
  border-radius: 30px;
  padding: clamp(28px, 5vw, 46px) !important;
  background: linear-gradient(180deg, #fff, var(--surface));
  box-shadow: var(--shadow);
}

.case-learning blockquote {
  margin: 28px 0 0;
  padding: 22px;
  border-left: 3px solid var(--primary);
  border-radius: 18px;
  background: #fff;
  color: var(--text);
}

@media (max-width: 1180px) {
  .case-summary-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
  .case-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 980px) {
  .case-highlight,
  .case-layout {
    grid-template-columns: 1fr;
  }
  .case-sidebar {
    position: static;
  }
  .case-sidebar nav {
    display: flex;
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
  }
  .case-sidebar a {
    white-space: nowrap;
  }
}

@media (max-width: 760px) {
  .case-grid,
  .case-proof-grid,
  .case-summary-grid {
    grid-template-columns: 1fr;
  }
  .case-card {
    min-height: auto;
    padding: 24px;
  }
  .case-summary-card,
  .case-learning {
    border-radius: 24px;
  }
}

/* v40: Globales Layout-, Typografie- und Abstands-System
   Ziel: bessere Lesbarkeit, konsistente Abstände, responsive ohne Einzelelement-Reparaturen. */
:root{
  --space-1:clamp(6px,.5vw,8px);
  --space-2:clamp(10px,.8vw,12px);
  --space-3:clamp(14px,1vw,18px);
  --space-4:clamp(20px,1.6vw,28px);
  --space-5:clamp(30px,2.8vw,44px);
  --space-6:clamp(44px,4.5vw,72px);
  --space-7:clamp(64px,7vw,112px);
  --readable: 74ch;
  --narrow: 62ch;
  --grid-gap: clamp(16px,2vw,24px);
  --card-pad: clamp(22px,2.4vw,34px);
}

body{font-size:16px;line-height:1.7;text-rendering:optimizeLegibility;}
main{overflow:hidden;}
.container{width:min(100% - clamp(32px,6vw,96px), var(--content-max-width,1240px)) !important;}
.section{padding:var(--space-7) 0 !important;}
.section + .section{border-top:0;}
.surface + .surface{padding-top:0 !important;}

.page-hero{padding:clamp(72px,9vw,128px) 0 var(--space-6) !important;}
.page-hero h1{max-width:980px;font-size:clamp(42px,6vw,82px) !important;line-height:1.02 !important;letter-spacing:-.055em !important;}
.page-hero p:not(.eyebrow){max-width:var(--readable);font-size:clamp(1rem,1.5vw,1.22rem);line-height:1.7;margin-top:var(--space-4);}

.section-head{display:grid !important;grid-template-columns:minmax(0,1fr) minmax(280px,520px) !important;gap:var(--space-5) !important;align-items:end;margin-bottom:var(--space-5) !important;}
.section-head h2{font-size:clamp(32px,4.8vw,64px) !important;line-height:1.06 !important;letter-spacing:-.05em !important;max-width:850px;}
.section-head p{max-width:var(--narrow);font-size:1rem;line-height:1.75;}
.eyebrow,.kicker,.card-kicker{margin:0 0 var(--space-3) !important;letter-spacing:.12em;line-height:1.35;}

p{max-width:var(--readable);}
p+p{margin-top:var(--space-3) !important;}
h1,h2,h3{overflow-wrap:normal;hyphens:auto;}

.card,.project-card,.text-block,.pain-card,.question-grid article,.case-card,.case-mini-grid article,.case-proof-grid article,.insight-example,.insights-principles article{padding:var(--card-pad) !important;border-radius:clamp(20px,2vw,28px) !important;}
.cards-grid,.project-grid,.content-grid,.pain-grid,.question-grid,.case-grid,.case-proof-grid,.insights-card-grid,.insights-example-grid,.insights-principles{gap:var(--grid-gap) !important;}
.card h3,.project-card h3,.pain-card h3,.question-grid h3,.case-card h3{margin-top:0;margin-bottom:var(--space-2);line-height:1.22;letter-spacing:-.025em;}
.card p,.project-card p,.pain-card p,.question-grid p,.case-card p{line-height:1.65;}
.button-row{margin-top:var(--space-4) !important;gap:12px !important;}

.case-hero .button-row{margin-top:var(--space-5) !important;}
.case-grid{grid-template-columns:repeat(3,minmax(0,1fr)) !important;align-items:stretch;}
.case-highlight{gap:var(--grid-gap) !important;}
.case-card{gap:var(--space-3) !important;min-height:0 !important;}
.case-card--featured{grid-column:span 1;}
.case-card .kicker{display:block;max-width:100%;white-space:normal;}
.case-meta{display:flex !important;flex-wrap:wrap !important;gap:8px !important;margin-top:auto !important;}
.case-meta span{display:inline-flex !important;align-items:center;margin:0 !important;white-space:normal;line-height:1.25;}
.case-card strong{display:inline-flex;margin-top:var(--space-2) !important;}

.case-summary-card{padding:clamp(26px,4vw,54px) !important;border-radius:clamp(24px,2.4vw,34px) !important;}
.case-summary-grid{grid-template-columns:repeat(5,minmax(0,1fr));gap:var(--grid-gap) !important;}
.case-summary-grid article{padding:clamp(18px,2vw,24px) !important;border-radius:20px;}
.case-summary-grid span{line-height:1.55;}
.case-layout{grid-template-columns:minmax(220px,260px) minmax(0,780px) !important;gap:var(--space-6) !important;align-items:start;}
.case-sidebar{top:calc(var(--header-offset,76px) + 24px) !important;}
.case-sidebar nav{gap:6px !important;}
.case-sidebar a{display:block;line-height:1.25;}
.case-article section{padding:0 0 var(--space-6) !important;margin-bottom:var(--space-6) !important;}
.case-article h2{font-size:clamp(28px,3.4vw,48px) !important;line-height:1.15 !important;letter-spacing:-.035em !important;margin:0 0 var(--space-4) !important;max-width:760px;}
.case-article p{font-size:clamp(1rem,1.1vw,1.08rem) !important;line-height:1.78 !important;margin:0 0 var(--space-3) !important;max-width:var(--readable);}
.case-list{gap:12px !important;margin:var(--space-3) 0 var(--space-4) !important;max-width:var(--readable);}
.case-list li{line-height:1.65;}
.case-learning{padding:clamp(28px,4.5vw,48px) !important;}
.case-learning blockquote{line-height:1.7;margin-top:var(--space-4);}

.target-card,.cta-card{padding:clamp(34px,5.5vw,72px) !important;border-radius:clamp(24px,2.8vw,34px) !important;}
.target-card h2,.cta-card h2{font-size:clamp(30px,4.5vw,58px) !important;line-height:1.09 !important;}

@media (min-width: 981px){
  .case-card--featured{padding:clamp(30px,3vw,42px) !important;}
}
@media (max-width:1180px){
  .section-head{grid-template-columns:1fr !important;align-items:start;}
  .case-grid{grid-template-columns:repeat(2,minmax(0,1fr)) !important;}
  .case-summary-grid{grid-template-columns:repeat(2,minmax(0,1fr)) !important;}
}
@media (max-width:980px){
  .case-layout{grid-template-columns:1fr !important;}
  .case-sidebar nav{display:flex !important;gap:8px !important;overflow-x:auto;padding:10px !important;scroll-snap-type:x proximity;}
  .case-sidebar a{flex:0 0 auto;scroll-snap-align:start;background:var(--surface);}
}
@media (max-width:760px){
  .section{padding:clamp(56px,13vw,78px) 0 !important;}
  .page-hero{padding:clamp(52px,12vw,76px) 0 clamp(34px,8vw,52px) !important;}
  .page-hero h1{font-size:clamp(34px,10vw,48px) !important;}
  .section-head{margin-bottom:var(--space-4) !important;}
  .section-head h2{font-size:clamp(30px,9vw,42px) !important;}
  .case-grid,.case-proof-grid,.case-summary-grid{grid-template-columns:1fr !important;}
  .case-meta{gap:6px !important;}
  .case-meta span{font-size:.76rem !important;}
  .floating-contact{bottom:max(12px,env(safe-area-inset-bottom)) !important;}
}

/* Home case-study teaser: compact, visual, click-oriented */
.home-cases {
  background: #fff;
}

.section-head--compact {
  margin-bottom: clamp(28px, 4vw, 48px) !important;
}

.home-case-feature {
  display: grid;
  grid-template-columns: minmax(0, 1.35fr) minmax(300px, .65fr);
  gap: var(--grid-gap, 24px);
  align-items: stretch;
  margin-bottom: var(--grid-gap, 24px);
}

.home-case-feature__main,
.home-case-side,
.home-case-tile {
  border: 1px solid var(--line);
  border-radius: clamp(22px, 2vw, 30px);
  background: #fff;
  color: inherit;
  min-width: 0;
}

.home-case-feature__main {
  display: flex;
  flex-direction: column;
  gap: clamp(14px, 2vw, 22px);
  padding: clamp(28px, 4.2vw, 54px);
  background: linear-gradient(180deg, #ffffff 0%, var(--surface) 100%);
  box-shadow: var(--shadow);
  transition: transform .2s ease, border-color .2s ease, box-shadow .2s ease;
}

.home-case-feature__main:hover,
.home-case-tile:hover {
  transform: translateY(-3px);
  border-color: rgba(17,17,17,.18);
  box-shadow: var(--shadow);
}

.home-case-feature__main h3 {
  max-width: 820px;
  margin: 0;
  color: var(--primary);
  font-size: clamp(1.7rem, 3.15vw, 3.3rem);
  line-height: 1.04;
  letter-spacing: -.05em;
}

.home-case-feature__main p {
  max-width: 760px;
  margin: 0;
  color: var(--muted);
  font-size: clamp(1rem, 1.15vw, 1.1rem);
  line-height: 1.7;
}

.home-case-feature__main strong,
.home-case-tile strong,
.text-link {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  width: fit-content;
  margin-top: auto;
  color: var(--primary);
  font-weight: 850;
}

.home-case-side {
  display: flex;
  flex-direction: column;
  justify-content: center;
  padding: clamp(24px, 3vw, 38px);
  background: var(--primary);
  color: #fff;
}

.home-case-side .eyebrow,
.home-case-side p {
  color: rgba(255,255,255,.7);
}

.home-case-side h3 {
  margin: 0 0 14px;
  color: #fff;
  font-size: clamp(1.3rem, 2vw, 2rem);
  line-height: 1.13;
  letter-spacing: -.035em;
}

.home-case-side p {
  margin: 0;
  line-height: 1.7;
}

.home-case-side .text-link {
  margin-top: clamp(22px, 3vw, 34px);
  color: #fff;
}

.home-case-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: var(--grid-gap, 24px);
}

.home-case-tile {
  display: flex;
  flex-direction: column;
  gap: 14px;
  padding: clamp(22px, 2.5vw, 32px);
  transition: transform .2s ease, border-color .2s ease, box-shadow .2s ease;
}

.home-case-tile span {
  color: var(--muted);
  font-weight: 850;
  letter-spacing: .12em;
  font-size: .78rem;
}

.home-case-tile h3 {
  margin: 0;
  color: var(--primary);
  font-size: clamp(1.08rem, 1.45vw, 1.35rem);
  line-height: 1.22;
  letter-spacing: -.025em;
}

.home-case-tile p {
  margin: 0;
  color: var(--muted);
  line-height: 1.65;
}

.home-cases .case-meta {
  margin-top: 0 !important;
}

@media (max-width: 1080px) {
  .home-case-feature {
    grid-template-columns: 1fr;
  }
  .home-case-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 720px) {
  .home-case-grid {
    grid-template-columns: 1fr;
  }
  .home-case-feature__main,
  .home-case-side,
  .home-case-tile {
    border-radius: 22px;
  }
  .home-case-feature__main,
  .home-case-side {
    padding: 24px;
  }
  .home-case-feature__main h3 {
    font-size: clamp(1.55rem, 8vw, 2.35rem);
  }
}

/* v41: Fallbeispiele im Karten-Design wie Themenbereich
   Ziel: kompakter Startseiten-Teaser und hochwertige Übersicht auf der Fallbeispielseite. */
.case-showcase {
  background: #fff;
}

.case-showcase__head {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(280px, 520px);
  gap: clamp(28px, 5vw, 84px);
  align-items: end;
  margin-bottom: clamp(28px, 4vw, 46px);
}

.case-showcase__head h1,
.case-showcase__head h2 {
  max-width: 780px;
  margin: 0;
  color: var(--primary);
  font-size: clamp(42px, 6.2vw, 82px) !important;
  line-height: .98 !important;
  letter-spacing: -.065em !important;
}

.case-showcase__head p:not(.eyebrow) {
  max-width: 560px;
  margin: 0;
  color: var(--muted);
  font-size: clamp(1.05rem, 1.4vw, 1.22rem);
  line-height: 1.65;
}

.case-filter {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  margin-bottom: clamp(26px, 3.6vw, 44px);
}

.case-filter__item {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 44px;
  padding: 10px 20px;
  border: 1px solid var(--line);
  border-radius: 999px;
  background: #fff;
  color: var(--primary);
  font-size: .98rem;
  font-weight: 850;
  line-height: 1;
  white-space: nowrap;
}

.case-filter__item.is-active {
  border-color: var(--primary);
  background: var(--primary);
  color: #fff;
}

.case-showcase__grid,
.case-library__grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: clamp(18px, 2vw, 26px);
}

.case-teaser {
  display: flex;
  flex-direction: column;
  min-height: clamp(240px, 18vw, 300px);
  padding: clamp(26px, 2.7vw, 38px);
  border: 1px solid var(--line);
  border-radius: clamp(22px, 2vw, 30px);
  background: #fff;
  color: inherit;
  text-decoration: none;
  transition: transform .2s ease, border-color .2s ease, box-shadow .2s ease;
}

.case-teaser[href]:hover {
  transform: translateY(-3px);
  border-color: rgba(17, 17, 17, .18);
  box-shadow: var(--shadow);
}

.case-teaser--featured {
  background: linear-gradient(180deg, #fff 0%, var(--surface) 100%);
  box-shadow: var(--shadow);
}

.case-teaser .card-kicker {
  display: block;
  margin: 0 0 clamp(20px, 2vw, 28px) !important;
  color: var(--muted);
  font-size: .78rem;
  font-weight: 850;
  letter-spacing: .14em;
  line-height: 1.35;
  text-transform: uppercase;
}

.case-teaser h3 {
  margin: 0 0 16px;
  color: var(--primary);
  font-size: clamp(1.28rem, 1.65vw, 1.75rem);
  line-height: 1.14;
  letter-spacing: -.035em;
}

.case-teaser p {
  margin: 0;
  color: var(--muted);
  font-size: clamp(.98rem, 1vw, 1.06rem);
  line-height: 1.66;
}

.case-teaser__link {
  display: inline-flex;
  width: fit-content;
  margin-top: auto;
  padding-top: clamp(18px, 2vw, 28px);
  color: var(--primary);
  font-weight: 850;
}

.case-showcase__footer {
  display: flex;
  justify-content: space-between;
  gap: clamp(18px, 3vw, 40px);
  align-items: center;
  margin-top: clamp(26px, 3.4vw, 44px);
}

.case-showcase__footer p {
  max-width: 640px;
  margin: 0;
  color: var(--muted);
  line-height: 1.65;
}

.case-library-hero {
  padding-bottom: clamp(20px, 4vw, 54px) !important;
}

.case-library {
  padding-top: clamp(18px, 3vw, 48px) !important;
}

.case-library .case-teaser--featured {
  grid-column: span 2;
}

.case-library .case-teaser--featured h3 {
  max-width: 760px;
  font-size: clamp(1.65rem, 2.55vw, 2.8rem);
  line-height: 1.06;
}

@media (max-width: 1180px) {
  .case-showcase__head {
    grid-template-columns: 1fr;
    gap: 18px;
  }
  .case-showcase__grid,
  .case-library__grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
  .case-library .case-teaser--featured {
    grid-column: span 2;
  }
}

@media (max-width: 760px) {
  .case-showcase__head h1,
  .case-showcase__head h2 {
    font-size: clamp(34px, 10vw, 48px) !important;
    line-height: 1.03 !important;
  }
  .case-filter {
    flex-wrap: nowrap;
    overflow-x: auto;
    padding-bottom: 4px;
    margin-left: calc(var(--space-2, 10px) * -1);
    margin-right: calc(var(--space-2, 10px) * -1);
    padding-left: var(--space-2, 10px);
    padding-right: var(--space-2, 10px);
    -webkit-overflow-scrolling: touch;
  }
  .case-filter__item {
    flex: 0 0 auto;
    min-height: 40px;
    padding: 9px 16px;
    font-size: .92rem;
  }
  .case-showcase__grid,
  .case-library__grid {
    grid-template-columns: 1fr;
  }
  .case-library .case-teaser--featured {
    grid-column: auto;
  }
  .case-teaser {
    min-height: 0;
    padding: 24px;
  }
  .case-showcase__footer {
    align-items: flex-start;
    flex-direction: column;
  }
}


/* Fallbeispiele: echte Filter-Navigation */
button.case-filter__item {
  appearance: none;
  cursor: pointer;
  font-family: inherit;
}

.case-filter__item:focus-visible {
  outline: 3px solid rgba(17, 17, 17, .22);
  outline-offset: 3px;
}

.case-teaser.is-filtered-out {
  display: none;
}

/* v42: Visuelle Feinpolitur ohne Inhaltsänderungen
   Ziel: ausgewogenere CTA-Bereiche, bessere Fallbeispiel-Lesbarkeit,
   keine verschachtelt/abgeschnitten wirkenden Karten, konsistente Responsive-Abstände. */
:root{
  --visual-section-y: clamp(64px, 7vw, 104px);
  --visual-card-radius: clamp(22px, 2.2vw, 32px);
  --visual-soft-shadow: 0 18px 60px rgba(17,17,17,.055);
}

/* Globale vertikale Rhythmik: große Boxen nicht künstlich aufblähen */
.section{padding-top:var(--visual-section-y) !important;padding-bottom:var(--visual-section-y) !important;}
.section.surface{background:#f8f8f8;}

/* CTA und Zielgruppen-Karten: kompakter, weniger Hero-Anmutung, bessere optische Balance */
.cta-section .cta-card,
.target-section .target-card,
.surface .target-card{
  width:min(100% - clamp(32px, 6vw, 96px), var(--content-max-width,1240px)) !important;
  display:grid !important;
  grid-template-columns:minmax(0, 1fr) auto;
  align-items:center;
  gap:clamp(24px,4vw,64px);
  text-align:left !important;
  padding:clamp(30px,4.2vw,56px) !important;
  border-radius:var(--visual-card-radius) !important;
  box-shadow:var(--visual-soft-shadow) !important;
  background:linear-gradient(180deg,#fff 0%,#fafafa 100%) !important;
}
.cta-section .cta-card .eyebrow,
.target-card .eyebrow{grid-column:1 / -1;margin-bottom:0 !important;}
.cta-section .cta-card h2,
.target-card h2{
  max-width:820px !important;
  font-size:clamp(30px,3.6vw,54px) !important;
  line-height:1.08 !important;
  letter-spacing:-.052em !important;
}
.cta-section .cta-card p:not(.eyebrow),
.target-card p:not(.eyebrow){
  max-width:680px !important;
  margin:clamp(12px,1.4vw,18px) 0 0 !important;
  font-size:clamp(1rem,1.1vw,1.1rem) !important;
  line-height:1.7 !important;
}
.cta-section .cta-card .button-row,
.target-card .button-row{
  grid-column:2;
  grid-row:2 / span 2;
  justify-content:flex-end !important;
  align-self:center;
  margin-top:0 !important;
  min-width:max-content;
}

/* Fallbeispiel-Detailseite: ausgewogenere Breite und stabilere Navigation */
.case-content-section{padding-top:clamp(48px,5vw,78px) !important;}
.case-layout{
  grid-template-columns:minmax(190px,230px) minmax(0,940px) !important;
  gap:clamp(28px,4.5vw,64px) !important;
  justify-content:center !important;
}
.case-sidebar nav{
  border-radius:20px !important;
  box-shadow:none !important;
}
.case-sidebar a{line-height:1.25 !important;}
.case-article{width:100%;}
.case-article section{
  max-width:940px;
  padding-bottom:clamp(42px,4.8vw,64px) !important;
  margin-bottom:clamp(42px,4.8vw,64px) !important;
}
.case-article h2{
  max-width:880px !important;
  font-size:clamp(30px,3.2vw,50px) !important;
  line-height:1.12 !important;
}
.case-article p,
.case-list{max-width:78ch !important;}
.case-list li{line-height:1.68 !important;}

/* Fazit-Karte: keine Karte-in-Karte-Optik und kein abgeschnitten wirkender Rand */
.case-learning{
  max-width:940px !important;
  padding:clamp(30px,4vw,50px) !important;
  border-radius:var(--visual-card-radius) !important;
  box-shadow:var(--visual-soft-shadow) !important;
  background:linear-gradient(180deg,#fff 0%,#fafafa 100%) !important;
}
.case-learning blockquote{
  max-width:78ch;
  margin:clamp(22px,2.8vw,34px) 0 0 !important;
  padding:clamp(18px,2vw,24px) 0 0 !important;
  border-left:0 !important;
  border-top:1px solid var(--line) !important;
  border-radius:0 !important;
  background:transparent !important;
  box-shadow:none !important;
}
.case-learning blockquote strong{display:block;margin-bottom:6px;color:var(--primary);}

/* Fallbeispiel-Karten: Metadaten sauber trennen und nicht zusammenkleben */
.case-meta{gap:8px !important;row-gap:8px !important;}
.case-meta span{white-space:nowrap;}
.case-filter{align-items:center;}
.case-filter__item{transition:background .18s ease,color .18s ease,border-color .18s ease,transform .18s ease;}
.case-filter__item:hover{transform:translateY(-1px);}

/* Kartenraster auf Unterseiten sauber ausrichten */
.case-showcase__grid,
.case-library__grid{align-items:stretch;}
.case-teaser{height:100%;}
.case-teaser p{max-width:100%;}

@media (max-width: 980px){
  .cta-section .cta-card,
  .target-section .target-card,
  .surface .target-card{
    grid-template-columns:1fr;
    gap:clamp(18px,4vw,28px);
    text-align:left !important;
  }
  .cta-section .cta-card .button-row,
  .target-card .button-row{
    grid-column:auto;
    grid-row:auto;
    justify-content:flex-start !important;
    min-width:0;
    margin-top:4px !important;
  }
  .case-layout{grid-template-columns:1fr !important;}
  .case-sidebar{position:relative !important;top:auto !important;z-index:2;}
  .case-sidebar nav{
    border-radius:999px !important;
    background:#fff !important;
  }
}

@media (max-width: 760px){
  .container{width:min(100% - 32px, var(--content-max-width,1240px)) !important;}
  .cta-section .cta-card,
  .target-section .target-card,
  .surface .target-card{
    padding:26px 22px !important;
    border-radius:24px !important;
  }
  .cta-section .cta-card h2,
  .target-card h2{font-size:clamp(28px,8vw,40px) !important;}
  .button-row{gap:10px !important;}
  .case-article section{
    padding-bottom:38px !important;
    margin-bottom:38px !important;
  }
  .case-learning{padding:26px 22px !important;}
  .case-filter{gap:10px !important;}
  .case-filter__item{min-height:42px !important;padding:9px 16px !important;}
}

@media (max-width: 460px){
  .btn{width:100%;}
  .cta-section .cta-card .button-row,
  .target-card .button-row{width:100%;}
  .case-sidebar nav{border-radius:18px !important;}
  .case-meta span{white-space:normal;}
}


/* Geschäftsbereiche-Übersicht */
.business-overview-hero .container > p:not(.eyebrow){max-width:760px;}
.business-card-grid{
  display:grid;
  grid-template-columns:repeat(4,minmax(0,1fr));
  gap:var(--grid-gap,20px);
  align-items:stretch;
}
.business-card{
  display:flex;
  flex-direction:column;
  min-height:clamp(280px,24vw,360px);
  padding:clamp(26px,2.6vw,38px);
  border:1px solid var(--line,#e5e7eb);
  border-radius:clamp(22px,2vw,30px);
  background:#fff;
  color:inherit;
  text-decoration:none;
  transition:transform .2s ease, box-shadow .2s ease, border-color .2s ease;
}
.business-card:hover{
  transform:translateY(-4px);
  border-color:#d1d5db;
  box-shadow:var(--shadow,0 20px 60px rgba(15,23,42,.08));
}
.business-card__kicker{
  display:block;
  margin-bottom:clamp(22px,2.2vw,34px);
  font-size:.76rem;
  font-weight:800;
  letter-spacing:.14em;
  line-height:1.2;
  text-transform:uppercase;
  color:var(--muted,#6b7280);
}
.business-card h3{
  margin:0 0 14px;
  color:var(--primary,#0b0b0f);
  font-size:clamp(1.28rem,1.55vw,1.72rem);
  line-height:1.12;
  letter-spacing:-.035em;
}
.business-card p{
  margin:0;
  color:var(--muted,#6b7280);
  font-size:1rem;
  line-height:1.65;
}
.business-card__link{
  display:inline-flex;
  align-items:center;
  gap:8px;
  margin-top:auto;
  padding-top:clamp(24px,2.5vw,36px);
  color:var(--primary,#0b0b0f);
  font-weight:800;
}
.business-card__link::after{content:"→";font-weight:800;transition:transform .18s ease;}
.business-card:hover .business-card__link::after{transform:translateX(3px);}

@media (max-width:1180px){
  .business-card-grid{grid-template-columns:repeat(2,minmax(0,1fr));}
}
@media (max-width:760px){
  .business-card-grid{grid-template-columns:1fr;}
  .business-card{min-height:auto;}
}

/* v44: Editorial start hero and proof strip
   Aligns the homepage with the clearer positioning and the case-study system. */
.hero--editorial {
  padding-top: clamp(72px, 8vw, 118px) !important;
  padding-bottom: clamp(64px, 7vw, 108px) !important;
}

.hero--editorial .hero-grid {
  grid-template-columns: minmax(0, 1.18fr) minmax(320px, 0.72fr) !important;
  gap: clamp(44px, 7vw, 108px) !important;
  align-items: center !important;
}

.hero--editorial .hero-copy {
  max-width: 840px !important;
}

.hero--editorial .hero-title {
  max-width: 820px !important;
  font-size: clamp(3rem, 5.35vw, 5.85rem) !important;
  line-height: 0.99 !important;
  letter-spacing: -0.075em !important;
  hyphens: none !important;
  word-break: normal !important;
  overflow-wrap: normal !important;
}

.hero--editorial .hero-copy > p:not(.eyebrow) {
  max-width: 720px !important;
  font-size: clamp(1.08rem, 1.45vw, 1.32rem) !important;
  line-height: 1.65 !important;
  margin-top: 30px !important;
}

.hero--editorial .hero-visual {
  justify-self: end !important;
  width: 100% !important;
  max-width: 500px !important;
}

.hero-photo-card--editorial {
  max-width: 500px !important;
  width: 100% !important;
  margin: 0 !important;
  border-radius: clamp(28px, 2.6vw, 42px) !important;
  border: 1px solid rgba(229, 231, 235, 0.88) !important;
  background: #f3f4f6 !important;
  box-shadow: 0 32px 90px rgba(17,17,17,.09) !important;
  overflow: hidden !important;
}

.hero-photo-card--editorial img {
  aspect-ratio: 4 / 5 !important;
  width: 100% !important;
  height: auto !important;
  object-fit: cover !important;
  object-position: 54% 50% !important;
  filter: saturate(.95) contrast(1.03) !important;
}

.home-proof {
  background: #fff;
  border-top: 1px solid var(--line);
  border-bottom: 1px solid var(--line);
}

.home-proof__inner {
  padding: clamp(34px, 4vw, 56px) 0;
}

.home-proof__inner .eyebrow {
  margin-bottom: 18px;
}

.home-proof__grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 14px;
}

.home-proof__item {
  display: grid;
  gap: 16px;
  min-height: 148px;
  padding: clamp(22px, 2.4vw, 30px);
  border: 1px solid var(--line);
  border-radius: 26px;
  background: #fff;
  transition: transform .2s ease, box-shadow .2s ease, border-color .2s ease;
}

.home-proof__item:hover {
  transform: translateY(-3px);
  border-color: #d1d5db;
  box-shadow: 0 20px 60px rgba(17,17,17,.06);
}

.home-proof__item span {
  font-weight: 800;
  color: var(--muted);
  letter-spacing: .08em;
  font-size: .82rem;
}

.home-proof__item strong {
  color: var(--primary);
  font-size: clamp(1rem, 1.25vw, 1.18rem);
  line-height: 1.25;
  letter-spacing: -0.025em;
}

.home-proof__link {
  display: inline-flex;
  margin-top: 22px;
  color: var(--primary);
  font-weight: 800;
}

@media (max-width: 1180px) {
  .hero--editorial .hero-grid {
    grid-template-columns: 1fr !important;
    gap: 42px !important;
  }
  .hero--editorial .hero-copy,
  .hero--editorial .hero-title {
    max-width: 900px !important;
  }
  .hero--editorial .hero-visual {
    justify-self: start !important;
    max-width: 560px !important;
  }
  .hero-photo-card--editorial {
    max-width: 560px !important;
  }
  .hero-photo-card--editorial img {
    aspect-ratio: 16 / 10 !important;
    object-position: 52% 42% !important;
  }
}

@media (max-width: 900px) {
  .hero--editorial .hero-title {
    font-size: clamp(2.55rem, 9vw, 4.6rem) !important;
    line-height: 1.02 !important;
  }
  .home-proof__grid {
    grid-template-columns: 1fr;
  }
  .home-proof__item {
    min-height: auto;
  }
}

@media (max-width: 560px) {
  .hero--editorial {
    padding-top: 54px !important;
    padding-bottom: 64px !important;
  }
  .hero--editorial .hero-title {
    font-size: clamp(2.15rem, 10.5vw, 3.15rem) !important;
    line-height: 1.05 !important;
    letter-spacing: -0.06em !important;
  }
  .hero--editorial .hero-copy > p:not(.eyebrow) {
    font-size: 1rem !important;
    margin-top: 22px !important;
  }
  .hero-photo-card--editorial {
    border-radius: 28px !important;
  }
  .hero-photo-card--editorial img {
    aspect-ratio: 4 / 5 !important;
    object-position: 52% 45% !important;
  }
}

/* v45: Homepage editorial hero large-screen balance fix
   Keeps the good laptop composition while preventing overly narrow headline columns
   on very large screens. This override intentionally sits at the end of the file. */
:root {
  --site-max-width: 1560px;
  --content-max-width: 1420px;
}

main,
.site-header,
.site-footer {
  max-width: var(--site-max-width) !important;
  margin-left: auto !important;
  margin-right: auto !important;
}

h1,
h2,
.hero-title,
.page-hero h1 {
  hyphens: none !important;
  word-break: normal !important;
  overflow-wrap: normal !important;
}

@media (min-width: 1281px) {
  .hero--editorial {
    min-height: calc(100vh - 76px) !important;
    padding-top: clamp(76px, 7vw, 116px) !important;
    padding-bottom: clamp(72px, 7vw, 116px) !important;
  }

  .hero--editorial .container.hero-grid,
  .hero--editorial .hero-grid {
    width: min(100% - 96px, var(--content-max-width)) !important;
    display: grid !important;
    grid-template-columns: minmax(680px, 1fr) minmax(400px, 520px) !important;
    gap: clamp(64px, 5vw, 96px) !important;
    align-items: center !important;
    justify-content: space-between !important;
  }

  .hero--editorial .hero-copy,
  .hero--editorial .hero-grid > div:first-child {
    max-width: 820px !important;
    min-width: 0 !important;
  }

  .hero--editorial .hero-title {
    max-width: 820px !important;
    font-size: clamp(4.35rem, 4.35vw, 5.55rem) !important;
    line-height: 1.01 !important;
    letter-spacing: -0.072em !important;
  }

  .hero--editorial .hero-copy > p:not(.eyebrow) {
    max-width: 660px !important;
    font-size: clamp(1.08rem, 1.25vw, 1.28rem) !important;
    line-height: 1.68 !important;
  }

  .hero--editorial .hero-visual {
    justify-self: end !important;
    width: 100% !important;
    max-width: 520px !important;
  }

  .hero--editorial .hero-photo-card--editorial {
    width: 100% !important;
    max-width: 520px !important;
  }
}

@media (min-width: 1680px) {
  .hero--editorial .container.hero-grid,
  .hero--editorial .hero-grid {
    grid-template-columns: minmax(760px, 1fr) minmax(420px, 540px) !important;
    gap: clamp(72px, 5vw, 108px) !important;
  }

  .hero--editorial .hero-copy,
  .hero--editorial .hero-grid > div:first-child,
  .hero--editorial .hero-title {
    max-width: 900px !important;
  }

  .hero--editorial .hero-title {
    font-size: clamp(4.8rem, 4.2vw, 5.8rem) !important;
  }

  .hero--editorial .hero-visual,
  .hero--editorial .hero-photo-card--editorial {
    max-width: 540px !important;
  }
}

@media (max-width: 1280px) {
  .hero--editorial .hero-grid {
    grid-template-columns: 1fr !important;
  }

  .hero--editorial .hero-title {
    max-width: 820px !important;
  }
}


/* About page refinement */
.about-hero .about-hero-grid{display:grid;grid-template-columns:minmax(0,1.15fr) minmax(320px,.85fr);gap:clamp(36px,6vw,96px);align-items:end}
.about-hero .about-hero-copy{max-width:560px;color:var(--muted);font-size:clamp(1.08rem,1.25vw,1.25rem);line-height:1.65}
.about-hero .button-row{margin-top:28px}
.about-profile-grid{display:grid;grid-template-columns:minmax(280px,420px) minmax(0,1fr);gap:clamp(44px,7vw,96px);align-items:center}
.about-main-portrait{border-radius:clamp(28px,3vw,44px);box-shadow:0 30px 80px rgba(15,23,42,.10)}
.card-kicker{display:inline-flex;margin-bottom:22px;color:var(--muted);font-size:.78rem;letter-spacing:.14em;text-transform:uppercase;font-weight:800}
.about-strengths-grid .text-block{min-height:260px}
.about-split{display:grid;grid-template-columns:minmax(0,.95fr) minmax(340px,1.05fr);gap:clamp(44px,7vw,92px);align-items:start}
.about-split>div:first-child p{color:var(--muted);font-size:1.08rem;line-height:1.75;max-width:680px}
.about-timeline{display:grid;gap:18px}
.about-timeline article{border:1px solid var(--line);border-radius:28px;background:#fff;padding:28px;box-shadow:0 16px 50px rgba(15,23,42,.04)}
.about-timeline span{display:block;margin-bottom:16px;color:var(--muted);font-size:.78rem;letter-spacing:.14em;text-transform:uppercase;font-weight:800}
.about-timeline h3{margin:0 0 10px;color:var(--primary);font-size:clamp(1.2rem,1.8vw,1.55rem);letter-spacing:-.035em;line-height:1.15}
.about-timeline p{margin:0;color:var(--muted);line-height:1.65}
.about-principles article{background:#fff}
.about-statement{text-align:left;max-width:1040px;margin-inline:auto}
.about-statement p:not(.eyebrow){max-width:820px}
.about-statement .button-row{margin-top:28px}
@media (max-width:980px){.about-hero .about-hero-grid,.about-profile-grid,.about-split{grid-template-columns:1fr}.about-hero .about-hero-copy{max-width:720px}.about-main-portrait{max-width:420px}}
@media (max-width:620px){.about-hero .button-row,.about-statement .button-row{width:100%}.about-strengths-grid .text-block{min-height:0}.about-timeline article{padding:22px}}

/* Über mich: Persönliches Statement, einspaltige, ruhige Darstellung */
.about-statement.target-card{
  display:block !important;
  width:100% !important;
  max-width:1040px !important;
  margin-inline:auto !important;
  text-align:left !important;
  padding:clamp(36px,5vw,64px) !important;
  border-radius:clamp(26px,3vw,36px) !important;
  background:linear-gradient(180deg,#fff 0%,#fafafa 100%) !important;
  box-shadow:0 24px 80px rgba(15,23,42,.06) !important;
}
.about-statement.target-card .eyebrow{
  display:block !important;
  margin:0 0 12px !important;
}
.about-statement.target-card h2{
  max-width:860px !important;
  margin:0 !important;
  font-size:clamp(2.1rem,4vw,4.1rem) !important;
  line-height:1.06 !important;
  letter-spacing:-.055em !important;
}
.about-statement.target-card p:not(.eyebrow){
  max-width:760px !important;
  margin:clamp(18px,2vw,26px) 0 0 !important;
  font-size:clamp(1.02rem,1.1vw,1.12rem) !important;
  line-height:1.72 !important;
}
.about-statement.target-card .button-row{
  display:flex !important;
  grid-column:auto !important;
  grid-row:auto !important;
  justify-content:flex-start !important;
  align-self:auto !important;
  margin-top:clamp(24px,2.8vw,34px) !important;
  min-width:0 !important;
}

@media (max-width:760px){
  .about-statement.target-card{
    padding:30px 24px !important;
  }
  .about-statement.target-card h2{
    font-size:clamp(2rem,9vw,2.8rem) !important;
    line-height:1.08 !important;
  }
  .about-statement.target-card .button-row{
    flex-direction:column !important;
    align-items:stretch !important;
    width:100% !important;
  }
}

/* Orientierungssystem: aktive Hauptnavigation und Abschnittsnavigation */
.site-nav .nav-item.is-active > a,
.site-nav > a.nav-item.is-active,
.site-nav a[aria-current="page"]{
  color: var(--primary) !important;
  font-weight: 800 !important;
}

.site-nav .nav-item.is-active::after,
.site-nav > a.nav-item.is-active::after{
  transform: scaleX(1) !important;
}

.dropdown a.is-active,
.dropdown a[aria-current="page"]{
  background: var(--surface) !important;
  color: var(--primary) !important;
  font-weight: 800 !important;
}

.section-anchor-nav{
  position: sticky;
  top: var(--header-offset, 76px);
  z-index: 90;
  background: rgba(255,255,255,.92);
  backdrop-filter: blur(16px);
  border-top: 1px solid rgba(229,231,235,.72);
  border-bottom: 1px solid rgba(229,231,235,.9);
  transform: translateZ(0);
}

.section-anchor-nav__inner{
  display:flex;
  align-items:center;
  gap:10px;
  min-height:58px;
  overflow-x:auto;
  -webkit-overflow-scrolling:touch;
  scrollbar-width:none;
}

.section-anchor-nav__inner::-webkit-scrollbar{display:none}

.section-anchor-nav__label{
  flex:0 0 auto;
  color:var(--muted);
  font-size:.72rem;
  font-weight:800;
  letter-spacing:.13em;
  text-transform:uppercase;
  margin-right:4px;
}

.section-anchor-nav__link{
  flex:0 0 auto;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:34px;
  padding:8px 13px;
  border:1px solid transparent;
  border-radius:999px;
  color:var(--muted);
  font-size:.86rem;
  font-weight:800;
  line-height:1;
  white-space:nowrap;
  transition:background-color .2s ease,color .2s ease,border-color .2s ease,transform .2s ease;
}

.section-anchor-nav__link:hover{
  color:var(--primary);
  background:var(--surface);
}

.section-anchor-nav__link.is-active,
.section-anchor-nav__link[aria-current="true"]{
  color:#fff;
  background:var(--primary);
  border-color:var(--primary);
}

.case-sidebar nav a.is-active,
.case-sidebar nav a[aria-current="true"]{
  color:var(--primary) !important;
  font-weight:800 !important;
  background:var(--surface) !important;
}

main section[id],
.case-article section[id]{
  scroll-margin-top:calc(var(--header-offset, 76px) + 76px);
}

@media (min-width:981px){
  .section-anchor-nav.is-case-detail-nav{
    display:none;
  }
}

@media (max-width:980px){
  .section-anchor-nav{
    top:var(--header-offset, 76px);
  }
  .section-anchor-nav__inner{
    min-height:54px;
  }
  .section-anchor-nav__label{
    display:none;
  }
  .section-anchor-nav__link{
    font-size:.82rem;
    min-height:32px;
    padding:8px 12px;
  }
}

@media (max-width:520px){
  .section-anchor-nav__inner{
    width:100%;
    padding-right:20px;
  }
  .section-anchor-nav__link{
    font-size:.8rem;
  }
}

/* Orientierung hat Vorrang: Header bleibt sichtbar, damit der aktive Bereich immer erkennbar ist. */
.site-header[data-header].is-hidden{
  transform:translate3d(-50%,0,0) !important;
}

/* Kontaktseite kompakt: klarer Fokus auf Kontaktaufnahme */
.contact-page--compact .section-tight{
  padding-top:clamp(54px,7vw,92px) !important;
  padding-bottom:clamp(54px,7vw,92px) !important;
}
.contact-hero{
  padding-top:clamp(72px,9vw,124px) !important;
  padding-bottom:clamp(48px,6vw,78px) !important;
}
.contact-hero__grid{
  display:grid;
  grid-template-columns:minmax(0,1.1fr) minmax(280px,.62fr);
  gap:clamp(36px,6vw,92px);
  align-items:center;
}
.contact-hero__copy{max-width:780px;min-width:0}
.contact-hero__copy h1{
  max-width:860px;
  margin:0;
  color:var(--primary);
  font-size:clamp(3.2rem,5.6vw,6rem);
  line-height:1.01;
  letter-spacing:-.065em;
  hyphens:none;
  overflow-wrap:normal;
}
.contact-hero__copy p:not(.eyebrow){
  max-width:660px;
  margin:clamp(22px,2.5vw,30px) 0 0;
  color:var(--muted);
  font-size:clamp(1.05rem,1.35vw,1.24rem);
  line-height:1.68;
}
.contact-hero__portrait{
  margin:0;
  width:100%;
  max-width:430px;
  justify-self:end;
  aspect-ratio:4/5;
  border-radius:clamp(28px,3vw,44px);
  overflow:hidden;
  background:var(--surface);
  box-shadow:0 28px 80px rgba(15,23,42,.10);
}
.contact-hero__portrait img{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
}
.section-head--compact{margin-bottom:clamp(24px,3vw,34px) !important}
.section-head--compact h2{max-width:760px}
.contact-reason-grid{
  display:grid;
  grid-template-columns:repeat(4,minmax(0,1fr));
  gap:clamp(14px,1.6vw,20px);
}
.contact-reason-grid article{
  min-width:0;
  border:1px solid var(--line);
  border-radius:clamp(22px,2vw,30px);
  background:#fff;
  padding:clamp(22px,2.4vw,30px);
  box-shadow:0 14px 45px rgba(15,23,42,.035);
}
.contact-reason-grid span{
  display:inline-flex;
  margin-bottom:18px;
  color:var(--muted);
  font-size:.76rem;
  letter-spacing:.14em;
  text-transform:uppercase;
  font-weight:800;
}
.contact-reason-grid h3{
  margin:0 0 10px;
  color:var(--primary);
  font-size:clamp(1.1rem,1.35vw,1.35rem);
  line-height:1.18;
  letter-spacing:-.035em;
}
.contact-reason-grid p{
  margin:0;
  color:var(--muted);
  line-height:1.62;
  font-size:.98rem;
}
.contact-statement-section{padding-top:clamp(50px,6vw,82px) !important}
.contact-statement-card{
  display:grid;
  grid-template-columns:minmax(0,1fr) minmax(280px,420px);
  gap:clamp(28px,5vw,64px);
  align-items:center;
  border:1px solid var(--line);
  border-radius:clamp(28px,3vw,42px);
  background:linear-gradient(180deg,#fff 0%,#fafafa 100%);
  box-shadow:0 24px 80px rgba(15,23,42,.06);
  padding:clamp(34px,5vw,62px);
}
.contact-statement-card h2{
  max-width:780px;
  margin:0;
  color:var(--primary);
  font-size:clamp(2.1rem,3.7vw,4.1rem);
  line-height:1.06;
  letter-spacing:-.055em;
  hyphens:none;
}
.contact-statement-card p:not(.eyebrow){
  max-width:720px;
  margin:clamp(18px,2vw,24px) 0 0;
  color:var(--muted);
  font-size:clamp(1rem,1.1vw,1.12rem);
  line-height:1.72;
}
.contact-direct-card{
  border:1px solid var(--line);
  border-radius:28px;
  background:#fff;
  padding:clamp(24px,3vw,34px);
  box-shadow:0 16px 52px rgba(15,23,42,.045);
}
.contact-direct-card__label{
  margin:0 0 18px !important;
  color:var(--muted) !important;
  font-size:.78rem !important;
  letter-spacing:.14em;
  text-transform:uppercase;
  font-weight:800;
  line-height:1.3 !important;
}
.contact-direct-card a{
  display:block;
  color:var(--primary);
  font-weight:800;
  overflow-wrap:anywhere;
}
.contact-direct-card__mail{font-size:clamp(1.05rem,1.45vw,1.22rem);margin-bottom:14px}
.contact-direct-card__phone{font-size:1rem;color:var(--muted) !important}
.contact-page--compact .process,
.contact-page--compact .contact-box{display:none !important}

@media (max-width:1040px){
  .contact-reason-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
  .contact-statement-card{grid-template-columns:1fr}
}
@media (max-width:860px){
  .contact-hero__grid{grid-template-columns:1fr}
  .contact-hero__portrait{justify-self:start;max-width:360px}
  .contact-hero__copy h1{font-size:clamp(2.65rem,9vw,4.2rem)}
}
@media (max-width:620px){
  .contact-page--compact .section-tight{padding-top:48px !important;padding-bottom:48px !important}
  .contact-hero{padding-top:54px !important}
  .contact-reason-grid{grid-template-columns:1fr}
  .contact-statement-card{padding:28px 22px;border-radius:26px}
  .contact-hero__portrait{max-width:100%}
  .contact-hero__copy .button-row{width:100%}
  .contact-hero__copy .button-row .btn{width:100%}
}

/* v45: Fallbeispiel-Fazit global optimiert
   Ziel: Fazit-Block weniger dominant, bessere Lesbarkeit, Learning klar hervorgehoben. */
.case-article .case-learning{
  max-width: 1040px !important;
  margin-left: auto !important;
  margin-right: auto !important;
  padding: clamp(34px, 4.6vw, 58px) !important;
  border: 1px solid rgba(17,17,17,.08) !important;
  border-radius: clamp(26px, 2.4vw, 34px) !important;
  background: linear-gradient(180deg, #fff 0%, #fbfbfb 100%) !important;
  box-shadow: 0 28px 80px rgba(17,17,17,.06) !important;
}

.case-article .case-learning .eyebrow{
  margin-bottom: clamp(16px, 1.8vw, 24px) !important;
}

.case-article .case-learning h2{
  max-width: 820px !important;
  font-size: clamp(30px, 3vw, 46px) !important;
  line-height: 1.08 !important;
  letter-spacing: -0.055em !important;
  margin-bottom: clamp(24px, 2.4vw, 34px) !important;
}

.case-article .case-learning p{
  max-width: 78ch !important;
  font-size: clamp(16px, 1.05vw, 18px) !important;
  line-height: 1.75 !important;
  margin-top: 0 !important;
  margin-bottom: clamp(16px, 1.4vw, 22px) !important;
}

.case-article .case-learning blockquote{
  max-width: 820px !important;
  margin: clamp(34px, 3.4vw, 46px) 0 0 !important;
  padding: clamp(22px, 2.4vw, 30px) !important;
  border: 1px solid rgba(17,17,17,.08) !important;
  border-left: 4px solid var(--primary) !important;
  border-radius: 24px !important;
  background: #fff !important;
  box-shadow: none !important;
  color: var(--text) !important;
  line-height: 1.7 !important;
}

.case-article .case-learning blockquote strong{
  display: block !important;
  margin-bottom: 10px !important;
  color: var(--primary) !important;
  font-size: .95rem !important;
  letter-spacing: -0.01em !important;
}

@media (max-width: 760px){
  .case-article .case-learning{
    padding: 28px 22px !important;
    border-radius: 24px !important;
  }
  .case-article .case-learning h2{
    font-size: clamp(28px, 8vw, 38px) !important;
  }
  .case-article .case-learning blockquote{
    padding: 20px !important;
    border-radius: 20px !important;
  }
}

/* Case study password gate */
.case-locked-panel {
  margin-top: clamp(32px, 5vw, 64px);
  padding: clamp(28px, 5vw, 56px);
  border: 1px solid var(--border, #e5e7eb);
  border-radius: 32px;
  background: linear-gradient(180deg, rgba(255,255,255,0.96), rgba(248,250,252,0.92));
  box-shadow: 0 34px 90px rgba(15, 23, 42, 0.08);
}
.case-locked-panel h2 {
  max-width: 760px;
  margin-bottom: 18px;
}
.case-locked-panel p {
  max-width: 760px;
}
.case-access-form {
  margin-top: 28px;
  max-width: 760px;
}
.case-access-form label {
  display: block;
  margin-bottom: 10px;
  font-weight: 700;
  color: var(--ink, #111827);
}
.case-access-form__row {
  display: flex;
  gap: 12px;
  align-items: stretch;
}
.case-access-form input {
  flex: 1 1 auto;
  min-width: 0;
  border: 1px solid var(--border, #e5e7eb);
  border-radius: 999px;
  padding: 0 20px;
  font: inherit;
  color: var(--ink, #111827);
  background: #fff;
}
.case-access-form input:focus {
  outline: none;
  border-color: rgba(17, 24, 39, 0.38);
  box-shadow: 0 0 0 4px rgba(17, 24, 39, 0.06);
}
.case-access-form__error {
  margin-top: 12px;
  color: #9f1239;
  font-weight: 600;
}
.case-locked-panel__hint {
  margin-top: 18px;
  font-size: 0.95rem;
}
.case-locked-panel__hint a {
  font-weight: 700;
  color: inherit;
  text-decoration: underline;
  text-underline-offset: 3px;
}
.case-teaser--locked-note {
  background: #f8fafc;
}
@media (max-width: 680px) {
  .case-access-form__row {
    flex-direction: column;
  }
  .case-access-form input {
    min-height: 52px;
  }
}


/* Fallbeispiel-Bilder: reduzierte Farbigkeit, Farbe bei Interaktion */
.case-teaser__media,
.case-detail-image {
  position: relative;
  overflow: hidden;
  border-radius: var(--radius, 28px);
  background: rgba(20, 20, 20, 0.04);
}

.case-teaser__media {
  aspect-ratio: 16 / 10;
  margin: 0 0 1.25rem;
}

.case-detail-image {
  aspect-ratio: 21 / 9;
  margin: 2rem 0 0;
}

.case-teaser__media img,
.case-detail-image img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
  filter: grayscale(78%) saturate(58%) contrast(1.02);
  transition: filter .45s ease, transform .45s ease;
}

.case-teaser:hover .case-teaser__media img,
.case-teaser:focus-visible .case-teaser__media img,
.case-detail-image:hover img {
  filter: grayscale(0%) saturate(100%) contrast(1);
  transform: scale(1.025);
}

@media (hover: none) {
  .case-teaser__media img,
  .case-detail-image img {
    filter: grayscale(35%) saturate(82%) contrast(1.01);
  }
}


/* Projektkalkulator-Lightbox */
.has-modal-open{overflow:hidden}.calculator-modal{position:fixed;inset:0;z-index:9999;display:grid;place-items:center;padding:clamp(14px,2.5vw,34px);opacity:0;pointer-events:none;transition:opacity .18s ease}.calculator-modal.is-open{opacity:1;pointer-events:auto}.calculator-modal__backdrop{position:absolute;inset:0;background:rgba(17,17,17,.52);backdrop-filter:blur(8px)}.calculator-modal__panel{position:relative;z-index:1;width:min(1180px,96vw);height:min(860px,92vh);display:flex;flex-direction:column;overflow:hidden;border:1px solid var(--line);border-radius:32px;background:#fff;box-shadow:0 28px 90px rgba(17,17,17,.24);outline:none;transform:translateY(8px) scale(.985);transition:transform .18s ease}.calculator-modal.is-open .calculator-modal__panel{transform:translateY(0) scale(1)}.calculator-modal__header{display:flex;align-items:flex-start;justify-content:space-between;gap:18px;padding:22px 24px 18px;border-bottom:1px solid var(--line);background:#fff}.calculator-modal__eyebrow{margin:0 0 6px;font-size:.72rem;letter-spacing:.14em;text-transform:uppercase;color:var(--muted);font-weight:800}.calculator-modal__header h2{margin:0;font-size:clamp(1.2rem,2vw,1.9rem);line-height:1.12;letter-spacing:-.045em;color:var(--primary)}.calculator-modal__close{display:inline-flex;align-items:center;justify-content:center;width:42px;height:42px;border:1px solid var(--line);border-radius:999px;background:#fff;color:var(--primary);font-size:2rem;line-height:1;cursor:pointer}.calculator-modal__close:hover{background:var(--soft)}.calculator-modal__frame{flex:1;width:100%;border:0;background:#fff}.calculator-modal__fallback{display:flex;align-items:center;justify-content:center;gap:8px;min-height:42px;padding:10px 16px;border-top:1px solid var(--line);font-size:.9rem;color:var(--muted);background:#fff}.calculator-modal__fallback a{font-weight:800;color:var(--primary);text-decoration:underline;text-underline-offset:3px}@media (max-width:760px){.calculator-modal{padding:0}.calculator-modal__panel{width:100vw;height:100dvh;border-radius:0;border:0}.calculator-modal__header{padding:16px 18px 14px}.calculator-modal__close{width:38px;height:38px}.calculator-modal__fallback{font-size:.82rem;flex-wrap:wrap;text-align:center}}

/* Update: CTA-Abschlussbereich linear über volle Breite ausrichten */
.cta-section .cta-card{
  display:block !important;
  text-align:left !important;
  width:min(100% - clamp(32px, 6vw, 96px), var(--content-max-width,1240px)) !important;
  padding:clamp(34px,5vw,64px) !important;
}
.cta-section .cta-card .eyebrow{
  margin-bottom:clamp(28px,3vw,46px) !important;
}
.cta-section .cta-card h2{
  max-width:980px !important;
  margin:0 !important;
}
.cta-section .cta-card p:not(.eyebrow){
  max-width:820px !important;
  margin:clamp(22px,2.2vw,30px) 0 0 !important;
}
.cta-section .cta-card .button-row{
  display:flex !important;
  justify-content:flex-start !important;
  align-items:center !important;
  flex-wrap:wrap !important;
  margin-top:clamp(28px,3vw,42px) !important;
  min-width:0 !important;
  width:100% !important;
}
@media (max-width: 760px){
  .cta-section .cta-card{padding:28px 22px !important;}
  .cta-section .cta-card .eyebrow{margin-bottom:24px !important;}
  .cta-section .cta-card .button-row{margin-top:28px !important;}
}


/* Update: Zielgruppen-Bereich auf der Startseite ohne Buttons vollbreit ausrichten */
.target-section .target-card{
  display:block !important;
  max-width:var(--content-max-width,1240px) !important;
  text-align:left !important;
}
.target-section .target-card h2{
  max-width:1120px !important;
}
.target-section .target-card p:not(.eyebrow){
  max-width:860px !important;
  margin-top:clamp(24px,3vw,42px) !important;
}
.target-section .target-card .button-row{
  display:none !important;
}


/* Footer optimization: remove tagline spacing and align legal links like navigation */
.site-footer__brand,
.footer__brand {
  align-self: flex-start;
}

.site-footer__brand p,
.footer__brand p {
  display: none;
}

.site-footer__logo,
.footer__logo {
  display: inline-flex;
  align-items: flex-start;
  margin-top: 0;
}

.site-footer__legal,
.footer__legal {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 1.15rem;
}

.site-footer__legal a,
.footer__legal a,
.footer__legal-link {
  display: inline-flex;
  line-height: 1.35;
}

.site-footer__contact,
.footer__contact,
.site-footer__email,
.footer__email {
  display: none;
}



/* Footer refinement */
.footer-grid {
  align-items: start;
}

.footer-brand-wrap {
  display: flex;
  align-items: flex-start;
}

.footer-brand {
  display: inline-flex;
  align-items: center;
  line-height: 1.2;
  margin: 0;
}

.footer-links,
.footer-links--legal {
  display: grid;
  gap: 10px;
  align-content: start;
}

.footer-links--legal a {
  line-height: 1.35;
}

@media (max-width: 780px) {
  .footer-grid {
    grid-template-columns: 1fr;
  }
}


/* Lightbox scroll fix for tablets and touch devices */
body.modal-open,
html.modal-open {
  overflow: hidden;
}

.calculator-modal,
.booking-modal,
.lightbox-modal,
.modal-overlay,
[data-modal-overlay] {
  overflow: auto;
  -webkit-overflow-scrolling: touch;
  overscroll-behavior: contain;
}

.calculator-modal__dialog,
.booking-modal__dialog,
.lightbox-modal__dialog,
.modal-dialog,
[data-modal-dialog] {
  max-height: calc(100dvh - 2rem);
  min-height: 0;
  display: flex;
  flex-direction: column;
}

.calculator-modal__body,
.booking-modal__body,
.lightbox-modal__body,
.modal-body,
[data-modal-body] {
  flex: 1 1 auto;
  min-height: 0;
  overflow: auto;
  -webkit-overflow-scrolling: touch;
}

.calculator-modal iframe,
.booking-modal iframe,
.lightbox-modal iframe,
.modal-dialog iframe,
[data-modal-dialog] iframe {
  width: 100%;
  height: min(82dvh, 820px);
  min-height: 520px;
  border: 0;
  overflow: auto;
  -webkit-overflow-scrolling: touch;
}

@media (max-width: 900px), (pointer: coarse) {
  .calculator-modal,
  .booking-modal,
  .lightbox-modal,
  .modal-overlay,
  [data-modal-overlay] {
    align-items: stretch;
    justify-content: stretch;
    padding: 0;
  }

  .calculator-modal__dialog,
  .booking-modal__dialog,
  .lightbox-modal__dialog,
  .modal-dialog,
  [data-modal-dialog] {
    width: 100%;
    max-width: none;
    height: 100dvh;
    max-height: 100dvh;
    border-radius: 0;
  }

  .calculator-modal__body,
  .booking-modal__body,
  .lightbox-modal__body,
  .modal-body,
  [data-modal-body] {
    height: 100%;
  }

  .calculator-modal iframe,
  .booking-modal iframe,
  .lightbox-modal iframe,
  .modal-dialog iframe,
  [data-modal-dialog] iframe {
    height: calc(100dvh - 72px);
    min-height: 0;
  }
}



/* v-responsive-final: Mobile-/Tablet-Optimierung, besonders für Fallbeispiel-Unterseiten.
   Ziel: keine horizontale Überbreite, stabile 100%-Breiten, bessere Scrollbarkeit auf Touch-Geräten. */
html,
body {
  width: 100%;
  max-width: 100%;
  overflow-x: clip;
}

@supports not (overflow-x: clip) {
  html,
  body {
    overflow-x: hidden;
  }
}

*,
*::before,
*::after {
  box-sizing: border-box;
}

img,
picture,
svg,
video,
canvas,
iframe {
  max-width: 100%;
}

img,
picture,
svg,
video,
canvas {
  height: auto;
}

main,
section,
article,
aside,
header,
footer,
.container,
.content-grid,
.cards-grid,
.project-grid,
.case-grid,
.case-layout,
.case-article,
.case-article section,
.case-summary-card,
.case-summary-grid,
.case-showcase,
.case-showcase__head,
.case-showcase__grid,
.case-library__grid,
.case-teaser,
.case-learning,
.case-sidebar,
.case-sidebar nav,
.button-row {
  max-width: 100%;
  min-width: 0;
}

.case-article h1,
.case-article h2,
.case-article h3,
.case-article p,
.case-article li,
.case-teaser h3,
.case-teaser p,
.case-learning,
.case-learning blockquote,
.page-hero h1,
.section-head h1,
.section-head h2 {
  overflow-wrap: anywhere;
  word-break: normal;
  hyphens: auto;
}

@media (max-width: 1180px) {
  .case-layout,
  .case-showcase__head,
  .home-case-feature,
  .contact-hero__grid,
  .hero-grid,
  .hero--editorial .hero-grid {
    grid-template-columns: 1fr !important;
  }
}

@media (max-width: 980px) {
  .case-content-section,
  .case-library,
  .case-library-hero,
  .case-showcase {
    overflow-x: clip;
  }

  .case-layout {
    width: 100% !important;
    grid-template-columns: minmax(0, 1fr) !important;
    gap: clamp(24px, 6vw, 42px) !important;
    justify-content: stretch !important;
  }

  .case-sidebar {
    width: 100% !important;
    max-width: 100% !important;
    overflow: hidden;
  }

  .case-sidebar nav {
    width: 100% !important;
    max-width: 100% !important;
    display: flex !important;
    flex-wrap: nowrap !important;
    overflow-x: auto !important;
    overflow-y: hidden !important;
    -webkit-overflow-scrolling: touch;
    scroll-snap-type: x proximity;
  }

  .case-sidebar nav a {
    flex: 0 0 auto;
    max-width: min(78vw, 320px);
    white-space: normal !important;
  }
}

@media (max-width: 760px) {
  .container {
    width: 100% !important;
    max-width: 100% !important;
    padding-left: max(20px, env(safe-area-inset-left)) !important;
    padding-right: max(20px, env(safe-area-inset-right)) !important;
  }

  .page-hero,
  .section,
  .case-content-section,
  .case-library,
  .case-showcase {
    width: 100% !important;
    max-width: 100% !important;
  }

  .case-article,
  .case-article section,
  .case-learning,
  .case-summary-card,
  .case-teaser,
  .card,
  .project-card,
  .text-block,
  .target-card,
  .cta-card {
    width: 100% !important;
    max-width: 100% !important;
  }

  .case-article section {
    overflow: visible;
  }

  .case-summary-grid,
  .case-showcase__grid,
  .case-library__grid,
  .case-grid,
  .case-proof-grid,
  .cards-grid,
  .project-grid,
  .content-grid,
  .pain-grid,
  .question-grid,
  .business-card-grid {
    grid-template-columns: minmax(0, 1fr) !important;
  }

  .case-library .case-teaser--featured,
  .case-card--featured {
    grid-column: auto !important;
  }

  .case-filter {
    max-width: 100% !important;
    margin-left: 0 !important;
    margin-right: 0 !important;
    padding-left: 0 !important;
    padding-right: 0 !important;
  }

  .case-filter__item {
    white-space: normal !important;
    text-align: center;
  }

  .case-meta {
    width: 100%;
    max-width: 100%;
    flex-wrap: wrap !important;
  }

  .case-meta span {
    max-width: 100%;
    white-space: normal !important;
  }

  .button-row {
    width: 100%;
    flex-wrap: wrap !important;
  }

  .button-row .btn,
  .case-article .btn,
  .cta-card .btn {
    max-width: 100%;
    white-space: normal;
  }

  .floating-contact {
    max-width: calc(100vw - 24px);
    right: max(12px, env(safe-area-inset-right)) !important;
  }

  .floating-contact a,
  .floating-contact button {
    max-width: 100%;
  }
}

@media (max-width: 460px) {
  .container {
    padding-left: max(18px, env(safe-area-inset-left)) !important;
    padding-right: max(18px, env(safe-area-inset-right)) !important;
  }

  .case-teaser,
  .case-learning,
  .case-summary-card,
  .card,
  .project-card,
  .text-block,
  .target-card,
  .cta-card {
    padding-left: min(22px, 6vw) !important;
    padding-right: min(22px, 6vw) !important;
  }

  .case-article h2,
  .page-hero h1,
  .case-showcase__head h1,
  .case-showcase__head h2 {
    letter-spacing: -0.045em !important;
  }
}



/* Event page: all about automation Hamburg 2026 */
.event-hero { position: relative; overflow: hidden; }
.event-hero::after { content: ""; position: absolute; inset: 0; background: radial-gradient(circle at 80% 20%, rgba(38, 182, 221, .18), transparent 34rem); pointer-events: none; }
.event-hero__grid { position: relative; z-index: 1; display: grid; grid-template-columns: minmax(0, 1.45fr) minmax(280px, .55fr); gap: clamp(28px, 5vw, 64px); align-items: center; }
.event-facts { padding: clamp(24px, 4vw, 34px); border-radius: 28px; background: rgba(255,255,255,.92); box-shadow: 0 24px 60px rgba(14, 33, 54, .12); border: 1px solid rgba(14,33,54,.08); }
.event-facts__label { display: inline-flex; margin-bottom: 14px; font-size: .78rem; font-weight: 800; letter-spacing: .08em; text-transform: uppercase; color: var(--accent, #0aa6d6); }
.event-facts strong { display: block; font-size: clamp(1.25rem, 2vw, 1.65rem); line-height: 1.15; margin-bottom: 10px; color: var(--text, #10243d); }
.event-facts p { margin-bottom: 18px; }
.event-facts ul { margin: 0; padding-left: 1.1rem; display: grid; gap: 10px; }
.event-facts li { line-height: 1.45; }
.event-popup { position: fixed; inset: 0; z-index: 10000; display: grid; place-items: center; padding: 20px; opacity: 0; pointer-events: none; transition: opacity .2s ease; }
.event-popup.is-open { opacity: 1; pointer-events: auto; }
.event-popup__backdrop { position: absolute; inset: 0; background: rgba(9, 20, 34, .62); backdrop-filter: blur(10px); }
.event-popup__panel { position: relative; width: min(720px, 100%); max-height: min(88vh, 760px); overflow: auto; padding: clamp(28px, 5vw, 48px); border-radius: 30px; background: #fff; box-shadow: 0 30px 90px rgba(0,0,0,.28); transform: translateY(12px) scale(.98); transition: transform .2s ease; }
.event-popup.is-open .event-popup__panel { transform: translateY(0) scale(1); }
.event-popup__close { position: absolute; top: 16px; right: 18px; width: 42px; height: 42px; border: 0; border-radius: 999px; background: rgba(12,32,52,.08); color: #10243d; font-size: 1.8rem; line-height: 1; cursor: pointer; }
.event-popup__panel h2 { margin: 0 0 14px; font-size: clamp(2rem, 5vw, 3.35rem); line-height: .98; letter-spacing: -.045em; }
.event-popup__panel p { max-width: 58ch; }
.event-countdown { display: grid; grid-template-columns: repeat(4, minmax(0, 1fr)); gap: 12px; margin: 26px 0; }
.event-countdown div { padding: 16px 10px; border-radius: 18px; background: rgba(10,166,214,.09); text-align: center; }
.event-countdown strong { display: block; font-size: clamp(1.45rem, 4vw, 2.25rem); line-height: 1; color: var(--accent, #0aa6d6); }
.event-countdown span { display: block; margin-top: 6px; font-size: .78rem; font-weight: 800; text-transform: uppercase; letter-spacing: .08em; color: rgba(16,36,61,.72); }
@media (max-width: 820px) { .event-hero__grid { grid-template-columns: 1fr; } .event-countdown { grid-template-columns: repeat(2, minmax(0, 1fr)); } }
@media (max-width: 460px) { .event-popup { padding: 12px; } .event-popup__panel { border-radius: 22px; padding: 26px 18px; } }

/* Update: all about automation page layout fix
   Prevent long German compound headings from running underneath adjacent cards
   in two-column split sections, especially on wide desktop viewports. */
.split-section > div,
.split-section .text-block {
  min-width: 0 !important;
}

.split-section h2 {
  max-width: 100% !important;
  overflow-wrap: anywhere !important;
  word-break: normal !important;
  hyphens: auto !important;
}

@media (min-width: 1081px) {
  .split-section {
    grid-template-columns: minmax(0, 0.92fr) minmax(360px, 1.08fr) !important;
  }
}

@media (max-width: 1280px) and (min-width: 1081px) {
  .split-section h2 {
    font-size: clamp(2.15rem, 3.6vw, 3.25rem) !important;
    line-height: 1.08 !important;
  }
}

/* All about Automation 2026 page image */
.event-hero__media-wrap { position: relative; z-index: 1; margin-top: clamp(30px, 5vw, 58px); }
.event-hero__media { margin: 0; border-radius: clamp(24px, 4vw, 42px); overflow: hidden; box-shadow: 0 28px 80px rgba(14, 33, 54, .18); border: 1px solid rgba(14, 33, 54, .08); background: #f4f7fb; }
.event-hero__media img { display: block; width: 100%; height: auto; aspect-ratio: 16 / 9; object-fit: cover; }
@media (max-width: 640px) { .event-hero__media img { aspect-ratio: 4 / 3; } }
