/* ============================================
   Calendar Styles
   カレンダー専用スタイルシート
============================================ */

:root {
	--calendar-primary: #333;
	--calendar-bg: #fff;
	--calendar-border: #ddd;
	--calendar-saturday: #0066cc; /* ← 土曜日の色（青系） */
	--calendar-holiday: #cc0000; /* ← 日曜・祝日の色（赤系） */
	--calendar-special: #ffd700; /* ← 特定日の色（黄色） */
	--calendar-disabled: #ccc;
}

/* Calendar Wrap */
.calendar_wrap {
	width: 100%;
	max-width: 800px;
	margin: 0 auto;
	padding: 20px;
}

.calendar_container {
	background: var(--calendar-bg);
	border: 1px solid var(--calendar-border);
	border-radius: 8px;
	padding: 20px;
	box-shadow: 0 2px 8px rgba(0, 0, 0, 0.1);
}

/* Calendar Header */
.calendar_header {
	display: flex;
	justify-content: space-between;
	align-items: center;
	margin-bottom: 20px;
	padding-bottom: 15px;
	border-bottom: 2px solid var(--calendar-border);
}

.calendar_title {
	font-size: 24px;
	font-weight: bold;
	color: var(--calendar-primary);
	margin: 0;
}

/* Navigation Buttons */
.calendar_nav {
	display: flex;
	align-items: center;
	gap: 8px;
	padding: 8px 16px;
	background: var(--color-navy);
	color: #fff;
	text-decoration: none;
	border-radius: 4px;
	font-weight: bold;
	transition: all 0.3s ease;
	-webkit-transition: all 0.3s ease;
	-moz-transition: all 0.3s ease;
}

.calendar_nav:hover {
	background: #00569e;
	transform: translateY(-2px);
	-webkit-transform: translateY(-2px);
	-moz-transform: translateY(-2px);
}

.calendar_nav.disabled {
	background: var(--calendar-disabled);
	color: #999;
	cursor: not-allowed;
	pointer-events: none; /* ← これが重要 */
}

.calendar_nav.disabled:hover {
	transform: none;
	-webkit-transform: none;
	-moz-transform: none;
}

.arrow {
	font-size: 18px;
	line-height: 1;
}

.nav_text {
	font-size: 14px;
}

/* Calendar Table */
.calendar_table {
	width: 100%;
	border-collapse: collapse;
	table-layout: fixed;
}

.calendar_th {
	padding: 12px 8px;
	text-align: center;
	font-weight: bold;
	background: #f5f5f5;
	border: 1px solid var(--calendar-border);
	font-size: 14px;
	color: #ccc; /* ← 薄いグレー */
}

.calendar_th--sun {
	color: var(--calendar-holiday); /* ← 日曜日ヘッダー */
}

.calendar_th--sat {
	color: var(--calendar-saturday); /* ← 土曜日ヘッダー */
}

.calendar_td {
	padding: 12px 8px;
	text-align: center;
	border: 1px solid var(--calendar-border);
	vertical-align: top;
	min-height: 80px;
	position: relative;
}

.calendar_td--empty {
	background: #fafafa;
}

/* 土曜日 */
.calendar_td--saturday {
	background: var(--color-yellow); /* ← 黄色背景 */
	border: 2px solid #ffcc66; /* ← 薄いオレンジ枠線 */
}

.calendar_td--saturday .calendar_day {
	color: var(--calendar-saturday); /* ← 青文字 */
	font-weight: bold;
}

/* 日曜日・祝日 */
.calendar_td--holiday {
	background: var(--color-yellow); /* ← 黄色背景 */
	border: 2px solid #ffcc66; /* ← 薄いオレンジ枠線 */
}

.calendar_td--holiday .calendar_day {
	color: var(--calendar-holiday); /* ← 赤文字 */
	font-weight: bold;
}

/* 特定日（黄色） */
.calendar_td--special {
	background: var(--color-yellow); /* ← 黄色背景 */
	border: 2px solid #ffcc66; /* ← 薄いオレンジ枠線 */
}

.calendar_td--special .calendar_day {
	color: #333; /* ← 濃いグレー文字 */
	font-weight: bold;
}

/* 日付表示 */
.calendar_day {
	display: block;
	font-size: 18px;
	font-weight: bold;
	margin-bottom: 4px;
	color: #ccc; /* ← 平日は薄いグレー（土日祝は個別に上書き） */
}

/* 祝日名表示 */
.holiday_name {
	display: block;
	font-size: 11px;
	color: var(--calendar-holiday);
	margin-top: 4px;
	line-height: 1.3;
}

/* カレンダー凡例 */
.calendar_legend {
	display: flex;
	justify-content: flex-start;
	align-items: center;
	margin-top: 20px;
	padding: 10px 0;
}

.legend_item {
	display: flex;
	align-items: center;
	gap: 8px;
	margin-right: 20px;
}

.legend_box {
	display: inline-block;
	width: 30px;
	height: 24px;
	border-radius: 4px;
}

.legend_box--special {
	background: var(--color-yellow);
	border: 2px solid #ffcc66;
}

.legend_text {
	font-size: 14px;
	color: var(--calendar-primary);
	font-weight: bold;
}

/* レスポンシブ対応 */
@media screen and (max-width: 768px) {
	.calendar_wrap {
		padding: 10px;
	}
	
	.calendar_container {
		padding: 15px;
	}
	
	.calendar_title {
		font-size: 20px;
	}
	
	.calendar_nav {
		padding: 6px 12px;
		font-size: 12px;
	}
	
	.nav_text {
		display: none; /* ← スマホでは矢印のみ表示 */
	}
	
	.calendar_th,
	.calendar_td {
		padding: 8px 4px;
		font-size: 12px;
	}
	
	.calendar_day {
		font-size: 16px;
	}
	
	.holiday_name {
		font-size: 10px;
	}
}

@media screen and (max-width: 480px) {
	.calendar_title {
		font-size: 18px;
	}
	
	.calendar_th,
	.calendar_td {
		padding: 6px 2px;
		font-size: 11px;
	}
	
	.calendar_day {
		font-size: 14px;
	}
	
	.holiday_name {
		font-size: 9px;
	}
}