/**
 * XtraWeb Shipping Calendar — shortcode'y.
 * Układ: jeden miesiąc widoczny, nawigacja strzałkami.
 */

.xtraweb-cal {
	--xtw-brand: #9C5C1D;
	--xtw-brand-dark: #7A4615;
	--xtw-brand-soft: #F5EBDC;
	--xtw-bg: #FFFFFF;
	--xtw-border: #E8DFD2;
	--xtw-muted: #B8A990;
	--xtw-text: #3A2A18;
	--xtw-blocked: #C97D7D;
	--xtw-blocked-bg: #FBEEEE;

	font-family: inherit;
	color: var(--xtw-text);
	background: var(--xtw-bg);
	border: 1px solid var(--xtw-border);
	border-radius: 12px;
	padding: 16px;
	width: 100%;
	box-sizing: border-box;
}

.xtraweb-cal *,
.xtraweb-cal *::before,
.xtraweb-cal *::after {
	box-sizing: border-box;
}

/* === Nagłówek "Najwcześniejsza wysyłka" === */
.xtraweb-cal__earliest {
	background: var(--xtw-brand-soft);
	border-radius: 8px;
	padding: 10px 14px;
	margin-bottom: 14px;
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: 6px;
	font-size: 13px;
	line-height: 1.4;
}

.xtraweb-cal__earliest-label {
	color: var(--xtw-text);
	font-weight: 500;
}

.xtraweb-cal__earliest-date {
	color: var(--xtw-brand-dark);
	font-weight: 700;
}

.xtraweb-cal__earliest--none {
	background: #f5f5f5;
	color: var(--xtw-muted);
	font-style: italic;
}

/* === Nagłówek nawigacji (tytuł + strzałki) === */
.xtraweb-cal__header {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 10px;
	margin-bottom: 12px;
	padding-bottom: 10px;
	border-bottom: 1px solid var(--xtw-border);
}

.xtraweb-cal__title {
	flex: 1;
	text-align: center;
	font-size: 15px;
	font-weight: 600;
	color: var(--xtw-brand);
	text-transform: capitalize;
	letter-spacing: 0.2px;
}

.xtraweb-cal__nav {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 32px;
	height: 32px;
	border-radius: 50%;
	background-color: var(--xtw-brand-soft);
	color: var(--xtw-brand);
	border: none;
	cursor: pointer;
	padding: 0;
	font-size: 18px;
	line-height: 1;
	font-weight: 700;
	transition: background-color 0.15s ease, color 0.15s ease, opacity 0.15s ease;
	flex-shrink: 0;
}

.xtraweb-cal__nav:hover:not(:disabled) {
	background-color: var(--xtw-brand);
	color: #fff;
}

.xtraweb-cal__nav:focus-visible {
	outline: 2px solid var(--xtw-brand);
	outline-offset: 2px;
}

.xtraweb-cal__nav:disabled {
	opacity: 0.35;
	cursor: not-allowed;
}

.xtraweb-cal__nav span {
	display: inline-block;
	line-height: 1;
	margin-top: -2px; /* optical centering glyphów strzałek */
}

/* === Slajdy miesięcy === */
.xtraweb-cal__slides {
	position: relative;
}

.xtraweb-cal-month {
	display: none;
}

.xtraweb-cal-month.is-active {
	display: block;
}

.xtraweb-cal-month__count {
	font-size: 11px;
	color: var(--xtw-muted);
	font-weight: 500;
	text-align: center;
	margin-bottom: 8px;
	text-transform: lowercase;
	letter-spacing: 0.2px;
}

/* === Tabela kalendarza === */
.xtraweb-cal-month__table {
	width: 100%;
	border-collapse: separate;
	border-spacing: 2px;
	margin: 0;
}

.xtraweb-cal-month__table th {
	font-size: 10px;
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: 0.5px;
	color: var(--xtw-muted);
	padding: 4px 0;
	text-align: center;
	background: transparent;
	border: none;
}

.xtraweb-cal-month__table td {
	padding: 0;
	border: none;
	text-align: center;
	background: transparent;
}

/* === Komórki dni === */
.xtraweb-cal-day {
	height: 36px;
	width: 36px;
}

.xtraweb-cal-day span {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 32px;
	height: 32px;
	margin: 0 auto;
	border-radius: 50%;
	font-size: 13px;
	font-weight: 500;
	line-height: 1;
}

.xtraweb-cal-day--empty {
	visibility: hidden;
}

.xtraweb-cal-day--past span {
	color: var(--xtw-muted);
	opacity: 0.35;
	text-decoration: line-through;
}

.xtraweb-cal-day--unavailable span {
	color: var(--xtw-muted);
	opacity: 0.55;
}

.xtraweb-cal-day--blocked span {
	color: var(--xtw-blocked);
	background-color: var(--xtw-blocked-bg);
	text-decoration: line-through;
	font-weight: 600;
}

.xtraweb-cal-day--available span {
	color: #fff;
	background-color: var(--xtw-brand);
	font-weight: 600;
}

/* === Legenda === */
.xtraweb-cal-legend {
	display: flex;
	flex-wrap: wrap;
	gap: 12px;
	font-size: 12px;
	color: var(--xtw-text);
	padding: 12px 0 0;
	margin-top: 12px;
	border-top: 1px solid var(--xtw-border);
}

.xtraweb-cal-legend__item {
	display: inline-flex;
	align-items: center;
	gap: 5px;
}

.xtraweb-cal-legend__dot {
	display: inline-block;
	width: 10px;
	height: 10px;
	border-radius: 50%;
	flex-shrink: 0;
}

.xtraweb-cal-legend__dot--available {
	background-color: var(--xtw-brand);
}

.xtraweb-cal-legend__dot--blocked {
	background-color: var(--xtw-blocked-bg);
	border: 1px solid var(--xtw-blocked);
}

.xtraweb-cal-legend__dot--unavailable {
	background-color: var(--xtw-muted);
	opacity: 0.45;
}

/* === Stan błędu === */
.xtraweb-cal__error {
	padding: 12px 16px;
	background: #fef2f2;
	border-radius: 8px;
	color: #c93030;
	font-size: 14px;
}

/* === Responsive === */
@media (max-width: 380px) {
	.xtraweb-cal {
		padding: 12px;
		max-width: 100%;
	}

	.xtraweb-cal-day {
		width: 32px;
		height: 32px;
	}

	.xtraweb-cal-day span {
		width: 28px;
		height: 28px;
		font-size: 12px;
	}

	.xtraweb-cal__title {
		font-size: 14px;
	}
}
