/**
 * Impfkalender + Impf-Lexikon + Reiseimpfplaner — shared stylesheet.
 *
 * S74 (2026-05-12). Folgt der pxz-Design-System-Konvention:
 *   - Container/Padding via Token-Variablen (--pxz-*)
 *   - Hero-Pattern parallel zu /sprechstunden/, /contact-us/
 *   - Cards mit Token-basierten Schatten + Rundungen
 */

/* ===== Hero (shared, alle drei Templates) =============================== */

.pxz-impf-hero {
  padding: var(--pxz-space-12, 4rem) 0 var(--pxz-space-8, 2.5rem);
  background: var(--pxz-bg-soft, #f7f7f5);
}

.pxz-impf-hero-inner {
  max-width: var(--pxz-cw-c2, 960px);
  margin: 0 auto;
  padding: 0 var(--pxz-space-5, 1.25rem);
}

.pxz-impf-eyebrow {
  font-size: var(--pxz-fs-eyebrow, 0.875rem);
  font-weight: 600;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--pxz-color-muted, #888);
  margin: 0 0 var(--pxz-space-2, 0.5rem);
}

.pxz-impf-title {
  font-size: var(--pxz-fs-h1, clamp(2rem, 4vw, 3rem));
  line-height: 1.1;
  margin: 0 0 var(--pxz-space-4, 1rem);
  color: var(--pxz-color-fg, #1a1a1a);
}

.pxz-impf-sub {
  font-size: var(--pxz-fs-lead, 1.125rem);
  line-height: 1.55;
  color: var(--pxz-color-fg-soft, #444);
  max-width: 65ch;
  margin: 0;
}

/* ===== Form Section (Kalender + Reiseplaner) ============================ */

.pxz-impf-form-section,
.pxz-reise-form-section {
  padding: var(--pxz-space-10, 3rem) 0 var(--pxz-space-16, 5rem);
}

.pxz-impf-form-inner,
.pxz-reise-form-inner {
  max-width: var(--pxz-cw-c2, 960px);
  margin: 0 auto;
  padding: 0 var(--pxz-space-5, 1.25rem);
}

.pxz-impf-form {
  display: grid;
  gap: var(--pxz-space-8, 2rem);
}

.pxz-impf-fieldset {
  background: #fff;
  border: 1px solid var(--pxz-color-border, #e8e8e2);
  border-radius: var(--pxz-radius-lg, 14px);
  padding: var(--pxz-space-6, 1.5rem) var(--pxz-space-7, 1.75rem);
  margin: 0;
  box-shadow: var(--pxz-shadow-card, 0 2px 8px rgba(0,0,0,0.04));
}

.pxz-impf-legend {
  font-size: var(--pxz-fs-h3, 1.25rem);
  font-weight: 600;
  color: var(--pxz-color-fg, #1a1a1a);
  padding: 0 var(--pxz-space-2, 0.5rem);
  background: #fff;
}

.pxz-impf-row {
  display: grid;
  gap: var(--pxz-space-2, 0.5rem);
  margin-top: var(--pxz-space-5, 1.25rem);
}

.pxz-impf-row-2col {
  grid-template-columns: 1fr 1fr;
  gap: var(--pxz-space-5, 1.25rem);
}

@media (max-width: 640px) {
  .pxz-impf-row-2col { grid-template-columns: 1fr; }
}

.pxz-impf-row-check {
  flex-direction: column;
  align-items: flex-start;
  gap: var(--pxz-space-3, 0.75rem);
  display: flex;
}

.pxz-impf-label {
  font-weight: 600;
  font-size: var(--pxz-fs-body, 1rem);
  color: var(--pxz-color-fg, #1a1a1a);
}

/* Robust input baseline — Blocksy/Browser-Defaults explizit überschreiben,
 * sonst klippt der native <select> die ausgewählte Option oben weg
 * (line-height < 1 aus dem Parent-Theme). Symptom (S74-Bug): Text in
 * Reisedaten-Dropdowns nur halb sichtbar.
 */
.pxz-impf-input {
  display: block;
  width: 100%;
  min-height: 2.875rem;
  box-sizing: border-box;
  padding: 0.625rem 1rem;
  border: 1px solid var(--pxz-color-border, #d0d0c8);
  border-radius: var(--pxz-radius-md, 10px);
  font-size: 1rem;
  line-height: 1.5;
  background: #fff;
  color: var(--pxz-color-fg, #1a1a1a);
  font-family: inherit;
  vertical-align: middle;
}

/* Select-spezifisch: native Pfeil abschalten + eigenen Chevron rechts,
 * damit Padding nicht vom OS-Renderer überschrieben wird (macOS Safari
 * + Chromium-on-mac sind hier besonders restriktiv).
 */
select.pxz-impf-input {
  appearance: none;
  -webkit-appearance: none;
  -moz-appearance: none;
  padding-right: 2.5rem;
  background-image: url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='8' viewBox='0 0 14 8'%3E%3Cpath fill='none' stroke='%231a1a1a' stroke-width='1.6' stroke-linecap='round' stroke-linejoin='round' d='M1 1l6 6 6-6'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right 1rem center;
  background-size: 14px 8px;
  cursor: pointer;
}

select.pxz-impf-input::-ms-expand { display: none; }

/* Date-Input: same baseline, kein eigener Chevron (Browser-nativ). */
input[type="date"].pxz-impf-input {
  padding-right: 0.75rem;
}

.pxz-impf-input:focus {
  outline: 2px solid var(--pxz-color-accent, #8b1a1a);
  outline-offset: 2px;
  border-color: var(--pxz-color-accent, #8b1a1a);
}

.pxz-impf-check {
  display: inline-flex;
  align-items: center;
  gap: var(--pxz-space-2, 0.5rem);
  font-size: var(--pxz-fs-body, 1rem);
  cursor: pointer;
}

.pxz-impf-check input {
  width: 18px;
  height: 18px;
  accent-color: var(--pxz-color-accent, #8b1a1a);
}

.pxz-impf-hint {
  font-size: var(--pxz-fs-small, 0.9375rem);
  color: var(--pxz-color-fg-soft, #555);
  margin: 0 0 var(--pxz-space-5, 1.25rem);
}

/* ----- Vakzine-Grid (Kalender) ------------------------------------------- */

.pxz-impf-vakzine-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
  gap: var(--pxz-space-5, 1.25rem);
}

.pxz-impf-vakzine {
  display: grid;
  gap: var(--pxz-space-2, 0.5rem);
  padding: var(--pxz-space-4, 1rem);
  border: 1px solid var(--pxz-color-border-soft, #efefe9);
  border-radius: var(--pxz-radius-md, 10px);
  background: var(--pxz-bg-soft, #fbfbf8);
}

.pxz-impf-vak-label {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--pxz-space-3, 0.75rem);
  font-weight: 600;
  font-size: 0.9375rem;
  cursor: pointer;
}

.pxz-impf-vak-name {
  flex: 1 1 auto;
  line-height: 1.3;
}

.pxz-impf-vak-badge {
  font-size: 0.6875rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  padding: 2px 8px;
  border-radius: 999px;
  background: #eaeae0;
  color: #333;
  white-space: nowrap;
}

.pxz-impf-vak-badge--standard   { background: #e3edf6; color: #1c3a5c; }
.pxz-impf-vak-badge--indikation { background: #f6efe3; color: #6c4a14; }
.pxz-impf-vak-badge--reise      { background: #e8f4e6; color: #265724; }
.pxz-impf-vak-badge--covid      { background: #f5e2e2; color: #6c1414; }

.pxz-impf-vak-info {
  font-size: 0.8125rem;
  color: var(--pxz-color-accent, #8b1a1a);
  text-decoration: none;
}

.pxz-impf-vak-info:hover { text-decoration: underline; }

/* ----- Actions ----------------------------------------------------------- */

.pxz-impf-actions {
  display: flex;
  gap: var(--pxz-space-3, 0.75rem);
  flex-wrap: wrap;
  justify-content: flex-end;
}

/* ----- Result-Box ------------------------------------------------------- */

.pxz-impf-result,
.pxz-reise-result {
  margin-top: var(--pxz-space-10, 3rem);
  padding: var(--pxz-space-7, 1.75rem);
  background: #fff;
  border: 1px solid var(--pxz-color-border, #e8e8e2);
  border-radius: var(--pxz-radius-lg, 14px);
  box-shadow: var(--pxz-shadow-card, 0 2px 8px rgba(0,0,0,0.04));
}

.pxz-impf-result-title {
  margin: 0 0 var(--pxz-space-6, 1.5rem);
  font-size: var(--pxz-fs-h2, 1.75rem);
}

.pxz-impf-result-groups {
  display: grid;
  gap: var(--pxz-space-7, 1.75rem);
}

.pxz-impf-result-group h3 {
  font-size: var(--pxz-fs-h3, 1.25rem);
  margin: 0 0 var(--pxz-space-3, 0.75rem);
  display: flex;
  align-items: baseline;
  gap: var(--pxz-space-2, 0.5rem);
}

.pxz-impf-result-count {
  color: var(--pxz-color-muted, #888);
  font-weight: 400;
  font-size: 0.875rem;
}

.pxz-impf-result-group--overdue h3 { color: #a31515; }
.pxz-impf-result-group--soon h3    { color: #b56a00; }
.pxz-impf-result-group--start h3   { color: #1c4a8c; }
.pxz-impf-result-group--ok h3      { color: #265724; }

.pxz-impf-result-list {
  list-style: none;
  padding: 0;
  margin: 0;
  display: grid;
  gap: var(--pxz-space-3, 0.75rem);
}

.pxz-impf-result-item {
  padding: var(--pxz-space-4, 1rem);
  border-left: 4px solid #ddd;
  background: var(--pxz-bg-soft, #f9f9f4);
  border-radius: var(--pxz-radius-sm, 6px);
}

.pxz-impf-result-group--overdue .pxz-impf-result-item { border-left-color: #a31515; }
.pxz-impf-result-group--soon    .pxz-impf-result-item { border-left-color: #b56a00; }
.pxz-impf-result-group--start   .pxz-impf-result-item { border-left-color: #1c4a8c; }
.pxz-impf-result-group--ok      .pxz-impf-result-item { border-left-color: #265724; }
.pxz-impf-result-group--lifelong .pxz-impf-result-item { border-left-color: #265724; opacity: 0.85; }
.pxz-impf-result-group--none    .pxz-impf-result-item { border-left-color: #b8b8b0; opacity: 0.6; }

.pxz-impf-result-head {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: var(--pxz-space-3, 0.75rem);
  margin-bottom: var(--pxz-space-2, 0.5rem);
}

.pxz-impf-result-name {
  font-weight: 700;
  font-size: 1.0625rem;
  color: var(--pxz-color-fg, #1a1a1a);
  text-decoration: none;
}

.pxz-impf-result-name:hover { text-decoration: underline; }

.pxz-impf-result-cat {
  font-size: 0.75rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  padding: 2px 8px;
  border-radius: 999px;
  background: #eaeae0;
  color: #555;
}

.pxz-impf-st {
  font-size: 0.75rem;
  font-weight: 700;
  padding: 3px 10px;
  border-radius: 999px;
}

.pxz-impf-st--start    { background: #e0eaf6; color: #1c3a5c; }
.pxz-impf-st--overdue  { background: #f6dada; color: #7a1212; }
.pxz-impf-st--soon     { background: #f6e8c4; color: #6c4a14; }
.pxz-impf-st--ok       { background: #dceedb; color: #265724; }
.pxz-impf-st--muted    { background: #ececea; color: #555; }

.pxz-impf-result-due {
  margin: 0 0 var(--pxz-space-2, 0.5rem);
  font-size: 0.9375rem;
}

.pxz-impf-result-reason {
  margin: 0;
  font-size: 0.9375rem;
  color: var(--pxz-color-fg-soft, #555);
  line-height: 1.5;
}

.pxz-impf-result-disclaimer {
  margin-top: var(--pxz-space-7, 1.75rem);
  padding: var(--pxz-space-4, 1rem) var(--pxz-space-5, 1.25rem);
  background: #fbf6e8;
  border-left: 4px solid #b56a00;
  border-radius: var(--pxz-radius-sm, 6px);
  font-size: 0.9375rem;
  color: #4a3300;
  line-height: 1.55;
}

/* ===== Lexikon ========================================================== */

.pxz-impf-lex-list {
  padding: var(--pxz-space-10, 3rem) 0 var(--pxz-space-16, 5rem);
}

.pxz-impf-lex-list-inner,
.pxz-impf-detail-inner {
  max-width: var(--pxz-cw-c3, 1140px);
  margin: 0 auto;
  padding: 0 var(--pxz-space-5, 1.25rem);
}

.pxz-impf-lex-cat {
  font-size: var(--pxz-fs-h2, 1.75rem);
  margin: var(--pxz-space-10, 3rem) 0 var(--pxz-space-5, 1.25rem);
  color: var(--pxz-color-fg, #1a1a1a);
}

.pxz-impf-lex-cat:first-of-type { margin-top: 0; }

.pxz-impf-lex-grid {
  list-style: none;
  padding: 0;
  margin: 0;
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
  gap: var(--pxz-space-5, 1.25rem);
}

.pxz-impf-lex-item a {
  display: block;
  padding: var(--pxz-space-5, 1.25rem);
  background: #fff;
  border: 1px solid var(--pxz-color-border, #e8e8e2);
  border-radius: var(--pxz-radius-md, 10px);
  text-decoration: none;
  color: inherit;
  transition: box-shadow 150ms, transform 150ms;
  height: 100%;
}

.pxz-impf-lex-item a:hover {
  box-shadow: var(--pxz-shadow-card-hover, 0 6px 18px rgba(0,0,0,0.08));
  transform: translateY(-2px);
}

.pxz-impf-lex-item h3 {
  margin: 0 0 var(--pxz-space-2, 0.5rem);
  font-size: 1.125rem;
  color: var(--pxz-color-accent, #8b1a1a);
}

.pxz-impf-lex-item p {
  margin: 0;
  font-size: 0.9375rem;
  color: var(--pxz-color-fg-soft, #555);
  line-height: 1.5;
}

/* ===== Lexikon-Detail =================================================== */

.pxz-impf-detail {
  padding: var(--pxz-space-10, 3rem) 0 var(--pxz-space-16, 5rem);
}

.pxz-impf-back {
  display: inline-block;
  margin-bottom: var(--pxz-space-6, 1.5rem);
  font-size: 0.9375rem;
  color: var(--pxz-color-accent, #8b1a1a);
  text-decoration: none;
}

.pxz-impf-back:hover { text-decoration: underline; }

.pxz-impf-detail-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: var(--pxz-space-5, 1.25rem);
}

@media (max-width: 720px) {
  .pxz-impf-detail-grid { grid-template-columns: 1fr; }
}

.pxz-impf-detail-card {
  padding: var(--pxz-space-5, 1.25rem) var(--pxz-space-6, 1.5rem);
  background: #fff;
  border: 1px solid var(--pxz-color-border, #e8e8e2);
  border-radius: var(--pxz-radius-md, 10px);
  box-shadow: var(--pxz-shadow-card, 0 2px 8px rgba(0,0,0,0.04));
}

.pxz-impf-detail-card--wide {
  grid-column: 1 / -1;
}

.pxz-impf-detail-card h2 {
  margin: 0 0 var(--pxz-space-3, 0.75rem);
  font-size: 1.125rem;
  color: var(--pxz-color-accent, #8b1a1a);
}

.pxz-impf-detail-card p {
  margin: 0;
  font-size: 1rem;
  line-height: 1.6;
  color: var(--pxz-color-fg-soft, #333);
}

.pxz-impf-detail-schema ol {
  margin: 0 0 var(--pxz-space-3, 0.75rem);
  padding-left: 1.25rem;
}

.pxz-impf-detail-schema li {
  margin-bottom: var(--pxz-space-2, 0.5rem);
}

.pxz-impf-booster {
  padding: var(--pxz-space-3, 0.75rem) var(--pxz-space-4, 1rem);
  background: var(--pxz-bg-soft, #f9f9f4);
  border-left: 4px solid var(--pxz-color-accent, #8b1a1a);
  border-radius: var(--pxz-radius-sm, 6px);
}

.pxz-impf-detail-source {
  margin-top: var(--pxz-space-7, 1.75rem);
  font-size: 0.9375rem;
  color: var(--pxz-color-muted, #888);
}

/* ===== Reiseimpfplaner Result =========================================== */

.pxz-reise-meta {
  padding: var(--pxz-space-4, 1rem) var(--pxz-space-5, 1.25rem);
  background: var(--pxz-bg-soft, #f9f9f4);
  border-radius: var(--pxz-radius-md, 10px);
  margin-bottom: var(--pxz-space-6, 1.5rem);
}

.pxz-reise-meta p { margin: 0.25rem 0; }

.pxz-reise-region-desc {
  font-size: 0.9375rem;
  color: var(--pxz-color-fg-soft, #555);
}

.pxz-reise-aa-link {
  margin-top: var(--pxz-space-3, 0.75rem);
}

/* S74b — Warning-Banner + Multi-Source-Quellen-Block. */
.pxz-reise-warning {
  margin: 0 0 var(--pxz-space-5, 1.25rem);
  padding: var(--pxz-space-4, 1rem) var(--pxz-space-5, 1.25rem);
  background: #fbeaea;
  border-left: 4px solid #a31515;
  border-radius: var(--pxz-radius-sm, 6px);
  color: #6c1414;
  font-size: 0.9375rem;
  line-height: 1.55;
}

.pxz-reise-sources {
  margin-top: var(--pxz-space-4, 1rem);
}

.pxz-reise-sources-label {
  margin: 0 0 var(--pxz-space-2, 0.5rem);
  font-size: 0.875rem;
  color: var(--pxz-color-fg, #1a1a1a);
}

.pxz-reise-sources-list {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-wrap: wrap;
  gap: var(--pxz-space-2, 0.5rem);
}

.pxz-reise-sources-list li {
  margin: 0;
}

.pxz-reise-sources-list a {
  display: inline-block;
  padding: 0.375rem 0.75rem;
  background: #fff;
  border: 1px solid var(--pxz-color-border, #d0d0c8);
  border-radius: 999px;
  font-size: 0.8125rem;
  color: var(--pxz-color-accent, #8b1a1a);
  text-decoration: none;
  transition: background 150ms, border-color 150ms;
}

.pxz-reise-sources-list a:hover {
  background: var(--pxz-color-accent, #8b1a1a);
  color: #fff;
  border-color: var(--pxz-color-accent, #8b1a1a);
}

.pxz-reise-blocks {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: var(--pxz-space-5, 1.25rem);
}

@media (max-width: 720px) {
  .pxz-reise-blocks { grid-template-columns: 1fr; }
}

.pxz-reise-block {
  padding: var(--pxz-space-5, 1.25rem);
  background: #fff;
  border: 1px solid var(--pxz-color-border, #e8e8e2);
  border-radius: var(--pxz-radius-md, 10px);
  border-top-width: 4px;
}

.pxz-reise-block--pflicht   { border-top-color: #a31515; grid-column: 1 / -1; background: #fff7f5; }
.pxz-reise-block--standard  { border-top-color: #1c4a8c; }
.pxz-reise-block--empfohlen { border-top-color: #265724; }
.pxz-reise-block--risiko    { border-top-color: #b56a00; }

.pxz-reise-block h3 {
  margin: 0 0 var(--pxz-space-3, 0.75rem);
  font-size: 1.0625rem;
}

.pxz-reise-vak-list {
  list-style: disc;
  margin: 0;
  padding-left: 1.25rem;
}

.pxz-reise-vak-list li {
  margin-bottom: var(--pxz-space-2, 0.5rem);
}

.pxz-reise-vak-list a {
  color: var(--pxz-color-fg, #1a1a1a);
  text-decoration: none;
}

.pxz-reise-vak-list a:hover {
  color: var(--pxz-color-accent, #8b1a1a);
  text-decoration: underline;
}

.pxz-reise-empty {
  font-style: italic;
  color: var(--pxz-color-muted, #888);
  margin: 0;
}

.pxz-reise-block-note {
  margin: var(--pxz-space-3, 0.75rem) 0 0;
  font-size: 0.8125rem;
  color: var(--pxz-color-muted, #888);
}

.pxz-reise-hinweise {
  margin-top: var(--pxz-space-6, 1.5rem);
  padding: var(--pxz-space-4, 1rem) var(--pxz-space-5, 1.25rem);
  background: #eef4f9;
  border-left: 4px solid #1c4a8c;
  border-radius: var(--pxz-radius-sm, 6px);
}

.pxz-reise-hinweise h3 {
  margin: 0 0 var(--pxz-space-2, 0.5rem);
  font-size: 1rem;
  color: #1c3a5c;
}

.pxz-reise-hinweise p {
  margin: 0;
  font-size: 0.9375rem;
  line-height: 1.55;
}
