/*
 * Praxiszentrum — Kontakt Page CSS
 * S2.3-kern (2026-04-21): Content-Styles für template-kontakt.php.
 *
 * Selector-Namespace: .pxz-kontakt-* (gemäß S2.2 §2.3)
 * Token-Quelle: tokens.css v2 (Schicht 2 Semantic + Schicht 1 Primitives).
 * Nutzt .pxz-container / .pxz-title-1/-2 / .pxz-lead / .pxz-eyebrow aus components.css,
 * aber scoped-Overrides via .pxz-kontakt-* wenn dediziertes Layout nötig.
 */

/* -------- Container & Sections -------------------------------------------- */

.pxz-kontakt {
  background: var(--pxz-c-bg);
  color: var(--pxz-c-ink);
}

/* S63c-fix2 (2026-05-02): Reset Blocksy main-wrapper width-constraints,
   otherwise .pxz-container (1600 px) inside the Locations-Section gets
   capped at the parent's content-area width (~1080 px in Blocksy default). */
body.page-template-template-kontakt main.site-main,
body.page-template-template-kontakt main.site-main > article,
body.page-template-template-kontakt .entry-content {
    padding: 0 !important;
    margin: 0 !important;
    max-width: none !important;
    width: 100% !important;
}

.pxz-kontakt-hero,
.pxz-kontakt-locations,
.pxz-kontakt-form {
  padding-top: var(--pxz-space-section-y-desktop);
  padding-bottom: var(--pxz-space-section-y-desktop);
}

/* Welle 10 (2026-05-10): Hero-Bottom + Locations-Top auf 1/3 reduziert —
 * Hero ist nur noch 1-zeiliger Title (Eyebrow entfernt), darunter folgen
 * direkt die 3 Standort-Slider. Default-Section-Padding wäre hier zu viel
 * Leerraum zwischen Title und erster Slide. */
.pxz-kontakt-hero { padding-bottom: calc(var(--pxz-space-section-y-desktop) / 3); }
.pxz-kontakt-locations { padding-top: 0; }

/* S64-loc-text (2026-05-02): Hero/Form/Map-Inner ebenfalls auf 1600 px
   outer — Konsistenz mit Loc-Card-Block (1600). Innen 75 ch Lese-Kanal
   für reine Text-Elemente, damit Lesefluss auf großen Monitoren OK bleibt. */
.pxz-kontakt-hero-inner,
.pxz-kontakt-form-inner {
  max-width: var(--pxz-c3-max);  /* S55d C3 */
  margin-inline: auto;
  padding-inline: var(--pxz-space-container-x-desktop);
}
.pxz-kontakt-hero-inner > .pxz-kontakt-title,
.pxz-kontakt-hero-inner > .pxz-kontakt-sub,
.pxz-kontakt-form-intro {
  max-width: var(--pxz-c1-max);  /* S55d C1 reading */
  margin-inline: auto;
}
/* Locations-Section nutzt seit S63c den .pxz-container (1600 px). */

@media (max-width: 960px) {
  .pxz-kontakt-hero,
  .pxz-kontakt-locations,
  .pxz-kontakt-form {
    padding-top: var(--pxz-space-section-y-tablet);
    padding-bottom: var(--pxz-space-section-y-tablet);
  }
  .pxz-kontakt-hero { padding-bottom: calc(var(--pxz-space-section-y-tablet) / 3); }
  .pxz-kontakt-locations { padding-top: 0; }
  .pxz-kontakt-hero-inner,
  .pxz-kontakt-form-inner {
    padding-inline: var(--pxz-space-container-x-tablet);
  }
}

@media (max-width: 600px) {
  .pxz-kontakt-hero,
  .pxz-kontakt-locations,
  .pxz-kontakt-form {
    padding-top: var(--pxz-space-section-y-mobile);
    padding-bottom: var(--pxz-space-section-y-mobile);
  }
  .pxz-kontakt-hero { padding-bottom: calc(var(--pxz-space-section-y-mobile) / 3); }
  .pxz-kontakt-locations { padding-top: 0; }
  .pxz-kontakt-hero-inner,
  .pxz-kontakt-form-inner {
    padding-inline: var(--pxz-space-container-x-mobile);
  }
}

/* -------- Hero ------------------------------------------------------------ */

.pxz-kontakt-eyebrow {
  font-family: var(--pxz-font-body);
  font-size: 14px;
  font-weight: 600;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--pxz-c-accent);
  margin: 0 0 12px;
}

/* S65b (2026-05-10): Title auf T2-Token, Sub auf T5-Token. Vorher
 * eigene clamp(28-48px)/fix-18px — jetzt fluid und konsistent.
 * Welle 10 (2026-05-10): Title-Farbe auf Logo-Rot (Eyebrow entfernt,
 * Title übernimmt die Akzent-Rolle und führt den Blick in die Slider). */
.pxz-kontakt-title {
  font-family: var(--pxz-font-display);
  font-size: var(--pxz-t2-size);
  line-height: var(--pxz-t2-line);
  letter-spacing: var(--pxz-t2-track);
  font-weight: var(--pxz-t2-weight);
  color: var(--pxz-red);
  margin: 0 0 16px;
  text-wrap: balance;
}

.pxz-kontakt-sub {
  font-family: var(--pxz-font-body);
  font-size: var(--pxz-t5-size);
  line-height: var(--pxz-t5-line);
  letter-spacing: var(--pxz-t5-track);
  font-weight: var(--pxz-t5-weight);
  color: var(--pxz-c-ink-muted);
  max-width: var(--pxz-c1-max);
  margin: 0;
}

/* -------- Locations ------------------------------------------------------- */

.pxz-kontakt-locations-inner {
  display: grid;
  grid-template-columns: 1.6fr 1fr;
  gap: 24px;
}

@media (max-width: 900px) {
  .pxz-kontakt-locations-inner {
    grid-template-columns: 1fr;
  }
}

.pxz-kontakt-location {
  background: var(--pxz-c-surface);
  border: 1px solid var(--pxz-c-line);
  border-radius: var(--pxz-radius-card);
  padding: 40px;
}

@media (max-width: 600px) {
  .pxz-kontakt-location {
    padding: 28px;
  }
}

.pxz-kontakt-location-badge {
  font-family: var(--pxz-font-body);
  font-size: 12px;
  font-weight: 600;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--pxz-c-ink-muted);
  margin: 0 0 8px;
}

.pxz-kontakt-location-title {
  font-family: var(--pxz-font-display);
  font-size: 26px;
  font-weight: 600;
  letter-spacing: -0.01em;
  margin: 0 0 4px;
  color: var(--pxz-c-ink);
}

.pxz-kontakt-location-address {
  font-family: var(--pxz-font-body);
  font-size: 16px;
  line-height: 1.5;
  color: var(--pxz-c-ink-muted);
  font-style: normal;
  margin: 0 0 28px;
}

.pxz-kontakt-location-note {
  font-family: var(--pxz-font-body);
  font-size: 15px;
  line-height: 1.55;
  color: var(--pxz-c-ink-muted);
  margin: 0;
}

.pxz-kontakt-location-grid {
  display: grid;
  grid-template-columns: 1.2fr 1fr 1fr;
  gap: 32px;
  padding-top: 24px;
  border-top: 1px solid var(--pxz-c-line);
}

@media (max-width: 700px) {
  .pxz-kontakt-location-grid {
    grid-template-columns: 1fr;
    gap: 24px;
  }
}

.pxz-kontakt-location-label {
  font-family: var(--pxz-font-body);
  font-size: 12px;
  font-weight: 600;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--pxz-c-ink-subtle);
  margin-bottom: 10px;
}

.pxz-kontakt-location-hours {
  margin: 0 0 12px;
  font-family: var(--pxz-font-body);
  font-size: 15px;
  line-height: 1.45;
}

.pxz-kontakt-location-hour-row {
  display: flex;
  justify-content: space-between;
  gap: 12px;
  padding: 4px 0;
}

.pxz-kontakt-location-hour-row dt {
  color: var(--pxz-c-ink);
  font-weight: 500;
  margin: 0;
}

.pxz-kontakt-location-hour-row dd {
  color: var(--pxz-c-ink-muted);
  margin: 0;
  font-variant-numeric: tabular-nums;
}

.pxz-kontakt-location-open {
  font-size: 14px;
  line-height: 1.45;
  color: var(--pxz-c-ink-muted);
  margin: 12px 0 0;
}

.pxz-kontakt-location-phones {
  list-style: none;
  margin: 0;
  padding: 0;
  display: grid;
  gap: 14px;
}

.pxz-kontakt-location-phone-kind {
  display: block;
  font-family: var(--pxz-font-body);
  font-size: 13px;
  color: var(--pxz-c-ink-subtle);
  margin-bottom: 2px;
}

.pxz-kontakt-location-tel,
.pxz-kontakt-location-email {
  font-family: var(--pxz-font-display);
  font-size: 17px;
  font-weight: 500;
  color: var(--pxz-c-ink);
  text-decoration: none;
  font-variant-numeric: tabular-nums;
  border-bottom: 1px solid transparent;
  transition: border-color 0.15s ease;
}

.pxz-kontakt-location-tel:hover,
.pxz-kontakt-location-email:hover,
.pxz-kontakt-location-tel:focus-visible,
.pxz-kontakt-location-email:focus-visible {
  border-bottom-color: var(--pxz-c-accent);
}

/* -------- Form ------------------------------------------------------------ */

.pxz-kontakt-form {
  background: var(--pxz-c-surface-alt);
}

.pxz-kontakt-form-intro {
  max-width: var(--pxz-c1-max);  /* S55d */
  margin: 0 auto 28px;
  text-align: center;
}

.pxz-kontakt-form-title {
  font-family: var(--pxz-font-display);
  font-size: clamp(24px, 3vw, 32px);
  font-weight: 600;
  margin: 0 0 10px;
  color: var(--pxz-c-ink);
}

.pxz-kontakt-form-sub {
  font-family: var(--pxz-font-body);
  font-size: 16px;
  line-height: 1.55;
  color: var(--pxz-c-ink-muted);
  margin: 0;
}

.pxz-kontakt-form-sub a {
  color: var(--pxz-c-accent);
  text-decoration: underline;
  text-underline-offset: 3px;
}

.pxz-kontakt-form-wpforms,
.pxz-kontakt-form-fallback {
  max-width: var(--pxz-c1-max);  /* S55d */
  margin: 0 auto;
  background: var(--pxz-c-surface);
  border: 1px solid var(--pxz-c-line);
  border-radius: var(--pxz-radius-card);
  padding: 32px;
}

.pxz-kontakt-form-fallback p {
  font-family: var(--pxz-font-body);
  font-size: 16px;
  line-height: 1.6;
  color: var(--pxz-c-ink);
  margin: 0 0 8px;
}

.pxz-kontakt-form-fallback p:last-child {
  margin-bottom: 0;
}

.pxz-kontakt-form-fallback a {
  color: var(--pxz-c-accent);
  text-decoration: underline;
  text-underline-offset: 3px;
}

/* -------- Map & Anfahrt --------------------------------------------------- */

.pxz-kontakt-map-title {
  font-family: var(--pxz-font-display);
  font-size: clamp(24px, 3vw, 32px);
  font-weight: 600;
  margin: 0 0 24px;
  color: var(--pxz-c-ink);
}

.pxz-kontakt-map-hints {
  list-style: none;
  margin: 0 0 28px;
  padding: 0;
  display: grid;
  gap: 10px;
}

.pxz-kontakt-map-hints li {
  font-family: var(--pxz-font-body);
  font-size: 16px;
  line-height: 1.5;
  color: var(--pxz-c-ink);
  padding-left: 16px;
  position: relative;
}

.pxz-kontakt-map-hints li::before {
  content: "";
  position: absolute;
  left: 0;
  top: 0.7em;
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: var(--pxz-c-accent);
}

.pxz-kontakt-map-embed {
  position: relative;
  width: 100%;
  aspect-ratio: 16 / 9;
  border-radius: var(--pxz-radius-card);
  overflow: hidden;
  border: 1px solid var(--pxz-c-line);
  background: var(--pxz-c-surface);
}

.pxz-kontakt-map-embed iframe {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  border: 0;
}

.pxz-kontakt-map-note {
  font-family: var(--pxz-font-body);
  font-size: 14px;
  line-height: 1.5;
  color: var(--pxz-c-ink-subtle);
  margin: 16px 0 0;
  font-style: italic;
}
