/* ============================================================
   BOOKING + CUSTOMER PORTAL — Styles
   ============================================================ */

/* ---------- Booking Hero ---------- */
.booking-hero {
  padding: clamp(60px, 9vw, 100px) 0 clamp(30px, 4vw, 50px);
  background: linear-gradient(180deg, #fafdff 0%, #f5f8fb 100%);
  text-align: center;
}
.booking-hero h1 {
  font-family: var(--f-display);
  font-size: clamp(2.4rem, 5.5vw, 4.2rem);
  line-height: 0.98;
  letter-spacing: -0.03em;
  margin: 18px 0 16px;
  color: var(--c-ink);
}
.booking-hero h1 .accent-italic {
  font-family: var(--f-serif);
  font-style: italic;
  font-weight: 400;
  color: var(--c-blue);
  letter-spacing: 0;
}
.booking-hero-sub {
  font-size: 1.1rem;
  color: var(--c-text-soft);
  max-width: 580px;
  margin: 0 auto;
  line-height: 1.5;
}
.hero-eyebrow {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 8px 16px;
  background: rgba(0,163,224,0.08);
  border: 1px solid rgba(0,163,224,0.2);
  border-radius: 999px;
  font-size: 0.82rem;
  font-weight: 600;
  color: var(--c-blue, #00a3e0);
  letter-spacing: 0.04em;
  text-transform: uppercase;
}

.booking-section {
  padding: clamp(20px, 4vw, 50px) 0 clamp(60px, 9vw, 100px);
  background: #f5f8fb;
  min-height: 60vh;
}
.container--booking {
  max-width: 920px;
  padding-inline: 20px;
  margin-inline: auto;
}

/* ---------- Progress Steps ---------- */
.booking-steps {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0;
  margin-bottom: 40px;
  flex-wrap: wrap;
}
.booking-step {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  padding: 8px 14px;
  border-radius: 12px;
  color: var(--c-text-soft, #5a6878);
  font-size: 0.9rem;
  font-weight: 600;
  transition: all 0.3s ease;
}
.booking-step-num {
  width: 28px;
  height: 28px;
  border-radius: 50%;
  background: rgba(13,27,42,0.08);
  display: grid;
  place-items: center;
  font-size: 0.85rem;
  font-weight: 700;
  color: var(--c-text-soft);
  transition: all 0.3s ease;
}
.booking-step--active {
  background: rgba(0,163,224,0.08);
  color: var(--c-blue);
}
.booking-step--active .booking-step-num {
  background: var(--c-blue);
  color: #fff;
  box-shadow: 0 4px 14px rgba(0,163,224,0.4);
}
.booking-step--done .booking-step-num {
  background: #2dd573;
  color: #fff;
}
.booking-step--done {
  color: #1a9c52;
}
.booking-step-line {
  width: 40px;
  height: 2px;
  background: rgba(13,27,42,0.1);
  margin: 0 4px;
}
@media (max-width: 640px) {
  .booking-step-line { width: 16px; }
  .booking-step-label { display: none; }
  .booking-step { padding: 8px; }
}

/* ---------- Booking Panel ---------- */
.booking-panel {
  background: #fff;
  border-radius: 24px;
  padding: clamp(28px, 4vw, 48px);
  box-shadow: 0 12px 40px rgba(13,27,42,0.05);
  border: 1px solid var(--c-line, #e6ebf0);
  animation: panel-fade 0.4s ease;
}
@keyframes panel-fade {
  from { opacity: 0; transform: translateY(12px); }
  to { opacity: 1; transform: translateY(0); }
}
.booking-panel h2 {
  font-family: var(--f-display);
  font-size: clamp(1.6rem, 3.5vw, 2.4rem);
  line-height: 1.05;
  letter-spacing: -0.025em;
  margin: 0 0 8px;
  color: var(--c-ink);
}
.booking-panel-sub {
  color: var(--c-text-soft, #5a6878);
  margin: 0 0 28px;
  font-size: 0.98rem;
}
.booking-panel-sub strong { color: var(--c-ink); font-weight: 700; }

/* ---------- Service Tiles ---------- */
.service-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: 14px;
}
.service-tile {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 6px;
  padding: 20px;
  background: #fff;
  border: 2px solid var(--c-line, #e6ebf0);
  border-radius: 16px;
  cursor: pointer;
  text-align: left;
  font-family: inherit;
  transition: all 0.25s ease;
  position: relative;
  overflow: hidden;
}
.service-tile:hover {
  border-color: var(--c-blue);
  transform: translateY(-3px);
  box-shadow: 0 10px 30px rgba(0,163,224,0.14);
}
.service-tile--selected {
  border-color: var(--c-blue);
  background: rgba(0,163,224,0.04);
  box-shadow: 0 12px 32px rgba(0,163,224,0.2);
}
.service-tile--selected::after {
  content: "✓";
  position: absolute;
  top: 14px;
  right: 14px;
  width: 24px;
  height: 24px;
  background: var(--c-blue);
  color: #fff;
  border-radius: 50%;
  display: grid;
  place-items: center;
  font-size: 0.85rem;
  font-weight: 800;
}
.service-tile--urgent {
  border-color: rgba(230,57,70,0.3);
  background: rgba(230,57,70,0.03);
}
.service-tile--urgent:hover {
  border-color: var(--c-red);
  background: rgba(230,57,70,0.06);
  box-shadow: 0 10px 30px rgba(230,57,70,0.18);
}
.service-tile-icon {
  font-size: 1.8rem;
  line-height: 1;
  margin-bottom: 4px;
}
.service-tile-name {
  font-family: var(--f-display);
  font-size: 1.15rem;
  font-weight: 400;
  color: var(--c-ink);
  letter-spacing: -0.015em;
  line-height: 1.1;
}
.service-tile-desc {
  font-size: 0.88rem;
  color: var(--c-text, #2c3e50);
  line-height: 1.4;
}
.service-tile-meta {
  font-size: 0.78rem;
  color: var(--c-text-soft, #5a6878);
  font-weight: 500;
  margin-top: 4px;
}
.service-tile--urgent .service-tile-meta { color: var(--c-red); }

/* ---------- Calendar ---------- */
.calendar-wrap {
  margin-top: 8px;
  margin-bottom: 28px;
}
.calendar-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  margin-bottom: 14px;
}
.cal-nav {
  width: 40px;
  height: 40px;
  border-radius: 12px;
  background: var(--c-bg-soft, #f5f8fb);
  border: 1px solid var(--c-line, #e6ebf0);
  font-size: 1.4rem;
  color: var(--c-ink);
  cursor: pointer;
  transition: all 0.18s ease;
  font-family: inherit;
}
.cal-nav:hover {
  background: var(--c-blue);
  color: #fff;
  border-color: var(--c-blue);
}
.cal-nav:disabled {
  opacity: 0.3;
  cursor: not-allowed;
}
.cal-month {
  font-family: var(--f-display);
  font-size: 1.4rem;
  font-weight: 400;
  letter-spacing: -0.02em;
  color: var(--c-ink);
  margin: 0;
}
.cal-weekdays {
  display: grid;
  grid-template-columns: repeat(7, 1fr);
  gap: 4px;
  margin-bottom: 8px;
  text-align: center;
  font-size: 0.78rem;
  font-weight: 600;
  color: var(--c-text-soft, #5a6878);
  text-transform: uppercase;
  letter-spacing: 0.05em;
}
.cal-grid {
  display: grid;
  grid-template-columns: repeat(7, 1fr);
  gap: 4px;
}
.cal-day {
  aspect-ratio: 1;
  border: 1.5px solid var(--c-line, #e6ebf0);
  border-radius: 10px;
  background: #fff;
  cursor: pointer;
  font-family: inherit;
  font-size: 0.95rem;
  font-weight: 600;
  color: var(--c-ink);
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 2px;
  transition: all 0.18s ease;
  position: relative;
  padding: 0;
}
.cal-day:not(:disabled):hover {
  border-color: var(--c-blue);
  background: rgba(0,163,224,0.04);
  transform: translateY(-1px);
}
.cal-day-num {
  line-height: 1;
}
.cal-day-dot {
  width: 5px;
  height: 5px;
  border-radius: 50%;
  background: transparent;
}
.cal-day--avail .cal-day-dot { background: #2dd573; }
.cal-day--limited .cal-day-dot { background: var(--c-yellow, #ffd000); }
.cal-day--full .cal-day-dot { background: var(--c-red, #e63946); }
.cal-day--empty {
  border: none;
  background: transparent;
  cursor: default;
}
.cal-day--past, .cal-day--closed {
  background: var(--c-bg-soft, #f5f8fb);
  color: var(--c-text-soft);
  cursor: not-allowed;
  opacity: 0.5;
}
.cal-day--full {
  background: rgba(230,57,70,0.04);
  color: var(--c-text-soft);
  cursor: not-allowed;
}
.cal-day--selected {
  background: var(--c-blue) !important;
  color: #fff !important;
  border-color: var(--c-blue) !important;
  box-shadow: 0 6px 20px rgba(0,163,224,0.4);
  transform: translateY(-2px);
}
.cal-day--selected .cal-day-dot { background: #fff !important; }

.cal-legend {
  display: flex;
  gap: 18px;
  margin-top: 16px;
  font-size: 0.82rem;
  color: var(--c-text-soft);
  flex-wrap: wrap;
  justify-content: center;
}
.cal-legend span {
  display: inline-flex;
  align-items: center;
  gap: 6px;
}
.cal-dot {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  display: inline-block;
}
.cal-dot--avail { background: #2dd573; }
.cal-dot--limited { background: var(--c-yellow); }
.cal-dot--full { background: var(--c-red); }

/* ---------- Slots ---------- */
.slots-wrap {
  margin-top: 32px;
  padding-top: 24px;
  border-top: 1px solid var(--c-line, #e6ebf0);
  animation: panel-fade 0.4s ease;
}
.slots-title {
  font-family: var(--f-body);
  font-size: 1rem;
  font-weight: 600;
  color: var(--c-ink);
  margin: 0 0 14px;
}
.slots-title span { color: var(--c-blue); }
.slots-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(90px, 1fr));
  gap: 8px;
}
.slot-btn {
  padding: 12px 16px;
  background: #fff;
  border: 1.5px solid var(--c-line, #e6ebf0);
  border-radius: 10px;
  font-family: inherit;
  font-size: 1rem;
  font-weight: 600;
  color: var(--c-ink);
  cursor: pointer;
  transition: all 0.18s ease;
}
.slot-btn:hover {
  border-color: var(--c-blue);
  background: rgba(0,163,224,0.04);
}
.slot-btn--selected {
  background: var(--c-blue);
  color: #fff;
  border-color: var(--c-blue);
  box-shadow: 0 4px 14px rgba(0,163,224,0.4);
}

/* ---------- Booking Summary ---------- */
.booking-summary {
  background: var(--c-bg-soft, #f5f8fb);
  border-radius: 14px;
  padding: 18px 22px;
  margin-bottom: 24px;
  display: flex;
  flex-direction: column;
  gap: 10px;
}
.booking-summary--lg {
  background: linear-gradient(135deg, rgba(0,163,224,0.06), rgba(255,208,0,0.06));
  padding: 24px 28px;
  margin: 0 0 28px;
}
.booking-summary-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  flex-wrap: wrap;
}
.booking-summary-label {
  font-size: 0.85rem;
  color: var(--c-text-soft);
  font-weight: 500;
}
.booking-summary-value {
  font-weight: 700;
  color: var(--c-ink);
  text-align: right;
}

/* ---------- Back button ---------- */
.booking-back {
  margin-top: 24px;
  background: none;
  border: none;
  color: var(--c-text-soft);
  font-size: 0.9rem;
  font-weight: 600;
  cursor: pointer;
  padding: 8px 12px;
  border-radius: 8px;
  font-family: inherit;
}
.booking-back:hover {
  color: var(--c-blue);
  background: rgba(0,163,224,0.06);
}

/* ---------- Confirmation step ---------- */
.booking-panel--success { text-align: center; }
.success-burst {
  position: relative;
  width: 100px;
  height: 100px;
  margin: 0 auto 20px;
}
.success-check {
  width: 100px;
  height: 100px;
  background: linear-gradient(135deg, #2dd573, #1a9c52);
  border-radius: 50%;
  display: grid;
  place-items: center;
  color: #fff;
  box-shadow: 0 16px 40px rgba(45,213,115,0.4);
  animation: success-pop 0.5s cubic-bezier(0.34, 1.56, 0.64, 1);
}
.success-check svg { width: 48px; height: 48px; }
@keyframes success-pop {
  0% { transform: scale(0); }
  100% { transform: scale(1); }
}
.success-burst::before, .success-burst::after {
  content: "";
  position: absolute;
  inset: 0;
  border-radius: 50%;
  border: 2px solid #2dd573;
  animation: success-ring 1.6s ease-out infinite;
  opacity: 0;
}
.success-burst::after {
  animation-delay: 0.4s;
}
@keyframes success-ring {
  0% { transform: scale(1); opacity: 0.7; }
  100% { transform: scale(1.8); opacity: 0; }
}
.success-lead {
  font-size: 1.1rem;
  color: var(--c-text);
  margin: 0 auto 28px;
  max-width: 540px;
}
.conf-next-steps {
  background: var(--c-bg-soft);
  border-radius: 14px;
  padding: 22px 24px;
  text-align: left;
  margin: 28px 0;
}
.conf-next-steps h4 {
  font-size: 0.95rem;
  font-weight: 700;
  color: var(--c-ink);
  margin: 0 0 12px;
  text-transform: uppercase;
  letter-spacing: 0.06em;
}
.conf-steps-list {
  margin: 0;
  padding-left: 22px;
  font-size: 0.96rem;
  color: var(--c-text);
  line-height: 1.6;
}
.conf-steps-list li { margin-bottom: 6px; }
.conf-actions {
  display: flex;
  gap: 12px;
  justify-content: center;
  flex-wrap: wrap;
  margin: 24px 0;
}
.conf-note {
  font-size: 0.86rem;
  color: var(--c-text-soft);
  background: rgba(230,57,70,0.05);
  border: 1px solid rgba(230,57,70,0.2);
  padding: 14px 18px;
  border-radius: 12px;
  text-align: left;
}
.conf-note strong { color: var(--c-red); }
.conf-note a { color: var(--c-red); font-weight: 700; }

/* ---------- Soft checkbox-field for portal opt-in ---------- */
.big-form .checkbox-field--soft {
  background: linear-gradient(135deg, rgba(255,208,0,0.10), rgba(0,163,224,0.06));
  border-color: rgba(255,208,0,0.30);
}
.big-form .checkbox-field--soft strong { color: var(--c-ink); }


/* ============================================================
   PORTAL — Login + Dashboard
   ============================================================ */

/* Login screen */
.portal-login, .portal-sent {
  min-height: 80vh;
  padding: 80px 0;
  display: flex;
  align-items: center;
  background: linear-gradient(180deg, #fafdff 0%, #f5f8fb 100%);
}
.login-card {
  background: #fff;
  border-radius: 28px;
  padding: clamp(40px, 6vw, 60px);
  text-align: center;
  box-shadow: 0 24px 70px rgba(13,27,42,0.08);
  border: 1px solid var(--c-line);
  max-width: 460px;
  margin: 0 auto;
}
.login-card--sent { max-width: 520px; }
.login-logo {
  width: 64px;
  height: 64px;
  margin: 0 auto 22px;
  background: linear-gradient(135deg, var(--c-yellow), #ffb800);
  border-radius: 20px;
  display: grid;
  place-items: center;
  color: var(--c-ink);
  box-shadow: 0 10px 28px rgba(255,184,0,0.4);
}
.login-logo svg { width: 32px; height: 32px; }
.login-card h1, .login-card h2 {
  font-family: var(--f-display);
  font-size: clamp(2rem, 4vw, 2.6rem);
  line-height: 1.1;
  letter-spacing: -0.025em;
  margin: 0 0 12px;
  color: var(--c-ink);
}
.login-card h1 .accent-italic {
  font-family: var(--f-serif);
  font-style: italic;
  font-weight: 400;
  color: var(--c-blue);
}
.login-sub {
  color: var(--c-text-soft);
  font-size: 1rem;
  margin: 0 0 32px;
}
.login-form {
  text-align: left;
  margin-bottom: 24px;
}
.login-form .field { margin-bottom: 14px; }
.login-form .field span {
  display: block;
  margin-bottom: 6px;
  font-size: 0.88rem;
  font-weight: 600;
  color: var(--c-ink);
}
.login-form input {
  width: 100%;
  padding: 14px 16px;
  background: #fff;
  border: 1.5px solid var(--c-line);
  border-radius: 12px;
  font-family: inherit;
  font-size: 1rem;
  color: var(--c-ink);
  box-sizing: border-box;
}
.login-form input:focus {
  outline: none;
  border-color: var(--c-blue);
  box-shadow: 0 0 0 4px rgba(0,163,224,0.12);
}
.login-hint {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  font-size: 0.84rem;
  color: var(--c-text-soft);
  background: rgba(0,163,224,0.04);
  padding: 12px 14px;
  border-radius: 10px;
  margin-top: 16px;
  text-align: left;
  line-height: 1.5;
}
.login-hint svg { width: 18px; height: 18px; flex-shrink: 0; margin-top: 1px; color: var(--c-blue); }
.login-demo {
  background: rgba(255,208,0,0.10);
  border: 1px dashed rgba(255,184,0,0.5);
  padding: 12px 14px;
  border-radius: 10px;
  font-size: 0.82rem;
  color: var(--c-text);
  text-align: left;
  line-height: 1.5;
}

/* Sent screen */
.sent-icon {
  width: 72px;
  height: 72px;
  margin: 0 auto 20px;
  background: linear-gradient(135deg, var(--c-blue), var(--c-blue-dark, #0077a8));
  border-radius: 20px;
  display: grid;
  place-items: center;
  color: #fff;
  box-shadow: 0 10px 30px rgba(0,163,224,0.4);
}
.sent-icon svg { width: 32px; height: 32px; }
.login-card .btn-ghost {
  background: none;
  border: none;
  color: var(--c-text-soft);
  font-family: inherit;
  font-size: 0.92rem;
  font-weight: 600;
  cursor: pointer;
  margin-top: 14px;
  padding: 8px;
}
.login-card .btn-ghost:hover { color: var(--c-blue); }


/* ============================================================
   DASHBOARD
   ============================================================ */
.portal-dashboard {
  padding: 60px 0 80px;
  background: linear-gradient(180deg, #fafdff 0%, #f5f8fb 100%);
  min-height: 100vh;
}
.portal-welcome {
  display: flex;
  justify-content: space-between;
  align-items: flex-end;
  gap: 24px;
  margin-bottom: 32px;
  flex-wrap: wrap;
}
.portal-welcome h1 {
  font-family: var(--f-display);
  font-size: clamp(2rem, 4vw, 3rem);
  line-height: 1.1;
  letter-spacing: -0.025em;
  margin: 8px 0 0;
  color: var(--c-ink);
}
.portal-welcome .accent-italic {
  font-family: var(--f-serif);
  font-style: italic;
  font-weight: 400;
  color: var(--c-blue);
}

/* Maintenance Alert */
.portal-alert {
  display: flex;
  align-items: center;
  gap: 18px;
  padding: 22px 26px;
  background: linear-gradient(135deg, #fffbe8 0%, #fff5d0 100%);
  border: 1px solid rgba(255, 208, 0, 0.4);
  border-left: 4px solid var(--c-yellow, #ffd000);
  border-radius: 16px;
  margin-bottom: 32px;
  box-shadow: 0 8px 24px rgba(255,184,0,0.12);
  flex-wrap: wrap;
}
.portal-alert-icon {
  width: 48px;
  height: 48px;
  background: var(--c-yellow);
  color: var(--c-ink);
  border-radius: 14px;
  display: grid;
  place-items: center;
  flex-shrink: 0;
}
.portal-alert-icon svg { width: 24px; height: 24px; }
.portal-alert-content {
  display: flex;
  flex-direction: column;
  gap: 2px;
  flex: 1;
  min-width: 240px;
}
.portal-alert-content strong {
  font-size: 1.05rem;
  color: var(--c-ink);
  font-weight: 700;
}
.portal-alert-content strong span {
  color: var(--c-red);
}
.portal-alert-content span {
  font-size: 0.88rem;
  color: var(--c-text-soft);
}

/* Portal Grid */
.portal-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 22px;
  margin-bottom: 36px;
}
.portal-card--wide {
  grid-column: 1 / -1;
}
@media (max-width: 880px) {
  .portal-grid { grid-template-columns: 1fr; }
  .portal-card--wide { grid-column: auto; }
}
.portal-card {
  background: #fff;
  border-radius: 22px;
  padding: 28px;
  border: 1px solid var(--c-line);
  box-shadow: 0 8px 24px rgba(13,27,42,0.04);
  transition: transform 0.3s ease, box-shadow 0.3s ease;
}
.portal-card:hover {
  transform: translateY(-2px);
  box-shadow: 0 16px 40px rgba(13,27,42,0.08);
}
.portal-card-header {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 14px;
  margin-bottom: 18px;
}
.portal-card-eyebrow {
  display: inline-block;
  font-size: 0.78rem;
  font-weight: 600;
  color: var(--c-text-soft);
  letter-spacing: 0.05em;
  margin-bottom: 4px;
}
.portal-card h3 {
  font-family: var(--f-display);
  font-size: 1.35rem;
  line-height: 1.2;
  letter-spacing: -0.02em;
  margin: 0;
  color: var(--c-ink);
}
.portal-badge {
  display: inline-flex;
  align-items: center;
  padding: 4px 10px;
  background: var(--c-bg-soft);
  border-radius: 999px;
  font-size: 0.76rem;
  font-weight: 600;
  color: var(--c-text-soft);
  white-space: nowrap;
}
.portal-badge--ok, .portal-badge--active {
  background: rgba(45,213,115,0.12);
  color: #1a9c52;
}
.portal-card-link {
  display: inline-block;
  margin-top: 16px;
  color: var(--c-blue);
  font-size: 0.92rem;
  font-weight: 600;
  text-decoration: none;
  transition: gap 0.2s ease;
}
.portal-card-link:hover { color: var(--c-blue-dark, #0077a8); }

/* Anlagenakte */
.anlage-list {
  margin: 0;
  display: flex;
  flex-direction: column;
}
.anlage-row {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 10px 0;
  border-bottom: 1px solid var(--c-line, #e6ebf0);
}
.anlage-row:last-child { border-bottom: none; }
.anlage-row dt {
  font-size: 0.88rem;
  color: var(--c-text-soft);
  font-weight: 500;
  margin: 0;
}
.anlage-row dd {
  font-size: 0.95rem;
  color: var(--c-ink);
  font-weight: 600;
  margin: 0;
  text-align: right;
}

/* Appointments */
.appointment-list { display: flex; flex-direction: column; gap: 14px; }
.appointment-item {
  display: flex;
  gap: 16px;
  padding: 14px;
  background: var(--c-bg-soft);
  border-radius: 12px;
  align-items: center;
}
.appointment-item--soon {
  background: rgba(0,163,224,0.06);
  border: 1px solid rgba(0,163,224,0.2);
}
.appt-date {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  min-width: 56px;
  padding: 8px;
  background: #fff;
  border-radius: 10px;
  text-align: center;
}
.appt-date strong {
  font-family: var(--f-display);
  font-size: 1.6rem;
  line-height: 1;
  color: var(--c-ink);
}
.appt-date span {
  font-size: 0.72rem;
  color: var(--c-text-soft);
  text-transform: uppercase;
  font-weight: 600;
  letter-spacing: 0.04em;
  margin-top: 2px;
}
.appt-info {
  display: flex;
  flex-direction: column;
  gap: 4px;
  flex: 1;
  min-width: 0;
}
.appt-info strong { color: var(--c-ink); font-size: 1rem; }
.appt-info span { color: var(--c-text-soft); font-size: 0.86rem; }
.appt-tag {
  display: inline-block;
  width: fit-content;
  margin-top: 4px;
  padding: 2px 8px;
  background: rgba(255,184,0,0.18);
  color: #8d6500;
  border-radius: 6px;
  font-size: 0.74rem;
  font-weight: 600;
}
.appt-tag--green {
  background: rgba(45,213,115,0.18);
  color: #1a9c52;
}

/* Timeline */
.history-timeline {
  position: relative;
  padding-left: 22px;
}
.history-timeline::before {
  content: "";
  position: absolute;
  left: 7px;
  top: 6px;
  bottom: 6px;
  width: 2px;
  background: var(--c-line);
}
.history-item {
  position: relative;
  padding-bottom: 22px;
  padding-left: 6px;
}
.history-item:last-child { padding-bottom: 0; }
.history-dot {
  position: absolute;
  left: -22px;
  top: 4px;
  width: 16px;
  height: 16px;
  background: #fff;
  border: 3px solid var(--c-blue);
  border-radius: 50%;
}
.history-item:first-child .history-dot {
  background: var(--c-blue);
}
.history-date {
  font-size: 0.78rem;
  color: var(--c-text-soft);
  font-weight: 600;
  letter-spacing: 0.04em;
  margin-bottom: 2px;
  text-transform: uppercase;
}
.history-item strong {
  display: block;
  font-size: 1rem;
  color: var(--c-ink);
  margin-bottom: 4px;
}
.history-item p {
  font-size: 0.92rem;
  color: var(--c-text);
  margin: 0 0 6px;
  line-height: 1.5;
}
.history-link {
  display: inline-block;
  color: var(--c-blue);
  font-size: 0.85rem;
  font-weight: 600;
  text-decoration: none;
}
.history-link:hover { text-decoration: underline; }

/* Invoices */
.invoice-list { display: flex; flex-direction: column; gap: 10px; }
.invoice-item {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 14px;
  padding: 12px 14px;
  background: var(--c-bg-soft);
  border-radius: 10px;
  transition: background 0.18s ease;
}
.invoice-item:hover { background: rgba(0,163,224,0.06); }
.invoice-item div:first-child {
  display: flex;
  flex-direction: column;
  gap: 1px;
}
.invoice-item strong { color: var(--c-ink); font-size: 0.95rem; }
.invoice-item span { color: var(--c-text-soft); font-size: 0.82rem; }
.invoice-amount {
  font-family: var(--f-display);
  font-size: 1.05rem;
  font-weight: 400;
  color: var(--c-ink);
  letter-spacing: -0.01em;
}
.invoice-link {
  width: 32px;
  height: 32px;
  border-radius: 8px;
  background: #fff;
  border: 1px solid var(--c-line);
  display: grid;
  place-items: center;
  color: var(--c-blue);
  text-decoration: none;
  font-weight: 700;
  font-size: 1.1rem;
  transition: all 0.18s ease;
}
.invoice-link:hover {
  background: var(--c-blue);
  color: #fff;
  border-color: var(--c-blue);
}

/* Highlight card (Wartungsabo) */
.portal-card--highlight {
  background: linear-gradient(135deg, var(--c-ink) 0%, #1a2b3d 100%);
  color: #fff;
  border: none;
}
.portal-card--highlight h3 { color: #fff; }
.portal-card--highlight .portal-card-eyebrow { color: var(--c-yellow); }
.portal-card--highlight .portal-badge--active {
  background: rgba(45,213,115,0.2);
  color: #5ee78f;
}
.benefit-list {
  list-style: none;
  padding: 0;
  margin: 0 0 18px;
  display: flex;
  flex-direction: column;
  gap: 8px;
}
.benefit-list li {
  font-size: 0.93rem;
  color: rgba(255,255,255,0.92);
  padding: 6px 0;
  border-bottom: 1px solid rgba(255,255,255,0.08);
}
.benefit-list li:last-child { border-bottom: none; }
.portal-abo-status {
  background: rgba(255,255,255,0.06);
  padding: 12px 14px;
  border-radius: 10px;
  font-size: 0.86rem;
  color: rgba(255,255,255,0.85);
  line-height: 1.5;
}
.portal-abo-status strong { color: var(--c-yellow); }

/* Förder-Radar */
.portal-card--accent {
  background: linear-gradient(135deg, #fffbe8 0%, #fff5d0 100%);
  border-color: rgba(255,208,0,0.35);
}
.foerder-item {
  padding: 14px 0;
  border-bottom: 1px dashed rgba(0,0,0,0.1);
}
.foerder-item:last-of-type { border-bottom: none; padding-bottom: 4px; }
.foerder-item strong {
  display: block;
  font-size: 0.98rem;
  color: var(--c-ink);
  margin-bottom: 4px;
}
.foerder-amount {
  display: inline-block;
  padding: 3px 10px;
  background: var(--c-ink);
  color: var(--c-yellow);
  border-radius: 999px;
  font-size: 0.84rem;
  font-weight: 800;
  font-family: var(--f-display);
  letter-spacing: -0.01em;
  margin: 4px 0;
}
.foerder-item p {
  font-size: 0.86rem;
  color: var(--c-text);
  margin: 4px 0 0;
  line-height: 1.5;
}

/* Empfehlung */
.portal-card--invite {
  background: linear-gradient(135deg, rgba(0,163,224,0.06), rgba(255,255,255,1));
}
.portal-card--invite p { color: var(--c-text); margin: 0 0 16px; }
.portal-card--invite p strong { color: var(--c-blue); font-size: 1.1em; }
.invite-link-wrap {
  display: flex;
  gap: 8px;
  align-items: center;
}
.invite-link-wrap input {
  flex: 1;
  padding: 10px 12px;
  background: var(--c-bg-soft);
  border: 1px solid var(--c-line);
  border-radius: 10px;
  font-family: var(--f-mono, monospace);
  font-size: 0.85rem;
  color: var(--c-ink);
}

/* Quick actions */
.portal-quick { margin-top: 36px; }
.portal-quick h3 {
  font-family: var(--f-display);
  font-size: 1.4rem;
  letter-spacing: -0.02em;
  margin: 0 0 16px;
  color: var(--c-ink);
}
.portal-quick-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
  gap: 14px;
}
.portal-quick-tile {
  display: flex;
  flex-direction: column;
  gap: 4px;
  padding: 20px;
  background: #fff;
  border: 1px solid var(--c-line);
  border-radius: 16px;
  text-decoration: none;
  color: var(--c-ink);
  transition: all 0.2s ease;
}
.portal-quick-tile:hover {
  transform: translateY(-3px);
  border-color: var(--c-blue);
  box-shadow: 0 12px 28px rgba(0,163,224,0.14);
}
.portal-quick-tile .qt-icon { font-size: 1.6rem; margin-bottom: 4px; }
.portal-quick-tile strong { font-size: 1rem; color: var(--c-ink); }
.portal-quick-tile span { font-size: 0.84rem; color: var(--c-text-soft); }
.portal-quick-tile--urgent {
  background: linear-gradient(135deg, var(--c-red), var(--c-red-dark, #b8202c));
  border-color: transparent;
  color: #fff;
}
.portal-quick-tile--urgent strong, .portal-quick-tile--urgent span { color: #fff; }
.portal-quick-tile--urgent:hover { box-shadow: 0 14px 32px rgba(230,57,70,0.4); }

/* ============================================================
   FOTO-DIAGNOSE
   ============================================================ */
.diag-hero {
  padding: clamp(60px, 9vw, 100px) 0 clamp(20px, 4vw, 40px);
  background: linear-gradient(180deg, #fafdff 0%, #f5f8fb 100%);
  text-align: center;
}
.diag-hero h1 {
  font-family: var(--f-display);
  font-size: clamp(2.4rem, 5.5vw, 4.2rem);
  line-height: 0.98;
  letter-spacing: -0.03em;
  margin: 18px 0 16px;
  color: var(--c-ink);
}
.diag-hero h1 .accent-italic {
  font-family: var(--f-serif);
  font-style: italic;
  font-weight: 400;
  color: var(--c-blue);
}
.diag-hero-sub {
  font-size: 1.1rem;
  color: var(--c-text-soft);
  max-width: 620px;
  margin: 0 auto;
  line-height: 1.6;
}
.diag-hero-sub strong { color: var(--c-ink); }

.diag-section {
  padding: 30px 0 clamp(60px, 9vw, 100px);
  background: #f5f8fb;
}

/* Flow visualization */
.diag-flow {
  display: flex;
  align-items: stretch;
  justify-content: center;
  gap: 0;
  margin-bottom: 36px;
  flex-wrap: wrap;
}
.diag-flow-step {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 4px;
  text-align: center;
  flex: 1;
  min-width: 140px;
  max-width: 200px;
}
.diag-flow-num {
  width: 44px;
  height: 44px;
  border-radius: 50%;
  background: linear-gradient(135deg, var(--c-blue), var(--c-blue-dark, #0077a8));
  color: #fff;
  display: grid;
  place-items: center;
  font-family: var(--f-display);
  font-size: 1.2rem;
  font-weight: 400;
  margin-bottom: 8px;
  box-shadow: 0 6px 16px rgba(0,163,224,0.3);
}
.diag-flow-step strong {
  font-size: 1.05rem;
  color: var(--c-ink);
  font-weight: 700;
}
.diag-flow-step span {
  font-size: 0.88rem;
  color: var(--c-text-soft);
  line-height: 1.4;
}
.diag-flow-line {
  height: 2px;
  background: linear-gradient(90deg, transparent, var(--c-blue), transparent);
  flex: 0 1 80px;
  margin: 22px 0 0;
  align-self: flex-start;
  opacity: 0.4;
}
@media (max-width: 640px) {
  .diag-flow-line { display: none; }
  .diag-flow { gap: 22px; }
}

/* Form panel */
.diag-panel {
  background: #fff;
  border-radius: 24px;
  padding: clamp(28px, 4vw, 44px);
  box-shadow: 0 12px 40px rgba(13,27,42,0.05);
  border: 1px solid var(--c-line, #e6ebf0);
}
.diag-panel--success { text-align: center; }
.diag-panel h2 {
  font-family: var(--f-display);
  font-size: clamp(1.8rem, 4vw, 2.6rem);
  letter-spacing: -0.025em;
  margin: 0 0 8px;
  color: var(--c-ink);
}

/* Dropzone */
.diag-upload { margin-bottom: 20px; }
.diag-dropzone {
  position: relative;
  display: block;
  min-height: 240px;
  border: 2px dashed rgba(0,163,224,0.3);
  border-radius: 16px;
  background: rgba(0,163,224,0.03);
  cursor: pointer;
  overflow: hidden;
  transition: all 0.2s ease;
}
.diag-dropzone:hover, .diag-dropzone--drag {
  border-color: var(--c-blue);
  background: rgba(0,163,224,0.06);
}
.diag-dropzone--has-photo {
  border-style: solid;
  background: var(--c-ink);
}
.diag-dropzone-empty {
  position: absolute;
  inset: 0;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 8px;
  padding: 30px 20px;
  text-align: center;
  color: var(--c-text);
}
.diag-dropzone-empty svg {
  width: 48px;
  height: 48px;
  color: var(--c-blue);
  margin-bottom: 8px;
}
.diag-dropzone-empty strong {
  font-size: 1.05rem;
  color: var(--c-ink);
}
.diag-dropzone-empty span {
  font-size: 0.88rem;
  color: var(--c-text-soft);
}
.diag-dropzone-empty .diag-hint {
  margin-top: 8px;
  padding: 6px 12px;
  background: var(--c-yellow);
  color: var(--c-ink);
  border-radius: 999px;
  font-size: 0.82rem;
  font-weight: 600;
}
.diag-preview {
  display: block;
  width: 100%;
  max-height: 480px;
  object-fit: contain;
  background: var(--c-ink);
}
.diag-remove {
  position: absolute;
  top: 12px;
  right: 12px;
  width: 36px;
  height: 36px;
  border-radius: 50%;
  background: rgba(0,0,0,0.7);
  color: #fff;
  border: none;
  font-size: 1.4rem;
  cursor: pointer;
  display: grid;
  place-items: center;
  font-family: inherit;
  line-height: 1;
  transition: background 0.18s ease;
}
.diag-remove:hover { background: var(--c-red); }

/* Trust bar */
.diag-trust {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 14px;
  margin-top: 28px;
}
@media (max-width: 720px) {
  .diag-trust { grid-template-columns: 1fr; }
}
.diag-trust-item {
  display: flex;
  align-items: flex-start;
  gap: 12px;
  padding: 16px 18px;
  background: #fff;
  border: 1px solid var(--c-line);
  border-radius: 14px;
}
.diag-trust-item svg {
  width: 24px;
  height: 24px;
  color: var(--c-blue);
  flex-shrink: 0;
}
.diag-trust-item strong {
  display: block;
  font-size: 0.95rem;
  color: var(--c-ink);
  margin-bottom: 2px;
}
.diag-trust-item span {
  font-size: 0.84rem;
  color: var(--c-text-soft);
  line-height: 1.4;
}

/* Fix: ensure preview img is hidden when no src */
.diag-preview:not([src]),
.diag-preview[src=""] {
  display: none !important;
}
.diag-preview[hidden] { display: none !important; }
.diag-remove[hidden] { display: none !important; }

/* Make sure the dropzone empty-state is centered & visible */
.diag-dropzone:not(.diag-dropzone--has-photo) .diag-dropzone-empty {
  position: relative;
  inset: auto;
}
