.availability-calendar-widget {
	--availability-calendar-border: #d7dee8;
	--availability-calendar-muted: #5f6c7b;
	--availability-calendar-surface: #ffffff;
	--availability-calendar-surface-soft: #f7f9fc;
	--availability-calendar-unavailable-bg: #fde8e8;
	--availability-calendar-unavailable-text: #c62828;
	--availability-calendar-today-ring: #1e88e5;
	--availability-calendar-text: #18212f;
	background: linear-gradient(180deg, #ffffff 0%, #f8fbff 100%);
	border: 1px solid var(--availability-calendar-border);
	border-radius: 18px;
	box-shadow: 0 10px 30px rgba(15, 23, 42, 0.05);
	color: var(--availability-calendar-text);
	padding: 20px;
}

.availability-calendar-widget__title {
	font-size: 1.5rem;
	margin: 0 0 16px;
}

.availability-calendar-widget__toolbar {
	align-items: center;
	display: grid;
	gap: 12px;
	grid-template-columns: 44px 1fr 44px;
	margin-bottom: 16px;
}

.availability-calendar-widget__month-label {
	font-size: 1.125rem;
	font-weight: 700;
	margin: 0;
	text-align: center;
}

.availability-calendar-widget__nav {
	align-items: center;
	background: var(--availability-calendar-surface);
	border: 1px solid var(--availability-calendar-border);
	border-radius: 999px;
	color: var(--availability-calendar-text);
	cursor: pointer;
	display: inline-flex;
	font-size: 1.5rem;
	height: 44px;
	justify-content: center;
	line-height: 1;
	padding: 0;
	transition: transform 0.15s ease, box-shadow 0.15s ease, background-color 0.15s ease;
	width: 44px;
}

.availability-calendar-widget__nav:hover,
.availability-calendar-widget__nav:focus-visible {
	background: #eef5ff;
	box-shadow: 0 0 0 3px rgba(30, 136, 229, 0.12);
	outline: none;
	transform: translateY(-1px);
}

.availability-calendar-widget__status {
	color: var(--availability-calendar-muted);
	font-size: 0.9375rem;
	min-height: 1.5em;
}

.availability-calendar-widget__status.is-error {
	color: var(--availability-calendar-unavailable-text);
}

.availability-calendar-widget__table {
	border-collapse: separate;
	border-spacing: 6px;
	table-layout: fixed;
	width: 100%;
}

.availability-calendar-widget__table th {
	color: var(--availability-calendar-muted);
	font-size: 0.875rem;
	font-weight: 700;
	padding: 8px 4px;
	text-align: center;
}

.availability-calendar-widget__day {
	background: var(--availability-calendar-surface);
	border: 1px solid var(--availability-calendar-border);
	border-radius: 14px;
	font-size: 1rem;
	height: 72px;
	padding: 10px 8px;
	position: relative;
	text-align: right;
	vertical-align: top;
}

.availability-calendar-widget__day--available {
	background: var(--availability-calendar-surface-soft);
}

.availability-calendar-widget__day--unavailable {
	background: var(--availability-calendar-unavailable-bg);
	border-color: #efb4b4;
	color: var(--availability-calendar-unavailable-text);
}

.availability-calendar-widget__day--today {
	box-shadow: inset 0 0 0 2px var(--availability-calendar-today-ring);
}

.availability-calendar-widget__day--empty {
	background: transparent;
	border: 0;
	box-shadow: none;
}

.availability-calendar-widget__day-number {
	display: inline-block;
	font-weight: 700;
}

.availability-calendar-widget__day-x {
	color: var(--availability-calendar-unavailable-text);
	display: inline-block;
	font-size: 1.35rem;
	font-weight: 800;
	left: 10px;
	line-height: 1;
	position: absolute;
	top: 10px;
}

.availability-calendar-widget__legend {
	align-items: center;
	display: flex;
	flex-wrap: wrap;
	gap: 12px 18px;
	margin-top: 18px;
}

.availability-calendar-widget__legend-item {
	align-items: center;
	display: inline-flex;
	font-size: 0.9375rem;
	gap: 8px;
}

.availability-calendar-widget__legend-swatch {
	align-items: center;
	background: var(--availability-calendar-surface-soft);
	border: 1px solid var(--availability-calendar-border);
	border-radius: 8px;
	display: inline-flex;
	font-weight: 800;
	height: 24px;
	justify-content: center;
	width: 24px;
}

.availability-calendar-widget__legend-swatch--unavailable {
	background: var(--availability-calendar-unavailable-bg);
	border-color: #efb4b4;
	color: var(--availability-calendar-unavailable-text);
}

.availability-calendar-widget__legend-swatch--today {
	box-shadow: inset 0 0 0 2px var(--availability-calendar-today-ring);
}

@media (max-width: 640px) {
	.availability-calendar-widget {
		padding: 16px;
	}

	.availability-calendar-widget__toolbar {
		grid-template-columns: 40px 1fr 40px;
	}

	.availability-calendar-widget__nav {
		height: 40px;
		width: 40px;
	}

	.availability-calendar-widget__table {
		border-spacing: 4px;
	}

	.availability-calendar-widget__table th {
		font-size: 0.75rem;
		padding: 4px 0;
	}

	.availability-calendar-widget__day {
		border-radius: 12px;
		font-size: 0.95rem;
		height: 56px;
		padding: 8px 6px;
	}

	.availability-calendar-widget__day-x {
		font-size: 1.1rem;
		left: 6px;
		top: 6px;
	}
}
