/* ==========================================================================
   Venue Availability Calendar (貸切空き状況・3ヶ月)
   ========================================================================== */

/* TimeTree iframe 埋め込み版 */
.venue-embed {
	max-width: 1100px;
	margin: 0 auto;
	background-color: #fff;
	border: 1px solid var(--color-border, #e0d8c5);
	border-radius: 12px;
	padding: 0;
	overflow: hidden;
	box-shadow: 0 4px 20px rgba(0, 0, 0, 0.08);
}

.venue-embed__frame {
	display: block;
	width: 100%;
	height: 720px;
	border: 0;
}

@media (max-width: 768px) {
	.venue-embed__frame {
		height: 600px;
	}
}

.venue-embed__note {
	max-width: 1100px;
	margin: 0.75rem auto 0;
	font-size: 0.85rem;
	color: var(--color-text-sub, #777);
	text-align: center;
}

/* 旧FullCalendar版 (互換性のため残す) */
.venue-availability {
	max-width: 1100px;
	margin: 0 auto;
	background-color: #fff;
	border: 1px solid var(--color-border);
	border-radius: 12px;
	padding: 1.5rem;
}

/* FullCalendar 全体 */
.venue-availability .fc {
	font-family: var(--font-body);
	color: var(--color-text-main);
}

/* ヘッダーツールバー（前/次ナビ） */
.venue-availability .fc .fc-toolbar.fc-header-toolbar {
	margin-bottom: 1.5rem;
	flex-wrap: wrap;
	gap: 0.75rem;
}

.venue-availability .fc .fc-toolbar-title {
	font-family: var(--font-heading);
	font-size: 1.15rem;
	color: var(--color-text-main);
	letter-spacing: 0.04em;
}

.venue-availability .fc .fc-button {
	background-color: #fff;
	border: 1px solid var(--color-border);
	color: var(--color-text-main);
	font-size: 0.85rem;
	font-weight: 600;
	padding: 0.4rem 0.9rem;
	letter-spacing: 0.03em;
	transition: all var(--transition-base);
	text-transform: none;
	box-shadow: none;
}

.venue-availability .fc .fc-button:hover:not(:disabled) {
	background-color: var(--color-accent-gold);
	border-color: var(--color-accent-gold);
	color: #1a1a1a;
}

.venue-availability .fc .fc-button:disabled {
	opacity: 0.4;
	cursor: not-allowed;
}

.venue-availability .fc .fc-button-primary:focus {
	box-shadow: 0 0 0 3px rgba(201, 168, 76, 0.25);
}

/* マルチ月レイアウト */
.venue-availability .fc .fc-multimonth {
	border: none;
	gap: 1.25rem;
}

.venue-availability .fc .fc-multimonth-month {
	border: 1px solid var(--color-border);
	border-radius: 8px;
	overflow: hidden;
	background-color: #fafafa;
}

.venue-availability .fc .fc-multimonth-title {
	font-family: var(--font-heading);
	font-size: 1.1rem;
	font-weight: 700;
	color: var(--color-text-main);
	background-color: #f0ece5;
	padding: 0.7rem 0.5rem;
	letter-spacing: 0.05em;
}

/* 予約済ピル: 12ヶ月表示で密度高くなるためコンパクト化 */
.venue-availability .fc-event.venue-availability__booked-pill .fc-event-title-container {
	overflow: hidden;
}

/* 曜日ヘッダ */
.venue-availability .fc .fc-col-header-cell {
	background-color: #f5f0eb;
	border-color: var(--color-border);
}

.venue-availability .fc .fc-col-header-cell-cushion {
	color: var(--color-text-sub);
	font-size: 0.75rem;
	font-weight: 700;
	padding: 0.4rem 0;
	text-decoration: none;
}

.venue-availability .fc .fc-day-sun .fc-col-header-cell-cushion,
.venue-availability .fc .fc-day-sun .fc-daygrid-day-number {
	color: #c00000;
}

.venue-availability .fc .fc-day-sat .fc-col-header-cell-cushion,
.venue-availability .fc .fc-day-sat .fc-daygrid-day-number {
	color: #1f4f9e;
}

/* セル */
.venue-availability .fc .fc-daygrid-day {
	background-color: #fff;
	border-color: var(--color-border);
	transition: background-color var(--transition-base);
}

.venue-availability .fc .fc-daygrid-day-frame {
	min-height: 2.6em;
	padding: 0.15rem;
}

.venue-availability .fc .fc-daygrid-day-number {
	color: var(--color-text-main);
	padding: 0.15rem 0.35rem;
	font-size: 0.85rem;
	font-weight: 500;
	text-decoration: none;
}

.venue-availability .fc .fc-day-today {
	background-color: rgba(201, 168, 76, 0.12) !important;
}

.venue-availability .fc .fc-day-today .fc-daygrid-day-number {
	color: #b88f2c;
	font-weight: 700;
}

.venue-availability .fc .fc-day-disabled {
	background-color: #f0ece5;
	opacity: 0.5;
}

/* 過去日 */
.venue-availability .fc .fc-day-past {
	background-color: #f6f3ee;
}

.venue-availability .fc .fc-day-past .fc-daygrid-day-number {
	color: rgba(0, 0, 0, 0.3);
}

/* 予約済セル背景（display: 'background' のイベント） */
.venue-availability .fc-event.venue-availability__booked-bg {
	background-color: rgba(192, 0, 0, 0.12) !important;
	border: none !important;
	opacity: 1;
}

/* 予約済ピル（小さなラベル） */
.venue-availability .fc-event.venue-availability__booked-pill {
	background-color: #c00000;
	border: none;
	color: #fff;
	font-size: 0.65rem;
	font-weight: 600;
	padding: 0.05rem 0.3rem;
	margin: 0 0.15rem 1px;
	border-radius: 3px;
	cursor: default;
}

.venue-availability .fc-event.venue-availability__booked-pill .fc-event-title {
	font-weight: 600;
	overflow: hidden;
	text-overflow: ellipsis;
}

/* 凡例 */
.venue-availability__legend {
	max-width: 1100px;
	margin: 1.5rem auto 0;
	display: flex;
	flex-wrap: wrap;
	gap: 1rem 2rem;
	justify-content: center;
	font-size: 0.9rem;
	color: var(--color-text-main);
}

.venue-availability__legend-item {
	display: inline-flex;
	align-items: center;
	gap: 0.5rem;
}

.venue-availability__legend-cell {
	width: 20px;
	height: 20px;
	border: 1px solid var(--color-border);
	border-radius: 3px;
	display: inline-block;
}

.venue-availability__legend-cell--free {
	background-color: #fff;
}

.venue-availability__legend-cell--booked {
	background-color: rgba(192, 0, 0, 0.12);
	border-color: rgba(192, 0, 0, 0.25);
	position: relative;
}

.venue-availability__legend-cell--booked::after {
	content: '';
	position: absolute;
	left: 2px;
	right: 2px;
	bottom: 2px;
	height: 5px;
	background-color: #c00000;
	border-radius: 2px;
}

/* CTA */
.venue-availability__cta {
	margin-top: 2.5rem;
	text-align: center;
}

.venue-availability__cta p {
	color: var(--color-text-sub);
	margin-bottom: 1.25rem;
}

/* レスポンシブ */
@media (max-width: 1024px) {
	.venue-availability .fc .fc-multimonth {
		grid-template-columns: 1fr 1fr !important;
	}
}

@media (max-width: 640px) {
	.venue-availability {
		padding: 0.75rem;
	}

	.venue-availability .fc .fc-multimonth {
		grid-template-columns: 1fr !important;
	}

	.venue-availability .fc .fc-multimonth-month {
		max-width: 420px;
		margin: 0 auto;
	}

	.venue-availability .fc .fc-daygrid-day-number {
		font-size: 0.8rem;
		padding: 0.1rem 0.25rem;
	}

	.venue-availability .fc-event.venue-availability__booked-pill {
		font-size: 0.6rem;
		padding: 0.05rem 0.2rem;
	}
}
