/* TOURS SEARCH FORM CONTROLS */
a#search-top {
	position: absolute;
	top: -80px;
}

.calendar-view a#search-top {
	top: -80px;
}

form.card.tours-controls {
	flex-basis: calc(33% - var(--spacing-x-large));
	position: sticky;
	top: calc(60px + var(--spacing));
	z-index: 10;
}

form.tours-controls {
	display: flex;
	flex-flow: column wrap;
}

div.calendar-view
form.tours-controls {
	flex-shrink: 0;
}

form.tours-controls h2 {
	margin-left: calc(-1 * var(--spacing-small));
	margin-bottom: 0;
	padding-right: var(--spacing-small);
}

form.tours-controls p {
	color: var(--grey);
	margin: calc(-1 * var(--spacing-small)) 0 var(--spacing-small);
}

form.tours-controls > fieldset {
	--control-width: 1.75em;
	position: relative;
	display: flex;
	flex-flow: column nowrap;
	gap: calc(var(--spacing-small) * 1.25) var(--spacing);

	border:none;
	padding: 0 0 var(--spacing) var(--spacing-small);
}

form.tours-controls > fieldset > div.fields {
	--gap: calc(var(--spacing-small) * 1.25) var(--spacing);
	display: flex;
	flex-flow: row wrap;
	gap: var(--gap);
}

form.tours-controls > fieldset > div.fields > label {
	flex-basis: calc(50% - var(--spacing-small));
}

form.tours-controls > fieldset.duration {
	padding: 0 0 var(--spacing-large) 0;
}

form.tours-controls > fieldset label {
	--control-offset: calc(var(--control-width) + var(--spacing-small) * 1.25);
	
	cursor: pointer;

	position: relative;
	display: block;
	
	color: var(--grey-mild);
	font-size: 0.925rem;
	/* line-height: 1.5; */

	height: var(--control-width);
	padding: calc(var(--spacing-small) / 2) 0 0 var(--control-offset);
}

form.tours-controls > fieldset label input {
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	bottom: 0;

	visibility: hidden;
	z-index: 10;
}

form.tours-controls > fieldset
label > input:checked ~ span {
	color: var(--interactive);
}

form.tours-controls > fieldset
label:hover > span {
	color: var(--green-lite);
}

form.tours-controls > fieldset
label > input + span.checkmark {
	position: absolute;
	top: 0;
	left: 0;

	display:block;

	background: var(--off-white);
	border: 2px solid var(--green);
	border-radius: 3px;

	width: var(--control-width);
	
	aspect-ratio: 1;
}

form.tours-controls > fieldset
label > input:checked + span.checkmark {
	background: var(--green);
}

form.tours-controls > fieldset
label:hover > input + span.checkmark {
	background: var(--green-lite);
}

form.tours-controls > fieldset
label > input:checked + span.checkmark::before {
	content: "✔";
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	bottom: 0;

	color: white;

	font-size: 1.5em;
	text-align: center;
}

form.tours-controls > fieldset.duration h2 {
	margin-left: 0;
}

form.tours-controls > fieldset.duration input[type="range"] {
	position: absolute;
	top:-7px;
	left:0;
	right:0;

	/*pointer-events: none;*/
	background: none;
	-webkit-appearance: none;
	-moz-appearance: none;
	appearance: none;
	opacity: 0;

	z-index: 50;
}

form.tours-controls > fieldset.duration input[type="range"].min {
	right: calc(var(--spacing) - 2px);
}

form.tours-controls > fieldset.duration input[type="range"].max {
	left: calc(var(--spacing) - 2px);
}

form.tours-controls > fieldset.duration
input[type="range"]::-webkit-slider-thumb,
form.tours-controls > fieldset.duration
input[type="range"]::-moz-range-thumb {
	cursor: grab;
	pointer-events: auto;
}

form.tours-controls > fieldset.duration input[type="number"] {
	position: absolute;
	top: 15px;
	
	-moz-appearance: textfield;
	appearance: textfield;
	background: transparent;
	border: none;

	text-align: center;

	width: 25px;
	height: 25px;
	padding:0;
}

form.tours-controls > fieldset.duration input[type="number"].min {
	left: 2px;
}

form.tours-controls > fieldset.duration input[type="number"].max {
	right: -2px;
}

form.tours-controls > fieldset.duration
input[type="number"]::-webkit-outer-spin-button,
form.tours-controls > fieldset.duration
input[type="number"]::-webkit-inner-spin-button {
	-webkit-appearance: none;
	margin: 0;
}

form.tours-controls > fieldset > .range-slider {
	position: relative;
	background: var(--green-x-lite);
	height: calc(var(--spacing-small) / 1.25);
}

form.tours-controls > fieldset > .range-slider::before,
form.tours-controls > fieldset > .range-slider::after,
form.tours-controls > fieldset > .range-slider > .range-selected::before,
form.tours-controls > fieldset > .range-slider > .range-selected::after {
	display: block;

	position: absolute;
	top: -1px;

	font-size: 1rem;
	text-align: center;

	width: calc(var(--spacing) + 2px);
	height: calc(var(--spacing) + 2px);
	aspect-ratio: 1;

	background: inherit;
	border-radius: 50%;
}

form.tours-controls > fieldset > .range-slider::before,
form.tours-controls > fieldset > .range-slider::after {
	color: var(--grey-lite);
	padding: 2px 1.5px;
	line-height: 5.25;
	z-index: 10;
}

form.tours-controls > fieldset > .range-slider > .range-selected::before,
form.tours-controls > fieldset > .range-slider > .range-selected::after {
	border: 4px solid var(--interactive);
	background: white;
	line-height: 5;
	z-index: 20;
}

form.tours-controls > fieldset > .range-slider::before,
form.tours-controls > fieldset > .range-slider > .range-selected::before {
	content: attr(min);
	left: -1px;
	transform: translate(0, -25%);
}

form.tours-controls > fieldset > .range-slider::after,
form.tours-controls > fieldset > .range-slider > .range-selected::after {
	content: attr(max);
	right: -1px;
	transform: translate(0, -25%);
}

form.tours-controls > fieldset > .range-slider > .range-selected {
	pointer-events: none;
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	bottom: 0;

	background: var(--interactive);
}

form.tours-controls > fieldset.activities label {
	color: var(--grey-milder);
	height: 1.25em;
	padding: 0;
}

form.tours-controls >
fieldset.calendar {
	padding-bottom: var(--spacing-small);
	padding-left: 0;
}

form.tours-controls >
fieldset.calendar >
h2 {
	margin-left:0;
}

form.tours-controls >
fieldset.calendar >
div.calendar-control {
	display: flex;
	flex-flow: row wrap;
	gap: var(--spacing-small);
	/*row-gap: var(--spacing);*/
}

form.tours-controls >
fieldset.calendar >
div.calendar-control >
select,
form.tours-controls >
fieldset.calendar >
button.clear {
	color: #77878B;
	background: var(--off-white) !important;
	background-image: none !important;
	border: 3px solid;
	border-radius: 10px;
	padding:
		var(--spacing-small)
		var(--spacing)
		var(--spacing-small)
		var(--spacing-small);
}

form.tours-controls >
fieldset.calendar >
button.clear {
	align-self: flex-end;
	font-family: "New Spirit", sans-serif;
	font-size: 1rem !important;
	padding:
		var(--spacing-small)
		var(--spacing)
		var(--spacing-small)
		var(--spacing) !important;
	overflow: hidden;
	opacity: 1;
	margin-bottom: 0;
	transition:
		opacity 250ms ease 0s,
		margin-bottom 250ms ease 0s;
}

form.tours-controls >
fieldset.calendar >
button.clear:hover {
	color: var(--green);
	background: var(--green-x-lite) !important;
}

form.tours-controls >
fieldset.calendar >
button.clear.disabled {
	opacity: 0;
	margin-bottom: calc(-1 * var(--spacing-x-large));
}

form.tours-controls >
fieldset.calendar >
div.calendar-control >
select.month {
	flex-basis: calc(60% - var(--spacing-small) / 2);
}

form.tours-controls >
fieldset.calendar >
div.calendar-control >
select.year {
	flex-basis: calc(40% - var(--spacing-small) / 2);
}

form.tours-controls >
fieldset.calendar >
div.calendar-control >
section.card.calendar {
	border-radius: var(--spacing) !important;
	flex-basis: 100%;
	padding: var(--spacing) var(--spacing-small);
}

form.tours-controls >
fieldset.calendar >
div.calendar-control >
section.card.calendar >
header {
	display: flex;
	flex-flow: row nowrap;
	justify-content: space-around;
	/* gap: var(--spacing-small); */
}

form.tours-controls >
fieldset.calendar >
div.calendar-control >
section.card.calendar >
header h3 {
	flex-basis: calc(100% / 7);
	font-size: 1.15rem;
	text-align: center;
	margin: 0 0 var(--spacing-small);
}

form.tours-controls >
fieldset.calendar >
div.calendar-control >
section.card.calendar >
ol.dates {
	display: flex;
	flex-flow: row wrap;
	justify-content: around;
	row-gap: 0;

	padding:0;
	margin:0;
	list-style: none;
}

form.tours-controls >
fieldset.calendar >
div.calendar-control >
section.card.calendar >
ol.dates > li {
	flex-basis: calc(100% / 7);
	display: flex;
	justify-content: center;
	align-items: center;

	cursor: pointer;
	color: var(--grey-green);
	border-radius: 6px;

	text-align: center;

	margin:0;
	padding:0;

	aspect-ratio: 1;
}

form.tours-controls >
fieldset.calendar >
div.calendar-control >
section.card.calendar >
ol.dates > li.today {
	background: var(--off-white-darker);
	font-weight: bold;
	color: var(--green);
	border: 3px solid var(--green);
}

form.tours-controls >
fieldset.calendar >
div.calendar-control >
section.card.calendar >
ol.dates > li.selected {
	color: var(--green);
	background: var(--green-x-lite);
	font-weight: bold;
	border-radius: 0;
}

form.tours-controls >
fieldset.calendar >
div.calendar-control >
section.card.calendar >
ol.dates > li.selected.first {
	border-top-left-radius: 6px;
	border-bottom-left-radius: 6px;
}

form.tours-controls >
fieldset.calendar >
div.calendar-control >
section.card.calendar >
ol.dates > li.selected.last {
	border-top-right-radius: 6px;
	border-bottom-right-radius: 6px;
}

form.tours-controls >
fieldset.calendar >
div.calendar-control >
section.card.calendar >
ol.dates > li:hover {
	background-color: var(--green-x-lite);
}

form.tours-controls >
fieldset.calendar >
div.calendar-control >
section.card.calendar >
ol.dates > li.disabled {
	pointer-events: none;
	color: var(--grey-lite);
}

button.scroll-to-top {
	position: fixed;
	top: 50%;
	left: var(--spacing-small);

	background-image: url("http://localhost:1337/wp-content/uploads/sahtu/arrow-btn-next.png") !important;
	background-position: center center;
	box-shadow: 0 0 12px #33333388;

	padding: 46px 0 0 !important;
	height: 0;
	width: 46px;

	font-size: 1px !important;
	line-height: 0;

	transform: translate(calc(-100% - var(--spacing-small) - 12px), 0);
	transition: transform 250ms ease 75ms;

	/* aspect-ratio: 1; */
	overflow: hidden;
}

button.scroll-to-top.enabled {
	transform: translate(0, 0) rotate(-90deg);
}

@media screen and (max-width: 1024px) and (min-width: 640px) {
	div.calendar-view > .e-con-inner
	form.tours-controls fieldset.activities div.fields {
		flex-flow: column nowrap;
	}
}

@media screen and (max-width: 960px) and (min-width: 880px) {
	form.tours-controls > fieldset.calendar h3 {
		display: none;
	}

	form.tours-controls > fieldset.calendar >
	div.calendar-control > section.card.calendar {
		padding: var(--spacing-small) calc(var(--spacing-small) / 2);
	}
}

@media screen and (max-width: 880px) and (min-width: 640px) {
	/* FLAG: THIS WILL LIKELY JUST NEED DELETED */
	/* div.calendar-view > .e-con-inner { */
		/* flex-wrap: wrap !important; */
		/* align-content: flex-start !important; */
	/* } */

	div.calendar-view form.tours-controls {
		position: static;
	}
	
	form.tours-controls >
	fieldset.calendar {
		width: 55%;
		max-width: 420px;
		margin: 0 auto;
	}

	div.calendar-view
	form.tours-controls >
	fieldset.activities {
		flex-basis: 40%;
		padding: 0 5px 10px 30px;
		border-left: 1px solid var(--grey-lite);
	}

	div.calendar-view > .e-con-inner
	form.tours-controls {
		flex-flow: row wrap;
		justify-content: flex-start;
		align-items: stretch;
	}
	
	div.calendar-view > .e-con-inner
	form.tours-controls fieldset.activities {
		flex-grow: 1;
		flex-shrink: 0;
	}

	div.tours-view > .e-con-inner
	form.tours-controls,
	div.calendar-view > .e-con-inner
	form.tours-controls {
		flex-flow: row wrap;
		justify-content: flex-start;
		align-items: stretch;
	}
	
	div.tours-view > .e-con-inner
	form.tours-controls fieldset.seasons,
	div.calendar-view > .e-con-inner
	form.tours-controls fieldset.seasons {
		flex-basis: 30%;
		flex-shrink: 2;
	}
	
	div.tours-view > .e-con-inner
	form.tours-controls fieldset.duration,
	div.calendar-view > .e-con-inner
	form.tours-controls fieldset.duration {
		flex-basis: 33%;
		flex-grow: 2;
		flex-shrink: 1;
		border-left: 1px solid var(--grey-lite);
		border-right: 1px solid var(--grey-lite);
		padding-left: var(--spacing);
		padding-right: var(--spacing);
		/* margin-left: calc(var(--spacing-small) / 2); */
		margin-right: calc(-1 * var(--spacing-small));
	}
	
	div.tours-view > .e-con-inner
	form.tours-controls fieldset.activities,
	div.calendar-view > .e-con-inner
	form.tours-controls fieldset.activities {
		flex-grow: 1;
		flex-shrink: 0;
	}
	
	div.tours-view > .e-con-inner
	form.tours-controls fieldset.activities div.fields,
	div.calendar-view > .e-con-inner
	form.tours-controls fieldset.activities div.fields {
		flex-flow: column nowrap;
	}
}

@media screen and (max-width: 880px) {
	div.tours-view > .e-con-inner
	form.tours-controls,
	div.calendar-view > .e-con-inner
	form.tours-controls {
		box-shadow: 0 0px 16px #00000011;
		top: calc(50px + var(--spacing));
		/* position: static; */
		flex-basis: 100%;
		flex-shrink: 0;
	}

	form.tours-controls >
	fieldset.calendar > h2 {
		display:none;
	}

	form.tours-controls >
	fieldset.calendar
	ol.dates > li {
		font-size: max(14px, 2vw);
	}
}

@media screen and (max-width: 640px) {
	div.tours-view > .e-con-inner
	form.tours-controls,
	div.calendar-view > .e-con-inner
	form.tours-controls {
		position: static;
	}

	form.tours-controls >
	fieldset.calendar
	ol.dates > li {
		font-size: max(13px, 3vw);
	}
}
