/* Shared patient-page layout (used by paediatrie / neurologie / psychiatrie / hausbesuche) */

.recruit-bar {
  background: var(--ink); color: var(--bg); padding: 10px var(--gutter);
  font-family: var(--mono); font-size: 0.78rem; letter-spacing: 0.04em;
  display: flex; justify-content: center; gap: 16px; align-items: center;
}
.recruit-bar a { color: var(--accent); text-decoration: underline; text-underline-offset: 3px; }

.p-hero { padding: clamp(56px, 8vw, 100px) var(--gutter) clamp(40px, 5vw, 64px); border-bottom: 1px solid var(--rule); }
.p-hero-inner { max-width: var(--maxw); margin: 0 auto; display: grid; grid-template-columns: 1.3fr 1fr; gap: 56px; align-items: end; }
.p-hero h1 { font-family: var(--serif); font-style: italic; font-weight: 400; font-size: clamp(2.6rem, 5vw, 4.6rem); line-height: 0.95; letter-spacing: -0.025em; margin: 16px 0 24px; max-width: 18ch; }
.p-hero h1 em { font-style: normal; color: var(--accent-ink); }
.p-hero .lead { max-width: 50ch; }
.p-hero .actions { margin-top: 28px; display: flex; gap: 12px; flex-wrap: wrap; }
.p-hero .photo { height: 380px; }

.signals { padding: clamp(48px, 6vw, 80px) var(--gutter); background: var(--bg-2); border-bottom: 1px solid var(--rule); }
.signals-inner { max-width: var(--maxw); margin: 0 auto; }
.signals h2 { font-family: var(--serif); font-style: italic; font-weight: 400; font-size: var(--step-3); margin: 12px 0 32px; max-width: 28ch; line-height: 1.05; letter-spacing: -0.02em; }
.signals h2 em { font-style: normal; color: var(--accent-ink); }
.signal-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 0; border-top: 1px solid var(--rule); }
.signal { padding: 20px 0; border-bottom: 1px solid var(--rule); padding-right: 32px; }
.signal:nth-child(even) { padding-left: 32px; border-left: 1px solid var(--rule); }
.signal q { font-family: var(--serif); font-style: italic; font-size: 1.4rem; line-height: 1.2; }
.signal small { display: block; margin-top: 8px; font-size: 0.85rem; color: var(--ink-soft); }

.what { padding: clamp(60px, 8vw, 100px) var(--gutter); }
.what-inner { max-width: var(--maxw); margin: 0 auto; display: grid; grid-template-columns: 1fr 1.5fr; gap: 64px; }
.what h2 { font-family: var(--serif); font-style: italic; font-weight: 400; font-size: var(--step-4); margin: 12px 0 0; max-width: 14ch; line-height: 1.05; letter-spacing: -0.02em; }
.what h2 em { font-style: normal; color: var(--accent-ink); }
.what-list { display: grid; gap: 0; }
.what-row { display: grid; grid-template-columns: 80px 1fr; gap: 24px; padding: 24px 0; border-top: 1px solid var(--rule); }
.what-row:last-child { border-bottom: 1px solid var(--rule); }
.what-row .num { font-family: var(--mono); font-size: 0.78rem; color: var(--ink-soft); letter-spacing: 0.05em; }
.what-row h3 { font-family: var(--serif); font-style: italic; font-size: 1.6rem; font-weight: 400; margin: 0 0 8px; }
.what-row p { margin: 0; color: var(--ink-2); max-width: 56ch; }

.first { padding: clamp(60px, 8vw, 100px) var(--gutter); background: var(--ink); color: var(--bg); }
.first-inner { max-width: var(--maxw); margin: 0 auto; }
.first h2 { font-family: var(--serif); font-style: italic; font-weight: 400; font-size: var(--step-4); margin: 12px 0 48px; max-width: 22ch; line-height: 1.05; letter-spacing: -0.02em; color: var(--bg); }
.first h2 em { font-style: normal; color: var(--accent); }
.steps { display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px; }
.step { padding: 28px 24px; border: 1px solid #2C3933; }
.step .n { font-family: var(--serif); font-style: italic; font-size: 3rem; color: var(--accent); line-height: 1; }
.step h3 { font-family: var(--sans); font-weight: 500; font-size: 1.2rem; margin: 16px 0 8px; }
.step p { color: #C7CCC9; font-size: 0.92rem; margin: 0; }

.therapists { padding: clamp(60px, 8vw, 100px) var(--gutter); }
.therapists-inner { max-width: var(--maxw); margin: 0 auto; }
.therapists h2 { font-family: var(--serif); font-style: italic; font-weight: 400; font-size: var(--step-4); margin: 12px 0 40px; max-width: 22ch; line-height: 1.05; letter-spacing: -0.02em; }
.therapists h2 em { font-style: normal; color: var(--accent-ink); }
.therapist-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 16px; }
.therapist { background: var(--paper); border: 1px solid var(--rule); padding: 0; display: flex; flex-direction: column; }
.therapist .photo { height: 240px; }
.therapist .body { padding: 22px; }
.therapist .name { font-family: var(--serif); font-style: italic; font-size: 1.5rem; }
.therapist .role { font-family: var(--mono); font-size: 0.74rem; color: var(--ink-soft); letter-spacing: 0.04em; margin: 4px 0 14px; }
.therapist p { font-size: 0.92rem; color: var(--ink-2); margin: 0; }

.faq2 { padding: clamp(60px, 8vw, 100px) var(--gutter); background: var(--bg-2); }
.faq2-inner { max-width: var(--maxw); margin: 0 auto; display: grid; grid-template-columns: 1fr 1.6fr; gap: 64px; }
.faq2 h2 { font-family: var(--serif); font-style: italic; font-weight: 400; font-size: var(--step-4); margin: 12px 0 0; max-width: 14ch; line-height: 1.05; letter-spacing: -0.02em; }
.faq2 h2 em { font-style: normal; color: var(--accent-ink); }
.faq2 details { padding: 22px 0; border-top: 1px solid var(--rule); }
.faq2 details:last-child { border-bottom: 1px solid var(--rule); }
.faq2 summary { list-style: none; cursor: pointer; font-weight: 500; font-size: 1.05rem; display: flex; justify-content: space-between; gap: 16px; }
.faq2 summary::-webkit-details-marker { display: none; }
.faq2 summary::after { content: "+"; font-family: var(--mono); font-size: 1.4rem; color: var(--accent-ink); }
.faq2 details[open] summary::after { content: "−"; }
.faq2 details p { margin: 12px 0 0; color: var(--ink-2); max-width: 60ch; }

.termin { padding: clamp(60px, 8vw, 100px) var(--gutter); background: var(--accent); }
.termin-inner { max-width: var(--maxw); margin: 0 auto; display: grid; grid-template-columns: 1fr 1fr; gap: 56px; align-items: center; }
.termin h2 { font-family: var(--serif); font-style: italic; font-weight: 400; font-size: var(--step-5); margin: 0; line-height: 0.95; letter-spacing: -0.02em; max-width: 12ch; }
.termin h2 em { font-style: normal; }
.termin p { color: var(--ink-2); max-width: 36ch; margin-top: 16px; }
.termin .actions { display: flex; gap: 12px; flex-wrap: wrap; margin-top: 24px; }

@media (max-width: 980px) {
  .p-hero-inner, .what-inner, .faq2-inner, .termin-inner { grid-template-columns: 1fr; gap: 32px; }
}
@media (max-width: 800px) {
  .signal-grid, .steps, .therapist-grid { grid-template-columns: 1fr; }
  .signal:nth-child(even) { padding-left: 0; border-left: 0; }
}
