/**
 * AA Events Frontend CSS.
 */

.aa-events-calendar-wrap {
	margin: 1.25rem 0;
}

/* Provide subtle horizontal scroll hint on mobile */
.aa-events-calendar-scroll {
	position: relative;
	overflow-x: auto;
	-webkit-overflow-scrolling: touch;
	padding-bottom: 0.5rem;
}

.aa-events-calendar-scroll:focus {
	outline: 2px solid #D54120;
	outline-offset: 2px;
}

/* Gradient edge indicators (hidden on large screens) */
@media (max-width: 768px) {

	.aa-events-calendar-scroll:before,
	.aa-events-calendar-scroll:after {
		content: '';
		position: absolute;
		top: 0;
		bottom: 0;
		width: 24px;
		pointer-events: none;
		z-index: 2;
	}
}

.aa-events-calendar-header {
	display: flex;
	justify-content: space-between;
	align-items: center;
	margin-bottom: 0.625rem;
}

/* Responsive header adjustments without affecting desktop */
@media (max-width: 640px) {
	.aa-events-calendar-header {
		flex-wrap: wrap;
		gap: 0.5rem 1rem;
		align-items: flex-start;
	}

	.aa-events-calendar-header>.px-4 {
		flex: 1 1 100%;
		order: 1;
		text-align: center;
		margin-bottom: 0.25rem;
	}

	.aa-events-calendar-header>.aa-events-calendar-today-link {
		order: 2;
	}

	.aa-events-calendar-header>.flex {
		order: 3;
		margin-left: auto;
	}

	.aa-events-calendar-today-btn {
		padding: 0.4rem 0.75rem;
		font-size: 0.85rem;
	}

	.aa-prev,
	.aa-next {
		font-size: 1.25rem;
		padding: 0.25rem 0.6rem;
		min-width: 2.25rem;
		text-align: center;
	}
}

.aa-events-calendar-today-btn {
	background: transparent;
	border-radius: 0.25rem;
	color: #D54120 !important;
	border: 2px solid #D54120;
	display: inline-block;
	font-weight: bold;
	padding: 0.5rem 1rem;
	text-decoration: none;

	&:hover {
		background: #eee;
	}
}

.aa-next,
.aa-prev {
	background: transparent;
	border: 2px solid #D54120;
	color: #D54120 !important;
	font-size: 1.5rem;
	font-weight: bold;
	text-decoration: none;

	&:hover {
		color: #a83218 !important;
		background: #eee;
	}
}

.aa-events-calendar {
	border-collapse: collapse;
	table-layout: fixed;
	width: 100%;

	th,
	td {
		border: 1px solid #aaa;
		padding: 0.625rem;
		text-align: left;
		vertical-align: top;
	}

	th {
		background-color: #f5f5f5;
		text-align: center;
	}

	td {
		height: 9.375rem;
	}

	.day-number {
		font-weight: bold;
		margin-bottom: 0.3125rem;
	}

	.today-cell {
		background: #A5D1E8;
		border: 4px solid #00629A;
		font-weight: bold;
	}

	/* Icon indicator for current day */
	.today-cell .day-number {
		position: relative;
	}

	.today-cell .day-number:after {
		content: '| Today';
		display: inline-block;
		margin-left: 0.25rem;
		color: #000;
		font-size: .5em;
		font-weight: 300;
		vertical-align: middle;
	}

	.events-list {
		list-style: none;
		margin: 0;
		padding: 0;
		position: relative;
		/* Base list: NO forced height or scroll; JS adds overflow class when needed */
	}

	/* Overflow state (added via JS if scrollHeight > threshold) */
	.events-list.events-list--overflow {
		max-height: 100px;
		/* Keep in sync with JS threshold */
		overflow-y: auto;
		scrollbar-width: thin;
		scrollbar-color: #D54120 #f0f0f0;
		mask-image: linear-gradient(to bottom, black 80%, transparent);
		-webkit-mask-image: linear-gradient(to bottom, black 80%, transparent);
	}

	.events-list.events-list--overflow::before {
		content: 'Scroll to see all events';
		position: sticky;
		top: 0;
		left: 0;
		display: block;
		width: 100%;
		padding: 2px 6px 4px;
		font-size: 10px;
		text-align: center;
		background: linear-gradient(to bottom, #fff, rgba(255, 255, 255, 0.75));
		color: #000;
		font-weight: 100;
		pointer-events: none;
		z-index: 2;
	}

	/* WebKit scrollbar styling (only visible if overflow) */
	.events-list.events-list--overflow::-webkit-scrollbar {
		width: 10px;
	}

	.events-list.events-list--overflow::-webkit-scrollbar-track {
		background: #f0f0f0;
		border-radius: 8px;
	}

	.events-list.events-list--overflow::-webkit-scrollbar-thumb {
		background: #D54120;
		border-radius: 8px;
		border: 2px solid #f0f0f0;
	}

	.events-list.events-list--overflow::-webkit-scrollbar-thumb:hover {
		background: #a83218;
	}

	/* (Optional) Pure CSS fallback using :has for browsers supporting it */
	.events-list:has(li:nth-child(n+11)) {
		/* Mild shadow hint if JS not executed */
		box-shadow: inset 0 -24px 16px -16px rgba(213, 65, 32, 0.25);
	}

	.events-list:focus-visible {
		outline: 2px solid #D54120;
		outline-offset: 2px;
	}

	.events-list li {
		margin-bottom: 0.3125rem;
		background: #ffffff;
		border: 1px solid #e5e5e5;
		padding: 0.25rem 0.5rem 0.25rem 0.875rem;
		position: relative;
		border-radius: 4px;
		font-size: 0.75rem;
		line-height: 1.15;
		box-shadow: 0 1px 2px rgba(0, 0, 0, 0.05);
		transition: background-color .15s ease, border-color .15s ease, box-shadow .15s ease;
	}

	.events-list li:hover,
	.events-list li:focus-within {
		background: #fff7f5;
		border-color: #D54120;
		box-shadow: 0 2px 4px rgba(0, 0, 0, 0.08);
	}
}

.aa-event-item .aa-event-details {
	border-top: 1px solid #ddd;
	margin-top: .25rem;
	padding-top: .25rem;

	div {
		margin-bottom: 0;
	}
}

/* Mobile: allow table to overflow and scroll horizontally */
@media (max-width: 768px) {
	.aa-events-calendar {
		width: auto;
		min-width: 600px;
		/* ensures columns don't collapse; adjust as needed */
		overflow-x: scroll;
	}

	/* Compact sizing for small screens */
	.aa-events-calendar th,
	.aa-events-calendar td {
		padding: 0.5rem 0.4rem;
		font-size: 0.8rem;
	}

	.aa-events-calendar td {
		height: 6rem;
	}

	.aa-events-calendar .day-number {
		font-size: 0.75rem;
		margin-bottom: 0.2rem;
	}

	.aa-events-calendar .events-list li {
		font-size: 0.65rem;
		padding: 0.2rem 0.4rem 0.2rem 0.6rem;
	}

	.aa-events-calendar .events-list li {
		white-space: nowrap;
		overflow: hidden;
		text-overflow: ellipsis;
	}
}

@media (max-width: 480px) {

	/* Extra tight for very small devices */
	.aa-events-calendar td {
		height: 5.25rem;
	}

	.aa-events-calendar .events-list li {
		font-size: 0.6rem;
	}
}

/* Focus styles for links inside events */
.aa-events-calendar .events-list a:focus-visible {
	outline: 2px solid #D54120;
	outline-offset: 2px;
}

/* Hover/focus unify for accessibility */
.aa-events-calendar .events-list li:focus-within {
	background: #fff7f5;
	border-color: #D54120;
}
