/* ============================================================
   Peter Zuschlag GaLaBau — site-custom.css
   Layout skeleton + page-specific compositions.
   (Deploy-Gate: jede *.html MUSS diese Datei verlinken.)
   ============================================================ */

/* --- Intro split (index) --- */
.intro-split {
  display: grid; grid-template-columns: 1.15fr 0.85fr; gap: var(--gap-2xl); align-items: center;
}
.intro-split .intro-lead {
  font-family: var(--f-display); font-style: italic; font-size: clamp(1.3rem, 2.2vw, 1.75rem);
  color: var(--c-brand); line-height: 1.4; border-left: 3px solid var(--c-stone);
  padding-left: var(--gap-md); margin-top: var(--gap-lg);
}
.intro-split .intro-figure {
  position: relative; border-radius: 6px; overflow: hidden;
  box-shadow: 0 36px 70px -42px rgba(31,51,38,0.6);
}
.intro-split .intro-figure img { width: 100%; aspect-ratio: 4/5; object-fit: cover; }
.intro-split .intro-figure .leaf-badge {
  position: absolute; bottom: 16px; right: 16px; width: 56px; height: auto;
  border-radius: 8px; box-shadow: 0 6px 18px rgba(0,0,0,0.3);
}
@media (max-width: 880px) {
  .intro-split { grid-template-columns: 1fr; gap: var(--gap-lg); }
}

/* --- Service detail layout (leistungen page sections) --- */
.svc-block { padding: var(--gap-2xl) 0; border-bottom: 1px solid var(--c-rule); scroll-margin-top: 80px; }
.svc-block:last-child { border-bottom: 0; }
.svc-head { display: grid; grid-template-columns: auto 1fr; gap: var(--gap-lg); align-items: baseline; margin-bottom: var(--gap-lg); }
.svc-head .svc-index {
  font-family: var(--f-display); font-size: clamp(3rem, 7vw, 6rem); font-weight: 400;
  color: var(--c-stone); line-height: 0.8; opacity: 0.85;
}
.svc-head .svc-titles h2 { margin-bottom: 4px; }
.svc-head .svc-titles .eyebrow { margin-bottom: 6px; }
.svc-body-grid { display: grid; grid-template-columns: 1.1fr 0.9fr; gap: var(--gap-xl); align-items: start; }
.svc-body-grid .svc-text p { color: var(--c-ink-mute); line-height: 1.75; }
.svc-figure { position: relative; border-radius: 6px; overflow: hidden; box-shadow: 0 30px 60px -38px rgba(31,51,38,0.55); }
.svc-figure img { width: 100%; aspect-ratio: 4/3; object-fit: cover; transition: transform 1s cubic-bezier(.2,.7,.2,1); }
.svc-figure:hover img { transform: scale(1.05); }
.svc-bullets { list-style: none; margin: var(--gap-md) 0 0; padding: 0; columns: 2; column-gap: var(--gap-lg); }
.svc-bullets li {
  position: relative; padding-left: 22px; margin-bottom: 10px; break-inside: avoid;
  font-family: var(--f-ui); font-size: 0.92rem; color: var(--c-ink);
}
.svc-bullets li::before { content: ""; position: absolute; left: 0; top: 8px; width: 8px; height: 8px; border-radius: 2px; background: var(--c-brand); transform: rotate(45deg); }
@media (max-width: 880px) {
  .svc-head { grid-template-columns: 1fr; gap: var(--gap-sm); }
  .svc-body-grid { grid-template-columns: 1fr; gap: var(--gap-lg); }
  .svc-bullets { columns: 1; }
}

/* mini-gallery strip inside a service block */
.svc-strip { display: grid; grid-template-columns: repeat(3, 1fr); gap: var(--gap-sm); margin-top: var(--gap-lg); }
.svc-strip .tile { overflow: hidden; border-radius: 4px; aspect-ratio: 4/3; background: var(--c-paper-warm); cursor: zoom-in; position: relative; }
.svc-strip .tile img { width: 100%; height: 100%; object-fit: cover; transition: transform .7s; }
.svc-strip .tile:hover img { transform: scale(1.07); }
@media (max-width: 620px) { .svc-strip { grid-template-columns: repeat(2, 1fr); } }

/* --- Über uns: values + story --- */
.values-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: var(--gap-lg); }
.value-card {
  background: var(--c-paper-warm); border-radius: 6px; padding: var(--gap-lg);
  border-top: 3px solid var(--c-brand); transition: transform .35s, box-shadow .35s;
}
.value-card:hover { transform: translateY(-5px); box-shadow: 0 24px 50px -30px rgba(31,51,38,0.45); }
.value-card h3 { font-size: 1.4rem; color: var(--c-brand); margin-bottom: var(--gap-xs); }
.value-card p { color: var(--c-ink-mute); font-size: 0.96rem; margin: 0; line-height: 1.65; }
@media (max-width: 820px) { .values-grid { grid-template-columns: 1fr; } }

.story-prose { max-width: 62ch; }
.story-prose p { font-size: 1.08rem; line-height: 1.8; color: var(--c-ink); margin-bottom: var(--gap-md); }

/* --- Contact page split --- */
.contact-split { display: grid; grid-template-columns: 1fr 1fr; gap: var(--gap-2xl); align-items: start; }
.contact-info .field-row { display: grid; grid-template-columns: auto 1fr; gap: var(--gap-md); padding: var(--gap-md) 0; border-bottom: 1px solid var(--c-rule); align-items: baseline; }
.contact-info .field-row:first-child { border-top: 1px solid var(--c-rule); }
.contact-info .field-row .lbl { font-family: var(--f-ui); font-size: 0.7rem; letter-spacing: 0.18em; text-transform: uppercase; color: var(--c-stone-deep); }
.contact-info .field-row .val { font-family: var(--f-display); font-size: 1.3rem; color: var(--c-ink); }
.contact-info .field-row .val a:hover { color: var(--c-brand); }
@media (max-width: 880px) { .contact-split { grid-template-columns: 1fr; gap: var(--gap-lg); } }

/* --- Service teaser pills (sub-page nav) --- */
.svc-pills { display: flex; flex-wrap: wrap; gap: 10px; justify-content: center; margin-top: var(--gap-lg); }
.svc-pills a {
  font-family: var(--f-ui); font-size: 0.8rem; font-weight: 500; padding: 0.5rem 1.05rem;
  border-radius: 999px; border: 1px solid var(--c-rule); color: var(--c-ink-mute); transition: all .25s;
}
.svc-pills a:hover { border-color: var(--c-brand); color: var(--c-brand); background: var(--c-brand-soft); }

/* --- Legal pages --- */
.legal-prose { max-width: 70ch; }
.legal-prose h2 { font-size: 1.5rem; color: var(--c-brand); margin-top: var(--gap-xl); }
.legal-prose h3 { font-size: 1.15rem; color: var(--c-ink); margin-top: var(--gap-lg); font-family: var(--f-ui); font-weight: 600; }
.legal-prose p, .legal-prose li { color: var(--c-ink-mute); line-height: 1.75; font-size: 0.98rem; }
.legal-prose a { color: var(--c-brand); border-bottom: 1px solid var(--c-rule); }
.legal-note {
  background: var(--c-paper-warm); border-left: 3px solid var(--c-stone); border-radius: 0 6px 6px 0;
  padding: var(--gap-md) var(--gap-lg); margin: var(--gap-lg) 0; font-size: 0.96rem; color: var(--c-ink);
}
.legal-note strong { color: var(--c-brand); }

/* --- CTA band --- */
.cta-band { position: relative; overflow: hidden; background: var(--c-brand); color: var(--c-paper); border-radius: 8px; padding: clamp(2.5rem, 6vw, 5rem); text-align: center; isolation: isolate; }
.cta-band::before { content: ""; position: absolute; inset: 0; z-index: -1; background: radial-gradient(60% 80% at 80% 20%, rgba(200,178,144,0.18), transparent 70%); }
.cta-band h2 { color: var(--c-paper); font-size: clamp(2rem, 4.5vw, 3.4rem); max-width: 20ch; margin: 0 auto var(--gap-md); }
.cta-band p { color: var(--c-cream-mute); font-family: var(--f-display); font-style: italic; font-size: 1.25rem; max-width: 50ch; margin: 0 auto var(--gap-lg); }
.cta-band .cta-actions { display: inline-flex; gap: var(--gap-md); flex-wrap: wrap; justify-content: center; }
.cta-band .leaf-bg { position: absolute; right: -40px; bottom: -40px; width: 240px; opacity: 0.07; filter: brightness(0) invert(1); z-index: -1; }
