: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 .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;
  }
}
