/**
 * Avian Commons Map – [avian-commons-map] shortcode
 * Filter bar (top), base image, SVG pins, tooltip, category panel.
 */

 .avian-commons-map__container {
	width: 100%;
	margin: 0 auto;
	background: transparent;
 }

 .avian-commons-map__container .map-layers {
	width: 100%;
 }

.avian-commons-map__container .avian-commons-map__inner {
	display: flex;
	flex-direction: column;
}

.avian-commons-map__container .avian-commons-map-key {
	order: 0;
	width: 100%;
	padding: 1rem 0;
}

.avian-commons-map-key__list {
	display: flex;
	flex-wrap: wrap;
	justify-content: flex-start;
	align-items: flex-start;
	gap: 0.5rem 0.75rem;
	margin: 0;
	padding: 0;
	list-style: none;
}

.avian-commons-map-key__btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 0.35rem;
	padding: 0.5rem 1.25rem;
	font-size: 0.9375rem;
	font-weight: 600;
	color: #333;
	background: transparent;
	border: 2px solid;
	border-radius: 999px;
	cursor: pointer;
	transition: all 0.3s ease;
}

.avian-commons-map-key__btn:hover {
	background: #f5f5f5;
}

/* All: color-5 (dark grey) */
.avian-commons-map-key__btn--all {
	border-color: var(--theme-palette-color-5);
	color: var(--theme-palette-color-5);
}

.avian-commons-map-key__btn--all.is-active {
	background: var(--theme-palette-color-5);
	border-color: var(--theme-palette-color-5);
	color: #fff;
}

/* Services: color-6 */
.avian-commons-map-key__btn--services {
	border-color: var(--theme-palette-color-6);
}

.avian-commons-map-key__btn--services .avian-commons-map-key__swatch {
	background: var(--theme-palette-color-6);
}

.avian-commons-map-key__btn--services.is-active {
	background: var(--theme-palette-color-6);
	border-color: var(--theme-palette-color-6);
	color: #fff;
}

.avian-commons-map-key__btn--services.is-active .avian-commons-map-key__swatch {
	background: #fff;
}

/* Recreational Areas: color-1 */
.avian-commons-map-key__btn--recreational {
	border-color: var(--theme-palette-color-1);
}

.avian-commons-map-key__btn--recreational .avian-commons-map-key__swatch {
	background: var(--theme-palette-color-1);
}

.avian-commons-map-key__btn--recreational.is-active {
	background: var(--theme-palette-color-1);
	border-color: var(--theme-palette-color-1);
	color: #fff;
}

.avian-commons-map-key__btn--recreational.is-active .avian-commons-map-key__swatch {
	background: #fff;
}

/* Available Spaces: color-4 */
.avian-commons-map-key__btn--available {
	border-color: var(--theme-palette-color-4);
}

.avian-commons-map-key__btn--available .avian-commons-map-key__swatch {
	background: var(--theme-palette-color-4);
}

.avian-commons-map-key__btn--available.is-active {
	background: var(--theme-palette-color-4);
	border-color: var(--theme-palette-color-4);
	color: #fff;
}

.avian-commons-map-key__btn--available.is-active .avian-commons-map-key__swatch {
	background: #fff;
}

/* Operational Businesses: color-2 */
.avian-commons-map-key__btn--operational {
	border-color: var(--theme-palette-color-2);
}

.avian-commons-map-key__btn--operational .avian-commons-map-key__swatch {
	background: var(--theme-palette-color-2);
}

.avian-commons-map-key__btn--operational.is-active {
	background: var(--theme-palette-color-2);
	border-color: var(--theme-palette-color-2);
	color: #fff;
}

.avian-commons-map-key__btn--operational.is-active .avian-commons-map-key__swatch {
	background: #fff;
}

/* Future Sites: color-3 */
.avian-commons-map-key__btn--future {
	border-color: var(--theme-palette-color-3);
}

.avian-commons-map-key__btn--future .avian-commons-map-key__swatch {
	background: var(--theme-palette-color-3);
}

.avian-commons-map-key__btn--future.is-active {
	background: var(--theme-palette-color-3);
	border-color: var(--theme-palette-color-3);
	color: #fff;
}

.avian-commons-map-key__btn--future.is-active .avian-commons-map-key__swatch {
	background: #fff;
}

.avian-commons-map-key__swatch {
	width: 8px;
	height: 8px;
	border-radius: 50%;
	flex-shrink: 0;
}

/* Map layers area */
.avian-commons-map__layers {
	position: relative;
	width: 100%;
	order: 1;
}

.avian-commons-map__layers-inner {
	position: relative;
	padding-bottom: 55%;
	overflow: hidden;
}

.avian-commons-map__container .avian-commons-map__layers-inner .map-layer-image {
	position: absolute;
	inset: 0;
	width: 100%;
	height: 100%;
}

.avian-commons-map__container .avian-commons-map__layers-inner .map-layer-image img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	opacity: 0;
	transition: opacity 0.4s ease;
}

.avian-commons-map__container.map-loaded .avian-commons-map__layers-inner .map-layer-image img {
	opacity: 1;
}

/* Pins overlay */
.avian-commons-map__pins {
	position: absolute;
	inset: 0;
	pointer-events: none;
}

.avian-commons-map__pins .avian-commons-map__pin {
	pointer-events: auto;
	position: absolute;
	transform: translate(-50%, -100%);
	margin-left: 0;
	margin-top: 0;
	width: 28px;
	height: 38px;
	padding: 0;
	border: none;
	background: none;
	cursor: pointer;
	transition: transform 0.2s ease;
}

.avian-commons-map__pin:hover,
.avian-commons-map__pin.is-hovered,
.avian-commons-map__pin.is-active {
	transform: translate(-50%, -100%) scale(1.35);
	z-index: 5;
}

.avian-commons-map__pin-icon {
	width: 100%;
	height: 100%;
	display: block;
	filter: drop-shadow(0 1px 2px rgba(0, 0, 0, 0.25));
	transform-origin: top center;
}

@media (max-width: 767px) {
	.avian-commons-map__pin-icon {
		transform: scale(0.6);
	}
}

/* Pin colors by category */
.avian-commons-map__pin--services { color: var(--theme-palette-color-6); }
.avian-commons-map__pin--services .avian-commons-map__pin-icon ellipse { fill: #fff; }

.avian-commons-map__pin--recreational_areas { color: var(--theme-palette-color-1); }
.avian-commons-map__pin--recreational_areas .avian-commons-map__pin-icon ellipse { fill: #fff; }

.avian-commons-map__pin--available_spaces { color: var(--theme-palette-color-4); }
.avian-commons-map__pin--available_spaces .avian-commons-map__pin-icon ellipse { fill: #fff; }

.avian-commons-map__pin--operational_businesses { color: var(--theme-palette-color-2); }
.avian-commons-map__pin--operational_businesses .avian-commons-map__pin-icon ellipse { fill: #fff; }

.avian-commons-map__pin--future_sites { color: var(--theme-palette-color-3); }
.avian-commons-map__pin--future_sites .avian-commons-map__pin-icon ellipse { fill: #fff; }

/* Tooltip */
.avian-commons-map__tooltip {
	position: fixed;
	pointer-events: none;
	z-index: 9999;
	max-width: 280px;
	padding: 0.6rem 0.85rem;
	background: #fff;
	font-size: 0.9375rem;
	box-shadow: 0 0 20px 4px rgba(154, 161, 177, 0.15), 0 4px 80px -8px rgba(36, 40, 47, 0.25);
}

.avian-commons-map__tooltip-title {
	margin: 0 0 0.35em;
	font-weight: 700;
	text-transform: uppercase;
	font-size: 0.8125rem;
	letter-spacing: 0.02em;
}

.avian-commons-map__tooltip-list {
	margin: 0;
	padding: 0 0 0 1rem;
	list-style: none;
}

.avian-commons-map__tooltip-list li {
	position: relative;
	padding-left: 0.5rem;
	margin-bottom: 0.2em;
}

.avian-commons-map__tooltip-list li::before {
	content: "";
	position: absolute;
	left: -0.6rem;
	top: 0.7em;
	width: 4px;
	height: 4px;
	background: var(--theme-palette-color-3);
}

/* Category panel (right side, like Trail Map loops panel) */
/* Hidden by default so raw {{ }} are not visible before Vue mounts; Vue's v-show controls visibility after mount */
.avian-commons-map__container .avian-commons-panel {
	display: none;
}

.avian-commons-map__container.vue-ready .avian-commons-panel {
	display: flex;
}

.avian-commons-panel {
	position: absolute;
	top: 1rem;
	right: 1rem;
	bottom: 4rem;
	z-index: 25;
	width: 100%;
	max-width: 360px;
	background: #fff;
	padding: 1.25rem;
	max-height: 50vh;
	flex-direction: column;
}

.avian-commons-panel__title {
	flex-shrink: 0;
}

.avian-commons-panel__list {
	margin: 0;
	padding: 0;
	list-style: none;
	overflow-y: auto;
	flex: 1;
	min-height: 0;
}

.avian-commons-panel__item {
	display: block;
	width: 100%;
	padding: 0.6rem 0;
	text-align: left;
	font-size: 0.9375rem;
	font-weight: 600;
	background: none;
	border: none;
	border-bottom: 1px solid #e5e5e5;
	cursor: pointer;
	transition: background 0.2s ease;
	color: var(--theme-palette-color-5);
}

.avian-commons-panel__list li:last-child .avian-commons-panel__item {
	border-bottom: none;
}

.avian-commons-panel__item:hover {
	background: rgba(0, 0, 0, 0.04);
}

.avian-commons-panel__item.is-active {
	background: rgba(234, 137, 44, 0.1);
}

.avian-commons-panel__label {
	display: block;
	text-transform: uppercase;
	letter-spacing: 0.02em;
	font-size: 0.8125rem;
	margin-bottom: 0.25rem;
}

.avian-commons-panel__bullets {
	margin: 0;
	padding: 0 0 0 1rem;
	list-style: none;
	font-weight: 400;
	font-size: 0.8125rem;
	color: #666;
}

.avian-commons-panel__bullets li {
	position: relative;
	padding-left: 0.25rem;
	margin-bottom: 0.15rem;
}

.avian-commons-panel__bullets li::before {
	content: "";
	position: absolute;
	left: -0.6rem;
	top: 0.7em;
	width: 4px;
	height: 4px;
	background: var(--theme-palette-color-3);
}

/* Zoom controls */
.avian-commons-map__container .avian-commons-map__layers .map-controls {
	position: absolute;
	bottom: 1rem;
	left: 1rem;
	margin-top: 0;
	right: auto;
	
	display: none;
}

.avian-commons-map__container .avian-commons-map__layers .map-controls button {
	color: #fff;
}

/* Panel on mobile: same fixed bottom sheet as Trail Map loops panel */
@media (max-width: 767px) {
	.avian-commons-map-key__list {
		padding: 0 0.75rem;
	}

	.avian-commons-map-key__btn {
		padding: 0.4rem 1rem;
		font-size: 0.875rem;
	}

	.avian-commons-panel {
		position: fixed;
		left: 0;
		right: 0;
		bottom: 0;
		top: auto;
		max-width: none;
		height: 30vh;
		max-height: 30vh;
		border-radius: 12px 12px 0 0;
		box-shadow: 0 -4px 24px rgba(0, 0, 0, 0.15);
		padding: 1rem 1.25rem calc(1rem + env(safe-area-inset-bottom, 0px));
	}

	.avian-commons-panel__title {
		padding-right: 2rem;
	}

	.avian-commons-panel__list {
		-webkit-overflow-scrolling: touch;
		overscroll-behavior: contain;
		flex: 1;
		min-height: 0;
	}

	.avian-commons-panel__item {
		min-height: 48px;
		padding: 0.75rem 0;
		font-size: 1rem;
		-webkit-tap-highlight-color: transparent;
	}

	.avian-commons-panel__item:active {
		background: rgba(234, 137, 44, 0.12);
	}
}
