/* ============================================================
   SUBPAGES — shared layout patterns for Leistungen, Ablauf, KI,
   Kontakt, Über mich. Pairs with design-system.css.
   ============================================================ */

.eyebrow-ds--light { color: var(--copper-300); }

/* ---- Page hero ---- */
.sp-hero { padding-top: clamp(48px,6vw,96px); padding-bottom: clamp(24px,3vw,40px); }
.sp-hero__inner { max-width: 58ch; }
.sp-hero h1 {
  font-family: var(--font-display); font-weight: 800; font-size: clamp(2.4rem,4.5vw,3.875rem);
  line-height: 1.08; letter-spacing: var(--tracking-tight); margin: 18px 0 20px;
}
.sp-hero h1 em { font-style: italic; font-weight: 600; color: var(--text-accent); }
.sp-hero p { font-size: var(--text-md); line-height: 1.65; color: var(--text-body); max-width: 54ch; margin: 0; }
.sp-hero--split { display: grid; grid-template-columns: 0.95fr 1.05fr; gap: clamp(32px,5vw,72px); align-items: center; padding-top: clamp(40px,6vw,88px); padding-bottom: clamp(32px,4vw,56px); }
.sp-hero--split.sp-hero--reverse { grid-template-columns: 0.85fr 1.15fr; }
.sp-hero__badge-row { display: flex; align-items: center; gap: 14px; margin-bottom: 18px; }

/* ---- Photo block (reused across hero variants) ---- */
.sp-photo { position: relative; }
.sp-photo__frame { position: relative; border-radius: 20px; overflow: hidden; box-shadow: var(--shadow-lg); aspect-ratio: 4/5; background: var(--navy-100); }
.sp-photo__frame img { width: 100%; height: 100%; object-fit: cover; object-position: 50% 25%; }
.sp-photo__badge {
  position: absolute; bottom: -22px; background: var(--surface-card); border-radius: 16px; padding: 16px 20px;
  box-shadow: var(--shadow-lg); display: flex; align-items: center; gap: 16px;
}
.sp-photo__badge--left { left: -22px; }
.sp-photo__badge--right { right: -22px; }
.sp-photo__badge-name { font-family: var(--font-display); font-size: var(--text-lg); font-weight: 700; color: var(--text-strong); line-height: 1; }

/* ---- Stats strip ---- */
.sp-stats-strip { display: flex; gap: clamp(32px,6vw,80px); flex-wrap: wrap; padding: 32px 0; border-top: 1px solid var(--border-subtle); border-bottom: 1px solid var(--border-subtle); margin-bottom: clamp(32px,4vw,56px); }

/* ---- Format row (Leistungen) ---- */
.sp-format { border-top: 1px solid var(--border-subtle); padding: clamp(48px,6vw,88px) 0; }
.sp-format--alt { background: var(--surface-card); border-bottom: 1px solid var(--border-subtle); }
.sp-format__inner { display: grid; grid-template-columns: 0.85fr 1.15fr; gap: clamp(32px,5vw,72px); align-items: start; }
.sp-format__num { font-family: var(--font-display); font-size: clamp(3rem,6vw,5rem); font-weight: 800; color: var(--copper-300); line-height: 1; }
.sp-format__badge-row { display: flex; align-items: center; gap: 16px; }
.sp-format__eyebrow { font-family: var(--font-eyebrow); font-size: 11px; letter-spacing: var(--tracking-eyebrow); text-transform: uppercase; color: var(--text-muted); margin: 14px 0 8px; }
.sp-format h2 { font-family: var(--font-display); font-weight: 700; font-size: var(--text-2xl); letter-spacing: var(--tracking-snug); color: var(--text-strong); margin: 0 0 16px; }
.sp-format p { font-size: var(--text-base); line-height: 1.65; color: var(--text-body); margin: 0 0 24px; max-width: 42ch; }
.sp-format__card-label { font-family: var(--font-eyebrow); font-size: 11px; letter-spacing: var(--tracking-eyebrow); text-transform: uppercase; color: var(--text-accent); margin-bottom: 20px; }

/* ---- Checklist (dash bullets) ---- */
.sp-checklist__item { display: flex; align-items: flex-start; gap: 14px; margin-bottom: 16px; }
.sp-checklist__item:last-child { margin-bottom: 0; }
.sp-checklist__dash { flex: none; width: 20px; height: 6px; border-radius: 999px; background: var(--copper-500); margin-top: 9px; }
.sp-checklist__text { font-size: var(--text-base); color: var(--text-body); line-height: 1.6; }
.sp-checklist--sm .sp-checklist__dash { width: 18px; height: 6px; margin-top: 8px; }

/* ---- CTA band (dark) ---- */
.sp-cta-band { position: relative; overflow: hidden; background: var(--navy-800); border-radius: 32px; padding: clamp(40px,5vw,72px); }
.sp-cta-band__mark { position: absolute; top: 28px; right: 36px; opacity: 0.5; }
.sp-cta-band__mark .layer-mark span:nth-child(1), .sp-cta-band__mark .layer-mark span:nth-child(3) { background: var(--navy-600); }
.sp-cta-band__mark .layer-mark span:nth-child(2) { background: var(--copper-500); }
.sp-cta-band__content { position: relative; max-width: 48ch; }
.sp-cta-band h2 { font-family: var(--font-display); font-weight: 700; font-size: var(--text-2xl); color: var(--sand-50); letter-spacing: var(--tracking-snug); margin: 16px 0; }
.sp-cta-band p { font-size: var(--text-md); color: var(--navy-200); line-height: 1.6; margin: 0 0 32px; }

/* ---- CTA band (light, used on Über mich) ---- */
.sp-cta-band--light { background: var(--surface-card); border: 1px solid var(--border-subtle); border-radius: 24px; padding: clamp(36px,4vw,56px); display: flex; align-items: center; justify-content: space-between; gap: 32px; flex-wrap: wrap; }
.sp-cta-band--light .sp-cta-band__content { max-width: 44ch; }
.sp-cta-band--light h2 { color: var(--text-strong); margin: 0 0 12px; }
.sp-cta-band--light p { color: var(--text-body); margin: 0; }

/* ---- Timeline (Ablauf) ---- */
.sp-timeline { max-width: 980px; }
.sp-timeline__step { display: grid; grid-template-columns: auto 1fr; gap: clamp(20px,3vw,40px); }
.sp-timeline__rail { display: flex; flex-direction: column; align-items: center; }
.sp-timeline__circle {
  flex: none; width: 60px; height: 60px; border-radius: 999px; background: var(--navy-800); color: var(--copper-200);
  display: flex; align-items: center; justify-content: center; font-family: var(--font-display); font-size: 22px; font-weight: 700;
}
.sp-timeline__circle--accent { background: var(--copper-600); color: var(--white); box-shadow: var(--shadow-accent); }
.sp-timeline__line { flex: 1; width: 2px; background: var(--copper-200); margin: 8px 0; }
.sp-timeline__body { padding-bottom: 48px; }
.sp-timeline__step:last-child .sp-timeline__body { padding-bottom: 0; }
.sp-timeline__tag-row { display: flex; align-items: center; gap: 12px; margin-bottom: 8px; }
.sp-timeline__tag { font-family: var(--font-eyebrow); font-size: 11px; letter-spacing: var(--tracking-eyebrow); text-transform: uppercase; color: var(--text-accent); }
.sp-timeline h2 { font-family: var(--font-display); font-weight: 700; font-size: var(--text-xl); color: var(--text-strong); margin: 0 0 12px; }
.sp-timeline p { font-size: var(--text-base); line-height: 1.65; color: var(--text-body); max-width: 56ch; margin: 0; }
.sp-timeline__quote { margin-top: 16px; }
.sp-timeline__quote p { font-family: var(--font-display); font-style: italic; font-size: var(--text-md); color: var(--text-strong); line-height: 1.5; margin: 0; }

/* ---- Principles grid (KI) ---- */
.sp-principle__index { font-family: var(--font-mono); font-size: 13px; color: var(--copper-600); margin-bottom: 16px; }
.sp-principle h3 { font-family: var(--font-display); font-weight: 700; font-size: var(--text-xl); color: var(--text-strong); margin: 0 0 12px; }
.sp-principle p { font-size: var(--text-base); color: var(--text-body); line-height: 1.65; margin: 0; }
.sp-grid-2 { display: grid; grid-template-columns: repeat(2,1fr); gap: 24px; }
.sp-grid-3 { display: grid; grid-template-columns: repeat(3,1fr); gap: 24px; }

/* ---- "Where AI helps" list ---- */
.sp-helplist__item { display: flex; align-items: flex-start; gap: 16px; padding: 20px 0; border-bottom: 1px solid var(--border-subtle); }
.sp-helplist__item:last-child { border-bottom: none; }
.sp-helplist__dash { flex: none; width: 24px; height: 7px; border-radius: 999px; background: var(--copper-500); margin-top: 8px; }
.sp-helplist__title { font-weight: 600; font-size: var(--text-md); color: var(--text-strong); margin-bottom: 4px; }
.sp-helplist__desc { font-size: var(--text-base); color: var(--text-body); line-height: 1.6; margin: 0; }

/* ---- Section heading (eyebrow + h2 + optional lead) ---- */
.sp-section-head { max-width: 52ch; margin-bottom: 48px; }
.sp-section-head h2 { font-family: var(--font-display); font-weight: 700; font-size: var(--text-2xl); letter-spacing: var(--tracking-snug); color: var(--text-strong); margin: 12px 0; }
.sp-section-head p { font-size: var(--text-md); color: var(--text-body); line-height: 1.6; margin: 0; }
.sp-section-head--split { display: grid; grid-template-columns: 0.9fr 1.1fr; gap: clamp(32px,5vw,72px); align-items: start; }
.sp-section-head--split h2 { margin: 12px 0 16px; }
.sp-section-head--split p { max-width: 42ch; }

/* ---- Bio / lead text (Über mich) ---- */
.sp-bio { display: grid; grid-template-columns: 0.4fr 1fr; gap: clamp(32px,5vw,72px); align-items: start; }
.sp-bio__content { max-width: 62ch; }
.sp-bio__lead { font-family: var(--font-display); font-size: var(--text-xl); line-height: 1.4; color: var(--text-strong); margin: 0 0 28px; }
.sp-bio__content p.sp-bio__p { font-size: var(--text-md); line-height: 1.7; color: var(--text-body); margin: 0 0 20px; }
.sp-bio__content p.sp-bio__p:last-child { margin-bottom: 0; }

/* ---- Quote band ---- */
.sp-quote-band { position: relative; overflow: hidden; background: var(--navy-800); border-radius: 32px; padding: clamp(40px,5vw,80px); }
.sp-quote-band__mark { position: absolute; top: 32px; right: 40px; opacity: 0.45; }
.sp-quote-band__mark .layer-mark span:nth-child(1), .sp-quote-band__mark .layer-mark span:nth-child(3) { background: var(--navy-600); }
.sp-quote-band__mark .layer-mark span:nth-child(2) { background: var(--copper-500); }
.sp-quote-band__inner { position: relative; max-width: 50ch; }
.sp-quote-band p.sp-quote-band__text { font-family: var(--font-display); font-style: italic; font-weight: 600; font-size: clamp(1.6rem,3vw,2.25rem); line-height: 1.35; color: var(--sand-50); margin: 0 0 24px; }
.sp-quote-band__attr { display: flex; align-items: center; gap: 14px; }
.sp-quote-band__attr-line { width: 36px; height: 1px; background: var(--copper-400); }
.sp-quote-band__attr span.name { font-size: var(--text-sm); color: var(--navy-200); }

/* ---- Kontakt page ---- */
.sp-kontakt {
  display: grid; grid-template-columns: 0.85fr 1.15fr; grid-template-areas: "intro form" "info form";
  gap: clamp(36px,5vw,80px); align-items: start; padding-top: clamp(48px,6vw,96px); padding-bottom: clamp(56px,7vw,112px);
}
.sp-kontakt__intro { grid-area: intro; }
.sp-kontakt__form { grid-area: form; }
.sp-kontakt__info { grid-area: info; }
.sp-kontakt__meta { display: flex; flex-direction: column; gap: 18px; margin-bottom: 40px; }
.sp-kontakt__meta-row { display: flex; align-items: center; gap: 14px; }
.sp-kontakt__meta-row a, .sp-kontakt__meta-row span.txt { font-size: var(--text-md); color: var(--text-strong); font-weight: 500; }
.sp-kontakt__form h2 { font-family: var(--font-display); font-weight: 700; font-size: var(--text-xl); color: var(--text-strong); margin: 0 0 24px; }
.sp-kontakt__form .field-row { display: grid; grid-template-columns: 1fr 1fr; gap: 20px; margin-bottom: 20px; }
.sp-kontakt__form .field-block { margin-bottom: 20px; }
.sp-kontakt__form .field-block--last { margin-bottom: 28px; }
.sp-kontakt__form .legal { font-size: var(--text-xs); color: var(--text-muted); line-height: 1.5; margin: 16px 0 0; }
.sp-kontakt__success { display: flex; flex-direction: column; align-items: flex-start; padding: 24px 0; }
.sp-kontakt__success h2 { font-family: var(--font-display); font-weight: 700; font-size: var(--text-2xl); color: var(--text-strong); margin: 24px 0 12px; }
.sp-kontakt__success p { font-size: var(--text-md); color: var(--text-body); line-height: 1.65; max-width: 44ch; margin: 0 0 28px; }

/* ---- Footer (subpages variant: navy-800, 3 columns) ---- */
.footer-sp { background: var(--navy-800); color: var(--navy-200); }
.footer-sp__inner { padding-top: clamp(48px,6vw,80px); padding-bottom: 32px; }
.footer-sp__top { display: grid; grid-template-columns: 1.5fr 1fr 1fr; gap: 40px; padding-bottom: 44px; border-bottom: 1px solid var(--navy-600); }
.footer-sp__about img { height: 40px; width: auto; margin-bottom: 18px; }
.footer-sp__about p { font-size: var(--text-sm); line-height: 1.65; color: var(--navy-300); max-width: 34ch; margin: 0; }
.footer-sp__col-head { font-family: var(--font-eyebrow); font-size: 11px; letter-spacing: var(--tracking-eyebrow); text-transform: uppercase; color: var(--copper-300); margin-bottom: 16px; }
.footer-sp__col-links { display: flex; flex-direction: column; gap: 10px; }
.footer-sp__col-links a { font-size: var(--text-sm); color: var(--navy-200); }
.footer-sp__col-links a:hover { color: var(--copper-300); }
.footer-sp__bottom { display: flex; align-items: center; justify-content: space-between; gap: 20px; padding-top: 24px; flex-wrap: wrap; }
.footer-sp__bottom span.copy { font-size: var(--text-xs); color: var(--navy-400); }

/* ---- Responsive ---- */
@media (max-width: 920px) {
  .sp-format__inner, .sp-hero--split, .sp-bio, .sp-section-head--split { grid-template-columns: 1fr; }
  .sp-kontakt { grid-template-columns: 1fr; grid-template-areas: "intro" "form" "info"; }
  .sp-grid-2, .sp-grid-3 { grid-template-columns: repeat(2,1fr); }
  .footer-sp__top { grid-template-columns: 1fr; gap: 28px; }
  .ds-header__nav { display: none; }
  .sp-quote-band__mark, .sp-cta-band__mark { display: none; }
}
@media (max-width: 600px) {
  .sp-grid-2, .sp-grid-3 { grid-template-columns: 1fr; }
  .sp-kontakt__form .field-row { grid-template-columns: 1fr; }
  .sp-cta-band--light { flex-direction: column; align-items: stretch; text-align: center; }
  .sp-photo__badge--left, .sp-photo__badge--right { left: 14px; right: 14px; bottom: -16px; padding: 12px 16px; justify-content: center; }
  .sp-photo__badge-name { font-size: var(--text-base); text-align: center; }
}
