/* Subpage-specific styles shared across pages/*.html */
.two-col-lead {
  display: grid; grid-template-columns: 1.4fr 1fr; gap: var(--s9); align-items: start;
  margin-top: var(--s7);
}
@media (max-width: 900px) { .two-col-lead { grid-template-columns: 1fr; } }

.aside-card {
  background: var(--surface-tint);
  border: 1px solid var(--border-light);
  border-radius: var(--r-lg);
  padding: var(--s7);
  position: sticky; top: 100px;
}
.aside-card h5 { margin-top: 0; }
.aside-card ul { list-style: none; padding: 0; margin: 0 0 var(--s5); display: grid; gap: var(--s3); }
.aside-card ul li::before { content: "→ "; color: var(--accent); font-weight: 700; }

.section-title { max-width: 720px; margin-bottom: var(--s8); }

/* Richtext */
.rt h2 { margin-top: var(--s9); }
.rt h3 { margin-top: var(--s8); font-size: 24px; }
.rt ul { padding-left: var(--s5); }
.rt ul li { margin-bottom: var(--s3); }

/* Team cards */
.team-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: var(--s8); }
@media (max-width: 900px) { .team-grid { grid-template-columns: 1fr; } }
.team-card { display: grid; grid-template-columns: 220px 1fr; gap: var(--s6); align-items: start; }
@media (max-width: 600px) { .team-card { grid-template-columns: 1fr; } }
.team-card .img-ph { aspect-ratio: 1/1; }
.team-card h3 { margin-bottom: var(--s3); }

/* Contact form */
.form {
  display: grid; gap: var(--s5);
  background: #fff; padding: var(--s8); border-radius: var(--r-lg);
  border: 1px solid var(--border-light);
}
.form label { font-size: 14px; font-weight: 600; color: var(--text-heading); }
.form input, .form textarea, .form select {
  width: 100%; height: var(--input-h); padding: 0 var(--s4);
  border: 1px solid var(--border-strong); border-radius: var(--r-sm);
  font: inherit; font-size: 16px; color: var(--text-body); background: #fff;
  transition: border-color var(--dur) var(--ease-std), box-shadow var(--dur) var(--ease-std);
}
.form textarea { height: 140px; padding: var(--s3) var(--s4); resize: vertical; }
.form input:focus, .form textarea:focus, .form select:focus {
  outline: none;
  border-color: var(--accent);
  box-shadow: 0 0 0 3px rgba(0,183,180,0.2);
}
.form-row { display: grid; grid-template-columns: 1fr 1fr; gap: var(--s4); }
@media (max-width: 600px) { .form-row { grid-template-columns: 1fr; } }

/* Standorte */
.location-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: var(--s6); }
@media (max-width: 900px) { .location-grid { grid-template-columns: 1fr; } }
.location-card { padding: var(--s7); background: #fff; border: 1px solid var(--border-light);
  border-radius: var(--r-lg); transition: all var(--dur-slow) var(--ease-std); }
.location-card:hover { transform: translateY(-3px); box-shadow: var(--sh-lift); }
.location-card h4 { margin-bottom: var(--s3); }
.location-card .addr { color: var(--text-muted); font-size: 15px; }

/* Values */
.values-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: var(--s6); }
@media (max-width: 900px) { .values-grid { grid-template-columns: 1fr; } }
.value { padding: var(--s7); background: #fff; border: 1px solid var(--border-light);
  border-radius: var(--r-lg); }
.value .n { font-size: 36px; font-weight: 800; color: var(--accent-warm); letter-spacing: -0.03em;
  display: block; margin-bottom: var(--s3); font-variant-numeric: tabular-nums; }

/* ============================================================
   Process timeline — 3-step detailed flow
   ============================================================ */
.process-section { padding: clamp(56px, 8vw, 96px) 0; background: #fff; }
.process-timeline {
  display: grid; grid-template-columns: repeat(3, 1fr);
  gap: var(--s7);
  counter-reset: ptstep;
  position: relative;
}
@media (max-width: 900px) { .process-timeline { grid-template-columns: 1fr; gap: var(--s6); } }

.pt-step {
  position: relative;
  padding: var(--s7);
  background: #fff;
  border: 1px solid var(--border-light);
  border-radius: var(--r-lg);
  transition: transform var(--dur-slow) var(--ease-std), box-shadow var(--dur-slow) var(--ease-std);
}
.pt-step:hover { transform: translateY(-3px); box-shadow: var(--sh-lift); }

.pt-step::before {
  content: "";
  position: absolute; left: var(--s7); top: var(--s7);
  width: 36px; height: 36px; border-radius: 50%;
  background: linear-gradient(135deg, var(--accent), var(--secondary));
  opacity: .08;
}

.pt-num {
  font-size: 12px; letter-spacing: 0.12em; text-transform: uppercase;
  font-weight: 700; color: var(--accent);
  margin: 0 0 var(--s5);
  position: relative; z-index: 1;
}
.pt-title {
  font-family: var(--font-sans); font-weight: 700;
  font-size: 22px; color: var(--text-heading);
  letter-spacing: -0.01em; margin: 0 0 var(--s4); line-height: 1.2;
}
.pt-desc {
  font-size: 16px; color: var(--text-body); line-height: 1.55;
  margin: 0 0 var(--s5);
}
.pt-meta {
  font-size: 13px; color: var(--text-muted);
  padding-top: var(--s4);
  border-top: 1px solid var(--border-light);
  margin: 0;
}

/* Connecting dashed line between steps (desktop only) */
@media (min-width: 901px) {
  .process-timeline::after {
    content: "";
    position: absolute;
    top: 50%; left: 6%; right: 6%;
    height: 2px;
    background-image: linear-gradient(90deg, var(--accent) 50%, transparent 50%);
    background-size: 12px 2px;
    z-index: 0; opacity: .25;
    pointer-events: none;
  }
}
