/*  slider  */
.slider
{
	position: relative;
	display: block;
	overflow: visible;
	margin-bottom: 1rem;
	width: 100%;
	text-align: center;
	/* aspect-ratio: 2; */
}
.slider a, .slider a:hover, .slider a:hover .link
{
	color: inherit;
	text-decoration: none;
}
.slider a
{
	margin: 0;
	padding: 0;
}
.slider a:focus-visible
{
	outline-offset: -2px;
}

/*  hint in cms  */
.pageroot .slider:before
{
	content: 'Slider';
	position: absolute;
	display: block;
	left: .5rem;
	top: .5rem;
	padding: .25rem;
	border-radius: .125rem;
	z-index: 1;
	font-size: .75rem;
	color: #000;
	background: rgba(255, 255, 255, .75);
}

/*  viewport  */
.slider .viewport
{
	position: absolute;
	display: block;
	overflow: hidden;
	width: 100%;
	height: 100%;
}

/*  wrapper  */
.slider .wrapper
{
	position: relative;
	display: flex;
	flex-flow: row nowrap;
	overflow: visible;
	height: 100%;
}

/*  slide  */
.slider .slide
{
	position: relative;
	display: block;
	overflow: hidden;
	flex: 0 0 auto;
	width: 100%;
	height: 100%;
	box-sizing: border-box;
	white-space: normal;
	-webkit-user-select: none; /* Safari 3.1+ */
	-moz-user-select: none; /* Firefox 2+ */
	-ms-user-select: none; /* IE 10+ */
	user-select: none; /* Standard syntax */
	background: rgba(0, 0, 0, .05);
}
.pageroot .slider .slide { display: none; }

/*  inner  */
.slider .inner
{
	position: relative;
	display: flex;
	justify-content: center;
	align-items: center;
	align-content: center;
	overflow: hidden;
	width: 100%;
	height: 100%;
}

/*  image  */
.slide .image
{
	position: absolute;
	display: flex;
	justify-content: center;
	align-items: center;
	align-content: center;
	left: 0;
	top: 0;
	width: 100%;
	height: 100%;
	max-width: none;
}
.slider .image *
{
	width: 100%;
	height: auto;
}

/*  box  */
.slider .box
{
	display: block;
	text-align: center;
	padding: 1rem;
	background: rgba(0, 0, 0, .75);
	color: #FFFFFF;
	z-index: 1;
	box-sizing: border-box;
}
.slider .box > * { display: block; }
.slider .title { font-size: 1.375em; }
.slider .title:not(:last-child) { margin-bottom: .5rem; }
.slider .text { font-size: 1em; }
.slider .link { font-size: 1em; display: inline-block; text-decoration: underline; color: inherit; }
.slider .link:not(:first-child) { margin-top: .5rem; }

/*  buttons  */
.slider button:is(.previous, .next)
{
	position: absolute;
	display: flex;
	justify-content: center;
	align-items: center;
	align-content: center;
	overflow: hidden;
	width: 2.5rem;
	height: 6rem;
	top: 50%;
	margin: -3rem 0 0 0;
	padding: 0;
	border: 0;
	border-radius: 0;
	cursor: pointer;
	z-index: 2;
	opacity: .5;
	background-color: var(--color-primary, #000);
	transition: translate .25s ease, opacity .25s ease;
}
.slider button.previous { left: 0; }
.slider button.next { right: 0; }
.slider button:is(.previous, .next)[aria-disabled=true] { background-color: var(--color-grey, #AAA); }
.slider:is(:hover, :has(:focus-visible)) button:is(.previous, .next) { opacity: .5; }
.slider button:is(.previous, .next):not([aria-disabled]):is(:hover, :focus-visible) { opacity: 1; }
.slider button:is(.previous, .next):before
{
	content: '';
	display: block;
	width: 1rem;
	height: 1rem;
	border-left: .25rem solid #FFF;
	border-top: .25rem solid #FFF;
}
.slider button.previous:before { transform: translate(22%, 0) rotate(-45deg); }
.slider button.next:before { transform: translate(-22%, 0) rotate(135deg); }



/*  pagination  */
.slider .pagination
{
	position: absolute;
	display: block;
	overflow: visible;
	width: 100%;
	bottom: 1rem;
	opacity: 1;
	text-align: center;
	transition: opacity .25s ease;
}
.slider:is(:hover, :has(:focus-visible)) .pagination
{
	opacity: 1;
	z-index: 1;
}
.slider .pagination button
{
	position: relative;
	display: inline-block;
	width: 1.25rem;
	height: 1.25rem;
	margin: 0 .375rem;
	padding: 0;
	border-radius: 50%;
	border: .25rem solid #FFF;
	background-color: #AAA;
	opacity: .5;
	cursor: pointer;
	transition: opacity .25s ease, background .25s ease;
}
.slider .pagination button:is(:hover, :focus-visible)
{
	opacity: 1;
}
.slider .pagination button.active
{
	background-color: var(--color-primary, #000);
	opacity: 1;
}


/*  options  */

/*  columns  */
.pageroot .slider .slide:nth-child(1) { display: block; }
.slider-columns-two .slide { width: 50%; }
.pageroot .slider-columns-two .slide:nth-child(2) { display: block; }
.slider-columns-three .slide { width: 33.333334%; /* round up to avoid iphone landscape bug */; }
.pageroot .slider-columns-three .slide:nth-child(2),
.pageroot .slider-columns-three .slide:nth-child(3) { display: block; }
.slider-columns-four .slide { width: 25%; }
.pageroot .slider-columns-four .slide:nth-child(2),
.pageroot .slider-columns-four .slide:nth-child(3),
.pageroot .slider-columns-four .slide:nth-child(4) { display: block; }

/*  layout  */
.slider-layout-beside:after { display: none; } /* auto height */
.slider-layout-beside .viewport, .slider-layout-beside .wrapper { position: relative; height: auto; }
.slider-layout-beside .slide { background: none; }
.slider-layout-beside .inner { flex-flow: row nowrap; justify-content: flex-start; align-items: flex-start; align-content: flex-start; }
.slider-layout-beside .image { position: relative; flex: 0 0 auto; width: 50%; height: auto; left: auto; top: auto; }
.slider-layout-beside .box { background: none; color: inherit; z-index: 0; height: auto; text-align: left; }

/*  buttons  */
.slider-buttons-auto button:is(.previous, .next) { opacity: 0; }
.slider-buttons-hide button:is(.previous, .next) { display: none; }

/*  pagination  */
.slider-pagination-auto .pagination { opacity: 0; }
.slider-pagination-hide .pagination { display: none; }


/* animation example:
.slider-layout-overlay .box { transition: transform .5s ease, opacity .5s ease; transform: scale(.97); opacity: 0; }
.slider-layout-overlay .active .box { transform: scale(1); opacity: 1; }
*/