/**
 * Seat Picker - Frontend Styles
 *
 * @package SH_Seats
 */

/* Container */
.sh-seat-picker {
	max-width: 100%;
	margin: 2rem 0;
}

.sh-seat-picker__header {
	margin-bottom: 1.5rem;
}

.sh-seat-picker__title {
	font-size: 1.5rem;
	font-weight: 600;
	margin: 0 0 0.5rem;
}

/* Stage */
.sh-seat-picker__stage {
	background: var(--sh-color-grey-border, #ccc);
	color: #666;
	text-align: center;
	padding: 0.75rem 2rem;
	margin-bottom: 1.5rem;
	border-radius: 4px 4px 0 0;
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: 0.1em;
}

/* Venue Map */
.sh-seat-picker__map {
	position: relative;
	border: 1px solid var(--sh-color-grey-border, #ccc);
	border-radius: 4px;
	padding: 1rem;
	background: #fafafa;
	height: 65vh;
	min-height: 350px;
	max-height: 700px;
	overflow: hidden;
}

.sh-seat-picker__map svg {
	display: block;
	margin: 0 auto;
}

/* Sections */
.sh-seat-picker__section {
	margin-bottom: 1.5rem;
}

.sh-seat-picker__section-name {
	font-weight: 600;
	margin-bottom: 0.5rem;
	color: #333;
}

.sh-seat-picker__section-price {
	font-size: 0.875rem;
	color: #666;
	margin-left: 0.5rem;
}

/* Rows */
.sh-seat-picker__row {
	display: flex;
	align-items: center;
	justify-content: center;
	margin-bottom: 0.25rem;
}

.sh-seat-picker__row-label {
	width: 2rem;
	text-align: center;
	font-weight: 500;
	color: #666;
	font-size: 0.75rem;
}

/* SVG Seat Picker Map */
.sh-seat-picker__svg {
	width: 100%;
	height: 100%;
	touch-action: none;
	cursor: grab;
}

.sh-seat-picker__svg:active {
	cursor: grabbing;
}

/* Zoom Controls */
.sh-seat-picker__controls {
	position: absolute;
	top: 0.5rem;
	right: 0.5rem;
	display: flex;
	flex-direction: column;
	gap: 2px;
	z-index: 10;
	pointer-events: auto;
}

.sh-seat-picker__zoom-btn {
	width: 32px;
	height: 32px;
	border: 1px solid #ccc;
	background: #fff;
	border-radius: 4px;
	font-size: 18px;
	line-height: 1;
	cursor: pointer;
	display: flex;
	align-items: center;
	justify-content: center;
	color: #333;
	padding: 0;
}

.sh-seat-picker__zoom-btn:hover {
	background: #f0f0f0;
	border-color: #999;
}

/* Seats (SVG fills) */
.sh-seat {
	cursor: pointer;
	transition: opacity 0.15s ease, fill 0.15s ease;
}

.sh-seat:hover {
	opacity: 0.85;
	filter: brightness(1.15);
}

/* Seat States — SVG fill colors */
.sh-seat--available {
	fill: var(--sh-seat-color, var(--sh-seat-color-available, #4CAF50));
}

.sh-seat--available:hover {
	fill: var(--sh-seat-color, #43A047);
	filter: brightness(0.9);
}

.sh-seat--selected {
	fill: var(--sh-seat-color-selected, #2196F3);
	stroke: var(--sh-color-primary, #115cb2);
	stroke-width: 2;
}

.sh-seat--locked {
	fill: var(--sh-seat-color-locked, #FFC107);
	cursor: not-allowed;
}

.sh-seat--locked:hover {
	opacity: 1;
	filter: none;
}

.sh-seat--sold {
	fill: var(--sh-seat-color-sold, #9E9E9E);
	cursor: not-allowed;
}

.sh-seat--sold:hover {
	opacity: 1;
	filter: none;
}

.sh-seat--blocked {
	fill: var(--sh-seat-color-blocked, #424242);
	cursor: not-allowed;
}

.sh-seat--accessible {
	/* Accessible seats render as circles */
}

.sh-seat--wheelchair {
	/* Wheelchair seats render as wider rounded rectangles (pill shape) */
	stroke: #fff;
	stroke-width: 1;
}

/* Tooltip */
.sh-seat-picker__tooltip {
	position: absolute;
	background: rgba(20, 20, 30, 0.95);
	color: #fff;
	padding: 10px 14px;
	border-radius: 8px;
	font-size: 13px;
	font-weight: 400;
	line-height: 1.4;
	pointer-events: none;
	white-space: nowrap;
	z-index: 100;
	box-shadow: 0 6px 20px rgba(0, 0, 0, 0.3);
	letter-spacing: 0.01em;
	min-width: 120px;
}

.sh-tooltip__location {
	display: flex;
	flex-direction: column;
	gap: 1px;
	margin-bottom: 4px;
}

.sh-tooltip__section {
	font-size: 11px;
	text-transform: uppercase;
	letter-spacing: 0.06em;
	color: rgba(255, 255, 255, 0.6);
	font-weight: 600;
}

.sh-tooltip__seat {
	font-size: 14px;
	font-weight: 600;
}

.sh-tooltip__type {
	display: inline-block;
	font-size: 10px;
	text-transform: uppercase;
	letter-spacing: 0.04em;
	padding: 2px 6px;
	border-radius: 3px;
	background: rgba(255, 255, 255, 0.15);
	margin-bottom: 4px;
	font-weight: 600;
}

.sh-tooltip__type--accessible { background: #2196F350; color: #90CAF9; }
.sh-tooltip__type--companion { background: #2196F350; color: #90CAF9; }
.sh-tooltip__type--wheelchair { background: #2196F350; color: #90CAF9; }

.sh-tooltip__price {
	font-size: 16px;
	font-weight: 700;
	color: #4CAF50;
	margin-top: 2px;
}

.sh-tooltip__status {
	font-size: 11px;
	color: rgba(255, 255, 255, 0.5);
	margin-top: 2px;
}

/* Legend */
.sh-seat-picker__legend {
	display: flex;
	flex-wrap: wrap;
	gap: 1rem;
	margin-top: 1.5rem;
	padding: 1rem;
	background: #f5f5f5;
	border-radius: 4px;
}

.sh-seat-picker__legend-item {
	display: flex;
	align-items: center;
	gap: 0.5rem;
	font-size: 0.875rem;
}

.sh-seat-picker__legend-icon {
	width: 20px;
	height: 20px;
	border-radius: 4px 4px 0 0;
}

.sh-seat-picker__legend-icon--selected {
	background: var(--sh-seat-color-selected, #2196F3);
}

.sh-seat-picker__legend-icon--locked {
	background: var(--sh-seat-color-locked, #FFC107);
}

.sh-seat-picker__legend-icon--sold {
	background: var(--sh-seat-color-sold, #9E9E9E);
}

/* Selection Summary */
.sh-seat-picker__summary {
	margin-top: 1.5rem;
	padding: 1rem;
	background: white;
	border: 1px solid var(--sh-color-grey-border, #ccc);
	border-radius: 4px;
}

.sh-seat-picker__selected-seats {
	margin-bottom: 1rem;
}

.sh-seat-picker__selected-label {
	font-weight: 600;
	margin-bottom: 0.5rem;
}

.sh-seat-picker__selected-list {
	display: flex;
	flex-wrap: wrap;
	gap: 0.5rem;
}

.sh-seat-picker__selected-item {
	background: var(--sh-color-primary, #115cb2);
	color: white;
	padding: 0.375rem 0.75rem;
	border-radius: 4px;
	font-size: 0.875rem;
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 0.5rem;
}

.sh-seat-picker__selected-info {
	display: flex;
	align-items: center;
	gap: 0.5rem;
	min-width: 0;
}

.sh-seat-picker__selected-name {
	white-space: nowrap;
	overflow: hidden;
	text-overflow: ellipsis;
}

.sh-seat-picker__selected-price {
	opacity: 0.85;
	font-weight: 600;
	white-space: nowrap;
}

.sh-seat-picker__selected-remove {
	cursor: pointer;
	opacity: 0.7;
}

.sh-seat-picker__selected-remove:hover {
	opacity: 1;
}

.sh-seat-picker__subtotal {
	font-size: 1.25rem;
	font-weight: 600;
	margin-bottom: 1rem;
}

.sh-seat-picker__add-to-cart {
	display: block;
	width: 100%;
	max-width: 300px;
	padding: 0.75rem 2rem;
	font-size: 1rem;
	font-weight: 600;
	background: var(--sh-color-primary, #115cb2);
	color: #fff;
	border: none;
	border-radius: 4px;
	cursor: pointer;
}

.sh-seat-picker__add-to-cart:hover:not(:disabled) {
	opacity: 0.9;
}

.sh-seat-picker__add-to-cart:disabled {
	opacity: 0.5;
	cursor: not-allowed;
}

/* Lock Timer */
.sh-seat-picker__lock-timer {
	text-align: center;
	padding: 0.5rem;
	background: #FFF3E0;
	border-radius: 4px;
	margin-top: 1rem;
	font-size: 0.875rem;
	color: #E65100;
}

.sh-seat-picker__lock-timer--warning {
	background: #FFEBEE;
	color: #C62828;
}

/* Responsive */
@media (max-width: 768px) {
	.sh-seat-picker__map {
		height: 50vh;
		min-height: 280px;
	}

	.sh-seat {
		width: 20px;
		height: 20px;
		margin: 1px;
		font-size: 8px;
	}

	.sh-seat-picker__row-label {
		width: 1.5rem;
		font-size: 0.625rem;
	}

	.sh-seat-picker__legend {
		flex-direction: column;
		gap: 0.5rem;
	}
}

/* Reserved seat count display in ticket list */
.sh-seats-count-display {
	font-weight: 600;
	font-size: 0.875rem;
	color: #555;
}

/* GA items in selected seats summary */
.sh-seat-picker__selected-item--ga {
	background: var(--sh-color-primary-light, #e3f2fd);
	color: var(--sh-color-primary, #115cb2);
	border: 1px solid var(--sh-color-primary, #115cb2);
}

/* =============================================
   Seated Event Layout — Tabs + Seat Picker
   ============================================= */

/* Tab bar */
.event__tabs {
	display: flex;
	border-bottom: 2px solid #e0e0e0;
}

.event__tab {
	flex: 1;
	padding: 12px 16px;
	font-weight: 700;
	font-size: 1rem;
	text-transform: uppercase;
	letter-spacing: 0.03em;
	background: #f5f5f5;
	border: 1px solid #e0e0e0;
	border-bottom: none;
	border-radius: 6px 6px 0 0;
	cursor: pointer;
	color: #999;
	transition: background-color 0.2s ease, color 0.2s ease;
}

.event__tab:hover {
	background: #fff;
	color: #333;
}

.event__tab--active {
	background: #fff;
	color: #333;
	border-bottom: 2px solid #fff;
	margin-bottom: -2px;
}

/* Tab content panels */
.event__tab-content {
	display: none;
}

.event__tab-content--active {
	display: block;
}

/* Seat picker column — remove top margin */
.event__seat-picker .sh-seat-picker {
	margin-top: 0;
}

/* Loading State */
.sh-seat-picker--loading {
	opacity: 0.6;
	pointer-events: none;
}

.sh-seat-picker__loader {
	text-align: center;
	padding: 2rem;
}

/* Error State */
.sh-seat-picker__error {
	background: #FFEBEE;
	color: #C62828;
	padding: 1rem;
	border-radius: 4px;
	margin-bottom: 1rem;
}

/* Toast Notifications */
.sh-seat-picker__toast {
	position: fixed;
	bottom: 20px;
	right: 20px;
	padding: 1rem 1.5rem;
	background: #333;
	color: white;
	border-radius: 4px;
	box-shadow: 0 4px 12px rgba(0, 0, 0, 0.15);
	z-index: 9999;
	animation: sh-toast-in 0.3s ease;
}

.sh-seat-picker__toast--error {
	background: #C62828;
}

.sh-seat-picker__toast--success {
	background: #2E7D32;
}

@keyframes sh-toast-in {
	from {
		opacity: 0;
		transform: translateY(20px);
	}
	to {
		opacity: 1;
		transform: translateY(0);
	}
}
