/* ===================================================================
   kursiv. — Unterseiten-Komponenten
=================================================================== */

/* ---------- Subpage Hero ---------- */
.subhero {
  max-width: var(--maxw);
  margin: 0 auto;
  padding: clamp(50px, 9vh, 110px) var(--gutter) clamp(40px, 6vh, 70px);
}
.subhero__eyebrow {
  font-size: 0.85rem;
  font-weight: 600;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  color: var(--accent);
  margin-bottom: 22px;
}
.subhero__title {
  font-family: var(--f-display);
  font-weight: 800;
  font-size: clamp(2.8rem, 9vw, 7rem);
  line-height: 0.96;
  letter-spacing: -0.045em;
  max-width: 16ch;
}
.subhero__lead {
  margin-top: 30px;
  max-width: 560px;
  font-size: clamp(1.1rem, 1.7vw, 1.4rem);
  color: var(--grey-600);
  line-height: 1.5;
}

/* ---------- Leistungen detail ---------- */
.leistung {
  max-width: var(--maxw);
  margin: 0 auto;
  padding: clamp(50px, 8vh, 90px) var(--gutter);
  display: grid;
  grid-template-columns: 0.9fr 1.1fr;
  gap: clamp(30px, 6vw, 90px);
  border-top: 1px solid var(--grey-200);
}
.leistung__head { position: sticky; top: 100px; align-self: start; }
.leistung__num { font-size: 0.85rem; font-weight: 600; color: var(--accent); }
.leistung__title {
  font-family: var(--f-display);
  font-weight: 800;
  font-size: clamp(2rem, 4.5vw, 3.4rem);
  letter-spacing: -0.035em;
  line-height: 1;
  margin-top: 14px;
}
.leistung__desc { margin-top: 18px; color: var(--grey-600); max-width: 40ch; }
.leistung__list { display: flex; flex-direction: column; gap: 2px; }
.leistung__item {
  display: flex;
  align-items: baseline;
  gap: 18px;
  padding: 22px 4px;
  border-bottom: 1px solid var(--grey-200);
}
.leistung__item:first-child { border-top: 1px solid var(--grey-200); }
.leistung__item span { font-size: 0.85rem; color: var(--grey-400); font-variant-numeric: tabular-nums; min-width: 30px; }
.leistung__item h3 { font-size: clamp(1.15rem, 2vw, 1.5rem); font-weight: 600; letter-spacing: -0.02em; }
.leistung__item p { margin-top: 4px; color: var(--grey-600); font-size: 0.98rem; }

/* ---------- Prose (Agentur / Karriere / Legal) ---------- */
.prose { max-width: 760px; margin: 0 auto; padding: clamp(40px, 6vh, 70px) var(--gutter) clamp(70px, 12vh, 130px); }
.prose h2 {
  font-family: var(--f-display);
  font-weight: 800;
  font-size: clamp(1.8rem, 4vw, 2.8rem);
  letter-spacing: -0.035em;
  line-height: 1.05;
  margin: 56px 0 18px;
}
.prose h2:first-child { margin-top: 0; }
.prose h3 { font-size: 1.25rem; font-weight: 700; margin: 32px 0 10px; letter-spacing: -0.02em; }
.prose p { color: var(--grey-600); margin-bottom: 16px; font-size: 1.08rem; line-height: 1.65; }
.prose p strong { color: var(--ink); font-weight: 600; }
.prose a { color: var(--accent); text-decoration: underline; text-underline-offset: 3px; }
.prose ul { margin: 0 0 16px 0; padding-left: 0; list-style: none; }
.prose ul li { color: var(--grey-600); padding: 8px 0 8px 28px; position: relative; line-height: 1.5; }
.prose ul li::before { content: "→"; position: absolute; left: 0; color: var(--accent); font-weight: 600; }

/* Values grid */
.values { max-width: var(--maxw); margin: 0 auto; padding: clamp(50px, 8vh, 90px) var(--gutter); }
.values__grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1px; background: var(--grey-200); border: 1px solid var(--grey-200); border-radius: var(--radius); overflow: hidden; }
.value { background: var(--paper); padding: clamp(26px, 3vw, 40px); min-height: 200px; display: flex; flex-direction: column; }
.value__num { font-size: 0.85rem; color: var(--grey-400); font-weight: 600; }
.value h3 { margin-top: auto; font-size: 1.5rem; font-weight: 700; letter-spacing: -0.02em; }
.value p { margin-top: 10px; color: var(--grey-600); font-size: 0.98rem; }

/* ---------- Insights grid ---------- */
.insights { max-width: var(--maxw); margin: 0 auto; padding: clamp(40px, 6vh, 70px) var(--gutter) clamp(70px, 12vh, 130px); }
.insights__grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 28px; }
.article { display: flex; flex-direction: column; }
.article__media { aspect-ratio: 3 / 2; border-radius: var(--radius); background: var(--grey-200); margin-bottom: 18px; transition: transform 0.5s var(--ease); }
.article:hover .article__media { transform: translateY(-4px); }
.article__media--1 { background: radial-gradient(120% 120% at 30% 20%, var(--accent), #c6ff00 130%); }
.article__media--2 { background: linear-gradient(135deg, var(--ink), var(--accent)); }
.article__media--3 { background: radial-gradient(120% 120% at 70% 30%, #a9c6ff, var(--accent) 120%); }
.article__cat { font-size: 0.8rem; font-weight: 600; text-transform: uppercase; letter-spacing: 0.04em; color: var(--accent); }
.article h3 { margin-top: 10px; font-size: 1.3rem; font-weight: 700; letter-spacing: -0.02em; line-height: 1.2; }
.article p { margin-top: 8px; color: var(--grey-600); font-size: 0.98rem; }

/* ---------- Kontakt ---------- */
.contact-page { max-width: var(--maxw); margin: 0 auto; padding: clamp(40px, 6vh, 70px) var(--gutter) clamp(70px, 12vh, 130px); display: grid; grid-template-columns: 1fr 1fr; gap: clamp(30px, 6vw, 80px); }
.contact-info h2 { font-family: var(--f-display); font-weight: 800; font-size: clamp(1.6rem, 3vw, 2.2rem); letter-spacing: -0.03em; margin-bottom: 8px; }
.contact-info .row { padding: 22px 0; border-bottom: 1px solid var(--grey-200); }
.contact-info .label { font-size: 0.82rem; text-transform: uppercase; letter-spacing: 0.05em; color: var(--grey-400); margin-bottom: 6px; }
.contact-info a { font-size: 1.15rem; font-weight: 500; border-bottom: 2px solid transparent; transition: border-color 0.2s var(--ease); }
.contact-info a:hover { border-color: var(--accent); }
.form { display: flex; flex-direction: column; gap: 18px; }
.field { display: flex; flex-direction: column; gap: 8px; }
.field label { font-size: 0.9rem; font-weight: 600; }
.field input, .field textarea {
  font: inherit;
  padding: 14px 16px;
  border: 1.5px solid var(--grey-200);
  border-radius: 12px;
  background: var(--white);
  color: var(--ink);
  transition: border-color 0.2s var(--ease);
}
.field input:focus, .field textarea:focus { outline: none; border-color: var(--accent); }
.field textarea { min-height: 130px; resize: vertical; }
.form__note { font-size: 0.85rem; color: var(--grey-400); }

/* ---------- Back link ---------- */
.backlink { display: inline-flex; align-items: center; gap: 8px; margin-top: 12px; font-weight: 600; font-size: 0.95rem; color: var(--grey-600); transition: color 0.2s var(--ease); }
.backlink:hover { color: var(--ink); }

/* ---------- Notice (Platzhalter Legal) ---------- */
.notice { background: var(--accent-soft); border-radius: var(--radius); padding: 20px 24px; margin-bottom: 30px; font-size: 0.95rem; color: var(--grey-900); }
.notice strong { color: var(--ink); }

/* ---------- Responsive ---------- */
@media (max-width: 860px) {
  .leistung, .contact-page { grid-template-columns: 1fr; }
  .leistung__head { position: static; }
  .values__grid, .insights__grid { grid-template-columns: 1fr; }
}
@media (max-width: 1024px) and (min-width: 861px) {
  .insights__grid, .values__grid { grid-template-columns: repeat(2, 1fr); }
}
