/*
 * ikraMed appointment.css
 * Vollständig auf den Termin-Tab beschränkt.
 * Wichtig: Diese Datei darf globale Praxis-/Nicepage-Styles nicht verändern.
 */

#tab-b4c6 .ikra-appointment-root {
--bg: #f3f4f6;
      --bg-soft: #e5f0ff;
      --primary: #2563eb;
      --primary-soft: #dbeafe;
      --primary-strong: #1d4ed8;
      --accent: #0ea5e9;
      --surface: #ffffff;
      --border-subtle: #e5e7eb;
      --text-main: #111827;
      --text-muted: #6b7280;
      --danger: #dc2626;
      --success: #16a34a;
      --radius-lg: 18px;
      --radius-pill: 999px;
      --shadow-soft: 0 18px 45px rgba(15, 23, 42, 0.10);
      --transition-fast: 150ms ease-out;
  width: 100%;
  max-width: 1120px;
  margin: 0 auto;
  padding: 24px 0 40px;
  font-family: Georgia, "Times New Roman", serif;
  font-size: 16px;
  line-height: 1.45;
  color: var(--text-main);
  box-sizing: border-box;
  min-height: auto;
}

#tab-b4c6 .ikra-appointment-root * {
box-sizing: border-box;
}

#tab-b4c6 .ikra-appointment-root .app-shell {
min-height: 100vh;
      display: flex;
      flex-direction: column;
}

#tab-b4c6 .ikra-appointment-root .app-header {
background: linear-gradient(110deg, #0ea5e9, #6366f1);
      color: white;
      padding: 1.1rem 1.5rem;
      border-bottom: 1px solid rgba(255, 255, 255, 0.15);
      position: sticky;
      top: 0;
      z-index: 10;
      backdrop-filter: blur(12px);
}

#tab-b4c6 .ikra-appointment-root .app-header-inner {
max-width: 1120px;
      margin: 0 auto;
      display: flex;
      align-items: center;
      justify-content: space-between;
      gap: 1rem;
}

#tab-b4c6 .ikra-appointment-root .brand {
display: flex;
      align-items: center;
      gap: 0.75rem;
}

#tab-b4c6 .ikra-appointment-root .brand-logo {
width: 38px;
      height: 38px;
      border-radius: 14px;
      background: radial-gradient(circle at 20% 0%, #e0f2fe, #1d4ed8 55%, #020617 95%);
      display: flex;
      align-items: center;
      justify-content: center;
      font-weight: 700;
      font-size: 0.95rem;
      letter-spacing: 0.03em;
      box-shadow: 0 10px 25px rgba(15, 23, 42, 0.35);
}

#tab-b4c6 .ikra-appointment-root .brand-text-main {
font-weight: 600;
      font-size: 1.05rem;
}

#tab-b4c6 .ikra-appointment-root .brand-text-sub {
font-size: 0.8rem;
      opacity: 0.9;
}

#tab-b4c6 .ikra-appointment-root .header-pill {
padding: 0.35rem 0.9rem;
      border-radius: 999px;
      background: rgba(15, 23, 42, 0.18);
      font-size: 0.78rem;
      display: inline-flex;
      align-items: center;
      gap: 0.4rem;
      white-space: nowrap;
}

#tab-b4c6 .ikra-appointment-root .header-pill-dot {
width: 7px;
      height: 7px;
      border-radius: 999px;
      background: #4ade80;
      box-shadow: 0 0 0 6px rgba(74, 222, 128, 0.3);
}

#tab-b4c6 .ikra-appointment-root .app-main {
flex: 1;
      padding: 2.25rem 1.5rem 2.5rem;
}

#tab-b4c6 .ikra-appointment-root .booking-view {
max-width: 1120px;
      margin: 0 auto;
      display: grid;
      grid-template-columns: minmax(0, 1.65fr) minmax(0, 1.05fr);
      gap: 2rem;
      align-items: flex-start;
}

@media (max-width: 960px) {
  #tab-b4c6 .ikra-appointment-root .app-main {
padding: 1.5rem 1rem 2rem;
  }

  #tab-b4c6 .ikra-appointment-root .booking-view {
grid-template-columns: minmax(0, 1fr);
  }
}

#tab-b4c6 .ikra-appointment-root .booking-shell {
background: var(--surface);
      border-radius: var(--radius-lg);
      
          box-shadow: 0 20px 50px rgba(15, 23, 42, 0.75);
      border: 1px solid rgba(148, 163, 184, 0.25);
      padding: 1.6rem 1.6rem 1.4rem;
      position: relative;
      overflow: hidden;
}

@media (max-width: 640px) {
  #tab-b4c6 .ikra-appointment-root .booking-shell {
padding: 1.2rem 1.1rem 1.1rem;
  }
}

#tab-b4c6 .ikra-appointment-root .booking-shell::before {
content: "";
      position: absolute;
      inset: 0;
      background: linear-gradient(130deg, rgba(59, 130, 246, 0.06), rgba(56, 189, 248, 0.05));
      opacity: 0.7;
      pointer-events: none;
}

#tab-b4c6 .ikra-appointment-root .booking-shell-inner {
position: relative;
      z-index: 1;
}

#tab-b4c6 .ikra-appointment-root .booking-header-topline {
display: flex;
      justify-content: space-between;
      gap: 1rem;
      margin-bottom: 0.8rem;
      align-items: center;
}

#tab-b4c6 .ikra-appointment-root .badge-subtle {
font-size: 0.7rem;
      text-transform: uppercase;
      letter-spacing: 0.08em;
      color: var(--primary-strong);
      background: rgba(219, 234, 254, 0.7);
      border-radius: 999px;
      padding: 0.3rem 0.7rem;
      border: 1px solid rgba(129, 140, 248, 0.5);
}

#tab-b4c6 .ikra-appointment-root .booking-title {
font-size: 1.25rem;
      font-weight: 600;
      margin: 0;
      color: var(--text-main);
}

#tab-b4c6 .ikra-appointment-root .booking-subtitle {
font-size: 0.9rem;
      color: var(--text-muted);
      margin: 0.2rem 0 1rem;
}

#tab-b4c6 .ikra-appointment-root .stepper {
list-style: none;
      padding: 0.55rem 0.9rem 0.7rem;
      margin: 0 0 1.1rem;
      border-radius: var(--radius-lg);
      background: rgba(248, 250, 252, 0.96);
      border: 1px solid rgba(209, 213, 219, 0.8);
      display: flex;
      gap: 0.9rem;
      justify-content: space-between;
}

@media (max-width: 640px) {
  #tab-b4c6 .ikra-appointment-root .stepper {
padding: 0.5rem;
        gap: 0.4rem;
  }
}

#tab-b4c6 .ikra-appointment-root .stepper-item {
flex: 1;
      min-width: 0;
      display: flex;
      align-items: center;
      gap: 0.55rem;
      font-size: 0.78rem;
      color: var(--text-muted);
      opacity: 0.8;
      position: relative;
}

#tab-b4c6 .ikra-appointment-root .stepper-item::after {
content: "";
      position: absolute;
      right: -0.5rem;
      top: 50%;
      width: 0.4rem;
      height: 1px;
      background: rgba(148, 163, 184, 0.6);
      transform: translateY(-50%);
}

#tab-b4c6 .ikra-appointment-root .stepper-item:last-child::after {
content: none;
}

#tab-b4c6 .ikra-appointment-root .stepper-index {
width: 22px;
      height: 22px;
      border-radius: 999px;
      border: 1px solid rgba(148, 163, 184, 0.8);
      font-size: 0.75rem;
      display: flex;
      align-items: center;
      justify-content: center;
      background: white;
}

#tab-b4c6 .ikra-appointment-root .stepper-label-main {
font-weight: 500;
      white-space: nowrap;
}

#tab-b4c6 .ikra-appointment-root .stepper-label-sub {
display: none;
}

#tab-b4c6 .ikra-appointment-root .stepper-item.is-active {
color: var(--primary-strong);
      opacity: 1;
}

#tab-b4c6 .ikra-appointment-root .stepper-item.is-active .stepper-index {
background: linear-gradient(135deg, var(--primary), var(--accent));
      border-color: transparent;
      color: white;
      box-shadow: 0 0 0 4px rgba(129, 140, 248, 0.38);
}

#tab-b4c6 .ikra-appointment-root .stepper-item.is-complete .stepper-index {
background: #22c55e;
      color: white;
      border-color: transparent;
      box-shadow: 0 0 0 3px rgba(34, 197, 94, 0.32);
}

#tab-b4c6 .ikra-appointment-root .stepper-item.is-complete {
color: #16a34a;
      opacity: 1;
}

#tab-b4c6 .ikra-appointment-root .stepper-item.is-complete .stepper-label-main::before {
content: "✓ ";
      font-weight: 600;
}

#tab-b4c6 .ikra-appointment-root .step-title {
font-size: 1.02rem;
      font-weight: 600;
      margin: 0 0 0.15rem;
}

#tab-b4c6 .ikra-appointment-root .step-intro {
font-size: 0.85rem;
      color: var(--text-muted);
      margin: 0 0 0.9rem;
}

#tab-b4c6 .ikra-appointment-root .steps-container {
margin-top: 0.5rem;
      min-height: 260px;
}

#tab-b4c6 .ikra-appointment-root fieldset.step {
border: none;
      padding: 0;
      margin: 0;
}

#tab-b4c6 .ikra-appointment-root fieldset[hidden] {
display: none;
}

#tab-b4c6 .ikra-appointment-root .form-grid {
display: grid;
      grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
      gap: 0.85rem 1rem;
      margin-bottom: 0.9rem;
}

@media (max-width: 720px) {
  #tab-b4c6 .ikra-appointment-root .form-grid {
grid-template-columns: minmax(0, 1fr);
  }
}

#tab-b4c6 .ikra-appointment-root .form-field {
margin-bottom: 0.85rem;
}

#tab-b4c6 .ikra-appointment-root .form-field label,
#tab-b4c6 .ikra-appointment-root .field-label {
display: flex;
      align-items: baseline;
      gap: 0.2rem;
      font-size: 0.84rem;
      font-weight: 500;
      margin-bottom: 0.25rem;
}

#tab-b4c6 .ikra-appointment-root .label-optional {
font-weight: 400;
      font-size: 0.78rem;
      color: var(--text-muted);
}

#tab-b4c6 .ikra-appointment-root .field-help {
font-size: 0.75rem;
      color: var(--text-muted);
      margin: 0.15rem 0 0;
}

#tab-b4c6 .ikra-appointment-root .field-error {
font-size: 0.74rem;
      color: var(--danger);
      margin: 0.25rem 0 0;
      display: none;
}

#tab-b4c6 .ikra-appointment-root .form-field.has-error .field-error {
display: block;
}

#tab-b4c6 .ikra-appointment-root .form-field.has-error select,
#tab-b4c6 .ikra-appointment-root .form-field.has-error textarea,
#tab-b4c6 .ikra-appointment-root .form-field.has-error input[type="text"],
#tab-b4c6 .ikra-appointment-root .form-field.has-error input[type="email"],
#tab-b4c6 .ikra-appointment-root .form-field.has-error input[type="tel"],
#tab-b4c6 .ikra-appointment-root .form-field.has-error input[type="date"] {
border-color: rgba(220, 38, 38, 0.85);
      box-shadow: 0 0 0 1px rgba(220, 38, 38, 0.55);
}

#tab-b4c6 .ikra-appointment-root select,
#tab-b4c6 .ikra-appointment-root textarea,
#tab-b4c6 .ikra-appointment-root input[type="text"],
#tab-b4c6 .ikra-appointment-root input[type="email"],
#tab-b4c6 .ikra-appointment-root input[type="tel"],
#tab-b4c6 .ikra-appointment-root input[type="date"] {
width: 100%;
      border-radius: 11px;
      border: 1px solid rgba(209, 213, 219, 0.95);
      padding: 0.55rem 0.7rem;
      font-size: 0.86rem;
      outline: none;
      background: rgba(248, 250, 252, 0.9);
      transition: border-color var(--transition-fast), box-shadow var(--transition-fast), background var(--transition-fast), transform var(--transition-fast);
}

#tab-b4c6 .ikra-appointment-root select:focus-visible,
#tab-b4c6 .ikra-appointment-root textarea:focus-visible,
#tab-b4c6 .ikra-appointment-root input[type="text"]:focus-visible,
#tab-b4c6 .ikra-appointment-root input[type="email"]:focus-visible,
#tab-b4c6 .ikra-appointment-root input[type="tel"]:focus-visible,
#tab-b4c6 .ikra-appointment-root input[type="date"]:focus-visible {
border-color: var(--primary);
      box-shadow: 0 0 0 1px rgba(59, 130, 246, 0.85);
      background: white;
      transform: translateY(-0.5px);
}

#tab-b4c6 .ikra-appointment-root textarea {
resize: vertical;
      min-height: 70px;
      max-height: 140px;
}

#tab-b4c6 .ikra-appointment-root .choice-pill-group {
display: flex;
      flex-wrap: wrap;
      gap: 0.4rem;
}

#tab-b4c6 .ikra-appointment-root .choice-pill {
position: relative;
      display: inline-flex;
      align-items: center;
      justify-content: center;
      padding: 0.35rem 0.7rem;
      border-radius: var(--radius-pill);
      border: 1px solid rgba(209, 213, 219, 0.9);
      background: rgba(255, 255, 255, 0.85);
      font-size: 0.8rem;
      color: var(--text-muted);
      cursor: pointer;
      transition: border-color var(--transition-fast), box-shadow var(--transition-fast), background var(--transition-fast), color var(--transition-fast), transform var(--transition-fast);
}

#tab-b4c6 .ikra-appointment-root .choice-pill input {
position: absolute;
      opacity: 0;
      pointer-events: none;
}

#tab-b4c6 .ikra-appointment-root .choice-pill.is-selected {
border-color: var(--primary);
      background: linear-gradient(135deg, var(--primary-soft), #eff6ff);
      color: var(--primary-strong);
      box-shadow: 0 0 0 1px rgba(59, 130, 246, 0.6);
      transform: translateY(-0.5px);
}

#tab-b4c6 .ikra-appointment-root .choice-pill:hover {
border-color: rgba(148, 163, 184, 0.9);
      transform: translateY(-0.5px);
}

#tab-b4c6 .ikra-appointment-root .time-slot-group {
display: grid;
      grid-template-columns: repeat(auto-fill, minmax(82px, 1fr));
      gap: 0.4rem;
}

#tab-b4c6 .ikra-appointment-root .time-slot {
border-radius: 11px;
      border: 1px solid rgba(209, 213, 219, 0.95);
      background: rgba(255, 255, 255, 0.85);
      padding: 0.35rem 0.2rem;
      font-size: 0.8rem;
      cursor: pointer;
      text-align: center;
      transition: border-color var(--transition-fast), box-shadow var(--transition-fast), background var(--transition-fast), transform var(--transition-fast);
}

#tab-b4c6 .ikra-appointment-root .time-slot[data-selected="true"] {
border-color: var(--primary);
      background: linear-gradient(135deg, var(--primary-soft), #eff6ff);
      box-shadow: 0 0 0 1px rgba(59, 130, 246, 0.7);
      transform: translateY(-0.5px);
      font-weight: 500;
      color: var(--primary-strong);
}

#tab-b4c6 .ikra-appointment-root .time-slot[data-disabled="true"] {
opacity: 0.5;
      cursor: not-allowed;
      text-decoration: line-through;
}

#tab-b4c6 .ikra-appointment-root .time-slot:focus-visible {
outline: 2px solid var(--primary);
      outline-offset: 2px;
}

#tab-b4c6 .ikra-appointment-root .inline-checkbox {
display: inline-flex;
      align-items: center;
      gap: 0.4rem;
      font-size: 0.8rem;
      color: var(--text-muted);
      margin-top: 0.2rem;
}

#tab-b4c6 .ikra-appointment-root .inline-checkbox input {
width: 15px;
      height: 15px;
      border-radius: 4px;
}

#tab-b4c6 .ikra-appointment-root .step-footer {
display: flex;
      justify-content: space-between;
      align-items: center;
      gap: 1rem;
      margin-top: 1.1rem;
      padding-top: 0.9rem;
      border-top: 1px dashed rgba(203, 213, 225, 0.9);
}

#tab-b4c6 .ikra-appointment-root .step-footer-left {
font-size: 0.78rem;
      color: var(--text-muted);
      /* display: flex; */
      flex-direction: column;
      gap: 0.1rem;
}

#tab-b4c6 .ikra-appointment-root .badge-secure {
display: inline-flex;
      align-items: center;
      gap: 0.35rem;
      padding: 0.2rem 0.6rem;
      border-radius: 999px;
      background: rgba(22, 163, 74, 0.08);
      border: 1px solid rgba(22, 163, 74, 0.4);
      font-size: 0.72rem;
      color: #15803d;
}

#tab-b4c6 .ikra-appointment-root .badge-secure-dot {
width: 6px;
      height: 6px;
      border-radius: 999px;
      background: #22c55e;
      box-shadow: 0 0 0 4px rgba(22, 163, 74, 0.35);
}

#tab-b4c6 .ikra-appointment-root .step-footer-buttons {
display: flex;
      gap: 0.5rem;
}

#tab-b4c6 .ikra-appointment-root .btn {
border-radius: 999px;
      border: 1px solid transparent;
      padding: 0.5rem 1rem;
      font-size: 0.86rem;
      font-weight: 500;
      cursor: pointer;
      display: inline-flex;
      align-items: center;
      gap: 0.4rem;
      background: transparent;
      transition: background var(--transition-fast), border-color var(--transition-fast), color var(--transition-fast), box-shadow var(--transition-fast), transform var(--transition-fast);
      white-space: nowrap;
}

#tab-b4c6 .ikra-appointment-root .btn-primary {
background: linear-gradient(120deg, var(--primary), var(--accent));
      color: white;
      box-shadow: 0 12px 25px rgba(37, 99, 235, 0.45);
      border-color: transparent;
}

#tab-b4c6 .ikra-appointment-root .btn-primary:hover {
transform: translateY(-1px);
      box-shadow: 0 16px 32px rgba(37, 99, 235, 0.55);
}

#tab-b4c6 .ikra-appointment-root .btn-primary:active {
transform: translateY(0);
      box-shadow: 0 8px 18px rgba(37, 99, 235, 0.4);
}

#tab-b4c6 .ikra-appointment-root .btn-secondary {
border-color: rgba(148, 163, 184, 0.9);
      background: rgba(248, 250, 252, 0.9);
      color: var(--text-muted);
}

#tab-b4c6 .ikra-appointment-root .btn-secondary:hover:not(:disabled) {
background: white;
      transform: translateY(-0.5px);
}

#tab-b4c6 .ikra-appointment-root .btn-secondary:disabled {
opacity: 0.5;
      cursor: default;
}

#tab-b4c6 .ikra-appointment-root .btn-full-width {
width: 100%;
      justify-content: center;
}

#tab-b4c6 .ikra-appointment-root .booking-summary-panel {
      
background: rgba(15, 23, 42, 0.9);
      color: white;
      border-radius: var(--radius-lg);
      padding: 1.4rem 1.3rem 1.51rem;
      box-shadow: 0 20px 50px rgba(15, 23, 42, 0.75);
      border: 1px solid rgba(148, 163, 184, 0.6);
      position: relative;
      overflow: hidden;
}


#tab-b4c6 .ikra-appointment-root .booking-summary-panel::before {
content: "";
      position: absolute;
      inset: -25%;
      background:
        radial-gradient(circle at top, rgba(96, 165, 250, 0.35), transparent 55%),
        radial-gradient(circle at bottom, rgba(56, 189, 248, 0.3), transparent 60%);
      opacity: 0.9;
      pointer-events: none;
}

#tab-b4c6 .ikra-appointment-root .summary-inner {
position: relative;
      z-index: 1;
}

#tab-b4c6 .ikra-appointment-root .summary-heading {
font-size: 0.95rem;
      font-weight: 600;
      margin: 0 0 0.15rem;
      display: flex;
      align-items: center;
      gap: 0.4rem;
}

#tab-b4c6 .ikra-appointment-root .summary-tagline {
font-size: 0.8rem;
      color: rgba(226, 232, 240, 0.86);
      margin: 0 0 0.9rem;
}

#tab-b4c6 .ikra-appointment-root .summary-badge {
font-size: 0.7rem;
      display: inline-flex;
      align-items: center;
      gap: 0.3rem;
      padding: 0.25rem 0.6rem;
      border-radius: 999px;
      background: rgba(15, 23, 42, 0.65);
      border: 1px solid rgba(148, 163, 184, 0.7);
      margin-bottom: 0.7rem;
}

#tab-b4c6 .ikra-appointment-root .summary-section {
background: rgba(15, 23, 42, 0.72);
      border-radius: 15px;
      padding: 0.7rem 0.75rem;
      border: 1px solid rgba(148, 163, 184, 0.45);
      margin-bottom: 0.55rem;
}

#tab-b4c6 .ikra-appointment-root .summary-section-title {
    font-family: 'Times New Roman', Times, serif;
font-size: 0.78rem;
      text-transform: uppercase;
      letter-spacing: 0.08em;
      color: rgba(191, 219, 254, 0.95);
      margin: 0 0 0.3rem;
}

#tab-b4c6 .ikra-appointment-root .summary-item {
display: flex;
      justify-content: space-between;
      gap: 0.6rem;
      font-size: 0.8rem;
      margin: 0.18rem 0;
      color: rgba(241, 245, 249, 0.95);
}

#tab-b4c6 .ikra-appointment-root .summary-item-label {
opacity: 0.7;
}

#tab-b4c6 .ikra-appointment-root .summary-item-value {
text-align: right;
      font-weight: 500;
}

#tab-b4c6 .ikra-appointment-root .summary-note {
font-size: 0.78rem;
      color: rgba(226, 232, 240, 0.85);
      margin-top: 0.8rem;
}

#tab-b4c6 .ikra-appointment-root .summary-note-strong {
font-weight: 500;
}

#tab-b4c6 .ikra-appointment-root .summary-footer {
margin-top: 0.9rem;
      font-size: 0.75rem;
      color: rgba(203, 213, 225, 0.9);
      display: flex;
      justify-content: space-between;
      gap: 0.7rem;
      flex-wrap: wrap;
}

#tab-b4c6 .ikra-appointment-root .success-state {
max-width: 560px;
      margin: 2rem auto 0;
      background: var(--surface);
      border-radius: var(--radius-lg);
      padding: 1.6rem 1.5rem 1.4rem;
      box-shadow: var(--shadow-soft);
      border: 1px solid rgba(148, 163, 184, 0.45);
      text-align: center;
}

#tab-b4c6 .ikra-appointment-root .success-icon {
width: 48px;
      height: 48px;
      border-radius: 999px;
      margin: 0 auto 0.75rem;
      background: radial-gradient(circle at 25% 0%, #bbf7d0, #22c55e 60%, #16a34a 90%);
      display: flex;
      align-items: center;
      justify-content: center;
      box-shadow: 0 16px 35px rgba(22, 163, 74, 0.5);
      color: white;
      font-size: 1.3rem;
      font-weight: 700;
}

#tab-b4c6 .ikra-appointment-root .success-title {
margin: 0 0 0.3rem;
      font-size: 1.15rem;
      font-weight: 600;
}

#tab-b4c6 .ikra-appointment-root .success-text {
margin: 0 0 0.8rem;
      font-size: 0.86rem;
      color: var(--text-muted);
}

#tab-b4c6 .ikra-appointment-root .success-highlight {
font-size: 0.82rem;
      padding: 0.5rem 0.7rem;
      border-radius: 12px;
      background: rgba(219, 234, 254, 0.85);
      border: 1px solid rgba(129, 140, 248, 0.5);
      color: var(--primary-strong);
      display: inline-flex;
      flex-direction: column;
      gap: 0.1rem;
      margin-bottom: 0.9rem;
}

#tab-b4c6 .ikra-appointment-root .success-mini {
font-size: 0.78rem;
      color: var(--text-muted);
}

#tab-b4c6 .ikra-appointment-root .app-footer {
max-width: 1120px;
      margin: 1.5rem auto 1.2rem;
      padding: 0 1.5rem;
      font-size: 0.75rem;
      color: var(--text-muted);
      display: flex;
      justify-content: space-between;
      gap: 0.5rem;
      flex-wrap: wrap;
}

@media (max-width: 640px) {
  #tab-b4c6 .ikra-appointment-root .app-footer {
padding: 0 1rem;
        font-size: 0.72rem;
  }
}

/* ---------------------------------------------------------
   Nicepage-Schutz: nur innerhalb des Termin-Tabs wirksam
   --------------------------------------------------------- */
#tab-b4c6 .ikra-appointment-root h1.booking-title {
  font-family: 'Times New Roman', Times, serif;
  font-size: 1.25rem !important;
  line-height: 1.25 !important;
  font-weight: 600 !important;
  margin: 0 !important;
  letter-spacing: normal !important;
  text-transform: none !important;
  color: var(--text-main) !important;
}

#tab-b4c6 .ikra-appointment-root h2.summary-section-title {
  font-size: 0.78rem !important;
  line-height: 1.3 !important;
  font-weight: 700 !important;
  letter-spacing: 0.08em !important;
  margin: 0 0 0.3rem !important;
  text-transform: uppercase !important;
  color: rgba(191, 219, 254, 0.95) !important;
}

#tab-b4c6 .ikra-appointment-root .app-shell {
  min-height: auto;
  display: block;
}

#tab-b4c6 .ikra-appointment-root .app-main {
  padding: 0;
  flex: none;
}

#tab-b4c6 .ikra-appointment-root .app-footer {
  display: none;
}

/* ---------------------------------------------------------
   E-Mail-Verifizierung im letzten Schritt
   --------------------------------------------------------- */
#tab-b4c6 .ikra-appointment-root .verification-box {
  margin: 0.2rem 0 0.95rem;
  padding: 0.85rem 0.9rem;
  border: 1px solid rgba(148, 163, 184, 0.45);
  border-radius: 16px;
  background: rgba(248, 250, 252, 0.88);
}

#tab-b4c6 .ikra-appointment-root .verification-box-header {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 1rem;
  margin-bottom: 0.75rem;
}

#tab-b4c6 .ikra-appointment-root .verification-box-header strong {
  display: block;
  font-size: 0.9rem;
  font-weight: 700;
  color: var(--text-main);
}

#tab-b4c6 .ikra-appointment-root .verification-badge {
  flex: 0 0 auto;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0.25rem 0.6rem;
  border-radius: 999px;
  border: 1px solid rgba(148, 163, 184, 0.65);
  background: rgba(255, 255, 255, 0.88);
  color: var(--text-muted);
  font-size: 0.72rem;
  font-weight: 600;
  white-space: nowrap;
}

#tab-b4c6 .ikra-appointment-root .verification-badge.is-success {
  border-color: rgba(22, 163, 74, 0.45);
  background: rgba(22, 163, 74, 0.08);
  color: #15803d;
}

#tab-b4c6 .ikra-appointment-root .verification-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem;
  margin-bottom: 0.55rem;
}

#tab-b4c6 .ikra-appointment-root .verification-code-row {
  display: grid;
  grid-template-columns: minmax(160px, 1fr) auto;
  gap: 0.75rem;
  align-items: end;
  margin-top: 0.65rem;
}

#tab-b4c6 .ikra-appointment-root .verification-code-row[hidden] {
  display: none !important;
}

#tab-b4c6 .ikra-appointment-root .verification-code-field {
  margin-bottom: 0;
}

#tab-b4c6 .ikra-appointment-root .verification-status {
  margin: 0.55rem 0 0;
  font-size: 0.76rem;
  line-height: 1.45;
}

#tab-b4c6 .ikra-appointment-root .verification-status.is-info {
  color: var(--text-muted);
}

#tab-b4c6 .ikra-appointment-root .verification-status.is-success {
  color: #15803d;
}

#tab-b4c6 .ikra-appointment-root .verification-status.is-error {
  color: var(--danger);
}

#tab-b4c6 .ikra-appointment-root .btn-small {
  padding: 0.45rem 0.85rem;
  font-size: 0.8rem;
}

#tab-b4c6 .ikra-appointment-root .btn:disabled,
#tab-b4c6 .ikra-appointment-root .btn[aria-disabled="true"] {
  opacity: 0.52;
  cursor: not-allowed;
  transform: none !important;
  box-shadow: none !important;
}

@media (max-width: 640px) {
  #tab-b4c6 .ikra-appointment-root .verification-box-header {
    flex-direction: column;
    align-items: flex-start;
  }

  #tab-b4c6 .ikra-appointment-root .verification-code-row {
    grid-template-columns: 1fr;
  }

  #tab-b4c6 .ikra-appointment-root .verification-code-row .btn {
    width: 100%;
    justify-content: center;
  }
}


/* ---------------------------------------------------------
   Arzt-Auswahl per Auswahlfeld + große Bildvorschau
   --------------------------------------------------------- */
#tab-b4c6 .ikra-appointment-root .doctor-choice-field {
  margin-top: 0.15rem;
  margin-bottom: 1rem;
}

#tab-b4c6 .ikra-appointment-root .doctor-preview {
  display: flex;
  align-items: center;
  gap: 1rem;
  margin-top: 0.75rem;
  padding: 0.85rem;
  border: 1px solid rgba(148, 163, 184, 0.45);
  border-radius: 18px;
  background: rgba(255, 255, 255, 0.78);
}

#tab-b4c6 .ikra-appointment-root .doctor-preview[hidden] {
  display: none !important;
}

#tab-b4c6 .ikra-appointment-root .doctor-preview-photo {
  position: relative;
  flex: 0 0 110px;
  width: 110px;
  height: 110px;
  border-radius: 24px;
  overflow: hidden;
  background: linear-gradient(135deg, #dbeafe, #eff6ff);
  border: 1px solid rgba(148, 163, 184, 0.55);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  box-shadow: 0 12px 28px rgba(15, 23, 42, 0.12);
}

#tab-b4c6 .ikra-appointment-root .doctor-preview-photo img {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
}

#tab-b4c6 .ikra-appointment-root .doctor-preview-initials {
  font-size: 1.25rem;
  font-weight: 700;
  color: var(--primary-strong);
}

#tab-b4c6 .ikra-appointment-root .doctor-preview-body {
  min-width: 0;
  display: flex;
  flex-direction: column;
  gap: 0.22rem;
}

#tab-b4c6 .ikra-appointment-root .doctor-preview-name {
  font-size: 1rem;
  line-height: 1.25;
  font-weight: 700;
  color: var(--text-main);
}

#tab-b4c6 .ikra-appointment-root .doctor-preview-specialty {
  font-size: 0.86rem;
  line-height: 1.35;
  color: var(--text-muted);
}

@media (max-width: 640px) {
  #tab-b4c6 .ikra-appointment-root .doctor-preview {
    align-items: flex-start;
  }

  #tab-b4c6 .ikra-appointment-root .doctor-preview-photo {
    flex-basis: 86px;
    width: 86px;
    height: 86px;
    border-radius: 20px;
  }
}




/* ---------------------------------------------------------
   Erfolgsmodus nach verbindlicher Terminanfrage
   Wichtig: bewusst mit #tab-b4c6 gescoped, damit Nicepage/Praxis-Styles
   und die bestehenden Termin-Regeln sicher überstimmt werden.
   --------------------------------------------------------- */
#tab-b4c6 .ikra-appointment-root .booking-view[hidden],
#tab-b4c6 .ikra-appointment-root .success-state[hidden] {
  display: none !important;
}

#tab-b4c6 .ikra-appointment-root.is-success-mode {
  max-width: 1120px;
  min-height: 520px;
  display: flex;
  align-items: center;
  justify-content: center;
  padding-top: 24px;
  padding-bottom: 40px;
}

#tab-b4c6 .ikra-appointment-root.is-success-mode .app-shell {
  width: 100%;
  min-height: auto;
  display: flex;
  justify-content: center;
}

#tab-b4c6 .ikra-appointment-root.is-success-mode .app-main {
  width: 100%;
  padding: 0 1.5rem;
  display: flex;
  justify-content: center;
}

#tab-b4c6 .ikra-appointment-root.is-success-mode .success-state {
  width: 100%;
  max-width: 720px;
  margin: 0 auto;
  text-align: center;
}

#tab-b4c6 .ikra-appointment-root.is-success-mode .success-highlight {
  text-align: left;
}

@media (max-width: 767px) {
  #tab-b4c6 .ikra-appointment-root.is-success-mode {
    min-height: 420px;
    align-items: flex-start;
    padding-top: 24px;
  }

  #tab-b4c6 .ikra-appointment-root.is-success-mode .app-main {
    padding: 0 1rem;
  }
}



/* ---------------------------------------------------------
   Responsive-Korrektur Terminbuchung:
   verhindert ovale Step-Zahlen und unschöne SSL/TLS-Darstellung
   --------------------------------------------------------- */

/* Step-Zahlen dürfen niemals zusammengedrückt werden */
#tab-b4c6 .ikra-appointment-root .stepper-index {
  flex: 0 0 22px;
  min-width: 22px;
  width: 22px;
  height: 22px;
  aspect-ratio: 1 / 1;
  line-height: 1;
}

/* Stepper bei schmalem Terminbereich sauber halten */
@media (max-width: 720px) {
  #tab-b4c6 .ikra-appointment-root .stepper {
    gap: 0.45rem;
    padding: 0.5rem;
  }

  #tab-b4c6 .ikra-appointment-root .stepper-item {
    gap: 0.4rem;
  }

  #tab-b4c6 .ikra-appointment-root .stepper-label-main {
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
  }

  #tab-b4c6 .ikra-appointment-root .stepper-item::after {
    right: -0.32rem;
    width: 0.25rem;
  }
}

/* Footer: SSL/TLS-Badge nicht zusammendrücken */
#tab-b4c6 .ikra-appointment-root .badge-secure {
  white-space: nowrap;
  flex: 0 0 auto;
}

/* Bei enger Breite Footer sauber untereinander statt gequetscht */
@media (max-width: 720px) {
  #tab-b4c6 .ikra-appointment-root .step-footer {
    flex-direction: column;
    align-items: stretch;
    gap: 0.75rem;
  }

  #tab-b4c6 .ikra-appointment-root .step-footer-left {
    align-items: flex-start;
  }

  #tab-b4c6 .ikra-appointment-root .badge-secure {
    padding: 0.28rem 0.65rem;
    font-size: 0.72rem;
  }

  #tab-b4c6 .ikra-appointment-root .step-footer-buttons {
    width: 100%;
    justify-content: flex-end;
    flex-wrap: wrap;
  }
}

/* Sehr schmal: Buttons dürfen umbrechen, aber bleiben sauber */
@media (max-width: 520px) {
  #tab-b4c6 .ikra-appointment-root .step-footer-buttons {
    justify-content: stretch;
  }

  #tab-b4c6 .ikra-appointment-root .step-footer-buttons .btn {
    flex: 1 1 auto;
    justify-content: center;
  }
}

/* =========================================================
   Best-Practice Responsive-Fix für den Termin-Tab
   Stand: 2026-05-17
   Ziel:
   - vollständig auf #tab-b4c6 / .ikra-appointment-root beschränkt
   - keine Überschneidungen bei kleinen, mittleren und großen Viewports
   - Nicepage-Container im Termin-Tab neutralisieren, ohne andere Tabs zu ändern
   ========================================================= */

/* Nicepage-Wrapper im Termin-Tab darf keine eigene Breite/Überläufe erzwingen */
#tab-b4c6,
#tab-b4c6 .u-container-layout-23,
#tab-b4c6 .u-custom-html-5 {
  width: 100% !important;
  max-width: 100% !important;
  min-width: 0 !important;
  overflow: visible !important;
}

#tab-b4c6 .u-container-layout-23 {
  padding-left: 0 !important;
  padding-right: 0 !important;
}

/* Termin-App: saubere Innenabstände, kein horizontales Überlaufen */
#tab-b4c6 .ikra-appointment-root {
  width: min(100%, 1120px);
  max-width: 100%;
  min-width: 0;
  padding: clamp(18px, 2.4vw, 28px) clamp(10px, 1.8vw, 20px) clamp(30px, 4vw, 44px);
  overflow-x: clip;
}

#tab-b4c6 .ikra-appointment-root,
#tab-b4c6 .ikra-appointment-root * {
  min-width: 0;
}

#tab-b4c6 .ikra-appointment-root .booking-title + br {
  display: none;
}

/* Desktop: zwei harmonische Spalten, Zusammenfassung bleibt kompakt */
#tab-b4c6 .ikra-appointment-root .booking-view {
  width: 100%;
  max-width: 1120px;
  grid-template-columns: minmax(0, 1.62fr) minmax(300px, 0.98fr);
  gap: clamp(1rem, 2.2vw, 2rem);
}

#tab-b4c6 .ikra-appointment-root .booking-shell,
#tab-b4c6 .ikra-appointment-root .booking-summary-panel {
  width: 100%;
  max-width: 100%;
}

#tab-b4c6 .ikra-appointment-root .booking-shell {
  box-shadow: 0 18px 42px rgba(15, 23, 42, 0.28);
}

#tab-b4c6 .ikra-appointment-root .booking-summary-panel {
  box-shadow: 0 18px 42px rgba(15, 23, 42, 0.36);
}

#tab-b4c6 .ikra-appointment-root .summary-badge,
#tab-b4c6 .ikra-appointment-root .summary-item,
#tab-b4c6 .ikra-appointment-root .summary-note,
#tab-b4c6 .ikra-appointment-root .summary-footer,
#tab-b4c6 .ikra-appointment-root .field-help,
#tab-b4c6 .ikra-appointment-root .field-error {
  overflow-wrap: anywhere;
  word-break: normal;
}

#tab-b4c6 .ikra-appointment-root .summary-item-label,
#tab-b4c6 .ikra-appointment-root .summary-item-value {
  min-width: 0;
}

#tab-b4c6 .ikra-appointment-root .summary-item-value {
  overflow-wrap: anywhere;
}

/* Eingaben und Buttons dürfen nie aus der Karte laufen */
#tab-b4c6 .ikra-appointment-root select,
#tab-b4c6 .ikra-appointment-root textarea,
#tab-b4c6 .ikra-appointment-root input[type="text"],
#tab-b4c6 .ikra-appointment-root input[type="email"],
#tab-b4c6 .ikra-appointment-root input[type="tel"],
#tab-b4c6 .ikra-appointment-root input[type="date"],
#tab-b4c6 .ikra-appointment-root .btn,
#tab-b4c6 .ikra-appointment-root .time-slot,
#tab-b4c6 .ikra-appointment-root .choice-pill {
  max-width: 100%;
}

#tab-b4c6 .ikra-appointment-root .btn {
  justify-content: center;
  text-align: center;
}

/* Tablet: Formular und Zusammenfassung untereinander */
@media (max-width: 960px) {
  #tab-b4c6 .ikra-appointment-root .booking-shell,
  #tab-b4c6 .ikra-appointment-root .booking-summary-panel {
    border-radius: 16px;
  }

  #tab-b4c6 .ikra-appointment-root .booking-shell {
    padding: 1.15rem;
  }

  #tab-b4c6 .ikra-appointment-root .booking-title {
    font-size: 1.12rem !important;
    line-height: 1.25 !important;
    margin-bottom: 0.8rem !important;
  }

  #tab-b4c6 .ikra-appointment-root .stepper {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 0.55rem;
    padding: 0.6rem;
  }

  #tab-b4c6 .ikra-appointment-root .stepper-item {
    flex-direction: column;
    align-items: center;
    justify-content: flex-start;
    gap: 0.25rem;
    text-align: center;
  }

  #tab-b4c6 .ikra-appointment-root .stepper-item::after {
    display: none;
  }

  #tab-b4c6 .ikra-appointment-root .stepper-index {
    flex: 0 0 24px;
    width: 24px;
    min-width: 24px;
    height: 24px;
  }

  #tab-b4c6 .ikra-appointment-root .stepper-label-main {
    width: 100%;
    font-size: 0.68rem;
    line-height: 1.16;
    white-space: normal;
    overflow: visible;
    text-overflow: clip;
    overflow-wrap: anywhere;
  }

  #tab-b4c6 .ikra-appointment-root .form-field label,
  #tab-b4c6 .ikra-appointment-root .field-label {
    flex-wrap: wrap;
    line-height: 1.3;
  }

  #tab-b4c6 .ikra-appointment-root .steps-container {
    min-height: auto;
  }

  #tab-b4c6 .ikra-appointment-root .step-footer {
    flex-direction: column;
    align-items: stretch;
  }

  #tab-b4c6 .ikra-appointment-root .step-footer-buttons {
    width: 100%;
    justify-content: flex-end;
    flex-wrap: wrap;
  }
}

/* Kleine Tablets / große Smartphones */
@media (max-width: 720px) {
  #tab-b4c6 .ikra-appointment-root .booking-shell,
  #tab-b4c6 .ikra-appointment-root .booking-summary-panel {
    border-radius: 16px;
  }

  #tab-b4c6 .ikra-appointment-root .booking-shell {
    padding: 1.15rem;
  }

  #tab-b4c6 .ikra-appointment-root .booking-title {
    font-size: 1.12rem !important;
    line-height: 1.25 !important;
    margin-bottom: 0.8rem !important;
  }

  #tab-b4c6 .ikra-appointment-root .stepper {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 0.55rem;
    padding: 0.6rem;
  }

  #tab-b4c6 .ikra-appointment-root .stepper-item {
    flex-direction: column;
    align-items: center;
    justify-content: flex-start;
    gap: 0.25rem;
    text-align: center;
  }

  #tab-b4c6 .ikra-appointment-root .stepper-item::after {
    display: none;
  }

  #tab-b4c6 .ikra-appointment-root .stepper-index {
    flex: 0 0 24px;
    width: 24px;
    min-width: 24px;
    height: 24px;
  }

  #tab-b4c6 .ikra-appointment-root .stepper-label-main {
    width: 100%;
    font-size: 0.68rem;
    line-height: 1.16;
    white-space: normal;
    overflow: visible;
    text-overflow: clip;
    overflow-wrap: anywhere;
  }

  #tab-b4c6 .ikra-appointment-root .form-field label,
  #tab-b4c6 .ikra-appointment-root .field-label {
    flex-wrap: wrap;
    line-height: 1.3;
  }

  #tab-b4c6 .ikra-appointment-root .steps-container {
    min-height: auto;
  }

  #tab-b4c6 .ikra-appointment-root .step-footer {
    flex-direction: column;
    align-items: stretch;
  }

  #tab-b4c6 .ikra-appointment-root .step-footer-buttons {
    width: 100%;
    justify-content: flex-end;
    flex-wrap: wrap;
  }
}

/* Smartphones */
@media (max-width: 560px) {
 #tab-b4c6 .ikra-appointment-root .booking-shell,
  #tab-b4c6 .ikra-appointment-root .booking-summary-panel {
    border-radius: 16px;
  }

  #tab-b4c6 .ikra-appointment-root .booking-shell {
    padding: 1.15rem;
  }

  #tab-b4c6 .ikra-appointment-root .booking-title {
    font-size: 1.12rem !important;
    line-height: 1.25 !important;
    margin-bottom: 0.8rem !important;
  }

  #tab-b4c6 .ikra-appointment-root .stepper {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 0.55rem;
    padding: 0.6rem;
  }

  #tab-b4c6 .ikra-appointment-root .stepper-item {
    flex-direction: column;
    align-items: center;
    justify-content: flex-start;
    gap: 0.25rem;
    text-align: center;
  }

  #tab-b4c6 .ikra-appointment-root .stepper-item::after {
    display: none;
  }

  #tab-b4c6 .ikra-appointment-root .stepper-index {
    flex: 0 0 24px;
    width: 24px;
    min-width: 24px;
    height: 24px;
  }

  #tab-b4c6 .ikra-appointment-root .stepper-label-main {
    width: 100%;
    font-size: 0.68rem;
    line-height: 1.16;
    white-space: normal;
    overflow: visible;
    text-overflow: clip;
    overflow-wrap: anywhere;
  }

  #tab-b4c6 .ikra-appointment-root .form-field label,
  #tab-b4c6 .ikra-appointment-root .field-label {
    flex-wrap: wrap;
    line-height: 1.3;
  }

  #tab-b4c6 .ikra-appointment-root .steps-container {
    min-height: auto;
  }

  #tab-b4c6 .ikra-appointment-root .step-footer {
    flex-direction: column;
    align-items: stretch;
  }

  #tab-b4c6 .ikra-appointment-root .step-footer-buttons {
    width: 100%;
    justify-content: flex-end;
    flex-wrap: wrap;
  }
}

/* Sehr schmale Geräte: kein Quetschen, Buttons sauber untereinander */
@media (max-width: 420px) {
  #tab-b4c6 .ikra-appointment-root {
    padding-left: 4px;
    padding-right: 4px;
  }

  #tab-b4c6 .ikra-appointment-root .booking-shell,
  #tab-b4c6 .ikra-appointment-root .booking-summary-panel {
    border-radius: 14px;
    padding: 0.85rem;
  }

  #tab-b4c6 .ikra-appointment-root .stepper {
    gap: 0.35rem;
    padding: 0.5rem 0.4rem;
  }

  #tab-b4c6 .ikra-appointment-root .stepper-label-main {
    font-size: 0.62rem;
  }

  #tab-b4c6 .ikra-appointment-root .doctor-preview {
    flex-direction: column;
    align-items: flex-start;
  }

  #tab-b4c6 .ikra-appointment-root .doctor-preview-photo {
    flex: 0 0 82px;
    width: 82px;
    height: 82px;
  }

  #tab-b4c6 .ikra-appointment-root .verification-code-row {
    grid-template-columns: 1fr;
  }

  #tab-b4c6 .ikra-appointment-root .verification-code-row .btn,
  #tab-b4c6 .ikra-appointment-root .step-footer-buttons .btn {
    width: 100%;
  }

  #tab-b4c6 .ikra-appointment-root .step-footer-buttons {
    flex-direction: column;
  }

  #tab-b4c6 .ikra-appointment-root .badge-secure {
    width: 100%;
    justify-content: center;
    white-space: normal;
    text-align: center;
  }
}

/* Extra Schutz für extrem schmale WebViews */
@media (max-width: 340px) {
  #tab-b4c6 .ikra-appointment-root .stepper-label-main {
    display: none;
  }

  #tab-b4c6 .ikra-appointment-root .stepper {
    align-items: center;
  }

  #tab-b4c6 .ikra-appointment-root .time-slot-group {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

/* Bewegungen reduzieren, wenn Nutzer dies im System aktiviert haben */
@media (prefers-reduced-motion: reduce) {
  #tab-b4c6 .ikra-appointment-root *,
  #tab-b4c6 .ikra-appointment-root *::before,
  #tab-b4c6 .ikra-appointment-root *::after {
    transition-duration: 0.01ms !important;
    animation-duration: 0.01ms !important;
    scroll-behavior: auto !important;
  }
}

/* =========================================================
   ikraMed Termin-Tab: Optimierung unter 990px
   Bitte GANZ UNTEN in /css/appointment.css einfügen.
   Ziel: Bei mittleren Breiten nicht mehr zwei gequetschte Spalten,
   sondern eine ruhige, zentrierte Tablet-Ansicht wie bei 100%.
   ========================================================= */

@media (max-width: 990px) {
  #tab-b4c6 .ikra-appointment-root {
    width: 100% !important;
    max-width: 100% !important;
    padding-left: clamp(12px, 2.4vw, 22px) !important;
    padding-right: clamp(12px, 2.4vw, 22px) !important;
    overflow-x: hidden !important;
  }

  #tab-b4c6 .ikra-appointment-root .booking-view {
    display: grid !important;
    grid-template-columns: minmax(0, 1fr) !important;
    gap: 1.15rem !important;
    width: 100% !important;
    max-width: 780px !important;
    margin-left: auto !important;
    margin-right: auto !important;
  }

  #tab-b4c6 .ikra-appointment-root .booking-shell,
  #tab-b4c6 .ikra-appointment-root .booking-summary-panel {
    width: 100% !important;
    max-width: 780px !important;
    margin-left: auto !important;
    margin-right: auto !important;
  }

  #tab-b4c6 .ikra-appointment-root .booking-summary-panel {
    order: 2 !important;
  }

  #tab-b4c6 .ikra-appointment-root .booking-title {
    max-width: 100% !important;
    margin-bottom: 0.85rem !important;
  }

  #tab-b4c6 .ikra-appointment-root .booking-title + br {
    display: none !important;
  }

  #tab-b4c6 .ikra-appointment-root .stepper {
    width: 100% !important;
    margin-bottom: 1.05rem !important;
  }

  #tab-b4c6 .ikra-appointment-root .stepper-item {
    min-width: 0 !important;
  }

  #tab-b4c6 .ikra-appointment-root .stepper-index {
    flex: 0 0 24px !important;
    width: 24px !important;
    min-width: 24px !important;
    height: 24px !important;
  }

  #tab-b4c6 .ikra-appointment-root .stepper-label-main {
    min-width: 0 !important;
    max-width: 100% !important;
    white-space: normal !important;
    line-height: 1.18 !important;
    overflow-wrap: anywhere !important;
  }

  #tab-b4c6 .ikra-appointment-root .form-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    gap: 0.85rem 1rem !important;
  }

  #tab-b4c6 .ikra-appointment-root select,
  #tab-b4c6 .ikra-appointment-root textarea,
  #tab-b4c6 .ikra-appointment-root input[type="text"],
  #tab-b4c6 .ikra-appointment-root input[type="email"],
  #tab-b4c6 .ikra-appointment-root input[type="tel"],
  #tab-b4c6 .ikra-appointment-root input[type="date"] {
    max-width: 100% !important;
  }

  #tab-b4c6 .ikra-appointment-root .summary-section {
    padding: 0.78rem 0.85rem !important;
  }

  #tab-b4c6 .ikra-appointment-root .summary-item {
    display: grid !important;
    grid-template-columns: minmax(110px, 0.9fr) minmax(0, 1.3fr) !important;
    align-items: start !important;
    gap: 0.65rem !important;
  }

  #tab-b4c6 .ikra-appointment-root .summary-item-value {
    text-align: right !important;
    min-width: 0 !important;
    overflow-wrap: anywhere !important;
  }
}

/* Zwischen Tablet und Smartphone: Formular wird einspaltig,
   damit Standort/Terminart und lange Labels nicht mehr gequetscht wirken. */
@media (max-width: 780px) {
  #tab-b4c6 .ikra-appointment-root .booking-view,
  #tab-b4c6 .ikra-appointment-root .booking-shell,
  #tab-b4c6 .ikra-appointment-root .booking-summary-panel {
    max-width: 680px !important;
  }

  #tab-b4c6 .ikra-appointment-root .form-grid {
    grid-template-columns: minmax(0, 1fr) !important;
  }
}

/* Ab hier nutzt die bestehende mobile Logik weiter,
   aber die Zusammenfassung bleibt zusätzlich sauber lesbar. */
@media (max-width: 560px) {
  #tab-b4c6 .ikra-appointment-root .summary-item {
    display: flex !important;
    flex-direction: column !important;
    align-items: flex-start !important;
    gap: 0.08rem !important;
  }

  #tab-b4c6 .ikra-appointment-root .summary-item-value {
    text-align: left !important;
  }
}

/* =========================================================
   ikraMed Termin-Tab: Button-Fix 521px bis 575px
   Stand: 2026-05-17
   Ziel:
   - hidden-Buttons bleiben wirklich unsichtbar
   - keine dritte Button-Zeile zwischen 521px und 575px
   - lange CTA "Terminanfrage senden" bricht sauber um
   - vollständig auf den Termin-Tab beschränkt
   ========================================================= */

/* HTML-hidden darf nicht durch .btn { display:inline-flex } überschrieben werden. */
#tab-b4c6 .ikra-appointment-root [hidden],
#tab-b4c6 .ikra-appointment-root button[hidden],
#tab-b4c6 .ikra-appointment-root .btn[hidden] {
  display: none !important;
}

/* Mittlere Smartphone-Breite: Zurück/Weiter bleiben harmonisch nebeneinander. */
@media (min-width: 521px) and (max-width: 575px) {
  #tab-b4c6 .ikra-appointment-root .step-footer {
    flex-direction: column !important;
    align-items: stretch !important;
    gap: 0.75rem !important;
  }

  #tab-b4c6 .ikra-appointment-root .step-footer-left {
    width: 100% !important;
    align-items: flex-start !important;
  }

  #tab-b4c6 .ikra-appointment-root .step-footer-buttons {
    width: 100% !important;
    display: grid !important;
    grid-template-columns: minmax(0, 1fr) minmax(0, 1fr) !important;
    gap: 0.6rem !important;
    align-items: stretch !important;
  }

  #tab-b4c6 .ikra-appointment-root .step-footer-buttons .btn {
    width: 100% !important;
    min-width: 0 !important;
    /* min-height: 44px !important; */
    padding: 0.55rem 0.75rem !important;
    justify-content: center !important;
    text-align: center !important;
    white-space: nowrap !important;
  }

  #tab-b4c6 .ikra-appointment-root .badge-secure {
    width: fit-content !important;
    max-width: 100% !important;
  }
}

/* Wenn im letzten Schritt der lange Senden-Button aktiv ist:
   Auf 521px-575px lieber klare, volle Breite statt gequetschter CTA. */
@media (min-width: 521px) and (max-width: 575px) {
  #tab-b4c6 .ikra-appointment-root .step-footer-buttons:has(#submit-btn:not([hidden])) {
    grid-template-columns: minmax(0, 1fr) !important;
  }

  #tab-b4c6 .ikra-appointment-root .step-footer-buttons:has(#submit-btn:not([hidden])) .btn:not([hidden]) {
    width: 100% !important;
  }
}

/* Fallback für Browser ohne :has(): Der lange CTA darf nie seitlich herauslaufen. */
@media (min-width: 521px) and (max-width: 575px) {
  #tab-b4c6 .ikra-appointment-root #submit-btn:not([hidden]) {
    grid-column: 1 / -1 !important;
    width: 100% !important;
    white-space: normal !important;
    line-height: 1.25 !important;
  }
}

/* =========================================================
   ikraMed Terminbuchung: Kalenderlink + QR-Code nach Erfolg
   ========================================================= */

#tab-b4c6 .ikra-appointment-root .calendar-add-card {
  width: 100%;
  margin: 0.95rem auto 1rem;
  padding: 1rem;
  border-radius: 20px;
  background:
    radial-gradient(circle at top left, rgba(219, 234, 254, 0.95), rgba(255, 255, 255, 0.96) 46%),
    #ffffff;
  border: 1px solid rgba(129, 140, 248, 0.38);
  box-shadow: 0 18px 45px rgba(15, 23, 42, 0.10);
  display: grid;
  grid-template-columns: minmax(0, 1.15fr) minmax(210px, 0.85fr);
  gap: 1rem;
  align-items: center;
  text-align: left;
}

#tab-b4c6 .ikra-appointment-root .calendar-add-card[hidden] {
  display: none !important;
}

#tab-b4c6 .ikra-appointment-root .calendar-add-eyebrow {
  display: inline-flex;
  width: fit-content;
  margin-bottom: 0.35rem;
  padding: 0.22rem 0.62rem;
  border-radius: 999px;
  background: rgba(37, 99, 235, 0.09);
  border: 1px solid rgba(37, 99, 235, 0.25);
  color: var(--primary-strong);
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.04em;
  text-transform: uppercase;
}

#tab-b4c6 .ikra-appointment-root .calendar-add-title {
  margin: 0 0 0.3rem;
  color: var(--text-main);
  font-size: 1.05rem;
  line-height: 1.25;
  font-weight: 700;
}

#tab-b4c6 .ikra-appointment-root .calendar-add-text,
#tab-b4c6 .ikra-appointment-root .calendar-qr-hint {
  margin: 0;
  color: var(--text-muted);
  font-size: 0.82rem;
  line-height: 1.45;
}

#tab-b4c6 .ikra-appointment-root .calendar-add-actions {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0.75rem;
}

#tab-b4c6 .ikra-appointment-root .calendar-add-link {
  display: none !important; /* Desktop: Button ist nicht relevant, QR-Code scannen */
  text-decoration: none;
  text-align: center;
  justify-content: center;
}

#tab-b4c6 .ikra-appointment-root .calendar-qr-frame {
  width: 256px;
  min-height: 256px;
  padding: 16px;              /* wichtige Quiet-Zone für Smartphone-Kameras */
  border-radius: 22px;        /* nur der Rahmen ist rund, nicht der QR-Code selbst */
  background: #ffffff;
  border: 1px solid rgba(203, 213, 225, 0.95);
  box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.9), 0 14px 30px rgba(15, 23, 42, 0.10);
  display: flex;
  align-items: center;
  justify-content: center;
}

#tab-b4c6 .ikra-appointment-root .calendar-qr-code {
  width: 220px;
  height: 220px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: #ffffff;
}

#tab-b4c6 .ikra-appointment-root .calendar-qr-code canvas,
#tab-b4c6 .ikra-appointment-root .calendar-qr-code img,
#tab-b4c6 .ikra-appointment-root .calendar-qr-code table {
  width: 220px !important;
  height: 220px !important;
  display: block;
  border-radius: 0 !important; /* verhindert abgeschnittene / verdeckte QR-Augen */
  background: #ffffff !important;
}

#tab-b4c6 .ikra-appointment-root .calendar-qr-fallback {
  color: var(--primary-strong);
  font-size: 0.8rem;
  text-align: center;
  text-decoration: underline;
}

#tab-b4c6 .ikra-appointment-root .calendar-qr-hint {
  max-width: 280px;
  text-align: center;
  font-size: 0.76rem;
}

@media (max-width: 760px) {
  #tab-b4c6 .ikra-appointment-root .calendar-add-card {
    grid-template-columns: minmax(0, 1fr);
    text-align: center;
    padding: 0.95rem;
  }

  #tab-b4c6 .ikra-appointment-root .calendar-add-eyebrow {
    margin-left: auto;
    margin-right: auto;
  }

  #tab-b4c6 .ikra-appointment-root .calendar-add-text {
    max-width: 34rem;
    margin-left: auto;
    margin-right: auto;
  }

  #tab-b4c6 .ikra-appointment-root .calendar-add-link {
    display: inline-flex !important;
  }

  #tab-b4c6 .ikra-appointment-root .calendar-qr-frame {
    width: 244px;
    min-height: 244px;
    padding: 12px;
  }

  #tab-b4c6 .ikra-appointment-root .calendar-qr-code,
  #tab-b4c6 .ikra-appointment-root .calendar-qr-code canvas,
  #tab-b4c6 .ikra-appointment-root .calendar-qr-code img,
  #tab-b4c6 .ikra-appointment-root .calendar-qr-code table {
    width: 214px !important;
    height: 214px !important;
  }
}

@media (max-width: 420px) {
  #tab-b4c6 .ikra-appointment-root .calendar-add-card {
    border-radius: 16px;
  }

  #tab-b4c6 .ikra-appointment-root .calendar-qr-frame {
    width: 232px;
    min-height: 232px;
    padding: 10px;
    border-radius: 18px;
  }

  #tab-b4c6 .ikra-appointment-root .calendar-qr-code,
  #tab-b4c6 .ikra-appointment-root .calendar-qr-code canvas,
  #tab-b4c6 .ikra-appointment-root .calendar-qr-code img,
  #tab-b4c6 .ikra-appointment-root .calendar-qr-code table {
    width: 206px !important;
    height: 206px !important;
  }
}


/* =========================================================
   iPhone / Mobile-Fix Termin Schritt 2
   Datum, Zeitfenster und Uhrzeit-Buttons
   Nur Termin-Tab, keine Auswirkung auf andere Bereiche
   ========================================================= */

/* iOS verhindert Zoom/unsaubere Darstellung bei Formularfeldern */
@media (max-width: 990px) {
  #tab-b4c6 .ikra-appointment-root select,
  #tab-b4c6 .ikra-appointment-root textarea,
  #tab-b4c6 .ikra-appointment-root input[type="text"],
  #tab-b4c6 .ikra-appointment-root input[type="email"],
  #tab-b4c6 .ikra-appointment-root input[type="tel"],
  #tab-b4c6 .ikra-appointment-root input[type="date"] {
    font-size: 16px !important;
  }

  /* Schritt 2: Datum und Zeitfenster nicht nebeneinander quetschen */
  #tab-b4c6 .ikra-appointment-root fieldset[data-step="1"] > .form-grid {
    grid-template-columns: minmax(0, 1fr) !important;
    gap: 0.8rem !important;
    margin-bottom: 1rem !important;
  }

  /* iPhone Date-Feld sauber und mittig darstellen */
  #tab-b4c6 .ikra-appointment-root fieldset[data-step="1"] input[type="date"] {
    min-height: 52px !important;
    height: 52px !important;
    line-height: 52px !important;
    padding: 0 0.85rem !important;
    text-align: center !important;
    border-radius: 14px !important;
    -webkit-appearance: none;
    appearance: none;
  }

  #tab-b4c6 .ikra-appointment-root fieldset[data-step="1"] input[type="date"]::-webkit-date-and-time-value {
    text-align: center;
    min-height: 1.4em;
  }

  /* Vormittag / Nachmittag gleichmäßig und touchfreundlich */
  #tab-b4c6 .ikra-appointment-root fieldset[data-step="1"] .choice-pill-group {
    display: grid !important;
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    gap: 0.55rem !important;
    width: 100%;
  }

  #tab-b4c6 .ikra-appointment-root fieldset[data-step="1"] .choice-pill {
    width: 100% !important;
    /* min-height: 44px !important; */
    padding: 0.55rem 0.75rem !important;
    font-size: 0.95rem !important;
    text-align: center !important;
  }

  /* Uhrzeit-Buttons grundsätzlich angenehmer */
  #tab-b4c6 .ikra-appointment-root fieldset[data-step="1"] .time-slot {
    min-height: 44px !important;
    padding: 0.55rem 0.35rem !important;
    font-size: 0.95rem !important;
  }
}

/* iPhone Querformat: nicht 6–7 Buttons nebeneinander */
@media (max-width: 990px) and (orientation: landscape) {
  #tab-b4c6 .ikra-appointment-root fieldset[data-step="1"] .time-slot-group {
    grid-template-columns: repeat(4, minmax(0, 1fr)) !important;
    gap: 0.5rem !important;
  }

  #tab-b4c6 .ikra-appointment-root .booking-shell {
    padding: 1rem !important;
  }

  #tab-b4c6 .ikra-appointment-root .stepper {
    margin-bottom: 0.85rem !important;
  }

  #tab-b4c6 .ikra-appointment-root .step-intro {
    margin-bottom: 0.75rem !important;
  }
}

/* iPhone Hochformat: schöne 3er-Reihe */
@media (max-width: 720px) {
  #tab-b4c6 .ikra-appointment-root fieldset[data-step="1"] .time-slot-group {
    grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
    gap: 0.5rem !important;
  }
}

/* Sehr schmale Geräte */
@media (max-width: 360px) {
  #tab-b4c6 .ikra-appointment-root fieldset[data-step="1"] .time-slot-group {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  }
}