/* ==========================================================================
   GP Sliders - Slider Field Styles
   ========================================================================== */

/* Container */
.gps-slider {
	--gps-track-inset: 0.25rem;
	position: relative;
	width: 100%;
	height: 20px;
	touch-action: none;
	user-select: none;
}

/* Shared inset container for handles and ticks (aligns with track border-radius) */
.gps-slider__inset-container {
	position: absolute;
	top: 0;
	left: var(--gps-track-inset);
	right: var(--gps-track-inset);
	bottom: 0;
	pointer-events: none;
}

/* Track - full background bar */
.gps-slider__track {
	position: absolute;
	top: 50%;
	left: 0;
	right: 0;
	height: 0.5rem;
	transform: translateY(-50%);
	background: #ddd;
	border-radius: 0.25rem;
}

/* Fill - active/selected portion */
.gps-slider__fill {
	position: absolute;
	top: 50%;
	left: 0;
	height: 0.5rem;
	transform: translateY(-50%);
	background: var(--gf-color-primary, #204ce5 );;
	border-radius: 0.25rem;
	/* width is set via inline style from PHP */
}

/* Handle - draggable thumb */
.gps-slider__handle {
	position: absolute;
	top: 50%;
	width: 20px;
	height: 20px;
	transform: translate(-50%, -50%);
	background: #fff;
	border: 2px solid var(--gf-color-primary, #204ce5 );
	border-radius: 50%;
	cursor: pointer;
	box-shadow: 0 1px 3px rgba(0, 0, 0, 0.2);
	pointer-events: auto; /* Re-enable pointer events on handles */
	/* left position is set via inline style from PHP */
}

.gps-slider__handle:focus {
	outline: none;
	box-shadow: 0 0 0 3px rgba(0, 115, 170, 0.3);
}

/* Range mode handle modifiers - positions set via inline style from PHP */
.gps-slider__handle--min,
.gps-slider__handle--max {
	/* Positions are set dynamically */
}

/* Value display container (populated by JS) */
.gps-slider__value-display {
	margin-top: 8px;
	text-align: center;
	font-size: 14px;
}

/* Hidden inputs */
.gps-slider__input {
	position: absolute;
	opacity: 0;
	pointer-events: none;
}

/* ==========================================================================
   Value Tooltip
   ========================================================================== */

.gps-slider__tooltip {
	position: absolute;
	bottom: 100%;
	left: 50%;
	transform: translateX(-50%);
	margin-bottom: 8px;
	padding: 4px 8px;
	background: #333;
	color: #fff;
	font-size: 12px;
	line-height: 1.3;
	border-radius: 4px;
	white-space: nowrap;
	pointer-events: none;
	opacity: 0;
	visibility: hidden;
	transition: opacity 0.15s ease, visibility 0.15s ease;
	z-index: 10;
}

/* Arrow pointing down to handle */
.gps-slider__tooltip::after {
	content: '';
	position: absolute;
	top: 100%;
	left: 50%;
	transform: translateX(-50%);
	border: 5px solid transparent;
	border-top-color: #333;
}

/* Show tooltip on handle hover */
.gps-slider__handle:hover .gps-slider__tooltip {
	opacity: 1;
	visibility: visible;
}

/* Keep tooltip visible on active handle during drag */
.gps-slider__handle--active .gps-slider__tooltip {
	opacity: 1;
	visibility: visible;
}

/* ==========================================================================
   Vertical Orientation
   ========================================================================== */

.gps-slider-field--vertical .gps-slider {
	width: 20px;
	height: 200px;
}

.gps-slider-field--vertical .gps-slider__track {
	top: 0;
	bottom: 0;
	left: 50%;
	right: auto;
	width: 0.5rem;
	height: auto;
	transform: translateX(-50%);
}

.gps-slider-field--vertical .gps-slider__fill {
	top: auto;
	bottom: 0;
	left: 50%;
	width: 0.5rem;
	transform: translateX(-50%);
	/* height is set via inline style from PHP */
}

.gps-slider-field--vertical .gps-slider__handle {
	left: 50%;
	transform: translate(-50%, -50%);
	/* top position is set via inline style from PHP */
}

/* Vertical slider: Use flexbox for side-by-side layout with centered value display */
.gps-slider-field--vertical .ginput_container_gps_slider {
	display: flex;
	align-items: center;
}

.gps-slider-field--vertical .gps-slider__value-display {
	margin-top: 0;
}

/* Value Tooltip - Vertical Orientation */
.gps-slider-field--vertical .gps-slider__tooltip {
	bottom: auto;
	left: 100%;
	top: 50%;
	transform: translateY(-50%);
	margin-bottom: 0;
	margin-left: 12px;
}

.gps-slider-field--vertical .gps-slider__tooltip::after {
	top: 50%;
	left: auto;
	right: 100%;
	transform: translateY(-50%);
	border: 5px solid transparent;
	border-right-color: #333;
}

/* ==========================================================================
   Transitions
   ========================================================================== */

.gps-slider__handle {
	transition: left 0.1s ease-out, top 0.1s ease-out, box-shadow 0.15s ease;
}

.gps-slider__fill {
	transition: left 0.1s ease-out, width 0.1s ease-out, top 0.1s ease-out, height 0.1s ease-out, bottom 0.1s ease-out;
}

/* Disable transitions during active drag for immediate feedback */
.gps-slider--dragging .gps-slider__handle,
.gps-slider--dragging .gps-slider__fill {
	transition: none;
}

/* ==========================================================================
   Reduced Motion
   ========================================================================== */

@media (prefers-reduced-motion: reduce) {
	.gps-slider__handle,
	.gps-slider__fill {
		transition: none;
	}
}

/* ==========================================================================
   Tick Marks - Horizontal
   ========================================================================== */

.gps-slider__ticks {
	/* Positioning provided by .gps-slider__inset-container */
}

.gps-slider__tick {
	position: absolute;
	display: flex;
	flex-direction: column;
	align-items: center;
	transform: translateX(-50%);
}

.gps-slider__tick::before {
	content: '';
	width: 1px;
	height: 8px;
	background: #999;
	margin-top: 16px; /* Position below the track center */
}

.gps-slider__tick-label {
	margin-top: 2px;
	font-size: 11px;
	line-height: 1.2;
	color: #666;
	white-space: nowrap;
}

/* Add spacing below slider when ticks are shown */
.gps-slider-field--show-ticks .gps-slider {
	margin-bottom: 12px;
}

.gps-slider-field--show-ticks.gps-slider-field--show-tick-labels .gps-slider {
	margin-bottom: 28px;
}

/* ==========================================================================
   Tick Marks - Vertical
   ========================================================================== */

/* Vertical orientation override for inset containers */
.gps-slider-field--vertical .gps-slider__inset-container {
	top: var(--gps-track-inset);
	bottom: var(--gps-track-inset);
	left: 0;
	right: 0;
}

.gps-slider-field--vertical .gps-slider__tick {
	flex-direction: row;
	align-items: center;
	transform: translateX(0) translateY(50%);
}

.gps-slider-field--vertical .gps-slider__tick::before {
	width: 8px;
	height: 1px;
	margin-top: 0;
	margin-left: 16px; /* Position to the right of the track center */
}

.gps-slider-field--vertical .gps-slider__tick-label {
	margin-top: 0;
	margin-left: 0.25rem;
}

/* Vertical spacing adjustments */
.gps-slider-field--vertical.gps-slider-field--show-ticks .gps-slider {
	margin-bottom: 0;
	margin-right: 20px;
}

.gps-slider-field--vertical.gps-slider-field--show-ticks.gps-slider-field--show-tick-labels .gps-slider {
	margin-right: 50px;
}

/* ==========================================================================
   Tick Labels Only (no tick marks)
   ========================================================================== */

/* Hide tick mark lines when only labels are shown */
.gps-slider-field--show-tick-labels:not(.gps-slider-field--show-ticks) .gps-slider__tick::before {
	display: none;
}

/* Horizontal: Bound first/last labels to track edges */
.gps-slider-field--show-tick-labels:not(.gps-slider-field--show-ticks) .gps-slider__tick:first-child {
	transform: translateX(0);
}

.gps-slider-field--show-tick-labels:not(.gps-slider-field--show-ticks) .gps-slider__tick:last-child {
	transform: translateX(-100%);
}

/* Horizontal: Spacing for labels-only mode */
.gps-slider-field--show-tick-labels:not(.gps-slider-field--show-ticks) .gps-slider {
	margin-bottom: 20px;
}

/* Horizontal: Position labels below track when no tick marks */
.gps-slider-field--show-tick-labels:not(.gps-slider-field--show-ticks) .gps-slider__tick-label {
	margin-top: 1.5rem;
}

/* Vertical: Center all labels on their position when no tick marks */
.gps-slider-field--vertical.gps-slider-field--show-tick-labels:not(.gps-slider-field--show-ticks) .gps-slider__tick {
	transform: translateX(0) translateY(50%);
}

/* Vertical: Spacing for labels-only mode */
.gps-slider-field--vertical.gps-slider-field--show-tick-labels:not(.gps-slider-field--show-ticks) .gps-slider {
	margin-bottom: 0;
	margin-right: 40px;
}

/* Vertical: Position labels to the right of track when no tick marks */
.gps-slider-field--vertical.gps-slider-field--show-tick-labels:not(.gps-slider-field--show-ticks) .gps-slider__tick-label {
	margin-top: 0;
	margin-left: 1.5rem;
}
