/* --- Terminübersicht --- */
.pht-terminliste {
  margin: 40px auto;
  max-width: 1100px;
  padding: 0 20px;
}

.pht-terminliste__heading {
  font-size: clamp(1.4rem, 2vw, 1.8rem);
  margin-bottom: 12px;
}

.pht-terminliste__list {
  list-style: none;
  padding: 0;
  margin: 0;
}

/* --- Filterleiste --- */
.pht-terminliste__filters {
  display: flex;
  gap: 16px;
  align-items: end;
  margin: 10px 0 16px;
  flex-wrap: wrap;
}

.pht-filter label {
  display: block;
  font-size: .9rem;
  color: #444;
  margin-bottom: 4px;
}

.pht-filter select,
.pht-filter input[type="search"] {
  min-width: 210px;
  padding: 8px 10px;
  border: 1px solid #ddd;
  border-radius: 6px;
}

/* --- Monats-Container + Sticky Header --- */
.pht-month {
  margin-top: 24px;
}

.pht-month__header {
  position: sticky;
  top: var(--pht-sticky-offset, 0px);
  z-index: 2;
  padding: 8px 10px;
  border-bottom: 1px solid #eee;
  font-weight: 700;
  font-size: 3rem;
}

/* --- Listenzeile Desktop / Tablet --- */
.pht-terminliste__item {
  display: grid;
  grid-template-columns: 56px max-content minmax(0, 1fr) auto auto;
  grid-template-areas: "thumb datetime title badge button";
  gap: 14px;
  align-items: center;
  padding: 12px 0;
  border-bottom: 1px solid #eee;
  min-width: 0;
}

/* Bild links */
.pht-terminliste__thumb-link {
  grid-area: thumb;
  display: block;
  width: 56px;
  height: 56px;
  min-width: 56px;
  overflow: hidden;
  border-radius: 50%;
}

.pht-terminliste__thumb {
  display: block;
  width: 56px;
  height: 56px;
  object-fit: cover;
  border-radius: 50%;
  box-shadow: 0 5px 15px rgba(0,0,0,0.15);
}

/* Datum */
.pht-dt__wd,
.pht-dt__time {
  color: #555;
}

/* Titel */
.pht-terminliste__title {
  grid-area: title;
  color: #2d2d2d;
  text-decoration: none;
  font-weight: 600;
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.pht-terminliste__title:hover,
.pht-terminliste__title:focus {
  text-decoration: underline;
}

.pht-terminliste__title:focus-visible {
  outline: 2px solid #000;
  outline-offset: 2px;
}

/* Badge */
.pht-terminliste__badge {
  grid-area: badge;
  background: #efefef;
  color: #222;
  border: 1px solid #d9d9d9;
  border-radius: 999px;
  padding: 3px 10px;
  font-size: 14px;
  white-space: nowrap;
  justify-self: end;
}

/* Buttons */
.pht-terminliste__btn,
.pht-terminliste__btn:hover,
.pht-terminliste__btn:visited,
.pht-terminliste__btn:focus,
.pht-terminliste__btn:active,
.pht-terminliste__btn--disabled {
  grid-area: button;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: #ffcb01;
  color: #2d2d2d !important;
  text-decoration: none;
  padding: 8px 12px;
  border-radius: 4px;
  font-weight: 600;
  min-width: 9.5rem;
  text-align: center;
  transition: .2s;
  justify-self: end;
  white-space: nowrap;
  box-sizing: border-box;
  border: 1px solid transparent;
}

.pht-terminliste__btn:hover,
.pht-terminliste__btn:focus {
  background: #000;
  color: #fff !important;
  outline: none;
}

.pht-terminliste__btn:focus-visible {
  outline: 3px solid #000;
  outline-offset: 2px;
}

.pht-terminliste__btn--disabled {
  grid-area: button;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: #ddd;
  color: #777 !important;
  padding: 8px 12px;
  border-radius: 4px;
  font-weight: 600;
  min-width: 9.5rem;
  text-align: center;
  justify-self: end;
  white-space: nowrap;
}

.pht-terminliste__datetime {
  display: flex;
  align-items: baseline;
  gap: 10px;
  white-space: nowrap;
  font-variant-numeric: tabular-nums;
}

.pht-dt__wd {
  color: #777;
  min-width: 2.4em;
}

.pht-dt__date {
  color: #555;
}

.pht-dt__time {
  color: #555;
}

.pht-dt__date::after {
  content: " · ";
  color: #999;
  margin: 0 0.35em;
}

/* --- Mobile --- */
@media (max-width: 760px) {
  .pht-terminliste {
    padding-left: 10px;
    padding-right: 10px;
    margin-top: 24px;
    margin-bottom: 24px;
  }

  .pht-terminliste__list {
    padding-left: 0 !important;
    margin: 0 !important;
  }

  .pht-terminliste__list li {
    margin-left: 0 !important;
    list-style: none;
  }

  .pht-terminliste__filters {
    gap: 10px;
    margin: 8px 0 14px;
    align-items: stretch;
  }

  .pht-filter {
    flex: 1 1 100%;
  }

  .pht-filter select,
  .pht-filter input[type="search"] {
    min-width: 0;
    width: 100%;
  }

  .pht-month__header {
    padding-left: 0;
    padding-right: 0;
    font-size: 2.2rem;
  }

  .pht-terminliste__item {
    grid-template-columns: 48px minmax(0, 1fr);
    grid-template-areas:
      "thumb datetime"
      "thumb title"
      "thumb badge"
      "thumb button";
    gap: 6px 10px;
    align-items: center;
    padding: 10px 0;
  }

  .pht-terminliste__thumb-link {
    width: 48px;
    height: 48px;
    min-width: 48px;
  }

  .pht-terminliste__thumb {
    width: 48px;
    height: 48px;
  }

  .pht-terminliste__datetime {
    grid-area: datetime;
    display: flex;
    align-items: center;
    flex-wrap: wrap;
    gap: 0;
    min-width: 0;
    white-space: normal;
    font-size: 14px;
    line-height: 1.2;
    font-variant-numeric: tabular-nums;
    width: auto;
  }

  .pht-dt__wd,
  .pht-dt__date,
  .pht-dt__time {
    display: inline;
  }

  .pht-dt__wd {
    color: #888;
    min-width: 0;
  }

  .pht-dt__date {
    color: #555;
  }

  .pht-dt__time {
    color: #444;
    font-weight: 500;
  }

  .pht-dt__wd::after,
  .pht-dt__date::after {
    content: " · ";
    color: #aaa;
    margin: 0 0.28em;
  }

  .pht-terminliste__title {
    grid-area: title;
    font-size: 15px;
    color: #2d2d2d;
    line-height: 1.25;
    min-width: 0;
    overflow-wrap: break-word;
    word-break: break-word;
    white-space: normal;
  }

  .pht-terminliste__badge {
    grid-area: badge;
    justify-self: start;
    max-width: none;
    font-size: 12px;
  }

  .pht-terminliste__btn,
  .pht-terminliste__btn:visited,
  .pht-terminliste__btn:hover,
  .pht-terminliste__btn:focus,
  .pht-terminliste__btn:active,
  .pht-terminliste__btn--disabled {
    grid-area: button;
    display: flex;
    align-items: center;
    justify-content: center;
    width: 100%;
    min-width: 0;
    max-width: 500px;
    min-height: 44px;
    padding: 10px 12px;
    box-sizing: border-box;
    border: 1px solid transparent;
    border-radius: 4px;
    font-size: 14px;
    line-height: 1.0;
    font-weight: 600;
    white-space: normal;
    text-align: center;
    justify-self: start;
    align-self: stretch;
    text-decoration: none;
    outline: none;
    box-shadow: none;
    transform: none;
  }

  .pht-terminliste__btn,
  .pht-terminliste__btn:visited,
  .pht-terminliste__btn:active {
    background: #ffcb01;
    color: #2d2d2d !important;
  }

  .pht-terminliste__btn:hover,
  .pht-terminliste__btn:focus {
    background: #000;
    color: #fff !important;
  }

  .pht-terminliste__btn--disabled {
    background: #e6e6e6;
    color: #444 !important;
    border: 1px solid #cfcfcf;
  }
}

/* --- Hero Dates (falls genutzt) --- */
.pht-hero__dates {
  margin: 1em 0;
  font-size: 1.1rem;
  font-weight: 500;
}

.pht-hero__date {
  margin-bottom: 0.25em;
}
