.react-calendar {
  width: 350px;
  max-width: 100%;
  background: white;
  border: 1px solid #a0a096;
  font-family: Arial, Helvetica, sans-serif;
  line-height: 1.125em;
}

.react-calendar--doubleView {
  width: 700px;
}

.react-calendar--doubleView .react-calendar__viewContainer {
  display: flex;
  margin: -0.5em;
}

.react-calendar--doubleView .react-calendar__viewContainer > * {
  width: 50%;
  margin: 0.5em;
}

.react-calendar,
.react-calendar *,
.react-calendar *:before,
.react-calendar *:after {
  -moz-box-sizing: border-box;
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
}

.react-calendar button {
  margin: 0;
  border: 0;
  outline: none;
}

.react-calendar button:enabled:hover {
  cursor: pointer;
}

.react-calendar__navigation {
  display: flex;
  height: 44px;
  margin-bottom: 1em;
}

.react-calendar__navigation button {
  min-width: 44px;
  background: none;
}

.react-calendar__navigation button:disabled {
  background-color: #f0f0f0;
}

.react-calendar__navigation button:enabled:hover,
.react-calendar__navigation button:enabled:focus {
  background-color: #e6e6e6;
}

.react-calendar__month-view__weekdays {
  text-align: center;
  text-transform: uppercase;
  font: inherit;
  font-size: 0.75em;
  font-weight: bold;
}

.react-calendar__month-view__weekdays__weekday {
  padding: 0.5em;
}

.react-calendar__month-view__weekNumbers .react-calendar__tile {
  display: flex;
  align-items: center;
  justify-content: center;
  font: inherit;
  font-size: 0.75em;
  font-weight: bold;
}

.react-calendar__month-view__days__day--weekend {
  color: #d10000;
}

.react-calendar__month-view__days__day--neighboringMonth,
.react-calendar__decade-view__years__year--neighboringDecade,
.react-calendar__century-view__decades__decade--neighboringCentury {
  color: #757575;
}

.react-calendar__year-view .react-calendar__tile,
.react-calendar__decade-view .react-calendar__tile,
.react-calendar__century-view .react-calendar__tile {
  padding: 2em 0.5em;
}

.react-calendar__tile {
  max-width: 100%;
  padding: 10px 6.6667px;
  background: none;
  text-align: center;
  line-height: 16px;
  font: inherit;
  font-size: 0.833em;
}

.react-calendar__tile:disabled {
  background-color: #f0f0f0;
  color: #ababab;
}

.react-calendar__month-view__days__day--neighboringMonth:disabled,
.react-calendar__decade-view__years__year--neighboringDecade:disabled,
.react-calendar__century-view__decades__decade--neighboringCentury:disabled {
  color: #cdcdcd;
}

.react-calendar__tile:enabled:hover,
.react-calendar__tile:enabled:focus {
  background-color: #e6e6e6;
}

.react-calendar__tile--now {
  background: #ffff76;
}

.react-calendar__tile--now:enabled:hover,
.react-calendar__tile--now:enabled:focus {
  background: #ffffa9;
}

.react-calendar__tile--hasActive {
  background: #76baff;
}

.react-calendar__tile--hasActive:enabled:hover,
.react-calendar__tile--hasActive:enabled:focus {
  background: #a9d4ff;
}

.react-calendar__tile--active {
  background: #006edc;
  color: white;
}

.react-calendar__tile--active:enabled:hover,
.react-calendar__tile--active:enabled:focus {
  background: #1087ff;
}

.react-calendar--selectRange .react-calendar__tile--hover {
  background-color: #e6e6e6;
}

/* React WooCommerce Booking Calendar — card UI (RTL + peach palette) */

:root {
	--rwcbc-peach: #e8a598;
	--rwcbc-peach-hover: #df9588;
	--rwcbc-peach-soft: #fdeee9;
	--rwcbc-brown: #4a3228;
	--rwcbc-brown-muted: #8b7a72;
	--rwcbc-gray-day: #a89890;
	--rwcbc-border: #ebe4df;
	--rwcbc-card-bg: #ffffff;
	--rwcbc-page-bg: #faf8f6;
}

.rwcbc-product-calendar-wrapper {
	margin: 24px 0;
	clear: both;
}

/* Outer card */
.rwcbc-card {
	max-width: 420px;
	margin: 0 auto;
	padding: 22px 20px 20px;
	background: var(--rwcbc-card-bg);
	border-radius: 22px;
	box-shadow: 0 4px 24px rgba(74, 50, 40, 0.06);
	font-family: inherit;
	color: var(--rwcbc-brown);
}

.rwcbc-card--rtl {
	direction: rtl;
	text-align: right;
}

/* Header: title block + icon */
.rwcbc-card__header {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 16px;
	margin-bottom: 18px;
}

.rwcbc-card--rtl .rwcbc-card__header {
	flex-direction: row-reverse;
}

.rwcbc-card__title {
	margin: 0 0 4px;
	font-size: 1.25rem;
	font-weight: 700;
	line-height: 1.3;
	color: var(--rwcbc-brown);
}

.rwcbc-card__subtitle {
	margin: 0;
	font-size: 0.9rem;
	color: var(--rwcbc-brown-muted);
	font-weight: 400;
	line-height: 1.4;
}

.rwcbc-card__icon {
	flex-shrink: 0;
	width: 52px;
	height: 52px;
	display: flex;
	align-items: center;
	justify-content: center;
	background: var(--rwcbc-peach-soft);
	border-radius: 14px;
	color: #c45c4a;
}

/* Calendar inner shell */
.rwcbc-card__calendar-shell {
	background: var(--rwcbc-card-bg);
	border: 1px solid var(--rwcbc-border);
	border-radius: 18px;
	padding: 12px 10px 14px;
	margin-bottom: 14px;
}

.rwcbc-calendar.react-calendar {
	width: 100%;
	border: none;
	font-family: inherit;
}

/* Navigation: circular arrows + centered month */
.rwcbc-card .react-calendar__navigation {
	display: flex;
	align-items: center;
	height: 44px;
	margin-bottom: 8px;
	padding: 0 4px;
}

.rwcbc-card--rtl .react-calendar__navigation {
	flex-direction: row-reverse;
}

.rwcbc-card .react-calendar__navigation__label {
	flex-grow: 1;
	text-align: center;
	font-weight: 600;
	font-size: 1rem;
	color: var(--rwcbc-brown);
	pointer-events: none;
}

.rwcbc-card .react-calendar__navigation__arrow {
	flex-shrink: 0;
	width: 40px;
	height: 40px;
	min-width: 40px;
	border-radius: 50%;
	border: 1px solid var(--rwcbc-border);
	background: var(--rwcbc-card-bg);
	color: var(--rwcbc-brown);
	font-size: 22px;
	line-height: 1;
	display: flex;
	align-items: center;
	justify-content: center;
	padding: 0;
	cursor: pointer;
	transition: background 0.15s ease, border-color 0.15s ease;
}

.rwcbc-card .react-calendar__navigation__arrow:enabled:hover,
.rwcbc-card .react-calendar__navigation__arrow:enabled:focus {
	background: var(--rwcbc-peach-soft);
	border-color: var(--rwcbc-peach);
}

.rwcbc-card .react-calendar__navigation__arrow[disabled] {
	opacity: 0.35;
	cursor: default;
}

/* Weekday row — RTL visual order (Sat … Sun) */
.rwcbc-card--rtl .react-calendar__month-view__weekdays {
	display: flex;
	flex-direction: row-reverse;
}

.rwcbc-card .react-calendar__month-view__weekdays {
	text-align: center;
	text-transform: none;
	font-weight: 600;
	font-size: 0.72rem;
	color: var(--rwcbc-brown-muted);
	margin-bottom: 4px;
}

.rwcbc-card .react-calendar__month-view__weekdays__weekday {
	padding: 6px 0;
}

.rwcbc-card .react-calendar__month-view__weekdays__weekday abbr {
	text-decoration: none;
}

/* Day grid RTL */
.rwcbc-card--rtl .react-calendar__month-view__days {
	display: flex !important;
	flex-direction: row-reverse;
	flex-wrap: wrap;
}

.rwcbc-card .react-calendar__month-view__days__day--neighboringMonth {
	color: #d4ccc7;
	opacity: 0.85;
}

.rwcbc-card .react-calendar__tile {
	max-width: 100%;
	aspect-ratio: 1;
	max-height: 44px;
	padding: 0;
	background: none;
	text-align: center;
	line-height: 1;
	font-size: 0.9rem;
	font-weight: 500;
	color: var(--rwcbc-gray-day);
	border-radius: 50%;
	display: flex;
	align-items: center;
	justify-content: center;
	margin: 2px auto;
}

.rwcbc-card .react-calendar__tile:enabled:hover,
.rwcbc-card .react-calendar__tile:enabled:focus {
	background-color: var(--rwcbc-peach-soft);
	color: var(--rwcbc-brown);
}

.rwcbc-card .react-calendar__tile--now {
	background: transparent;
	color: var(--rwcbc-brown);
	font-weight: 700;
}

/* Available future days — subtle */
.rwcbc-card .react-calendar__tile.rwcbc-available {
	background: transparent;
	color: var(--rwcbc-gray-day);
	font-weight: 500;
}

.rwcbc-card .react-calendar__tile.rwcbc-available:enabled:hover {
	background: var(--rwcbc-peach-soft);
	color: var(--rwcbc-brown);
}

/* Unavailable / past / reserved */
.rwcbc-card .react-calendar__tile.rwcbc-unavailable {
	background: #f5f3f1 !important;
	color: #c9c0bb !important;
	cursor: not-allowed;
	font-weight: 400;
}

.rwcbc-card .react-calendar__tile:disabled {
	background: #f5f3f1 !important;
	color: #c9c0bb !important;
}

/* Selected — peach circle */
.rwcbc-card .react-calendar__tile.rwcbc-selected {
	background: var(--rwcbc-peach) !important;
	color: var(--rwcbc-brown) !important;
	font-weight: 700;
	box-shadow: none;
}

.rwcbc-card .react-calendar__tile.rwcbc-selected:enabled:hover,
.rwcbc-card .react-calendar__tile.rwcbc-selected:enabled:focus {
	background: var(--rwcbc-peach-hover) !important;
}

/* Legend */
.rwcbc-card__legend {
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 22px;
	margin-bottom: 14px;
	font-size: 0.85rem;
	color: var(--rwcbc-brown);
}

.rwcbc-card--rtl .rwcbc-card__legend {
	flex-direction: row-reverse;
}

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

.rwcbc-legend-dot {
	width: 12px;
	height: 12px;
	border-radius: 50%;
	flex-shrink: 0;
}

.rwcbc-legend-dot--available {
	background: var(--rwcbc-brown);
}

.rwcbc-legend-dot--unavailable {
	background: #fff;
	border: 2px solid #d5ccc6;
}

.rwcbc-card__selected-line {
	margin: 0 0 12px;
	font-size: 0.9rem;
	color: var(--rwcbc-brown-muted);
	text-align: center;
}

.rwcbc-card--rtl .rwcbc-card__selected-line {
	text-align: center;
}

/* Primary CTA */
.rwcbc-card__cta {
	width: 100%;
	display: block;
	padding: 14px 20px;
	margin: 0 0 12px;
	border: none;
	border-radius: 16px;
	background: var(--rwcbc-peach);
	color: #fff;
	font-size: 1rem;
	font-weight: 700;
	cursor: pointer;
	transition: background 0.2s ease, opacity 0.2s ease;
	box-shadow: 0 2px 12px rgba(232, 165, 152, 0.35);
}

.rwcbc-card__cta:hover:not(:disabled) {
	background: var(--rwcbc-peach-hover);
}

.rwcbc-card__cta:disabled {
	opacity: 0.55;
	cursor: not-allowed;
	box-shadow: none;
}

/* Error */
.rwcbc-error {
	margin-top: 12px;
	padding: 12px 14px;
	background: #fdeef0;
	border: 1px solid #f5c2c7;
	border-radius: 12px;
	color: #7a2a32;
	font-size: 0.9rem;
}

.rwcbc-error p {
	margin: 0;
}

@media (max-width: 480px) {
	.rwcbc-card {
		padding: 18px 14px;
		border-radius: 18px;
	}

	.rwcbc-card__title {
		font-size: 1.1rem;
	}

	.rwcbc-card .react-calendar__tile {
		max-height: 40px;
		font-size: 0.82rem;
	}
}

