/* ============================================================
   CULPA WYPOŻYCZALNIA — Duration-first booking calendar
   Pattern inspirowany Airbnb "I'm Flexible" (2 mld użyć od 2021).
   3 kroki:
     1) chip wyboru długości
     2) klik dnia startu w kalendarzu
     3) podsumowanie + CTA
   "Inne" → custom range mode (2-click + hover preview).
   ============================================================ */

culpa-calendar {
	--cal-primary: #D50000;
	--cal-primary-deep: #B30000;
	--cal-primary-soft: #FFEAEA;
	--cal-primary-mid: rgba(213, 0, 0, 0.12);
	--cal-text: #181818;
	--cal-text-soft: #4a4a4a;
	--cal-text-mute: #888888;
	--cal-text-faint: #c8c8c8;
	--cal-bg: #ffffff;
	--cal-bg-soft: #FAFAFA;
	--cal-bg-mute: #F2F2F2;
	--cal-border: #EAEAEA;
	--cal-amber: #f0a020;
	--cal-amber-bg: #fff4dc;
	--cal-cell-size: 44px;
	--cal-cell-gap: 4px;
	--cal-radius: 8px;
	--cal-radius-cell: 8px;

	display: block;
	font-family: "Jost", -apple-system, BlinkMacSystemFont, sans-serif;
	color: var(--cal-text);
	font-feature-settings: "lnum", "tnum";
}

@media (min-width: 768px) {
	culpa-calendar {
		--cal-cell-size: 48px;
	}
}

/* === Reset wszystkich buttonów w kalendarzu — Elementor Kit globalnie ustawia
       body button { background: var(--e-global-color-primary) = #D50000 } co
       nadpisuje nasze klasy. Tutaj zerujemy default. === */
culpa-calendar button,
culpa-calendar input[type="button"],
culpa-calendar input[type="submit"] {
	background: transparent;
	color: inherit;
	border: 0;
	box-shadow: none;
	background-image: none;
	-webkit-appearance: none;
	appearance: none;
	font-family: inherit;
}
culpa-calendar button:hover,
culpa-calendar button:focus,
culpa-calendar input[type="button"]:hover,
culpa-calendar input[type="submit"]:hover {
	background: transparent;
	color: inherit;
	box-shadow: none;
}

/* ============================================================
   Container
   ============================================================ */

.culpa-cal {
	background: var(--cal-bg);
	border: 1px solid var(--cal-border);
	border-radius: var(--cal-radius);
	overflow: hidden;
	box-shadow: 0 1px 3px rgba(0,0,0,0.04);
}

.culpa-cal--error {
	padding: 24px;
	color: var(--cal-primary);
	font-style: italic;
	text-align: center;
}

.culpa-cal__step {
	padding: 16px 20px;
}

.culpa-cal__step + .culpa-cal__step {
	border-top: 1px solid var(--cal-border);
}

.culpa-cal__step-label {
	font-size: 12px;
	font-weight: 700;
	color: var(--cal-text-mute);
	text-transform: uppercase;
	letter-spacing: 0.1em;
	margin-bottom: 12px;
}

/* ============================================================
   STEP 1 — Chips
   ============================================================ */

.culpa-cal__chips {
	display: flex;
	flex-wrap: wrap;
	gap: 8px;
}

culpa-calendar .culpa-cal__chip {
	display: inline-flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	gap: 2px;
	padding: 8px 14px;
	min-height: 40px;
	font-family: inherit;
	font-size: 13px;
	font-weight: 500;
	color: var(--cal-text) !important;
	background: var(--cal-bg) !important;
	border: 1px solid var(--cal-border) !important;
	border-radius: 100px;
	cursor: pointer;
	transition: all 180ms cubic-bezier(0.4, 0, 0.2, 1);
	position: relative;
	flex: 0 0 auto;
	box-shadow: none !important;
	background-image: none !important;
}

culpa-calendar .culpa-cal__chip:hover,
culpa-calendar .culpa-cal__chip:focus {
	border-color: var(--cal-primary) !important;
	color: var(--cal-primary-deep) !important;
	background: var(--cal-primary-soft) !important;
}

culpa-calendar .culpa-cal__chip.is-active {
	background: var(--cal-text) !important;
	color: #fff !important;
	border-color: var(--cal-text) !important;
	font-weight: 600;
	box-shadow: 0 2px 8px rgba(0,0,0,0.15) !important;
}

.culpa-cal__chip-hint {
	font-size: 9px !important;
	font-weight: 500;
	letter-spacing: 0.06em;
	text-transform: uppercase;
	color: var(--cal-text-mute);
	margin-top: 1px;
	line-height: 1;
}

culpa-calendar .culpa-cal__chip.is-active .culpa-cal__chip-hint {
	color: rgba(255, 255, 255, 0.75);
}

culpa-calendar .culpa-cal__chip:hover .culpa-cal__chip-hint,
culpa-calendar .culpa-cal__chip:focus .culpa-cal__chip-hint {
	color: var(--cal-primary-deep);
}

.culpa-cal__chip-label {
	display: block;
	line-height: 1.1;
}

.culpa-cal__chip-hint {
	display: block;
	font-size: 10px;
	font-weight: 500;
	letter-spacing: 0.04em;
	text-transform: uppercase;
	color: var(--cal-text-mute);
	margin-top: 2px;
	line-height: 1;
}

.culpa-cal__chip.is-active .culpa-cal__chip-hint {
	color: rgba(255,255,255,0.65);
}

.culpa-cal__chip:focus-visible {
	outline: 2px solid var(--cal-primary);
	outline-offset: 2px;
}

/* ============================================================
   STEP 2 — Calendar
   ============================================================ */

.culpa-cal__step--calendar {
	padding: 0;
}

.culpa-cal__step--calendar > .culpa-cal__step-label {
	padding: 16px 20px 0;
}

.culpa-cal__step--calendar[data-locked="true"] {
	opacity: 0.55;
	pointer-events: none;
	background: var(--cal-bg-soft);
}

.culpa-cal__step--calendar[data-locked="true"] .culpa-cal__nav,
.culpa-cal__step--calendar[data-locked="true"] .culpa-cal__day {
	cursor: not-allowed;
}

culpa-calendar .culpa-cal__step--calendar > .culpa-cal__step-label {
	display: flex;
	align-items: center;
	gap: 8px;
	padding: 14px 20px;
	background: var(--cal-bg-soft);
	border-radius: 0;
	border-bottom: 1px solid var(--cal-border);
	margin-bottom: 0;
	transition: background 200ms ease;
}

.culpa-cal__step-label-text {
	font-style: normal;
	font-weight: 600;
	letter-spacing: 0;
	text-transform: none;
	font-size: 14px;
	color: var(--cal-text);
	display: flex;
	align-items: center;
	gap: 8px;
}

.culpa-cal__step-label-text::before {
	content: "";
	display: inline-block;
	width: 8px;
	height: 8px;
	border-radius: 50%;
	background: var(--cal-primary);
	flex-shrink: 0;
	box-shadow: 0 0 0 3px rgba(213, 0, 0, 0.18);
}

/* W trybie „teraz wybierz koniec" — żółte tło + pulsująca kropka, żeby user wiedział że trzeba zrobić drugi klik */
culpa-calendar .culpa-cal__step--calendar:has(.culpa-cal__step-label-text[data-state="mid"]) > .culpa-cal__step-label,
culpa-calendar .culpa-cal__step-label-text[data-state="mid"] {
	background: #FFF8E1;
}

.culpa-cal__step-label-text[data-state="mid"] {
	color: #8a5410;
	background: transparent;
}

.culpa-cal__step-label-text[data-state="mid"]::before {
	background: #f0a020;
	box-shadow: 0 0 0 3px rgba(240, 160, 32, 0.25);
	animation: culpa-cal-dot-pulse 1.4s ease-in-out infinite;
}

@keyframes culpa-cal-dot-pulse {
	0%, 100% { transform: scale(1); }
	50%      { transform: scale(1.3); }
}

.culpa-cal__header {
	display: flex;
	align-items: center;
	justify-content: space-between;
	padding: 12px 20px;
	border-bottom: 1px solid var(--cal-border);
	background: var(--cal-bg);
}

.culpa-cal__title {
	font-size: 16px;
	font-weight: 600;
	letter-spacing: -0.01em;
	color: var(--cal-text);
	text-transform: capitalize;
}

culpa-calendar .culpa-cal__nav {
	width: 36px;
	height: 36px;
	border: 1px solid var(--cal-border) !important;
	background: var(--cal-bg) !important;
	border-radius: 50%;
	font-size: 16px;
	color: var(--cal-text) !important;
	cursor: pointer;
	font-family: inherit;
	transition: all 200ms cubic-bezier(0.4, 0, 0.2, 1);
	display: inline-flex;
	align-items: center;
	justify-content: center;
	padding: 0;
	box-shadow: none !important;
	background-image: none !important;
}

culpa-calendar .culpa-cal__nav:hover,
culpa-calendar .culpa-cal__nav:focus {
	background: var(--cal-text) !important;
	color: #fff !important;
	border-color: var(--cal-text) !important;
}

/* Loading */
.culpa-cal__loading {
	padding: 48px 20px;
	text-align: center;
	color: var(--cal-text-mute);
	font-size: 14px;
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 12px;
}

.culpa-cal__spinner {
	width: 28px;
	height: 28px;
	border: 2px solid var(--cal-border);
	border-top-color: var(--cal-primary);
	border-radius: 50%;
	animation: culpa-cal-spin 0.7s linear infinite;
}

@keyframes culpa-cal-spin {
	to { transform: rotate(360deg); }
}

/* Weekdays */
.culpa-cal__weekdays {
	display: grid;
	grid-template-columns: repeat(7, 1fr);
	gap: var(--cal-cell-gap);
	padding: 12px 12px 0;
}

.culpa-cal__weekday {
	padding: 6px 0;
	font-size: 10px;
	font-weight: 700;
	color: var(--cal-text-mute);
	text-align: center;
	text-transform: uppercase;
	letter-spacing: 0.12em;
}

.culpa-cal__weekday--weekend {
	color: var(--cal-primary);
}

/* Days grid */
.culpa-cal__days {
	display: grid;
	grid-template-columns: repeat(7, 1fr);
	gap: var(--cal-cell-gap);
	padding: 8px 12px 12px;
}

culpa-calendar .culpa-cal__day {
	background: var(--cal-bg) !important;
	color: var(--cal-text) !important;
	border: 1px solid transparent !important;
	box-shadow: none !important;
	background-image: none !important;
	padding: 0;
	min-height: var(--cal-cell-size);
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	cursor: pointer;
	font-family: inherit;
	font-size: 15px;
	font-weight: 500;
	border-radius: var(--cal-radius-cell);
	position: relative;
	transition:
		background-color 180ms cubic-bezier(0.4, 0, 0.2, 1),
		color 180ms cubic-bezier(0.4, 0, 0.2, 1),
		border-color 180ms cubic-bezier(0.4, 0, 0.2, 1),
		transform 180ms cubic-bezier(0.4, 0, 0.2, 1),
		box-shadow 180ms cubic-bezier(0.4, 0, 0.2, 1);
	overflow: hidden;
}

.culpa-cal__day:disabled {
	cursor: not-allowed;
}

.culpa-cal__day--padding {
	background: transparent;
	cursor: default;
	pointer-events: none;
}

.culpa-cal__day-num {
	display: block;
	font-variant-numeric: tabular-nums;
	line-height: 1.1;
}

/* === Status colors === */

culpa-calendar .culpa-cal__day--free {
	background: var(--cal-bg) !important;
	color: var(--cal-text) !important;
}

culpa-calendar .culpa-cal__day--free:hover:not(:disabled),
culpa-calendar .culpa-cal__day--free:focus:not(:disabled) {
	background: var(--cal-primary-soft) !important;
	color: var(--cal-primary-deep) !important;
	border-color: var(--cal-primary) !important;
	transform: translateY(-1px);
	box-shadow: 0 2px 8px rgba(213, 0, 0, 0.18) !important;
}

culpa-calendar .culpa-cal__day--pending {
	background: var(--cal-amber-bg);
	color: #b87100;
	border-color: rgba(240, 160, 32, 0.25);
}

culpa-calendar .culpa-cal__day--approved {
	background: var(--cal-primary);
	color: #fff;
	border-color: var(--cal-primary);
	font-weight: 600;
}

culpa-calendar .culpa-cal__day--blocked {
	background: var(--cal-bg-mute);
	color: var(--cal-text-mute);
	background-image:
		repeating-linear-gradient(
			135deg,
			transparent 0,
			transparent 5px,
			rgba(0,0,0,0.06) 5px,
			rgba(0,0,0,0.06) 10px
		);
	border-color: var(--cal-border);
}

culpa-calendar .culpa-cal__day--past:not(.culpa-cal__day--padding) {
	color: var(--cal-text-faint);
	background: var(--cal-bg);
	cursor: not-allowed;
	opacity: 0.5;
}

/* Free day, ale invalid jako start (range by kolidował) → wygaszony */
culpa-calendar .culpa-cal__day--invalid-start {
	color: var(--cal-text-faint);
	background: var(--cal-bg-soft);
	cursor: not-allowed;
}

.culpa-cal__day--invalid-start:hover {
	background: var(--cal-bg-soft) !important;
	transform: none !important;
	box-shadow: none !important;
	border-color: transparent !important;
	color: var(--cal-text-faint) !important;
}

/* Status icon dot */
.culpa-cal__day-icon {
	position: absolute;
	top: 4px;
	right: 4px;
	width: 6px;
	height: 6px;
	border-radius: 50%;
	pointer-events: none;
}

.culpa-cal__day-icon--pending  { background: var(--cal-amber); }
.culpa-cal__day-icon--approved { background: #fff; }
.culpa-cal__day-icon--blocked  { background: #888; }

/* Today indicator */
.culpa-cal__day--today {
	font-weight: 700;
}

.culpa-cal__day--today:not(.culpa-cal__day--range-start):not(.culpa-cal__day--range-end):not(.culpa-cal__day--range-middle)::after {
	content: "";
	position: absolute;
	bottom: 5px;
	left: 50%;
	transform: translateX(-50%);
	width: 14px;
	height: 2px;
	background: var(--cal-primary);
	border-radius: 1px;
}

/* === Selection range === */

culpa-calendar .culpa-cal__day--range-start,
culpa-calendar .culpa-cal__day--range-end {
	background: var(--cal-primary) !important;
	color: #fff !important;
	border-color: var(--cal-primary) !important;
	font-weight: 700;
	box-shadow: 0 4px 14px rgba(213, 0, 0, 0.45), 0 0 0 3px rgba(213, 0, 0, 0.18);
	z-index: 2;
	animation: culpa-cal-pop 280ms cubic-bezier(0.34, 1.56, 0.64, 1);
	transform: scale(1.02);
}

/* Tylko start zaznaczony (czeka na end) — pulsujący border żeby user widział „teraz wybierz koniec" */
culpa-calendar .culpa-cal__day--range-start:not(.culpa-cal__day--range-end):where(:not([class*='range-end'])) {
	animation: culpa-cal-pop 280ms cubic-bezier(0.34, 1.56, 0.64, 1), culpa-cal-pulse 1.6s ease-in-out 280ms infinite;
}

@keyframes culpa-cal-pulse {
	0%, 100% { box-shadow: 0 4px 14px rgba(213, 0, 0, 0.45), 0 0 0 3px rgba(213, 0, 0, 0.18); }
	50%      { box-shadow: 0 4px 14px rgba(213, 0, 0, 0.45), 0 0 0 6px rgba(213, 0, 0, 0.22); }
}

culpa-calendar .culpa-cal__day--range-middle {
	background: var(--cal-primary-mid) !important;
	color: var(--cal-primary-deep) !important;
	border-color: transparent !important;
	font-weight: 600;
	border-radius: 0 !important;
}

@keyframes culpa-cal-pop {
	0%   { transform: scale(0.85); }
	50%  { transform: scale(1.05); }
	100% { transform: scale(1); }
}

.culpa-cal__day--range-start {
	border-top-right-radius: 0 !important;
	border-bottom-right-radius: 0 !important;
}

.culpa-cal__day--range-end {
	border-top-left-radius: 0 !important;
	border-bottom-left-radius: 0 !important;
}

.culpa-cal__day--range-start.culpa-cal__day--range-end {
	border-radius: var(--cal-radius-cell) !important;
}

/* OD/DO label */
.culpa-cal__day-label {
	position: absolute;
	bottom: 4px;
	left: 50%;
	transform: translateX(-50%);
	font-size: 9px;
	font-weight: 700;
	letter-spacing: 0.1em;
	text-transform: uppercase;
	color: rgba(255,255,255,0.85);
	line-height: 1;
}

.culpa-cal__day--range-start .culpa-cal__day-num,
.culpa-cal__day--range-end .culpa-cal__day-num {
	margin-bottom: 2px;
}

/* Hover preview (custom mode) */
.culpa-cal__day--preview-start,
.culpa-cal__day--preview-end {
	background: var(--cal-primary-mid) !important;
	color: var(--cal-primary-deep) !important;
	border: 1.5px dashed var(--cal-primary) !important;
	font-weight: 600;
}

.culpa-cal__day--preview-middle {
	background: var(--cal-primary-mid) !important;
	color: var(--cal-primary-deep) !important;
	border-top: 1.5px dashed var(--cal-primary) !important;
	border-bottom: 1.5px dashed var(--cal-primary) !important;
	border-left: 0 !important;
	border-right: 0 !important;
	font-weight: 600;
	border-radius: 0 !important;
}

.culpa-cal__day--preview-start { border-radius: var(--cal-radius-cell) 0 0 var(--cal-radius-cell) !important; border-right-style: solid !important; }
.culpa-cal__day--preview-end   { border-radius: 0 var(--cal-radius-cell) var(--cal-radius-cell) 0 !important; border-left-style: solid !important; }

.culpa-cal__day--preview-conflict {
	background: rgba(255, 200, 200, 0.4) !important;
	color: #888 !important;
	border: 1px dashed #cc6666 !important;
	border-radius: 0 !important;
	cursor: not-allowed !important;
}

/* === Legend === */
.culpa-cal__legend {
	display: flex;
	flex-wrap: wrap;
	gap: 14px;
	padding: 12px 20px;
	background: var(--cal-bg-soft);
	border-top: 1px solid var(--cal-border);
	font-size: 11px;
	color: var(--cal-text-mute);
}

.culpa-cal__legend-item {
	display: inline-flex;
	align-items: center;
	gap: 6px;
}

.culpa-cal__swatch {
	display: inline-block;
	width: 12px;
	height: 12px;
	border-radius: 3px;
	border: 1px solid rgba(0,0,0,0.1);
}

.culpa-cal__swatch--free     { background: #fff; }
.culpa-cal__swatch--pending  { background: var(--cal-amber-bg); border-color: var(--cal-amber); }
.culpa-cal__swatch--approved { background: var(--cal-primary); border-color: var(--cal-primary); }
.culpa-cal__swatch--blocked  {
	background: var(--cal-bg-mute);
	background-image: repeating-linear-gradient(135deg, transparent 0 3px, rgba(0,0,0,0.15) 3px 6px);
}

/* ============================================================
   STEP 3 — Summary card
   ============================================================ */

.culpa-cal__step--summary {
	display: flex;
	align-items: center;
	gap: 16px;
	padding: 16px 20px;
	background: linear-gradient(180deg, #fff 0%, #fafafa 100%);
}

.culpa-cal__sum-block {
	flex: 1;
	display: flex;
	flex-direction: column;
	gap: 2px;
	min-width: 0;
}

.culpa-cal__sum-label {
	font-size: 10px;
	font-weight: 700;
	color: var(--cal-text-mute);
	text-transform: uppercase;
	letter-spacing: 0.12em;
}

.culpa-cal__sum-date {
	font-size: 18px;
	font-weight: 600;
	color: var(--cal-text);
	letter-spacing: -0.01em;
	font-variant-numeric: tabular-nums;
	line-height: 1.2;
}

.culpa-cal__sum-arrow {
	font-size: 16px;
	color: var(--cal-primary);
	font-weight: 700;
	flex-shrink: 0;
	margin-top: 14px;
}

.culpa-cal__sum-duration {
	display: inline-block;
	padding: 6px 12px;
	background: var(--cal-primary);
	color: #fff;
	font-size: 12px;
	font-weight: 700;
	letter-spacing: 0.04em;
	text-transform: uppercase;
	border-radius: 100px;
	margin-top: 14px;
	white-space: nowrap;
	flex-shrink: 0;
}

.culpa-cal__sum-duration:empty { display: none; }

culpa-calendar .culpa-cal__sum-clear {
	width: 32px;
	height: 32px;
	border: 1px solid var(--cal-border);
	background: var(--cal-bg);
	border-radius: 50%;
	color: var(--cal-text-mute);
	cursor: pointer;
	font-size: 18px;
	line-height: 1;
	font-family: inherit;
	margin-top: 8px;
	flex-shrink: 0;
	transition: all 180ms ease;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	padding: 0;
}

culpa-calendar .culpa-cal__sum-clear:hover,
culpa-calendar .culpa-cal__sum-clear:focus {
	background: var(--cal-primary);
	color: #fff;
	border-color: var(--cal-primary);
	transform: rotate(90deg);
}

@media (max-width: 540px) {
	.culpa-cal__step--summary {
		gap: 10px;
		padding: 14px 16px;
	}
	.culpa-cal__sum-date { font-size: 15px; }
	.culpa-cal__sum-arrow { display: none; }
	.culpa-cal__sum-duration { font-size: 10px; padding: 4px 10px; }
}

/* ============================================================
   Reduced motion
   ============================================================ */

@media (prefers-reduced-motion: reduce) {
	.culpa-cal__day,
	.culpa-cal__chip,
	.culpa-cal__nav,
	.culpa-cal__sum-clear {
		transition: none !important;
		animation: none !important;
	}
	.culpa-cal__spinner { animation: none; }
}
