/**
 * Calendar WP - Material Design 3 calendar styles.
 *
 * Translates the Tailwind-based reference design to plain CSS.
 * Month view on desktop (>= 768px), week strip on mobile.
 */

/* ------------------------------------------------------------------ */
/*  M3 colour tokens                                                  */
/* ------------------------------------------------------------------ */
:root {
	--cwp-c-bg: #fff9ef;
	--cwp-c-surface: #fff9ef;
	--cwp-c-surface-low: #faf3e7;
	--cwp-c-surface-container: #f4ede1;
	--cwp-c-surface-high: #eee7dc;
	--cwp-c-surface-highest: #e8e2d6;
	--cwp-c-surface-lowest: #ffffff;
	--cwp-c-on-surface: #1e1b15;
	--cwp-c-on-surface-var: #4c4637;
	--cwp-c-primary: #5b4b00;
	--cwp-c-primary-fixed: #fde17a;
	--cwp-c-primary-container: #776300;
	--cwp-c-on-primary: #ffffff;
	--cwp-c-error: #ba1a1a;
	--cwp-c-outline: #7d7765;
	--cwp-c-outline-var: #cec6b2;
}

/* ------------------------------------------------------------------ */
/*  Material Symbols                                                  */
/* ------------------------------------------------------------------ */
.calendar-wp .material-symbols-outlined {
	font-variation-settings: 'FILL' 0, 'wght' 400, 'GRAD' 0, 'opsz' 24;
}

/* ------------------------------------------------------------------ */
/*  Wrapper                                                           */
/* ------------------------------------------------------------------ */
.calendar-wp {
	font-family: 'Be Vietnam Pro', sans-serif;
	color: var(--cwp-c-on-surface);
	max-width: 80rem;
	margin: 0 auto;
}

/* ------------------------------------------------------------------ */
/*  Header                                                            */
/* ------------------------------------------------------------------ */
.cwp-cal-header {
	display: flex;
	flex-direction: column;
	gap: 1.5rem;
	margin-bottom: 2rem;
}

.cwp-cal-header-left {
	flex: 1 1 auto;
}

.cwp-cal-header-today-label {
	display: block;
	font-size: 0.875rem;
	font-weight: 700;
	letter-spacing: 0.1em;
	text-transform: uppercase;
	color: var(--cwp-c-primary);
	margin-bottom: 0.5rem;
}

.cwp-cal-header-title {
	font-family: 'Plus Jakarta Sans', sans-serif;
	font-size: 2rem;
	font-weight: 800;
	color: var(--cwp-c-on-surface);
	margin: 0;
	line-height: 1.2;
}

.cwp-cal-nav {
	display: flex;
	align-items: center;
	gap: 0;
	background: var(--cwp-c-surface-high);
	border-radius: 9999px;
	padding: 0.25rem;
	align-self: flex-start;
}

.cwp-cal-nav-btn {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 2.75rem;
	height: 2.75rem;
	border: none;
	background: transparent;
	border-radius: 9999px;
	cursor: pointer;
	color: var(--cwp-c-on-surface);
	transition: background 0.15s;
}

.cwp-cal-nav-btn:hover {
	background: var(--cwp-c-surface-highest);
}

.cwp-cal-nav-btn:active {
	transform: scale(0.9);
}

.cwp-cal-nav-btn .material-symbols-outlined {
	font-size: 1.25rem;
}

.cwp-cal-nav-label {
	font-weight: 700;
	padding: 0 1rem;
	cursor: pointer;
	user-select: none;
}

/* ------------------------------------------------------------------ */
/*  Legend                                                             */
/* ------------------------------------------------------------------ */
.cwp-cal-legend {
	display: flex;
	flex-wrap: wrap;
	gap: 0.75rem;
	margin-bottom: 2rem;
}

.cwp-cal-legend-item {
	display: flex;
	align-items: center;
	gap: 0.5rem;
	padding: 0.5rem 1rem;
	border-radius: 9999px;
}

.cwp-cal-legend-dot {
	width: 0.75rem;
	height: 0.75rem;
	border-radius: 9999px;
	flex-shrink: 0;
}

.cwp-cal-legend-label {
	font-size: 0.875rem;
	font-weight: 600;
	text-transform: capitalize;
	white-space: nowrap;
}

/* ------------------------------------------------------------------ */
/*  Grid wrapper                                                      */
/* ------------------------------------------------------------------ */
.cwp-cal-grid-wrap {
	background: var(--cwp-c-surface-lowest);
	border-radius: 1rem;
	overflow: hidden;
	box-shadow: 0 25px 50px -12px rgba(0, 0, 0, 0.12);
}

/* ------------------------------------------------------------------ */
/*  Weekday header                                                    */
/* ------------------------------------------------------------------ */
.cwp-cal-weekdays {
	display: grid;
	grid-template-columns: repeat(7, minmax(0, 1fr));
	background: var(--cwp-c-surface-container);
}

.cwp-cal-wd {
	padding: 1rem 0;
	text-align: center;
	font-weight: 700;
	font-size: 0.875rem;
	color: var(--cwp-c-on-surface-var);
}

.cwp-cal-wd--weekend {
	color: var(--cwp-c-error);
}

/* ------------------------------------------------------------------ */
/*  Day grid                                                          */
/* ------------------------------------------------------------------ */
.cwp-cal-days {
	display: grid;
	grid-template-columns: repeat(7, minmax(0, 1fr));
}

.cwp-cal-cell {
	background: var(--cwp-c-surface-lowest);
	min-height: 140px;
	padding: 1rem;
	display: flex;
	flex-direction: column;
	gap: 0.25rem;
	position: relative;
	border-top: 1px solid var(--cwp-c-outline-var);
	border-right: 1px solid var(--cwp-c-outline-var);
	transition: background 0.15s;
	overflow: hidden;
	min-width: 0;
}

.cwp-cal-cell:nth-child(7n) {
	border-right: none;
}

.cwp-cal-cell:hover {
	background: var(--cwp-c-surface-low);
}

.cwp-cal-cell--outside {
	background: rgba(250, 243, 231, 0.5);
}

.cwp-cal-cell--weekend {
	background: var(--cwp-c-surface-low);
}

.cwp-cal-cell--today {
	background: var(--cwp-c-surface-high);
	box-shadow: inset 0 0 0 4px var(--cwp-c-primary-fixed);
}

.cwp-cal-cell--bl { border-bottom-left-radius: 1rem; }
.cwp-cal-cell--br { border-bottom-right-radius: 1rem; }

/* ------------------------------------------------------------------ */
/*  Today badge                                                       */
/* ------------------------------------------------------------------ */
.cwp-cal-today-badge {
	position: absolute;
	top: 0.5rem;
	right: 0.5rem;
	background: var(--cwp-c-primary);
	color: var(--cwp-c-on-primary);
	font-size: 0.625rem;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: -0.05em;
	padding: 0.125rem 0.5rem;
	border-radius: 9999px;
}

/* ------------------------------------------------------------------ */
/*  Day number                                                        */
/* ------------------------------------------------------------------ */
.cwp-cal-num {
	font-size: 1.5rem;
	font-weight: 700;
	color: var(--cwp-c-on-surface-var);
	line-height: 1;
}

.cwp-cal-num--today {
	font-size: 1.875rem;
	font-weight: 800;
	color: var(--cwp-c-primary);
}

.cwp-cal-num--weekend {
	color: rgba(186, 26, 26, 0.6);
}

/* ------------------------------------------------------------------ */
/*  Event pill                                                        */
/* ------------------------------------------------------------------ */
.cwp-cal-pill {
	display: block;
	padding: 0.375rem 0.5rem;
	border-radius: 0.5rem;
	text-decoration: none;
	transition: opacity 0.15s;
	overflow: hidden;
	flex-shrink: 0;
	min-width: 0;
}

.cwp-cal-pill:hover {
	opacity: 0.8;
}

.cwp-cal-pill-text {
	font-size: 0.75rem;
	font-weight: 700;
	white-space: nowrap;
	overflow: hidden;
	text-overflow: ellipsis;
	display: block;
}

.cwp-cal-more {
	font-size: 0.75rem;
	font-weight: 600;
	color: var(--cwp-c-on-surface-var);
	padding: 0.25rem 0.5rem;
}

/* ------------------------------------------------------------------ */
/*  Loading                                                           */
/* ------------------------------------------------------------------ */
.cwp-cal-loading {
	display: flex;
	justify-content: center;
	padding: 4rem;
	color: var(--cwp-c-on-surface-var);
}

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

.cwp-cal-spin {
	animation: cwp-spin 1s linear infinite;
	font-size: 2rem;
}

/* ------------------------------------------------------------------ */
/*  Week view                                                         */
/* ------------------------------------------------------------------ */
.cwp-cal-week {
	display: grid;
	grid-template-columns: repeat(7, 1fr);
	gap: 0.5rem;
}

.cwp-cal-week-day {
	background: var(--cwp-c-surface-lowest);
	border: 1px solid var(--cwp-c-outline-var);
	border-radius: 1rem;
	padding: 0.75rem;
	min-height: 120px;
	display: flex;
	flex-direction: column;
	gap: 0.5rem;
}

.cwp-cal-week-day--today {
	border-color: var(--cwp-c-primary);
	box-shadow: inset 0 0 0 3px var(--cwp-c-primary-fixed);
	background: var(--cwp-c-surface-high);
}

.cwp-cal-week-day--weekend {
	background: var(--cwp-c-surface-low);
}

.cwp-cal-week-label {
	font-size: 0.75rem;
	font-weight: 700;
	text-transform: uppercase;
	color: var(--cwp-c-on-surface-var);
}

.cwp-cal-week-num {
	font-size: 1.25rem;
	font-weight: 700;
	color: var(--cwp-c-on-surface-var);
}

.cwp-cal-week-num--today {
	font-size: 1.5rem;
	font-weight: 800;
	color: var(--cwp-c-primary);
}

.cwp-cal-week-ev {
	display: block;
	padding: 0.5rem;
	border-radius: 0.5rem;
	text-decoration: none;
	font-size: 0.75rem;
	font-weight: 600;
	transition: opacity 0.15s;
}

.cwp-cal-week-ev:hover {
	opacity: 0.8;
}

.cwp-cal-week-ev-time {
	font-weight: 700;
}

.cwp-cal-week-ev-title {
	font-weight: 600;
}

/* ------------------------------------------------------------------ */
/*  Month transition animations                                       */
/* ------------------------------------------------------------------ */
@keyframes cwp-slide-from-right {
	from { opacity: 0; transform: translateX(40px); }
	to   { opacity: 1; transform: translateX(0); }
}

@keyframes cwp-slide-from-left {
	from { opacity: 0; transform: translateX(-40px); }
	to   { opacity: 1; transform: translateX(0); }
}

@keyframes cwp-fade-in {
	from { opacity: 0; transform: scale(0.98); }
	to   { opacity: 1; transform: scale(1); }
}

.cwp-cal-enter-next {
	animation: cwp-slide-from-right 0.35s cubic-bezier(0.22, 1, 0.36, 1);
}

.cwp-cal-enter-prev {
	animation: cwp-slide-from-left 0.35s cubic-bezier(0.22, 1, 0.36, 1);
}

.cwp-cal-enter-today {
	animation: cwp-fade-in 0.35s cubic-bezier(0.22, 1, 0.36, 1);
}

/* ------------------------------------------------------------------ */
/*  Bottom week navigation (mobile only)                              */
/* ------------------------------------------------------------------ */
.cwp-cal-week-nav {
	display: none;
}

/* ------------------------------------------------------------------ */
/*  Responsive: desktop (>= 1024px)                                   */
/* ------------------------------------------------------------------ */
@media (min-width: 1024px) {
	.cwp-cal-header {
		flex-direction: row;
		justify-content: space-between;
		align-items: flex-end;
	}

	.cwp-cal-header-title {
		font-size: 2.25rem;
	}

	.cwp-cal-grid-wrap {
		display: block;
	}

	.cwp-cal-week {
		display: none;
	}
}

/* ------------------------------------------------------------------ */
/*  Responsive: tablet & mobile (< 1024px)                            */
/* ------------------------------------------------------------------ */
@media (max-width: 1023px) {
	.cwp-cal-grid-wrap {
		display: none;
	}

	.cwp-cal-week {
		display: grid;
		grid-template-columns: 1fr;
		gap: 0.375rem;
	}

	.cwp-cal-week-day {
		min-height: auto;
	}

	.cwp-cal-week-nav {
		display: flex;
		align-items: center;
		justify-content: center;
		background: var(--cwp-c-surface-high);
		border-radius: 9999px;
		padding: 0.25rem;
		margin-top: 1.5rem;
	}
}

@media (max-width: 480px) {
	.cwp-cal-header-title {
		font-size: 1.5rem;
	}
}
