/* ============================================================
   WEISHAUPT BAU — Leistungsseiten
   Ergänzt style.css — nutzt dieselben Tokens, Fonts und Nav.
   ============================================================ */

/* Subpage wrapper — nav is fixed/transparent on index; here we want a
   solid-white look from the start so the dark text is always readable. */
.subpage{
  padding-top:var(--nav-h);
  background:#fff;
  color:var(--ink-2);
}

/* Force the nav into its scrolled (solid light) look on subpages —
   there is no dark hero behind it, so white-on-image styling is wrong. */
body.is-subpage .nav{background:rgba(255,255,255,.92);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);color:var(--ink);border-bottom:1px solid var(--line-2)}
body.is-subpage .nav::before{opacity:0}
body.is-subpage .nav__logo img{filter:none;mix-blend-mode:multiply}
body.is-subpage .nav__menu a,
body.is-subpage .nav__drop-trigger,
body.is-subpage .nav__icons a{text-shadow:none}

/* ============================================================
   Subhero
   ============================================================ */
.subhero{padding:clamp(40px,7vh,80px) var(--gutter) clamp(40px,7vh,80px);max-width:var(--maxw);margin:0 auto}
.subhero__back{display:inline-flex;align-items:center;gap:8px;font-size:12px;font-weight:500;letter-spacing:.12em;text-transform:uppercase;color:var(--gray);margin-bottom:clamp(32px,5vh,60px);transition:color .2s ease,gap .3s var(--ease)}
.subhero__back::before{content:"←";font-size:14px}
.subhero__back:hover{color:var(--ink);gap:12px}

.subhero__grid{display:grid;grid-template-columns:1.15fr 1fr;gap:clamp(32px,5vw,80px);align-items:end}
.subhero__grid--solo{grid-template-columns:1fr;max-width:920px}
@media(max-width:900px){.subhero__grid{grid-template-columns:1fr;gap:40px}}

/* Lean Subhero — Weitere Leistungen (Maler/Maurer/Beton/Spechtloch/Schnelldienst).
   Kein Bild, zentrierter Titel, kompaktes editoriales Layout. */
.subhero--lean{padding:clamp(32px,5vh,64px) var(--gutter) clamp(40px,6vh,80px)}
.subhero--lean .subhero__grid{display:block;max-width:760px;margin:0 auto;text-align:center}
.subhero--lean .subhero__title{font-size:clamp(36px,5.2vw,68px);letter-spacing:-.025em}
.subhero--lean .subhero__lead{margin:32px auto 0;max-width:60ch}
.subhero--lean::after{
  content:"";display:block;
  width:48px;height:1px;background:var(--ink);
  margin:clamp(40px,5vh,64px) auto 0;
  opacity:.2;
}

.subhero__label{display:flex;align-items:baseline;gap:20px;margin-bottom:24px;padding-bottom:18px;border-bottom:1px solid var(--line-2)}
.subhero__num{font-family:inherit;font-size:clamp(34px,5vw,64px);line-height:1;font-weight:600;color:var(--ink);letter-spacing:-.03em;font-variant-numeric:tabular-nums}
.subhero__cat{flex:1;text-align:right;font-size:11px;font-weight:500;letter-spacing:.22em;text-transform:uppercase;color:var(--gray)}

.subhero__title{font-size:clamp(44px,7.5vw,108px);line-height:.96;letter-spacing:-.035em;font-weight:600;color:var(--ink)}
.subhero__title em{font-style:italic;color:var(--blue);font-weight:600}
.subhero__lead{font-size:17px;line-height:1.6;color:var(--ink-2);margin-top:28px;max-width:60ch}

.subhero__image{position:relative;aspect-ratio:4/5;overflow:hidden;border-radius:8px;background:var(--bg-2);box-shadow:0 30px 60px -25px rgba(0,0,0,.2)}
.subhero__image img{width:100%;height:100%;object-fit:cover}
.subhero__image-cap{position:absolute;top:14px;left:14px;font-size:10px;font-weight:500;letter-spacing:.16em;text-transform:uppercase;color:#fff;background:rgba(23,26,32,.7);padding:6px 10px;border-radius:4px;backdrop-filter:blur(8px)}

/* reveal-line — simpler than the subpage.css version, no animation needed */
.reveal-line{display:block}
.reveal-line > span{display:inline-block}

/* ============================================================
   Sections
   ============================================================ */
.sp-section{padding:clamp(72px,12vh,140px) var(--gutter);max-width:var(--maxw);margin:0 auto}
.sp-section--cream{background:var(--bg-2);max-width:none;margin:0}
.sp-section--cream .sp-section__inner{max-width:var(--maxw);margin:0 auto;padding:clamp(72px,12vh,140px) var(--gutter)}
.sp-section--dark{background:var(--ink);color:#fff;max-width:none;margin:0}
.sp-section--dark .sp-section__inner{max-width:var(--maxw);margin:0 auto;padding:clamp(72px,12vh,140px) var(--gutter)}

.sp-section__split{display:grid;grid-template-columns:1fr 2fr;gap:clamp(32px,4vw,72px);align-items:start}
@media(max-width:900px){.sp-section__split{grid-template-columns:1fr}}

.sp-section h2{font-size:clamp(32px,4.8vw,64px);line-height:1.02;letter-spacing:-.025em;font-weight:600;color:inherit;margin:0}
.sp-section h2 em{font-style:italic;color:var(--blue);font-weight:600}
.sp-section--dark h2 em{color:#8aa8ff}

.sp-prose p{font-size:16px;line-height:1.65;color:var(--ink-2);margin-bottom:16px;max-width:62ch}
.sp-prose p:last-child{margin-bottom:0}
.sp-prose strong{color:var(--ink);font-weight:600}
.sp-section--dark .sp-prose p{color:rgba(255,255,255,.78)}
.sp-section--dark .sp-prose strong{color:#fff}

.eyebrow{display:inline-flex;align-items:center;gap:10px;font-size:11px;font-weight:500;letter-spacing:.22em;text-transform:uppercase;color:var(--gray);margin-bottom:24px}
.eyebrow::before{content:"";width:32px;height:1px;background:currentColor;display:inline-block}
.eyebrow--light{color:rgba(255,255,255,.65)}

/* ============================================================
   Benefits grid
   ============================================================ */
.sp-benefits{display:grid;grid-template-columns:repeat(2,1fr);gap:14px;margin-top:40px}
@media(max-width:700px){.sp-benefits{grid-template-columns:1fr}}

.sp-benefit{padding:28px 24px;border:1px solid var(--line-2);background:#fff;border-radius:8px;transition:transform .3s var(--ease),border-color .25s,box-shadow .3s}
.sp-benefit:hover{transform:translateY(-3px);border-color:var(--ink);box-shadow:0 14px 30px -18px rgba(0,0,0,.2)}
.sp-benefit__num{display:block;font-size:12px;font-weight:600;color:var(--blue);letter-spacing:.08em;margin-bottom:12px;font-variant-numeric:tabular-nums}
.sp-benefit h3{font-size:18px;font-weight:600;letter-spacing:-.005em;margin:0 0 6px;color:var(--ink);line-height:1.3}
.sp-benefit p{font-size:14px;line-height:1.55;color:var(--gray);margin:0}
.sp-section--dark .sp-benefit{background:rgba(255,255,255,.04);border-color:rgba(255,255,255,.12)}
.sp-section--dark .sp-benefit:hover{border-color:#fff}
.sp-section--dark .sp-benefit h3{color:#fff}
.sp-section--dark .sp-benefit p{color:rgba(255,255,255,.65)}
.sp-section--dark .sp-benefit__num{color:#8aa8ff}

/* ============================================================
   Steps list
   ============================================================ */
.sp-steps{margin-top:32px;border-top:1px solid var(--line-2)}
.sp-section--dark .sp-steps{border-top-color:rgba(255,255,255,.15)}
.sp-step{display:grid;grid-template-columns:60px 1fr;gap:24px;padding:22px 0;border-bottom:1px solid var(--line-2);align-items:start}

/* ============================================================
   WDVS 8-Schichten-Animation — Grid daneben + nahtlose Integration
   ============================================================ */
.wdvs-aufbau-grid{
  display:grid;grid-template-columns:minmax(360px, 0.85fr) 1.7fr;
  gap:clamp(32px,4vw,72px);
  margin-top:32px;align-items:start;
}
.wdvs-aufbau-grid .sp-steps{margin-top:0}

.wdvs-anim{
  /* Transparenter, randloser Container — fügt sich direkt in die dunkle Sektion ein */
  position:sticky;top:calc(var(--nav-h) + 32px);
  width:100%;aspect-ratio:10/11;
  background:transparent;
  border:0;border-radius:0;
  overflow:visible;
}
.wdvs-anim__svg{width:100%;height:100%;display:block;overflow:visible}

/* Die Step-Nummern + Texte neben der Animation etwas kompakter */
.wdvs-aufbau-grid .sp-step{grid-template-columns:52px 1fr;gap:20px;padding:18px 0}
.wdvs-aufbau-grid .sp-step h3{font-size:16px;margin-bottom:4px}
.wdvs-aufbau-grid .sp-step p{font-size:13px;line-height:1.55}
.wdvs-aufbau-grid .sp-step__num{font-size:15px}

@media(max-width:1100px){
  .wdvs-aufbau-grid{grid-template-columns:minmax(340px, 0.9fr) 1.5fr;gap:40px}
}
@media(max-width:960px){
  .wdvs-aufbau-grid{grid-template-columns:1fr;gap:40px}
  .wdvs-anim{position:static;aspect-ratio:11/8}
  .wdvs-aufbau-grid .sp-step{grid-template-columns:60px 1fr;gap:24px;padding:22px 0}
  .wdvs-aufbau-grid .sp-step h3{font-size:20px}
  .wdvs-aufbau-grid .sp-step p{font-size:14px}
  .wdvs-aufbau-grid .sp-step__num{font-size:18px}
}
.sp-section--dark .sp-step{border-bottom-color:rgba(255,255,255,.12)}
.sp-step__num{font-size:18px;font-weight:600;color:var(--blue);font-variant-numeric:tabular-nums;letter-spacing:-.01em}
.sp-section--dark .sp-step__num{color:#8aa8ff}
.sp-step h3{font-size:20px;font-weight:600;letter-spacing:-.01em;margin:0 0 6px;color:inherit;line-height:1.3}
.sp-step p{font-size:14px;line-height:1.6;color:var(--gray);margin:0;max-width:64ch}
.sp-section--dark .sp-step p{color:rgba(255,255,255,.65)}

/* ============================================================
   Facts strip
   ============================================================ */
.sp-facts{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;margin-top:56px;padding-top:40px;border-top:1px solid var(--line-2)}
.sp-section--dark .sp-facts{border-top-color:rgba(255,255,255,.15)}
@media(max-width:800px){.sp-facts{grid-template-columns:repeat(2,1fr)}}
.sp-fact__val{font-size:clamp(28px,3.5vw,44px);line-height:1;font-weight:600;letter-spacing:-.02em;color:var(--ink);margin-bottom:6px;font-variant-numeric:tabular-nums}
.sp-section--dark .sp-fact__val{color:#fff}
.sp-fact__val em{font-style:italic;color:var(--blue)}
.sp-section--dark .sp-fact__val em{color:#8aa8ff}
.sp-fact__label{font-size:11px;font-weight:500;letter-spacing:.18em;text-transform:uppercase;color:var(--gray)}
.sp-section--dark .sp-fact__label{color:rgba(255,255,255,.55)}

/* ============================================================
   Comparison — Echtklinker vs. Meldorfer
   Nutzt CSS-Subgrid, damit in beiden Karten die Zeilen (Tag,
   Titel, Sub, Beschreibung, Spec-Tabelle, CTA) exakt auf gleicher
   Höhe stehen — egal wie lang die Texte individuell sind.
   ============================================================ */
.sp-compare{
  display:grid;
  grid-template-columns:repeat(2,1fr);
  grid-template-rows:auto auto auto 1fr auto auto;
  gap:20px;
  margin-top:40px;
}
@media(max-width:900px){
  .sp-compare{grid-template-columns:1fr;grid-template-rows:none}
}

.sp-compare__card{
  position:relative;
  display:grid;
  grid-template-rows:auto auto auto 1fr auto auto;
  grid-row:span 6;
  row-gap:0;
  padding:36px 32px 32px;
  border:1px solid var(--line-2);
  background:#fff;
  border-radius:10px;
  transition:transform .35s var(--ease),border-color .25s,box-shadow .35s;
}
@supports(grid-template-rows:subgrid){
  .sp-compare__card{grid-template-rows:subgrid}
}
@media(max-width:900px){
  .sp-compare__card{grid-template-rows:auto auto auto 1fr auto auto;grid-row:auto}
}
.sp-compare__card:hover{transform:translateY(-3px);border-color:var(--ink);box-shadow:0 20px 40px -22px rgba(0,0,0,.22)}

.sp-compare__tag{display:inline-flex;justify-self:start;align-items:center;font-size:10px;font-weight:600;letter-spacing:.18em;text-transform:uppercase;padding:5px 10px;border-radius:999px;margin:0 0 20px;color:var(--ink);background:var(--bg-2)}
.sp-compare__card--alt .sp-compare__tag{background:var(--blue);color:#fff}

.sp-compare__card h3{font-size:clamp(22px,2.4vw,30px);font-weight:600;letter-spacing:-.015em;line-height:1.15;margin:0 0 6px;color:var(--ink)}
.sp-compare__card h3 em{font-style:italic;color:var(--blue);font-weight:600}
.sp-compare__sub{font-size:13px;font-weight:500;letter-spacing:.01em;color:var(--gray);margin:0 0 18px}

.sp-compare__desc{font-size:15px;line-height:1.6;color:var(--ink-2);margin:0 0 24px;max-width:44ch;align-self:start}
.sp-compare__desc strong{color:var(--ink);font-weight:600}

.sp-compare__specs{list-style:none;padding:0;margin:0 0 28px;border-top:1px solid var(--line-2)}
.sp-compare__specs li{display:flex;justify-content:space-between;align-items:baseline;padding:11px 0;border-bottom:1px solid var(--line-2);font-size:13.5px;gap:16px}
.sp-compare__specs li > span:first-child{color:var(--gray);letter-spacing:.02em}
.sp-compare__specs li > span:last-child{color:var(--ink);font-weight:500;font-variant-numeric:tabular-nums;text-align:right}
.sp-compare__specs li > span:last-child em{font-style:normal;color:var(--blue)}

.sp-compare__link{display:inline-flex;align-items:center;gap:10px;padding:13px 20px;background:var(--ink);color:#fff;border-radius:999px;font-size:13px;font-weight:500;letter-spacing:.02em;justify-self:start;align-self:end;transition:transform .3s var(--ease),background .25s,gap .3s var(--ease)}
.sp-compare__link:hover{transform:translateY(-2px);background:var(--blue);gap:14px}
.sp-compare__link span{font-size:15px;line-height:1}

/* ============================================================
   Gallery
   ============================================================ */
.sp-gallery{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-top:32px}
@media(max-width:800px){.sp-gallery{grid-template-columns:repeat(2,1fr)}}
@media(max-width:500px){.sp-gallery{grid-template-columns:1fr}}
.sp-gallery figure{margin:0;aspect-ratio:4/5;overflow:hidden;border-radius:6px;background:var(--bg-2)}
.sp-gallery figure:first-child{grid-column:span 2;grid-row:span 2;aspect-ratio:1/1}
@media(max-width:800px){.sp-gallery figure:first-child{grid-column:span 2;grid-row:auto;aspect-ratio:4/5}}
.sp-gallery img{width:100%;height:100%;object-fit:cover;transition:transform .8s var(--ease)}
.sp-gallery figure:hover img{transform:scale(1.04)}

/* ============================================================
   CTA section
   ============================================================ */
.sp-cta{background:var(--ink);color:#fff;padding:clamp(80px,12vh,140px) var(--gutter);text-align:center}
.sp-cta__inner{max-width:900px;margin:0 auto}
.sp-cta .eyebrow{color:rgba(255,255,255,.6);justify-content:center}
.sp-cta h2{font-size:clamp(40px,6vw,88px);line-height:.98;font-weight:600;letter-spacing:-.03em;color:#fff;margin:0 0 36px}
.sp-cta h2 em{font-style:italic;color:#8aa8ff}
.sp-cta__actions{display:flex;gap:14px;justify-content:center;flex-wrap:wrap}
.sp-cta a{display:inline-flex;align-items:center;gap:10px;padding:14px 26px;background:#fff;color:var(--ink);border-radius:999px;font-size:14px;font-weight:500;letter-spacing:.01em;transition:transform .3s var(--ease),background .25s}
.sp-cta a:hover{transform:translateY(-2px);background:var(--bg-2)}
.sp-cta a.sp-cta__secondary{background:transparent;color:#fff;border:1px solid rgba(255,255,255,.35)}
.sp-cta a.sp-cta__secondary:hover{background:#fff;color:var(--ink);border-color:#fff}
.sp-cta a span{font-size:16px;line-height:1}

/* ============================================================
   Other services
   ============================================================ */
.sp-other{padding:clamp(72px,10vh,120px) var(--gutter);background:var(--bg-2)}
.sp-other__head{max-width:var(--maxw);margin:0 auto 32px;display:flex;justify-content:space-between;align-items:baseline;gap:20px;flex-wrap:wrap}
.sp-other__title{font-size:clamp(28px,3.8vw,44px);line-height:1;font-weight:600;letter-spacing:-.02em;color:var(--ink);margin:0}
.sp-other__grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:12px;max-width:var(--maxw);margin:0 auto}
.sp-other__card{position:relative;padding:22px 20px;background:#fff;border:1px solid var(--line-2);border-radius:8px;display:flex;align-items:center;min-height:90px;transition:transform .3s var(--ease),border-color .25s,box-shadow .3s;color:inherit}
.sp-other__card:hover{transform:translateY(-3px);border-color:var(--ink);box-shadow:0 14px 30px -18px rgba(0,0,0,.2)}
.sp-other__card h4{font-size:17px;font-weight:600;line-height:1.25;letter-spacing:-.005em;color:var(--ink);margin:0;padding-right:36px}
.sp-other__card-arr{position:absolute;top:18px;right:20px;color:var(--gray);font-size:18px;transition:transform .3s var(--ease),color .25s}
.sp-other__card:hover .sp-other__card-arr{transform:translate(4px,-2px);color:var(--ink)}
