/* カレンダーの4色スタイル追加 */

/* 営業日（緑色） */
.calendar-day.type-open {
  background: linear-gradient(135deg, #e8f5e9 0%, #c8e6c9 100%);
  border-color: #4CAF50;
}

.calendar-day.type-open .day-number {
  color: #2e7d32;
}

.calendar-day.type-open .day-label {
  color: #4CAF50;
  font-weight: bold;
}

.calendar-day.type-open:hover {
  background: linear-gradient(135deg, #c8e6c9 0%, #a5d6a7 100%);
  box-shadow: 0 4px 8px rgba(76, 175, 80, 0.3);
}

/* 定休日（グレー） */
.calendar-day.type-closed {
  background: linear-gradient(135deg, #f5f5f5 0%, #e0e0e0 100%);
  border-color: #9e9e9e;
}

.calendar-day.type-closed .day-number {
  color: #616161;
}

.calendar-day.type-closed .day-label {
  color: #757575;
  font-weight: bold;
}

.calendar-day.type-closed:hover {
  background: linear-gradient(135deg, #e0e0e0 0%, #bdbdbd 100%);
  box-shadow: 0 4px 8px rgba(158, 158, 158, 0.3);
}

/* 臨時休業（赤色） */
.calendar-day.type-temporary-closed {
  background: linear-gradient(135deg, #ffebee 0%, #ffcdd2 100%);
  border-color: #f44336;
}

.calendar-day.type-temporary-closed .day-number {
  color: #c62828;
}

.calendar-day.type-temporary-closed .day-label {
  color: #f44336;
  font-weight: bold;
}

.calendar-day.type-temporary-closed:hover {
  background: linear-gradient(135deg, #ffcdd2 0%, #ef9a9a 100%);
  box-shadow: 0 4px 8px rgba(244, 67, 54, 0.3);
}

/* 予約開業日（オレンジ色） */
.calendar-day.type-reservation-only {
  background: linear-gradient(135deg, #fff3e0 0%, #ffe0b2 100%);
  border-color: #ff9800;
}

.calendar-day.type-reservation-only .day-number {
  color: #e65100;
}

.calendar-day.type-reservation-only .day-label {
  color: #ff9800;
  font-weight: bold;
}

.calendar-day.type-reservation-only:hover {
  background: linear-gradient(135deg, #ffe0b2 0%, #ffcc80 100%);
  box-shadow: 0 4px 8px rgba(255, 152, 0, 0.3);
}

/* 冬季休業（濃い青色） */
.calendar-day.type-winter-closed {
  background: linear-gradient(135deg, #e3f2fd 0%, #bbdefb 100%);
  border-color: #2196F3;
}

.calendar-day.type-winter-closed .day-number {
  color: #1565c0;
}

.calendar-day.type-winter-closed .day-label {
  color: #2196F3;
  font-weight: bold;
}

.calendar-day.type-winter-closed:hover {
  background: linear-gradient(135deg, #bbdefb 0%, #90caf9 100%);
  box-shadow: 0 4px 8px rgba(33, 150, 243, 0.3);
}

/* イベント（ピンク色） */
.calendar-day.type-event {
  background: linear-gradient(135deg, #fce4ec 0%, #f8bbd0 100%);
  border-color: #E91E63;
}

.calendar-day.type-event .day-number {
  color: #ad1457;
}

.calendar-day.type-event .day-label {
  color: #E91E63;
  font-weight: bold;
}

.calendar-day.type-event:hover {
  background: linear-gradient(135deg, #f8bbd0 0%, #f48fb1 100%);
  box-shadow: 0 4px 8px rgba(233, 30, 99, 0.3);
}

/* 凡例のスタイル */
.calendar-legend {
  display: flex;
  justify-content: center;
  flex-wrap: wrap;
  gap: 20px;
  margin-top: 20px;
  padding: 15px;
  background: #f9f9f9;
  border-radius: 8px;
}

.legend-item {
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: 0.9rem;
}

.legend-color {
  width: 24px;
  height: 24px;
  border-radius: 4px;
  border: 2px solid;
}

.legend-color.open {
  background: linear-gradient(135deg, #e8f5e9 0%, #c8e6c9 100%);
  border-color: #4CAF50;
}

.legend-color.closed {
  background: linear-gradient(135deg, #f5f5f5 0%, #e0e0e0 100%);
  border-color: #9e9e9e;
}

.legend-color.temporary-closed {
  background: linear-gradient(135deg, #ffebee 0%, #ffcdd2 100%);
  border-color: #f44336;
}

.legend-color.reservation-only {
  background: linear-gradient(135deg, #fff3e0 0%, #ffe0b2 100%);
  border-color: #ff9800;
}

.legend-color.winter-closed {
  background: linear-gradient(135deg, #e3f2fd 0%, #bbdefb 100%);
  border-color: #2196F3;
}

.legend-color.event {
  background: linear-gradient(135deg, #fce4ec 0%, #f8bbd0 100%);
  border-color: #E91E63;
}

/* イベントリストの色分け */
.event-item.type-open {
  border-left: 4px solid #4CAF50;
  background: #e8f5e9;
}

.event-item.type-closed {
  border-left: 4px solid #9e9e9e;
  background: #f5f5f5;
}

.event-item.type-temporary-closed {
  border-left: 4px solid #f44336;
  background: #ffebee;
}

.event-item.type-reservation-only {
  border-left: 4px solid #ff9800;
  background: #fff3e0;
}

.event-item.type-winter-closed {
  border-left: 4px solid #2196F3;
  background: #e3f2fd;
}

.event-item.type-event {
  border-left: 4px solid #E91E63;
  background: #fce4ec;
}

.event-item.type-open .event-type {
  color: #4CAF50;
  font-weight: bold;
}

.event-item.type-closed .event-type {
  color: #757575;
  font-weight: bold;
}

.event-item.type-temporary-closed .event-type {
  color: #f44336;
  font-weight: bold;
}

.event-item.type-reservation-only .event-type {
  color: #ff9800;
  font-weight: bold;
}

.event-item.type-winter-closed .event-type {
  color: #2196F3;
  font-weight: bold;
}

.event-item.type-event .event-type {
  color: #E91E63;
  font-weight: bold;
}

/* 今月のお知らせスタイル */
#event-list {
  line-height: 1.8;
}

#event-list h3 {
  color: #4CAF50;
  border-bottom: 2px solid #4CAF50;
  padding-bottom: 10px;
  margin-top: 20px;
  margin-bottom: 15px;
}

#event-list ul {
  list-style: none;
  padding-left: 0;
}

#event-list ul li {
  padding: 8px 0;
  padding-left: 25px;
  position: relative;
}

#event-list ul li::before {
  content: "✓";
  position: absolute;
  left: 0;
  color: #4CAF50;
  font-weight: bold;
}

#event-list a {
  color: #4CAF50;
  text-decoration: none;
  font-weight: bold;
}

#event-list a:hover {
  text-decoration: underline;
}

/* レスポンシブ対応 */
@media (max-width: 768px) {
  .calendar-legend {
    gap: 10px;
  }
  
  .legend-item {
    font-size: 0.85rem;
  }
  
  .legend-color {
    width: 20px;
    height: 20px;
  }
}
