/**
 * 店頭受取予約カレンダー スタイル（修正版）
 * Encore! Coffee Roastery のサイトデザインに合わせた調整
 */

/* =============================================
   カレンダーコンテナ
   ============================================= */
#pickup-calendar-container {
  margin: 15px 0 20px;
}

.pickup-calendar-inner {
  max-width: 420px;
}

/* =============================================
   Flatpickr カスタマイズ
   ============================================= */

/* カレンダー全体 */
#pickup-calendar-container .flatpickr-calendar {
  width: 100% !important;
  max-width: 420px;
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.1);
  border: 1px solid #ddd;
  border-radius: 8px;
  font-family: inherit;
}

/* ★ 7列レイアウトを強制 */
#pickup-calendar-container .flatpickr-days {
  width: 100% !important;
}

#pickup-calendar-container .dayContainer {
  width: 100% !important;
  min-width: 100% !important;
  max-width: 100% !important;
  display: flex !important;
  flex-wrap: wrap !important;
}

#pickup-calendar-container .flatpickr-day {
  width: calc(100% / 7) !important;
  max-width: calc(100% / 7) !important;
  flex-basis: calc(100% / 7) !important;
  box-sizing: border-box;
}

#pickup-calendar-container .flatpickr-weekdays {
  width: 100% !important;
}

#pickup-calendar-container .flatpickr-weekdaycontainer {
  display: flex !important;
  width: 100% !important;
}

#pickup-calendar-container span.flatpickr-weekday {
  flex: 1 !important;
  max-width: calc(100% / 7) !important;
}

/* ヘッダー（月の表示部分） */
#pickup-calendar-container .flatpickr-months {
  background-color: transparent;
  border-radius: 8px 8px 0 0;
}

#pickup-calendar-container .flatpickr-months .flatpickr-month {
  color: #333 !important;
  height: 44px;
}

#pickup-calendar-container .flatpickr-current-month {
  font-size: 1.1em;
  color: #333 !important;
}

#pickup-calendar-container .flatpickr-current-month .flatpickr-monthDropdown-months,
#pickup-calendar-container .flatpickr-current-month input.cur-year {
  color: #333 !important;
  font-weight: bold;
  background-color: transparent !important;
}

#pickup-calendar-container .flatpickr-months .flatpickr-prev-month,
#pickup-calendar-container .flatpickr-months .flatpickr-next-month {
  color: #333 !important;
  fill: #333 !important;
}

#pickup-calendar-container .flatpickr-months .flatpickr-prev-month svg,
#pickup-calendar-container .flatpickr-months .flatpickr-next-month svg {
  fill: #333 !important;
}

#pickup-calendar-container .flatpickr-months .flatpickr-prev-month,
#pickup-calendar-container .flatpickr-months .flatpickr-next-month {
  color: #333;
  fill: #333;
}

#pickup-calendar-container .flatpickr-months .flatpickr-prev-month:hover,
#pickup-calendar-container .flatpickr-months .flatpickr-next-month:hover {
  color: #ccc;
  fill: #ccc;
}

/* 曜日ヘッダー */
#pickup-calendar-container .flatpickr-weekdays {
  background-color: #f5f5f5;
}

#pickup-calendar-container span.flatpickr-weekday {
  color: #333;
  font-size: 0.85em;
  font-weight: bold;
}

/* 日曜の曜日ヘッダー */
#pickup-calendar-container span.flatpickr-weekday:first-child {
  color: #c0392b;
}

/* 土曜の曜日ヘッダー */
#pickup-calendar-container span.flatpickr-weekday:last-child {
  color: #2980b9;
}

/* 日付セル共通 */
#pickup-calendar-container .flatpickr-day {
  border-radius: 4px;
  font-size: 0.9em;
  line-height: 38px;
  height: 38px;
  margin: 1px 0;
  transition: background-color 0.15s ease, color 0.15s ease;
}

/* ホバー */
#pickup-calendar-container .flatpickr-day:hover:not(.flatpickr-disabled):not(.selected) {
  background-color: #f0e6d3;
  border-color: #d4a574;
}

/* 選択中 */
#pickup-calendar-container .flatpickr-day.selected,
#pickup-calendar-container .flatpickr-day.selected:hover {
  background-color: #8B6914;
  border-color: #8B6914;
  color: #fff;
  font-weight: bold;
}

/* 今日 */
#pickup-calendar-container .flatpickr-day.today:not(.selected) {
  border-color: #8B6914;
  color: #8B6914;
  font-weight: bold;
}

/* 選択不可（定休日・休業日） */
#pickup-calendar-container .flatpickr-day.flatpickr-disabled,
#pickup-calendar-container .flatpickr-day.flatpickr-disabled:hover {
  color: #ccc;
  background-color: #f7f7f7;
  text-decoration: line-through;
  cursor: not-allowed;
}

/* 日曜日マーク */
#pickup-calendar-container .flatpickr-day.pickup-sunday {
  color: #c0392b;
}

/* 祝日マーク */
#pickup-calendar-container .flatpickr-day.pickup-holiday-mark {
  color: #c0392b;
  position: relative;
}

#pickup-calendar-container .flatpickr-day.pickup-holiday-mark::after {
  content: '';
  position: absolute;
  bottom: 3px;
  left: 50%;
  transform: translateX(-50%);
  width: 4px;
  height: 4px;
  border-radius: 50%;
  background-color: #c0392b;
}

/* 金曜マーク */
#pickup-calendar-container .flatpickr-day.pickup-friday {
  position: relative;
}

#pickup-calendar-container .flatpickr-day.pickup-friday::after {
  content: '';
  position: absolute;
  bottom: 3px;
  left: 50%;
  transform: translateX(-50%);
  width: 4px;
  height: 4px;
  border-radius: 50%;
  background-color: #8B6914;
}

/* 選択中のドットは非表示 */
#pickup-calendar-container .flatpickr-day.selected::after {
  display: none;
}

/* =============================================
   凡例
   ============================================= */
.pickup-calendar-legend {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  margin-top: 10px;
  padding: 8px 4px;
  font-size: 0.8em;
  color: #666;
}

.legend-item {
  display: inline-flex;
  align-items: center;
  gap: 2px;
}

.legend-closed {
  color: #ccc;
}

.legend-sunday {
  color: #c0392b;
}

.legend-friday {
  color: #8B6914;
}

/* =============================================
   選択中の日付表示
   ============================================= */
.pickup-selected-date {
  margin-top: 12px;
  padding: 12px 16px;
  background-color: #faf6ee;
  border: 1px solid #e8dcc8;
  border-radius: 6px;
  font-size: 0.95em;
  line-height: 1.6;
  min-height: 0;
}

.pickup-selected-date:empty {
  display: none;
}

.selected-date-label {
  color: #666;
  font-size: 0.85em;
}

.pickup-selected-date strong {
  color: #8B6914;
  font-size: 1.1em;
}

.selected-date-info {
  display: block;
  color: #888;
  font-size: 0.85em;
  margin-top: 2px;
}

/* =============================================
   レスポンシブ
   ============================================= */
@media screen and (max-width: 480px) {
  .pickup-calendar-inner {
    max-width: 100%;
  }

  #pickup-calendar-container .flatpickr-calendar {
    max-width: 100%;
  }

  #pickup-calendar-container .flatpickr-day {
    height: 34px;
    line-height: 34px;
    font-size: 0.85em;
  }

  .pickup-calendar-legend {
    gap: 8px;
    font-size: 0.75em;
  }
/* 予約ページの既存カレンダーを非表示 */
body.page-id-421 .calendar-wrapper {
  display: none !important;
}